## CH32F/V20x\_V30x\_V31x Reference Manual

V2.4

https://wch-ic.com

## **Overview**

CH32F20x is a general-purpose microcontroller based on the ARM®Cortex<sup>TM</sup>-M3 core, and is compatible with most ARM tools and software. It provides rich communication interfaces and control units, which are suitable for most embedded fields such as control, connection, synthesis, etc.

CH32V20x, CH32V30x and CH32V31x series are industrial-grade general-purpose microcontrollers based on 32-bit RISC-V instruction set and architecture. Different core models are matched according to the differences in product performance and resources. CH32V203 uses QingKe V4B core to support hardware interrupt stack to improve interrupt response efficiency; CH32V208 uses QingKe V4C core to further accelerate the speed of hardware division and increases memory protection; CH32V303/305/307/317 uses QingKe V4F core to further support hardware floating-point operations. This series of products are loaded with a wealth of peripheral interfaces and functional modules. Its internal organizational structure meets the low-cost and low-power embedded application scenarios.

For users' application development, this manual provides detailed use information of CH32F20x series, CH32V20x series, CH32V30x series and CH32V31x series products. It is suitable for different memory capacity, functional resources and packaged products in the series. If there are any differences, special instructions will be made in the corresponding functional chapter.

Note: (1) CH32F20x includes: CH32F203, CH32F205, CH32F207, CH32F208;

(2) CH32V20x includes:CH32V203, CH32V208;

(3) CH32V30x includes: CH32V303, CH32V305, CH32V307;

(4) CH32V31x includes: CH32V317.

Please refer to the following datasheet for the device characteristics of this series.

CH32F20x\_D6: *CH32F203DS0* 

CH32F20x\_D8, CH32F20x\_D8C:*CH32F207DS0*.

CH32F20x D8W: CH32F208DS0.

CH32V20x D6, CH32V20x D8: CH32V203DS0.

CH32V20x\_D8W:CH32V208DS0.

CH32V30x D8, CH32V30x D8C, CH32V31x D8C: CH32V307DS0.

For information about the ARM® Cortex<sup>TM</sup>-M3 core, please refer to the ARM® Cortex®-M3 Processor Technical Reference Manual Revision <math>r2p1, which can be downloaded from the ARM website.

For information about the RISC-V core, please refer to *QingKeV4 Processor Manual*.

CH32F20x serial products overview

| C1152F20x seriai products overview |              |                |                |              |                   |            |  |  |  |  |
|------------------------------------|--------------|----------------|----------------|--------------|-------------------|------------|--|--|--|--|
|                                    | dium-density | High-density s | general (F203) | Connectivity | Interconnectivity | Wireless   |  |  |  |  |
| general                            |              |                |                | (F205)       | (F207)            | (F208)     |  |  |  |  |
| 32K Flash                          | 64K Flash    | 128K Flash     | 256K Flash     | 128K Flash   | 256K Flash        | 128K Flash |  |  |  |  |
| 10K SRAM                           | 20K SRAM     | 32K SRAM       | 64K SRAM       | 32K SRAM     | 64K SRAM          | 64K SRAM   |  |  |  |  |
|                                    |              |                |                |              | 2*ADC(TKey)       |            |  |  |  |  |
|                                    |              |                |                |              | 2*DAC             |            |  |  |  |  |
|                                    |              |                | 2*ADC(TKey)    | 2*ADC(TKey)  | 4*ADTM            | ADC(TKey)  |  |  |  |  |
|                                    |              |                | 2*DAC          | 2*DAC        | 4*GPTM            | ADTM       |  |  |  |  |
| 2*ADC(TKey)                        | 2*ADC(TKey)  | 2*ADC(TKey)    | 4*ADTM         | 4*ADTM       | 2*BCTM            | 3*GPTM     |  |  |  |  |
| ADTM                               | ADTM         | 2*DAC          | 4*GPTM         | 4*GPTM       | 8*U(S)ART         | GPTM(32)   |  |  |  |  |
| 2*GPTM                             | 3*GPTM       | ADTM           | 2*BCTM         | 2*BCTM       | 3*SPI(2*I2S)      | 4*U(S)ART  |  |  |  |  |
| 2*USART                            | 4*U(S)ART    | 3*GPTM         | 8*U(S)ART      | 5*U(S)ART    | 2*I2C             | 2*SPI      |  |  |  |  |
| SPI                                | 2*SPI        | 3*USART        | 3*SPI(2*I2S)   | 3*SPI(2*I2S) | OTG_FS            | 2*I2C      |  |  |  |  |
| I2C                                | 2*I2C        | 2*SPI          | 2*I2C          | 2*I2C        | USBHS(+PHY)       | USBD       |  |  |  |  |
| USBD                               | USBD         | 2*I2C          | USBD           | OTG_FS       | 2*CAN             | USBFS      |  |  |  |  |
| USBFS                              | USBFS        | USBD           | CAN            | USBHS(+PHY)  | RTC               | CAN        |  |  |  |  |
| CAN                                | CAN          | CAN            | RTC            | 2*CAN        | 2*WDG             | RTC        |  |  |  |  |
| RTC                                | RTC          | RTC            | 2*WDG          | RTC          | 4*OPA             | 2*WDG      |  |  |  |  |
| 2*WDG                              | 2*WDG        | 2*WDG          | 4*OPA          | 2*WDG        | RNG               | 2*OPA      |  |  |  |  |
| 2*OPA                              | 2*OPA        | 4*OPA          | RNG            | 4*OPA        | SDIO              | ETH-10M    |  |  |  |  |
|                                    |              |                | SDIO           | RNG          | FSMC              | (+PHY)     |  |  |  |  |
|                                    |              |                | FSMC           | SDIO         | DVP               | BLE5.3     |  |  |  |  |
|                                    |              |                |                |              | ETH-1000MAC       |            |  |  |  |  |
|                                    |              |                |                |              | 10M PHY           |            |  |  |  |  |
|                                    |              |                |                |              |                   |            |  |  |  |  |

Note: Please confirm the product package when selecting, as the number of some peripherals and function of the same series product may be limited by the package.

CH32V20x, CH32V30x and CH32V31x serial products overview

| Low- and me                                                            | edium-density<br>(V203)                                                      | High-density §                                                                                               | •                                                                                                           | Connectivity (V305)                                                                                                   | Interconnectivit y (V307)                                                                                                                                | Interconnectivit y (V317)                                                                                                                    | Wireless<br>(V208)                                                                                         |
|------------------------------------------------------------------------|------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|
|                                                                        | V4B core                                                                     | 12077 FL 1                                                                                                   |                                                                                                             | QingKe V4F core                                                                                                       | ſ                                                                                                                                                        | 25 (W. F.L. 1                                                                                                                                | QingKe<br>V4C core                                                                                         |
| 32K Flash                                                              | 64K Flash                                                                    | 128K Flash                                                                                                   | 256K Flash                                                                                                  | 128K Flash                                                                                                            | 256K Flash                                                                                                                                               | 256K Flash                                                                                                                                   | 128K Flash                                                                                                 |
| 10K SRAM                                                               | 20K SRAM                                                                     | 32K SRAM                                                                                                     | 64K SRAM                                                                                                    | 32K SRAM                                                                                                              | 64K SRAM                                                                                                                                                 | 64K SRAM                                                                                                                                     | 64K SRAM                                                                                                   |
| 2*ADC(TKey) ADTM 3*GPTM 2*USART SPI I2C USBD USBFS CAN RTC 2*WDG 2*OPA | 2*ADC(TKey) ADTM 3*GPTM 4*U(S)ART 2*SPI 2*I2C USBD USBFS CAN RTC 2*WDG 2*OPA | 2*ADC(TKey)<br>2*DAC<br>ADTM<br>3*GPTM<br>3*USART<br>2*SPI<br>2*I2C<br>USBFS<br>CAN<br>RTC<br>2*WDG<br>4*OPA | 2*ADC(TKey) 2*DAC 4*ADTM 4*GPTM 2*BCTM 8*U(S)ART 3*SPI(2*I2S) 2*I2C USBFS CAN RTC 2*WDG 4*OPA RNG SDIO FSMC | 2*ADC(TKey) 2*DAC 4*ADTM 4*GPTM 2*BCTM 5*U(S)ART 3*SPI(2*I2S) 2*I2C OTG_FS USBHS(+PHY) 2*CAN RTC 2*WDG 4*OPA RNG SDIO | 2*ADC(TKey) 2*DAC 4*ADTM 4*GPTM 2*BCTM 8*U(S)ART 3*SPI(2*I2S) 2*I2C OTG_FS USBHS(+PHY) 2*CAN RTC 2*WDG 4*OPA RNG SDIO FSMC DVP ETH-1000M MAC ETH-10M PHY | 2*ADC(TKey) 2*DAC 4*ADTM 4*GPTM 2*BCTM 8*U(S)ART 3*SPI(2*I2S) 2*I2C OTG_FS USBHS(+PHY ) 2*CAN RTC 2*WDG 4*OPA RNG SDIO DVP ETH- 10M/100M PHY | ADC(TKey) ADTM 3*GPTM GPTM(32) 4*U(S)ART 2*SPI 2*I2C USBD USBFS CAN RTC 2*WDG 2*OPA ETH- 10M(+PHY ) BLE5.3 |

Note: Please confirm the product package when selecting, as the number of some peripherals and function of the same series product may be limited by the package.

RISC-V cores version comparison overview

| Features   | Instruction set | Hardware stack | Interrupt<br>nested | Fast<br>interrupt<br>channel | Integer<br>division<br>cycle | Vector table mode | Expand instruction | Memory<br>Protection |
|------------|-----------------|----------------|---------------------|------------------------------|------------------------------|-------------------|--------------------|----------------------|
| QingKe V4B | IMAC            | 2              | 2                   | 4                            | 9                            | Address/Command   | Supported          | None                 |
| QingKe V4C | IMAC            | 2              | 2                   | 4                            | 5                            | Address/Command   | Supported          | Standard             |
| QingKe V4F | IMAFC           | 3              | 8                   | 4                            | 5                            | Address/Command   | Supported          | Standard             |

Abbreviated description of the bit attribute in the register:

| Register bit properties | Property Description                                       |
|-------------------------|------------------------------------------------------------|
| RF                      | Read-only property, reads a fixed value.                   |
| RO                      | Read-only property, changed by hardware.                   |
| RZ                      | Read-only property, auto bit clear 0 after read operation. |
| WO                      | Write only property (not readable, read value uncertain)   |

| WA   | Write only property, writable in safe mode.                 |
|------|-------------------------------------------------------------|
| WZ   | Write only property, auto bit clear 0 after write operation |
| RW   | Readable and writable.                                      |
| RWA  | Read only property, writable in safe mode.                  |
| RW1  | Readable, write 1 is valid, write 0 is invalid.             |
| RW0  | Readable, write 0 is valid, write 1 is invalid.             |
| RW1T | Readable, write 0 invalid, write 1 flipped.                 |
| RW1Z | Readable, write 1 to clear this bit, write 0 is invalid.    |
| SC   | Auto cleared.                                               |

## Classification description of CH32 MCUs:

| Classification abbreviation | Size of FLASH  | Product type                      |
|-----------------------------|----------------|-----------------------------------|
| D6                          | 32KB or 64KB   | Low-and-medium-density general    |
| D8                          | 128KB or 256KB | High-density general              |
| D8C                         | 128KB or 256KB | Connectivity or interconnectivity |
| D8W                         | 128KB or 256KB | Wireless                          |

Note: D (Density), 6 (2^6), 8 (2^8) Specific classification abbreviations:

CH32F20x\_D6: CH32F203K8, CH32F203C6 and CH32F203C8.

CH32F20x D8: CH32F203CB, CH32F203RC, CH32F203VC and CH32F203RB.

CH32F20x\_D8C: CH32F205RB and CH32F207VC. CH32F20x\_D8W: CH32F208RB and CH32F208WB.

 $CH32V20x\_D6: CH32V203F6, CH32V203G6, CH32V203F8, CH32V203G8, CH32V203K8, CH32V203C6 \ and CH32V204F6, CH32V203F8, CH32V203G8, CH32V203K8, CH32V203C6 \ and CH32V204F6, CH32V203F8, CH32V203F8, CH32V203K8, CH32V203C6 \ and CH32V204F6, CH32V203F8, CH32V203F8, CH32V203F8, CH32V203K8, CH32V203C6 \ and CH32V204F6, CH32V203F8, CH32V205F8, CH32$ 

CH32V203C8.

CH32V20x D8: CH32V203RB.

CH32V20x\_D8W: CH32V208GB, CH32V208CB, CH32V208RB and CH32V208WB. CH32V30x\_D8: CH32V303CB, CH32V303RB, CH32V303RC and CH32V303VC.

CH32V30x\_D8C: CH32V305FB, CH32V305RB, CH32V305GB, CH32V307RC, CH32V307WC and

CH32V307VC.

CH32V31x\_D8C: CH32V317SC, CH32V317WC, CH32V317VC.

## **Chapter 1 Memory and Bus Architecture**

### 1.1 Bus Architecture

The CH32F20x is a microcontroller designed based on the ARM®Cortex<sup>TM</sup>-M3 core. The core, arbitration unit, DMA module, and SRAM memory, etc. in the framework interact through multiple sets of buses. The CH32V20x, CH32V30x and CH32V31x are general microcontrollers designed based on the RISC-V instruction set. The core, arbitration unit, DMA module and SRAM memory, etc. of the architecture interact through multiple sets of buses.



Figure 1-1 CH32F203 (Small-and-medium capacity general-purpose) system architecture

V2. 4 1 WCH<sup>\*</sup>

V<sub>DD</sub>: 2.4V~3.6V V<sub>SS</sub> FLASH ARM Cortex-M3 I-code Bus POR | PDR | PVD **CTRL** TRACESWO TPIU V<sub>IO</sub>: 2.4V~3.6V V<sub>SS</sub> NVIC SW CLK SW DIO @VIO33 SWD Flash GPIO power ŽΩ Memory DMA1 7 Channels  $V_{DDA}: V_{IO} V_{SSA}$ @VDDA DMA2 11 Channels System Bus ADD[23:16]
DAT[15:0]
CLK
NOE
NWE
NBL[1:0]
NWAIT
NADV
NE1/NCE2 МІ **FSMC** TXD[1:0],TXEN RXD[1:0],REFCLK,CRSDV MDC,MDIO PPS\_OUT Μ RMI SRAM → SYSCLK → HBCLK → PB1CLK Reset & TXD[3:0],GTXC,TXEN RXD[3:0],RXC,RXCTL MDC,MDIO 125IN\_ ETH MAC RGMI MUX & DIV 10/100/1000 → PB2CLK ſί RXP, RXN TXP, TXN HSI-RC 10M PHY PLL OSC IN HSE → osc\_out DAT[11:0] PCLK VSYNC,HSYNC PLL2 DVP RCCPLL3 ᇤ LSI-RC VBUS OTG\_FS < F<sub>max</sub> = 144MHz TRNG OSC32\_IN LSE → OSC32\_OUT **USBHS** HS\_DP HS\_DM\_ +PHY @VBAT FS\_DP FS\_DM **USBFS** HB to PB1 RTC/BKP Bridge SDIO OPAx\_CHP OPAx\_CHN OPAx\_OUT (x=1,2,3,4) OPA1-4 TIM3 TIM4 HB to PB2 TIM5 Bridge USART2 RX, TX, CTS, RTS, CK USART3 EXTIT/WKUP UART4 PA0 ~ PA15 GPIOA GPIOB UART5 PB0 ~ PB15 UART6 PC0 ~ PC15 **GPIOC** PD0 ~ PD15 GPIOD UART7 RX. TX F<sub>max</sub> = PE0 ~ PE15 **GPIOE** UART8 ➤ MOSI/SD, MISO, SCK/CK, MCK, NSS/WS MOSI,MISO,SCK, NSS SPI2/I2S2 144MHz RX, TX, CTS, RTS, CK ➤ MOSI/SD, MISO, SCK/CK, MCK, NSS/WS IWDG SPI3/12S3 4 channels I. Channels ETR, BIKN TIM1 I2C1 ➤ SCL, SDA, SMBA WWDG 4 channels 3 compl. Channels ETR, BIKN I2C2 ➤ SCL, SDA, SMBA TIM8 bxCAN1 4 channels I. Channels ETR, BIKN CAN1\_TX,CAN1\_RX TIM6 TIM9 SRAM 512B 4 channels 3 compl. Channels ETR, BIKN TIM7 TIM10 bxCAN2 CAN2 TX,CAN2 RX Tkey AIN0 ~ AIN15 USBD USBDM,USBDP ADC1  $(VSSA)V_{REF}$  -  $(2.4V^{\sim}VDDA)V_{REF}$ + ADC2

Figure 1-2 CH32F20x (Connection/interconnection/high capacity general-purpose) system architecture

DAC1

DAC2

➤ DAC OUT1

→ DAC\_OUT2

Temp Sensor

V<sub>DD</sub>: 2.4V~3.6V V<sub>SS</sub> @VDD FLASH ARM Cortex-M3 I-code Bus POR | PDR | PVD CTRL TRACESWO TPIU V<sub>IO</sub>: 2.4V~3.6V V<sub>SS</sub> SWCLK SWDIO SWD @VIO33 Flash GPIO power ΜΩ Memory V<sub>DDA</sub>: V<sub>IO</sub> V<sub>SSA</sub> DMA 8 Channels @VDDA System Bus MUX SRAM → SYSCLK → HBCLK → PB1CLK → PB2CLK Reset & MUX & DIV 10M PHY HSI-RC PLL \*) ¬ъъ • BLE 5.3  $\mathsf{OSC}\_\mathsf{IN}$ HSE → osc\_out RCCUSBFS LSI-RC F<sub>max</sub> = 144MHz RTC\_CLK ←
IWDG\_CLK ← OSC32\_IN → OSC32\_OUT @VBAT OPA1-2 HB to PB1 RTC/BKP Bridge TIM3 4 channels, ETR HB to PB2 Bridge TIM4 → 4 channels, ETR TIM5 → 4 channels EXTIT/WKUP PA0 ~ PA15 ← GPIOA → RX, TX, CTS, RTS, CK USART2 PB0 ~ PB15 ◀ GPIOB → RX, TX, CTS, RTS, CK USART3 PB1: PC0 ~ PC15 ◀ **GPIOC** PB2: F<sub>max</sub> = 144MHz UART4 RX, TX PD2 ◀ GPIOD SPI2 → MOSI, MISO, SCK, NSS IWDG MOSI,MISO,SCK, NSS ◀ SPI1 I2C1 SCL, SDA, SMBA WWDG I2C2 RX, TX, CTS, RTS, CK USART1 bxCAN1 CAN1\_TX,CAN1\_RX 4 channels 3 complementary Channels ETR, BIKN TIM1 Tkey AIN0 ~ AIN15 (VSSA)V<sub>REF</sub> -USBD → USBDM,USBDP ADC (2.4V~VDDA)V<sub>REF</sub>+

Figure 1-3 CH32F208 (Wireless) system architecture

V<sub>DD</sub>: 2.4V~3.6V @VDD FLASH RISC-V (V4B) I-code Bus POR | PDR | PVD CTRL PFIC RV32 V<sub>10</sub>: 2.4V~3.6V SW CLK SW DIO @VIO33 IMAC SDI D-code Bus Flash GPIO power MUX Memory V<sub>DDA</sub>: V<sub>IO</sub> @VDDA DMA 8Channels System Bus → SYSCLK → HBCLK Reset & **SRAM** → PB1CLK → PB2CLK MUX & DIV USBFS HSI-RC PLL - OSC\_IN HSE → osc\_out RCC RTC\_CLK ←
IWDG\_CLK ← OPAx\_CHP OPAx\_CHN OPAx\_OUT (x=1,2) OSC32\_IN OPA1-2 144MHz ➤ OSC32\_OUT @VBAT HB to PB1 Bridge RTC/BKP HB to PB2 TAMPER-RTC Bridge TIM2 4 channels, ETR TIM3 EXTIT/WKUP TIM4 PB1: PA0 ~ PA15 **GPIOA** TIM5 4 channels(CH32V203RBx PB0 ~ PB15 GPIOB Fmax USART2 RX, TX, CTS, RTS, CK PC0 ~ PC15 ◆ GPIOC PB2: = 144MHz RX, TX, CTS, RTS, CK USART3 GPIOD PD0 ~ PD2 ◀ UART4 MOSI,MISO,SCK, NSS ◀ SPI1 SPI2 ► MOSI, MISO, SCK , NSS USART1 144MHz 4 channels 3 complementary Channels ETR, BIK<u>N</u> IWDG TIM1 I2C1 ➤ SCL, SDA, SMBA 12C2 WWDG ► SCL, SDA, SMBA Tkey AIN0 ~ AIN15 ADC1 bxCAN1 → CAN1\_TX,CAN1\_RX (VSSA)V<sub>REF</sub> -ADC2 (2.4V~VDDA)V<sub>REF</sub>+ USBD USBDM,USBDP Temp Sensor

Figure 1-4 CH32V203 (Small-and-medium capacity general-purpose) system architecture

V<sub>DD</sub>: 2.4V~3.6V V<sub>SS</sub> FLASH RISC-V (V4C) I-code Bus POR | PDR | PVD CTRL PFIC V<sub>10</sub>: 2.4V~3.6V V<sub>SS</sub> SWCLK -SDI IMAC @VIO33 Flash GPIO power ΜÜ Memory V<sub>DDA</sub>: V<sub>IO</sub> DMA 8 Channels @VDDA System Bus Μ SRAM → SYSCLK → HBCLK Reset & → PB1CLK → PB2CLK MUX & DIV ► 10M PHY < HSI-RC PLL BLE 5.3 OSC\_IN HSE → osc\_out RCC В USBFS LSI-RC F<sub>max</sub> = 144MHz OSC32\_IN LSE → OSC32\_OUT @VBAT OPA1-2 HB to PB1 RTC/BKP → TAMPER-RTC Bridge TIM2 TIM3 → 4 channels, ETR HB to PB2 Bridge TIM4 → 4 channels, ETR TIM5 → 4 channels EXTIT/WKUP PA0 ~ PA15 ← GPIOA ➤ RX, TX, CTS, RTS, CK USART2 PB0 ~ PB15 GPIOB → RX, TX, CTS, RTS, CK USART3 PB1: PC0 ~ PC15 ◆ **GPIOC** PB2: F<sub>max</sub> = UART4 RX, TX PD2 ◀ GPIOD ► MOSI/SD, MISO, SCK/CK, MCK, NSS/WS SP12 144MHz 144MHz IWDG SPI1 MOSI,MISO,SCK, NSS ◀ I2C1 ➤ SCL, SDA, SMBA WWDG I2C2 RX, TX, CTS, RTS, CK USART1 bxCAN1 CAN1\_TX,CAN1\_RX 4 channels 3 complementary Channels ETR, BIKN TIM1 Tkey AINO ~ AIN15 (VSSA)V<sub>REF</sub> -USBD ➤ USBDM,USBDP ADC (2.4V~VDDA)V<sub>REF</sub>+

Figure 1-5 CH32V208 (Wireless) system architecture

V<sub>DD</sub>: 2.4V~3.6V V<sub>SS</sub> FLASH RISC-V (V4F) I-code Bus POR | PDR | PVD **CTRL** PFIC V<sub>IO</sub>: 2.4V~3.6V V<sub>SS</sub> SW CLK SW DIO IMAFC @VIO33 SDI Flash GPIO power ŽΩ Memory DMA1 7 Channels  $V_{DDA}: V_{IO} V_{SSA}$ @VDDA DMA2 11 Channels System Bus ADD[23:16]
DAT[15:0]
CLK
NOE
NWE
NBL[1:0]
NWAIT
NADV
NE1/NCE2 МІ **FSMC** TXD[1:0],TXEN RXD[1:0],REFCLK,CRSDV MDC,MDIO PPS\_OUT Μ RMI SRAM → SYSCLK → HBCLK → PB1CLK Reset & ETH MAC RGMI MUX & DIV 10/100/1000 → PB2CLK ſί HSI-RC 10M PHY PLL OSC IN HSE → osc\_out PLL2 DAT[11:0] PCLK VSYNC,HSYNC RCC PLL3 DVP ᇤ LSI-RC F<sub>max</sub> = 144MHz USBHS TRNG OSC32\_IN HS\_DP HS\_DM LSE +PHY → OSC32\_OUT FS\_DP,FS\_DM VBUS,ID DP, DM-USBFS/ @VBAT OTG\_FS HB to PB1 RTC/BKP Bridge SDIO OPAx\_CHP OPAx\_CHN OPAx\_OUT (x=1,2,3,4) OPA1-4 TIM3 TIM4 HB to PB2 TIM5 Bridge USART2 RX, TX, CTS, RTS, CK USART3 EXTIT/WKUP UART4 PA0 ~ PA15 GPIOA GPIOB UART5 PB0 ~ PB15 UART6 PB1: PC0 ~ PC15 **GPIOC** PD0 ~ PD15 GPIOD PB2: UART7 RX. TX F<sub>max</sub> = PE0 ~ PE15 **GPIOE** UART8 MOSI/SD, MISO, SCK/CK, MCK, NSS/WS MOSI,MISO,SCK, NSS SPI1 SPI2/I2S2 144MHz RX, TX, CTS, RTS, CK ➤ MOSI/SD, MISO, SCK/CK, MCK, NSS/WS IWDG SPI3/12S3 4 channels ry Channels ETR, BIKN TIM1 I2C1 ➤ SCL, SDA, SMBA WWDG 4 channels 3 Complementary Channels ETR, BIKN I2C2 ➤ SCL, SDA, SMBA TIM8 bxCAN1 4 channels lementary Channels ETR, BIKN CAN1\_TX,CAN1\_RX TIM6 TIM9 SRAM 512B 4 channels 3 Complementary Channels ETR, BIKN TIM7 TIM10 bxCAN2 ➤ CAN2 TX,CAN2 RX Tkey AIN0 ~ AIN15 ADC1  $(VSSA)V_{REF}$  -  $(2.4V^{\sim}VDDA)V_{REF}$ + DAC1 DAC\_OUT1 ADC2 DAC2 ➤ DAC\_OUT2 Temp Sensor

Figure 1-6 CH32V30x (Connection/interconnection/high capacity general-purpose) system architecture



Figure 1-7 CH32V317 (Interconnection) system architecture

The system is equipped with: General DMA controller to reduce CPU burden and improve efficiency; clock tree hierarchical management to reduce the total operating power consumption of peripherals, while being also provided with actions such as data protection mechanism and clock security system protection mechanism to increase system stability.

• The command bus (I-Code) connects the core and the FLASH command interface, and the prefetch is completed on this bus.

- The data bus (D-Code) connects the core and the FLASH data interface for constant load and debug.
- The system bus connects the core and the bus matrix for coordinating the access of the core, DMA, SRAM and peripherals.
- The DMA bus connects the DMA HB master control interface and the bus matrix, and the bus access objects include FLASH data, SRAM and peripherals.
- The bus matrix is used for the access coordination among the system bus, data bus, DMA bus, SRAM and HB/APB bridge.
- The HB/PB bridge provides a synchronous connection for the HB bus and 2 PB buses. Different
  peripherals are connected to different PB buses, and different bus clocks can be configured according to
  actual needs to optimize performance.

## 1.2 Memory Image

The CH32F20x, CH32V20x, CH32V30x and CH32V31x all have program memory, data memory, core register, peripheral register, etc., all of which are addressed in a 4GB linear space.

The system memory stores data in little-endian format, i.e., the low bytes are stored in the low address, and the high bytes are stored in the high address.

Figure 1-8 CH32F203 (Small-and-medium capacity general-purpose) memory image



V2. 4 9

Figure 1-9 CH32F20x (Connected/interconnected/high-capacity general-purpose) memory image

|              |                               |              |                              | / 0vE00E 040             | Reserved                                          |
|--------------|-------------------------------|--------------|------------------------------|--------------------------|---------------------------------------------------|
|              |                               |              |                              | 0x5005 040               | I DVP                                             |
|              |                               |              |                              | 0x5005 000               | Reserved                                          |
|              |                               |              |                              | 0x5004 000               | USBFS/OTG FS                                      |
|              |                               |              |                              | 0x5000 000               | Reserved                                          |
|              |                               |              |                              | 0x4002 A00               | Ethernet                                          |
|              |                               |              |                              | 0x4002 800               | Reserved                                          |
|              |                               |              |                              | 0x4002 400               | )                                                 |
|              |                               |              |                              | 0x4002 3C0               | IRNG                                              |
|              |                               |              |                              | 0x4002 380               | USBHS                                             |
|              |                               |              |                              | 0x4002 340               | ) <del>                                    </del> |
|              |                               |              |                              | 0x4002 300               | CRC                                               |
|              |                               |              |                              | 0x4002 240               | Reserved                                          |
|              |                               |              |                              | 0x4002 200               | Flash Interface                                   |
|              |                               |              |                              | 0x4002 140               | Reserved                                          |
|              |                               |              |                              | 0x4002 100               | RCC                                               |
|              |                               |              |                              | 0x4002 080               | Reserved                                          |
|              |                               |              |                              | 0x4002 040               | DMA2                                              |
|              |                               |              |                              | 0x4002 000               | I DMA1                                            |
|              |                               |              |                              | 0x4001 840               | Reserved                                          |
|              |                               |              |                              | 0x4001 800               | SDIO                                              |
|              |                               |              |                              | 0x4001 540               | Reserved                                          |
|              |                               |              |                              | 0x4001 500               | I TIM10                                           |
|              |                               |              |                              | 0x4001 4C0               | I TIM9                                            |
|              |                               |              |                              | 0x4001 4C0<br>0x4001 3C0 | Reserved                                          |
|              |                               |              |                              |                          | USART1                                            |
|              |                               |              |                              | 0x4001 380               | I TIM8                                            |
|              |                               |              |                              | 0x4001 340               | I SPI1                                            |
|              |                               |              |                              | 0x4001 300               | I TIM1                                            |
|              |                               |              |                              | 0x4001 2C0               | ADC2/TouchKev                                     |
|              |                               |              |                              | 0x4001 280               | ADC1/TouchKev                                     |
|              |                               |              |                              | 0x4001 240               | l Reserved                                        |
|              |                               |              |                              | 0x4001 1C0               | l Port E                                          |
|              |                               |              |                              | 0x4001 180               | l Port D                                          |
|              |                               |              |                              | 0x4001 140               | Port C                                            |
|              |                               |              |                              | 0x4001 100               | Port B                                            |
|              |                               | 0xFFFF FFFFF |                              | 0x4001 0C0               | I Port A                                          |
|              |                               | UXFFFF FFFF  | Reserved                     | 0x4001 080               | I EXTI                                            |
|              |                               | _            | eserveu                      | 0x4001 040               | AFIO                                              |
|              |                               | 0xE010 0000  | Core Private                 | 0x4001 000               | Reserved                                          |
|              |                               | 0xE000 0000  | Peripherals                  | 0x4000 780               | DAC                                               |
|              |                               |              |                              | 0x4000 740               | l PWR                                             |
|              |                               |              | Reserved                     | 0x4000 700               | I BKP                                             |
|              |                               |              |                              | 0x4000 6C0               | bxCAN2                                            |
|              |                               | 0xC000 0000  |                              | 0x4000 680               | l bxCAN1                                          |
|              |                               |              |                              | 0x4000 640               | share 512B SRAM                                   |
| 0x1FFF FFFF  |                               | 1\           | Reserved                     | 0x4000 600               | Reserved                                          |
| 0,4555 5000  | Reserved                      | 0xA000 1000  |                              | 0x4000 5C0               | 12C2                                              |
| 0x1FFF F880  | Option Bytes                  | 0xA000 0000  | FSMC register                | 0x4000 580               | 12C1                                              |
| 0x1FFF F800  | Vendor Bytes                  | 1 \          | Donomus -l                   | 0x4000 540               | UART5                                             |
| 0x1FFF F700  | ·                             | 1 \          | Reserved                     | 0x4000 500               | UART4                                             |
| 0x1FFF F000  | Reserved                      | 0x8000 0000  | FORMS have a server from the | 0x4000 4C0               | USART3                                            |
| 2/11/1000    |                               | 0x7000 0000  | FSMC bank2 NAND(NAND1)       | 0x4000 480               | USART2                                            |
|              | System FLASH                  |              |                              | 0x4000 440               | Reserved                                          |
|              | (BOOT_28KB)                   |              | Reserved                     | 0x4000 400               | SPI3/I2S3                                         |
| 0x1FFF 8000  |                               | 0x6400 0000  |                              | 0x4000 3C0               | SPI2/I2S2                                         |
| JAZ. 11 3000 |                               | 0x6000 0000  | FSMC bank1 NOR/PSRAM 1       | 0x4000 380               | Reserved                                          |
|              |                               | \            |                              | 0x4000 340               | IWDG                                              |
|              | Reserved                      | 1 \          | Reserved                     | 0x4000 300i              | WWDG                                              |
|              |                               | 1 \          |                              | 0x4000 2C0               | RTC                                               |
|              |                               | 0x4000 0000  | Peripherals                  | 0x4000 280               | Reserved                                          |
|              | Codo FLACU                    | 0x4000 0000  |                              | 0x4000 240               | UART8                                             |
|              | Code FLASH<br>480KB max       |              | Reserved                     | 0x4000 200               | UART7                                             |
|              | Includes 0 wait and non-0     | 0x2002 0000  |                              | 0x4000 1C0               | UART6                                             |
|              | waiting areas                 |              | SRAM (128KBmax)              | 0x4000 180               | TIM7                                              |
| 0x0800 0000  |                               | 0x2000 0000  |                              | 0x4000 140               | TIM6                                              |
| 0x0800 0000  | Aliased to Flash or           |              |                              | 0x4000 100               | ) —                                               |
| 0x0800 0000  | CUCTOM MOMORY                 | 1            | FLASH                        | 0x4000 0C0               | TIM5                                              |
| 0x0800 0000  | system memory<br>depending on |              |                              | \                        |                                                   |
|              | depending on<br>BOOT pins     |              |                              | 0x4000 080               | TIM4                                              |
| 0x0000 0000  | depending on                  | 0x0000 0000  | G linear address space       | \ \                      | TIM3                                              |

Figure 1-10 CH32F208 (Wireless) memory image



V2. 4 11 **WCH** 

Figure 1-11 CH32V203 (Small-and-medium capacity general-purpose) memory image



V2. 4 12 **W1H** 

Figure 1-12 CH32V208 (Wireless) memory image



Figure 1-13 CH32V3x (Connected/interconnected/high-capacity general-purpose) and CH32V31x (Interconnected) memory image



V2. 4 15 **W1H** 

#### 1.2.1 Bit Segment Access

Bit manipulation means the operation of reading/writing a bit independently. The CH32F20x provides bit operation read and write to the contents of peripheral register and SRAM area through the mapping processing method. Specific methods:

- 1) Read the 32-bit data in the mapped address area, the read value is 0 or non-zero, and the target bit value is 0 or 1;
- 2) Write the 32-bit data in the mapped address area, write 0 or 1, and modify the target bit value to 0 or 1.

Address mapping:

Target bit field: Base address (BEaddr) + offset address (Ofaddr) + bit number (BitN)

Mapping address: Mapaddr

 $Mapaddr = BEaddr + 0x2000000 + (Ofaddr \times 32) + (BitN \times 4)$ 

Example 1: Operate the bit3 target bit field in the 0x20000100 address byte of the SRAM area:

Mapaddr= 0x20000000+0x2000000+(0x100\*32)+(3\*4)=0x2200200C

Read the 4-byte data content of the 0x2200200C address to know whether bit3 in the 0x20000100 address byte is 0 or 1; write 0 or 1 to the 0x2200200C address, you can modify the bit3 in the 0x20000100 address byte to 0 or 1.

Example 2: Operate bit24 in the 0x40021000 address of the peripheral area:

Mapaddr = 0x40000000+0x2000000+(0x21000\*32)+(24\*4)=0x42420060

Read the 4-byte data content of the 0x22420060 address to confirm whether the bit24 in the 0x40021000 peripheral address is 0 or 1; write 0 or 1 to the 0x22420060 address; you can modify the bit24 in the 0x40021000 peripheral address to 0 or 1.

Note: The CH32V20x, CH32V30x and CH32V31x do not support bit segment mapping access mode.

#### 1.2.2 Memory Allocation

Built-in maximum 128 Kbytes of SRAM, start address 0x20000000, support byte, half word (2 bytes), full word (4 bytes) access.

Built-in maximum 480 Kbytes of Flash program memory, for storing user applications.

Built-in 28K bytes of system memory (Bootloader), is selected as the boot space (Manufacturer's solidified bootloading program).

Built-in 128-byte used to store the manufacturer's configuration word, which is solidified before delivery out of the factory and cannot be modified by the user.

Built-in 128-byte space is used for user option byte storage.

Note: Memory allocation varies by model, refer to the corresponding datasheet of the chip for details.

## 1.3 Boot Configuration

The system can select 3 different boot modes through the BOOT0 and BOOT1 pins.

Table 1-1 Boot modes

| BOOT0 | BOOT1 | Boot mode                      |
|-------|-------|--------------------------------|
| 0     | X     | Boot from program flash memory |
| 1     | 0     | Boot from system memory        |
| 1     | 1     | Boot from internal SRAM        |

The user selects the startup mode after reset by setting the status value of BOOT pins. After the system is reset or the power is reset, the value of the BOOT pin will be latched again.

The program flash memory, system memory and internal SRAM have different access methods in different startup modes:

- When it is started up from the program flash memory, the program flash memory address will be mapped to the 0x00000000 address area and can also be accessed in the start address area 0x08000000.
- When it is started up from the system memory, the system memory address will be mapped to the address area 0x00000000 and can also be accessed in the original address area 0x1FFF8000.
- When it is started up from the internal SRAM, it can be only accessed from 0x20000000 address area. When the CH32F20x is started up in this area, it is necessary to set the vector table offset register through the NVIC controller to remap the vector table to SRAM. For CH32V20x, CH32V30x and CH32V31x, such action is not required.

## **Chapter 2 Power Control (PWR)**

This chapter applies to the whole family of CH32F20x, CH32V20x, CH32V30x and CH32V31x.

### 2.1 Overview

The CH32F20x, CH32V20x, and CH32V30x products have a system operating voltage  $V_{DD}$  range of 2.4<sup>(1)</sup> to 3.6V, and the CH32V31x products have a system operating voltage  $V_{DD}$  range of 2.4<sup>(1)</sup> to 3.6V, with a built-in voltage regulator to provide the operating power supply required by the core. When the main power  $(V_{DD})$  is off, backup power supply such as battery can supply power to the real-time clock (RTC) and backup registers through the  $V_{BAT}$  pin. If the backup power supply is not required, it is recommended to connect  $V_{DD}$  directly to the  $V_{BAT}$  pin.

Note: (1) For chips with FEATURE\_SIGN register VLEVEL bit 1, the system operating voltage  $V_{DD}$  supports a minimum supply voltage of 2.4V; For chips with VLEVEL bit 0, the system operating voltage  $V_{DD}$  supports a minimum supply voltage of 1.8V.

For CH32V31x products the following parameters are also included (refer to the CH32V307DS0 manual for specific data):

- (1)  $V_{DD}$  ETH: Power supply for the built-in Ethernet 10/100M PHY.
- (2)  $V_{DDK}$ : Internal power LDO decoupling terminal, external decoupling capacitor is required.

The  $V_{DDA}$  and  $V_{SSA}$  pins are dedicated to supply power to the analog related circuits in the system, including ADC, DAC, temperature sensors, etc. As reference points of some analog circuits,  $V_{REF^+}$  and  $V_{REF^-}$  are equal to  $V_{DDA}$  and  $V_{SSA}$  inside the chip.



Figure 2-1 Power supply overview

After the main power  $(V_{DD})$  is off, the analog switch will be turned to  $V_{BAT}$ , and the backup area will be

powered by the  $V_{BAT}$  pin. At this time, the PC13 to PC15 IOs cannot be used as GPIOs, and only the following functions are available:

- PC13 can be used as TAMPER pin, RTC alarm or second output.
- PC14 and PC15 can be only used as LSE pins.

When the main power ( $V_{DD}$ ) is stable, the system will automatically switch the backup area powered by  $V_{DD}$ , and the PC13 to PC15 IOs can be used as GPIOs.

When the PC13 to PC15 pins are used as GPIO output, the speed must be limited below 2MHz, the maximum load capacitance is 30pF, and it is forbidden to use it in the occasions of continuous output and draw current, such as LED drive.

Note: During the restoration of the main power supply  $(V_{DD})$ , the internal  $V_{BAT}$  power supply is still connected to the external backup power supply through the corresponding  $V_{BAT}$  pin. If VDD is less than the reset delay time  $t_{RSTTEMPO}$ , it will be stabilized and be higher than the value of  $V_{BAT}$  by more than 0.6V, and the current may be injected into  $V_{BAT}$  through the diode between  $V_{DD}$  and  $V_{BAT}$  in a very short moment. Then, the backup power supply such as the battery will be injected through the  $V_{BAT}$  pin. If the backup power supply cannot withstand such instantaneously injected current, it is then recommended to add a positive on low-dropout diode between the backup power supply and  $V_{BAT}$  pin.

## 2.2 Power Supply Management

#### 2.2.1 Power-on Reset and Power-down Reset

The power-on reset (POR) and power-down reset (PDR) circuits are integrated inside the system. When  $V_{DD}/V_{DDA}$  is below the corresponding threshold, the system will be reset by the relevant circuits, without the need for an external reset circuit. Please refer to the corresponding data sheet for more details concerning the power-on threshold ( $V_{POR}$ ) and the power-down threshold ( $V_{PDR}$ ).



Figure 2-2 POR/PDR waveform

#### 2.2.2 Programmable Voltage Detector

The programmable voltage detector (PVD) is mainly used to monitor the main power of the system and compares it to the threshold selected by the PLS [2:0] bits in the power control register (PWR\_CTLR). Coordinated with the external interrupt register (EXTI) setting, it can generate related interrupt to notify the system in time to perform operations before power failure such as data storage.

Configuration procedure:

- 1) Set the PLS [2:0] bits in the PWR CTLR register and select the voltage threshold to be detected.
- 2) Optional interrupt processing. The PVD function is internally connected to the line16 of the EXTI module

V2. 4 19 WH

to trigger the setting of rising/falling edges. Enable this interrupt (with EXTI configured). When  $V_{DD}$  drops below the PVD threshold or rises above the PVD threshold, a PVD interrupt can be generated.

- 3) Set the PVDE bit in the PWR CTLR register to enable PVD.
- 4) Read the PVDO bit in the PWR\_CSR register to obtain the relationship between the main power supply of the current system and the threshold set by PLS [2:0] bits, and perform the corresponding soft processing. When the VDD voltage is higher than the threshold set by PLS[2:0], PVDO position 0; when the VDD voltage is lower than the threshold set by PLS[2:0], PVDO position 1.

PVD Approx. 200mV threshold threshol

Figure 2-3 PVD thresholds

## 2.3 Low-power Modes

After the system reset, the microcontroller is at a normal working status (Run mode). At this time, the system power can be saved by reducing the system clock frequency or disabling the peripheral clock or reducing the working peripheral clock. If the system does not need to work, the user can set the system to enter low-power mode, and let the system jump out of this status through specific events.

The microcontroller currently features 3 low-power modes, which are divided into the following modes according to the working differences of processors, peripherals and voltage regulators, etc.:

- Sleep mode: The core stops running, and all peripherals (Including the core private peripherals) are still
  running.
- Stop mode: Stop all clocks, and the system will continue to run after awakening.
- Standby mode: Stop all clocks, and reset the microcontroller after awakening (Power reset).

| Mode    | Entry                                                  | Wake-up source                                                                                                                                                   | Effect on clock                              | Voltage regulator                     |
|---------|--------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|---------------------------------------|
|         | WFI                                                    | Any interrupt                                                                                                                                                    | Core clock OFF,                              |                                       |
| Sleep   | WFE                                                    | Wake-up event                                                                                                                                                    | no effect on other clocks                    | ON                                    |
| Stop    | Set SLEEPDEEP<br>to 1<br>Clear PDDS to 0<br>WFI or WFE | Any external interrupt/event (Set in the external interrupt register)                                                                                            | HSE, HSI, PLL<br>and peripheral<br>clock OFF | ON: LPDS=0 or<br>Low-power:<br>LPDS=1 |
| Standby | Set SLEEPDEEP<br>to 1<br>Set PDDS to 1<br>WFI or WFE   | WKUP pin rising edge, RTC alarm event, NRST pin reset, IWDG reset.  Note: Any event can also wake up the system, but the system will not be reset after wake-up. | HSE, HSI, PLL<br>and peripheral<br>clock OFF | OFF                                   |

Table 2-1 List of low-power modes

Note: The SLEEPDEEP bit is the core private peripheral control bit. For CH32F20x, refer to the Cortex-M3

core manual. For CH32V20x, CH32V30x and CH32V31x, refer to the PFIC SCTLR register.

## 2.3.1 Low-power Configuration

#### • WFI and WFE

WFI: The microcontroller is woken up by an interrupt source that has an interrupt controller response. After the system wakes up, the interrupt service function is executed firstly (Except for the microcontroller reset).

WFE: When a wake-up event triggers the microcontroller, it exits the low-power mode. Wake-up events include:

- 1) Configure an external or internal EXTI line as event mode. At this time, an interrupt controller does not need to be configured;
- 2) Or configure an interrupt source, which is equivalent to WFI wake-up, and the system will execute the interrupt service function first;
- 3) Or configure the SEVONPEND bit to enable the peripheral interrupt, but do not enable the interrupt in the interrupt controller, and the interrupt pending bit needs to be cleared after the system is wakened up.

#### SLEEPONEXIT

Enable: After executing the WFI or WFE instructions, the microcontroller enters the low-power mode when it ensures that it exits all interrupt services to be processed.

Disable: After executing the WFI or WFE instructions, the microcontroller immediately enters the low-power mode.

#### SEVONPEND

Enable: All interrupts or wake-up events can wake it up from the low power mode that is entered by executing WFE.

Disable: Only the interrupt or wake-up event enabled in the interrupt controller can wake it up from the low power mode that is entered by executing WFE.

#### 2.3.2 Sleep Mode

In this mode, all I/O pins keep the same state as in the Run mode, and all peripheral clocks are normal, so disable useless peripheral clocks to reduce power consumption before entering sleep mode. This mode offers the lowest wake-up time.

Enter: Configure the core register control bit SLEEPDEEP=0, and power control register PDDS=0. LPDS determines the status of the internal voltage regulator. Execute WFI or WFE, and select SEVONPEND or SLEEPONEXIT.

Exit: Any interrupt or wakeup events.

#### 2.3.3 Stop Mode

The stop mode is based on the core deep-sleep mode (SLEEPDEEP) combined with peripheral clock gating. The voltage regulator can be configured in a lower-power mode. In this mode, the high-frequency clocks (HSE/HSI/PLL) in the domain are stopped, SRAM and register contents are preserved, and the I/O pins keep the same state. The system can continue to run after being woken up from this mode, and HSI is the default system clock.

If Flash memory programming or an access to the PB domain is ongoing, the Stop mode entry is delayed until the memory or PB access has completed.

Modules that can work in stop mode: Independent watchdog (IWDG), real-time clock (RTC), low-frequency clock (LSI/LSE).

Enter: Configure the core register control bit SLEEPDEEP=1, and power control register PDDS=0. LPDS bit is optional. Execute WFI or WFE, and SEVONPEND and SLEEPONEXIT are optional.

Exit: Any external interrupt/event (Set in the external interrupt register).

In stop mode, the LPDS bit can be configured. The voltage regulator works in normal mode when LPDS=0, and it is in low-power mode when LPDS=1. In low-power mode, configure RAMLV=1 in the PWR\_CTRL register, to enable RAM low voltage mode and achieve the lowest power consumption.

### 2.3.4 Standby Mode

In standby mode, the voltage regulator is disabled, and all circuits except the wake-up circuit and backup domain circuit are powered down to achieve minimum power consumption. Upon exiting under specified wake-up conditions, the microcontroller is reset and undergoes a power-on reset.

Modules that can work in standby mode: Independent watchdog (IWDG), real-time clock (RTC), low-frequency clock (LSI/LSE).

Enter: Configure the core register control bit SLEEPDEEP=1, and power control register PDDS=1. Execute WFI or WFE, and SEVONPEND and SLEEPONEXIT are optional.

Exit: 1) Any events (Set in the external interrupt register), and the wake-up equivalent stop mode exits.

2) The rising edge of the WKUP pin, the rising edge of the RTC alarm event, the external reset and the IWDG reset on the NRST pin. After this wake-up, the microcontroller will perform a power reset.

In standby mode: when it is supplied normally, configure R2KSTY=1 in the PWR\_CTLR register, to keep the 2K-byte RAM on, and configure R30KSTY=1, to keep the 30K-byte RAM on. When it is supplied by VBAT, configure R2KVBAT=1 in the PWR\_CTLR register, to keep the 2K-byte RAM on, and configure R32KVBAT=1 to keep the 30K-byte RAM on. On this basis, configure RAMLV=1 in the PWR\_CTRL register, to enable RAM low-voltage mode and achieve the lowest power consumption.

Note: In debug mode, if the microprocessor enters the stop or standby mode, the debug connection is lost.

R2KSTY=1: control 2-Kbyte RAM with addresses ranging from 0x20000000 to 0x20000000+2K.

R30KSTY=1: control 30-Kbyte RAM with addresses ranging from 0x20000000+2K to 0x20000000+2K+30K.

#### 2.3.5 RTC Auto-wakeup

RTC can be used to automatically wake up the MCU without depending on an external interrupt. By programming the time base, it can wake up from stop or standby mode at regular intervals.

An external low-power 32.768kHz crystal oscillator (LSE) can be selected as the RTC clock source, or an internal oscillator (LSI) can be selected as the RTC clock source. The accuracy and power consumption indicator of LSI are worse than those of LSE.

The RTC alarm event is able to wake up the MCU from the Shutdown mode, in order to realize this function, it is necessary to configure the external interrupt line 17 and set the RTC to generate alarm events. To wake up the MCU from Standby mode, only the RTC needs to be set to generate an alarm event.

## 2.4 Register Description

Table 2-2 PWR registers

| Name         | Access address | Description                   | Reset value |
|--------------|----------------|-------------------------------|-------------|
| R32_PWR_CTLR | 0x40007000     | Power control register        | 0x00000000  |
| R32_PWR_CSR  | 0x40007004     | Power control/status register | 0x00000000  |

## 2.4.1 Power Control Register (PWR\_CTLR)

Offset address: 0x00

| 31 | 30       | 29 | 28 | 27 | 26 | 25  | 24 | 23         | 22        | 21           | 20          | 19          | 18         | 17    | 16 |
|----|----------|----|----|----|----|-----|----|------------|-----------|--------------|-------------|-------------|------------|-------|----|
|    | Reserved |    |    |    |    |     |    |            | RAML<br>V | R30K<br>VBAT | R2KV<br>BAT | R30K<br>STY | R2KS<br>TY |       |    |
| 15 | 14       | 13 | 12 | 11 | 10 | 9   | 8  | 7          | 6         | 5            | 4           | 3           | 2          | 1     | 0  |
|    | Reserved |    |    |    |    | DBP | ΡΙ | <br>_S[2:0 | )1        | PVDE         | CSBF        | CWUF        | PDD        | I PDS |    |

| Bit     | Name     | Access | Description                                                                                                                                                                                                                                                                                                                                                                                               | Reset value |
|---------|----------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:21] | Reserved | RO     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                  | 0           |
| 20      | RAMLV    | RW     | RAM low voltage mode enable (Lower power consumption): 0: Disable; 1: Enable.  Note: Valid when the LPDS bit of PWR CTLR register is 1.                                                                                                                                                                                                                                                                   | 0           |
| 19      | R30KVBAT | RW     | 30K RAM power enable in Standby mode when V <sub>BAT</sub> supplies power:  0: Power disabled;  1: Power enabled.  Note: Applied for CH32F20x_D8, CH32F20x_D8C, CH32V30x_D8, CH32V30x_D8C, CH32V31x_D8C, CH32V20x_D8, CH32V20x_D8W and CH32F20x_D8.                                                                                                                                                       | 0           |
| 18      | R2KVBAT  | RW     | When VBAT is powered, whether the 2K RAM is charged in Standby mode or not:  0: Not charged;  1: Charged;  Note: Applicable to CH32F20x_D8, CH32F20x_D8C, CH32V30x_D8, CH32V30x_D8C, CH32V31x_D8C, CH32V20x_D8, CH32V20x_D8W, CH32F20x_D8.  When VBAT is powered, whether the 20K RAM in Standby mode is charged control bit:  0: Not charged;  1: Charged;  Note: Suitable for CH32F20x_D6, CH32V20x_D6. | 0           |
| 17      | R30KSTY  | RW     | 30K RAM power enable in Standby mode: 0: Not charged; 1: Charged; Note: Applied for CH32F20x_D8, CH32F20x_D8C, CH32V30x_D8, CH32V30x_D8CV, CH32V31x_D8C, CH32V20x_D8, CH32V20x_D8W and CH32F20x_D8.                                                                                                                                                                                                       | 0           |
| 16      | R2KSTY   | RW     | Whether the 2K RAM is charged with control bits in Standby mode:  0: Not charged;  1: Charged;  Note: Applicable to CH32F20x_D8, CH32F20x_D8C, CH32V30x_D8, CH32V30x_D8C, CH32V30x_D8, CH32V20x_D8W, CH32F20x_D8.  Whether the 20K RAM is charged with control bits in Standby mode:  0: Not charged;  1: Charged;  Note: Suitable for CH32F20x_D6, CH32V20x_D6.                                          | 0           |

| [15:9] | Reserved | RO   | Reserved                                                               | 0 |
|--------|----------|------|------------------------------------------------------------------------|---|
|        |          |      | Backup domain write enable. When the clock of RTC is 128               |   |
| 8      | DDD      | DIII | frequency division of the external clock, this bit must set to 1.      | 0 |
| 8      | DBP      | RW   | 0: Access to RTC and backup registers disabled;                        | 0 |
|        |          |      | 1: Access to RTC and backup registers enabled.                         |   |
|        |          |      | PVD level selection. For details, refer to the electrical              |   |
|        |          |      | characteristics of the manual.                                         |   |
|        |          |      | Applicable to products with a VLEVEL bit of 1 (V <sub>DD</sub> voltage |   |
|        |          |      | of 2.4V):                                                              |   |
|        |          |      | 000: 2.37V at the rising edge/2.29V at the falling edge;               |   |
|        |          |      | 001: 2.55V at the rising edge /2.46V at the falling edge;              |   |
|        |          |      | 010: 2.63V at the rising edge /2.55V at the falling edge;              |   |
|        |          |      | 011: 2.76V at the rising edge /2.67V at the falling edge;              |   |
|        |          |      | 100: 2.87V at the rising edge /2.78V at the falling edge;              |   |
|        |          |      | 101: 3.03V at the rising edge /2.93V at the falling edge;              |   |
|        |          |      | 110: 3.18V at the rising edge /3.06V at the falling edge;              |   |
| [7:5]  | PLS[2:0] | RW   | 111: 3.29V at the rising edge /3.19V at the falling edge.              | 0 |
|        |          |      | Applicable to products with a VLEVEL bit of 0 (V <sub>DD</sub> voltage |   |
|        |          |      | of 1.8V):                                                              |   |
|        |          |      | 000: 2.19V at the rising edge/2.13V at the falling edge;               |   |
|        |          |      | 001: 2.33V at the rising edge /2.25V at the falling edge;              |   |
|        |          |      | 010: 2.39V at the rising edge /2.32V at the falling edge;              |   |
|        |          |      | 011: 2.48V at the rising edge /2.42V at the falling edge;              |   |
|        |          |      | 100: 2.57V at the rising edge /2.51V at the falling edge;              |   |
|        |          |      | 101: 2.69V at the rising edge /2.61V at the falling edge;              |   |
|        |          |      | 110: 2.78V at the rising edge /2.69V at the falling edge;              |   |
|        |          |      | 111: 2.88V at the rising edge /2.79V at the falling edge.              |   |
|        |          |      | Power voltage detector enable bit                                      |   |
| 4      | PVDE     | RW   | 0: Power voltage detector disabled;                                    | 0 |
|        |          |      | 1: Power voltage detector enabled;                                     |   |
|        |          |      | Clear standby flag bit. This bit is always read as 0.                  |   |
| 3      | CSBF     | RW1  | 0: No effect;                                                          | 0 |
|        |          |      | 1: Clear the SBF Standby Flag bit;                                     |   |
|        |          |      | Clear wakeup flag bit. This bit is always read as 0.                   |   |
| 2      | CWUF     | RW1  | 0: No effect;                                                          | 0 |
|        |          |      | 1: Clear the WUF after 2 system clock cycles;                          |   |
|        |          |      | Standby/stop mode selection bit when power-down and                    |   |
|        |          |      | deepsleep.                                                             |   |
| 1      | PDDS     | RW   | 0: Enter stop mode. The regulator status depends on the LPDS           | 0 |
|        |          |      | bit;                                                                   |   |
|        |          |      | 1: Enter standby mode.                                                 |   |
|        |          |      | Voltage regulator working mode selection bit in stop mode. It          |   |
| 0      | LPDS     | RW   | works when PDDS=0.                                                     | 0 |
|        |          |      | 0: The voltage regulator works in the normal mode;                     |   |
|        |          |      | 1: The voltage regulator works in low-power mode.                      |   |

Note: This register BIT16~BIT20 can only be reset by backup, other BITs are reset when waking up from Standby mode.

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

Offset address: 0x04

| 31 | 30       | 29 | 28 | 27 | 26 | 25   | 24       | 23 | 22 | 21 | 20 | 19   | 18  | 17  | 16 |
|----|----------|----|----|----|----|------|----------|----|----|----|----|------|-----|-----|----|
|    | Reserved |    |    |    |    |      |          |    |    |    |    |      |     |     |    |
| 15 | 14       | 13 | 12 | 11 | 10 | 9    | 8        | 7  | 6  | 5  | 4  | 3    | 2   | 1   | 0  |
|    | Reserved |    |    |    |    | EWUP | Reserved |    |    |    |    | PVDO | SBF | WUF |    |

| Bit    | Name     | Access | Description                                                                                                                                                                                                                                             |   |
|--------|----------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| [31:9] | Reserved | RO     | Reserved.                                                                                                                                                                                                                                               | 0 |
| 8      | EWUP     | RW     | WKUP pin enable bit 0: WKUP pin is used for general purpose I/O, and it is not used to wake up the MCU from standby mode; 1: WKUP is forced in input pull-down configuration, used to wake up the MCU from standby mode.                                | 0 |
| [7:3]  | Reserved | RO     | Reserved.                                                                                                                                                                                                                                               | 0 |
| 2      | PVDO     | RO     | PVD output bit. It is valid only when PVD is enabled by the PVDE in the PWR_CTLR register. 0: $V_{DD}/V_{DDA}$ is higher than the PVD threshold set by the PLS[2:0] bits; 1: $V_{DD}/V_{DDA}$ is lower than the PVD threshold set by the PLS[2:0] bits; | 0 |
| 1      | SBF      | RO     | Standby flag bit, cleared by setting the CSBF bit to 1.  0: MCU is not in standby mode;  1: MCU enters standby mode;                                                                                                                                    | 0 |
| 0      | WUF      | RO     | Wake-up flag bit, cleared by setting the CWUF bit to 1.  0: No wake-up event occurred;  1: A wake-up event or RTC alarm event is detected on the WKUP pin.                                                                                              | 0 |

Note: This register remains unchanged after woken up from Standby mode.

## **Chapter 3 Reset and Clock Control (RCC)**

#### This chapter applies to the whole family of CH32F20x, CH32V20x, CH32V30x and CH32V31x.

The controller provides different types of reset and a configurable clock tree structure according to the division of power regions and taking into account the peripheral power consumption management in the application. This chapter describes the action scope of each clock in the system.

#### 3.1 Main Features

- Several types of reset
- Several clock sources, bus clock management
- Built-in external crystal oscillation monitor and clock security system
- Independent management of each peripheral clock: reset, enable, disable
- Internal clock output

### 3.2 Reset

There are 3 types of reset: Power Reset, System Reset and Backup Domain Reset.

#### 3.2.1 Power Reset

When power reset occurs, all registers are reset except the Backup domain (Backup domain is powered by  $V_{BAT}$ ).

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

- Power-on/power-down reset (POR/PDR)
- Wake up from standby mode

### 3.2.2 System Reset

When a system reset occurs, all registers are reset except the reset flags and backup domain in the control/status register (RCC\_RSTSCKR). Identify the source of the reset event by checking the reset status flag bit in the RCC\_RSTSCKR register.

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

- Low level on NRST pin (External reset)
- Window watchdog end of count condition (WWDG reset)
- Independent watchdog end of count condition (IWDG reset)
- Software reset (SW reset)
- Low-power management reset

Window/independent watchdog reset: Triggered by the counting cycle overflow of the peripheral timer of the window/independent watchdog. For detailed description, please refer to the corresponding chapters.

Software reset: CH32F20x resets the system by setting bit2 in the core register (AIRCR) to 1. For specific operations, please refer to the Cortex-M3 Core Manual. The CH32V20x, CH32V30x and CH32V31x reset the system by setting the SYSRESET bit in the interrupt configuration register (PFIC\_CFGR) to 1, or by setting the SYSRESET bit in the PFIC\_SCTLR register to 1. Refer to the corresponding chapters for details.

Low-power management reset: By resetting the nRST\_STDBY bit in the user option bytes, the standby mode reset is enabled. After the process of entering the standby mode is executed at this time, a system reset will be performed instead of entering standby mode. By setting the nRST\_STOP bit in User Option Bytes to 0, the stop mode reset is enabled. After the process of entering the stop mode is executed, a system reset will be executed instead of entering stop mode.

NRST

Power Reset
Software Reset
WWDG Reset
IWDG Reset
Low-power management reset

Figure 3-1 System reset structure

### 3.2.3 Backup Domain Reset

When the backup domain reset occurs, only the backup domain register will be reset, including the backup register, RCC\_BDCTLR register (RTC enable and LSE oscillator). A backup domain reset is generated when one of the following events occurs:

- On the premise that both V<sub>DD</sub> and V<sub>BAT</sub> are powered off, it is caused by power-on of V<sub>DD</sub> or V<sub>BAT</sub>
- Set the BDRST bit in the RCC BDCTLR register to 1

## 3.3 Clock

### 3.3.1 System Clock Structure

40kHz IW\_DGCLK to independent watchdog LSI RC OSC32 IN 32.768kHz RTCCLK → to RTC LSE OSC OSC32\_OUT 60MHz ► ETH-PHY /128 PLL3MUL ➤ to I2S2 interface PLL3CLK \*2.5,\*4,••• to I2S3 interface \*16,\*20 PLL3VCO (2\*PLL3CLK) to TRNG PREDIV2 PLL2MUL PREDIV1SRC \*2.5,\*4,\*\*\* /1,/2,... PREDIV1 \*16,\*20 /15,/16 PLLSRC XTI to MCO /1,/2,... PLL2VCO (2\*PLL2CLK) PLLMUL /15,/16 OSC\_IN \*3,\*4,... HSE OSC OSC\_OUT /2 \*16,\*18 8MHz HSI RC SYSCLK USB prescaler 48MHz USBCLK PLLCLK -/1,/2,/3 USB /1,/2,... → OTGFSCLK CLKFLS48MHz CSS **HSPLL** /7,/8 HSPLLSRC USBHSPREDIV USB2.0 PHY 480MHz MCO[3:0] to Flash prog IF HSE to HB bus/core/memory/DMA HSI HB prescaler /1,/2···/512 FCLK core free running clock PLLCLK/2 MCOI to Core System timer PLL2CLK PLL3CLK/2 PLL3CLK PB1 prescaler PCLK1 ► to PB1 peripherals HCLK /1,/2…/16 XTI 144MHz max peripheral clock enable MII/RMII interface if(PB1 prescaler=1)\*1 else \*2 TIMxCLK to TIM2,3,4,5,6,7 MII\_TXC ► MACTXCLK peripheral clock enable MII\_RMII\_SEL in AFIO\_MAPR MII\_RXC ► MACRXCLK PB2 prescaler to Ethernet MAC PCLK2 ► to PB2 peripherals /1,/2…/16 peripheral clock enable GTXC RGMIION ADC prescaler ▶ GRXC ADCCLK to ADC1,2 GRXC /2,/4,/6,/8 ETH1G\_EN peripheral clock enable EXT\_125M ETH1G\_125M if(PB2 prescaler=1)\*1 else \*2 PLL2VCO to TIM1,8,9,10 PLL3VCO ETH1G\_SRC RGMII interface peripheral clock enable

Figure 3-2 CH32V305/307/317 and CH32F205/207 clock tree structure

Note: This clock tree structure is applied for CH32F20x D8C, CH32V30x D8C and CH32V31x D8C.



Figure 3-3 CH32F203/V203/V303 clock tree structure

Note: This clock tree structure is applied for CH32F20x\_D6, CH32F20x\_D8, CH32V20x\_D6 and CH32V30x\_D8. When using the USB function, the CPU frequency must be 48MHz, 96MHz or 144MHz. when using the USB high speed function, the clock source of USBHSPLL can only be HSE. when the system wakes up from the stop or standby mode, the system will automatically switch to HSI as the main frequency.



Figure 3-4 CH32V203RB clock tree structure

Note: (1) CH32V203RB (CH32V20x\_D8) products have an external crystal or clock (HSE) of 32M, and there is no need for a load capacitor to have been built in when using an external crystal.

(2) The blue dotted line in Figure 3-4 above applies only to CH32V203RB chips with the penultimate digit of the lot number greater than zero.

V2. 4 30 WCH<sup>®</sup>



Figure 3-5 CH32FV208 clock tree structure

Note: This clock tree structure is applied for CH32F20x\_D8W and CH32V20x\_D8W. When USB and ETH are used simultaneously, set the USBPRE[1:0] bits to 11b. The external crystal or clock (HSE) is 32M. When the external crystal is enabled, no load capacitor is required as it is built in.

### 3.3.2 High-speed Clock (HSI/HSE)

HSI is a high-speed clock signal generated by an 8MHz RC oscillator in the system. The HSI RC oscillator can provide the system clock without depending on any external device. Its startup time is very short but the clock frequency accuracy is poor. HSI is enabled/disabled by setting the HSION bit in the RCC CTLR register. The HSIRDY bit indicates whether the HSI RC oscillator is stable. By default, HSION and HSIRDY are set to 1 (Recommended not to disable). If the HSIRDYIE bit in the RCC INTR register is set, a corresponding interrupt is generated.

- Factory calibration: The difference in manufacturing process may cause the RC oscillation frequency of each chip to be different, so HSI calibration is performed for each chip before the chip is delivered out of the factory. After the system is reset, the factory calibration value is loaded into the HSICAL[7:0] bits in the RCC CTLR register.
- User adjustment: Based on different voltages or ambient temperatures, the application program can adjust the HSI frequency through the HSITRIM[4:0] bits in the RCC CTLR register.

Note: If the HSE crystal oscillator fails, HSI clock is used as a backup clock source (clock security system).

HSE is a High-Speed External clock signal, including external crystal/ceramic resonator generation or external high-speed clock input.

External crystal/ceramic resonator (HSE crystal): An external 3 to 25MHz oscillator provides a more accurate clock source for the system. For details, please refer to the electrical characteristics of this manual. The HSE crystal can be enabled/disabled by setting the HSEON bit in the RCC CTLR register. The HSERDY bit indicates whether the HSE crystal oscillation is stable. The clock is not released until the HSERDY bit is set to 1 by hardware. If the HSERDYIE bit in the RCC INTR register is set, a corresponding interrupt can be generated.

Figure 3-6 HSE crystal circuit

Note: The load capacitor should be placed as close as possible to the oscillator pins, and the loading capacitance values must be adjusted according to the selected oscillator.

External high-speed clock source (HSE bypass): In this mode, an external clock source is directly provided to the OSC IN pin, and the OSC OUT pin is suspended. It can have a frequency of up to 25MHz. The application program needs to set the HSEBYP bit when the HSEON bit is 0, to enable HSE bypass, and then set the HSEON bit.

WCH<sup>®</sup> V2. 4 32

Figure 3-7 High-speed clock source circuit



### 3.3.3 Low-speed Clock (LSI/LSE)

LSI is a low-speed clock signal generated by the system's internal RC oscillator. It can keep running in stop and standby modes, and provide a clock reference for the RTC clock, independent watchdog, and wake-up unit. For further information, please refer to the electrical characteristics of this manual. LSI can be enabled/disabled by setting the LSION bit in the RCC\_RSTSCKR register, and then it checks whether the LSI RC oscillation is stable by querying the LSIRDY bit. The clock is not released until the LSIRDY bit is set to 1 by hardware. If the LSIRDYIE bit in the RCC\_INTR register is set, a corresponding interrupt can be generated.

LSE is an external low-speed clock signal, including external crystal/ceramic resonator generation or external low-speed clock input. It provides a low-power but highly accurate clock source for RTC clock or other timing functions.

External crystal/ceramic resonator (LSE crystal): External 32.768kHz low-speed oscillator. LSE can be enabled/disabled by setting the LSEON bit in the RCC\_BDCTLR register. The LSERDY bit indicates whether the LSE crystal oscillation is stable. The clock is not released until the LSERDY bit is set to 1 by hardware. If the LSERDYIE bit in the RCC\_INTR register is set, a corresponding interrupt can be generated.

Figure 3-8 LSE crystal circuit

OSC32\_IN

OSC32\_OUT

External low-speed clock source (LSE bypass): In this mode, an external clock source is directly provided
to the OSC32\_IN pin, and the OSC32\_OUT pin is suspended. The application program needs to set the
LSEBYP bit when the LSEON bit is 0, to enable the LSE bypass, and then set the LSEON bit.

Figure 3-9 Low-speed clock source circuit



#### 3.3.4 PLL Clock

By configuring the RCC\_CFGR0 register and the EXTEND\_CTR register, 3 clock sources and multiplication factors can be selected for the internal PLL clock. These settings must be completed before each PLL is enabled. Once the PLL is enabled, these parameters cannot be changed. PLL can be enabled/disabled by setting the PLLON bit in the RCC\_CTLR register. The PLLRDY bit indicates whether the PLL clock is stable. The clock is not released until the PLLRDY bit is set to 1 by hardware. PLL2 can be enabled/disabled by setting the PLLON2 bit in the RCC\_CTLR register. The PLLRDY2 bit indicates whether the PLL2 clock is stable. The clock is not released until the PLLRDY2 bit is set to 1 by hardware. PLL3 can be enabled/disabled by setting the PLLON3 bit in the RCC\_CTLR register. The PLLRDY3 bit indicates whether the PLL3 clock is stable. The clock is not released until the PLLRDY3 bit is set to 1 by hardware. If the PLLRDYIE bit, the PLL2RDYIE bit and the PLL3RDYIE bit in the RCC\_INTR register are set, a corresponding interrupt can be generated.

#### PLL clock sources:

- HSI clock
- HSI clock divided by 2
- HSE clock or PLL2 clock through a configurable divider
   PLL2 and PLL3 are clocked by HSE through a configurable divider (PREDIV2)

### 3.3.5 Bus/Peripheral Clock

#### 3.3.5.1 System Clock (SYSCLK)

Configure the system clock source by configuring the SW[1:0] bits in the RCC\_CFGR0 register. The SWS[1:0] bits indicate the current system clock source status.

- HSI as the system clock
- HSE as the system clock
- PLL clock as the system clock

After the controller reset, HSI clock is selected as the system clock source by default. A switch from one clock source to another occurs only if the target clock source is ready.

#### 3.3.5.2 HB/PB1/PB2 Bus Peripheral Clock (HCLK/PCLK1/PCLK2)

By configuring the HPRE[3:0], PPRE1[2:0], and PPRE2[2:0] bits in the RCC\_CFGR0 register, the clocks of the HB, PB1, and PB2 buses can be configured respectively. These bus clocks determine the access clock reference of the peripheral interfaces mounted below them. The application program can adjust different values to reduce the power consumption of some peripherals.

Different peripheral modules can be reset by bits in the RCC\_AHBRSTR, RCC\_APB1PRSTR, and RCC\_APB2PRSTR registers to restore them to the initial state.

By setting bits in the RCC\_AHBPCENR, RCC\_APB1PCENR and RCC\_APB2PCENR registers, the communication clock interface of different peripheral modules can be enabled or disabled separately. To use a peripheral, firstly enable the corresponding clock bit to access its register.

### 3.3.5.3 RTC Clock (RTCCLK)

By setting the RTCSEL[1:0] bits in the RCC\_BDCTLR register, the RTCCLK clock source can either be HSE, LSE or LSI clocks. Before modifying this bit, ensure that the DBP bit in the power control register

(PWR CTLR) is set to 1, and this bit can be reset only when the backup domain is reset.

- LSE as the RTC clock: As LSE is at the backup domain and is powered by the V<sub>BAT</sub> supply, as long as
   V<sub>BAT</sub> maintains supplying power, RTC will continuously work even though V<sub>DD</sub> power supply is switched
   off.
- LSI as the RTC clock: If the V<sub>DD</sub> power supply is switched off, the Auto-wakeup unit (AWU)clock cannot be guaranteed.
- The HSE is divided and used as the RTC clock: if the VDD supply is cut off or the internal voltage regulator is turned off (the supply to the 1.8V domain is cut off), the RTC status is indeterminate. Refer to the description of the RCC\_BDCTLR register RTCSEL[1:0] bits for the dividing factor of the HSE for the corresponding chip model.

### 3.3.5.4 Independent Watchdog Clock

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

### 3.3.5.5 Microcontroller Clock Output (MCO)

The microcontroller clock output (MCO) capability allows the clock to output onto the MCO pin. Configure the alternate push-pull output mode in the corresponding GPIO port register. By setting the MCO[3:0] bits in the RCC CFGR0 register, the following 8 clock signals can be selected as the MCO clock output:

- System clock (SYSCLK)
- HSI clock
- HSE clock
- PLL clock divided by 2
- PLL2 clock
- PLL3 clock
- PLL3 clock divided by 2
- XT1 external 3-25MHz oscillator (For Ethernet)

#### 3.3.5.6 USB clock

USBD 48MHz clock source is a PLL clock through a configurable divider, and the PLL supports 3 types of clock configurations, including 48MHz, 96MHz and 144MHz. By configuring the USBPRE[1:0] bits in the RCC CFGR0 register, the 48MHz clock is output to USBD.

USBFS/OTG\_FS 48MHz clock source is a PLL clock or USBHSPLL clock through a configurable divider, and it can be selected by configuring the USBFSSRC bit in the RCC\_CFGR2 register. If a PLL clock through a configurable divider is selected as the clock source, refer to USBD for configuration steps. If USBHSPLL clock is selected as the clock source, USBHSPLL reference clock frequency can be selected by configuring the USBHS\_CKREFSEL[1:0] bits in the RCC\_CFGR2 register (Reference clock frequency must be consistent with USBHSPLL input clock).

USBHD clock source is originated from USBHSPLL clock. USBHSPLL reference clock frequency can be selected by configuring the USBHS\_CKREFSEL[1:0] bits in the RCC\_CFGR2 register (Reference clock frequency must be consistent with USBHSPLL input clock). By setting the USBHS\_PLLALIVE bit in the RCC\_CFGR2 register, USB PHY internal PLL can be enabled.

### 3.3.5.7 ETH clock

For details, please refer to Section 27.1.4.5.

#### 3.3.5.8 I2S and RNG clock

I2S and RNG clock source are originated from PLL3VCO or system clock (SYSCLK). By configuring the I2S2SRC/I2S3SRC/RNG\_SRC bit in the RCC\_CFGR2 register, I2S2/I2S3/RNG clock source can be selected respectively.

### 3.3.6 Clock Security System

The clock security system is an operation protection mechanism of the controller. It can switch to HSI clock when a failure is detected on the HSE clock, generate interrupt notification and allow the application software to perform rescue operations.

By setting the CSSON bit in the RCC\_CTLR register to 1, the clock security system can be activated. In this case, the clock detector is enabled after the HSE oscillator startup delay (HSERDY=1), and disabled after the HSE oscillator is stopped. Once a failure is detected on the HSE clock during system operation, the HSE oscillator will be disabled, and the clock failure event will be sent to the break input of the advanced-control timers (TIM1 and TIM8). Then a clock security interrupt is generated, the CSSF bit is set to 1, and the application program enters the non-maskable interrupt (NMI). The CSSF bit can be cleared by setting the CSSC bit, and the NMI interrupt pending bit can be cancelled.

If the current HSE is selected as the system clock, or the current HSE is selected as the PLL input clock and the PLL is selected as the system clock, the clock security system will automatically switch the system clock to the HSI oscillator when the failure occurs, and disable the HSE oscillator and PLL.

### 3.4 Register Description

Table 3-1 RCC registers

| Name              | Access address | Description                          | Reset value |
|-------------------|----------------|--------------------------------------|-------------|
| R32_RCC_CTLR      | 0x40021000     | Clock control register               | 0x0000xx83  |
| R32_RCC_CFGR0     | 0x40021004     | Clock configuration register 0       | 0x00000000  |
| R32_RCC_INTR      | 0x40021008     | Clock interrupt register             | 0x00000000  |
| R32_RCC_APB2PRSTR | 0x4002100C     | PB2 peripheral reset register        | 0x00000000  |
| R32_RCC_APB1PRSTR | 0x40021010     | PB1 peripheral reset register        | 0x00000000  |
| R32_RCC_AHBPCENR  | 0x40021014     | HB peripheral clock enable register  | 0x00000014  |
| R32_RCC_APB2PCENR | 0x40021018     | PB2 peripheral clock enable register | 0x00000000  |
| R32_RCC_APB1PCENR | 0x4002101C     | PB1 peripheral clock enable register | 0x00000000  |
| R32_RCC_BDCTLR    | 0x40021020     | Backup domain control register       | 0x00000000  |
| R32_RCC_RSTSCKR   | 0x40021024     | Control/status register              | 0x0C000000  |
| R32_RCC_AHBRSTR   | 0x40021028     | HB peripheral reset register         | 0x00000000  |
| R32_RCC_CFGR2     | 0x4002102C     | Clock configuration register 2       | 0x00000000  |

Table 3-2 OSC registers

| Name             | Access address | Description                                         | Reset value |
|------------------|----------------|-----------------------------------------------------|-------------|
| R32_HSE_CAL_CTRL | 0x4002202C     | HSE crystal oscillator calibration control register | 0x09000000  |

| R16_LSI32K_TUNE      | 0x40022036 | LSI crystal oscillator calibration tune register          | 0x1011 |  |
|----------------------|------------|-----------------------------------------------------------|--------|--|
| R8_LSI32K_CAL_CFG    | 0x40022049 | LSI crystal oscillator calibration configuration register | 0x01   |  |
| R16_LSI32K_CAL_STATR | 0x4002204C | LSI crystal oscillator calibration status register        | 0x0000 |  |
| R8_LSI32K_CAL_OV_CNT | 0x4002204E | LSI crystal oscillator calibration counter                | 0x00   |  |
| R8_LSI32K_CAL_CTRL   | 0x4002204F | LSI crystal oscillator calibration control register       | 0x80   |  |

Note: Applied for CH32V20x\_D8W and CH32F20x\_D8W.

## 3.4.1 Clock Control Register (RCC\_CTLR)

| 31   | 30          | 29          | 28         | 27          | 26         | 25         | 24        | 23 | 22   | 21    | 20    | 19        | 18           | 17         | 16        |
|------|-------------|-------------|------------|-------------|------------|------------|-----------|----|------|-------|-------|-----------|--------------|------------|-----------|
| Rese | erved       | PLL3<br>RDY | PLL3<br>ON | PLL2<br>RDY | PLL2<br>ON | PLL<br>RDY | PLL<br>ON |    | Rese | erved |       | CSSO<br>N | HSE<br>BYP   | HSE<br>RDY | HSE<br>ON |
| 15   | 14          | 13          | 12         | 11          | 10         | 9          | 8         | 7  | 6    | 5     | 4     | 3         | 2            | 1          | 0         |
|      | HSICAL[7:0] |             |            |             |            |            |           |    | HSI  | TRIM  | [4:0] |           | Reser<br>ved | HSI<br>RDY | HSIO<br>N |

| Bit     | Name     | Access | Description                                              | Reset value |
|---------|----------|--------|----------------------------------------------------------|-------------|
| [31:30] | Reserved | RO     | Reserved                                                 | 0           |
|         |          |        | PLL3 clock ready lock flag bit (Set by hardware):        |             |
|         |          |        | 0: PLL3 unlocked;                                        |             |
| 29      | PLL3RDY  | RO     | 1: PLL3 locked.                                          | 0           |
|         |          |        | Note: Applied for CH32F20x_D8C, CH32V30x_D8C,            |             |
|         |          |        | CH32V31x_D8C.                                            |             |
|         |          |        | PLL3 clock enable control bit:                           |             |
|         |          |        | 0: PLL3 disabled;                                        |             |
| 28      | PLL3ON   | RW     | 1: PLL3 enabled.                                         | 0           |
| 26      | FLESON   | KW     | Note: This bit is cleared by hardware when entering stop | U           |
|         |          |        | or standby low-power mode. Applied for CH32F20x_D8C,     |             |
|         |          |        | CH32V30x_D8C, CH32V31x_D8C.                              |             |
|         |          |        | PLL2 clock ready lock flag bit (Set by hardware):        |             |
|         |          |        | 0: PLL unlocked;                                         |             |
| 27      | PLL2RDY  | RO     | 1: PLL locked.                                           | 0           |
|         |          |        | Note: Applied for CH32F20x_D8C, CH32V30x_D8C,            |             |
|         |          |        | CH32V31x_D8C.                                            |             |
|         |          |        | PLL2 clock enable control bit:                           |             |
|         |          |        | 0: PLL disabled;                                         |             |
| 26      | PLL2ON   | RW     | 1: PLL enabled.                                          | 0           |
| 20      | LL2ON    | KW     | Note: This bit is cleared by hardware when entering stop |             |
|         |          |        | or standby low-power mode. Applied for CH32F20x_D8C,     |             |
|         |          |        | CH32V30x_D8C, CH32V31x_D8C.                              |             |
| 25      | PLLRDY   | RO     | PLL clock ready lock flag bit (Set by hardware):         | 0           |

|         |              |      | 0: PLL unlocked;                                               |       |
|---------|--------------|------|----------------------------------------------------------------|-------|
|         |              |      | 1: PLL locked.                                                 |       |
|         |              |      | PLL clock enable control bit:                                  |       |
|         |              |      | 0: PLL disabled;                                               |       |
| 24      | PLLON        | RW   | 1: PLL enabled.                                                | 0     |
|         |              |      | Note: This bit is cleared by hardware when entering stop       |       |
|         |              |      | or standby low-power mode.                                     |       |
| [23:20] | Reserved     | RO   | Reserved                                                       | 0     |
| [23.20] | reserved     | Ro   | Clock security system enable control bit:                      |       |
|         |              |      | 0: Disable clock security system;                              |       |
|         |              |      | 1: Enable clock security system. When the HSE is ready         |       |
|         |              |      | (HSERDY is set to 1), the HSE clock detector is enabled        |       |
|         |              |      | by hardware. When a HSE clock failure is detected, the         |       |
| 19      | CSSON        | RW   | CSSF flag and NMI interrupt is enabled. When the HSE is        | 0     |
|         |              |      | not ready, the HSE clock detector is disabled by hardware.     |       |
|         |              |      | Note: This feature is not applicable to CH32V20x D6            |       |
|         |              |      | chips where the fifth digit from the end of the lot number is  |       |
|         |              |      | 0.                                                             |       |
|         |              |      |                                                                |       |
|         |              |      | HSE clock bypass control bit:                                  |       |
| 18      | HSEBYP       | RW   | 0: Not bypass HSE oscillator;                                  | 0     |
|         |              |      | 1: Bypass HSE oscillator (Using external clock source).        |       |
|         |              |      | Note: This bit can be written only when HSEON is 0.            |       |
|         |              |      | HSE clock ready flag bit (Set by hardware):                    |       |
| 1.77    | HGEDDY       | D.O. | 0: HSE oscillator not ready;                                   | 0     |
| 17      | HSERDY       | RO   | 1: HSE oscillator ready.                                       | 0     |
|         |              |      | Note: After the HSEON bit is cleared, it takes 6 cycles of     |       |
|         |              |      | the HSE oscillator clock to clear this bit.                    |       |
|         |              |      | HSE clock enable control bit:                                  |       |
| 1.6     | Haran        | DIII | 0: Disable HSE oscillator;                                     | 0     |
| 16      | HSEON        | RW   | 1: Enable HSE oscillator.                                      | 0     |
|         |              |      | Note: After entering the stop or standby low-power mode,       |       |
|         |              |      | this bit is cleared by hardware.                               |       |
| [15:8]  | HSICAL[7:0]  | RO   | HSI clock calibration, automatically initialized at startup.   | xxh   |
|         |              |      | HSI clock trimming:                                            |       |
|         |              |      | The user can input a trimming value that is added to the       |       |
|         |              |      | HSICAL[7:0] bits, and adjust the frequency of the internal     |       |
| [7:3]   | HSITRIM[4:0] | RW   | HSI RC oscillator according to variations in voltage and       | 10000 |
| [,]     |              |      | temperature.                                                   |       |
|         |              |      | The default value is 16, which allows you to adjust the HSI    |       |
|         |              |      | to 8MHz ±0.25%; the change in HSICAL is adjusted about         |       |
|         |              |      | 20kHz per step.                                                |       |
| 2       | Reserved     | RO   | Reserved                                                       | 0     |
|         |              |      | HSI clock (8MHz) ready flag bit (Set by hardware):             |       |
| 1       | HSIRDY       | RO   | 0: HIS oscillator (8MHz) not ready;                            | 1     |
| 1       | нэкрү        | KO   | 1: HIS oscillator (8MHz) ready.                                | 1     |
|         |              |      | Note: After the HSION bit is cleared, it takes 6 cycles of the |       |

|   |       |    | HSI oscillator clock to clear this bit.                       |   |
|---|-------|----|---------------------------------------------------------------|---|
|   |       |    | HSI clock (8MHz) enable control bit:                          |   |
|   |       |    | 0: Disable HSI oscillator;                                    |   |
|   |       |    | 1: Enable HSI oscillator.                                     |   |
| 0 | HSION | RW | Note: When the system returns from standby and stop           | 1 |
|   |       |    | modes or when the external oscillator HSE selected as the     |   |
|   |       |    | system clock fails, this bit will be set by hardware to start |   |
|   |       |    | the internal 8MHz RC oscillator.                              |   |

# 3.4.2 Clock Configuration Register 0 (RCC\_CFGR0)

| 31          | 30                       | 29  | 28         | 27 | 26  | 25     | 24 | 23         | 22         | 21     | 20    | 19      | 18    | 17               | 16         |
|-------------|--------------------------|-----|------------|----|-----|--------|----|------------|------------|--------|-------|---------|-------|------------------|------------|
| ADCDU<br>TY | ADC<br>_DU<br>TY_<br>SEL |     | ETH<br>PRE |    | MCC | 0[3:0] |    | USB<br>[1: | PRE<br>:0] |        | PLLMU | JL[3:0] |       | PLL<br>XTP<br>RE | PLL<br>SRC |
| 15          | 14                       | 13  | 12         | 11 | 10  | 9      | 8  | 7          | 6          | 5      | 4     | 3       | 2     | 1                | 0          |
| ADCPRI      | Ξ[1:0                    | PPI | RE2[2:     | 0] | PP  | RE1[2: | 0] |            | HPRI       | E[3:0] |       | SWS     | [1:0] | SW[              | [1:0]      |

| Bit     | Name         | Access | Description                                         | Reset value |
|---------|--------------|--------|-----------------------------------------------------|-------------|
|         |              |        | ADC clock duty cycle adjustment:                    |             |
| 31      | ADCDUTY      | RW     | 0: ADC clock duty cycle is 50%;                     | 0           |
|         |              |        | 1: ADC clock at low level for longer.               |             |
|         |              |        | ADC clock duty cycle selection:                     |             |
|         |              |        | 0: ADC clock duty cycle is 50%;                     |             |
|         |              |        | 1: ADC clock duty cycle is 75%.                     |             |
| 30      | ADC_DUTY_SEL | RW     | Note: This bit only applies to CH32F20x_D8,         |             |
|         |              |        | CH32F20x_D8C, CH32V30x_D8, CH32V30x_D8C, and        |             |
|         |              |        | CH32V31x_D8C lot numbers that do not have a zero in |             |
|         |              |        | the penultimate sixth digit.                        |             |
| 29      | Reserved     | RO     | Reserved                                            | 0           |
|         |              |        | Ethernet clock source prescaler control:            |             |
|         |              |        | 0: Not divided;                                     |             |
| 28      | ETHPRE       | RW     | 1: Divided by 2.                                    |             |
|         |              |        | Note: Applied for CH32V20x_D8W, CH32V20x_D8 and     |             |
|         |              |        | CH32F20x_D8W.                                       |             |
|         |              |        | Microcontroller clock output (MCO) control:         |             |
|         |              |        | 00xx: No clock;                                     |             |
|         |              |        | 0100: System clock (SYSCLK);                        |             |
| [27:24] | MCO[3:0]     | RW     | 0101: Internal 8MHz RC oscillator clock (HSI);      | 0           |
| [27.24] | WCO[3.0]     | KW     | 0110: External oscillator clock (HSE);              | U           |
|         |              |        | 0111: PLL clock divided by 2;                       |             |
|         |              |        | 1000: PLL2 clock;                                   |             |
|         |              |        | 1001: PLL3 clock divided by 2;                      |             |

| PLL multiplication factor (These bits can be written only when PLL is disabled):   For CH32F20x_D6, CH32F20x_D8, CH32F20x_D8W, CH32V20x_D6, CH32V20x_D8, CH32V20x_D8W, CH32V30x_D8:   0000: PLL input clock x 2; 0001: PLL input clock x 3; 0010: PLL input clock x 4; 0011: PLL input clock x 5; 0100: PLL input clock x 6; 0101: PLL input clock x 7; 0110: PLL input clock x 8; 0111: PLL input clock x 9; 1000: PLL input clock x 10; 1001: PLL input clock x 11; 1010: PLL input clock x 12; 1011: PLL input clock x 13;     PLLMUL[3:0] RW   1100: PLL input clock x 14; 1101: PLL input clock x 15;   0     1110: PLL input clock x 16; 1111: PLL input clock x 18;   For CH32F20x_D8C, CH32V30x_D8C, CH32V31x_D8C:   0000: PLL input clock x 4; 0011: PLL input clock x 5;   0100: PLL input clock x 8;   0111: PLL input clock x 7;   0110: PLL input clock x 8;   0111: PLL input clock x 9;   1000: PLL input clock x 10; 1001: PLL input clock x 11;   1010: PLL input clock x 12; 1011: PLL input clock x 11;   1010: PLL input clock x 12; 1011: PLL input clock x 13;   1100: PLL input clock x 14; 1101: PLL input clock x 13;   1100: PLL input clock x 14; 1101: PLL input clock x 13;   1100: PLL input clock x 14; 1101: PLL input clock x 16.   1101: PLL inp | [23:22] USBPRE[1:0] | RW | 1010: XT1 external oscillator clock; 1011: PLL3 clock.  Note: This clock output may have some truncated cycles at startup or during MCO clock source switching. The values from 1000 to 1011 are applied for CH32F20x_D8C, CH32V30x_D8C, CH32V31x_D8C.  USBFS/USBOTG clock prescaler configuration: 00: Not divided (When PLLCLK=48MHz); 01: Divided by 2 (When PLLCLK=96MHz); 10: Divided by 3 (When PLLCLK=144MHz); 11: Divided by 5, and PLL source is HSE divided by 2 (PLLCLK=240MHz, only applied for CH32V20x_D8W/CH32F20x_D8W and CH32V20x_D8 lot number where the penultimate digit is greater than 0).  Note: The 11b option is supported for CH32V20x_D8W, CH32F20x_D8W, and CH32V20x_D8 with the penultimate digit of the lot number greater than 0. The option is retained for the remaining models.  The USBD/USBHS module clock requires 48 MHz. This bit must be configured before the USBD and USBHS clocks                                                                                                                                                                                                                                                                                                                                         | 0 |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| 17 PLLXTPRE RW HSE divider for PLL entry (It can be written only when 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                     |    | PLL multiplication factor (These bits can be written only when PLL is disabled):  For CH32F20x_D6, CH32F20x_D8, CH32F20x_D8W, CH32V20x_D6, CH32V20x_D8, CH32V20x_D8W, CH32V30x_D8:  0000: PLL input clock x 2; 0001: PLL input clock x 3; 0010: PLL input clock x 4; 0011: PLL input clock x 5; 0100: PLL input clock x 6; 0101: PLL input clock x 7; 0110: PLL input clock x 8; 0111: PLL input clock x 9; 1000: PLL input clock x 10; 1001: PLL input clock x 11; 1010: PLL input clock x 12; 1011: PLL input clock x 13; 1100: PLL input clock x 14; 1101: PLL input clock x 15; 1110: PLL input clock x 16; 1111: PLL input clock x 18; For CH32F20x_D8C, CH32V30x_D8C, CH32V31x_D8C:  0000: PLL input clock x 18; 0001: PLL input clock x 3; 0010: PLL input clock x 4; 0011: PLL input clock x 5; 0100: PLL input clock x 6; 0101: PLL input clock x 7; 0110: PLL input clock x 10; 1001: PLL input clock x 9; 1000: PLL input clock x 10; 1001: PLL input clock x 11; 1010: PLL input clock x 12; 1011: PLL input clock x 11; 1010: PLL input clock x 12; 1011: PLL input clock x 13; 1100: PLL input clock x 14; 1101: PLL input clock x 13; 1100: PLL input clock x 14; 1101: PLL input clock x 13; 1100: PLL input clock x 14; 1101: PLL input clock x 16. |   |

V2. 4 40 WCH°

|         |             |    | PLL is disabled)                                           | ı |
|---------|-------------|----|------------------------------------------------------------|---|
|         |             |    | For the CH32F20x D8C, CH32V30x D8C series, this bit        |   |
|         |             |    | is reserved.                                               |   |
|         |             |    | 0: HSE clock not divided;                                  |   |
|         |             |    | 1: HSE clock divided by 2.                                 |   |
|         |             |    | For CH32F20x D8C, CH32V30x D8C,                            |   |
|         |             |    | CH32V31x D8C:                                              |   |
|         |             |    | The lowest bit of the PREDIV1 dividing factor is selected  |   |
|         |             |    | by software by setting a 1 or clearing a 0. The PLLXTPRE   |   |
|         |             |    | bit is the same bit as bit [0] of the RCC CFGR2 register,  |   |
|         |             |    | so modifying bit [0] of the RCC CFGR2 register changes     |   |
|         |             |    | this bit at the same time.                                 |   |
|         |             |    | If bits [3:1] of the RCC CFGR2 register are 000b, this bit |   |
|         |             |    | controls PREDIV1 to divide the input clock by 2            |   |
|         |             |    | (PLLXPRE=1) or not divide the input clock                  |   |
|         |             |    | (PLLXPRE=0).                                               |   |
|         |             |    | For CH32F20x D8W, CH32V20x D8W,                            |   |
|         |             |    | CH32V20x D8.                                               |   |
|         |             |    | 0: HSE clock divided by 4;                                 |   |
|         |             |    | 1: HSE clock divided by 8.                                 |   |
|         |             |    | PLL entry clock source (It can be written only when the    |   |
|         |             |    | PLL is disabled):                                          |   |
|         |             |    | For CH32F20x_D6, CH32F20x_D8, CH32V20x_D6,                 |   |
|         |             |    | CH32V30x_D8:                                               |   |
|         |             |    | 0: HSI clock not divided or divided by 2;                  |   |
|         |             |    | 1: HSE clock not divided or divided by 2.                  |   |
|         |             |    |                                                            |   |
|         |             |    | For CH32F20x_D8C, CH32V30x_D8C,                            |   |
| 16      | PLLSRC      | RW | CH32V31x_D8C:                                              | 0 |
|         |             |    | 0: HSI not divided or divided by 2 fed to PLL;             |   |
|         |             |    | 1: PREDIV1 output fed to PLL.                              |   |
|         |             |    |                                                            |   |
|         |             |    | For CH32F20x_D8W, CH32V20x_D8W,                            |   |
|         |             |    | CH32V20x_D8:                                               |   |
|         |             |    | 0: HSI no divided or divided by 2 feed to PLL;             |   |
|         |             |    | 1: HSE divided by 2 or divided by 4 or divided by 8 fed to |   |
|         |             |    | PLL.                                                       |   |
|         |             |    | ADC clock source prescaler control:                        |   |
|         |             |    | 00: PCLK2 divided by 2;                                    |   |
| [15:14] | ADCPRE[1:0] | RW | 01: PCLK2 divided by 4;                                    | 0 |
|         | r . i       |    | 10: PCLK2 divided by 6;                                    |   |
|         |             |    | 11: PCLK2 divided by 8;                                    |   |
|         |             |    | Note: ADC clock shall not exceed 14MHz at most.            |   |

V2. 4 41 WCH°

| [13:11] | PPRE2[2:0] | RW | PB2 clock source prescaler control:  0xx: HCLK not divided;  100: HCLK divided by 2;  101: HCLK divided by 4;  110: HCLK divided by 8;  111: HCLK divided by 16.                                                                                                                                                                                                                                                                 | 0 |
|---------|------------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| [10:8]  | PPRE1[2:0] | RW | PB1 clock source prescaler control:  0xx: HCLK not divided;  100: HCLK divided by 2;  101: HCLK divided by 4;  110: HCLK divided by 8;  111: HCLK divided by 16.                                                                                                                                                                                                                                                                 | 0 |
| [7:4]   | HPRE[3:0]  | RW | HB clock source prescaler control:  0xxx: SYSCLK not divided;  1000: SYSCLK divided by 2;  1001: SYSCLK divided by 4;  1010: SYSCLK divided by 8;  1011: SYSCLK divided by 16;  1100: SYSCLK divided by 64;  1101: SYSCLK divided by 128;  1110: SYSCLK divided by 256;  1111: SYSCLK divided by 512.                                                                                                                            | 0 |
| [3:2]   | SWS[1:0]   | RO | System clock (SYSCLK) switch status (set by hardware): 00: HSI oscillator used as system clock; 01: HSE oscillator used as system clock; 10: PLL oscillator used as system clock; 11: Not applicable.                                                                                                                                                                                                                            | 0 |
| [1:0]   | SW[1:0]    | RW | System clock source switch:  00: HSI oscillator used as system clock;  01: HSE oscillator used as system clock;  10: PLL oscillator used as system clock;  11: Not applicable.  Note: When the system returns from standby and stop modes or when the external oscillator HSE used as the system clock fails after the clock security system is enabled (CSSON=1), HSI is forced to be selected as the system clock by hardware. | 0 |

# 3.4.3 Clock Interrupt Register (RCC\_INTR)

| 31 | 30 | 29 | 28   | 27    | 26 | 25 | 24 | 23   | 22           | 21           | 20          | 19          | 18          | 17          | 16          |
|----|----|----|------|-------|----|----|----|------|--------------|--------------|-------------|-------------|-------------|-------------|-------------|
|    |    |    | Rese | erved |    |    |    | CSSC | PLL3<br>RDYC | PLL2<br>RDYC | PLL<br>RDYC | HSE<br>RDYC | HSI<br>RDYC | LSE<br>RDYC | LSI<br>RDYC |
|    |    |    |      |       |    |    |    |      |              |              |             |             |             |             |             |
| 15 | 14 | 13 | 12   | 11    | 10 | 9  | 8  | 7    | 6            | 5            | 4           | 3           | 2           | 1           | 0           |

| - 1 |   |   |   |     |   |   |   |   |   |   |   |   |   |   |
|-----|---|---|---|-----|---|---|---|---|---|---|---|---|---|---|
| i   | F | E | E | E   | F | F | F | E | F | E | F | F | F | F |
|     | ட | ட | 1 | L L | L | Ľ | ட | 1 | 1 | 1 | 1 | 1 | 1 | 1 |

| Bit     | Name      | Access | Description                                            | Reset value |
|---------|-----------|--------|--------------------------------------------------------|-------------|
| [31:24] | Reserved  | RO     | Reserved                                               | 0           |
|         |           |        | Clock security system interrupt clear flag bit (CSSF): |             |
| 23      | CSSC      | WO     | 0: No action;                                          | 0           |
|         |           |        | 1: Clear CSSF interrupt flag.                          |             |
|         |           |        | PLL3 ready interrupt clear flag bit:                   |             |
|         |           |        | 0: No action;                                          |             |
| 22      | PLL3RDYC  | WO     | 1: Clear PLL3RDYF interrupt flag.                      | 0           |
|         |           |        | Note: Applied for CH32F20x_D8C, CH32V30x_D8C,          |             |
|         |           |        | CH32V31x_D8C.                                          |             |
|         |           |        | PLL2 ready interrupt clear flag bit:                   |             |
|         |           |        | 0: No action;                                          |             |
| 21      | PLL2RDYC  | WO     | 1: Clear PLL2RDYF interrupt flag.                      | 0           |
|         |           |        | Note: Applied for CH32F20x_D8C and                     |             |
|         |           |        | CH32V30x_D8C.                                          |             |
|         |           |        | PLL ready interrupt clear flag bit:                    |             |
| 20      | PLLRDYC   | WO     | 0: No action;                                          | 0           |
|         |           |        | 1: Clear the PLLRDYF interrupt flag.                   |             |
|         |           |        | HSE oscillator ready interrupt clear flag bit:         |             |
| 19      | HSERDYC   | WO     | 0: No action;                                          | 0           |
|         |           |        | 1: Clear HSERDYF interrupt flag.                       |             |
|         |           |        | HSI oscillator ready interrupt clear flag bit:         |             |
| 18      | HSIRDYC   | WO     | 0: No action;                                          | 0           |
|         |           |        | 1: Clear HSIRDYF interrupt flag.                       |             |
|         |           |        | LSE oscillator ready interrupt clear flag bit:         |             |
| 17      | LSERDYC   | WO     | 0: No action;                                          | 0           |
|         |           |        | 1: Clear LSERDYF interrupt flag.                       |             |
|         |           |        | LSI oscillator ready interrupt clear flag bit:         |             |
| 16      | LSIRDYC   | WO     | 0: No action;                                          | 0           |
|         |           |        | 1: Clear LSIRDYF interrupt flag.                       |             |
| 15      | Reserved  | RO     | Reserved                                               | 0           |
|         |           |        | PLL3 ready interrupt enable bit:                       |             |
| 14      | PLL3RDYIE | RW     | 0: Disable PLL3 ready interrupt;                       | 0           |
|         |           |        | 1: Enable PLL3 ready interrupt.                        |             |
|         |           |        | PLL2 ready interrupt enable bit:                       |             |
| 13      | PLL2RDYIE | RW     | 0: Disable PLL2 ready interrupt;                       | 0           |
|         |           |        | 1: Enable PLL2 ready interrupt.                        |             |
|         |           |        | PLL ready interrupt enable bit:                        |             |
| 12      | PLLRDYIE  | RW     | 0: Disable PLL ready interrupt;                        | 0           |
|         |           |        | 1: Enable PLL ready interrupt.                         |             |
|         |           |        | HSE ready interrupt enable bit:                        |             |
| 11      | HSERDYIE  | RW     | 0: Disable HSE ready interrupt;                        | 0           |
|         |           |        | 1: Enable HSE ready interrupt.                         |             |

| 10 | HSIRDYIE   | RW   | HSI ready interrupt enable bit: 0: Disable HSI ready interrupt; | 0 |
|----|------------|------|-----------------------------------------------------------------|---|
|    |            |      | 1: Enable HSI ready interrupt.                                  |   |
|    |            |      | LSE ready interrupt enable bit:                                 |   |
| 9  | LSERDYIE   | RW   | 0: Disable LSE ready interrupt;                                 | 0 |
|    |            |      | 1: Enable LSE ready interrupt.                                  |   |
|    |            |      | LSI ready interrupt enable bit:                                 |   |
| 8  | LSIRDYIE   | RW   | 0: Disable LSI ready interrupt;                                 | 0 |
| O  | ESIRE TIE  | 1011 | 1: Enable LSI ready interrupt.                                  | Ü |
|    |            |      | Clock security system interrupt flag bit:                       |   |
|    |            |      | 0: No clock security system interrupt caused by HSE             |   |
|    |            |      | clock failure;                                                  |   |
| 7  | CSSF       | RO   | 1: Clock security interrupt caused by HSE clock failure.        | 0 |
|    |            |      | Set by hardware. Write 1 to CSSC bit by software to             |   |
|    |            |      | clear.                                                          |   |
|    |            |      | PLL3 clock ready interrupt flag:                                |   |
|    |            |      | 0: No clock ready interrupt riag:                               |   |
|    |            |      | 1: Clock ready interrupt caused by PLL3 clock,                  |   |
| (  | DI I 2DDVE | DO.  |                                                                 | 0 |
| 6  | PLL3RDYF   | RO   | Set by hardware. Write 1 to PLL3RDYC by software to             | U |
|    |            |      | clear.                                                          |   |
|    |            |      | Note: Applied for CH32F20x_D8C, CH32V30x_D8C,                   |   |
|    |            |      | CH32V31x_D8C.                                                   |   |
|    |            |      | PLL2 clock ready interrupt flag:                                |   |
|    |            |      | 0: No clock ready interrupt caused by PLL2 clock;               |   |
| _  |            |      | 1: Clock ready interrupt caused by PLL2 clock.                  |   |
| 5  | PLL2RDYF   | RO   | Set by hardware. Write 1 to PLL2RDYC by software to             | 0 |
|    |            |      | clear.                                                          |   |
|    |            |      | Note: Applied for CH32F20x_D8C, CH32V30x_D8C,                   |   |
|    |            |      | CH32V31x_D8C.                                                   |   |
|    |            |      | PLL clock ready interrupt flag:                                 |   |
|    |            |      | 1: Clock ready interrupt caused by PLL clock;                   |   |
| 4  | PLLRDYF    | RO   | 0: No clock ready interrupt caused by PLL clock.                | 0 |
|    |            |      | Set by hardware. Write 1 to PLLRDYC by software to              |   |
|    |            |      | clear.                                                          |   |
|    |            |      | HSE clock ready interrupt flag:                                 |   |
|    |            |      | 0: No clock ready interrupt caused by HSE clock;                |   |
| 3  | HSERDYF    | RO   | 1: Clock ready interrupt caused by HSE clock.                   | 0 |
|    |            |      | Set by hardware. Write 1 to HSERDYC bit by software             |   |
|    |            |      | to clear.                                                       |   |
|    |            |      | HSI clock ready interrupt flag:                                 |   |
|    |            |      | 0: No clock ready interrupt caused by HSI clock;                |   |
| 2  | HSIRDYF    | RO   | 1: Clock ready interrupt caused by HSI clock.                   | 0 |
|    |            |      | Set by hardware. Write 1 to HSIRDYC bit by software             |   |
|    |            |      | to clear.                                                       |   |
| 1  | I CEDDVE   | RO   | LSE clock ready interrupt flag:                                 |   |
| 1  | LSERDYF    | KU   | 0: No clock ready interrupt caused by LSE clock;                | 0 |

V2. 4 44 WCH°

|   |         |    | 1: Clock ready interrupt caused by LSE clock.          |   |
|---|---------|----|--------------------------------------------------------|---|
|   |         |    | Set by hardware. Write 1 to LSERDYC bit by software    |   |
|   |         |    | to clear.                                              |   |
|   |         |    | LSI clock ready interrupt flag:                        |   |
|   |         |    | 0: No clock ready interrupt caused by LSI clock;       |   |
| 0 | LSIRDYF | RO | 1: Clock ready interrupt caused by LSI clock.          | 0 |
|   |         |    | Set by hardware. Write 1 to LSIRDYC bit by software to |   |
|   |         |    | clear.                                                 |   |

# 3.4.4 PB2 Peripheral Reset Register (RCC\_APB2PRSTR)

| 31           | 30                | 29          | 28          | 27          | 26          | 25          | 24   | 23    | 22          | 21          | 20               | 19          | 18          | 17           | 16          |
|--------------|-------------------|-------------|-------------|-------------|-------------|-------------|------|-------|-------------|-------------|------------------|-------------|-------------|--------------|-------------|
|              | Reserved          |             |             |             |             |             |      |       |             |             | TIM1<br>0<br>RST | TIM9<br>RST | F           | Reserve      | d           |
| 15           | 14                | 13          | 12          | 11          | 10          | 9           | 8    | 7     | 6           | 5           | 4                | 3           | 2           | 1            | 0           |
| Reser<br>ved | USAR<br>T1<br>RST | TIM8<br>RST | SPI1<br>RST | TIM1<br>RST | ADC2<br>RST | ADC1<br>RST | Rese | erved | IOPE<br>RST | IOPD<br>RST | IOPC<br>RST      | IOPB<br>RST | IOPA<br>RST | Reser<br>ved | AFIO<br>RST |

| Bit      | Name       | Access | Description                    | Reset value |
|----------|------------|--------|--------------------------------|-------------|
| [31:21]  | Reserved   | RO     | Reserved.                      | 0           |
| 20       | TIMIODOT   | DW     | TIM10 reset:                   | 0           |
| 20       | TIM10RST   | RW     | 0: No effect; 1: Reset TIM10.  | 0           |
| 10       | TIMODOT    | DW     | TIM9 reset:                    | 0           |
| 19       | TIM9RST    | RW     | 0: No effect; 1: Reset TIM9t.  | 0           |
| [18:15]  | Reserved   | RO     | Reserved.                      | 0           |
| 1.4      | LICADTIDET | DW     | USART1 reset:                  | 0           |
| 14       | USART1RST  | RW     | 0: No effect; 1: Reset USART1. | 0           |
| 1.2      | TIMODET    | RW     | TIM8 reset:                    | 0           |
| 13       | TIM8RST    | KW     | 0: No effect; 1: Reset TIM8.   | 0           |
| 12       | SPI1RST    | RW     | SPI1 reset:                    | 0           |
| 12       | SPIIKSI    | KW     | 0: No effect; 1: Reset SPI1.   |             |
| 11       | TIM1RST    | RW     | TIM1 reset:                    | 0           |
| 11       | TIMIKSI    | KW     | 0: No effect; 1: Reset TIM1.   | U           |
| 10       | ADC2RST    | RW     | ADC2 reset:                    | 0           |
| 10       | ADC2K51    | IX VV  | 0: No effect; 1: Reset ADC2.   | U           |
| 9        | ADC1RST    | RW     | ADC1 reset:                    | 0           |
| <i>,</i> | ADCIKSI    | IXW    | 0: No effect; 1: Reset ADC1.   | U           |
| [8:7]    | Reserved   | RO     | Reserved                       | 0           |
| 6        | IOPERST    | RW     | IO port PE reset:              | 0           |
|          | IOI EKS1   | IXW    | 0: No effect; 1: Reset PE.     | U           |
| 5        | IOPDRST    | RW     | IO port PD reset:              | 0           |
| <i>J</i> | IOI DIXS I | IX VV  | 0: No effect; 1: Reset PD.     | U           |
| 4        | IOPCRST    | RW     | IO port PC reset:              | 0           |
| 4        | IOFCKSI    | IX VV  | 0: No effect; 1: Reset PC.     | 0           |

| , | IOPBRST  | DW    | IO port PB reset:                          | 0 |
|---|----------|-------|--------------------------------------------|---|
| 3 | IOPBRST  | RW    | 0: No effect; 1: Reset PB.                 | 0 |
| 2 | IOPARST  | RW    | IO port PA reset:                          | 0 |
|   | IOPARST  | IX VV | 0: No effect; 1: Reset PA.                 | 0 |
| 1 | Reserved | RO    | Reserved                                   | 0 |
| 0 | AFIORST  | RW    | Alternate function IO reset:               | 0 |
| 0 | AFIORSI  | ΚW    | 0: No effect; 1: Reset alternate function. | 0 |

## 3.4.5 PB1 Peripheral Reset Register (RCC\_APB1PRSTR)

Offset address: 0x10

| 31   | 30    | 29         | 28         | 27         | 26              | 25              | 24           | 23              | 22          | 21          | 20                | 19                | 18                | 17                | 16           |
|------|-------|------------|------------|------------|-----------------|-----------------|--------------|-----------------|-------------|-------------|-------------------|-------------------|-------------------|-------------------|--------------|
| Rese | erved | DAC<br>RST | PWR<br>RST | BKP<br>RST | CAN<br>2<br>RST | CAN<br>1<br>RST | Reser<br>ved | USB<br>D<br>RST | I2C2<br>RST | I2C1<br>RST | USA<br>RT5<br>RST | USA<br>RT4<br>RST | USART<br>3<br>RST | USART<br>2<br>RST | Rese<br>rved |
| 15   | 14    | 13         | 12         | 11         | 10              | 9               | 8            | 7               | 6           | 5           | 4                 | 3                 | 2                 | 1                 | 0            |
|      |       |            |            |            |                 |                 |              | ,               |             |             |                   |                   |                   |                   |              |

| Bit     | Name        | Access | Description                               | Reset value |
|---------|-------------|--------|-------------------------------------------|-------------|
| [31:30] | Reserved    | RO     | Reserved.                                 | 0           |
| 29      | DACRST      | RW     | DAC module reset:                         | 0           |
| 29      | DACKSI      | KW     | 0: No effect; 1: Reset DAC.               | U           |
| 28      | PWRRST      | RW     | Power interface module reset:             | 0           |
| 20      | r wkksi     | IX VV  | 0: No effect; 1: Reset Power interface.   | U           |
| 27      | BKPRST      | RW     | Backup interface reset:                   | 0           |
| 21      | DKFKS1      | IX VV  | 0: No effect; 1: Reset back-up interface. | U           |
| 26      | CAN2RST     | RW     | CAN2 module reset:                        | 0           |
| 20      | CANZKST     | IXVV   | 0: No effect; 1: Reset CAN2.              | U           |
| 25      | CAN1RST     | RW     | CAN1 module reset:                        | 0           |
| 23      | CANTRST     | IXVV   | 0: No effect; 1: Reset CAN1.              | U           |
| 24      | Reserved    | RO     | Reserved                                  | 0           |
| 23      | USBDRST     | RW     | USBD module reset:                        | 0           |
| 23      | OSDDKST     | IXVV   | 0: No effect; 1: Reset USBD.              | U           |
| 22      | I2C2RST     | RW     | I2C2 interface reset:                     | 0           |
| 22      | 12C2K31     | IXVV   | 0: No effect; 1: Reset I2C2.              | U           |
| 21      | I2C1RST     | RW     | I2C1 interface reset:                     | 0           |
| 21      | IZCIRSI     | ICVV   | 0: No effect; 1: Reset I2C1.              | U           |
| 20      | USART5RST   | RW     | USART5 interface reset:                   | 0           |
| 20      | OSAKI SKS I | ICVV   | 0: No effect; 1: Reset USART5.            | U           |
| 19      | USART4RST   | RW     | USART4 interface reset:                   | 0           |
| 17      | USAKI 4KS I | ICVV   | 0: No effect; 1: Reset USART4.            | U           |
| 18      | USART3RST   | RW     | USART3 interface reset:                   | 0           |
| 10      | OBARTSRST   | 17. 44 | 0: No effect; 1: Reset USART3.            | U           |
| 17      | USART2RST   | RW     | USART2 interface reset:                   | 0           |

V2. 4 46 WCH°

|         |            |       | 0: No effect;           | 1: Reset USART2.          |   |
|---------|------------|-------|-------------------------|---------------------------|---|
| 16      | Reserved   | RO    | Reserved                |                           | 0 |
| 15      | SPI3RST    | RW    | SPI3 interface reset:   |                           | 0 |
| 13      | SFISKSI    | IX VV | 0: No effect;           | 1: Reset SPI3.            | U |
| 14      | SPI2RST    | RW    | SPI2 interface reset:   |                           | 0 |
| 17      | 51 12 13 1 | IX VV | 0: No effect;           | 1: Reset SPI2.            | U |
| [13:12] | Reserved   | RO    | Reserved                |                           | 0 |
| 11      | WWDGRST    | RW    | Window watchdog reset:  |                           | 0 |
| 11      | W WDGR51   | ICVV  | 0: No effect;           | 1: Reset window watchdog. | U |
| [10:9]  | Reserved   | RO    | Reserved                |                           | 0 |
| 8       | USART8RST  | RW    | USART8 interface reset: |                           | 0 |
|         | CSARTORST  | IX VV | 0: No effect;           | 1: Reset USART8.          | U |
| 7       | USART7RST  | RW    | USART7 interface reset: |                           | 0 |
|         | CS/IKT/KST | ICW   | 0: No effect;           | 1: Reset USART7.          | V |
| 6       | USART6RST  | RW    | USART6 interface reset: |                           | 0 |
|         | CS/IKTOKST | IX W  | 0: No effect;           | 1: Reset USART6.          | V |
| 5       | TIM7RST    | RW    | Timer7 module reset:    |                           | 0 |
|         | THVI/ICST  | 10,1  | 0: No effect;           | 1: Reset Timer7.          | 0 |
| 4       | TIM6RST    | RW    | Timer6 module reset:    |                           | 0 |
|         | Thirons    | 10,1  |                         | 1: Reset Timer6.          |   |
| 3       | TIM5RST    | RW    | Timer5 module reset:    |                           | 0 |
|         | Thvistoi   | 1000  |                         | 1: Reset Timer5.          |   |
| 2       | TIM4RST    | RW    | Timer4 module reset:    |                           | 0 |
|         |            | 10,,  |                         | 1: Reset Timer4.          |   |
| 1       | TIM3RST    | RW    | Timer3 module reset:    |                           | 0 |
| •       | -11.101.01 | 10,7  |                         | 1: Reset Timer3.          |   |
| 0       | TIM2RST    | RW    | Timer2 module reset:    |                           | 0 |
|         |            | 11.,  | 0: No effect;           | 1: Reset Timer2.          |   |

## 3.4.6 HB Peripheral Clock Enable Register (RCC\_AHBPCENR)

| 31                 | 30 | 29 | 28               | 27          | 26         | 25        | 24         | 23           | 22        | 21           | 20           | 19           | 18         | 17         | 16                      |
|--------------------|----|----|------------------|-------------|------------|-----------|------------|--------------|-----------|--------------|--------------|--------------|------------|------------|-------------------------|
|                    |    |    |                  |             |            | Rese      | erved      |              |           |              |              |              |            |            | ETHMA<br>CRXEN<br>/BLEC |
| 15                 | 14 | 13 | 12               | 11          | 10         | 9         | 8          | 7            | 6         | 5            | 4            | 3            | 2          | 1          | 0                       |
| ETHM<br>ACTX<br>EN |    |    | OTG<br>_FSE<br>N | USBHS<br>EN | SDIO<br>EN | RNG<br>EN | FSM<br>CEN | Reser<br>ved | CRC<br>EN | Reser<br>ved | Reser<br>ved | Reser<br>ved | SRAM<br>EN | DMA2<br>EN | DMA1<br>EN              |

| Bit     | Name     | Access | Description             | Reset value |
|---------|----------|--------|-------------------------|-------------|
| [31:18] | Reserved | RO     | Reserved                | 0           |
|         |          |        | BLES clock enable:      |             |
| 17      | BLES     | RW     | 0: BLES clock disabled; | 1           |
|         |          |        | 1: BLES clock enabled.  |             |

|    |            |        | Note: Applied for CH32V20x_D8W and CH32F20x_D8W.                           |   |
|----|------------|--------|----------------------------------------------------------------------------|---|
|    |            |        | BLEC clock enable:                                                         |   |
|    |            |        | 0: BLEC clock disabled;                                                    |   |
| 16 | BLEC       | RW     | 1: BLEC clock enabled.                                                     | 1 |
|    |            |        | Note: Applied for CH32V20x_D8W and CH32F20x_D8W.                           |   |
|    |            |        | Ethernet MAC receive clock enable:                                         |   |
|    |            |        | 0: Ethernet MAC receive clock disabled;                                    |   |
| 16 | ETHMACRXEN | RW     | 1: Ethernet MAC receive clock enabled.                                     | 0 |
|    |            |        | Note: Applied for CH32V30x D8C, CH32V31x D8C,                              |   |
|    |            |        | CH32F20x D8C with 100M/Gigabit external PHY.                               |   |
|    |            |        | Ethernet MAC transmit clock enable:                                        |   |
|    |            |        | 0: Ethernet MAC transmit clock disabled;                                   |   |
| 15 | ETHMACTXEN | RW     | 1: Ethernet MAC transmit clock enabled.                                    | 0 |
| 10 |            | 2277   | Note: Applied for CH32V30x D8C, CH32V31x D8C,                              | Ü |
|    |            |        | CH32F20x D8C with 100M/Gigabit external PHY.                               |   |
|    |            |        | Ethernet MAC clock enable:                                                 |   |
|    |            |        | 0: Ethernet MAC clock disabled;                                            |   |
| 14 | ETHMACEN   | RW     | 1: Ethernet MAC clock enabled.                                             | 0 |
| 17 | BITHMACEN  | 17. 44 | Note: Applied for CH32V30x D8C, CH32V31x D8C,                              | U |
|    |            |        |                                                                            |   |
|    |            |        | CH32F20x_D8C with 100M/Gigabit external PHY.  DVP module clock enable bit: |   |
| 12 | DVDEN      | DW     |                                                                            | 0 |
| 13 | DVPEN      | RW     | 0: DVP clock disabled;                                                     | 0 |
|    |            |        | 1: DVP clock enabled.                                                      |   |
| 10 | ome Feel   | DIII   | USBOTG_FS module clock enable bit:                                         | 0 |
| 12 | OTG_FSEN   | RW     | 0: USBOTG_FS clock disabled;                                               | 0 |
|    |            |        | 1: USBOTG_FS clock enabled.                                                |   |
|    |            |        | USBHS module clock enable bit:                                             |   |
| 11 | USBHSEN    | RW     | 0: USBHS clock disabled;                                                   | 0 |
|    |            |        | 1: USBHS clock enabled.                                                    |   |
|    |            |        | SDIO module clock enable bit:                                              |   |
| 10 | SDIOEN     | RW     | 0: SDIO clock disabled;                                                    | 0 |
|    |            |        | 1: SDIO clock enabled.                                                     |   |
|    |            |        | RNG module clock enable bit:                                               |   |
| 9  | RNGEN      | RW     | 0: RNG clock disabled;                                                     | 0 |
|    |            |        | 1: RNG clock enabled.                                                      |   |
|    |            |        | FSMCEN module clock enable bit:                                            |   |
| 8  | FSMCEN     | RW     | 0: FSMCEN clock disabled;                                                  | 0 |
|    |            |        | 1: FSMCEN clock enabled.                                                   |   |
| 7  | Reserved   | RO     | Reserved                                                                   | 0 |
|    |            |        | CRC module clock enable bit:                                               |   |
| 6  | CRCEN      | RW     | 0: CRC clock disabled;                                                     | 0 |
|    |            |        | 1: CRC clock enabled.                                                      |   |
| 5  | Reserved   | RO     | Reserved                                                                   | 0 |
| 4  | Reserved   | RO     | Reserved                                                                   | 0 |
| 3  | Reserved   | RO     | Reserved                                                                   | 0 |
| 2  | SRAMEN     | RW     | SRAM interface clock enable bit:                                           | 1 |

|   |        |    | 0: In sleep mode, SRAM interface clock disabled; |   |
|---|--------|----|--------------------------------------------------|---|
|   |        |    | 1: In sleep mode, SRAM interface clock enabled;  |   |
|   |        |    | DMA2 module clock enable bit:                    |   |
| 1 | DMA2EN | RW | 0: DMA2 clock disabled;                          | 0 |
|   |        |    | 1: DMA2 clock enabled.                           |   |
|   |        |    | DMA1 module clock enable bit:                    |   |
| 0 | DMA1EN | RW | 0: DMA1 clock disabled;                          | 0 |
|   |        |    | 1: DMA1 clock enabled.                           |   |

## 3.4.7 PB2 Peripheral Clock Enable Register (RCC\_APB2PCENR)

Offset address: 0x18

| 31           | 30           | 29         | 28         | 27         | 26         | 25         | 24   | 23    | 22         | 21         | 20          | 19         | 18         | 17           | 16         |
|--------------|--------------|------------|------------|------------|------------|------------|------|-------|------------|------------|-------------|------------|------------|--------------|------------|
|              | Received     |            |            |            |            |            |      |       |            |            | TIM1<br>0EN | TIM9<br>EN | R          | Reserve      | d          |
| 15           | 14           | 13         | 12         | 11         | 10         | 9          | 8    | 7     | 6          | 5          | 4           | 3          | 2          | 1            | 0          |
| Reser<br>ved | USART<br>1EN | TIM8<br>EN | SPI1<br>EN | TIM1<br>EN | ADC2<br>EN | ADC1<br>EN | Rese | erved | IOPE<br>EN | IOPD<br>EN | IOPC<br>EN  | IOPB<br>EN | IOPA<br>EN | Reser<br>ved | AFIO<br>EN |

| Bit     | Name     | Access | Description                                        | Reset value |
|---------|----------|--------|----------------------------------------------------|-------------|
| [31:21] | Reserved | RO     | Reserved.                                          | 0           |
| 20      | TIM10EN  | RW     | TIM10 interface clock enable bit:                  | 0           |
| 20      | TIMITUEN | KW     | 0: TIM10 clock disabled; 1: TIM10 clock enabled.   | U           |
| 19      | TIM9EN   | RW     | TIM9 interface clock enable bit:                   | 0           |
| 19      | THVISEN  | I K VV | 0: TIM9 clock disabled; 1: TIM9 clock enabled.     | U           |
| [18:15] | Reserved | RO     | Reserved.                                          | 0           |
| 14      | USART1EN | RW     | USART1 interface clock enable bit:                 | 0           |
| 14      | USAKITEN | IX W   | 0: USART1 clock disabled; 1: USART1 clock enabled. | U           |
| 13      | TIM8EN   | RW     | TIM8 module clock enable bit:                      | 0           |
| 13      | THVIOLIV | IXW    | 0: TIM8 clock disabled; 1: TIM8 clock enabled.     | V           |
| 12      | SPI1EN   | RW     | SPI1 interface clock enable bit:                   | 0           |
| 12      | STILLY   | IX VV  | 0: SPI1 clock disabled; 1: SPI1 clock enabled.     | V           |
| 11      | TIM1EN   | RW     | TIM1 module clock enable bit:                      | 0           |
| 11      | THITTE   | 10,11  | 0: TIM1 clock disabled; 1: TIM1 clock enabled.     |             |
| 10      | ADC2EN   | RW     | ADC2 module clock enable bit:                      | 0           |
|         | TIDCZEIV | 10,11  | 0: ADC2 clock disabled; 1: ADC2 clock enabled.     |             |
| 9       | ADC1EN   | RW     | ADC1 module clock enable bit:                      | 0           |
|         |          |        | 0: ADC1 clock disabled; 1: ADC1 clock enabled.     |             |
| [8:7]   | Reserved | RO     | Reserved.                                          | 0           |
| 6       | IOPEEN   | RW     | IO port PE clock enable bit:                       | 0           |
|         | TOT EET  | 1011   | 0: PE clock disabled; 1: PE clock enabled.         |             |
| 5       | IOPDEN   | RW     | IO port PD clock enable bit:                       | 0           |
|         | 3 IOFDEN |        | 0: PD clock disabled; 1: PD clock enabled.         |             |
| 4       | IOPCEN   | RW     | IO port PC clock enable bit:                       | 0           |
|         |          |        | 0: PC clock disabled; 1: PC clock enabled.         |             |
| 3       | IOPBEN   | RW     | IO port PB clock enable bit:                       | 0           |

V2. 4 49 WCH°

|   |          |      | 0: PB clock disabled; 1: PB clock enabled. |   |
|---|----------|------|--------------------------------------------|---|
| 2 | IOPAEN   | RW   | IO port PA clock enable bit:               | 0 |
|   | IOPAEN   | IX W | 0: PA clock disabled; 1: PA clock enabled. | U |
| 1 | Reserved | RO   | Reserved.                                  | 0 |
|   |          |      | Alternate function IO clock enable bit:    |   |
| 0 | AFIOEN   | RW   | 0: Alternate function IO clock disabled;   | 0 |
|   |          |      | 1: Alternate function IO clock enabled;    |   |

## 3.4.8 PB1 Peripheral Clock Enable Register (RCC\_APB1PCENR)

| 31         | 30         | 29        | 28        | 27             | 26             | 25             | 24               | 23               | 22               | 21         | 20               | 19               | 18               | 17               | 16           |
|------------|------------|-----------|-----------|----------------|----------------|----------------|------------------|------------------|------------------|------------|------------------|------------------|------------------|------------------|--------------|
| Rese       | erved      | DAC<br>EN | PWR<br>EN | BKP<br>EN      | CAN<br>2<br>EN | CAN<br>1<br>EN | Reser<br>ved     | USB<br>D<br>EN   | I2C2<br>EN       | I2C1<br>EN | USAR<br>T5<br>EN | USAR<br>T4<br>EN | USAR<br>T3<br>EN | USAR<br>T2<br>EN | Reser<br>ved |
| 15         | 14         | 13        | 12        | 11             | 10             | 9              | 8                | 7                | 6                | 5          | 4                | 3                | 2                | 1                | 0            |
| SPI3<br>EN | SPI2<br>EN | Rese      | erved     | WW<br>DG<br>EN | Rese           | erved          | USA<br>RT8E<br>N | USA<br>RT7E<br>N | USA<br>RT6E<br>N | TIM7<br>EN | TIM6<br>EN       | TIM5<br>EN       | TIM4<br>EN       | TIM3<br>EN       | TIM2<br>EN   |

| Bit     | Name        | Access | Description                                        | Reset value |  |
|---------|-------------|--------|----------------------------------------------------|-------------|--|
| [31:30] | Reserved    | RO     | Reserved.                                          | 0           |  |
| 29      | DACEN       | RW     | DAC module clock enable bit:                       | 0           |  |
| 29      | DACEN       |        | 0: DAC clock disabled; 1: DAC clock enabled.       | 0           |  |
|         |             |        | Power interface clock enable bit:                  |             |  |
| 28      | PWREN       | RW     | 0: Power interface clock disabled;                 | 0           |  |
|         |             |        | 1: Power interface clock enabled.                  |             |  |
|         |             |        | Backup interface clock enable bit:                 |             |  |
| 27      | BKPEN       | RW     | 1: Backup interface clock enabled;                 | 0           |  |
|         |             |        | 0: Backup interface clock disabled.                |             |  |
| 26      | CANOENI     | RW     | CAN2 module clock enable bit:                      | 0           |  |
| 26      | CAN2EN      | RW     | 0: CAN2 clock disabled; 1: CAN2 clock enabled.     | 0           |  |
| 25      | CANITENI    | RW     | CAN1 module clock enable bit:                      | 0           |  |
| 25      | CAN1EN      | KW     | 0: CAN1 clock disabled; 1: CAN1 clock enabled.     | 0           |  |
| 24      | Reserved    | RO     | Reserved                                           | 0           |  |
| 23      | USBDEN      | RW     | USBD module clock enable bit:                      | 0           |  |
| 23      | USBDEN      | KW     | 0: USBD clock disabled; 1: USBD clock enabled.     | U           |  |
| 22      | I2C2EN      | RW     | I2C2 interface clock enable bit:                   | 0           |  |
| 22      | I2C2EN      | RW     | 0: I2C2 clock disabled; 1: I2C2 clock enabled.     | 0           |  |
| 21      | I2C1EN      | RW     | I2C1 interface clock enable bit:                   | 0           |  |
| 21      | I2C1EN      | RW     | 0: I2C1 clock disabled; 1: I2C1 clock enabled.     | 0           |  |
| 20      | LICADTEEN   | DW     | USART5 interface clock enable bit:                 | 0           |  |
| 20      | USART5EN    | RW     | 0: USART5 clock disabled; 1: USART5 clock enabled. | 0           |  |
| 10      | LICADTAENI  | RW     | USART4 interface clock enable bit:                 | 0           |  |
| 19      | 19 USART4EN |        | 0: USART4 clock disabled; 1: USART4 clock enabled. | U           |  |
| 18      | USART3EN    | RW     | USART3 interface clock enable bit:                 | 0           |  |

|         |              |       | 0: USART3 clock disabled; 1: USART3 clock enabled. |          |
|---------|--------------|-------|----------------------------------------------------|----------|
| 17      | LICADTOEN    | RW    | USART2 interface clock enable bit:                 | 0        |
| 17      | USART2EN     | RW    | 0: USART2 clock disabled; 1: USART2 clock enabled. | U        |
| 16      | Reserved     | RO    | Reserved                                           | 0        |
| 1.5     | CDIZENI      | DW    | SPI3interface clock enable bit:                    | 0        |
| 15      | SPI3EN       | RW    | 0: SPI3 clock disabled; 1: SPI3 clock enabled.     | 0        |
| 14      | SPI2EN       | RW    | SPI2interface clock enable bit:                    | 0        |
| 14      | SPIZEN       | KW    | 0: SPI2 clock disabled; 1: SPI2 clock enabled      | <u> </u> |
| [13:12] | Reserved     | RO    | Reserved                                           | 0        |
|         |              |       | Window watchdog clock enable bit:                  |          |
| 11      | WWDGEN       | RW    | 0: Window watchdog clock disabled;                 | 0        |
|         |              |       | 1: Window watchdog clock enabled;                  |          |
| [10:9]  | Reserved     | RO    | Reserved                                           | 0        |
|         |              |       | USART8 enable bit:                                 |          |
| 8       | USART8EN     | RW    | 0: USART8 clock disabled;                          | 0        |
|         |              |       | 1: USART8 clock enabled.                           |          |
| 7       | USART7EN     | RW    | USART7 enable bit:                                 | 0        |
| ,       | OSAKI /LIV   | ICVV  | 0: USART7 clock disabled; 1: USART7 clock enabled. |          |
| 6       | USART6EN     | RW    | USART6 enable bit:                                 | 0        |
| 0       | OS/ HCT OLIV | ICVV  | 0: USART6 clock disabled; 1: USART6 clock enabled. | 0        |
| 5       | TIM7EN       | RW    | Timer7 module clock enable bit:                    | 0        |
|         | THVITEIN     | ICVV  | 0: Timer7 clock disabled; 1: Timer7 clock enabled. |          |
| 4       | TIM6EN       | RW    | Timer6 module clock enable bit:                    | 0        |
|         | THVIOLIT     | 10,1  | 0: Timer6 clock disabled; 1: Timer6 clock enabled. |          |
| 3       | TIM5EN       | RW    | Timer5 module clock enable bit:                    | 0        |
|         | THVISEIV     | 10,1  | 0: Timer5 clock disabled; 1: Timer5 clock enabled. |          |
| 2       | TIM4EN       | RW    | Timer4 module clock enable bit:                    | 0        |
|         | 11111111     | 12,11 | 0: Timer4 clock disabled; 1: Timer4 clock enabled. |          |
| 1       | TIM3EN       | RW    | Timer3 module clock enable bit:                    | 0        |
| 1       | 11113111     | 10,7  | 0: Timer3 clock disabled; 1: Timer3 clock enabled. |          |
| 0       | TIM2EN       | RW    | Timer2 module clock enable bit:                    | 0        |
| J       | 111112111    | 10,11 | 0: Timer2 clock disabled; 1: Timer2 clock enabled. |          |

## 3.4.9 Backup Domain Control Register (RCC\_BDCTLR)



| Bit     | Name     | Access | Description                           | Reset value |
|---------|----------|--------|---------------------------------------|-------------|
| [31:17] | Reserved | RO     | Reserved.                             | 0           |
| 16      | BDRST    | RW     | Backup domain software reset control: | 0           |

|              |                                                        | 0: Reset not activated;                                        |                                    |
|--------------|--------------------------------------------------------|----------------------------------------------------------------|------------------------------------|
|              |                                                        | 1: Reset the entire backup domain.                             |                                    |
|              |                                                        | RTC clock enable control:                                      |                                    |
|              |                                                        | 0: RTC clock disabled;                                         |                                    |
| RTCEN        | RW                                                     |                                                                | 0                                  |
|              |                                                        |                                                                |                                    |
|              |                                                        | -                                                              |                                    |
| Reserved     | RO                                                     |                                                                | 0                                  |
|              |                                                        |                                                                |                                    |
|              |                                                        |                                                                |                                    |
|              |                                                        |                                                                |                                    |
|              |                                                        |                                                                |                                    |
|              |                                                        |                                                                |                                    |
|              |                                                        |                                                                |                                    |
|              |                                                        |                                                                |                                    |
|              |                                                        |                                                                |                                    |
| DTCCEL [1.0] | DW                                                     |                                                                | 0                                  |
| KICSEL[1:0]  | IX VV                                                  |                                                                | U                                  |
|              |                                                        |                                                                |                                    |
|              |                                                        |                                                                |                                    |
|              |                                                        |                                                                |                                    |
|              |                                                        |                                                                |                                    |
|              |                                                        |                                                                |                                    |
|              |                                                        |                                                                |                                    |
|              |                                                        |                                                                |                                    |
|              |                                                        |                                                                |                                    |
| Reserved     | RO                                                     |                                                                | 0                                  |
|              |                                                        |                                                                |                                    |
| LSEBYP       | RW                                                     |                                                                | 0                                  |
|              | 12                                                     |                                                                | Ū                                  |
|              |                                                        | Note: This bit can be written only when LSEON is 0.            |                                    |
|              |                                                        | External low-speed oscillator ready flag bit (Set by           |                                    |
|              |                                                        | hardware):                                                     |                                    |
| I SERDV      | RO                                                     | 0: LSE oscillator not ready;                                   | 0                                  |
| LSERDT       | RO                                                     | 1: LSE oscillator ready.                                       | U                                  |
|              |                                                        | Note: After the LSEON bit is cleared, it takes 6 cycles of     |                                    |
|              |                                                        | LSE clock to clear this bit.                                   |                                    |
|              |                                                        | External low-speed crystal oscillator enable control bit:      |                                    |
| LSEON        | RW                                                     | 0: LSE oscillator disabled;                                    | 0                                  |
|              |                                                        | 1: LSE oscillator enabled.                                     |                                    |
|              | RTCEN  Reserved  RTCSEL[1:0]  Reserved  LSEBYP  LSERDY | Reserved RO  RTCSEL[1:0] RW  Reserved RO  LSEBYP RW  LSERDY RO | I: Reset the entire backup domain. |

Note: The LSEON, LSEBYP, RTCSEL and RTCEN bits in the backup domain control register (RCC\_BDCTLR) are in the backup domain. Therefore, these bits are in a write-protected status after reset, and these bits can only be changed after the DBP bit in the power control register (PWR\_CTLR) is set to 1. These bits can only be cleared by the backup domain reset. Any internal or external reset will not affect these bits.

V2. 4 52 WH

# 3.4.10 Control/Status Register (RCC\_RSTSCKR)

| 31               | 30               | 29               | 28          | 27          | 26          | 25           | 24       | 23 | 22 | 21 | 20   | 19         | 18        | 17 | 16 |
|------------------|------------------|------------------|-------------|-------------|-------------|--------------|----------|----|----|----|------|------------|-----------|----|----|
| LPW<br>RRST<br>F | WW<br>DGR<br>STF | IWD<br>GRS<br>TF | SFT<br>RSTF | POR<br>RSTF | PIN<br>RSTF | Reser<br>ved | RMV<br>F |    |    |    | Rese | erved      |           |    |    |
| 15               | 14               | 13               | 12          | 11          | 10          | 9            | 8        | 7  | 6  | 5  | 4    | 3          | 2         | 1  | 0  |
|                  | Reserved         |                  |             |             |             |              |          |    |    |    |      | LSI<br>RDY | LSIO<br>N |    |    |

| Bit | Name     | Access | Description                                                                                                                                                                                                                     | Reset value |
|-----|----------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| 31  | LPWRRSTF | RO     | Low-power reset flag:  0: No low-power reset occurred;  1: Low-power reset occurred.  When low-power management reset occurs, set by hardware. Cleared by writing to the RMVF bit by software.                                  | 0           |
| 30  | WWDGRSTF | RO     | Window watchdog reset flag:  0: No window watchdog reset occurred;  1: Window watchdog reset occurred.  When the window watchdog reset occurs, set by hardware. Cleared by writing to the RMVF bit by software.                 | 0           |
| 29  | IWDGRSTF | RO     | Independent watchdog reset flag:  0: No independent watchdog reset occurred;  1: Independent watchdog reset occurred.  When independent watchdog reset occurs, set by hardware. Cleared by writing to the RMVF bit by software. | 0           |
| 28  | SFTRSTF  | RO     | Software reset flag: 0: No software reset occurred; 1: Software reset occurred. When software reset occurs, set by hardware. Cleared by writing to the RMVF bit by software.                                                    | 0           |
| 27  | PORRSTF  | RO     | Power-on/power-down reset flag:  0: No power-on/power-down reset occurred;  1: Power-on/power-down reset occurred.  When the power-on/power-down reset, set by hardware.  Cleared by writing to the RMVF bit by software.       | 1           |
| 26  | PINRSTF  | RO     | External manual reset (NRST pin) flag: 0: No NRST pin reset occurred; 1: NRST pin reset occurred. When the NRST pin reset, set by hardware. Cleared by writing to the RMVF bit by software.                                     | 0           |
| 25  | Reserved | RO     | Reserved.                                                                                                                                                                                                                       | 0           |
| 24  | RMVF     | RW     | Remove reset flag control:                                                                                                                                                                                                      | 0           |

|        |          |    | 0: No effect;                                              |   |
|--------|----------|----|------------------------------------------------------------|---|
|        |          |    | 1: Clear reset flag;                                       |   |
| [23:2] | Reserved | RO | Reserved.                                                  | 0 |
|        |          |    | Internal low-speed clock (LSI) ready flag bit (Set by      |   |
|        |          |    | hardware):                                                 |   |
| 1      | LSIRDY   | RO | 0: Internal low-speed clock (40 KHz) not ready;            | 0 |
| 1      | LSIKDT   | KO | 1: Internal low-speed clock (40 KHz) ready.                | U |
|        |          |    | Note: After the LSION bit is cleared, it takes 3 cycles of |   |
|        |          |    | LSI clock to clear this bit.                               |   |
|        |          |    | Internal low-speed clock (LSI) enable control bit:         |   |
| 0      | LSION    | RW | 0: LSI (40KHz) oscillator disabled;                        | 0 |
|        |          |    | 1:LSI (40KHz) oscillator enabled;                          |   |

Note: The Write Clear Reset flag can be cleared except for BIT1 which is cleared by a power-on reset.

### 3.4.11 HB Peripheral Reset Register (RCC\_AHBRSTR)

Offset address: 0x28

| 31           | 30                | 29         | 28           | 27 | 26 | 25 | 24   | 23    | 22  | 21    | 20 | 19 | 18 | 17 | 16 |
|--------------|-------------------|------------|--------------|----|----|----|------|-------|-----|-------|----|----|----|----|----|
|              |                   |            |              |    |    |    | Rese | erved |     |       |    |    |    |    |    |
| 15           | 14                | 13         | 12           | 11 | 10 | 9  | 8    | 7     | 6   | 5     | 4  | 3  | 2  | 1  | 0  |
| Reser<br>ved | ETH<br>MAC<br>RST | DVP<br>RST | OTGF<br>SRST |    |    |    |      |       | Res | erved |    |    |    |    |    |

| Bit       | Name        | Access | Description                          | Reset value |
|-----------|-------------|--------|--------------------------------------|-------------|
| [31:15]   | Reserved    | RO     | Reserved                             | 0           |
| 14 ETI    | ETHMACRST   | RW     | Ethernet MAC reset control:          | 0           |
|           | ETHWACKST   | KW     | 0: No effect; 1: Reset Ethernet MAC. | U           |
| 13 DVPRST |             | RW     | DVP reset control:                   | 0           |
| 13        | DVPKS1      | RW     | 0: No effect; 1: Reset DVP.          | U           |
| 12        | 12 OTOFOROT |        | USBOTG_FS module reset control:      | 0           |
| 1.2       | OTGFSRST    | RW     | 0: No effect; 1: Reset USBHD.        | U           |
| [11:0]    | Reserved    | RO     | Reserved                             | 0           |

### 3.4.12 Clock Configuration Register 2 (RCC\_CFGR2)

| 31           | 30               | 29         | 28           | 27                  | 26  | 25    | 24    | 23           | 22          | 21 | 20          | 19         | 18          | 17          | 16                 |
|--------------|------------------|------------|--------------|---------------------|-----|-------|-------|--------------|-------------|----|-------------|------------|-------------|-------------|--------------------|
| USBF<br>SSRC | USB<br>HSPL<br>L | USBI<br>[1 | ISCLK<br>:0] | USB<br>HSPL<br>LSRC | USB | HSDIV | [2:0] | Reser<br>ved | ETH1<br>GEN |    | GSRC<br>:0] | RNG<br>SRC | I2S3S<br>RC | I2S2S<br>RC | PRE<br>DIV1<br>SRC |
| 15           | 14               | 13         | 12           | 11                  | 10  | 9     | 8     | 7            | 6           | 5  | 4           | 3          | 2           | 1           | 0                  |
| PLL3MUL[3:0] |                  |            | P            | LL2MUL[3:0]         |     |       | ]     | PREDI        | V2[3:0      | )] |             | PREDI      | V1[3:0      | ]           |                    |

| Bit | Name     | Access | Description                         | Reset value |
|-----|----------|--------|-------------------------------------|-------------|
| 31  | USBHSSRC | RW     | USBHS 48MHz clock source selection: | 0           |

|         |                                                                              |    | 0: PLL CLK 1: USB PHY.                                |      |  |  |  |  |  |
|---------|------------------------------------------------------------------------------|----|-------------------------------------------------------|------|--|--|--|--|--|
|         |                                                                              |    | USBHS PHY internal PLL control bit:                   |      |  |  |  |  |  |
| 30      | USBHSPLL                                                                     | RW | 0: USB PHY internal PLL disabled;                     | 0    |  |  |  |  |  |
|         |                                                                              |    | 1: USB PHY internal PLL enabled.                      |      |  |  |  |  |  |
|         |                                                                              |    | USBHSPLL reference clock selection                    |      |  |  |  |  |  |
|         |                                                                              |    | (USBHSPLLSRC/ USBHSDIV):                              |      |  |  |  |  |  |
|         |                                                                              | RW | 00: 3MHz;                                             |      |  |  |  |  |  |
| [29:28] | USBHSCLK[1:0]                                                                |    | 01: 4MHz;                                             | 00   |  |  |  |  |  |
|         |                                                                              |    | 10: 8MHz;                                             |      |  |  |  |  |  |
|         |                                                                              |    | 11: 5MHz.                                             |      |  |  |  |  |  |
|         |                                                                              |    | USBHSPLL reference source selection:                  |      |  |  |  |  |  |
| 27      | USBHSPLLSRC                                                                  | RW | 0: HSE; 1: HIS.                                       | 0    |  |  |  |  |  |
|         |                                                                              |    | USBHSPLL reference source prescaler:                  |      |  |  |  |  |  |
|         |                                                                              |    | 000: Not divided; 001: Divided by 2;                  |      |  |  |  |  |  |
| [26:24] | USBHSDIV[2:0]                                                                | RW | 010: Divided by 3; 011: Divided by 4;                 | 000  |  |  |  |  |  |
|         | [ ]                                                                          |    | 100: Divided by 5; 101: Divided by 6;                 |      |  |  |  |  |  |
|         |                                                                              |    | 110: Divided by 7; 111: Divided by 8.                 |      |  |  |  |  |  |
| 23      | Reserved                                                                     | RO | Reserved                                              | 0    |  |  |  |  |  |
|         | ETH1G_125M_E                                                                 |    | Gigabit Ethernet 125M clock enable bit:               |      |  |  |  |  |  |
| 22      | 22   RW   Organic Ethernet 125W clock chance bit.   0: Disabled; 1: Enabled. |    |                                                       |      |  |  |  |  |  |
|         |                                                                              |    | Gigabit Ethernet 125M clock selection:                |      |  |  |  |  |  |
|         | [21:20] ETH1GSRC[2:0]                                                        |    | 00: PLL2 VCO;                                         |      |  |  |  |  |  |
| [21:20] |                                                                              |    | 01: PLL3 VCO;                                         |      |  |  |  |  |  |
|         |                                                                              |    | 1x: External PB1 pin input.                           |      |  |  |  |  |  |
|         |                                                                              |    | RNG clock source selection:                           |      |  |  |  |  |  |
| 19      | RNG_SRC                                                                      | RW | 0: System clock; 1: PLL3 VCO.                         |      |  |  |  |  |  |
|         |                                                                              |    | I2S3 clock source:                                    |      |  |  |  |  |  |
| 18      | I2S3SRC                                                                      | RW | 0: System clock (SYSCLK);                             | 0    |  |  |  |  |  |
|         |                                                                              |    | 1: PLL3 VCO.                                          |      |  |  |  |  |  |
|         |                                                                              |    | I2S2 clock source:                                    |      |  |  |  |  |  |
| 17      | I2S2SRC                                                                      | RW | 0: System clock (SYSCLK);                             | 0    |  |  |  |  |  |
|         |                                                                              |    | 1: PLL3 VCO.                                          |      |  |  |  |  |  |
|         |                                                                              |    | PREDIV1 clock source:                                 |      |  |  |  |  |  |
| 16      | PREDIV1SRC                                                                   | RW | 0: HSE;                                               | 0    |  |  |  |  |  |
|         |                                                                              |    | 1: PLL2.                                              |      |  |  |  |  |  |
|         |                                                                              |    | PLL3 multiplication factor (These bits can be written |      |  |  |  |  |  |
|         |                                                                              |    | only when PLL3 is disabled).                          |      |  |  |  |  |  |
|         |                                                                              |    | 0000: PLL3 input clock x 2.5;                         |      |  |  |  |  |  |
|         |                                                                              |    | 0001: PLL3 input clock x 12.5;                        |      |  |  |  |  |  |
|         |                                                                              |    | 0010: PLL3 input clock x 4;                           |      |  |  |  |  |  |
| [15:12] | PLL3MUL[3:0]                                                                 | RW | 0011: PLL3 input clock x 5;                           | 0000 |  |  |  |  |  |
| -       |                                                                              |    | 0100: PLL3 input clock x 6;                           |      |  |  |  |  |  |
|         |                                                                              |    | 0101: PLL3 input clock x 7;                           |      |  |  |  |  |  |
|         |                                                                              |    | 0110: PLL3 input clock x 8;                           |      |  |  |  |  |  |
|         |                                                                              |    | 0111: PLL3 input clock x 9;                           |      |  |  |  |  |  |
|         |                                                                              |    | 1000: PLL3 input clock x 10;                          |      |  |  |  |  |  |

|                     |                |                              | 1001. DI I 2 imput ala ala y 11:                             |      |
|---------------------|----------------|------------------------------|--------------------------------------------------------------|------|
|                     |                |                              | 1001: PLL3 input clock x 11;<br>1010: PLL3 input clock x 12; |      |
|                     |                |                              |                                                              |      |
|                     |                |                              | 1011: PLL3 input clock x 13;                                 |      |
|                     |                |                              | 1100: PLL3 input clock x 14;                                 |      |
|                     |                |                              | 1101: PLL3 input clock x 15;                                 |      |
|                     |                |                              | 1110: PLL3 input clock x 16;                                 |      |
|                     |                |                              | 1111: PLL3 input clock x 20.                                 |      |
|                     |                |                              | PLL2 multiplication factor (These bits can be written        |      |
|                     |                |                              | only when PLL2 is disabled).                                 |      |
|                     |                |                              | 0000: PLL2 input clock x 2.5;                                |      |
|                     |                |                              | 0001: PLL2 input clock x 12.5;                               |      |
|                     |                |                              | 0010: PLL2 input clock x 4;                                  |      |
| [11:8] PLL2MUL[3:0] |                | 0011: PLL2 input clock x 5;  |                                                              |      |
|                     |                | 0100: PLL2 input clock x 6;  |                                                              |      |
|                     |                | 0101: PLL2 input clock x 7;  |                                                              |      |
|                     | RW             | 0110: PLL2 input clock x 8;  | 0000                                                         |      |
|                     | 17. 44         | 0111: PLL2 input clock x 9;  | 0000                                                         |      |
|                     |                | 1000: PLL2 input clock x 10; |                                                              |      |
|                     |                | 1001: PLL2 input clock x 11; |                                                              |      |
|                     |                | 1010: PLL2 input clock x 12; |                                                              |      |
|                     |                | 1011: PLL2 input clock x 13; |                                                              |      |
|                     |                | 1100: PLL2 input clock x 14; |                                                              |      |
|                     |                |                              | 1101: PLL2 input clock x 15;                                 |      |
|                     |                |                              | 1110: PLL2 input clock x 16;                                 |      |
|                     |                |                              | 1111: PLL2 input clock x 20.                                 |      |
|                     |                |                              | PREDIV2 prescaler factor (These bits can be written          |      |
|                     |                |                              | only when PLL2 and PLL3 both are disabled).                  |      |
|                     |                |                              | 0000: PREDIV2 not divided;                                   |      |
|                     |                |                              | 0001: PREDIV2 input clock divided by 2;                      |      |
|                     |                |                              | 0010: PREDIV2 input clock divided by 3;                      |      |
|                     |                |                              | 0011: PREDIV2 input clock divided by 4;                      |      |
|                     |                |                              | 0100: PREDIV2 input clock divided by 5;                      |      |
|                     |                |                              | 0101: PREDIV2 input clock divided by 6;                      |      |
|                     |                |                              | 0110: PREDIV2 input clock divided by 7;                      |      |
| [7:4]               | PREDIV2[3:0]   | RW                           | 0111: PREDIV2 input clock divided by 8;                      | 0000 |
|                     |                |                              | 1000: PREDIV2 input clock divided by 9;                      |      |
|                     |                |                              | 1000: PREDIV2 input clock divided by 9,                      |      |
|                     |                |                              | 1001. I REDIV2 input clock divided by 10,                    |      |
|                     |                |                              | 1010: PREDIV2 input clock divided by 11;                     |      |
|                     |                |                              |                                                              |      |
|                     |                |                              | 1100: PREDIV2 input clock divided by 13;                     |      |
|                     |                |                              | 1101: PREDIV2 input clock divided by 14;                     |      |
|                     |                |                              | 1110: PREDIV2 input clock divided by 15;                     |      |
|                     |                |                              | 1111: PREDIV2 input clock divided by 16.                     |      |
| F0 0-               | DD DD 33455 55 | <b></b>                      | PREDIV1 prescaler factor (These bits can be written          |      |
| [3:0]               | PREDIV1[3:0]   | RW                           | only when PLL is disabled).                                  | 0000 |
|                     |                |                              | 0000: PREDIV1 not divided;                                   |      |

V2. 4 56 WCH°

| 0001: PREDIV1 input clock divided by 2;                   |
|-----------------------------------------------------------|
| 0010: PREDIV1 input clock divided by 3;                   |
| 0011: PREDIV1 input clock divided by 4;                   |
| 0100: PREDIV1 input clock divided by 5;                   |
| 0101: PREDIV1 input clock divided by 6;                   |
|                                                           |
| 0110: PREDIV1 input clock divided by 7;                   |
| 0111: PREDIV1 input clock divided by 8;                   |
| 1000: PREDIV1 input clock divided by 9;                   |
| 1001: PREDIV1 input clock divided by 10;                  |
| 1010: PREDIV1 input clock divided by 11;                  |
| 1011: PREDIV1 input clock divided by 12;                  |
| 1100: PREDIV1 input clock divided by 13;                  |
| 1101: PREDIV1 input clock divided by 14;                  |
| 1110: PREDIV1 input clock divided by 15;                  |
| 1111: PREDIV1 input clock divided by 16.                  |
| Note: Bit0 is the same as bit17 in the RCC_CFGR0          |
| register. Bit0 in this register changes when bit17 in the |
| RCC_CFGR0 register is modified.                           |

Note: Applied for CH32F20x\_D8C, CH32V30x\_D8C, CH32V31x\_D8C.

## 3.4.13 HSE Crystal Oscillator Calibration Control Register (HSE\_CAL\_CTRL)

| 31   | 30       | 29 | 28 | 27           | 26                                    | 25 | 24 | 23       | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|----------|----|----|--------------|---------------------------------------|----|----|----------|----|----|----|----|----|----|----|
| HSEC |          |    |    | HSEF<br>AULT | HSEF Reser HSEITRIM<br>AULT ved [1:0] |    |    | Reserved |    |    |    |    |    |    |    |
| 15   | 14       | 13 | 12 | 11           | 10                                    | 9  | 7  | 6        | 5  | 4  | 3  | 2  | 1  | 0  |    |
|      | Reserved |    |    |              |                                       |    |    |          |    |    |    |    |    |    |    |

| Bit     | Name          | Access | Description                                                                                                                             | Reset value |
|---------|---------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:28] | HSEC[3:0]     | RW     | HSE internal match capacitor adjustment: 000: 8Pf; 001: 10pF; 010: 12pF; 011: 14pF; 100: 16pF; 101: 18pF; 110: 20pF; 111: 22pF.         | 0           |
| [27]    | HSEFAULT      | RW     | HSE fault detection disable:  0: Analog input HSE fault detection signal enabled;  1: Analog input HSE fault detection signal disabled. | 0           |
| [26]    | Reserved      | RW     | Reserved                                                                                                                                | 0           |
| [25:24] | HSEITRIM[1:0] | RW     | HSE starting current adjustment bit.                                                                                                    | 01b         |

| [23: | 0] F | Reserved | RO | Reserved | 0 | Ī |
|------|------|----------|----|----------|---|---|
|------|------|----------|----|----------|---|---|

### 3.4.14 LSI Crystal Oscillator Calibration Tune Register (LSI32K\_TUNE)

Offset address: 0x0A



| Bit     | Name       | Access | Description        | Reset value |
|---------|------------|--------|--------------------|-------------|
| [15:13] | Reserved   | RO     | Reserved           | 0           |
| [12:5]  | HTUNE[7:0] | RW     | LSI32K fine tune   | 0x80        |
| [4:0]   | LTUNE[4:0] | RW     | LSI32K coarse tune | 0x11        |

### 3.4.15 LSI Crystal Oscillator Calibration Configuration Register (LSI32K\_CAL\_CFG)

| 7        | 6    | 5      | 4      | 3 | 2     | 1       | 0 |
|----------|------|--------|--------|---|-------|---------|---|
| Reserved | LPEN | WKUPEN | HALTMD |   | CNTVI | LU[3:0] |   |

| Bit   | Name        | Access | Description                                                                                                                                                                                                                                                                                                                                                                 | Reset value |
|-------|-------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [7]   | Reserved    | RO     | Reserved                                                                                                                                                                                                                                                                                                                                                                    | 0           |
| [6]   | LPEN        | RW     | Calibration enable in low-power mode: 0: Calibration disabled in low-power mode; 1: Calibration enabled in low-power mode. Note: It works together with RB_HSE_KEEP_LP in EXTEN.                                                                                                                                                                                            | 0           |
| [5]   | WKUPEN      | RW     | LSI32K wake-up interrupt enable:  0: LSI32K wake-up interrupt disabled;  1: LSI32K wake-up interrupt enabled.                                                                                                                                                                                                                                                               | 0           |
| [4]   | HALTMD      | RW     | LSI32K calibration count halt duration configuration: 0: Count halts for 1 CK32K cycle; 1: Count halts for 3 CK32K cycles.                                                                                                                                                                                                                                                  | 0           |
| [3:0] | CNTVLU[3:0] | RW     | LSI32K calibration sampling duration configuration: 0000: 2 CK32K cycles; 0001: 4 CK32K cycles; 0010: 32 CK32K cycles; 0011: 64 CK32K cycles; 0100: 128 CK32K cycles; 0100: 1256 CK32K cycles; 0101: 512 CK32K cycles; 0110: 512 CK32K cycles; 1010: 1024 CK32K cycles; 1000: 1088 CK32K cycles; 1001: 1152 CK32K cycles; 1011: 1216 CK32K cycles; 1011: 1280 CK32K cycles; | 0001Ь       |

| 1100: 2000 CK32K cycles.                         |
|--------------------------------------------------|
| Note: Other configuration values correspond to 2 |
| CK32K cycles.                                    |

### 3.4.16 LSI Crystal Oscillator Calibration Status Register (LSI32K\_CAL\_STATR)

Offset address: 0x20

| _ | 15        | 14        | 13 | 12 | 11 | 10 | 9 | 8 | 7   | 6      | 5 | 4 | 3 | 2 | 1 | 0 |
|---|-----------|-----------|----|----|----|----|---|---|-----|--------|---|---|---|---|---|---|
|   | IFEN<br>D | CNT<br>OV |    |    |    |    |   |   | CNT | [13:0] |   |   |   |   |   |   |

| Bit    | Name       | Access | Description                                      | Reset value |
|--------|------------|--------|--------------------------------------------------|-------------|
|        |            |        | LSI32K calibration count end interrupt flag:     |             |
| [15]   | IFEND      | RW1    | 0: During sampling count, no flag;               | 0           |
|        |            |        | 1: Sampling count ends, the flag is set.         |             |
|        |            |        | LSI32K sampling counter overflow flag:           |             |
| [14]   | CNTOV      | RW1    | 0: Not overflow;                                 | 0           |
|        |            |        | 1: Overflow.                                     |             |
|        |            |        | Count for several CK32K cycles based on system   |             |
| [12.0] | CNIT[12.0] | DO.    | clock frequency.                                 | 0**0000     |
| [13:0] | CNT[13:0]  | RO     | Note: The specific number of CK32K cycles can be | 0x0000      |
|        |            |        | configured.                                      |             |

### 3.4.17 LSI Crystal Oscillator Calibration Counter (LSI32K\_CAL\_OV\_CNT)

Offset address: 0x22

| 7 | 6 | 5 | 4    | 3       | 2 | 1 | 0 |
|---|---|---|------|---------|---|---|---|
|   |   |   | OVCN | IT[7:0] |   |   |   |

| Bit   | Name       | Access | Description                                                                                              | Reset value |
|-------|------------|--------|----------------------------------------------------------------------------------------------------------|-------------|
| [7:0] | OVCNT[7:0] |        | LSI32K sampling counter overflow count.  Note: Clear the overflow flag and this counter will be cleared. | 0x00        |

### 3.4.18 LSI Crystal Oscillator Calibration Control Register (LSI32K\_CAL\_CTRL)

|   | 7    | 6 | 5 | 4        | 3 | 2 | 1     | 0        |
|---|------|---|---|----------|---|---|-------|----------|
| Г | HALT |   |   | Reserved |   |   | CALEN | CALINTEN |

| Bit   | Name     | Access | Description                                            | Reset value |
|-------|----------|--------|--------------------------------------------------------|-------------|
|       |          |        | LSI32K calibration count halt:                         |             |
| [7]   | HALT     | RO     | 0: During count, and the count value is not available; | 1           |
|       |          |        | 1: Count halts, and the count value is available.      |             |
| [6:2] | Reserved | RO     | Reserved                                               | 0           |
| [1]   | CALEN    | RW     | LSI32K calibration enable:                             | 0           |

|     |          |    | 0: Disable LSI32K calibration;           |   |
|-----|----------|----|------------------------------------------|---|
|     |          |    | 1: Enable LSI32K calibration.            |   |
|     |          |    | LSI32K calibration interrupt enable:     |   |
| [0] | CALINTEN | RW | 0: Disable LSI32K calibration interrupt; | 0 |
|     |          |    | 1: Enable LSI32K calibration interrupt.  |   |

Note: Applied for CH32F20x\_D8C and CH32V30x\_D8C.

## **Chapter 4 Backup Register (BKP)**

This chapter applies to the whole family of CH32F20x, CH32V20x, CH32V30x and CH32V31x.

Backup Register (BKP) provides up to 42 16-bit backup data registers, which can be used to store up to 84 bytes of user data. After the main power supply  $(V_{DD})$  switched off, these data can still be maintained by the power supply of  $V_{BAT}$  without being affected by the standby status, system reset or power reset. In addition, the BKP unit also provides tamper detection management, RTC clock calibration and pulse output functions.

### 4.1 Main Features

- Tamper detection (TAMPER) function
- RTC clock calibration function
- Output RTC clock divided by 64, alarm pulse or second pulse on PC13 pin

### 4.2 Backup Data Register

After the microcontroller reset, the access to the backup register and RTC will be disabled, and the access to the backup register needs to be enabled by the following operations:

- 1) Set the PWREN bit and BKPEN bit in the RCC\_APB1PCENR register to enable the power supply and the operating clock of the backup interface;
- 2) Set the DBP bit in the power control register (PWR\_CTLR) to enable access to the backup register and RTC register.

### 4.2.1 Backup Data Register

The backup data register can be used as a general data buffer. Because of its feature of saving data by  $V_{BAT}$  power when  $V_{DD}$  is powered off, it can be used to store some important or sensitive data. But these data will be completely cleared after the tamper event occurs.

### 4.2.2 Tamper Detection

When an external signal (Rising or falling edge) is provided, a tamper event is generated, and the important information retained in the current system is cleared automatically by hardware. Tamper detection increases the security of system information.

A tamper event is generated when a transition edge is detected on the tamper detection pin (Depending on the TPAL bit). If the tamper detection interrupt is enabled, a tamper detection interrupt is also generated at the same time. As long as a tamper event occurs, all backup data registers are cleared. In addition, the hardware detection adopts the memory mode. Even if the tamper detection function is not enabled (TPE=0), the system still samples and checks whether there is a transition edge, and if the TPAL bit selection is met, the tamper event is locked in advance, and the TPE bit is set to 1 to trigger a tamper event.

For example: When TPAL=0, if it is not enabled (TPE=0) but the TAMPER pin is already high, an additional tamper event is generated (The system locks the rising edge in advance) once TPE=1. When TPAL=1, if it is not enabled (TPE=0) but the TAMPER pin is already low, an additional tamper event is generated (The system locks the falling edge in advance) once TPE=1.

Therefore, in order to avoid unnecessary tamper events from causing the backup registers to be cleared, it is recommended to set the CTE bit in the BKP\_TPCSR register to 1 at the beginning of the hardware detection of the tamper pin, to firstly clear the tamper events that may have been remembered by hardware, and ensure

that the current tamper detection pin is invalid.

Note: When the  $V_{DD}$  power supply is disconnected, the tamper detection function is still valid. In order to avoid unnecessary backup registers of resetting data, the TAMPER pin shall be connected to the correct level correctly.

#### 4.2.3 RTC Calibration

For this function, the tamper detection pin must be selected as a common IO port. Clear the TPE bit in the BKP TPCTLR register.

#### • Pulse output

Configure the ASOE bit in the BKP\_OCTLR register, enable RTC pulse output, set the ASOS bit, and select either the second pulse output or the alarm pulse output.

#### • RTC calibration

After the CCO bit in the BKP\_OCTLR register is configured, the internal RTC clock divided by 64 is output to the tamper detection pin (TAMPER). Through the actual test, adjust the clock and calibrate the RTC by configuring the CAL[6:0] bits by software.

#### 4.2.4 BKP Interface Reset

The BKP domain can be independently powered-on by  $V_{BAT}$  when the  $V_{DD}$  power is switched off. The application code controls the reset of BKP domain register, the BKP\_DATAR1-10, ASOS bit and ASOE bit in the backup data register are reset by setting the BDRST bit in the RCC\_BDCTLR register by software, which is not affected by the RCC peripheral interface control BKPRST bit.

### 4.3 Register Description

Table 4-1 BKP registers

|                 | Table          | 4-1 DKF Tegisters                 | ,           |
|-----------------|----------------|-----------------------------------|-------------|
| Name            | Access address | Description                       | Reset value |
| R16_BKP_DATAR1  | 0x40006C04     | Backup data register 1            | 0x0000      |
| R16_BKP_DATAR2  | 0x40006C08     | Backup data register 2            | 0x0000      |
| R16_BKP_DATAR3  | 0x40006C0C     | Backup data register 3            | 0x0000      |
| R16_BKP_DATAR4  | 0x40006C10     | Backup data register 4            | 0x0000      |
| R16_BKP_DATAR5  | 0x40006C14     | Backup data register 5            | 0x0000      |
| R16_BKP_DATAR6  | 0x40006C18     | Backup data register 6            | 0x0000      |
| R16_BKP_DATAR7  | 0x40006C1C     | Backup data register 7            | 0x0000      |
| R16_BKP_DATAR8  | 0x40006C20     | Backup data register 8            | 0x0000      |
| R16_BKP_DATAR9  | 0x40006C24     | Backup data register 9            | 0x0000      |
| R16_BKP_DATAR10 | 0x40006C28     | Backup data register 10           | 0x0000      |
| R16_BKP_OCTLR   | 0x40006C2C     | RTC calibration register          | 0x0000      |
| R16_BKP_TPCTLR  | 0x40006C30     | Tamper detection control register | 0x0000      |
| R16_BKP_TPCSR   | 0x40006C34     | Tamper detection status register  | 0x0000      |
| R16_BKP_DATAR11 | 0x40006C40     | Backup data register 11           | 0x0000      |
| R16_BKP_DATAR12 | 0x40006C44     | Backup data register 12           | 0x0000      |
| R16_BKP_DATAR13 | 0x40006C48     | Backup data register 13           | 0x0000      |
| R16_BKP_DATAR14 | 0x40006C4C     | Backup data register 14           | 0x0000      |
| R16_BKP_DATAR15 | 0x40006C50     | Backup data register 15           | 0x0000      |

| R16_BKP_DATAR16 | 0x40006C54 | Backup data register 16 | 0x0000 |
|-----------------|------------|-------------------------|--------|
| R16_BKP_DATAR17 | 0x40006C58 | Backup data register 17 | 0x0000 |
| R16_BKP_DATAR18 | 0x40006C5C | Backup data register 18 | 0x0000 |
| R16_BKP_DATAR19 | 0x40006C60 | Backup data register 19 | 0x0000 |
| R16_BKP_DATAR20 | 0x40006C64 | Backup data register 20 | 0x0000 |
| R16_BKP_DATAR21 | 0x40006C68 | Backup data register 21 | 0x0000 |
| R16_BKP_DATAR22 | 0x40006C6C | Backup data register 22 | 0x0000 |
| R16_BKP_DATAR23 | 0x40006C70 | Backup data register 23 | 0x0000 |
| R16_BKP_DATAR24 | 0x40006C74 | Backup data register 24 | 0x0000 |
| R16_BKP_DATAR25 | 0x40006C78 | Backup data register 25 | 0x0000 |
| R16_BKP_DATAR26 | 0x40006C7C | Backup data register 26 | 0x0000 |
| R16_BKP_DATAR27 | 0x40006C80 | Backup data register 27 | 0x0000 |
| R16_BKP_DATAR28 | 0x40006C84 | Backup data register 28 | 0x0000 |
| R16_BKP_DATAR29 | 0x40006C88 | Backup data register 29 | 0x0000 |
| R16_BKP_DATAR30 | 0x40006C8C | Backup data register 30 | 0x0000 |
| R16_BKP_DATAR31 | 0x40006C90 | Backup data register 31 | 0x0000 |
| R16_BKP_DATAR32 | 0x40006C94 | Backup data register 32 | 0x0000 |
| R16_BKP_DATAR33 | 0x40006C98 | Backup data register 33 | 0x0000 |
| R16_BKP_DATAR34 | 0x40006C9C | Backup data register 34 | 0x0000 |
| R16_BKP_DATAR35 | 0x40006CA0 | Backup data register 35 | 0x0000 |
| R16_BKP_DATAR36 | 0x40006CA4 | Backup data register 36 | 0x0000 |
| R16_BKP_DATAR37 | 0x40006CA8 | Backup data register 37 | 0x0000 |
| R16_BKP_DATAR38 | 0x40006CAC | Backup data register 38 | 0x0000 |
| R16_BKP_DATAR39 | 0x40006CB0 | Backup data register 39 | 0x0000 |
| R16_BKP_DATAR40 | 0x40006CB4 | Backup data register 40 | 0x0000 |
| R16_BKP_DATAR41 | 0x40006CB8 | Backup data register 41 | 0x0000 |
| R16_BKP_DATAR42 | 0x40006CBC | Backup data register 42 | 0x0000 |
|                 |            |                         |        |

Note: The BKP\_DATARx (x=11-42) registers are applied for CH32F20x\_D8, CH32F20x\_D8C, CH32F20x\_D8W, CH32V20x\_D8, CH32V20x\_D8W, CH32V30x\_D8 and CH32V30x\_D8C, CH32V31x\_D8C.

### 4.3.1 Backup Data Register (BKP\_DATARx) (x=1-42)

Offset address: 0x04 to 0x28, 0x40 to 0xBC

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 D [15:0]

| Bit    | Name    | Access | Description                                                                                                                                                                    | Reset value |
|--------|---------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [15:0] | D[15:0] | RW     | Backup data, which can be written with user data. Note: They are only reset by backup domain reset (BDRST) or by a TAMPER pin event (If the TAMPER pin function is activated). | 0           |

### 4.3.2 RTC Calibration Register (BKP\_OCTLR)

Offset address: 0x2C

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0

| Reserved | ASO<br>S | ASO<br>E | ССО | CAL[6:0] |
|----------|----------|----------|-----|----------|
|----------|----------|----------|-----|----------|

| Bit     | Name     | Access | Description                                                         | Reset value |
|---------|----------|--------|---------------------------------------------------------------------|-------------|
| [15:10] | Reserved | RO     | Reserved.                                                           | 0           |
|         |          |        | TAMPER pin alarm/second output selection:                           |             |
|         |          |        | 0: Alarm pulse output selected;                                     |             |
| 9       | ASOS     | RW     | 1: Second pulse output selected.                                    | 0           |
|         |          |        | Note: This bit can only be reset by backup domain                   |             |
|         |          |        | reset (BDRST).                                                      |             |
|         |          |        | TAMPER pin alarm/second output enable:                              |             |
|         |          |        | 0: Alarm/second pulse output disabled;                              |             |
| 8       | ASOE     | RW     | 1: Alarm/second pulse output enabled.                               | 0           |
|         |          |        | Note: This bit can only be reset by backup domain                   |             |
|         |          |        | reset (BDRST).                                                      |             |
|         |          |        | Calibration clock output selection:                                 |             |
|         |          |        | 0: No calibration clock output;                                     |             |
|         |          |        | 1: TEMPER pin output RTC clock divided by 64.                       |             |
| 7       | CCO      | RW     | Note 1: The tamper detection function must be                       | 0           |
|         |          |        | switched off to enable this function.                               |             |
|         |          |        | <i>Note2: This bit is cleared when</i> $V_{DD}$ <i>power supply</i> |             |
|         |          |        | is switched off.                                                    |             |
|         |          |        | Calibration value register. The value of this                       |             |
|         |          |        | register indicates the number of clock pulses that                  |             |
| [6:0]   | CAL      |        | will be skipped every $2^{20}$ clock pulses. This allows            |             |
|         |          |        | the calibration of the RTC clock. The clock can be                  |             |
|         |          |        | slowed down from 0 to 121ppm.                                       |             |

### 4.3.3 Tamper Detection Control Register (BKP\_TPCTLR)

Offset address: 0x30



| Bit    | Name     | Access | Description                                         | Reset value |  |
|--------|----------|--------|-----------------------------------------------------|-------------|--|
| [15:2] | Reserved | RO     | Reserved.                                           | 0           |  |
|        |          |        | TEMPER pin active level:                            |             |  |
|        |          |        | 0: High level on the TEMPER pin cause all backup    |             |  |
| 1      | TPAL     | RW     | data registers cleared (hardware lock rising edge); | 0           |  |
| 1      |          | KW     | 1: Low level on the TEMPER pin causer all           | U           |  |
|        |          |        | backup data registers cleared (hardware lock        |             |  |
|        |          |        | falling edge);                                      |             |  |
|        |          |        | TEMPER pin enable:                                  |             |  |
| 0      | TPE      | RW     | 0: TEMPER pin used as common IO port;               | 0           |  |
|        |          |        | 1: TEMPER pin used for the tamper detection.        | l           |  |

Note: When the TPAL and TPE bits are cleared at the same time, a false tamper event occurs. It is

recommended to change the status of the TPAL bit only when TPE is 0.

### 4.3.4 Tamper Detection Status Register (BKP\_TPCSR)



| Bit     | Name     | Access | Description                                                                                                                                                                                                                                                                                                     | Reset value |
|---------|----------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [15:10] | Reserved | RO     | Reserved.                                                                                                                                                                                                                                                                                                       | 0           |
| 9       | TIF      | RO     | Tamper interrupt flag. When a tamper event is detected and the TPIE bit is set to 1, this bit is set. Cleared by writing 1 to the CTI bit. If the TPIE bit is reset, this bit is reset at the same time.  Note: This bit is reset only when the system is reset or woken up from Standby mode.                  | 0           |
| 8       | TEF      | RO     | Tamper event flag. When a tamper event is detected, this bit is set. Cleared by writing 1 to the CTE bit.  Note: When this bit is 1, all BKP_DATARx registers are cleared, and all write operations to the BKP_DATARx register are invalid before this bit is not reset.                                        | 0           |
| [7:3]   | Reserved | RO     | Reserved.                                                                                                                                                                                                                                                                                                       | 0           |
| 2       | TPIE     | RW     | Tamper interrupt enable: 0: Tamper detection interrupt disabled; 1: Tamper detection interrupt enabled (TPE needs to be set to 1).  Note 1: The tamper detection interrupt cannot wake up the core from low-power mode.  Note 2: This bit is reset only when the system is reset or woken up from standby mode. | 0           |
| 1       | СТІ      | WO     | Clear Tamper detection interrupt. Write 1 to clear it, and the value read out is invalid.                                                                                                                                                                                                                       | 0           |
| 0       | СТЕ      | WO     | Clear Tamper detection event. Write 1 to clear it, and the value read out is invalid.                                                                                                                                                                                                                           | 0           |

## Chapter 5 Cyclic Redundancy Check (CRC)

This chapter applies to the whole family of CH32F20x, CH32V20x, CH32V30x and CH32V31x.

The cyclic redundancy check (CRC) calculation unit is used to get a CRC code from a 32-bit data word and a fixed generator polynomial. It is generally used to verify data transmission or storage integrity. The hardware CRC calculation unit provided by the system can greatly save CPU and RAM resources and improve efficiency.

CRC computation
(polynomial: 0x4C11DB7)

32-bit write

Data register
(CRC\_DATAR)

Figure 5-1 CRC structure block diagram

#### 5.1 Main Features

- CRC32 polynomial (0x4C11DB7)
   X<sup>32</sup>+X<sup>26</sup>+X<sup>23</sup>+X<sup>22</sup>+X<sup>16</sup>+X<sup>12</sup>+X<sup>11</sup>+X<sup>10</sup>+X<sup>8</sup>+X<sup>7</sup>+X<sup>5</sup>+X<sup>4</sup>+X<sup>2</sup>+X+1
- Single input/output 32-bit data register
- CRC computation done in 4 HB clock cycles (HCLK)

### 5.2 Functional Description

#### CRC unit reset

To start a new CRC calculation, it is needed to reset the CRC calculation unit. Write 1 to the RST bit in the CRC\_CTLR register, to reset the data register by hardware, and it restores the initial value 0xFFFFFFF.

#### • CRC calculation

The CRC calculation unit is a combination of the previous CRC calculation value and the new CRC calculation value. When writing into the CRC\_DATAR register, new data is input to the hardware calculation unit. When reading the register, the latest CRC calculation value can be obtained. The hardware calculation interrupts the write operation of the system, so new values can be written continuously.

*Note: The CRC unit calculates the whole 32-bit data word, rather than byte per byte.* 

#### Independent data buffer

The CRC unit provides an 8-bit independent data register (CRC\_IDATAR), which is used to temporarily store 1 byte of data for the application code and is not affected by the reset of the CRC unit.

## **5.3 Register Description**

Table 5-1 CRC registers

| Name          | Access address | Description               | Reset value |  |  |
|---------------|----------------|---------------------------|-------------|--|--|
| R32_CRC_DATAR | 0x40023000     | Data register             | 0xFFFFFFFF  |  |  |
| R8_CRC_IDATAR | 0x40023004     | Independent data register | 0x00        |  |  |
| R32_CRC_CTLR  | 0x40023008     | Control register          | 0x00000000  |  |  |

### 5.3.1 Data Register (CRC\_DATAR)

Offset address: 0x00

| 31 | 30        | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|-----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|    | DR[31:16] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15 | 14        | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    | DR[15:0]  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| j | Bit    | Name | Access | Description                                           | Reset value |
|---|--------|------|--------|-------------------------------------------------------|-------------|
| Ī | [31:0] | DR   | RW     | Write the original data; read the calculation result. | 0xFFFFFFF   |

### 5.3.2 Independent Data Register (CRC\_IDATAR)

Offset address: 0x04

| 15 | 14 | 13 | 12   | 11   | 10 | 9 | 8 | 7 | 6 | 5 | 4   | 3     | 2 | 1 | 0 |
|----|----|----|------|------|----|---|---|---|---|---|-----|-------|---|---|---|
|    |    |    | Rese | rved |    |   |   |   |   |   | IDR | [7:0] |   |   |   |

| Bit   | Name     | Access | Description                                                                                           | Reset value |
|-------|----------|--------|-------------------------------------------------------------------------------------------------------|-------------|
| [7:0] | IDR[7:0] | RW     | 8-bit general register, can be used as data buffer. This register is not affected by RST in CRC_CTLR. |             |

### **5.3.3** Control Register (CRC\_CTLR)

| 31       | 30       | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18  | 17 | 16 |
|----------|----------|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|
|          | Reserved |    |    |    |    |    |    |    |    |    |    |    |     |    |    |
| 15       | 14       | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2   | 1  | 0  |
| Reserved |          |    |    |    |    |    |    |    |    |    |    |    | RST |    |    |

| Bit    | Name     | Access | Description                                         | Reset value |
|--------|----------|--------|-----------------------------------------------------|-------------|
| [31:1] | Reserved | RO     | Reserved.                                           | 0           |
| 0      | RST      | WO     | CRC calculation unit reset control. Write 1 to set. |             |
|        |          |        | Automatically cleared by hardware. It sets the data |             |
|        |          |        | register to 0xFFFFFFF.                              |             |

# **Chapter 6 Real-Time Clock (RTC)**

### This chapter applies to the whole family of CH32F20x, CH32V20x, CH32V30x and CH32V31x.

The real-time clock (RTC) is an independent timer module. It supports up to 32-bit programmable counter. With software, the real-time clock function can be implemented, and the counter value can be modified to reconfigure the current time and date of the system. The RTC module is in the backup power supply area, and is not affected by the system reset and standby mode wake-up.

### **6.1 Main Features**

- Prescaler factor: up to  $2^{20}$
- 32-bit programmable counter
- Multiple types of clock sources, interrupt
- Independent reset

## 6.2 Functional Description

#### 6.2.1 Overview

Figure 6-1 RTC structure block diagram



As shown in Figure 6-1, the RTC module is mainly composed of 3 parts: PB1 bus interface, prescaler and

counter, control and status registers. The prescaler and counter are in the backup area and are powered by V<sub>BAT</sub>. After RTCCLK is input to the prescaler (RTC\_DIV), it is divided into TR\_CLK. It is worth noting that a self-decrement counter is located in the prescaler (RTC\_DIV). When the self-decrement reaches the overflow, a TR\_CLK is output. Then, take the preset value from the reload value register (RTC\_PSCR) and reload it into the prescaler. Reading the prescaler actually means reading its real-time value (Read only). The prescaler factor should be written to the reload value register (RTC\_PSCR). Generally, the cycle of TR\_CLK is set to 1s, TR\_CLK triggers the second event, and the main counter (RTC\_CNT) will be self-incremented by one at the same time. When the main counter is increased to the same value as the value of the alarm register, the alarm event is triggered. When the main counter is incremented till overflow, an overflow event is triggered. These 3 events can all trigger the interrupt, which is controlled by the corresponding interrupt enable bit.

#### **6.2.2** Reset

Due to the special purposes of the real-time clock, the 4 sets of registers in the backup domain: prescaler, prescaler of reloading value, main counter and alarm clock. They can only be reset by the reset signal in the backup domain. Refer to the chapter of RCC backup domain reset. The control register of the real-time clock is controlled by system reset or power reset.

### 6.2.3 Special Read/Write Register Operations

Due to the special purpose of the real-time clock, the RTC and PB1 buses are independent, and the reading of RTC by PB1 is not necessarily real-time. The RTC register reading through PB1 must go through a RTC rising edge after PB1 is started up. This situation may occur after system reset and power reset, wake-up from standby or stop mode. It is convenient to wait when the RSF bit of the control register (CTLR) is set high. For the write operator of RTC, the operation must be made specifically according to the following steps in the configuration mode when the previous write operation ends:

- 1) Query RTOFF bit unit it changes to 1;
- 2) Set CNF bit to enter the configuration mode;
- 3) Perform write operation to one or more RTC registers;
- 4) Clear the CNF bit to exit the configuration mode, and the RTC register will start being written on the PB1 interface;
- 5) Query the RTOFF bit until it changes to 1. So far, the write is completed.

# 6.3 Register Description

Table 6-1 RTC Registers

| Name          | Access address | Description                    | Reset value |
|---------------|----------------|--------------------------------|-------------|
| R16_RTC_CTLRH | 0x40002800     | RTC control register high      | 0x0000      |
| R16_RTC_CTLRL | 0x40002804     | RTC control register low       | 0x0020      |
| R16_RTC_PSCRH | 0x40002808     | Prescaler reload register high | 0x0000      |
| R16_RTC_PSCRL | 0x4000280C     | Prescaler reload register low  | 0xXXXX      |
| R16_RTC_DIVH  | 0x40002810     | Divider register high          | 0xXXXX      |
| R16_RTC_DIVL  | 0x40002814     | Divider register low           | 0xXXXX      |
| R16_RTC_CNTH  | 0x40002818     | RTC counter register high      | 0xXXXX      |
| R16_RTC_CNTL  | 0x4000281C     | RTC counter register low       | 0xXXXX      |
| R16_RTC_ALRMH | 0x40002820     | Alarm clock register high      | 0xXXXX      |

| R16 RTC ALRML 0x40002824 Alarm clock register low 0xXXXX |
|----------------------------------------------------------|
|----------------------------------------------------------|

# 6.3.1 RTC Control Register High (RTC\_CTLRH)

Offset address: 0x00

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0

Reserved OWIE ALRIE SECIE

| Bit    | Name     | Access | Description                | Reset value |
|--------|----------|--------|----------------------------|-------------|
| [15:3] | Reserved | RO     | Reserved.                  | 0           |
| 2      | OWIE     | RW     | Overflow interrupt enable. | 0           |
| 1      | ALRIE    | RW     | Alarm interrupt enable.    | 0           |
| 0      | SECIE    | RW     | Second interrupt enable.   | 0           |

# 6.3.2 RTC Control Register Low (RTC\_CTLRL)

| 15 14 13 12 11 10 9 8 7 6 |  |  |  |  |  |  |           | 5   | 4   | 3   | 2        | 1    | 0 |
|---------------------------|--|--|--|--|--|--|-----------|-----|-----|-----|----------|------|---|
| Reserved                  |  |  |  |  |  |  | RTOF<br>F | CNF | RSF | OWF | ALR<br>F | SECF |   |

| Bit    | Name     | Access | Description                                          | Reset value |
|--------|----------|--------|------------------------------------------------------|-------------|
| [15:6] | Reserved | RO     | Reserved.                                            | 0           |
|        |          |        | RTC operation OFF. It indicates the status of the    |             |
|        |          |        | last write operation performed on the RTC. To        |             |
| 5      | RTOFF    | RO     | perform operation on RTC, this bit must be 1.        | 1           |
| )      | RIOTT    | RO     | 0: Last write operation on RTC is still ongoing;     | 1           |
|        |          |        | 1: Last write operation on RTC has been              |             |
|        |          |        | completed.                                           |             |
|        |          |        | Configuration flag. Write 1 to this bit to enter the |             |
|        |          |        | configuration mode, so as to allow to write to       |             |
|        | CNF      | RW     | R16_RTC_CNTx, R16_RTC_ALRMx and                      |             |
|        |          |        | R16_RTC_PSCRx. The write operation can be            |             |
| 4      |          |        | performed only when this bit is written 1 and        | 0           |
|        |          |        | cleared by software:                                 |             |
|        |          |        | 0: Exit the configuration mode, and start updating   |             |
|        |          |        | the RTC register;                                    |             |
|        |          |        | 1: Enter the configuration mode.                     |             |
|        |          |        | Registers synchronized flag. Ensure that it is set   |             |
|        |          |        | by hardware (registers synchronized) before          |             |
|        |          |        | read/write operation is performed on PSCRx,          |             |
| 3      | RSF      | RW0    | ALRMx and CNTx. When reading/ writing these          | ()          |
|        | KS1      | RWO    | registers, or after the PB1 is reset or PB1 clock is | Ü           |
|        |          |        | stopped, the bit should be reset firstly.            |             |
|        |          |        | 0: Register not synchronized;                        |             |
|        |          |        | 1: Register synchronized.                            |             |

|   |      |     | Counter overflow flag. When the 32-bit counter                                                                                                                                                                                                                                                                                                                       |   |
|---|------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| 2 | OWF  | RW0 | overflows, this bit is set by hardware. If the OWIE bit is set, an overflow interrupt is also generated. This bit can only be cleared by software and cannot be set by software.                                                                                                                                                                                     | 0 |
| 1 | ALRF | RW0 | Alarm flag. When the counter value reaches the value of the alarm register (ALRMx), this bit will be set by the hardware. If the alarm interrupt enable bit (ALRIE) is set, an alarm interrupt is also generated. This bit can only be cleared by software and cannot be set by software.                                                                            | 0 |
| 0 | SECF | RW0 | Second flag. When the clock generates a falling edge after divided by the prescaler, the counter will self-increase by 1 and generate a second event, and the bit will be set. If the second interrupt is enabled (SECIE bit is set), a second interrupt is also generated at the same time. This bit can only be cleared by software and cannot be set by software. | 0 |

# 6.3.3 Prescaler Reload Register High (RTC\_PSCRH)

Offset address: 0x08

|   | 15 14 13 12 11 10 9 8 7 6 5 4 |  |  |  |  |      |      |  | 4 | 3 | 2 | 1 | 0 |       |       |  |
|---|-------------------------------|--|--|--|--|------|------|--|---|---|---|---|---|-------|-------|--|
| ſ |                               |  |  |  |  | Rese | rved |  |   |   |   |   |   | PRL[1 | 9:16] |  |

| Bit    | Name       | Access | Description                     | Reset value |
|--------|------------|--------|---------------------------------|-------------|
| [15:4] | Reserved   | RO     | Reserved.                       | 0           |
| [3:0]  | PRL[19:16] | WO     | Prescaler reload register high. | X           |

# 6.3.4 Prescaler Reload Register Low (RTC\_PSCRL)

Offset address: 0x0C



| Bit    | Name      | Access | Description                                                                                                                                                                                                  | Reset value |
|--------|-----------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [15:0] | PRL[15:0] | WO     | Prescaler reload register low. The actual division factor is (PSCR[19:0]+1). For example, if the RTC input frequency is 32768Hz, then this value can be set to 0x7fff to divide the signal with cycle of 1s. | v           |

# 6.3.5 Divider Register High (RTC\_DIVH)

Offset address: 0x10

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0

| Reserved |
|----------|
|----------|

| Bit    | Name       | Access | Description                      | Reset value |
|--------|------------|--------|----------------------------------|-------------|
| [15:4] | Reserved   | RO     | Reserved.                        | 0           |
| [3:0]  | DIV[19:16] | RO     | Prescaler divider register high. | X           |

# 6.3.6 Divider Register Low (RTC\_DIVL)

Offset address: 0x14

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 DIV[15:0]

| Bit    | Name      | Access | Description                                                                                                                                                                                                                                                                                                                                 | Reset value |
|--------|-----------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [15:0] | DIV[15:0] | RO     | Prescaler divider register low. DIV is actually a self-decrement counter. The DIV counter will decrease by 1 per incoming clock of RTC_CLK. After overflow, it will output a TR_CLK and reload the value from PSCR at the same time. DIV can only be read, and the remaining value of the counter of the current prescaler divider is read. | X           |

## 6.3.7 RTC Counter Register High (RTC\_CNTH)

Offset address: 0x18

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 CNT[31:16]

| ĺ | Bit    | Name       | Access | Description               | Reset value |
|---|--------|------------|--------|---------------------------|-------------|
| İ | [15:0] | CNT[31:16] | RW     | RTC counter register high | X           |

## 6.3.8 RTC Counter Register Low (RTC CNTL)

Offset address: 0x1C

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 CNT[15:0]

| Bit    | Name      | Access | Description                                                                                                                                                                                                                          | Reset value |
|--------|-----------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [15:0] | CNT[15:0] | RW     | RTC counter register low. Core component of the RTC timer; the clock is provided with TRCLK (The cycle is generally set to 1 second). Calculate current time by reading CNT[31:0]. Enter the configuration mode to write this value. | X           |

## 6.3.9 Alarm Register High (RTC\_ALRMH)

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8    | 7      | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|------|--------|---|---|---|---|---|---|---|
|    |    |    |    |    |    |   | ALR[ | 31:16] |   |   |   |   |   |   |   |

| ĺ | Bit    | Name       | Access | Description         | Reset value |
|---|--------|------------|--------|---------------------|-------------|
| İ | [15:0] | ALR[31:16] | WO     | Alarm register high | X           |

# 6.3.10 Alarm Register Low (RTC\_ALRML)

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8   | 7      | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|-----|--------|---|---|---|---|---|---|---|
|    | -  |    |    |    |    |   | ALR | [15:0] |   |   |   |   |   |   |   |

| Bit    | Name      | Access | Description                                                                                                                                                                                                | Reset value |
|--------|-----------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [15:0] | ALR[15:0] | WO     | Alarm register low. When the value of the alarm register ALRM[31:0] is consistent with the value of the counter CNT[31:0], an alarm event is generated. Enter the configuration mode to modify this value. | X           |

# **Chapter 7 Independent Watchdog (IWDG)**

This chapter applies to the whole family of CH32F20x, CH32V20x, CH32V30x and CH32V31x.

The system is equipped with an Independent Watchdog (IWDG) to detect logic errors and software faults caused by external environmental interference. The IWDG clock source comes from LSI, can run independently of the main program, and is suited for applications with low precision requirements.

### 7.1 Main Features

- 12-bit free-running downcounter
- Clocked from LSI clock divided, can run in low-power mode
- Reset condition: The downcounter value reaches 0

## 7.2 Functional Description

### 7.2.1 Principle and Application

The clock source of the independent watchdog is LSI clock, and its function can still work normally in stop and standby mode. When the watchdog downcounter value reaches 0, a system reset is generated, so the timeout period is (Reload value + 1) clocks.

CORE Prescaler register Status register Reload register Conctrol register **IWDG PSCR IWDG STATR IWDG RLDR** IWDG CTLR 12-bit reload value 8-bit LSI prescaler (40kHz 12-bit downcounter VDD voltage domain

Figure 7-1 Structure block diagram of Independent Watchdog

### • Enable independent watchdog

After the system reset, the watchdog is OFF. Write 0xCCCC to the IWDG\_CR register to enable the watchdog, and then it can no longer be disabled unless a reset occurs.

If the hardware independent watchdog enable bit (IWDG\_SW) is enabled in User Option Bytes, the IWDG is permanently enabled after the microcontroller reset.

#### Watchdog configuration

A 12-bit downcounter is in the watchdog. When the value of downcounter is reduced to 0, the system reset occurs. To enable IWDG, the following operations are needed:

- 1) Counter time base: IWDG clock source is LSI. Set the LSI divider factor clock as IWDG counter time base through IWDG\_PSCR register. Firstly write 0x5555 to the IWDG\_CTLR register, and then modify the divider factor in the IWDG\_PSCR register. The PVU bit in the IWDG\_STATR register indicates the update status of the divider factor. The divider factor can only be modified and read after the update is finished.
- 2) Reload value: It is used to update the current value of the counter in the independent watchdog, and the counter counts down from this value. Firstly write 0x5555 to the IWDG\_CTLR register, and then modify

the IWDG\_RLDR register to set the target reload value. The RVU bit in the IWDG\_STATR register indicates the update status of the reload value. The IWDG\_RLDR register can only be modified and read after the update is finished.

- 3) Watchdog enable: Write 0xCCCC to the IWDG\_CTLR register to enable the watchdog function.
- 4) Feed dog: The current counter value is refreshed before the watchdog downcounter reaches 0 to prevent the system reset. Write 0xAAAA to the IWDG\_CTLR register to update the IWDG\_RLDR register value to the watchdog counter by the hardware. This action needs to be executed regularly after the watchdog function is enabled. Otherwise, the watchdog reset action occurs.

### 7.2.2 Debug Mode

When the system enters the debug mode, the IWDG counter can be configured by the debug module register to continue working or stop.

## 7.3 Register Description

Table 7-1 IWDG registers

| Name           | Access address | Description        | Reset value |
|----------------|----------------|--------------------|-------------|
| R16_IWDG_CTLR  | 0x40003000     | Control register   | 0x0000      |
| R16_IWDG_PSCR  | 0x40003004     | Prescaler register | 0x0000      |
| R16_IWDG_RLDR  | 0x40003008     | Reload register    | 0x0FFF      |
| R16_IWDG_STATR | 0x4000300C     | Status register    | 0x0000      |

### 7.3.1 IWDG Control Register (IWDG CTLR)

Offset address: 0x00



| Bit    | Name      | Access | Description                                                                                                                                                    | Reset value |
|--------|-----------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [15:0] | KEY[15:0] | WO     | Operation key value lock.  0xAAAA: Feed dog. Load the IWDG_RLDR register value to the independent watchdog counter;  0x5555: Allow to modify R16 IWDG PSCR and |             |
| []     |           |        | R16_IWDG_RLDR registers; 0xCCCC: Enable the watchdog. If the hardware watchdog is enabled (User Option Bytes configured), there is no such restriction.        |             |

### 7.3.2 Prescaler Register (IWDG\_PSCR)



| Bit    | Name     | Access | Description                                                                                                                                                                                                                                                                                                                                                                                  | Reset value |
|--------|----------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [15:3] | Reserved | RO     | Reserved.                                                                                                                                                                                                                                                                                                                                                                                    | 0           |
| [2:0]  | PR[2:0]  | RW     | IWDG clock divider factor. Write 0x5555 to KEY before modifying this domain.  000: Divided by 4; 001: Divided by 8;  010: Divided by 16; 011: Divided by 32;  100: Divided by 64; 101: Divided by 128;  110: Divided by 256; 111: Divided by 256.  IWDG count time base = LSI/ division factor.  Note: Before reading the value of this domain, make sure that the PVU bit in the IWDG_STATR | 000Ь        |
|        |          |        | register is 0. Otherwise, the read value is invalid.                                                                                                                                                                                                                                                                                                                                         |             |

# 7.3.3 Reload Register (IWDG\_RLDR)

Offset address: 0x08

| 15 | 14   | 13    | 12 | 11 | 10 | 9 | 8 | 7 | 6   | 5     | 4 | 3 | 2 | 1 | 0 |
|----|------|-------|----|----|----|---|---|---|-----|-------|---|---|---|---|---|
|    | Rese | erved |    |    |    |   |   |   | RL[ | 11:0] |   |   |   |   |   |

| Bit     | Name     | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                      | Reset value |
|---------|----------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [15:12] | Reserved | RO     | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                        | 0           |
| [11:0]  | RL[11:0] | RW     | Counter reload value. Write 0x5555 to KEY before modifying this domain.  After writing 0xAAAA to KEY, the value of this field will be loaded into the counter by hardware, and then the counter will count down from this value.  Note: Before reading/writing the value of this domain, make sure that the RVU bit in the IWDG_STATR register is 0. Otherwise, read /write operation on this domain is invalid. | 0xFFF       |

# 7.3.4 Status Register (IWDG\_STATR)



| Bit    | Name     | Access | Description                                                                                                                                                                                                                                                      | Reset value |
|--------|----------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [15:2] | Reserved | RO     | Reserved.                                                                                                                                                                                                                                                        | 0           |
| 1      | RVU      | RO     | Reload value update. Set and cleared by hardware.  0: Update of the reload update completed (5 LSI cycles at most);  1: Update of the reload value is ongoing.  Note: The reload value register IWDG_RLDR can only be read /written after the RVU bit is cleared | 0           |

|     |    | to 0.                                              |   |
|-----|----|----------------------------------------------------|---|
|     |    | Clock prescaler value update. Set and cleared by   |   |
|     |    | hardware.                                          |   |
|     |    | 0: Update of the clock prescaler value completed   |   |
| PVU | RO | (At most 5 LSI cycles);                            | 0 |
| PVU | RO | 1: Update of the clock prescaler value is ongoing. | U |
|     |    | Note: The prescaler factor register                |   |
|     |    | (IWDG_PSCR) can only be read and written after     |   |
|     |    | the PVU bit is cleared to 0.                       |   |

Note: After the prescale or reload value is updated, there is no need to wait for the RVU or PVU to reset, the following code can be continued. (Even in low-power mode, this write operation can still be performed.)

V2. 4 77 WCH°

# **Chapter 8 Window Watchdog (WWDG)**

### This chapter applies to the whole family of CH32F20x, CH32V20x, CH32V30x and CH32V31x.

The Window Watchdog is generally used to monitor the software fault of the system operation, such as external interference and unforeseen logic errors. It needs to refresh the counter (Feed the dog) within a specific window time (With upper and lower limits). Otherwise, the watchdog circuit will generate a system reset before or after this window time.

### 8.2 Function Description

### 8.2.1 Principle and Application

The window watchdog runs based on a 7-bit downcounter, which is mounted under the APB1 bus. The counter time base WWDG\_CLK originates from the clock prescaler (PCLK1/4096). The clock prescaler factor is set by the WDGTB[1:0] bits in the WWDG\_CFGR register. The downcounter is at a free running status. No matter whether the watchdog function is enabled or not, the counter keeps counting down in a cycle. The internal structure block diagram of window watchdog is as shown in Figure 8-1.



Figure 8-1 Window Watchdog block diagram

### Enable window watchdog

After the system reset, the watchdog is disabled. Set the WDGA bit in the WWDG\_CTLR register to switch on the watchdog, and then it can no longer be disabled unless a reset occurs.

Note: WWDG clock source can be disabled by setting the RCC\_APB1PCENR register to suspend WWDG\_CLK counting and indirectly stop the watchdog function. Or reset the WWDG module by setting the RCC APB1PRSTR register, which is equivalent to the function of reset.

### Watchdog configuration

A 7-bit counter which continues downcounting in a cycle is in the watchdog, and it supports read/write access. To enable watchdog reset function, the following operations are needed:

1) Counter time base: The WDGTB[1:0] bits in the WWDG\_CFGR register. Note to switch on the WWDG module clock of the RCC unit.

- 2) Window counter: Set the W[6:0] bits in the WWDG CFGR register. This counter is used to be compared with the current counter by hardware, the value is configured by the user software and will not change. It serves as the maximum value of window time.
- 3) Watchdog enable: The WDGA bit in the WWDG CTLR register is set to 1 by software, and the watchdog function is enabled to reset the system.
- 4) Feed dog: Refresh the current counter value and configure the T[6:0] bits in the WWDG CTLR register. This action needs to be executed in the periodic window time after the watchdog function is enabled. Otherwise, the watchdog reset action occurs.

### Feed dog window time

As shown in Figure 8-2, the gray area is the detector window area of the window watchdog. Its maximum timeout (t<sub>2</sub>) corresponds to the time point when the current counter value reaches the window value W[6:0]. Its minimum timeout (t<sub>3</sub>) corresponds to the time point when the current counter value reaches 0x3F. Within this area time (t<sub>2</sub><t<t<sub>3</sub>), the feed dog operation can be performed (write T[6:0]) to refresh the current counter value.



Figure 8-2 Counting mode of window watchdog

### Watchdog reset:

1) When the feed dog operation is not performed in time, the value of the T[6:0] counter changes from 0x40 to 0x3F, a "Window Watchdog Reset" occurs, and a system reset occurs. I.e., when T6-bit is detected as 0 by hardware, the system reset occurs.

Note: The application program can write 0 to the T6-bit by software to implement system reset, which is equivalent to software reset function.

2) When the counter refresh action is executed when the feed dog operation is disabled, i.e., when write operation is performed on the T[6:0] bits when t₁≤t≤t₂, a "window watchdog reset" occurs, and a system reset occurs.

WCH<sup>®</sup> V2. 4 79

### Early wakeup

In order to avoid system reset caused by not refreshing the counter in time, the watchdog module provides early wake-up interrupt (EWI) notification. When the downcounter reaches 0x40, an early wake-up signal is generated and the EWIF flag is set to 1. If the EWI bit is set, the window watchdog interrupt is triggered at the same time. In this case, it takes single counter clock cycle to the hardware reset (Downcounting to 0x3F), and the application can immediately perform feed dog operation within the time limit.

### 8.2.2 Debug Mode

When the system enters debug mode, the WWDG counter can either continues to work normally or stops, depending on the debugging module register.

## 8.3 Register Description

Table 8-1 WWDG registers

| Name           | Access address | Description            | Reset value |
|----------------|----------------|------------------------|-------------|
| R16_WWDG_CTLR  | 0x40002C00     | Control register       | 0x007F      |
| R16_WWDG_CFGR  | 0x40002C04     | Configuration register | 0x007F      |
| R16_WWDG_STATR | 0x40002C08     | Status register        | 0x0000      |

## 8.3.1 WWDG Control Register (WWDG\_CTLR)

Offset address: 0x00



| Bit    | Name     | Access | Description                                                                                                                                                                         | Reset value |
|--------|----------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [15:8] | Reserved | RO     | Reserved                                                                                                                                                                            | 0           |
| 7      | WDGA     | RW1    | Window watchdog activation bit.  0: Watchdog disabled;  1: Watchdog enabled (Reset signal can be generated).  Set by software, and only cleared by hardware after reset.            | 0           |
| [6:0]  | T[6:0]   | RW     | 7-bit downcounter. Decremented every (4096*2 <sup>WDGTB</sup> ) PCLK1 cycles. When the counter rolls over from 0x40 to 0x3F, i.e., a watchdog reset is generated when T6 becomes 0. | ()x'/F      |

### 8.3.2 WWDG Configuration Register (WWDG CFGR)



| Bit     | Name     | Access | Description | Reset value |
|---------|----------|--------|-------------|-------------|
| [15:10] | Reserved | RO     | Reserved    | 0           |

|       |            |         | Early wakeup interrupt:                             |      |
|-------|------------|---------|-----------------------------------------------------|------|
| 9     | EWI        | RW1     | If it set to 1, interrupt is generated when the     | 0    |
|       | EWI        | IX VV 1 | counter reaches 0x40. It can only be cleared by     | U    |
|       |            |         | hardware after reset.                               |      |
|       |            |         | Window watchdog time base:                          |      |
|       |            | RW      | 00: not divided, counter time base =PCLK1/4096;     |      |
| [8:7] | WDGTB[1:0] |         | 01: divided by 2, counter time base = PCLK1/4096/2; | 00b  |
|       |            |         | 10: divided by 4, counter time base = PCLK1/4096/4; |      |
|       |            |         | 11: divided by 8, counter time base = PCLK1/4096/8. |      |
|       |            |         | Window watchdog 7-bit window value. It is used      |      |
|       |            |         | to be compared with the counter value. The feed     |      |
| [6:0] | W[6:0]     | RW      | dog operation can be performed only when the        | 0x7F |
|       |            |         | counter value is less than the window value and is  |      |
|       |            |         | greater than 0x3F.                                  |      |

# 8.3.3 WWDG Status Register (WWDG\_STATR)

Offset address: 0x08

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8       | 7  | 6 | 5 | 4 | 3 | 2 | 1 | 0    |
|----|----|----|----|----|----|---|---------|----|---|---|---|---|---|---|------|
|    |    |    |    |    |    | I | Reserve | ed |   |   |   |   |   |   | EWIF |

| Bit    | Name     | Access | Description                                                                                                                                                                                                                              | Reset value |
|--------|----------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [15:1] | Reserved | WO     | Reserved.                                                                                                                                                                                                                                | 0           |
| 0      | EWIF     |        | Early wakeup interrupt flag.  When the counter reaches 0x40, this bit is set by hardware, and it must be cleared by software. User setting is invalid. Even if the EWI is not set, this bit is still set as usual when the event occurs. | 0           |

V2. 4 81 WH°

# **Chapter 9 Interrupt and Events (NVIC/PFIC)**

### This chapter applies to the whole family of CH32F20x, CH32V20x, CH32V30x and CH32V31x.

TheCH32F20x is based on the Cortex-M3 core. It has a built-in Nested Vectored Interrupt Controller (NVIC) to manage 88 maskable external interrupt channels and 10 core interrupt channels, and other interrupt sources are reserved. The interrupt controller is closely connected with the core interface, which provides a flexible interrupt management function with the minimum interrupt delay. For details about the NVIC controller, please refer to the related documents of Cortex-M3.

The CH32V20x, CH32V30x and CH32V31x both have built-in Programmable Fast Interrupt Controller (PFIC), which supports up to 255 interrupt vectors. The current system manages 88 peripheral interrupt channels and 8 core interrupt channels, and others are reserved.

### 9.1 Main Features

### 9.1.1 **NVIC**

- 88 maskable interrupt channels
- Quick response of non-maskable interrupt
- Vectorized interrupt, which implements that the vector entry address directly enters the core
- Automatic stack and recovery when the interrupt enters and exits, with no additional command overhead needed
- 16 nested levels, priority-level dynamically modified

### 9.1.2 PFIC

- 88 peripheral interrupts. each interrupt request has an independent trigger bit and a mask control bit, and has a dedicated status bit
- Programmable multi-level interrupt nested, up to 8 nested levels, 3 hardware stack levels
- Dedicated fast interrupt in/out mechanism, hardware automatic stack and recovery, no command overhead needed
- Vector Table Free (VTF) interrupt response mechanism, 4-channel programmable access interrupt vector address

## 9.2 SysTick Timer

### • CH32F20x

The Cortex-M3 core is provided with a 24-bit downcounter (SysTick timer). It supports HCLK or HCLK/8 served as the time base and has a very high priority level (6). It is generally used to control time base of the system. Refer to related documents of Cortex-M3 for details.

### CH32V30x and CH32V31x

The core is provided with a 64-bit downcounter (SysTick) that supports HCLK or HCLK/8 as the time base, has a higher priority and can be used for time base after calibration.

# 9.3 Vector Table of Interrupt and Exception

Table 9-1 CH32F20x vector table

| Position | Priority | Priority type | Name                  | Description                             | Absolute address          |
|----------|----------|---------------|-----------------------|-----------------------------------------|---------------------------|
|          | -        | -             | -                     | Reserved                                | 0x00000000                |
|          | -3       | fixed         | Reset                 | Reset                                   | 0x00000004                |
|          | -2       | fixed         | NMI                   | Non-maskable interrupt                  | 0x00000008                |
|          | -1       | fixed         | HardFault             | All class of fault                      | 0x0000000C                |
|          | 0        | settable      | MemManage             | Memory management                       | 0x00000010                |
|          | 1        | settable      | BusFault              | Prefetch fault, memory access fault     | 0x00000014                |
|          | 2        | settable      | UsageFault            | Undefined instruction or illegal state  | 0x00000018                |
|          | -        | -             | -                     | Reserved                                | 0x0000001C-<br>0x0000002B |
|          | 3        | settable      | SVCall                | System service call via SWI instruction | 0x0000002C                |
|          | 4        | settable      | Debug Monitor         | Debug monitor                           | 0x00000030                |
|          | -        | -             | -                     | Reserved                                | 0x00000034                |
|          | 5        | settable      | PendSV                | Pendable system service                 | 0x00000038                |
|          | 6        | settable      | SysTick               | System tick timer                       | 0x0000003C                |
| 0        | 7        | programmable  | WWDG                  | Window watchdog timer interrupt         | 0x00000040                |
| 1        | 8        | programmable  | PVD                   | PVD through EXTI Line detection         | 0x00000044                |
| 2        | 9        | programmable  | TAMPER                | Tamper interrupt                        | 0x00000048                |
| 3        | 10       | programmable  | RTC                   | Real-time clock (RTC) global interrupt  | 0x0000004C                |
| 4        | 11       | programmable  | FLASH                 | FLASH global interrupt                  | 0x00000050                |
| 5        | 12       | programmable  | RCC                   | Reset and clock control (RCC) interrupt | 0x00000054                |
| 6        | 13       | programmable  | EXTI0                 | EXTI line0 interrupt                    | 0x00000058                |
| 7        | 14       | programmable  | EXTI1                 | EXTI line1 interrupt                    | 0x0000005C                |
| 8        | 15       | programmable  | EXTI2                 | EXTI line2 interrupt                    | 0x00000060                |
| 9        | 16       | programmable  | EXTI3                 | EXTI line3 interrupt                    | 0x00000064                |
| 10       | 17       | programmable  | EXTI4                 | EXTI line4 interrupt                    | 0x00000068                |
| 11       | 18       | programmable  | DMA1_CH1              | DMA1 channel1 global interrupt          | 0x0000006C                |
| 12       | 19       | programmable  | DMA1_CH2              | DMA1 channel2 global interrupt          | 0x00000070                |
| 13       | 20       | programmable  | DMA1_CH3              | DMA1 channel3 global interrupt          | 0x00000074                |
| 14       | 21       | programmable  | DMA1_CH4              | DMA1 channel4 global interrupt          | 0x00000078                |
| 15       | 22       | programmable  | DMA1_CH5              | DMA1 channel5 global interrupt          | 0x0000007C                |
| 16       | 23       | programmable  | DMA1_CH6              | DMA1 channel6 global interrupt          | 0x00000080                |
| 17       | 24       | programmable  | DMA1_CH7              | DMA1 channel7 global interrupt          | 0x00000084                |
| 18       | 25       | programmable  | ADC1_2                | ADC1 and ADC2 global interrupt          | 0x00000088                |
| 19       | 26       | programmable  | USB_HP or<br>CAN1_TX  | USB_HP or CAN1_TX global interrupt      | 0x0000008C                |
| 20       | 27       | programmable  | USB_LP or<br>CAN1_RX0 | USB_LP or CAN1_RX0 global interrupt     | 0x00000090                |
| 21       | 28       | programmable  | CAN1_RX1              | CAN1_RX1 global interrupt               | 0x00000094                |
| 22       | 29       | programmable  | CAN1_SCE              | CAN1_SCE global interrupt               | 0x00000098                |

| 23 | 30 | programmable | EXTI9 5      | EXTI line[9:5] interrupts                 | 0x0000009C                             |
|----|----|--------------|--------------|-------------------------------------------|----------------------------------------|
| 24 | 31 | programmable | TIM1 BRK     | TIM1 break interrupt                      | 0x000000000000000000000000000000000000 |
| 25 | 32 | programmable | TIM1_UP      | TIM1 update interrupt                     | 0x000000A4                             |
| 26 | 33 | programmable | TIM1_TRG_COM | TIM1 trigger and communication interrupts | 0x000000A8                             |
| 27 | 34 | programmable | TIM1 CC      | TIM1 capture compare interrupt            | 0x000000AC                             |
| 28 | 35 | programmable | TIM2         | TIM2 global interrupt                     | 0x000000B0                             |
| 29 | 36 | programmable | TIM3         | TIM3 global interrupt                     | 0x000000B4                             |
| 30 | 37 | programmable | TIM4         | TIM4 global interrupt                     | 0x000000B8                             |
| 31 | 38 | programmable | I2C1_EV      | I2C1 event interrupt                      | 0x000000BC                             |
| 32 | 39 | programmable | I2C1 ER      | I2C1 error interrupt                      | 0x000000C0                             |
| 33 | 40 | programmable | I2C2 EV      | I2C2 event interrupt                      | 0x000000C4                             |
| 34 | 41 | programmable | I2C2 ER      | I2C2 error interrupt                      | 0x000000C8                             |
| 35 | 42 | programmable | SPI1         | SPI1 global interrupt                     | 0x000000CC                             |
| 36 | 43 | programmable | SPI2         | SPI2 global interrupt                     | 0x000000D0                             |
| 37 | 44 | programmable | USART1       | USART1 global interrupt                   | 0x000000D4                             |
| 38 | 45 | programmable | USART2       | USART2 global interrupt                   | 0x000000D8                             |
| 39 | 46 | programmable | USART3       | USART3 global interrupt                   | 0x000000DC                             |
| 40 | 47 | programmable | EXTI15 10    | EXTI line[15:10] interrupts               | 0x000000E0                             |
| 41 | 48 | programmable | RTCAlarm     | RTC alarm through EXTI line interrupt     | 0x000000E4                             |
| 42 | 49 | programmable | USBWakeUp    | USB wake-up through EXTI line             | 0x000000E8                             |
| 43 | 50 | programmable | TIM8 BRK     | TIM8 break interrupt                      | 0x000000EC                             |
| 44 | 51 | programmable | TIM8_UP      | TIM8 update interrupt                     | 0x000000F0                             |
| 45 | 52 | programmable | TIM8_TRG_COM | TIM8 trigger and communication interrupts | 0x000000F4                             |
| 46 | 53 | programmable | TIM8 CC      | TIM8 capture compare interrupt            | 0x000000F8                             |
| 47 | 54 | programmable | RNG          | RNG global interrupt                      | 0x000000FC                             |
| 48 | 55 | -            | -            | Reserved                                  | 0x00000100                             |
| 49 | 56 | programmable | SDIO         | SDIO global interrupt                     | 0x00000104                             |
| 50 | 57 | programmable | TIM5         | TIM5 global interrupt                     | 0x00000108                             |
| 51 | 58 | programmable | SPI3         | SPI3 global interrupt                     | 0x0000010C                             |
| 52 | 59 | programmable | USART4       | USART4 global interrupt                   | 0x00000110                             |
| 53 | 60 | programmable | USART5       | USART5 global interrupt                   | 0x00000114                             |
| 54 | 61 | programmable | TIM6         | TIM6 global interrupt                     | 0x00000118                             |
| 55 | 62 | programmable | TIM7         | TIM7 global interrupt                     | 0x0000011C                             |
| 56 | 63 | programmable | DMA2_CH1     | DMA2 channel1 global interrupt            | 0x00000120                             |
| 57 | 64 | programmable | DMA2_CH2     | DMA2 channel2 global interrupt            | 0x00000124                             |
| 58 | 65 | programmable | DMA2_CH3     | DMA2 channel3 global interrupt            | 0x00000128                             |
| 59 | 66 | programmable | DMA2_CH4     | DMA2 channel4 global interrupt            | 0x0000012C                             |
| 60 | 67 | programmable | DMA2_CH5     | DMA2 channel5 global interrupt            | 0x00000130                             |
| 61 | 68 | programmable | ETH          | ETH global interrupt                      | 0x00000134                             |
| 62 | 69 | programmable | ETH_WKUP     | ETH wakeup interrupt                      | 0x00000138                             |
| 63 | 70 | programmable | CAN2_TX      | CAN2_TX global interrupt                  | 0x0000013C                             |
| 64 | 71 | programmable | CAN2_RX0     | CAN2_RX0 global interrupt                 | 0x00000140                             |

| CAN2_SCE   CAN2_SCE global interrupt   Ox0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |         |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| 67 74 programmable OTG_FS Full-speed OTG interrupt 0x0 68 75 programmable USBHSWakeUp High-speed USB wakeup interrupt 0x0 69 76 programmable USBHS High-speed USB global interrupt 0x0 70 77 programmable DVP DVP global interrupt 0x0 71 78 programmable USART6 USART6 global interrupt 0x0 72 79 programmable USART7 USART7 global interrupt 0x0 73 80 programmable USART8 USART8 global interrupt 0x0 74 81 programmable TIM9_BRK TIM9 break interrupt 0x0 75 82 programmable TIM9_UP TIM9 update interrupt 0x0 76 83 TIM9_TRG_COM 77 84 programmable TIM9_CC TIM9 capture compare interrupt 0x0 78 85 programmable TIM10_BRK TIM10 break interrupt 0x0 79 86 programmable TIM10_UP TIM10 update interrupt 0x0 TIM10 trigger and communication 0x0 TIM10 trigger and communication 0x0 TIM10 trigger and communication 0x0 TIM10 trigger and communication 0x0 TIM10 trigger and communication 0x0 TIM10 trigger and communication 0x0 TIM10 trigger and communication 0x0 TIM10 trigger and communication 0x0 TIM10 trigger and communication 0x0                                                                                                                                        | 0000144 |
| 68 75 programmable USBHSWakeUp High-speed USB wakeup interrupt 0x0 69 76 programmable USBHS High-speed USB global interrupt 0x0 70 77 programmable DVP DVP global interrupt 0x0 71 78 programmable USART6 USART6 global interrupt 0x0 72 79 programmable USART7 USART7 global interrupt 0x0 73 80 programmable USART8 USART8 global interrupt 0x0 74 81 programmable TIM9_BRK TIM9 break interrupt 0x0 75 82 programmable TIM9_UP TIM9 update interrupt 0x0 76 83 programmable TIM9_CC TIM9 capture compare interrupt 0x0 77 84 programmable TIM9_CC TIM9 capture compare interrupt 0x0 78 85 programmable TIM10_BRK TIM10 break interrupt 0x0 79 86 programmable TIM10_UP TIM10 update interrupt 0x0 TIM10 trigger and communication 0x0 TIM10 trigger and communication 0x0 TIM10 trigger and communication 0x0 TIM10 trigger and communication 0x0 TIM10 trigger and communication 0x0 TIM10 trigger and communication 0x0 TIM10 trigger and communication 0x0 TIM10 trigger and communication 0x0                                                                                                                                                                                        | 0000148 |
| 69       76       programmable       USBHS       High-speed USB global interrupt       0x0         70       77       programmable       DVP       DVP global interrupt       0x0         71       78       programmable       USART6       USART6 global interrupt       0x0         72       79       programmable       USART7       USART7 global interrupt       0x0         73       80       programmable       USART8       USART8 global interrupt       0x0         74       81       programmable       TIM9_BRK       TIM9 break interrupt       0x0         75       82       programmable       TIM9_UP       TIM9 update interrupt       0x0         76       83       programmable       TIM9_TRG_COM       TIM9 trigger and communication interrupts       0x0         77       84       programmable       TIM10_BRK       TIM10 break interrupt       0x0         78       85       programmable       TIM10_UP       TIM10 update interrupt       0x0         79       86       programmable       TIM10_TRG_CO       TIM10 trigger and communication       0x0         80       87       programmable       TIM10_TRG_CO       TIM10 trigger and communication       0x0 | 000014C |
| 70       77       programmable       DVP       DVP global interrupt       0x0         71       78       programmable       USART6       USART6 global interrupt       0x0         72       79       programmable       USART7       USART7 global interrupt       0x0         73       80       programmable       USART8       USART8 global interrupt       0x0         74       81       programmable       TIM9_BRK       TIM9 break interrupt       0x0         75       82       programmable       TIM9_UP       TIM9 update interrupt       0x0         76       83       programmable       TIM9_TRG_COM       TIM9 trigger and communication interrupt       0x0         77       84       programmable       TIM10_BRK       TIM10 break interrupt       0x0         78       85       programmable       TIM10_UP       TIM10 update interrupt       0x0         79       86       programmable       TIM10_TRG_CO       TIM10 trigger and communication       0x0         80       87       programmable       TIM10_TRG_CO       TIM10 trigger and communication       0x0                                                                                                     | 0000150 |
| 71       78       programmable       USART6       USART6 global interrupt       0x0         72       79       programmable       USART7       USART7 global interrupt       0x0         73       80       programmable       USART8       USART8 global interrupt       0x0         74       81       programmable       TIM9_BRK       TIM9 break interrupt       0x0         75       82       programmable       TIM9_UP       TIM9 update interrupt       0x0         76       83       programmable       TIM9_TRG_COM       TIM9 trigger and communication interrupts       0x0         77       84       programmable       TIM10_BRK       TIM10 break interrupt       0x0         78       85       programmable       TIM10_BRK       TIM10 update interrupt       0x0         79       86       programmable       TIM10_TRG_CO       TIM10 trigger and communication       0x0         80       87       programmable       TIM10_TRG_CO       TIM10 trigger and communication       0x0                                                                                                                                                                                         | 0000154 |
| 72       79       programmable       USART7       USART7 global interrupt       0x0         73       80       programmable       USART8       USART8 global interrupt       0x0         74       81       programmable       TIM9_BRK       TIM9 break interrupt       0x0         75       82       programmable       TIM9_UP       TIM9 update interrupt       0x0         76       83       programmable       TIM9_TRG_COM       TIM9 trigger and communication interrupts       0x0         77       84       programmable       TIM9_CC       TIM9 capture compare interrupt       0x0         78       85       programmable       TIM10_BRK       TIM10 break interrupt       0x0         79       86       programmable       TIM10_UP       TIM10 update interrupt       0x0         80       87       programmable       TIM10_TRG_CO       TIM10 trigger and communication       0x0                                                                                                                                                                                                                                                                                            | 0000158 |
| 73       80       programmable       USART8       USART8 global interrupt       0x0         74       81       programmable       TIM9_BRK       TIM9 break interrupt       0x0         75       82       programmable       TIM9_UP       TIM9 update interrupt       0x0         76       83       programmable       TIM9_TRG_COM       TIM9 trigger and communication interrupts       0x0         77       84       programmable       TIM9_CC       TIM9 capture compare interrupt       0x0         78       85       programmable       TIM10_BRK       TIM10 break interrupt       0x0         79       86       programmable       TIM10_UP       TIM10 update interrupt       0x0         80       87       programmable       TIM10_TRG_CO       TIM10 trigger and communication       0x0                                                                                                                                                                                                                                                                                                                                                                                        | 000015C |
| 74     81     programmable     TIM9_BRK     TIM9 break interrupt     0x0       75     82     programmable     TIM9_UP     TIM9 update interrupt     0x0       76     83     programmable     TIM9_TRG_COM     TIM9 trigger and communication interrupts     0x0       77     84     programmable     TIM9_CC     TIM9 capture compare interrupt     0x0       78     85     programmable     TIM10_BRK     TIM10 break interrupt     0x0       79     86     programmable     TIM10_UP     TIM10 update interrupt     0x0       80     87     programmable     TIM10_TRG_CO     TIM10 trigger and communication     0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0000160 |
| 75 82 programmable TIM9_UP TIM9 update interrupt 0x0  76 83 programmable TIM9_TRG_COM TIM9 trigger and communication interrupts  77 84 programmable TIM9_CC TIM9 capture compare interrupt 0x0  78 85 programmable TIM10_BRK TIM10 break interrupt 0x0  79 86 programmable TIM10_UP TIM10 update interrupt 0x0  80 87 programmable TIM10_TRG_CO TIM10 trigger and communication 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 0000164 |
| 76 83 programmable TIM9_TRG_COM TIM9 trigger and communication interrupts 0x0 interrupts  77 84 programmable TIM9_CC TIM9 capture compare interrupt 0x0 78 85 programmable TIM10_BRK TIM10 break interrupt 0x0 79 86 programmable TIM10_UP TIM10 update interrupt 0x0 programmable TIM10_TRG_CO TIM10 trigger and communication 0x0 0x0 0x0 0x0 0x0 0x0 0x0 0x0 0x0 0x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0000168 |
| 76 83 TIM9_TRG_COM interrupts 0x0  77 84 programmable TIM9_CC TIM9 capture compare interrupt 0x0  78 85 programmable TIM10_BRK TIM10 break interrupt 0x0  79 86 programmable TIM10_UP TIM10 update interrupt 0x0  80 87 programmable TIM10_TRG_CO TIM10 trigger and communication 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 000016C |
| 78 85 programmable TIM10_BRK TIM10 break interrupt 0x0 79 86 programmable TIM10_UP TIM10 update interrupt 0x0 80 87 programmable TIM10_TRG_CO TIM10 trigger and communication 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0000170 |
| 79 86 programmable TIM10_UP TIM10 update interrupt 0x0  80 87 programmable TIM10_TRG_CO TIM10 trigger and communication 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0000174 |
| 80 87 programmable TIM10_TRG_CO TIM10 trigger and communication 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 0000178 |
| 80 87 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 000017C |
| M interrupts                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0000180 |
| 81 88 programmable TIM10_CC TIM10 capture compare interrupt 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0000184 |
| 82 89 programmable DMA2_CH6 DMA2 channel6 global interrupt 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0000188 |
| 83 90 programmable DMA2_CH7 DMA2 channel7 global interrupt 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 000018C |
| 84 91 programmable DMA2_CH8 DMA2 channel8 global interrupt 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0000190 |
| 85 92 programmable DMA2_CH9 DMA2 channel9 global interrupt 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0000194 |
| 86 93 programmable DMA2_CH10 DMA2 channel10 global interrupt 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0000198 |
| 87 94 programmable DMA2_CH11 DMA2 channel11 global interrupt 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 000019C |

Table 9-2 CH32V20x, CH32V30x and CH32V31x vector table

| No.   | Priority | Туре         | Name       | Description                        | Entry address |
|-------|----------|--------------|------------|------------------------------------|---------------|
| 0     | -        | -            | -          | -                                  | 0x00000000    |
| 1     | -        | -            | -          | -                                  | 0x00000004    |
| 2     | -5       | fixed        | NMI        | Non-maskable interrupt             | 0x00000008    |
| 3     | -4       | fixed        | HardFault  | Exception interrupt                | 0x0000000C    |
| 4     | -        | -            | -          | Reserved                           | 0x00000010    |
| 5     | -3       | fixed        | Ecall-M    | Callback interrupt in machine mode | 0x00000014    |
| 6-7   |          |              |            | Reserved                           | 0x00000018 to |
| 0-7   | -        | -            | -          | Reserved                           | 0x0000001C    |
| 8     | -2       | fixed        | Ecall-U    | Callback interrupt in user mode    | 0x00000020    |
| 9     | -1       | fixed        | BreakPoint | Breakpoint callback interrupt      | 0x00000024    |
| 10-11 |          |              |            | Reserved                           | 0x00000028 to |
| 10-11 | -        | -            | -          | Reserved                           | 0x0000002C    |
| 12    | 0        | programmable | SysTick    | System timer interrupt             | 0x00000030    |
| 13    | -        | -            | -          | Reserved                           | 0x00000034    |
| 14    | 1        | programmable | SW         | Software interrupt                 | 0x00000038    |
| 15    | -        | -            | -          | Reserved                           | 0x0000003C    |

| 16 | 2  | , macmanahla | WWDG                 | Window timer interrupt                    | 0x00000040 |
|----|----|--------------|----------------------|-------------------------------------------|------------|
| 10 |    | programmable | w wDG                | Power voltage detector interrupt          | 0x00000040 |
| 17 | 3  | programmable | PVD                  | (EXTI)                                    | 0x00000044 |
| 18 | 4  | programmable | TAMPER               | Tamper interrupt                          | 0x00000048 |
| 19 | 5  | programmable | RTC                  | Real-time clock interrupt                 | 0x0000004C |
| 20 | 6  | programmable | FLASH                | Flash memory global interrupt             | 0x00000050 |
| 21 | 7  | programmable | RCC                  | Reset and clock control interrupt         | 0x00000054 |
| 22 | 8  | programmable | EXTI0                | EXTI line0 interrupt                      | 0x00000058 |
| 23 | 9  | programmable | EXTI1                | EXTI line1 interrupt                      | 0x0000005C |
| 24 | 10 | programmable | EXTI2                | EXTI line2 interrupt                      | 0x00000060 |
| 25 | 11 | programmable | EXTI3                | EXTI line3 interrupt                      | 0x00000064 |
| 26 | 12 | programmable | EXTI4                | EXTI line4 interrupt                      | 0x00000068 |
| 27 | 13 | programmable | DMA1_CH1             | DMA1 channel1 global interrupt            | 0x0000006C |
| 28 | 14 | programmable | DMA1_CH2             | DMA1 channel2 global interrupt            | 0x00000070 |
| 29 | 15 | programmable | DMA1_CH3             | DMA1 channel3 global interrupt            | 0x00000074 |
| 30 | 16 | programmable | DMA1_CH4             | DMA1 channel4 global interrupt            | 0x00000078 |
| 31 | 17 | programmable | DMA1_CH5             | DMA1 channel5 global interrupt            | 0x0000007C |
| 32 | 18 | programmable | DMA1_CH6             | DMA1 channel6 global interrupt            | 0x00000080 |
| 33 | 19 | programmable | DMA1_CH7             | DMA1 channel7 global interrupt            | 0x00000084 |
| 34 | 20 | programmable | ADC1_2               | ADC1 and ADC2global interrupt             | 0x00000088 |
| 35 | 21 | programmable | USB_HP or<br>CAN1_TX | USB_HP or CAN1_TXglobal interrupt         | 0x0000008C |
| 36 | 22 | programmable | USB_LP or            | USB_LP or CAN1_RX0global                  | 0x00000090 |
| 27 | 22 | 1.1          | CAN1_RX0             | interrupt                                 | 0.0000004  |
| 37 | 23 | programmable | CAN1_RX1             | CANI_RX1global interrupt                  | 0x00000094 |
| 38 | 24 | programmable | CAN1_SCE             | CAN1_SCEglobal interrupt                  | 0x00000098 |
| 39 | 25 | programmable | EXTI9_5              | EXTI line[9:5] interrupts                 | 0x0000009C |
| 40 | 26 | programmable | TIM1_BRK             | TIM1 break interrupt                      | 0x000000A0 |
| 41 | 27 | programmable | TIM1_UP              | TIM1 update interrupt                     | 0x000000A4 |
| 42 | 28 | programmable | TIM1_TRG_COM         | TIM1 trigger and communication interrupts | 0x000000A8 |
| 43 | 29 | programmable | TIM1_CC              | TIM1 capture compare interrupt            | 0x000000AC |
| 44 | 30 | programmable | TIM2                 | TIM2 global interrupt                     | 0x000000B0 |
| 45 | 31 | programmable | TIM3                 | TIM3 global interrupt                     | 0x000000B4 |
| 46 | 32 | programmable | TIM4                 | TIM4 global interrupt                     | 0x000000B8 |
| 47 | 33 | programmable | I2C1_EV              | I <sup>2</sup> C1 event interrupt         | 0x000000BC |
| 48 | 34 | programmable | I2C1_ER              | I <sup>2</sup> C1 error interrupt         | 0x000000C0 |
| 49 | 35 | programmable | I2C2_EV              | I <sup>2</sup> C2 event interrupt         | 0x000000C4 |
| 50 | 36 | programmable | I2C2_ER              | I <sup>2</sup> C2 error interrupt         | 0x000000C8 |
| 51 | 37 | programmable | SPI1                 | SPI1 global interrupt                     | 0x000000CC |
| 52 | 38 | programmable | SPI2                 | SPI2 global interrupt                     | 0x000000D0 |
| 53 | 39 | programmable | USART1               | USART1 global interrupt                   | 0x000000D4 |
| 54 | 40 | programmable | USART2               | USART2 global interrupt                   | 0x000000D8 |
| 55 | 41 | programmable | USART3               | USART3 global interrupt                   | 0x000000DC |
| 56 | 42 | programmable | EXTI15_10            | EXTI line[15:10] interrupts               | 0x000000E0 |

| 57 | 43 | programmable | RTCAlarm          | RTC alarm interrupt (EXTI)                 | 0x000000E4 |
|----|----|--------------|-------------------|--------------------------------------------|------------|
| 58 | 44 | programmable | USBWakeUp         | USB wakeup interrupt (EXTI)                | 0x000000E8 |
| 59 | 45 | programmable | TIM8 BRK          | TIM8 break interrupt                       | 0x000000EC |
| 60 | 46 | programmable | TIM8 UP           | TIM8 update interrupt                      | 0x000000F0 |
|    |    |              | _                 | TIM8 trigger and communication             |            |
| 61 | 47 | programmable | TIM8_TRG_COM      | interrupts                                 | 0x000000F4 |
| 62 | 48 | programmable | TIM8 CC           | TIM8 capture compare interrupt             | 0x000000F8 |
| 63 | 49 | programmable | RNG               | RNG global interrupt                       | 0x000000FC |
| 64 | 50 | -            | -                 | Reserved                                   | 0x00000100 |
| 65 | 51 | programmable | SDIO              | SDIO global interrupt                      | 0x00000104 |
| 66 | 52 | programmable | TIM5              | TIM5 global interrupt                      | 0x00000108 |
| 67 | 53 | programmable | SPI3              | SPI3 global interrupt                      | 0x0000010C |
| 68 | 54 | programmable | USART4            | USART4 global interrupt                    | 0x00000110 |
| 69 | 55 | programmable | USART5            | USART5 global interrupt                    | 0x00000114 |
| 70 | 56 | programmable | TIM6              | TIM6 global interrupt                      | 0x00000118 |
| 71 | 57 | programmable | TIM7              | TIM7 global interrupt                      | 0x0000011C |
| 72 | 58 | programmable | DMA2_CH1          | DMA2 channel1 global interrupt             | 0x00000120 |
| 73 | 59 | programmable | DMA2_CH2          | DMA2 channel2 global interrupt             | 0x00000124 |
| 74 | 60 | programmable | DMA2_CH3          | DMA2 channel3 global interrupt             | 0x00000128 |
| 75 | 61 | programmable | DMA2_CH4          | DMA2 channel4 global interrupt             | 0x0000012C |
| 76 | 62 | programmable | DMA2_CH5          | DMA2 channel5 global interrupt             | 0x00000130 |
| 77 | 63 | programmable | ETH               | ETH global interrupt                       | 0x00000134 |
| 78 | 64 | programmable | ETH_WKUP          | ETH wakeup interrupt                       | 0x00000138 |
| 79 | 65 | programmable | CAN2_TX           | CAN2_TX global interrupt                   | 0x0000013C |
| 80 | 66 | programmable | CAN2_RX0          | CAN2_RX0 global interrupt                  | 0x00000140 |
| 81 | 67 | programmable | CAN2_RX1          | CAN2_RX1 global interrupt                  | 0x00000144 |
| 82 | 68 | programmable | CAN2_SCE          | CAN2_SCE global interrupt                  | 0x00000148 |
| 83 | 69 | programmable | OTG_FS            | Full-speed OTG interrupt                   | 0x0000014C |
| 84 | 70 | programmable | USBHSWakeUp       | High-speed USB wakeup interrupt            | 0x00000150 |
| 85 | 71 | programmable | USBHS             | High-speed USB global interrupt            | 0x00000154 |
| 86 | 72 | programmable | DVP               | DVP global interrupt                       | 0x00000158 |
| 87 | 73 | programmable | USART6            | USART6 global interrupt                    | 0x0000015C |
| 88 | 74 | programmable | USART7            | USART7 global interrupt                    | 0x00000160 |
| 89 | 75 | programmable | USART8            | USART8 global interrupt                    | 0x00000164 |
| 90 | 76 | programmable | TIM9_BRK          | TIM9 break interrupt                       | 0x00000168 |
| 91 | 77 | programmable | TIM9_UP           | TIM9 update interrupt                      | 0x0000016C |
| 92 | 78 | programmable | TIM9_TRG_COM      | TIM9 trigger and communication interrupts  | 0x00000170 |
| 93 | 79 | programmable | TIM9_CC           | TIM9 capture compare interrupt             | 0x00000174 |
| 94 | 80 | programmable | TIM10_BRK         | TIM10 break interrupt                      | 0x00000178 |
| 95 | 81 | programmable | TIM10_UP          | TIM10 update interrupt                     | 0x0000017C |
| 96 | 82 | programmable | TIM10_TRG_CO<br>M | TIM10 trigger and communication interrupts | 0x00000180 |
| 97 | 83 | programmable | TIM10_CC          | TIM10 capture compare interrupt            | 0x00000184 |
| 98 | 84 | programmable | DMA2_CH6          | DMA2 channel6 global interrupt             | 0x00000188 |

| 99  | 85 | programmable | DMA2_CH7  | DMA2 channel7 global interrupt  | 0x0000018C |
|-----|----|--------------|-----------|---------------------------------|------------|
| 100 | 86 | programmable | DMA2_CH8  | DMA2 channel8 global interrupt  | 0x00000190 |
| 101 | 87 | programmable | DMA2_CH9  | DMA2 channel9 global interrupt  | 0x00000194 |
| 102 | 88 | programmable | DMA2_CH10 | DMA2 channel10 global interrupt | 0x00000198 |
| 103 | 89 | programmable | DMA2_CH11 | DMA2 channel11 global interrupt | 0x0000019C |

# 9.4 External Interrupt and Event Controller (EXTI)

### 9.4.1 Overview

Figure 9-1 External interrupt (EXTI) interface block diagram



Figure shown in Figure 9-1, the trigger source of an external interrupt can be either a software interrupt (SWIEVR) or an actual external interrupt channel. The signal of the external interrupt channel is firstly filtered by the edge detect circuit. As long as either soft interrupt or external interrupt signal is generated, it is output to dual AND gate circuits of event enable and interrupt enable through the OR circuit in the figure. As long as the interrupt or the event is enabled, an interrupt or event is generated. 6 registers of EXTI are accessed by the processer through PB2 interface.

### 9.4.2 Wakeup Event

The system can wake up from sleep mode caused by WFE command via wake-up event. The wake-up event is generated through the following 2 types of configuration:

- Enable an interrupt in the peripheral register, but do not enable the interrupt in the NVIC or PEIC of the core, and enable the SEVONPEND bit in the core at the same time. Reflected in EXTI, EXTI interrupt is enabled, but EXTI interrupt in NVIC or PEIC is not enabled, at the same time, enable the SEVONPEND bit. When the CPU is woken up from WFE, the EXTI interrupt flag bit and NVIC/PEIC pending bit need to be cleared.
- Enable an EXTI channel as an event channel. It is not necessary to clear the interrupt flag bit and NVIC/PEIC pending bit after the CPU is woken up from WFE.

### 9.4.3 Description

To use the external interrupt, it is needed to configure the corresponding external interrupt channel, i.e., select the corresponding trigger edge and enable the interrupt. When the set trigger edge appears on the external interrupt channel, an interrupt request is generated and the corresponding interrupt flag bit is also set. Write 1 to the flag bit to clear such flag bit.

Steps to use external hardware interrupt:

- 1) Configure GPIO;
- 2) Configure the EXTI INTENR bit in the corresponding external interrupt channel;
- 3) Configure the trigger edge (EXTI\_RTENR or EXTI\_FTENR), select rising edge trigger, falling edge trigger or double edges trigger;
- 4) Configure the EXTI interrupt in the NVIC/PFIC of the core to ensure that it can respond correctly.

Steps to use external hardware event:

- 1) Configure GPIO;
- 2) Configure the EXTI\_EVENR bit in the corresponding external interrupt channel;
- 3) Configure the trigger edge (EXTI\_RTENR or EXTI\_FTENR), select rising edge trigger, falling edge trigger or double edges trigger.

Steps to use software interrupt/event:

- 1) Enable external interrupt (EXTI\_INTENR) or external event (EXTI\_EVENR);
- 2) To use the interrupt service function, set the EXTI interrupt in the NVIC/PEIC of the core;
- 3) Set the software interrupt trigger (EXTI SWIEVR) to generate an interrupt.

### 9.4.4 External Event Map

Table 9-3 EXTI interrupt map

| External interrupt/event line | Mapping event description                                                                                                                                            |  |  |  |  |  |  |  |  |
|-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| EXTI0~EXTI15                  | Px0~Px15 (x=A/B/C/D/E). Any IO port can enable the external interrupt/event function, configured by AFIO_EXTICRx register.                                           |  |  |  |  |  |  |  |  |
| EXTI16                        | PVD event: Exceed the voltage detector threshold                                                                                                                     |  |  |  |  |  |  |  |  |
| EXTI17                        | RTC alarm event                                                                                                                                                      |  |  |  |  |  |  |  |  |
| EXTI18                        | USBD/USBFSOTG wakeup event (Applied for CH32F20x_D8, CH32F20x_D8C, CH32V30x_D8, CH32V30x_D8C and CH32V31x_D8C) USBD wakeup event (Applied for other product numbers) |  |  |  |  |  |  |  |  |
| EXTI19                        | ETH wakeup event                                                                                                                                                     |  |  |  |  |  |  |  |  |
| EXTI20                        | USBHS wakeup event (Applied for <i>CH32F20x_D8C</i> , <i>CH32V30x_D8C</i> and CH32V31x_D8C)                                                                          |  |  |  |  |  |  |  |  |

|        | USBFS wakeup event (Applied for other product numbers)          |  |  |  |  |  |  |  |  |
|--------|-----------------------------------------------------------------|--|--|--|--|--|--|--|--|
| EXTI21 | Internal 32K calibration wakeup event (Applied for CH32V20x_D8, |  |  |  |  |  |  |  |  |
| EAT121 | CH32V20x_D8W and CH32F20x_D8W)                                  |  |  |  |  |  |  |  |  |

# 9.5 Register Description

# 9.5.1 EXTI Registers

Table 9-4 EXTI registers

| Name            | Access address | Description                          | Reset value |
|-----------------|----------------|--------------------------------------|-------------|
| R32_EXTI_INTENR | 0x40010400     | Interrupt enable register            | 0x00000000  |
| R32_EXTI_EVENR  | 0x40010404     | Event enable register                | 0x00000000  |
| R32_EXTI_RTENR  | 0x40010408     | Rising edge trigger enable register  | 0x00000000  |
| R32_EXTI_FTENR  | 0x4001040C     | Falling edge trigger enable register | 0x00000000  |
| R32_EXTI_SWIEVR | 0x40010410     | Software interrupt event register    | 0x00000000  |
| R32_EXTI_INTFR  | 0x40010414     | Interrupt flag register              | 0x0000XXXX  |

# 9.5.1.1 Interrupt Enable Register (EXTI\_INTENR)

Offset address: 0x00

| 31  | 30       | 29  | 28   | 27  | 26  | 25  | 24  | 23  | 22       | 21       | 20       | 19       | 18       | 17   | 16  |
|-----|----------|-----|------|-----|-----|-----|-----|-----|----------|----------|----------|----------|----------|------|-----|
|     | Reserved |     |      |     |     |     |     |     | MR2<br>1 | MR2<br>0 | MR1<br>9 | MR1<br>8 | MR1<br>7 | MR16 |     |
| 15  | 14       | 13  | 12   | 11  | 10  | 9   | 8   | 7   | 6        | 5        | 4        | 3        | 2        | 1    | 0   |
| MR1 | MR1      | MR1 | MR12 | MR1 | MR1 | MR9 | MR8 | MR7 | MR6      | MR5      | MR4      | MR3      | MR2      | MR1  | MR0 |

| Bit     | Name     | Access | Description                                    | Reset value |
|---------|----------|--------|------------------------------------------------|-------------|
| [31:22] | Reserved | RO     | Reserved.                                      | 0           |
|         |          | RW     | Interrupt request signal of external interrupt |             |
| [21:0]  | MRx      |        | channelx enable:                               | 0           |
| [21.0]  | IVIIX    |        | 0: Interrupt disabled;                         |             |
|         |          |        | 1: Interrupt enabled.                          |             |

# 9.5.1.2 Event Enable Register (EXTI\_EVENR)

| 31       | 30       | 29  | 28   | 27  | 26       | 25  | 24  | 23       | 22       | 21       | 20       | 19       | 18   | 17  | 16  |
|----------|----------|-----|------|-----|----------|-----|-----|----------|----------|----------|----------|----------|------|-----|-----|
| Reserved |          |     |      |     |          |     |     | MR2<br>1 | MR2<br>0 | MR1<br>9 | MR1<br>8 | MR1<br>7 | MR16 |     |     |
| 15       | 14       | 13  | 12   | 11  | 10       | 9   | 8   | 7        | 6        | 5        | 4        | 3        | 2    | 1   | 0   |
| MR1      | MR1<br>4 | MR1 | MR12 | MR1 | MR1<br>0 | MR9 | MR8 | MR7      | MR6      | MR5      | MR4      | MR3      | MR2  | MR1 | MR0 |

| Bit     | Name     | Access | Description                                         | Reset value |  |
|---------|----------|--------|-----------------------------------------------------|-------------|--|
| [31:22] | Reserved | RO     | Reserved.                                           | 0           |  |
| [21:0]  | MRx      | RW     | Event request signal of external interrupt channels | 0           |  |

| enable:            |
|--------------------|
| 0: Event disabled; |
| 1: Event enabled.  |

## 9.5.1.3 Rising Edge Trigger Enable Register (EXTI\_RTENR)

Offset address: 0x08

| 31   | 30   | 29  | 28   | 27   | 26    | 25  | 24  | 23  | 22  | 21   | _20  | 19   | 18   | 17   | 16   |
|------|------|-----|------|------|-------|-----|-----|-----|-----|------|------|------|------|------|------|
|      |      |     | ,    | Rese | erved |     |     |     |     | TR21 | TR20 | TR19 | TR18 | TR17 | TR16 |
| 15   | 14   | 13  | 12   | 11   | 10    | 9   | 8   | 7   | 6   | 5    | 4    | 3    | 2    | 1    | 0    |
| TR15 | TR14 | TR1 | TR12 | TR11 | TR10  | TR9 | TR8 | TR7 | TR6 | TR5  | TR4  | TR3  | TR2  | TR1  | TR0  |

| Bit     | Name     | Access | Description                                                                                  | Reset value |  |
|---------|----------|--------|----------------------------------------------------------------------------------------------|-------------|--|
| [31:22] | Reserved | RO     | Reserved.                                                                                    | 0           |  |
| [21:0]  | TRx      | RW     | Rising edge trigger of external interrupt channelx enable:  0: Rising edge trigger disabled; | 0           |  |
|         |          |        | 1: Rising edge trigger enabled.                                                              |             |  |

## 9.5.1.4 Falling Edge Trigger Enable Register (EXTI\_FTENR)

Offset address: 0x0C

| 31   | 30   | 29  | 28   | 27   | 26    | 25  | 24  | 23  | 22  | 21   | 20   | 19   | 18   | 17   | 16   |
|------|------|-----|------|------|-------|-----|-----|-----|-----|------|------|------|------|------|------|
|      |      |     |      | Rese | erved |     |     |     |     | TR21 | TR20 | TR19 | TR18 | TR17 | TR16 |
| 15   | 14   | 13  | 12   | 11   | 10    | 9   | 8   | 7   | 6   | 5    | 4    | 3    | 2    | 1    | 0    |
| TR15 | TR14 | TR1 | TR12 | TR11 | TR10  | TR9 | TR8 | TR7 | TR6 | TR5  | TR4  | TR3  | TR2  | TR1  | TR0  |

| Bit     | Name     | Access | Description                                         | Reset value |
|---------|----------|--------|-----------------------------------------------------|-------------|
| [31:22] | Reserved | RO     | Reserved                                            | 0           |
|         |          |        | Falling edge trigger of external interrupt channelx |             |
| [21.0]  | TRx      | RW     | enable:                                             | 0           |
| [21:0]  | I KX     | KW     | 0: Falling edge trigger disabled;                   | U           |
|         |          |        | 1: Falling edge trigger enabled.                    |             |

# 9.5.1.5 Software Interrupt Event Register (EXTI\_SWIEVR)

Offset address: 0x10

| 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21          | 20          | 19          | 18          | 17          | 16          |
|----------|----|----|----|----|----|----|----|----|----|-------------|-------------|-------------|-------------|-------------|-------------|
| Reserved |    |    |    |    |    |    |    |    |    | SWIE<br>R21 | SWIE<br>R20 | SWIE<br>R19 | SWIE<br>R18 | SWIE<br>R17 | SWIE<br>R16 |
|          |    |    |    |    |    |    |    |    |    |             |             |             |             |             |             |
| 15       | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5           | 4           | 3           | 2           | 1           | 0           |

V2. 4 91 WCH<sup>®</sup>

| Bit     | Name     | Access | Description                                                                                                                                                                                                                                                                                     | Reset value |
|---------|----------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:22] | Reserved | RO     | Reserved.                                                                                                                                                                                                                                                                                       | 0           |
| [21:0]  | SWIERx   | RW     | Set a software interrupt on the corresponding external trigger interrupt channel. With these bits set, the corresponding bit of the interrupt flag bit (EXTI_INTER) is set. If the interrupt (EXTI_INTENR) is enabled or the event (EXTI_EVENR) is enabled, an interrupt or event is generated. | 0           |

# 9.5.1.6 Interrupt Flag Register (EXTI\_INTFR)

Offset address: 0x14

| 31   | 30       | 29   | 28   | 27   | 26   | 25  | 24  | 23  | 22  | 21  | 20   | 19   | 18   | 17   | 16   |
|------|----------|------|------|------|------|-----|-----|-----|-----|-----|------|------|------|------|------|
|      | Reserved |      |      |      |      |     |     |     |     |     | IF20 | IF19 | IF18 | IF17 | IF16 |
| 15   | 14       | 13   | 12   | 11   | 10   | 9   | 8   | 7   | 6   | 5   | 4    | 3    | 2    | 1    | 0    |
| IF15 | IF14     | IF13 | IF12 | IF11 | IF10 | IF9 | IF8 | IF7 | IF6 | IF5 | IF4  | IF3  | IF2  | IF1  | IF0  |

| Bit     | Name     | Access | Description                                                                                                      | Reset value |
|---------|----------|--------|------------------------------------------------------------------------------------------------------------------|-------------|
| [31:22] | Reserved | RO     | Reserved.                                                                                                        | 0           |
| [21:0]  | IFx      |        | Interrupt flag. When these bits are set, the corresponding external interrupt has occurred. Write 1 to clear it. |             |

# 9.5.2 PFIC Registers

Table 9-5 PFIC registers

| Name               | Access address | Description                                              | Reset value |
|--------------------|----------------|----------------------------------------------------------|-------------|
| R32_PFIC_ISR1      | 0xE000E000     | PFIC interrupt enable status register1                   | 0x00000000  |
| R32_PFIC_ISR2      | 0xE000E004     | PFIC interrupt enable status register2                   | 0x00000000  |
| R32_PFIC_ISR3      | 0xE000E008     | PFIC interrupt enable status register3                   | 0x00000000  |
| R32_PFIC_ISR4      | 0xE000E00C     | PFIC interrupt enable status register4                   | 0x00000000  |
| R32_PFIC_IPR1      | 0xE000E020     | PFIC interrupt pending status register1                  | 0x00000000  |
| R32_PFIC_IPR2      | 0xE000E024     | PFIC interrupt pending status register2                  | 0x00000000  |
| R32_PFIC_IPR3      | 0xE000E028     | PFIC interrupt pending status register3                  | 0x00000000  |
| R32_PFIC_IPR4      | 0xE000E02C     | PFIC interrupt pending status register4                  | 0x00000000  |
| R32_PFIC_ITHRESDR  | 0xE000E040     | PFIC interrupt priority threshold configuration register | 0x00000000  |
| R32_PFIC_CFGR      | 0xE000E048     | PFIC interrupt configuration register                    | 0x00000000  |
| R32_PFIC_GISR      | 0xE000E04C     | PFIC interrupt global status register                    | 0x00000000  |
| R32_PFIC_VTFIDR    | 0xE000E050     | PFIC VTF interrupt ID configuration register             | 0xXXXXXXXX  |
| R32_PFIC_VTFADDRR0 | 0xE000E060     | PFIC VTF interrupt0 offset address register              | 0xXXXXXXXX  |
| R32_PFIC_VTFADDRR1 | 0xE000E064     | PFIC VTF interrupt1 offset address                       | 0xXXXXXXXX  |

|                    |            | register                               |            |
|--------------------|------------|----------------------------------------|------------|
|                    |            | PFIC VTF interrupt2 offset address     | 0xXXXXXXXX |
| R32_PFIC_VTFADDRR2 | 0xE000E068 | register                               |            |
|                    |            | PFIC VTF interrupt3 offset address     | 0xXXXXXXXX |
| R32_PFIC_VTFADDRR3 | 0xE000E06C | register                               |            |
| R32_PFIC_IENR1     | 0xE000E100 | PFIC interrupt enable set register1    | 0x00000000 |
| R32_PFIC_IENR2     | 0xE000E104 | PFIC interrupt enable set register2    | 0x00000000 |
| R32_PFIC_IENR3     | 0xE000E108 | PFIC interrupt enable set register3    | 0x00000000 |
| R32_PFIC_IENR4     | 0xE000E10C | PFIC interrupt enable set register4    | 0x00000000 |
| R32_PFIC_IRER1     | 0xE000E180 | PFIC interrupt enable clear register1  | 0x00000000 |
| R32_PFIC_IRER2     | 0xE000E184 | PFIC interrupt enable clear register2  | 0x00000000 |
| R32_PFIC_IRER3     | 0xE000E188 | PFIC interrupt enable clear register3  | 0x00000000 |
| R32_PFIC_IRER4     | 0xE000E18C | PFIC interrupt enable clear register4  | 0x00000000 |
| R32_PFIC_IPSR1     | 0xE000E200 | PFIC interrupt pending set register1   | 0x00000000 |
| R32_PFIC_IPSR2     | 0xE000E204 | PFIC interrupt pending set register2   | 0x00000000 |
| R32_PFIC_IPSR3     | 0xE000E208 | PFIC interrupt pending set register3   | 0x00000000 |
| R32_PFIC_IPSR4     | 0xE000E20C | PFIC interrupt pending set register4   | 0x00000000 |
| R32_PFIC_IPRR1     | 0xE000E280 | PFIC interrupt pending clear register1 | 0x00000000 |
| R32_PFIC_IPRR2     | 0xE000E284 | PFIC interrupt pending clear register2 | 0x00000000 |
| R32_PFIC_IPRR3     | 0xE000E288 | PFIC interrupt pending clear register3 | 0x00000000 |
| R32_PFIC_IPRR4     | 0xE000E28C | PFIC interrupt pending clear register4 | 0x00000000 |
| R32_PFIC_IACTR1    | 0xE000E300 | PFIC interrupt activation register1    | 0x00000000 |
| R32_PFIC_IACTR2    | 0xE000E304 | PFIC interrupt activation register2    | 0x00000000 |
| R32_PFIC_IACTR3    | 0xE000E308 | PFIC interrupt activation register3    | 0x00000000 |
| R32_PFIC_IACTR4    | 0xE000E30C | PFIC interrupt activation register4    | 0x00000000 |
| D22 DEIG IDDIOD    | 0 50005400 | PFIC interrupt priority configuration  | 0.0000000  |
| R32_PFIC_IPRIORx   | 0xE000E400 | register                               | 0x00000000 |
| R32_PFIC_SCTLR     | 0xE000ED10 | PFIC system control register           | 0x00000000 |

Note: 1. Interrupts of NMI, HardFault, ECALL-M, ECALL-U and BREAKPOINT are always enabled by default.

- 2. ECALL-M, ECALL-U and BREAKPOINT each is 1 case of EXC. The status is indicated by bit3 in the EXC.
- 3. NMI and EXC both support interrupt pending clear and set operation, but they do not support interrupt enable clear and set operation.
- 4. ECALL-M, ECALL-U and BREAKPOINT do not support interrupt pending clear and set operation or interrupt enable clear and set operation.

Note: When using the PFIC\_IENRx register to mask any interrupt or the CSR register to mask global interrupts, add an additional 'fence.i' instruction to synchronize the kernel control state with the interrupt enable state.

### 9.5.2.1 PFIC Interrupt Enable Status Register 1 (PFIC\_ISR1)

| 31 | 30 | 29 | 28             | 27 | 26 | 25 | 24   | 23     | 22  | 21 | 20 | 19            | 18            | 17   | 16    |
|----|----|----|----------------|----|----|----|------|--------|-----|----|----|---------------|---------------|------|-------|
|    |    |    |                |    |    | IN | TENS | ΓA[31: | 16] |    |    |               |               |      |       |
| 15 | 14 | 13 | 12             | 11 | 10 | 9  | 8    | 7      | 6   | 5  | 4  | 3             | 2             | 1    | 0     |
|    |    |    | INTEN<br>STA12 |    |    |    | Rese | erved  |     |    |    | INTEN<br>STA3 | INTEN<br>STA2 | Rese | erved |

| Bit     | Name     | Access | Description                             | Reset value |
|---------|----------|--------|-----------------------------------------|-------------|
|         |          |        | Enable status of 12# to 31# interrupts. |             |
| [31:12] | INTENSTA | RO     | 0: Interrupt disabled;                  | 0           |
|         |          |        | 1: Interrupt enabled.                   |             |
| [11:4]  | Reserved | RO     | Reserved                                | 0           |
|         |          |        | Enable status of 2# to 3# interrupts.   |             |
| [3:2]   | INTENSTA | RO     | 0: Interrupt disabled;                  | 0           |
|         |          |        | 1: Interrupt enabled;                   |             |
| [1:0]   | Reserved | RO     | Reserved                                | 0           |

# 9.5.2.2 PFIC Interrupt Enable Status Register 2 (PFIC\_ISR2)

Offset address: 0x04

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24    | 23     | 22  | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|-------|--------|-----|----|----|----|----|----|----|
|    |    |    |    |    |    | IN | TENST | ΓA[63: | 48] |    |    |    |    |    |    |
|    |    |    |    |    |    |    |       |        |     |    |    |    | _  |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | - 8   | 7      | 6   | 5  | 4  | 3  | 2  | 1  | 0  |

| Bit    | Name     | Access | Description                                                     | Reset value |
|--------|----------|--------|-----------------------------------------------------------------|-------------|
| [31:0] | INTENSTA | RO     | Enable status of 32# to 63# interrupts:  0: Interrupt disabled; | 0           |
|        |          |        | 1: Interrupt enabled.                                           |             |

# 9.5.2.3 PFIC Interrupt Enable Status Register 3 (PFIC\_ISR3)

Offset address: 0x08

| 31 | 30              | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|    | INTENSTA[95:80] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15 | 14              | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    | INTENSTA[79:64] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit    | Name     | Access | Description                                                                             | Reset value |
|--------|----------|--------|-----------------------------------------------------------------------------------------|-------------|
| [31:0] | INTENSTA | RO     | Enable status of 64# to 95# interrupts:  0: Interrupt disabled.;  1: Interrupt enabled. | 0           |

## 9.5.2.4 PFIC Interrupt Enable Status Register4 (PFIC\_ISR4)

| 31 | 30       | 29 | 28 | 27 | 26 | 25 | 24   | 23   | 22 | 21 | 20    | 19     | 18   | 17 | 16 |
|----|----------|----|----|----|----|----|------|------|----|----|-------|--------|------|----|----|
|    |          |    |    |    |    |    | Rese | rved |    |    |       |        |      |    |    |
| 15 | 14       | 13 | 12 | 11 | 10 | 9  | 8    | 7    | 6  | 5  | 4     | 3      | 2    | 1  | 0  |
|    | Reserved |    |    |    |    |    |      |      |    | IN | ΓENST | `A[103 | :96] |    |    |

| Bit    | Name     | Access | Description                              | Reset value |
|--------|----------|--------|------------------------------------------|-------------|
| [31:8] | Reserved | RO     | Reserved                                 | 0           |
|        |          |        | Enable status of 96# to 103# interrupts: |             |
| [7:0]  | INTENSTA | RO     | 0: Interrupt disabled;                   | 0           |
|        |          |        | 1: Interrupt enabled.                    |             |

## 9.5.2.5 PFIC Interrupt Pending Status Register1 (PFIC\_IPR1)

Offset address: 0x20

| 31                | 30                | 29                | 28                | 27 | 26 | 25 | 24    | 23     | 22  | 21 | 20 | 19               | 18               | 17   | 16    |
|-------------------|-------------------|-------------------|-------------------|----|----|----|-------|--------|-----|----|----|------------------|------------------|------|-------|
|                   |                   |                   | -                 |    | -  | PI | ENDST | A[31:1 | [6] | _  | _  |                  |                  |      |       |
| 15                | 14                | 13                | 12                | 11 | 10 | 9  | 8     | 7      | 6   | 5  | 4  | 3                | 2                | 1    | 0     |
| PEN<br>DST<br>A15 | PEN<br>DST<br>A14 | PEN<br>DST<br>A13 | PEN<br>DST<br>A12 |    |    |    | Rese  | erved  |     |    |    | PEN<br>DST<br>A3 | PEN<br>DST<br>A2 | Rese | erved |

| Bit     | Name     | Access | Description                              | Reset value |
|---------|----------|--------|------------------------------------------|-------------|
|         |          |        | Pending status of 12# to 31# interrupts: |             |
| [31:12] | PENDSTA  | RO     | 0: Interrupt not pended;                 | 0           |
|         |          |        | 1: Interrupt pended.                     |             |
| [11:4]  | Reserved | RO     | Reserved                                 | 0           |
|         |          |        | Pending status of 2# to 3# interrupts.   |             |
| [3:2]   | PENDSTA  | RO     | 0: Interrupt not pended;                 | 0           |
|         |          |        | 1: Interrupt pended.                     |             |
| [1:0]   | Reserved | RO     | Reserved                                 | 0           |

# 9.5.2.6 PFIC Interrupt Pending Status Register2 (PFIC\_IPR2)

Offset address: 0x24

| 31 | 30             | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|    | PENDSTA[63:48] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15 | 14             | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    | PENDSTA[47:32] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit    | Name    | Access | Description                                                        | Reset value |
|--------|---------|--------|--------------------------------------------------------------------|-------------|
| [31:0] | PENDSTA | RO     | Pending status of 32# to 63# interrupts:  0: Interrupt not pended; | 0           |
|        |         |        | 1: Interrupt pended.                                               |             |

## 9.5.2.7 PFIC Interrupt Pending Status Register3 (PFIC\_IPR3)

| 31 | 30             | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|    | PENDSTA[95:80] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15 | 14             | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    | PENDSTA[79:64] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit    | Name    | Access | Description                                                                              | Reset value |
|--------|---------|--------|------------------------------------------------------------------------------------------|-------------|
| [31:0] | PENDSTA | RO     | Pending status of 64# to 95# interrupts:  0: Interrupt not pended;  1: Interrupt pended. | 0           |

### 9.5.2.8 PFIC Interrupt Pending Status Register4 (PFIC\_IPR4)

Offset address: 0x2C

| 31 | 30 | 29 | 28   | 27    | 26 | 25 | 24   | 23    | 22 | 21 | 20    | 19     | 18  | 17 | 16 |
|----|----|----|------|-------|----|----|------|-------|----|----|-------|--------|-----|----|----|
|    |    |    |      |       |    |    | Rese | erved |    |    |       |        |     |    |    |
| 15 | 14 | 13 | 12   | 11    | 10 | 9  | 8    | 7     | 6  | 5  | 4     | 3      | 2   | 1  | 0  |
|    |    |    | Rese | erved |    |    |      |       |    | PE | ENDST | A[103: | 96] |    |    |

| Bit    | Name     | Access | Description                                                         | Reset value |
|--------|----------|--------|---------------------------------------------------------------------|-------------|
| [31:8] | Reserved | RO     | Reserved                                                            | 0           |
| [7:0]  | PENDSTA  | RO     | Pending status of 96# to 103# interrupts:  0: Interrupt not pended; | 0           |
| [,.0]  |          | 100    | 1: Interrupt pended.                                                | J           |

## 9.5.2.9 PFIC Interrupt Priority Threshold Configuration Register (PFIC\_ITHRESDR)

Offset address: 0x40

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0

| Reserved THRESHOLD[7:0] |
|-------------------------|
|-------------------------|

| Bit    | Name      | Access | Description                                                                                                                                                                                                                                                                                                      | Reset value |
|--------|-----------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:8] | Reserved  | RO     | Reserved.                                                                                                                                                                                                                                                                                                        | 0           |
| [7:0]  | THRESHOLD | RW     | Interrupt priority threshold. Interrupts whose interrupt priority is lower than the threshold value set do not perform interrupt service when they hang up; a 0 in this register indicates that the threshold register function is invalid. For V4B/C/F: [7:5]: Priority threshold. [4:0]: Reserved. Fixed to 0. | 0           |

## 9.5.2.10 PFIC Interrupt Configuration Register (PFIC\_CFGR)

| 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24         | 23     | 22  | 21 | 20      | 19 | 18 | 17 | 16 |
|----------|----|----|----|----|----|----|------------|--------|-----|----|---------|----|----|----|----|
|          |    |    |    |    |    | K  | EYCO       | DE[15: | :0] |    |         |    |    |    |    |
| 15       | 14 | 13 | 12 | 11 | 10 | 9  | 8          | 7      | 6   | 5  | 4       | 3  | 2  | 1  | 0  |
| Reserved |    |    |    |    |    |    | RSTS<br>YS |        |     | F  | Reserve | ed |    |    |    |

| Bit     | Name     | Access | Description                                                                                                                                                                                                                                        | Reset value |
|---------|----------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:16] | KEYCODE  | WO     | Correspond to different target control bits. These bits can only be modified when the corresponding security access identification data is written synchronously, and the read data is fixed to 0.  KEY1 = 0xFA05;  KEY2 = 0xBCAF;  KEY3 = 0xBEEF. | 0           |
| [15:8]  | Reserved | RO     | Reserved.                                                                                                                                                                                                                                          | 0           |
| 7       | RSTSYS   | WO     | System reset (Write to KEY3 synchronously). Cleared automatically. Valid when writing 1, while invalid when writing 0. Note: It has the same function as that of the SYSRESET bit in the PFIC_SCTLR register.                                      | 0           |
| [6:0]   | Reserved | RO     | Reserved.                                                                                                                                                                                                                                          | 0           |

# 9.5.2.11 PFIC Interrupt Global Status Register (PFIC\_GISR)

| 31       | 30 | 29 | 28 | 27 | 26 | 25               | 24              | 23   | 22 | 21 | 20    | 19     | 18 | 17 | 16 |
|----------|----|----|----|----|----|------------------|-----------------|------|----|----|-------|--------|----|----|----|
|          |    |    |    |    |    |                  | Rese            | rved |    |    |       |        |    |    |    |
| 15       | 14 | 13 | 12 | 11 | 10 | 9                | 8               | 7    | 6  | 5  | 4     | 3      | 2  | 1  | 0  |
| Reserved |    |    |    |    |    | GPE<br>ND<br>STA | GAC<br>T<br>STA |      |    | 1  | NESTS | TA[7:0 | )] |    |    |

| Bit     | Name     | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                           | Reset value |
|---------|----------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:10] | Reserved | RO     | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0           |
| 9       | GPENDSTA | RO     | Whether there is pending interrupt currently:  0: No; 1: Yes.                                                                                                                                                                                                                                                                                                                                                                                         | 0           |
| 8       | GACTSTA  | RO     | Whether the interrupt is executed currently: 0: No; 1: Yes.                                                                                                                                                                                                                                                                                                                                                                                           | 0           |
| [7:0]   | NESTSTA  | RO     | Current interrupt nested status. 8 nested levels currently supported, up to 3 hardware stack levels. If the set nested depth is greater than 3, the lower 3 interrupts should be configured as hardware stack, and other interrupts are configured as software stack.  0xFF: Level 8 interrupt; 0x7F: Level 7 interrupt; 0x3F: Level 6 interrupt; 0x1F: Level 5 interrupt; 0x0F: Level 4 interrupt; 0x07: Level 3 interrupt; 0x07: Level 3 interrupt; | 0           |

| 0x01: Level 1 interrupt;                      |
|-----------------------------------------------|
| 0x00: No interrupt;                           |
| Others: Impossible case.                      |
| _                                             |
| Note: Applicable to QingKeV4F core:           |
| CH32V30x_D8, CH32V30x_D8C,                    |
| CH32V31x_D8C.                                 |
|                                               |
| Current interrupt nesting status, currently   |
| supports a maximum of 2 levels of nesting and |
| a maximum hardware stack depth of 2 levels.   |
| 0x03: Level 2 interrupt.                      |
| 0x01: Level 1 interrupt.                      |
| 0x00: No interrupt.                           |
| Others: Impossible case.                      |
| Note: Applicable to QingKeV4B and V4C         |
| cores: CH32V20x_D6, CH32V20x_D8,              |
| CH32V20x_D8W.                                 |

# 9.5.2.12 PFIC VTF Interrupt ID Configuration Register (PFIC\_VTFIDR)

Offset address: 0x50

| 31 | 30 | 29 | 28  | 27   | 26 | 25 | 24 | 23 | 22 | 21 | 20  | 19   | 18 | 17 | 16 |
|----|----|----|-----|------|----|----|----|----|----|----|-----|------|----|----|----|
|    |    |    | VTI | FID3 |    |    |    |    |    |    | VTI | FID2 |    |    |    |
| 15 | 14 | 13 | 12  | 11   | 10 | 9  | 8  | 7  | 6  | 5  | 4   | 3    | 2  | 1  | 0  |
|    |    |    | VTI | FID1 |    |    |    |    |    |    | VTI | FID0 |    |    |    |

| Bit     | Name   | Access | Description                 | Reset value |
|---------|--------|--------|-----------------------------|-------------|
| [31:24] | VTFID3 | RW     | Configure VTF interrupt3 ID | X           |
| [23:16] | VTFID2 | RW     | Configure VTF interrupt2 ID | X           |
| [15:8]  | VTFID1 | RW     | Configure VTF interrupt1 ID | X           |
| [7:0]   | VTFID0 | RW     | Configure VTF interrupt0 ID | X           |

# 9.5.2.13 PFIC VTF Interrupt 0 Address Register (PFIC\_VTFADDRR0)

| 31 | 30          | 29 | 28 | 27 | 26 | 25 | 24    | 23      | 22 | 21 | 20 | 19         | 18 | 17 | 16 |
|----|-------------|----|----|----|----|----|-------|---------|----|----|----|------------|----|----|----|
|    |             |    |    |    |    |    | ADDR( | 0[31:16 | 6] |    |    |            |    |    |    |
| 15 | 14          | 13 | 12 | 11 | 10 | 9  | 8     | 7       | 6  | 5  | 4  | 3          | 2  | 1  | 0  |
|    | ADDR0[15:1] |    |    |    |    |    |       |         |    |    |    | VTF0E<br>N |    |    |    |

| Bit    | Name   | Access | Description                             | Reset value |
|--------|--------|--------|-----------------------------------------|-------------|
| [31:1] | ADDR0  | RW     | VTF interrupt0 service program address. | X           |
|        |        |        | VTF interrupt0 enable bit:              |             |
| 0      | VTF0EN | RW     | 0: Disabled;                            | 0           |
|        |        |        | 1: VTF interrupt0 channel enabled.      |             |

# 9.5.2.14 PFIC VTF Interrupt1 Address Register (PFIC\_VTFADDRR1)

Offset address: 0x64

| 31          | 30 | 29 | 28 | 27 | 26 | 25 | 24   | 23      | 22 | 21 | 20         | 19 | 18 | 17 | 16 |
|-------------|----|----|----|----|----|----|------|---------|----|----|------------|----|----|----|----|
|             |    |    |    |    |    |    | ADDR | 1[31:16 | 5] |    |            |    |    |    |    |
| 15          | 14 | 13 | 12 | 11 | 10 | 9  | 8    | 7       | 6  | 5  | 4          | 3  | 2  | 1  | 0  |
| ADDR1[15:1] |    |    |    |    |    |    |      |         |    |    | VTF1E<br>N |    |    |    |    |

| Bit    | Name   | Access | Description                              | Reset value |
|--------|--------|--------|------------------------------------------|-------------|
| [31:1] | ADDR1  | RW     | VTF interrupt 1 service program address. | X           |
|        |        |        | VTF interrupt 1 enable bit:              |             |
| 0      | VTF1EN | RW     | 0: Disabled;                             | 0           |
|        |        |        | 1: VTF interrupt 1 channel enabled.      |             |

## 9.5.2.15 PFIC VTF Interrupt2 Address Register (PFIC\_VTFADDRR2)

Offset address: 0x68

| 31 | 30          | 29 | 28 | 27 | 26 | 25 | 24    | 23      | 22 | 21 | 20 | 19         | 18 | 17 | 16 |
|----|-------------|----|----|----|----|----|-------|---------|----|----|----|------------|----|----|----|
|    |             |    |    |    |    | 1  | ADDR2 | 2[31:16 | 5] |    |    |            |    |    |    |
| 15 | 14          | 13 | 12 | 11 | 10 | 9  | 8     | 7       | 6  | 5  | 4  | 3          | 2  | 1  | 0  |
|    | ADDR2[15:1] |    |    |    |    |    |       |         |    |    |    | VTF2E<br>N |    |    |    |

| Bit    | Name   | Access | Description                                        | Reset value |
|--------|--------|--------|----------------------------------------------------|-------------|
| [31:1] | ADDR2  | RW     | VTF interrupt 2 service program address bit[31:1]. | X           |
| 0      | VTF2EN | RW     | VTF interrupt 2 enable bit: 0: Disabled;           | 0           |
|        |        |        | 1: VTF interrupt 2 channel enabled.                |             |

# 9.5.2.16 PFIC VTF Interrupt3 Address Register (PFIC\_VTFADDRR3)

| 31           | 30             | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20     | 19 | 18 | 17 | 16 |
|--------------|----------------|----|----|----|----|----|----|----|----|----|--------|----|----|----|----|
| ADDR3[31:16] |                |    |    |    |    |    |    |    |    |    |        |    |    |    |    |
| 15           | 14             | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4      | 3  | 2  | 1  | 0  |
|              | ADDR3[15:1] VT |    |    |    |    |    |    |    |    |    | VTF3EN |    |    |    |    |

| Bit    | Name   | Access | Description                                                                  | Reset value |
|--------|--------|--------|------------------------------------------------------------------------------|-------------|
| [31:1] | ADDR3  | RW     | VTF interrupt 3 service program address bit[31:1].                           | X           |
| 0      | VTF3EN | RW     | VTF interrupt 3 enable bit: 0: Disabled; 1: VTF interrupt 3 channel enabled. | 0           |

# 9.5.2.17 PFIC Interrupt Enable Set Register 1 (PFIC\_IENR1)

Offset address: 0x100

| 31          | 30          | 29          | 28      | 27 | 26 | 25 | 24    | 23      | 22  | 21     | 20 | 19 | 18 | 17 | 16 |
|-------------|-------------|-------------|---------|----|----|----|-------|---------|-----|--------|----|----|----|----|----|
|             |             |             |         |    |    | ]  | INTEN | [31:16] | ]   |        |    |    |    |    |    |
| 15          | 14          | 13          | 12      | 11 | 10 | 9  | 8     | 7       | 6   | 5      | 4  | 3  | 2  | 1  | 0  |
| INTEN<br>15 | INTEN1<br>4 | INTE<br>N13 | INTEN12 |    |    |    |       |         | Res | served |    |    |    |    |    |

| Bit     | Name     | Access | Description                                                                                         | Reset value |
|---------|----------|--------|-----------------------------------------------------------------------------------------------------|-------------|
| [31:12] | INTEN    | WO     | <ul><li>12# to 31# interrupts enable:</li><li>0: No effect;</li><li>1: Interrupt enabled.</li></ul> | 0           |
| [11:0]  | Reserved | RO     | Reserved                                                                                            | 0           |

## 9.5.2.18 PFIC Interrupt Enable Set Register 2 (PFIC\_IENR2)

Offset address: 0x104

| 31 | 30           | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|    | INTEN[63:48] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15 | 14           | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    | INTEN[47:32] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit    | Name  | Access | Description                                 | Reset value |
|--------|-------|--------|---------------------------------------------|-------------|
| [31:0] | INTEN | WO     | 32# to 63# interrupts enable: 0: No effect; | 0           |
| [65.0] |       |        | 1: Interrupt enabled.                       | ·           |

## 9.5.2.19 PFIC Interrupt Enable Set Register 3 (PFIC\_IENR3)

Offset address: 0x108

| 31 | 30           | 29 | 28 | 27 | 26 | 25 | 24    | 23     | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|--------------|----|----|----|----|----|-------|--------|----|----|----|----|----|----|----|
|    | INTEN[95:80] |    |    |    |    |    |       |        |    |    |    |    |    |    |    |
| 15 | 14           | 13 | 12 | 11 | 10 | 9  | 8     | 7      | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |              |    |    |    |    |    | INTEN | [79:64 | ]  |    |    |    |    |    |    |

| Bit    | Name  | Access | Description                                 | Reset value |
|--------|-------|--------|---------------------------------------------|-------------|
| [31:0] | INTEN | WO     | 64# to 95# interrupts enable: 0: No effect; | 0           |
|        |       |        | 1: Interrupt enabled.                       |             |

## 9.5.2.20 PFIC Interrupt Enable Set Register 4 (PFIC\_IENR4)

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|

|    |    |    |      |      |    |   | Rese | erved |   |   |       |        |    |   |   |
|----|----|----|------|------|----|---|------|-------|---|---|-------|--------|----|---|---|
| 15 | 14 | 13 | 12   | 11   | 10 | 9 | 8    | 7     | 6 | 5 | 4     | 3      | 2  | 1 | 0 |
|    |    |    | Rese | rved |    |   |      |       |   | I | NTEN[ | 103:96 | 5] |   |   |

| Bit    | Name     | Access | Description                    | Reset value |
|--------|----------|--------|--------------------------------|-------------|
| [31:8] | Reserved | RO     | Reserved                       | 0           |
|        |          |        | 96# to 103# interrupts enable: |             |
| [7:0]  | INTEN    | WO     | 0: No effect;                  | 0           |
|        |          |        | 1: Interrupt enabled.          |             |

# 9.5.2.21 PFIC Interrupt Enable Clear Register 1 (PFIC\_IRER1)

Offset address: 0x180

| 31                | 30            | 29                | 28            | 27 | 26 | 25 | 24    | 23     | 22  | 21     | 20 | 19 | 18 | 17 | 16 |
|-------------------|---------------|-------------------|---------------|----|----|----|-------|--------|-----|--------|----|----|----|----|----|
|                   |               |                   |               |    |    | II | NTRSE | T[31:1 | 6]  |        |    |    |    |    |    |
| 15                | 14            | 13                | 12            | 11 | 10 | 9  | 8     | 7      | 6   | 5      | 4  | 3  | 2  | 1  | 0  |
| INTR<br>SET1<br>5 | INTRSE<br>T14 | INT<br>RSE<br>T13 | INTRSET<br>12 | ,  |    |    |       |        | Res | served |    |    |    |    | -  |

| Bit     | Name     | Access | Description                                | Reset value |
|---------|----------|--------|--------------------------------------------|-------------|
| [31:12] | INTRSET  | WO     | 12# to 31# interrupts reset: 0: No effect; | 0           |
|         |          |        | 1: Interrupt reset.                        |             |
| [11:0]  | Reserved | RO     | Reserved                                   | 0           |

# 9.5.2.22 PFIC Interrupt Enable Clear Register 2 (PFIC\_IRER2)

Offset address: 0x184

| 31 | 30             | 29 | 28 | 27 | 26 | 25 | 24    | 23     | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----------------|----|----|----|----|----|-------|--------|----|----|----|----|----|----|----|
|    |                |    |    |    |    | II | NTRSE | T[63:4 | 8] |    |    |    |    |    |    |
| 15 | 14             | 13 | 12 | 11 | 10 | 9  | 8     | 7      | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    | INTRSET[47:32] |    |    |    |    |    |       |        |    |    |    |    |    |    |    |

| Bit    | Name    | Access | Description                                                    | Reset value |
|--------|---------|--------|----------------------------------------------------------------|-------------|
| [31:0] | INTRSET | WO     | 32# to 63# interrupts reset: 0: No effect; 1: Interrupt reset. | 0           |

## 9.5.2.23 PFIC Interrupt Enable Clear Register 3 (PFIC\_IRER3)

| 31 | 30 | 29 | 28 | 27 | 26 | 25  | 24    | 23     | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|-----|-------|--------|----|----|----|----|----|----|----|
|    |    |    |    |    |    | II. | NTRSE | T[95:8 | 0] |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8     | 7      | 6  | 5  | 4  | 3  | 2  | 1  | 0  |

| Bit    | Name    | Access | Description                                                    | Reset value |
|--------|---------|--------|----------------------------------------------------------------|-------------|
| [31:0] | INTRSET | WO     | 64# to 95# interrupts reset: 0: No effect; 1: Interrupt reset. | 0           |

## 9.5.2.24 PFIC Interrupt Enable Clear Register 4 (PFIC\_IRER4)

Offset address: 0x18C

| 31 | 30 | 29 | 28   | 27    | 26 | 25 | 24   | 23    | 22 | 21 | 20   | 19      | 18  | 17 | 16 |
|----|----|----|------|-------|----|----|------|-------|----|----|------|---------|-----|----|----|
|    |    |    |      |       |    |    | Rese | erved |    |    |      |         |     |    |    |
| 15 | 14 | 13 | 12   | 11    | 10 | 9  | 8    | 7     | 6  | 5  | 4    | 3       | 2   | 1  | 0  |
|    |    |    | Rese | erved |    |    |      |       |    | IN | TRSE | Γ[103:9 | 96] |    |    |

| Bit    | Name     | Access | Description                   | Reset value |
|--------|----------|--------|-------------------------------|-------------|
| [31:8] | Reserved | RO     | Reserved                      | 0           |
|        |          |        | 96# to 103# interrupts reset: |             |
| [7:0]  | INTRSET  | WO     | 0: No effect;                 | 0           |
|        |          |        | 1: Interrupt reset.           |             |

## 9.5.2.25 PFIC Interrupt Pending Set Register 1 (PFIC\_IPSR1)

Offset address: 0x200

|               | - 112 <b>- 1</b> |                   | . 011=00      |    |    |    |       |         |    |    |    |    |              |      |      |
|---------------|------------------|-------------------|---------------|----|----|----|-------|---------|----|----|----|----|--------------|------|------|
| 31            | 30               | 29                | 28            | 27 | 26 | 25 | 24    | 23      | 22 | 21 | 20 | 19 | 18           | 17   | 16   |
|               |                  |                   |               |    |    | PI | ENDSE | ET[31:1 | 6] |    |    |    |              |      |      |
| 15            | 14               | 13                | 12            | 11 | 10 | 9  | 8     | 7       | 6  | 5  | 4  | 3  | 2            | 1    | 0    |
| PEND<br>SET15 | PEND<br>SET14    | PEN<br>DSE<br>T13 | PEND<br>SET12 |    |    |    | Re    | served  |    |    |    |    | PEND<br>SET2 | Rese | rved |

| Bit     | Name     | Access | Description                                                                                                | Reset value |
|---------|----------|--------|------------------------------------------------------------------------------------------------------------|-------------|
| [31:12] | PENDSET  | WO     | 12# to 31# interrupts pending set. 13# and 15# interrupts are reserved. 0: No effect; 1: Interrupt pended. | 0           |
| [11:4]  | Reserved | RO     | Reserved                                                                                                   | 0           |
| [3:2]   | PENDSET  | WO     | 2# to 3# interrupts pending set. 0: No effect; 1: Interrupt pended.                                        | 0           |
| [1:0]   | Reserved | RO     | Reserved                                                                                                   | 0           |

# 9.5.2.26 PFIC Interrupt Pending Set Register 2 (PFIC\_IPSR2)

Offset address: 0x204

 $31 \quad 30 \quad 29 \quad 28 \quad 27 \quad 26 \quad 25 \quad 24 \quad 23 \quad 22 \quad 21 \quad 20 \quad 19 \quad 18 \quad 17 \quad 16$ 

|    | PENDSET[63:48] |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----------------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 15 | 14             | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|    | PENDSET[47:32] |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit    | Name    | Access | Description                                                           | Reset value |
|--------|---------|--------|-----------------------------------------------------------------------|-------------|
| [31:0] | PENDSET | WO     | 32# to 63# interrupts pending set. 0: No effect; 1: Interrupt pended. | 0           |

## 9.5.2.27 PFIC Interrupt Pending Set Register 3 (PFIC\_IPSR3)

Offset address: 0x208

| 31 | 30             | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|    | PENDSET[95:80] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15 | 14             | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    | PENDSET[79:64] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

|   | Bit    | Name    | Access | Description                                       | Reset value |
|---|--------|---------|--------|---------------------------------------------------|-------------|
|   | [31:0] | PENDSET | WO     | 64# to 95# interrupts pending set.  0: No effect; | 0           |
| 1 |        |         |        | 1: Interrupt pended.                              |             |

# 9.5.2.28 PFIC Interrupt Pending Set Register 4 (PFIC\_IPSR4)

Offset address: 0x20C

| 31 | 30       | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20   | 19      | 18  | 17 | 16 |
|----|----------|----|----|----|----|----|----|----|----|----|------|---------|-----|----|----|
|    | Reserved |    |    |    |    |    |    |    |    |    |      |         |     |    |    |
| 15 | 14       | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4    | 3       | 2   | 1  | 0  |
|    | Reserved |    |    |    |    |    |    |    |    | PE | NDSE | Γ [103: | 96] |    |    |

| E   | Bit          | Name Access |    | Description                                       | Reset value |
|-----|--------------|-------------|----|---------------------------------------------------|-------------|
| [3] | 1:8]         | Reserved    | RO | Reserved                                          | 0           |
| [7  | <b>[</b> :0] | PENDSET     | WO | 96# to 103# interrupts pending set. 0: No effect; | 0           |
|     | -            |             |    | 1: Interrupt pended.                              |             |

# 9.5.2.29 PFIC Interrupt Pending Clear Register 1 (PFIC\_IPRR1)

| 31                  | 30             | 29                  | 28 | 27 | 26       | 25 | 24 | 23 | 22 | 21 | 20 | 19                 | 18                 | 17   | 16    |
|---------------------|----------------|---------------------|----|----|----------|----|----|----|----|----|----|--------------------|--------------------|------|-------|
|                     | PENDRST[31:16] |                     |    |    |          |    |    |    |    |    |    |                    |                    |      |       |
| 15                  | 14             | 13                  | 12 | 11 | 10       | 9  | 8  | 7  | 6  | 5  | 4  | 3                  | 2                  | 1    | 0     |
| PEND<br>RESET<br>15 |                | PEND<br>RESE<br>T13 |    |    | Reserved |    |    |    |    |    |    | PEND<br>RESE<br>T3 | PEND<br>RESE<br>T2 | Rese | erved |

| Bit     | Name     | Access | Description                              | Reset value |
|---------|----------|--------|------------------------------------------|-------------|
|         |          |        | 12# to 31# interrupts pending reset. 13# |             |
| [31:12] | PENDRST  | WO     | and 15# are reserved.                    | 0           |
| [31.12] | FENDIST  | WO     | 0: No effect;                            | U           |
|         |          |        | 1: Interrupt pending status reset.       |             |
| [11:4]  | Reserved | RO     | Reserved                                 | 0           |
|         |          |        | 2# to 3# interrupts pending reset:       |             |
| [3:2]   | PENDRST  | WO     | 0: No effect;                            | 0           |
|         |          |        | 1: Interrupt pending status reset.       |             |
| [1:0]   | Reserved | RO     | Reserved                                 | 0           |

### 9.5.2.30 PFIC Interrupt Pending Clear Register 2 (PFIC\_IPRR2)

Offset address: 0x284

| 31 | 30             | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|    | PENDRST[63:48] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15 | 14             | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    | PENDRST[47:32] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit    | Name    | Access | Description                                                                                                             | Reset value |
|--------|---------|--------|-------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:0] | PENDRST | WO     | <ul><li>32# to 63# interrupts pending reset:</li><li>0: No effect;</li><li>1: Interrupt pending status reset.</li></ul> | 0           |

## 9.5.2.31 PFIC Interrupt Pending Clear Register 3 (PFIC\_IPRR3)

Offset address: 0x288

| 31 | 30             | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|    | PENDRST[95:80] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15 | 14             | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    | PENDRST[79:64] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit    | Name      | Access | Description                                                                                                             | Reset value |
|--------|-----------|--------|-------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:0] | PENDRESET | WO     | <ul><li>64# to 95# interrupts pending reset:</li><li>0: No effect;</li><li>1: Interrupt pending status reset.</li></ul> | 0           |

## 9.5.2.32 PFIC Interrupt Pending Clear Register 4 (PFIC\_IPRR4)

| 31 | 30       | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20   | 19      | 18  | 17 | 16 |
|----|----------|----|----|----|----|----|----|----|----|----|------|---------|-----|----|----|
|    | Reserved |    |    |    |    |    |    |    |    |    |      |         |     |    |    |
| 15 | 14       | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4    | 3       | 2   | 1  | 0  |
|    | Reserved |    |    |    |    |    |    |    |    | PE | NDRS | Γ [103: | 96] |    |    |

| Bit    | Name     | Access | Description                           | Reset value |
|--------|----------|--------|---------------------------------------|-------------|
| [31:8] | Reserved | RO     | Reserved                              | 0           |
|        |          |        | 96# to 103# interrupts pending reset: |             |
| [7:0]  | PENDSET  | WO     | 0: No effect;                         | 0           |
|        |          |        | 1: Interrupt pending status reset.    |             |

## 9.5.2.33 PFIC Interrupt Activation Register 1 (PFIC\_IACTR1)

Offset address: 0x300

| 31          | 30          | 29          | 28          | 27 | 26 | 25 | 24    | 23      | 22 | 21 | 20 | 19         | 18         | 17   | 16    |
|-------------|-------------|-------------|-------------|----|----|----|-------|---------|----|----|----|------------|------------|------|-------|
|             |             |             |             |    |    | ]  | IACTS | [31:16] | ]  |    |    |            |            |      |       |
| 15          | 14          | 13          | 12          | 11 | 10 | 9  | 8     | 7       | 6  | 5  | 4  | 3          | 2          | 1    | 0     |
| IACTS<br>15 | IACTS1<br>4 | IACTS<br>13 | IACTS1<br>2 |    |    |    | Res   | served  |    |    |    | IACTS<br>3 | IACTS<br>2 | Rese | erved |

| Bit     | Name     | Access | Description                                                                                                            | Reset value |
|---------|----------|--------|------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:12] | IACTS    | RO     | 12# to 31# interrupts activation status. 13# and 15# are reserved. 0: No interrupt activated; 1: Interrupt activating. | 0           |
| [11:4]  | Reserved | RO     | Reserved                                                                                                               | 0           |
| [3:2]   | IACTS    | RO     | 2# to 3# interrupts activation status: 0: No interrupt activated; 1: Interrupt activating.                             | 0           |
| [1:0]   | Reserved | RO     | Reserved                                                                                                               | 0           |

## 9.5.2.34 PFIC Interrupt Activation Register 2 (PFIC\_IACTR2)

Offset address: 0x304

| 31 | 30           | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|    | IACTS[63:48] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15 | 14           | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    | IACTS[47:32] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit    | Name  | Access | Description                                                                                  | Reset value |
|--------|-------|--------|----------------------------------------------------------------------------------------------|-------------|
| [31:0] | IACTS | RO     | 32# to 63# interrupts activation status: 0: No interrupt activated; 1: Interrupt activating. | 0           |

## 9.5.2.35 PFIC Interrupt Activation Register 3 (PFIC\_IACTR3)

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24    | 23      | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|-------|---------|----|----|----|----|----|----|----|
|    |    |    |    |    |    |    | IACTS | [95:80] |    |    |    |    |    |    |    |

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8     | 7       | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|-------|---------|---|---|---|---|---|---|---|
|    |    |    |    |    |    |   | IACTS | [79:64] |   |   |   |   |   |   |   |

| Bit    | Name  | Description | Reset value                              |   |
|--------|-------|-------------|------------------------------------------|---|
|        |       |             | 64# to 95# interrupts activation status: |   |
| [31:0] | IACTS | RO          | 0: No interrupt activated;               | 0 |
|        |       |             | 1: Interrupt activating.                 |   |

#### 9.5.2.36 PFIC Interrupt Activation Register 4 (PFIC\_IACTR4)

Offset address: 0x30C

| 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24   | 23    | 22 | 21 | 20   | 19      | 18 | 17 | 16 |
|----------|----|----|----|----|----|----|------|-------|----|----|------|---------|----|----|----|
|          |    |    | -  |    | -  | -  | Rese | erved |    | _  | -    | -       | -  | -  |    |
| 15       | 14 | 13 | 12 | 11 | 10 | 9  | 8    | 7     | 6  | 5  | 4    | 3       | 2  | 1  | 0  |
| Reserved |    |    |    |    |    |    |      |       |    | I  | ACTS | [103:96 | 5] |    |    |

| Bit    | Name     | Access | Description                               | Reset value |
|--------|----------|--------|-------------------------------------------|-------------|
| [31:8] | Reserved | RO     | Reserved                                  | 0           |
|        |          |        | 96# to 103# interrupts activation status: |             |
| [7:0]  | IACTS    | WO     | 0: No interrupt activated;                | 0           |
|        |          |        | 1: Interrupt activating.                  |             |

### 9.5.2.37 PFIC Interrupt Priority Configuration Register (PFIC\_IPRIORx) (x=0-63)

Offset address: 0x400 to 0x4FF

The controller supports 256 interrupts (0-255), and the priority of each interrupt is controlled by 8bits.

|                | 31          | 24  | 23    | 16     | 15     | 8      | 7      | 0     |  |
|----------------|-------------|-----|-------|--------|--------|--------|--------|-------|--|
| IPRIOR63       | PRIO        | 255 | PRIO  | 254    | PRIO   | _253   | PRIO   | 252   |  |
|                |             |     |       |        |        |        |        |       |  |
| IPRIORx        | PRIO_(4x+3) |     | PRIO_ | (4x+2) | PRIO_( | (4x+1) | PRIO   | _(4x) |  |
| •••            |             |     |       |        |        |        |        |       |  |
| IPRIOR0 PRIO_3 |             | O_3 | PRI   | O_2    | PRIC   | O_1    | PRIO_0 |       |  |

| Bit         | Name   | Access | Description                        | Reset value |
|-------------|--------|--------|------------------------------------|-------------|
| [2047:2040] | IP_255 | RW     | See description of IP_0.           | 0           |
|             |        | •••    |                                    | •••         |
| [31:24]     | IP_3   | RW     | See description of IP_0.           | 0           |
| [23:16]     | IP_2   | RW     | See description of IP_0.           | 0           |
| [15:8]      | IP_1   | RW     | See description of IP_0.           | 0           |
|             |        |        | Interrupt0 priority configuration: |             |
| [7:0]       | IP_0   | RW     | [7:5]: Priority control bits.      | 0           |
|             |        |        | No nested, no preemption bit;      |             |

| For 2 nested levels, bit7 is the preemption bit;         |
|----------------------------------------------------------|
| For 4 nested levels, bit7-bit6 are preemption bits;      |
| For 8 nested levels, bit7-bit5 are preemption bits.      |
| The smaller priority value, the higher the priority. If  |
| interrupts with the same preemption priority are         |
| pended at the same time, execute the interrupt with the  |
| highest priority firstly.                                |
| [4:0]: Reserved, fixed to 0, write invalid.              |
| Note: Applicable to QingKe V4F core:                     |
| CH32V30x_D8, CH32V30x_D8C, CH32V31x_D8C.                 |
|                                                          |
| Number 0 interrupt priority configuration.               |
| [7:5]: Priority control bits.                            |
| If no nesting is configured, no preemption bit.          |
| If configured with 2 levels of nesting, bit7 is the      |
| preemption bit.                                          |
| The smaller the priority value, the higher the priority. |
| If the same preemption priority interrupt hangs at the   |
| same time, the interrupt with the higher priority is     |
| executed first.                                          |
| [4:0]: Reserved, fixed to 0, write invalid.              |
| Note: Applicable to QingKe V4B and V4C cores:            |
| CH32V20x D6, CH32V20x D8, CH32V20x D8W.                  |
|                                                          |

# 9.5.2.38 PFIC System Control Register (PFIC\_SCTLR)

| 31         | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23               | 22                | 21               | 20                | 19                  | 18 | 17 | 16 |
|------------|----|----|----|----|----|----|----|------------------|-------------------|------------------|-------------------|---------------------|----|----|----|
| SYS<br>RST |    |    |    |    |    |    | F  | Reserve          | d                 |                  |                   |                     |    |    |    |
| 15         | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7                | 6                 | 5                | 4                 | 3                   | 2  | 1  | 0  |
| Reserved   |    |    |    |    |    |    |    | SET<br>EVE<br>NT | SEV<br>ONPE<br>ND | WFIT<br>O<br>WFE | SLEE<br>P<br>DEEP | SLEEP<br>ONEX<br>IT |    |    |    |

| Bit    | Name      | Access   | Description                                                                                                                                                                              | Reset value |
|--------|-----------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| 31     | SYSRST    | WO       | System reset. Cleared automatically. Valid when writing 1, while invalid when writing 0. It has the same effect as that of the PFIC_CFGR register.                                       | 0           |
| [30:6] | Reserved  | Reserved | 0                                                                                                                                                                                        |             |
| 5      | SETEVENT  | WO       | Set event. To wake up WFE.                                                                                                                                                               | 0           |
| 4      | SEVONPEND | RW       | When an event or interrupt is pended, wake up the system via WFE instruction. If WFE instruction is not executed, system wakes up immediately the next time WFE instruction is executed. | 0           |

|   |                               |                                                      | 0: Only enabled events and enabled interrupts can wake up the system; |   |  |  |  |  |
|---|-------------------------------|------------------------------------------------------|-----------------------------------------------------------------------|---|--|--|--|--|
|   |                               | 1: The enabled events and all interrupts             |                                                                       |   |  |  |  |  |
|   |                               |                                                      | (Including disabled interrupts) can wake                              |   |  |  |  |  |
|   | up the system.                |                                                      |                                                                       |   |  |  |  |  |
|   | WFI instruction serves as WFE |                                                      |                                                                       |   |  |  |  |  |
| 3 | WFITOWFE                      | RW                                                   | 0: No effect;                                                         | 0 |  |  |  |  |
| 3 |                               |                                                      | 1: Subsequent WFI instruction serves as                               | U |  |  |  |  |
|   |                               |                                                      | WFE instruction.                                                      |   |  |  |  |  |
| 2 | SLEEPDEEP                     | RW                                                   | System low power mode control:                                        | 0 |  |  |  |  |
|   | SLEEFDEEF                     | IX W                                                 | 0: Sleep; 1: Deep sleep.                                              | U |  |  |  |  |
|   |                               |                                                      | System status control after exiting                                   |   |  |  |  |  |
| 1 | CLEEDONEVIT                   | DW                                                   | interrupt service program:                                            | 0 |  |  |  |  |
|   | SLEEPUNEALI                   | SLEEPONEXIT RW 0: System goes into the main program; |                                                                       |   |  |  |  |  |
|   |                               |                                                      | 1: System goes into low-power mode.                                   |   |  |  |  |  |
| 0 | Reserved                      | RO                                                   | Reserved.                                                             | 0 |  |  |  |  |

#### 9.5.3 Dedicated CSR Registers

RISC-V defines some Control and Status Control Registers (CSR), which are used to configure, flag or record run status. CSR register is a register in the cores, with dedicated 12-bit address space. The CH32V20x, CH32V30x and CH32V31x not only have standard registers defined in RISC-V privileged architecture documentation, but also have some additional vendor-defined registers which need csr instruction to access.

Note: The CSR registers with attribute of MRW/MRO/MRW1 need to be accessed in machine mode.

#### 9.5.3.1 Interrupt System Control Register (INTSYSCR)

CSR address: 0x804

| 31 | 30 | 29 | 28  | 27  | 26 | 25 | 24   | 23    | 22   | 21                 | 20            | 19  | 18   | 17          | 16              |
|----|----|----|-----|-----|----|----|------|-------|------|--------------------|---------------|-----|------|-------------|-----------------|
|    |    |    |     |     |    |    | Rese | erved |      |                    |               |     |      |             |                 |
| 15 | 14 | 13 | 12  | 11  | 10 | 9  | 8    | 7     | 6    | 5                  | 4             | 3   | 2    | 1           | 0               |
|    |    |    | РМТ | STA |    |    |      | Rese  | rved | GIHW<br>STKN<br>EN | HWSTK<br>OVEN | PM" | ГСFG | INES<br>TEN | HWS<br>TKE<br>N |

| Bit     | Name     | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                  | Reset value |
|---------|----------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:16] | Reserved | MRO    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0           |
| [15:8]  | PMTSTA   | MRO    | Preemption bit status:  0x00: No preemption bit in priority configuration bits, and no interrupt nested;  0x80: The preemption bit is the highest bit of the priority configuration bits, 2 interrupt nested levels;  0xC0: The preemption bits are the higher 2 bits of the priority configuration bits, 4 interrupt nested levels;  0xE0: The preemption bits are the higher 3 bits of the priority configuration bits, 8 interrupt nested | 0           |

| [7:6] | Reserved  GIHWSTKN EN | MRO<br>MRW1 | levels.  Note: This bit only applicable to QingKe V4F core:  CH32V30x_D8, CH32V30x_D8C,  CH32V31x_D8C.  Reserved  Global interrupt and hardware stack disable:  Note: This bit is usually used for real-time system operation. When interrupt switches context, set this bit and the global interrupt and hardware stack out can be disabled. When the switch is finished, this bit is cleared automatically by hardware after the interrupt is returned.                                            | 0 |
|-------|-----------------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| 4     | HWSTKOVEN             | MRW         | Interrupt enable after hardware stack overflows:  0: Global interrupt disabled after hardware stack overflows;  1: Interrupt still can be executed after hardware stack overflow.  Note: This bit only applicable to CH32V30x_D8,  CH32V30x_D8C and CH32V31x_D8C, its hardware stack depth is 3. When the configuration nesting level is greater than 3, if this bit is set to 1, the low priority three interrupts need to be configured as hardware stack and the high priority as software stack. | 0 |
| [3:2] | PMTCFG[1:0            | MRW         | Preemption bit configuration:  0b00: No nested, no preemption bit;  0b01: 2 nested levels, 1 preemption bit;  0b10: 4 nested levels, 2 preemption bits;  0b11: 8 nested levels, 3 preemption bits.  Note: This bit only applicable to QingKe V4F core:  CH32V30x_D8, CH32V30x_D8C and  CH32V31x_D8C.                                                                                                                                                                                                 | 0 |
| 1     | INESTEN               | MRW         | Interrupt nested enable:  0: Interrupt nested disabled; 1: Interrupt nested enabled.                                                                                                                                                                                                                                                                                                                                                                                                                 | 0 |
| 0     | HWSTKEN               | MRW         | Hardware stack enable:  0: Hardware stack disabled; 1: Hardware stack enabled.                                                                                                                                                                                                                                                                                                                                                                                                                       | 0 |

## 9.5.3.2 Machine Trap-vector Base Address Register (MTVEC)

CSR address: 0x305

| 31 | 30             | 29 | 28 | 27 | 26 | 25 | 24    | 23      | 22  | 21 | 20    | 19  | 18 | 17 | 16 |
|----|----------------|----|----|----|----|----|-------|---------|-----|----|-------|-----|----|----|----|
|    |                |    |    |    |    | В  | ASEAD | DR[31:1 | [6] |    |       |     |    |    |    |
| 15 | 14             | 13 | 12 | 11 | 10 | 9  | 8     | 7       | 6   | 5  | 4     | 3   | 2  | 1  | 0  |
|    | BASEADDR[15:2] |    |    |    |    |    |       |         |     |    | MODE1 | MOD |    |    |    |

|   | '      |
|---|--------|
| ! |        |
|   |        |
|   | I EU I |
|   |        |

| Bit    | Name           | Access | Description                                                                                                                                                                                            | Reset value |
|--------|----------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:2] | BASEADDR[31:2] | MRW    | Base address of interrupt vector table                                                                                                                                                                 | 0           |
| 1      | MODE1          | MRW    | Interrupt vector table identification mode:  0: Identify by jump instruction. Limited range, non-jump instruction supported;  1: Identify by absolute address. Full range supported, but it must jump. | 0           |
| 0      | MODE0          | MRW    | Interrupt or trap-vector address mode selection: 0: Unified entry address; 1: Address offset based on Interrupt No. *4.                                                                                | 0           |

#### 9.5.4 Physical Memory Protection (PMP)

To improve system security, a set of physical address access restrictions is defined in the RISC-V architecture, and it allows physical memory access privileges (Read, write, execute) to be specified for each physical memory region, and the minimum region length is 4 bytes for protection. The PMP unit is always effective in user mode, and optionally effective in machine mode. If the current memory limit is violated, a system exception interrupt (EXC) is generated.

The PMP unit contains 4 sets of 8-bit configuration registers (32bits) and 4 sets of address registers, which need to be accessed using the csr instruction and performed in machine mode.

#### 9.5.4.1 PMP Configuration Register (PMPCFG0)

CSR address: 0x3A0

| 31 | 30 | 29 | 28  | 27   | 26 | 25 | 24 | 23 | 22 | 21 | 20    | 19  | 18 | 17 | 16 |
|----|----|----|-----|------|----|----|----|----|----|----|-------|-----|----|----|----|
|    |    |    | pmp | 3cfg |    |    |    |    | ,  |    | pmp2c | fg  |    |    |    |
| 15 | 14 | 13 | 12  | 11   | 10 | 9  | 8  | 7  | 6  | 5  | 4     | 3   | 2  | 1  | 0  |
|    |    | ,  | pmp | 1cfg |    |    |    |    |    |    | pmp0c | efg |    |    |    |

| Bit     | Name    | Access | Description                 | Reset value |
|---------|---------|--------|-----------------------------|-------------|
| [31:24] | pmp3cfg | MRW    | See description of pmp0cfg. | 0           |
| [23:16] | pmp2cfg | MRW    | See description of pmp0cfg. | 0           |
| [15:8]  | pmplcfg | MRW    | See description of pmp0cfg. | 0           |

|       |         |     | Bit   | Name | Description                        |   |
|-------|---------|-----|-------|------|------------------------------------|---|
|       |         |     |       |      | Lock enable. It can be unlocked in |   |
|       |         |     | 7     | L    | machine mode                       |   |
|       |         |     | /     | L    | 0: Not locked;                     |   |
|       |         |     |       |      | 1: Related registers locked.       |   |
| [7:0] | pmp0cfg | MRW | [6:5] | -    | Reserved                           | 0 |
|       |         |     | [4.2] |      | Address aligned and protection     |   |
|       |         |     | [4:3] | A    | region range selection             |   |
|       |         |     | 2     | X    | Excute Attibute                    |   |
|       |         |     | 1     | W    | Write Attibute                     |   |
|       |         |     | 0     | R    | Read Attibute                      |   |

For address aligned and protection region range selection, it performs memory protection for the region between A\_ADDR and B\_ADDR (A\_ADDR and B\_ADDR are both required 4-byte aligned):

- 1. If B ADDR A ADDR ==  $2^2$ , it is based on NA4;
- 2. If  $B\_ADDR A\_ADDR == 2^{(G+2)}$  and  $G \ge 1$ , and if  $A\_ADDR = 2^{(G+2)}$ , it is aligned based on NAPOT;
- 3. Otherwise it is based on TOR.

| A   | Name  | Description                                                                                 |
|-----|-------|---------------------------------------------------------------------------------------------|
| 00b | OFF   | No region to protect.                                                                       |
|     |       | Top aligned region protection:                                                              |
|     |       | For pmp0cfg, 0≤ region <pmpaddr0;< td=""></pmpaddr0;<>                                      |
|     |       | For pmp1cfg, pmpaddr0≤ region <pmpaddr1;< td=""></pmpaddr1;<>                               |
| 01b | TOR   | For pmp2cfg, pmpaddr1≤ region <pmpaddr2;< td=""></pmpaddr2;<>                               |
|     |       | For pmp3cfg, pmpaddr2≤ region <pmpaddr3;< td=""></pmpaddr3;<>                               |
|     |       | pmpaddr <sub>i-1</sub> = $A_ADDR >> 2$ ;                                                    |
|     |       | $pmpaddr_i = B\_ADDR >> 2.$                                                                 |
|     |       | Fixed 4-byte region protection.                                                             |
| 10b | NA4   | For pmp0cfg~pmp3cfg, pmpaddr0 to pmpaddr3 serve as start address.                           |
|     |       | $pmpaddr_i = A\_ADDR >> 2.$                                                                 |
| 111 | NADOT | $2^{(G+2)}$ region protection, G $\geq$ 1, in this case, A_ADDR is aligned on $2^{(G+2)}$ . |
| 11b | NAPOT | pmpaddri = $((A\_ADDR \mid (2(G+2)-1)) & \sim (1 << G+1)) >> 2.$                            |

### 9.5.4.2 PMP Address 0 Register (PMPADDR0)

CSR address: 0x3B0

| 31 | 30          | 29 | 28 | 27 | 26 | 25 | 24   | 23      | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|-------------|----|----|----|----|----|------|---------|----|----|----|----|----|----|----|
|    |             |    |    |    |    |    | ADDR | 0[33:18 | 3] |    |    |    |    |    |    |
| 15 | 14          | 13 | 12 | 11 | 10 | 9  | 8    | 7       | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    | ADDR0[17:2] |    |    |    |    |    |      |         |    |    |    |    |    |    |    |

| Bit    | Name        | Access | Description                                                                       | Reset value |
|--------|-------------|--------|-----------------------------------------------------------------------------------|-------------|
| [31:0] | ADDR0[31:0] | MRW    | The [33:2] bits of the PMP set address0, actually the higher 2 bits are not used. | 0           |

## 9.5.4.3 PMP Address 1 Register (PMPADDR1)

CSR address: 0x3B1

| 31 | 30          | 29 | 28 | 27 | 26 | 25 | 24     | 23      | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|-------------|----|----|----|----|----|--------|---------|----|----|----|----|----|----|----|
|    |             |    |    |    |    | 1  | ADDR : | 1[33:18 | 3] |    |    |    |    |    |    |
| 15 | 14          | 13 | 12 | 11 | 10 | 9  | 8      | 7       | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    | ADDR1[17:2] |    |    |    |    |    |        |         |    |    |    |    |    |    |    |

| Bit    | Name        | Access | Description                                                                        | Reset value |
|--------|-------------|--------|------------------------------------------------------------------------------------|-------------|
| [31:0] | ADDR1[31:0] | MRW    | The [33:2] bits of the PMP set address 1, actually the higher 2 bits are not used. | 0           |

## 9.5.4.4 PMP Address 2 Register (PMPADDR2)

CSR address: 0x3B2

| 31 | 30           | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|    | ADDR2[33:18] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15 | 14           | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit    | Name        | Access | Description                                                                       | Reset value |
|--------|-------------|--------|-----------------------------------------------------------------------------------|-------------|
| [31:0] | ADDR2[31:0] | MRW    | The [33:2] bits of the PMP set address2, actually the higher 2 bits are not used. | 0           |

## 9.5.4.5 PMP Address 3 Register (PMPADDR3)

CSR address: 0x3B3

| 31 | 30           | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|    | ADDR3[33:18] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15 | 14           | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    | ADDR3[17:2]  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit    | Name        | Access | Description                                                                       | Reset value |
|--------|-------------|--------|-----------------------------------------------------------------------------------|-------------|
| [31:0] | ADDR3[31:0] | MRW    | The [33:2] bits of the PMP set address3, actually the higher 2 bits are not used. | 0           |

## 9.5.5 RISC-V-SysTick Registers

Table 9-6 STK registers

| Name         | Access address | Description                   | Reset value |
|--------------|----------------|-------------------------------|-------------|
| R32_STK_CTLR | 0xE000F000     | System count control register | 0x00000000  |
| R32_STK_SR   | 0xE000F004     | System count status register  | 0x00000000  |
| R32_STK_CNTL | 0xE000F008     | System counter low register   | 0x00000000  |
| R32_STK_CNTH | 0xE000F00C     | System counter high register  | 0x00000000  |

| R32_STK_CMPLR | 0xE000F010 | Count/compare low register  | 0x00000000 |
|---------------|------------|-----------------------------|------------|
| R32_STK_CMPHR | 0xE000F014 | Count/compare high register | 0x00000000 |

Note: Applied for general-purpose MCUs designed based on 32-bit RISC-V instruction set and architecture.

## 9.5.5.1 System Count Control Register (STK\_CTLR)

| 31   | 30       | 29 | 28 | 27 | 26 | 25 | 24 | 23      | 22 | 21   | 20       | 19   | 18        | 17   | 16  |
|------|----------|----|----|----|----|----|----|---------|----|------|----------|------|-----------|------|-----|
| SWIE |          |    |    |    |    |    | I  | Reserve | d  |      |          |      |           |      |     |
| 15   | 14       | 13 | 12 | 11 | 10 | 9  | 8  | 7       | 6  | 5    | 4        | 3    | 2         | 1    | 0   |
|      | Reserved |    |    |    |    |    |    |         |    | INIT | MOD<br>E | STRE | STCL<br>K | STIE | STE |

| Bit    | Name     | Access | Description                                                                                                                                                                                                                                                                                                  | Reset value |
|--------|----------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| 31     | SWIE     | RW     | Software interrupt trigger enable (SWI):  0: Trigger disabled;  1: Software interrupt triggered.  After going into software interrupt, it needs to be cleared by software, otherwise it is constantly triggered.                                                                                             | 0           |
| [30:6] | Reserved | RO     | Reserved                                                                                                                                                                                                                                                                                                     |             |
| 5      | INIT     | W1     | Counter initial value update: 0: No effect; 1: Updated to 0 when upcounting, while updated to the compare value when downcounting.                                                                                                                                                                           |             |
| 4      | MODE     | RW     | Count mode: 0: Upcount; 1: Downcount.                                                                                                                                                                                                                                                                        |             |
| 3      | STRE     | RW     | Auto reload count enable bit:  0: Continue to upcount after upcounting to the compare value, and downcount from the maximum value after downcounting to 0;  1: After upcounting to the compare value, start counting from 0 again, and after downcounting to 0, start counting again from the compare value. |             |
| 2      | STCLK    | RW     | Counter system clock sourse selection bit:  0: HCLK/8 serves as time base;  1: HCLK serves as time base.                                                                                                                                                                                                     |             |
| 1      | STIE     | RW     | Counter interrupt enable control bit: 0: Counter interrupt disabled; 1: Counter interrupt enabled.                                                                                                                                                                                                           |             |
| 0      | STE      | RW     | System counter enable control bit:  0: STK disabled, the counter stops counting; 1: STK enabled.                                                                                                                                                                                                             | 0           |

### 9.5.5.2 System Count Status Register (STK\_SR)

Offset address: 0x04

| 31 | 30       | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18    | 17 | 16 |
|----|----------|----|----|----|----|----|----|----|----|----|----|----|-------|----|----|
|    | Reserved |    |    |    |    |    |    |    |    |    |    |    |       |    |    |
| 15 | 14       | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2     | 1  | 0  |
|    | Reserved |    |    |    |    |    |    |    |    |    |    |    | CNTIF |    |    |

| Bit    | Name                                        | Access | Description                                      | Reset value |
|--------|---------------------------------------------|--------|--------------------------------------------------|-------------|
| [31:1] | Reserved                                    | RO     | Reserved                                         | 0           |
|        |                                             |        | Count value compare flag. Cleared by writing 0,  |             |
| 0      | CNTIF                                       | PW0    | invalid when writing 1:                          | 0           |
| U      | CNTIF RW0 0: The compare value not reached; |        | 0: The compare value not reached;                | U           |
|        |                                             |        | 1: Upcount to the compare value, downcount to 0. |             |

### 9.5.5.3 System Counter Low Register (STK\_CNTL)

Offset address: 0x08

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24   | 23     | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|------|--------|----|----|----|----|----|----|----|
|    |    |    |    |    |    |    | CNT[ | 31:16] |    |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8    | 7      | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    |    | CNT  | [15:0] |    |    |    |    |    |    |    |

| Bit    | Name      | Access | Description                                     | Reset value |
|--------|-----------|--------|-------------------------------------------------|-------------|
| [31:0] | CNT[31:0] | RW     | Low 32 bits of the current counter count value. | 0           |

Note: STK\_CNTL and STK\_CNTH constitute a 64-bit system counter.

#### 9.5.5.4 System Counter High Register (STK\_CNTH)

Offset address: 0x0C

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24   | 23     | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|------|--------|----|----|----|----|----|----|----|
|    |    |    |    |    | ,  |    | CNT[ | 63:48] | ,  | ,  |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8    | 7      | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    |    | CNT[ | 47:32] |    |    |    |    |    |    |    |

| ĺ | Bit    | Name       | Access | Description                                      | Reset value |
|---|--------|------------|--------|--------------------------------------------------|-------------|
| ĺ | [31:0] | CNT[63:32] | RW     | High 32 bits of the current counter count value. | 0           |

Note: STK\_CNTL and STK\_CNTH constitute a 64-bit system counter.

## 9.5.5.5 Count/Compare Low Register (STK\_CMPLR)

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24   | 23     | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|------|--------|----|----|----|----|----|----|----|
|    |    |    |    |    |    |    | CMP[ | 31:16] |    |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8    | 7      | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    |    | CMP  | [15:0] |    |    |    |    |    |    |    |

| ĺ | Bit    | Name      | Access | Description                                       | Reset value |
|---|--------|-----------|--------|---------------------------------------------------|-------------|
| Ĭ | [31:0] | CMP[31:0] | RW     | Set the low 32 bits of the compare counter value. | 0           |

Note: STK\_CMPLR and STK\_CMPHR constitute a 64-bit system counter compare value.

### 9.5.5.6 Count/Compare High Register (STK\_CMPHR)

Offset address: 0x14

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24   | 23      | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|------|---------|----|----|----|----|----|----|----|
|    |    |    |    |    |    | -  | CMP[ | [63:48] |    |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8    | 7       | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    | _  | CMP[ | [47:32] |    |    |    |    |    |    |    |

| Ï | Bit    | Name       | Access | Description                                        | Reset value |
|---|--------|------------|--------|----------------------------------------------------|-------------|
| ĺ | [31:0] | CMP[63:32] | RW     | Set the high 32 bits of the compare counter value. | 0           |

Note: STK\_CMPLR and STK\_CMPHR constitute a 64-bit system counter compare value.

### 9.5.6 ARM-SysTick Registers

Table 9-7 SysTick registers

|               |                | , ,                          |             |
|---------------|----------------|------------------------------|-------------|
| Name          | Access address | Description                  | Reset value |
| R32_STK_CTRL  | 0xE000E010     | SysTick control register     | 0x00000000  |
| R32_STK_LOAD  | 0xE000E014     | SysTick reload register      | 0x00000000  |
| R32_STK_VAL   | 0xE000E018     | SysTick value register       | 0x00000000  |
| R32_STK_CALIB | 0xE000E01C     | SysTick calibration register | 0x00000000  |

Note: Applied for general-purpose MCUs designed based on ARM® CortexTM-M3 core.

#### 9.5.6.1 SysTick Control Register (STK\_CTRL)

| 31 | 30 | 29 | 28 | 27 | 26 | 25      | 24      | 23 | 22 | 21 | 20 | 19 | 18                | 17          | 16                |
|----|----|----|----|----|----|---------|---------|----|----|----|----|----|-------------------|-------------|-------------------|
|    |    |    |    |    |    | I       | Reserve | ed |    |    |    |    |                   |             | COU<br>NTFL<br>AG |
| 15 | 14 | 13 | 12 | 11 | 10 | 9       | 8       | 7  | 6  | 5  | 4  | 3  | 2                 | 1           | 0                 |
|    |    |    |    |    | I  | Reserve | ed      |    |    |    |    |    | CLK<br>SOU<br>RCE | TICK<br>INT | ENA<br>BLE        |

| Bit     | Name      | Access | Description                                                                                                                              | Reset value |
|---------|-----------|--------|------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:17] | Reserved  | RO     | Reserved                                                                                                                                 | 0           |
| 16      | COUNTFLAG | RO     | This bit is 1 if SysTick has counted to zero since<br>this register was read last time. Reading this bit<br>will automatically clear it. |             |
| [15:3]  | Reserved  | RO     | Reserved                                                                                                                                 | 0           |
| 2       | CLKSOURCE | RW     | 0: External clock source (STCLK);<br>1: Internal clock (FCLK).                                                                           | 0           |

|   |         |    | 0: No action when it counts to zero;        |   |
|---|---------|----|---------------------------------------------|---|
| 1 | TICKINT | RW | 1: SysTick exception request generated when | 0 |
|   |         |    | SysTick counts down to zero.                |   |
|   |         |    | SysTick enable                              |   |
| 0 | ENABLE  | RW | 0: Disable;                                 | 0 |
|   |         |    | 1: Enable.                                  |   |

### 9.5.6.2 SysTick Reload Register (STK\_LOAD)

Offset address: 0x04

| 31 | 30       | 29 | 28 | 27 | 26 | 25 | 24    | 23     | 22 | 21 | 20   | 19     | 18 | 17 | 16 |
|----|----------|----|----|----|----|----|-------|--------|----|----|------|--------|----|----|----|
|    | Reserved |    |    |    |    |    |       |        |    | R  | ELOA | D[23:1 | 6] |    |    |
| 15 | 14       | 13 | 12 | 11 | 10 | 9  | 8     | 7      | 6  | 5  | 4    | 3      | 2  | 1  | 0  |
|    |          |    |    |    | -  |    | RELOA | D[15:( | )] |    | -    |        |    |    |    |

| Bit     | Name         | Access | Description                                | Reset value |
|---------|--------------|--------|--------------------------------------------|-------------|
| [31:24] | Reserved     | RO     | Reserved                                   | 0           |
| [23:0]  | RELOAD[23:0] | RW     | Reloads value when it counts down to zero. | 0           |

## 9.5.6.3 SysTick Value Register (STK\_VAL)

Offset address: 0x08

| 31 | 30       | 29            | 28 | 27 | 26 | 25 | 24 | 23 | 22    | 21     | 20  | 19 | 18 | 17 | 16 |
|----|----------|---------------|----|----|----|----|----|----|-------|--------|-----|----|----|----|----|
|    | Reserved |               |    |    |    |    |    | CI | URREN | NT[23: | [6] |    |    |    |    |
| 15 | 14       | 13            | 12 | 11 | 10 | 9  | 8  | 7  | 6     | 5      | 4   | 3  | 2  | 1  | 0  |
|    |          | CURRENT[15:0] |    |    |    |    |    |    |       |        |     |    |    |    |    |

|   | Bit     | Name     | Access | Description                                                                                                                                                    | Reset value |
|---|---------|----------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| ĺ | [31:24] | Reserved | RO     | Reserved                                                                                                                                                       | 0           |
|   | [23:0]  | CURRENT  | RW     | Read it, and it will return current count value. Write to it, and it will be cleared, the COUNTFLAG flag in the SysTick control register will also be cleared. | 0           |

## 9.5.6.4 SysTick Calibration Register (STK\_CALIB)

| 31        | 30          | 29 | 28 | 27   | 26    | 25 | 24 | 23 | 22 | 21 | 20    | 19      | 18 | 17 | 16 |
|-----------|-------------|----|----|------|-------|----|----|----|----|----|-------|---------|----|----|----|
| NOR<br>EF | SKE<br>W    |    |    | Rese | erved |    |    |    |    | -  | ΓENMS | S[23:16 | 5] |    |    |
| 15        | 14          | 13 | 12 | 11   | 10    | 9  | 8  | 7  | 6  | 5  | 4     | 3       | 2  | 1  | 0  |
|           | TENMS[15:0] |    |    |      |       |    |    |    |    |    |       |         |    |    |    |

| 31 | NOREF | RO | 0: Available external reference clock; 1: No external reference clock (STCLK not available); | 0 |
|----|-------|----|----------------------------------------------------------------------------------------------|---|
| 30 | SKEW  | RO | 0: The calibration value is exactly 10ms;                                                    | 0 |

|         |          |    | 1: The calibration value is not exactly 10ms.                                                                                                                                                            |   |
|---------|----------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| [29:24] | Reserved | RO | Reserved                                                                                                                                                                                                 | 0 |
| [23:0]  | TENMS    | RW | The number of cells counted down within 10ms. The chip designer should provide this value through the input signal of the Cortex-M3. If the read value is zero, the calibration function cannot be used. | 0 |

V2. 4 117 WH°

# Chapter 10 GPIO and Alternate Functions (GPIO/AFIO)

This chapter applies to the whole family of CH32F20x, CH32V20x, CH32V30x and CH32V31x.

The GPIO ports can be configured as a variety of input or output modes, with built-in pull-up/pull-down resistors which can be switched off, and can be configured as push-pull or open-drain functions. GPIO ports also have some other alternate functions.

#### 10.1 Main Features

Each pin of the port can be configured into one of the following modes:

- Floating input
- Open-drain output
- Pull-up input
- Push-pull output
- Pull-down input
- Input and output of alternate function
- Analog input

Many pins have alternate functions, and many other peripherals map their own output and input channels to these pins. The specific application of these alternate pins needs to be with reference to each peripheral, and this chapter shall specify whether these pins are alternate and remapped.

## 10.2 Function Description

#### 10.2.1 Overview

Figure 10-1 Basic structure of GPIO module



The IO port structure is as shown in Figure 10-1. Each pin has 2 protection diodes inside the chip, and the IO port can be divided into input and output drive modules internally. The weak pull-up and pull-down resistors are optional for input drive, and can be connected to analog input peripherals such as AD; if inputted to digital peripherals, they need to pass through a TTL Schmitt trigger, and then shall be connected to GPIO input register or other alternate peripherals. The output drive has a pair of MOS transistors. The IO port can be configured as open-drain or push-pull output by configuring whether the upper and lower MOS transistors are enabled;

the output drive can also be internally configured to the output controlled by GPIO or other alternate peripherals.

#### 10.2.2 GPIO Initialization

Immediately after reset, the GPIO ports are running in the initial status. At this time, most IO ports are running at the floating input status, but there are also peripheral-related pins such as HSE that is running on peripheral alternate functions. Please refer to related chapters of pins for the specific initialization function.

#### 10.2.3 External Interrupt

All GPIO ports can be configured with external interrupt input channels, but an external interrupt input channel can only be mapped to a GPIO pin at most, and the serial number of the external interrupt channel must be consistent with the bit number of the GPIO port, such as PA1 (Or PB1, PC1, PD1 and PE1) can only be mapped to EXTI1, and EXTI1 can only accept mappings from one of PA1, PB1, PC1, PD1 and PE1. Both ports have one-to-one relationship.

#### 10.2.4 Alternate Function

Attention shall be paid to the following when the alternate function is used:

- To use the alternate function of the input direction, the port must be configured to alternate input mode, the pull-up and pull-down settings can be set according to actual needs
- To use the alternate function of the output direction, the port must be configured to alternate output mode, push-pull or open drain can be set according to the actual situation
- For the bidirectional alternate function, the port must be configured as multiplex output mode, and then
  the driver will be configured as float control input mode

The same IO port may have multiple peripherals alternate to this pin, so in order to give play to the use of each peripheral as far as possible, the alternate pins of the peripherals can be remapped to other pins in addition to the default alternate pins, avoiding occupied pins.

#### 10.2.5 Locking Mechanism

The locking mechanism can lock the configuration of IO port. After a specific write sequence, the selected IO pin configuration is locked and cannot be changed until the next reset.

V2. 4 119 WCH<sup>\*</sup>

#### 10.2.6 Input Configuration

on/off Read Input data register TTL Schmitt Protection trigger on/of diode Input driver I/O pir Write registers Protection diode Output dat Read/write register

Figure 10-2 Input configuration structure block diagram of GPIO module

When the IO port is configured as input mode, the output driver is disconnected, the input pull-up and pull-down are optional, and the alternate function and analog input are not connected. The data on each IO port is sampled to the input data register at each PB2 clock, and the corresponding bit of the input data register is read to obtain the level state of the corresponding pin.

**Output driver** 

#### 10.2.7 Output Configuration

from on-chip peripheral

Figure 10-3 Output configuration structure block diagram of GPIO module



When the IO port is configured as output mode, a pair of MOS in the output driver can be configured as push-pull or open-drain mode as required, without using alternate function. The pull-up and pull-down resistors of the input drive are disabled, the TTL Schmitt trigger is activated, and the level appearing on the IO pin will be sampled to the input data register every PB2 clock, so IO status will be obtained by reading the input data register. In the push-pull output mode, the value written last time will be obtained through the access to the output data register.

#### 10.2.8 Alternate Function Configuration

Figure 10-4 Structure block diagram when GPIO module is multiplexed by other peripherals



When the alternate function is enabled, the output driver is enabled and can be configured as open-drain or push-pull mode as required. Schmitt trigger will be also turned on, the input and output lines of the alternate function is connected, but the output data register is disconnected, and the level appearing on the IO pin is sampled to the input data register every PB2 clock. In the open-drain mode, the current status of the IO port is obtained by reading the input data register. In the push-pull mode, the last written value is obtained by reading the output data register.

#### 10.2.9 Analog Input Configuration

To on-chip Analog Input peripheral Read Input data register TTL Schmitt Protection trigge diode Input driver I/O pin Write Bit set/rese registers Output drive Protection diode Output data Read/write register Push-pull, open-drain or disabled

Figure 10-5 Configuration structure block diagram of GPIO module as analog input

When the analog input is enabled, the output buffer is disconnected and the Schmitt trigger input in the input driver is disabled to prevent consumption on the IO port. The pull-up and pull-down resistors is disabled, and the read input data register is always 0.

### 10.2.10 Peripheral GPIO Setting

The following table recommends the corresponding GPIO port configuration of each peripheral pin.

Table 10-1 Advanced-control timer (TIM1/8/9/10)

| TIM1/8/9/10        | Configuration                  | GPIO configuration         |  |  |
|--------------------|--------------------------------|----------------------------|--|--|
| TIM1/8/9/10 CHx    | Input capture channel x        | Floating input             |  |  |
| 111V11/8/9/10_C11X | Output compare channel x       | Push-pull alternate output |  |  |
| TIM1/8/9/10_CHxN   | Complementary output channel x | Push-pull alternate output |  |  |
| TIM1/8/9/10_BKIN   | Break input                    | Floating input             |  |  |
| TIM1/8/9/10_ETR    | External trigger clock input   | Floating input             |  |  |

Table 10-2 General-purpose timer (TIM2/3/4/5)

| TIM2/3/4/5 pinout | Configuration                | GPIO configuration         |
|-------------------|------------------------------|----------------------------|
| TIM2/2/4/5 CII    | Input capture channel x      | Floating input             |
| TIM2/3/4/5_CHx    | Output compare channel x     | Push-pull alternate output |
| TIM2/3/4/5_ETR    | External trigger clock input | Floating input             |

Table 10-3 Universal Synchronous Asynchronous Receiver Transmitter (USART)

| USART pinout | Configuration                | GPIO configuration              |
|--------------|------------------------------|---------------------------------|
| LICADT TV    | Full-duplex mode             | Push-pull alternate output      |
| USARTx_TX    | Half-duplex synchronous mode | Open-drain alternate output     |
| LICADT DV    | Full-duplex mode             | Floating input or pull-up input |
| USARTx_RX    | Half-duplex synchronous mode | Not used                        |
| USARTx_CK    | Synchronous mode             | Push-pull alternate output      |
| USARTx_RTS   | Hardware flow control        | Push-pull alternate output      |
| USARTx_CTS   | Hardware flow control        | Floating input or pull-up input |

Table 10-4 Serial Peripheral Interface (SPI) module

| SPI pinout           | Configuration                 | GPIO configuration                 |  |
|----------------------|-------------------------------|------------------------------------|--|
| CDI <sub>W</sub> CCV | Master mode                   | Push-pull alternate output         |  |
| SPIx_SCK             | Slave mode                    | Floating input                     |  |
|                      | Full duplex master mode       | Push-pull alternate output         |  |
|                      | Full duplex slave mode        | Floating input or pull-up input    |  |
| SPIx MOSI            | Simplex bidirectional data    | Duck mult alternate autmut         |  |
| SPIX_MOSI            | line/master mode              | Push-pull alternate output         |  |
|                      | Simplex bidirectional data    | Not used                           |  |
|                      | line/slave mode               | Not used                           |  |
|                      | Full duplex master mode       | Floating input or pull-up input    |  |
|                      | Full duplex slave mode        | Push-pull alternate output         |  |
| SPIx MISO            | Simplex bidirectional data    | Not wood                           |  |
| SPIX_MISO            | line/master mode              | Not used                           |  |
|                      | Simplex bidirectional data    | Dush null alternate output         |  |
|                      | line/slave mode               | Push-pull alternate output         |  |
| SPIx_NSS             | Hardware master or slave mode | Floating input or pull-up or pull- |  |

|                          | down input                  |
|--------------------------|-----------------------------|
| Hardware master mode/NSS | Durch mult altermate output |
| output enable            | Push-pull alternate output  |
| Software mode            | Not used                    |

#### Table 10-5 Inter IC Sound (I2S) module

| I2S pinout           | Configuration | GPIO configuration             |  |  |
|----------------------|---------------|--------------------------------|--|--|
| I2Sx WS              | Master mode   | Push-pull alternate output     |  |  |
| 128x_ws              | Slave mode    | Floating input                 |  |  |
| IDC <sub>V</sub> CV  | Master mode   | Push-pull alternate output     |  |  |
| I2Sx_CK              | Slave mode    | Floating input                 |  |  |
|                      | Transmitter   | Push-pull alternate output     |  |  |
| I2Sx_SD              | Receiver      | Floating, pull-up or pull-down |  |  |
|                      | Receivei      | input                          |  |  |
| IDS <sub>W</sub> MCV | Master mode   | Push-pull alternate output     |  |  |
| I2Sx_MCK             | Slave mode    | Not used                       |  |  |

#### Table 10-6 Inter Integrated Circuit (I2C) module

| I <sup>2</sup> C pinout | Configuration          | GPIO configuration          |  |  |  |  |
|-------------------------|------------------------|-----------------------------|--|--|--|--|
| I <sup>2</sup> C_SCL    | I <sup>2</sup> C clock | Open-drain alternate output |  |  |  |  |
| I <sup>2</sup> C_SDA    | I <sup>2</sup> C data  | Open-drain alternate output |  |  |  |  |

### Table 10-7 Controller LAN (CAN) module

| CAN pinout | GPIO configuration              |  |
|------------|---------------------------------|--|
| CANx_TX    | Push-pull alternate output      |  |
| CANx_RX    | Floating input or pull-up input |  |

#### Table 10-8 USB Full-speed Device (USBD) controller

| USBD pinout GPIO configuration |                                                                      |
|--------------------------------|----------------------------------------------------------------------|
| USBD DM/USBD DP                | After the USB is enabled, alternate IO port connects to the internal |
| OSDD_DM/OSDD_DF                | USBD transceiver automatically                                       |

### Table 10-9 USB Host Device (USBHD) controller

| USBHD pinout      | GPIO configuration                                                   |  |
|-------------------|----------------------------------------------------------------------|--|
| USBHD DM/USBHD DP | After the USB is enabled, alternate IO port connects to the internal |  |
| USBHD_DM/USBHD_DF | USBHD transceiver automatically                                      |  |

#### Table 10-10 USB OTG controller

| USB OTG pinout | GPIO configuration                           |
|----------------|----------------------------------------------|
| OTG_FS_VBUS    | Analog input                                 |
| OTG_FS_ID      | Pull-up input                                |
| OTG_FS_DM      | Automatically controlled by USB disconnected |
| OTG_FS_DP      | Automatically controlled by USB disconnected |

Table 10-11 Security Digital Input and Output (SDIO) module

| SDIO pinout | Configuration | GPIO configuration         |
|-------------|---------------|----------------------------|
| SDIO_CK     | Clock         | Push-pull alternate output |
| SDIO_CMD    | Command       | Push-pull alternate output |
| SDIO[D7:D0] | Data          | Push-pull alternate output |

Table 10-12 Flexible Static Memory Controller (FSMC)

| FSMC pinout   | GPIO configuration              |  |
|---------------|---------------------------------|--|
| FSMC_A[23:16] | Duck will alternate output      |  |
| FSMC_D[15:0]  | Push-pull alternate output      |  |
| FSMC_CK       | Push-pull alternate output      |  |
| FSMC_NOE      | Push-pull alternate output      |  |
| FSMC_NWE      |                                 |  |
| FSMC_NE1      | Push-pull alternate output      |  |
| FSMC_NCE2     |                                 |  |
| FSMC_NWAIT    | Floating input or pull-up input |  |
| FSMC_NBL[1:0] | Push-pull alternate output      |  |

Table 10-13 Analog-to-Digital Converter (ADC) and Digital-to-Analog Converter (DAC)

| ADC/DAC pinout | GPIO configuration |
|----------------|--------------------|
| ADC/DAC        | Analog input       |

Table 10-14 Other IO function settings

|            |                           | 8                                  |  |
|------------|---------------------------|------------------------------------|--|
| Pinout     | Configuration function    | GPIO configuration                 |  |
| TAMBED DTC | RTC output                | Hardware automatic setting         |  |
| TAMPER_RTC | Tamper event input        |                                    |  |
| MCO        | Clock output              | Push-pull alternate output         |  |
| EXTI       | External interment in mut | Floating input or pull-up or pull- |  |
| EAH        | External interrupt input  | down input                         |  |

## 10.2.11 Remapping GPIO Settings with Alternate Function

#### 10.2.11.1 OSC32\_IN/OSC32\_OUT as GPIO Port PC14/PC15

When LSEON=0, the LSE oscillator pin OSC32\_IN/OSC32\_OUT can be used as PC14/PC15 of GPIO respectively.

When LSEON=1, it is used as LSE pin.

#### 10.2.11.2 OSC\_IN/OSC\_OUT as GPIO port PD0/PD1

OSC\_IN/OSC\_OUT can be used as PD0/PD1 of GPIO, which is achieved by setting remapping register 1 (AFIO PCFR1).

This remapping applies to CH32V30x\_D8, CH32V30x\_D8C, CH32V31x\_D8C, CH32F20x\_D6, CH32F20x\_D8, CH32F20x\_D8C series chips, but for LQFP100 packages, it is not necessary to be performed by software as PD0 and PD1 are intrinsic function pins. remapping settings.

This remapping is only available for CH32V203CxT6, CH32V203CxU6, CH32V203K8T6, CH32V203G6U6,

CH32V203F6P6 chips for CH32V20x\_D6 series chips; for CH32V20x\_D8 series chips, CH32V203RBT6, only the OSC\_ IN and OSC\_OUT function pins, mapping is not supported.

Note: For CH32V307R, CH32V305R, CH32V305G, CH32V305F, CH32V303C, CH32V303R, CH32F205R, CH32F203R, CH32F203C chips with the penultimate digit of the batch number less than 4 and the penultimate digit of the sixth digit equal to 0. When PD0 and PD1 are used as normal pins, the external interrupt/event function is not mapped and cannot be used to generate external interrupts/events.

#### 10.2.11.3 Timer Alternate Function Remapping

Table 10-15 TIM1 Multiplexed Function Remapping

|             | 1               | 11 8            |                      |
|-------------|-----------------|-----------------|----------------------|
| Multiplexed | TIM1_RM=00      | TIM1_RM=01      | TIM1_RM=11           |
| Function    | Default Mapping | Partial Mapping | Complete Mapping (1) |
| TIM1_ETR    | PA12            | PA12            | PE7                  |
| TIM1_CH1    | PA8             | PA8             | PE9                  |
| TIM1_CH2    | PA9             | PA9             | PE11                 |
| TIM1_CH3    | PA10            | PA10            | PE13                 |
| TIM1_CH4    | PA11            | PA11            | PE14                 |
| TIM1_BKIN   | PB12            | PA6             | PE15                 |
| TIM1_CH1N   | PB13            | PA7             | PE8                  |
| TIM1_CH2N   | PB14            | PB0             | PE10                 |
| TIM1_CH3N   | PB15            | PB1             | PE12                 |

Note: (1) Only LQFP100 package, support this bit remapping function.

Table 10-16 TIM2 Multiplexed Function Remapping

| Multiplexed | TIM2_RM=00      | TIM2_RM=01      | TIM2_RM=10      | TIM2_RM=11       |
|-------------|-----------------|-----------------|-----------------|------------------|
| Function    | Default Mapping | Partial Mapping | Partial Mapping | Complete Mapping |
| TIM2_ETR    | PA0             | PA15            | PA0             | PA15             |
| TIM2_CH1    | PA0             | PA15            | PA0             | PA15             |
| TIM2_CH2    | PA1             | PB3             | PA1             | PB3              |
| TIM2_CH3    | PA2             | PA2             | PB10            | PB10             |
| TIM2_CH4    | PA3             | PA3             | PB11            | PB11             |

Table 10-17 TIM3 Multiplexed Function Remapping

|             |                 | 1               | 11 0                 |
|-------------|-----------------|-----------------|----------------------|
| Multiplexed | TIM3_RM=00      | TIM3_RM=10      | TIM3_RM=11           |
| Function    | Default Mapping | Partial Mapping | Complete Mapping (1) |
| TIM3_CH1    | PA6             | PB4             | PC6                  |
| TIM3_CH2    | PA7             | PB5             | PC7                  |
| TIM3_CH3    | PB0             | PB0             | PC8                  |
| TIM3_CH4    | PB1             | PB1             | PC9                  |

Note: (1) The bit mapping is not supported in packages below 64 pins.

Table 10-18 TIM4 Multiplexed Function Remapping

| Multiplexed | TIM4_RM=0       | TIM4_RM=1     |
|-------------|-----------------|---------------|
| Function    | Default Mapping | Remapping (1) |
| TIM4_CH1    | PB6             | PD12          |
| TIM4_CH2    | PB7             | PD13          |
| TIM4_CH3    | PB8             | PD14          |
| TIM4_CH4    | PB9             | PD15          |

Note: (1) Only LQFP100 package, support this bit remapping function.

Table 10-19 TIM5 Multiplexed Function Remapping

|             | <u> </u>        | 11 0               |
|-------------|-----------------|--------------------|
| Multiplexed | TIM5CH4_RM=0    | TIM5CH4_RM=1       |
| Function    | Default Mapping | Remapping          |
| TIM5_CH4    | PA3             | LSI internal clock |

Table 10-20 TIM8 Multiplexed Function Remapping (1)

|             |                 | 11 0      |
|-------------|-----------------|-----------|
| Multiplexed | TIM8_RM=0       | TIM8_RM=1 |
| Function    | Default Mapping | Remapping |
| TIM8_ETR    | PA0             | PA0       |
| TIM8_CH1    | PC6             | PB6       |
| TIM8_CH2    | PC7             | PB7       |
| TIM8_CH3    | PC8             | PB8       |
| TIM8_CH4    | PC9             | PC13      |
| TIM8_BKIN   | PA6             | PB9       |
| TIM8_CH1N   | PA7             | PA13      |
| TIM8_CH2N   | PB0             | PA14      |
| TIM8_CH3N   | PB1             | PA15      |

Table 10-21 TIM8 Multiplexed Function Remapping

| Multiplexed Function | TIM9_RM=00<br>Default Mapping | TIM9_RM=01<br>Partial Mapping | TIM9_RM=1x Complete Mapping (1) |
|----------------------|-------------------------------|-------------------------------|---------------------------------|
| Tunction             | Default Mapping               | r artiai Mapping              | Complete Mapping                |
| TIM9_ETR             | PA2                           | PA2                           | PD9                             |
| TIM9_CH1             | PA2                           | PA2                           | PD9                             |
| TIM9_CH2             | PA3                           | PA3                           | PD11                            |
| TIM9_CH3             | PA4                           | PA4                           | PD13                            |
| TIM9_CH4             | PC4                           | PC14                          | PD15                            |
| TIM9_BKIN            | PC5                           | PA1                           | PD14                            |
| TIM9_CH1N            | PC0                           | PB0                           | PD8                             |
| TIM9_CH2N            | PC1                           | PB1                           | PD10                            |
| TIM9_CH3N            | PC2                           | PB2                           | PD12                            |

Note: (1) Only LQFP100 package, support this bit remapping function.

Table 10-22 TIM10 Multiplexed Function Remapping

| Multiplexed Function | TIM10_RM=00 Default Mapping | TIM10_RM=01 Partial Mapping | TIM10_RM=1x Complete Mapping (1) |
|----------------------|-----------------------------|-----------------------------|----------------------------------|
|                      | Betaut Mapping              | Turiur Mupping              |                                  |
| TIM10_ETR            | PC10                        | PB11                        | PD0                              |
| TIM10_CH1            | PB8                         | PB3                         | PD1                              |
| TIM10_CH2            | PB9                         | PB4                         | PD3                              |
| TIM10_CH3            | PC3                         | PB5                         | PD5                              |
| TIM10_CH4            | PC11                        | PC15                        | PD7                              |
| TIM10_BKIN           | PC12                        | PB10                        | PE2                              |
| TIM10_CH1N           | PA12                        | PA5                         | PE3                              |
| TIM10_CH2N           | PA13                        | PA6                         | PE4                              |
| TIM10_CH3N           | PA14                        | PA7                         | PE5                              |

Note: (1) Only LQFP100 package, support this bit remapping function.

#### 10.2.11.4 USART Alternate Function Remapping

Table 10-23 USART1 alternate function remapping

| A Itamata  | USART1_RM1=0 (1) | USART1_RM1=1 (1) | USART1_RM1=0 (1) | USART1_RM1=1 (1) |
|------------|------------------|------------------|------------------|------------------|
| Alternate  | USART1_RM2=0 (2) | USART1_RM2=0 (2) | USART1_RM2=1 (2) | USART1_RM2=1 (2) |
| Function   | Default Mapping  | Remapping        | Remapping        | Remapping        |
| USART1_CK  | PA8              | PA8              | PA10             | PA5              |
| USART1_TX  | PA9              | PB6              | PB15             | PA6              |
| USART1_RX  | PA10             | PB7              | PA8              | PA7              |
| USART1_CTS | PA11             | PA11             | PA5              | PC4              |
| USART1_RTS | PA12             | PA12             | PA9              | PC5              |

Note: (1) USART1 RM1 is AFIO PCFR1 register bit2, which is the low bit of mapping configuration.

(2) USART1\_RM2 is AFIO\_PCFR2 register bit26, which is the high bit of mapping configuration. CH32V20x\_D6 and CH32F20x\_D6 do not support this bit mapping.

Table 10-24 USART2 alternate function remapping

| Alternate Function | USART2_RM=0 Default Mapping | USART2_RM=1 Remapping (1) |
|--------------------|-----------------------------|---------------------------|
| USART2_CTS         | PA0                         | PD3                       |
| USART2_RTS         | PA1                         | PD4                       |
| USART2_TX          | PA2                         | PD5                       |
| USART2_RX          | PA3                         | PD6                       |
| USART2_CK          | PA4                         | PD7                       |

Table 10-25 USART3 alternate function remapping

| Alternate Function | USART3_RM=00    | USART3_RM=01        | USART3_RM=10        | USART3_RM=11         |
|--------------------|-----------------|---------------------|---------------------|----------------------|
|                    | Default Mapping | Partial Mapping (1) | Partial Mapping (2) | Complete Mapping (3) |
| USART3_TX          | PB10            | PC10                | PA13                | PD8                  |

| USART3_RX  | PB11 | PC11 | PA14 | PD9  |
|------------|------|------|------|------|
| USART3_CK  | PB12 | PC12 | PD10 | PD10 |
| USART3_CTS | PB13 | PB13 | PD11 | PD11 |
| USART3_RTS | PB14 | PB14 | PD12 | PD12 |

Note: (1) The bit mapping is not supported for packages below 48 pins.

- (2) Applies only to CH32F20x\_D8, CH32F20x\_D8C, CH32V30x\_D8, CH32V30x\_D8C, and CH32V31x\_D8C series chips where the fifth digit from the end of the lot number is greater than or equal to 2, or the sixth digit from the end is not 0.
  - (3) Only the LQFP100 package supports this bit remapping function.

Table 10-26 USART4 alternate function remapping

| İ | Altamata Franctica (1) | USART4_RM=00    | USART4_RM=01 | USART4_RM=1x  |  |
|---|------------------------|-----------------|--------------|---------------|--|
|   | Alternate Function (1) | Default Mapping | Remapping    | Remapping (2) |  |
| İ | USART4_TX              | PC10            | PB0          | PE0           |  |
| ı | USART4_RX              | PC11            | PB1          | PE1           |  |

Note: (1) Applicable to CH32V30x\_D8C, CH32V31x\_D8C, CH32V30x\_D8, CH32V30x\_D8W, CH32V20x\_D8, CH32F20x\_D8C, CH32F20x\_D8C, CH32F20x\_D8W.

(2) Only LQFP100 package supports this bit remapping function.

Table 10-27 USART4 alternate function remapping (1)

| Alternate Function | USART4_RM=x0    | USART4_RM=x1 |
|--------------------|-----------------|--------------|
|                    | Default Mapping | Remapping    |
| USART4_CK          | PB2             | PA6          |
| USART4_TX          | PB0             | PA5          |
| USART4_RX          | PB1             | PB5          |
| USART4_CTS         | PB3             | PA7          |
| USART4_RTS         | PB4             | PA15         |

Note: (1) This feature is only supported on CH32V203C8, CH32F203C8 and 64-pin and above.

Table 10-28 USART5 alternate function remapping

| Altamata Franction | USART5_RM=00    | USART5_RM=01 | USART5_RM=1x  |
|--------------------|-----------------|--------------|---------------|
| Alternate Function | Default Mapping | Remapping    | Remapping (1) |
| USART5_TX          | PC12            | PB4          | PE8           |
| USART5_RX          | PD2             | PB5          | PE9           |

Note: (1) Only LQFP100 package, support this bit remapping function.

(2) This function is not supported for products below 64 pins.

Table 10-29 USART6 alternate function remapping (2)

|           |                     | * *          |               |
|-----------|---------------------|--------------|---------------|
| Alternate | USART6_RM=00        | USART6_RM=01 | USART6_RM=1x  |
| Function  | Default Mapping (2) | Remapping    | Remapping (1) |

| USART6_TX | PC0 | PB8 | PE10 |
|-----------|-----|-----|------|
| USART6_RX | PC1 | PB9 | PE11 |

Note: (1) Only LQFP100 package, support this bit remapping function.

(2) This function is not supported for products below 64 pins.

Table 10-30 USART7 alternate function remapping<sup>(2)</sup>

| Alternate Function | USART7_RM=00 Default Mapping | USART7_RM=01 Remapping | USART7_RM=1x Remapping (1) |
|--------------------|------------------------------|------------------------|----------------------------|
| USART7_TX          | PC2                          | PA6                    | PE12                       |
| USART7_RX          | PC3                          | PA7                    | PE13                       |

Note: (1) Only LQFP100 package, support this bit remapping function.

(2) This function is not supported for products below 64 pins.

Table 10-31 USART8 alternate function remapping<sup>(2)</sup>

| Alternate Function | USART8_RM=00 Default Mapping | USART8_RM=01    | USART8_RM=1x Remapping (1) |
|--------------------|------------------------------|-----------------|----------------------------|
| USART8 TX          | PC4                          | Remapping PA 14 | PE14                       |
| USART8_RX          | PC5                          | PA15            | PE15                       |

Note: (1) Only LQFP100 package, support this bit remapping function.

(2) This function is not supported for products below 64 pins.

#### 10.2.11.5 SPI Alternate Function Remapping

Table 10-32 SPI1 alternate function remapping

| Alternate Function | SPI1_RM=0       | SPI1_RM=1 |
|--------------------|-----------------|-----------|
| Alternate Function | Default Mapping | Remapping |
| SPI1_NSS           | PA4             | PA15      |
| SPI1_SCK           | PA5             | PB3       |
| SPI1_MISO          | PA6             | PB4       |
| SPI1_MOSI          | PA7             | PB5       |

Table 10-33 SPI3/I2S3 alternate function remapping

| Alternate Function | SPI3_RM=0 Default Mapping | SPI3_RM=1 Remapping |
|--------------------|---------------------------|---------------------|
| SPI3_NSS           | PA15                      | PA4                 |
| SPI3_SCK           | PB3                       | PC10                |
| SPI3_MISO          | PB4                       | PC11                |
| SPI3_MOSI          | PB5                       | PC12                |

|--|

|          | Default Mapping | Remapping |
|----------|-----------------|-----------|
| I2S3_WS  | PA15            | PA4       |
| I2S3_CK  | PB3             | PC10      |
| I2S3_MCK | PC7             | PC7       |
| I2S3_SD  | PB5             | PC12      |

#### 10.2.11.6 I2C Alternate Function Remapping

Table 10-34 I2C alternate function remapping

| Alternate Function | I2C1_RM=0 Default Mapping | I2C1_RM=1<br>Remapping |
|--------------------|---------------------------|------------------------|
| I2C1_SCL           | PB6                       | PB8                    |
| I2C1_SDA           | PB7                       | PB9                    |

#### 10.2.11.7 CAN Alternate Function Remapping

Table 10-35 CAN1 alternate function remapping

| Alternate Function | CAN1_RM=00<br>Default Mapping | CAN1_RM=10<br>Remapping | CAN1_RM=11<br>Remapping |
|--------------------|-------------------------------|-------------------------|-------------------------|
| CAN1_RX            | PA11                          | PB8                     | PD0                     |
| CAN1_TX            | PA12                          | PB9                     | PD1                     |

Table 10-36 CAN2 alternate function remapping

| Alternate Function | CAN2_RM=0 Default Mapping | CAN2_RM=1 Remapping |
|--------------------|---------------------------|---------------------|
| CAN2_RX            | PB12                      | PB5                 |
| CAN2_TX            | PB13                      | PB6                 |

### 10.2.11.8 ADC Alternate Function Remapping

Table 10-37 ADC1 external trigger injection conversion alternate function remapping

| Altamata Evantian     | ADC1_ETRGINJ_RM=0                                              | ADC1_ETRGINJ_RM=1               |
|-----------------------|----------------------------------------------------------------|---------------------------------|
| Alternate Function    | Default Mapping                                                | Remapping                       |
| ADC1 external trigger | ADC1 external trigger injection conversion connected to EXTI15 | ADC1 external trigger injection |
| injection conversion  |                                                                | conversion connected to         |
| injection conversion  |                                                                | TIM8_CH4                        |

Table 10-38 ADC1 external trigger rule conversion alternate function remapping

| Altamata Francian                     | ADC1_ETRGREG_RM=0          | ADC1_ETRGREG_RM=1          |
|---------------------------------------|----------------------------|----------------------------|
| Alternate Function                    | Default Mapping            | Remapping                  |
| ADC1 autamal trigger mula             | ADC1 external trigger rule | ADC1 external trigger rule |
| ADC1 external trigger rule conversion | conversion connected to    | conversion connected to    |
|                                       | EXTI11                     | TIM8_TRGO                  |

Table 10-39 ADC2 external trigger injection conversion alternate function remapping

| Altamata Evantian     | ADC2_ETRGINJ_RM=0               | ADC2_ETRGINJ_RM=1               |
|-----------------------|---------------------------------|---------------------------------|
| Alternate Function    | Default Mapping                 | Remapping                       |
| ADC2 external trigger | ADC2 external trigger injection | ADC2 external trigger injection |
| injection conversion  | conversion connected to EXTI15  | conversion connected to         |
| injection conversion  | Conversion connected to EXTITS  | TIM8_CH4                        |

Table 10-40 ADC2 external trigger rule conversion alternate function remapping

| A 14 4- E 4:               | ADC2_ETRGREG_RM=0          | ADC2_ETRGREG_RM=1          |  |  |
|----------------------------|----------------------------|----------------------------|--|--|
| Alternate Function         | Default Mapping            | Remapping                  |  |  |
| ADC2                       | ADC2 external trigger rule | ADC2 external trigger rule |  |  |
| ADC2 external trigger rule | conversion connected to    | conversion connected to    |  |  |
| conversion                 | EXTI11                     | TIM8_TRGO                  |  |  |

Note: ADC1 remapping is only supported for products where TIM8 is present, see the relevant datasheet for details.

#### 10.2.11.9 ETH Alternate Function Remapping

Table 10-41 ETH alternate function remapping

|                        |                 | 11 8          |
|------------------------|-----------------|---------------|
| Alternate Function (1) | ETH_RM=0        | ETH_RM=1      |
|                        | Default Mapping | Remapping (1) |
| ETH_RX_DV              | PA7             | PD8           |
| ETH_CRS_DV             | PA7             | PD8           |
| ETH_RXD0               | PC4             | PD9           |
| ETH_RXD1               | PC5             | PD10          |
| ETH_RXD2               | PB0             | PD11          |
| ETH_RXD3               | PB1             | PD12          |

Note: (1) Only LQFP100 package interconnect type supports this bit remapping function.

### 10.2.11.10 FSMC\_NADV Alternate Function Remapping

Table 10-42 FSMC NADV alternate function remapping

| Altamata Erration (1)  | FSMCEN=1        | FSMCEN=1&USBHSEN=1 |  |  |
|------------------------|-----------------|--------------------|--|--|
| Alternate Function (1) | Default Mapping | &RB_UC_RST_SIE=0   |  |  |
| FSMC_NADV              | PB7             | PD2                |  |  |

*Note:* (1) FSMC NADV output is disabled when FSMC NADV=1.

(2) This function is not supported if the fifth inverse digit of the lot number is less than 2 and the sixth inverse digit of the lot number is equal to 0.

#### 10.2.11.11 DVP Alternate Function Remapping

Table 10-43 DVP alternate function remapping

| Alternate Function | DVPEN=1         | DVPEN=1&USBHSEN=1 |  |  |
|--------------------|-----------------|-------------------|--|--|
| Alternate Function | Default Mapping | &RB_UC_RST_SIE=0  |  |  |
| DVP_D5             | PB6             | PB3               |  |  |

Note: (1) This function is not supported if the fifth inverse digit of the lot number is less than 2 and the sixth inverse digit of the lot number is equal to 0.

#### 10.2.11.12 SDIO Alternate Function Remapping

Table 10-44 SDIO alternate function remapping

| Alternate function | SDIOEN=1 | SDIOEN=1&ETHMACEN=1 |  |  |  |
|--------------------|----------|---------------------|--|--|--|
| SDCK               | PC12     | PC12                |  |  |  |
| CMD                | PD2      | PD2                 |  |  |  |
| SD0                | PC8      | PB14                |  |  |  |
| SD1                | PC9      | PB15                |  |  |  |
| SD2                | PC10     | PC10<br>PC11        |  |  |  |
| SD3                | PC11     |                     |  |  |  |
| SD4                | PB8      | PB8                 |  |  |  |
| SD5                | PB9      | PB9                 |  |  |  |
| SD6                | PC6      | PC6                 |  |  |  |
| SD7                | PC7      | PC7                 |  |  |  |

Note: (1) This function is not supported if the fifth inverse digit of the lot number is less than 2 and the sixth inverse digit of the lot number is equal to 0.

#### 10.2.11.13 SPI3/I2S3 Alternate Function Remapping (1)

Table 10-45 SPI3 alternate function remapping

| Alternate function | SPI3EN=1 | SPI3EN=1&ETHMACEN=1 <sup>(3)</sup> |
|--------------------|----------|------------------------------------|
| SPI3_NSS           | PA15     | Invaild <sup>(2)</sup>             |
| SPI3_SCK           | PB3      | PB3                                |
| SPI3_MISO          | PB4      | PB4                                |
| SPI3_MOSI          | PB5      | PA15                               |

Note: (1) This function is not supported if the fifth inverse digit of the lot number is less than 2 and the sixth inverse digit of the lot number is equal to 0.

- (2) SPI3\_NSS does not support the hardware function.
- (3) I2S3 is disabled when SPI3EN=1&ETHMACEN=1.

#### 10.2.11.14 SPI3/I2S3 Alternate Function Remapping (1)

Table 10-46 I2S3 alternate function remapping

| Alternate function | SPI3EN=1 | I2SMOD=1&ETH10M=1 <sup>(2)</sup> |
|--------------------|----------|----------------------------------|

| I2S3_WS  | PA15 | PA15 |
|----------|------|------|
| I2S3_CK  | PB3  | PB3  |
| I2S3_MCK | PC7  | PA8  |
| I2S3_SD  | PB5  | PA9  |

Note: (1) This function is not supported if the fifth inverse digit of the lot number is less than 2 and the sixth inverse digit of the lot number is equal to 0.

(2) I2S mode is selected when I2SMOD position 1 of SPI\_I2S\_CFGR register is selected, and 10M Ethernet function is enabled and clock enabled when ETH10M position 1 of EXTEN CTR register is selected.

## 10.3 Register Description

### 10.3.1 GPIO Registers

Unless otherwise specified, the GPIO registers must be operated in words (Operate these registers in 32 bits).

Table 10-47 GPIO registers

| Name            | Access address | Description                         | Reset value |
|-----------------|----------------|-------------------------------------|-------------|
| R32_GPIOA_CFGLR | 0x40010800     | PA port configuration register low  | 0x4444444   |
| R32_GPIOB_CFGLR | 0x40010C00     | PB port configuration register low  | 0x4444444   |
| R32_GPIOC_CFGLR | 0x40011000     | PC port configuration register low  | 0x4444444   |
| R32_GPIOD_CFGLR | 0x40011400     | PD port configuration register low  | 0x4444444   |
| R32_GPIOE_CFGLR | 0x40011800     | PE port configuration register low  | 0x4444444   |
| R32_GPIOA_CFGHR | 0x40010804     | PA port configuration register high | 0x4444444   |
| R32_GPIOB_CFGHR | 0x40010C04     | PB port configuration register high | 0x4444444   |
| R32_GPIOC_CFGHR | 0x40011004     | PC port configuration register high | 0x4444444   |
| R32_GPIOD_CFGHR | 0x40011404     | PD port configuration register high | 0x4444444   |
| R32_GPIOE_CFGHR | 0x40011804     | PE port configuration register high | 0x4444444   |
| R32_GPIOA_INDR  | 0x40010808     | PA port input data register         | 0x0000XXXX  |
| R32_GPIOB_INDR  | 0x40010C08     | PB port input data register         | 0x0000XXXX  |
| R32_GPIOC_INDR  | 0x40011008     | PC port input data register         | 0x0000XXXX  |
| R32_GPIOD_INDR  | 0x40011408     | PD port input data register         | 0x0000XXXX  |
| R32_GPIOE_INDR  | 0x40011808     | PE port input data register         | 0x0000XXXX  |
| R32_GPIOA_OUTDR | 0x4001080C     | PA port output data register        | 0x00000000  |
| R32_GPIOB_OUTDR | 0x40010C0C     | PB port output data register        | 0x00000000  |
| R32_GPIOC_OUTDR | 0x4001100C     | PC port output data register        | 0x00000000  |
| R32_GPIOD_OUTDR | 0x4001140C     | PD port output data register        | 0x00000000  |
| R32_GPIOE_OUTDR | 0x4001180C     | PE port output data register        | 0x00000000  |
| R32_GPIOA_BSHR  | 0x40010810     | PA port set/reset register          | 0x00000000  |
| R32_GPIOB_BSHR  | 0x40010C10     | PB port set/reset register          | 0x00000000  |
| R32_GPIOC_BSHR  | 0x40011010     | PC port set/reset register          | 0x00000000  |
| R32_GPIOD_BSHR  | 0x40011410     | PD port set/reset register          | 0x00000000  |
| R32_GPIOE_BSHR  | 0x40011810     | PE port set/reset register          | 0x00000000  |
| R32_GPIOA_BCR   | 0x40010814     | PA port reset register              | 0x00000000  |
| R32_GPIOB_BCR   | 0x40010C14     | PB port reset register              | 0x00000000  |

| R32_GPIOC_BCR  | 0x40011014 | PC port reset register              | 0x00000000 |
|----------------|------------|-------------------------------------|------------|
| R32_GPIOD_BCR  | 0x40011414 | PD port reset register              | 0x00000000 |
| R32_GPIOE_BCR  | 0x40011814 | PE port reset register              | 0x00000000 |
| R32_GPIOA_LCKR | 0x40010818 | PA port configuration lock register | 0x00000000 |
| R32_GPIOB_LCKR | 0x40010C18 | PB port configuration lock register | 0x00000000 |
| R32_GPIOC_LCKR | 0x40011018 | PC port configuration lock register | 0x00000000 |
| R32_GPIOD_LCKR | 0x40011418 | PD port configuration lock register | 0x00000000 |
| R32_GPIOE_LCKR | 0x40011818 | PE port configuration lock register | 0x00000000 |

## 10.3.1.1 GPIO Configuration Register Low (GPIOx\_CFGLR) (x=A/B/C/D/E)

Offset address: 0x00

| 31  | 30     | 29  | 28      | 27  | 26     | 25   | 24      | 23   | 22     | 21   | 20      | 19   | 18     | 17   | 16      |
|-----|--------|-----|---------|-----|--------|------|---------|------|--------|------|---------|------|--------|------|---------|
| CNF | 7[1:0] | MOD | E7[1:0] | CNF | 6[1:0] | MODE | E6[1:0] | CNF: | 5[1:0] | MODI | E5[1:0] | CNF4 | 4[1:0] | MODI | E4[1:0] |
| 15  | 14     | 13  | 12      | 11  | 10     | 9    | 8       | 7    | 6      | 5    | 4       | 3    | 2      | 1    | 0       |
| CNF | 3[1:0] | MOD | E3[1:0] | CNF | 2[1:0] | MODE | E2[1:0] | CNF  | [1:0]  | MODI | E1[1:0] | CNF  | 0[1:0] | MODI | E0[1:0] |

| Bit                                                                              | Name       | Access | Description                                                                                                                                                                                                                                                                                                                                                           | Reset value |
|----------------------------------------------------------------------------------|------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:30]<br>[27:26]<br>[23:22]<br>[19:18]<br>[15:14]<br>[11:10]<br>[7:6]<br>[3:2] | CNFy[1:0]  | RW     | (y=0-7), the configuration bit of port x; configure the corresponding port through these bits.  Input mode (MODE=00b): 00: Analog input mode; 01: Floating input mode; 10: Mode with pull-up and pull-down 11: Reserved. Output mode (MODE>00b): 00: General push-pull output mode; 01: General open-drain output mode; 10: Alternate function push-pull output mode; | 01b         |
| [29:28]<br>[25:24]<br>[21:20]<br>[17:16]<br>[13:12]<br>[9:8]<br>[5:4]<br>[1:0]   | MODEy[1:0] | RW     | (y=0-7), port x mode selection, configure the corresponding port through these bits.  00: Input mode;  01: Output mode, maximum speed: 10MHz;  10: Output mode, maximum speed: 2MHz;  11: Output mode, maximum speed: 50MHz;                                                                                                                                          | 0           |

## 10.3.1.2 GPIO Configuration Register High (GPIOx\_CFGHR) (x=A/B/C/D/E)

| 31   | 30     | 29   | 28       | 27   | 26     | 25   | 24       | 23   | 22     | 21   | 20      | 19   | 18     | 17           | 16      |
|------|--------|------|----------|------|--------|------|----------|------|--------|------|---------|------|--------|--------------|---------|
| CNF1 | 5[1:0] | MODI | E15[1:0] | CNF1 | 4[1:0] | MODE | [14[1:0] | CNF1 | 3[1:0] | MODE | 13[1:0] | CNF1 | 2[1:0] | )] MODE12[1: |         |
| 15   | 14     | 13   | 12       | 11   | 10     | 9    | 8        | 7    | 6      | 5    | 4       | 3    | 2      | 1            | 0       |
| CNF1 | 1[1:0] | MODI | E11[1:0] | CNF1 | 0[1:0] | MODE | [1:0]    | CNF  | 9[1:0] | MODI | E9[1:0] | CNF  | 8[1:0] | MODI         | E8[1:0] |

| Bit                                                                              | Name       | Access | Description                                                                                                                                                                                                                                                                                                                                                                    | Reset value |
|----------------------------------------------------------------------------------|------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:30]<br>[27:26]<br>[23:22]<br>[19:18]<br>[15:14]<br>[11:10]<br>[7:6]<br>[3:2] | CNFy[1:0]  | RW     | (y=8-15), the configuration bit of port x; configure the corresponding port through these bits.  Input mode (MODE=00b):  00: Analog input mode;  01: Floating input mode;  10: Mode with pull-up and pull-down  11: Reserved.  Output mode (MODE>00b):  00: General push-pull output mode;  01: General open-drain output mode;  10: Alternate function push-pull output mode; | 016         |
| [29:28]<br>[25:24]<br>[21:20]<br>[17:16]<br>[13:12]<br>[9:8]<br>[5:4]<br>[1:0]   | MODEy[1:0] | RW     | (y=8-15), the configuration mode of port x; configure the corresponding port through these bits.  00: Input mode; 01: Output mode, maximum speed: 10MHz; 10: Output mode, maximum speed: 2MHz; 11: Output mode, maximum speed: 50MHz;                                                                                                                                          | 0           |

## 10.3.1.3 Port Input Register (GPIOx\_INDR) (x=A/B/C/D/E)

Offset address: 0x08

| 31    | 30    | 29    | 28    | 27    | 26    | 25   | 24   | 23    | 22   | 21   | 20   | 19   | 18   | 17   | 16   |
|-------|-------|-------|-------|-------|-------|------|------|-------|------|------|------|------|------|------|------|
|       |       |       |       |       |       |      | Rese | erved |      |      |      |      |      |      |      |
| 15    | 14    | 13    | 12    | 11    | 10    | 9    | 8    | 7     | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| IDR15 | IDR14 | IDR13 | IDR12 | IDR11 | IDR10 | IDR9 | IDR8 | IDR7  | IDR6 | IDR5 | IDR4 | IDR3 | IDR2 | IDR1 | IDR0 |

| Bit     | Name     | Access | Description                                                                                             | Reset value |
|---------|----------|--------|---------------------------------------------------------------------------------------------------------|-------------|
| [31:16] | Reserved | RO     | Reserved                                                                                                | 0           |
| [15:0]  | IDRy     | RO     | (y=0-15), port input data. These bits are read-only and can only be read in 16-bit form. The read value | X           |
|         |          |        | represents the high/low status of the corresponding bit.                                                |             |

### 10.3.1.4 Port Output Register (GPIOx\_OUTDR) (x=A/B/C/D/E)

| 31        | 30        | 29   | 28        | 27        | 26        | 25   | 24   | 23   | 22   | 21   | 20   | 19   | 18   | 17   | 16   |
|-----------|-----------|------|-----------|-----------|-----------|------|------|------|------|------|------|------|------|------|------|
|           |           |      |           |           |           |      | Rese | rved |      |      |      |      |      |      |      |
| 15        | 14        | 13   | 12        | 11        | 10        | 9    | 8    | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| ODR1<br>5 | ODR1<br>4 | ODR1 | ODR1<br>2 | ODR1<br>1 | ODR1<br>0 | ODR9 | ODR8 | ODR7 | ODR6 | ODR5 | ODR4 | ODR3 | ODR2 | ODR1 | ODR0 |

| Bit     | Name     | Access | Description                                                                                                                                                                                                                       | Reset value |
|---------|----------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:16] | Reserved | RO     | Reserved                                                                                                                                                                                                                          | 0           |
| [15:0]  | ODRy     | RW     | (y=0-15), port output data. These bits can only be operated in form of 16 bits. The I/O port outputs the value of these registers externally. For input modes with pull-up and pull-down.  0: pull-down input.  1: pull-up input. |             |

## 10.3.1.5 Port Set/Reset Register (GPIOx\_BSHR) (x=A/B/C/D/E)

Offset address: 0x10

| 31   | 30   | 29   | 28   | 27   | 26   | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  |
|------|------|------|------|------|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| BR15 | BR14 | BR13 | BR12 | BR11 | BR10 | BR9 | BR8 | BR7 | BR6 | BR5 | BR4 | BR3 | BR2 | BR1 | BR0 |
| 15   | 14   | 13   | 12   | 11   | 10   | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
| BS15 | BS14 | BS13 | BS12 | BS11 | BS10 | BS9 | BS8 | BS7 | BS6 | BS5 | BS4 | BS3 | BS2 | BS1 | BS0 |

| Bit     | Name | Access | Description                                                                                                                                                                                                                     | Reset value |
|---------|------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:16] | BRy  | WO     | (y=0-15), setting these bits will clear the corresponding OUTDR bits, and writing 0 has no effect. These bits can only be accessed in form of 16 bits. If the BR and BS bits are set at the same time, the BS bit takes effect. | 0           |
| [15:0]  | BSy  | WO     | (y=0-15), setting these bits will set the corresponding OUTDR bits, and writing 0 has no effect. These bits can only be accessed in form of 16 bits. If the BR and BS bits are set at the same time, the BS bit takes effect.   | 0           |

## 10.3.1.6 Port Reset Register (GPIOx\_BCR) (x=A/B/C/D/E)

| 31   | 30   | 29   | 28   | 27   | 26   | 25  | 24   | 23   | 22  | 21  | 20  | 19  | 18  | 17  | 16  |
|------|------|------|------|------|------|-----|------|------|-----|-----|-----|-----|-----|-----|-----|
|      |      |      |      |      |      |     | Rese | rved |     |     |     |     |     |     |     |
| 15   | 14   | 13   | 12   | 11   | 10   | 9   | 8    | 7    | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
| BR15 | BR14 | BR13 | BR12 | BR11 | BR10 | BR9 | BR8  | BR7  | BR6 | BR5 | BR4 | BR3 | BR2 | BR1 | BR0 |

| Bit     | Name     | Access | Description                                                                                                                                            | Reset value |
|---------|----------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:16] | Reserved | RO     | Reserved                                                                                                                                               | 0           |
| [15:0]  | BRy      | WO     | (y=0-15), setting these bits will clear the corresponding OUTDR bits, and writing 0 has no effect. These bits can only be accessed in form of 16 bits. | 0           |

### 10.3.1.7 Configuration Lock Register (GPIOx\_LCKR) (x=A/B/C/D/E)

Offset address: 0x18

| 31   | 30       | 29   | 28        | 27        | 26        | 25   | 24   | 23   | 22   | 21   | 20   | 19   | 18   | 17   | 16   |
|------|----------|------|-----------|-----------|-----------|------|------|------|------|------|------|------|------|------|------|
|      | Reserved |      |           |           |           |      |      |      |      |      |      |      | LCKK |      |      |
| 15   | 14       | 13   | 12        | 11        | 10        | 9    | 8    | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| LCK1 | LCK1     | LCK1 | LCK1<br>2 | LCK1<br>1 | LCK1<br>0 | LCK9 | LCK8 | LCK7 | LCK6 | LCK5 | LCK4 | LCK3 | LCK2 | LCK1 | LCK0 |

| Bit     | Name     | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Reset value |
|---------|----------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:17] | Reserved | RO     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0           |
| 16      | LCKK     | RW     | Lock key. It can be locked by writing in a specific sequence, but it can be read out at any time. When it is read as 0, it means that it is unlocked. When it is read as 1, it means that it is locked.  The write sequence of the lock key is: write 1-write 0-write 1-read 0-read 1. The last step is not necessary, but can be used to check whether the lock key has been activated.  When the sequence is written, any error will not lock the activation. When the sequence is written, the value of LCK[15:0] cannot be changed. After the lock takes effect, the port configuration can be only changed after the next reset. | 0           |
| [15:0]  | LCKy     | RW     | (y=0-15), when these bits are 1, it means that the configuration of the corresponding port is locked. These bits can only be changed before the LCKK is unlocked. The locked configuration refers to GPIOx_CFGLR and GPIOx_CFGHR.                                                                                                                                                                                                                                                                                                                                                                                                     | 0           |

Note: After the LOCK sequence is performed on the corresponding port bit, the configuration of the port bit cannot be changed until the next system reset.

### 10.3.2 AFIO Registers

Unless otherwise specified, the AFIO registers must be operated in words (Operate these registers in 32 bits).

Table 10-48 AFIO registers

| Name             | Access address | Description                                | Reset value |
|------------------|----------------|--------------------------------------------|-------------|
| R32_AFIO_ECR     | 0x40010000     | Event control register                     | 0x00000000  |
| R32_AFIO_PCFR1   | 0x40010004     | Remap register1                            | 0x00000000  |
| R32_AFIO_EXTICR1 | 0x40010008     | External interrupt configuration register1 | 0x00000000  |
| R32_AFIO_EXTICR2 | 0x4001000C     | External interrupt configuration register2 | 0x00000000  |
| R32_AFIO_EXTICR3 | 0x40010010     | External interrupt configuration register3 | 0x00000000  |
| R32_AFIO_EXTICR4 | 0x40010014     | External interrupt configuration register4 | 0x00000000  |

| R32 AFIO PCFR2 | 0x4001001C | Remap register2 | 0x00000000 |
|----------------|------------|-----------------|------------|
|----------------|------------|-----------------|------------|

# 10.3.2.1 Event Control Register (AFIO\_ECR)

Offset address: 0x00

| 31 | 30       | 29 | 28 | 27 | 26 | 25   | 24 | 23    | 22  | 21 | 20  | 19    | 18 | 17 | 16 |
|----|----------|----|----|----|----|------|----|-------|-----|----|-----|-------|----|----|----|
|    | Reserved |    |    |    |    |      |    |       |     |    |     |       |    |    |    |
| 15 | 14       | 13 | 12 | 11 | 10 | 9    | 8  | 7     | 6   | 5  | 4   | 3     | 2  | 1  | 0  |
|    | Reserved |    |    |    |    | EVOE | P  | ORT[2 | :0] |    | PIN | [3:0] |    |    |    |

| Bit    | Name      | Access | Description                                                                                                                                                                    | Reset value |
|--------|-----------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:8] | Reserved  | RO     | Reserved                                                                                                                                                                       | 0           |
| 7      | EVOE      | RW     | Event output enable bit. By setting this bit, the EVENTOUT of core is connected to the selected IO ports of PORT and PIN.                                                      |             |
| [6:4]  | PORT[2:0] | RW     | Used to select the port of core output EVENTOUT:  000: PA port;  010: PC port;  011: PD port;  Others: Reserved.                                                               | 0           |
| [3:0]  | PIN[3:0]  | RW     | The value of these bits is used to determine the number of the pin that selects the core EVENTOUT to the port. Values 0-15 correspond to pins 0-15 of the PX selected in PORT. | 0           |

# 10.3.2.2 Remap Register 1 (AFIO\_PCFR1)

| 31               | 30                 | 29                  | 28          | 27           | 26 | 25    | 24           | 23                  | 22          | 21         | 20                              | 19                          | 18                              | 17                          | 16                 |
|------------------|--------------------|---------------------|-------------|--------------|----|-------|--------------|---------------------|-------------|------------|---------------------------------|-----------------------------|---------------------------------|-----------------------------|--------------------|
| Reser<br>ved     | PTP_<br>PPS_<br>RM | TIM2<br>ITR1<br>_RM | SPI3_<br>RM | Reser<br>ved | SW | _CFG[ | 2:0]         | MII_<br>RMII<br>SĒL | CAN<br>2_RM | ETH_<br>RM | ADC<br>2_ET<br>RGR<br>EG_R<br>M | ADC<br>2_ET<br>RGIN<br>J_RM | ADC<br>1_ET<br>RGR<br>EG_R<br>M | ADC<br>1_ET<br>RGIN<br>J_RM | TIM5<br>CH4_<br>RM |
| 15               | 14                 | 13                  | 12          | 11           | 10 | 9     | 8            | 7                   | 6           | 5          | 4                               | 3                           | 2                               | 1                           | 0                  |
| PDP<br>D1_<br>RM | CAN1<br>[1:        | _                   | TIM4<br>_RM | TIM3<br>[1:  | _  |       | 2_RM]<br>:0] |                     | _RM]<br>:0] |            | T3_RM<br>:0]                    | USAR<br>T2<br>_RM           | USAR<br>T1<br>_RM               | I2C1<br>_RM                 | SPI1<br>_RM        |

| Bit | Name        | Access | Description                                   | Reset value |
|-----|-------------|--------|-----------------------------------------------|-------------|
| 31  | Reserved    | RO     | Reserved                                      | 0           |
|     |             |        | Ethernet PTP PPS remap                        |             |
|     |             |        | 0: PTP PPS not output to the PB5 pin;         |             |
| 30  | PTP_PPS_RM  | RW     | 1: PTP PPS output to the PB5 pin.             | 0           |
|     |             |        | Note: This bit applies to CH32F20x, CH32V20x, |             |
|     |             |        | CH32V30x and CH32V31x series chips.           |             |
| 29  | TIM2ITR1_RM | RW     | TIM2 internal trigger1 remap                  | 0           |

|         |                      |    | 0: Internally connect TIM2_ITR1 to Ethernet PTP output; 1: Internally connect TIM2_ITR1 to SOF output of full-speed USB OTG.  Note: This bit applies to CH32F2x, CH32V2x, CH32V31x_D8C and CH32V3x whole series                                                                                                                                                                                                                                      |   |
|---------|----------------------|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| 28      | SPI3_RM              | RW | chips.  SPI3 remap  0: Default map (NSS/PA15, SCK/PB3, MSIO/PB4, MOSI/PB5);  1: Remap (NSS/PA4, SCK/PC10, MSIO/PC11, MOSI/PC12).  Note: This bit applies to CH32V30x_D8, CH32V30x_D8C, CH32V31x_D8C and CH32F20x_D8, CH32F20x_D8, CH32F20x_D8, CH32F20x_D8C series chips.                                                                                                                                                                            | 0 |
| [26:24] | Reserved SW_CFG[2:0] | RO | Reserved  These bits are used to configure the IO port with SW function and tracking function. SWD (SDI) is a debug interface to access the core. After system reset, it is always used as the SWD port.  0xx: SWD enabled (SDI); 100: SWD disabled (SDI), served as GPIO; Others: Invalid.  Note: This bit applies to CH32F20x, CH32V20x, CH32V30x and CH32V31x whole series chips.                                                                 | 0 |
| 23      | MII_RMII_SEL         | RW | MII or RMII selection. Configure the internal Ethernet MAC to use the external transceiver with MII interface or RMII interface (PHY).  0: Configure the Ethernet MAC to use the external transceiver with MII interface (PHY);  1: Configure the Ethernet MAC to use the external transceiver with RMII interface (PHY).  Note: This bit applies to CH32F20x_D8C, CH32V30x_D8C, CH32V30x_D8C, CH32V20x_D8W, CH32V20x_D8, CH32V20x_D8W series chips. | 0 |
| 22      | CAN2_RM              | RW | CAN2 remap bit.  0: Default map (CAN2_RX/PB12, CAN2_TX/PB13);  1: Remap (CAN2_RX/PB5, CAN2_TX/PB6).  Note: This bit applies to CH32V30x_D8,  CH32V30x_D8C, CH32V31x_D8C,  CH32F20x_D8 and CH32F20x_D8C,  CH32V20x_D8series chips.                                                                                                                                                                                                                    | 0 |
| 21      | ETH_RM               | RW | Ethernet remap bit.  0: Default map (RX_DV-CRS_DV/PA7, RXD0/PC4, RXD1/PC5, RXD2/PB0, RXD3/PB1);                                                                                                                                                                                                                                                                                                                                                      | 0 |

|    |                     |    | 1: Remap (RX_DV-CRS_DV/PD8, RXD0/PD9, RXD1/PD10, RXD2/PD11, RXD3/PD12)  Note: The remapping function for Ethernet is only available for CH32F207VCT6, CH32V307VCT6, CH32V317VCT6 chips.                                                                                       |   |
|----|---------------------|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| 20 | ADC2_ETRGREG_<br>RM | RW | Remap bit of ADC1 external trigger regular conversion.  0: ADC2 external trigger regular conversion EXTI11;  1: ADC2 external trigger regular conversion TIM8_TRGO.  Note: This bit applies to CH32F20x_D8, CH32F20x_D8C, CH32V30x and CH32V31x whole series chips.           | 0 |
| 19 | ADC2_ETRGINJ_R<br>M | RW | Remap bit of ADC2 external trigger injection conversion  0: ADC2 external trigger injection conversion to EXTI15;  1: ADC2 external trigger injection conversion to TIM8_CH4.  Note: This bit applies to CH32F20x_D8, CH32F20x_D8C, CH32V30x and CH32V31x whole series chips. | 0 |
| 18 | ADC1_ETRGREG_<br>RM | RW | Remap bit of ADC1 external trigger regular conversion  0: ADC1 external trigger regular conversion to EXTI11;  1: ADC1 external trigger regular conversion to TIM8_TRGO.  Note: This bit applies to CH32F20x_D8, CH32F20x_D8C, CH32V30x and CH32V31x whole series chips.      | 0 |
| 17 | ADC1_ETRGINJ_R<br>M | RW | Remap bit of ADC1 external trigger injection conversion  0: ADC1 external trigger injection conversion to EXTI15;  1: ADC1 external trigger injection conversion to TIM8_CH4.  Note: This bit applies to CH32F20x_D8, CH32F20x_D8C, CH32V30x and CH32V31x whole series chips. | 0 |
| 16 | TIM5CH4_RM          | RW | Remapping of timer 5 channel 4.  0: Default mapping, remapping of timer 5 channel 4;  1: Remapping, timer 5 channel 4 mapped to the LSI internal clock.                                                                                                                       | 0 |

V2. 4 140 WCH°

|         |              |    | Note: This bit applies to the full series of                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |   |
|---------|--------------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| 15      | PD0PD1_RM    | RW | Pin PD0&PD1 remap bit, which can be read or written by the user. It controls whether the GPIO functions of PD0 & PD1 are remapped, i.e. PD0 & PD1 are mapped to OSC_IN & OSC_OUT.  0: Pin is used as crystal pin;  1: pins are used as GPIO ports;  Note: (1) This bit remapping is applicable to CH32V30x_D8, CH32V30x_D8C, CH32V30x_D8C, CH32F20x_D6, CH32F20x_D8, CH32F20x_D6, CH32F20x_D8, CH32F20x_D8C series of chips, however, for LQFP100 packages, it is not necessary since PD0 and PD1 are intrinsic function pins to be remapping setting by software.  (2) This bit remapping is only applicable to CH32V203CxT6, CH32V203CxU6, CH32V203K8T6, CH32V203G6U6, CH32V203F6P6 chips for CH32V20x_D6 series chips.  (3) For CH32V20x_D8 series chips CH32V203RBT6 has only OSC_IN and OSC_OUT function pins and does not support mapping. | 0 |
| [14:13] | CAN1_RM[1:0] | RW | CAN1 alternate function remap bits, which can be read and written by the user. Control remapping of CAN_RX and CAN_TX:  00: CAN1_RX is mapped to PA11, and CAN1_TX is mapped to PA12;  10: CAN1_RX is mapped to PB8, and CAN1_TX is mapped to PB9;  01: Reserved;  11: CAN1_RX is mapped to PD0, and CAN1_TX is mapped to PD1.  Note: (1) This bit applies to CH32F20x, CH32V20x, CH32V30x and CH32V31x series chips.                                                                                                                                                                                                                                                                                                                                                                                                                            | 0 |
| 12      | TIM4_RM      | RW | Remap bit of timer4. This bit can be read and written by the user. It controls remapping of channel1 to channel4 of timer4:  0: Default map (CH1/PB6, CH2/PB7, CH3/PB8, CH4/PB9);  1: Remap (CH1/PD12, CH2/PD13, CH3/PD14, CH4/PD15).  Note: This bit remapping applies to CH32V303VCT6, CH32V307VCT6,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 0 |

V2. 4 141 WH°

|         |              |    | CH32V317VCT6, CH32F203VCT6,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |   |
|---------|--------------|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| [11:10] | TIM3_RM[1:0] | RW | CH32F207VCT6 chips.  Remap bits of timer3. These bits can be read and written by the user. It controls remapping of channel1 to channel4 of timer3:  00: Default map (CH1/PA6, CH2/PA7, CH3/PB0, CH4/PB1);  01: Reserved;  10: Partly map (CH1/PB4, CH2/PB5, CH3/PB0, CH4/PB1);  11: Fully map (CH1/PC6, CH2/PC7, CH3/PC8, CH4/PC9).  Note: (1) The remapping does not affect TIM3_ETR on PD2.  (2) This bit remapping applies to CH32F20x, CH32V20x, CH32V30x and CH32V31x series 64-pin and above package chips                                                            | 0 |
| [9:8]   | TIM2_RM[1:0] | RW | pin and above package chips.  Remap bits of timer 2. These bits can be written and read by the user. It controls the mapping of channel1 to channel4 of timer2 and external trigger (ETR) on the GPIO port:  00: Default map (ETR/PA0, CH1/PA0, CH2/PA1, CH3/PA2, CH4/PA3);  01: Partly map (ETR/PA15, H1/PA15, CH2/PB3, CH3/PA2, CH4/PA3);  10: Partly map (ETR/PA0, CH1/PA0, CH2/PA1, CH3/PB10, CH4/PB11);  11: Fully map (ETR/PA15, CH1/PA15, CH2/PB3, CH3/PB10, CH4/PB11).  Note: This bit applies to the full range of CH32F20x, CH32V20x, CH32V30x and CH32V31x chips. | 0 |
| [7:6]   | TIM1_RM[1:0] | RW | Remap bit of timer 1. These bits can be written and read by the user. It controls the mapping of channel1 to channel4 of timer1, 1N to 3N, external trigger (ETR) and break input (BKIN) on the GPIO port:  00: Default map (ETR/PA12, CH1/PA8, CH2/PA9, CH3/PA10, CH4/PA11, BKIN/PB12, CH1N/PB13, CH2N/PB14, CH3N/PB15);  01: Partly map (ETR/PA12, CH1/PA8, CH2/PA9, CH3/PA10, CH4/PA11, BKIN/PA6, CH1N/PA7, CH2N/PB0, CH3N/PB1);  10: Reserved;  11: Fully map (ETR/PE7, CH1/PE9, CH2/PE11, CH3/PE13, CH4/PE14, BKIN/PE15, CH1N/PE8,                                      | 0 |

V2. 4 142 WH

| [5:4] | USART3_RM[1:0] | RW | CH2N/PE10, CH3N/PE12).  Note: This bit partial mapping applies to the full series of CH32F20x, CH32V20x, CH32V30x and CH32V31x chips; full mapping applies only to CH32V303VCT6, CH32V307VCT6, CH32F203VCT6, CH32F207VCT6 chips.  USART3 remap bits. These bits can be read and written by the user. It controls the mapping of CTS, RTS, CK, TX and RX alternate functions of USART3 on the GPIO port:  00: Default map (TX/PB10, RX/PB11, CK/PB12, CTS/PB13, RTS/PB14);  01: Partly remap (TX/PC10, RX/PC11, CK/PC12, CTS/PB13, RTS/PB14);  10: Partial remapping (TX/PA13, RX/PA14, CK/PD10, CTS/PD11, RTS/PD12);  11: Fully remap (TX/PD8, RX/PD9, CK/PD10, CTS/PD11, RTS/PD12).  Note: (1) Packages below 48 pins do not support (01b) partial remapping.  (2) Partial remapping (10b) applies only to CH32F20x_D8, CH32F20x_D8C, CH32V30x_D8, CH32F20x_D8C, CH32V30x_D8, CH32V30x_D8C, and CH32V31x_D8C series chips where the fifth digit from the end of the batch number is greater than or equal to 2, or the sixth digit from the end is not 0.  (3) Full remapping is only available for CH32V303VCT6, CH32V307VCT6, | 0 |
|-------|----------------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| 3     | USART2_RM      | RW | 0. (3) Full remapping is only available for                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0 |
| 2     | USART1_RM      | RW | USART1 map configuration low bit (used with the bit26 (USART1RM1) in the AFIO_PCFR2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0 |

V2. 4 143 WCH°

|   |            |      | register).                                                                                   |   |
|---|------------|------|----------------------------------------------------------------------------------------------|---|
|   |            |      | 00: Default map (CK/PA8, TX/PA9, RX/PA10,                                                    |   |
|   |            |      | CTS/PA11, RTS/PA12);                                                                         |   |
|   |            |      | 01: Remap (CK/PA8, TX/PB6, RX/PB7,                                                           |   |
|   |            |      | CTS/PA11, RTS/PA12);                                                                         |   |
|   |            |      | 10: Remap (CK/PA10, TX/PB15, RX/PA8,                                                         |   |
|   |            |      | CTS/PA5, RTS/PA9);                                                                           |   |
|   |            |      | 11: Remap (CK/PA5, TX/PA6, RX/PA7,                                                           |   |
|   |            |      | CTS/PC4, RTS/PC5).                                                                           |   |
|   |            |      | <i>Note: CH32F20x_D6, CH32F20x_D8,</i>                                                       |   |
|   |            |      | CH32F20x_D8W, CH32V20x_D6,                                                                   |   |
|   |            |      | CH32V20x_D8, CH32V20x_D8W exist only in the                                                  |   |
|   |            |      | default mapping (00b), remapping (01b).                                                      |   |
|   |            |      | Remap of I2C1. This bit can be read and written                                              |   |
|   |            |      | by the user. It controls the mapping of the SCL and                                          |   |
|   |            |      | SDA alternate functions of I2C1 at the GPIO port:                                            |   |
| 1 | I2C1 RM    | RW   | 0: Default map (SCL/PB6, SDA/PB7);                                                           | 0 |
|   | 12 01_10.1 | 12., | 1: Remap (SCL/PB8, SDA/PB9).                                                                 | Ü |
|   |            |      | Note: This bit applies to the full range of                                                  |   |
|   |            |      | CH32F20x, CH32V20x, CH32V30x and                                                             |   |
|   |            |      | CH32V31x chips.                                                                              |   |
|   |            |      | Remap of SPI1. This bit can be read and written                                              |   |
|   |            |      | by the user. It controls the mapping of NSS, SCK,                                            |   |
|   |            |      | MISO and MOSI alternate functions of SPI1 at the                                             |   |
|   |            |      | GPIO port:                                                                                   |   |
|   |            |      | 0: Default map (NSS/PA4, SCK/PA5, MISO/PA6,                                                  |   |
| 0 | SPI1_RM    | RW   | MOSI/PA7);                                                                                   | 0 |
|   |            |      | 1: Remap (NSS/PA15, SCK/PB3, MISO/PB4,                                                       |   |
|   |            |      | MOSI/PB5).                                                                                   |   |
|   |            |      | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1                                                      |   |
|   |            |      | Note: This bit applies to the full range of                                                  |   |
|   |            |      | Note: This bit applies to the full range of CH32F20x, CH32V20x, CH32V30x and CH32V31x chips. |   |

## 10.3.2.3 External Interrupt Configuration Register1 (AFIO\_EXTICR1)

Offset address: 0x08

| 31 | 30       | 29      | 28 | 27         | 26 | 25 | 24         | 23 | 22 | 21 | 20         | 19 | 18 | 17 | 16 |
|----|----------|---------|----|------------|----|----|------------|----|----|----|------------|----|----|----|----|
|    | Reserved |         |    |            |    |    |            |    |    |    |            |    |    |    |    |
| 15 | 14       | 13      | 12 | 11         | 10 | 9  | 8          | 7  | 6  | 5  | 4          | 3  | 2  | 1  | 0  |
|    | EXT      | [3[3:0] |    | EXTI2[3:0] |    |    | EXTI1[3:0] |    |    |    | EXTI0[3:0] |    |    |    |    |

| Bit     | Name       | Access | Description                                         | Reset value |
|---------|------------|--------|-----------------------------------------------------|-------------|
| [31:16] | Reserved   | RO     | Reserved                                            | 0           |
| [15:12] |            |        | (x=0-3), external interrupt input pin configuration |             |
| [11:8]  | EXTIx[3:0] | RW     | bits. These bits are used to determine which port   | 0           |
| [7:4]   |            |        | pin the external interrupt pin is mapped to:        |             |

| [3:0] | 0000: | Pin x of the PA pin; |
|-------|-------|----------------------|
|       | 0001: | Pin x of the PB pin; |
|       | 0010: | Pin x of the PC pin; |
|       | 0011: | Pin x of the PD pin; |
|       | 0100: | Pin x of the PE pin; |
|       | Other | s: Reserved.         |

## 10.3.2.4 External Interrupt Configuration Register2 (AFIO\_EXTICR2)

Offset address: 0x0C

| 31 | 30       | 29      | 28 | 27 | 26         | 25 | 24 | 23         | 22 | 21 | 20 | 19         | 18 | 17 | 16 |
|----|----------|---------|----|----|------------|----|----|------------|----|----|----|------------|----|----|----|
|    | Reserved |         |    |    |            |    |    |            |    |    |    |            |    |    |    |
| 15 | 14       | 13      | 12 | 11 | 10         | 9  | 8  | 7          | 6  | 5  | 4  | 3          | 2  | 1  | 0  |
|    | EXT      | [7[3:0] |    |    | EXTI6[3:0] |    |    | EXTI5[3:0] |    |    |    | EXTI4[3:0] |    |    |    |

| Bit                                 | Name       | Access | Description                                                                                                                                                                                                                                                                                  | Reset value |
|-------------------------------------|------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:16]                             | Reserved   | RO     | Reserved                                                                                                                                                                                                                                                                                     | 0           |
| [15:12]<br>[11:8]<br>[7:4]<br>[3:0] | EXTIx[3:0] | RW     | (x=4-7), external interrupt input pin configuration bits, used to determine which port pin the external interrupt pin is mapped to: 0000: Pin x of the PA pin; 0001: Pin x of the PB pin; 0010: Pin x of the PC pin; 0011: Pin x of the PD pin; 0100: Pin x of the PE pin; 0thers: Reserved. |             |

## 10.3.2.5 External Interrupt Configuration Register3 (AFIO\_EXTICR3)

Offset address: 0x10

| 31 | 30       | 29      | 28 | 27 | 26          | 25 | 24 | 23         | 22 | 21 | 20         | 19 | 18 | 17 | 16 |
|----|----------|---------|----|----|-------------|----|----|------------|----|----|------------|----|----|----|----|
|    | Reserved |         |    |    |             |    |    |            |    |    |            |    |    |    |    |
| 15 | 14       | 13      | 12 | 11 | 10          | 9  | 8  | 7          | 6  | 5  | 4          | 3  | 2  | 1  | 0  |
|    | EXTI     | 11[3:0] | ]  |    | EXTI10[3:0] |    |    | EXTI9[3:0] |    |    | EXTI8[3:0] |    |    |    |    |

| Bit                                 | Name       | Access | Description                                                                                                                                                                                                                                                         | Reset value |
|-------------------------------------|------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:16]                             | Reserved   | RO     | Reserved                                                                                                                                                                                                                                                            | 0           |
| [15:12]<br>[11:8]<br>[7:4]<br>[3:0] | EXTIx[3:0] | RW     | (x=8-11), external interrupt input pin configuration bits. These bits are used to determine which port pin the external interrupt pin is mapped to:  0000: Pin x of the PA pin;  0001: Pin x of the PB pin;  0010: Pin x of the PC pin;  0011: Pin x of the PD pin; |             |

|  |  | O.1 D 1            |  |
|--|--|--------------------|--|
|  |  | ( )thers: Reserved |  |
|  |  | Officis. Reserved. |  |

## 10.3.2.6 External Interrupt Configuration Register4 (AFIO\_EXTICR4)

Offset address: 0x14

| 31 | 30          | 29 | 28 | 27 | 26   | 25      | 24  | 23    | 22    | 21      | 20 | 19 | 18   | 17      | 16 |
|----|-------------|----|----|----|------|---------|-----|-------|-------|---------|----|----|------|---------|----|
|    |             |    |    |    |      |         | Res | erved |       |         |    |    |      |         |    |
| 15 | 14          | 13 | 12 | 11 | 10   | 9       | 8   | 7     | 6     | 5       | 4  | 3  | 2    | 1       | 0  |
|    | EXTI15[3:0] |    |    |    | EXTI | 14[3:0] |     |       | EXTI1 | 13[3:0] |    |    | EXTI | 12[3:0] |    |

| Bit                                 | Name       | Access | Description                                                                                                                                                                                                                                                                                                   | Reset value |
|-------------------------------------|------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:16]                             | Reserved   | RO     | Reserved                                                                                                                                                                                                                                                                                                      | 0           |
| [15:12]<br>[11:8]<br>[7:4]<br>[3:0] | EXTIx[3:0] | RW     | (x=12-15), external interrupt input pin configuration bits. These bits are used to determine which port pin the external interrupt pin is mapped to: 0000: Pin x of the PA pin; 0001: Pin x of the PB pin; 0010: Pin x of the PC pin; 0011: Pin x of the PD pin; 0100: Pin x of the PE pin; Others: Reserved. |             |

## 10.3.2.7 Remap Register 2 (AFIO\_PCFR2)

Offset address: 0x1C

| 31 | 30       | 29      | 28 | 27                | 26                 | 25      | 24                | 23 | 22                 | 21 | 20          | 19          | 18                | 17    | 16                |
|----|----------|---------|----|-------------------|--------------------|---------|-------------------|----|--------------------|----|-------------|-------------|-------------------|-------|-------------------|
|    | F        | Reserve | ed |                   | USAR<br>T1_R<br>M1 | ľ       | RT8_R<br>M<br>:0] | N  | RT7_R<br>/I<br>:0] | N  | _           | N           | RT5_R<br>M<br>:0] | N     | RT4_R<br>M<br>:0] |
| 15 | 14       | 13      | 12 | 11                | 10                 | 9       | 8                 | 7  | 6                  | 5  | 4           | 3           | 2                 | 1     | 0                 |
|    | Reserved |         |    | FSMC<br>_NAD<br>V |                    | Reserve | d                 |    | 0_RM<br>:0]        |    | P_RM<br>:0] | TIM8<br>_RM | Rese              | erved |                   |

| Bit     | Name       | Access | Description                                  | Reset value |
|---------|------------|--------|----------------------------------------------|-------------|
| [31:27] | Reserved   | RO     | Reserved                                     | 0           |
|         |            |        | USART1 map configuration high bit (Used with |             |
|         |            |        | the bit2 (USART1RM) in the AFIO_PCFR1        |             |
|         |            |        | register).                                   |             |
|         | USART1_RM1 |        | 00: Default map (CK/PA8, TX/PA9, RX/PA10,    |             |
| 26      |            | RW     | CTS/PA11, RTS/PA12);                         | 0           |
|         |            |        | 01: Remap (CK/PA8, TX/PB6, RX/PB7,           | ,           |
|         |            |        | CTS/PA11, RTS/PA12);                         |             |
|         |            |        | 10: Remap (CK/PA10, TX/PB15, RX/PA8,         |             |
|         |            |        | CTS/PA5, RTS/PA9);                           |             |

|         |                |    | 11: Remap (CK/PA5, TX/PA6, RX/PA7, CTS/PC4, RTS/PC5).  Note: CH32F20x_D6, CH32F20x_D8, CH32F20x_D8W, CH32V20x_D6, CH32V20x_D8, CH32V20x_D8, CH32V20x_D8W exist only in the default mapping (00b), remapping (01b).                                                                                                              |     |
|---------|----------------|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| [25:24] | USART8_RM[1:0] | RW | USART8 remap 00: Default map (TX/PC4, RX/PC5); 01: Remap (TX/PA14, RX/PA15); 1x: Remap (TX/PE14, RX/PE15). Note: (1) This bit (01b) remapping does not support products below 64 pins. (2) (1xb) remapping is only available for LQFP100 package chips of CH32V303VCT6, CH32V307VCT6, CH32F203VCT6, CH32F203VCT6, CH32F207VCT6. | 00Ь |
| [23:22] | USART7_RM[1:0] | RW | USART7 remap 00: Default map (TX/PC2, RX/PC3); 01: Remap (TX/PA6, RX/PA7); 1x: Remap (TX/PE12, RX/PE13).  Note: (1) This bit (01b) remapping does not support products below 64 pins. (2) (1xb) remapping is only available for LQFP100 package chips of CH32V303VCT6, CH32V307VCT6, CH32F203VCT6, CH32F207VCT6.                | 00b |
| [21:20] | USART6_RM[1:0] | RW | USART6 remap 00: Default map (TX/PC0, RX/PC1); 01: Remap (TX/PB8, RX/PB9); 1x: Remap (TX/PE10, RX/PE11). Note: (1) (1xb) remapping is only available for LQFP100 package chips of CH32V303VCT6, CH32V307VCT6, CH32V307VCT6, CH32F203VCT6, CH32F207VCT6. (2) This bit remapping does not support products below 64 pins.         | 00Ь |
| [19:18] | USART5_RM[1:0] | RW | USART5 remap 00: Default map (TX/PC12, RX/PD2); 01: Remap (TX/PB4, RX/PB5); 1x: Remap (TX/PE8, RX/PE9). Note: (1) This bit remapping does not support products below 64 pins. (2) (1xb) remapping is only available for LQFP100 package chips of CH32V303VCT6, CH32V307VCT6, CH32F203VCT6, CH32F203VCT6, CH32F207VCT6.          | 00b |

V2. 4 147 WCH°

| [17:16] | USART4_RM[1:0] | RW | UART4 remap  00: Default map (TX/PC10, RX/PC11);  01: Remap (TX/PB0, RX/PB1);  1x: Remap (TX/PE0, RX/PE1).  Note: Applied for CH32V30x_D8C,  CH32V31x_D8C, CH32V30x_D8,  CH32V30x_D8W, CH32V20x_D8,  CH32F20x_D8C, CH32F20x_D8 and  CH32F20x_D8W.  x0: Default map (CK/PB2, TX/PB0, RX/PB1,  CTS/PB3, RTS/PB4).  x1: Remap (CK/PA6, TX/PA5, RX/PB5,  CTS/PA7, RTS/PA15).  Note: This function only supports CH32V203C8,  CH32F203C8 and products with 64 pins and above. | 00b |
|---------|----------------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| [15:11] | Reserved       | RW | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0   |
| 10      | FSMC_NADV      | RW | FSMC_NADV remap  0: FSMC_NADV is mapped to PB7;  1: FSMC_NADV output disabled.  Note: This function is not supported if the fifth inverse digit of the lot number is less than 2 and the sixth inverse digit of the lot number is equal to 0.                                                                                                                                                                                                                            | 0   |
| [9:7]   | Reserved       | RO | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0   |
| [6:5]   | TIM10_RM[1:0]  | RW | TIM10 remap bits  00: Default map (ETR/PC10, CH1/PB8, CH2/PB9, CH3/PC3, CH4/PC11, BKIN/PC12, CH1N/PA12, CH2N/PA13, CH3N/PA14);  01: Partial map (ETR/PB11, CH1/PB3, CH2/PB4, CH3/PB5, CH4/PC15, BKIN/PB10, CH1N/PA5, CH2N/PA6, CH3N/PA7);  1x: Full map (ETR/PD0, CH1/PD1, CH2/PD3, CH3/PD5, CH4/PD7, BKIN/PE2, CH1N/PE3, CH2N/PE4, CH3N/PE5).  Note: This bit is fully mapped for CH32V303VCT6, CH32V307VCT6, CH32V317VCT6 and CH32F207VCT6, CH32F203VCT6 chips         | 00Ь |
| [4:3]   | TIM9_RM[1:0]   | RW | CH32F203VCT6 chips.  TIM9 remap bits 00: Default map (ETR/PA2, CH1/PA2, CH2/PA3, CH3/PA4, CH4/PC4, BKIN/PC5, CH1N/PC0, CH2N/PC1, CH3N/PC2); 01: Partial map (ETR/PA2, CH1/PA2, CH2/PA3, CH3/PA4, CH4/PC14, BKIN/PA1, CH1N/PB0, CH2N/PB1, CH3N/PB2);                                                                                                                                                                                                                      | 00b |

V2. 4 148 WH°

|                |    | 1x: Full map (ETR/PD9, CH1/PD9, CH2/PD11, CH3/PD13, CH4/PD15, BKIN/PD14, CH1N/PD8, CH2N/PD10, CH3N/PD12).  Note: This bit is fully mapped for CH32V303VCT6, CH32V307VCT6, CH32V317VCT6 and CH32F207VCT6, CH32F203VCT6 chips.                                                                                         |   |
|----------------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| 2 TIM8_RM      | RW | TIM8 remap bit  0: Default map (ETR/PA0, CH1/PC6, CH2/PC7, CH3/PC8, CH4/PC9, BKIN/PA6, CH1N/PA7, CH2N/PB0, CH3N/PB1);  1: Remap (ETR/PA0, CH1/PB6, CH2/PB7, CH3/PB8, CH4/PC13, BKIN/PB9, CH1N/PA13, CH2N/PA14, CH3N/PA15);  Note: This bit applies to CH32F20x_D8, CH32F20x_D8C, CH32V30x and CH32V31x series chips. | 0 |
| [1:0] Reserved | RW | Reserved                                                                                                                                                                                                                                                                                                             | 0 |

V2. 4 149 WH°

## **Chapter 11 Direct Memory Access Control (DMA)**

#### This chapter applies to the whole family of CH32F20x, CH32V20x, CH32V30x and CH32V31x.

Direct memory access controller (DMA) provides a high-speed data transmission method between peripheral and memory or between memories. Without CPU intervention, data can be moved quickly through DMA to save CPU resources for other operations.

Each channel of DMA controllers is dedicated to managing memory access requests from one or more peripherals. There is also an arbiter to coordinate the priority between the channels.

## 11.1 Main Features

- Multiple independent configurable channels
- Each channel is directly connected to dedicated hardware DMA request, and supports software trigger
- Support cyclic buffer management
- The priority of requests between multiple channels can be set by software programming (Very high, high, medium and low level). When the priority settings are equal, it is determined by the channel number (The lower the channel number, the higher the priority)
- Support transmission from peripheral to memory, memory to peripheral, and memory to memory
- Flash memory, SRAM, peripheral SRAM, PB1, PB2 and HB peripherals can all be used as the sources and targets of access
- Number of programmable data transfer byte: 65535 at most

## 11.2 Functional Description

#### 11.2.1 DMA Channel Processing

## 1) Arbitration priority

DMA requests generated by multiple independent channels are inputted to the DMA controller through logic or structure, and currently only a channel request is responded. The internal arbiter of the module selects the peripheral/memory access to be started according to the priority of the channel request.

In software management, the application program can independently configure the priority level for each channel by setting the PL[1:0] bits in the DMA\_CFGRx register, including 4 levels: very high, high, medium, and low level. When the software setting levels between the channels are the same, the priority will be selected for the module according to the fixed hardware. The lower number of channel shall have the higher priority than the higher number.

## 2) DMA configuration

When the DMA controller receives a request signal, it will access the requested peripheral or memory to establish data transmission between the peripheral or memory and the memory. Mainly including the 3 following operation steps:

- (1) Fetch data from the peripheral data register or the memory address indicated by the current peripheral/memory address register. The start address of the first transmission is the peripheral base address or memory address specified by the DMA\_PADDRx or DMA\_MADDRx register.
- (2) Save data to the peripheral data register or the memory address indicated by the current peripheral/memory address register. The initial address during the first transmission is the peripheral base address or memory address specified by the DMA PADDRx or DMA MADDRx register.

(3) Perform a decrement operation of the value in the DMA\_CNTRx register, which indicates the number of unfinished transfer operations.

Each channel has 3 DMA data transfer modes:

- Peripheral to memory (MEM2MEM=0, DIR=0)
- Memory to peripheral (MEM2MEM=0, DIR=1)
- Memory to memory (MEM2MEM=1)

Note: The memory-to-memory mode does not require peripheral request signals. After configuring this mode (MEM2MEM=1), the channel will be switched on (EN=1) to start data transmission. This mode does not support cycle mode.

The configuration process is as follows:

- (1) Set the initial address of the peripheral register or the memory data address in the memory-to-memory mode (MEM2MEM=1) in the DMA\_PADDRx register. When a DMA request occurs, this address will be the source or destination address of the data transmission.
- (2) Set the memory data address in the DMA\_MADDRx register. When a DMA request occurs, the transmitted data will be read from or written to this address.
- (3) Set the number of data to be transmitted in the DMA\_CNTRx register. After each data transmission, this value will decrease progressively.
- (4) Set the channel priority through the PL[1:0] bits in the DMA CFGRx register.
- (5) In the DMA\_CFGRx register, set the direction of data transmission, cycle mode, incremental mode of peripheral and memory, data width of peripheral and memory, DMA Half Transfer, DMA Transfer complete, and tDMA Transfer Error interrupt enable bit,
- (6) Set the EN bit in the DMA CFGRx register to enable channel x.

Note: The control bits in DMA\_PADDRx/DMA\_MADDRx/DMA\_CNTRx register and DMA\_CFGRx register such as data transmission direction (DIR), cycle mode (location), peripheral and memory incremental mode (MINC/PINC) can only be configured and written in when the DMA channel is switched off.

#### 3) Cycle mode

Set the CIRC bit in the DMA\_CFGRx register to 1, to enable the cyclic mode function of the channel data transmission. In the cycle mode, when the number of data transmission becomes 0, the content of the DMA\_CNTRx register is automatically reloaded to its initial value, and the internal peripheral and memory address register is also reloaded to the initial address value set by the DMA\_PADDRx and DMA\_MADDRx registers, DMA operation continues until the channel or DMA mode is switched off.

#### 4) DMA processing status

- DMA Half Transfer: Set the HTIFx bit in the corresponding DMA\_INTFR register by the hardware. When the number of DMA transfer bytes is reduced to less than half of the initial set value, the DMA transfer half completion flag is generated. If HTIE is set in the DMA\_CFGRx register, an interrupt is generated. The hardware reminds the application program through this flag, and can prepare for a new round of data transmission.
- DMA Transfer complete: Set the TCIFx bit in the corresponding DMA\_INTFR register by the hardware.
   When the number of DMA transfer bytes is reduced to 0, a DMA transmission completion flag is generated. If TCIE is set in the DMA CFGRx register, an interrupt is generated.
- DMA Transfer Error: Set the TEIFx bit in the corresponding DMA\_INTFR register by the hardware.
   Reading and writing a reserved address area results in a DMA transmission error. Meanwhile, the module

V2. 4 151 WH

hardware automatically clears the EN bit in the DMA\_CFGRx register corresponding to the channel where the error is generated, and the channel is switched off. If TEIE is set in the DMA\_CFGRx register, an interrupt is generated.

When the application program queries the status of the DMA channel, it firstly accesses the GIFx bit in the DMA\_INTFR register to determine which channel currently has a DMA event, and then process the specific DMA event content of the channel.

#### 11.2.2 Programmable Data Transmission Total Size/Data Bit Width/Alignment

The total size of data transmitted in every round of each channel of DMA is programmable, up to 65535 times. The DMA\_CNTRx register indicates the number of transfer bytes. When EN=0, write the setting value. After the DMA transmission channel is switched on during EN=1, this register becomes read-only, and the value decreases progressively after each transmission.

The transmission data value of peripherals and memory supports the automatic increment function of the address pointer, and the pointer increment is programmable. The first transmitted data address accessed by them is stored in the DMA\_PADDRx and DMA\_MADDRx registers. By setting the PINC bit or MINC bit in the DMA\_CFGRx register to 1, the peripheral address auto-increment mode or memory address auto-increment mode can be enabled respectively. PSIZE[1: 0] bits are used to set the peripheral address fetch data size and address self-increase size, including 3 options: 8-bit, 16-bit, 32-bit. The specific data transfer method is as shown in the table below:

Table 11-1 DMA transfer under different data bit width (PINC=MINC=1)

| Source<br>bit<br>width | Target<br>bit<br>width | Transferred data Number | Source:<br>address/data                          | Target: address/data                                             | Transfer operation                                                                                                                                                         |
|------------------------|------------------------|-------------------------|--------------------------------------------------|------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8                      | 8                      | 4                       | 0x00/B0<br>0x01/B1<br>0x02/B2<br>0x03/B3         | 0x00/B0<br>0x01/B1<br>0x02/B2<br>0x03/B3                         | • The increment of the source address is aligned with the data bit width set at the source end, and the value is                                                           |
| 8                      | 16                     | 4                       | 0x00/B0<br>0x01/B1<br>0x02/B2<br>0x03/B3         | 0x00/00B0<br>0x02/00B1<br>0x04/00B2<br>0x06/00B3                 | <ul> <li>equal to the source data bit width</li> <li>The increment of the target address is aligned with the bit width of the target set data, and the value is</li> </ul> |
| 8                      | 32                     | 4                       | 0x00/B0<br>0x01/B1<br>0x02/B2<br>0x03/B3         | 0x00/000000B0<br>0x04/000000B1<br>0x08/000000B2<br>0x0C/000000B3 | <ul><li>equal to the bit width of the target data</li><li>Principle for transferring the data to the target end by DMA: In case of</li></ul>                               |
| 16                     | 8                      | 4                       | 0x00/B1B0<br>0x02/B3B2<br>0x04/B5B4<br>0x06/B7B6 | 0x00/B0<br>0x01/B2<br>0x02/B4<br>0x03/B6                         | insufficient data size, supplement 0 at high bit. In case of data size overflow, the high bit is removed.  • Data storage: Little-endian mode;                             |
| 16                     | 16                     | 4                       | 0x00/B1B0<br>0x02/B3B2<br>0x04/B5B4<br>0x06/B7B6 | 0x00/B1B0<br>0x02/B3B2<br>0x04/B5B4<br>0x06/B7B6                 | low bytes are stored at the low<br>address and high bytes are stored at<br>high address                                                                                    |

|     |    |   | 0x00/B1B0     | 0x00/0000B1B0 |
|-----|----|---|---------------|---------------|
| 1.6 | 22 | , | 0x02/B3B2     | 0x04/0000B3B2 |
| 16  | 32 | 4 | 0x04/B5B4     | 0x08/0000B5B4 |
|     |    |   | 0x06/B7B6     | 0x0C/0000B7B6 |
|     |    |   | 0x00/B3B2B1B0 | 0x00/B0       |
| 22  | 8  | 4 | 0x04/B7B6B5B4 | 0x01/B4       |
| 32  | 8  |   | 0x08/BBBAB9B8 | 0x02/B8       |
|     |    |   | 0x0C/BFBEBDBC | 0x03/BC       |
|     | 16 | 4 | 0x00/B3B2B1B0 | 0x00/B1B0     |
| 32  |    |   | 0x04/B7B6B5B4 | 0x02/B5B4     |
| 32  | 10 |   | 0x08/BBBAB9B8 | 0x04/B9B8     |
|     |    |   | 0x0C/BFBEBDBC | 0x06/BDBC     |
|     |    |   | 0x00/B3B2B1B0 | 0x00/B3B2B1B0 |
| 32  | 32 | 4 | 0x04/B7B6B5B4 | 0x04/B7B6B5B4 |
| 32  | 32 | 4 | 0x08/BBBAB9B8 | 0x08/BBBAB9B8 |
|     |    |   | 0x0C/BFBEBDBC | 0x0C/BFBEBDBC |

## 11.2.3 DMA Request Mapping

QingKe V4F MCUs (CH32V30x\_D8C, CH32V31x\_D8C and CH32V30x\_D8) and ARM®CortexTM-M3 MCUs (CH32F20x\_D8C and CH32F20x\_D8). The DMA controllers provide 18 channels, as DMA1 provides 7 channels and DMA2 provides 11 channels. Each channel corresponds to multiple peripheral requests. By setting the corresponding DMA control bit in the corresponding peripheral register, the DMA function of each peripheral can be switched on or off independently.

Note: (1) DMA1 in the use of attention, for lot numbers where the penultimate digit is less than 3 and the penultimate digit is equal to 0, DMA1 all channels of the DMA access address must not exceed 64K boundaries. For example - CH32V307VCT6 configuration RAM for 128K, at this time the configuration of the DAM1 need to pay attention to the DMA source address + the number of transmission data, or DMA destination address + the transmission of data can only be in the 0-64K, or 64K - 128K area, not 63K-65K similar cases. 128K region, not 63K-65K similar cases. For lot numbers where the penultimate digit is less than 3 and the penultimate digit is equal to 0, DAM1 channel 2, 3, 4, 5, DMA access address must not exceed 128K boundary, DMA1 channel 1, 6, 7 DMA access address still must not exceed 64K boundary, there is no restriction on the use of DMA2.

- (2) There is no restriction on the use of DMA1 for CH32F20x\_D8, CH32F20x\_D8C, CH32V30x\_D8, CH32V30x\_D8C, and CH32V31x\_D8C products whose lot numbers do not have a zero in the penultimate sixth digit.
- (3) There is no restriction on the use of DMA2.

EN bit of channel 1 ADC1 Hardware request1 TIM2\_CH3 Channel 1 TIM4\_CH1 Software Trigger Arbiter MEM2MEM bit SPI1\_RX EN bit of channel 2 USART3\_TX Hardware request2 TIM1\_CH1 Channel 2 TIM2\_UP Software Priority TIM3\_CH3 Software Trigger MEM2MEM bit PL setting value of SPI1\_TX EN bit of channel 3 channel Hardware request3 USART3\_RX TIM1\_CH2 Channel 3 TIM3\_CH4/TIM3\_UP Software Trigger MEM2MEM bit DMA SPI/I2S2\_RX EN bit of channel 4 RequestUSART1\_TX Hardware request4 to internal I2C2\_TX Channel 4 TIM1\_TRIG/TIM1\_COM/TIM1\_CH4 Software Trigger TIM4\_CH2 MEM2MEM bit SPI/I2S2\_TX EN bit of channel 5  ${\tt USART1\_RX}$ Hardware request5 I2C2\_RX TIM1\_UP Channel 5 TIM2\_CH1 TIM4\_CH3 Fixed hardware Software Trigger priority MEM2MEM bit Channel USART2\_RX EN bit of chann el 6 No. Hardware request6 I2C1\_TX TIM1\_CH3 Channel 6 TIM3\_CH1/TIM3\_TRIG Software Trigger MEM2MEM bit  ${\sf USART2\_TX}$ Hardware request7 I2C1\_RX TIM2\_CH2/TIM2\_CH4 Channel 7 TIM4\_UP Software Trigger MEM2MEM bit

Figure 11-1 DMA1 request mapping

Table 11-2 DMA2 request mapping



Table 11-2 Peripheral mapping table of each DMA1 channel

| Peripheral Channel 1  | Channel 2 | Channel 3 | Channel 4  | Channel 5  | Channel 6  | Channel 7 |
|-----------------------|-----------|-----------|------------|------------|------------|-----------|
| r empherar chainner i | enamer 2  | emanmer s | CHAINIEI I | CHAIMICI S | CHAINICI O | CHAIMET / |

| ADC1     | ADC1     |           |           |             |             |           |           |
|----------|----------|-----------|-----------|-------------|-------------|-----------|-----------|
| SPI1     |          | SPI1_RX   | SPI1_TX   |             |             |           |           |
| SPI/I2S2 |          |           |           | SPI/I2S2_RX | SPI/I2S2_TX |           |           |
| USART1   |          |           |           | USART1_TX   | USART1_RX   |           |           |
| USART2   |          |           |           |             |             | USART2_RX | USART2_TX |
| USART3   |          | USART3_TX | USART3_RX |             |             |           |           |
| I2C1     |          |           |           |             |             | I2C1_TX   | I2C1_RX   |
| I2C2     |          |           |           | I2C2_TX     | I2C2_RX     |           |           |
|          |          |           |           | TIM1_CH4    |             |           |           |
| TIM1     |          | TIM1_CH1  | TIM1_CH2  | TIM1_TRIG   | TIM1_UP     | TIM1_CH3  |           |
|          |          |           |           | TIM1_COM    |             |           |           |
| TIM2     | TIM2 CH3 | TIM2 UP   |           |             | TIM2 CH1    |           | TIM2_CH2  |
| 111V12   | TIMZ_CH3 | TIMZ_OF   |           |             | TIMZ_CHT    |           | TIM2_CH4  |
| TIM3     |          | TIM3 CH3  | TIM3_CH4  |             |             | TIM3_CH1  |           |
| 111013   |          | TIM5_CIIS | TIM3_UP   |             |             | TIM3_TRIG |           |
| TIM4     | TIM4_CH1 |           |           | TIM4_CH2    | TIM4_CH3    |           | TIM4_UP   |

Table 11-3 Peripheral mapping table of each DMA2 channel (I)

| Peripheral          | Channel 1             | Channel 2                   | Channel 3 | Channel 4 | Channel 5 | Channel 6 | Channel 7               |
|---------------------|-----------------------|-----------------------------|-----------|-----------|-----------|-----------|-------------------------|
| TIM5                | TIM5_CH4<br>TIM5_TRIG | TIM5_CH3<br>TIM5_UP         |           | TIM5_CH2  | TIM5_CH1  |           |                         |
| TIM6                | TIME_TREE             | TIME_OF                     | TIM6_UP   |           |           |           |                         |
| TIM7                |                       |                             |           | TIM7_UP   |           |           |                         |
| TIM8                | TIM8_CH3 TIM8_UP      | TIM8_CH4 TIM8_TRIG TIM8_COM | TIM8_CH1  |           | TIM8_CH2  |           |                         |
| TIM9                |                       |                             |           |           |           | TIM9_UP   | TIM9_CH1                |
| TIM10               |                       |                             |           |           |           | TIM10_CH4 | TIM10_TRIG<br>TIM10_COM |
| USART4              |                       |                             | USART4_RX |           | USART4_TX |           |                         |
| USART5              |                       | USART5_RX                   |           | USART5_TX |           |           |                         |
| USART6              |                       |                             |           |           |           | USART6_TX | USART6_RX               |
| USART7              |                       |                             |           |           |           |           |                         |
| USART8              |                       |                             |           |           |           |           |                         |
| SPI/I2S3            | SPI/I2S3_RX           | SPI/I2S3_TX                 |           |           |           |           |                         |
| SDIO                |                       |                             |           | SDIO      |           |           |                         |
| DAC1                |                       |                             | DAC1      |           |           |           |                         |
| DAC2                |                       |                             |           | DAC2      |           |           |                         |
| ADC2 <sup>(1)</sup> |                       |                             |           |           | ADC2      |           |                         |

Note: (1) The DMA channel peripheral mapping for ADC2 is only available for CH32F20x\_D8, CH32F20x\_D8C, CH32V30x\_D8, CH32V30x\_D8C, and CH32V31x\_D8C with the penultimate sixth digit of the lot number not being zero.

V2. 4 156

Table 11-4 Peripheral mapping table of each DMA2 channel (II)

| Peripheral | Channel 8 | Channel 9 | Channel 10 | Channel 11 |
|------------|-----------|-----------|------------|------------|
| TIM5       |           |           |            |            |
| TIM6       |           |           |            |            |
| TIM7       |           |           |            |            |
| TIM8       |           |           |            |            |
| TIMO       | TIMO CIIA | TIMO CHO  | TIM9_TRIG  | TIMO CH2   |
| TIM9       | TIM9_CH4  | TIM9_CH2  | TIM9_COM   | TIM9_CH3   |
| TIM10      | TIM10_CH1 | TIM10_CH3 | TIM10_CH2  | TIM10_UP   |
| USART4     |           |           |            |            |
| USART5     |           |           |            |            |
| USART6     |           |           |            |            |
| USART7     | USART7_TX | USART7_RX |            |            |
| USART8     |           |           | USART8_TX  | USART8_RX  |
| SPI/I2S3   |           |           |            |            |
| SDIO       |           |           |            |            |
| DAC1       |           |           |            |            |
| DAC2       |           |           |            |            |

QingKe V4B MCUs (CH32V20x\_D6) and ARM<sup>R</sup>Cortex<sup>TM</sup>-M3 MCUs (CH32F20x\_D6). The DMA controller provides 8 channels. Each channel corresponds to multiple peripheral requests. By setting the corresponding DMA control bit in the corresponding peripheral register, the DMA function of each peripheral can be switched on or off independently.

Table 11-5 DMA peripheral mapping table by channel

| Peripheral | Channel 1 | Channel 2 | Channel 3 | Channel 4 | Channel 5  | Channel 6 | Channel 7 | Channel 8 |
|------------|-----------|-----------|-----------|-----------|------------|-----------|-----------|-----------|
| ADC1       | ADC1      |           |           |           |            |           |           |           |
| SPI1       |           | SPI1_RX   | SPI1_TX   |           |            |           |           |           |
| SPI2       |           |           |           | SPI2_RX   | SPI2_TX    |           |           |           |
| USART1     |           |           |           | USART1_TX | USART1_RX  |           |           |           |
| USART2     |           |           |           |           |            | USART2_RX | USART2_TX |           |
| USART3     |           | USART3_TX | USART3_RX |           |            |           |           |           |
| USART4     | USART4_TX |           |           |           |            |           |           | USART4_RX |
| I2C1       |           |           |           |           |            | I2C1_TX   | I2C1_RX   |           |
| I2C2       |           |           |           | I2C2_TX   | I2C2_RX    |           |           |           |
|            |           |           |           | TIM1_CH4  |            |           |           |           |
| TIM1       |           | TIM1_CH1  | TIM1_CH2  | TIM1_TRIG | TIM1_UP    | TIM1_CH3  |           |           |
|            |           |           |           | TIM1_COM  |            |           |           |           |
| TIM2       | TIM2_CH3  | TIM2_UP   |           |           | TIM2_CH1   |           | TIM2_CH2  |           |
| 111112     | TIMZ_CII3 |           |           |           | THVIZ_CITI |           | TIM2_CH4  |           |
| TIM3       |           | TIM3_CH3  | TIM3_CH4  |           |            | TIM3_CH1  |           |           |
| 111013     |           | THM5_CH3  | TIM3_UP   |           |            | TIM3_TRIG |           |           |
| TIM4       | TIM4_CH1  |           |           | TIM4_CH2  | TIM4_CH3   |           | TIM4_UP   |           |



Table 11-3 DMA request mapping

QingKe V4C MCUs (CH32V20x\_D8W and CH32V20x\_D8) and ARM ® Cortex<sup>TM</sup>-M3 MCUs (CH32F20x\_D8W). The DMA controller provides 8 channels. Each channel corresponds to multiple peripheral requests. By setting the corresponding DMA control bit in the corresponding peripheral register, the DMA function of each peripheral can be switched on or off independently.

Table 11-6 DMA peripheral mapping table by channel

| Peripheral | Channel 1 | Channel 2 | Channel 3 | Channel 4 | Channel 5 | Channel 6 | Channel 7 | Channel 8 |
|------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|
| ADC1       | ADC1      |           |           |           |           |           |           |           |
| SPI1       |           | SPI1_RX   | SPI1_TX   |           |           |           |           |           |
| SPI2       |           |           |           | SPI2_RX   | SPI2_TX   |           |           |           |
| USART1     |           |           |           | USART1_TX | USART1_RX |           |           |           |
| USART2     |           |           |           |           |           | USART2_RX | USART2_TX |           |
| USART3     |           | USART3_TX | USART3_RX |           |           |           |           |           |
| USART4     | USART4_TX |           |           |           |           |           |           | USART4_RX |
| I2C1       |           |           |           |           |           | I2C1_TX   | I2C1_RX   |           |

| I2C2   |           |          |          | I2C2_TX   | I2C2_RX   |           |           |          |
|--------|-----------|----------|----------|-----------|-----------|-----------|-----------|----------|
|        |           |          |          | TIM1_CH4  |           |           |           |          |
| TIM1   |           | TIM1_CH1 | TIM1_CH2 | TIM1_TRIG | TIM1_UP   | TIM1_CH3  |           |          |
|        |           |          |          | TIM1_COM  |           |           |           |          |
| TIM2   | TIM2 CH3  | TIM2 UP  |          |           | TIM2 CH1  |           | TIM2_CH2  |          |
| 111012 | TIMZ_CH3  | TIMZ_OF  |          |           | THVIZ_CHT |           | TIM2_CH4  |          |
| TIM3   |           | TIM3 CH3 | TIM3_CH4 |           |           | TIM3_CH1  |           |          |
| 111015 |           | TIM5_CH3 | TIM3_UP  |           |           | TIM3_TRIG |           |          |
| TIM4   | TIM4_CH1  |          |          | TIM4_CH2  | TIM4_CH3  |           | TIM4_UP   |          |
| TIM5   | TIM5 CH2  |          | TIM5 CH3 |           |           | TIM5_CH4  | TIM5_CH1  | TIM5_UP  |
| 111015 | THVIJ_CH2 |          | TIM5_CH3 |           |           | TIM5_CH4  | TIM5_TRIG | TIMIS_OF |

Table 11-4 DMA request mapping



# 11.3 Register Description

Table 11-7 DMA1 registers

| Name            | Access address | Description                               | Reset value |
|-----------------|----------------|-------------------------------------------|-------------|
| R32_DMA1_INTFR  | 0x40020000     | DMA1 interrupt flag register              | 0x00000000  |
| R32_DMA1_INTFCR | 0x40020004     | DMA1 interrupt flag clear register        | 0x00000000  |
| R32_DMA1_CFGR1  | 0x40020008     | DMA1 channel1 configuration register      | 0x00000000  |
| R32_DMA1_CNTR1  | 0x4002000C     | DMA1 channel1 transferred data register   | 0x00000000  |
| R32_DMA1_PADDR1 | 0x40020010     | DMA1 channel1 peripheral address register | 0x00000000  |
| R32_DMA1_MADDR1 | 0x40020014     | DMA1 channel1 memory address register     | 0x00000000  |
| R32_DMA1_CFGR2  | 0x4002001C     | DMA1 channel2 configuration register      | 0x00000000  |
| R32_DMA1_CNTR2  | 0x40020020     | DMA1 channel2 transferred data register   | 0x00000000  |
| R32_DMA1_PADDR2 | 0x40020024     | DMA1 channel2 peripheral address register | 0x00000000  |
| R32_DMA1_MADDR2 | 0x40020028     | DMA1 channel2 memory address register     | 0x00000000  |
| R32_DMA1_CFGR3  | 0x40020030     | DMA1 channel3 configuration register      | 0x00000000  |
| R32_DMA1_CNTR3  | 0x40020034     | DMA1 channel3 transferred data register   | 0x00000000  |
| R32_DMA1_PADDR3 | 0x40020038     | DMA1 channel3 peripheral address register | 0x00000000  |
| R32_DMA1_MADDR3 | 0x4002003C     | DMA1 channel3 memory address register     | 0x00000000  |
| R32_DMA1_CFGR4  | 0x40020044     | DMA1 channel4 configuration register      | 0x00000000  |
| R32_DMA1_CNTR4  | 0x40020048     | DMA1 channel4 transferred data register   | 0x00000000  |
| R32_DMA1_PADDR4 | 0x4002004C     | DMA1 channel4 peripheral address register | 0x00000000  |
| R32_DMA1_MADDR4 | 0x40020050     | DMA1 channel4 memory address register     | 0x00000000  |
| R32_DMA1_CFGR5  | 0x40020058     | DMA1 channel5 configuration register      | 0x00000000  |
| R32_DMA1_CNTR5  | 0x4002005C     | DMA1 channel5 transferred data register   | 0x00000000  |
| R32_DMA1_PADDR5 | 0x40020060     | DMA1 channel5 peripheral address register | 0x00000000  |
| R32_DMA1_MADDR5 | 0x40020064     | DMA1 channel5 memory address register     | 0x00000000  |
| R32_DMA1_CFGR6  | 0x4002006C     | DMA1 channel6 configuration register      | 0x00000000  |
| R32_DMA1_CNTR6  | 0x40020070     | DMA1 channel6 transferred data register   | 0x00000000  |
| R32_DMA1_PADDR6 | 0x40020074     | DMA1 channel6 peripheral address register | 0x00000000  |
| R32_DMA1_MADDR6 | 0x40020078     | DMA1 channel6 memory address register     | 0x00000000  |
| R32_DMA1_CFGR7  | 0x40020080     | DMA1 channel7 configuration register      | 0x00000000  |
| R32_DMA1_CNTR7  | 0x40020084     | DMA1 channel7 transferred data register   | 0x00000000  |
| R32_DMA1_PADDR7 | 0x40020088     | DMA1 channel7 peripheral address register | 0x00000000  |
| R32_DMA1_MADDR7 | 0x4002008C     | DMA1 channel7 memory address register     | 0x00000000  |
| R32_DMA1_CFGR8  | 0x40020094     | DMA1 channel8 configuration register      | 0x00000000  |
| R32_DMA1_CNTR8  | 0x40020098     | DMA1 channel8 transferred data register   | 0x00000000  |
| R32_DMA1_PADDR8 | 0x4002009C     | DMA1 channel8 peripheral address register | 0x00000000  |
| R32_DMA1_MADDR8 | 0x400200A0     | DMA1 channel8 memory address register     | 0x00000000  |

Table 11-8 DMA2 registers

|                 |                | <u> </u>                             |             |
|-----------------|----------------|--------------------------------------|-------------|
| Name            | Access address | Description                          | Reset value |
| R32_DMA2_INTFR  | 0x40020400     | DMA2 interrupt flag register         | 0x00000000  |
| R32_DMA2_INTFCR | 0x40020404     | DMA2 interrupt flag clear register   | 0x00000000  |
| R32_DMA2_CFGR1  | 0x40020408     | DMA2 channel1 configuration register | 0x00000000  |

| R32 DMA2 CNTR1                     | 0x4002040C               | DMA2 channel1 transferred data register    | 0x00000000 |
|------------------------------------|--------------------------|--------------------------------------------|------------|
| R32 DMA2 PADDR1                    | 0x4002040C               | DMA2 channel1 peripheral address register  | 0x00000000 |
| R32 DMA2 MADDR1                    | 0x40020414               | DMA2 channel1 memory address register      | 0x00000000 |
| R32 DMA2 CFGR2                     | 0x4002041C               | DMA2 channel2 configuration register       | 0x00000000 |
| R32 DMA2 CNTR2                     | 0x40020420               | DMA2 channel2 transferred data register    | 0x00000000 |
| R32 DMA2 PADDR2                    | 0x40020424               | DMA2 channel2 peripheral address register  | 0x00000000 |
| R32 DMA2 MADDR2                    | 0x40020424               | DMA2 channel2 memory address register      | 0x00000000 |
| R32_DMA2_CFGR3                     | 0x40020428               | DMA2 channel3 configuration register       | 0x00000000 |
| R32 DMA2 CNTR3                     | 0x40020430               | DMA2 channel3 transferred data register    | 0x00000000 |
| R32_DMA2_CNTR3 R32_DMA2_PADDR3     | 0x40020434<br>0x40020438 | DMA2 channel3 peripheral address register  | 0x00000000 |
| R32_DMA2_MADDR3                    | 0x40020438<br>0x4002043C | DMA2 channel3 memory address register      | 0x00000000 |
| R32 DMA2 CFGR4                     | 0x4002043C               | DMA2 channel4 configuration register       | 0x00000000 |
| R32_DMA2_CTGR4 R32_DMA2_CNTR4      | 0x40020444<br>0x40020448 | DMA2 channel4 transferred data register    | 0x00000000 |
|                                    | 0x40020446<br>0x4002044C | DMA2 channel4 peripheral address register  | 0x00000000 |
| R32_DMA2_PADDR4<br>R32_DMA2_MADDR4 |                          | DMA2 channel4 memory address register      | 0x00000000 |
| R32_DMA2_MADDR4 R32_DMA2_CFGR5     | 0x40020450               | ,                                          | 0x00000000 |
|                                    | 0x40020458<br>0x4002045C | DMA2 channel5 transformed data register    |            |
| R32_DMA2_CNTR5                     |                          | DMA2 channel5 transferred data register    | 0x00000000 |
| R32_DMA2_PADDR5                    | 0x40020460               | DMA2 channel5 peripheral address register  | 0x00000000 |
| R32_DMA2_MADDR5                    | 0x40020464               | DMA2 channel5 memory address register      | 0x00000000 |
| R32_DMA2_CFGR6                     | 0x4002046C               | DMA2 channel6 configuration register       | 0x00000000 |
| R32_DMA2_CNTR6                     | 0x40020470               | DMA2 channel6 transferred data register    | 0x00000000 |
| R32_DMA2_PADDR6                    | 0x40020474               | DMA2 channel6 peripheral address register  | 0x00000000 |
| R32_DMA2_MADDR6                    | 0x40020478               | DMA2 channel6 memory address register      | 0x00000000 |
| R32_DMA2_CFGR7                     | 0x40020480               | DMA2 channel7 configuration register       | 0x00000000 |
| R32_DMA2_CNTR7                     | 0x40020484               | DMA2 channel7 transferred data register    | 0x00000000 |
| R32_DMA2_PADDR7                    | 0x40020488               | DMA2 channel7 peripheral address register  | 0x00000000 |
| R32_DMA2_MADDR7                    | 0x4002048C               | DMA2 channel7 memory address register      | 0x00000000 |
| R32_DMA2_CFGR8                     | 0x40020490               | DMA2 channel8 configuration register       | 0x00000000 |
| R32_DMA2_CNTR8                     | 0x40020494               | DMA2 channel8 transferred data register    | 0x00000000 |
| R32_DMA2_PADDR8                    | 0x40020498               | DMA2 channel8 peripheral address register  | 0x00000000 |
| R32_DMA2_MADDR8                    | 0x4002049C               | DMA2 channel8 memory address register      | 0x00000000 |
| R32_DMA2_CFGR9                     | 0x400204A0               | DMA2 channel9 configuration register       | 0x00000000 |
| R32_DMA2_CNTR9                     | 0x400204A4               | DMA2 channel9 transferred data register    | 0x00000000 |
| R32_DMA2_PADDR9                    | 0x400204A8               | DMA2 channel9 peripheral address register  | 0x00000000 |
| R32_DMA2_MADDR9                    | 0x400204AC               | DMA2 channel9 memory address register      | 0x00000000 |
| R32_DMA2_CFGR10                    | 0x400204B0               | DMA2 channel10 configuration register      | 0x00000000 |
| R32_DMA2_CNTR10                    | 0x400204B4               | DMA2 channel10 transferred data register   | 0x00000000 |
| R32_DMA2_PADDR10                   | 0x400204B8               | DMA2 channel10 peripheral address register | 0x00000000 |
| R32_DMA2_MADDR10                   | 0x400204BC               | DMA2 channel10 memory address register     | 0x00000000 |
| R32_DMA2_CFGR11                    | 0x400204C0               | DMA2 channel11 configuration register      | 0x00000000 |
| R32_DMA2_CNTR11                    | 0x400204C4               | DMA2 channel11 transferred data register   | 0x00000000 |
| R32_DMA2_PADDR11                   | 0x400204C8               | DMA2 channel11 peripheral address register | 0x00000000 |
| R32_DMA2_MADDR11                   | 0x400204CC               | DMA2 channel11 memory address register     | 0x00000000 |
| R32_DMA2_EXTEM_INTFR               | 0x400204D0               | DMA2 extend interrupt flag register        | 0x00000000 |
| R32_DMA2_EXTEM_INTFCR              | 0x400204D4               | DMA2 extend interrupt flag clear register  | 0x00000000 |

## 11.3.1 DMAx Interrupt Flag Register (DMAx\_INTFR) (x=1/2)

Offset address: 0x00 + (x-1)\*0x400

| 31    | 30    | 29    | 28   | 27    | 26    | 25    | 24   | 23    | 22    | 21    | 20   | 19    | 18    | 17    | 16   |
|-------|-------|-------|------|-------|-------|-------|------|-------|-------|-------|------|-------|-------|-------|------|
| TEIF8 | HTIF8 | TCIF8 | GIF8 | TEIF7 | HTIF7 | TCIF7 | GIF7 | TEIF6 | HTIF6 | TCIF6 | GIF6 | TEIF5 | HTIF5 | TCIF5 | GIF5 |
| 15    | 14    | 13    | 12   | 11    | 10    | 9     | 8    | 7     | 6     | 5     | 4    | 3     | 2     | 1     | 0    |
| TEIF4 | HTIF4 | TCIF4 | GIF4 | TEIF3 | HTIF3 | TCIF3 | GIF3 | TEIF2 | HTIF2 | TCIF2 | GIF2 | TEIF1 | HTIF1 | TCIF1 | GIF1 |

| Bit        | Name  | Access | Description                                                 | Reset value |
|------------|-------|--------|-------------------------------------------------------------|-------------|
|            |       |        | DMA Transfer Error flag of channel x (x=1/2/3/4/5/6/7/8):   |             |
| 31/27/23/1 |       |        | 0: No transmission error occurred on channel x;             |             |
| 9/15/11/7/ | TEIFx | RO     | 1: A transmission error occurred on channel x.              | 0           |
| 3          |       |        | Set by hardware, and write CTEIFx bit by software to clear  |             |
|            |       |        | this flag.                                                  |             |
|            |       |        | DMA Half Transfer flag of channel x (x=1/2/3/4/5/6/7/8):    |             |
|            |       |        | 0: No transmission half completion event has occurred on    |             |
| 30/26/22/1 |       |        | channel x;                                                  |             |
| 8/14/10/6/ | HTIFx | RO     | 1: A transmission half completion event has occurred on     | 0           |
| 2          |       |        | channel x.                                                  |             |
|            |       |        | Set by hardware, and write CHTIFx bit by software to clear  |             |
|            |       |        | this flag.                                                  |             |
|            |       |        | DMA Transfer complete flag of channel x                     |             |
|            |       |        | (x=1/2/3/4/5/6/7/8):                                        |             |
|            |       |        | 0: No transmission completion event has occurred on         |             |
| 29/25/21/1 | TCIFx | RO     | channel x;                                                  | 0           |
| 7/13/9/5/1 | TCIIX | RO     | 1: A transmission completion event has occurred on          | U           |
|            |       |        | channel x.                                                  |             |
|            |       |        | Set by hardware, and write CTCIFx bit by software to clear  |             |
|            |       |        | this flag.                                                  |             |
|            |       |        | Global interrupt flag of channel x ( $x=1/2/3/4/5/6/7/8$ ): |             |
|            |       |        | 0: No TEIFx or HTIFx or TCIFx is generated on channel       |             |
| 28/24/20/1 | GIFx  | RO     | x;                                                          | 0           |
| 6/12/8/4/0 | GII'X | KO     | 1: TEIFx or HTIFx or TCIFx is generated on channel x.       | U           |
|            |       |        | It is set by hardware, and write CGIFx bit by software to   |             |
|            |       |        | clear this flag.                                            |             |

Note: Channel8 is applied for CH32V20x\_D8, CH32V20x\_D8W, CH32F20x\_D8W, CH32F20x\_D6 and CH32V20x\_D6.

## 11.3.2 DMAx Interrupt Flag Clear Register (DMAx\_INTFCR) (x=1/2)

Offset address: 0x04 + (x-1)\*0x400

| 31     | 30     | 29     | 28    | 27     | 26     | 25     | 24    | 23     | 22        | 21            | 20    | 19     | 18     | 17     | 16    |
|--------|--------|--------|-------|--------|--------|--------|-------|--------|-----------|---------------|-------|--------|--------|--------|-------|
| CTEIF8 | CHTIF8 | CTCIF8 | CGIF8 | CTEIF7 | CHTIF7 | CTCIF7 | CGIF7 | CTEIF6 | CHTIF6    | CTCIF6        | CGIF6 | CTEIF5 | CHTIF5 | CTCIF5 | CGIF5 |
| 15     | 14     | 13     | 12    | 11     | 10     | 9      | 8     | 7      | 6         | 5             | 4     | 3      | 2      | 1      | 0     |
|        |        |        |       |        |        |        |       |        | ~******** | ~ ~ ~ ~ ~ ~ ~ | ~~~~  | ~===== |        | CTCIF1 | ~~~   |

| Bit         | Name   | Access | Description                                        | Reset value |
|-------------|--------|--------|----------------------------------------------------|-------------|
|             |        |        | Clear DMA Transfer Error flag of channel x         |             |
| 31/27/23/19 | CTEIFx | WO     | (x=1/2/3/4/5/6/7/8):                               | 0           |
| /15/11/7/3  | CIEIIX | WO     | 0: No effect;                                      | U           |
|             |        |        | 1: Clear the TEIFx flag in the DMA_INTFR register. |             |
|             |        |        | Clear DMA Half Transfer of channel x               |             |
| 30/26/22/18 | CUTIE  | WO     | (x=1/2/3/4/5/6/7/8):                               | 0           |
| /14/10/6/2  | CHTIFx | WO     | 0: No effect;                                      | 0           |
|             |        |        | 1: Clear the HTIFx flag in the DMA_INTFR register. |             |
|             |        |        | Clear DMA Transfer complete flag of channel x      |             |
| 29/25/21/17 | CTCIFx | WO     | (x=1/2/3/4/5/6/7/8):                               | 0           |
| /13/9/5/1   | CICIFX | WO     | 0: No effect;                                      | U           |
|             |        |        | 1: Clear the TCIFx flag in the DMA_INTFR register. |             |
|             |        |        | Clear the global interrupt flag of channel x       |             |
| 29/24/20/16 |        |        | (x=1/2/3/4/5/6/7/8):                               |             |
| 28/24/20/16 | CGIFx  | WO     | 0: No effect;                                      | 0           |
| /12/8/4/0   |        |        | 1: Clear the TEIFx/HTIFx/TCIFx/ GIFx flag in the   |             |
|             |        |        | DMA_INTFR register.                                |             |

Note: Channel8 is applied for CH32V20x\_D8, CH32V20x\_D8W, CH32F20x\_D8W, CH32F20x\_D6 and CH32V20x\_D6.

# 11.3.3 DMAy Channelx Configuration Register (DMAy\_CFGRx) (x=1/2/3/4/5/6/7/8, y=1/2) Offset address: 0x08 + (x-1)\*20 + (y-1)\*0x400

Reserved Reser MEM2 MSIZE[1:0] PSIZE[1:0] MINC PINC CIRC TEIE HTIE TCIE PL[1:0] DIR EN MEM ved

| Bit     | Name       | Access | Description                       | Reset value |
|---------|------------|--------|-----------------------------------|-------------|
| [31:15] | Reserved   | RO     | Reserved.                         | 0           |
|         |            |        | Memory to memory mode enable:     |             |
| 14      | MEM2MEM    | RW     | 0: Disable memory to memory mode; | 0           |
|         |            |        | 1: Enable memory to memory mode.  |             |
|         |            |        | Channel priority level setting:   |             |
| [13:12] | PL[1:0]    | RW     | 00: Low; 01: Medium;              | 0           |
|         |            |        | 10: High; 11: Very high.          |             |
|         |            |        | Memory size setting:              |             |
| [11:10] | MSIZE[1:0] | RW     | 00: 8 bits; 01: 16 bits;          | 0           |
|         |            |        | 10: 32 bits; 11: Reserved.        |             |
|         |            |        | Peripheral size setting:          |             |
| [9:8]   | PSIZE[1:0] | RW     | 00: 8 bits; 01: 16 bits;          | 0           |
|         |            |        | 10: 32 bits; 11: Reserved.        |             |

|   |      |       | Memory increment mode enable:                            |   |
|---|------|-------|----------------------------------------------------------|---|
| 7 | MINC | RW    | 0: Disable memory increment mode;                        | 0 |
|   |      |       | 1: Enable memory increment mode.                         |   |
|   |      |       | Peripheral increment mode enable:                        |   |
| 6 | PINC | RW    | 0: Disable peripheral increment mode;                    | 0 |
|   |      |       | 1: Enable peripheral increment mode.                     |   |
|   |      |       | DMA channel circular mode enable:                        |   |
| 5 | CIRC | RW    | 0: Disable circular mode;                                | 0 |
|   |      |       | 1: Enable circular mode.                                 |   |
|   |      |       | Data transfer direction:                                 |   |
| 4 | DIR  | RW    | 0: Read from peripheral;                                 | 0 |
|   |      |       | 1: Read from memory.                                     |   |
|   |      |       | Transfer error interrupt enable control:                 |   |
| 3 | TEIE | RW    | 0: Disable transfer error interrupt;                     | 0 |
|   |      |       | 1: Enable transfer error interrupt.                      |   |
|   |      |       | Half transfer interrupt enable control:                  |   |
| 2 | HTIE | RW    | 0: Disable transmission half interrupt;                  | 0 |
|   |      |       | 1: Enable transmission half interrupt.                   |   |
|   |      |       | Transfer complete interrupt enable control:              |   |
| 1 | TCIE | RW    | 0: Disable transmission completion interrupt;            | 0 |
|   |      |       | 1: Enable transmission completion interrupt.             |   |
|   |      |       | Channel enable control:                                  |   |
| 0 | EN   | RW    | 0: Channel disabled; 1: Channel enabled.                 | 0 |
| U | LEIN | IX VV | When a DMA transmission error occurs, it will be cleared | U |
|   |      |       | to 0 automatically by hardware, and channel is disabled. |   |

Note: Channel8 is applied for CH32V20x\_D8, CH32V20x\_D8W, CH32F20x\_D8W, CH32F20x\_D6 and CH32V20x D6.

## 11.3.4 DMAy Channelx Transferred Data Register (DMAy\_CNTRx) (x=1/2/3/4/5/6/7/8, y=1/2)

Offset address: 0x0C + (x-1)\*20 + (y-1)\*0x400Reserved

NDT[15:0]

| Bit     | Name      | Access | Description                                                                                                                                                                                                                                                                                                   | Reset value |
|---------|-----------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:16] | Reserved  | RO     | Reserved.                                                                                                                                                                                                                                                                                                     | 0           |
| [15:0]  | NDT[15:0] | RW     | Number of data transfer, range: 0-65535. Indicating the number of pending transfers remaining (The contents of the register are decremented after each DMA transfer). When the channel is in the cyclic mode, the contents of the register will be automatically reloaded to the previously configured value. | 0           |

Note: Indicating the current number of pending transfers. This register can only be changed when EN=0 and is not writable when EN=1. When the register content is 0, no data transmission occurs regardless of whether the channel is switched on or not. Channel8 is applied for  $CH32V20x\_D8$ ,  $CH32V20x\_D8W$ ,  $CH32F20x\_D6$  and  $CH32V20x\_D6$ .

# 11.3.5 DMAy Channelx Peripheral Address Register (DMAy\_PADDRx) (x=1/2/3/4/5/6/7/8, y=1/2)

Offset address: 0x10 + (x-1)\*20 + (y-1)\*0x400

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0

PA[31:0]

| Bit    | Name     | Access | Description                                                                                                                                                                                                                                                                                                                                                              | Reset value |
|--------|----------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:0] | PA[31:0] | RW     | Peripheral base address, as the source or destination address of peripheral data transmission. When PSIZE[1:0]='01' (16 bits), the module automatically ignores bit0, and the operation address is automatically 2 bytes aligned. When PSIZE[1:0]='10' (32 bits), the module automatically ignores bit[1:0], and the operation address is automatically 4 bytes aligned. | 0           |

Note: This register can only be changed when EN=0, and cannot be written when EN=1. Channel8 is applied for CH32V20x D8, CH32V20x D8W, CH32F20x D8W, CH32F20x D6 and CH32V20x D6.

# 11.3.6 DMAy Channelx Memory Address Register (DMAy\_MADDRx) (x=1/2/3/4/5/6/7/8, v=1/2)

Offset address: 0x14 + (x-1)\*20 + (y-1)\*0x400

 $31\ 30\ 29\ 28\ 27\ 26\ 25\ 24\ 23\ 22\ 21\ 20\ 19\ 18\ 17\ 16\ 15\ 14\ 13\ 12\ 11\ 10\ 9\ 8\ 7\ 6\ 5\ 4\ 3\ 2\ 1\ 0$ 

MA[31:0]

| Bit    | Name     | Access | Description                                                                                                                                                                                                                                                                                                                                                | Reset value |
|--------|----------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:0] | MA[31:0] | RW     | Memory data address, as the source or target address of data transmission.  When MSIZE[1:0]='01' (16 bits), the module automatically ignores bit0, and the operation address is automatically 2 bytes aligned. When MSIZE[1:0]='10' (32 bits), the module automatically ignores the [1:0] bits, and the operation address is automatically4 bytes aligned. | 0           |

Note: This register can only be changed when EN=0, and cannot be written when EN=1. Channel8 is applied for CH32V20x\_D8, CH32V20x\_D8W, CH32F20x\_D8W, CH32F20x\_D6 and CH32V20x\_D6.

## 11.3.7 DMA2 Channelx Configuration Register (DMA2 CFGRx) (x=8/9/10/11)

Offset address: 0x490 + (x-8)\*16

| 31 | 30                                    | 29 | 28 | 27 | 26 | 25 | 24   | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|---------------------------------------|----|----|----|----|----|------|-------|----|----|----|----|----|----|----|
|    |                                       |    |    |    |    |    | Rese | erved |    |    | ,  |    |    | ,  |    |
| 15 | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |    |    |    |    |    |      |       |    |    |    |    |    |    |    |

| Bit     | Name       | Access | Description                                              | Reset value |
|---------|------------|--------|----------------------------------------------------------|-------------|
| [31:15] | Reserved   | RO     | Reserved                                                 | 0           |
|         |            |        | Memory to memory mode enable:                            |             |
| 14      | MEM2MEM    | RW     | 0: Disable memory to memory mode;                        | 0           |
|         |            |        | 1: Enable memory to memory mode.                         |             |
|         |            |        | Channel priority level setting:                          |             |
| [13:12] | PL[1:0]    | RW     | 00: Low; 01: Medium;                                     | 0           |
|         |            |        | 10: High; 11: Very high.                                 |             |
|         |            |        | Memory size setting:                                     |             |
| [11:10] | MSIZE[1:0] | RW     | 00: 8 bits; 01: 16 bits;                                 | 0           |
|         |            |        | 10: 32 bits; 11: Reserved.                               |             |
|         |            |        | Peripheral size setting:                                 |             |
| [9:8]   | PSIZE[1:0] | RW     | 00: 8 bits; 01: 16 bits;                                 | 0           |
|         |            |        | 10: 32 bits; 11: Reserved.                               |             |
|         |            |        | Memory increment mode enable:                            |             |
| 7       | MINC       | RW     | 0: Disable memory increment mode;                        | 0           |
|         |            |        | 1: Enable memory increment mode.                         |             |
|         |            |        | Peripheral increment mode enable:                        |             |
| 6       | PINC       | RW     | 0: Disable peripheral increment mode;                    | 0           |
|         |            |        | 1: Enable peripheral increment mode.                     |             |
|         |            |        | DMA channel circular mode enable:                        |             |
| 5       | CIRC       | RW     | 0: Disable circular mode;                                | 0           |
|         |            |        | 1: Enable circular mode.                                 |             |
|         |            |        | Data transfer direction:                                 |             |
| 4       | DIR        | RW     | 0: Read from peripheral;                                 | 0           |
|         |            |        | 1: Read from memory.                                     |             |
|         |            |        | Transfer error interrupt enable control:                 |             |
| 3       | TEIE       | RW     | 0: Disable transfer error interrupt;                     | 0           |
|         |            |        | 1: Enable transfer error interrupt.                      |             |
|         |            |        | Half transfer interrupt enable control:                  |             |
| 2       | HTIE       | RW     | 0: Disable transmission half interrupt;                  | 0           |
|         |            |        | 1: Enable transmission half interrupt.                   |             |
|         |            |        | Transfer complete interrupt enable control:              |             |
| 1       | TCIE       | RW     | 0: Disable transmission completion interrupt;            | 0           |
|         |            |        | 1: Enable transmission completion interrupt.             |             |
|         |            |        | Channel enable control:                                  |             |
| 0       | EN         | RW     | 0: Channel disabled; 1: Channel enabled.                 | 0           |
|         | LIN        | ΙζW    | When a DMA transmission error occurs, it is cleared to 0 | U           |
|         |            |        | automatically by hardware, and channel is disabled.      |             |

Note: Applied for CH32F20x\_D8, CH32F20x\_D8C, CH32V30x\_D8, CH32V30x\_D8C and CH32V31x\_D8C.

## 11.3.8 DMA2 Channelx Transferred Data Register (DMA2\_CNTRx) (x=8/9/10/11)

Offset address: 0x494 + (x-8)\*16

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24   | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|------|-------|----|----|----|----|----|----|----|
|    |    |    |    |    |    |    | Rese | erved |    |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8    | 7     | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    |    | NDT  |       |    |    |    |    |    |    |    |

| Bit     | Name      | Access | Description                                                                                                                                                                                                                                                                                                        | Reset value |
|---------|-----------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:16] | Reserved  | RO     | Reserved.                                                                                                                                                                                                                                                                                                          | 0           |
| [15:0]  | NDT[15:0] | RW     | Number of data to transfer, range: 0-65535.  Indicating the number of pending transfers remaining (The contents of the register are decremented after each DMA transfer).  When the channel is in the cyclic mode, the contents of the register will be automatically reloaded to the previously configured value. | 0           |

Note: Indicating the current number of pending transfers. When the register content is 0, no data transmission occurs regardless of whether the channel is switched on or not. Applied for CH32F20x\_D8, CH32F20x\_D8C, CH32V30x\_D8, CH32V30x\_D8C and CH32V31x\_D8C.

## 11.3.9 DMA2 Channelx Peripheral Address Register (DMA2 PADDRx) (x=8/9/10/11)

Offset address: 0x498 + (x-8)\*16

 $31\ 30\ 29\ 28\ 27\ 26\ 25\ 24\ 23\ 22\ 21\ 20\ 19\ 18\ 17\ 16\ 15\ 14\ 13\ 12\ 11\ 10\ 9\ 8\ 7\ 6\ 5\ 4\ 3\ 2\ 1\ 0$ 

PA[31:0]

| Bit    | Name     | Access | Description                                                                                                                                                                                                                                                                                                                                                          | Reset value |
|--------|----------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:0] | PA[31:0] | RW     | Peripheral base address, as the source or target address of peripheral data transmission.  When PSIZE[1:0]='01' (16 bits), the module automatically ignores bit0, and the operation address is automatically 2 bytes aligned. When PSIZE[1:0]='10' (32 bits), the module automatically ignores bit[1:0], and the operation address is automatically 4 bytes aligned. | 0           |

Note: This register can only be changed when EN=0, and cannot be written when EN=1. Applied for CH32F20x\_D8, CH32F20x\_D8C, CH32V30x\_D8 and CH32V30x\_D8C.

## 11.3.10 DMA2 Channelx Memory Address Register (DMA2\_MADDRx) (x=8/9/10/11)

Offset address: 0x49C + (x-8)\*16

 $31\ 30\ 29\ 28\ 27\ 26\ 25\ 24\ 23\ 22\ 21\ 20\ 19\ 18\ 17\ 16\ 15\ 14\ 13\ 12\ 11\ 10\ 9\ 8\ 7\ 6\ 5\ 4\ 3\ 2\ 1\ 0$ 

MA[31:0]

| Bit    | Name     | Access | Description                                                                                                                                                                                                                              | Reset value |
|--------|----------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:0] | MA[31:0] | RW     | Memory data address, as the source or target address of data transmission.  When MSIZE[1:0]='01' (16 bits), the module automatically ignores bit0, and the operation address is automatically 2 bytes aligned. When MSIZE[1:0]='10' (32) | 0           |

| bits), the module automatically ignores bit[1:0], and the |  |
|-----------------------------------------------------------|--|
| operation address is automatically 4 bytes aligned.       |  |

Note: This register can only be changed when EN=0, and cannot be written when EN=1. Applied for  $CH32F20x\_D8$ ,  $CH32F20x\_D8C$ ,  $CH32V30x\_D8$  and  $CH32V30x\_D8C$ .

## 11.3.11 DMA2 Extend Interrupt Status Register (DMA2\_EXTEM\_INTFR)

Offset address: 0x4D0

| 31         | 30         | 29         | 28        | 27         | 26         | 25         | 24        | 23        | 22        | 21        | 20       | 19        | 18        | 17        | 16       |
|------------|------------|------------|-----------|------------|------------|------------|-----------|-----------|-----------|-----------|----------|-----------|-----------|-----------|----------|
|            |            |            |           |            |            |            | Rese      | erved     |           |           |          |           |           |           |          |
| 15         | 14         | 13         | 12        | 11         | 10         | 9          | 8         | 7         | 6         | 5         | 4        | 3         | 2         | 1         | 0        |
| TEIF<br>11 | HTIF<br>11 | TCIF<br>11 | GIF<br>11 | TEIF<br>10 | HTIF<br>10 | TCIF<br>10 | GIF<br>10 | TEIF<br>9 | HTIF<br>9 | TCIF<br>9 | GIF<br>9 | TEIF<br>8 | HTIF<br>8 | TCIF<br>8 | GIF<br>8 |

| Bit       | Name     | Access | Description                                                 | Reset value |  |  |  |  |  |
|-----------|----------|--------|-------------------------------------------------------------|-------------|--|--|--|--|--|
| [31:16]   | Reserved | RO     | Reserved                                                    | 0           |  |  |  |  |  |
|           |          |        | DMA Transfer Error flag of channelx (x=8/9/10/11):          |             |  |  |  |  |  |
|           |          |        | 0: No transfer error occurred on channel x;                 |             |  |  |  |  |  |
| 15/11/7/3 | TEIFx    | RO     | 1: A transfer error occurred on channel x.                  | 0           |  |  |  |  |  |
|           |          |        | Set by hardware, and write CTEIFx bit by software to clear  |             |  |  |  |  |  |
|           |          |        | this flag.                                                  |             |  |  |  |  |  |
|           |          |        | DMA Half Transfer flag of channelx (x=8/9/10/11):           |             |  |  |  |  |  |
|           |          |        | 0: No transfer half completion event has occurred on        |             |  |  |  |  |  |
|           |          |        | channel x;                                                  |             |  |  |  |  |  |
| 14/10/6/2 | HTIFx    | RO     | 1: A transfer half completion event has occurred on channel | 0           |  |  |  |  |  |
|           |          |        | x.                                                          |             |  |  |  |  |  |
|           |          |        | Set by hardware, and write CHTIFx bit by software to clear  |             |  |  |  |  |  |
|           |          |        | this flag.                                                  |             |  |  |  |  |  |
|           |          |        | DMA Transfer complete of channelx (x=8/9/10/11):            |             |  |  |  |  |  |
|           |          |        | 0: No transfer completion event has occurred on channel x;  |             |  |  |  |  |  |
| 13/9/5/1  | TCIFx    | RO     | 1: A transfer completion event has occurred on channel x.   | 0           |  |  |  |  |  |
|           |          |        | Set by hardware, and write CTCIFx bit by software to clear  |             |  |  |  |  |  |
|           |          |        | this flag.                                                  |             |  |  |  |  |  |
|           |          |        | Global interrupt flag of channelx ( $x=8/9/10/11$ ):        |             |  |  |  |  |  |
|           |          |        | 0: No TEIFx or HTIFx or TCIFx is generated on channel       |             |  |  |  |  |  |
| 12/8/4/0  | GIFx     | RO     | x;                                                          | 0           |  |  |  |  |  |
| 12/0/1/0  |          | 100    | 1: TEIFx or HTIFx or TCIFx is generated on channel x.       |             |  |  |  |  |  |
|           |          |        | Set by hardware, and write CGIFx bit by software to clear   |             |  |  |  |  |  |
|           |          |        | this flag.                                                  |             |  |  |  |  |  |

Note: Applied for CH32F20x D8, CH32F20x D8C, CH32V30x D8, CH32V30x D8C and CH32V31x D8C.

## 11.3.12 DMA2 Extend Interrupt Flag Clear Register (DMA2\_EXTEM\_INTFCR)

Offset address: 0x4D4

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24   | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|------|-------|----|----|----|----|----|----|----|
|    |    |    |    |    |    | '  | Rese | erved |    |    |    |    |    |    |    |

|   | 15    | 14    | 13    | 12   | 11    | 10    | 9     | 8    | 7     | 6    | 5     | 4    | 3     | 2     | 1     | 0    |
|---|-------|-------|-------|------|-------|-------|-------|------|-------|------|-------|------|-------|-------|-------|------|
| ſ | CTEIF | CHTIF | CTCIF | CGIF | CTEIF | CHTIF | CTCIF | CGIF | CTEIF | CHTI | CTCIF | CGIF | CTEIF | CHTIF | CTCIF | CGIF |
| l | 11    | 11    | 11    | 11   | 10    | 10    | 10    | 10   | 9     | F9   | 9     | 9    | 8     | 8     | 8     | 8    |

| Bit       | Name     | Access | Description                                                     | Reset value |
|-----------|----------|--------|-----------------------------------------------------------------|-------------|
| [31:16]   | Reserved | RO     | Reserved                                                        | 0           |
|           |          |        | Clear DMA Transfer Error flag of channel x                      |             |
| 15/11/7/3 | CTEIFx   | WO     | (x=8/9/10/11):                                                  | 0           |
| 13/11///3 | CIEIFX   | WO     | 0: No effect;                                                   | U           |
|           |          |        | 1: Clear the TEIFx flag in the DMA_INTFR register.              |             |
|           |          |        | Clear DMA Half Transfer flag of channel x (x=8/9/10/11):        |             |
| 14/10/6/2 | CHTIFx   | WO     | 0: No effect;                                                   | 0           |
|           |          |        | 1: Clear the HTIFx flag in the DMA_INTFR register.              |             |
|           |          |        | Clear DMA Transfer complete flag of channel x                   |             |
| 13/9/5/1  | CTCIFx   | WO     | (x=8/9/10/11):                                                  | 0           |
| 13/9/3/1  | CICIIX   | WO     | 0: No effect;                                                   | U           |
|           |          |        | 1: Clear the TCIFx flag in the DMA_INTFR register.              |             |
|           |          |        | Clear the global interrupt flag of channel x ( $x=8/9/10/11$ ): |             |
| 12/8/4/0  | CGIFx    | WO     | 0: No effect;                                                   | 0           |
| 12/0/4/0  | COILY    | WO     | 1: Clear the TEIFx/HTIFx/TCIFx/ GIFx flag in the                | U           |
|           |          |        | DMA_INTFR register.                                             |             |

*Note: Applied for CH32F20x\_D8, CH32F20x\_D8C, CH32V30x\_D8, CH32V30x\_D8C and CH32V31x\_D8C.* 

## **Chapter 12 Analog-to-digital Converter (ADC)**

## This chapter applies to the whole family of CH32F20x, CH32V20x, CH32V30x and CH32V31x.

The ADC module contains 2 12-bit successive approximation analog-to-digital converters with a maximum input clock of 14MHz. It supports sampling sources of 16 external channels and 2 internal sources. It can be performed in single, continuous, automatic scan, discontinuous, external trigger and dual sample modes. The analog watchdog function can be used to monitor whether the channel voltage is within the threshold range.

## 12.1 Main Features

- 12-bit resolution
- 16 external channels and 2 internal signal sources for sample
- Multiple sampling conversion modes for multiple channels: single, continuous, scan, trigger, discontinuous, etc.
- Data alignment mode: Left alignment, right alignment
- Sampling time can be programmed separately per channel
- Both regular conversion and injected conversion support external trigger
- Analog watchdog monitors the channel voltage, and has self-calibration function
- Dual mode
- ADC channel input range:  $0 \le V_{IN} \le V_{DDA}$
- Adjustable input gain, to implement small signal amplification and sampling

## 12.2 Functional Description

## 12.2.1 Module Structure

Conversion ends

→ E0 C=1 Rule channel dat a  $V_{DDA}$ register (16 bits) VSSA End of Injection Injection channel data conversion JE0C=1  $V_{REF+}$ register (4×16 bits) -ADC\_IOFRx [1:1:0] ADC\_INO **ADCCLK** Analog to ADC IN1 Max=14MHz Rule channel **GPIO** Digital DC\_SAMPTP group Port Converters Injection ADC\_IN150 DMA channel group Request Temperature sensor V<sub>REF INT</sub> Analog Watchdog Low threshold (10-bit) Com pare Results AWD=1 EXTSEL[2:0] TIM1\_CC1 TIM1\_CC2-TIM1\_CC3-TIM2\_CC2-TIM3\_TRGO TIM4\_CC4 SWSTART **EXTTRIG** EXTI11 TIM8 TRGC ADCx\_ETRGREG\_RM JEXTSEL[2:0] TIM1\_TRGO-TIM1\_CC4-TIM2\_TRGO-TIM2\_CC1 TIM3\_CC4 TIM4 TRGO JEXTTRIG EXTI15 TIM8 CC4 ADCx\_ETRG INJ\_RM

Figure 12-1 ADC module block diagram

## 12.2.2 ADC Configuration

## 1) Module power on

The ADON bit in the ADC\_CTLR2 register is 1, indicating that the ADC module is powered on. When the ADC module enters the power-on status (ADON=1) from the power-down mode (ADON=0), it needs to delay a period of time t<sub>STAB</sub> as the module stabilization time. Afterwards, write the ADON bit as 1 again, to serve as the start signal for software to start ADC conversion. By clearing the ADON bit to 0, you can terminate the current conversion and place the ADC module in power-down mode. In this status, the ADC consumes almost

no power.

#### 2) Sample clock

The register operation of the module is based on the PCLK2 (PB2 bus) clock. The clock reference ADCCLK of the conversion unit is synchronized with PCLK2. The frequency division is configured by ADCPRE[1:0] in the RCC CFGR0 register, and the maximum cannot exceed 14MHz.

#### 3) Channel configuration

The ADC module provides 18 channels of sampling sources, including 16 external channels and 2 internal channels. They can be configured into 2 conversion groups: regular group and injected group, in order to realize the group conversion formed by a series of conversions on any number of channels in any order.

#### Conversion group:

- Regular group: Composed of up to 16 conversions. The regular channels and their conversion sequence
  are set in the ADC\_RSQRx register. The total number of conversions in the regular group shall be written
  into L[3:0] in the ADC\_RSQR1 register.
- Injected group: Composed of up to 4 conversions. The injected channels and their conversion sequence are set in the ADC\_ISQR register. The total number of conversions in the injected group shall be written into JL[1:0] in the ADC\_ISQR register.

Note: If the ADC\_RSQRx or ADC\_ISQR register is changed during the conversion, the current conversion will be terminated, and a new start signal will be sent to the ADC to convert the newly selected group.

#### Two internal channels:

- Temperature sensor: Connect ADC IN16 channel to measure the temperature (TA) around the device.
- Internal reference voltage (V<sub>REFINT</sub>): Connect the ADC IN17 channel.

#### 4) Calibration

Initialize the calibration register by writing the RSTCAL bit of the ADC\_CTLR2 register to 1. The initiation is completed when the RSTCAL hardware is cleared. Set the CAL bit to start the calibration function. Once the calibration is completed, the hardware will automatically clear the CAL bit and save the calibration code in ADC\_RDATAR. Then, the normal conversion function can be used. It is recommended to perform an ADC calibration when the ADC module is powered on.

Note: Before starting calibration, you must ensure that the ADC module is in the power-on status (ADON=1) for more than 2 ADC clock cycles at least.

## 5) Programmable sample time

Several ADCCLK cycles are used to sample the input voltage. The number of sampling cycles of the channel can be changed by the SMPx[2:0] bits in the ADC\_SAMPTR1 and ADC\_SAMPTR2 registers. Each channel can be sampled at a different time.

The total conversion time is calculated as follows:

 $T_{CONV} = Sampling time + 11T_{ADCCLK}$ 

The regular channel conversion of ADC supports DMA function. The converted value of the regular channel is stored in the only data register ADC\_RDATAR. To prevent continuous conversion of multiple regular channels, the DMA function of ADC can be enabled for the data not timely removed in the ADC\_RDATAR register. The hardware will generate a DMA request when the conversion of the regular channel is completed (EOC bit is set), and transmit the converted data from the ADC\_RDATAR register to the destination address

specified by the user.

After the channel configuration of the DMA controller module is completed, write the DMA bit of the ADC CTLR2 register to 1 to enable the DMA function of the ADC.

*Note: The injected group conversion does not support DMA function.* 

#### 6) Data alignment

The data storage alignment method after ADC conversion is selected for the ALIGN bit in the ADC\_CTLR2 register. 12-bit data supports left alignment and right alignment modes.

The data register ADC\_RDATAR of the regular group channel saves the actual converted 12-bit digital value; while the data register ADC\_IDATARx of the injected group channel is the value written after the actual converted data is subtracted from the defined offset of the ADC\_IOFRx register, the value may be positive or negative, so there will be a sign bit (SIGNB).

Figure 12-2 Data left alignment

| Regula   | Regular group data register  |     |    |    |    |    |    |    |    |    |    |    |   |   |   |
|----------|------------------------------|-----|----|----|----|----|----|----|----|----|----|----|---|---|---|
| D11      | D10                          | D9  | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | 0  | 0 | 0 | 0 |
| Injected | Injected group data register |     |    |    |    |    |    |    |    |    |    |    |   |   |   |
| SIGNI    | 3 D11                        | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | 0 | 0 | 0 |

Figure 12-3 Data right alignment

|         | Figure 12-3 Data right alignment |     |       |       |     |     |     |    |     |            |    |    |    |    |     |            |    |
|---------|----------------------------------|-----|-------|-------|-----|-----|-----|----|-----|------------|----|----|----|----|-----|------------|----|
| Regula  | Regular group data register      |     |       |       |     |     |     |    |     |            |    |    |    |    |     |            |    |
| 0       | 0                                | 0   | 0     | D11   | D10 | D9  | D8  | D7 | 7 I | <b>D</b> 6 | D5 | D4 | D3 | D  | 2 I | <b>D</b> 1 | D0 |
| Injecte | Injected group data register     |     |       |       |     |     |     |    |     |            |    |    |    |    |     |            |    |
| SIGN    | IB SI                            | GNB | SIGNE | 3 SIC | GNB | D11 | D10 | D9 | D8  | D7         | D6 | D5 | D4 | D3 | D2  | D1         | D0 |

## 12.2.3 External Trigger Source

The ADC conversion start event can be triggered by an external event. If the REXTTRI or IEXTTRIG bit in the ADC\_CTLR2 register is set, the conversion of the regular group or the injected group channel can be triggered by an external event, respectively. At this time, the configuration of the REXTSEL[2:0] and IEXTSEL[2:0] bits determines the external event source of the rule group and the injected group.

Note: When an external trigger signal is selected for ADC rule or injection conversion, only its rising edge can start the conversion.

| REXTSEL[2:0] | Trigger source              | Туре                             |  |  |  |  |
|--------------|-----------------------------|----------------------------------|--|--|--|--|
| 000          | CC1 event of timer1         |                                  |  |  |  |  |
| 001          | CC2 event of timer1         |                                  |  |  |  |  |
| 010          | CC3 event of timer1         | Internal signal from on-chip     |  |  |  |  |
| 011          | CC2 event of timer2         | timers                           |  |  |  |  |
| 100          | TRGO event of timer3        |                                  |  |  |  |  |
| 101          | CC4 event of timer4         |                                  |  |  |  |  |
| 110          | EXTI line11/TIM8 TRGO       | From external pin/internal timer |  |  |  |  |
| 110          | LATT IIIIETT/TIIVI8_TRGO    | signal                           |  |  |  |  |
| 111          | SWSTART bit set by software | Software control bit             |  |  |  |  |

Table 12-1 External trigger sources of regular group channel

Table 12-2 External trigger sources of injected group channel

| IEXTSEL[2:0] | Trigger source | Туре |
|--------------|----------------|------|
|--------------|----------------|------|

| 000 | TRGO event of timer1              |                                         |
|-----|-----------------------------------|-----------------------------------------|
| 001 | CC4 event of timer1               |                                         |
| 010 | TRGO event of timer2              | Internal signal from an abin timera     |
| 011 | CC1 event of timer2               | Internal signal from on-chip timers     |
| 100 | CC4 event of timer3               |                                         |
| 101 | TRGO event of timer4              |                                         |
| 110 | EXTI line15/TIM8_CC4              | From external pin/internal timer signal |
| 111 | JSWSTART bit set to 1 by software | Software control bit                    |

## 12.2.4 Conversion Mode

Table 12-3 Conversion mode combination

| AD   | C_CTLR | 1 and ADC_CTLR2 r | ADC conversion mode |                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|--------|-------------------|---------------------|--------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CONT | SCAN   | DISCEN/JDISCEN    | JAUTO               | Start event                                            | ADC conversion mode                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|      | 0      | 0                 | 0                   | ADON bit set to 1                                      | Single single-channel mode: The single conversion is performed through a regular channel.                                                                                                                                                                                                                                                                                                                                                                  |
|      | O      | 0                 | U                   | External<br>trigger<br>mode                            | Single single-channel mode: A single conversion is performed through one of the regular channels or injected channels.                                                                                                                                                                                                                                                                                                                                     |
| 0    | 1      | 0                 | 0                   | ADON bit<br>set to 1 or<br>external<br>trigger<br>mode | Single scan mode: Perform a single conversion on all selected regular group channels (ADC_RSQRx) or all injected group channels (ADC_ISQR) in sequence.  Trigger injected mode: When the regular group channel is converted, all conversions of the injected group channel can be inserted, and then the regular group channel conversion is continued; but the regular group channel conversion is not inserted when injected group channel is converted. |
|      |        |                   | 1                   | ADON bit<br>set to 1 or<br>external<br>trigger<br>mode | Single scan mode: Perform a single conversion on all selected regular group channels (ADC_RSQRx) or all injected group channels (ADC_ISQR) in sequence.  Automatic injected mode: After regular group channel is converted, the injected group channel will be automatically converted.  Note: The external trigger signal injected into the channel is not allowed to appear                                                                              |

| _ |   |                                                     |   |                             | during the conversion process.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---|---|-----------------------------------------------------|---|-----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   | 0 | 1 (DISCEN and JDISCEN cannot be 1 at the same time) | 0 | External<br>trigger<br>mode | Single discontinuous mode: Whenever an event is started, a short sequence (the number defined by DISCNUM[2:0]) of channel number conversion will be performed, and the event will be restarted until the conversion of all selected channels is completed.  Note: The mode control bits selected for the regular group and the injected group are DISCEN and JDISCEN respectively. The discontinuous mode cannot be configured for the regular group and the injected group at the same time, and the discontinuous mode can only be used for single conversion. |
|   |   |                                                     | 1 | -                           | Disable such mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|   | 1 | 1                                                   | X | -                           | No such mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 1 | 0 | 0                                                   | 0 | ADON bit                    | Continuous single channel/scan mode:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|   | 1 | 0                                                   | 0 | set to 1 or                 | After each round, a new round of                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|   |   |                                                     | 1 | external<br>trigger<br>mode | conversion will be repeated, and it can be terminated until CONT is cleared to 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

Note: The external trigger event of regular group and injected group is different, and the 'ACON' bit can only start the channel conversion of the regular group, so the start event of the channel conversion of the regular group and the injected group is independent.

#### 1) Single single-channel conversion mode

In this mode, only one conversion is performed for the current channel. The first channel in the regular group or injected group is converted in this mode. It can be started up by setting the ADON bit in ADC\_CTLR2 register to 1 (only applicable to regular channel), or by an external trigger (applicable to regular channel or injected channel). Once the conversion of the selected channels is completed:

If a regular group channel is converted, the conversion data is saved in the 16-bit ADC\_RDATAR register, and the EOC flag is set. If the EOCIE bit is set, the ADC interrupt is triggered.

If the injected group channel is converted, the conversion data is stored in the 16-bit ADC\_IDATAR1 register, and the EOC and IEOC flags is set. If the IEOCIE or EOCIE bit is set, the ADC interrupt is triggered.

#### 2) Single scan mode conversion

Enter the ADC scan mode by setting the SCAN bit in the ADC\_CTLR1 register to 1. This mode is used to scan a group of analog channels, and perform a single conversion for all channels selected by ADC\_RSQRx register (for regular channels) or ADC\_ISQR (for injected channels) one by one. When the current channel conversion ends, the next channel in the same group is automatically converted.

In the scan mode, according to the status of the JAUTO bit, it is divided into trigger injected mode and automatic injected mode.

#### Trigger injection

The JAUTO bit is 0. When a trigger event for the channel conversion of the injected group occurs during the scanning of the regular group channel, the current conversion is reset, and the sequence of the injected channel is carried out in a single scan mode. After the scanning and conversion of all selected injected group channels are completed, the previous interrupted regular group channel conversion is restored.

If a regular channel start event occurs currently while scanning the injected group channel sequence, the injected group conversion is not interrupted, but the regular sequence conversion is executed after the injected sequence conversion is completed.

Note: When using triggered injected conversion, you must ensure that the interval of the trigger event is longer than the injected sequence. For example, the total conversion time to complete the injected sequence is 28 ADCCLKs, so the minimum event interval time for triggering the injected channel is 29 ADCCLKs.

#### Automatic injection

The JAUTO bit is 1. After scanning all the channels selected by the regular group, the conversion of the channels selected by the injected group is automatically performed. This method can be used to convert up to 20 conversion sequences in the ADC RSQRx and ADC ISQR registers.

In this mode, the external trigger of the injected channel must be disabled (IEXTTRIG=0).

Note: For the ADC clock prescale factor(ADCPRE[1:0]) of 4 to 8, when switching from regular conversion to injected sequence or from injected conversion to regular sequence, 1 ADCCLK interval will be inserted automatically; when the ADC clock prescale factor is 2, there is a delay of 2 ADCCLK intervals.

### 3) Single interval mode conversion

Enter the discontinuous mode of the regular group or injected group by setting either the DISCEN or JDISCEN bit in the ADC\_CTLR1 register to 1. This mode differs from scanning a complete set of channels in scan mode, but divides a set of channels into multiple short sequences, and each external trigger event executes a short sequence of scan conversion.

The length of the short sequence n (n<=8) is defined by the DISCNUM[2:0] bits in the ADC\_CTLR1 register. When DISCEN is 1, it is the discontinuous mode of the regular group. The total length to be converted is defined by the L[3:0] bits in the ADC\_RSQR1 register. When JDISCEN is 1, it is the discontinuous mode of the injected group, and the total length to be converted is defined by the JL[1:0] bits in the ADC\_ISQR register. The regular group and injected group cannot be set to discontinuous mode at the same time.

Example of regular group discontinuous mode:

DISCEN=1, DISCNUM[2:0]=3, L[3:0]=8, channels to be converted=1, 3, 2, 5, 8, 4, 10, 6

For the first external trigger, conversion sequence: 1, 3, 2

For the second external trigger, conversion sequence: 5, 8, 4

For the third external trigger, conversion sequence: 10, 6, and the EOC event is generated in the meantime

For the fourth external trigger, conversion sequence: 1, 3, 2

Example of injected group discontinuous mode:

JDISCEN=1, JL[1:0]=3, channels to be converted=1, 3, 2

For the first external trigger, conversion sequence: 1

For the second external trigger, conversion sequence: 3

For the third external trigger, conversion sequence: 2, and the EOC and IEOC events are generated in the meantime

For the fourth external trigger, conversion sequence: 1

Note: 1. When switching a regular group or injected group in the discontinuous mode, it will not automatically start from the beginning after the conversion sequence ends. When all subgroups are converted, the next

trigger event will start the conversion of the first subgroup.

- 2. Automatic injection (JAUTO=1) and intermittent mode cannot be used at the same time.
- 3. The discontinuous mode cannot be set for the regular group and the injected group at the same time, and the discontinuous mode can only be used for single conversion.
- 4. In the intermittent mode of the injection group, the number of injection channels to be converted after the external trigger is 1.

#### 4) Continuous conversion

In the continuous conversion mode, another conversion is started as soon as the previous ADC conversion is completed. The conversion will not stop on the last channel of the selection group, but will continue conversion from the first channel of the selection group again. The startup events in this mode include external trigger events and the ADON bit is set to 1. After setting the startup, the CONT bit needs to be set to 1.

If a regular channel is converted, the conversion data is stored in the ADC\_RDATAR register, the conversion end flag EOC is set, and if EOCIE is set, an interrupt is generated.

If an injection channel is converted, the conversion data is stored in the ADC\_IDATARx register, the injection conversion end flag JEOC is set, and if JEOCIE is set, an interrupt is generated.

#### 12.2.5 Analog Watchdog

If the analog voltage converted by the ADC is lower than the low threshold or higher than the high threshold, the AWD analog watchdog status bit will be set. The threshold setting is located in the low 12 active bits in the ADC\_WDHTR and ADC\_WDLTR registers. By setting the AWDIE bit in the ADC\_CTLR1 register, the corresponding interrupt is allowed to be generated.

Alert High
Threshold

Alert Area

Alert Low
Threshold

Analog voltage
conversion values

ADC\_WDHTR

ADC\_WDLTR

Figure 12-4 Analog watchdog threshold area

Configure the AWDSGL, AWDEN, JAWDEN and AWDCH[4:0] bits in the ADC\_CTLR1 register to select the channel for analog watchdog vigilance. The specific relationship is shown in the following table:

Table 12-4 Analog Watchdog Channel Selection

| 14                                | oic 12-4 Allalog V |              |                     |                       |
|-----------------------------------|--------------------|--------------|---------------------|-----------------------|
| Analog watchdog                   |                    | ADC_CTLR1 re | egister control bit |                       |
| vigilance channel                 | AWDSGL             | AWDEN        | JAWDEN              | AWDCH[4:0]            |
| Non-vigilance                     | Ignore             | 0            | 0                   | Ignore                |
| All injected channels             | 0                  | 0            | 1                   | Ignore                |
| All regular channels              | 0                  | 1            | 0                   | Ignore                |
| All injected and regular channels | 0                  | 1            | 1                   | Ignore                |
| Single injected channel           | 1                  | 0            | 1                   | Determine channel No. |
| Single regular channel            | 1                  | 1            | 0                   | Determine channel No. |

| Single injected and regular | 1 | 1 | 1 | Determine   |
|-----------------------------|---|---|---|-------------|
| channel                     | 1 | 1 | 1 | channel No. |

### 12.2.6 Temperature Sensor

The chip has a built-in temperature sensor, which is connected to the ADC\_INT16 channel. The voltage output by the sensor is converted into a digital value through the ADC to feed back the internal temperature of the chip. The recommended sampling time is 17.1us. The output voltage of a temperature sensor varies linearly with temperature. Due to manufacturing discretization, the slope and offset of the curve of the linear variation varies, so internal temperature sensors are better suited for detecting changes in temperature rather than measuring absolute temperature. If you need to measure accurate temperature, you shall use an external temperature sensor.

By setting the TSVREFE bit in the ADC\_CTLR2 register to 1, wake up the ADC internal sampling channel. The ADC temperature sensor channel conversion is started up by the software or external trigger to read the data results (mV). The conversion formula of digital value and temperature (°C) is as follows:

Temperature (°C) =  $((V_{SENSE}-V_{25})/Avg$  Slope)+25

V25: The voltage value of the temperature sensor at 25°C

Avg Slope: Average slope of temperature and V<sub>SENSE</sub> curve (mV/°C)

Refer to the actual values of V<sub>25</sub> and Avg Slope in the electrical characteristics chapter of this manual.

Note: A setup time is required for the internal temperature sensor power-on (TSVREFE bit is changed to 1 from 0) and a setup time is also required for ADC module power-on (ADON bit is changed to 1 from 0), so in order to shorten the waiting time, you can set ADON and TSVREFE bits at the same time.

#### 12.2.7 Dual ADC Mode

In devices with 2 ADC modules, the 2 ADC modules can be used together to implement dual ADC mode. In dual ADC mode, ADC1 is the master ADC, and ADC2 is the slave ADC. The conversion is triggered alternately or simultaneously, depending on the mode selected by the DUALMODE[3:0] bits in the ADC1 CTLR1 register.

Note: In dual ADC mode, when configuring conversion to be triggered by an external event, the external triggers must be enabled on both master and slave ADCs and the user must set the corresponding trigger for the master ADC and set a software trigger for the slave ADC, to prevent spurious triggers to start unwanted slave conversion.

The following modes can be implemented:

- Independent mode
- Injected simultaneous mode
- Regular simultaneous mode
- Fast interleaved mode
- Slow interleaved mode
- Alternate trigger mode
- Regular simultaneous mode + Injected simultaneous mode
- Regular simultaneous mode + Alternate trigger mode
- Injected simultaneous mode + Fast interleaved mode
- Injected simultaneous mode + Slow interleaved mode

Note: 1. In dual ADC mode, the DMA bit must be enabled, to read the slave converted data on the master data register.

2. Only ADC1 has DMA function. the ADC2 converted data only can be transferred by DMA of ADC1

in dual ADC mode.

End of ADC2 Regular channel data E0C=1 (slave) registers (16-bit) End of injection Injected channel data conversion → JE0C=1 registers (4×16 bits) -ADC\_IOFRx [11:0] ADCCLK Max=14MHz Analog-to-digital Rule channel ADC SAMPTRX converter group PGA Injection DMA request channel group End of Regular channel data ADC1 registers (16-bit) master) End of injection Injected channel data conversion JE0C=1 registers (4×16 bits) -ADC\_IOFRx [11:0] ADC\_INO ADCCLK Max=14MHz ADC\_IN1 Rule channel Analog-to-digita ADC\_SAMPTRx group converter PGA Injection ADC\_IN15 channel group ►DMA request Temperature Sensor V<sub>REF I NT</sub> EXTSEL [2:0] TIM1\_CC1-TIM1\_CC2-TIM1\_CC3-TIM2 CC2-TIM2\_CC2 TIM3\_TRGO TIM4\_CC4 SWSTART EXTTRIG EXTI11 Dual ADC mode control ADCx ETRGINJ RM JEXTSEL[2:0] TIM1\_TRG0-TIM1\_CC4-TIM2\_TRG0-TIM2\_CC1-TIM3\_CC4-TIM4\_TRG0-JSWSTAR<sup>T</sup> JEXTTR IG EXTI15 TIM8\_CC4 ADCx\_E TRGREG\_RM

Figure 12-5 Dual ADC block diagram

#### 1) Independent mode

In independent mode, the dual ADC modules do not work synchronously, and each ADC works independently.

### 2) Injected simultaneous mode

This mode converts an injected channel group. By setting the IEXTSEL[2:0] bits in the ADC1\_CTLR1 register, the trigger source can be selected. And a simultaneous trigger is provided to ADC2. After conversion, the

converted data is stored in the ADC\_IDATARx registers of each ADC. If an ADC interrupt is enabled, an IEOC interrupt is generated after conversion.

Figure 12-6 Injected simultaneous mode on 4 channels



Note: 1. Do not convert the same channel on the 2 ADCs.

2. In simultaneous mode, to ensure that the conversion of the 2 groups can be completed each time, the conversion groups of ADC1 and ADC2 should have the same time, or the time of the longer conversion group is less than the trigger time interval.

#### 3) Regular simultaneous mode

This mode is performed on a regular channel group. By setting the REXTSEL[2:0] bits in the ADC1\_CTLR1 register, the trigger source can be selected. And a simultaneous trigger is provided to ADC2. After conversion, a 32-bit DMA transfer request is generated, which transfers the data in the ADC1\_RDATAR register to SRAM, and the high 16 bits contain the ADC2 converted data, the low 16 bits contain the ADC1 converted data. If an ADC interrupt is enabled, an EOC interrupt is generated.

Figure 12-7 Regular simultaneous mode on 16 channels



Note: 1. Do not convert the same channel on ADC1 and ADC2;

2. In simultaneous mode, to ensure that the conversion of the 2 groups can be completed each time, the conversion groups of ADC1 and ADC2 should have the same time, or the time of the longer conversion group is less than the trigger time interval.

#### 4) Fast interleaved mode

This mode only applies to a regular channel (Usually only one channel). By setting the REXTSEL[2:0] bits in the ADC1\_CTLR1 register, the trigger source can be selected. After a trigger occurs, ADC2 starts conversion immediately, while ADC1 starts conversion after a delay of 7 ADC clock cycles. If both ADC1 and ADC2 enable continuous mode (The CONT bit is set), continuous interleaved conversion is performed on regular channel. If an interrupt is enabled, ADC1 generates an EOC interrupt. If both ADC1 and ADC2 enable DMA, a 32-bit DMA transfer request is generated, which transfers the data in the ADC1\_RDATAR register to SRAM, and the high 16 bits contain the ADC2 converted data, the low 16 bits contain the ADC1 converted data.

V2. 4 180 **WIH** 

7 ADCCLK cycles

ADC2 conversion ends

ADC2 CH0 ··· CH0

ADC1 CH0 ··· CH0

Trigger ADC1 conversion ends

Figure 12-8 Fast interleaved mode on 1 channel in continuous conversion mode

Note: The sampling time should be less than 7 ADC clock cycles, to avoid the overlap between ADC1 and ADC2 sampling phases in the event that they convert the same channel.

### 5) Slow interleaved mode

This mode only applies to a regular channel (Only one channel). By setting the REXTSEL[2:0] bits in the ADC1\_CTLR1 register, the trigger source can be selected. After a trigger occurs, ADC2 starts conversion immediately, while ADC1 starts conversion after a delay of 14 ADC clock cycles, and ADC2 starts again after a second delay of 14 ADC clock cycles, and so on. If an interrupt is enabled, ADC1 generates an EOC interrupt. If both ADC1 and ADC2 enable DMA, a 32-bit DMA transfer request is generated, which transfers the data in the ADC1\_RDATAR register to SRAM, and the high 16 bits contain the ADC2 converted data, the low 16 bits contain the ADC1 converted data.

ADC2 CH0 CH0

ADC1 CH0 CH0

Trigger ADC1 conversion ends

Figure 12-9 Slow interleaved mode on 1 channel

Note: 1. The sampling time should be less than 14 ADC clock cycles, to avoid an overlap with the next conversion;

- 2. After 28 ADC clock cycles, a new ADC2 start is generated automatically;
- 3. The CONT bit cannot be set.

#### 6) Alternate trigger mode

This mode only applies to an injected channel group. By setting the REXTSEL[2:0] bits in the ADC1\_CTLR1 register, the trigger source can be selected. When the first trigger occurs, all injected group channels in ADC1 are converted. When the second trigger occurs, all injected group channels in ADC2 are converted. And so on. If an interrupt is enabled, an IEOC interrupt is generated after all injected group channels in ADC1 are converted. If an interrupt is enabled, an IEOC interrupt is generated after all injected group channels in ADC2 are converted.

V2. 4 181 **WI**H

3rd Nth EOC, Sample EOC, trigger trigger trigger IEOC(ADC1) IEOC(ADC1) conversion ADC1 ADC2 ÈOC, EOC, N+1th 2nd IEOC(ADC2) 4th IEOC(ADC2) trigger trigger trigger

Figure 12-10 Alternate trigger: injected channel group of each ADC

If the injected discontinuous mode is enabled, when the first trigger occurs, the first injected channel in ADC1 is converted. When the second trigger occurs, the first injected channel in ADC2 is converted. And so on. If an interrupt is enabled, an IEOC interrupt is generated after all injected group channels in ADC1 are converted. If an interrupt is enabled, an IEOC interrupt is generated after all injected group channels in ADC2 are converted.

Figure 12-11 Alternate trigger: injected channel group of each ADC in discontinuous mode



#### 7) Regular simultaneous mode + Injected simultaneous mode

This mode can interrupt simultaneous conversion of a regular group to start simultaneous conversion of an injected group. In this mode, the conversion groups of ADC1 and ADC2 should have the same time, or the time of the longer conversion group is less than the trigger time interval.

#### 8) Regular simultaneous mode + Alternate trigger mode

This mode can interrupt simultaneous conversion of a regular group to start alternate trigger conversion of an injected group. When an injected event occurs, alternate trigger conversion starts immediately. If the regular conversion is already running, the regular conversion of both ADCs is stopped, and it is resumed synchronously at the end of the injected conversion.



Figure 12-12 Alternate trigger conversion in regular simultaneous mode

V2. 4 182 WH

Note: In this mode, the conversion groups of ADC1 and ADC2 should have the same time, or the time of the longer conversion group is less than the trigger time interval.

If a trigger occurs during an injected conversion that has interrupted a regular conversion, it will be ignored. The Figure 12-13 shows the behavior in this case (The second trigger is ignored).



Figure 12-13 Trigger event occurring during injected conversion

### 9) Injected simultaneous mode + Interleaved mode

In this mode, an injected conversion can stop the interleaved conversion. When an injected event occurs, the interleaved conversion is interrupted, and the injected conversion starts. After injected conversion, the interleaved conversion is resumed.



Figure 12-14 Injected group conversion during interleaved conversion

Note: When the ADC clock prescaler is set to 4, the sampling interval is 8 ADC clock cycles followed by 6 ADC clock cycles, instead of 7 ADC clock cycles followed by 7 ADC clock cycles.

# 12.3 Register Description

| Name             | Access address | Description                                 | Reset value |
|------------------|----------------|---------------------------------------------|-------------|
| R32_ADC1_STATR   | 0x40012400     | ADC1 status register                        | 0x00000000  |
| R32_ADC1_CTLR1   | 0x40012404     | ADC1 control register1                      | 0x00000000  |
| R32_ADC1_CTLR2   | 0x40012408     | ADC1 control register 2                     | 0x00000000  |
| R32_ADC1_SAMPTR1 | 0x4001240C     | ADC1 sample time configuration register1    | 0x00000000  |
| R32_ADC1_SAMPTR2 | 0x40012410     | ADC1 sample time configuration register2    | 0x00000000  |
| R32_ADC1_IOFR1   | 0x40012414     | ADC1 injected channel data offset register1 | 0x00000000  |
| R32_ADC1_IOFR2   | 0x40012418     | ADC1 injected channel data offset register2 | 0x00000000  |
| R32_ADC1_IOFR3   | 0x4001241C     | ADC1 injected channel data offset register3 | 0x00000000  |

Table 12-5 ADC1 registers

| R32_ADC1_IOFR4   | 0x40012420 | ADC1 injected channel data offset register4 | 0x00000000 |
|------------------|------------|---------------------------------------------|------------|
| R32_ADC1_WDHTR   | 0x40012424 | ADC1 watchdog high threshold register       | 0x00000FFF |
| R32_ADC1_WDLTR   | 0x40012428 | ADC1 watchdog low threshold register        | 0x00000000 |
| R32_ADC1_RSQR1   | 0x4001242C | ADC1 regular channel sequence register1     | 0x00000000 |
| R32_ADC1_RSQR2   | 0x40012430 | ADC1 regular channel sequence register2     | 0x00000000 |
| R32_ADC1_RSQR3   | 0x40012434 | ADC1 regular channel sequence register3     | 0x00000000 |
| R32_ADC1_ISQR    | 0x40012438 | ADC1 injected channel sequence register     | 0x00000000 |
| R32_ADC1_IDATAR1 | 0x4001243C | ADC1 injected data register1                | 0x00000000 |
| R32_ADC1_IDATAR2 | 0x40012440 | ADC1 injected data register2                | 0x00000000 |
| R32_ADC1_IDATAR3 | 0x40012444 | ADC1 injected data register3                | 0x00000000 |
| R32_ADC1_IDATAR4 | 0x40012448 | ADC1 injected data register4                | 0x00000000 |
| R32_ADC1_RDATAR  | 0x4001244C | ADC1 regular data register                  | 0x00000000 |
| R32_ADC1_AUX     | 0x40012454 | ADC1 sample time register                   | 0x00000000 |

Table 12-6 ADC2 registers

| Name             | Access address | Description                                 | Reset value |
|------------------|----------------|---------------------------------------------|-------------|
| R32_ADC2_STATR   | 0x40012800     | ADC2 status register                        | 0x00000000  |
| R32_ADC2_CTLR1   | 0x40012804     | ADC2 control register1                      | 0x00000000  |
| R32_ADC2_CTLR2   | 0x40012808     | ADC2 control register 2                     | 0x00000000  |
| R32_ADC2_SAMPTR1 | 0x4001280C     | ADC2 sample time configuration register1    | 0x00000000  |
| R32_ADC2_SAMPTR2 | 0x40012810     | ADC2 sample time configuration register2    | 0x00000000  |
| R32_ADC2_IOFR1   | 0x40012814     | ADC2 injected channel data offset register1 | 0x00000000  |
| R32_ADC2_IOFR2   | 0x40012818     | ADC2 injected channel data offset register2 | 0x00000000  |
| R32_ADC2_IOFR3   | 0x4001281C     | ADC2 injected channel data offset register3 | 0x00000000  |
| R32_ADC2_IOFR4   | 0x40012820     | ADC2 injected channel data offset register4 | 0x00000000  |
| R32_ADC2_WDHTR   | 0x40012824     | ADC2 watchdog high threshold register       | 0x00000FFF  |
| R32_ADC2_WDLTR   | 0x40012828     | ADC2 watchdog low threshold register        | 0x00000000  |
| R32_ADC2_RSQR1   | 0x4001282C     | ADC2 regular channel sequence register1     | 0x00000000  |
| R32_ADC2_RSQR2   | 0x40012830     | ADC2 regular channel sequence register2     | 0x00000000  |
| R32_ADC2_RSQR3   | 0x40012834     | ADC2 regular channel sequence register3     | 0x00000000  |
| R32_ADC2_ISQR    | 0x40012838     | ADC2 injected channel sequence register     | 0x00000000  |
| R32_ADC2_IDATAR1 | 0x4001283C     | ADC2 injected data register1                | 0x00000000  |
| R32_ADC2_IDATAR2 | 0x40012840     | ADC2 injected data register2                | 0x00000000  |
| R32_ADC2_IDATAR3 | 0x40012844     | ADC2 injected data register3                | 0x00000000  |
| R32_ADC2_IDATAR4 | 0x40012848     | ADC2 injected data register4                | 0x00000000  |
| R32_ADC2_RDATAR  | 0x4001284C     | ADC2 regular data register                  | 0x00000000  |
| R32_ADC2_AUX     | 0x40012854     | ADC2 sample time register                   | 0x00000000  |

# 12.3.1 ADCx Status Register (ADCx\_STATR) (x=1/2)

Offset address: 0x00

| 31 | 30       | 29 | 28 | 27 | 26      | 25 | 24 | 23 | 22 | 21 | 20   | 19    | 18   | 17  | 16  |
|----|----------|----|----|----|---------|----|----|----|----|----|------|-------|------|-----|-----|
|    | Reserved |    |    |    |         |    |    |    |    |    |      |       |      |     |     |
| 15 | 14       | 13 | 12 | 11 | 10      | 9  | 8  | 7  | 6  | 5  | 4    | 3     | 2    | 1   | 0   |
|    |          |    |    | F  | Reserve | d  |    |    |    |    | STRT | JSTRT | JEOC | EOC | AWD |

| Bit Name Access |          | Access | Description                                                  | Reset |
|-----------------|----------|--------|--------------------------------------------------------------|-------|
| Dit             | rune     | recess | Description                                                  | value |
| [31:5]          | Reserved | RO     | Reserved.                                                    | 0     |
|                 |          |        | Regular channel conversion start status:                     |       |
|                 |          |        | 0: The regular channel conversion has not started;           |       |
| 4               | STRT     | RW0    | 1: The regular channel conversion has started.               | 0     |
|                 |          |        | This bit is set by hardware and cleared by software (Invalid |       |
|                 |          |        | if writing 1).                                               |       |
|                 |          |        | Injected channel conversion start status:                    |       |
|                 |          |        | 0: The injected channel conversion has not started;          |       |
| 3               | JSTRT    | RW0    | 1: The injected channel conversion has started.              | 0     |
|                 |          |        | This bit is set by hardware and cleared by software (Invalid |       |
|                 |          |        | if writing 1).                                               |       |
|                 |          |        | Injected channel group conversion completion status:         |       |
|                 |          | RW0    | 0: The conversion has not completed;                         |       |
|                 | IFOC     |        | 1: The conversion has completed.                             |       |
| 2               | JEOC     |        | This bit is set to 1 by hardware (The conversion of all      |       |
|                 |          |        | injected channels is completed), and cleared by software     |       |
|                 |          |        | (Invalid if writing 1).                                      |       |
|                 |          |        | Conversion completion status:                                |       |
|                 |          |        | 0: The conversion has not completed;                         |       |
|                 |          |        | 1: The conversion has completed.                             |       |
| 1               | EOC      | RW0    | This bit is set to 1 by hardware (The regular or injected    |       |
|                 |          |        | channel group conversion ends), and is cleared by software   |       |
|                 |          |        | (Invalid if writing 1) or clearing when ADC_RDATAR is        |       |
|                 |          |        | read.                                                        |       |
|                 |          |        | Analog watchdog flag bit:                                    |       |
|                 |          |        | 0: No analog watchdog event occurs;                          |       |
|                 | AWD      | DWO    | 1: The analog watchdog event occurs.                         |       |
| 0               | AWD      | RW()   | This bit is set to 1 by hardware (The conversion value is    |       |
|                 |          |        | out of the ADC_WDHTR and ADC_WDLTR register                  |       |
|                 |          |        | range), and is cleared by software (Invalid if writing 1).   |       |

# 12.3.2 ADCx Control Register1 (ADCx\_CTLR1) (x=1/2)

Offset address: 0x04

| 31                              | 30      | 29         | 28        | 27         | 26        | 25          | 24           | 23        | 22         | 21  | 20     | 19            | 18 | 17 | 16  |
|---------------------------------|---------|------------|-----------|------------|-----------|-------------|--------------|-----------|------------|-----|--------|---------------|----|----|-----|
| R                               | Reserve | ed         | PGA       | [1:0]      | BUF<br>EN | TKI<br>TUNE | TKENAB<br>LE | AWDE<br>N | JAWDE<br>N | Res | served | rved DUALMOD[ |    |    | :0] |
| 15                              | 14      | 13         | 12        | 11         | 10        | 9           | 8            | 7         | 6          | 5   | 4      | 3             | 2  | 1  | 0   |
| DISCNUM[2:0] JDISC DIS<br>EN EN |         | DISC<br>EN | JAUT<br>O | AWD<br>SGL | SCAN      | JEOC<br>IE  | AWDIE        | EO<br>CIE |            | AW  | DCH[4  | 4:0]          |    |    |     |

| Bit     | Name              | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Reset value |  |  |  |  |
|---------|-------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--|--|--|--|
| [31:29] | Reserved PGA[1:0] | RO     | Reserved ADC channel gain configuration: 00: x1; 01: x4; 10: x16;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0           |  |  |  |  |
| [20.27] | 10/1[1.0]         | ICW    | 11: x64.  Note: The input gain can be configured, for amplifying small signals and sampling. ADC_Buffer needs to be enabled to use this function.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |             |  |  |  |  |
| 26      | BUFEN             | RW     | ADC BUFFER enable:  0: Buffer input disabled;  1: Buffer input enabled.  Note: Cases where buffer needs to be turned on:  1. When TKENABLE bit or TSVREFE position 1, buffer is on by default and cannot be turned off (So in these two cases, ADC calibration needs to be before TKENABLE bit or TSVREFE position 1 and buffer needs to be turned off).  2. When the external input impedance is greater than the maximum input impedance requirement, the buffer can be turned on to improve the ADC acquisition data (At this time, the ADC sampling time is not recommended to be less than 7.5T), the external input impedance is detailed in CH32F203DS0/CH32F208DS0/CH32V203DS0/CH32V2  08DS0 data sheet Table 4-28 CH32V307DS0/CH32F207DS0 datasheet Table 4-41. Refer to EVT related routines for specific operation. | 0           |  |  |  |  |
| 25      | TKITUNE           | RW     | TKEY module charging current configuration: 0: Charging current is 35uA; 1: Charging current is reduced half.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0           |  |  |  |  |
| 24      | TKENABLE          | RW     | TKEY module enable control, including TKEY_F and TKEY_V units:  0: Disable TKEY module;  1: Enable TKEY module.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0           |  |  |  |  |
| 23      | AWDEN             | RW     | Analog watchdog enable bit on regular channels:  0: Disable analog watchdog on regular channels;  1: Enable analog watchdog on regular channels.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0           |  |  |  |  |
| 22      | JAWDEN            | RW     | Analog watchdog enable bit on injected channels:  0: Disable analog watchdog on injected channels;  1: Enable analog watchdog on injected channels.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0           |  |  |  |  |
| [21:20] | Reserved          | RO     | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0           |  |  |  |  |
| [19:16] | DUALMOD<br>[3:0]  | RW     | Dual mode selection: 0000: Independent mode; 0001: Regular simultaneous mode + Injected simultaneous mode;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0           |  |  |  |  |

|         |              |    | 0010: Regular simultaneous mode + Alternate trigger mode; 0011: Injected simultaneous mode + Fast interleaved mode; 0100: Injected simultaneous mode + Slow interleaved mode; 0101: Injected simultaneous mode 0110: Regular simultaneous mode 0111: Fast interleaved mode; 1000: Slow interleaved mode; 1000: Slow interleaved mode; 1001: Alternate trigger mode.  Note: These bits in ADC2 are reserved. Modification of a configuration bit must be performed when dual mode is disabled. |   |
|---------|--------------|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| [15:13] | DISCNUM[2:0] | RW | In discontinuous mode, the number of regular channels to be converted after external trigger:  000: 1 channel;   111: 8 channels.                                                                                                                                                                                                                                                                                                                                                             | 0 |
| 12      | JDISCEN      | RW | Discontinuous mode enable bit on injected channel:  0: Disable discontinuous mode on the injected channel;  1: Enable discontinuous mode on the injected channel.                                                                                                                                                                                                                                                                                                                             | 0 |
| 11      | DISCEN       | RW | Discontinuous mode enable bit on the regular channel:  0: Disable discontinuous mode on the regular channel;  1: Enable discontinuous mode on the regular channel.                                                                                                                                                                                                                                                                                                                            | 0 |
| 10      | JAUTO        | RW | After regular channel is enabled, automatically injected channel group conversion enable bit:  0: Disable automatic injected channel group conversion;  1: Enable automatic injected channel group conversion.  Note: The external trigger function of the injected channel needs to be disabled in this mode.                                                                                                                                                                                | 0 |
| 9       | AWDSGL       | RW | In scan mode, analog watchdog enable bit on a single channel:  0: Disable analog watchdog on all channels;  1: Enable analog watchdog on single channel (AWDCH[4:0] selection).                                                                                                                                                                                                                                                                                                               | 0 |
| 8       | SCAN         | RW | Scan mode enable bit: 0: Disable scan mode; 1: Enable scan mode (Continuous conversion of all channels selected by ADC_IOFRx and ADC_RSQRx).                                                                                                                                                                                                                                                                                                                                                  | 0 |
| 7       | JEOCIE       | RW | Injected channel group conversion completion interrupt enable bit:  0: Disable injected channel group transfer completion interrupt;  1: Enable injected channel group transfer completion interrupt (IEOC flag).                                                                                                                                                                                                                                                                             | 0 |
| 6       | AWDIE        | RW | Analog watchdog interrupt enable bit:  0: Disable analog watchdog interrupt;  1: Enable analog watchdog interrupt.                                                                                                                                                                                                                                                                                                                                                                            | 0 |

V2. 4 187 WH

|       |            |    | Note: In scan mode, if this interrupt occurs, the scan will be aborted.                                                                                                           |   |
|-------|------------|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| 5     | EOCIE      | RW | Conversion completion (Regular or injected channel group) interrupt enable bit;  0: Disable the transfer completion interrupt;  1: Enable the transfer completion bit (EOC flag). | 0 |
| [4:0] | AWDCH[4:0] | RW | Analog watchdog channel selection bit: 00000: Analog input channel0; 00001: Analog input channel1; 10001: Analog input channel17.                                                 | 0 |

# 12.3.3 ADCx Control Register2 (ADCx\_CTLR2) (x=1/2)

Offset address: 0x08

| 31           | 30  | 29    | 28    | 27        | 26   | 25   | 24  | 23          | 22          | 21           | 20          | 19         | 18     | 17       | 16           |
|--------------|-----|-------|-------|-----------|------|------|-----|-------------|-------------|--------------|-------------|------------|--------|----------|--------------|
|              |     |       | Rese  | erved     |      |      |     | TS<br>VREFE | SW<br>START | JSW<br>START | EXT<br>TRIG | EX         | TSEL[2 | 2:0]     | Reser<br>ved |
| 15           | 14  | 13    | 12    | 11        | 10   | 9    | 8   | 7           | 6           | 5            | 4           | 3          | 2      | 1        | 0            |
| JEXT<br>TRIG | JEX | KTSEL | [2:0] | ALIG<br>N | Rese | rved | DMA |             | Rese        | erved        |             | RST<br>CAL | CAL    | CON<br>T | ADO<br>N     |

| Bit     | Name                                                                                                                                                                                                                                                                                                | Access | Description                                                                                                                                                                                                                                 | Reset value |  |  |
|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--|--|
| [31:24] | Reserved                                                                                                                                                                                                                                                                                            | RO     | Reserved.                                                                                                                                                                                                                                   | 0           |  |  |
| 23      | TSVREFE                                                                                                                                                                                                                                                                                             | RW     | Temperature sensor and internal voltage ( $V_{REFINT}$ ) channel enable:  0: Disable the temperature sensor and $V_{REFINT}$ channel;  1: Enable the temperature sensor and $V_{REFINT}$ channel.  Note: This bit is only applied for ADC1. | 0           |  |  |
| 22      | SWSTART  SWSTART  RW  Start conversion of a regular channel, set by software to start:  0: Reset status;  1: Start conversion of a regular channel.  This bit is set by software, and cleared by hardware after the conversion starts.  Start conversion of an injected channel, set by software to |        |                                                                                                                                                                                                                                             |             |  |  |
| 21      | JSWSTART                                                                                                                                                                                                                                                                                            | RW     | Start conversion of an injected channel, set by software to start:  0: Reset status;  1: Start conversion of an injected channels.  This bit is set by software, and cleared by hardware or software after the conversion starts.           | 0           |  |  |
| 20      | EXTTRIG  EXTTRIG  External trigger conversion mode enable for regular channels:  0: Disable conversion on external event;  1: Enable conversion on external event.                                                                                                                                  |        | 0                                                                                                                                                                                                                                           |             |  |  |
| [19:17] | EXTSEL[2:0]                                                                                                                                                                                                                                                                                         | RW     | External trigger event select for regular channel:                                                                                                                                                                                          | 0           |  |  |

V2. 4 188 WH°

|           |              |      | 000: CC1 event of timer 1;                                     |   |  |  |  |  |  |
|-----------|--------------|------|----------------------------------------------------------------|---|--|--|--|--|--|
|           |              |      | 001: CC2 event of timer 1;                                     |   |  |  |  |  |  |
|           |              |      | 010: CC3 event of timer 1;                                     |   |  |  |  |  |  |
|           |              |      | 011: CC2 event of timer 2;                                     |   |  |  |  |  |  |
|           |              |      | 100: TRGO event of timer 3;                                    |   |  |  |  |  |  |
|           |              |      | 101: CC4 event of timer 4;                                     |   |  |  |  |  |  |
|           |              |      | 110: EXTI line11/ TRGO event of timer8;                        |   |  |  |  |  |  |
|           |              |      | 111: SWSTART software trigger.                                 |   |  |  |  |  |  |
|           |              |      | Note: Only high-density devices have TRGO event in timer8.     |   |  |  |  |  |  |
| 16 R      | Reserved     | RO   | Reserved                                                       | 0 |  |  |  |  |  |
|           |              |      | External trigger conversion mode enable for injected           |   |  |  |  |  |  |
| 15 J      | EVTTDIC      | RW   | channels:                                                      | 0 |  |  |  |  |  |
| 13 J      | EXTTRIG      | ΚW   | 0: Disable conversion on external event;                       | 0 |  |  |  |  |  |
|           |              |      | 1: Enable conversion on external event.                        |   |  |  |  |  |  |
|           |              |      | External trigger event select for injected channels:           |   |  |  |  |  |  |
|           |              |      | 000: TRGO event of timer 1;                                    |   |  |  |  |  |  |
|           |              |      | 001: CC4 event of timer 1;                                     |   |  |  |  |  |  |
|           |              |      | 010: TRGO event of timer 2;                                    |   |  |  |  |  |  |
| [14 12] I | EVECEL [2 0] | DW   | 011: CC1 event of timer 2;                                     | 0 |  |  |  |  |  |
| [14:12] J | EXTSEL[2:0]  | RW   | 100: CC4 event of timer 3;                                     | 0 |  |  |  |  |  |
|           |              |      | 101: TRGO event of timer 4;                                    |   |  |  |  |  |  |
|           |              |      | 110: EXTI line 15/CC4 event of timer8;                         |   |  |  |  |  |  |
|           |              |      | 111: JSWSTART software trigger.                                |   |  |  |  |  |  |
|           |              |      | Note: Only high-density devices have CC4 event in timer8.      |   |  |  |  |  |  |
|           |              |      | Data alignment:                                                |   |  |  |  |  |  |
| 11 A      | ALIGN        | RW   | 0: Right alignment;                                            | 0 |  |  |  |  |  |
|           |              |      | 1: Left alignment.                                             |   |  |  |  |  |  |
| [10:9] R  | Reserved     | RO   | Reserved.                                                      | 0 |  |  |  |  |  |
|           |              |      | Direct memory access (DMA) mode enable:                        |   |  |  |  |  |  |
| 8 [       | OMA          | RW   | 0: Disable DMA mode;                                           | 0 |  |  |  |  |  |
|           |              |      | 1: Enable DMA mode.                                            |   |  |  |  |  |  |
| [7:4] R   | Reserved     | RO   | Reserved.                                                      | 0 |  |  |  |  |  |
|           |              |      | Reset calibration, this bit is set by software, and cleared by |   |  |  |  |  |  |
|           |              |      | hardware after reset:                                          |   |  |  |  |  |  |
|           |              |      | 0: The calibration register initialized;                       |   |  |  |  |  |  |
| 3 R       | RSTCAL       | RW   | 1: Initialize calibration register.                            | 0 |  |  |  |  |  |
|           |              |      | Note: If RSTCAL is set while the conversion is in progress,    |   |  |  |  |  |  |
|           |              |      | it takes extra cycles to clear the calibration register.       |   |  |  |  |  |  |
|           |              |      | A/D calibration, set by software and cleared by hardware       |   |  |  |  |  |  |
| 2         |              | D.W. | when the calibration is completed.                             | • |  |  |  |  |  |
| 2         | CAL          | RW   | 0: Calibration completed;                                      | 0 |  |  |  |  |  |
|           |              |      | 1: Enable the calibration.                                     |   |  |  |  |  |  |
|           |              |      |                                                                |   |  |  |  |  |  |
|           |              |      | Continuous conversion enable:                                  |   |  |  |  |  |  |
| 1 0       | CONT         | RW   | O: Single conversion mode ;                                    | 0 |  |  |  |  |  |

V2. 4 189 WCH°

|   |      |       | If this bit is set, the conversion will continue until the bit is |   |
|---|------|-------|-------------------------------------------------------------------|---|
|   |      |       | cleared.                                                          |   |
|   |      |       | A/D converter ON/OFF                                              |   |
|   |      |       | When this bit is 0, writing 1 will wake up the ADC from           |   |
|   |      |       | power-down mode; when this bit is 1, writing 1 will start         |   |
|   |      | RW    | the conversion.                                                   |   |
| 0 | ADON |       | 0: Disable ADC conversion/calibration, and go to power            | 0 |
|   | ADON | IX VV | down mode;                                                        | U |
|   |      |       | 1: Enable ADC and to start conversion.                            |   |
|   |      |       | Note: When only ADON changes in the register, a                   |   |
|   |      |       | conversion will be started. If any other bits are sent to         |   |
|   |      |       | change, a new conversion will not be started.                     |   |

# 12.3.4 ADCx Sample Time Configuration Register 1 (ADCx\_SAMPTR1) (x=1/2)

Offset address: 0x0C

| 31                     | 30 | 29 | 28    | 27  | 26 | 25   | 24 | 23         | 22  | 21 | 20         | 19  | 18 | 17         | 16  |
|------------------------|----|----|-------|-----|----|------|----|------------|-----|----|------------|-----|----|------------|-----|
|                        |    |    | Reser | ved |    |      |    | SMP17[2:0] |     |    | SMP16[2:0] |     |    | SMP15[2:1] |     |
| 15                     | 14 | 13 | 12    | 11  | 10 | 9    | 8  | 7          | 6   | 5  | 4          | 3   | 2  | 1          | 0   |
| SMP15[0] SMP14[2:0] SM |    |    |       |     |    | 2:0] | SN | лР12[2     | :0] | SN | лР11[2     | :0] | SN | лР10[2     | :0] |

| Bit     | Name      | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Reset value |
|---------|-----------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:24] | Reserved  | RO     | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0           |
| [23:0]  | SMPx[2:0] | RW     | SMPx[2:0]: Sample time configuration of channel x: 000: 1.5 cycles; 001: 7.5 cycles; 010: 13.5 cycles; 011: 28.5 cycles; 100: 41.5 cycles; 101: 55.5 cycles; 110: 71.5 cycles; 111: 239.5 cycles; MPx[2:0]: the sample time configuration for channel x when the ADC_SMP_SELx bit is set (only for CH32F20x_D8, CH32F20x_D8C, CH32V30x_D8, CH32V30x_D8C, CH32V31x_D8C products where the penultimate sixth bit of the batch number is not 0): 000: 1.5 cycles; 011: 28.5 cycles; 100: 2.5 cycles; 111: 5.5 cycles; 111: 5.5 cycles; These bits are used to independently select the sample time of each channel, and the channel configuration value must remain unchanged during the sampling period. |             |

# 12.3.5 ADCx Sample Time Configuration Register 2 (ADCx\_SAMPTR2) (x=1/2)

Offset address: 0x10

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16

| Reserve | ed        | SMP9[2:0] |    | ]         | SMP8[2:0] |           |   | SMP7[2:0] |           |   | SI | MP6[2:    | 0] | SMP | 5[2:1] |
|---------|-----------|-----------|----|-----------|-----------|-----------|---|-----------|-----------|---|----|-----------|----|-----|--------|
| 15      | 14        | 13        | 12 | 11        | 10        | 9         | 8 | 7         | 6         | 5 | 4  | 3         | 2  | 1   | 0      |
| SMP5[0] | SMP4[2:0] |           | S  | SMP3[2:0] |           | SMP2[2:0] |   |           | SMP1[2:0] |   |    | SMP0[2:0] |    |     |        |

| Bit     | Name      | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Reset value |
|---------|-----------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:30] | Reserved  | RO     | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0           |
| [29:0]  | SMPx[2:0] | RW     | SMPx[2:0]: Sample time configuration of channel x: 000: 1.5 cycles; 001: 7.5 cycles; 010: 13.5 cycles; 011: 28.5 cycles; 100: 41.5 cycles; 101: 55.5 cycles; 110: 71.5 cycles; 111: 239.5 cycles; MPx[2:0]: the sample time configuration for channel x when the ADC_SMP_SELx bit is set (only for CH32F20x_D8, CH32F20x_D8C, CH32V30x_D8, CH32V30x_D8C, CH32V31x_D8C products where the penultimate sixth bit of the batch number is not 0): 000: 1.5 cycles; 001: 7.5 cycles; 010: 13.5 cycles; 011: 28.5 cycles; 100: 2.5 cycles; 101: 3.5 cycles; 111: 5.5 cycles; These bits are used to independently select the sample time of each channel, and the channel configuration value must remain unchanged during the sampling period. |             |

# 12.3.6 ADCy Injected Channel Data Offset Register (ADCy\_IOFRx) (y=1/2; x=1/2/3/4)

Offset address: 0x14 + (x-1)\*4

| 31 | 30       | 29 | 28 | 27 | 26             | 25 | 24   | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----------|----|----|----|----------------|----|------|-------|----|----|----|----|----|----|----|
|    |          |    |    |    |                |    | Rese | erved |    |    |    |    |    |    |    |
| 15 | 14       | 13 | 12 | 11 | 10             | 9  | 8    | 7     | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    | Reserved |    |    |    | JOFFSETx[11:0] |    |      |       |    |    |    |    |    |    |    |

| Ï | Bit     | Name           | Access | Description                                               | Reset value |
|---|---------|----------------|--------|-----------------------------------------------------------|-------------|
| Ī | [31:12] | Reserved       | RO     | Reserved.                                                 | 0           |
| Ī |         |                |        | Data offset for injected channel x.                       |             |
| ١ |         |                |        | When the injected channel is converted, these bits define |             |
| l | [11:0]  | JOFFSETx[11:0] | RW     | the value to be subtracted from the original conversion   | 0           |
| ١ |         |                |        | data. The result of the conversion can be read in the     |             |
| ١ |         |                |        | ADC_IDATARx register                                      |             |

# 12.3.7 ADCx Watchdog High Threshold Register (ADCx\_WDHTR) (x=1/2)

Offset address: 0x24

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 Reserved

| 15 | 14 13    | 12 | 11 | 10 | 9 | 8 | 7 | 6  | 5      | 4 | 3 | 2 | 1 | 0 |
|----|----------|----|----|----|---|---|---|----|--------|---|---|---|---|---|
|    | Reserved |    |    |    |   | _ |   | HT | [11:0] |   |   |   |   |   |

| Bit     | Name     | Access | Description                              | Reset value |
|---------|----------|--------|------------------------------------------|-------------|
| [31:12] | Reserved | RO     | Reserved.                                | 0           |
| [11:0]  | HT[11:0] | RW     | Analog watchdog high threshold set bits. | FFFh        |

Note: The values of WDHTR and WDLTR can be changed during the conversion, but they will take effect in the next conversion.

# 12.3.8 ADCx Watchdog Low Threshold Register (ADCx\_WDLTR) (x=1/2)

Offset address: 0x28

| 31 | 30       | 29 | 28 | 27 | 26 | 25 | 24   | 23    | 22 | 21     | 20 | 19 | 18 | 17 | 16 |
|----|----------|----|----|----|----|----|------|-------|----|--------|----|----|----|----|----|
|    |          | -  |    |    |    | -  | Rese | erved |    | _      |    | -  | -  | -  |    |
| 15 | 14       | 13 | 12 | 11 | 10 | 9  | 8    | 7     | 6  | 5      | 4  | 3  | 2  | 1  | 0  |
|    | Reserved |    |    |    |    |    |      |       | LT | [11:0] |    |    |    |    |    |

| Bit     | Name     | Access | Description                             | Reset value |
|---------|----------|--------|-----------------------------------------|-------------|
| [31:12] | Reserved | RO     | Reserved.                               | 0           |
| [11:0]  | LT[11:0] | RW     | Analog watchdog low threshold set bits. | 0           |

Note: The values of WDHTR and WDLTR can be changed during the conversion, but they will take effect in the next conversion.

# 12.3.9 ADCx Regular Channel Sequence Register1 (ADCx\_RSQR1) (x=1/2)

Offset address: 0x2C

| 31      | 30       | 29 | 28     | 27   | 26 | 25 | 24 | 23     | 22   | 21 | 20         | 19 | 18     | 17 | 16 |
|---------|----------|----|--------|------|----|----|----|--------|------|----|------------|----|--------|----|----|
|         | Reserved |    |        |      |    |    |    | L[3    | 3:0] |    | RSQ16[4:1] |    |        |    |    |
| 15      | 14       | 13 | 12     | 11   | 10 | 9  | 8  | 7      | 6    | 5  | 4          | 3  | 2      | 1  | 0  |
| SQ16[0] |          |    | SQ15[4 | 1:0] |    |    | S  | Q14[4: | 0]   |    |            | S  | Q13[4: | 0] |    |

| Bit     | Name      | Access | Description                                                      | Reset value |
|---------|-----------|--------|------------------------------------------------------------------|-------------|
| [31:24] | Reserved  | RO     | Reserved.                                                        | 0           |
|         |           |        | The quantity of channels to be converted in the regular          |             |
| [23:20] | L[3:0]    | RW     | channel conversion sequence:                                     | 0           |
|         |           |        | 0000-1111: 1 to 16 converted channels.                           |             |
| [19:15] | SQ16[4:0] | RW     | No. (0 to 17) of the 16th converted channel in regular sequence. | 0           |
| [14:10] | SQ15[4:0] | RW     | No. (0 to 17) of the 15th converted channel in regular sequence. | 0           |
| [9:5]   | SQ14[4:0] | RW     | No. (0 to 17) of the 14th converted channel in regular sequence. | 0           |
| [4:0]   | SQ13[4:0] | RW     | No. (0 to 17) of the 13th converted channel in regular sequence. | 0           |

## 12.3.10 ADCx Regular Channel Sequence Register2 (ADCx\_RSQR2) (x=1/2)

Offset address: 0x30

| 31 30    | 29 | 28 | 27 | 26  | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18   | 17     | 16 |
|----------|----|----|----|-----|----|----|----|----|----|----|----|------|--------|----|
| Reserved |    | S  |    | [0] |    |    | S  |    | 0] |    |    | SQ10 | )[4:1] |    |

| 15      | 14 | 13 | 12     | 11  | 10 | 9 | 8 | 7      | 6  | 5 | 4 | 3 | 2      | 1   | 0 |
|---------|----|----|--------|-----|----|---|---|--------|----|---|---|---|--------|-----|---|
| SQ10[0] |    |    | SQ9[4: | :0] |    |   | S | Q8[4:0 | )] |   |   | S | Q7[4:0 | ) [ |   |

| Bit     | Name      | Access | Description                                                      | Reset value |
|---------|-----------|--------|------------------------------------------------------------------|-------------|
| [31:30] | Reserved  | RO     | Reserved.                                                        | 0           |
| [29:25] | SQ12[4:0] | RW     | No. (0 to 17) of the 12th converted channel in regular sequence. | 0           |
| [24:20] | SQ11[4:0] | RW     | No. (0 to 17) of the 11th converted channel in regular sequence. | 0           |
| [19:15] | SQ10[4:0] | RW     | No. (0 to 17) of the 10th converted channel in regular sequence. | 0           |
| [14:10] | SQ9[4:0]  | RW     | No. (0 to 17) of the 9th converted channel in regular sequence.  | 0           |
| [9:5]   | SQ8[4:0]  | RW     | No. (0 to 17) of the 8th converted channel in regular sequence.  | 0           |
| [4:0]   | SQ7[4:0]  | RW     | No. (0 to 17) of the 7th converted channel in regular sequence.  | 0           |

# 12.3.11 ADCx Regular Channel Sequence Register 3 (ADCx\_RSQR3) (x=1/2)

Offset address: 0x34

| 31      | 30                | 29 | 28    | 27  | 26 | 25 | 24       | 23 | 22      | 21 | 20       | 19 | 18      | 17 | 16 |
|---------|-------------------|----|-------|-----|----|----|----------|----|---------|----|----------|----|---------|----|----|
| Reserve | Reserved SQ6[4:0] |    |       |     |    |    |          | S  | SQ5[4:0 | )] | SQ4[4:1] |    |         |    |    |
| 15      | 14                | 13 | 12    | 11  | 10 | 9  | 8        | 7  | 6       | 5  | 4        | 3  | 2       | 1  | 0  |
| SQ4[0]  |                   |    | SQ3[4 | :0] |    |    | SQ2[4:0] |    |         |    |          | S  | SQ1[4:0 | )] |    |

| Bit     | Name     | Access | Description                                                     | Reset value |
|---------|----------|--------|-----------------------------------------------------------------|-------------|
| [31:30] | Reserved | RO     | Reserved                                                        | 0           |
| [29:25] | SQ6[4:0] | RW     | No. (0 to 17) of the 6th converted channel in regular sequence. | 0           |
| [24:20] | SQ5[4:0] | RW     | No. (0 to 17) of the 5th converted channel in regular sequence. | 0           |
| [19:15] | SQ4[4:0] | RW     | No. (0 to 17) of the 4th converted channel in regular sequence. | 0           |
| [14:10] | SQ3[4:0] | RW     | No. (0 to 17) of the 3th converted channel in regular sequence. | 0           |
| [9:5]   | SQ2[4:0] | RW     | No. (0 to 17) of the 2nd converted channel in regular sequence. | 0           |
| [4:0]   | SQ1[4:0] | RW     | No. (0 to 17) of the 1st converted channel in regular sequence. | 0           |

# 12.3.12 ADCx Injected Channel Sequence Register (ADCx\_ISQR) (x=1/2)

Offset address: 0x38

| 31      | 30        | 29 | 28 | 27 | 26 | 25        | 24 | 23 | 22 | 21  | 20        | 19 | 18   | 17         | 16 |
|---------|-----------|----|----|----|----|-----------|----|----|----|-----|-----------|----|------|------------|----|
|         | Reserved  |    |    |    |    |           |    |    |    | JL[ | 1:0]      |    | JSQ4 | ·<br>[4:1] |    |
| 15      | 14        | 13 | 12 | 11 | 10 | 9         | 8  | 7  | 6  | 5   | 4         | 3  | 2    | 1          | 0  |
| JSQ4[0] | JSQ3[4:0] |    |    |    |    | JSQ2[4:0] |    |    |    |     | JSQ1[4:0] |    |      |            |    |

| Bit     | Name      | Access | Description                                                                                                              | Reset value |
|---------|-----------|--------|--------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:22] | Reserved  | RO     | Reserved.                                                                                                                | 0           |
| [21:20] | JL[1:0]   |        | The quantity of channels to be converted in the injected channel conversion sequence:  00-11: 1 to 4 converted channels. | 0           |
| [19:15] | JSQ4[4:0] | RW     | No. (0 to 17) of the 4th converted channel in injected sequence.                                                         | 0           |

|         |           |    | Note: The software writes and assigns the channel number (0-     |   |
|---------|-----------|----|------------------------------------------------------------------|---|
|         |           |    | 17) as the 4th in the sequence to be converted.                  |   |
| [14:10] | JSQ3[4:0] | RW | No. (0 to 17) of the 3rd converted channel in injected sequence. | 0 |
| [9:5]   | JSQ2[4:0] | RW | No. (0 to 17) of the 2nd converted channel in injected sequence. | 0 |
| [4:0]   | JSQ1[4:0] | RW | No. (0 to 17) of the 1st converted channel in injected sequence. | 0 |

Note: Different from regular conversion sequence, if the length of JL[1:0] is less than 4, the sequence of conversion will start from (4-JL).

For example, when JL[1:0]=3 (4 injected transitions in the sequencer), the ADC will convert channels in the following order: JSQ1[4:0], JSQ2[4:0], JSQ3[4:0], and JSQ4[4:0];

When JL[1:0]=2 (3 injected transitions in the sequencer), the ADC will convert the channels in the following order: JSQ2[4:0], JSQ3[4:0] and JSQ4[4:0];

When JL[1:0]=1 (2 injected conversions in the sequencer), the ADC converts the channels in the following order: first JSQ3[4:0], then JSQ4[4:0];

When JL[1:0] = 0 (1 injection conversion in the sequencer), the ADC will convert only the JSQ4[4:0] channels. If  $ADCx\_ISQR[21:0] = 10\ 00111\ 00011\ 00111\ 00010$ , the ADC will convert channels in the following order: JSQ2[4:0], JSQ3[4:0], and JSQ4[4:0], indicating that the scan conversions are performed in the following channel order: 7, 3, 7.

### 12.3.13 ADCy Injected Data Register (ADCy\_IDATARx) (y=1/2; x=1/2/3/4)

Offset address: 0x3C + (x-1)\*4

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24    | 23      | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|-------|---------|----|----|----|----|----|----|----|
|    |    |    |    |    |    |    | Rese  | rved    |    |    | ,  |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8     | 7       | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    |    | JDAT/ | A[15:0] |    |    |    |    |    |    |    |

| Bit     | Name        | Access | Description                                                               | Reset value |
|---------|-------------|--------|---------------------------------------------------------------------------|-------------|
| [31:16] | Reserved    | RO     | Reserved.                                                                 | 0           |
| [15:0]  | JDATA[15:0] | R()    | Injected channel converted data (data left alignment or right alignment). | 0           |

## 12.3.14 ADCx Regular Data Register (ADCx\_RDATAR) (x=1/2)

Offset address: 0x4C

| _ 31 | 30             | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|      | ADC2DATA[15:0] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15   | 14             | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|      | DATA[15:0]     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit     | Name           | Access | Description                                                                                                                         | Reset value |
|---------|----------------|--------|-------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:16] | ADC2DATA[15:0] | RO     | ADC2 converted data: ADC1: These bits store the regular channel data converted by ADC2 in dual mode. ADC2: These bits are not used. | 0           |
| [15:0]  | DATA[15:0]     | RO     | Regular channel converted data (Data left or right alignment).                                                                      | 0           |

# 12.3.15 ADCx Sample Time Register (ADCx\_AUX) (x=1/2)

Offset address: 0x54

| 31                      | 30                         | 29 | 28                        | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18                        | 17                        | 16 |
|-------------------------|----------------------------|----|---------------------------|----|----|----|----|----|----|----|----|----|---------------------------|---------------------------|----|
|                         |                            |    |                           |    |    |    |    |    |    |    |    |    | ADC<br>_SMP<br>_SEL<br>17 | ADC<br>_SMP<br>_SEL<br>16 |    |
| 15                      | 14                         | 13 | 12                        | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2                         | 1                         | 0  |
| ADC<br>SMP<br>SEL<br>15 | ADC<br>_SMP<br>_SEL<br>_14 |    | ADC<br>_SMP<br>_SEL<br>12 |    |    |    |    |    |    |    | _  |    |                           | ADC<br>_SMP<br>_SEL<br>1  |    |

| Bit     | Name        | Access | Description                                                                                                                                                                                                                                                                                         | Reset value |
|---------|-------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:18] | Reserved    | R0     | Reserved                                                                                                                                                                                                                                                                                            | 0           |
| [17:0]  | ADC_SMP_SEL | RW     | x=0-17, sample time optional enable bit for channel x (Only if SMPx is 100-111):  0: Sample time is the corresponding SMPx configuration cycle;  1: SMPx=100: sampling time 2.5 cycles; SMPx=101: sampling time 3.5 cycles; SMPx=110: sampling time 4.5 cycles; SMPx=111: sampling time 5.5 cycles. | 0           |

Note: The ADCx\_AUX register is only available for CH32F20x\_D8, CH32F20x\_D8C, CH32V30x\_D8, CH32V30x\_D8C, and CH32V31x\_D8C lot numbers that do not have a zero in the penultimate sixth bit.

V2. 4 195 WCH<sup>®</sup>

# **Chapter 13 Touch Key Detection (TKEY)**

This chapter applies to the whole family of CH32F20x, CH32V20x, CH32V30x and CH32V31x.

The Touch Key Detection control (TKEY) unit implements the touch-key detection function by converting the capacitance to the voltage for sampling, with the help of the voltage conversion function of the ADC module. The detection channel multiplexes the 16 external channels of the ADC. It implements the touch-key detection through the single conversion mode of ADC.

# 13.1 Functional Description

#### Enable TKEY

For TKEY detection, the ADC module is needed. To enable TKEY, ensure that ADC is powered on (ADON=1), then set the TKENABLE bit in the ADC\_CTLR1 register to 1. The charge current of the TKEY module can be adjusted by the TKITUNE bit.

TKEY only supports single 1-channel conversion mode, which configures the channel to be converted as the first channel in the regular sequence of ADC. And software starts conversion (Write to TKEY ACT DCG).

Note: When the TKEY conversion is disabled, ADC channel configuration function can still be retained.



Figure 13-1 TKEY working timing diagram

### Programmable sampling time

For TKEY unit conversion, multiple ADCCLK clock cycles (t<sub>DISCHG</sub>) need to be used for discharge, then charge and sample voltage on the channel through multiple ADCCLK cycles (t<sub>CHG</sub>). The charge cycle is the total of the configuration values of the TKCGx[2:0] bits in the TKEY\_CHARGE1register and the TKEY\_CHARGE2 register and the offset value of TKEY\_CHGOFFSET. For each channel, different charge cycles can be used to adjust sampling voltage.

# 13.2 TKEY Operations

TKEY detection is an extended function of ADC module. Its working principle is to change the capacitance sensed by the hardware channel through "touch" and "non-touch" methods, and then to convert the capacitance change into the voltage change and finally convert into a digital value by the ADC module.

During sample, ADC needs to be configured as a single 1-channel working mode, and a conversion is started by the "write operation" of the TKEY ACT register. The specific process is as follows:

- 1) Initialize the ADC function, configure the ADC module as a single conversion module, set the ACON bit to 1, and wake up the ADC module. Set the TKENABLE bit in the ADC\_CTLR1 register to 1, and switch on the TKEY unit.
- 2) Set the channel to be converted, write the channel serial number into the first conversion position in the ADC regular group sequence (ADC RSQR3[4:0]), and set L[3:0] to 1.
- 3) Set the charge sample time of the channel, write to the TKEY\_CHARGEx register, to configure different charge times for each channel.
- 4) Write to TKEY\_CHGOFFSET, set the offset charge time of the channel (Low 8 bits active), to adjust the charge time.
- 5) Write to TKEY\_ACT\_DCG, set the discharge time (Low 8 bits active), to start a TKEY sample and conversion.
- 6) Wait for the EOC conversion end flag bit in the ADC status register to be set to 1, read the ADC\_DR register to obtain the conversion value.
- 7) To perform next conversion, repeat steps 2-6. If you do not need to modify the channel discharge time or charge sampling time, you can skip step 3 or 4.

# 13.3 TKEY Register Description

Table 13-1 TKEY1 registers

| Name                | Access address                   | Description                               | Reset value |
|---------------------|----------------------------------|-------------------------------------------|-------------|
| R32_TKEY1_CHARGE1   | 0x4001240C                       | TKEY charge sample time register1         | 0x00000000  |
| R32_TKEY1_CHARGE2   | 0x40012410                       | TKEY charge sample time register2         | 0x00000000  |
| R32_TKEY1_CHGOFFSET | TKEY charge time offset register | 0x00000000                                |             |
| R32_TKEY1_ACT_DCG   | 0x4001244C                       | TKEY activate and discharge time register | X           |
| R32_TKEY1_DR        | 0x4001244C                       | TKEY data register                        | X           |

Table 13-2 TKEY2 registers

| Name                | Access address | Description                               | Reset value |  |  |
|---------------------|----------------|-------------------------------------------|-------------|--|--|
| R32_TKEY2_CHARGE1   | 0x4001280C     | TKEY charge sample time register1         | 0x00000000  |  |  |
| R32_TKEY2_CHARGE2   | 0x40012810     | TKEY charge sample time register2         | 0x00000000  |  |  |
| R32_TKEY2_CHGOFFSET | 0x4001283C     | TKEY charge time offset register          | 0x00000000  |  |  |
| R32_TKEY2_ACT_DCG   | 0x4001284C     | TKEY activate and discharge time register | X           |  |  |
| R32_TKEY2_DR        | 0x4001284C     | TKEY data register                        | X           |  |  |

### 13.3.1 TKEYx Charge Sample Time Register 1 (TKEYx CHARGE1) (x=1/2)

Offset address: 0x0C

| 31       | 30               | 29 | 28          | 27 | 26 | 25 | 24          | 23          | 22 | 21          | 20          | 19 | 18          | 17               | 16 |
|----------|------------------|----|-------------|----|----|----|-------------|-------------|----|-------------|-------------|----|-------------|------------------|----|
| Reserved |                  |    |             |    |    |    |             | TKCG17[2:0] |    |             | :0] TKCG16[ |    |             | 2:0] TKCG15[2:1] |    |
| 15       | 14               | 13 | 12          | 11 | 10 | 9  | 8           | 7           | 6  | 5           | 4           | 3  | 2           | 1                | 0  |
| TKCG15   | CG15 TKCG14[2:0] |    | TKCG13[2:0] |    |    | TK | TKCG12[2:0] |             |    | TKCG11[2:0] |             |    | TKCG10[2:0] |                  |    |

| Bit     | Name       | Access | Description                                     | Reset value |
|---------|------------|--------|-------------------------------------------------|-------------|
| [31:24] | Reserved   | RO     | Reserved                                        | 0           |
|         |            |        | TKCGx[2:0] (x=10-17): Select the charge sample  |             |
|         |            |        | time of channelx                                |             |
|         |            |        | These bits are used to independently select the |             |
|         |            |        | charge time for each channel.                   |             |
| [23:0]  | TKCGx[2:0] | RW     | 000: 1.5 cycles 100: 41.5 cycles                | 0           |
|         |            |        | 001: 7.5 cycles 101: 55.5 cycles                |             |
|         |            |        | 010: 13.5 cycles 110: 71.5 cycles               |             |
|         |            |        | 011: 28.5 cycles 111: 239.5 cycles              |             |
|         |            |        | Time base: ADC clock.                           |             |

Note: This register maps the sample time register1 (ADC\_SAMPTR1) of the ADC module. When the ADC function is configured, it is the channel sample time. When the TKEY\_F function is configured, it is the channel charge time.

# 13.3.2 TKEYx Charge Sample Time Register 2 (TKEYx\_CHARGE2) (x=1/2)

Offset address: 0x10

| 31       | 30              | 29         | 28          | 27   | 26 | 25     | 24   | 23         | 22 | 21 | 20         | 19    | 18   | 17         | 16 |
|----------|-----------------|------------|-------------|------|----|--------|------|------------|----|----|------------|-------|------|------------|----|
| Reserved |                 | TKCG9[2:0] |             | 2:0] | TK | .CG8[2 | 2:0] | TKCG7[2:0] |    |    | TKCG6[2:0] |       |      | TKCG5[2:1] |    |
| 15       | 14              | 13         | 12          | 11   | 10 | 9      | 8    | 7          | 6  | 5  | 4          | 3     | 2    | 1          | 0  |
| TKCG5    | 5 TKCG4[2:0] TF |            | CG3[2:0] TK |      |    | CG2[2  | 2:0] | TKCG1[2:0] |    |    | Tŀ         | CG0[2 | 2:0] |            |    |

| Bit     | Name       | Access | Description                                     | Reset value |
|---------|------------|--------|-------------------------------------------------|-------------|
| [31:30] | Reserved   | RO     | Reserved                                        | 0           |
|         |            |        | TKCGx[2:0] (x=0-9): Select the charge sample    |             |
|         |            |        | time of channel x                               |             |
|         |            |        | These bits are used to independently select the |             |
|         |            |        | charge time for each channel.                   |             |
| [29:0]  | TKCGx[2:0] | RW     | 000: 1.5 cycles 100: 41.5 cycles                | 0           |
|         |            |        | 001: 7.5 cycles 101: 55.5 cycles                |             |
|         |            |        | 010: 13.5 cycles 110: 71.5 cycles               |             |
|         |            |        | 011: 28.5 cycles 111: 239.5 cycles              |             |
|         |            |        | Time base: ADC clock.                           |             |

Note: This register maps the sample time register1 (ADC\_SAMPTR2) of the ADC module. When the ADC function is configured, it is the channel sample time. When the TKEY\_F function is configured, it is the channel charge time.

# 13.3.3 TKEYx Charge Time Offset Register (TKEYx\_CHGOFFSET) (x=1/2)

Offset address: 0x3C

| 31 | 30       | 29 | 28 | 27 | 26 | 25 | 24 | 23              | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----------|----|----|----|----|----|----|-----------------|----|----|----|----|----|----|----|
|    | Reserved |    |    |    |    |    |    |                 |    |    |    |    |    |    |    |
| 15 | 14       | 13 | 12 | 11 | 10 | 9  | 8  | 7               | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    | Reserved |    |    |    |    |    |    | TKCGOFFSET[7:0] |    |    |    |    |    |    |    |

| Bit    | Name            | Access | Description                                 | Reset value |
|--------|-----------------|--------|---------------------------------------------|-------------|
| [31:8] | Reserved        | RO     | Reserved                                    | 0           |
|        |                 |        | TKEY charge time offset configuration value |             |
| [7:0]  | TKCGOFFSET[7:0] | WO     | Total charge time:                          | 0           |
|        |                 |        | TCHG=TKCGOFFSET+ TKCGx                      |             |

Note: This register maps the injected data register1 (ADC\_IDATAR1) of the ADC module. So when write operation is performed on this address register, it serves as TKEY charge time offset (TKEY\_CHGOFFSET). When read operation is performed, it serves as the injected data register1 (ADC\_IDATAR1) of the ADC module.

### 13.3.4 TKEYx Activate and Discharge Time Register (TKEYx\_ACT\_DCG) (x=1/2)

Offset address: 0x4C

| 31 | 30       | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21    | 20    | 19   | 18 | 17 | 16 |
|----|----------|----|----|----|----|----|----|----|----|-------|-------|------|----|----|----|
|    | Reserved |    |    |    |    |    |    |    |    |       |       |      |    |    |    |
| 15 | 14       | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5     | 4     | 3    | 2  | 1  | 0  |
|    | Reserved |    |    |    |    |    |    |    | Tŀ | KACT_ | DCG[7 | 7:0] |    |    |    |

| Bit    | Name           | Access | Description                                  | Reset value |
|--------|----------------|--------|----------------------------------------------|-------------|
| [31:8] | Reserved       | RO     | Reserved                                     | 0           |
| [7:0]  | TKACT DCG[7:0] | WO     | Write the discharge time and activate a TKEY | 0           |
|        | TRACI_DCU[7.0] | ***    | channel detection.                           | U           |

Note: This register maps the regular data register (ADC\_RDATAR) of the ADC module.

## 13.3.5 TKEYx Data Register (TKEYx\_DR) (x=1/2)

Offset address: 0x4C

| 31 | 30         | 29 | 28 | 27 | 26 | 25 | 24   | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|------------|----|----|----|----|----|------|-------|----|----|----|----|----|----|----|
|    |            |    |    |    |    |    | Rese | erved |    |    |    |    |    |    |    |
| 15 | 14         | 13 | 12 | 11 | 10 | 9  | 8    | 7     | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    | DATA[15:0] |    |    |    |    |    |      |       |    |    |    |    |    |    |    |

| Bit     | Name       | Access | Description     | Reset value |
|---------|------------|--------|-----------------|-------------|
| [31:16] | Reserved   | RO     | Reserved        | 0           |
| [15:0]  | DATA[15:0] | RO     | Converted data. | 0           |

Note: This register maps the regular data register (ADC\_RDATAR) of the ADC module.

V2. 4 199 WH

# **Chapter 14 Advanced-control Timer (ADTM)**

This chapter applies to the whole family of CH32F20x, CH32V20x, CH32V30x and CH32V31x.

The advanced-control timer module contains a powerful 16-bit auto-reload timer (TIM1, TIM8, TIM9 and TIM10), which can be used to measure pulse width or generate pulse and PWM wave, etc. It is used for fields of motor control and power, etc.

### 14.1 Main Features

Advanced-control timer (TIM1/8/9/10) features include:

- 16-bit auto-reload counter, supports up count, down count and up/down count;
- 16-bit prescaler; the frequency division factor is dynamically adjustable from 1 to 65536;
- Four independent compare/capture channels;
- Each compare/capture channel supports multiple working modes, such as: input capture, output compare, PWM generation and single pulse output;
- Complementary outputs with programmable deadband time;
- External signal to control timer;
- Repetition counter to update the timer after the determination of the cycle;
- Break signal input to put the timer's output signals in reset status or in a known status;
- DMA generation in multiple modes;
- Incremental encoder;
- Cascade connection and synchronization between timers

# 14.2 Principle and Structure

This section describes the internal structure of the advanced-control timer.

#### **14.2.1 Overview**

As shown in Figure 14-1, the structure of the advanced-control timer can be roughly divided into 3 parts: Input clock part, core counterpart and compare/capture channel part.

The advanced-control timer clock can come from PB bus clock (CK\_INT), external clock input pin (TIMx\_ETR), other timers with clock output function (ITRx), or the input end of compare capture channel (TIMx\_CHx). These input clock signals will become CK\_PSC clocks after various set filtering and frequency division operations, and will output to the core counterpart. In addition, these complex clock sources can also be output as TRGO to other peripherals such as timer, ADC and DAC.

The core of the advanced-control timer is a 16-bit counter (CNT). After CK\_PSC is divided by the prescaler (PSC), it becomes CK\_CNT and output to CNT. CNT supports up-counting mode, down-counting mode and up/down counting mode, and there is an automatic reload value register (ATRLR). After each counting cycle is completed, CNT will be reloaded with the initial value. In addition, there is an auxiliary counter that counts the number of times that ATRLR reloads the initial value for CNT. When the number of times reaches the number set in the repeat count register (RPTCR), a specific event can be generated.

The advanced-control timer has 4 groups of compare/capture channels. On each group of compare/capture channel, pulses can be inputted from its dedicated pins or output waveforms to the pins, i.e., the compare/capture channels support input and output modes. The input of each channel of the compare/capture register supports operations such as filtering, frequency division and edge detection, and supports mutual

triggering between channels, and can also provide a clock for the core counter CNT. Each compare/capture channel has a set of compare/capture register (CHxCVR), which supports comparison with the main counter (CNT) so as to output pulse.



Figure 14-1 Structure block diagram of advanced-control timer

#### 14.2.2 Clock Input

Figure 14-2 CK\_PSC source block diagram of advanced-control timer



There are many clock sources for advanced-control timer CK PSC, which can be divided into 4 categories:

- 1) The route of external clock pin (ETR) input clock: ETR→ETRP→ETRF;
- 2) Internal PB clock input route: CK INT;
- 3) The route from the compare/capture channel pin (TIMx\_CHx): TIMx\_CHx→TIx→TIxFPx; this route is also used in encoder mode;
- 4) Input from other internal timers: ITRx;

The actual operation can be divided into 4 categories by determining the input pulse selection of the SMS from the CK PSC source:

- 1) Select the internal clock source (CK\_INT);
- 2) External clock source mode 1;
- 3) External clock source mode 2;
- 4) Encoder mode;

The 4 clock sources mentioned above can be selected by these 4 operations.

#### 14.2.2.1 Internal clock source (CK INT)

If the advanced-control timer is started when the SMS field is kept at 000b, then the internal clock source (CK INT) is selected as the clock. At this moment, CK INT is CK PSC.

#### 14.2.2.2 External clock source mode1

If SMS is set to 111b, the external clock source mode1 is enabled. When external clock source 1 is enabled, TRGI is selected as the source of CK\_PSC. It is worth noting that you need to configure TS to select the source of TRGI. For TS, the following pulses can be used as the clock sources:

- 1) Internal Trigger (ITRx, x is 0,1,2,3);
- 2) Signal of compare/capture 1 after passing through the edge detector (TI1F ED);
- 3) Signals TI1FP1 and TI2FP2 of compare/capture channel;
- 4) Signal ETRF from external clock pin.

#### 14.2.2.3 External clock source mode2

Use external trigger mode2 to count on every rising or falling edge of the external clock pin input. When the ECE bit is set, the external clock source mode2 is used. When the external clock source mode2 is used, ETRF is selected as CK\_PSC. The ETR pin passes through the optional inverter (ETP) and frequency divider (ETPS) to become ETRP, and then passes through the filter (ETF) to become ETRF.

When ECE bit is set and the SMS is set to 111b, it means that the TS selects ETRF as the input.

#### **14.2.2.4 Encoder mode**

Set SMS as 001b, 010b and 011b to enable the encoder mode. After enabling the encoder mode, you may choose to use another transition edge as a signal for signal output at a certain level in TI1FP1 and TI2FP2. This mode is used when the external encoder is used. Refer to Section 14.3.9 for specific functions.

### 14.2.3 Counter and Periphery

CK\_PSC inputs to the prescaler (PSC) for frequency division. PSC is 16 bits, and the actual frequency division factor is equivalent to the value of R16\_TIMx\_PSC+1. CK\_PSC will become CK\_INT after PSC. The changed value of R16\_TIM1\_PSC will not take effect in real time, but will be updated to the PSC after the update event. Update events include clearing and resetting the UG bit. The core of the timer is a 16-bit counter (CNT). CK\_CNT will eventually be inputted to CNT. CNT supports up-counting mode, down-counting mode and up/down counting mode, and there is an automatic reload value register (ATRLR) which re-loads the initial value for CNT after each counting cycle is completed. In addition, there is an auxiliary counter that records the number of times that ATRLR reloads the initial value for CNT. When the number of times reaches the number set in the repeat count register (RPTCR), a specific event can be generated.

### 14.2.4 Compare/Capture Channel and Periphery

The compare/capture channel is the main component of the timer to achieve complex functions. Its core is the compare/capture register, supplemented by the digital filtering of the peripheral input part, frequency division and channel multiplexing, the output part comparator and output control.

To the slave mode controller TI1F\_Rising TI1 0 TI1F TI1FP1 Edge detector Filter TI1F\_Falling 01 downcounter Divider TI2FP1 10 /1,/2,/4,/8 CC1P/CC1NP ICF[3:0] **TRC** TIMx\_CCMR1 TIMx CCER (from slave mode controller) TI2F\_Rising (from channel 2) CC1S[1:0] | ICPS[1:0] CC1E TI2F\_Falling TIMx\_CCER (from channel 2) TIMx\_CHCTLR1 **PB Bus** MCU-peripheral interface 16-bit) high S Write CCR1H <u>≷</u> Read CCR1H Ξ write\_in\_progress read in progress R Write CCR1L Capture/compare preload register Read CCR1L R Output CC1S[1] apture\_transfer compare\_transfe mode CC1S[0] Input CC1S[1] mode OC1PE Capture/compare shadow register OC1PE UEV TIM1\_CHCTLR1 (from time Capture Comparator IC1PS base unit) CC1E Counter CC1G TIM1\_SWEVGR To the master mode controller\_ Output **ETRF** OC1 enable circuit OC1REFC OC1REF OC1\_DT CC1P CNT > CCR1 Output Output Dead-time TIM1 CCER mode selector generator CNT = CCR1 OC1N\_DT ontrolle Output OC1N **OCxREF** enable **OCxREF** circuit CC1NE CC1E TIM1\_CCER OC1CE OC1M[3:0] DTG[7:0] CC1NE CC1E CC1NP | MOE | OSSI | OSSR TIM1 CHCTLR1 TIM1\_BDTR TIM1\_CCER TIM1 CCER TIM1 BDTR

Figure 14-3 Structure block diagram of compare/capture channel

The block diagram of the compare/capture channel is as shown in Figure 14-3. After the signal is inputted from the channel x pin, it can be selected as TIx (the source of TI1 may be more than CH1. See the timer structure block diagram 14-1). TI1 passes through the filter (ICF[3:0]) to generate TI1F, and then is divided into TI1F\_Rising and TI1F\_Falling after passing through the edge detector. These 2 signals are selected (CC1P) to generate TI1FP1, TI1FP1 and TI2FP1 from channel 2 are sent to CC1S together to be selected as IC1, and

then sent to the compare/capture register after going through the ICPS frequency division.

The compare/capture register is composed of a preload register and a shadow register, and only the preload register is operated during reading and writing. In the capture mode, the capture occurs on the shadow register, and then copied to the preload register; in the comparison mode, the content of the preload register is copied to the shadow register, and then the content of the shadow register is compared with the core counter (CNT).

# 14.3 Function and Implementation

The advanced-control timer complex functions are implemented by the operation of comparison &capture channel, clock input circuit, counter and peripheral parts of the timer. The timer's clock input can come from multiple clock sources including the input of the compare/capture channel. The operation of compare/capture channel and the clock source selection directly determines its function. The compare/capture channel is bidirectional and can work in input and output modes.

### 14.3.1 Input Capture Mode

The input capture mode is one of basic functions of timer. The principle of the input capture mode is that when a certain edge on the ICxPS signal is detected, a capture event will occur, and the current value of the counter will be latched into the compare/capture register (R16\_TIMx\_CHCTLRx). When a capture event occurs, CCxIF (in R16\_TIMx\_INTFR) bit will be set. If an interrupt or DMA is enabled, a corresponding interrupt or DMA will be generated. If CCxIF is already set when a capture event occurs, then the CCxOF bit will be set. CCxIF can be cleared by software or by hardware through reading the compare/capture register. CCxOF is cleared by the software.

Take an example of channel 1 to illustrate the steps to use the input capture mode, as follows:

- 1) Configure CCxS and select the source of ICx signal. For example, it is set to 10b, and TI1FP1 is selected as the source of IC1, and the default setting cannot be used. CCxS defaults to use the compare capture module as the output channel;
- 2) Configure ICxF and set the digital filter of the TI signal. The digital filter will output a jump based on the determined frequency and determined sampling times. The sampling frequency and times are determined by ICxF;
- 3) Configure CCxP bit and set the polarity of TIxFPx. For example, maintain CC1P bit to be low and select the jump of rising edge;
- 4) Configure ICxPS and set ICx signal as the frequency division factor between ICxPS. For example, maintain the ICxPS as 00b without frequency division;
- 5) Configure the CCxE bit to allow to capture the core counter (CNT) value to the compare/capture register. Set the CC1E bit;
- 6) Configure the CCxIE and CCxDE bits as needed to decide whether to enable interrupt or DMA. After these operations, the compare & capture channel configuration is completed.

When TI1 inputs a captured pulse, the value of the core counter (CNT) will be recorded in the compare/capture register, and CC1IF will be set. When CC1IF has been set before, the CCIOF bit will also be set. If CC1IE is set, then an interrupt will be generated; if CC1DE is set, a DMA request will be generated. An input capture event can be generated by software through writing the event generation register (TIMx\_SWEVGR).

#### 14.3.2 Compare Output Mode

The compare output mode is one of basic functions of timer. The principle of the compare output mode is to output a specific change or waveform when the value of the core counter (CNT) is consistent with the value

of the compare/capture register. OCxM (in R16\_TIMx\_CHCTLRx) and the CCxP bit (in R16\_TIMx\_CCER) determine whether the output is determined high or low level or level inversion. When a comparison consistent event is generated, the CCxIF bit will be also set. If the CCxIE bit is preset, an interrupt will be generated; if the CCxDE bit is preset, a DMA request will be generated.

The procedure of compare output mode configuration is as follows:

- 1) Configure the clock source and auto-reload value of the core counter (CNT);
- 2) Set the count value to be compared to the compare/capture register (R16 TIMx CHxCVR);
- 3) If an interrupt needs to be generated, set the CCxIE bit;
- 4) Keep OCxPE as 0 and disable the preload register of the compare register;
- 5) Set the output mode, and set OCxM and CCxP bit;
- 6) Enable the output and set the CCxE bit;
- 7) Set the CEN bit to start the timer.

### 14.3.3 Forced Output Mode

The output mode of the compare/capture channel of the timer can be forced to output a certain level by software, instead of relying on the shadow register and the core counter of the compare/capture register.

The specific means is to set OCxM to 100b, which means to force OCxREF to be low; or to set OCxM to 101b, which means setting OCxREF to a high value by force.

It should be noted that if OCxM is set to 100b or 101b by force, the comparison process between the internal core counter and the compare/capture register will be still in progress, the corresponding flag bit will be still set, and interrupts and DMA request will still be generated.

### 14.3.4 PWM Input Mode

The PWM input mode is used to measure the duty cycle and frequency of the PWM, which is a special case of the input capture mode. The operation is the same as the input capture mode except for the following differences: PWM occupies 2 compare/capture channels, and the input polarity of the 2 channels is set to opposite. One of the signals is set to trigger input, and SMS is set to reset mode.

For example, to measure the cycle and frequency of the PWM wave input from TI1, the following operations are required:

- 1) Set TI1 (TI1FP1) as the input of IC1 signal. Set CC1S to 01b;
- 2) Set TI1FP1 as the rising edge valid. Keep CC1P to 0;
- 3) Set TI1 (TI1FP2) as the input of IC2 signal. Set CC2S to 10b;
- 2) Set TI1FP2 as the falling edge valid. Set CC2P to 1;
- 5) The source of the clock source is TI1FP1. Set TS to 101b;
- 6) Set SMS to reset mode, i.e., 100b;
- 7) Enable the input capture. Set CC1E and CC2E bits;

In this way, the value of the compare/capture register 1 is the cycle of PWM, and the value of the compare/capture register 2 is its duty cycle.

Note: Since only TI1FP1 and TI2FP2 are connected to the slave mode controller, only TIMx\_CH1/TIMx\_CH2 can be used in the PWM input mode.

#### 14.3.5 PWM Output Mode

The PWM output mode is one of basic functions of timer. The most common method of PWM output mode is to use the reload value to determine the PWM frequency, and to use the capture comparison register to determine the duty cycle. Set 110b or 111b in OCxM to use PWM mode 1 or mode 2, set the OCxPE bit to

enable the preload register, and finally set the ARPE bit. Since the value of the preload register can be sent to the shadow register when an update event occurs, it is necessary to set the UG bit to initialize all registers before the core counter starts counting. In the PWM mode, the core counter and the compare/capture register are always being compared. According to the CMS bit, the timer can output edge-aligned or center-aligned PWM signals.

#### • Edge alignment

When the edge alignment is used, the core counter counts up or down. In the scenario of PWM mode 1, when the value of the core counter is greater than that of the compare/capture register, OCxREF will be high; when the value of the core counter is less than the compare capture register (Such as When the core counter increases to the value of R16 TIMx ATRLR and returns to all 0s), OCxREF drops to low.

#### Central alignment

When the center-aligned mode is used, the core counter will run in a mode where up counting and down counting are performed alternately, and OCxREF performs rising and falling jumps when the values of the core counter and the compare/capture register are consistent. However, in 3 types of central alignment mode of comparison flag, the bit setting timing is different somewhat. When the center-alignment mode is used, it is the best to generate a software update flag (Setting the UG bit) before starting the core counter.

### 14.3.6 Complementary Output and Deadband

The compare/capture channel generally has 2 output pins (Compare/capture channel 4 has only one output pin), to output 2 complementary signals (OCx and OCxN). OCx and OCxN can be independently set by the CCxP and CCxNP bits. The output enable is set independently through CCxE and CCxNE, and the deadband and other controls are performed through the MOE, OIS, OISN, OSSI and OSSR bits. Meanwhile, OCx and OCxN outputs are enabled to insert into the deadband, each channel has a 10-bit deadband generator. If there is a break circuit, set the MOE bit. OCx and OCxN are generated by OCxREF in association. If OCx and OCxN are both high and effective, then OCx will be the same as OCxREF, but the rising edge of OCx is equivalent to OCxREF with a delay. OCxN is opposite to OCxREF, and its rising edge has a delay relative to the falling edge of the reference signal, and if the delay is greater than the effective output width, the corresponding pulse will not be generated.

Figure 14-4 shows the relationship between OCx, OCxN and OCxREF, and shows the deadband.



Figure 14-4 Complementary output and deadband

### 14.3.7 Break Signal

When the break signal is generated, the output enable signal and the invalid level will be modified according to the MOE, OIS, OISN, OSSI and OSSR bits. But OCx and OCxN will not be at the effective level at any time. The break event source can come from the break input pin, or it can be a clock failure event, and the clock failure event will be generated by CSS (Clock Security System).

After the system reset, the break function will be disabled by default (MOE bit is low). Setting the BKE bit

can enable the break function. The polarity of the input break signal can be set by setting BKP. The BKE and BKP signals can be written at the same time. There will be an PB clock delay before the actual write, so you need to wait for an PB cycle to read the written value correctly.

When the selected level appears on the break pin, the system will generate the following actions:

- 1) The MOE bit is asynchronously cleared, and the output is set to the invalid status, idle status or reset status according to the setting of the SOOI bit;
- 2) After MOE is cleared, each output channel will output the level determined by OISx;
- 3) During the supplementary output: the output will be in an invalid status, depending on the polarity;
- 4) If BIE is set, an interrupt will be generated when BIF is set; if the BDE bit is set, a DMA request will be generated;
- 5) If AOE is set, the MOE bit will be automatically set during the next update of event UEV.

#### 14.3.8 Single Pulse Mode

The single pulse mode can be used to allow the microcontroller to respond to a specific event to generate a pulse after a delay. The delay and pulse width are programmable. Setting the OPM bit can make the core counter stop when the next update event UEV is generated (the counter turns over to 0).

As shown in Figure 14-5, it is necessary to detect the beginning of a rising edge on the TI2 input pin. After delaying Tdelay, a positive pulse of length Tpulse will be generated on OC1:



Figure 14-5 Single pulse generation

- 1) Set TI2 as trigger. Set CC2S to 01b and map TI2FP2 to TI2; set CC2P bit to 0b and set TI2FP2 to rising edge detection; set TS to 110b and set TI2FP2 as the trigger source; set SMS to 110b, and TI2FP2 is used to start the counter;
- 2) Tdelay is determined by the value of the compare/capture register, and Tpulse is determined by the value of the auto-reload value register and the value of the compare/capture register.

#### 14.3.9 Encoder Mode

The encoder mode is a typical application of the timer. It can be used to access the dual-phase output of the encoder. The counting direction of the core counter is synchronized with the rotating shaft of the encoder. Each pulse outputted by the encoder will increase the core counter by adding one or subtracting one. The steps to use the encoder are: set the SMS field to 001b (counting only on TI2 edge), 010b (counting only on TI1 edge) or 011b (counting on both TI1 and TI2 edges), and connect the encoder to compare/capture channel 1, 2 input

V2. 4 208 **KIH** 

terminals, set a value for the reload value register and this value can be set to be greater. In the encoder mode, the internal compare/capture register of timer, prescaler, repeat count register, etc. all work normally. The following table shows the relationship between the counting direction and the encoder signal.

|                        | Relative | TI1FP1 signal edge TI2FP2 signal |           |           | 2 signal  |
|------------------------|----------|----------------------------------|-----------|-----------|-----------|
| Counting active edge   | signal   | Rising                           | Falling   | Rising    | Falling   |
|                        | level    | edge                             | edge      | edge      | edge      |
| Only count at TI1 edge | High     | Downcount                        | Upcount   | Not (     | count     |
| Omy count at 111 cage  | Low      | Upcount                          | Downcount | Not count |           |
| Only count at TI2 adag | High     | Not                              |           | Upcount   | Downcount |
| Only count at TI2 edge | Low      | Not count Downcount Upcoun       |           |           | Upcount   |
| Count on both edges of | High     | Downcount Upcount                |           | Upcount   | Downcount |
| TI1 and TI2            | Low      | Upcount                          | Downcount | Downcount | Upcount   |

Table 14-1 Relationship between counting direction of timer encoder mode and encoder signal

#### 14.3.10 Timer Synchronous Mode

The timer can output clock pulses (TRGO) and can also receive input from other timers (ITRx). The sources of ITRx of different timers (TRGO of other timers) are different. Table 14-2 shows the internal trigger connection of the timers.

| Slave timer | ITR0(TS=000) | ITR1(TS=001) | ITR2(TS=010) | ITR3(TS=011) |
|-------------|--------------|--------------|--------------|--------------|
| TIM1        | TIM5         | TIM2         | TIM3         | TIM4         |
| TIM8        | TIM1         | TIM2         | TIM4         | TIM5         |
| TIM9        | TIM10        | TIM5         | TIM6         | TIM7         |
| TIM10       | TIM9         | TIM2         | TIM4         | TIM5         |

Table 14-2 TIMx internal trigger connection

## 14.3.11 Dual-edge Capture Mode

The pulse can be measured through the TIMx AUX register.

For example, to capture the pulse width through channel 2, on the capture function configuration, select the source of the IC2 signal (CC2S bit of the TIMx\_CHCTLR1 register is 11b), and enable the dual-edge capture function of channel 2 (CAP\_ED\_CH2 bit of the TIMx\_AUX register is 1). At this point the dual-edge capture configuration has been completed.

The captured dual-edge pulse width value can be read with the CCR2 bit of the TIMx\_CH2CVR register.

Note: Only available for CH32F20x\_D8, CH32F20x\_D8C, CH32V30x\_D8, CH32V30x\_D8C, and CH32V31x\_D8C lot numbers where the penultimate sixth bit is not zero.

#### **14.3.12 Debug Mode**

When the system enters the debug mode, the timer continues to run or stop according to the setting of the DBG module.

# 14.4 Register Description

Table 14-3 TIM1 registers

| Name               | Access address | Description                             | Reset value |
|--------------------|----------------|-----------------------------------------|-------------|
| R16_TIM1_CTLR1     | 0x40012C00     | Control register1                       | 0x0000      |
| R16_TIM1_CTLR2     | 0x40012C04     | Control register2                       | 0x0000      |
| R16_TIM1_SMCFGR    | 0x40012C08     | Slave mode configuration register       | 0x0000      |
| R16_TIM1_DMAINTENR | 0x40012C0C     | DMA/interrupt enable register           | 0x0000      |
| R16_TIM1_INTFR     | 0x40012C10     | Interrupt flag register                 | 0x0000      |
| R16_TIM1_SWEVGR    | 0x40012C14     | Event generation register               | 0x0000      |
| R16_TIM1_CHCTLR1   | 0x40012C18     | Compare/capture control register1       | 0x0000      |
| R16_TIM1_CHCTLR2   | 0x40012C1C     | Compare/capture control register2       | 0x0000      |
| R16_TIM1_CCER      | 0x40012C20     | Compare/capture enable register         | 0x0000      |
| R16_TIM1_CNT       | 0x40012C24     | Counter                                 | 0x0000      |
| R16_TIM1_PSC       | 0x40012C28     | Prescaler                               | 0x0000      |
| R16_TIM1_ATRLR     | 0x40012C2C     | Auto-reload register                    | 0xFFFF      |
| R16_TIM1_RPTCR     | 0x40012C30     | Repeat count register                   | 0x0000      |
| R16_TIM1_CH1CVR    | 0x40012C34     | Compare/capture register1               | 0x0000      |
| R16_TIM1_CH2CVR    | 0x40012C38     | Compare/capture register2               | 0x0000      |
| R16_TIM1_CH3CVR    | 0x40012C3C     | Compare/capture register3               | 0x0000      |
| R16_TIM1_CH4CVR    | 0x40012C40     | Compare/capture register4               | 0x0000      |
| R16_TIM1_BDTR      | 0x40012C44     | Break and deadband register             | 0x0000      |
| R16_TIM1_DMACFGR   | 0x40012C48     | DMA configuration register              | 0x0000      |
| R16_TIM1_DMAADR    | 0x40012C4C     | DMA address register in continuous mode | 0x0000      |
| R16_TIM1_AUX       | 0x40012C50     | Dual-edge capture register              | 0x0000      |

Table 14-4 TIM8 registers

| Name               | Access address | Description                       | Reset value |
|--------------------|----------------|-----------------------------------|-------------|
| R16_TIM8_CTLR1     | 0x40013400     | Control register1                 | 0x0000      |
| R16_TIM8_CTLR2     | 0x40013404     | Control register2                 | 0x0000      |
| R16_TIM8_SMCFGR    | 0x40013408     | Slave mode configuration register | 0x0000      |
| R16_TIM8_DMAINTENR | 0x4001340C     | DMA/interrupt enable register     | 0x0000      |
| R16_TIM8_INTFR     | 0x40013410     | Interrupt flag register           | 0x0000      |
| R16_TIM8_SWEVGR    | 0x40013414     | Event generation register         | 0x0000      |
| R16_TIM8_CHCTLR1   | 0x40013418     | Compare/capture control register1 | 0x0000      |
| R16_TIM8_CHCTLR2   | 0x4001341C     | Compare/capture control register2 | 0x0000      |
| R16_TIM8_CCER      | 0x40013420     | Compare/capture enable register   | 0x0000      |
| R16_TIM8_CNT       | 0x40013424     | Counter                           | 0x0000      |
| R16_TIM8_PSC       | 0x40013428     | Prescaler                         | 0x0000      |
| R16_TIM8_ATRLR     | 0x4001342C     | Auto-reload register              | 0xFFFF      |
| R16_TIM8_RPTCR     | 0x40013430     | Repeat count register             | 0x0000      |
| R16_TIM8_CH1CVR    | 0x40013434     | Compare/capture register1         | 0x0000      |
| R16_TIM8_CH2CVR    | 0x40013438     | Compare/capture register2         | 0x0000      |
| R16_TIM8_CH3CVR    | 0x4001343C     | Compare/capture register3         | 0x0000      |
| R16_TIM8_CH4CVR    | 0x40013440     | Compare/capture register4         | 0x0000      |
| R16_TIM8_BDTR      | 0x40013444     | Break and deadband register       | 0x0000      |

| R16_TIM8_DMACFGR | 0x40013448 | DMA configuration register              | 0x0000 |
|------------------|------------|-----------------------------------------|--------|
| R16_TIM8_DMAADR  | 0x4001344C | DMA address register in continuous mode | 0x0000 |
| R16_TIM8_AUX     | 0x40013450 | Dual-edge capture register              | 0x0000 |

Table 14-5 TIM9 registers

| Name               | Access address | Description                             | Reset value |
|--------------------|----------------|-----------------------------------------|-------------|
| R16_TIM9_CTLR1     | 0x40014C00     | Control register1                       | 0x0000      |
| R16_TIM9_CTLR2     | 0x40014C04     | Control register2                       | 0x0000      |
| R16_TIM9_SMCFGR    | 0x40014C08     | Slave mode configuration register       | 0x0000      |
| R16_TIM9_DMAINTENR | 0x40014C0C     | DMA/interrupt enable register           | 0x0000      |
| R16_TIM9_INTFR     | 0x40014C10     | Interrupt flag register                 | 0x0000      |
| R16_TIM9_SWEVGR    | 0x40014C14     | Event generation register               | 0x0000      |
| R16_TIM9_CHCTLR1   | 0x40014C18     | Compare/capture control register1       | 0x0000      |
| R16_TIM9_CHCTLR2   | 0x40014C1C     | Compare/capture control register2       | 0x0000      |
| R16_TIM9_CCER      | 0x40014C20     | Compare/capture enable register         | 0x0000      |
| R16_TIM9_CNT       | 0x40014C24     | Counter                                 | 0x0000      |
| R16_TIM9_PSC       | 0x40014C28     | Prescaler                               | 0x0000      |
| R16_TIM9_ATRLR     | 0x40014C2C     | Auto-reload register                    | 0xFFFF      |
| R16_TIM9_RPTCR     | 0x40014C30     | Repeat count register                   | 0x0000      |
| R16_TIM9_CH1CVR    | 0x40014C34     | Compare/capture register1               | 0x0000      |
| R16_TIM9_CH2CVR    | 0x40014C38     | Compare/capture register2               | 0x0000      |
| R16_TIM9_CH3CVR    | 0x40014C3C     | Compare/capture register3               | 0x0000      |
| R16_TIM9_CH4CVR    | 0x40014C40     | Compare/capture register4               | 0x0000      |
| R16_TIM9_BDTR      | 0x40014C44     | Break and deadband register             | 0x0000      |
| R16_TIM9_DMACFGR   | 0x40014C48     | DMA configuration register              | 0x0000      |
| R16_TIM9_DMAADR    | 0x40014C4C     | DMA address register in continuous mode | 0x0000      |
| R16_TIM9_AUX       | 0x40014C50     | Dual-edge capture register              | 0x0000      |

Table 14-6 TIM10 registers

| Name                | Access address | Description                       | Reset value |
|---------------------|----------------|-----------------------------------|-------------|
| R16_TIM10_CTLR1     | 0x40015000     | Control register1                 | 0x0000      |
| R16_TIM10_CTLR2     | 0x40015004     | Control register2                 | 0x0000      |
| R16_TIM10_SMCFGR    | 0x40015008     | Slave mode configuration register | 0x0000      |
| R16_TIM10_DMAINTENR | 0x4001500C     | DMA/interrupt enable register     | 0x0000      |
| R16_TIM10_INTFR     | 0x40015010     | Interrupt flag register           | 0x0000      |
| R16_TIM10_SWEVGR    | 0x40015014     | Event generation register         | 0x0000      |
| R16_TIM10_CHCTLR1   | 0x40015018     | Compare/capture control register1 | 0x0000      |
| R16_TIM10_CHCTLR2   | 0x4001501C     | Compare/capture control register2 | 0x0000      |
| R16_TIM10_CCER      | 0x40015020     | Compare/capture enable register   | 0x0000      |
| R16_TIM10_CNT       | 0x40015024     | Counter                           | 0x0000      |
| R16_TIM10_PSC       | 0x40015028     | Prescaler                         | 0x0000      |
| R16_TIM10_ATRLR     | 0x4001502C     | Auto-reload register              | 0xFFFF      |
| R16_TIM10_RPTCR     | 0x40015030     | Repeat count register             | 0x0000      |
| R16_TIM10_CH1CVR    | 0x40015034     | Compare/capture register1         | 0x0000      |

| R16_TIM10_CH2CVR  | 0x40015038 | Compare/capture register2               | 0x0000 |
|-------------------|------------|-----------------------------------------|--------|
| R16_TIM10_CH3CVR  | 0x4001503C | Compare/capture register3               | 0x0000 |
| R16_TIM10_CH4CVR  | 0x40015040 | Compare/capture register4               | 0x0000 |
| R16_TIM10_BDTR    | 0x40015044 | Break and deadband register             | 0x0000 |
| R16_TIM10_DMACFGR | 0x40015048 | DMA configuration register              | 0x0000 |
| R16_TIM10_DMAADR  | 0x4001504C | DMA address register in continuous mode | 0x0000 |
| R16_TIM10_AUX     | 0x40015050 | Dual-edge capture register              | 0x0000 |

## 14.4.1 Control Register 1 (TIMx\_CTLR1) (x=1/8/9/10)

| 15 | 14 | 13  | 12    | 11 | 10 | 9   | 8     | 7        | 6   | 5      | 4   | 3   | 2   | 1    | 0   | _ |
|----|----|-----|-------|----|----|-----|-------|----------|-----|--------|-----|-----|-----|------|-----|---|
|    |    | Res | erved |    |    | CKD | [1:0] | ARP<br>E | CMS | S[1;0] | DIR | OPM | URS | UDIS | CEN |   |

| Bit     | Name     | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Reset value |
|---------|----------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [15:10] | Reserved | RO     | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0           |
| [9:8]   | CKD[1:0] | RW     | These 2 bits define the frequency, dead-zone time of timer clock (CK_INT) and frequency division ratio of sampling clock used for the dead-zone generator and digital filter (ETR,TIx):  00: Tdts=Tck_int  01: Tdts = 2 * Tck_int  10: Tdts = 4 * Tck_int  11: Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |             |
| 7       | ARPE     | RW     | Auto reload and preload enable bit:  0: Auto reload register (ATRLR) disabled;  1: Auto reload register (ATRLR) enabled;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0           |
| [6:5]   | CMS[1:0] | RW     | Central alignment mode selection:  00: Edge alignment mode. The counter counts up or down according to the direction bit (DIR).  01: Center alignment mode1. The counter counts up and down alternately. The output comparison interrupt flag bit of the channel configured as an output (CCxS=00 in the CHCTLRx register) is only set when the counter counts down.  10: Center alignment mode2. The counter counts up and down alternately. The output comparison interrupt flag bit of the channel configured as an output (CCxS=00 in the CHCTLRx register) is only set when the counter counts up.  11: Center alignment mode3. The counter counts up and down alternately. The output comparison interrupt flag bit of the channel configured as an output (CCxS=00 in the CHCTLRx register) is only set when the counter | 0           |

|   |       |    | counts up and down.                                     |   |
|---|-------|----|---------------------------------------------------------|---|
|   |       |    | Note: When the counter is enabled (CEN=1), it is not    |   |
|   |       |    | allowed to switch from edge alignment mode to center    |   |
|   |       |    | alignment mode.                                         |   |
|   |       |    | Counter direction:                                      |   |
|   |       |    | 0: Upcount;                                             |   |
| 4 | DIR   | RW | 1: Downcount.                                           | 0 |
|   |       |    | Note: When the counter is configured in the center      |   |
|   |       |    | alignment mode or encoder mode, this bit is invalid.    |   |
|   |       |    | Single pulse mode:                                      |   |
|   |       |    | 0: The counter does not stop when the next update event |   |
| 3 | OPM   | RW | occurs;                                                 | 0 |
|   |       |    | 1: The counter stops (Clearing the CEN bit) when the    |   |
|   |       |    | next update event occurs.                               |   |
|   |       |    | Update request source; the software selects the source  |   |
|   |       |    | of UEV event through this bit.                          |   |
|   |       |    | 0: If the update interrupt or DMA request is enabled,   |   |
|   |       |    | any of the following events will generate an update     |   |
|   |       |    | interrupt or DMA request.                               |   |
| 2 | URS   | RW | -Counter overflow/underflow                             | 0 |
|   |       |    | -Set the UG bit                                         |   |
|   |       |    | - Generate update from the mode controlled              |   |
|   |       |    | 1: If the updating interrupt or DMA request is enabled, |   |
|   |       |    | only the counter overflow/underflow will generate the   |   |
|   |       |    | update interrupt or DMA request.                        |   |
|   |       |    | Update disabled. Software allows/disables the           |   |
|   |       |    | generation of UEV events through this bit.              |   |
|   |       |    | 0: Allow UEV. Update (UEV) events are generated by      |   |
|   |       |    | any of the following events:                            |   |
|   |       |    | - Counter overflow/underflow                            |   |
|   |       |    | -Set the UG bit                                         |   |
| 1 | LIDIC | DW | - Generate update from the mode controlled              | 0 |
| 1 | UDIS  | RW | Registers with buffers are loaded with their preloaded  | 0 |
|   |       |    | values.                                                 |   |
|   |       |    | 1: Disable UEV. No update event is generated, and the   |   |
|   |       |    | registers (ARR, PSC, CHxCVR) maintain their values.     |   |
|   |       |    | If the UG bit is set or a hardware reset is issued from |   |
|   |       |    | the mode controller, the counter and prescaler will be  |   |
|   |       |    | reinitialized.                                          |   |
|   |       |    | Counter enable:                                         |   |
|   |       |    | 0: Counter disabled;                                    |   |
|   |       |    | 1: Counter enabled.                                     |   |
| 0 | CEN   | RW | Note: After CEN bit is set by software, the external    | 0 |
|   |       |    | clock, gating mode and encoder mode can only work.      |   |
|   |       |    | The trigger mode can automatically set the CEN bit by   |   |
| 1 |       |    | hardware.                                               |   |

V2. 4 213 WCH°

## 14.4.2 Control Register2 (TIMx\_CTLR2) (x=1/8/9/10)

Offset address: 0x04

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0

Reserved OIS4 OIS3N OIS3 OIS2N OIS2 OIS1N OIS1 TI1S MMS[2:0] CCDS CCUS Reserved CCPC

| Bit   | Name          | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Reset value |
|-------|---------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| 15    | Reserved      | RO     | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0           |
| 14    | OIS4          | RW     | Output idle status 4:  0: For MOE=0, if the OC4N is implemented, OC4=0 after deadband;  1: If the OC4N is implemented for MOE=0, OC4=1 after deadband.  Note: After levels 1, 2 and 3 have been set for LOCK (TIMx_BDTR register), such bit cannot be modified.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0           |
| 13    | OIS3N         | RW     | During the output idle status 3:  0: When MOE=0, OC3N=0 after the deadband;  1: When MOE=0, OC3N=1 after the deadband.  Note: After LOCK (TIMx_BDTR register) levels 1, 2 or 3 have been set, this bit cannot be modified.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |             |
| 12    | OIS3          | RW     | Output idle status 3, refer to OIS4.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0           |
| 11    | OIS2N         | RW     | Output idle status 2, refer to OIS3N.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0           |
| 10    | OIS2<br>OIS1N | RW     | Output idle status 2, refer to OIS4.  Output idle status 1, refer to OIS3N.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0           |
| 8     | OIS1N         | RW     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | -           |
| 8     | OIST          | RW     | Output idle status 1, refer to OIS4.  TI1 selection:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0           |
| 7     | TIIS          | RW     | 0: TIMx_CH1 pin is directly connected to TI1 input; 1: TIMx_CH1, TIMx_CH2 and TIMx_CH3 pins are connected to TI1 input through XOR.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0           |
| [6:4] | MMS[2:0]      | RW     | Master mode selection: These 3 bits are used to select the synchronization information (TRGO) sent to the slave timer in the master mode.  The possible combination is as follows:  000: Reset – The UG bit in the TIMx_EGR register is used as a trigger output (TRGO). If it is a reset generated by a trigger input (the slave mode controller is in reset mode), the signal on TRGO will have a delay relative to the actual reset;  001: Enable-the counter enables signal CNT_EN to be used as a trigger output (TRGO). Sometimes, it is necessary to start multiple timers at the same time or control to enable slave timers within a period of time. The counter enable signal is generated by the logical OR of the CEN control bit and the trigger input signal in the gating mode. When the counter enable signal is | 0           |

|   |          |      | controlled by the trigger input, there will be a delay on                                           |   |
|---|----------|------|-----------------------------------------------------------------------------------------------------|---|
|   |          |      | TRGO, unless the master/slave mode is selected (See the description of the MSM bit in the TIMx SMCR |   |
|   |          |      | register);                                                                                          |   |
|   |          |      | 010: Update- An update event is selected as the trigger                                             |   |
|   |          |      | output (TRGO). For example, the clock of a master                                                   |   |
|   |          |      | timer can be used as a prescaler for a slave timer;                                                 |   |
|   |          |      | 011: Compare pulse-when a capture occurs or a                                                       |   |
|   |          |      | comparison is successful, and the CC1IF flag is to be                                               |   |
|   |          |      | set (Even if it is already high), the trigger output will                                           |   |
|   |          |      | send a positive pulse (TRGO);                                                                       |   |
|   |          |      | 100: Compare-OC1REF signal is used as trigger output                                                |   |
|   |          |      | (TRGO);                                                                                             |   |
|   |          |      | 101: Compare-OC2REF signal is used as trigger output                                                |   |
|   |          |      | (TRGO);                                                                                             |   |
|   |          |      | 110: Compare-OC3REF signal is used as trigger output                                                |   |
|   |          |      | (TRGO);                                                                                             |   |
|   |          |      | 111: Compare-OC4REF signal is used as trigger output                                                |   |
|   |          |      | (TRGO).                                                                                             |   |
|   |          |      | DMA selection of capture/compare                                                                    |   |
|   | CCDC     | DIII | 0: When CHxCVR occurs, a DMA request of CHxCVR                                                      | 0 |
| 3 | CCDS     | RW   | is generated;                                                                                       | 0 |
|   |          |      | 1: When an update event occurs, a DMA request of CHxCVR is transferred.                             |   |
|   |          |      | Compare/capture control update selection bit.                                                       |   |
|   |          |      | 0: If CCPC is set, they can only be updated by setting                                              |   |
|   |          |      | the COM bit;                                                                                        |   |
| 2 | CCUS     | RW   | 1: If CCPC is set, they can be updated by setting the                                               | 0 |
|   |          |      | COM bit or a rising edge on TRGI.                                                                   | Ť |
|   |          |      | Note: This bit only works on channels with                                                          |   |
|   |          |      | complementary outputs.                                                                              |   |
| 1 | Reserved | RO   | Reserved.                                                                                           | 0 |
|   |          |      | Compare/capture preload control bit.                                                                |   |
|   |          |      | 0: CCxE, CCxNE and OCxM bits are not preloaded;                                                     |   |
|   |          |      | 1: CCxE, CCxNE and OCxM bits are pre-loaded. After                                                  |   |
| 0 | CCPC     | RW   | the bits are set, they will only be updated after setting                                           | 0 |
|   |          |      | of the COM bit.                                                                                     |   |
|   |          |      | Note: This bit only works on channels with                                                          |   |
|   |          |      | complementary outputs.                                                                              |   |

# 14.4.3 Slave Mode Configuration Mode (TIMx\_SMCFGR) (x=1/8/9/10)

| 15  | 14 | 13   | 12    | 11 | 10  | 9     | 8 | 7   | 6 | 5       | 4 | 3        | 2 | 1      | 0  |
|-----|----|------|-------|----|-----|-------|---|-----|---|---------|---|----------|---|--------|----|
| ETP |    | ETPS | [1:0] |    | ETF | [3:0] |   | MSM |   | TS[2:0] |   | Reserved | S | MS[2:0 | )] |

| Bit     | Name      | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Reset value |
|---------|-----------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| 15      | ЕТР       | RO     | ETR trigger polarity selection; this bit selects whether to directly input ETR or input inverted ETR.  0: ETR, valid at high level or rising edge;  1: ETR inverted, active at low level or falling edge.                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0           |
| 14      | ECE       | RW     | External clock mode 2 enable selection:  0: Disable the external clock mode 2;  1: Enable the external clock mode 2.  Note 1: Slave mode can be used simultaneously with external clock mode 2: reset mode, gating mode and trigger mode; however, TRGI cannot be connected to ETRF at this time (TS bit cannot be '111').  Note 2: When both external clock mode 1 and external clock mode 2 are enabled at the same time, the input of the external clock will be ETRF.                                                                                                                                                                                       | 0           |
| [13:12] | ETPS[1:0] | RW     | External trigger prescaler (ETRP); the frequency must be at most 1/4 of TIMxCLK frequency, and the frequency can be reduced through this domain: 00: Prescale OFF; 01: ETRP frequency divided by 2; 10: ETRP frequency divided by 4; 11: ETRP frequency divided by 8.                                                                                                                                                                                                                                                                                                                                                                                           | 0           |
| [11:8]  | ETF       | RW     | External trigger filtering. In fact, the digital filter is an event counter. N events are needed to validate a transition on the output.  0000: No filter, sampling is done at Fdts;  0001: Fsampling=Fck_int, N=2;  0010: Fsampling=Fck_int, N=4;  0011: Fsampling=Fck_int, N=8;  0100: Fsampling=Fdts/2, N=6;  0101: Fsampling=Fdts/2, N=6;  0110: Fsampling=Fdts/4, N=6;  0111: Fsampling=Fdts/4, N=6;  1000: Fsampling=Fdts/8, N=6;  1001: Fsampling=Fdts/8, N=6;  1010: Fsampling=Fdts/16, N=5;  1011: Fsampling=Fdts/16, N=6;  1100: Fsampling=Fdts/16, N=6;  1101: Fsampling=Fdts/32, N=5;  1110: Fsampling=Fdts/32, N=6;  1111: Fsampling=Fdts/32, N=8; | 0           |
| 7       | MSM       | RW     | Master/Slave mode selection:  0: Not effect;  1: The event on the trigger input (TRGI) is delayed to allow perfect synchronization between the current timer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0           |

|       |          |    | (Via TRGO) and its slave timer. This is very useful when it is required to synchronize several timers to a single external event.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |   |
|-------|----------|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| [6:4] | TS[2:0]  | RW | Trigger selection bits. Select the trigger input source used to synchronize the counter through these 3 bits: 000: Internal trigger0 (ITR0); 001: Internal trigger1 (ITR1); 010: Internal trigger2 (ITR2); 011: Internal trigger3 (ITR3); 100: Edge detector of TI1 (TI1F_ED); 101: Timer input1 after filtering (TI1FP1); 110: Timer input2 after filtering (TI2FP2); 111: External trigger input (ETRF). The values can be changed only when SMS is 0. <i>Note: See Table 14-2 for details</i> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0 |
| 3     | Reserved | RO | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0 |
| [2:0] | SMS[2:0] | RW | Input mode selection. Select the clock and trigger mode of the core counter.  000: Driven by the internal clock CK_INT;  001: Encoder mode 1; according to the level of TI1FP1, the core counter counts up or down on the edge of TI2FP2;  010: Encoder mode 2; according to the level of TI2FP2, the core counter counts up or down on the edge of TI1FP1;  011: Encoder mode 3; according to the input level of another signal, the core counter counts up and down on the edge of TI1FP1 and TI2FP2; 100: Reset mode; the rising edge of the trigger input (TRGI) will initialize the counter and generate a signal for updating the register; 101: Gating mode; when the trigger input (TRGI) is high, the clock of the counter will be turned on; when the trigger input becomes low, the counter will stop, and the start and stop of the counter will be controlled; 110: Trigger mode; the counter starts on the rising edge of the trigger input TRGI, and only the start of the counter is controlled;  111: External clock mode 1; the rising edge of the selected trigger input (TRGI) drives the counter. | 0 |

# 14.4.4 DMA/Interrupt Enable Register (TIMx\_DMAINTENR) (x=1/8/9/10)

| 15 | 14 | 13        | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1         | 0       |
|----|----|-----------|----|----|----|---|---|---|---|---|---|---|---|-----------|---------|
|    |    | COMD<br>E |    |    |    |   |   |   |   |   |   |   |   | CC1I<br>E | UI<br>E |

| Bit | Name     | Access | Description                                  | Reset value |
|-----|----------|--------|----------------------------------------------|-------------|
| 15  | Reserved | RO     | Reserved.                                    | 0           |
|     |          |        | Trigger DMA request enable bit.              |             |
| 14  | TDE      | RW     | 0: Trigger DMA request disabled;             | 0           |
|     |          |        | 1: Trigger DMA request enabled.              |             |
|     |          |        | DMA request enable bit of COM.               |             |
| 13  | COMDE    | RW     | 0: DMA request of COM disabled;              | 0           |
|     |          |        | 1: DMA request of COM enabled.               |             |
|     |          |        | DMA request enable bit of compare/capture4.  |             |
| 12  | CC4DE    | RW     | 0: DMA request of compare/capture4 disabled; | 0b          |
|     |          |        | 1: DMA request of compare/capture4 enabled.  |             |
|     |          |        | DMA request enable bit of compare/capture3.  |             |
| 11  | CC3DE    | RW     | 0: DMA request of compare/capture3 disabled; | 0           |
|     |          |        | 1: DMA request of compare/capture3 enabled.  |             |
|     |          |        | DMA request enable bit of compare/capture2.  |             |
| 10  | CC2DE    | RW     | 0: DMA request of compare/capture2 disabled; | 0           |
|     |          |        | 1: DMA request of compare/capture2 enabled.  |             |
|     |          |        | DMA request enable bit of compare/capture1.  |             |
| 9   | CC1DE    | RW     | 0: DMA request of compare/capture1 disabled; | 0           |
|     |          |        | 1: DMA request of compare/capture1 enabled.  |             |
|     |          |        | Update DMA request enable bit.               |             |
| 8   | UDE      | RW     | 0: Update DMA request enable bit disabled;   | 0b          |
|     |          |        | 1: Update DMA request enable bit enabled.    |             |
|     |          |        | Break interrupt enable bit.                  |             |
| 7   | BIE      | RW     | 0: Break interrupt disabled;                 | 0           |
|     |          |        | 1: Break interrupt enabled.                  |             |
|     |          |        | Trigger interrupt enable bit.                |             |
| 6   | TIE      | RW     | 0: Trigger interrupt disabled;               | 0           |
|     |          |        | 1: Trigger interrupt enabled.                |             |
|     |          |        | COM interrupt enable bit.                    |             |
| 5   | COMIE    | RW     | 0: COM interrupt disabled;                   | 0           |
|     |          |        | 1: COM interrupt enabled.                    |             |
|     |          |        | Interrupt enable bit of compare/capture4.    |             |
| 4   | CC4IE    | RW     | 0: Interrupt of compare/capture4 disabled;   | 0           |
|     |          |        | 1: Interrupt of compare/capture4 enabled.    |             |
|     |          |        | Interrupt enable bit of compare/capture3.    |             |
| 3   | CC3IE    | RW     | 0: Interrupt of compare/capture3 disabled;   | 0           |
|     |          |        | 1: Interrupt of compare/capture3 enabled.    |             |
|     |          |        | Interrupt enable bit of compare/capture2.    |             |
| 2   | CC2IE    | RW     | 0: Interrupt of compare/capture2 disabled;   | 0           |
|     |          |        | 1: Interrupt of compare/capture2 enabled;    |             |
|     |          |        | Interrupt enable bit of compare/capture1.    |             |
| 1   | CC1IE    | RW     | 0: Interrupt of compare/capture1 disabled;   | 0           |
|     |          |        | 1: Interrupt of compare/capture1 enabled.    |             |
| 0   | UIE      | RW     | Update interrupt enable bit.                 | 0           |

|  | 0: Update interrupt disabled; |  |
|--|-------------------------------|--|
|  | 1: Update interrupt enabled.  |  |

## 14.4.5 Interrupt Flag Register (TIMx\_INTFR) (x=1/8/9/10)

Offset address: 0x10

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0

Reserved CC4OF CC3OF CC2OF CC1OF Reserved BIF TIF COMIF CC4IF CC3IF CC2IF CC1IF UIF

| Bit     | Name     | Access | Description                                                                                                                                                                                                                                                                                                                              | Reset value |  |  |  |  |  |
|---------|----------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--|--|--|--|--|
| [15:13] | Reserved | RO     | Reserved.                                                                                                                                                                                                                                                                                                                                | 0           |  |  |  |  |  |
| 12      | CC4OF    | RW0    | Overcapture flag bit of compare/capture 4.                                                                                                                                                                                                                                                                                               | 0           |  |  |  |  |  |
| 11      | CC3OF    | RW0    | Overcapture flag bit of compare/capture 3.                                                                                                                                                                                                                                                                                               | 0           |  |  |  |  |  |
| 10      | CC2OF    | RW0    | Overcapture flag bit of compare/capture 2.                                                                                                                                                                                                                                                                                               | 0           |  |  |  |  |  |
| 9       | CC10F    | RW0    | Overcapture flag bit of compare/capture 1 is only used when the compare/capture is configured in the input capture mode. This flag bit is set by hardware, and cleared by writing 0 by software.  0: No overcapture is generated;  1: When the value of counter is captured into compare/capture register, status of CC1IF has been set. | 0b          |  |  |  |  |  |
| 8       | Reserved | RO     | Reserved.                                                                                                                                                                                                                                                                                                                                | 0           |  |  |  |  |  |
| 7       | BIF      | RW0    | Break interrupt flag bit, once the break input is valid, the bit is set by hardware and cleared by software.  0: No break event is generated;  1: The set effective level is detected on break pin input.                                                                                                                                |             |  |  |  |  |  |
| 6       | TIF      | RW0    | Trigger interrupt flag bit; when a trigger event occurs, set by hardware and cleared by software. Trigger events include the detection of a valid edge at the TRGI input terminal from modes other than gating mode, or any edge in gating mode.  0: No trigger event occurs;  1: Trigger event occurs.                                  | 0           |  |  |  |  |  |
| 5       | COMIF    | RW0    | COM interrupt flag bit; once a COM event occurs, this bit is set by hardware and cleared by software. COM interrupt flag bit; once a COM event occurs, this bit is set by hardware and cleared by software.  0: No COM event occurs;  1: A COM event occurs.                                                                             | 0           |  |  |  |  |  |
| 4       | CC4IF    | RW0    | Interrupt flag bit of compare/capture 4.                                                                                                                                                                                                                                                                                                 | 0           |  |  |  |  |  |
| 3       | CC3IF    | RW0    | Interrupt flag bit of compare/capture 3.                                                                                                                                                                                                                                                                                                 | 0           |  |  |  |  |  |
| 2       | CC2IF    | RW0    | Interrupt flag bit of compare/capture 2.                                                                                                                                                                                                                                                                                                 | 0           |  |  |  |  |  |
| 1       | CC1IF    | RW0    | Interrupt flag bit of compare/capture 1. If the compare/capture is configured as output mode: This bit is set by hardware when the counter value                                                                                                                                                                                         | 0           |  |  |  |  |  |

|   |     |     | matches the comparison value, except in the center       |   |  |  |  |  |
|---|-----|-----|----------------------------------------------------------|---|--|--|--|--|
|   |     |     | symmetric mode. This bit is cleared by software.         |   |  |  |  |  |
|   |     |     | 1: The value of the core counter matches the value of    |   |  |  |  |  |
|   |     |     | the compare/capture register 1; 0: no match occurs.      |   |  |  |  |  |
|   |     |     | If the compare/capture is configured as input mode:      |   |  |  |  |  |
|   |     |     | This bit is set by hardware when a capture event occurs, |   |  |  |  |  |
|   |     |     | and it is cleared by software or cleared by reading the  |   |  |  |  |  |
|   |     |     | compare/capture register.                                |   |  |  |  |  |
|   |     |     | 0: No input capture is generated;                        |   |  |  |  |  |
|   |     |     | 1: The counter value has been captured by the            | ; |  |  |  |  |
|   |     |     | compare/capture register 1.                              |   |  |  |  |  |
|   |     |     | Update interrupt flag bit. When an update event occurs,  |   |  |  |  |  |
|   |     |     | this bit is set by hardware and cleared by software.     |   |  |  |  |  |
|   |     |     | 0: No update interrupt is generated;                     |   |  |  |  |  |
|   |     |     | 1: Update interrupt is generated.                        |   |  |  |  |  |
|   |     |     | The update event occurs in case of the following         |   |  |  |  |  |
| 0 | UIF | RW0 | circumstances:                                           | 0 |  |  |  |  |
|   | Off | KWU | For UDIS=0, when the repeated counter value              | U |  |  |  |  |
|   |     |     | overflows or underflows;                                 |   |  |  |  |  |
|   |     |     | For URS=0, UDIS=0, when the UG bit is set, or when       |   |  |  |  |  |
|   |     |     | the counter core is reinitialized by software;           |   |  |  |  |  |
|   |     |     | For URS=0, UDIS=0, when the counter CNT is               |   |  |  |  |  |
|   |     |     | reinitialized by a trigger event;                        |   |  |  |  |  |

# 14.4.6 Event Generation Register (TIMx\_SWEVGR) (x=1/8/9/10)

| 15 | 14 | 13 | 12   | 11   | 10 | 9 | 8 | 7  | 6  | 5    | 4    | 3    | 2    | 1    | 0  |
|----|----|----|------|------|----|---|---|----|----|------|------|------|------|------|----|
|    |    |    | Rese | rved |    |   |   | BG | TG | COMG | CC4G | CC3G | CC2G | CC1G | UG |

| Bit    | Name     | Access | Description                                                                                                                                                                                                                                                                           | Reset value |
|--------|----------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [15:8] | Reserved | RO     | Reserved.                                                                                                                                                                                                                                                                             | 0           |
| 7      | BG       | WO     | Break event generation bit; this bit is set and cleared by software to generate a break event.  0: No effect;  1: A break event is generated. At this time, MOE=0, BIF=1; if the corresponding interrupt and DMA are enabled, the corresponding interrupt and DMA will be generated.  | 0           |
| 6      | TG       | WO     | Trigger event generation bit; this bit is set by software and cleared by hardware to generate a trigger event.  0: No effect;  1: Generate a trigger event; if TIF is set and the corresponding interrupt and DMA are enabled, the corresponding interrupt and DMA will be generated. | 0           |
| 5      | COMG     | WO     | Compare/capture control update generation bit.                                                                                                                                                                                                                                        | 0           |

|   |      |    | Generating compare/capture control update event. This bit is set by software and cleared automatically by hardware.  0: No effect;  1: When CCPC=1, it is allowed to update the CCxE, CCxNE and OCxM bits.  Note: This bit is only valid for channels with complementary outputs (channels 1, 2 and 3).                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |
|---|------|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| 4 | CC4G | WO | Compare/capture event generates bit4. Generating compare/capture event 4.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0 |
| 3 | CC3G | WO | Compare/capture event generates bit3. Generating the compare/capture event 3.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0 |
| 2 | CC2G | WO | Compare/capture event generates bit2. Generating compare/capture event 2.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0 |
| 1 | CC1G | WO | Compare/capture event generates bit1. Generating compare/capture event 1.  This bit is set by software and cleared by hardware. It is used to generate a compare/capture event.  0: No effect;  1: Generating a compare/capture event on the compare/capture 1:  If the compare/capture 1 is configured as output:  CC1IF bit is set. If the corresponding interrupt and DMA are enabled, the corresponding interrupt and DMA is generated;  If the compare/capture is configured as input:  The current core counter value is captured to compare/capture register 1; set the CC1IF bit, if the corresponding interrupt and DMA are enabled, the corresponding interrupt and DMA is generated. If the CC1IF bit has been set, set the CC1OF bit. | 0 |
| 0 | UG   | WO | The update event generation bit generates the update event. This bit is set by software and cleared automatically by hardware.  0: No effect;  1: Initialize the counter and generate an update event.  Note: The counter of prescaler is also cleared, but the prescaler factor remains unchanged. In centro symmetric mode or up-counting mode, the core counter will be cleared; in the down-counting mode, the core counter will take the value of the reload value register.                                                                                                                                                                                                                                                                 | 0 |

## 14.4.7 Compare/Capture Control Register 1 (TIMx\_CHCTLR1) (x=1/8/9/10)

Offset address: 0x18

The channel can be used for input (capture mode) or output (comparison mode), and the direction of the channel is defined by the corresponding CCxS bit. The functions of other bits of this register are different in

input and output modes. OCxx describes the function of the channel in output mode, and ICxx describes the function of the channel in input mode.

| _ | 15    | 14    | _13   | 12   | 11    | 10     | 9    | - 8    | 7     | 6     | 5     | 4    | 3     | 2      | 1    | 0      |
|---|-------|-------|-------|------|-------|--------|------|--------|-------|-------|-------|------|-------|--------|------|--------|
|   | OC2CE | OC    | C2M[2 | 2:0] | OC2PE | OC2FE  | CC20 | 7F1 A7 | OC1CE | OC    | C1M[2 | 2:0] | OC1PE | OC1FE  | 0010 | 351 03 |
| ſ | I     | C2F[: | 3:0]  |      | IC2PS | C[1:0] | CC2S | S[1:0] | I     | C1F[. | 3:0]  |      | IC1PS | C[1:0] | CCIS | 5[1:0] |

Compare mode (pin direction is output):

| Bit     | Name      | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Reset value |
|---------|-----------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| 15      | OC2CE     | RW     | Clear enable bit of compare/capture 2. 0: OC2REF is not affected by the ETRF input; 1: Once the ETRF input high level is detected, clear the OC2REF bit to zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 0           |
| [14:12] | OC2M[2:0] | RW     | Mode setting of compare/capture 2.  The 3 bits define the action of the output reference signal OC2REF, and OC2REF determines the value of OC2 and OC2N. OC2REF is active at high level, while the active level of OC2 and OC2N depends on the CC2P and CC2NP bits.  000: Frozen. The comparison value between the value of the compare/capture register and the core counter has no effect on OC2REF;  001: Forced to be an effective level. When the core counter and compare/capture register 2 have the same value, force OC2REF to be high;  010: Set as inactive level by force. When the value of the core counter is the same as compare/capture register 2, force OC2REF to be low;  011: Overturn. When the core counter and compare/capture register 2 have the same value, overturn the level of OC2REF;  100: Force to be inactive level. Force OC2REF to be low.  101: Force to be inactive level. Force OC2REF to be high.  110: PWM mode 1: When counting up, once the core counter is less than the value of the comparison capture register, channel 2 is an effective level, otherwise it is an invalid level; When counting down, once the core counter is greater than the value of the comparison capture register, Channel 2 is at an invalid level (OC2REF=0), otherwise it is at an effective level (OC2REF=1).  111: PWM mode 2: When counting up, once the core counter is less than the value of the comparison capture register, channel 2 is at an invalid level (OC2REF=1). | 000Ъ        |

|       |           |    | core counter is greater than the value of the comparison capture register, Channel 2 is active (OC2REF=1), otherwise it is inactive (OC2REF=0).  Note: Once the LOCK level is set to 3 and CC1S=00b, this bit cannot be modified. In PWM mode 1 or PWM mode 2, the OC2REF level changes only when compare result changes or when switching from freezing mode to PWM mode in the output comparison mode.                                                                                                                                                                                                                                                                                                                                                                                                              |     |
|-------|-----------|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| 11    | OC2PE     | RW | Preload enable bit of compare/capture register 2.  0: Disable the preload function of capture register 2; it can be written to compare/capture register 2 at any time, and the newly written value will take effect immediately;  1: Enable the preload function of the comparison capture register 2. Read and write operations are only made on the preload register. The preload value of the compare/capture register 2 is loaded into the current shadow register when the update event arrives.  Note: Once the LOCK level is set to 3 and CC2S=00, this bit cannot be modified; only in single pulse mode (OPM=1) you can use PWM mode without confirming the preload register; Otherwise its action is uncertain.                                                                                             | 0   |
| 10    | OC2FE     | RW | Compare/capture 2 fast enable bit; this bit is used to speed up the response of the compare/capture output to the trigger input event.  0: According to the value of counter and compare/capture register 1, compare/capture 2 operates normally, even if the trigger is turned on. When the input of the trigger has a valid edge, the minimum delay for activating the output of the compare/capture 2 will be 5 clock cycles;  1: The effect of the valid edge inputted to the trigger is like a comparison match. Therefore, OC is set to the comparison level regardless of the comparison result. The delay between the valid edge of the sampling trigger and the output of the compare/capture 2 is shortened to 3 clock cycles.  Note: OC2FE only works when the channel is configured in PWM1 or PWM2 mode. | 0   |
| [9:8] | CC2S[1:0] | RW | Input selection of compare/capture 2.  00: Compare/capture 2 is configured as output;  01: Compare/capture 2 is configured as input, and IC2 is mapped on TI2;  10: Compare/capture 2 is configured as input, and IC2 is mapped on TI1;  11: Compare/capture 2 is configured as an input, and                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 00Ь |

|       |           |    | IC2 is mapped on TRC. This mode only works when              |   |
|-------|-----------|----|--------------------------------------------------------------|---|
|       |           |    | the internal trigger input is selected (selected by TS bit). |   |
|       |           |    | Note: Compare/capture 2 is only writable when the            |   |
|       |           |    | channel is switched off (CC2E is zero).                      |   |
| 7     | OC1CE     | RW | Compare/capture 1 clear enable bit.                          | 0 |
| [6:4] | OC1M[2:0] | RW | Mode setting bits of compare/capture 1.                      | 0 |
| 3     | OC1PE     | RW | Preload enable bit of compare/capture register 1.            | 0 |
| 2     | OC1FE     | RW | Fast enable bit of compare/capture 1.                        | 0 |
| [1:0] | CC1S[1:0] | RW | Input selection bits of compare/capture 1.                   | 0 |

## Capture mode (pin direction is input):

| Bit     | Name        | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Reset value |
|---------|-------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [15:12] | IC2F[3:0]   | RW     | Input capture2 filter configuration bits; these bits set the sampling frequency and digital filter length of TI1 input. The digital filter is composed of an event counter, in which N events are needed to validate a transition on the output.  0000: No filter, sampling is done at Fdts; 1000: Fsampling=Fdts/8, N=6; 0001: Fsampling=Fck_int, N=2; 1001: Fsampling=Fck_int, N=4; 1010: Fsampling=Fck_int, N=4; 1010: Fsampling=Fdts/16, N=5; 0011: Fsampling=Fdts/16, N=6; 1010: Fsampling=Fdts/2, N=6; 1100: Fsampling=Fdts/2, N=8; 1101: Fsampling=Fdts/32, N=5; 0110: Fsampling=Fdts/32, N=6; 1110: Fsampling=Fdts/4, N=6; 1111: Fsampling=Fdts/4, N=8; 1111: Fsampling=Fdts/32, N=8; | 0000Ь       |
| [11:10] | IC2PSC[1:0] | RW     | Compare/capture 2 prescaler configuration bits; these 2 bits define prescaler factor of compare/capture 2. Once CC1E=0, the prescaler will be reset.  00: No prescaler, each edge detected on the capture input port triggers a capture;  01: Trigger a capture every 2 events;  10: Trigger a capture every 4 events;  11: Trigger a capture every 8 events;                                                                                                                                                                                                                                                                                                                                 | 00b         |
| [9:8]   | CC2S[1:0]   | RW     | Compare/capture 2 input selection bits. These 2 bits define the direction of the channel (Input/output) and the selection of input pins.  00: Compare/capture 2 is configured as output;  01: Compare/capture 2 is configured as input, and IC1                                                                                                                                                                                                                                                                                                                                                                                                                                               | 00Ь         |

|       |             |    | is mapped on TI1;                                          |   |
|-------|-------------|----|------------------------------------------------------------|---|
|       |             |    | 10: Compare/capture 2 is configured as input, and IC1      |   |
|       |             |    | is mapped on TI2;                                          |   |
|       |             |    | 11: Compare/capture 2 is configured as an input, and       |   |
|       |             |    | IC1 is mapped on TRC. This mode only works when            |   |
|       |             |    | the internal trigger input is selected (Selected by the TS |   |
|       |             |    | bit).                                                      |   |
|       |             |    | Note: CC2S is writable only when the channel is closed     |   |
|       |             |    | (CC2E is 0).                                               |   |
| [7:4] | IC1F[3:0]   | RW | Input capture1 filter configuration bits.                  | 0 |
| [3:2] | IC1PSC[1:0] | RW | Prescale configuration bits of compare/capture 1.          | 0 |
| [1:0] | CC1S[1:0]   | RW | Input selection bits of compare/capture 1.                 | 0 |

### 14.4.8 Compare/Capture Control Register 2 (TIMx\_CHCTLR2) (x=1/8/9/10)

Offset address: 0x1C

The channel can be used for input (Capture mode) or output (Compare mode), and the direction of the channel is defined by the corresponding CCxS bit. The functions of other bits of this register are different in input and output modes. OCxx describes the function of the channel in output mode, and ICxx describes the function of the channel in input mode.

| 15    | 14    | 13    | 12   | 11    | 10     | 9    | 8      | 7     | 6    | 5     | 4    | 3     | 2      | 1   | 0       |
|-------|-------|-------|------|-------|--------|------|--------|-------|------|-------|------|-------|--------|-----|---------|
| OC4CE | 00    | C4M[2 | 2:0] | OC4PE | OC4FE  | CC16 | 251.01 | OC3CE | OC   | C3M[2 | 2:0] | ОС3РЕ | OC3FE  | CC2 | 251.01  |
|       | [C4F[ | 3:0]  |      | IC4PS | C[1:0] | CC4S | 5[1:0] | I     | C3F[ | 3:0]  |      | IC3PS | C[1:0] | CC3 | S[1:0][ |

#### Compare mode (pin direction is output):

| Bit     | Name      | Access | Description                                       | Reset value |
|---------|-----------|--------|---------------------------------------------------|-------------|
| 15      | OC4CE     | RW     | Clear enable bit of compare/capture 4.            | 0           |
| [14:12] | OC4M[2:0] | RW     | Mode setting of compare/capture 4.                | 0           |
| 11      | OC4PE     | RW     | Preload enable bit of compare/capture register 4. | 0           |
| 10      | OC4FE     | RW     | Fast enable bit of compare/capture 4.             | 0           |
| [9:8]   | CC4S[1:0] | RW     | Input selection of compare/capture 4.             | 0           |
| 7       | OC3CE     | RW     | Clear enable bit of compare/capture 3.            | 0           |
| [6:4]   | OC3M[2:0] | RW     | Mode setting of compare/capture 3.                | 0           |
| 3       | OC3PE     | RW     | Preload enable bit of compare/capture register 3. | 0           |
| 2       | OC3FE     | RW     | Fast enable bit of compare/capture 3.             | 0           |
| [1:0]   | CC3S[1:0] | RW     | Input selection of compare/capture 3.             | 0           |

### Capture mode (pin direction is input):

| Bit     | Name        | Access | Description                                  | Reset value |
|---------|-------------|--------|----------------------------------------------|-------------|
| [15:12] | IC4F[3:0]   | RW     | Input capture 4 filter configuration.        | 0           |
| [11:10] | IC4PSC[1:0] | RW     | Prescale configuration of compare/capture 4. | 0           |
| [9:8]   | CC4S[1:0]   | RW     | Input selection of compare/capture 4.        | 0           |
| [7:4]   | IC3F[3:0]   | RW     | Input capture 3 filter configuration.        | 0           |
| [3:2]   | IC3PSC[1:0] | RW     | Prescale configuration of compare/capture 3. | 0           |
| [1:0]   | CC3S[1:0]   | RW     | Input selection of compare/capture 3.        | 0           |

# 14.4.9 Compare/Capture Enable Register (TIMx\_CCER) (x=1/8/9/10)

| 15 14        | 13       | 12       | 11        | 10        | 9        | 8        | 7         | 6         | 5 | 4 | 3         | 2         | 1        | 0        |
|--------------|----------|----------|-----------|-----------|----------|----------|-----------|-----------|---|---|-----------|-----------|----------|----------|
| Reserve<br>d | CC4<br>P | CC4<br>E | CC3N<br>P | CC3N<br>E | CC3<br>P | CC3<br>E | CC2N<br>P | CC2N<br>E |   |   | CC1N<br>P | CC1N<br>E | CC1<br>P | CC1<br>E |

| Bit     | Name     | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Reset value |
|---------|----------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [15:14] | Reserved | RO     | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0           |
| 13      | CC4P     | RW     | Output polarity setting bit of compare/capture 4.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0           |
| 12      | CC4E     | RW     | Output enable bit of compare/capture 4.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0           |
| 11      | CC3NP    | RW     | Complementary output polarity setting bit of compare/capture 3.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0           |
| 10      | CC3NE    | RW     | Complementary output enable bit of compare/capture 3.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 0           |
| 9       | CC3P     | RW     | Output polarity setting bit of compare/capture 3.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0           |
| 8       | CC3E     | RW     | Output enable bit of compare/capture 3.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0           |
| 7       | CC2NP    | RW     | Complementary output polarity setting bit of compare/capture 2.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0           |
| 6       | CC2NE    | RW     | Complementary output enable bit of compare/capture 3.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 0           |
| 5       | CC2P     | RW     | Output polarity setting bit of compare/capture 2.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0           |
| 4       | CC2E     | RW     | Output enable bit of compare/capture 2.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0           |
| 3       | CC1NP    | RW     | Complementary output polarity setting bit of compare/capture 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0           |
| 2       | CC1NE    | RW     | Complementary output enable bit of compare/capture 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 0           |
| 1       | CC1P     | RW     | Output polarity setting bit of compare/capture 1.  CC1 channel configured as output:  0: OC1 active high;  1: OC1 active low.  CC1 channel configured as input:  This bit selects whether IC1 or the inverted signal of IC1 is used as the trigger or capture signal.  0: Non-inverted: capture occurs on the rising edge of IC1; when used as an external trigger, IC1 is not inverted;  1: Inverted: capture occurs on the falling edge of IC1; when used as an external trigger, IC1 is inverted.  Note: Once the LOCK level (LOCK bit in TIMx_BDTR register) is set to 3 or 2, this bit cannot be modified. | 0           |
| 0       | CC1E     | RW     | Output enable bit of compare/capture 1.  The CC1 channel is configured as output:  0: off. OC1 disables output, so the output level of OC1 depends on the values of MOE, OSSI, OSSR, OIS1, OIS1N, and CC1NE bits.  1: On. The OC1 signal is output to the corresponding output pin, and its output level depends on the values of the MOE, OSSI, OSSR, OIS1, OIS1N, and CC1NE bits.                                                                                                                                                                                                                             | 0           |

| The CC1 channel is configured as an input:           |
|------------------------------------------------------|
| This bit determines whether the counter value can be |
| captured into the TIMx_CCR1 register.                |
| 0: Capture disable;                                  |
| 1: capture enable.                                   |

## 14.4.10 Counter of Advanced-control Timer (TIMx\_CNT) (x=1/8/9/10)

Offset address: 0x24

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8   | 7      | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|-----|--------|---|---|---|---|---|---|---|
|    |    | _  |    |    |    |   | CNT | [15:0] |   |   |   |   |   |   |   |

| Bit    | Name      | Access | Description                         | Reset value |
|--------|-----------|--------|-------------------------------------|-------------|
| [15:0] | CNT[15:0] | RW     | Real-time value of timer's counter. | 0           |

## 14.4.11 Count Clock Prescaler (TIMx\_PSC) (x=1/8/9/10)

Offset address: 0x28



| Bit    | Name      | Access | Description                                                                                                                                        | Reset value |
|--------|-----------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [15:0] | PSC[15:0] | RW     | The frequency division factor of the timer's prescaler; the clock frequency of the counter is equal to the input frequency of the divider/(PSC+1). |             |

### 14.4.12 Auto-reload Register (TIMx ATRLR) (x=1/8/9/10)

Offset address: 0x2C



| Bit    | Name      | Access | Description                                                                                                                                                      | Reset value |
|--------|-----------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [15:0] | ARR[15:0] | RW     | The value of these bits is loaded into the counter. Please refer to Section 14.2.3 for ATRLR acting and update time; when ATRLR is empty, the counter will stop. |             |

### 14.4.13 Repeat Count Register (TIMx\_RPTCR) (x=1/8/9/10)



| Bit    | Name     | Access | Description             | Reset value |
|--------|----------|--------|-------------------------|-------------|
| [15:8] | Reserved | RO     | Reserved.               | 0           |
| [7:0]  | REP[7:0] | RW     | Repeated counter value. | 0           |

### 14.4.14 Compare/Capture Register 1 (TIMx CH1CVR) (x=1/8/9/10)

Offset address: 0x34

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0

CCR1[15:0]

| Bit    | Name       | Access | Description                                  | Reset value |
|--------|------------|--------|----------------------------------------------|-------------|
| [15:0] | CCR1[15:0] | RW     | Value of compare/capture register channel 1. | 0           |

## 14.4.15 Compare/Capture Register 2 (TIMx\_CH2CVR) (x=1/8/9/10)

Offset address: 0x38

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0

CCR2[15:0]

| Ï | Bit    | Name       | Access | Description                                  | Reset value |
|---|--------|------------|--------|----------------------------------------------|-------------|
| ĺ | [15:0] | CCR2[15:0] | RW     | Value of compare/capture register channel 2. | 0           |

### 14.4.16 Compare/Capture Register 3 (TIMx CH3CVR) (x=1/8/9/10)

Offset address: 0x3C

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 CCR3[15:0]

|   | Bit    | Name       | Access | Description                                  | Reset value |
|---|--------|------------|--------|----------------------------------------------|-------------|
| ĺ | [15:0] | CCR3[15:0] | RW     | Value of compare/capture register channel 3. | 0           |

## 14.4.17 Compare/Capture Register4 (TIMx\_CH4CVR) (x=1/8/9/10)

Offset address: 0x40

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 CCR4[15:0]

| ĺ | Bit Name Acces |            | Access | Description                                  | Reset value |
|---|----------------|------------|--------|----------------------------------------------|-------------|
| ĺ | [15:0]         | CCR4[15:0] | RW     | Value of compare/capture register channel 4. | 0           |

### 14.4.18 Break and Deadband Register (TIMx BDTR) (x=1/8/9/10)

Offset address: 0x44

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 MOE AOE BKP BKE OSSR OSSI LOCK[1:0] DTG[7:0]

| Bit | Name | Access | Description                                                                                                                                            | Reset value |
|-----|------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| 15  | МОЕ  | RW     | Master output enable bit. Once a break signal is effective, it will be cleared asynchronously.  0: Disable the output of OCx and OCxN or setting it to | 0           |

|       |           |    | idle status by force;                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|-------|-----------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
|       |           |    | 1: Enable to set OCx and OCxN as output.                                                                                                                                                                                                                                                                                                                                                                                                                                             |   |
| 14    | AOE       | RW | Automatic output enable.  0: MOE can only be set by software;  1: MOE can be set by software or set in the next update event.                                                                                                                                                                                                                                                                                                                                                        | 0 |
| 13    | ВКР       | RW | Break input polarity setting bit.  0: Break input active at low level;  1: Break input active at high level.  Note: When LOCK level 1 is set, this bit cannot be modified. Writing to this bit requires an PB clock to take effect.                                                                                                                                                                                                                                                  | 0 |
| 12    | ВКЕ       | RW | Break function enable bit.  0: Disable break input;  1: Enable break input.  Note: When LOCK level 1 is set, this bit cannot be modified. Writing to this bit requires an PB clock to take effect.                                                                                                                                                                                                                                                                                   | 0 |
| 11    | OSSR      | RW | 0: Disable OC/OCN output when the timer is not working; 1: When the timer is not working, once CCxE=1 or CCxNE=1, firstly turn on OC/OCN and output an inactive level, and then set the OCx and OCxN to enable output signal =1.  Note: When LOCK level 1 is set, this bit cannot be modified.                                                                                                                                                                                       | 0 |
| 10    | OSSI      |    | 0: Disable OC/OCN output when the timer is not working; 1: When the timer is not working, once CCxE=1 or CCxNE=1, OC/OCN will firstly output its idle level, and then OCx, OCxN will enable output signal=1.  Note: When LOCK level 1 is set, this bit cannot be modified.                                                                                                                                                                                                           | 0 |
| [9:8] | LOCK[1:0] | RW | Lock function setting.  00: Switching off the lock function; 01: Lock level 1; DTG, BKE, BKP, AOE, OISx and OISxN bits cannot be written; 10: Lock level 2; you cannot write the bits in lock level 1, nor can you write the CC polarity bit, OSSR and OSSI bits; 11: Lock level 3; you cannot write each bit in lock level 2, nor can you write the CC control bit.  Note: After the system reset, the LOCK bit can only be written once, and cannot be modified again until reset. | 0 |

|       |          |    | Deadband setting bits; these bits define the duration of |   |
|-------|----------|----|----------------------------------------------------------|---|
|       |          |    | the deadband between complementary outputs.              |   |
|       |          |    | Assume that DT represents its duration:                  |   |
|       |          |    | DTG[7:5]=0xx=>DT=DTG[7:0]*Tdtg, Tdtg =TDTS;              |   |
|       |          |    | DTG[7:5]=10x=>DT=(64+DTG[5:0])*Tdtg,                     |   |
|       |          |    | Tdtg= 2*TDTS;                                            |   |
| [7:0] | DTG[7:0] | RW | DTG[7:5]=110=>DT=(32+DTG[4:0])*Tdtg,                     | 0 |
|       |          |    | Tdtg =8 ×TDTS;                                           |   |
|       |          |    | DTG[7:5]=111=>DT=(32+DTG[4:0])*Tdtg,                     |   |
|       |          |    | Tdtg =16 *TDTS.                                          |   |
|       |          |    | Note: Once the LOCK level (LOCK[1:0] bits in the         |   |
|       |          |    | TIMx_BDTR register) is set to 01b, 10b, or 11b, these    |   |
|       |          |    | bits cannot be modified.                                 |   |

# 14.4.19 DMA Configuration Register (TIMx\_DMACFGR) (x=1/8/9/10)

| 15 | 14     | 13 | 12 | 11 | 10      | 9      | 8 | 7 | 6      | 5 | 4 | 3 | 2      | 1  | 0 |
|----|--------|----|----|----|---------|--------|---|---|--------|---|---|---|--------|----|---|
| R  | eserve |    |    | Г  | )BL[4:( | <br>)] |   | R | eserve |   |   | D | BA[4:0 | )] |   |

| Bit     | Name     | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Reset value |
|---------|----------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [15:13] | Reserved | RO     | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0           |
| [12:8]  | DBL[4:0] |        | Length of DMA continuous transfer; the actual value is the value of these bits + 1.  When the TIMx_DMAADR register is read or written, the timer performs a continuous transmission), that is, defining the number of transmissions. The transmission can be half words (Double bytes) or bytes:  00000: 1 transmission;  00001: 2 transmissions;  00002: 3 transmissions;   10001: 18 transmissions.  Suppose we perform such transmission: DBL=7, DBA=TIM2_CTLR1.  If DBL=7, DBA=TIM2_CTLR1 represents the address of the data to be transferred, then the transferred address is given by the following formula: (address of TIMx_CTLR1)+DBA+(DMA index), where DMA index=DBL, where (Address of TIMx_CTLR1)+ DBA plus 7 gives the address where the data will be written or read, so that the data transfer will occur in 7 registers starting from the address (The address of TIMx_CR1) + DBA. Depending on the setting of the DMA data length, the following situations may occur: | 0           |

|       |                                         |    | 1. If the data is set to half word (16 bits), then the data |   |
|-------|-----------------------------------------|----|-------------------------------------------------------------|---|
|       | will be transferred to all 7 registers. |    | will be transferred to all 7 registers.                     |   |
|       |                                         |    | 2. If the data is set to bytes, the data will still be      |   |
|       |                                         |    | transferred to all 7 registers: the first register contains |   |
|       |                                         |    | the first MSB byte, the second register contains the first  |   |
|       |                                         |    | LSB byte, and so on. So for timers, the user must           |   |
|       |                                         |    | specify the data width transferred by DMA.                  |   |
| [7:5] | Reserved                                | RO | Reserved.                                                   | 0 |
|       |                                         |    | These bits define the offset of DMA from the address        |   |
|       |                                         |    | of control register1 in continuous mode.                    |   |
| [4.0] | DD 4 [4.0]                              | DW | 00000: TIMx_CTLR1;                                          | 0 |
| [4:0] | DBA[4:0]                                | RW | 00001: TIMx_CTLR2;                                          | U |
|       |                                         |    | 00010: TIMx_SMCFGR;                                         |   |
|       |                                         |    |                                                             |   |

# 14.4.20 DMA Address Register in Continuous Mode (TIMx\_DMAADR) (x=1/8/9/10)

Offset address: 0x4C

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 DMAB[15:0]

| Bit    | Name       | Access | Description                                                                                                                                                                                                                                                                                            | Reset value |
|--------|------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| Dit    | Ivanic     | Access | DMA address in continuous mode.  Reading or writing the TIMx_DMAADR register will result in an access operation to the register located at the following address: TIMx_CTLR1 address + DBA +                                                                                                           |             |
| [15:0] | DMAB[15:0] | RW     | DMA index, where: "TIMx_CTLR1 address" is the address where control register 1 (TIMx_CTLR1) is located; "DBA" is the TIMx_DMACFGR register. The base address defined in the "DMA index" is the offset automatically controlled by the DMA and depends on the DBL defined in the TIMx_DMACFGR register. | 0           |

## 14.4.21 Dual-edge Capture Register (TIMx\_AUX) (x=1/8/9/10)

Offset address: 0x50

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0

Reserved CAP\_ED\_CH4 CAP\_ED\_CH3 CAP\_ED\_CH2

| Bit    | Name       | Access | Description                                                                                                                                             | Reset value |
|--------|------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [15:3] | Reserved   | R0     | Reserved                                                                                                                                                | 0           |
| 2      | CAP_ED_CH4 |        | Dual-edge capture enable for channel 4:  0: Disables the dual-edge capture enable for channel 4;  1: Enable the dual-edge capture enable for channel 4. | 0           |

| 1 | CAP_ED_CH3 | RW | Dual-edge capture enable for channel 3:  0: Disables the dual-edge capture enable for channel 3;  1: Enable the dual-edge capture enable for channel 3. | 0 |
|---|------------|----|---------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| 0 | CAP_ED_CH2 | RW | Dual-edge capture enable for channel 2: 0: Disables the dual-edge capture enable for channel 2; 1: Enable the dual-edge capture enable for channel 2.   | 0 |

Note: The TIMx\_AUX register is only available for CH32F20x\_D8, CH32F20x\_D8C, CH32V30x\_D8, CH32V30x\_D8C, and CH32V31x\_D8C lot numbers that do not have a zero in the penultimate sixth digit.

# **Chapter 15 General-purpose Timer (GPTM)**

This chapter applies to the whole family of CH32F20x, CH32V20x, CH32V30x and CH32V31x.

The general-purpose timer module contains 4 16-bit timers (TIM2, TIM3, TIM4 and TIM5) that can be automatically reloaded to measure pulse width or generate specific frequency pulse and PWM wave, etc. It can be used for automatic control and power.

Note: For the products of CH32F20x\_D8W, CH32V20x\_D8 and CH32V20x\_D8W series, the TIM5 is 32-bit, and the TIM5 of other series chips is 16-bit.

### 15.1 Main Features

General purpose timer features include:

- 16-bit automatic reload counter, supports upcount, downcount and up/down-count
- 16-bit prescaler; the frequency division factor is dynamically adjustable from 1 to 65536
- Four independent compare/captures channels
- Each compare/capture channel supports multiple working modes, such as: input capture, output comparison, PWM generation and single pulse output
- External signal to control timer
- DMA generation in multiple modes

### 15.2 Principle and Structure



Figure 15-1 Structure block diagram of general-purpose timer

#### 15.2.1 Overview

As shown in Figure 15-1, the structure of the general-purpose timer can be roughly divided into 3 parts: Input clock, core counter and compare/capture channel.

The general-purpose timer clock can come from HB bus clock (CK\_INT), external clock input pin (TIMx\_ETR), other timers with clock output function (ITRx), or the input end of compare/capture channel (TIMx\_CHx). These input clock signals will become CK\_PSC clocks after various set filtering and frequency division operations, and will output to the core counterpart. In addition, these complex clock sources can also be output as TRGO to other peripherals such as timer, ADC and DAC.

The core of the general-purpose timer is a 16-bit counter (CNT). After CK\_PSC is divided by the prescaler (PSC), it becomes CK\_CNT and finally outputs to CNT. CNT supports up-counting mode, down-counting mode and up/down counting mode, and there is an automatic reload value register (ATRLR). After each

counting cycle is completed, CNT will be reloaded with the initial value.

The general-purpose timer has 4 groups of compare/captures. On each group of compare/capture, pulses can be inputted from its dedicated pins or output waveforms to the pins, i.e., the compare/captures support input and output modes. The input of each channel of the compare/capture register supports operations such as filtering, frequency division and edge detection, and supports mutual triggering between channels, and can also provide a clock for the core counter CNT. Each compare/capture has a set of compare/capture register (CHxCVR), which supports comparison with the main counter (CNT) so as to output pulse.

#### 15.2.2 Difference between General-purpose Timer and Advanced-control Timer

Compared with the advanced-control timer, the general-purpose timer is lack of the following functions:

- 1) The general-purpose timer lacks a repeated counting register that counts the count cycle of core counter.
- 2) The compare/capture of general-purpose timer lacks deadband generation and has no complementary output.
- 3) The general-purpose timer has no break signal mechanism.
- 4) The default clock CK\_INT of the general-purpose timer comes from PB1, while the CK\_INT of the advanced-control timer comes from PB2.

#### 15.2.3 Clock Input

This section describes the source of CK\_PSC. The clock source part of the general structure block diagram of the general-purpose timer is abstracted here.



Figure 15-2 Block diagram of general-purpose timer source

The available input clocks can be divided into 4 categories:

- 1) External clock pin (ETR) input: ETR→ETRP→ETRF;
- 2) Internal PB clock input: CK INT;
- 3) From the compare/capture pin (TIMx CHx): TIMx CHx \rightarrow TIx \rightarrow TIxFPx; it is also used in encoder mode;
- 4) Input from other internal timers: ITRx.

The actual operation can be divided into 3 categories by determining the input pulse selection of the SMS from the CK\_PSC source:

- 1) Select the internal clock source (CK INT);
- 2) External clock source mode 1;
- 3) External clock source mode 2;

4) Encoder code.

The 4 clock sources mentioned above can be selected by these 4 operations.

#### 15.2.3.1 Internal Clock Source (CK INT)

If the general-purpose timer is started when the SMS domain is kept at 000b, then the internal clock source (CK INT) is selected as the clock. At this moment, CK INT is CK PSC.

#### 15.2.3.2 External Clock Source Model

If SMS is set to 111b, the external clock source model is enabled. When external clock source model is enabled, TRGI is selected as the source of CK\_PSC. It is worth noting that the user needs to configure TS to select the source of TRGI. For TS, the following pulses can be used as the clock source:

- 1) Internal Trigger (ITRx, x is 0,1,2,3);
- 2) Signal of compare/capture1 after passing through the edge detector (TI1F ED);
- 3) Signals TI1FP1 and TI2FP2 of compare/capture;
- 4) Signal ETRF from external clock pin.

#### 15.2.3.3 External Clock Source Mode2

Use external trigger mode2 to count on every rising or falling edge of the external clock pin input. When the ECE bit is set, the external clock source mode2 is enabled. When the external clock source mode2 is enabled, ETRF is selected as CK\_PSC. The ETR pin passes through the optional inverter (ETP) and frequency divider (ETPS) to become ETRP, and then passes through the filter (ETF) to become ETRF.

When the ECE bit is set and the SMS is set to 111b, it means that the TS selects ETRF as the input.

#### 15.2.3.4 Encoder Mode

Set SMS to 001b, 010b and 011b to enable the encoder mode. After enable the encoder mode, you may choose to use another transition edge as a signal for signal output at a certain level in TI1FP1 and TI2FP2. This mode is used when the external encoder is used. Refer to Section15.3.7 for the specific functions.

#### 15.2.4 Counter and Periphery

CK\_PSC inputs to the prescaler (PSC) for frequency division. PSC has 16 bits, and the actual frequency division factor is equivalent to the value of R16\_TIMx\_PSC+1. CK\_PSC becomes CK\_INT through PSC. The changed value of R16\_TIM1\_PSC does not take effect in real time, but can be updated to the PSC after the update event. Update events include clearing and resetting the UG bit.

### 15.2.5 Compare/capture Channel

The compare/capture is the core of the timer to achieve complex functions. Its core is the compare/capture register, supplemented by the digital filtering of the peripheral input part, frequency division and channel multiplexing, the output part comparator and output control. The block diagram of the compare/capture is as shown in Figure 15-3.



Figure 15-3 Structure block diagram of compare/capture channel

After the signal is input from the channel x pin, it can be selected as TIx (the source of TI1 may be more than CH1. See Figure 14-1 timer block diagram). TI1 passes through the filter (ICF[3:0]) to generate TI1F, and then is divided into TI1F\_Rising and TI1F\_Falling after passing through the edge detector. These 2 signals are selected (CC1P) to generate TI1FP1, and TI1FP1 and TI2FP1 from channel 2 are sent to CC1S together to be selected as IC1, and then sent to the compare/capture register after going through the ICPS frequency division. The compare/capture register is composed of preload register and shadow register, and only the preload register is operated during reading and writing. In the capture mode, the capture occurs on the shadow register, and then copied to the preload register; in the comparison mode, the content of the preload register is copied to the shadow register, and then the content of the shadow register is compared with the core counter (CNT).

## 15.3 Function and Implementation

The general-purpose timer complex functions are implemented by the operation of compare/capture channel, clock input circuit, counter and peripheral parts of the timer. The timer's clock input can come from multiple clock sources including the input of the compare/capture. The operation of compare/capture register channel and the clock source selection directly determines its function. The compare/capture is bidirectional and can work in input and output modes.

#### 15.3.1 Input Capture Mode

The input capture mode is one of basic functions of timer. The principle of the input capture mode is that when a certain edge on the ICxPS signal is detected, a capture event will occur, and the current value of the counter will be latched into the compare/capture register (R16\_TIMx\_CHCTLRx). When a capture event occurs, CCxIF (in R16\_TIMx\_INTFR) bit will be set. If an interrupt or DMA is enabled, a corresponding interrupt or DMA will be generated. If CCxIF is already set when a capture event occurs, then the CCxOF bit will be set. CCxIF can be cleared by software or by hardware through reading the compare/capture register. CCxOF is cleared by the software.

Take an example of channel 1 to illustrate the steps to use the input capture mode, as follows:

- 1) Configure CCxS and select the source of ICx signal. For example, it is set to 10b, and TI1FP1 is selected as the source of IC1, and the default setting cannot be used. CCxS defaults to use the compare capture module as the output channel;
- 2) Configure ICxF and set the digital filter of the TI signal. The digital filter will output a jump based on the determined frequency and determined sampling times. The sampling frequency and times are determined by ICxF;
- 3) Configure the CCxP bit and set the polarity of TIxFPx. For example, maintain CC1P bit to be low and select the jump of rising edge;
- 4) Configure ICxPS and set ICx signal as the frequency division factor between ICxPS. For example, maintain the ICxPS as 00b without frequency division;
- 5) Configure the CCxE bit to allow to capture the core counter (CNT) value to the compare/capture register. Set the CC1E bit;
- 6) Configure the CCxIE and CCxDE bits as needed to decide whether to enable interrupt or DMA. After these operations, the compare/capture channel configuration is completed.

When TI1 inputs a captured pulse, the value of the core counter (CNT) is recorded in the compare/capture register, and CC1IF is set. When CC1IF has been set before, the CCIOF bit will also be set. If the CC1IE bit is set, then an interrupt will be generated; if CC1DE is set, a DMA request will be generated. An input capture event can be generated by software through writing the event generation register (R16\_TIMx\_SWEVGR).

#### 15.3.2 Compare Output Mode

The compare output mode is one of basic functions of timer. The principle of the compare output mode is to output a specific change or waveform when the value of the core counter (CNT) is consistent with the value of the compare/capture register. OCxM (in R16\_TIMx\_CHCTLRx) and the CCxP bit (in R16\_TIMx\_CCER) determine whether the output is determined high or low level or level inversion. When a compare consistent event is generated, the CCxIF bit will be also set. If the CCxIE bit is preset, an interrupt will be generated; if the CCxDE bit is preset, a DMA request will be generated.

The procedure of compare output mode configuration is as follows:

- 1) Configure the clock source and auto-reload value of the core counter (CNT);
- 2) Set the count value to be compared to the compare/capture register (R16\_TIMx\_CHxCVR);

- 3) If an interrupt needs to be generated, set the CCxIE bit;
- 4) Keep OCxPE as 0 and disable the preload register of the compare/capture register;
- 5) Set the output mode, and set OCxM and CCxP bit;
- 6) Enable the output and set the CCxE bit;
- 7) Set the CEN bit and start the timer;

#### 15.3.3 Forced Output Mode

The output mode of the compare/capture of the timer can be forced to output a certain level by software, instead of relying on the shadow register and the core counter of the compare/capture register.

The specific means is to set OCxM to 100b, which means to force OCxREF to be low; or to set OCxM to 101b, which means setting OCxREF to a high value by force.

It shall be noted that if OCxM is set to 100b or 101b by force, the compare process between the internal main counter and the compare/capture register will be still in progress, the corresponding flag bit will be still set, and interrupts and DMA request will still be generated.

#### 15.3.4 PWM Input Mode

The PWM input mode is used to measure the duty cycle and frequency of the PWM, which is a special case of the input capture mode. The operation is the same as the input capture mode except for the following differences: PWM occupies 2 compare/captures, and the input polarity of the 2 channels is set to opposite. One of the signals is set to trigger input, and SMS is set to reset mode.

For example, to measure the cycle and frequency of the PWM wave input from TI1, the following operations are required:

- 1) Set TI1 (TI1FP1) as the input of IC1 signal. Set CC1S to 01b;
- 2) Set TI1FP1 as the rising edge valid. Keep CC1P as 0;
- 3) Set TI1 (TI1FP2) as the input of IC2 signal. Set CC2S to 10b;
- 2) Set TI1FP2 as the falling edge valid. Set CC2P to 1;
- 5) The source of the clock source is TI1FP1. Set TS to 101b;
- 6) Set SMS to reset mode, i.e., 100b;
- 7) Enable the input capture. Set CC1E and CC2E bits.

Note: Since only TI1FP1 and TI2FP2 are connected to the slave mode controller, only TIMx\_CH1/TIMx\_CH2 can be used in the PWM input mode.

### 15.3.5 PWM Output Mode

The PWM output mode is one of basic functions of timer. The most common method of PWM output mode is to use the reload value to determine the PWM frequency, and to use the capture comparison register to determine the duty cycle. Set 110b or 111b in OCxM to use PWM mode 1 or mode 2, set the OCxPE bit to enable the preload register, and finally set the ARPE bit. Since the value of the preload register can be sent to the shadow register when an update event occurs, it is necessary to set the UG bit to initialize all registers before the core counter starts counting. In the PWM mode, the core counter and the compare/capture register are always being compared. According to the CMS bit, the timer can output edge-aligned or center-aligned PWM signals.

#### • Edge alignment

When the edge alignment is used, the core counter counts up or down. In the scenario of PWM mode 1, when the value of the core counter is greater than that of the compare/capture register, OCxREF will rise to be high; when the value of the core counter is less than the compare/capture register (such as When the core counter

increases to the value of R16 TIMx ATRLR and returns to all 0s), OCxREF drops to low.

#### Central alignment

When the center-aligned mode is used, the core counter will run in a mode where up counting and down counting are performed alternately, and OCxREF performs rising and falling jumps when the values of the core counter and the compare/capture register are consistent. However, in 3 types of central alignment mode, the bit setting timing of comparison flag is different somewhat. When the center-alignment mode is used, it is the best to generate a software update flag (set the UG bit) before starting the core counter.

### 15.3.6 Single Pulse Mode

The single pulse mode can be used to respond to a specific event to generate a pulse after a delay. The delay and pulse width are programmable. Setting the OPM bit can make the core counter stop when the next update event UEV is generated (the counter turns over to 0).



Figure 15-4 Event generation and pulse response

As shown in Figure 15-4, it is necessary to detect the beginning of a rising edge on the TI2 input pin. After delaying Tdelay, a positive pulse of length Tpulse will be generated on OC1:

- 1) Set TI2 as trigger. Set the CC2S field to 01b and map TI2FP2 to TI2; set the CC2P bit to 0b and set TI2FP2 to rising edge detection; set the TS field to 110b and set TI2FP2 as the trigger source; set the SMS field to 110b, and TI2FP2 is used to start the counter;
- 2) Tdelay is defined by the value of the compare/capture register, and Tpulse is determined by the value of the auto-reload value register and the value of the compare/capture register.

### 15.3.7 Encoder Mode

The encoder mode is a typical application of the timer. It can be used to access the dual-phase output of the encoder. The count direction of the core counter is synchronized with the rotating shaft of the encoder. Each pulse output by the encoder will increase the core counter by adding one or subtracting one. The steps to use the encoder are: set the SMS field to 001b (count only on TI2 edge), 010b (count only on TI1 edge) or 011b (count on both TI1 and TI2 edges), and connect the encoder to compare/capture 1, 2 inputs, set a value for the reload value register and this value can be set to be greater. In the encoder mode, the internal compare/capture register of timer, prescaler, repeat count register and other registers all work normally. The following table shows the relationship between the counting direction and the encoder signal.

V2. 4 240 **WI**H

TI1FP1 signal edge TI2FP2 signal edge Relative Count active edge signal Rising Falling Rising **Falling** level edge edge edge edge Downcount Upcount High Only count at TI1 edge Not count Low Upcount Downcount Upcount Downcount High Only count at TI2 edge Not count Low Downcount Upcount Count on both edges of High Downcount Upcount Upcount Downcount TI1 and TI2 Low Upcount Downcount Downcount Upcount

Table 15-1 Relationship between count direction of timer in encoder mode and encoder signal

#### 15.3.8 Timer Synchronous Mode

The timer can output clock pulses (TRGO) and can also receive input from other timers (ITRx). The sources of ITRx of different timers (TRGO of other timers) are different. Table 15-2 shows the internal trigger connection of timers.

|   | rigate 13 2 GTI W meethat trigger connection |              |              |              |              |  |  |  |  |  |  |
|---|----------------------------------------------|--------------|--------------|--------------|--------------|--|--|--|--|--|--|
|   | Slave timer                                  | ITR0(TS=000) | ITR1(TS=001) | ITR2(TS=010) | ITR3(TS=011) |  |  |  |  |  |  |
| I | TIM2                                         | TIM1         | TIM8/USB/ETH | TIM3         | TIM4         |  |  |  |  |  |  |
|   | TIM3                                         | TIM1         | TIM2         | TIM5         | TIM4         |  |  |  |  |  |  |
|   | TIM4                                         | TIM1         | TIM2         | TIM3         | TIM8         |  |  |  |  |  |  |
| ı | TIM5                                         | TIM2         | TIM3         | TIM4         | TIM8         |  |  |  |  |  |  |

Figure 15-2 GTPM internal trigger connection

#### 15.3.9 Dual-edge Capture Mode

The pulse can be measured through the TIMx\_AUX register.

CH32V31x D8C lot numbers where the penultimate sixth bit is not zero.

For example, to capture the pulse width through channel 2, on the capture function configuration, select the source of the IC2 signal (CC2S bit of the TIMx\_CHCTLR1 register is 11b), and enable the dual-edge capture function of channel 2 (CAP\_ED\_CH2 bit of the TIMx\_AUX register is 1). At this point the dual-edge capture configuration has been completed.

The captured dual-edge pulse width value can be read with the CCR2 bit of the TIMx\_CH2CVR register.

Note: Only available for CH32F20x\_D8, CH32F20x\_D8C, CH32V30x\_D8, CH32V30x\_D8C, and

#### **15.3.10 Debug Mode**

When the system enters debug mode, the timer continues to run or stops according to the setting of the DBG module.

## 15.4 Register Description

Table 15-3 TIM2 registers

| Name Offset address |            | Description            | Reset value |
|---------------------|------------|------------------------|-------------|
| R16_TIM2_CTLR1      | 0x40000000 | TIM2 control register1 | 0x0000      |

| R16_TIM2_CTLR2     | 0x40000004 | TIM2 control register2                  | 0x0000 |  |
|--------------------|------------|-----------------------------------------|--------|--|
| R16_TIM2_SMCFGR    | 0x40000008 | TIM2 slave mode configuration register  | 0x0000 |  |
| R16_TIM2_DMAINTENR | 0x4000000C | TIM2 DMA/interrupt enable register      | 0x0000 |  |
| R16_TIM2_INTFR     | 0x40000010 | TIM2 interrupt flag register            | 0x0000 |  |
| R16_TIM2_SWEVGR    | 0x40000014 | TIM2 event generation register          | 0x0000 |  |
| R16_TIM2_CHCTLR1   | 0x40000018 | TIM2 compare/capture control register1  | 0x0000 |  |
| R16_TIM2_CHCTLR2   | 0x4000001C | TIM2 compare/capture control register2  | 0x0000 |  |
| R16_TIM2_CCER      | 0x40000020 | TIM2 compare/capture enable register    | 0x0000 |  |
| R32_TIM2_CNT       | 0x40000024 | TIM2 counter                            | 0x0000 |  |
| R16_TIM2_PSC       | 0x40000028 | TIM2 prescaler                          | 0x0000 |  |
| R32_TIM2_ATRLR     | 0x4000002C | TIM2 auto-reload register               | 0xFFFF |  |
| R32_TIM2_CH1CVR    | 0x40000034 | TIM2 compare/capture register1          | 0x0000 |  |
| R32_TIM2_CH2CVR    | 0x40000038 | TIM2 compare/capture register2          | 0x0000 |  |
| R32_TIM2_CH3CVR    | 0x4000003C | TIM2 compare/capture register3          | 0x0000 |  |
| R32_TIM2_CH4CVR    | 0x40000040 | TIM2 compare/capture register4          | 0x0000 |  |
| R16_TIM2_DMACFGR   | 0x40000048 | TIM2 DMA configuration register         | 0x0000 |  |
| D16 TIM2 DMAADD    | 040000046  | TIM2 DMA address register in continuous | 0000   |  |
| R16_TIM2_DMAADR    | 0x4000004C | mode                                    | 0x0000 |  |
| R16_TIM2_AUX       | 0x40000050 | TIM2 dual-edge capture register         | 0x0000 |  |

Table 15-4 TIM3 registers

| Name               | Offset address | Description                                  | Reset value |
|--------------------|----------------|----------------------------------------------|-------------|
| R16_TIM3_CTLR1     | 0x40000400     | TIM3 control register1                       | 0x0000      |
| R16_TIM3_CTLR2     | 0x40000404     | TIM3 control register2                       | 0x0000      |
| R16_TIM3_SMCFGR    | 0x40000408     | TIM3 slave mode configuration register       | 0x0000      |
| R16_TIM3_DMAINTENR | 0x4000040C     | TIM3 DMA/interrupt enable register           | 0x0000      |
| R16_TIM3_INTFR     | 0x40000410     | TIM3 interrupt flag register                 | 0x0000      |
| R16_TIM3_SWEVGR    | 0x40000414     | TIM3 event generation register               | 0x0000      |
| R16_TIM3_CHCTLR1   | 0x40000418     | TIM3 compare/capture control register1       | 0x0000      |
| R16_TIM3_CHCTLR2   | 0x4000041C     | TIM3 compare/capture control register2       | 0x0000      |
| R16_TIM3_CCER      | 0x40000420     | TIM3 compare/capture enable register         | 0x0000      |
| R16_TIM3_CNT       | 0x40000424     | TIM3 counter                                 | 0x0000      |
| R16_TIM3_PSC       | 0x40000428     | TIM3 prescaler                               | 0x0000      |
| R16_TIM3_ATRLR     | 0x4000042C     | TIM3 auto reload register                    | 0xFFFF      |
| R16_TIM3_CH1CVR    | 0x40000434     | TIM3 compare/capture register1               | 0x0000      |
| R16_TIM3_CH2CVR    | 0x40000438     | TIM3 compare/capture register2               | 0x0000      |
| R16_TIM3_CH3CVR    | 0x4000043C     | TIM3 compare/capture register3               | 0x0000      |
| R16_TIM3_CH4CVR    | 0x40000440     | TIM3 compare/capture register4               | 0x0000      |
| R16_TIM3_DMACFGR   | 0x40000448     | TIM3 DMA configuration register              | 0x0000      |
| R16_TIM3_DMAADR    | 0x4000044C     | TIM3 DMA address register in continuous mode | 0x0000      |
| R16_TIM3_AUX       | 0x40000450     | TIM3 dual-edge capture register              | 0x0000      |

Table 15-5 TIM4 registers

| Name               | Offset address | Description                                  | Reset value |
|--------------------|----------------|----------------------------------------------|-------------|
| R16_TIM4_CTLR1     | 0x40000800     | TIM4 control register1                       | 0x0000      |
| R16_TIM4_CTLR2     | 0x40000804     | TIM4 control register2                       | 0x0000      |
| R16_TIM4_SMCFGR    | 0x40000808     | TIM4 slave mode configuration register       | 0x0000      |
| R16_TIM4_DMAINTENR | 0x4000080C     | TIM4 DMA/interrupt enable register           | 0x0000      |
| R16_TIM4_INTFR     | 0x40000810     | TIM4 interrupt flag register                 | 0x0000      |
| R16_TIM4_SWEVGR    | 0x40000814     | TIM4 event generation register               | 0x0000      |
| R16_TIM4_CHCTLR1   | 0x40000818     | TIM4 compare/capture control register1       | 0x0000      |
| R16_TIM4_CHCTLR2   | 0x4000081C     | TIM4 compare/capture control register2       | 0x0000      |
| R16_TIM4_CCER      | 0x40000820     | TIM4 compare/capture enable register         | 0x0000      |
| R16_TIM4_CNT       | 0x40000824     | TIM4 counter                                 | 0x0000      |
| R16_TIM4_PSC       | 0x40000828     | TIM4 prescaler                               | 0x0000      |
| R16_TIM4_ATRLR     | 0x4000082C     | TIM4 auto-reload register                    | 0xFFFF      |
| R16_TIM4_CH1CVR    | 0x40000834     | TIM4 compare/capture register1               | 0x0000      |
| R16_TIM4_CH2CVR    | 0x40000838     | TIM4 compare/capture register2               | 0x0000      |
| R16_TIM4_CH3CVR    | 0x4000083C     | TIM4 compare/capture register3               | 0x0000      |
| R16_TIM4_CH4CVR    | 0x40000840     | TIM4 compare/capture register4               | 0x0000      |
| R16_TIM4_DMACFGR   | 0x40000848     | TIM4 DMA configuration register              | 0x0000      |
| R16_TIM4_DMAADR    | 0x4000084C     | TIM4 DMA address register in continuous mode | 0x0000      |
| R16_TIM4_AUX       | 0x40000850     | TIM4 dual-edge capture register              | 0x0000      |

Table 15-6 TIM5 registers

| Name               | Offset address | Description                                  | Reset value |
|--------------------|----------------|----------------------------------------------|-------------|
| R16_TIM5_CTLR1     | 0x40000C00     | TIM5 control register 1                      | 0x0000      |
| R16_TIM5_CTLR2     | 0x40000C04     | TIM5 control register 2                      | 0x0000      |
| R16_TIM5_SMCFGR    | 0x40000C08     | TIM5 slave mode configuration register       | 0x0000      |
| R16_TIM5_DMAINTENR | 0x40000C0C     | TIM5 DMA/interrupt enable register           | 0x0000      |
| R16_TIM5_INTFR     | 0x40000C10     | TIM5 interrupt flag register                 | 0x0000      |
| R16_TIM5_SWEVGR    | 0x40000C14     | TIM5 event generation register               | 0x0000      |
| R16_TIM5_CHCTLR1   | 0x40000C18     | TIM5 compare/capture register 1              | 0x0000      |
| R16_TIM5_CHCTLR2   | 0x40000C1C     | TIM5 compare/capture control register2       | 0x0000      |
| R16_TIM5_CCER      | 0x40000C20     | TIM5 compare/capture enable register         | 0x0000      |
| R16_TIM5_CNT       | 0x40000C24     | TIM5 counter                                 | 0x0000      |
| R16_TIM5_PSC       | 0x40000C28     | TIM5 prescaler                               | 0x0000      |
| R16_TIM5_ATRLR     | 0x40000C2C     | TIM5 auto-reload register                    | 0x0000FFFF  |
| R16_TIM5_CH1CVR    | 0x40000C34     | TIM5 compare/capture register1               | 0x00000000  |
| R16_TIM5_CH2CVR    | 0x40000C38     | TIM5 compare/capture register2               | 0x00000000  |
| R16_TIM5_CH3CVR    | 0x40000C3C     | TIM5 compare/capture register3               | 0x00000000  |
| R16_TIM5_CH4CVR    | 0x40000C40     | TIM5 compare/capture register4               | 0x00000000  |
| R16_TIM5_DMACFGR   | 0x40000C48     | TIM5 DMA configuration register              | 0x0000      |
| R16_TIM5_DMAADR    | 0x40000C4C     | TIM5 DMA address register in continuous mode | 0x0000      |

# 15.4.1 Control Register 1 (TIMx\_CTLR1) (x=2/3/4)

| 15 | 14 | 13   | 12    | 11 | 10 | 9   | 8     | 7    | 6   | 5     | 4   | 3   | 2   | 1    | 0   |
|----|----|------|-------|----|----|-----|-------|------|-----|-------|-----|-----|-----|------|-----|
|    |    | Rese | erved |    |    | CKD | [1:0] | ARPE | CMS | [1:0] | DIR | OPM | URS | UDIS | CEN |

| Bit     | Name     | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Reset value |
|---------|----------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [15:10] | Reserved | RO     | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0           |
| [9:8]   | CKD[1:0] | RW     | These 2 bits define the frequency division ratio of timer clock (CK_INT) frequency and sampling clock used for the digital filter:  00: Tdts=Tck_int;  01: Tdts= 2xTck_int;  10: Tdts= 4xTck_int;  11: Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |             |
| 7       | ARPE     | RW     | Auto-reload and preload enable:  0: Auto-reload value register (ATRLR) disabled;  1: Auto-reload value register (ATRLR) enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0           |
| [6:5]   | CMS[1:0] | RW     | Central alignment mode selection: 00: Edge alignment mode. The counter counts up or down according to the direction bit (DIR). 01: Center alignment mode 1. The counter counts up and down alternately. The output comparison interrupt flag bit of the channel configured as an output (CCxS=00 in the CHCTLRx register) is only set when the counter counts down. 10: Center alignment mode 2. The counter counts up and down alternately. The output comparison interrupt flag bit of the channel configured as an output (CCxS=00 in the CHCTLRx register) is only set when the counter counts up. 11: Center alignment mode 3. The counter counts up and down alternately. The output comparison interrupt flag bit of the channel configured as an output (CCxS=00 in the CHCTLRx register) is only set when the counter counts up and down.  Note: When the counter is enabled (CEN=1), it is not allowed to switch from edge alignment mode to center alignment mode. | 0           |
| 4       | DIR      | RW     | Counter direction: 0: Upcount; 1: Downcount. Note: When the counter is configured in the center alignment mode or encoder mode, this bit will be                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |             |

|   |      |      | invalid.                                                   |   |
|---|------|------|------------------------------------------------------------|---|
|   |      |      | Single pulse mode.                                         |   |
|   |      |      | 0: The counter does not stop when the next update event    |   |
| 3 | OPM  | RW   | occurs;                                                    | 0 |
|   |      |      | 1: The counter stops when the next update event            |   |
|   |      |      | (clearing the CEN bit) occurs.                             |   |
|   |      |      | Update request source; the software selects the source     |   |
|   |      |      | of UEV event through this bit.                             |   |
|   |      |      | 0: If the update interrupt or DMA request is enabled,      |   |
|   |      |      | any of the following events will generate an update        |   |
|   |      |      | interrupt or DMA request:                                  |   |
| 2 | URS  | RW   | -Counter overflow/underflow                                | 0 |
|   |      |      | -Set the UG bit                                            |   |
|   |      |      | - Update generated by the slave mode controller            |   |
|   |      |      | 1: If the update interrupt or DMA request is enabled,      |   |
|   |      |      | only the counter overflow/underflow will generate the      |   |
|   |      |      | update interrupt or DMA request.                           |   |
|   |      |      | Update disable. Software allows/disables the               |   |
|   |      |      | generation of UEV events through this bit.                 |   |
|   |      |      | 0: Allow UEV. Update (UEV) events are generated by         |   |
|   |      |      | any of the following events:                               |   |
|   |      |      | - Counter overflow/underflow                               |   |
|   |      |      | -Set the UG bit                                            |   |
| 1 | UDIS | RW   | - Update generated by the slave mode controller            | 0 |
| 1 | ODIS | ICVV | Registers with buffers are loaded with their preloaded     | V |
|   |      |      | values.                                                    |   |
|   |      |      | 1: Disable UEV. No update event is generated, and the      |   |
|   |      |      | registers (ATRLR, PSC and CHCTLRx) maintain their          |   |
|   |      |      | values. If the UG bit is set or a hardware reset is issued |   |
|   |      |      | from the mode controller, the counter and prescaler will   |   |
|   |      |      | be reinitialized.                                          |   |
|   |      |      | Counter enable.                                            |   |
|   |      |      | 1: Counter enabled;                                        |   |
|   |      |      | 0: Counter disabled.                                       |   |
| 0 | CEN  | RW   | Note: After the CEN bit is set by software, the external   | 0 |
|   |      |      | clock, gating mode and encoder mode can only work.         |   |
|   |      |      | The trigger mode can automatically set the CEN bit by      |   |
|   |      |      | hardware.                                                  |   |

## 15.4.2 Control Register2 (TIMx\_CTLR2) (x=2/3/4/5)

| 15 | 14 | 13 | 12   | 11    | 10 | 9 | 8 | 7    | 6 | 5 | 4   | 3    | 2    | 1        | 0    |
|----|----|----|------|-------|----|---|---|------|---|---|-----|------|------|----------|------|
|    |    |    | Rese | erved |    |   |   | TI1S | M |   | .01 | CCDS | CCUS | Reserved | CCPC |

| Bit | Name | Access | Description | Reset value |
|-----|------|--------|-------------|-------------|
|-----|------|--------|-------------|-------------|

| [15:8] | Reserved | RO | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0 |
|--------|----------|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| 7      | TIIS     | RW | TI1 selection: 0: TIMx_CH1 pin is directly connected to TI1 input; 1: TIMx_CH1, TIMx_CH2 and TIMx_CH3 pins are connected to TI1 input through XOR.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 0 |
| [6:4]  | MMS[2:0] | RW | Master mode selection: These 3 bits are used to select the synchronization information (TRGO) sent to the slave timer in the master mode. The possible combination is as follows:  000: Reset – The UG bit is used as a trigger output (TRGO). If it is a reset generated by a trigger input (the slave mode controller is in reset mode), the signal on TRGO will have a delay relative to the actual reset;  001: Enable-the counter enables signal CNT_EN to be used as a trigger output (TRGO). Sometimes, it is necessary to start multiple timers at the same time or control to enable slave timers within a period of time. The counter enable signal is generated by the logical OR of the CEN control bit and the trigger input signal in the gating mode. When the counter enable signal is controlled by the trigger input, there will be a delay on TRGO, unless the master/slave mode is selected (see the description of the MSM bit in the TIMx_SMCFGR register);  010: An update event is selected as the trigger output (TRGO). For example, the clock of a master timer can be used as a prescaler for a slave timer;  011: Comparison pulse, when a capture occurs or a comparison is successful, and the CC1IF flag is to be set (even if it is already high), the trigger output will send a positive pulse (TRGO);  100: OC1REF signal is used as trigger output (TRGO);  101: OC2REF signal is used as trigger output (TRGO);  110: OC3REF signal is used as trigger output (TRGO); | 0 |
| 3      | CCDS     | RW | 0: When CHxCVR occurs, a DMA request of CHxCVR will be generated; 1: When an update event occurs, send a DMA request of CHxCVR.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0 |
| 2      | CCUS     | RW | Compare/capture control update selection.  0: If CCPC is set, they can only be updated by setting the COM bit;  1: If CCPC is set, they can be updated by setting the COM bit or a rising edge on TRGI.  Note: This bit only works on channels with complementary outputs.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0 |

| 1 | Reserved | RO | Reserved.                                                                                                                                                                                                                                                                          | 0 |
|---|----------|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| 0 | CCPC     | RW | Compare/capture preload control.  0: CCxE, CCxNE and OCxM bits are not preloaded;  1: CCxE, CCxNE and OCxM bits are pre-loaded. After the bits are set, they will only be updated after setting of the COM bit.  Note: This bit only works on channels with complementary outputs. |   |

## 15.4.3 Slave Mode Configuration Register (TIMx\_SMCFGR) (x=2/3/4/5)

Offset address: 0x08

| 15  | 14  | 13   | 12     | 11 | 10   | 9     | 8 | 7   | 6 | 5       | 4 | 3        | 2 | 1      | 0  |
|-----|-----|------|--------|----|------|-------|---|-----|---|---------|---|----------|---|--------|----|
| ETP | ECE | ETPS | 5[1:0] |    | ETF[ | [3:0] |   | MSM |   | TS[2:0] |   | Reserved | S | MS[2:0 | )] |

| Bit     | Name      | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Reset value |
|---------|-----------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| 15      | ЕТР       | RO     | ETR trigger polarity selection; this bit selects whether to directly input ETR or input inverted ETR.  0: ETR, active at high level or rising edge;                                                                                                                                                                                                                                                                                                                                                          | 0           |
| 14      | ECE       | RW     | 1: ETR inverted, active at low level or falling edge.  External clock mode2 enable.  0: External clock mode2 disabled;  1: External clock mode2 enabled.  Note 1: Slave mode can be used simultaneously with external clock mode 2: reset mode, gating mode and trigger mode; however, TRGI cannot be connected to ETRF at this time (TS bit cannot be 111b).  Note 2: When both external clock mode 1 and external clock mode 2 are enabled at the same time, the input of the external clock will be ETRF. | 0           |
| [13:12] | ETPS[1:0] | RW     | External trigger prescaler (ETRP); the frequency must be at most 1/4 of TIMxCLK frequency, and the frequency can be reduced through this domain.  00: Prescale OFF;  01: ETRP frequency divided by 2;  10: ETRP frequency divided by 4;  11: ETRP frequency divided by 8.                                                                                                                                                                                                                                    |             |
| [11:8]  | ETF[3:0]  | RW     | External trigger filter. In fact, the digital filter is an event counter. N events are needed to validate a transition on the output.  0000: No filter, sampling is done at Fdts;  0001: Fsampling=Fck_int, N=2;  0010: Fsampling=Fck_int, N=4;  0011: Fsampling=Fck_int, N=8;  0100: Fsampling=Fdts/2, N=6;  0101: Fsampling=Fdts/2, N=8;                                                                                                                                                                   |             |

V2. 4 247 WH

|       |              |     | 0110: Fsampling=Fdts/4, N=6;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |   |
|-------|--------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
|       |              |     | 0111: Fsampling=Fdts/4, N=8;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |   |
|       |              |     | 1000: Fsampling=Fdts/8, N=6;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |   |
|       |              |     | 1001: Fsampling=Fdts/8, N=8;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |   |
|       |              |     | 1010: Fsampling=Fdts/16, N=5;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |   |
|       |              |     | 1011: Fsampling=Fdts/16, N=6;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |   |
|       |              |     | 1100: Fsampling=Fdts/16, N=8;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |   |
|       |              |     | 1101: Fsampling=Fdts/32, N=5;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |   |
|       |              |     | 1110: Fsampling=Fdts/32, N=6;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |   |
|       |              |     | 1111: Fsampling=Fdts/32, N=8.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |   |
|       |              |     | Master/Slave mode selection:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |   |
|       |              |     | 0: Not action;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |   |
|       |              |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |   |
| 7     | MCM          | DIV | 1: The event on the trigger input (TRGI) is delayed to                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0 |
| 7     | MSM          | RW  | allow perfect synchronization between the current timer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0 |
|       |              |     | (via TRGO) and its slave timer. This is very useful                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |   |
|       |              |     | when it is required to synchronize several timers to a                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |   |
|       |              |     | single external event.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |   |
|       |              |     | Trigger selection; these 3 bits select the trigger input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |   |
|       |              |     | source used to synchronize the counter.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |   |
|       |              |     | 000: Internal trigger 0 (ITR0);                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |   |
|       |              |     | 100: Edge detector of TI1 (TI1F_ED);                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |   |
|       |              |     | 001: Internal trigger 1 (ITR1);                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |   |
| [6:4] | TS           | RW  | 101: Timer input 1 (TI1FP1) after filtering;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0 |
|       |              |     | 010: Internal trigger 2 (ITR2);                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |   |
|       |              |     | 110: Timer input 2 (TI12FP2) after filtering;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |   |
|       |              |     | 011: Internal trigger 3 (ITR3);                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |   |
|       |              |     | 111: External trigger input (ETRF);                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |   |
|       |              |     | The values can be changed only when SMS is 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |   |
| 3     | Reserved     | _   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |   |
|       | 1 COSCI V CG | RO  | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0 |
|       | reserved     | RO  | Reserved.  Input mode selection. Select the clock and trigger mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0 |
|       | reserved     | RO  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0 |
|       | resorved     | RO  | Input mode selection. Select the clock and trigger mode of the core counter.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0 |
|       | resorved     | RO  | Input mode selection. Select the clock and trigger mode of the core counter.  000: Driven by the internal clock CK_INT;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0 |
|       | resorved     | RO  | Input mode selection. Select the clock and trigger mode of the core counter.  000: Driven by the internal clock CK_INT;  001: Encoder mode1; depending on TI1FP1 level, the                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 0 |
|       | resorved     | RO  | Input mode selection. Select the clock and trigger mode of the core counter.  000: Driven by the internal clock CK_INT;  001: Encoder mode1; depending on TI1FP1 level, the core counter counts up or down on edge of TI2FP2;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0 |
|       | resorved     | RO  | Input mode selection. Select the clock and trigger mode of the core counter.  000: Driven by the internal clock CK_INT;  001: Encoder mode1; depending on TI1FP1 level, the core counter counts up or down on edge of TI2FP2;  010: Encoder mode2; depending on TI2FP2 level, the                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0 |
|       | resorved     | RO  | Input mode selection. Select the clock and trigger mode of the core counter.  000: Driven by the internal clock CK_INT;  001: Encoder mode1; depending on TI1FP1 level, the core counter counts up or down on edge of TI2FP2;  010: Encoder mode2; depending on TI2FP2 level, the core counter counts up or down on edge of TI1FP1;                                                                                                                                                                                                                                                                                                                                                                                                  | 0 |
| [2:0] |              |     | Input mode selection. Select the clock and trigger mode of the core counter.  000: Driven by the internal clock CK_INT;  001: Encoder mode1; depending on TI1FP1 level, the core counter counts up or down on edge of TI2FP2;  010: Encoder mode2; depending on TI2FP2 level, the core counter counts up or down on edge of TI1FP1;  011: Encoder mode3; depending on the input level of                                                                                                                                                                                                                                                                                                                                             |   |
| [2:0] | SMS[2:0]     | RO  | Input mode selection. Select the clock and trigger mode of the core counter.  000: Driven by the internal clock CK_INT;  001: Encoder mode1; depending on TI1FP1 level, the core counter counts up or down on edge of TI2FP2;  010: Encoder mode2; depending on TI2FP2 level, the core counter counts up or down on edge of TI1FP1;  011: Encoder mode3; depending on the input level of another signal, the core counter counts up and down on                                                                                                                                                                                                                                                                                      | 0 |
| [2:0] |              |     | Input mode selection. Select the clock and trigger mode of the core counter.  000: Driven by the internal clock CK_INT;  001: Encoder mode1; depending on TI1FP1 level, the core counter counts up or down on edge of TI2FP2;  010: Encoder mode2; depending on TI2FP2 level, the core counter counts up or down on edge of TI1FP1;  011: Encoder mode3; depending on the input level of another signal, the core counter counts up and down on the edge of TI1FP1 and TI2FP2;                                                                                                                                                                                                                                                       |   |
| [2:0] |              |     | Input mode selection. Select the clock and trigger mode of the core counter.  000: Driven by the internal clock CK_INT;  001: Encoder mode1; depending on TI1FP1 level, the core counter counts up or down on edge of TI2FP2;  010: Encoder mode2; depending on TI2FP2 level, the core counter counts up or down on edge of TI1FP1;  011: Encoder mode3; depending on the input level of another signal, the core counter counts up and down on the edge of TI1FP1 and TI2FP2;  100: Reset mode; the rising edge of the trigger input                                                                                                                                                                                                |   |
| [2:0] |              |     | Input mode selection. Select the clock and trigger mode of the core counter.  000: Driven by the internal clock CK_INT;  001: Encoder mode1; depending on TI1FP1 level, the core counter counts up or down on edge of TI2FP2;  010: Encoder mode2; depending on TI2FP2 level, the core counter counts up or down on edge of TI1FP1;  011: Encoder mode3; depending on the input level of another signal, the core counter counts up and down on the edge of TI1FP1 and TI2FP2;  100: Reset mode; the rising edge of the trigger input (TRGI) will initialize the counter and generate a signal                                                                                                                                       |   |
| [2:0] |              |     | Input mode selection. Select the clock and trigger mode of the core counter.  000: Driven by the internal clock CK_INT;  001: Encoder mode1; depending on TI1FP1 level, the core counter counts up or down on edge of TI2FP2;  010: Encoder mode2; depending on TI2FP2 level, the core counter counts up or down on edge of TI1FP1;  011: Encoder mode3; depending on the input level of another signal, the core counter counts up and down on the edge of TI1FP1 and TI2FP2;  100: Reset mode; the rising edge of the trigger input (TRGI) will initialize the counter and generate a signal for updating the register;                                                                                                            |   |
| [2:0] |              |     | Input mode selection. Select the clock and trigger mode of the core counter.  000: Driven by the internal clock CK_INT;  001: Encoder mode1; depending on TI1FP1 level, the core counter counts up or down on edge of TI2FP2;  010: Encoder mode2; depending on TI2FP2 level, the core counter counts up or down on edge of TI1FP1;  011: Encoder mode3; depending on the input level of another signal, the core counter counts up and down on the edge of TI1FP1 and TI2FP2;  100: Reset mode; the rising edge of the trigger input (TRGI) will initialize the counter and generate a signal for updating the register;  101: Gating mode; when the trigger input (TRGI) is                                                        |   |
| [2:0] |              |     | Input mode selection. Select the clock and trigger mode of the core counter.  000: Driven by the internal clock CK_INT;  001: Encoder mode1; depending on TI1FP1 level, the core counter counts up or down on edge of TI2FP2;  010: Encoder mode2; depending on TI2FP2 level, the core counter counts up or down on edge of TI1FP1;  011: Encoder mode3; depending on the input level of another signal, the core counter counts up and down on the edge of TI1FP1 and TI2FP2;  100: Reset mode; the rising edge of the trigger input (TRGI) will initialize the counter and generate a signal for updating the register;  101: Gating mode; when the trigger input (TRGI) is high, the clock of the counter will be turned on; when |   |
| [2:0] |              |     | Input mode selection. Select the clock and trigger mode of the core counter.  000: Driven by the internal clock CK_INT;  001: Encoder mode1; depending on TI1FP1 level, the core counter counts up or down on edge of TI2FP2;  010: Encoder mode2; depending on TI2FP2 level, the core counter counts up or down on edge of TI1FP1;  011: Encoder mode3; depending on the input level of another signal, the core counter counts up and down on the edge of TI1FP1 and TI2FP2;  100: Reset mode; the rising edge of the trigger input (TRGI) will initialize the counter and generate a signal for updating the register;  101: Gating mode; when the trigger input (TRGI) is                                                        |   |

V2. 4 248 WH°

| ı |  | 110: Trigger mode; the counter starts on the rising edge |  |
|---|--|----------------------------------------------------------|--|
| ı |  | of the trigger input TRGI, and only the start of the     |  |
| ı |  | counter is controlled;                                   |  |
| ı |  | 111: External clock model; the rising edge of the        |  |
| ı |  | selected trigger input (TRGI) drives the counter.        |  |

# 15.4.4 DMA/Interrupt Enable Register (TIMx\_DMAINTENR) (x=2/3/4/5)

Offset address: 0x0C

| 15           | 14      | 13        | 12 | 11 | 10        | 9 | 8 | 7            | 6       | 5 | 4         | 3 | 2         | 1         | 0       |
|--------------|---------|-----------|----|----|-----------|---|---|--------------|---------|---|-----------|---|-----------|-----------|---------|
| Reserv<br>ed | TD<br>E | COMD<br>E |    |    | CC2D<br>E |   |   | Reserv<br>ed | TI<br>E |   | CC4I<br>E |   | CC2I<br>E | CC1I<br>E | UI<br>E |

| Bit | Name     | Access | Description                                  | Reset value |
|-----|----------|--------|----------------------------------------------|-------------|
| 15  | Reserved | RO     | Reserved.                                    | 0           |
|     |          |        | Trigger DMA request enable.                  |             |
| 14  | TDE      | RW     | 0: Trigger DMA request disabled;             | 0           |
|     |          |        | 1: Trigger DMA request enabled.              |             |
|     |          |        | DMA request enable of COM.                   |             |
| 13  | COMDE    | RW     | 0: DMA request of COM disabled;              | 0           |
|     |          |        | 1: DMA request of COM enabled.               |             |
|     |          |        | DMA request enable of compare/capture4.      |             |
| 12  | CC4DE    | RW     | 0: DMA request of compare/capture4 disabled; | 0           |
|     |          |        | 1: DMA request of compare/capture4 enabled.  |             |
|     |          |        | DMA request enable of compare/capture3.      |             |
| 11  | CC3DE    | RW     | 0: DMA request of compare/capture3 disabled; | 0           |
|     |          |        | 1: DMA request of compare/capture3 enabled.  |             |
|     |          |        | DMA request enable of compare/capture2.      |             |
| 10  | CC2DE    | RW     | 0: DMA request of compare/capture2 disabled; | 0           |
|     |          |        | 1: DMA request of compare/capture2 enabled.  |             |
|     |          |        | DMA request enable of compare/capture1.      |             |
| 9   | CC1DE    | RW     | 0: DMA request of compare/capture1 disabled; | 0           |
|     |          |        | 1: DMA request of compare/capture1 enabled.  |             |
|     |          |        | Update DMA request enable.                   |             |
| 8   | UDE      | RW     | 0: Update DMA request disabled;              | 0           |
|     |          |        | 1: Update DMA request enabled.               |             |
| 7   | Reserved | RO     | Reserved.                                    | 0           |
|     |          |        | Trigger interrupt enable.                    |             |
| 6   | TIE      | RW     | 0: Trigger interrupt disabled;               | 0           |
|     |          |        | 1: Trigger interrupt enabled.                |             |
| 5   | Reserved | RO     | Reserved.                                    | 0           |
|     |          |        | Interrupt enable of compare/capture4.        |             |
| 4   | CC4IE    | RW     | 0: Interrupt of compare/capture4 disabled;   | 0           |
|     |          |        | 1: Interrupt of compare/capture4 enabled.    |             |
| 2   | CC2IE    | DW     | Interrupt enable of compare/capture3.        | 0           |
| 3   | CC3IE    | RW     | 0: Interrupt of compare/capture3 disabled;   | 0           |

V2. 4 249 WCH°

|   |       |    | 1: Interrupt of compare/capture3 enabled.  |   |
|---|-------|----|--------------------------------------------|---|
|   |       |    | Interrupt enable of compare/capture2.      |   |
| 2 | CC2IE | RW | 0: Interrupt of compare/capture2 disabled; | 0 |
|   |       |    | 1: Interrupt of compare/capture2 enabled.  |   |
|   |       |    | Interrupt enable of compare/capture1.      |   |
| 1 | CC1IE | RW | 0: Interrupt of compare/capture1 disabled; | 0 |
|   |       |    | 1: Interrupt of compare/capture1 enabled.  |   |
|   |       |    | Update interrupt enable.                   |   |
| 0 | UIE   | RW | 0: Update interrupt disabled;              | 0 |
|   |       |    | 1: Update interrupt enabled.               |   |

# 15.4.5 Interrupt Flag Register (TIMx\_INTFR) (x=2/3/4/5)

Offset address: 0x10

 15
 14
 13
 12
 11
 10
 9
 8
 7
 6
 5
 4
 3
 2
 1
 0

 Reserved
 CC40F
 CC30F
 CC20F
 CC10F
 Reserved
 CC4IF
 CC3IF
 CC2IF
 CC1IF
 UIF

| Bit     | Name     | Access | Description                                                                                                                                                                                                                                                                                                                                         | Reset value |
|---------|----------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [15:13] | Reserved | RO     | Reserved.                                                                                                                                                                                                                                                                                                                                           | 0           |
| 12      | CC4OF    | RW0    | Compare/capture4 overcapture flag.                                                                                                                                                                                                                                                                                                                  | 0           |
| 11      | CC3OF    | RW0    | Compare/capture3 overcapture flag.                                                                                                                                                                                                                                                                                                                  | 0           |
| 10      | CC2OF    | RW0    | Compare/capture2 overcapture flag.                                                                                                                                                                                                                                                                                                                  | 0           |
| 9       | CC10F    | RW0    | Compare/capture1 overcapture flag is only used when the compare/capture is configured in the input capture mode. This flag bit is set by the hardware, write 0 by software to clear the bit.  0: No Overcapture is generated;  1: When the value of the counter is captured into the capture comparison register, the status of CC1IF has been set. | 0           |
| [8:7]   | Reserved | RO     | Reserved.                                                                                                                                                                                                                                                                                                                                           | 0           |
| 6       | TIF      | RW0    | Trigger interrupt flag. When a trigger event occurs, set by hardware and cleared by software. Trigger events include the detection of a valid edge at the TRGI input terminal from modes other than gating mode, or any edge in gating mode.  0: No trigger event occurs;  1: Trigger event occurs.                                                 | 0           |
| 5       | Reserved | RO     | Reserved.                                                                                                                                                                                                                                                                                                                                           | 0           |
| 4       | CC4IF    | RW0    | Compare/capture4 interrupt flag.                                                                                                                                                                                                                                                                                                                    | 0           |
| 3       | CC3IF    | RW0    | Compare/capture3 interrupt flag.                                                                                                                                                                                                                                                                                                                    | 0           |
| 2       | CC2IF    | RW0    | Compare/capture2 interrupt flag.                                                                                                                                                                                                                                                                                                                    | 0           |
| 1       | CC1IF    | RW0    | Compare/capture1 interrupt flag.  If the compare/capture is configured as the output mode, this bit is set by hardware when the counter value matches the compare value, except in center-aligned                                                                                                                                                   | 0           |

|   |     |     | mode. This bit is cleared by software.                 | 1 |
|---|-----|-----|--------------------------------------------------------|---|
|   |     |     | 0: No;                                                 |   |
|   |     |     | 1: The value of core counter matches the value of      |   |
|   |     |     | compare/capture register 1.                            |   |
|   |     |     |                                                        |   |
|   |     |     | If the compare/capture is configured as the output     |   |
|   |     |     | mode, this bit is set by hardware when a capture event |   |
|   |     |     | occurs, and it is cleared by software or cleared by    |   |
|   |     |     | reading the compare/capture register.                  |   |
|   |     |     | 0: No input capture is generated;                      |   |
|   |     |     | 1: The counter value has been captured by the          |   |
|   |     |     | compare/capture register 1.                            |   |
|   |     |     | Update interrupt flag. When an update event occurs, it |   |
|   |     |     | is set by hardware and cleared by software.            |   |
|   |     |     | 0: No update interrupt generated;                      |   |
|   |     |     | 1: Update interrupt generated.                         |   |
|   |     |     | The update event generates in case of the following    |   |
|   |     |     | circumstances:                                         |   |
| 0 | UIF | RW0 | For UDIS=0, when the repeated counter value            | 0 |
|   |     |     | overflows or underflows;                               |   |
|   |     |     | For URS=0, UDIS=0, when the UG bit is set, or when     |   |
|   |     |     | the counter core is reinitialized by software;         |   |
|   |     |     | For URS=0, UDIS=0, when the counter CNT is             |   |
|   |     |     | reinitialized by a trigger event.                      |   |
|   |     |     | Territalized by a disself event.                       |   |

# 15.4.6 Event Generation Register (TIMx\_SWEVGR) (x=2/3/4/5)

| 15 | 14 | 13 | 12   | 11   | 10 | 9 | 8 | 7  | 6  | 5    | 4    | 3    | 2    | 1    | 0  |
|----|----|----|------|------|----|---|---|----|----|------|------|------|------|------|----|
|    |    |    | Rese | rved |    |   |   | BG | TG | COMG | CC4G | CC3G | CC2G | CC1G | UG |

| Bit    | Name     | Access | Description                                                                                                                                                                                                                                                             | Reset value |
|--------|----------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [15:8] | Reserved | RO     | Reserved.                                                                                                                                                                                                                                                               | 0           |
| 7      | BG       | WO     | Break event generation. Set and cleared by software to generate a break event.  0: No effect;  1: A break event generated. In this case, MOE=0, BIF=1; if the corresponding interrupt and DMA are enabled, the corresponding interrupt and DMA will be generated.       | 0           |
| 6      | TG       | WO     | Trigger event generation. Set by software, and cleared by hardware to generate a trigger event.  0: No effect;  1: A trigger event generated; if TIF is set and the corresponding interrupt and DMA are enabled, the corresponding interrupt and DMA will be generated. | 0           |
| 5      | COMG     | WO     | Compare/capture control update generation bit.                                                                                                                                                                                                                          | 0           |

|   |       |    | Generating compare/capture control update event. This bit is set by software and cleared automatically by hardware.  0: No effect;  1: When CCPC=1, it is allowed to update the CCxE, CCxNE and OCxM bits.  Note: This bit is only valid for channels with                                                                                                                                                                                                                                                                                                                                                                                                                           |   |
|---|-------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
|   | 0.010 |    | complementary outputs (channels 1, 2 and 3).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |   |
| 4 | CC4G  | WO | Compare/capture 4 generation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0 |
| 3 | CC3G  | WO | Compare/capture 3 generation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0 |
| 2 | CC2G  | WO | Compare/capture 2 generation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0 |
| 1 | CC1G  | WO | Compare/capture1 generation. This bit is set by software and cleared by hardware. It is used to generate a compare/capture event.  0: No effect.  1: Generate compare/capture event on channel 1: If compare/capture 1 is configured as output: Set the CC1IF bit. If the corresponding interrupt and DMA are enabled, the corresponding interrupt and DMA will be generated; If compare/capture 1 is configured as input, the current core counter value is captured to compare/capture register 1; set the CC1IF bit, if the corresponding interrupt and DMA are enabled, the corresponding interrupt and DMA will be generated. If the CC1IF bit has been set, set the CC1OF bit. | 0 |
| 0 | UG    | WO | Update event generation. This bit is set by software and cleared automatically by hardware.  0: No effect;  1: Initialize the counter and generate an update event.  Note: The counter of the prescaler is also cleared, but the prescaler factor remains unchanged. In Centro symmetric mode or up-counting mode, the core counter will be cleared; in the down-counting mode, the core counter will take the value of the reload value register.                                                                                                                                                                                                                                   | 0 |

#### 15.4.7 Compare/Capture Control Register1 (TIMx\_CHCTLR1) (x=2/3/4/5)

Offset address: 0x18

The channel can be used for input (capture mode) or output (comparison mode), and the direction of the channel is defined by the corresponding CCxS bit. The functions of other bits of this register are different in input and output modes. OCxx describes the function of the channel in output mode, and ICxx describes the function of the channel in input mode.

| 15    | _14   | 13   | 12  | 11    | 10     | 9    | 8     | 7     | 6    | 5     | 4    | 3     | 2      | 1    | 0       |
|-------|-------|------|-----|-------|--------|------|-------|-------|------|-------|------|-------|--------|------|---------|
| OC2CE | OC    | 2M[2 | :0] | OC2PE | OC2FE  | GG26 | F1 01 | OC1CE | OC   | C1M[2 | 2:0] | OC1PE | OC1FE  | 0010 | 751 07  |
| I     | C2F[: | 3:0] |     | IC2PS | C[1:0] | CC2S | [1:0] | I     | C1F[ | 3:0]  |      | IC1PS | C[1:0] | CCIS | S[1:0]I |

Compare mode (pin direction is output):

| Bit     | Name      | Access | Description                                                                               | Reset value |  |  |  |  |
|---------|-----------|--------|-------------------------------------------------------------------------------------------|-------------|--|--|--|--|
|         |           |        | Compare/capture 2 clear enable.                                                           |             |  |  |  |  |
| 1.5     | OC2CE     | DW     | 0: OC2REF is not affected by the ETRF input;                                              | 0           |  |  |  |  |
| 15      | OC2CE     | RW     | 1: Once the ETRF input high level is detected, clear the                                  |             |  |  |  |  |
|         |           |        | OC2REF bit to zero.                                                                       |             |  |  |  |  |
|         |           |        | Compare/capture2 mode setting.                                                            |             |  |  |  |  |
|         |           |        | These 3 bits define the action of the output reference                                    |             |  |  |  |  |
|         |           |        | signal OC2REF, and OC2REF determines the value of                                         |             |  |  |  |  |
|         |           |        | OC2 and OC2N. OC2REF is active at high level, while                                       |             |  |  |  |  |
|         |           |        | the active level of OC2 and OC2N depends on the                                           |             |  |  |  |  |
|         |           |        | CC2P and CC2NP bits.                                                                      |             |  |  |  |  |
|         |           |        | 000: Frozen. The comparison value between the value                                       |             |  |  |  |  |
|         |           |        | of the compare/capture register and the core counter has                                  |             |  |  |  |  |
|         |           |        | no effect on OC2REF;                                                                      |             |  |  |  |  |
|         |           |        | 001: Active by force. When the core counter and                                           |             |  |  |  |  |
|         |           |        | compare/capture register 2 have the same value, force                                     |             |  |  |  |  |
|         |           |        | OC2REF to be high;                                                                        |             |  |  |  |  |
|         |           |        | 010: Set as inactive level by force. When the value of                                    |             |  |  |  |  |
|         |           |        | the core counter is the same as compare/capture register                                  |             |  |  |  |  |
|         |           |        | 2, force OC2REF to be low; 011: Overturn. When the core counter and                       |             |  |  |  |  |
|         |           |        | compare/capture register 2 have the same value,                                           |             |  |  |  |  |
|         |           |        | overturn the level of OC2REF;                                                             |             |  |  |  |  |
|         |           |        | 100: Inactive by force. Force OC2REF to be low.                                           |             |  |  |  |  |
|         |           |        | 101: Force to be active level. Force OC2REF to be high.                                   |             |  |  |  |  |
| [14:12] | OC2M[2:0] | RW     | 110: PWM mode 1: When counting up, once the core                                          | 0           |  |  |  |  |
|         |           |        | counter is less than the value of the comparison capture                                  |             |  |  |  |  |
|         |           |        | register, channel 2 is an effective level, otherwise it is                                |             |  |  |  |  |
|         |           |        | an invalid level; When counting down, once the core                                       |             |  |  |  |  |
|         |           |        | counter is greater than the value of the comparison                                       |             |  |  |  |  |
|         |           |        | capture register, Channel 2 is at an invalid level                                        |             |  |  |  |  |
|         |           |        | (OC2REF=0), otherwise it is at an effective level                                         |             |  |  |  |  |
|         |           |        | (OC2REF=1).                                                                               |             |  |  |  |  |
|         |           |        | 111: PWM mode 2: When counting up, once the core                                          |             |  |  |  |  |
|         |           |        | counter is less than the value of the comparison capture                                  |             |  |  |  |  |
|         |           |        | register, channel 2 is at an invalid level, otherwise it is                               |             |  |  |  |  |
|         |           |        | at an effective level; When counting down, once the                                       |             |  |  |  |  |
|         |           |        | core counter is greater than the value of the comparison                                  |             |  |  |  |  |
|         |           |        | capture register, Channel 2 is active (OC2REF=1), otherwise it is inactive (OC2REF=0)     |             |  |  |  |  |
|         |           |        | otherwise it is inactive (OC2REF=0).  Note: Once the LOCK level is set to 3 and CC2S=00b, |             |  |  |  |  |
|         |           |        | this bit cannot be modified. In PWM model or PWM                                          |             |  |  |  |  |
|         |           |        | mode2, the OC2REF level changes only when the                                             |             |  |  |  |  |
|         |           |        | comparison result changes or when switching from                                          |             |  |  |  |  |
|         |           |        | freezing mode to PWM mode in output compare mode.                                         |             |  |  |  |  |
|         |           |        | preezing mode to 1 mm mode in output compare mode.                                        |             |  |  |  |  |

| 11    | OC2PE     | RW | Compare/capture register 2 preload enable.  0: Disable the pre-loading function of compare/capture register 2. Compare/capture register 2 can be written at any time, and the newly written value takes effect immediately.  1: Enable the preload function of the compare/capture register 2. Read and write operations are only made on the preload register. The preload value of the compare/capture register 2 is loaded into the current shadow register when the update event arrives.  Note: Once the LOCK level is set to 3 and CC2S=00b, this bit cannot be modified; only in single pulse mode (OPM=1) you can use PWM mode without confirming the preload register; Otherwise its action is uncertain.                                                                           | 0 |
|-------|-----------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| 10    | OC2FE     | RW | Compare/capture2 fast enable. It is used to speed up the response of the compare/capture output to the trigger input event.  0: According to the value of counter and compare/capture register2, compare/capture 2 operates normally, even if the trigger is turned on. When the input of the trigger has a valid edge, the minimum delay for activating the output of the compare/capture2 is 5 clock cycles.  1: The effect of the inactive edge inputted to the trigger is like a comparison match. Therefore, OC is set to the comparison level regardless of the comparison result. The delay between the valid edge of the sampling trigger and the output of compare/capture 1 is shortened to 3 clock cycles;  OC2FE only works when the channel is configured in PWM1 or PWM2 mode. | 0 |
| [9:8] | CC2S[1:0] | RW | Compare/capture2 input selection.  00: The compare/capture2 is configured as output;  01: Compare/capture2 is configured as input, and IC2 is mapped on TI2;  10: Compare/capture2 is configured as input, and IC2 is mapped on TI1;  11: Compare/capture2 is configured as an input, and IC2 is mapped on TRC. This mode only works when the internal trigger input is selected (Selected by the TS bit).  Note: Compare/capture2 is only writable when the channel is switched off (CC2E is zero).                                                                                                                                                                                                                                                                                         | 0 |
| 7     | OC1CE     | RW | Compare/capture1 clear enable.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0 |
| [6:4] | OC1M[2:0] | RW | Compare/capture1 mode setting.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0 |
| 3     | OC1PE     | RW | Compare/capture register1 preload enable.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0 |

| 2     | OC1FE     | RW | Compare/capture1 fast enable.     | 0 |
|-------|-----------|----|-----------------------------------|---|
| [1:0] | CC1S[1:0] | RW | Compare/capture1 input selection. | 0 |

Capture mode (pin direction is input):

| Bit     | Name        | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Reset value |
|---------|-------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [15:12] | IC2F[3:0]   | RW     | Input capture2 filter configuration. These bits set the sampling frequency and digital filter length of TI1 input. The digital filter is composed of an event counter, in which N events are needed to validate a transition on the output.  0000: No filter, sampling is done at Fdts; 1000: Fsampling=Fdts/8, N=6; 0001: Fsampling=Fck_int, N=2; 1001: Fsampling=Fck_int, N=4; 1010: Fsampling=Fdts/16, N=5; 0011: Fsampling=Fdts/16, N=6; 0101: Fsampling=Fdts/16, N=6; 1100: Fsampling=Fdts/2, N=6; 1100: Fsampling=Fdts/2, N=8; 1101: Fsampling=Fdts/32, N=5; 0110: Fsampling=Fdts/32, N=6; 1110: Fsampling=Fdts/4, N=6; 1111: Fsampling=Fdts/4, N=8; 1111: Fsampling=Fdts/3, N=8. | 0           |
| [11:10] | IC2PSC[1:0] | RW     | Compare/capture2 prescaler configuration. These 2 bits define the prescaler factor of compare/capture 2. Once CC1E=0, the prescaler will be reset.  00: Prescaler OFF, each edge detected on the capture input port triggers a capture;  01: Trigger a capture every 2 events;  10: Trigger a capture every 4 events;  11: Trigger a capture every 8 events.                                                                                                                                                                                                                                                                                                                            |             |
| [9:8]   | CC2S[1:0]   | RW     | Compare/capture2 input selection. These 2 bits define the direction of the channel (Input/output) and selection of input pins.  00: Compare/capture1 is configured as output;  01: Compare/capture1 is configured as input, and IC1 is mapped on TI1;  10: Compare/capture1 is configured as input, and IC1 is mapped on TI2;  11: Compare/capture1 is configured as an input, and IC1 is mapped on TRC. This mode only works when the internal trigger input is selected (Selected by the TS bit).                                                                                                                                                                                     | 0           |

|       |             |    | Note: CCIS can be written only when the channel is |   |
|-------|-------------|----|----------------------------------------------------|---|
|       |             |    | closed (CC1E is 0).                                |   |
| [7:4] | IC1F[3:0]   | RW | Input capture1 filter configuration.               | 0 |
| [3:2] | IC1PSC[1:0] | RW | Compare/capture1 prescaler configuration.          | 0 |
| [1:0] | CC1S[1:0]   | RW | Compare/capture1 input selection.                  | 0 |

#### 15.4.8 Compare/Capture Control Register 2 (TIMx CHCTLR2) (x=2/3/4/5)

Offset address: 0x1C

The channel can be used for input (Capture mode) or output (Comparison mode), and the direction of the channel is defined by the corresponding CCxS bit. The functions of other bits of this register are different in input and output modes. OCxx describes the function of the channel in output mode, and ICxx describes the function of the channel in input mode.

| 15    | 14   | 13    | 12   | 11    | 10     | 9    | 8      | 7     | 6    | 5     | 4    | 3     | 2      | 1   | 0      |
|-------|------|-------|------|-------|--------|------|--------|-------|------|-------|------|-------|--------|-----|--------|
| OC4CE | 00   | C4M[2 | 2:0] | OC4PE | OC4FE  | 0040 | (F1 A1 | OC3CE | OC   | C3M[2 | 2:0] | OC3PE | OC3FE  | CC2 | 251 03 |
| I     | C4F[ | 3:0]  |      | IC4PS | C[1:0] | CC48 | [1:0]  | I     | C3F[ | 3:0]  |      | IC3PS | C[1:0] | CC3 | 5[1:0] |

#### Compare mode (pin direction is output):

| Bit     | Name      | Access | Description                      | Reset value |
|---------|-----------|--------|----------------------------------|-------------|
| 15      | OC4CE     | RW     | Compare/capture4 clear enable    | 0           |
| [14:12] | OC4M[2:0] | RW     | Compare/capture4 mode setting    | 0           |
| 11      | OC4PE     | RW     | Compare/capture4 preload enable  | 0           |
| 10      | OC4FE     | RW     | Compare/capture4 fast enable     | 0           |
| [9:8]   | CC4S[1:0] | RW     | Compare/capture4 input selection | 0           |
| 7       | OC3CE     | RW     | Compare/capture3 clear enable    | 0           |
| [6:4]   | OC3M[2:0] | RW     | Compare/capture3 mode setting    | 0           |
| 3       | OC3PE     | RW     | Compare/capture3 preload enable  | 0           |
| 2       | OC3FE     | RW     | Compare/capture3 fast enable     | 0           |
| [1:0]   | CC3S[1:0] | RW     | Compare/capture3 input selection | 0           |

## Capture mode (pin direction is input):

| Bit     | Name        | Access | Description                             | Reset value |
|---------|-------------|--------|-----------------------------------------|-------------|
| [15:12] | IC4F[3:0]   | RW     | Input capture4 filter configuration     | 0           |
| [11:10] | IC4PSC[1:0] | RW     | Compare/capture4 prescale configuration | 0           |
| [9:8]   | CC4S[1:0]   | RW     | Compare/capture4 input selection        | 0           |
| [7:4]   | IC3F[3:0]   | RW     | Input capture3 filter configuration     | 0           |
| [3:2]   | IC3PSC[1:0] | RW     | Compare/capture3 prescale configuration | 0           |
| [1:0]   | CC3S[1:0]   | RW     | Compare/capture3 input selection        | 0           |

#### 15.4.9 Compare/Capture Enable Register (TIMx CCER) (x=2/3/4/5)

| 15   | 14   | 13   | 12   | 11   | 10    | 9    | 8    | 7    | 6     | 5    | 4    | 3    | 2     | 1    | 0    |
|------|------|------|------|------|-------|------|------|------|-------|------|------|------|-------|------|------|
| Rese | rved | CC4P | CC4E | Rese | erved | CC3P | СС3Е | Rese | erved | CC2P | CC2E | Rese | erved | CC1P | CC1E |

| Bit | Name | Access | Description | Reset value |  |
|-----|------|--------|-------------|-------------|--|
|     |      |        |             |             |  |

| [15:14] | Reserved  | RO | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0 |
|---------|-----------|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| 13      | CC4P      | RW | Compare/capture4 output polarity                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0 |
| 12      | CC4E      | RW | Compare/capture4 output enable                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0 |
| [11:10] | Reserved  | RO | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0 |
| 9       | CC3P      | RW | Compare/capture3 output polarity                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0 |
| 8       | CC3E      | RW | Compare/capture3 output enable                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0 |
| [7:6]   | CC2NP     | RO | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0 |
| 5       | CC2P      | RW | Compare/capture2 output polarity                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0 |
| 4       | CC2E      | RW | Compare/capture2 output enable                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0 |
| [3:2]   | Reserved  | RO | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0 |
| 1       | CC1P      | RW | Compare/capture1 output polarity CC1 channel configured as output: 0: OC1 active high; 1: OC1 active low. CC1 channel configured as input: This bit selects whether IC1 or the inverted signal of IC1 is used as the trigger or capture signal. 0: not inverted: capture occurs on the rising edge of IC1; when used as an external trigger, IC1 is not inverted. 1: Inverted: capture occurs on the falling edge of IC1; when used as an external trigger, IC1 is inverted. | 0 |
| 0       | 0 CC1E RW |    | Compare/capture1 output enable The CC1 channel is configured to output: 0: Off: OC1 output is disabled. 1: On: OC1 signal is output to the corresponding output pin. CC1 channel configured as input: This bit determines whether the counter value can be captured into the TIMx_CCR1 register. 0: Capture disable; 1: Capture enable.                                                                                                                                      | 0 |

# 15.4.10 Counter of General-purpose Timer (TIMx\_CNT) (x=2/3/4)

Offset address: 0x24



| Bit    | Name      | Access | Description                       | Reset value |
|--------|-----------|--------|-----------------------------------|-------------|
| [15:0] | CNT[15:0] | RW     | Real-time value of timer counter. | 0           |

# 15.4.11 Counter of General-purpose Timer (TIMx\_CNT) (x=5)

Offset address: 0x24

|    |    |    |    |    |    |   | CNT[ | 31:16] |   |   |   |   |   |   |   |
|----|----|----|----|----|----|---|------|--------|---|---|---|---|---|---|---|
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8    | 7      | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|    |    |    |    |    |    |   | CNT  | [15:0] |   |   |   |   |   |   |   |

| Bit    | Name      | Access | Description                       | Reset value |
|--------|-----------|--------|-----------------------------------|-------------|
| [31:0] | CNT[31:0] | RW     | Real-time value of timer counter. | 0           |

Note: The 32-bit TIM5\_CNT is only applicable to the products with model number CH32F20x\_D8W, CH32V20x\_D8, CH32V20x\_D8W series, and the TIM5\_CNT for other series of chips is 16-bit.

# 15.4.12 Prescaler (TIMx\_PSC) (x=2/3/4/5)

Offset address: 0x28

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8    | 7     | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|------|-------|---|---|---|---|---|---|---|
|    |    |    |    |    |    |   | PSC[ | 15:0] |   | · |   |   |   |   |   |

| Bit    | Name      | Access | Description                                                                                                                                                  | Reset value |
|--------|-----------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [15:0] | PSC[15:0] | RW     | The frequency division factor of the timer's prescaler; the clock frequency of the counter is equal to the input frequency of the frequency divider/(PSC+1). |             |

## 15.4.13 Auto-reload Value Register (TIMx\_ATRLR) (x=2/3/4)

Offset address: 0x2C

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8   | 7      | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|-----|--------|---|---|---|---|---|---|---|
|    |    |    |    |    |    |   | ARR | [15:0] |   |   |   |   |   |   |   |

| Bit    | Name      | Access | Description                                                                                                                                                   | Reset value |
|--------|-----------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [15:0] | ARR[15:0] | RW     | The value of ATRLR[15:0] is loaded into the counter. Please refer to Section 15.2.4 for ATRLR acting and update time. When ATRLR is empty, the counter stops. | FFFFh       |

#### 15.4.14 Auto-reload Value Register (TIMx ATRLR) (x=5)

Offset address: 0x2C

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24   | 23     | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|------|--------|----|----|----|----|----|----|----|
|    |    |    |    |    |    |    | ARR[ | 31:16] |    |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8    | 7      | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    |    | ARR  | [15:0] |    |    |    |    |    |    |    |

| Bit    | Name      | Access | Description                                                                                                                                                   | Reset value |
|--------|-----------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:0] | ARR[31:0] | RW     | The value of ATRLR[31:0] is loaded into the counter. Please refer to Section 15.2.4 for ATRLR acting and update time. When ATRLR is empty, the counter stops. | FFFFh       |

Note: The 32-bit TIM5\_ATRLR is only applicable to the products with model number CH32F20x\_D8W,

CH32V20x\_D8, CH32V20x\_D8W series, and the TIM5\_ATRLR for other series of chips is 16-bit.

#### 15.4.15 Compare/Capture Register1 (TIMx CH1CVR) (x=2/3/4)

Offset address: 0x34

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8    | 7      | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|------|--------|---|---|---|---|---|---|---|
|    |    |    |    |    |    |   | CCR1 | [15:0] |   |   |   |   |   |   |   |

| ĺ | Bit    | Name       | Access | Description                         | Reset value |
|---|--------|------------|--------|-------------------------------------|-------------|
| ĺ | [15:0] | CCR1[15:0] | RW     | Value of compare/capture channel 1. | 0           |

#### 15.4.16 Compare/Capture Register1 (TIMx\_CH1CVR) (x=5)

Offset address: 0x34

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24   | 23      | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|------|---------|----|----|----|----|----|----|----|
|    |    |    |    |    |    |    | CCR1 | [31:16] |    |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8    | 7       | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    |    | CCR1 | [15:0]  |    |    |    |    |    |    |    |

| Bit    | Name       | Access | Description                         | Reset value |
|--------|------------|--------|-------------------------------------|-------------|
| [31:0] | CCR1[31:0] | RW     | Value of compare/capture channel 1. | 0           |

Note: The 32-bit TIM5\_CH1CVR is only applicable to the products with model number CH32F20x\_D8W, CH32V20x\_D8, CH32V20x\_D8W series, and the TIM5\_CH1CVR for other series of chips is 16-bit.

#### 15.4.17 Compare/Capture Register2 (TIMx\_CH2CVR) (x=2/3/4)

Offset address: 0x38



| Bit    | Name       | Access | Description                         | Reset value |
|--------|------------|--------|-------------------------------------|-------------|
| [15:0] | CCR2[15:0] | RW     | Value of compare/capture channel 2. | 0           |

#### 15.4.18 Compare/Capture Register2 (TIMx CH2CVR) (x=5)

Offset address: 0x38

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24   | 23      | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|------|---------|----|----|----|----|----|----|----|
|    |    | -  | -  |    | -  |    | CCR2 | [31:16] | -  | -  |    | -  |    | -  |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8    | 7       | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    |    | CCR2 | 2[15:0] |    |    |    |    |    |    |    |

| İ | Bit    | Name       | Access | Description                         | Reset value |
|---|--------|------------|--------|-------------------------------------|-------------|
| İ | [31:0] | CCR1[31:0] | RW     | Value of compare/capture channel 2. | 0           |

Note: The 32-bit TIM5 CH2CVR is only applicable to the products with model number CH32F20x D8W,

CH32V20x\_D8, CH32V20x\_D8W series, and the TIM5\_CH2CVR for other series of chips is 16-bit.

#### 15.4.19 Compare/Capture Register3 (TIMx CH3CVR) (x=2/3/4)

Offset address: 0x3C

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8    | 7      | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|------|--------|---|---|---|---|---|---|---|
|    |    |    |    | ,  |    |   | CCR3 | [15:0] |   |   |   |   |   |   |   |

|    | Bit   | Name       | Access | Description                         | Reset value |
|----|-------|------------|--------|-------------------------------------|-------------|
| [1 | 15:0] | CCR3[15:0] | RW     | Value of compare/capture channel 3. | 0           |

#### 15.4.20 Compare/Capture Register3 (TIMx\_CH3CVR) (x=5)

Offset address: 0x3C

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24   | 23      | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|------|---------|----|----|----|----|----|----|----|
|    |    |    |    |    |    |    | CCR3 | [31:16] |    | ,  |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8    | 7       | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    |    | CCR3 | [15:0]  |    | '  |    |    |    |    |    |

| Bit    | Name       | Access | Description                         | Reset value |
|--------|------------|--------|-------------------------------------|-------------|
| [31:0] | CCR3[31:0] | RW     | Value of compare/capture channel 3. | 0           |

Note: The 32-bit TIM5\_CH3CVR is only applicable to the products with model number CH32F20x\_D8W, CH32V20x\_D8, CH32V20x\_D8W series, and the TIM5\_CH3CVR for other series of chips is 16-bit.

#### 15.4.21 Compare/Capture Register4 (TIMx\_CH4CVR) (x=2/3/4)

Offset address: 0x40



| Bit    | Name       | Access | Description                         | Reset value |
|--------|------------|--------|-------------------------------------|-------------|
| [15:0] | CCR4[15:0] | RW     | Value of compare/capture channel 4. | 0           |

#### 15.4.22 Compare/Capture Register4 (TIMx CH4CVR) (x=5)

Offset address: 0x40

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24   | 23      | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|------|---------|----|----|----|----|----|----|----|
|    |    | -  | -  | -  | -  |    | CCR4 | [31:16] |    | -  | -  | -  | -  | -  |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8    | 7       | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    |    | CCR4 | [15:0]  | _  |    |    |    |    |    |    |

|   | Bit    | Name       | Access | Description                         | Reset value |
|---|--------|------------|--------|-------------------------------------|-------------|
| ĺ | [31:0] | CCR4[31:0] | RW     | Value of compare/capture channel 4. | 0           |

Note: The 32-bit TIM5 CH4CVR is only applicable to the products with model number CH32F20x D8W,

CH32V20x\_D8, CH32V20x\_D8W series, and the TIM5\_CH4CVR for other series of chips is 16-bit.

## 15.4.23 DMA Control Register (TIMx\_DMACFGR) (x=2/3/4/5)

Offset address: 0x48

| 15 | 14      | 13 | 12 | 11 | 10      | 9 | 8 | 7 | 6       | 5  | 4 | 3 | 2      | 1 | 0 |
|----|---------|----|----|----|---------|---|---|---|---------|----|---|---|--------|---|---|
| I  | Reserve | u  |    | Γ  | )BL[4:( | ) |   | R | leserve | ed |   | D | BA[4:0 | ) |   |

| Bit     | Name       | Access | Description                                          | Reset value |
|---------|------------|--------|------------------------------------------------------|-------------|
| [15:13] | Reserved   | RO     | Reserved.                                            | 0           |
| [12:8]  | DBL[4:0]   | RW     | Length of data that DMA continuously transfers; the  | 0           |
| [12.8]  | DBL[4.0]   | K W    | actual value is the value of this domain + 1.        | U           |
| [7:5]   | Reserved   | RO     | Reserved.                                            | 0           |
| [4.0]   | DD 4 [4.0] | RW     | These bits define the offset of DMA from the address | 0           |
| [4:0]   | DBA[4:0]   | KW     | of control register 1 in continuous mode.            | 0           |

#### 15.4.24 DMA Address Register in Continuous Mode (TIMx DMAADR) (x=2/3/4/5)

Offset address: 0x4C



| Bit    | Name       | Access | Description                     | Reset value |
|--------|------------|--------|---------------------------------|-------------|
| [15:0] | DMAB[15:0] | RW     | DMA address in continuous mode. | 0           |

# 15.4.25 Dual-edge Capture Register (TIMx\_AUX) (x=1/8/9/10)

|   | 15 14 13 12 11 10 9 8 7 6 5 4 3 |  |  |  |  |  |  |  |  | 2 | 1          | 0          |            |
|---|---------------------------------|--|--|--|--|--|--|--|--|---|------------|------------|------------|
| ĺ | Reserved                        |  |  |  |  |  |  |  |  |   | CAP_ED_CH4 | CAP_ED_CH3 | CAP_ED_CH2 |

| Bit    | Name       | Access | Description                                                                                                                                             | Reset value |
|--------|------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [15:3] | Reserved   | R0     | Reserved                                                                                                                                                | 0           |
| 2      | CAP_ED_CH4 | RW     | Dual-edge capture enable for channel 4: 0: Disables the dual-edge capture enable for channel 4; 1: Enable the dual-edge capture enable for channel 4.   | 0           |
| 1      | CAP_ED_CH3 | RW     | Dual-edge capture enable for channel 3:  0: Disables the dual-edge capture enable for channel 3;  1: Enable the dual-edge capture enable for channel 3. | 0           |
| 0      | CAP_ED_CH2 | RW     | Dual-edge capture enable for channel 2:<br>0: Disables the dual-edge capture enable for channel 2;                                                      | 0           |

|  | 1: Enable the dual-edge capture enable for channel |  |
|--|----------------------------------------------------|--|
|  | 2.                                                 |  |

Note: The TIMx\_AUX register is only available for CH32F20x\_D8, CH32F20x\_D8C, CH32V30x\_D8, CH32V30x\_D8C, and CH32V31x\_D8C lot numbers that do not have a zero in the penultimate sixth digit.

# **Chapter 16 Basic Timer (BCTM)**

#### This chapter applies to the whole family of CH32F20x, CH32V30x and CH32V31x.

The basic timer module contains a 16-bit auto-reload timer (TIM6 and TIM7), that can be used to count and generate interrupt/DMA request on the update event.

#### 16.1 Main Features

Basic timer features include:

- 16-bit auto-reload counter, supports upcount
- 16-bit prescaler, the frequency division factor is dynamically adjustable from 1 to 65536
- Synchronization circuit to trigger the DAC
- Interrupt/DMA request generation on the update event

#### **16.2 Principle and Structure**



Figure 16-1 Structure block diagram of basic timer

#### **16.2.1 Overview**

As shown in Figure 16-1, the structure of the basic timer can be divided into 2 parts: input clock and core counter.

The clock source of basic timer is HB bus clock (CK\_INT). These input clock signals become CK\_PSC clock after various set filtering and frequency division operations, and then they are output to the core counter. In addition, these complex clock sources can also be output to DAC peripheral as TRGO.

The core of the basic timer is a 16-bit counter (CNT). CK\_PSC is divided by prescaler (PSC) and becomes CK\_CNT, finally it is output to CNT. CNT supports upcount, and it has an auto-reload register (ATRLR), that reloads the initial value for the CNT every time a count cycle ends.

#### 16.2.2 Difference between Basic Timer and General-purpose Timer

Compared with general purpose timer, basic timer is lack of the following functions:

- 1) The basic timer does not support downcount or up/down count.
- 2) The basic timer does not have the 4 independent compare/capture channels.
- 3) The basic timer does not support external signals to control timer.
- 4) The basic timer does not support incremental code, or cascade connection/synchronization between timers.

#### 16.2.3 Clock Input

The clock of basic timer is provided by the internal clock (CK INT).

#### 16.2.4 Counter and Periphery

CK\_PSC is input to the prescaler (PSC) for frequency division. PSC has 16 bits, and the actual frequency division factor is equivalent to the value of R16\_TIMx\_PSC + 1. CK\_PSC becomes CK\_INT through PSC. The changed value of R16\_TIM1\_PSC does not take effect in real time, but can be updated to PSC after the update event. Update events include clearing the UG bit and resetting the UG bit.

### 16.3 Debug Mode

When the system enters debug mode, the timer continues to run or stops according to the setting of the DBG module.

# 16.4 Register Description

Table 16-1 TIM6 registers

| Name               | Offset address | Description                        | Reset value |  |
|--------------------|----------------|------------------------------------|-------------|--|
| R16_TIM6_CTLR1     | 0x40001000     | TIM6 control register1             | 0x0000      |  |
| R16_TIM6_CTLR2     | 0x40001004     | TIM6 control register2             | 0x0000      |  |
| R16_TIM6_DMAINTENR | 0x4000100C     | TIM6 DMA/interrupt enable register | 0x0000      |  |
| R16_TIM6_INTFR     | 0x40001010     | TIM6 interrupt flag register       | 0x0000      |  |
| R16_TIM6_SWEVGR    | 0x40001014     | TIM6 event generation register     | 0x0000      |  |
| R16_TIM6_CNT       | 0x40001024     | TIM6 counter                       | 0x0000      |  |
| R16_TIM6_PSC       | 0x40001028     | TIM6 prescaler                     | 0x0000      |  |
| R16_TIM6_ATRLR     | 0x4000102C     | TIM6 auto-reload register          | 0xFFFF      |  |

Table 16-2 TIM7 registers

| Name               | Offset address | Description                        | Reset value |
|--------------------|----------------|------------------------------------|-------------|
| R16_TIM7_CTLR1     | 0x40001400     | TIM7 control register1             | 0x0000      |
| R16_TIM7_CTLR2     | 0x40001404     | TIM7 control register2             | 0x0000      |
| R16_TIM7_DMAINTENR | 0x4000140C     | TIM7 DMA/interrupt enable register | 0x0000      |
| R16_TIM7_INTFR     | 0x40001410     | TIM7 interrupt flag register       | 0x0000      |
| R16_TIM7_CNT       | 0x40001424     | TIM7 counter                       | 0x0000      |
| R16_TIM7_PSC       | 0x40001428     | TIM7 prescaler                     | 0x0000      |
| R16_TIM7_ATRLR     | 0x4000142C     | TIM7 auto-reload register          | 0xFFFF      |

# 16.4.1 Control Register 1 (TIMx\_CTLR1) (x=6/7)

| 15 | 15 14 13 12 11 10 9 8 |  |  |  |  |  |  |  | 6 | 5       | 4  | 3   | 2   | 1    | 0   |
|----|-----------------------|--|--|--|--|--|--|--|---|---------|----|-----|-----|------|-----|
|    | Reserved              |  |  |  |  |  |  |  |   | Reserve | ed | OPM | URS | UDIS | CEN |

| Bit    | Name     | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Reset value |
|--------|----------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [15:8] | Reserved | RO     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0           |
|        |          |        | Auto reload and preload enable:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |             |
| 7      | ARPE     | RW     | 0: Auto-reload value register (ATRLR) disabled;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0           |
|        |          |        | 1: Auto-reload value register (ATRLR) enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |             |
| [6:4]  | Reserved | RO     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0           |
| 3      | ОРМ      | RW     | Single pulse mode.  0: The counter does not stop when the next update event occurs;  1: The counter stops when the next update event (The CEN bit is cleared) occurs.                                                                                                                                                                                                                                                                                                                                                                                                                       | 0           |
| 2      | URS      | RW     | Update request source; the software selects the source of UEV event through this bit.  0: If the update interrupt or if DMA request is enabled, any of the following events will generate an update interrupt or DMA request:  -Counter overflow/underflow -Set the UG bit  - Update generated by the slave mode controller  1: If the update interrupt or if the DMA request is enabled, only the counter overflow/underflow will generate the update interrupt or DMA request.                                                                                                            | 0           |
| 1      | UDIS     | RW     | Update disable. Software enables/disables the generation of UEV events through this bit.  0: UEV enabled. Update (UEV) events are generated by any of the following events:  - Counter overflow/underflow -Set the UG bit  - Update generated by the slave mode controller Registers with buffers are loaded with their preloaded values.  1: UEV disabled. No update event is generated, and the registers (ATRLR, PSC and CHCTLRx) maintain their values. If the UG bit is set or a hardware reset is sent by the slave mode controller, the counter and prescaler will be reinitialized. | 0           |
| 0      | CEN      | RW     | Counter enable. 0: Counter disabled; 1: Counter enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0           |

# 16.4.2 Control Register 2 (TIMx\_CTLR2) (x=6/7)

Offset address: 0x04



| Bit    | Name     | Access | Description                                                                                           | Reset value |
|--------|----------|--------|-------------------------------------------------------------------------------------------------------|-------------|
| [15:7] | Reserved | RO     | Reserved                                                                                              | 0           |
|        |          | RO     |                                                                                                       | 0           |
|        |          |        | controlled by the trigger input, there will be a delay on                                             |             |
|        |          |        | TRGO, unless the master/slave mode is selected (See the description of the MSM bit in the TIMx_SMCFGR |             |
|        |          |        | register);                                                                                            |             |
|        |          |        | 010: An update event is selected as the trigger output                                                |             |
|        |          |        | (TRGO). For example, the clock of a master timer can                                                  |             |
|        |          |        | be used as a prescaler for a slave timer.                                                             |             |
| [3:0]  | Reserved | RO     | Reserved                                                                                              | 0           |

# 16.4.3 DMA/Interrupt Enable Register (TIMx\_DMAINTENR) (x=6/7)



| Bit    | Name     | Access | Description                     | Reset value |
|--------|----------|--------|---------------------------------|-------------|
| [15:9] | Reserved | RO     | Reserved                        | 0           |
|        |          |        | Update DMA request enable.      |             |
| 8      | UDE      | RW     | 0: Update DMA request disabled; | 0           |
|        |          |        | 1: Update DMA request enabled.  |             |
| [7:1]  | Reserved | RO     | Reserved                        | 0           |
| 0      | UIE      | RW     | Update interrupt enable.        | 0           |

| 1: Update interrupt enabled. | 0: Update interrupt disabled; |  |
|------------------------------|-------------------------------|--|
|                              | 1: Update interrupt enabled.  |  |

# 16.4.4 Interrupt Flag Register (R16\_TIMx\_INTFR) (x=6/7)

Offset address: 0x10



| Bit    | Name     | Access | Description                                                                                                                                                                                                                                                                                                                                                                                    | Reset value |
|--------|----------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [15:1] | Reserved | RO     | Reserved                                                                                                                                                                                                                                                                                                                                                                                       | 0           |
| 0      | UIF      | RW0    | Update interrupt flag. When an update event occurs, this bit is set by hardware and cleared by software.  0: No update interrupt generated;  1: Update interrupt generated.  An update event generates in case of the following circumstances:  UDIS=0, the repeat counter value overflows or underflows;  URS=0, UDIS=0, the UG bit is set, or the counter core is reinitialized by software. | 0           |

# 16.4.5 Event Generation Register (TIMx\_SWEVGR) (x=6/7)

Offset address: 0x14

| 15 | 14       | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2  | 1 | 0 |
|----|----------|----|----|----|----|---|---|---|---|---|---|---|----|---|---|
|    | Reserved |    |    |    |    |   |   |   |   |   |   |   | UG |   |   |

| Bit    | Name     | Access | Description                                              | Reset value |
|--------|----------|--------|----------------------------------------------------------|-------------|
| [15:1] | Reserved | RO     | Reserved                                                 | 0           |
|        |          |        | Update event generation, to generate an update event.    |             |
|        |          |        | This bit is set by software and cleared automatically by |             |
|        |          |        | hardware.                                                |             |
| 0      | UG       | WO     | 0: No effect;                                            | 0           |
|        | UG       | WO     | 1: Initialize the counter and generate an update event.  | U           |
|        |          |        | Note: The prescaler's counter is also cleared, but the   |             |
|        |          |        | prescaler ratio remains unchanged. If in increment       |             |
|        |          |        | mode, the core counter is cleared.                       |             |

#### 16.4.6 Counter of General-purpose Timer (TIMx CNT) (x=6/7)



| Bit Name Access Description Res | eset value |
|---------------------------------|------------|
|---------------------------------|------------|

| [15:0] CNT[15:0] RW Real-time value of counter. | 0 |
|-------------------------------------------------|---|
|-------------------------------------------------|---|

# 16.4.7 Prescaler (TIMx\_PSC) (x=6/7)

Offset address: 0x28

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8    | 7     | 6 | 5 | _4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|------|-------|---|---|----|---|---|---|---|
|    |    |    | ., |    |    |   | PSC[ | 15:0] |   |   |    |   |   |   |   |

| Bit    | Name      | Access | Description                                                                                                                                    | Reset value |
|--------|-----------|--------|------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [15:0] | PSC[15:0] | RW     | Frequency division factor of the timer's prescaler. The clock frequency of the counter is equal to the input frequency of the divider/(PSC+1). |             |

# 16.4.8 Auto-reload Register (TIMx\_ATRLR) (x=6/7)

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8    | 7      | 6 | 5 | 4   | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|------|--------|---|---|-----|---|---|---|---|
|    |    |    |    |    |    |   | ARR[ | [15:0] |   |   | · · |   |   |   |   |

| Bit    | Name      | Access | Description                                                                                                                                                   | Reset value |
|--------|-----------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [15:0] | ARR[15:0] | RW     | The value of ATRLR[15:0] is loaded into the counter. Please refer to Section 16.2.4 for ATRLR acting and update time. When ATRLR is empty, the counter stops. | FFFFh       |

# **Chapter 17 Digital-to-Analog Converter (DAC)**

This chapter applies to some family of CH32F20x, CH32V20x, CH32V30x and CH32V31x.

The digital-to-analog converter (DAC) contains 2 converters that converts 8/12-bit digital input to 2-channel analog voltage output. The DAC module has built-in triangular-wave generator and noise-wave generator, and it supports multiple event trigger conversions and supports DMA.

#### 17.1 Main Features

- Two DAC converters, and each has single output channel
- Triangular-wave generator and noise-wave generator
- Configurable 8-bit or 12-bit output
- Left or right data alignment in 12-bit mode
- Dual DAC channel for independent or simultaneous conversions
- DMA capability
- Multiple trigger events

# 17.2 Functional Description

#### 17.2.1 DAC Structure



Figure 17-1 DAC block diagram

#### 17.2.2 DAC Channel Configuration

#### **17.2.2.1 Enable DAC:**

Set the ENx bit in the DAC\_CTLR register to 1, to enable the analog power to DAC channel x. After a period of start-up time, DAC channel x can be enabled. The DAC contains 2 analog output channels which can output independently or simultaneously.

Note: In order to avoid parasitic interference and additional power consumption, the corresponding pins of the DAC channel need to be set to analog input (AIN) mode in advance.

#### 17.2.2.2 Enable Output Buffer:

DAC integrates output buffers, which can be used to reduce the output impedance and increase the drive capacity to directly drive the external loads. Each DAC channel output buffer can be enabled or disabled by setting the BOFFx bit in the DAC\_CTLR register.

#### **17.2.2.3 Data Format:**

In single DAC channel mode, data formats include 8-bit right alignment, 12-bit left alignment and 12-bit right alignment.

When 8-bit data is right-aligned, write data to DAC\_R8BDHRx[7:0], and the module will load (after 1 PB1 clock cycle) its left-shifted data to the data output register DAC DORx[11:4].

When 12-bit data is right-aligned, write data to DAC\_R12BDHRx[11:0], and the module will load (after 1 PB1 clock cycle) right-aligned data into the data output register DAC\_DORx[11:0].

When 12 data are left-aligned, write the data to DAC\_L12BDHRx[15:4]. After the corresponding shift, the module will load (after 1 PB1 clock cycle) the left-aligned data to the data output register DAC\_DORx[11:0].

31 24 15 7 0

8 Bit right-aligned

12 Bit left-aligned

12 Bit right-aligned

Figure 17-2 Data formats in single channel mode

In dual DAC channel mode, there are also three methods: 8-bit data right alignment, 12-bit data left alignment, and 12-bit data right alignment.

For 8-bit data right-aligned, write data to DAC\_RD8BDHR[7:0], the module will load (after 1 PB1 clock cycle) bits [7:0] shifted to DAC\_DOR1[11:4] and bits [15:8] shifted to DAC\_DOR2[11:4].

For 12 data left-aligned, write data to DAC\_LD12BDHR[31:0], the module will load (after 1 PB clock cycle) bit[15:4] data shifted to DAC\_DOR1[11:0] and bit[31:20] data shifted to DAC\_DOR2[11:0].

12-bit data right-aligned, write data to DAC\_RD12BDHR[31:0], the module will load (after 1 PB clock cycle) bit[11:0] data to DAC\_DOR1[11:0] and bit[27:16] data to DAC\_DOR2[11:0].



Figure 17-3 Data formats in dual channel mode

#### 17.2.2.4 DMA Capability:

DAC channel has the DMA capability. Set the DMAENx bit in the DAC\_CTLR register to 1, to enable DMA of the corresponding channel. When a trigger event occurs (Software trigger not included), a DMA request is generated. And then the data in the DAC\_DORx register can be updated.

#### 17.2.2.5 Trigger Event Selection:

DAC conversion can be triggered by the following events. When the TENx bit in the DAC\_CTLR register is set to 1, a trigger event to trigger DAC conversion can be selected by configuring the TSELx[2:0] bits.

Trigger source
Type
TSELx[2:0]

Timer 6 TRGO event
Timer 8 TRGO event
Timer 7 TRGO event
Timer 7 TRGO event
Timer 7 TRGO event
Timer 7 TRGO event

271

Table 17-1 Trigger events

| Timer 5 TRGO event        |                      | 011 |
|---------------------------|----------------------|-----|
| Timer 2 TRGO event        |                      | 100 |
| Timer 4 TRGO event        |                      | 101 |
| EXTI line9                | External pin         | 110 |
| SWTRIG (Software trigger) | Software control bit | 111 |

Every time a DAC interface detects a rising edge on the selected timer TRGO output or on the selected external interrupt line 9, the DAC DORx register is updated 3 PB1 clock cycles after the trigger occurs.

If the software trigger mode is configured, once the SWTRIG bit is set to 1, a conversion is started. The DAC\_DORx register is updated single PB1 clock cycle after the trigger occurs, and the SWTRIG bit can be automatically cleared by hardware.

Note: The TSELx[2:0] bits cannot be changed when ENx is 1.

#### 17.2.3 DAC Conversion

The data of the DAC channel comes from the DAC\_DORx register, but data cannot be directly written to the register DAC\_DORx. Any data output to the DAC channel x must be written into the DAC\_R12BDHR1, DAC\_L12BDHR1, DAC\_L12BDHR2, DAC\_L12BDHR2, DAC\_RD12BDHR, DAC\_LD12BDHR and DAC\_RD8BDHR registers. The internal DAC\_DHRx register obtains the value of above registers and transfers it to the DAC\_DORx register after the corresponding time.

In the non-trigger mode, the data written into the DAC\_xDHRx register is shifted into the DAC\_DORx register in an PB1 clock cycle.

In software trigger mode, the DAC\_DORx register is automatically updated in an PB1 clock cycle after the rising edge of the event trigger.

In hardware trigger mode (Timer TRGO event or external interrupt line 9 rising edge), the DAC\_DORx register is automatically updated in 3 PB1 clock cycles after the trigger event.

Load the DAC\_DORx register data. After the time of t<sub>SETTLING</sub>, the output can be valid, and the length of this period of time will vary depending on the supply voltage and the analog output load.

The digital input is linearly converted to analog voltage output by the DAC, and it ranges from 0 to  $V_{DDA}$ . The output voltage on any DAC channel pin shall meet the following relationship:

DAC output voltage =  $V_{DDA}$ \* (DAC DORx/ 4096).

#### 17.2.4 DAC Triangular-wave Generator

The module has a built-in triangular-wave generator, which can add a small amplitude triangle-wave to the reference signal. Set WAVEx[1:0] bit as '10' and select the triangular-wave generation function of DAC. Set MAMPx[3:0] bit in the DAC\_CTLR register to select the amplitude of triangular-wave.

The system contains a triangular-wave counter starting from 0, which accumulates by 1 in 3 PB1 clock cycles after each trigger event. The value of the counter is added to the value of the DAC\_DHRx register and the overflow bit is discarded and then written to the DAC\_DORx register. When the value transmitted into the DAC\_DORx register is smaller than the maximum amplitude defined by the MAMPx[3:0] bits, the triangular-wave counter will gradually accumulate. Once it reaches the set maximum amplitude, the counter will begin to decrease progressively, and then start to accumulate after reaching 0. Repeat this cycle. Set WAVEx[1:0] bits to '00' to reset the generation of triangle-waves.

Note: 1. To generate a triangular-wave, DAC trigger must be enabled, i.e., setting the TENx bit in the DAC CTLR register to 1.

2. MAMPx[3:0] bits must be set before enable the DAC. Otherwise, its value cannot be modified.



#### 17.2.5 DAC Noise-wave Generator

The module has a built-in noise-generator that uses the Linear Feedback Shift Register (LFSR) to generate pseudo noise with varying amplitude. Set WAVE[1:0] bits to '01' to select the DAC noise generation function. Set the MAMPx[3:0] bits in the DAC CTLR register to select the data of the masked part of the LFSR.

The preload value of the register LFSR is 0xAAA. According to a specific algorithm, the value of this register is updated in 3 PB1 clock cycles after each trigger event. Setting the MAMPx[3:0] bits in the DAC\_CR register can mask part or all of the LFSR data, so that the LSFR value obtained is added to the value of DAC\_DHRx, and the overflow bit is removed and then written into the DAC\_DORx register. If the register LFSR value is 0x000, it will inject '1' (Anti-lock mechanism). Set WAVEx[1:0] bit to '00' to reset the generation algorithm of LFSR waveform.

Note: To generate a noise-wave, DAC trigger must be enabled, i.e., setting the TENx bit in the DAC\_CTLR register to 1.



#### 17.3 Dual DAC Conversion

When the 2 DAC channels are required at the same time, the module integrates 3 data registers in dual DAC mode (DAC\_RD8BDHR, DAC\_LD12BDHR, DAC\_RD12BDHR), in order to efficiently operate the DAC module. The conversion value of the 2 DACs can be updated when only one of the 3 registers is operated. For dual DAC conversion, other registers of the module can be used to implement 11 types of conversion modes with different combinations. The value of data to be converted in the 2 channels needs to be written to one of the 3 data registers.

#### 17.3.1 Independent Trigger with the Same LFSR Generation

Set the TENx bits. TSELx can be set as different values. WAVEx is set to 0b01. MAMPx is set as the same LFSR mask value. When a channel1 trigger event occurs, add the counter (LFSR1) with the same mask value to the channel1 data register (DAC\_DHR1), and the sum is transferred to DAC\_DOR1 after delay of 3 PB1 clocks, for conversion. Then the LFSR1 counter is updated. When a channel2 trigger event occurs, add the counter (LFSR2) with the same mask value to the channel2 data register (DAC\_DHR2), and the sum is transferred to DAC\_DOR2 for conversion after delay of 3 PB1 clocks. Then the LFSR2 counter is updated.

V2. 4 273 WTH

#### 17.3.2 Independent Trigger with Different LFSR Generation

Set the TENx bits. TSELx can be set as different values. WAVEx is set to 0b01. MAMPx can be set as different mask values of LFSR. When a channel1 trigger event occurs, add the LFSR1 counter, with the mask value configured by the MAMP1[3:0] bits, to the channel1 data register (DAC\_DHR1), and the sum is transferred to DAC\_DOR1 for conversion after delay of 3 PB1 clocks. Then the LFSR1 counter is updated. When a channel2 trigger event occurs, add the LFSR2 counter, with the mask value configured by the MAMP2[3:0] bits, to the channel2 data register (DAC\_DHR2), and the sum is transferred to DAC\_DOR2 for conversion after delay of 3 PB1 clocks. Then the LFSR2 counter is updated.

#### 17.3.3 Independent Trigger with the Same Triangle Generation

Set the TENx bits. TSELx can be set as different values. WAVEx is set to 0b1x. MAMPx is set as the same triangle amplitude value. When a channel1 trigger event occurs, add the channel1 triangle counter, with the same triangle amplitude, to the channel1 data register (DAC\_DHR1), and the sum is transferred to DAC\_DOR1 for conversion after delay of 3 PB1 clocks. Then the channel1 triangle counter is updated. When a channel2 trigger event occurs, add the channel2 triangle counter, with the same triangle amplitude, to the channel2 data register (DAC\_DHR2), and the sum is transferred to DAC\_DOR2 for conversion after delay of 3 PB1 clocks. Then the channel2 triangle counter is updated.

#### 17.3.4 Independent Trigger with Different Triangle Generation

Set the TENx bits. TSELx can be set as different values. WAVEx is set to 0b1x. MAMPx can be set as different triangle amplitude values. When a channel1 trigger event occurs, add the channel1 triangle counter, with a triangle amplitude configured by MAMP1, to the channel1 data register (DAC\_DHR1), and the sum is transferred to DAC\_DOR1 for conversion after delay of 3 PB1 clocks. Then the channel1 triangle counter is updated. When a channel2 trigger event occurs, add the channel2 triangle counter, with a triangle amplitude configured by MAMP2, to the channel2 data register (DAC\_DHR2), and the sum is transferred to DAC\_DOR2 for conversion after delay of 3 PB1 clocks. Then the channel2 triangle counter is updated.

#### 17.3.5 Independent Trigger with No Wave Generation

Set the TENx bits. TSELx can be set as different values to select different trigger sources. When a channel 1 trigger event occurs, the value of the channel 1 data register (DAC\_DHR1) delayed 3 PB1 clocks is transferred to DAC\_DOR1 for conversion. When a channel 2 trigger event occurs, the value of the channel 2 data register (DAC\_DHR2) delayed 3 PB1 clocks is transferred to DAC\_DOR2 for conversion.

#### 17.3.6 Simultaneous Software Trigger

In this conversion mode, write the dual DAC channel data to the desired register. An PB1 clock cycle later, the data in DAC\_DHR1 and DAC\_DHR2 is respectively transferred to DAC\_DOR1 and DAC\_DOR2 for conversion.

#### 17.3.7 Simultaneous Trigger with the Same LFSR Generation

Set the TENx bits. TSELx is set as the same value. WAVEx is set to 0b01. MAMPx is set as the same LFSR mask value. When a trigger event occurs, add the LFDR1 counter, with the same mask value, to the DAC\_DHR1 register, and the sum is transferred to DAC\_DOR1 after delay of 3 PB1 clocks for conversion. Then the LFSR1 counter is updated. At the same time, add the LFDR2 counter, with the same mask value, to

the DAC\_DHR2 register, and the sum is transferred to DAC\_DOR2 after delay of 3 PB1 clocks for conversion. Then the LFSR2 counter is updated.

#### 17.3.8 Simultaneous Trigger with Different LFSR Generation

Set the TENx bits. TSELx is set as the same value. WAVEx is set to 0b01. MAMPx can be set as different LFSR mask values. When a trigger event occurs, add the LFSR1 counter, with different mask values, to the DAC\_DHR1 register, and the sum is transferred to DAC\_DOR1 after delay of 3 PB1 clocks for conversion. Then the LFSR1 counter is updated. At the same time, add the LFSR2 counter, with different mask values, to the DAC\_DHR2 register, and the sum is transferred to DAC\_DOR2 after delay of 3 PB1 clocks for conversion. Then the LFSR2 counter is updated.

#### 17.3.9 Simultaneous Trigger with the Same Triangle Generation

Set the TENx bits. TSELx is set as the same value. WAVEx is set to 0b1x. MAMPx is set as the same triangle amplitude value. When a trigger event occurs, add the counter, with the same triangle amplitude value, to the DAC\_DHR1 register, and the sum is transferred to DAC\_DOR1 after delay of 3 PB1 clocks for conversion. Then the channel1 triangle counter is updated. At the same time, add the counter, with the same triangle amplitude value, to the DAC\_DHR2 register, and the sum is transferred to DAC\_DOR2 after delay of 3 PB1 clocks for conversion. Then the channel2 triangle counter is updated.

#### 17.3.10 Simultaneous Trigger with Different Triangle Generation

Set the TENx bits. TSELx is set as the same value. WAVEx is set to 0b1x. MAMPx can be set as different triangle amplitude values. When a trigger event occurs, add the counter, with a triangle amplitude configured by MAMP1[3:0], to the DAC\_DHR1 register, and the sum is transferred to DAC\_DOR1 after delay of 3 PB1 clocks for conversion. Then the channel1 triangle counter is updated. At the same time, add the counter, with a triangle amplitude configured by MAMP2[3:0], to the DAC\_DHR2 register, and the sum is transferred to DAC\_DOR2 after delay of 3 PB1 clocks for conversion. Then the channel2 triangle counter is updated.

#### 17.3.11 Simultaneous Trigger with No Wave Generation

Set the TENx bits. TSELx is set as the same value. In this conversion mode, when a trigger event occurs, the values of the DAC\_DHR1 register and the DAC\_DHR2 register delayed 3 PB1 clocks are respectively transferred to DAC\_DOR1 and DAC\_DOR2 for DAC conversion.

# 17.4 Register Description

Table 17-2 DAC registers

| Name              | Access address | Description                            | Reset value |  |  |
|-------------------|----------------|----------------------------------------|-------------|--|--|
| R32_DAC_CTLR      | 0x40007400     | DAC control register                   | 0x00000000  |  |  |
| R32_DAC_SWTR      | 0x40007404     | DAC software trigger register          | 0x00000000  |  |  |
| R32 DAC R12BDHR1  | 0x40007408     | DAC channel1 right-aligned 12-bit data | 0x00000000  |  |  |
| R32_DAC_R12BDHR1  | 0x40007408     | hold register                          | 020000000   |  |  |
| R32 DAC L12BDHR1  | 0x4000740C     | DAC channell left-aligned 12-bit data  |             |  |  |
| K32_DAC_L12BDfik1 | 0x4000/40C     | hold register                          | 0x00000000  |  |  |
| R32 DAC R8BDHR1   | 0x40007410     | 0x00000000                             |             |  |  |
| K32_DAC_R0DDHKI   | 034000/410     | hold register                          | 0x0000000   |  |  |

| R32_DAC_R12BDHR2 | 0x40007414 | DAC channel2 right-aligned 12-bit data hold register | 0x00000000 |
|------------------|------------|------------------------------------------------------|------------|
| R32_DAC_L12BDHR2 | 0x40007418 | DAC channel2 left-aligned 12-bit data hold register  | 0x00000000 |
| R32_DAC_R8BDHR2  | 0x4000741C | DAC channel2 right-aligned 8-bit data hold register  | 0x00000000 |
| R32_DAC_RD12BDHR | 0x40007420 | Dual channel right-aligned 12-bit data hold register | 0x00000000 |
| R32_DAC_LD12BDHR | 0x40007424 | Dual channel left-aligned 12-bit data hold register  | 0x00000000 |
| R32_DAC_RD8BDHR  | 0x40007428 | Dual channel right-aligned 8-bit data hold register  | 0x00000000 |
| R32_DAC_DOR1     | 0x4000742C | DAC channel1 data output register                    | 0x00000000 |
| R32_DAC_DOR2     | 0x40007430 | DAC channel2 data output register                    | 0x00000000 |

# 17.4.1 DAC Control Register (DAC\_CTLR)

| 31 | 30       | 29 | 28         | 27 | 26         | 25      | 24         | 23   | 22         | 21 | 20   | 19        | 18   | 17        | 16  |
|----|----------|----|------------|----|------------|---------|------------|------|------------|----|------|-----------|------|-----------|-----|
| R  | Reserved | l  | DMAE<br>N2 |    | MAMP2[3:0] |         | WAVE2[2:0] |      | TSEL2[2:0] |    | TEN2 | BOFF<br>2 | EN2  |           |     |
| 15 | 14       | 13 | 12         | 11 | 10         | 9       | 8          | 7    | 6          | 5  | 4    | 3         | 2    | 1         | 0   |
| R  | Reserved | l  | DMAE<br>N1 |    | MAM        | P1[3:0] |            | WAVE | E1[2:0]    | TS |      | :0]       | TEN1 | BOFF<br>1 | EN1 |

| Bit     | Name           | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Reset value |
|---------|----------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:29] | Reserved       | RO     | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0           |
| 28      | DMAEN2         | RW     | DMA enable of DAC channel2: 0: DMA of DAC channel2 disabled; 1: DMA of DAC channel2 enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0           |
| [27:24] | MAMP2<br>[3:0] | RW     | DAC channel2 mask/amplitude setting. The software sets this area to select the LFSR data mask bit in the noise generation mode, and select the waveform amplitude in the triangle waveform generation mode:  0000: Unmask bit0 of LFSR/Triangle amplitude equal to 1;  0001: Unmask bits[1:0] of LFSR / Triangle amplitude equal to 3;  0010: Unmask bits[2:0] of LFSR / Triangle amplitude equal to 7;  0011: Unmask bits[3:0] of LFSR / Triangle amplitude equal to 15;  0100: Unmask bits[4:0] of LFSR / Triangle amplitude equal to 31;  0101: Unmask bits[5:0] of LFSR / Triangle amplitude equal to 63;  0110: Unmask bits[6:0] of LFSR / Triangle amplitude equal to 127;  1011: Unmask bits[7:0] of LFSR / Triangle amplitude equal to 511;  1001: Unmask bits[9:0] of LFSR / Triangle amplitude equal to 1023;  1010: Unmask bits[9:0] of LFSR / Triangle amplitude equal to 2047;  ≥1011: Unmask bits[10:0] of LFSR / Triangle amplitude equal to 2047; | 0           |

|                    |               |      | 4095.                                                               |   |
|--------------------|---------------|------|---------------------------------------------------------------------|---|
|                    |               |      | Noise/triangular wave generation enable of DAC channel2             |   |
| 500.007            | WAVE2         |      | 00: Wave generator disabled;                                        |   |
| [23:22]            | [1:0]         | RW   | 01: Noise-wave generator enabled;                                   | 0 |
|                    |               |      | 1x: Triangular-wave generator enabled.                              |   |
|                    |               |      | Trigger event selection of DAC channel2:                            |   |
|                    |               |      | 000: TIM6 TRGO event;                                               |   |
|                    |               |      | 001: TIM8 TRGO event;                                               |   |
|                    |               |      | 010: TIM7 TRGO event;                                               |   |
| F <b>Q</b> 1 1 0 1 | TSEL2[2:      | DIII | 011: TIM5 TRGO event;                                               | 0 |
| [21:19]            | 0]            | RW   | 100: TIM2 TRGO event;                                               | 0 |
|                    |               |      | 101: TIM4 TRGO event;                                               |   |
|                    |               |      | 110: External interrupt line9;                                      |   |
|                    |               |      | 111: Software trigger;                                              |   |
|                    |               |      | Others: Reserved.                                                   |   |
|                    |               |      | External trigger mode enable of DAC channel2:                       |   |
|                    |               |      | 0: Trigger of DAC channel2 disabled. The data written into the      |   |
|                    |               |      | DAC xDHR register is sent to the DAC DOR2 register in 1 PB1         |   |
|                    |               |      | clock cycle.                                                        |   |
| 18                 | TEN2          | RW   | 1: Trigger of DAC channel2 enabled. The data written into the       | 0 |
|                    |               |      | DAC_xDHR register is sent to the DAC_DOR2 register in 3 PB1         |   |
|                    |               |      | clock cycles.                                                       |   |
|                    |               |      | Note: If software trigger is selected, the data in DAC xDHR only    |   |
|                    |               |      | needs to be sent to the DAC_DOR2 register in an PB1 clock cycle.    |   |
|                    |               |      | DAC channel2 output buffer disable control (recommended to be       |   |
|                    |               |      | enabled):                                                           |   |
| 17                 | BOFF2         | RW   | 0: DAC channel2 output buffer enabled;                              | 0 |
|                    |               |      | 1: DAC channel2 output buffer disabled.                             |   |
|                    |               |      | DAC channel2 enable:                                                |   |
| 16                 | EN2           | RW   | 0: DAC channel2 disabled;                                           | 0 |
|                    |               |      | 1: DAC channel2 enabled.                                            |   |
| [15:13]            | Reserved      | RO   | Reserved.                                                           | 0 |
|                    |               |      | DMA enable of DAC channel1:                                         |   |
| 12                 | DMAEN1        | RW   | 0: DMA function of DAC channel1 disabled;                           | 0 |
|                    |               |      | 1: DMA function of DAC channel1 enabled.                            |   |
|                    |               |      | DAC channel 1 mask/amplitude setting. The software sets these       |   |
|                    |               |      | bits to select the LFSR data mask bit in the noise generation mode, |   |
|                    |               |      | and select the wave amplitude in the triangle waveform generation   |   |
|                    |               |      | mode:                                                               |   |
|                    | N ( A 3 4 D 1 |      | 0000: Unmask bit0 of LFSR / Triangle amplitude equal to 1;          |   |
| [11:8]             | MAMP1         | RW   | 0001: Unmask bits[1:0] of LFSR / Triangle amplitude equal to 3;     | 0 |
| -                  | [3:0]         |      | 0010: Unmask bits[2:0] of LFSR / Triangle amplitude equal to 7;     |   |
|                    |               |      | 0011: Unmask bits[3:0] of LFSR / Triangle amplitude equal to 15;    |   |
|                    |               |      | 0100: Unmask bits[4:0] of LFSR / Triangle amplitude equal to 31;    |   |
|                    |               |      | 0101: Unmask bits[5:0] of LFSR / Triangle amplitude equal to 63;    |   |
|                    |               |      |                                                                     |   |

V2. 4 277 WCH°

|       |                |    | 0111: Unmask bits[7:0] of LFSR / Triangle amplitude equal to 255; 1000: Unmask bits[8:0] of LFSR / Triangle amplitude equal to 511; 1001: Unmask bits[9:0] of LFSR / Triangle amplitude equal to 1023; 1010: Unmask bits[10:0] of LFSR / Triangle amplitude equal to 2047; ≥1011: Unmask bits[11:0] of LFSR / Triangle amplitude equal to 4095.  Noise/triangular-wave generation enable of DAC channel1.                                                          |   |
|-------|----------------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| [7:6] | WAVE1<br>[1:0] | RW | <ul><li>00: Wave generator disabled;</li><li>01: Noise wave generator enabled;</li><li>1x: Triangular wave generator enabled.</li></ul>                                                                                                                                                                                                                                                                                                                            | 0 |
| [5:3] | TSEL1<br>[2:0] | RW | Trigger event selection of DAC channel1:  000: TIM6 TRGO event;  001: TIM8 TRGO event;  010: TIM7 TRGO event;  011: TIM5 TRGO event;  100: TIM2 TRGO event;  101: TIM4 TRGO event;  111: Software trigger;  Others: Reserved.                                                                                                                                                                                                                                      | 0 |
| 2     | TEN1           | RW | External trigger mode enable of DAC channel1:  0: Trigger of DAC channel1 disabled. The data written into the DAC_xDHR register is sent to the DAC_DOR1 register in 1 PB1 clock cycle.  1: Trigger of DAC channel1 enabled. The data written into the DAC_xDHR register is sent to the DAC_DOR1 register in 3 PB1 clock cycles.  Note: If software trigger is selected, the data in DAC_xDHR only needs to be sent to the DAC_DOR1 register in an PB1 clock cycle. | 0 |
| 1     | BOFF1          | RW | DAC channel1 output buffer disable control (Recommended to be enabled):  0: DAC channel1 output buffer enabled;  1: DAC channel1 output buffer disabled.                                                                                                                                                                                                                                                                                                           | 0 |
| 0     | EN1            | RW | DAC channel1 enable: 0: DAC channel1 disabled; 1: DAC channel1 enabled.                                                                                                                                                                                                                                                                                                                                                                                            | 0 |

# 17.4.2 DAC Software Trigger Register (DAC\_SWTR)

| 31 | 30       | 29 | 28 | 27 | 26 | 25 | 24   | 23    | 22 | 21 | 20              | 19              | 18 | 17 | 16 |
|----|----------|----|----|----|----|----|------|-------|----|----|-----------------|-----------------|----|----|----|
|    |          |    |    |    |    |    | Rese | erved |    |    |                 |                 |    |    |    |
| 15 | 14       | 13 | 12 | 11 | 10 | 9  | 8    | 7     | 6  | 5  | 4               | 3               | 2  | 1  | 0  |
|    | Reserved |    |    |    |    |    |      |       |    |    | SW<br>TRIG<br>2 | SW<br>TRIG<br>1 |    |    |    |

| Bit    | Name                | Access | Description                                    | Reset value |
|--------|---------------------|--------|------------------------------------------------|-------------|
| [31:2] | Reserved            | RO     | Reserved.                                      | 0           |
|        |                     |        | Software trigger control bit of DAC channel2:  |             |
|        |                     |        | 0: Software trigger of DAC channel2 disabled;  |             |
| 1      | SWTRIG2             | WO     | 1: Software trigger of DAC channel2 enabled.   | 0           |
| 1      | 5 W 1141 5 <b>2</b> | ,,,    | Note: Once the data in DAC_xDHR (After 1 PB1   | Ü           |
|        |                     |        | clock cycle) is sent to the DAC_DOR2 register, |             |
|        |                     |        | this bit can be cleared by hardware.           |             |
|        |                     |        | Software trigger control bit of DAC channel1:  |             |
|        |                     |        | 0: Software trigger of DAC channel1 disabled;  |             |
|        | SWTRIG1             | WO     | 1: Software trigger of DAC channel1 enabled.   | 0           |
| 0      | SWIRIGI             | WO     | Note: Once the data in DAC_xDHR (After 1 PB1   | U           |
|        |                     |        | clock cycle) is sent to the DAC_DOR1 register, |             |
|        |                     |        | this bit can be cleared by hardware.           |             |

# 17.4.3 DAC Channel 1 Right-aligned 12-bit Data Hold Register (DAC\_R12BDHR1)

Offset address: 0x08

| 31 | 30       | 29 | 28 | 27 | 26 | 25 | 24   | 23    | 22    | 21    | 20  | 19 | 18 | 17 | 16 |
|----|----------|----|----|----|----|----|------|-------|-------|-------|-----|----|----|----|----|
|    |          | -  |    | -  |    |    | Rese | erved |       | -     |     |    |    | -  |    |
| 15 | 14       | 13 | 12 | 11 | 10 | 9  | 8    | 7     | 6     | 5     | 4   | 3  | 2  | 1  | 0  |
|    | Reserved |    |    |    |    |    |      | DA    | ACC1D | HR[11 | :0] |    | _  |    |    |

| Bit     | Name           | Access | Description                                | Reset value |
|---------|----------------|--------|--------------------------------------------|-------------|
| [31:12] | Reserved       | RO     | Reserved.                                  | 0           |
| [11:0]  | DACC1DHR[11:0] | RW     | 12-bit right-aligned data of DAC channel1. | 0           |

# 17.4.4 DAC Channel 1 Left-aligned 12-bit Data Hold Register (DAC\_L12BDHR1)

Offset address: 0x0C

| 31             | 30       | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19    | 18  | 17 | 16 |
|----------------|----------|----|----|----|----|----|----|----|----|----|----|-------|-----|----|----|
|                | Reserved |    |    |    |    |    |    |    |    |    |    |       |     |    |    |
| 15             | 14       | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3     | 2   | 1  | 0  |
| DACC1DHR[11:0] |          |    |    |    |    |    |    |    |    |    |    | Reser | ved |    |    |

| Bit     | Name           | Access | Description                               | Reset value |
|---------|----------------|--------|-------------------------------------------|-------------|
| [31:16] | Reserved       | RO     | Reserved.                                 | 0           |
| [15:4]  | DACC1DHR[11:0] | RW     | 12-bit left-aligned data of DAC channel1. | 0           |
| [3:0]   | Reserved       | RO     | Reserved.                                 | 0           |

# 17.4.5 DAC Channel 1 Right-aligned 8-bit Data Hold Register (DAC\_R8BDHR1)

Offset address: 0x10

|    |          |    |    |    |    |   | Rese | rved |   |    |       |       |     |   |   |
|----|----------|----|----|----|----|---|------|------|---|----|-------|-------|-----|---|---|
| 15 | 14       | 13 | 12 | 11 | 10 | 9 | 8    | 7    | 6 | 5  | 4     | 3     | 2   | 1 | 0 |
|    | Reserved |    |    |    |    |   |      |      |   | D. | ACC1I | DHR[7 | :0] |   |   |

| Bit    | Name          | Access | Description                                | Reset value |
|--------|---------------|--------|--------------------------------------------|-------------|
| [31:8] | Reserved      | RO     | Reserved                                   | 0           |
| [7:0]  | DACC1DHR[7:0] | RW     | 8-bit right-aligned data of DAC channel 1. | 0           |

# 17.4.6 DAC Channel 2 Right-aligned 12-bit Data Hold Register (DAC\_R12BDHR2)

Offset address: 0x14

| 31 | 30       | 29 | 28 | 27 | 26 | 25 | 24   | 23    | 22    | 21    | 20  | 19 | 18 | 17 | 16 |
|----|----------|----|----|----|----|----|------|-------|-------|-------|-----|----|----|----|----|
|    |          | -  | _  |    | -  | _  | Rese | erved |       | -     |     | -  |    | _  |    |
| 15 | 14       | 13 | 12 | 11 | 10 | 9  | 8    | 7     | 6     | 5     | 4   | 3  | 2  | 1  | 0  |
|    | Reserved |    |    |    |    |    |      | D     | ACC2E | HR[11 | :0] |    |    |    |    |

| Bit     | Name           | Access | Description                                 | Reset value |
|---------|----------------|--------|---------------------------------------------|-------------|
| [31:12] | Reserved       | RO     | Reserved                                    | 0           |
| [11:0]  | DACC2DHR[11:0] | RW     | 12-bit right-aligned data of DAC channel 2. | 0           |

# 17.4.7 DAC Channel 2 Left-aligned 12-bit Data Hold Register (DAC\_L12BDHR2)

Offset address: 0x18

| 31 | 30             | 29 | 28 | 27 | 26 | 25 | 24   | 23    | 22 | 21 | 20 | 19 | 18    | 17  | 16 |
|----|----------------|----|----|----|----|----|------|-------|----|----|----|----|-------|-----|----|
|    |                |    |    |    |    |    | Rese | erved |    |    |    |    |       |     |    |
| 15 | 14             | 13 | 12 | 11 | 10 | 9  | 8    | 7     | 6  | 5  | 4  | 3  | 2     | 1   | 0  |
|    | DACC2DHR[11:0] |    |    |    |    |    |      |       |    |    |    |    | Reser | ved |    |

| Bit     | Name           | Access | Description                               | Reset value |
|---------|----------------|--------|-------------------------------------------|-------------|
| [31:16] | Reserved       | RO     | Reserved                                  | 0           |
| [15:4]  | DACC2DHR[11:0] | RW     | 12-bit left-aligned data of DAC channel2. | 0           |
| [3:0]   | Reserved       | RO     | Reserved                                  | 0           |

# 17.4.8 DAC Channel 2 Right-aligned 8-bit Data Hold Register (DAC\_R8BDHR2)

| 31 | 30 | 29 | 28   | 27    | 26 | 25 | 24   | 23    | 22 | 21 | 20    | 19    | 18  | 17 | 16 |
|----|----|----|------|-------|----|----|------|-------|----|----|-------|-------|-----|----|----|
|    |    |    |      |       |    |    | Rese | erved |    |    |       |       |     | -  |    |
| 15 | 14 | 13 | 12   | 11    | 10 | 9  | 8    | 7     | 6  | 5  | 4     | 3     | 2   | 1  | 0  |
|    |    |    | Rese | erved |    |    |      |       |    | D  | ACC2I | DHR[7 | :0] |    |    |

| Bit    | Name          | Access | Description                               | Reset value |
|--------|---------------|--------|-------------------------------------------|-------------|
| [31:8] | Reserved      | RO     | Reserved                                  | 0           |
| [7:0]  | DACC2DHR[7:0] | RW     | 8-bit right-aligned data of DAC channel2. | 0           |

# 17.4.9 DAC Dual Channel Right-aligned 12-bit Data Hold Register (DAC\_RD12BDHR)

Offset address: 0x20

| 31 | 30   | 29    | 28 | 27 | 26 | 25 | 24 | 23 | 22    | 21    | 20  | 19 | 18 | 17 | 16 |
|----|------|-------|----|----|----|----|----|----|-------|-------|-----|----|----|----|----|
|    | Rese | rved  |    |    |    |    |    | DA | ACC2D | HR[11 | :0] |    |    |    |    |
| 15 | 14   | 13    | 12 | 11 | 10 | 9  | 8  | 7  | 6     | 5     | 4   | 3  | 2  | 1  | 0  |
|    | Rese | erved |    |    |    |    |    | DA | ACC1D | HR[11 | :0] |    |    |    |    |

| Bit     | Name           | Access | Description                                 | Reset value |
|---------|----------------|--------|---------------------------------------------|-------------|
| [31:28] | Reserved       | RO     | Reserved                                    | 0           |
| [27:16] | DACC2DHR[11:0] | RW     | 12-bit right-aligned data of DAC channel 2. | 0           |
| [15:12] | Reserved       | RO     | Reserved                                    | 0           |
| [11:0]  | DACC1DHR[11:0] | RW     | 12-bit right-aligned data of DAC channel 1. | 0           |

# 17.4.10 DAC Dual Channel Left-aligned 12-bit Data Hold Register (DAC\_LD12BDHR)

Offset address: 0x24

| 31 | 30             | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18   | 17    | 16 |
|----|----------------|----|----|----|----|----|----|----|----|----|----|----|------|-------|----|
|    | DACC2DHR[11:0] |    |    |    |    |    |    |    |    |    |    |    | Rese | erved |    |
| 15 | 14             | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2    | 1     | 0  |
|    | DACC1DHR[11:0] |    |    |    |    |    |    |    |    |    |    |    | Rese | erved |    |

| Bit     | Name           | Access | Description                                | Reset<br>value |
|---------|----------------|--------|--------------------------------------------|----------------|
| [31:20] | DACC2DHR[11:0] | RW     | 12-bit left-aligned data of DAC channel 2. | 0              |
| [19:16] | Reserved       | RO     | Reserved                                   | 0              |
| [15:4]  | DACC1DHR[11:0] | RW     | 12-bit left-aligned data of DAC channel 1. | 0              |
| [3:0]   | Reserved       | RO     | Reserved                                   | 0              |

# 17.4.11 DAC Dual Channel Right-aligned 8-bit Data Hold Register (DAC\_RD8BDHR)

| 31 | 30 | 29 | 28    | 27    | 26  | 25 | 24   | 23    | 22 | 21 | 20    | 19    | 18  | 17 | 16 |
|----|----|----|-------|-------|-----|----|------|-------|----|----|-------|-------|-----|----|----|
|    |    |    |       |       |     |    | Rese | erved |    |    |       |       |     |    |    |
| 15 | 14 | 13 | 12    | 11    | 10  | 9  | 8    | 7     | 6  | 5  | 4     | 3     | 2   | 1  | 0  |
|    | ·  | D. | ACC2I | OHR[7 | :0] |    |      |       |    | D  | ACC1I | DHR[7 | :0] | ·  |    |

| Bit     | Name          | Access | Description                                | Reset value |
|---------|---------------|--------|--------------------------------------------|-------------|
| [31:16] | Reserved      | RO     | Reserved                                   | 0           |
| [15:8]  | DACC2DHR[7:0] | RW     | 8-bit right-aligned data of DAC channel 2. | 0           |
| [7:0]   | DACC1DHR[7:0] | RW     | 8-bit right-aligned data of DAC channel 1. | 0           |

# 17.4.12 DAC Channel 1 Data Output Register (DAC\_DOR1)

Offset address: 0x2C

| 31 | 30   | 29    | 28 | 27 | 26 | 25 | 24   | 23    | 22    | 21    | 20  | 19 | 18 | 17 | 16 |
|----|------|-------|----|----|----|----|------|-------|-------|-------|-----|----|----|----|----|
|    |      |       |    |    |    |    | Rese | erved |       |       |     |    |    |    |    |
| 15 | 14   | 13    | 12 | 11 | 10 | 9  | 8    | 7     | 6     | 5     | 4   | 3  | 2  | 1  | 0  |
|    | Rese | erved |    |    |    |    |      | DA    | ACC1D | OR[11 | :0] |    |    |    |    |

| Bit     | Name           | Access | Description                  | Reset value |
|---------|----------------|--------|------------------------------|-------------|
| [31:12] | Reserved       | RO     | Reserved.                    | 0           |
| [11:0]  | DACC1DOR[11:0] | RO     | Output data of DAC channel 1 | 0           |

# 17.4.13 DAC Channel 2 Data Output Register (DAC\_DOR2)

| 31 | 30       | 29 | 28 | 27 | 26             | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----------|----|----|----|----------------|----|----|----|----|----|----|----|----|----|----|
|    | Reserved |    |    |    |                |    |    |    |    |    |    |    |    |    |    |
| 15 | 14       | 13 | 12 | 11 | 10             | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    | Reserved |    |    |    | DACC2DOR[11:0] |    |    |    |    |    |    |    |    |    |    |

| Bit     | Name           | Access | Description                  | Reset value |  |
|---------|----------------|--------|------------------------------|-------------|--|
| [31:12] | Reserved       | RO     | Reserved.                    | 0           |  |
| [11:0]  | DACC2DOR[11:0] | RO     | Output data of DAC channel 2 | 0           |  |

# Chapter 18 Universal Synchronous Asynchronous Receiver Transmitter (USART)

This chapter applies to the whole family of CH32F20x, CH32V20x, CH32V30x and CH32V31x.

This module contains 3 Universal Synchronous Asynchronous Receiver Transmitters (USART1/2/3) and 5 Universal Asynchronous Receiver Transmitter (UART4/5/6/7/8).

Note: For CH32V203C8, CH32F203C8, the serial port 4 is a universal synchronous asynchronous receiver transmitter (USART4).

#### 18.1 Main Features

- Full-duplex or half-duplex synchronous or asynchronous communication
- NRZ data format
- Fractional baud rate generator, up to 9 Mbps
- Programmable data word length
- Configurable stop bits
- Supports LIN, IrDA encoder, smart card
- Supports DMA
- Multiple interrupt sources

#### 18.2 Overview

**PWDATA PRDATA** Write (CPU or DMA) (DATA REGISTER) DATAR (CPU or DMA) Transmit Data Register Receive Data Register TX IrDA RX **Transmit Shift Register** Receive Shift Register ENDEC RIOCK SW RX (Connect with RX Internally) **GPR** CK CONTROL ->- ἀακ GI **CTLR3** CTLR2 DMAT DMAR SCEN NACK HD | IRLP | IREN |LINE STOP[1:0] CKEN | CPOL | CPHA LBCL CTLR2 **USART Address** UE M WAKE PCE PS PEIE Harriwar flow controlle RECEIVER WAKE RECEIVER CLOCK TRANSMIT CONTROL CONTROL UNIT TXEIE TOE RXNE IDLE CTS LBD TXE TC RXNE IDLE ORE NE FE PE ΤE RE RWU SBK **USART** INTERRUPT CONTROL USART BRR

Figure 18-1 USART block diagram

When TE (Transmission enable bit) is set, the data in the transmitter shift register will be outputted on the TX pin, and the clock will be outputted on the CK pin. During transmission, the lowest significant bit is the first to be shifted out. Each data frame starts with a low-level start bit, and then the transmitter sends 8-bit data or 9-bit data according to the setting of the M (Word length) bit, and finally a configurable number of stop bits. If there is a parity check bit, the last bit of the data word is the check bit. After TE is set, an idle frame is sent. The idle frame is 10-bit or 11-bit high level, including the stop bit. The break frame is a 10-bit or 11-bit low level, followed by a stop bit.

#### 18.3 Baud Rate Generator

The baud rate of the transceiver =  $F_{CLK}/(16*USARTDIV)$ ;  $F_{CLK}$  is the clock of PBx, i.e., PCLK1 or PCLK2, PCLK2 is used for the USART1 module, and PCLK1 shall be used for the rest. The value of USARTDIV is

determined according to the 2 domains: DIV\_M and DIV\_F in USART\_BRR. The specific calculation formula is:

$$USARTDIV = DIV M+(DIV F/16)$$

It should be noted that the baud rate generated by the baud rate generator may not precisely match the user's required value, as deviations may occur. Besides selecting the closest value, another method to reduce deviation is to increase the PBx clock. For example, when setting the baud rate to 9600 bps, setting USARTDIV to 78.125 yields 9600 bps at 12 MHz. However, if you require a baud rate of 115200 bps, the calculated USARTDIV is 6.51. but the closest value that can be entered into USART\_BRR is 6.5. The actual generated baud rate is 115384bps, resulting in an error of 0.16%.

When the serial port waveform sent by the transmitter is transmitted to the receiver, there is a certain error in the baud rate between the receiver and the sender. The error mainly comes from 3 aspects: the actual baud rate of the receiver and the sender are inconsistent; the clocks of the receiver and the sender have errors; the waveform changes in the circuit. The receiver of the peripheral module has a certain tolerance for receiving. When the sum of the total deviations generated in the above 3 aspects is less than the tolerance limit of the module, the total deviation will not affect the receiving and sending. The tolerance limit of the module is affected by the use of fractional baud rate and M bit (Data field word length) or not. The use of fractional baud rate and the use of 9-bit data field length will reduce the tolerance limit, but it shall not be less than 3%.

## 18.4 Synchronous Mode

The synchronous mode enables the system to output clock signals when the USART module is used. When the synchronous mode is enabled to send data externally, the CK pin will output clock externally at the same time.

To enable synchronous mode, set CLKEN bit in the control register2 (R16\_USARTx\_CTLR2), but you need to switch off the LIN mode, smart card mode, infrared mode and half-duplex mode at the same time, i.e., to ensure that the SCEN, HDSEL and IREN bits are in the reset status. These 3 bits are in the control register3 (R16\_USARTx\_CTLR3).

The main point of the synchronous mode is the output control of the clock. Attention shall be paid to the following:

- 1) The synchronous mode of the USART module only works in the master mode, i.e., the CK pin only outputs the clock and does not receive input;
- 2) The clock signal is outputted only when TX pin outputs data;
- 3) The LBCL bit determines whether the clock is outputted when the last data bit is sent. The CPOL bit determines the polarity of the clock, and the CPHA determines the phase position of the clock. These 3 bits are in the control register 2 (R16\_USARTx\_CTLR2). These 3 bits need to be set when TE and RE are not enabled. The specific difference is shown in Figure 18-2.
- 4) In the synchronous mode, the receiver will only sample when outputting the clock, and the slave needs to maintain a certain signal setup time and hold time, specifically as shown in Figure 18-3.



Figure 18-2 Example of USART clock timing (M=0)

Figure 18-3 Data sample hold time



#### $t_{SETUP} = t_{HOLD}$ 1/16 bit time

## 18.5 1-wire Half-duplex Mode

The half-duplex mode supports the use of a single pin (Only TX pin) to receive and transmit, and the TX pin and RX pin are connected inside the chip.

To enable half-duplex mode, set HDSEL bit in the control register3 (R16\_USARTx\_CTLR3), but you need to disable LIN mode, smartcard mode, infrared mode and synchronous mode at the same time, i.e., to ensure that the SCEN, CLKEN and IREN bits are in the reset status. These 3 bits are in the control register2 and the control register3 (R16\_USARTx\_CTLR2 and R16\_USARTx\_CTLR3).

After setting to half-duplex mode, it is needed to set the TX IO port to open-drain output high mode. When TE bit is set, the data will be sent out as long as the data is written to the data register. Special attention shall be paid to the fact that bus conflicts may occur when multiple devices use a single bus to transmit and receive in half-duplex mode. This requires users to avoid it by software.

#### 18.6 Smartcard

The smartcard mode supports ISO7816-3 protocol to access the smart card controller.

To enable smartcard mode, set the SCEN bit in the control register3 (R16 USARTx CTLR3), but it is needed

to disable LIN mode, half-duplex mode and infrared mode at the same time, i.e., to ensure that the LINEN, HDSEL and IREN bits are in the reset status, but CLKEN can be switched on to output the clock. These 3 bits are in the control register2 and the control register3 (R16\_USARTx\_CTLR2 and R16\_USARTx\_CTLR3). In order to support smartcard mode, USART shall be set to 8 data bits plus 1 check bit. It is recommended that the stop bit be configured to 1.5 bits for both transmitting and receiving. The smart card mode is a 1-wire half-duplex protocol, which uses TX line as the data communication and shall be configured as open drain output plus pull-up. When the receiver receives a frame of data and detects a parity check error, it will send a NACK signal at the stop bit, i.e., actively reducing a cycle of TX during the stop bit. After the sender detects the NACK signal, a frame error will be generated, and the application can resend accordingly. Figure 17-4 shows the waveforms on the TX pin under correct conditions and in the event of parity check errors. The TC flag (transmission completion flag) of the USART can delay the generation of GT (protection time) clocks, and the receiver will not recognize the NACK signal set by itself as the start bit.

Without Parity error **Guard time** S 2 3 4 5 6 7 Ρ Start bit With Parity error Guard time S 0 1 2 3 4 5 6 7 Ρ Line pulled low Start by receiver during stop in bit case of parity error

Figure 18-4 (No) parity check error

In smartcard mode, the output waveform after the CK pin is enabled has nothing to do with the communication. It only provides the clock for the smart card. Its value is the PB clock and then the 5-bit settable clock frequency division (the frequency division value is double of PSC, and the highest is frequency division 62).

#### 18.7 IrDA

USART module supports control IrDA infrared transceiver for physical layer communication. To use IrDA, the LINEN, STOP, CLKEN, SCEN and HDSEL bits must be cleared. NRZ (Non-return-to-zero) coding is used between the USART module and the SIR physical layer (Infrared transceiver), and the maximum support rate is 115200bps.

IrDA is a half-duplex protocol. If UASRT sends data to the SIR physical layer, the IrDA decoder ignores the newly sent infrared signal. If the USART receives data from SIR, then SIR does not accept USART signal. The level logic sent by USART to SIR and SIR to USART is different. In SIR receive logic, '1' represents high level and '0' represents low level. However, in the SIR transmit logic, '0' represents high level and '1' represents low level.

#### 18.8 DMA

The USART module supports DMA, and can use DMA to implement fast continuous reception and transmission. When DMA is enabled and the TXE bit is set, DMA writes data to the transmit buffer from the set memory space. When DMA is used for reception, DMA transfers the data in the receive buffer to a specific memory space each time the RXNE bit is set.

## 18.9 Interrupt

The USART module supports multiple interrupt sources, including transmit data register empty (TXE), CTS, transmission complete (TC), received data ready (RXNE), data overrun error (ORE), idle line (IDLE), parity check error (PE), break flag (LBD), noise (NE), multi-buffer communication overrun (ORT) and framing error (FE).

| Interrupt source                                  | Enable bit |  |  |
|---------------------------------------------------|------------|--|--|
| Transmit data register empty (TXE)                | TXEIE      |  |  |
| Transmission allowed (CTS)                        | CTSIE      |  |  |
| Transmission complete (TC)                        | TCIE       |  |  |
| Received data ready (RXNE)                        | RXNEIE     |  |  |
| Overrun error detected (ORE)                      | KAINEIE    |  |  |
| Idle line (IDLE)                                  | IDLEIE     |  |  |
| Parity error (PE)                                 | PEIE       |  |  |
| Break flag (LBD)                                  | LBDIE      |  |  |
| Noise (NE)                                        |            |  |  |
| Overrun error in multi-buffer communication (ORT) | EIE        |  |  |
| Framing error (FE) in multi-buffer communication  |            |  |  |

Table 18-1 Interrupts and the corresponding enable bits

# 18.10 Register Description

Table 18-2 USART1 registers

| Name             | Access address | Description                              | Reset value |
|------------------|----------------|------------------------------------------|-------------|
| R32 USART1 STATR | 0x40013800     | UASRT1 status register                   | 0x000000C0  |
| R32 USART1 DATAR | 0x40013804     | UASRT1 data register                     | 0x00000000  |
| R32_USART1_BRR   | 0x40013808     | UASRT1 baud rate register                | 0x00000000  |
| R32_USART1_CTLR1 | 0x4001380C     | UASRT1 control register 1                | 0x00000000  |
| R32_USART1_CTLR2 | 0x40013810     | UASRT1 control register 2                | 0x00000000  |
| R32_USART1_CTLR3 | 0x40013814     | UASRT1 control register 3                | 0x00000000  |
| R32_USART1_GPR   | 0x40013818     | UASRT1 guard time and prescaler register | 0x00000000  |
| R32_USART1_CTRL4 | 0x4001381C     | UASRT1 control register 4                | 0x00000000  |

Table 18-3 USART2 registers

| Name             | Access address | Description                              | Reset value |
|------------------|----------------|------------------------------------------|-------------|
| R32_USART2_STATR | 0x40004400     | UASRT2 status register                   | 0x000000C0  |
| R32_USART2_DATAR | 0x40004404     | UASRT2 data register                     | 0x00000000  |
| R32_USART2_BRR   | 0x40004408     | UASRT2 baud rate register                | 0x00000000  |
| R32_USART2_CTLR1 | 0x4000440C     | UASRT2 control register 1                | 0x00000000  |
| R32_USART2_CTLR2 | 0x40004410     | UASRT2 control register 2                | 0x00000000  |
| R32_USART2_CTLR3 | 0x40004414     | UASRT2 control register 3                | 0x00000000  |
| R32_USART2_GPR   | 0x40004418     | UASRT2 guard time and prescaler register | 0x00000000  |
| R32_USART2_CTRL4 | 0x4000441C     | UASRT2 control register 4                | 0x00000000  |

## Table 18-4 USART3 registers

| Name             | Access address | Description                              | Reset value |
|------------------|----------------|------------------------------------------|-------------|
| R32_USART3_STATR | 0x40004800     | UASRT3 status register                   | 0x000000C0  |
| R32_USART3_DATAR | 0x40004804     | UASRT3 data register                     | 0x00000000  |
| R32_USART3_BRR   | 0x40004808     | UASRT3 baud rate register                | 0x00000000  |
| R32_USART3_CTLR1 | 0x4000480C     | UASRT3 control register1                 | 0x00000000  |
| R32_USART3_CTLR2 | 0x40004810     | UASRT3 control register2                 | 0x00000000  |
| R32_USART3_CTLR3 | 0x40004814     | UASRT3 control register3                 | 0x00000000  |
| R32_USART3_GPR   | 0x40004818     | UASRT3 guard time and prescaler register | 0x00000000  |
| R32_USART3_CTRL4 | 0x4000481C     | UASRT3 control register 4                | 0x00000000  |

## Table 18-5 USART4 registers

| Name             | Access address | Description                              | Reset value |
|------------------|----------------|------------------------------------------|-------------|
| R32_USART4_STATR | 0x40004C00     | USART4 status register                   | 0x000000C0  |
| R32_USART4_DATAR | 0x40004C04     | USART4 data register                     | 0x00000000  |
| R32_USART4_BRR   | 0x40004C08     | USART4 baud rate register                | 0x00000000  |
| R32_USART4_CTLR1 | 0x40004C0C     | USART4 control register1                 | 0x00000000  |
| R32_USART4_CTLR2 | 0x40004C10     | USART4 control register2                 | 0x00000000  |
| R32_USART4_CTLR3 | 0x40004C14     | USART4 control register3                 | 0x00000000  |
| R32_USART4_GPR   | 0x40004C18     | USART4 guard time and prescaler register | 0x00000000  |
| R32_USART4_CTRL4 | 0x40004C1C     | UASRT4 control register 4                | 0x00000000  |

## Table 18-6 USART5 registers

| Name             | Access address | Description                              | Reset value |
|------------------|----------------|------------------------------------------|-------------|
| R32_USART5_STATR | 0x40005000     | USART5 status register                   | 0x000000C0  |
| R32_USART5_DATAR | 0x40005004     | USART5 data register                     | 0x00000000  |
| R32_USART5_BRR   | 0x40005008     | USART5 baud rate register                | 0x00000000  |
| R32_USART5_CTLR1 | 0x4000500C     | USART5 control register1                 | 0x00000000  |
| R32_USART5_CTLR2 | 0x40005010     | USART5 control register2                 | 0x00000000  |
| R32_USART5_CTLR3 | 0x40005014     | USART5 control register3                 | 0x00000000  |
| R32_USART5_GPR   | 0x40005018     | USART5 guard time and prescaler register | 0x00000000  |
| R32_USART5_CTRL4 | 0x4000501C     | UASRT5 control register 4                | 0x00000000  |

## Table 18-7 USART6 registers

| Name             | Access address | Description                              | Reset value |
|------------------|----------------|------------------------------------------|-------------|
| R32_USART6_STATR | 0x40001800     | USART6 status register                   | 0x000000C0  |
| R32_USART6_DATAR | 0x40001804     | USART6 data register                     | 0x00000000  |
| R32_USART6_BRR   | 0x40001808     | USART6 baud rate register                | 0x00000000  |
| R32_USART6_CTLR1 | 0x4000180C     | USART6 control register1                 | 0x00000000  |
| R32_USART6_CTLR2 | 0x40001810     | USART6 control register2                 | 0x00000000  |
| R32_USART6_CTLR3 | 0x40001814     | USART6 control register3                 | 0x00000000  |
| R32_USART6_GPR   | 0x40001818     | USART6 guard time and prescaler register | 0x00000000  |
| R32_USART6_CTRL4 | 0x4000181C     | UASRT6 control register 4                | 0x00000000  |

## Table 18-8 USART7 registers

| Name Access address | Description | Reset value |
|---------------------|-------------|-------------|
|---------------------|-------------|-------------|

| R32_USART7_STATR | 0x40001C00 | USART7 status register                   | 0x000000C0 |
|------------------|------------|------------------------------------------|------------|
| R32_USART7_DATAR | 0x40001C04 | USART7 data register                     | 0x00000000 |
| R32_USART7_BRR   | 0x40001C08 | USART7 baud rate register                | 0x00000000 |
| R32_USART7_CTLR1 | 0x40001C0C | USART7 control register1                 | 0x00000000 |
| R32_USART7_CTLR2 | 0x40001C10 | USART7 control register2                 | 0x00000000 |
| R32_USART7_CTLR3 | 0x40001C14 | USART7 control register3                 | 0x00000000 |
| R32_USART7_GPR   | 0x40001C18 | USART7 guard time and prescaler register | 0x00000000 |
| R32_USART7_CTRL4 | 0x40001C1C | UASRT7 control register 4                | 0x00000000 |

## Table 18-9 USART8 registers

| Name              | Access address | Description                              | Reset value |
|-------------------|----------------|------------------------------------------|-------------|
| R32_USART8_STATR  | 0x40002000     | USART8 status register                   | 0x000000C0  |
| R32_USSART8_DATAR | 0x40002004     | USART8 data register                     | 0x00000000  |
| R32_UART8_BRR     | 0x40002008     | USART8 baud rate register                | 0x00000000  |
| R32_USART8_CTLR1  | 0x4000200C     | USART8 control register1                 | 0x00000000  |
| R32_USART8_CTLR2  | 0x40002010     | USART8 control register2                 | 0x00000000  |
| R32_USART8_CTLR3  | 0x40002014     | USART8 control register3                 | 0x00000000  |
| R32_USART8_GPR    | 0x40002018     | USART8 guard time and prescaler register | 0x00000000  |
| R32_USART8_CTRL4  | 0x4000201C     | UASRT8 control register 4                | 0x00000000  |

## 18.10.1 USART Status Register (USARTx\_STATR) (x=1/2/3/4/5/6/7/8)

| 31 | 30  | 29    | 28 | 27         | 26              | 25  | 24   | 23   | 22 | 21       | 20   | 19  | 18 | 17 | 16 |
|----|-----|-------|----|------------|-----------------|-----|------|------|----|----------|------|-----|----|----|----|
| ,  |     |       |    |            |                 | ,   | Rese | rved | ,  |          | ,    | ,   | ,  |    |    |
| 15 | 14  | 13    | 12 | 11         | 10              | 9   | 8    | 7    | 6  | 5        | 4    | 3   | 2  | 1  | 0  |
|    | Res | erved |    | MS_<br>ERR | RX_<br>BUS<br>Y | CTS | LBD  | TXE  | TC | RXN<br>E | IDLE | ORE | NE | FE | PE |

| Bit     | Name     | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Reset value |
|---------|----------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:12] | Reserved | RO     | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0           |
| 11      | MS_ERR   | RO     | MARK or SPACE checksum error flag. In receive mode, hardware sets this bit if a MARK or SPACE checksum error is generated. An operation that reads this bit and then reads the data register resets this bit. If MS_ERRIE was previously set, then this bit being set generates the appropriate interrupt.  Note: Only applicable to CH32F20x_D8, CH32F20x_D8C, CH32V30x_D8C, CH32V30x_D8C, and CH32V31x_D8C products with the penultimate sixth digit of the lot number not being zero. | 0           |
| 10      | RX_BUSY  | RO     | Receive status indication bit:  0: In non-reception state;                                                                                                                                                                                                                                                                                                                                                                                                                               | 0           |

|   |       |         | 1: This bit when working in receiving state.            |   |
|---|-------|---------|---------------------------------------------------------|---|
|   |       |         | Note: Only applicable to CH32F20x_D8,                   |   |
|   |       |         | $CH32F20x\_D8C$ , $CH32V30x\_D8$ ,                      |   |
|   |       |         | CH32V30x_D8C, and CH32V31x_D8C products                 |   |
|   |       |         | with the penultimate sixth digit of the lot number      |   |
|   |       |         | not being zero.                                         |   |
|   |       |         | CTS status change flag. If the CTSE bit is set, this    |   |
|   |       |         | bit will be set high by hardware when the nCTS          |   |
|   |       |         | output status changes. It is cleared by the software.   |   |
| 9 | CTS   | RW0     | If the CTSIE bit has been set, an interrupt is          | 0 |
|   |       |         | generated.                                              |   |
|   |       |         | 0: No change on the nCTS status line;                   |   |
|   |       |         | 1: A change on the nCTS status line.                    |   |
|   |       |         | LIN Break detection flag. When LIN Break is             |   |
|   |       |         | detected, this bit will be set by hardware. It is       |   |
| 8 | LBD   | RW0     | cleared by the software. If the LBDIE bit has been      | 0 |
|   | LDD   | KWO     | set, an interrupt will be generated.                    | O |
|   |       |         | 0: No LIN Break detected;                               |   |
|   |       |         | 1: LIN Break detected.                                  |   |
|   |       |         | Transmission data register empty flag. When data        |   |
|   |       |         | in TDR register is transferred to shift register by     |   |
|   |       |         | hardware, this bit will be set by hardware. If          |   |
| 7 | TXE   | RO      | TXEIE bit has been set, an interrupt will be            | 1 |
| , | 1712  | Ro      | generated, the data register will be written and this   | 1 |
|   |       |         | bit will be reset.                                      |   |
|   |       |         | 0: Data is not transferred to the shift register;       |   |
|   |       |         | 1: Data is transferred to the shift register.           |   |
|   |       |         | Transmission complete flag. When a frame                |   |
|   |       |         | containing data is sent and TXE bit is set, the         |   |
|   |       |         | hardware will set this bit. If TCIE is set, a           |   |
|   |       |         | corresponding interrupt will be generated. The          |   |
| 6 | TC    | RW0     | software will read this bit and then write the data     | 1 |
|   |       |         | register to clear this bit. You can also directly write |   |
|   |       |         | 0 to clear this bit.                                    |   |
|   |       |         | 0: Transmission not completed;                          |   |
|   |       |         | 1: Transmission completed.                              |   |
|   |       |         | Read data register not empty flag. When the data        |   |
|   |       |         | in the shift register is transferred to the data        |   |
|   |       |         | register, this bit will be set by the hardware. If the  |   |
| _ | DADE  | D ***-* | RXNEIE bit has been set, the corresponding              | _ |
| 5 | RXNE  | RW0     | interrupt will be generated. This bit can be cleared    | 0 |
|   |       |         | by the write operation of the data register. This bit   |   |
|   |       |         | can be also cleared by directly writing 0.              |   |
|   |       |         | 0: The data is not received;                            |   |
|   | IDI E |         | 1: The data is received and can be read.                |   |
| 4 | IDLE  | RO      | Idle line flag. When an idle line is detected, the bit  | 0 |

V2. 4 291 WCH°

|   |     |    | will be set by hardware. If IDLEIE bit has been set, the corresponding interrupt will be generated. This bit can be cleared by reading the status register and then reading the data register.  0: Idle bus is not detected;  1: The bus is idle now.  Note: This bit will not be set again until RXNE is set.                                                                                                                                                                                                                                                                                                                                    |   |
|---|-----|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| 3 | ORE | RO | Overrun error flag. When the receiving shift register has data that needs to be transferred to the data register, but this bit will be set when there is still data that has not been read in the receiving field of the data register. If the RXNEIE bit is set, the corresponding interrupt will be generated.  0: No overrun error has occurred;  1: The overrun error has occurred.  Note: When an overrun error occurs, the value of the data register will not be lost, but the value of the shift register will be overwritten. If the EIE bit is set, the ORE flag bit will generate an interrupt in the multi-buffer communication mode. | 0 |
| 2 | NE  | RO | Noise error flag. When the noise error flag is detected, it will be set by hardware. This bit can be reset by reading the status register and then reading the data register.  0: No noise is detected;  1: The noise is detected.  Note: This bit will not generate the interrupt. If the EIE bit has been set, the FE flag bit will generate an interrupt in the multi-buffer communication mode.                                                                                                                                                                                                                                               | 0 |
| 1 | FE  | RO | Frame error flag. When a synchronization error, excessive noise or disconnection is detected, this bit will be set by hardware. This bit can be reset by reading the bit and then reading the data register.  0: No frame error is detected;  1: A frame error is detected.  Note: This bit will not generate interrupt. If the EIE bit has been set, the FE flag bit will generate an interrupt in the multi-buffer communication mode.                                                                                                                                                                                                          | 0 |
| 0 | PE  | RO | Parity error flag. In the receiving mode, if a parity error occurs, this bit can be set by hardware. This bit can be reset by reading the bit and then reading the data register. Before this bit is cleared, the                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0 |

| software must wait for the RXNE flag bit to be set. |
|-----------------------------------------------------|
| If PEIE bit has been set before, then the           |
| corresponding interrupt will be generated when      |
| this bit is set.                                    |
| 0: No parity check error occurs;                    |
| 1: Parity check error occurs.                       |

## 18.10.2 USART Data Register (USARTx\_DATAR) (x=1/2/3/4/5/6/7/8)

Offset address: 0x04

| 31 | 30 | 29 | 28      | 27 | 26 | 25 | 24   | 23    | 22 | 21 | 20     | 19 | 18 | 17 | 16 |
|----|----|----|---------|----|----|----|------|-------|----|----|--------|----|----|----|----|
|    |    |    |         |    |    |    | Rese | erved |    |    |        |    | ,  |    |    |
| 15 | 14 | 13 | 12      | 11 | 10 | 9  | 8    | 7     | 6  | 5  | 4      | 3  | 2  | 1  | 0  |
|    |    | -  | Reserve | ed |    |    |      |       |    | •  | DR[8:0 | )] | -  |    |    |

| Bit    | Name     | Access | Description                                                                                                                                                                                                                                                                | Reset value |
|--------|----------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:9] | Reserved | RO     | Reserved.                                                                                                                                                                                                                                                                  | 0           |
| [8:0]  | DR[8:0]  | RW     | Data register. This register is actually composed of 2 registers: receive data register (RDR) and transmit data register (TDR). The start of the read and write operations of DR is to read the receive data register (RDR) and write to the transmit data register (TDR). | 0           |

## 18.10.3 USART Baud Rate Register (USARTx\_BRR) (x=1/2/3/4/5/6/7/8)

Offset address: 0x08

| 31                 | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23    | 22 | 21 | 20     | 19      | 18  | 17 | 16 |
|--------------------|----|----|----|----|----|----|-----|-------|----|----|--------|---------|-----|----|----|
|                    |    |    |    |    |    |    | Res | erved |    |    |        |         |     |    |    |
| 15                 | 14 | 13 | 12 | 11 | 10 | 9  | 8   | 7     | 6  | 5  | 4      | 3       | 2   | 1  | 0  |
| DIV_Mantissa[11:0] |    |    |    |    |    |    |     |       |    | D: | IV_Fra | ction[3 | :0] |    |    |

| Bit     | Name          | Access | Description                                             | Reset value |
|---------|---------------|--------|---------------------------------------------------------|-------------|
| [31:16] | Reserved      | RO     | Reserved.                                               | 0           |
| [15:4]  | DIV_ Mantissa | RW     | These 12 bits define the mantissa of the USART divider. | 0           |
| [3:0]   | DIV_Fraction  | RW     | These 4 bits define the fraction of the USART divider.  | 0           |

## 18.10.4 USART Control Register1 (USARTx\_CTLR1) (x=1/2/3/4/5/6/7/8)

| 31 | 30       | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|    | Reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15 | 14       | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |

| Bit     | Name     | Access | Description                                               | Reset value |
|---------|----------|--------|-----------------------------------------------------------|-------------|
| [31:16] | Reserved | RO     | Reserved.                                                 | 0           |
|         |          |        | Word length extension bits:                               |             |
|         |          |        | 00: Invalid, M bit determines data length.                |             |
|         |          |        | 01: 7 data bits;                                          |             |
|         |          |        | 10: 6 data bits;                                          |             |
| [15:14] | M_EXT    | RW     | 11: 5 data bits.                                          | 0           |
|         |          |        | Note: Only applicable to CH32F20x_D8,                     |             |
|         |          |        | CH32F20x_D8C, CH32V30x_D8, CH32V30x_D8C,                  |             |
|         |          |        | and CH32V31x_D8C products with the penultimate            |             |
|         |          |        | sixth digit of the lot number not being zero.             |             |
|         |          |        | USART enable.                                             |             |
|         |          |        | 0: Disable USART;                                         |             |
| 12      | LIE      | DW     | 1: Enable USART.                                          | 0           |
| 13      | UE       | RW     | When this bit is cleared, the frequency divider and       | 0           |
|         |          |        | output of USART both stop working after the current       |             |
|         |          |        | byte transmission is completed.                           |             |
|         |          |        | Word length.                                              |             |
| 12      | M        | RW     | 0: 8 data bits;                                           | 0           |
|         |          |        | 1: 9 data bits.                                           |             |
|         |          |        | Wake-up. This bit decides the method to wake up           |             |
| 1.1     | WA IZE   | DW     | USART:                                                    | 0           |
| 11      | WAKE     | RW     | 0: Idle line;                                             | 0           |
|         |          |        | 1: Address flag.                                          |             |
|         |          |        | Parity control enable.                                    |             |
|         |          |        | 0: Parity bit disabled;                                   |             |
|         |          |        | 1: Parity bit enabled.                                    |             |
| 10      | PCE      | RW     | For the receiver, the parity of the data is performed;    | 0           |
|         |          |        | for the transmitter, the check bit is inserted. Once this |             |
|         |          |        | bit is set, the parity control enable takes effect only   |             |
|         |          |        | after the current byte transmission is completed.         |             |
|         |          |        | Parity selection.                                         |             |
|         |          |        | 0: Even parity;                                           |             |
| 0       | DC       | DII.   | 1: Odd parity.                                            |             |
| 9       | PS       | RW     | After this bit is set, the parity control enable takes    | 0           |
|         |          |        | effect only after the current byte transmission is        |             |
|         |          |        | completed.                                                |             |
|         |          |        | Parity check interrupt enable.                            |             |
| 8       | PEIE     | RW     | 0: Disable generation of parity check error interrupt;    | 0           |
|         |          |        | 1: Enable generation of parity check error interrupt.     |             |
|         |          |        | Transmit buffer empty interrupt enable.                   |             |
| 7       | TXEIE    | RW     | 0: Disable generation of transmit buffer empty            | 0           |
|         |          |        | interrupt;                                                |             |

|   |        |    | 1: Enable generation of transmit buffer empty interrupt.                                                                                                                                                                                                                                                                                                                                                                                 |   |
|---|--------|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| 6 | TCIE   | RW | Transmission completion interrupt enable.  0: Disable generation of transmit complete interrupt;  1: Enable generation of transmit complete interrupt.                                                                                                                                                                                                                                                                                   | 0 |
| 5 | RXNEIE | RW | Receive buffer non-empty interrupt enable.  0: Disable generation of receive buffer not empty interrupt;  1: Enable generation of receive buffer not empty interrupt.                                                                                                                                                                                                                                                                    | 0 |
| 4 | IDLEIE | RW | Idle line interrupt enable.  0: Disable generation of idle line interrupt;  1: Enable generation of idle line interrupt.                                                                                                                                                                                                                                                                                                                 | 0 |
| 3 | TE     | RW | Transmitter enable.  0: Disable transmitter;  1: Enable transmitter.                                                                                                                                                                                                                                                                                                                                                                     | 0 |
| 2 | RE     | RW | Receiver enable.  0: Disable receiver;  1: Enable receiver, and the receiver starts detecting the start bit on the PX pin                                                                                                                                                                                                                                                                                                                | 0 |
| 1 | RWU    | RW | start bit on the RX pin.  Receiver wake-up. This bit decides whether the USART is in mute mode:  0: The receiver is in active mode;  1: The receiver is in mute mode.  Note 1: Before the RWU bit is set, USART needs to receive a data byte firstly. Otherwise, it cannot be woken up by the idle bus in mute mode;  Note 2: When configured to wake up from address flag, the RWU bit cannot be modified by software when RXNE is set. | 0 |
| 0 | SBK    | RW | Send break character control. This bit is set to transmit a frame break character. For the stop bit of break frame, the bit is set by hardware.  0: No break character transmitted;  1: Break character transmitted.                                                                                                                                                                                                                     | 0 |

# 18.10.5 USART Control Register2 (USARTx\_CTLR2) (x=1/2/3/4/5/6/7/8)

| 31           | 30        | 29 | 28  | 27        | 26       | 25       | 24       | 23           | 22        | 21       | 20           | 19       | 18 | 17 | 16 |
|--------------|-----------|----|-----|-----------|----------|----------|----------|--------------|-----------|----------|--------------|----------|----|----|----|
|              |           |    |     |           |          |          | Rese     | erved        |           |          |              |          |    |    |    |
| 15           | 14        | 13 | 12  | 11        | 10       | 9        | 8        | 7            | 6         | 5        | 4            | 3        | 2  | 1  | 0  |
| Reser<br>ved | LINE<br>N | S  | ГОР | CLK<br>EN | CPO<br>L | CPH<br>A | LBC<br>L | Reser<br>ved | LBDI<br>E | LBD<br>L | Reser<br>ved | ADD[3:0] |    |    |    |

| Bit | Name | Access | Description | Reset value |
|-----|------|--------|-------------|-------------|
|-----|------|--------|-------------|-------------|

| [31:15] | Reserved | RO | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                        | 0 |
|---------|----------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| 14      | LINEN    | RW | LIN mode enable. When this bit is set, the LIN mode is enabled. In LIN mode, you can use the SBK bit to send the LIN synchronization disconnection symbol and detect the LIN synchronization disconnection symbol.                                                                                                                                                                                                               | 0 |
| [13:12] | STOP     | RW | Stop bit setting. These bits are used to set the stop bits.  00: 1 stop bit;  01: 0.5 stop bit;  10: 2 stop bits;  11: 1.5 stop bit.                                                                                                                                                                                                                                                                                             | 0 |
| 11      | CLKEN    | RW | Clock enable. This bit is used to enable CK pin.  0: Disable;  1: Enable.                                                                                                                                                                                                                                                                                                                                                        | 0 |
| 10      | CPOL     | RW | Clock polarity. In synchronous mode, this bit can be used to select the polarity of the clock output on the SLCK pin, and work with CPHA to generate the required clock/data sampling relationship.  0: Low level is maintained on the CK pin when the bus is idle;  1: High level is maintained on the CK pin when the bus is idle.  Note: This bit cannot be modified after enabling transmission.                             | 0 |
| 9       | СРНА     | RW | Clock phase position setting. In the synchronization mode, you can use this bit to select the phase position of the clock output on the SLCK pin, and work with CPOL bit to generate the required clock/data sampling relationship.  0: Data capture is performed on the first edge of the clock;  1: Data capture is performed on the second edge of the clock.  Note: This bit cannot be modified after enabling transmission. | 0 |
| 8       | LBCL     | RW | Last bit clock pulse control.  In synchronous mode, it is used to control whether to output the clock pulse corresponding to the last data byte sent on the CK pin;  0: The clock pulse of the last bit of data is output from CK;  1: The clock pulse of the last bit of data is not output from CK.  Note: This bit cannot be modified after enabling transmission.                                                            | 0 |
|         |          |    |                                                                                                                                                                                                                                                                                                                                                                                                                                  |   |

| 6     | LBDIE         | RW    | LIN Break detection interrupt enable.  0: Disbale the interrupt caused by LBD; | 0   |
|-------|---------------|-------|--------------------------------------------------------------------------------|-----|
|       | LBDIE         | IX VV | 1: Enable the interrupt caused by LBD.                                         | · · |
|       |               |       | LIN Break detection length, used to select 11-bit or                           |     |
| 5     | <i>5</i> LDD1 | RW    | 10-bit break character detection.                                              | 0   |
| 3     | 5 LBDL        |       | 0: 10-bit break detection;                                                     | U   |
|       |               |       | 1: 11-bit break detection.                                                     |     |
| 4     | Reserved      | RW    | Reserved.                                                                      | 0   |
|       |               |       | Address of the USART node, used to set the USART                               |     |
|       |               |       | node address of the device. When the data is used                              |     |
| [3:0] | ADD[3:0]      | RW    | during mute mode in multi-processor communication,                             | 0   |
|       |               |       | the address flag is used to wake up a certain USART                            |     |
|       |               |       | device.                                                                        |     |

# 18.10.6 USART Control Register 3 (USARTx\_CTLR3) (x=1/2/3/4/5/6/7/8)

| 31 | 30 | 29     | 28 | 27 | 26        | 25   | 24   | 23       | 22       | 21       | 20       | 19        | 18   | 17   | 16  |
|----|----|--------|----|----|-----------|------|------|----------|----------|----------|----------|-----------|------|------|-----|
|    |    |        |    |    |           |      | Rese | erved    |          |          |          |           |      |      |     |
| 15 | 14 | 13     | 12 | 11 | 10        | 9    | 8    | 7        | 6        | 5        | 4        | 3         | 2    | 1    | 0   |
|    | ]  | Reserv | ed |    | CTSI<br>E | CTSE | RTSE | DMA<br>T | DMA<br>R | SCE<br>N | NAC<br>K | HDS<br>EL | IRLP | IREN | EIE |

| Bit     | Name     | Access | Description                                   | Reset value |
|---------|----------|--------|-----------------------------------------------|-------------|
| [31:11] | Reserved | RO     | Reserved.                                     | 0           |
|         |          |        | CTSIE interrupt enable                        |             |
| 10      | CTSIE    | RW     | 0: No interrupt is generated when CTS is set; | 0           |
|         |          |        | 1: An interrupt is generated when CTS is set. |             |
|         |          |        | CTS enable.                                   |             |
| 9       | CTSE     | RW     | 0: Diable CTS flow control;                   | 0           |
|         |          |        | 1: Enable CTS flow control.                   |             |
|         |          |        | RTS enable.                                   |             |
| 8       | RTSE     | RW     | 0: Diable RTS flow control;                   | 0           |
|         |          |        | 1: Enable RTS flow control.                   |             |
|         |          |        | DMA transmission enable.                      |             |
| 7       | DMAT     | RW     | 0: Not use DMA mode for transmission;         | 0           |
|         |          |        | 1: Use DMA mode for transmission.             |             |
|         |          |        | DMA reception enable.                         |             |
| 6       | DMAR     | RW     | 0: Not use DMA mode for reception;            | 0           |
|         |          |        | 1: Use DMA mode for for reception.            |             |
|         |          |        | Smartcard mode enable.                        |             |
| 5       | SCEN     | RW     | 0: Disable smartcard mode;                    | 0           |
|         |          |        | 1: Enable smartcard mode.                     |             |
|         |          |        | Smart card NACK enable.                       |             |
| 4       | NACK     | RW     | 0: NACK is not transmitted when the check     | 0           |
|         |          |        | error occurs;                                 |             |

|   |       |       | 1: NACK is transmitted when the check error   |   |
|---|-------|-------|-----------------------------------------------|---|
|   |       |       | occurs.                                       |   |
|   |       |       | Half-duplex mode selection.                   |   |
| 3 | HDSEL | RW    | 0: Disable half-duplex mode;                  | 0 |
|   |       |       | 1: Enable half-duplex mode.                   |   |
|   |       |       | Infrared low-power selection.                 |   |
|   |       |       | 0: Disable low-power mode when selected       |   |
| 2 | IRLP  | RW    | Infrared;                                     | 0 |
|   |       |       | 1: Enable low-power mode when selected        |   |
|   |       |       | Infrared.                                     |   |
|   |       |       | Infrared enable.                              |   |
| 1 | IREN  | RW    | 0: Disable infrared mode;                     | 0 |
|   |       |       | 1: Enable infrared mode.                      |   |
|   |       |       | Error interrupt enable.                       |   |
|   |       |       | 0: Disable error interrupt;                   |   |
|   | EIE   | RW    | 1: Enable error interrupt.                    | 0 |
|   | EIE   | IX VV | When this bit is set, and when DMAR is set,   | U |
|   |       |       | an interrupt is generated if the FE or ORE or |   |
|   |       |       | NE bit is set.                                |   |

## 18.10.7 USART Guard Time and Prescaler Register (USARTx\_GPR) (x=1/2/3/4/5/6/7/8)

Offset address: 0x18

1 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16

Reserved

| 15      | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4   | 3     | 2 | 1 | 0 |
|---------|----|----|----|----|----|---|---|---|---|---|-----|-------|---|---|---|
| GT[7:0] |    |    |    |    |    |   |   |   |   |   | PSC | [7:0] |   |   |   |

| Bit     | Name     | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                   | Reset value |
|---------|----------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:16] | Reserved | RO     | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                     | 0           |
| [15:8]  | GT[7:0]  | RW     | Guard time domain. These bits specify the guard time in unit of baud rate clock. In smartcard mode, the transmission complete flag is set after the guard time has passed.                                                                                                                                                                                                                                                    | 0           |
| [7:0]   | PSC[7:0] | RW     | Prescaler domain. In infrared low-power mode, the source clock is divided by this value (All 8 bits are valid), and a value of 0 means reservation; In infrared normal mode, these bits can only be set to 1; In smartcard mode, the value (The lower 5 bits are valid) is multiplied by 2 to give the division factor of the source clock frequency, to provide the clock to the smart card. A value of 0 means reservation. | 0           |

## 18.10.8 USART Control Register 4 (USARTx\_CTLR4) (x=1/2/3/4/5/6/7/8)

Offset address: 0x1C

| 31 | 30       | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22         | 21            | 20               | 19           | 18 | 17 | 16 |
|----|----------|----|----|----|----|----|----|----|------------|---------------|------------------|--------------|----|----|----|
|    | Reserved |    |    |    |    |    |    |    |            |               |                  |              |    |    |    |
| 15 | 14       | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6          | 5             | 4                | 3            | 2  | 1  | 0  |
|    | Reserved |    |    |    |    |    |    |    | CHEC<br>L[ | CK_SE<br>1:0] | MS_<br>ERRI<br>E | Reser<br>ved |    |    |    |

| Bit    | Name                 | Access | Description                            | Reset value |
|--------|----------------------|--------|----------------------------------------|-------------|
| [31:4] | Reserved             | RO     | Reserved                               | 0           |
|        |                      |        | Checksum function select bit:          |             |
| [2,2]  | CHECK SEL[1.0]       | RW     | 0x: Disables MARK and SPACE checksums. | 0           |
| [3:2]  | [3:2] CHECK_SEL[1:0] | KW     | 10: Enable MARK checksum.              | U           |
|        |                      |        | 11: Enable SPACE checksum.             |             |
|        |                      |        | SPACE or MARK checksum enable bit:     |             |
|        |                      |        | 0: Disable generation of SPACE or MARK |             |
| 1      | MS_ERRIE             | RW     | checksum error interrupts;             | 0           |
|        |                      |        | 1: Enable generation of SPACE or MARK  |             |
|        |                      |        | checksum error interrupt.              |             |
| 0      | Reserved             | RO     | Reserved                               | 0           |

Note: USARTx\_CTLR4 register only applicable to CH32F20x\_D8, CH32F20x\_D8C, CH32V30x\_D8, CH32V30x\_D8C, and CH32V31x\_D8C products with the penultimate sixth digit of the lot number not being zero.

V2. 4 299 WCH°

# Chapter 19 Inter-integrated Circuit (I2C) Interface

#### This chapter applies to the whole family of CH32F20x, CH32V20x, CH32V30x and CH32V31x.

The inter-integrated circuit (I2C) is widely used in the communication between microcontroller and sensor and other off-chip modules. It supports multi-master mode and multi-slave mode. The communication can be carried out at 2 speeds: 100kHz (Standard) and 400kHz (Fast) only through 2 wires (SDA and SCL). The I2C bus is also compatible with the SMBus protocol. It not only supports I2C timing, but also supports arbitration, timing and DMA, and has CRC check capability.

#### 19.1 Main Features

- Master mode and slave mode
- 7-bit or 10-bit address
- Slave device supports dual 7-bit address.
- Two speed modes: 100kHz and 400kHz
- Multiple status modes, multiple error flags
- Optional clock stretching
- 2 interrupt vectors
- DMA capability
- Support PEC
- Compatible with SMBus

#### 19.2 Overview

I2C is a half-duplex bus, and it can only run in one of the following 4 modes at the same time: master transmitter, master receiver, slave transmitter and slave receiver. The I2C module works in the slave mode by default. After the start condition is generated, it automatically switches to master mode. When the arbitration is lost or the stop signal is generated, it switches to the slave mode. I2C module supports multi-host function. When working in master mode, the I2C module actively sends out data and addresses. Both data and address are transferred as 8-bit bytes, and MSB first. One-byte (In 7-bit address mode) or two-byte (in 10-bit address mode) address is located after the initial event. Every time the master device sends 8-bit data or address, the slave device needs to reply an ACK, i.e., pulling the SDA bus to be low, as shown in Figure 19-1.

Figure 19-1 I2C timing diagram



For normal use, the correct clock must be input to I2C. In the standard mode, the minimum input clock is 2MHz, while the minimum input clock is 4MHz in the fast mode.

Figure 19-2 shows the block diagram of I2C.



Figure 19-2 I2C block diagram

#### 19.3 Master Mode

In master mode, the I2C module leads the data transmission and outputs the clock signal. The data transfer starts with a Start event and ends with a Stop event. The following is the required operations in master mode: Set the correct clock in the control register2 (R16\_I2Cx\_CTLR2) and the clock control register (R16\_I2Cx\_CKCFGR).

Set a proper rising edge in the rising edge register (R16 I2Cx RTR).

Set the PE bit in R16 I2Cx CTLR1 to start the peripheral.

Set the START bit in the control register (R16 I2Cx CTLR1) to generate a start event.

After the START bit is set, the I2C module automatically switches to master mode, the MSL bit is set, and a Start event is generated. After the start event is generated, the SB bit is set. If the ITEVTEN bit (in R16\_I2Cx\_CTLR2) is set, an interrupt is generated. In this case, it is needed to read the R16\_I2Cx\_STAR1 register. After the slave address is written to the data register, the SB bit is automatically cleared.

If the 10-bit address mode is enabled, then write the data register to send the header sequence (the header sequence is 11110xx0b, of which the xx bits are the highest 2 bits of the 10-bit address).

After the header sequence is transmitted, the ADD10 bit in the status register is set. If the ITEVTEN bit is already set, an interrupt will be generated. At this time, read the R16 I2Cx STAR1 register and write the

second address byte to the data register. Then, clear the ADD10 bit.

Then, write the data register to send the second address byte. After sending the second address byte, the ADDR bit in the status register is set. If the ITEVTEN bit has been set, an interrupt will be generated. Read the R16\_I2Cx\_STAR2 register at this time and then read R16\_I2Cx\_STAR1 register again to clear the ADDR bit; If the 7-bit address mode is enabled, the write data register transmit the address byte. After the address byte is sent, the ADDR bit in the status register is set. If the ITEVTEN bit has been set, an interrupt will be generated. Read the R16\_I2Cx\_STAR1 register and then read the R16\_I2Cx\_STAR2 register again to clear the ADDR bit.

In the 7-bit address mode, the first byte sent is the address byte, the first 7 bits represent the address of the target slave device, the 8th bit determines the direction of the subsequent message, and '0' means the master device writes data to the slave device, '1' means that the master device reads information from the slave device. In the 10-bit address mode, as shown in Figure 19-3, the first byte is 11110xx0, xx are the highest 2 bits of the 10-bit address, and the second byte is the lower 8 bits of the 10-bit address in the address transmission phase. If you subsequently enter the master transmitter mode, send data continuously. If the device enters the master receiver mode subsequently, a start event needs to be re-sent, and a byte of 11110xx1 will be sent together. Then, enter the master receiver mode.



Figure 19-3 Master receive/transmits data in 10-bit address mode

#### Master transmit mode:

The master device's internal shift register sends data from the data register to the SDA line. When the master device receives an ACK, TxE in status register 1 (R16\_I2Cx\_STAR1) is set, and an interrupt is also generated if ITEVTEN and ITBUFEN are set. Writing data to the data register will clear the TxE bit.

If the TxE bit is set and no new data was written to the data register before the last data was sent, then the BTF bit will be set and SCL will remain low until it is cleared, and writing data to the data register after reading R16 I2Cx STAR1 will clear the BTF bit.



Figure 19-4 Master transmitter transmission sequence diagram

#### Master receive mode:

The I2C module will receive data from the SDA line and write it into the data register via a shift register. After each byte, if the ACK bit is set, then the I2C module will send an answer low, and the RxNE bit will be set, and an interrupt will be generated if ITEVTEN and ITBUFEN are set. If RxNE is set and the original data is not read before the new data is received, then the BTF bit will be set and SCL will remain low until the BTF is cleared. Reading R16\_I2Cx\_STAR1 and then reading the data register will clear the BTF bit.



Figure 19-5 Receiver transmission sequence diagram

When the master device ends sending data, it will actively send an end event, i.e. set the STOP bit, and the I2C will switch to slave mode. In receive mode, the master device needs to NAK at the answer position of the last data bit, and after receiving NACK, the slave device releases control of the SCL and SDA lines; the master device can then send a stop/restart condition. Note that the I2C module will automatically switch to slave mode after the stop condition is generated.

#### 19.4 Slave Mode

In the slave mode, the I2C module can identify its own address and the general call address. The software can control to enable or disable the identification of the broadcast calling address. Once the start event is detected, the I2C module will compare the SDA data with its own address (The number of bits depends on ENDUAL

and ADDMODE) or the broadcast address (When ENGC is set) through the shift register. If there is no match, it will be ignored until a new start event is generated. If it matches the header sequence, it will generate an ACK signal and wait for the address of the second byte; if the address of the second byte also matches or the whole-section address matches in the case of a 7-bit address, then:

Firstly generate an ACK response;

The ADDR bit will be set; if the ITEVTEN bit is already set, then the corresponding interrupt will be generated; If the dual-address mode (The ENDUAL bit is set) is used, you also need to read the DUALF bit to determine which address is woken up by the master device.

The slave mode is the receiving mode by default. When the last bit of the received header sequence is 1, or the last bit of the 7-bit address is 1 (Depending on whether the header sequence is received for the first time or a normal 7-bit address), the I2C module will enter the transmitter mode, and the TRA bit will indicate whether it is currently in receiver or transmitter mode.

#### Slave transmit mode:

After the ADDR bit is cleared, the I2C module sends bytes from the data register to the SDA line via a shift register. The slave device holds SCL low until the ADDR bit is cleared and the data to be sent has been written to the data register. (See EVT1 and EVT3 in the figure below). Upon receipt of an answer ACK, the TxE bit will be set and an interrupt will be generated if ITEVTEN and ITBUFEN are set. The BTF bit will be set if TxE is set but no new data is written to the data register before the end of the next data transmission. SCL will remain low until the BTF is cleared. Reading status register 1 (R16\_I2Cx\_STAR1) and then writing data to the data register will clear the BTF bit.



Figure 19-6 Slave transmitter transmission sequence diagram

#### Slave receive mode:

After ADDR is cleared, the I2C module stores the data on SDA into the data register via a shift register. After every byte received, the I2C module sets an ACK bit and sets the RxNE bit. If ITEVTEN and ITBUFEN are set, an interrupt is also generated. If RxNE is set and the old data is not read before the new data is received, then BTF is set. SCL will remain low until the BTF bit is cleared. Reading status register 1 (R16\_I2Cx\_STAR1) and reading the data in the data register will clear the BTF bit.

V2. 4 304 WH

7-bit slave reception Data1 DataN Address EVT2 EVT2 EVT2 EVT4 EVT1 10-bit slave reception DataN Address Data1 EVT2 EVT4 EVT1 FVT2 Description: S=Start (start condition), Sr=repeated start condition, P=Stop (stop condition), A=response, NA=nonresponse, EVTx=event (interrupt generated when ITEVFEN=1) EVT1; ADDR=1, reading SR1 then SR2 will erase the event. EVT2: RxNE=1, reading DR will clear the event. EVT4: STOPF=1, reading SR1 and then writing CR1 register will clear the event. Note: 1: EVT1 event elongates SCL low until the end of the corresponding software sequence. 2: The software sequence of EVT2 must be completed before the end of the current byte transfer.

Figure 19-7 Receiver transmission sequence diagram

The master device will generate a stop condition after the last data byte is transferred. When the I2C module detects a stop event, it will set the STOPF bit, and if the ITEVFEN bit is set, it will also generate an interrupt. The user needs to read the status register (R16\_I2Cx\_STAR1) and then write the control register (e.g. reset control word SWRST) to clear it. (See EVT4 in the figure above).

#### **19.5 Error**

#### 19.5.1 Bus error (BERR)

During address or data transmission, when the I2C module detects an external start or stop event, a bus error will be generated. When a bus error occurs, the BERR bit will be set, and an interrupt will be generated if ITERREN is set. The data is discarded and the hardware releases the bus in the slave mode. For a start signal, the hardware will consider it as a restart signal and begin to wait for an address or stop signal; for a stop signal, it will be operated according to normal stop conditions in advance. In the master mode, the hardware will not release the bus and will not affect the current transmission. The user code decides whether to abort the transmission.

#### 19.5.2 Acknowledge failure (AF)

When the I2C module does not respond after detecting a byte, it will generate an acknowledge failure. When an acknowledge failure occurs, AF is set, and an interrupt is generated if ITERREN is set. If an AF error is encountered and the I2C module is working in the slave mode, the hardware must release the bus. If it is in master mode, the software must generate a stop event.

#### 19.5.3 Arbitration lost (ARLO)

When the I2C module detects that the arbitration is lost, an arbitration loss error will be generated. When an arbitration loss error occurs, the ARLO bit will be set. If ITERREN is set, an interrupt will be generated; the I2C module will switch to the slave mode and no longer respond to the transmission initiated by its slave address, unless the host initiates a new start event; the hardware will release the bus.

#### 19.5.4 Overrun/ Underrun error (OVR)

#### Overrun error:

In the slave mode, if clock extension is disabled, the I2C module is receiving data. If 1-byte data has been

received, but the data received at the previous time has not been read, an overrun error will occur. When an overrun error occurs, the last received byte will be discarded, and the sender shall retransmit the last byte transmitted.

#### Underrun error:

In the slave mode, if the clock extension is disabled, the I2C module is sending data. If new data has not been written to the data register before the next byte of the clock arrives, an underrun error will occur. When an underrun error occurs, the data in the previous data register will be sent twice. If an underrun error occurs, the receiver shall discard the data received repeatedly. In order not to generate an underrun error, the I2C module shall write data into the data register before the first rising edge of the next byte.

#### 19.6 Clock extension

If clock extension is disabled, there is a possibility of overrun/underrun errors. But if clock extension is enabled:

- In transmitter mode, if TxE is set and BTF is set, SCL will always be low, until the user reads the status register and writes the data to be sent to the data register;
- In receiver mode, if RxNE is set and BTF is set, SCL will remain low after receiving data until the user reads the status register and reads the data register;

It can be seen that enabling clock extension can avoid overrun/underrun errors.

#### **19.7 SMBus**

SMBus is also a 2-wire interface, which is generally used between the system and power management. SMBus and I2C have many similarities. For example, SMBus uses the same 7-bit address mode as I2C.

Similarities between SMBus and I2C:

- 1) Master-slave communication mode; the host provides the clock and supports multiple masters and multiple slaves;
- 2) 2-wire communication structure, of which a warning line can be selected for SMBus;
- 3) Support 7-bit address format.

Differences between SMBus and I2C:

- 1) I2C supports the maximum speed of 400kHz, while SMBus supports the maximum speed of 100kHz, and SMBus has the minimum speed limit of 10kHz;
- 2) When the SMBus clock is lower than 35mS, it will report a timeout, but I2C has no such limitation;
- 3) SMBus has a fixed logic level, but I2C does not, depending on V<sub>DD</sub>;
- 4) SMBus has a bus protocol, but I2C does not.

SMBus also includes device identification, address resolution protocol, unique device identifier, SMBus reminder, and various bus protocols. For details, please refer to SMBus specification version 2.0. When SMBus is used, only the SMBus bit of the control register needs to be set, and the SMBTYPE and ENAARP bits need to be configured as needed.

## 19.8 Interrupt

Each I2C module has 2 interrupt vectors: event interrupt and error interrupt. 2 types of interrupts support the interrupt sources as shown in Figure 19-4.

ITEVFEN SB ADDR ADD10 STOPF it\_event BTF ITBUFEN RxNE ITERREN BERR ARLO ΑF OVR PECERR TIMEOUT SMBALERT

Figure 19-4 I2C interrupt request

#### 19.9 DMA

DMA can be used to receive/transmit bulk data. When DMA is used, the ITBUFEN bit of the control register cannot be set.

#### • DMA is used for transmission

The DMA mode can be activated by setting the DMAEN bit in the CTLR2 register. As long as the TxE bit is set, the data can be loaded into the I2C data register from the set memory by DMA. The following settings are required to allocate channels for I2C.

- 1) Set the I2Cx\_DATAR register address to the DMA\_PADDRx register, and set the memory address in the DMA\_MADDRx register, so that the data will be sent from the memory to the I2Cx\_DATAR register after each TxE event.
- 2) Set the required number of transferred bytes in the DMA\_CNTRx register. After each TxE event, this value will be reduced progressively.
- 3) The channel priority is configured using the PL[0:1] bits in the DMA CFGRx register.
- 4) Set the DIR bit in the DMA\_CFGRx register, and it can be configured to issue an interrupt request according to application requirements when the entire transmission is half or wholly completed.
- 5) Activate the channel by setting the EN bit in the DMA CFGRx register.

When the number of data transfer bytes set in the DMA controller has been completed, the DMA controller will send an EOT/EOT\_1 signal indicating the end of the transmission to the I2C interface. When the interrupt is allowed, a DMA interrupt will be generated.

#### DMA is used for reception

After the DMAEN bit in the CTLR2 register is set, DMA receiver mode can be started. When DMA is used for reception, DMA transfers the data in the data register to the preset memory area. The following steps are required to allocate channels for I2C.

1) Set the I2Cx\_DATAR register address to the DMA\_PADDRx register, and set the memory address in the DMA\_MADDRx register, so that the data will be written into the memory from the I2Cx\_DATAR register

after each RxNE event.

- 2) Set the required number of transferred bytes in the DMA\_CNTRx register. After each RxNE event, this value will be reduced progressively.
- 3) The channel priority is configured by the PL[0:1] bits in the DMA CFGRx register.
- 4) Clear the DIR bit in the DMA\_CFGRx register, and it can be configured to issue an interrupt request according to application requirements when the data transmission is half or wholly completed.
- 5) Activate the channel by setting the EN bit in the DMA CFGRx register.

When the number of data transfer bytes set in the DMA controller has been completed, the DMA controller will send an EOT/EOT\_1 signal indicating the end of the transmission to the I2C interface. When the interrupt is allowed, a DMA interrupt will be generated.

## 19.10 Packet error checking

Packet error checking (PEC) is a CRC8 check step added to provide the transmission reliability. Each bit of serial data can be calculated through the following polynomial:

$$C=X^8+X^2+X+1$$

PEC calculation is activated by the ENPEC bit in the control register, and all information bytes are calculated, including address and read/write bits. During transmission, enabling PEC will add a byte of CRC8 calculation result after the last byte of data. While in receiver mode, the last byte is considered to be the CRC8 check result. If it does not match the internal calculation result, it will reply with a NAK. For the master receiver, it will reply with a NAK regardless of whether the check result is correct or not.

## 19.11 Debug mode

After the system enters the debug mode, the DBG\_I2Cx\_SMBUS\_TIMEOUT bit in the DEBUG module can be used to determine whether to continue operating or stop the time-out control of I2CSMBus.

## 19.12 Register description

Table 19-1 I2C1 registers

| Table 19 1 1201 logisters |                |                         |             |  |  |  |  |  |  |  |
|---------------------------|----------------|-------------------------|-------------|--|--|--|--|--|--|--|
| Name                      | Access address | Description             | Reset value |  |  |  |  |  |  |  |
| R16_I2C1_CTLR1            | 0x40005400     | I2C1 control register1  | 0x0000      |  |  |  |  |  |  |  |
| R16_I2C1_CTLR2            | 0x40005404     | I2C1 control register2  | 0x0000      |  |  |  |  |  |  |  |
| R16_I2C1_OADDR1           | 0x40005408     | I2C1 address register1  | 0x0000      |  |  |  |  |  |  |  |
| R16_I2C1_OADDR2           | 0x4000540C     | I2C1 address register2  | 0x0000      |  |  |  |  |  |  |  |
| R16_I2C1_DATAR            | 0x40005410     | I2C1 data register      | 0x0000      |  |  |  |  |  |  |  |
| R16_I2C1_STAR1            | 0x40005414     | I2C1 status register1   | 0x0000      |  |  |  |  |  |  |  |
| R16_I2C1_STAR2            | 0x40005418     | I2C1 status register2   | 0x0000      |  |  |  |  |  |  |  |
| R16_I2C1_CKCFGR           | 0x4000541C     | I2C1 clock register     | 0x0000      |  |  |  |  |  |  |  |
| R16_I2C1_RTR              | 0x40005420     | I2C1 rise time register | 0x0002      |  |  |  |  |  |  |  |

Table 19-2 I2C2 registers

| Name           | Access address | Description            | Reset value |
|----------------|----------------|------------------------|-------------|
| R16_I2C2_CTLR1 | 0x40005800     | I2C2 control register1 | 0x0000      |

| R16_I2C2_CTLR2  | 0x40005804 | I2C2 control register2  | 0x0000 |
|-----------------|------------|-------------------------|--------|
| R16_I2C2_OADDR1 | 0x40005808 | I2C2 address register1  | 0x0000 |
| R16_I2C2_OADDR2 | 0x4000580C | I2C2 address register2  | 0x0000 |
| R16_I2C2_DATAR  | 0x40005810 | I2C2 data register      | 0x0000 |
| R16_I2C2_STAR1  | 0x40005814 | I2C2 status register1   | 0x0000 |
| R16_I2C2_STAR2  | 0x40005818 | I2C2 control register2  | 0x0000 |
| R16_I2C2_CKCFGR | 0x4000581C | I2C2 clock register     | 0x0000 |
| R16_I2C2_RTR    | 0x40005820 | I2C2 rise time register | 0x0002 |

# 19.12.1 I2C Control Register (I2Cx\_CTLR1) (x=1/2)

| 15        | 14           | 13        | 12  | 11  | 10  | 9    | 8         | 7                 | 6        | 5         | 4         | 3           | 2            | 1         | 0  | _ |
|-----------|--------------|-----------|-----|-----|-----|------|-----------|-------------------|----------|-----------|-----------|-------------|--------------|-----------|----|---|
| SWR<br>ST | Reser<br>ved | ALE<br>RT | PEC | POS | ACK | STOP | STAR<br>T | NOS<br>TRET<br>CH | ENG<br>C | ENPE<br>C | ENA<br>RP | SMB<br>TYPE | Reser<br>ved | SMB<br>US | PE |   |

| Bit | Name     | Access | Description                                                                                                                                                                                                                                                                                                                                                                 | Reset value |
|-----|----------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| 15  | SWRST    | RW     | Software reset. Setting this bit by user code will reset the I2C peripheral. Before reset, make sure that the pins of the I2C bus are released and the bus is idle.  Note: This bit can reset the I2C module when no stop condition is detected on the bus but the busy bit is 1.                                                                                           | 0           |
| 14  | Reserved | RO     | Reserved.                                                                                                                                                                                                                                                                                                                                                                   | 0           |
| 13  | ALERT    | RW     | SMBus alert. This bit can be set or cleared by the user code. When PE is set, this bit can be cleared by hardware.  0: Release the SMBusALERT pin to make it high, and the response address header shall closely follow the NACK signal;  1: Drive the SMBusALERT pin to make it low, and the response address header shall closely follow the ACK signal.                  | 0           |
| 12  | PEC      | RW     | Packet error check enable. Set this bit to enable data packet error detection. This bit can be set or cleared by the user code. When the PEC is transmitted, or a start or end signal is generated, or the PE bit is cleared to 0, the bit can be cleared by hardware.  0: Not provided with PEC;  1: Provided with PEC.  Note: PEC will fail when the arbitration is lost. | 0           |
| 11  | POS      | RW     | ACK and PEC position setting. This bit can be set and cleared by user code, and it can be cleared by hardware after PE is cleared;  0: The ACK bit controls the ACK or NAK of the byte currently being received in the shift register. The PEC                                                                                                                              | 0           |

|    |           |    | bit indicates that the byte of the shift register before the current bit is PEC;  1: The ACK bit controls the ACK or NAK of the next byte received in the shift register. The next byte received in the PEC shift register is PEC.  Note: The usage of POS bit in 2-byte data reception is as follows: It must be configured before receiving. For the second byte of NACK, the ACK bit must be                                          |   |
|----|-----------|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
|    |           |    | cleared immediately after the ADDR bit is cleared; in order to detect the PEC of the second byte, the PEC bit must be set after the ADDR event occurs following the POS bit.                                                                                                                                                                                                                                                             |   |
| 10 | ACK       | RW | Acknowledge enable. This bit can be set or cleared by user code. When PE bit is set, this bit can be cleared by hardware;  0: No acknowledge is returned;  1: Acknowledge returned after a byte is received.                                                                                                                                                                                                                             | 0 |
| 9  | STOP      | RW | Stop event generation. It can be set or cleared by user code, or cleared by hardware when a stop event is detected, or set by hardware when a timeout error is detected.  In master mode:  0: No stop event occurs;  1: A stop event is generated after the current byte transfer or the current start condition is issued.  In slave mode:  0: No stop event occurs;  1: Release the SCL and SDA lines after the current byte transfer. | 0 |
| 8  | START     | RW | Start event generation. This bit can be set or cleared by the user code. When the start condition is issued or PE is cleared, it can be cleared by hardware.  In master mode:  0: No start event is generated;  1: A start event is generated repeatedly.  In slave mode:  0: No start event is generated;  1: When the bus is idle, a start event is generated.                                                                         | 0 |
| 7  | NOSTRETCH | RW | Clock stretching disable. This bit is used to disable clock stretching in slave mode when the ADDR or BTF flag bit is set until it is cleared by software.  0: Clock stretching enabled; 1: Clock stretching disabled.                                                                                                                                                                                                                   | 0 |
| 6  | ENGC      | RW | General call enable. Set this bit to enable the general call, and respond to general address 00h.                                                                                                                                                                                                                                                                                                                                        | 0 |
| 5  | ENPEC     | RW | PEC enable.                                                                                                                                                                                                                                                                                                                                                                                                                              | 0 |

V2. 4 310 WCH°

|   |          |    | 0: Disable PEC calculation;                       |   |
|---|----------|----|---------------------------------------------------|---|
|   |          |    | 1: Enable PEC calculation.                        |   |
|   |          |    | ARP enable.                                       |   |
|   |          |    | 0: Disable ARP;                                   |   |
| 4 | ENARP    | RW | 1: Enable ARP.                                    | 0 |
| 4 | ENARP    | KW | If SMBTYPE=0, the default address of the SMBus    | U |
|   |          |    | device is used. If SMBTYPE=1, the main address of |   |
|   |          |    | the SMBus is used.                                |   |
|   |          |    | SMBus device type:                                |   |
| 3 | SMBTYPE  | RW | 0: SMBus slave device;                            | 0 |
|   |          |    | 1: SMBus master device.                           |   |
| 2 | Reserved | RO | Reserved.                                         | 0 |
|   |          |    | SMBus mode selection.                             |   |
| 1 | SMBUS    | RW | 0: I2C mode;                                      | 0 |
|   |          |    | 1: SMBus mode.                                    |   |
|   |          |    | I2C peripheral enable.                            |   |
| 0 | PE       | RW | 0: I2C module disabled;                           | 0 |
|   |          |    | 1: I2C module enabled.                            |   |

# 19.12.2 I2C Control Register 2 (I2Cx\_CTLR2) (x=1/2)

| 15 | 14       | 13 | 12   | 11        | 10          | 9           | 8           | 7    | 6    | 5 | 4 | 3    | 2      | 1 | 0 |
|----|----------|----|------|-----------|-------------|-------------|-------------|------|------|---|---|------|--------|---|---|
| ]  | Reserved | l  | LAST | DMA<br>EN | ITBU<br>FEN | ITEV<br>TEN | ITER<br>REN | Rese | rved |   |   | FREC | Q[5:0] |   |   |

| Bit     | Name     | Access | Description                                                                                                                                                                                                                        | Reset value |
|---------|----------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [15:13] | Reserved | RO     | Reserved.                                                                                                                                                                                                                          | 0           |
| 12      | LAST     | RW     | Last transfer setting of DMA.  0: Next DMA EOT is not the last transfer;  1: Next DMA EOT is the last transfer;  Note: This bit is used in master receiver mode and can generate a NAK when the data is received at the last time. |             |
| 11      | DMAEN    | RW     | DMA request enable. 0: Disable DMA request when TxE or RxNE bit is set; 1: Enable DMA request when TxE or RxNE bit is set.                                                                                                         | 0           |
| 10      | ITBUFEN  | RW     | Buffer interrupt enable.  0: When the TxE bit is set, or when the RxNE bit is set, no interrupt is generated;  1: When the TxE bit is set, or when the RxNE bit is set, an event interrupt is generated.                           | 0           |
| 9       | ITEVTEN  | RW     | Event interrupt enable. 0: Disable event interrupt;                                                                                                                                                                                | 0           |

|       |           |    | 1: Enable event interrupt.                         |   |
|-------|-----------|----|----------------------------------------------------|---|
|       |           |    | Under the following conditions, the interrupt can  |   |
|       |           |    | be generated:                                      |   |
|       |           |    | SB=1 (Master mode);                                |   |
|       |           |    | ADDR=1(Master and slave modes);                    |   |
|       |           |    | ADDR10=1 (Master mode);                            |   |
|       |           |    | STOPF=1 (Slave mode);                              |   |
|       |           |    | BTF=1, but no TxE or RxNE event occurs;            |   |
|       |           |    | If ITBUFEN=1, TxE event is 1;                      |   |
|       |           |    | If ITBUFEN=1, RxNE event is 1.                     |   |
|       |           |    | Error interrupt enable.                            |   |
|       |           |    | 0: Disable error interrupt;                        |   |
|       |           |    | 1: Enable error interrupt.                         |   |
| 8     | ITERREN   | RW | Under the following conditions, the interrupt can  | 0 |
|       |           |    | be generated:                                      |   |
|       |           |    | BERR=1; ARLO=1; AF=1; OVR=1; PECERR=1;             |   |
|       |           |    | TIMEOUT=1; SMBAlert=1.                             |   |
| [7:6] | Reserved  | RO | Reserved.                                          | 0 |
|       |           |    | I2C module clock frequency domain. The correct     |   |
|       |           |    | clock frequency must be input to generate the      |   |
| [5:0] | FREQ[5:0] | RW | correct timing, and the allowable range is between | 0 |
|       |           |    | 4-60MHz. It must be set between 000100b and        |   |
|       |           |    | 111100b, and the unit is MHz.                      |   |

# 19.12.3 I2C Address Register 1 (I2Cx\_OADDR1) (x=1/2)

| 15              | 14 | 13 | 12      | 11 | 10 | 9   | 8     | 7 | 6 | 5 | 4      | 3  | 2 | 1 | 0        |
|-----------------|----|----|---------|----|----|-----|-------|---|---|---|--------|----|---|---|----------|
| ADD<br>MOD<br>E |    | R  | Reserve | d  |    | ADD | [9:8] |   |   | A | .DD[7: | 1] |   |   | ADD<br>0 |

| Bit     | Name     | Access | Description                                                                                                                            | Reset value |
|---------|----------|--------|----------------------------------------------------------------------------------------------------------------------------------------|-------------|
| 15      | ADDMODE  | RW     | Addressing mode.  0: 7-bit slave address (10-bit address not acknowledged);  1: 10-bit slave address (7-bit address not acknowledged). | 0           |
| [14:10] | Reserved | RO     | Reserved.                                                                                                                              | 0           |
| [9:8]   | ADD[9:8] | RW     | Interface address. The 9th bit and the 8th bit when a 10-bit address is used, while ignored when a 7-bit address is used.              |             |
| [7:1]   | ADD[7:1] | RW     | Interface address, bit 7-1.                                                                                                            | 0           |
| 0       | ADD0     | RW     | Interface address. Bit0 when a 10-bit address is used. It is ignored when a 7-bit address is used.                                     | 0           |

## 19.12.4 I2C Address Register2 (I2Cx\_OADDR2) (x=1/2)

Offset address: 0x0C

| 15 | 14 | 13 | 12   | 11    | 10 | 9 | 8 | 7 | 6 | 5 | 4      | 3   | 2 | 1 | 0          |
|----|----|----|------|-------|----|---|---|---|---|---|--------|-----|---|---|------------|
|    |    |    | Rese | erved |    |   |   |   |   | A | DD2[7: | :1] |   |   | ENDU<br>AL |

| Bit    | Name      | Access | Description                                                                    | Reset value |
|--------|-----------|--------|--------------------------------------------------------------------------------|-------------|
| [15:8] | Reserved  | RO     | Reserved.                                                                      | 0           |
| [7:1]  | ADD2[7:1] | RW     | Interface address. Bit7 to bit1 of address in dual-address mode.               | 0           |
| 0      | ENDUAL    | RW     | Dual addressing mode enable. When this bit is set, the ADD2 can be identified. | 0           |

## 19.12.5 I2C Data Register (I2Cx\_DATAR) (x=1/2)

Offset address: 0x10

| 15 | 14 | 13 | 12   | 11    | 10 | 9 | 8 | 7 | 6 | 5 | 4   | 3     | 2 | 1 | 0 |
|----|----|----|------|-------|----|---|---|---|---|---|-----|-------|---|---|---|
|    |    |    | Rese | erved |    |   |   |   |   |   | DR[ | [7:0] |   |   |   |

| Bit  | Name     | Access | Description                                          | Reset value |
|------|----------|--------|------------------------------------------------------|-------------|
| 15:8 | Reserved | RO     | Reserved.                                            | 0           |
| 7.0  | DD[7.0]  | I RW   | Data register. This domain is used to store received | 0           |
| 7:0  | DR[7:0]  |        | data or store data to be transmitted to the bus.     | U           |

## 19.12.6 I2C Status Register 1 (I2Cx\_STAR1) (x=1/2)

| 15               | 14          | 13           | 12         | 11  | 10 | 9        | 8        | 7   | 6    | 5            | 4         | 3         | 2   | 1        | 0  |
|------------------|-------------|--------------|------------|-----|----|----------|----------|-----|------|--------------|-----------|-----------|-----|----------|----|
| SMB<br>ALE<br>RT | TIME<br>OUT | Reser<br>ved | PECE<br>RR | OVR | AF | ARL<br>O | BER<br>R | TxE | RxNE | Reser<br>ved | STOP<br>F | ADD<br>10 | BTF | ADD<br>R | SB |

| Bit | Name     | Access | Description                                                                                                                                                                                                                                                                                                   | Reset value |
|-----|----------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| 15  | SMBALERT | RW0    | SMBus alert. It can be reset by user writing 0, or reset by hardware when PE becomes low.  In master mode of SMBus: 0: No SMBus alert; 1: SMBus alert is generated on the pin.  In slave mode of SMBus: 0: No SMBAlert response address header; 1: SMBAlert response address header to SMBAlert LOW received. | 0           |
| 14  | TIMEOUT  | RW0    | Timeout or Tlow error flag. It can be reset by user writing 0, or reset by hardware when PE becomes low. 0: 25ms;                                                                                                                                                                                             |             |

|    |          |     | 1: SCL is low and has reached 25ms, or the accumulated clock expansion time of the master device low level exceeds 10ms, or the accumulated time of the slave device low level exceeds 25ms.  Note: When this bit is set in slave mode, the slave device resets the communication and the hardware releases the bus. When this bit is set in master mode, hardware issues a stop condition. |   |
|----|----------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| 13 | Reserved | RO  | Reserved.                                                                                                                                                                                                                                                                                                                                                                                   | 0 |
| 12 | PECERR   | RW0 | PEC error flag occurs during reception. This bit can be reset by user writing 0, or reset by hardware when PE becomes low.  0: No PEC error;  1: PEC error. After PEC is received, NAK is returned.                                                                                                                                                                                         | 0 |
| 11 | OVR      | RW0 | Overrun and underrun flag.  0: No overrun and underrun event;  1: Overrun or underrun event occurs: In case of NOSTRETCH=1, when a new byte is received in the receiver mode and the content in the data register has not been read, the newly received byte will be lost. In the transmitter mode, no new data is written into the data register, and the same byte will be sent twice.    | 0 |
| 10 | AF       | RW0 | Acknowledge failure flag. This bit can be reset by user writing 0, or reset by hardware when PE becomes low.  0: Normal acknowledge;  1: Acknowledge error.                                                                                                                                                                                                                                 | 0 |
| 9  | ARLO     | RW0 | Arbitration lost flag. It can be reset by user writing 0, or reset by hardware when PE becomes low. 0: Normal arbitration; 1: Arbitration lost is detected and the module loses control of the bus.                                                                                                                                                                                         | 0 |
| 8  | BERR     | RW0 | Bus error flag. It can be reset by user writing 0, or reset by hardware when PE becomes low.  0: Normal;  1: Start or stop condition error.                                                                                                                                                                                                                                                 | 0 |
| 7  | TxE      | RO  | Data register empty flag, which can be cleared by writing data to the data register, or it is automatically cleared by hardware after a start or stop bit is generated, or when PE is 0.  0: The data register is non-empty;  1: When the data is transmitted, the transmit data register is empty.                                                                                         | 0 |

V2. 4 314 WCH°

|          |          |            | Data ragistar not amonth flog Danding and writing           |   |
|----------|----------|------------|-------------------------------------------------------------|---|
|          |          |            | Data register not empty flag. Reading and writing           |   |
|          | DyNE     | DO         | to the data register will clear this bit, or when PE        | 0 |
| 6        | RxNE     | RO         | is 0, the hardware will clear this bit.                     | 0 |
|          |          |            | 0: Data register empty;                                     |   |
| 5        | Dagamad  | DO         | 1: When data is received, data register not empty.          |   |
|          | Reserved | RO         | Reserved.  Stop event flog. After the user reads the status | 0 |
|          |          |            | Stop event flag. After the user reads the status            |   |
|          |          |            | register1, writing to the control register1 will clear      |   |
| 4        | CTODE    | D.C.       | this bit, or when PE is 0, the hardware will clear          | 0 |
| 4        | STOPF    | RO         | this bit.                                                   | 0 |
|          |          |            | 0: No stop event is detected;                               |   |
|          |          |            | 1: After the response, the slave device will detect         |   |
|          | <u> </u> |            | a stop event on the bus.                                    |   |
|          |          |            | 10-bit address header sent flag. After the user             |   |
|          |          |            | reads the status register1, writing to the control          |   |
|          | ADD10    | <b>P</b> ~ | register1 will clear this bit, or when PE is 0, the         | ^ |
| 3        | ADD10    | RO         | hardware will clear this bit.                               | 0 |
|          |          |            | 0: None;                                                    |   |
|          |          |            | 1: In 10-bit address mode, the master device has            |   |
|          |          |            | sent the first address byte.                                |   |
|          |          |            | Byte transmission end flag. After the user reads            |   |
|          |          |            | the status register1, reading and writing to the data       |   |
|          |          |            | register will clear this bit. During transmission,          |   |
|          |          |            | after a start or stop event is initiated, or when PE        |   |
| _        | DITTE    | _          | is 0, this bit will be cleared by hardware.                 | * |
| 2        | BTF      | RO         | 0: None;                                                    | 0 |
|          |          |            | 1: Byte transmission completed. In case of                  |   |
|          |          |            | NOSTRETCH=0: when a new data is sent and the                |   |
|          |          |            | data register has not been written with new data            |   |
|          |          |            | during transmission; when a new byte is received            |   |
| <u> </u> |          |            | but the data register has not been read.                    |   |
|          |          |            | Address transmitted/matched flag. After the user            |   |
|          |          |            | reads the status register 1, the read operation of the      |   |
|          |          |            | status register2 will clear this bit, or when PE is 0,      |   |
|          |          |            | the hardware will clear this bit.                           |   |
|          |          |            | Master mode:                                                |   |
|          |          |            | 0: The address transmission is not finished;                |   |
| ] .      | ADDR     | DIII       | 1: End of address transmission: In 10-bit address           | 0 |
| 1        | ADDR     | RW0        | mode, the bit will be changed to be set after the           | 0 |
|          |          |            | ACK of the second byte of the address is received;          |   |
|          |          |            | in 7-bit address mode, the bit will be set after the        |   |
|          |          |            | ACK of the address is received.                             |   |
|          |          |            | Slave mode:                                                 |   |
|          |          |            | 0: The address does not match or no address is              |   |
|          |          |            | received;                                                   |   |
|          |          |            | 1: The received address matches.                            |   |

V2. 4 315 WH

| 0 | SB | RO | Start bit transmission flag. After reading the status register 1, the operation of writing the data register will clear this bit, or when PE is 0, the hardware will clear this bit. |  |
|---|----|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|   |    |    | will clear this bit.  0: The start bit has not been transmitted;  1: The start bit has been transmitted.                                                                             |  |

# **19.12.7 I2C Status Register 2 (I2Cx\_STAR2) (x=1/2)**Offset address: 0x18

| <br>15 | 14 | 13 | 12  | 11    | 10 | 9 | 8 | 7         | 6               | 5                  | 4               | 3            | 2   | 1        | 0   |
|--------|----|----|-----|-------|----|---|---|-----------|-----------------|--------------------|-----------------|--------------|-----|----------|-----|
|        |    |    | PEC | [7:0] |    |   |   | DUA<br>LF | SMB<br>HOS<br>T | SMB<br>DEFA<br>ULT | GEN<br>CAL<br>L | Reser<br>ved | TRA | BUS<br>Y | MSL |

| Bit    | Name       | Access | Description                                                                                                                                                                                                                           | Reset value |
|--------|------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [15:8] | PEC[7:0]   | RO     | Packet error checking. When PEC is enabled (ENPEC is set), this domain stores the value of PEC.                                                                                                                                       |             |
| 7      | DUALF      | RO     | Matched detection flag. When the stop bit or start bit is generated, or when PE=0, the hardware will clear this bit.  1: The received address matched with OAR2;  0: The received address matched with OAR1.                          |             |
| 6      | SMBHOST    | RO     | SMBus host header flag. When the stop bit or start bit is generated, or when PE=0, the hardware will clear this bit.  1: When SMBTYPE=1 and ENARP=1, the SMBus host address will be received;  0: SMBus host address is not received. | 0           |
| 5      | SMBDEFAULT | RO     | SMBus device default address flag. When the stop bit or start bit is generated, or when PE=0, the hardware will clear this bit.  1: When ENARP=1, the default address of the SMBus device is received;  0: No address is received.    | 0           |
| 4      | GENCALL    | RO     | General call address flag. When the stop bit or start bit is generated, or when PE=0, the hardware will clear this bit.  1: When ENGC=1, the address of general call is received;  0: No general call address is received.            |             |
| 3      | Reserved   | RO     | Reserved.                                                                                                                                                                                                                             | 0           |
| 2      | TRA        | RO     | Transmitter/receiver flag, cleared by hardware when a stop event (STOPF=1) is detected, repeated start condition or bus arbitration is lost (ARLO=1) or PE=0.                                                                         | 0           |

|   |       |      | 1: Data has been sent;                                |   |
|---|-------|------|-------------------------------------------------------|---|
|   |       |      | 0: Data is received.                                  |   |
|   |       |      | This bit is determined by R/W bit of address byte.    |   |
|   |       |      | Bus busy flag. This bit is cleared when a stop bit    |   |
|   |       |      | is detected. When the interface is disabled (PE=0),   |   |
| 1 | DIICV | D.O. | the information is still updated.                     | 0 |
| 1 | BUSY  | RO   | 1: Busy bus: SDA or SCL has a low level;              | U |
|   |       |      | 0: The bus is idle and does not have                  |   |
|   |       |      | communication.                                        |   |
|   |       |      | Master/slave mode indication. When the interface      |   |
|   |       |      | is in master mode (SB=1), the hardware will set       |   |
| 0 | MSL   | RO   | this bit. When the bus detects a stop bit and the     | 0 |
|   |       |      | arbitration is lost, or PE=0, the hardware will clear |   |
|   |       |      | this bit.                                             |   |

## 19.12.8 I2C Clock Register (I2Cx\_CKCFGR) (x=1/2)

Offset address: 0x1C

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0

F/S DUT Reserved CCR[11:0]

| Bit     | Name      | Access | Description                                               | Reset value |
|---------|-----------|--------|-----------------------------------------------------------|-------------|
|         |           |        | Master mode selection.                                    |             |
| 15      | F/S       | RW     | 0: Standard mode;                                         | 0           |
|         |           |        | 1: Fast mode.                                             |             |
|         |           |        | Duty cycle in the fast mode:                              |             |
| 14      | DUTY      | RW     | 0: T <sub>Low level</sub> /T <sub>High level</sub> =2;    | 0           |
|         |           |        | 1: T <sub>Low level</sub> /T <sub>High level</sub> =16/9. |             |
| [13:12] | Reserved  | RO     | Reserved.                                                 | 0           |
| F1.1.03 | CCD[11 A] | DW     | Clock frequency division factor. These bits determine     | 0           |
| [11:0]  | CCR[11:0] | RW     | the frequency waveform of the SCL clock.                  | 0           |

# 19.12.9 I2C Rise Time Register (I2Cx\_RTR) (x=1/2)

Offset address: 0x20

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0

Reserved TRISE[5:0]

| Bit    | Name       | Access | Description                                                                                                                                                                                                                                          | Reset value |
|--------|------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [15:6] | Reserved   | RO     | Reserved.                                                                                                                                                                                                                                            | 0           |
| [5:0]  | TRISE[5:0] | RW     | Maximum rise time domain. The rise time of SCL in master mode is set at this bit. The maximum rising edge time is equal to TRISE-1 clock cycle. This bit can only be set when PE is cleared. For example, if the input clock cycle of the IIC module | 000010Ь     |

| is 125ns and the value of TRISE is 9, then the |
|------------------------------------------------|
| maximum rising edge time is (9-1)*125ns, i.e., |
| 1000ns.                                        |

# **Chapter 20 Serial Peripheral Interface (SPI/I2S)**

#### This chapter applies to the whole family of CH32F20x, CH32V20x, CH32V30x and CH32V31x.

SPI supports data exchange in 3-wire synchronous serial mode, and the chip select line supports hardware switching between master and slave modes, and supports communication with a single data line.

I2S is also a 3-wire synchronous serial interface communication protocol, which supports 4 audio standards, including Philips I2S standard, MSB alignment standard, LSB alignment standard and PCM standard.

#### **20.1 Main Features**

#### 20.1.1 SPI Features

- Supports full-duplex synchronous serial mode
- Supports 1-wire half-duplex mode
- Support master mode and slave mode, multi-slave mode
- Supports 8-bit or 16-bit data structures
- The highest clock frequency is supported to half of Fpclk
- Data ordering supports MSB or LSB first
- Supports hardware or software control of the NSS pin
- Transceiver supports hardware CRC
- Transceiver buffer supports DMA transfer
- Supports modifying clock phase and polarity

#### 20.1.2 I2S Features

- Support simplex communication
- Supports master mode and slave mode
- Supports 16-bit, 24-bit and 32-bit data formats
- Audio sampling frequency support range 8kHz-562.2kHz
- Supports clock polarity programmable
- Support common I2S protocols: Philips standard, MSB alignment standard, LSB alignment standard and PCM standard
- Transceiver buffer supports DMA transfer
- Support master clock output to external audio equipment

# 20.2 SPI functional Description

### 20.2.1 Overview

Address and data bus Read Rx buffer SPI\_CTLR2 MOSI RXNE TXDM RXDM 0 SS0E ΙE AEN AEN Shift register MISO STATR LSB first **BSY** 0VR MODF 0 TXE RXNE Tx buffer Write Communication control SCK Baud rate BR[2:0] generator LSB SPE BR2 BR1 BR0 MSTR CP0L **CPHA** FIRST SPI CTLR1 Master control logic BIDI CRC CRC BIDI SS MODE ONI Y EN Next NSS

Figure 20-1 SPI structure diagram

As can be seen from Figure 20-1, the 4 pins related to SPI are MISO, M0SI, SCK and NSS. The MISO pin is the data input pin when the SPI module works in the master mode; it is the data output pin when it works in the slave mode. When the MOSI pin works in master mode, it is a data output pin; when it works in slave mode, it is a data input pin. SCK is the clock pin, the clock signal is always output by the master, and the slave receives the clock signal and synchronizes data transmission and reception. The NSS pin is a chip select pin and has the following uses:

- NSS is controlled by software: At this time, SSM is set, and the internal NSS signal is determined by SSI
  to output high or low. This situation is generally used in SPI master mode;
- NSS is controlled by hardware: When the NSS output is enabled, i.e., when SSOE is set, the NSS pin will be actively pulled down when the SPI host sends the output outward, and a hardware error will be generated if the NSS pin cannot be successfully pulled down and pulled down, indicating that there are other host devices on the main line that are communicating; SSOE If it is not set, it can be used in multi-master mode. If it is pulled low, it will be forced into slave mode, and the MSTR bit will be automatically cleared.

The working mode of the SPI can be configured through CPHA and CPOL. If CPHA is set, it means that the module samples the data on the second edge of the clock, and the data is latched. If CPHA is not set, it means that the SPI module samples on the first edge of the clock, and the data is latched. CPOL indicates whether the

clock remains high or low when there is no data. See Figure 20-2 below for details.



Figure 20-2 SPI model

The host and device need to be set to the same SPI mode, and the SPE bit needs to be cleared before configuring the SPI mode. The DEF bit can decide whether the single data length of SP is 8 bits or 16 bits. LSBFIRST can control whether a single data word is big-endian or little-endian.

### 20.2.2 Master Mode

When the SPI module works in master mode, the serial clock is generated by SCK. To configure into master mode do the following steps:

Configure the BR[2:0] bits in the control register to determine the clock;

Configure the CPOL and CPHA bits to determine the SPI mode;

Configure DEF to determine the data word length;

Capture strobe

Configure LSBFIRST to determine the frame format;

Configure the NSS pin, such as setting the SSOE bit to let the hardware reset NSS. You can also set the SSM bit and set the SSI bit high;

To set the MSTR bit and the SPE bit, it is necessary to ensure that NSS is already high at this time.

When you need to send data, you only need to write the data to be sent to the data register. SPI will send data from the transmit buffer to the shift register in parallel, and then send the data from the shift register according to the setting of LSBFIRST. When the data has reached the shift register, the TXE flag will be set. If it has been set TXEIE, then an interrupt will be generated. If the TXE flag bit is set, data needs to be filled into the data register to maintain a complete data flow.

When the receiver receives data, when the last sampling clock edge of the data word arrives, the data is transferred from the shift register to the receive buffer in parallel, the RXNE bit is set, and if the RXNEIE bit was previously set, it will also generate interrupt. At this time, the data register should be read as soon as possible to remove the data.

#### 20.2.3 Slave Mode

When the SPI module works in slave mode, SCK is used to receive the clock sent by the host, and its own baud rate setting is invalid. The steps to configure into slave mode are as follows:

Configure the DEF bit to set the data bit length;

Configure the CPOL and CPHA bits to match the host mode;

Configure LSBFIRST to match the host data frame format;

In hardware management mode, the NSS pin needs to be kept at a low level. If NSS is set to software management (SSM is set), then please keep SSI not set;

Clear the MSTR bit and set the SPE bit to enable SPI mode.

When transmitting, when the first slave receive sampling edge occurs on SCK, the slave starts to transmit. The process of sending is to move the data in the send buffer to the send shift register. When the data in the send buffer is moved to the shift register, the TXE flag will be set. If the TXEIE bit was previously set, an interrupt will be generated.

When receiving, after the last clock sampling edge, the RXNE bit is set, the byte received by the shift register is transferred to the receive buffer, and the read operation of the read data register can obtain the data in the receive buffer. An interrupt will be generated if RXNEIE is set before RXNE is set.

### 20.2.4 Simplex Mode

The SPI interface can work in half-duplex mode, that is, the master device uses the MOSI pin, and the slave device uses the MISO pin for communication. When using half-duplex communication, BIDIMODE needs to be set, and BIDIOE is used to control the transmission direction.

Setting the RXONLY bit in normal full-duplex mode can set the SPI module to receive-only simplex mode. After RXONLY is set, a data pin will be released. The pins released in master mode and slave mode are not the same. It is also possible to ignore the received data and set the SPI to transmit-only mode.

### 20.2.5 CRC

The SPI module uses CRC to ensure the reliability of full-duplex communication, and separate CRC calculators are used for data transmission and reception. The polynomial of the CRC calculation is determined by the polynomial register. For 8-bit data width and 16-bit data width, different calculation methods are used respectively.

Setting the CRCEN bit enables CRC and resets the CRC calculator. After the last data byte is sent, setting the CRCNEXT bit will send the calculation result of the TXCRCR calculator after the current byte is sent. At the same time, if the last received value of the receive shift register is not the same as the locally calculated value

of RXCRCR, then the CRCERR bit will be set. To use the CRC, you need to set the polynomial calculator and set the CRCEN bit when configuring the SPI working mode, and set the CRCNEXT bit in the last word or half word to send the CRC and check the received CRC. Note that the CRC calculation polynomials of the sender and receiver should be unified.

#### 20.2.6 DMA

The SPI module supports the use of DMA to speed up data communication. You can use DMA to fill in data into the send buffer, or use DMA to take data from the receive buffer in time. DMA will take or send data in time with RXNE and TXE as signals. DMA can also work in simplex or CRC mode.

#### 20.2.7 Error

#### Master mode failure error

When the SPI works in the NSS pin hardware management mode, an external operation of pulling down the NSS pin occurs; or in the NSS pin software management mode, the SSI bit is cleared; or the SPE bit is cleared, causing the SPI to be turned off; or the MSTR bit is cleared, the SPI enters slave mode. An interrupt will also be generated if the ERRIE bit has been set. Clear MODF bit steps: first perform a read or write operation to R16 SPI1 STATR, and then write to R16 SPI1 CTLR1.

#### Overflow error

If the master sends data and there is unread data in the slave's receive buffer, an overrun error occurs, the OVR bit is set, and an interrupt is generated if ERRIE is set. Sending an overflow error should restart the current transfer. Reading the data register followed by the status register will clear this bit.

### • CRC error

When the received CRC word does not match the value of RXCRCR, a CRC error will occur, and the CRCERR bit will be set.

# 20.2.8 Interrupt

The interrupt of the SPI module supports 5 interrupt sources. The 2 events of the send buffer empty and the receive buffer non-empty will set TXE and RXNE respectively, and an interrupt will be generated when the TXEIE and RXNEIE bits are set respectively. In addition, the 3 errors mentioned above will also generate interrupts, namely MODF, OVR and CRCERR. After the ERRIE bit is enabled, these 3 errors will also generate error interrupts.

# 20.3 I2S Functional Description

### 20.3.1 I2S Overview

Figure 20-3 I2S structure diagram



The I2S function is enabled by setting the I2SMOD bit in register I2SCFGR. At this point, the SPI module can be used as an I2S audio interface. I2S and SPI share 3 pins:

- SD: Serial data (Mapped to MOSI pin), used to send and receive 2 time-multiplexed data channels;
- WS: word selection (Mapped to NSS pin), output as data control signal in master mode, and input in slave mode;
- CK: Serial clock (Mapped to the SCK pin), output as a clock signal in master mode, and input in slave mode.

When the main clock is required for some external audio devices, there is an additional pin to output the clock:

• MCK: main clock (Independent mapping), when the I2S is configured as the main mode and the MCKOE bit of the register I2SPR is 1, it is used as an output additional clock signal pin. The frequency of the output clock signal is preset to 256×Fs, where Fs is the sampling frequency of the audio signal.

V2. 4 324 WH

When set to master mode, I2S uses its own clock generator to generate the clock signal for communication. This clock generator is also the clock source for the master clock output. There are 2 additional registers in I2S mode, one is the clock generator configuration related register I2SPR, the other is the I2S general configuration register I2SCFGR (Can set the audio standard, slave/master mode, data format, packet frame, clock pole parameters, etc.). Register CTLR1 and all CRCR registers are not used in I2S mode. Similarly, the SSOE bit in the CTLR2 register, and the MODF bit and the CRCERR bit in the register STATR are not used in the I2S mode. I2S uses the same register DATAR as SPI for 16-bit wide mode data transfer.

## 20.3.2 Supported Audio Protocols

The 3-wire bus supports time division multiplexing of audio data on 2 channels: left and right, but only one 16-bit register is used for transmit or receive. Therefore, when writing data to the data register, the software must write the corresponding data according to the channel currently being transmitted; similarly, when reading the register data, check the CHSIDE bit of the register STATR to determine which channel the received data belongs to. The left channel always sends data before the right channel (The CHSIDE bit has no meaning under the PCM protocol). There are 4 available data and packet frame combinations. Data can be sent in the following 4 data formats:

- 16-bit data is packed into 16-bit frames
- 16-bit data is packed into 32-bit frames
- 24-bit data is packed into 32-bit frames
- 32-bit data is packed into 32-bit frames

When using 16-bit data to expand to a 32-bit frame, the first 16 bits (MSB) are meaningful data, and the last 16 bits (LSB) are forced to 0. This operation requires no software intervention and no DMA request (Only requires a read or write operation). 24-bit and 32-bit data frames require the CPU to perform 2 read or write operations on the register DATAR, and 2 DMA transfers are required when using DMA. For 24-bit data, after expansion to 32 bits, the lowest 8 bits are set to 0 by hardware. For all data formats and communication standards, the most significant bit (MSB) is always sent first. The I2S interface supports 4 audio standards, which can be selected by setting the I2SSTD[1:0] bits and PCMSYNC bits in the I2SCFGR register.

# 20.3.2.1 I2S Philips Standard

Under this standard, pin WS is used to indicate which channel the data being sent belongs to. The pin is valid 1 clock cycle before the first data bit (MSB) is sent. The sender changes the data on the falling edge of the clock signal (CK) and the receiver reads the data on the rising edge. The WS signal also changes on the falling edge of the clock signal.

CK
WS
Transmission
Reception
SD
Maybe16-bit, 32-bit
Chamle left
Chamle right

Figure 20-4 Philips protocol waveform (16/32 full precision, CPOL=0)





This mode requires 2 read or write operations to the SPI\_DATAR register. In transmit mode: if you need to send 0x8EAA33 (24 bits):



In receive mode: if 0x8EAA33 is received:



CK

Transmission

Reception

16-bit data

16-bit remaining
0 forced

Channel left 32-bit

Channel right

Figure 20-6 Philips protocol standard waveforms (16-bit extended to 32-bit packet frame, CPOL=0)

In the I2S configuration stage, if you choose to extend the 16-bit data to a 32-bit channel frame, you only need to access the register DATAR once to extend to 32-bit. The lower 16 bits are set to 0x0000 by hardware. If the data to be transmitted or received is 0x76A3 (Extended to 32 bits is 0x76A30000), only one operation of DATAR is required. When sending, the MSB needs to be written into the register DATAR; if the flag bit TXE is 1, it means that new data can be written, and if the corresponding interrupt is allowed, an interrupt can be generated. The transmission is done by hardware, even if the last 16 bits of 0x0000 have not been sent, the TXE will be set and the corresponding interrupt will be generated. When receiving, each time the upper 16-bit half-word (MSB) is received, the flag bit RXNE is set to 1, and if the corresponding interrupt is enabled, an interrupt can be generated. This way, there is more time between the 2 reads and writes, preventing underflow or overflow conditions.

### 20.3.2.2 MSB alignment standard

Under this standard, the WS signal and the first data bit, the most significant bit (MSB), are generated simultaneously.



Figure 20-7 MSB aligned 16-bit or 32-bit full precision (CPOL = 0)

The sender changes data on the falling edge of the clock signal; the receiver reads data on the rising edge.



Figure 20-8 MSB aligned 24-bit data, CPOL = 0

Figure 20-9 MSB-aligned 16-bit data extended to 32-bit packet frame, CPOL = 0



# 20.3.2.3 LSB alignment standard

This standard is similar to the MSB alignment standard (No difference in 16-bit or 32-bit full-precision frame format).

Figure 20-10 LSB-aligned 16- or 32-bit full precision, CPOL = 0



Figure 20-11 LSB-aligned 24-bit data, CPOL = 0



In transmit mode, if you want to send data 0x3478AE, you need to write the register DATAR twice by software or DMA.



In receive mode, if you want to receive data 0x3478AE, you need to read the register DATAR once when 2 consecutive RXNE events occur.



Figure 20-12 LSB aligned 16-bit data extended to 32-bit packet frame, CPOL = 0



During the I2S configuration stage, if you choose to extend the 16-bit data to a 32-channel frame, you only need to access the DATAR register once. At this point, the high half word (16-bit MSB) after extending to 32 bits is set to 0x0000 by hardware.

If the data to be transmitted or received is 0x76A3 (Extended to 32 bits is 0x000076A3), only one operation of DATAR is required. When sending, if TXE is 1, the user needs to write the data to be sent (i.e. 0x76A3). The 0x0000 part, which is used to extend to 32 bits, is first sent by the hardware, and once the valid data starts to be sent from the SD pin, the next TXE event occurs. On reception, the RXNE event occurs as soon as valid data is received (Instead of the 0x0000 part). This way, there is more time between the 2 reads and writes, preventing underflow or overflow conditions.

### 20.3.2.4 PCM standard

Under the PCM standard, there is no information for channel selection. The PCM standard has 2 available frame structures, short or long, which can be selected by setting the PCMSYNC bit in register I2SCFGR.



Figure 20-13 PCM standard waveform (16-bit)

For the long frame, in the main mode, the valid time of the WS signal used for synchronization is fixed to 13 bits. For short frames, the length of the WS signal used for synchronization is only 1 bit.



Figure 20-14 PCM standard waveform (16-bit)

No matter which mode (Master or slave), which synchronization method (Short frame or long frame), the time difference between 2 consecutive frames of data and between 2 synchronization signals, (Even in slave mode) needs to be set by setting the I2SCFGR register determined by the DATLEN bit and the CHLEN bit.

V2. 4 330 WCH<sup>\*</sup>

### 20.3.3 Clock Generator

The bit rate of I2S determines the data flow on the I2S data line and the frequency of the I2S clock signal. I2S bit rate = number of bits per channel  $\times$  number of channels  $\times$  audio sampling frequency.

For a signal with left and right channels and 16-bit audio, the I2S bit rate is calculated as follows:

I2S bit rate = 
$$16 \times 2 \times Fs$$

If the packet length is 32 bits, the I2S bit rate is calculated as follows:

I2S bit rate = 
$$32 \times 2 \times Fs$$

Figure 20-15 Audio sampling frequency definition



In master mode, the linear divider needs to be set correctly in order to obtain the desired audio frequency.



Figure 20-16 I2S clock generator structure

The clock source of I2SxCLK in the figure is the system clock (i.e., the HSI, HSE, or PLL that drives the HB clock). I2SxCLK can come from SYSCLK, or the PLL3 VCO (2xPLL3CLK) clock, which can be selected by the I2S2SRC and I2S3SRC bits in the RCC\_CFGR2 register. Audio can be sampled at 96kHz, 48kHz, 44.1kHz, 32kHz, 22.05kHz, 16kHz, 11.025kHz, or 8kHz (Or any value within this range). To obtain the desired frequency, set the linear divider according to the following formula:

When the master clock needs to be generated (The MCKOE bit of the register SPI\_I2SPR is 1): When the frame length of the channel is 16 bits, Fs = I2SxCLK / [(16\*2)\*((2\*I2SDIV) + ODD)\*8] When the frame length of the channel is 32 bits, Fs = I2SxCLK / [(32\*2)\*((2\*I2SDIV) + ODD)\*4]

When the main clock is turned off (MCKOE bit is '0'):

When the frame length of the channel is 16 bits,  $F_s = I2SxCLK / [(16*2)*((2*I2SDIV) + ODD)]$ 

When the frame length of the channel is 32 bits,  $F_s = I2SxCLK / [(32*2)*((2*I2SDIV) + ODD)]$ 

### 20.3.4 I2S Master Mode

Set I2S to work in master mode, the serial clock is output by pin CK, and the word selection signal is generated by pin WS. The master clock (MCK) can be selected to be output or not output by setting the MCKOE bit in register I2SPR.

### 20.3.4.1 Configuration Process

- Set I2SDIV[7:0] in the I2SPR register to define the serial clock baud rate corresponding to the audio sampling frequency. Also define the ODD bit of the register I2SPR.
- Set the CKPOL bit to define the level state of the communication clock when it is idle. If the main clock MCK needs to be provided to the external DAC/ADC audio device, the MCKOE position of the register I2SPR is required.
- Set the I2SMOD bit in the I2SCFGR register to 1 to activate the I2S function, set the I2SSTD[1:0] and PCMSYNC bits to select the I2S standard used, and set CHLEN to select the number of data bits per channel. Also set the I2SCFG[1:0] in the SPI\_I2SCFGR register to select the I2S master mode and direction (transmitter or receiver).
- If required, the required interrupt function and DMA function can be turned on by setting register CR2.
- The I2SE bit in the I2SCFGR register must be set to 1.
- Pins WS and CK need to be configured for output mode. If the MCKOE bit in the SPI\_I2SPR register is 1, the pin MCK is also configured to output mode.

#### 20.3.4.2 Transmission Process

The transmission process starts when 1 half word (16 bits) of data is written to the transmit buffer. It is assumed that the first data written to the transmit buffer corresponds to the left channel data. When the data is moved from the transmit buffer to the shift register, the flag bit TXE is set to 1. At this time, the data corresponding to the right channel should be written into the transmit buffer. The flag bit CHSIDE indicates which channel the data to be transmitted currently corresponds to. The value of the flag bit CHSIDE is updated when TXE is 1, so it has meaning when TXE is 1. After the data of the left channel and then the right channel have been transmitted, it can be regarded as a complete data frame. It is not possible to transmit only part of the data frame, such as data only for the left channel.

When the first bit of data is sent out, the half-word data is transferred to the 16-bit shift register in parallel, and then the following bits are sent out from pins MOSI/SD in high-order first. Each time data is moved from the transmit buffer to the shift register, the flag bit TXE is set to 1, and an interrupt is generated if the TXEIE bit in the CR2 register is 1.

In order to ensure continuous audio data transmission, it is recommended to write the next data to be transmitted to the register DATAR before the current transmission is completed. It is recommended to wait for the flag bit TXE=1 and BSY=0 when the I2S function is to be turned off, and then clear the I2SE bit to '0'.

#### 20.3.4.3 Reception Process

Except for point 3, the configuration steps of the reception process are consistent with the transmission process (See the aforementioned "transmission process"). It is necessary to select the main reception mode by

configuring I2SCFG[1:0]. Regardless of the data and channel length, audio data is always received in 16-bit packets. That is, after the receive buffer is filled up each time, the flag bit RXNE is set to 1, and if the RXNEIE bit of the register CR2 is 1, an interrupt is generated. Depending on the configured data and channel length, receiving data from the left or right channel will require 1/2 times to transmit the data to the receive buffer. The RXNE flag is cleared by reading the DATAR register. CHSIDE is updated after each reception. Its value depends on the WS signal generated by the I2S unit. If the previous received data has not been read, and new data is received, that is, an overflow occurs, and the flag bit OVR is set to 1. If the ERRIE bit in the CR2 register is 1, an interrupt is generated, indicating that an error has occurred. To disable I2S, special operations need to be performed to ensure that the I2S module can normally complete the transfer cycle without starting a new data transfer. The operation process is related to the data configuration and channel length, and the mode of the audio protocol:

- 16-bit data extended to 32-bit channel length (DATLEN=00 and CHLEN=1), using LSB (Low bit) alignment mode (I2SSTD=10)
  - a) Wait for the penultimate (n-1) RXNE=1;
  - b) Wait for 17 I2S clock cycles (Using software delay);
  - c) Disable I2S (I2SE=0).
- 16-bit data extended to 32-bit channel length (DATLEN=00 and CHLEN=1), using MSB (High bit) alignment, I2S or PCM mode (I2SSTD=00, I2SSTD=01 or I2SSTD=11 respectively)
  - a) Wait for the last RXNE=1;
  - b) Wait for 1 I2S clock cycle (Using software delay);
  - c) Disable I2S (I2SE=0).
- For all other combinations of DATLEN and CHLEN, any audio mode selected by I2SSTD, use the following method to turn off I2S:
  - a) Wait for the penultimate (n-1) RXNE=1;
  - b) Wait for one I2S clock cycle (Using software delay);
  - c) Disable I2S (I2SE=0).

Note: The BSY flag is always low during transmission.

### 20.3.5 I2S Slave Mode

In slave mode, I2S can be set to transmission and reception mode. The configuration method of the slave mode basically follows the same process as the configuration of the master mode. In slave mode, no clock is required from the I2S interface. Both the clock signal and the WS signal are provided by an external master I2S device connected to the corresponding pins. So the user does not need to configure the clock.

- The configuration steps are as follows:
- Set the I2SMOD bit in the I2SCFGR register to activate the I2S function; set I2SSTD[1:0] to select the I2S standard used; set DATLEN[1:0] to select the number of data bits; set CHLEN to select the number of data bits per channel. Set the I2SCFG[1:0] in the I2SCFGR register to select the data direction (transmitter or receiver) of the I2S slave mode.
- As needed, set register CR2 to turn on the desired interrupt function and DMA function.
- The I2SE bit in the I2SCFGR register must be set to 1.

#### 20.3.5.1 Transmission Process

The transmission process starts when the external master sends a clock signal, and when the NSS\_WS signal requests data transmission. The slave device must be enabled and the I2S data register must be written before the external master device can start communication. For the MSB-aligned and LSB-aligned modes of I2S, the

first data item written to the data register corresponds to the data of the left channel. When the communication starts, the data is transferred from the transmit buffer to the shift register, and then the flag bit TXE is set to 1; at this time, the data item corresponding to the right channel should be written into the I2S data register. The flag bit CHSIDE indicates which channel the data to be transmitted currently corresponds to. Compared to the transmit flow in master mode, in slave mode, CHSIDE depends on the WS signal from the external master I2S. This means that the slave I2S has to prepare the first data to be sent before receiving the clock signal generated by the master. A WS signal of 1 means that the left channel is sent first.

#### 20.3.5.2 Reception Process

Except for point 1, the configuration steps are the same as the transmission process. The master reception mode needs to be selected by configuring I2SCFG[1:0]. Regardless of the data and channel length, audio data is always received in the form of 16-bit packets, that is, every time the receive buffer is filled, the flag bit RXNE is set to 1, and if the RXNEIE bit in the I2S\_CTLR2 register is 1, an interrupt is generated. According to different data and channel length settings, receiving left channel or right channel data will require 1 or 2 times to transmit data to the receive buffer. CHSIDE is updated every time data is received (to be read out from DATAR), which corresponds to the WS signal generated by the I2S unit. Reading the SPI\_DATAR register will clear the RXNE bit. When the previous received data has not been read out and new data is received, an overflow occurs, and the flag bit OVR is set to 1; if the ERRIE bit in the register I2S\_CTLR2 is 1, an interrupt is generated, indicating that an error has occurred. To turn off the I2S function, it is necessary to clear the I2SE bit to 0 when the last RXNE=1 is received.

# 20.3.6 Status Flag

There are 3 status flags for the user to monitor the status of the I2S bus.

## 20.3.6.1 Busy Flag (BSY)

The BSY flag is set and cleared by hardware (writing this bit has no effect). This flag bit indicates the status of the I2S communication layer. When this bit is 1, it indicates that I2S communication is in progress, with one exception: in master receive mode (I2SCFG=11), the BSY flag is always low during reception. Before the software closes the SPI module, the BSY flag can be used to detect whether the transfer is over, so as to avoid destroying the last transfer, so it is necessary to strictly follow the procedure below. When a transfer starts, the BSY flag is set to 1, unless the I2S module is in master receive mode. This flag is cleared when the transfer ends or when the I2S module is turned off. When communication is continuous, in master transmit mode, the BSY flag is always high during the entire transfer; in slave mode, between each data item transmission, the BSY flag goes low within 1 I2S clock cycle.

# 20.3.6.2 TX Buffer Empty Flag (TXE)

When the flag bit is 1, it indicates that the sending buffer is empty, and new data to be sent can be written into the sending buffer. When there is data in the transmit buffer, the flag bit is cleared to 0. When I2S is turned off (I2SE bit is 0), this flag is also 0.

## 20.3.6.3 RX Buffer Not Empty Flag (RXNE)

Setting this flag bit indicates that there is valid data received in the receive buffer. This bit is cleared to 0 when the DATAR register is read.

#### **20.3.6.4 Channel Side Flag (CHSIDE)**

In transmit mode, this flag is refreshed when TXE is high, indicating which channel the data is sent from the SD pin. If an underflow error occurs in the slave sending mode, the value of this flag is invalid, and the I2S needs to be turned off and on before restarting the communication. In receive mode, this flag bit is refreshed when the register DATAR receives data, indicating the channel where the received data is located. Note that if an error occurs, this flag is meaningless, and I2S needs to be turned off and on again. Under the PCM standard, no matter the short frame format or the long frame format, this flag has no meaning. If the flag bit OVR or UDR in the STATR register is 1, and the ERRIE bit in the CR2 register is 1, an interrupt will be generated. (After the interrupt source has been cleared) The interrupt flag can be cleared by reading the STATR register.

### 20.3.7 Error Flag

### 20.3.7.1 Underrun Flag (UDR)

In the slave transmit mode, if the new data has not been written to the DATAR register when the first clock edge of the data transfer arrives, this flag will be set to 1. This flag is valid only after the I2SMOD bit of the register I2SCFGR is set. An interrupt will be generated if the ERRIE bit in register CR2 is 1. This flag is cleared by reading the STATR register.

### 20.3.7.2 Overrun Flag (OVR)

If the previous received data has not been read, and new data is received, that is, an overflow occurs, and the flag is set to 1. If the ERRIE bit of the register CTLR2 is 1, an interrupt is generated to indicate that an error has occurred. At this time, the content of the receiving buffer will not be refreshed with the new data sent from the sending device. A read of register DATAR returns the last correctly received data. All other 16-bit data sent by the sending device after the overflow occurs are lost. This flag is cleared by first reading the DATAR register and then reading the STATR register.

### 20.3.8 I2S Interrupt

I2S has 4 interrupt sources, of which the send buffer is empty and the receive buffer is not empty. These 2 events will set TXE and RXNE respectively, and an interrupt will be generated when the TXEIE and RXNEIE bits are set respectively. If the previous received data has not been read out, new data is received, that is, an overflow occurs. If ERRIE is set, an overflow interrupt will be generated; in slave transmit mode, if the first clock of data transmission When the edge arrives, the new data is still not written to the DATAR register. If ERRIE is set, an underflow interrupt will be generated.

#### 20.3.9 DMA Features

The way DMA works in I2S mode is exactly the same as in SPI mode except that the CRC function is not available. Because there is no data transmission protection system in I2S mode.

# 20.4 Register Description

Table 20-1 SPI1 registers

| Name           | Access address | Description            | Reset value |
|----------------|----------------|------------------------|-------------|
| R16_SPI1_CTLR1 | 0x40013000     | SPI1 control register1 | 0x0000      |
| R16_SPI1_CTLR2 | 0x40013004     | SPI1 control register2 | 0x0000      |
| R16_SPI1_STATR | 0x40013008     | SPI1 status register   | 0x0002      |
| R16_SPI1_DATAR | 0x4001300C     | SPI1 data register     | 0x0000      |

| R16_SPI1_CRCR     | 0x40013010 | SPI1 polynomial register         | 0x0007 |
|-------------------|------------|----------------------------------|--------|
| R16_SPI1_RCRCR    | 0x40013014 | SPI1 receive CRC register        | 0x0000 |
| R16_SPI1_TCRCR    | 0x40013018 | SPI1 transmit CRC register       | 0x0000 |
| R16_SPI1_I2S_CFGR | 0x4001301C | SPI1 I2S configuration register  | 0x00   |
| R16_SPI1_HSCR     | 0x40013024 | SPI1 high-speed control register | 0x00   |

# Table 20-2 SPI2 registers

| Name              | Access address | Description                      | Reset value |
|-------------------|----------------|----------------------------------|-------------|
| R16_SPI2_CTLR1    | 0x40003800     | SPI2 control register1           | 0x0000      |
| R16_SPI2_CTLR2    | 0x40003804     | SPI2 control register2           | 0x0000      |
| R16_SPI2_STATR    | 0x40003808     | SPI2 status register             | 0x0002      |
| R16_SPI2_DATAR    | 0x4000380C     | SPI2 data register               | 0x0000      |
| R16_SPI2_CRCR     | 0x40003810     | SPI2 polynomial register         | 0x0007      |
| R16_SPI2_RCRCR    | 0x40003814     | SPI2 receive CRC register        | 0x0000      |
| R16_SPI2_TCRCR    | 0x40003818     | SPI2 transmit CRC register       | 0x0000      |
| R16_SPI2_I2S_CFGR | 0x4000381C     | SPI2 I2S configuration register  | 0x00        |
| R16_SPI2_I2SPR    | 0x40003820     | SPI2 I2S prescaler register      | 0x00        |
| R16_SPI2_HSCR     | 0x40003824     | SPI2 high-speed control register | 0x00        |

# Table 20-3 SPI3 registers

| Name              | Access address | Description                      | Reset value |
|-------------------|----------------|----------------------------------|-------------|
| R16_SPI3_CTLR1    | 0x40003C00     | SPI3 control register1           | 0x0000      |
| R16_SPI3_CTLR2    | 0x40003C04     | SPI3 control register2           | 0x0000      |
| R16_SPI3_STATR    | 0x40003C08     | SPI3 status register             | 0x0002      |
| R16_SPI3_DATAR    | 0x40003C0C     | SPI3 data register               | 0x0000      |
| R16_SPI3_CRCR     | 0x40003C10     | SPI3 polynomial register         | 0x0007      |
| R16_SPI3_RCRCR    | 0x40003C14     | SPI3 receive CRC register        | 0x0000      |
| R16_SPI3_TCRCR    | 0x40003C18     | SPI3 transmit CRC register       | 0x0000      |
| R16_SPI3_I2S_CFGR | 0x40003C1C     | SPI3 I2S configuration register  | 0x00        |
| R16_SPI3_I2SPR    | 0x40003C20     | SPI3 I2S prescaler register      | 0x00        |
| R16_SPI3_HSCR     | 0x40003C24     | SPI3 high-speed control register | 0x00        |

# 20.4.1 SPI Control Register 1 (SPIx\_CTLR1) (x=1/2/3)

Offset address: 0x00

| 1 | 5          | 14         | 13        | 12          | 11  | 10         | 9   | 8   | 7            | 6   | 5 | 4       | 3 | 2        | 1        | 0        |
|---|------------|------------|-----------|-------------|-----|------------|-----|-----|--------------|-----|---|---------|---|----------|----------|----------|
|   | IDI<br>ODE | BIDI<br>OE | CRC<br>EN | CRC<br>NEXT | DFF | RX<br>ONLY | SSM | SSI | LSB<br>FIRST | SPE |   | BR[2:0] |   | MST<br>R | CPO<br>L | CPH<br>A |

| Bit | Name     | Access | Description                                    | Reset value |
|-----|----------|--------|------------------------------------------------|-------------|
|     |          |        | Unidirectional data mode enable.               |             |
| 15  | BIDIMODE | RW     | 0: 2-wire bidirectional mode;                  | 0           |
|     |          |        | 1: 1-wire bidirectional mode.                  |             |
|     |          |        | Single-line output enable, used in conjunction |             |
| 14  | BIDIOE   | RW     | with BIDIMODE.                                 | 0           |
|     |          |        | 0: Disable output, only receive;               |             |

|       |          |      | 1: Enable output, only transmit.                    |   |
|-------|----------|------|-----------------------------------------------------|---|
|       |          |      | Hardware CRC check enable, this bit can only be     |   |
|       |          |      | written when SPE is 0, this bit can only be used in |   |
| 13    | CRCEN    | RW   | full duplex mode.                                   | 0 |
|       |          |      | 0: Disable CRC calculation;                         |   |
|       |          |      | 1: Enable CRC calculation.                          |   |
|       |          |      | Value of the transmit CRC register after next data  |   |
|       |          |      | transfer. This bit should be set immediately after  |   |
|       | an ar    |      | writing the last data to the data register.         | ^ |
| 12    | CRCNEXT  | RW   | 0: Continue to transmit the data of the data        | 0 |
|       |          |      | register;                                           |   |
|       |          |      | 1: Transmit the CRC result.                         |   |
|       |          |      | Data frame length, this bit can only be written     |   |
|       |          |      | when SPE is 0.                                      |   |
| 11    | DFF      | RW   | 0: Use 8-bit data length for transmission and       | 0 |
|       |          |      | reception;                                          |   |
|       |          |      | 1: Use 16-bit data length to transmit and receive.  |   |
|       |          |      | Rx only in 2-wire mode. It is used in conjunction   |   |
|       |          |      | with BIDIMODE. Setting this bit allows the          |   |
| 10    | RXONLY   | RW   | device to only receive and not transmit.            | 0 |
|       |          |      | 0: Full-duplex mode;                                |   |
|       |          |      | 1: Receive only, simplex mode.                      |   |
|       |          |      | CS pin management, this bit determines whether      |   |
|       |          | RW   | the level of the NSS pin is controlled by hardware  |   |
| 9     | SSM      |      | or software.                                        | 0 |
|       |          |      | 0: Hardware controls NSS pin;                       |   |
|       |          |      | 1: Software control NSS pin.                        |   |
|       |          |      | CS pin control. When SSM is set, this bit           |   |
| 8     | SSI      | RW   | determines the level of the NSS pin.                | 0 |
| 9     |          | 10,, | 0: NSS is low level;                                | Ü |
|       |          |      | 1: NSS is high level.                               |   |
|       |          |      | Frame format control. This bit cannot be modified   |   |
| 7     | LSBFIRST | RW   | during communication.                               | 0 |
| •     | 1        |      | 0: Transmit MSB first;                              | - |
|       |          |      | 1: Transmit LSB first.                              |   |
| _     |          |      | SPI enable.                                         | _ |
| 6     | SPE      | RW   | 0: Disable SPI;                                     | 0 |
|       |          |      | 1: Enable SPI.                                      |   |
|       |          |      | Baud rate setting domain, this domain cannot be     |   |
|       |          |      | modified during communication.                      |   |
|       |          |      | When the HSRXEN bit is 0, the SCK frequency         |   |
| [5:3] | BR[2:0]  | RW   | is:                                                 | 0 |
| -     |          |      | 000: FPCLK/2; 001: FPCLK/4;                         |   |
|       |          |      | 010: FPCLK/8; 011: FPCLK/16;                        |   |
|       |          |      | 100: FPCLK/32; 101: FPCLK/64;                       |   |
|       |          |      | 110: FPCLK/128; 111: FPCLK/256.                     |   |

|   |       |      | When the HSRXEN bit is 1, the SCK frequency         |    |
|---|-------|------|-----------------------------------------------------|----|
|   |       |      | is:                                                 |    |
|   |       |      | 000: FPCLK/2; 001: FPCLK/3;                         |    |
|   |       |      | 010: FPCLK/4; 011: FPCLK/5;                         |    |
|   |       |      | 100: FPCLK/6; 101: FPCLK/7;                         |    |
|   |       |      | 110: FPCLK/8; 111: FPCLK/9.                         |    |
|   |       |      | Note: This bit is only applicable to                |    |
|   |       |      | CH32F20x_D8, CH32F20x_D8C,                          |    |
|   |       |      | CH32V30x_D8, CH32V30x_D8C,                          |    |
|   |       |      | CH32V31x_D8C series chips whose penultimate         |    |
|   |       |      | sixth digit of the lot number is not equal to zero. |    |
|   |       |      | Master/slave setting. It cannot be modified during  |    |
| 2 | MSTR  | RW   | communication.                                      | 0b |
|   | WISTR | KW   | 0: Configured as the slave device;                  | 00 |
|   |       |      | 1: Configure as the master device.                  |    |
|   |       |      | Clock polarity selection. It cannot be modified     |    |
| 1 | CPOL  | RW   | during communication.                               | 0  |
|   | Crob  | 1011 | 0: In idle state, SCK remains low;                  | Ů  |
|   |       |      | 1: In idle state, SCK remains high.                 |    |
|   |       |      | Clock phase setting. It cannot be modified during   |    |
|   |       |      | communication.                                      |    |
| 0 | СРНА  | RW   | 0: Data sampling starts from the first clock edge;  | 0  |
|   |       |      | 1: Data sampling starts from the second clock       |    |
|   |       |      | edge.                                               |    |

# 20.4.2 SPI Control Register 2 (SPIx\_CTLR2) (x=1/2/3)

Offset address: 0x04

| 15 | 14 | 13 | 12   | 11    | 10 | 9 | 8 | 7         | 6          | 5         | 4    | 3     | 2    | 1               | 0               |
|----|----|----|------|-------|----|---|---|-----------|------------|-----------|------|-------|------|-----------------|-----------------|
|    |    |    | Rese | erved |    |   |   | TXEI<br>E | RXN<br>EIE | ERRI<br>E | Rese | erved | SSOE | TXD<br>MA<br>EN | RXD<br>MA<br>EN |

# Control Register 2

| Bit    | Name     | Access | Description                                       | Reset value |
|--------|----------|--------|---------------------------------------------------|-------------|
| [15:8] | Reserved | RO     | Reserved                                          | 0           |
|        |          |        | Transmit buffer empty interrupt enable.           |             |
| 7      | TXEIE    | RW     | 0: Disable interrupt generation when TXE is set;  | 0           |
|        |          |        | 1: Enable interrupt generation when TXE is set.   |             |
|        |          |        | Receive buffer not empty interrupt enable.        |             |
| 6      | RXNEIE   | RW     | 0: Disable interrupt generation when RXNE is set; | 0           |
|        |          |        | 1: Enable interrupt generation when RXNE is set.  |             |
|        |          |        | Error interrupt enable.                           |             |
|        |          |        | 0: Disable interrupt generation when an error     |             |
| 5      | ERRIE    | RW     | (CRCERR, OVR, MODF) is generated;                 | 0           |
|        |          |        | 1: Enable interrupt generation when an error      |             |
|        |          |        | (CRCERR, OVR, MODF) is generated.                 |             |

| [4:3] | Reserved | RO | Reserved                                       | 0 |
|-------|----------|----|------------------------------------------------|---|
|       |          |    | SS output enable. Disable SS output to work in |   |
| 2     | SSOE     | RW | multi-master mode.                             | 0 |
| 2     | SSUE     | RW | 0: Disable SS output in master mode;           | U |
|       |          |    | 1: Enable SS output.                           |   |
|       |          |    | Transmit buffer DMA enable.                    |   |
| 1     | TXDMAEN  | RW | 0: Disable transmit buffer DMA;                | 0 |
|       |          |    | 1: Enable transmit buffer DMA.                 |   |
|       |          |    | Receive buffer DMA enable.                     |   |
| 0     | RXDMAEN  | RW | 0: Disable receive buffer DMA;                 | 0 |
|       |          |    | 1: Enable receive buffer DMA.                  |   |

# 20.4.3 SPI Status Register (SPIx\_STATR) (x=1/2/3)

Offset address: 0x08

| 15 | 14 | 13 | 12   | 11    | 10 | 9 | 8 | 7   | 6   | 5        | 4          | 3   | 2          | 1   | 0        |
|----|----|----|------|-------|----|---|---|-----|-----|----------|------------|-----|------------|-----|----------|
|    |    |    | Rese | erved |    |   |   | BSY | OVR | MOD<br>F | CRC<br>ERR | UDR | CHSI<br>DE | TXE | RXN<br>E |

| Bit    | Name     | Access | Description                                                                                                                                                                         | Reset value |  |  |
|--------|----------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--|--|
| [15:8] | Reserved | RO     | Reserved                                                                                                                                                                            | 0           |  |  |
| 7      | BSY      | RO     | Busy flag. Set and reset by hardware.  0: SPI is not communicating;  1: SPI is communicating, or the transmit buffer is not empty.                                                  | 0           |  |  |
| 6      | OVR      | RO     | 0: No overflow error occurred; 1: An overflow error occurred.  Mode error flag. Set by hardware, and reset by software. 0: No mode error occurred; 1: A mode error occurred.        |             |  |  |
| 5      | MODF     | RO     | software.  0: No mode error occurred;                                                                                                                                               | 0           |  |  |
| 4      | CRCERR   | RW0    | CRC error flag. Set by hardware, and reset by software.  0: The received CRC value is the same as the RCRCR value;  1: The received CRC value is inconsistent with the RCRCR value. | 0           |  |  |
| 3      | UDR      | RO     | Underflow flag. Set by hardware, and reset by software.  0: Underflow has not occurred;  1: Underflow occurs.                                                                       | 0           |  |  |
| 2      | CHSIDE   | RO     | Channel. Set by hardware and reset by software.  0: The left channel needs to be transmitted or received;                                                                           | 0           |  |  |

|   |       |    | 1: The right channel needs to be transmitted or |   |
|---|-------|----|-------------------------------------------------|---|
|   |       |    | received.                                       |   |
|   |       |    | Transmit buffer empty flag.                     |   |
| 1 | TXE   | RO | 0: The transmit buffer is not empty;            | 1 |
|   |       |    | 1: The transmit buffer is empty.                |   |
|   |       |    | Receive buffer not empty flag.                  |   |
| 0 | RXNE  | RO | 0: The receive buffer is empty;                 | 0 |
| 0 | KAINE | KO | 1: The receive buffer is not empty.             | U |
|   |       |    | Note: Read DATAR and auto-zero.                 |   |

# 20.4.4 SPI Data Register (SPIx\_DATAR) (x=1/2/3)

Offset address: 0x0C

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 DR[15:0]

| Bit    | Name   | Access | Description                                                                                                                                                                                                                         | Reset value |
|--------|--------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
|        | rvanie | recess | Data register. It is used to store the received data or pre-store the data to be sent, so the read and write of the data register is actually a different area for operations, among which the read pair uses the                   |             |
| [15:0] | DATAR  | RW     | receive buffer, and the write corresponds to the send buffer. Data reception and transmission can be 8-bit or 16-bit, and it is necessary to determine how many bits of data to use before transmission.                            | 0           |
|        |        |        | When using 8 bits for data transmission, only the lower 8 bits of the data register are used, and the upper 8 bits are forced to 0 when receiving. Using the 16-bit data structure will cause all 16-bit data registers to be used. |             |

# 20.4.5 SPI Polynomial Register (SPIx\_CRCR) (x=1/2/3)

Offset address: 0x10

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0

CRCPOLY[15:0]

| Bit    | Name          | Access | Description                                                                      | Reset Value |
|--------|---------------|--------|----------------------------------------------------------------------------------|-------------|
| [15:0] | CRCPOLY[15:0] | I RW   | CRC polynomial. This domain defines the polynomial used for the CRC calculation. | 0x0007      |

# 20.4.6 SPI Receive CRC Register (SPIx\_RCRCR) (x=1/2/3)

Offset address: 0x14

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 RXCRC[15:0]

| Bit    | Name        | Access | Description                                                                                                                                                                                                                                    | Reset Value |
|--------|-------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [15:0] | RXCRC[15:0] | RO     | Rx CRC value. Stores the result of the calculated CRC check of the received bytes. Setting CRCEN will reset this register. The calculation method uses the polynomial used by CRCPOLY. In 8-bit mode, only the lower 8 bits participate in the | 0           |
|        |             |        | calculation, and in 16-bit mode, all 16 bits will participate in the calculation. This register needs to be read when BSY is 0.                                                                                                                |             |

# 20.4.7 Transmit CRC Register (SPIx\_TCRCR) (x=1/2/3)

Offset address: 0x18

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 TXCRC[15:0]

| Bit    | Name        | Access | Description                                                                                                                                                                                                                                                                                                                                                                               | Reset value |
|--------|-------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [15:0] | TXCRC[15:0] | RO     | Tx CRC value. Stores the calculated result of the CRC check of the bytes that have been sent. Setting CRCEN will reset this register. The calculation method uses the polynomial used by CRCPOLY. In 8-bit mode, only the lower 8 bits participate in the calculation, and in 16-bit mode, all 16 bits will participate in the calculation. This register needs to be read when BSY is 0. | 0           |

# 20.4.8 SPI\_I2S Configuration Register (SPIx\_I2S\_CFGR) (x=1/2/3)

Offset address: 0x1C

| 15 | 14   | 13   | 12 | 11         | 10   | 9    | 8  | 7           | 6            | 5 4    | 4 3   | 2   | 1   | 0         |
|----|------|------|----|------------|------|------|----|-------------|--------------|--------|-------|-----|-----|-----------|
|    | Rese | rved |    | I2S<br>MOD | I2SE | I2SC | FG | PCM<br>SYNC | Reser<br>ved | I2SSTD | CKPOL | DAT | LEN | CHL<br>EN |

| Bit     | Name        | Access | Description                                       | Reset value |  |
|---------|-------------|--------|---------------------------------------------------|-------------|--|
| [15:12] | Reserved    | RO     | Reserved                                          | 0           |  |
|         |             |        | I2S mode selection, this bit can only be set when |             |  |
| 11      | I2SMOD      | RW     | SPI or I2S is disabled.                           | 0           |  |
| 11      | 1281/101    | KW     | 0: Select SPI mode;                               | U           |  |
|         |             |        | 1: Select I2S mode.                               |             |  |
|         | I2SE        | RW     | I2S enable, not used in SPI mode.                 |             |  |
| 10      |             |        | 0: I2S disabled;                                  | 0           |  |
|         |             |        | 1: I2S enabled.                                   |             |  |
|         |             | RW     | I2S mode selection, this bit can only be set when |             |  |
| [0.01   | 12CCEC[1.0] |        | I2S is disabled:                                  | 001         |  |
| [9:8]   | I2SCFG[1:0] |        | 00: Slave device transmits;                       | 00Ь         |  |
|         |             |        | 01: Slave device receives;                        |             |  |

|       |                   |          | 10: Master device transmit;                                                                                                                                                                                                  |     |
|-------|-------------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
|       |                   |          | 11: Master device receives.                                                                                                                                                                                                  |     |
| 7     | PCMSYNC  Reserved | RW<br>RO | PCM frame synchronization. This bit is only meaningful when I2SSTD = 11 (Using the PCM standard).  0: Short frame sync;  1: Long frame synchronization.  Reserved                                                            | 0   |
| [5:4] | I2SSTD[1:0]       | RW       | I2S standard selection, this bit can only be set when I2S is disabled.  00: I2S Philips standard;  01: High byte alignment standard (Left alignment);  10: Low byte alignment standard (Right justified);  11: PCM standard. | 00Ь |
| 3     | CKPOL             | RW       | Quiescent clock polarity, for correct operation, this bit should only be set when I2S is turned off.  0: I2S clock quiescent state is low;  1: I2S clock quiescent state is high level.                                      | 0   |
| [2:1] | DATLEN[1:0]       | RW       | Length of the data to be transmitted. For correct operation, this bit can only be set when I2S is turned off.  00: 16-bit data length;  01: 24-bit data length;  10: 32-bit data length;  11: Not allowed.                   | 00Ь |
| 0     | CHLEN             | RW       | Channel length. Only when DATLEN = 00, the write operation of this bit is meaningful, otherwise the channel length is fixed to 32 bits by hardware. 0: 16 bits wide; 1: 32 bits wide.                                        | 0   |

# 20.4.9 SPI\_I2S Prescaler Register (SPIx\_I2SPR) (x=2/3)

Offset Address: 0x20

| 15 | 14 | 13   | 12    | 11 | 10 | 9         | 8   | 7 | 6 | 5 | 4     | 3      | 2 | 1 | 0 |
|----|----|------|-------|----|----|-----------|-----|---|---|---|-------|--------|---|---|---|
|    |    | Rese | erved |    |    | MCK<br>OE | ODD |   |   |   | I2SDI | V[7:0] |   |   |   |

| Bit     | Name     | Access | Description                                                                                                                                                                                                           | Reset value |
|---------|----------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [15:10] | Reserved | RO     | Reserved                                                                                                                                                                                                              | 0           |
| 9       | МСКОЕ    | RW     | Master clock output enable, for proper operation, this bit can only be set when I2S is turned off. This bit is only used in I2S master mode.  0: Master clock output disabled; 1: Master device clock output enabled. |             |

| 8     | ODD         | RW | Odd coefficient prescaler, for correct operation, this bit should only be set when I2S is turned off. This bit is only used in I2S master mode.  0: Actual division factor = I2SDIV*2;  1: Actual division factor = (I2SDIV*2)+1. |  |
|-------|-------------|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| [7:0] | I2SDIV[7:0] | RW | I2S linear prescaler. For proper operation, this bit should only be set when I2S is turned off. This bit is only used in I2S master mode. Disable setting I2SDIV[7:0] = 0 or I2SDIV[7:0] = 1 See Section 20.3.3.                  |  |

# 20.4.10 SPI High-speed Control Register (SPIx\_HSCR) (x=1/2/3)

Offset address: 0x24

| 15 | 14 | 13 | 12 | 11 | 10 | 9       | 8 | 7 | 6 | 5 | 4 | 3 | 2               | 1            | 0              |
|----|----|----|----|----|----|---------|---|---|---|---|---|---|-----------------|--------------|----------------|
|    |    |    |    |    | R  | Reserve | d |   |   |   |   |   | HSR<br>XEN<br>2 | Reser<br>ved | HSR<br>X<br>EN |

| Bit    | Name     | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Reset value |
|--------|----------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [15:3] | Reserved | RO     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0           |
| 2      | HSRXEN2  | RW     | SPI High Speed Read Mode 2  This mode is used only when HSRXEN is turned on and SPI PCLK is greater than or equal to 120M; this bit is not recommended for less than 120M. A higher host read speed can be obtained than if only HSRXEN is turned on.  0: Disables high-speed read mode 2;  1: Enable high-speed read mode 2.  Note: Only applicable to CH32F20x_D8, CH32F20x_D8C, CH32V30x_D8C, CH32V30x_D8C, products with the penultimate sixth bit of the lot number that | 0           |
| 0      | Reserved | RO W0  | is not zero.  Reserved  High-speed read mode enable bit:  0: High-speed read mode disabled;  1: High-speed read mode enabled.  This bit is read and write only for all chip models except CH32F20x_D8, CH32F20x_D8C, CH32V30x_D8, CH32V30x_D8C, and CH32V31x_D8C where the penultimate sixth bit of the lot number is not zero.  For all versions of the CH32F20x_D6, CH32V20x_D6 series chips support This mode is                                                           | 0           |

V2. 4 343 WCH°

only valid at clock division 2 (i.e., BR = 000 in the CTLR1 register). This bit is write only. For CH32F20x\_D8, CH32F20x\_D8C, CH32V30x D8, CH32V30x D8C, CH32V31x\_D8C series chips with the fifth inverse digit of the lot number less than 2 and the sixth inverse digit of the lot number is 0, CH32V20x D8, CH32V20x D8W, CH32F20x D8W series Chip lot number inverse fifth digit is less than 2, only support this mode is only valid when clock 2 divisions (i.e., BR = 000 in CTLR1 register), other lots are not restricted.

# **Chapter 21 USB Full-speed Device Controller (USBD)**

### This chapter applies to the whole family of CH32F20x, CH32V20x, CH32V30x and CH32V31x.

The USBD module is a USB full-speed and low-speed protocol communication controller based on the USB2.0 full-speed device technical specification. Built-in hardware automatically handles reverse non-return-to-zero (NRZI) encoding/decoding, bit stuffing of physical signals. The control can drive various states of the USB bus, send and receive protocol packets, and provide functions such as automatic response for flow control to ensure application processing time.

## 21.1 Main Features

- Compliant with USB2.0 full-speed device specification
- Support USB full-speed 12Mbps, low-speed 1.5Mbps mode
- Support configuration of 16 transmission channels
- Supports endpoint address range 0-15
- Support control, interrupt, batch, isochronous transfer
- Double-buffered mechanism supporting bulk/isochronous endpoints
- USB suspend, wake, resume operation
- The hardware automatically performs data PID inversion and transmission flow control
- Frame locked clock pulse generation

Note: USBD and CAN controller share a dedicated 512-byte SRAM area for data transmission and reception in the design, so when using USBD and CAN functions at the same time, this shared area needs to be allocated reasonably to prevent data conflicts.

# 21.2 Function Description

### 21.2.1 Features

The USBD module provides a communication connection that conforms to the USB specification for the data communication between the USB host (Usually a PC) and the microcontroller, and is completed by the application program and the module hardware when used. The module contains a shared 512-byte dedicated SRAM area as a USB transceiver data buffer. The actual use range is determined by the number of configured endpoints and the maximum data packet length of each endpoint, for up to 16 unidirectional or 8 bidirectional endpoints.

#### USBD module features include:

- Physical signal encoding/decoding: PID detection of token packets, data packets, and handshake packets is implemented according to USB specifications, including bit stuffing, CRC generation and verification, frame header synchronization identification, etc.
- Transaction processing: determine correct transmission and error status, and provide respective flag status and interrupt notification.
- Bus Suspend/Reset/Wakeup status recognition notification.
- Automatic data packet PID: According to the protocol, perform hardware flipping or locking on the sending and receiving data packet PIDs of asynchronous endpoints and synchronous endpoints to reduce application work.

V2. 4 345 WH

- Automatic response packet PID: According to the protocol, after a USB transaction is completed, the status of the response packet will be automatically modified for the asynchronous endpoint to provide enough processing and preparation time for the application, but it will not affect the physical transmission and reception on the USB bus.
- Management data sending and receiving: locate the endpoint configuration and buffer description area, and detect the buffer boundary to prevent overflow. Single-buffer/double-buffer area management, interrupt reporting priority management by endpoint type, etc.
- Provide general class, endpoint class, buffer description class register configuration.

### Applications can:

- Get the frame interval time point based on USB protocol, bus status: suspended, reset.
- Customize the number of endpoints, endpoint type, endpoint size. Customize the transfer data buffer area.
- Get the current or suspended endpoint's service for processing.
- Get error status like bit stuffing, format, CRC, protocol, missing ACK, buffer overflow/buffer not full,
- The drive module enters a low power consumption mode.

The USBD module maps USB events to 3 different NVIC or PFIC request lines (3 interrupt numbers are used):

- 1) USB high-priority interrupts: Can only be triggered by correct transfer events for isochronous and double-buffered bulk transfers, in order to guarantee maximum transfer rates.
- 2) USB low priority interrupt: Can be triggered by all USB events (Proper transfer, USB reset, etc.). Firmware should first determine the source of the interrupt before handling the interrupt.
- 3) USB Wakeup Interrupt: Triggered by a wakeup event from USB suspend mode.

### 21.2.2 Functional Configuration

### 1) GPIO Port

Once the USBD module is enabled, the GPIO ports for UDP and UPM are automatically connected to the internal USB transceiver, and the port settings for its GPIO peripherals are disconnected. Therefore, it is recommended that the GPIO port be configured to output a low level in a push-pull mode to prevent the USB device from being notified in advance when the port is in an uncertain state or when the PC host is connected before the USBD function is turned on.

The USBD module has a built-in 1.5K pull-up resistor in USB device mode, and no external pull-up resistor is required. For specific configuration, please refer to the description of the configuration extension control register (EXTEND CTR).

#### 2) Module initialization

First, the analog part related to the USB transceiver requires a standard 48MHz clock as the reference clock, which is derived from the HB bus. The application program needs to ensure that the current USB clock is 48MHz by configuring the corresponding control bit of the clock management logic (RCC\_CFGR0 register), and then enable the USB interface clock, so that the program can access the registers of the USBD module.

Second, when the module is forced to reset (The FRES bit in the USBD\_CNTR register is 1 by default), the application should initialize the required registers and packet buffer description table. Including: packet buffer description table address register (USBD\_BTABLE), endpoint configuration register (USBD\_EPRx) and packet buffer description table register. Configure the ADD[6:0] bits in the USBD\_DADDR register to be 0 (the default address of the USB protocol), and set the EF bit to enable the endpoint transfer function.

V2. 4 346 WCH<sup>\*</sup>

Finally, enable the internal 1.5K pull-up resistor and set the speed mode (EXTEND\_CTR register), then, clear the FRES bit on the USBD\_CNTR register, cancel the forced reset state of the USBD module to enable the USBD module, and clear the various status flags in the USBD\_ISTR register so that Clear unhandled false interrupt flags before enabling operation of any other unit. Turn on the required interrupt control bits in the USBD\_CNTR register.

#### 3) USB reset

USB reset includes: USBD module forced reset and USB bus reset (Protocol reset). Both will generate the RESET flag in the USBD\_ISTR register. When a USB reset occurs, all endpoint communications are disabled (The USBD module will not respond to any packet transfers). After a USB reset, the USBD module is enabled, and the USB endpoint also needs to be enabled to respond to the USB host (the EF bit in the USBD\_DADDR register is 1). During the enumeration phase of the USB device, the host will assign a unique address to the device, which must be written into the ADD[6:0] bits in the USBD\_DADDR register.

Note: The RESET flag comes from the state of the forced reset control bit (FRES) of the USBD module and the start of the USB bus reset signal.

# 4) Endpoint configuration and buffer description table

Each endpoint configuration register can configure a bidirectional endpoint single-buffered attribute, or a unidirectional endpoint double-buffered attribute.

For example: configure the bidirectional endpoint single buffer attribute, endpoint configuration register 3 (USBD\_EPRx), EA[3:0] is 2, then there can exist endpoint 2 upload channel and endpoint 2 download channel on USB transmission (Specifically determined by the descriptor information.); configure the unidirectional endpoint double buffer properties (only for bulk endpoints and synchronous endpoints), endpoint configuration register 3 (USBD\_EPRx), EA[3:0] is 2, endpoint type (EPTYPE) is synchronous or bulk endpoint, EP\_KIND bit is 1, then there can exist endpoint 2 upload channel or endpoint 2 downlink channel on USB transmission, choose 1 of 2, the sending and receiving speed is faster than single buffer, the microcontroller processing and USBD module physical sending and receiving can be performed synchronously, reducing waiting time.

Note: The USBD module has a built-in conflict arbitration mechanism, which makes the access of the microcontroller and the USBD module to the packet buffer just like the access to a dual-port SRAM. Even if the microcontroller accesses the buffer continuously, there will be no access conflict.

Each endpoint configuration register corresponds to a set of buffer description class registers (Description table) and the corresponding data sending and receiving buffer area, they are all located in the shared 512-byte dedicated SRAM area (Base address 0x40006000). Among them, the USBD\_BTABLE register defines the starting address of the buffer description table in the SRAM area, and the data transceiver buffer area can be located anywhere in the entire dedicated SRAM area, because their addresses and lengths are defined in the corresponding buffer description table, pay attention to the allocation conflict problem.

Note: When the CH32V20x\_D6, CH32V20x\_D8, CH32V20x\_D8W, CH32F20x\_D6, CH32F20x\_D8W series of products use CAN, the CAN filter table uses the high 128 bytes of the shared 512-byte dedicated SRAM area, and the USB uses the low 384 bytes.

When CH32V30x\_D8, CH32V30x\_D8C, CH32V31x\_D8C, CH32F20x\_D8, CH32F20x\_D8C series products use CAN1, the CAN filter table uses the high 128 bytes in the shared 512-byte dedicated SRAM area, and the USB uses the low 384 bytes; when both CAN1 & CAN2 are used at the same time, the CAN filter table When both CAN1 & CAN2 are used, the CAN filter table uses the high 256 bytes of the shared 512-byte dedicated SRAM area, and the USB uses the low 256 bytes.



Figure 21-1 Buffer description table structure

Whether receiving or sending, the packet buffer is used from the bottom. The USBD module does not change the contents of other buffers beyond the currently allocated buffer area. If the buffer receives a data packet larger than itself, it will only receive data up to its own size, and the others will be discarded, that is, a so-called buffer overflow exception occurs.

### 1) Endpoint initialization

The first step in initializing an endpoint is to write the appropriate values to the USBD ADDRX TX or USBD ADDRx RX registers so that the USBD module can find the data to transmit or a buffer that is ready to receive data. The EPTYPE[1:0] bits in the USBD EPRx register determine the basic type of the endpoint, and the EP KIND bits determine the special characteristics of the endpoint. As a sender, you need to set the STAT TX bit of the USBD EPRx register to enable the endpoint, and configure the COUNTx TX bit to determine the transmission length. As a receiver, you need to set the STAT RX bit to enable the endpoint, and set the BL SIZE and NUM BLOCK bits to determine the size of the receive buffer to detect buffer overflow exceptions. For unidirectional endpoints with asynchronous non-double-buffered bulk transfers, only one register in the transfer direction needs to be set. Once the endpoint is enabled, the application can no longer modify the value of the USBD EPRx register location USBD ADDRx TX/USBD ADDRx RX, USBD COUNTx TX/USBD COUNTx RX registers, because these values are modified in real time by the hardware. When the data transfer is completed, the CTR interrupt will be generated, at this time the above registers can be accessed and new transfers can be re-enabled.

#### 2) IN transaction (Transmit data)

When receiving an IN-token packet, if the received address is consistent with a configured endpoint address, and the STAT\_TX bit in the USBD\_EPRx register at this time indicates that it can be sent, the USBD module will be based on the contents of the buffer description table and the DTOG\_TX bit performs packet encoding to send out packets. If the endpoint corresponding to the received token packet is invalid, a NAK or STALL handshake packet will be sent according to the STAT\_TX bit in the USBD\_EPRx register instead of a data packet.

After receiving the ACK handshake packet responded by the host, the value of the USBD\_EPRx register is updated as follows: the DTOG\_TX bit is toggled, the STAT\_TX bit is '10' (NAK state), invalidating the endpoint, and the CTR\_TX bit is set. The application needs to identify the USB endpoint that generates the interrupt through the EP\_ID and DIR bits of the USBD\_ISTR register. The interrupt service routine of the CTR\_TX event needs to clear the interrupt flag first. If you want to continue sending data (Which can be executed whenever data needs to be sent), you need to prepare the data buffer to be sent, and update COUNTx\_TX to the number of bytes to be transmitted next time, and finally set the STAT\_TX bit to '11' (ACK, the endpoint is valid) to enable data transmission again. When the STAT\_TX bit is '10' (NAK state), any IN request sent to the endpoint will be NAKed, and the USB host will resend the IN request until the endpoint acknowledges that the request is valid.

### 3) OUT transaction and SETUP transaction (Receive data)

The USBD module handles these 2 transactions in basically the same way; when an OUT or SETUP packet is received, if the received address matches a configured endpoint address, and if the STAT\_RX bit in the USBD\_EPRx register at this time indicates that it is ready to receive, the USBD module judges whether the PID of the received data matches according to the DTOG\_RX bit. If it matches, it will access the buffer description table, find the ADDRx\_RX and COUNTx\_RX registers related to the endpoint, and save the received data packet (The one received first is the low byte). Go to the address space defined by ADDRx\_RX and detect whether the receive overflows the buffer according to the values of BL\_SIZE and NUM\_BLOCK. If there are no errors in transmission, send an ACK handshake packet to the host. Even if a CRC error or other type of error occurs (Bit stuffing, framing errors, etc.), the data is saved to the packet buffer, at least until the data point where the error occurred, it's just that the ACK handshake is not sent, and the USBD\_ISTR register The ERR bit will be set. In this case, the application program usually does not need to intervene in the processing, and the USBD module will automatically recover from the transfer error and be ready for the next transfer. If the endpoint corresponding to the received packet is not ready, the USBD module will send a NAK or STALL handshake packet according to the STAT\_RX bit in the USBD\_EPRx register, and the data will not be written into the receive buffer.

The value of ADDRx\_RX determines the starting address of the receive buffer, and COUNTx\_RX determines the size of the receive buffer (Expected effective data length + 2-byte CRC). If the length of the received data packet exceeds the range of the buffer, the data beyond the range will not be written into the buffer, the USBD module will report the buffer overflow, send a STALL handshake packet to the host, and set the packet buffer overflow Logo PMAOVR.

If the transfer is completed correctly, the USBD module will send an ACK handshake packet and write the number of valid data bytes in the actual received packet into the COUNTx\_RX register. The values of the USBD\_EPRx registers are updated as follows: the DTOG\_RX bit is toggled, the STAT\_RX bit is '10' (NAK state) to invalidate the endpoint, and the CTR\_RX bit is set. The application needs to identify the USB endpoint that generates the interrupt through the EP\_ID and DIR bits of the USBD\_ISTR register. The interrupt service routine of the CTR\_RX event must first determine the type of transmission according to the SETUP bit, clear the interrupt flag bit at the same time, and then read the COUNTx\_RX register pointed to by the relevant buffer description table entry to obtain the total number of bytes transmitted this time, and process the received data. After processing, the application needs to set the STAT\_RX bit in USBD\_EPRx to '11' (ACK state) to enable the next transmission. When the STAT\_RX bit is '10' (NAK state), any OUT request sent to the endpoint will be NAKed, except for the SETUP request (the protocol specifies that the SETUP request must be received with an ACK handshake). The PC host will continue to resend the NAKed OUT transaction packet until it receives the endpoint's ACK handshake packet.

### 4) Control Transfer

The control (SETUP) transfer must occur on endpoint 0, so it is also called endpoint 0-bit control endpoint. The control transfer consists of 3 phases, first the SETUP phase in which the host sends a SETUP transaction, then the data phase in which the host sends zero or more data (IN/OUT transactions), and finally the status phase, consisting of the data phase in the opposite direction of the data phase.

The SETUP transaction is very similar to the transmission process of the OUT transaction, so the control endpoint must check the SETUP bit in the USBD\_EPRx register every time the CTR\_RX interrupt occurs to identify whether it is a normal OUT transaction or a SETUP transaction. When the host sends a SETUP transaction, the USBD module will always reply to the ACK handshake packet and receive it, ignoring the content of STAT\_RX and DTOG\_RX. Then force DTOG\_RX and DTOG\_TX to be set to DATA1 state, and set STAT\_RX and STAT\_TX to '10' (NAK), to ensure that the application can decide whether the subsequent transmission is IN or OUT according to the corresponding data in the SETUP transaction. If subsequent data transmission is rejected or an error occurs, the application can set STAT\_RX or STAT\_TX to '01' and respond to the STALL handshake packet. If the application receives a SETUP transaction and processes it, CTR\_RX remains set at this time, and another SETUP packet is received, the USBD module will discard the SETUP packet and not give any handshake packet response, in order to simulate a reception error, forcing the host to send the SETUP packet again, in order to avoid losing another SETUP transaction transmission immediately following a CTR\_RX interrupt.

During the status phase of a control transfer, if an OUT transaction sent by the host to the device is being performed, then the STATUS\_OUT bit (EP\_KIND in the USBD\_EPRx register) should be set, only then if a non-zero length of the transfer is received during the status phase data packets, will generate transmission errors. After completing the status phase transfer, the application should clear the STATUS\_OUT bit, and set STAT\_RX to ACK to indicate that it is ready to receive a new command request, and set STAT\_TX to NAK to not accept any data upload requests.

### 21.2.3 Dual Buffer Mechanism

In the USB protocol standard, the application description of different data transmission methods is carried out. Among them, bulk transfer is suitable for bulk data transfer between the USB host and the device, and the host uses as much bandwidth as possible to perform bulk transfer within the frame time. However, this transmission needs to ensure the correctness and integrity of the data, so the transmission includes the sequence of token packets, data packets, and handshake packets. Synchronous transmission is suitable for transmitting data at a constant rate, but has a certain tolerance for errors. It is believed that the transmission can generally be successful. The host has a fixed bandwidth to perform synchronous transmission in each frame time to ensure the transmission rate. Therefore, during transmission Contains token packets, data packets in sequence, without handshake packets to confirm the transmission status and terminate the transmission.

### 21.2.3.1 One-way Dual-buffered Bulk Endpoint

Bulk transmission, in the single buffer mode, when the application processes the previous data transmission of the batch endpoint, and receives a new data packet, the USBD module will respond to the NAK handshake packet, so that the PC host will continue to resend the same data packet until the application resets the ACK handshake. Such retransmissions take up a lot of bandwidth and affect the rate of bulk transfers. Therefore, the double buffering mechanism is introduced to the bulk endpoint to improve the data transfer rate. In dual buffering mode, a one-way bulk endpoint has 2 data buffers, that is, the receive buffer and the transmit buffer. The data flip bit (DTOG\_RX or DTOG\_TX) is used to select which one of the 2 buffers is currently used, so

that the application can operate on the other buffer while the USBD module accesses one of the buffers. For example, when transferring an OUT transaction to a double-buffered bulk endpoint, the USBD module saves data from the PC host in a buffer while the application can process data in another buffer (for IN transactions, the case it's the same). In this way, the data processing of the application program is completed by using the time of receiving or sending data of the USBD module, and the efficiency of USB transmission and reception is improved. Because 2 buffers are required for a transmission direction, the bulk endpoint that configures the bidirectional buffer must be configured as a unidirectional endpoint, and its USBD\_EPRx register only needs to set the STAT\_RX bit (As a double-buffered bulk receive endpoint) or the STAT\_TX bit (As a double-buffered endpoint bulk send endpoint). In order to take advantage of double buffering as much as possible and achieve a higher transfer rate, the flow control of the USBD module to handle double-buffered bulk endpoints is slightly different from that of other endpoints. It only sets the endpoint to NAK state when there is an access violation in the buffer, rather than setting the endpoint to NAK state after every successful transfer.

The DTOG\_xx bits in the USBD\_EPRx register are used to identify the memory buffers currently used by the USBD module and the application respectively to avoid access conflicts. When configured as a unidirectional send double buffer endpoint, DTOG\_TX identifies the buffer currently used by the USBD module, and DTOG\_RX identifies the buffer currently used by the application; when configured as a unidirectional receive double buffer endpoint, DTOG\_RX identifies the buffer currently used by the USBD module area, and DTOG\_TX identifies the buffer currently used by the application. We named the USBD module using the buffer ID as DTOG and the application using the buffer ID as SW\_BUF. So the double buffered unidirectional bulk endpoint identifier is defined as follows:

Buffer Flag Transmission endpoint Reception endpoint

DTOG DTOG\_TX (USBD\_EPRx register bit6) DTOG\_RX (USBD\_EPRx register bit14)

SW BUF DTOG RX (USBD EPRx register bit14) DTOG TX (USBD EPRx register bit6)

Table 21-1 Buffer ID

| Table 21-2 | Double- | buffered | hulk | endnoint | buffer |
|------------|---------|----------|------|----------|--------|

| Endpoint<br>Type | DTOG | SW_BUF | Buffer used by USBD module | Buffer used by application software |
|------------------|------|--------|----------------------------|-------------------------------------|
|                  | 0    | 1      | ADDRx_TX_0/COUNTx_TX_0     | ADDRx_TX_1/COUNTx_TX_1              |
| IN               | 1    | 0      | ADDRx_TX_1/COUNTx_TX_1     | ADDRx_TX_0/COUNTx_TX_0              |
| Endpoint         | 0    | 0      | Set endpoint in NAK state  | ADDRx_TX_0/COUNTx_TX_0              |
|                  | 1    | 1      | Set endpoint in NAK state  | ADDRx_TX_1/COUNTx_TX_1              |
|                  | 0    | 1      | ADDRx_RX_0/COUNTx_RX_0     | ADDRx_RX_1/COUNTx_RX_1              |
| OUT              | 1    | 0      | ADDRx_RX_1/COUNTx_RX_1     | ADDRx_RX_0/COUNTx_RX_0              |
| Endpoint         | 0    | 0      | Set endpoint in NAK state  | ADDRx_RX_0/COUNTx_RX_0              |
|                  | 1    | 1      | Set endpoint in NAK state  | ADDRx_RX_1/COUNTx_RX_1              |

To configure a double-buffered bulk endpoint, the application needs to set the EPTYPE[1:0] bits in the USBD\_EPRx register to '00' and the EP\_KIND bit to '1'. The DTOG and SW\_BUF bits are initialized according to the buffer used at the beginning of the transfer. After each successful transfer, the USBD module will operate according to the flow control of the double-buffered bulk endpoint and will continue until EP\_KIND becomes invalid. At the end of each transfer, either the CTR\_RX bit or the CTR\_TX bit will be set, depending on the endpoint's transfer direction. At the same time, the hardware will set the corresponding DTOG\_xx bit (Flip) and implement buffer exchange. If there is no buffer access conflict between the USBD module and the application (i.e. DTOG and SW\_BUF are the same value, see Table 154), the status value of

the STAT\_xx bit is maintained, otherwise it will be set to '10' (NAK status). So after the application accesses the buffer, it needs to flip the SW BUF bit to notify the USB module that the block buffer has become available.

### 21.2.3.2 Sync Endpoint

Isochronous transmission is generally used to transmit audio streams, compressed video streams, and other data that have strict requirements on data transmission rates. The endpoint that performs the isochronous transfer is the isochronous endpoint. The USB host will allocate a fixed bandwidth to the synchronous endpoint for IN transaction or OUT transaction transmission in each frame time, and there is no retransmission mechanism, no handshake protocol, and the PID of the transmitted data packet is fixed as DATA0, and DATA0 and DATA1 data rollover mechanism (Appears in control/bulk/interrupt transfers) will not appear.

Because there is no handshake mechanism in synchronous transmission, the STAT\_RX bit and STAT\_TX bit in the USBD\_EPRx register can only be set to '00' (Transmission disabled) and '11' (Running transmission) respectively. Isochronous transfers use a double buffering mechanism to simplify the software process. It also uses 2 buffers to ensure that while the USB module is using one of the buffers, the application can access the other. Different from the double-buffering mechanism of one-way batch endpoints, synchronous endpoints have fixed time intervals and fault tolerance for transmission in the USB standard, so the USBD module does not judge the conflict with the application buffer, and only uses the DTOG bit to identify its current status. The buffer used (DTOG\_RX bits in the USBD\_EPRx register are used to identify the receive sync endpoint, and DTOG TX bits are used to identify the transmit sync endpoint).

| Endpoint<br>Type | DTOG | Buffer used by USBD module | Buffer used by application software |
|------------------|------|----------------------------|-------------------------------------|
| IN               | 0    | ADDRx_TX_0/COUNTx_TX_0     | ADDRx_TX_1/COUNTx_TX_1              |
| endpoint         | 1    | ADDRx_TX_1/COUNTx_TX_1     | ADDRx_TX_0/COUNTx_TX_0              |
| OUT              | 0    | ADDRx_RX_0/COUNTx_RX_0     | ADDRx_RX_1/COUNTx_RX_1              |
| endpoint         | 1    | ADDRx_RX_1/COUNTx_RX_1     | ADDRx_RX_0/COUNTx_RX_0              |

Table 21-3 Sync endpoint buffer ID

To configure a synchronous endpoint, the application needs to set the EPTYPE[1:0] bits in the USBD\_EPRX register to '10'. The DTOG bits are initialized according to the buffer used at the beginning of the transfer. After each successful transfer, either the CTR\_RX bit or the CTR\_TX bit will be set, depending on the endpoint's transfer direction. At the same time, the hardware will set the corresponding DTOG\_xx bits (Flipped) to implement the buffer swap, but will not change the expected or sent packet PID (Fixed to DATA0). The STAT\_RX or STAT\_TX bits do not change. In synchronous transmission, even if a CRC error or buffer overflow occurs in the OUT transaction, the transmission is still considered correct, and the CTR\_RX interrupt event can be triggered. However, when a CRC error occurs, the hardware will set the ERR bit of the USB\_ISTR register to remind the application Program data may be corrupted.

### 21.2.4 Suspend/Wake Process

A bus state is defined in the USB standard - SUSPEND. If the USB bus does not have any activity within 3ms, it enters the suspended state. In this state, the current provided on the USB bus will be reduced (Low-speed devices generally do not exceed 500uA, and high-speed devices or devices that support remote wake-up function generally do not exceed 2.5mA). This current limit is critical for bus-powered USB devices, while self-powered devices do not need to strictly adhere to such current consumption limits.

Under normal working conditions, the USB host will send SOF packets at 1ms intervals, so if the USBD

module detects 3 consecutive SOF packet loss events, it can determine that the host has issued a suspend request. At this time, it will set the USBD\_ISTR register. The SUSP bit, if enabled, also triggers pending interrupts. The USBD module will continuously detect the suspend state of the bus and update the SUSP bit (Clearing the SUSP bit flag will still be set again by hardware when the bus is in the suspend state). So when the application receives the USB bus suspend event, it needs to perform the following process:

Set the FSUSP bit in the USBD\_CNTR register to 1 to shield the hardware suspend state detection and prevent the suspend event from being triggered continuously.

Eliminate or reduce quiescent current consumption of modules other than the USBD module.

Set the LPMODE bit in the USBD\_CNTR register to 1 to put the USBD module in a low-power operating state, but still detect the bus wake-up signal.

The external oscillator and PLL can optionally be turned off to stop any activity on the device.

A USB device or host in a suspend state will be woken up by a wake-up sequence. The so-called wake-up sequence can be initiated by the USB host to wake up the suspended USB device, or it can be triggered by the USB device to wake up the suspended USB host, but the wake-up sequence is finally ended by the USB host. In addition, as a suspended USB device, it needs to be able to detect the function of the RESET signal (Bus reset) and perform it as a normal reset operation.

After the suspended USBD module receives the wake-up signal, it will trigger a WKUP interrupt event (channel 42), and set the WKUP bit in the USBD\_ISTR register to 1 to automatically clear the LPMODE bit. When the application receives the USB wakeup event, it needs to perform the following process:

Clear the FSUSP bit in the USBD\_CNTR register and restart the suspend state detection function of the USB bus;

The external oscillator and PLL can be optionally activated.

Query the RXDP and RXDM bits of the USBD\_FNR register to determine what triggers the wake-up event and execute the corresponding software operation.

The USBD module can issue a wake-up sequence to wake up a suspended USB host. In this case, first set the RESUME bit in the USBD\_CNTR register to 1, and then clear it to 0 between 1ms-15ms to start the wake-up sequence. After the RESUME bit is cleared, the wake-up process will be done by the host PC (This sequence will continue after the USB host wakes up to wake up other mounted USB devices). The application can query the RXDP and RXDM bits of the USBD\_FNR register to determine whether the wake-up is complete.

Note: The RESUME bit can only be set when the USBD module is set to suspend state (Set the FSUSP bit in the USB\_CNTR register to '1').

| RXDP | RXDM | Condition                | USB bus status             |                 |
|------|------|--------------------------|----------------------------|-----------------|
| 0    | 0    | >10ms                    | Bus reset                  |                 |
|      | 1    | >1ms (Full-speed device) | Wake-up sequence begins    |                 |
| 0 1  | 1    | 1                        | >3ms (Low-speed device)    | Suspended state |
| 1    | 0    | >3ms (Full-speed device) | Suspended state            |                 |
|      |      | >1ms (Low-speed device)  | Wake-up sequence begins    |                 |
| 1    | 1    | -                        | Bus error (Or disturbance) |                 |

Table 21-4 USB Bus Status

# 21.3 Register Description

The USBD module has the following 3 types of registers:

- Common registers: USBD module control, interrupt related, base address 0x40005C40.
- Endpoint-specific registers: related to endpoint configuration, transmit/receive status, base address

0x40005C00.

• Buffer description register: related to the data transmit/receive buffer, the base address is 0x40006000.

Table 21-5 USBD common registers

| Name            | Access address | Description                                          | Reset value |
|-----------------|----------------|------------------------------------------------------|-------------|
| R16_USBD_CNTR   | 0x40005C40     | USB control register                                 | 0x0003      |
| R16_USBD_ISTR   | 0x40005C44     | USB interrupt status register                        | 0x0000      |
| R16_USBD_FNR    | 0x40005C48     | USB frame number register                            | 0x0XXX      |
| R16_USBD_DADDR  | 0x40005C4C     | USB device address register                          | 0x0000      |
| R16_USBD_BTABLE | 0x40005C50     | USB packet buffer description table address register | 0x0000      |

Table 21-6 USBD endpoint-specific registers

| Name          | Access address | Description                          | Reset value |
|---------------|----------------|--------------------------------------|-------------|
| R16_USBD_EPR0 | 0x40005C00     | USB endpoint configuration register0 | 0x0000      |
| R16_USBD_EPR1 | 0x40005C04     | USB endpoint configuration register1 | 0x0000      |
| R16_USBD_EPR2 | 0x40005C08     | USB endpoint configuration register2 | 0x0000      |
| R16_USBD_EPR3 | 0x40005C0C     | USB endpoint configuration register3 | 0x0000      |
| R16_USBD_EPR4 | 0x40005C10     | USB endpoint configuration register4 | 0x0000      |
| R16_USBD_EPR5 | 0x40005C14     | USB endpoint configuration register5 | 0x0000      |
| R16_USBD_EPR6 | 0x40005C18     | USB endpoint configuration register6 | 0x0000      |
| R16_USBD_EPR7 | 0x40005C1C     | USB endpoint configuration register7 | 0x0000      |

Table 21-7 USBD buffer description registers

| Name               | Access address           | Description                                 | Reset value |
|--------------------|--------------------------|---------------------------------------------|-------------|
| R16_USBD_ADDR0_TX  | 0x40006000+[USBD_BTABLE] | Endpoint transmit buffer address register 0 | 0x0000      |
| R16_USBD_COUNT0_TX | 0x40006004+[USBD_BTABLE] | Endpoint transmit byte count register0      | 0x0000      |
| R16_USBD_ADDR0_RX  | 0x40006008+[USBD_BTABLE] | Endpoint receive buffer address register0   | 0x0000      |
| R16_USBD_COUNT0_RX | 0x4000600C+[USBD_BTABLE] | Endpoint Received Data Bytes<br>Register 0  | 0x0000      |
| R16_USBD_ADDR1_TX  | 0x40006010+[USBD_BTABLE] | Endpoint transmit buffer address register1  | 0x0000      |
| R16_USBD_COUNT1_TX | 0x40006014+[USBD_BTABLE] | Endpoint transmit byte count register1      | 0x0000      |
| R16_USBD_ADDR1_RX  | 0x40006018+[USBD_BTABLE] | Endpoint receive buffer address register1   | 0x0000      |
| R16_USBD_COUNT1_RX | 0x4000601C+[USBD_BTABLE] | Endpoint receive byte count register1       | 0x0000      |
| R16_USBD_ADDR2_TX  | 0x40006020+[USBD_BTABLE] | Endpoint transmit buffer address register2  | 0x0000      |
| R16_USBD_COUNT2_TX | 0x40006024+[USBD_BTABLE] | Endpoint transmit byte count register2      | 0x0000      |

V2. 4 354 WCH<sup>®</sup>

| R16_USBD_ADDR2_RX  | 0x40006028+[USBD_BTABLE]        | Endpoint receive buffer address register2  | 0x0000 |
|--------------------|---------------------------------|--------------------------------------------|--------|
| R16_USBD_COUNT2_RX | 0x4000602C+[USBD_BTABLE]        | Endpoint receive byte count register2      | 0x0000 |
| R16_USBD_ADDR3_TX  | 0x40006030+[USBD_BTABLE]        | Endpoint transmit buffer address register3 | 0x0000 |
| R16_USBD_COUNT3_TX | 0x40006034+[USBD_BTABLE]        | Endpoint transmit byte count register3     | 0x0000 |
| R16_USBD_ADDR3_RX  | 0x40006038+[USBD_BTABLE]        | Endpoint receive buffer address register3  | 0x0000 |
| R16_USBD_COUNT3_RX | 0x4000603C+[USBD_BTABLE]        | Endpoint receive byte count register3      | 0x0000 |
| R16_USBD_ADDR4_TX  | 0x40006040+[USBD_BTABLE]        | Endpoint transmit buffer address register4 | 0x0000 |
| R16_USBD_COUNT4_TX | 0x40006044+[USBD_BTABLE]        | Endpoint transmit byte count register4     | 0x0000 |
| R16_USBD_ADDR4_RX  | 0x40006048+[USBD_BTABLE]        | Endpoint receive buffer address register4  | 0x0000 |
| R16_USBD_COUNT4_RX | 0x4000604C+[USBD_BTABLE]        | Endpoint receive byte count register4      | 0x0000 |
| R16_USBD_ADDR5_TX  | 0x40006050+[USBD_BTABLE]        | Endpoint transmit buffer address register5 | 0x0000 |
| R16_USBD_COUNT5_TX | 0x40006054+[USBD_BTABLE]        | Endpoint transmit byte count register 5    | 0x0000 |
| R16_USBD_ADDR5_RX  | 0x40006058+[USBD_BTABLE]        | Endpoint receive buffer address register5  | 0x0000 |
| R16_USBD_COUNT5_RX | 0x4000605C+[USBD_BTABLE]        | Endpoint receive byte count register5      | 0x0000 |
| R16_USBD_ADDR6_TX  | 0x40006060+[USBD_BTABLE]        | Endpoint transmit buffer address register6 | 0x0000 |
| R16_USBD_COUNT6_TX | 0x40006064+[USBD_BTABLE]        | Endpoint transmit byte count register6     | 0x0000 |
| R16_USBD_ADDR6_RX  | 0x40006068+[USBD_BTABLE]        | Endpoint receive buffer address register6  | 0x0000 |
| R16_USBD_COUNT6_RX | 0x4000606C+[USBD_BTABLE]        | Endpoint receive byte count register6      | 0x0000 |
| R16_USBD_ADDR7_TX  | 0x40006070+[USBD_BTABLE]        | Endpoint transmit buffer address register7 | 0x0000 |
| R16_USBD_COUNT7_TX | 0x40006074+[USBD_BTABLE]        | Endpoint transmit byte count register7     | 0x0000 |
| R16_USBD_ADDR7_RX  | 0x40006078+[USBD_BTABLE]        | Endpoint receive buffer address register7  | 0x0000 |
| R16_USBD_COUNT7_RX | 0x4000607C+[USBD_BTABLE]        | Endpoint receive byte count register7      | 0x0000 |
| M . TI 1 1 CC      | r description class registers a |                                            | 1      |

Note: The above buffer description class registers and endpoint configuration registers are used correspondingly. For example: USB endpoint configuration register 0 corresponds to endpoint sending buffer

address register 0, endpoint sending data byte count register 0, endpoint receiving buffer address register 0, endpoint receiving data byte count register 0.

# 21.3.1 USB Control Register (USBD\_CNTR)

Offset address: 0x40

| 15       | 14              | 13       | 12        | 11        | 10   | 9        | 8         | 7                      | 6    | 5     | 4          | 3         | 2              | 1        | 0    |
|----------|-----------------|----------|-----------|-----------|------|----------|-----------|------------------------|------|-------|------------|-----------|----------------|----------|------|
| CTR<br>M | PMA<br>OVR<br>M | ERR<br>M | WKU<br>PM | SUSP<br>M | RSTM | SOF<br>M | ESOF<br>M | MOD<br>E_1<br>WIR<br>E | Rese | erved | RESU<br>ME | FSUS<br>P | LP<br>MOD<br>E | PDW<br>N | FRES |

| Bit | Name    | Access | Description                                                                                                                                                                                                            | Reset value |
|-----|---------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| 15  | CTRM    | RW     | Correct transfer interrupt enable: 0: Disable correct transfer (CTR) interrupt; 1: Enable correct transfer (CTR) interrupt, and generate an interrupt when the corresponding bit of the interrupt                      | 0           |
| 14  | PMAOVRM | RW     | register is set to 1.  Packet buffer overflow interrupt enable: 0: Disable PMAOVR interrupt; 1: Enable PMAOVR interrupt and generate an interrupt when the corresponding bit of the interrupt register is set to 1.    | 0           |
| 13  | ERRM    | RW     | Error interrupt enable: 0: Disable error interrupt; 1: Enable error interrupt, and generate an interrupt when the corresponding bit of the interrupt register is set to 1.                                             | 0           |
| 12  | WKUPM   | RW     | Wake-up interrupt enable:  1: Enable wake-up interrupt and generate an interrupt when the corresponding bit of the interrupt register is set to 1;  0: Disable wake-up interrupt.                                      | 0           |
| 11  | SUSPM   | RW     | Pending interrupt enable:  0: Suspend (SUSP) interrupt disabled;  1: Enable suspend (SUSP) interrupt, and generate an interrupt when the corresponding bit of the interrupt register is set to 1.                      | 0           |
| 10  | RESETM  | RW     | USB reset (Bus reset or forced reset) interrupt enable: 0: Disable USB reset interrupt; 1: Enable the USB reset interrupt, and generate an interrupt when the corresponding bit of the interrupt register is set to 1. | 0           |
| 9   | SOFM    | RW     | Start of Frame (SOF) interrupt enable: 0: Disable SOF interrupt; 1: Enable SOF interrupt and generate an interrupt when the corresponding bit of the interrupt register is set to 1.                                   | 0           |
| 8   | ESOFM   | RW     | Time frame first missing interrupt enable:  0: Disable ESOF interrupt;                                                                                                                                                 | 0           |

|       |             |    | 1: Enable the ESOF interrupt, and generate an interrupt when the corresponding bit of the interrupt register is set to 1.                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |
|-------|-------------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| 7     | MODE_1 WIRE | RW | USB 1-wire mode enable: 0: Disable USB 1-wire mode; 1: Enable USB 1-wire mode. Note: Only applicable to products with CH32F20x_D8 lot number where the penultimate sixth digit is not 0.                                                                                                                                                                                                                                                                                                                                                                           |   |
| [6:5] | Reserved    | RO | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 0 |
| 4     | RESUME      | RW | Wake-up request control:  0: Idle state;  1: Output wake-up signal.  According to the USB protocol, if this bit remains valid within 1ms to 15ms, the host will wake up the USBD module.  Note: This bit can only be set when the FSUSP bit is 1.                                                                                                                                                                                                                                                                                                                  | 0 |
| 3     | FSUSP       | RW | Mask suspend detection control:  0: Enable bus pending state detection;  1: Mask bus suspend state detection. At this time, the clock and static power consumption of the USB analog transceiver are still maintained. If you need to enter a low-power state (Bus-powered device), you need to set FSUSP first and then set LPMODE.  Note: When there is no data communication (Including SOF) on the USB bus for 3ms, the SUSP interrupt will be triggered. At this time, the software must set this bit, otherwise the SUSP interrupt will always be triggered. | 0 |
| 2     | LPMODE      | RW | Low-power mode control:  This mode is used to reduce power consumption in USB suspend state. In this mode, except for the power supply of the external pull-up resistor, other static power consumption is turned off, and the system clock will be stopped or reduced to a certain frequency to reduce power consumption. Activity on the USB bus (Wakeup event) will clear this bit (Can also be cleared by software).  0: Not in low-power mode;  1: low-power mode.                                                                                            | 0 |
| 1     | PDWN        | RO | Power down mode: It is used to completely shut down the USB module. The USB module cannot be used when this bit is set. 0: Get out of power down mode; 1: Get into power down mode.                                                                                                                                                                                                                                                                                                                                                                                | 1 |
| 0     | FRES        | RW | Force USB reset control: 0: Clear USB reset; 1: Forcibly reset the USBD module. The USBD module will remain in reset until software clears this bit. If the USB                                                                                                                                                                                                                                                                                                                                                                                                    | 1 |

V2. 4 357 WH

| reset interrupt is enabled, a reset interrupt will be |
|-------------------------------------------------------|
| generated.                                            |

# 21.3.2 USB Interrupt Status Register (USBD\_ISTR)

Offset address: 0x44

| 15  | 14         | 13  | 12       | 11   | 10    | 9   | 8    | 7 | 6       | 5 | 4   | 3 | 2     | 1      | 0 |
|-----|------------|-----|----------|------|-------|-----|------|---|---------|---|-----|---|-------|--------|---|
| CTR | PMAO<br>VR | ERR | WKU<br>P | SUSP | RESET | SOF | ESOF | R | Reserve | d | DIR |   | EP_II | D[3:0] |   |

| Bit | Name   | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Reset value |
|-----|--------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| 15  | CTR    | RO     | Correct transfer status. This bit is set by hardware after the endpoint has correctly completed a data transfer. The application can identify which endpoint completed the correct data transfer through the DIR and EP_ID bits.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0           |
| 14  | PMAOVR | RW0    | Packet buffer overflow flag.  This bit is set by hardware when the microcontroller has not responded to a request to access the USB packet buffer for an extended period of time. The USBD module usually sets this bit when an ACK handshake packet is not sent during reception, or a bit stuffing error occurs during transmission, in both cases the host will require data retransmission. PMAOVR interrupts are not generated during normal data transfers. Since the failed transmission will be retransmitted by the host, the application can accelerate other operations of the device in this interrupted service routine and prepare for retransmission. But this interrupt will not be generated in isochronous transmission (Isochronous transmission does not support retransmission) so data may be lost.  This bit is readable, write 0 to clear, write 1 to void. | 0           |
| 13  | ERR    | RW0    | Error flag, this bit is set by hardware when the following errors occur:  NANS: No response. The host's reply timed out.  CRC: Checksum error. There is an error in the CRC check in the USB packet.  BST: Bit stuffing error. A bit stuffing error was detected in the USB data bits.  FVIO: Frame format error. Received non-standard frame (Like EOP at wrong moment, wrong token, etc.).  USB applications can usually ignore these errors because both the USBD module and the host initiate a retransmission mechanism when an error occurs. The interrupt generated by this bit can be used in the development phase of the application program, and can be used to monitor the transmission quality of the USB bus                                                                                                                                                          | 0           |

|    |       |     | and identify possible errors that may occur to the user (Loose connection cable, severe environmental interference, damaged USB cable, etc.).  This bit is readable, write 0 to clear, write 1 to void.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|----|-------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| 12 | WKUP  | RW0 | Wake-up signal flag: When the USBD module is in suspend state, this bit will be set by hardware if a wake-up signal is detected. At this time, the LP_MODE bit of the CTLR register will be cleared to 0, and the FSUSP bit needs to be cleared by software to enable the suspension detection. At the same time USB_WAKEUP is activated, notifying other parts of the device (Such as the wake-up unit) that the wake-up process will begin. This bit is readable, write 0 to clear, write 1 to void.                                                                                                                                                                                                                                                                 | 0 |
| 11 | SUSP  | RW0 | Bus suspend flag: This bit is set by hardware when there is no signal transmission on the USB line for more than 3ms. After the USB reset (Bus reset or forced reset) is cancelled, the hardware immediately enables the detection of the suspend signal, but in the suspend mode (FSUSP=1) the hardware will not detect the suspend signal again until the wake-up process ends. This bit is readable, write 0 to clear, write 1 to void.                                                                                                                                                                                                                                                                                                                             | 0 |
| 10 | RESET | RW0 | USB reset (Bus reset or forced reset) flag: This bit is set by hardware when the USBD module detects an edge of the USB bus reset signal or a forced reset state. At this time, the USBD module will reset the internal protocol state machine and respond by triggering a reset interrupt when the interrupt is enabled. The transmit and receive parts of the USBD module will be disabled until this bit is cleared. All configuration registers are not reset unless they are cleared by the application. This is used to ensure that the USB transfer can be performed correctly immediately after the reset is reversed. However, the device's address and endpoint registers are reset by a USB reset. This bit is readable, write 0 to clear, write 1 to void. | 0 |
| 9  | SOF   | RW0 | Start of Frame (SOF) flag: This bit is set by hardware when the USBD module detects a SOF packet on the bus. The interrupt service routine can complete the 1ms synchronization with the host by detecting the SOF event, and correctly read the updated content of the register when it receives the SOF (This function is very meaningful during synchronous transmission). This bit is readable, write 0 to clear, write 1 to void.                                                                                                                                                                                                                                                                                                                                 | 0 |

|       |            | t   | ,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |   |
|-------|------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| 8     | ESOF       | RW0 | Expected start of frame (ESOF) flag: This bit is set by hardware when the USBD module does not receive the SOF packet on time. The host should send a SOF packet every millisecond, but if the USBD module does not receive it, the suspend timer will trigger this interrupt. If the ESOF interrupt occurs 3 times in a row, that is, the SOF packet is not received 3 times in a row, a SUSP interrupt will be generated. This bit is readable, write 0 to clear, write 1 to void.                                                                                                                                                                                                                                                                                                                                                                | 0 |
| [7:5] | Reserved   | RO  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0 |
| 4     | DIR        | RO  | Transaction data transfer direction. This bit is written by hardware according to the transfer direction after completing the data transfer and generating an interrupt. If DIR=0, the CTR_TX bit of the corresponding endpoint is set, marking the completion of an IN transaction (Data transfer from the USBD module to the PC host). If DIR=1, the CTR_RX bit of the corresponding endpoint is set, marking the completion of an OUT transaction (Data transfer from the PC host to the USBD module). If the CTR_TX bit is also set at the same time, it indicates that there are both pending OUT and IN transactions. The application can use this information to access the operation corresponding to the USBD_EPnR bit, which indicates the information of the pending interrupt transfer direction.                                       | 0 |
| [3:0] | EP_ID[3:0] | RO  | Endpoint ID.  These bits are written by hardware according to the endpoint ID requested to be interrupted after the USBD module completes the data transfer and generates an interrupt. If there are multiple endpoint request interrupts at the same time, the hardware writes the endpoint ID with the highest priority. The priorities of endpoints are defined as follows: isochronous and double-buffered bulk endpoints have high priority, other endpoints have low priority. If multiple endpoints of the same priority request an interrupt, the priority is determined according to the endpoint ID, that is, endpoint 0 has the highest priority, and the smaller the endpoint ID, the higher the priority.  The application can process the interrupt request of the endpoint sequentially through the above-mentioned priority policy. | 0 |

# 21.3.3 USB Fame Number Register (USBD\_FNR)

Offset address: 0x48

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0

| - |          |          |     |           |          |
|---|----------|----------|-----|-----------|----------|
|   | RXD<br>P | RXD<br>M | LCK | LSOF[1:0] | FN[10:0] |

| Bit     | Name      | Access | Description                                                                                                                                                                                                                                                                                                                                        | Reset value |
|---------|-----------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| 15      | RXDP      | RO     | D+ data line level status.                                                                                                                                                                                                                                                                                                                         | 0           |
| 14      | RXDM      | RO     | D- data line level status.                                                                                                                                                                                                                                                                                                                         | 0           |
| 13      | LCK       | RO     | SOF packet count stop lock.  The USBD module will detect SOF packets after the reset or wake-up sequence, if at least 2 SOF packets are detected consecutively, the hardware will set this bit. Once this bit is locked, the frame counter will stop counting and will not resume counting until the USBD module is reset or the bus is suspended. | 0           |
| [12:11] | LSOF[1:0] | RO     | Frame loss flag. When an ESOF event occurs, the hardware will write the number of lost SOF packets to this field. If the SOF packet is received again, this field is cleared.                                                                                                                                                                      | X           |
| [10:0]  | FN[10:0]  | RO     | Frame number. This field is the 11-bit frame number in the most recently received SOF packet. Every time the host sends a frame, the frame number will be incremented by itself, which is very meaningful for synchronous transmission. This field is updated when a SOF outage occurs.                                                            | X           |

# 21.3.4 USB Device Address Register (USBD\_DADDR)

Offset Address: 0x4C

| 15 | 14       | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3      | 2  | 1 | 0 |
|----|----------|----|----|----|----|---|---|---|---|---|---|--------|----|---|---|
|    | Reserved |    |    |    |    |   |   |   |   |   | A | .DD[6: | 0] |   |   |

| Bit    | Name     | Access | Description                                                                                                                                                                                                                                                                                                          | Reset value |
|--------|----------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [15:8] | Reserved | RO     | Reserved                                                                                                                                                                                                                                                                                                             | 0           |
| 7      | EF       | RW     | USB function enable. This bit is set by the application when the USB device function needs to be enabled. If this bit is 0, the USBD module will stop working, ignore the settings of all registers, and will not respond to any USB communication.  0: Stop the USB device function; 1: Enable USB device function. |             |
| [6:0]  | ADD[6:0] | RW     | USB device address.  This field is the address value that the USB host assigns to the USB device during enumeration. The address value and the EA bit must match the address information in the USB token packet in order to perform correct USB transmission at the specified endpoint.                             | 0           |

# 21.3.5 USB Packet Buffer Description Table Address Register (USBD\_BTABLE)

Offset address: 0x50

| 15 | 14 | 13 | 12 | 11 | 10  | 9     | 8     | 7 | 6 | 5 | 4 | 3 | 2 | 1       | 0 |
|----|----|----|----|----|-----|-------|-------|---|---|---|---|---|---|---------|---|
|    |    |    |    |    | BLA | BLE[1 | 15:3] |   |   |   |   |   | R | Reserve |   |

| Bit    | Name         | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Reset value |
|--------|--------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [15:3] | BLABLE[15:3] | RW     | Buffer table. This domain is the base address of the packet buffer description table. The packet buffer description table is used to indicate the address and size of the packet buffer of each endpoint, aligned by 8 bytes (i.e. the lowest 3 bits are 000). At the beginning of each transmission, the USBD module reads the packet buffer description table corresponding to the corresponding endpoint to obtain the buffer address and size information. |             |
| [2:0]  | Reserved     | RO     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0           |

# 21.3.6 USB Endpoint Configuration Register x(USBD\_EPRx) (x=0/1/2/3/4/5/6/7)

Offset address: 0x00 to 0x1C

| 15         | 14 | 13 12           | 2 | 11        | 10 9            | 8          | 7 | 6           | 5 | 4    | 3 | 2   | 1     | 0 |
|------------|----|-----------------|---|-----------|-----------------|------------|---|-------------|---|------|---|-----|-------|---|
| CTR<br>_RX |    | STAT_F<br>[1:0] |   | SETU<br>P | EPTYPE<br>[1:0] | EP<br>KIND |   | DTOG<br>_TX |   | TX 0 |   | EA[ | [3:0] |   |

| Bit | Name    | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Reset value |
|-----|---------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| 15  | CTR_RX  | RW0    | Correct reception flag (OUT/SETUP).  This bit is set by hardware when an OUT or SETUP transaction is correctly received (An ACK is sent). If the CTRM bit is set, the corresponding interrupt will be generated and the application needs to clear this bit after handling the event. Whether an OUT transaction or a SETUP transaction was received can be determined by the SETUP bits below.  This bit is readable, write 0 to clear, write 1 to have no effect.  Note: This bit is not set for transactions acknowledged with NAK or STALL or for erroneous transfers. | 0           |
| 14  | DTOG_RX | RW1T   | Expect the next received packet PID (OUT/SETUP), hardware settings:  0: Expect DATA0;  1: Expect DATA1.  For asynchronous endpoints, after receiving the correct PID packet, the USBD module sends an ACK handshake packet, and the hardware automatically flips this bit.  For control endpoints, the hardware sets (DATA1) after receiving the correct SETUP packet.                                                                                                                                                                                                     |             |

|         |         |      | For endpoints with double-buffering attributes, in addition to automatically flipping this bit to indicate the expected packet PID, the hardware also supports the exchange of double-buffering according to this bit identification (Please refer to the description of the double-buffering mechanism).  For synchronous endpoints, the hardware does not judge the PID of the data packet, and only supports the exchange of double buffers through this bit identification.  This bit is readable, write 0 is invalid, and write 1 flips.  Note: The application can initialize this bit, or toggle this bit for special purposes.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |   |
|---------|---------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| [13:12] | STAT_RX | RW1T | Status bits indicating data reception (In OUT/SETUP transactions):  00: DISABLED, the endpoint ignores all receive requests and does not respond;  01: STALL, the endpoint responds to the request with a STALL packet;  10: NAK, the endpoint responds to the receive request with a NAK packet;  11: ACK, the endpoint responds to the receive request with an ACK packet.  When a correct OUT or SETUP data transfer is completed (CTR_RX=1), the hardware will automatically set this bit to the NAK state, so that the application has enough time to process and respond to the next transaction.  For double-buffered bulk endpoints, due to the use of a special transfer flow control policy, the transfer state is controlled according to the buffer state used (See Double-buffered endpoints).  For isochronous endpoints, hardware will not set this bit after a proper transfer since the endpoint state can only be active or disabled.  If this field is set to STALL or NAK, the action that the USBD module responds to is undefined.  This field is readable, writing 0 to the bit is invalid, and writing 1 to flip it.  Note: The application program can initialize the field bits. | 0 |
| 11      | SETUP   | RO   | SETUP transaction transfer completion flag:  0: Non-SETUP transaction;  1: It is a SETUP transaction and received correctly (Send ACK response).  Note: Hardware will only modify this bit when CTR RX=0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0 |
| [10:9]  | ЕРТҮРЕ  | RW   | Transport Endpoint Type: 00: BULK, bulk endpoint; 01: CONTROL, control endpoint;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 0 |

|   |         |     | Only control end<br>types of endpo<br>transmission can<br>If the control end<br>SETUP packet, the<br>request, and a re-                                                                             | points will have SETUP transfers, other points ignore such transfers. SETUP not respond with NAK or STALL packet. point is in NAK state when receiving the ne USBD module will not respond to the ecception error will occur. If the control                                                                                                                                                                                                                                                       |   |
|---|---------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
|   |         |     | received correctly and an interrupt we correct transmissed endpoint is handled Bulk endpoints a very similar was handling of the E                                                                  | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |   |
| 8 | EP_KIND | RW  | EPTYPE[1:0] BULK  CONTROL  ISO INTERRUTP  DBL_BUF: Setti bulk endpoints. STATUS_OUT: device expects the in the control tranthe STALL hand length is not 0. endpoints and is a layer errors.) If the | EP_KIND  DBL_BUF: Enable double buffering.  STATUS_OUT: Control the data packet length judgment in the transmission status stage.  Unused.  Unused.  Unused.  Setting this bit indicates that the USB e host to send the status phase transaction asfer. At this time, the device responds to shake packet for any data packet whose (This feature is only used for control useful for providing detection of protocol as STATUS_OUT bit is cleared, an OUT e status phase can contain data of any | 0 |
| 7 | CTR_TX  | RW0 | Correct transmit in This bit is set by (ACK received) in the corresponding application need event. At the end the host responds transfer was unsured.                                               | hardware when a correct IN transaction s complete. If the CTRM bit has been set, g interrupt will be generated, and the s to clear this bit after processing the of the IN packet, this bit will not be set if with a NAK or STALL because the data                                                                                                                                                                                                                                                | 0 |

|       |         |      | effect.                                                                  |   |  |
|-------|---------|------|--------------------------------------------------------------------------|---|--|
|       |         |      | Note: This bit is not set if the host responds with a NAK or STALL.      |   |  |
|       |         |      | Packet PID(IN) to send, hardware setting:                                |   |  |
|       |         |      | 0: Send DATA0;                                                           |   |  |
|       |         |      | 1: Send DATA1.                                                           |   |  |
|       |         |      | For asynchronous endpoints, after sending the correct PID                |   |  |
|       |         |      | packet, if the USBD module receives the ACK handshake                    |   |  |
|       |         |      | packet from the host, the hardware automatically flips this              |   |  |
|       |         |      | bit.                                                                     |   |  |
|       |         |      | For control endpoints, the hardware sets (DATA1) after                   |   |  |
|       |         |      | receiving the correct SETUP packet.                                      |   |  |
|       |         |      | For endpoints with double-buffering attributes, in addition              |   |  |
| 6     | DTOG_TX | RW1T | to automatically flipping this bit to indicate the PID of the            | 0 |  |
|       |         |      | sent data packet, the hardware also supports the exchange                |   |  |
|       |         |      | of double-buffering according to this bit identification                 |   |  |
|       |         |      | (Please refer to the description of the double-buffering                 |   |  |
|       |         |      | mechanism).                                                              |   |  |
|       |         |      | For isochronous endpoints, the hardware forces the                       |   |  |
|       |         |      | transmission of the data packet DATA0, and this bit                      |   |  |
|       |         |      | indicates that the exchange of double buffers is supported.              |   |  |
|       |         |      | This bit is readable, writing 0 is invalid, and writing 1 flips.         |   |  |
|       |         |      | Note: The application can initialize this bit, or toggle this            |   |  |
|       |         |      | bit for special purposes.                                                |   |  |
|       |         |      | Status of the transmitted data (In the IN transaction):                  |   |  |
|       |         |      | 00: DISABLED, the endpoint ignores all sending requests                  |   |  |
|       |         |      | and does not respond;                                                    |   |  |
|       |         |      | 01: STALL, the endpoint responds to the host IN request                  |   |  |
|       |         |      | with a STALL packet;                                                     |   |  |
|       |         |      | 10: NAK, the endpoint responds to the host IN request with a NAK packet; |   |  |
|       |         |      | 11: ACK, the endpoint can send data.                                     |   |  |
|       |         |      | When an IN transaction data transmission is completed                    |   |  |
|       |         |      | correctly (CTR_TX=1), the hardware will automatically                    |   |  |
|       |         |      | set this bit to NAK state to ensure that the application has             |   |  |
| [5:4] | STAT_TX | RW1T | enough time to process and respond to the next transaction               | 0 |  |
|       |         |      | transmission.                                                            |   |  |
|       |         |      | For double-buffered bulk endpoints, due to the use of a                  |   |  |
|       |         |      | special transfer flow control policy, the transfer state is              |   |  |
|       |         |      | controlled according to the buffer state used (See Double-               |   |  |
|       |         |      | buffered endpoints).                                                     |   |  |
|       |         |      | For isochronous endpoints, hardware will not set this bit                |   |  |
|       |         |      | after a proper transfer since the endpoint state can only be             |   |  |
|       |         |      | active or disabled.                                                      |   |  |
|       |         |      | If this field is set to STALL or NAK, the operation that the             |   |  |
|       |         |      | USBD module responds to is undefined.                                    |   |  |

V2. 4 365

|       |    |    | This field is readable, writing 0 to the bit is invalid, and |   |
|-------|----|----|--------------------------------------------------------------|---|
|       |    |    | writing 1 to flip it.                                        |   |
|       |    |    | Note: The application program can initialize the field bits. |   |
|       |    |    | Endpoint address domain (Set the endpoint ID):               |   |
| [3:0] | EA | RW | The application program sets an endpoint address for this    | 0 |
|       |    |    | endpoint configuration register.                             |   |

# 21.3.7 Endpoint Transmit Buffer Address Register x(USBD\_ADDRx\_TX) (x=0/1/2/3/4/5/6/7)

Offset address: [USBD BTABLE] + x\*16

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 ADDRx TX[15:1]

| Bit    | Name     | Access | Description                                                              | Reset value |
|--------|----------|--------|--------------------------------------------------------------------------|-------------|
| [15:1] | ADDRx_TX | RW     | Start address of the data buffer to be sent (In an IN transaction).      | 0           |
| 0      | -        | RZ     | The address of the buffer must be 2-byte aligned, so this bit must be 0. | 0           |

#### 21.3.8 Endpoint Transmit Byte Count Register x(USBD\_COUNTx\_TX) (x=0/1/2/3/4/5/6/7)

Offset address: [USBD BTABLE] + x\*16 + 4

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0

Reserved COUNTx\_TX[9:0]

| Bit     | Name                 | Access | Description                                             | Reset value |  |
|---------|----------------------|--------|---------------------------------------------------------|-------------|--|
| [15:10] | Reserved             | RO     | Reserved                                                | 0           |  |
| [9:0]   | [9:0] COUNTX TX[9:0] | RW     | The number of bytes of data length to be sent (In an IN | 0           |  |
| [9.0]   | COONTX_1X[7.0]       | ICVV   | transaction).                                           | U           |  |

Note: There are 2 USBD\_ADDRx\_TX registers and 2 USB\_COUNTx\_TX registers for double-buffered and synchronous IN endpoints: USBD\_ADDRx\_TX\_1 and USBD\_ADDRx\_TX\_0, USB\_COUNTx\_TX\_1 and USB\_COUNTx\_TX\_0 respectively, the contents are as follows:

USBD ADDRx TX is mapped to USBD ADDRx TX 0

USBD ADDRx RX is mapped to USBD ADDRx TX 1

USBD COUNTx TX is mapped to USB COUNTx TX 0

 $USBD\_COUNTx\_RX \ is \ mapped \ to \ USB\_COUNTx\_TX\_1$ 

#### 21.3.9 Endpoint Receive Buffer Address Register x(USBD\_ADDRx\_RX) (x=0/1/2/3/4/5/6/7)

Offset address: [USBD BTABLE] + x\*16 + 8

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 ADDRx\_RX[15:1] -

| Bit Name Access Description Re | Reset value |
|--------------------------------|-------------|
|--------------------------------|-------------|

|   | [15:1] | ADDRx_RX[15:1] | RW | Start address of the data buffer to be received (In an OUT or SETUP transaction). | 0 |
|---|--------|----------------|----|-----------------------------------------------------------------------------------|---|
| Î | 0      | -              | RZ | The address of the buffer must be 2-byte aligned, so this bit must be 0.          | 0 |

#### 21.3.10 Endpoint Receive Byte Count Register x(USBD\_COUNTx\_RX) (x=0/1/2/3/4/5/6/7)

Offset address: [USBD\_BTABLE] + x\*16 + 12

| 15         | 14 | 13  | 12    | 11      | 10 | 9 | 8 | 7 | 6  | 5    | 4        | 3   | 2 | 1 | 0 |
|------------|----|-----|-------|---------|----|---|---|---|----|------|----------|-----|---|---|---|
| BLSIZ<br>E |    | NUM | _BLOC | CK[4:0] |    |   |   |   | CC | DUNT | <br>RX[9 | :0] |   |   |   |

| Bit     | Name               | Access | Description                                                                                                                                                                                                                                          | Reset value |
|---------|--------------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| 15      | BLSIZE             | RW     | Memory block size: 0: The block size is 2 bytes, used with NUM_BLOCK, the receive buffer range can be allocated 2-62 bytes; 1: The block size is 32 bytes. When used with NUM_BLOCK, the receive buffer range can be allocated from 32 to 512 bytes. | 0           |
| [14:10] | NUM_BLOCK<br>[4:0] | RW     | The number of memory blocks.                                                                                                                                                                                                                         | 0           |
| [9:0]   | COUNTx_RX<br>[9:0] | RO     | The number of bytes of data length actually received by the endpoint (In an OUT or SETUP transaction).                                                                                                                                               | X           |

Note: There are 2 USBD\_ADDRx\_RX registers and 2 USB\_COUNTx\_RX registers for double buffer and synchronous IN endpoints: USBD\_ADDRx\_RX\_1 and USBD\_ADDRx\_RX\_0, USB\_COUNTx\_RX\_1 and USB\_COUNTx\_RX\_0 respectively. The contents are as follows:

 $USBD\_ADDRx\_TX \ is \ mapped \ to \ USBD\_ADDRx\_RX\_0$ 

USBD ADDRx RX is mapped to USBD ADDRx RX 1

USBD COUNTx TX is mapped to USB COUNTx RX 0

USBD\_COUNTx\_RX is mapped to USB\_COUNTx\_RX\_1

The upper 6 bits of the USBD\_COUNTx\_RX register define the size of the receive packet buffer so that the USBD module can detect the overflow boundary of the buffer. The size of the buffer can be expressed according to the parameter maxPacketSize in the endpoint descriptor during the device enumeration process.

Table 20-8 Buffer size definition

| NUM DI OCUIA.01 | Receive Buffer Limit Size |            |  |  |  |  |
|-----------------|---------------------------|------------|--|--|--|--|
| NUM_BLOCK[4:0]  | BLSIZE = 0                | BLSIZE = 1 |  |  |  |  |
| 00000           | not allowed               | 32 bytes   |  |  |  |  |
| 00001           | 2 bytes                   | 64 bytes   |  |  |  |  |
| 00010           | 4 bytes                   | 96 bytes   |  |  |  |  |
| 00011           | 6 bytes                   | 128 bytes  |  |  |  |  |
|                 |                           |            |  |  |  |  |
| 01111           | 30 bytes                  | 512 bytes  |  |  |  |  |
| 10000           | 32 bytes                  | Reserved   |  |  |  |  |

|       | •••      | •••      |
|-------|----------|----------|
| 11110 | 60 bytes | Reserved |
| 11111 | 62 bytes | Reserved |

# **Chapter 22 USB Host/Device Controller (USBHD)**

This chapter applies to the whole family of CH32F20x, CH32V20x, CH32V30x and CH32V31x.

#### 22.1 USB Controller Introduction

Embedded USB2.0 controller and USB-PHY, with dual roles of host controller and USB device controller. When used as a host controller, it supports low-speed, full-speed and high-speed USB devices/HUBs. When used as a device controller, it can be flexibly set to low-speed, full-speed or high-speed mode to suit various applications.

USB Controller features include:

- Supports USB Host function and USB Device function.
- In the host mode, the downlink port is supported to connect to the high-speed/full-speed HUB.
- In device mode, it supports USB2.0 high-speed 480Mbps, full-speed 12Mbps or low-speed 1.5Mbps.
- Supports USB control transfer, bulk transfer, interrupt transfer and isochronous/real-time transfer.
- Support DMA to directly access the data of each endpoint buffer.
- Support suspend, wake-up/remote wake-up.
- Endpoint 0 supports data packets with a maximum size of 64 bytes. Except for device endpoint 0, other endpoints support data packets with a maximum size of 1024 bytes, and all support double buffering.

#### 22.2 Register Description

The USB registers are divided into 3 parts, and some registers are multiplexed in the host and device modes.

- USB global registers
- USB device control registers
- USB host control registers

#### 22.2.1 Global Register Description

Table 22-1 USBHS registers

| Name              | Access address | Description                       | Reset value |
|-------------------|----------------|-----------------------------------|-------------|
| R8_USB_CTRL       | 0x40023400     | USB control register              | 0x06        |
| R8_USB_INT_EN     | 0x40023402     | USB interrupt enable register     | 0x00        |
| R8_USB_DEV_AD     | 0x40023403     | USB device address register       | 0x00        |
| R16_USB_FRAME_NO  | 0x40023404     | USB frame number register         | 0x0000      |
| R8_USB_SUSPEND    | 0x40023406     | USB suspend register              | 0x00        |
| R8_USB_SPPED_TYPE | 0x40023408     | USB current speed type register   | 0x00        |
| R8_USB_MIS_ST     | 0x40023409     | USB miscellaneous status register | 0xX8        |
| R8_USB_INT_FG     | 0x4002340A     | USB interrupt flag register       | 0x00        |
| R8_USB_INT_ST     | 0x4002340B     | USB interrupt status register     | 0xXX        |
| R16_USB_RX_LEN    | 0x4002340C     | USB receive length register       | 0xXXXX      |

22.2.1.1 USB Control Register (R8\_USB\_CTRL)

| Bit | Name        | Access | Description                   | Reset value |
|-----|-------------|--------|-------------------------------|-------------|
| 7   | RB_UC_HOST_ | RW     | USB operating mode selection: | 0           |

|       | MODE               |      | 0: Device mode;                                  |   |  |
|-------|--------------------|------|--------------------------------------------------|---|--|
|       |                    |      | 1: Host mode.                                    |   |  |
|       |                    |      | USB bus signal transfer rate selection:          |   |  |
|       | DD HG CDEED        |      | 00: Full-speed;                                  | 0 |  |
| [6:5] | RB_UC_SPEED_       | RW   | 01: High-speed;                                  |   |  |
|       | TYPE[1:0]          |      | 10: Low-speed.                                   |   |  |
|       |                    |      | 11: Reserved.                                    |   |  |
|       |                    |      | USB device enable and internal pull-up resistor  |   |  |
|       | DD LIC DEV D       |      | control in device mode:                          |   |  |
| 4     | RB_UC_DEV_P        | RW   | 0: Not enabled;                                  | 0 |  |
|       | U_EN               |      | 1: Enable USB device transfer and enable         |   |  |
|       |                    |      | internal pull-up resistor.                       |   |  |
|       |                    |      | Auto suspend enable before USB transfer          |   |  |
|       | RB_UC_INT_BU<br>SY |      | completed interrupt flag is not cleared:         |   |  |
|       |                    |      | 0: Not pause;                                    |   |  |
| 3     |                    | RW   | 1: Automatically suspend before                  | 0 |  |
|       |                    | KW   | UIF_TRANSFER is cleared, automatically           | U |  |
|       |                    |      | respond busy NAK in device mode, and             |   |  |
|       |                    |      | automatically suspend subsequent transfers in    |   |  |
|       |                    |      | host mode.                                       |   |  |
|       |                    |      | USB protocol processor software reset control:   |   |  |
|       |                    | RW   | 0: No reset;                                     |   |  |
| 2     | RB_UC_RESET_       |      | 1: Forcibly reset the USB protocol processor     | 1 |  |
| 2     | SIE                | ICVV | (SIE), which needs to be cleared by software.    | 1 |  |
|       |                    |      | After this bit is cleared, PB6/PB7 automatically |   |  |
|       |                    |      | switches to USBIO mode.                          |   |  |
|       |                    |      | USB FIFO and interrupt flag clear:               |   |  |
| 1     | RB_UC_CLR_A        | RW   | 0: Not clear;                                    | 1 |  |
| '     | LL                 | 1644 | 1: Clear the USB interrupt flag and FIFO, which  | 1 |  |
|       |                    |      | needs to be cleared by software.                 |   |  |
|       |                    |      | Enable USB DMA, this bit must be set to 1 in     |   |  |
| 0     | RB_UC_DMA_E        | RW   | normal transfer mode:                            | 0 |  |
|       | N                  | 1644 | 0: Disable DMA;1: Enable DMA function and        |   |  |
|       |                    |      | DMA interrupt.                                   |   |  |

22.2.1.2 USB Interrupt Enable Register (R8\_USB\_INT\_EN)

| Bit | Name           | Access         | Description                                   | Reset value |
|-----|----------------|----------------|-----------------------------------------------|-------------|
|     | DD THE DEV NA  |                | USB device mode, receive NAK interrupt:       |             |
| 7   | RB_UIE_DEV_NA  | RW             | 0: Disable the corresponding interrupt;       | 0           |
|     | K              |                | 1: Enable the corresponding interrupt.        |             |
|     | RB_UIE_ISO_ACT | JIE_ISO_ACT RW | Isochronous transfer starts sending/receiving |             |
| 6   |                |                | data interrupt:                               | 0           |
| 0   |                |                | 0: Disable the corresponding interrupt;       | 0           |
|     |                |                | 1: Enable the corresponding interrupt.        |             |
| 5   | RB_UIE_SETUP_A | RW             | SETUP transaction completion interrupt:       | 0           |

|   | CT                  |    | 0: Disable the corresponding interrupt;    |   |  |
|---|---------------------|----|--------------------------------------------|---|--|
|   |                     |    | 1: Enable the corresponding interrupt.     |   |  |
| 4 | DD THE FIEO OV      | DW | FIFO overflow interrupt:                   | 0 |  |
| 4 | RB_UIE_FIFO_OV      | RW | 0: Disable interrupt; 1: Enable interrupt. | 0 |  |
|   |                     |    | USB host mode, SOF timing interrupt:       |   |  |
|   |                     |    | 0: Disable interrupt 1: Enable interrupt.  |   |  |
| 3 | RB_UIE_SOF_ACT      | RW | USB device mode, when enabled, receive SOF | 0 |  |
|   |                     |    | packets to generate a transfer completion  |   |  |
|   |                     |    | interrupt                                  |   |  |
| 2 | DD THE CHCDEND      | RW | USB bus suspend or wakeup event interrupt: | 0 |  |
| 2 | RB_UIE_SUSPEND      | KW | 0: Disable interrupt; 1: Enable interrupt. | U |  |
|   | RB_UIE_TRANSFE<br>R | RW | USB transfer (excluding SETUP transaction) |   |  |
| 1 |                     |    | complete interrupt:                        | 0 |  |
|   |                     |    | 0: Disable interrupt; 1: Enable interrupt. |   |  |
|   |                     |    | USB host mode, USB device connect or       |   |  |
|   | RB_UIE_DETECT       | RW | disconnect event interrupt:                | 0 |  |
| 0 |                     |    | 0: Disable interrupt 1: Enable interrupt.  |   |  |
|   |                     | RW | USB device mode, USB bus reset event       |   |  |
|   | RB_UIE_BUS_RST      |    | interrupt:                                 | 0 |  |
|   |                     |    | 0: Disable interrupt 1: Enable interrupt.  |   |  |

22.2.1.3 USB Device Address Register (R16\_USB\_DEV\_AD)

| Bit   | Name                      | Access | Description                                                                                                                  | Reset value |
|-------|---------------------------|--------|------------------------------------------------------------------------------------------------------------------------------|-------------|
| 7     | Reserved                  | RO     | Reserved                                                                                                                     | 0           |
| [6:0] | RB_MASK_USB_A<br>DDR[6:0] | RW     | In host mode, it is the address or HUB address of the currently operating USB device; In device mode, it is USB own address. | 0           |

22.2.1.4 USB Frame Number Register (R16 USB FRAME NO)

| Bit    | Name                   | Access | Description                                                                                                                                                                                                                                                                                                       | Reset value |
|--------|------------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [15:0] | USB_FRAME_NO[1<br>5:0] | RO     | Frame number. In host mode, it indicates the frame number of the SOF packet to be sent. In device mode, it indicates the frame number of the currently received SOF packet. Among them, the lower 11 bits are the effective frame number, and the upper 3 bits are the micro frame number of the high-speed mode. | 0           |

Note: USB\_FRAME\_NO is a 16-bit register, in which the lower 11 bits represent the frame number of the SOF packet, and the upper 3 bits represent the current micro-frame, which can be used for interrupt, synchronization/real-time transmission under the operation of high-speed HUB.

#### 22.2.1.5 USB Suspend Register (R8\_USB\_SUSPEND)

| Bit   | Name                    | Access | Description                                                                                                             | Reset value |
|-------|-------------------------|--------|-------------------------------------------------------------------------------------------------------------------------|-------------|
| [7:6] | Reserved                | RO     | Reserved                                                                                                                | 0           |
| [5:4] | RB_USB_LINESTATE[ 1:0]  | RO     | PHY Linestate signal                                                                                                    | X           |
| 3     | Reserved                | RO     | Reserved                                                                                                                | 0           |
| 2     | RB_USB_WAKEUP_<br>ST    | RO     | In the suspend state, if a wake-up signal from the host is received, this bit is set until the suspend state is exited. | Х           |
| [1:0] | RB_USB_SYS_MOD[<br>1:0] | RW     | Test mode in Host mode                                                                                                  | 00b         |

Note: When remote wake-up is required, pull the RB UH REMOTE WKUP bit high and then low.

22.2.1.6 USB Speed Type Register (R8\_USB\_SPEED\_TYPE)

| Bit   | Name                       | Access | Description                                                                                                                                                                                                  | Reset value |
|-------|----------------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [7:2] | Reserved                   | RO     | Reserved                                                                                                                                                                                                     | 0           |
| [1:0] | RB_USB_SPEED_T<br>YPE[1:0] | RO     | In host mode, it indicates the speed type of the currently connected device; in device mode, it indicates the speed type of the current device; 00: Full-speed; 01: High-speed; 10: Low-speed. 11: Reserved. | 00Ь         |

Note: Different from RB\_UC\_SPEED\_TYPE in the R8\_USB\_CTRL register, RB\_UC\_SPEED\_TYPE represents the expected maximum speed. Assuming that in device mode, set RB\_UC\_SPEED\_TYPE to high-speed, when the device is connected to a full-speed host, the actual speed type is full-speed. By querying R8\_USB\_SPEED\_TYPE registers can be known. In host mode, set RB\_UC\_SPEED\_TYPE to high-speed. When a full-speed device is connected, the actual communication speed is full-speed, which can be known by querying the R8\_USB\_SPEED\_TYPE register.

22.2.1.7 USB Miscellaneous Status Register (R8 USB MIS ST)

| Bit | Name            | Access                              | Description                                 | Reset value |
|-----|-----------------|-------------------------------------|---------------------------------------------|-------------|
|     |                 |                                     | SOF packet presage status in USB host       |             |
|     |                 |                                     | mode:                                       |             |
| 7   | RB_UMS_SOF_PR   | RO                                  | 0: No SOF packet is sent;                   | X           |
| _ ′ | ES              | KO                                  | 1: SOF packet is about to be sent, if there | Λ           |
|     |                 |                                     | are other USB packets at this time, it will |             |
|     |                 |                                     | be automatically delayed.                   |             |
|     |                 |                                     | SOF packet transfer status in USB host      |             |
| 6   | RB_UMS_SOF_AC   | RO                                  | mode:                                       | X           |
|     | T               | KO                                  | 0: Transmit complete or idle;               | Λ           |
|     |                 | 1: SOF packet is being transmitted. |                                             |             |
|     | DD LIME CIE EDE |                                     | USB protocol handler free:                  |             |
| 5   | RB_UMS_SIE_FRE  | RO                                  | 0: Busy, USB transfer in progress;          | 1           |
|     | E               |                                     | 1: The protocol device is free.             |             |

| 4 | RB_UMS_R_FIFO_<br>RDY | RO | USB receive FIFO data ready: 0: The receive FIFO is empty; 1: The receive FIFO is not empty.                                                      | 0 |
|---|-----------------------|----|---------------------------------------------------------------------------------------------------------------------------------------------------|---|
| 3 | RB_UMS_BUS_RE<br>SET  | RO | USB bus reset: 0: The current USB bus is not reset; 1: The current USB bus is reset.                                                              | X |
| 2 | RB_UMS_SUSPEN<br>D    | RO | USB suspend: 0: The USB bus is in a non-suspend state; 1: The USB bus is in a suspended state, and there is no USB activity for a period of time. | 0 |
| 1 | RB_UMS_DEV_AT<br>TACH | RO | USB device attach status for the port in USB host mode: 0: The port has no USB device connected; 1: The port has been connected to a USB device.  | 0 |
| 0 | RB_UMS_SPLIT_C<br>AN  | RO | In USB host mode, SPLIT packet transmit enable:  1: Enable transmit SPLIT packets;  0: Disable transmit.                                          | 0 |

22.2.1.8 USB Interrupt Flag Register (R8\_USB\_INT\_FG)

| Bit | Name                 | Access | Description                                                                                                                                                                                                                                                                                                                      | Reset value |
|-----|----------------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| 7   | Reserved             | RO     | Reserved                                                                                                                                                                                                                                                                                                                         | 0           |
| 6   | RB_UIF_ISO_ACT       | RO     | Synchronous transmission starts to send/receive data interrupt flag, write 1 to clear:  0: No event;  1: Start transmitting/receiving data trigger.  Note: For receiving, if the CRC16 error is received, UIF_TRANSFER will not be generated, otherwise UIF_TRANSFER will still be generated after the transaction is completed. | 0           |
| 5   | RB_<br>UIF_SETUP_ACT | RO     | SETUP transaction completion interrupt flag, write 1 to clear:  0: No event;  1: The SETUP transaction is completed.                                                                                                                                                                                                             | 1           |
| 4   | RB_UIF_FIFO_OV       | RW     | USB FIFO overflow interrupt flag, write 1 to clear: 0: no event; 1: FIFO overflow trigger.                                                                                                                                                                                                                                       | 0           |
| 3   | RB_UIF_HST_SOF       | RW     | SOF timer interrupt flag in USB host mode, write 1 to clear: 0: No event; 1: SOF packet transmission completion                                                                                                                                                                                                                  | 0           |

|   |                |    | trigger.                                    |   |
|---|----------------|----|---------------------------------------------|---|
|   |                |    | USB bus suspend or wake-up event            |   |
|   |                |    | interrupt flag, write 1 to clear:           |   |
| 2 | RB_UIF_SUSPEND | RW | 0: No event;                                | 0 |
|   |                |    | 1: Triggered by USB suspend event or        |   |
|   |                |    | wake-up event.                              |   |
|   |                |    | USB transfer completion interrupt flag,     |   |
| 1 | RB_UIF_TRANSFE | RW | write 1 to clear:                           | 0 |
| 1 | R              | KW | 0: No event;                                |   |
|   |                |    | 1: A USB transfer completion trigger.       |   |
|   | RB_UIF_DETECT  | RW | In USB host mode, USB device connect or     | 0 |
|   |                |    | disconnect event interrupt flag, write 1 to |   |
|   |                |    | clear:                                      |   |
|   |                |    | 0: No event;                                | O |
| 0 |                |    | 1: Detection USB device connection or       |   |
| V |                |    | disconnection trigger.                      |   |
|   |                |    | In USB device mode, USB bus reset event     | 0 |
|   | RB UIF BUS RST | RW | interrupt flag, write 1 to clear:           |   |
|   | KD_OH_DOS_KS1  | KW | 0: No event;                                |   |
|   |                |    | 1: USB bus reset event trigger.             |   |

22.2.1.9 USB Interrupt Status Register (R8\_USB\_INT\_ST)

| Bit   | Name                    | Access | Description                                                                                                                                                                    | Reset value |
|-------|-------------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| 7     | RB_UIS_IS_NAK           | RO     | NAK response status in USB device mode, same as RB_U_IS_NAK:  0: No NAK response;                                                                                              | 0           |
|       |                         |        | 1: Respond to NAK during the current USB transfer process.                                                                                                                     |             |
| 6     | RB_UIS_TOG_OK           | RO     | After the USB transaction is received, the Toggle of the received data packet and the set expected value Match Status Bits:  0: Toggle does not match;  1: Toggle match.       | 0           |
| [5:4] | MASK_UIS_TOKEN [1:0]    | RO     | In device mode, the token PID identifier of the current USB transfer transaction.                                                                                              | XXb         |
|       | MASK_UIS_ENDP[3 :0]     | RO     | In device mode, the endpoint number of the current USB transfer transaction.                                                                                                   | XXXXb       |
| [3:0] | MASK_UIS_H_RES[<br>3:0] | RO     | In host mode, the response PID identifier of the current USB transfer transaction, 0000 means the device has no response or timed out; other values indicate the response PID. | XXXXb       |

Note: MASK\_UIS\_TOKEN is used to identify the token PID of the current USB transfer transaction in USB device mode: 00 means OUT packet; 01 means SOF packet; 10 means IN packet; 11 means SETUP packet.

MASK\_UIS\_H\_RES is only valid in host mode. In the host mode, if the host sends the OUT/SETUP token packet, the PID is the handshake packet ACK/NAK/STALL, or the device has no response/timeout. If the host sends an IN token packet, the PID is the PID of the data packet (DATA0/DATA1) or the PID of the handshake packet.

22.2.1.10 USB Receive Length Register (R16\_USB\_RX\_LEN)

| Bit   | Name                     | Access | Description                                                   | Reset Value |
|-------|--------------------------|--------|---------------------------------------------------------------|-------------|
| [15:0 | R16_USB_RX_LEN[<br>15:0] | RO     | The current number of data bytes received by the USB endpoint | X           |

#### 22.2.2 Device Register Description

In USB device mode, the USBHD module provides a total of 16 groups of bidirectional endpoints from endpoints 0 to 15. The maximum packet length of all endpoints except endpoint 0 is 1024 bytes, and the maximum packet length of endpoint 0 is 64 bytes.

- Endpoint 0 is the default endpoint, which supports control transmission. Transmitting and receiving share a 64-byte data buffer.
- Endpoints 1-15 each include a transmitting endpoint IN and a receiving endpoint OUT, each with an independent data buffer for transmitting and receiving, supporting bulk transfer, interrupt transfer and real-time/synchronous transfer.
- Endpoint 0 has an independent DMA address, which is shared for transmitting and receiving. Endpoints 1 to 15 each have a DMA address for transmitting and receiving. By entering the R32\_UEPn\_BUF\_MOD register, the mode of the data buffer can be set to double buffer or single buffer. If using double buffer mode, the endpoint can only use one-way transfers.
- Each group of endpoints has transceiver control registers R8\_UEPn\_TX\_CTRL, R8\_UEPn\_RX\_CTRL and transmit length registers R16\_UEPn\_T\_LEN and R32\_UEPn\_\*¬\_DMA (n=0~15), which are used to configure the synchronization trigger bits of the endpoint, responses to OUT transactions and IN transactions, and transmit data length, etc.

The USB bus pull-up resistor necessary as a USB device can be set by software at any time to enable or not. When RB\_UC\_DEV\_PU\_EN in the USB control register R8\_USB\_CTRL is set to 1, the controller is set according to the speed of RB\_UC\_SPEED\_TYPE, which is the DP/DM pin of the USB bus internally. Connect a pull-up resistor and enable the USB device function.

When a USB bus reset, USB bus suspend or wake-up event is detected, or when the USB successfully processes data transmission or data reception, the USB protocol processor will set the corresponding interrupt flag. If the interrupt enable is turned on, it will also generate corresponding interrupt request. The application can query directly or query and analyze the interrupt flag register R8\_USB\_INT\_FG in the USB interrupt service routine, and perform corresponding processing according to RB\_UIF\_BUS\_RST and RB\_UIF\_SUSPEND; and, if RB\_UIF\_TRANSFER is valid, then it is necessary to continue to analyze the USB interrupt status register R8\_USB\_INT\_ST, according to the current endpoint number MASK\_UIS\_ENDP and the current transaction token PID identify MASK\_UIS\_TOKEN for corresponding processing. If the synchronization trigger bit RB\_UEP\_R\_TOG of the OUT transaction of each endpoint is set in advance, then RB\_U\_TOG\_OK or RB\_UIS\_TOG\_OK can be used to judge whether the synchronization trigger bit of the currently received data packet matches the synchronization trigger bit of the endpoint. If the data is synchronized, the data Valid; if the data is out of sync, the data should be discarded. After each USB

transmission or reception interrupt is processed, the synchronization trigger bit of the corresponding endpoint should be modified correctly to detect whether the next data packet sent or received next time is synchronously detected; in addition, setting RB\_UEP\_T\_TOG\_AUTO or RB\_UEP\_R\_TOG\_AUTO enables automatic modification of the corresponding synchronization trigger bit (Flip or self-decrease) after successful transmission or successful reception.

The data to be sent by each endpoint is in its own buffer, and the length of the data to be sent is independently set in R16\_UEPn\_T\_LEN; the data received by each endpoint is in its own buffer, but the length of the received data is in the USB receive length. In the register R16\_USB\_RX\_LEN, it can be distinguished according to the current endpoint number when the USB receives an interrupt.

Table 22-2 Device registers

| Name             | Access address | Description                              | Reset value |
|------------------|----------------|------------------------------------------|-------------|
| R32_UEP_CONFIG   | 0x40023410     | Endpoint enable configuration register   | 0x00000000  |
| R32_UEP_TYPE     | 0x40023414     | Endpoint type configuration register     | 0x00000000  |
| R32_UEP_BUF_MOD  | 0x40023418     | Endpoint buffer mode register            | 0x00000000  |
| R32_UEP0_DMA     | 0x4002341C     | Endpoint0 buffer start address           | 0xXXXXXXXX  |
| R32_UEP1_RX_DMA  | 0x40023420     | Endpoint1 receive buffer start address   | 0xXXXXXXXX  |
| R32_UEP2_RX_DMA  | 0x40023424     | Endpoint2 receive buffer start address   | 0xXXXXXXXX  |
| R32_UEP3_RX_DMA  | 0x40023428     | Endpoint3 receive buffer start address   | 0xXXXXXXXX  |
| R32_UEP4_RX_DMA  | 0x4002342C     | Endpoint4 receive buffer start address   | 0xXXXXXXXX  |
| R32_UEP5_RX_DMA  | 0x40023430     | Endpoint5 receive buffer start address   | 0xXXXXXXXX  |
| R32_UEP6_RX_DMA  | 0x40023434     | Endpoint6 receive buffer start address   | 0xXXXXXXXX  |
| R32_UEP7_RX_DMA  | 0x40023438     | Endpoint7 receive buffer start address   | 0xXXXXXXXX  |
| R32_UEP8_RX_DMA  | 0x4002343C     | Endpoint8 receive buffer start address   | 0xXXXXXXXX  |
| R32_UEP9_RX_DMA  | 0x40023440     | Endpoint9 receive buffer start address   | 0xXXXXXXXX  |
| R32_UEP10_RX_DMA | 0x40023444     | Endpoint10 receive buffer start address  | 0xXXXXXXXX  |
| R32_UEP11_RX_DMA | 0x40023448     | Endpoint11 receive buffer start address  | 0xXXXXXXXX  |
| R32_UEP12_RX_DMA | 0x4002344C     | Endpoint12 receive buffer start address  | 0xXXXXXXXX  |
| R32_UEP13_RX_DMA | 0x40023450     | Endpoint13 receive buffer start address  | 0xXXXXXXXX  |
| R32_UEP14_RX_DMA | 0x40023454     | Endpoint14 receive buffer start address  | 0xXXXXXXXX  |
| R32_UEP15_RX_DMA | 0x40023458     | Endpoint15 receive buffer start address  | 0xXXXXXXXX  |
| R32_UEP1_TX_DMA  | 0x4002345C     | Endpoint1 transmit buffer start address  | 0xXXXXXXXX  |
| R32_UEP2_TX_DMA  | 0x40023460     | Endpoint2 transmit buffer start address  | 0xXXXXXXXX  |
| R32_UEP3_TX_DMA  | 0x40023464     | Endpoint3 transmit buffer start address  | 0xXXXXXXXX  |
| R32_UEP4_TX_DMA  | 0x40023468     | Endpoint4 transmit buffer start address  | 0xXXXXXXXX  |
| R32_UEP5_TX_DMA  | 0x4002346C     | Endpoint5 transmit buffer start address  | 0xXXXXXXXX  |
| R32_UEP6_TX_DMA  | 0x40023470     | Endpoint6 transmit buffer start address  | 0xXXXXXXXX  |
| R32_UEP7_TX_DMA  | 0x40023474     | Endpoint7 transmit buffer start address  | 0xXXXXXXXX  |
| R32_UEP8_TX_DMA  | 0x40023478     | Endpoint8 transmit buffer start address  | 0xXXXXXXXX  |
| R32_UEP9_TX_DMA  | 0x4002347C     | Endpoint9 transmit buffer start address  | 0xXXXXXXXX  |
| R32_UEP10_TX_DMA | 0x40023480     | Endpoint10 transmit buffer start address | 0xXXXXXXXX  |
| R32_UEP11_TX_DMA | 0x40023484     | Endpoint11 transmit buffer start address | 0xXXXXXXXX  |
| R32_UEP12_TX_DMA | 0x40023488     | Endpoint12 transmit buffer start address | 0xXXXXXXXX  |
| R32_UEP13_TX_DMA | 0x4002348C     | Endpoint13 transmit buffer start address | 0xXXXXXXXX  |
| R32_UEP14_TX_DMA | 0x40023490     | Endpoint14 transmit buffer start address | 0xXXXXXXXX  |

|                   |            | +                                                                       | ,          |
|-------------------|------------|-------------------------------------------------------------------------|------------|
| R32_UEP15_TX_DMA  | 0x40023494 | Endpoint15 transmit buffer start address                                | 0xXXXXXXXX |
| R16_UEP0_MAX_LEN  | 0x40023498 | Endpoint0 maximum length packet register                                | 0xXXXX     |
| R16_UEP1_MAX_LEN  | 0x4002349C | Endpoint1 maximum length packet register                                | 0xXXXX     |
| R16_UEP2_MAX_LEN  | 0x400234A0 | Endpoint2 maximum length packet register                                | 0xXXXX     |
| R16_UEP3_MAX_LEN  | 0x400234A4 | Endpoint3 maximum length packet register                                | 0xXXXX     |
| R16_UEP4_MAX_LEN  | 0x400234A8 | Endpoint4 maximum length packet register                                | 0xXXXX     |
| R16_UEP5_MAX_LEN  | 0x400234AC | Endpoint5 maximum length packet register                                | 0xXXXX     |
| R16_UEP6_MAX_LEN  | 0x400234B0 | Endpoint6 maximum length packet register                                | 0xXXXX     |
| R16_UEP7_MAX_LEN  | 0x400234B4 | Endpoint7 maximum length packet register                                | 0xXXXX     |
| R16_UEP8_MAX_LEN  | 0x400234B8 | Endpoint8 maximum length packet register                                | 0xXXXX     |
| R16_UEP9_MAX_LEN  | 0x400234BC | Endpoint9 maximum length packet register                                | 0xXXXX     |
| R16_UEP10_MAX_LEN | 0x400234C0 | Endpoint10 maximum length packet register                               | 0xXXXX     |
| R16_UEP11_MAX_LEN | 0x400234C4 | Endpoint11 maximum length packet register                               | 0xXXXX     |
| R16_UEP12_MAX_LEN | 0x400234C8 | Endpoint12 maximum length packet register                               | 0xXXXX     |
| R16_UEP13_MAX_LEN | 0x400234CC | Endpoint13 maximum length packet register                               | 0xXXXX     |
| R16_UEP14_MAX_LEN | 0x400234D0 | Endpoint14 maximum length packet register                               | 0xXXXX     |
| R16_UEP15_MAX_LEN | 0x400234D4 | Endpoint15 maximum length packet register                               | 0xXXXX     |
| R16_UEP0_T_LEN    | 0x400234D8 | Endpoint0 transmit length register                                      | 0xXXXX     |
| R8_UEP0_TX_CTRL   | 0x400234DA | Endpoint0 transmit control register                                     | 0x00       |
| R8_UEP0_RX_CTRL   | 0x400234DB | Endpoint0 receive control register                                      | 0x00       |
| R16_UEP1_T_LEN    | 0x400234DC | Endpoint1 transmit length register                                      | 0xXXXX     |
| R8_UEP1_TX_CTRL   | 0x400234DE | Endpoint1 transmit control register                                     | 0x00       |
| R8_UEP1_RX_CTRL   | 0x400234DF | Endpoint1 receive control register                                      | 0x00       |
| R16_UEP2_T_LEN    | 0x400234E0 | Endpoint2 transmit length register                                      | 0xXXXX     |
| R8_UEP2_TX_CTRL   | 0x400234E2 | Endpoint2 transmit control register                                     | 0x00       |
| R8_UEP2_RX_CTRL   | 0x400234E3 | Endpoint2 receive control register                                      | 0x00       |
| R16_UEP3_T_LEN    | 0x400234E4 | Endpoint3 transmit length register                                      | 0xXXXX     |
| R8_UEP3_TX_CTRL   | 0x400234E6 | Endpoint3 transmit control register                                     | 0x00       |
| R8_UEP3_RX_CTRL   | 0x400234E7 | Endpoint3 receive control register                                      | 0x00       |
| R16_UEP4_T_LEN    | 0x400234E8 | Endpoint4 transmit length register                                      | 0xXXXX     |
| R8_UEP4_TX_CTRL   | 0x400234EA | Endpoint4 transmit control register                                     | 0x00       |
| R8_UEP4_RX_CTRL   | 0x400234EB | Endpoint4 receive control register                                      | 0x00       |
| R16 UEP5 T LEN    | 0x400234EC | Endpoint5 transmit length register                                      | 0xXXXX     |
| R8 UEP5 TX CTRL   | 0x400234EE | Endpoint5 transmit control register                                     | 0x00       |
| R8 UEP5 RX CTRL   | 0x400234EF | Endpoint5 receive control register                                      | 0x00       |
| R16 UEP6 T LEN    | 0x400234F0 | Endpoint6 transmit length register                                      | 0xXXXX     |
| R8_UEP6_TX_CTRL   | 0x400234F2 | Endpoint6 transmit control register                                     | 0x00       |
| R8 UEP6 RX CTRL   | 0x400234F3 | Endpoint6 receive control register                                      | 0x00       |
| R16 UEP7 T LEN    | 0x400234F4 | Endpoint7 transmit length register                                      | 0xXXXX     |
| R8 UEP7 TX CTRL   | 0x400234F6 | Endpoint7 transmit control register                                     | 0x00       |
| R8 UEP7 RX CTRL   | 0x400234F7 | Endpoint7 receive control register                                      | 0x00       |
| R16 UEP8 T LEN    | 0x400234F8 | Endpoint/ receive control register  Endpoint8 transmit length register  | 0xXXXX     |
| R8 UEP8 TX CTRL   | 0x400234FA | Endpoints transmit tength register  Endpoint8 transmit control register | 0x00       |
| R8 UEP8 RX CTRL   | 0x400234FB | Endpoints transmit control register  Endpoint8 receive control register | 0x00       |
| KO_OELO_KA_CIKL   | UATUU234FD | Liaponito receive control register                                      | UAUU       |

| R16_UEP9_T_LEN   | 0x400234FC | Endpoint9 transmit length register   | 0xXXXX |
|------------------|------------|--------------------------------------|--------|
| R8_UEP9_TX_CTRL  | 0x400234FE | Endpoint9 transmit control register  | 0x00   |
| R8_UEP9_RX_CTRL  | 0x400234FF | Endpoint9 receive control register   | 0x00   |
| R16_UEP10_T_LEN  | 0x40023500 | Endpoint10 transmit length register  | 0xXXXX |
| R8_UEP10_TX_CTRL | 0x40023502 | Endpoint10 transmit control register | 0x00   |
| R8_UEP10_RX_CTRL | 0x40023503 | Endpoint10 receive control register  | 0x00   |
| R16_UEP11_T_LEN  | 0x40023504 | Endpoint11 transmit length register  | 0xXXXX |
| R8_UEP11_TX_CTRL | 0x40023506 | Endpoint11 transmit control register | 0x00   |
| R8_UEP11_RX_CTRL | 0x40023507 | Endpoint11 receive control register  | 0x00   |
| R16_UEP12_T_LEN  | 0x40023508 | Endpoint12 transmit length register  | 0xXXXX |
| R8_UEP12_TX_CTRL | 0x4002350A | Endpoint12 transmit control register | 0x00   |
| R8_UEP12_RX_CTRL | 0x4002350B | Endpoint12 receive control register  | 0x00   |
| R16_UEP13_T_LEN  | 0x4002350C | Endpoint13 transmit length register  | 0xXXXX |
| R8_UEP13_TX_CTRL | 0x4002350E | Endpoint13 transmit control register | 0x00   |
| R8_UEP13_RX_CTRL | 0x4002350F | Endpoint13 receive control register  | 0x00   |
| R16_UEP14_T_LEN  | 0x40023510 | Endpoint14 transmit length register  | 0xXXXX |
| R8_UEP14_TX_CTRL | 0x40023512 | Endpoint14 transmit control register | 0x00   |
| R8_UEP14_RX_CTRL | 0x40023513 | Endpoint14 receive control register  | 0x00   |
| R16_UEP15_T_LEN  | 0x40023514 | Endpoint15 transmit length register  | 0xXXXX |
| R8_UEP15_TX_CTRL | 0x40023516 | Endpoint15 transmit control register | 0x00   |
| R8_UEP15_RX_CTRL | 0x40023517 | Endpoint15 receive control register  | 0x00   |

22.2.2.1 USB Endpoint Configuration Register (R32\_UEP\_CONFIG)

| Bit     | Name        | Access | Description                       | Reset value |
|---------|-------------|--------|-----------------------------------|-------------|
|         |             |        | Endpoint 1 to 15 receive enable:  |             |
| [31:17] | RB_UEP_R_EN | RW     | 0: Disable;                       | 0           |
|         |             |        | 1: Enable.                        |             |
| 16      | Reserved    | RO     | Reserved                          | 0           |
|         |             |        | Endpoint 1 to 15 transmit enable: |             |
| [15:1]  | RB_UEP_T_EN | RW     | 0: Disable;                       | 0           |
|         |             |        | 1: Enable.                        |             |
| 0       | Reserved    | RO     | Reserved                          | 0           |

Note: The transceiver enable signal of endpoint 0 is always valid.

22.2.2.2 USB Endpoint Type Control Register (R32\_UEP\_TYPE)

| Bit     | Name          | Access | Description                                                                                                    | Reset value |
|---------|---------------|--------|----------------------------------------------------------------------------------------------------------------|-------------|
| [31:17] | RB_UEP_R_TYPE | RW     | Endpoint 1 to 15, OUT direction transmission type 0: No Synchronous transmission; 1: Synchronous transmission. | 0           |
| 16      | Reserved      | RO     | Reserved                                                                                                       | 0           |
| [15:1]  | RB_UEP_T_TYPE | RW     | Endpoint 1 to 15, IN direction transmission type                                                               | 0           |

|   |          |    | 0: No Synchronous transmission; |   |
|---|----------|----|---------------------------------|---|
|   |          |    | 1: Synchronous transmission.    |   |
| 0 | Reserved | RO | Reserved                        | 0 |

22.2.2.3 USB Endpoint Buffer Mode Control Register (R32\_UEP\_BUF\_MOD)

| Bit     | Name                   | Access | Description                                           | Reset value |
|---------|------------------------|--------|-------------------------------------------------------|-------------|
| [31:16] | RB_UEP_ISO_BUF<br>_MOD | RW     | Synchronous endpoint buffer mode control, 1 is valid. | 0           |
| [15:0]  | RB_UEP_BUF_MOD         | RW     | Endpoint buffer mode control                          | 0           |

Note: When RB\_UEP\_ISO\_BUF\_MOD is 1, for the synchronous IN endpoint, after receiving the SOF packet, the hardware will perform the following operations: load the content of EPx\_R\_TOG into EPx\_T\_TOG; load the value of EPx\_MAX\_LEN into EPx\_T\_LEN; load the value of UEPn\_RX\_DMA into UEPn\_TX\_DMA. When RB\_UEP\_ISO\_BUF\_MOD is 1, for the synchronous OUT endpoint, after receiving the SOF packet, the hardware will perform the following operations: load the content of EPx\_T\_TOG into EPx\_R\_TOG; load the value of UEPn\_TX\_DMA into UEPn\_RX\_DMA.

Table 21-3 Endpoint n buffer mode (n=1-15)

| UEPn_RX_EN | UEPn_TX_EN | UEPn_BUF_MOD | Description: Arrange from low to high with UEPn_DMA as the starting address             |
|------------|------------|--------------|-----------------------------------------------------------------------------------------|
| 0          | 0          | X            | The endpoint is disabled and the UEPn_*_DMA buffers are not used.                       |
| 1          | 0          | 0            | The first address of the receive (OUT) buffer is UEPn_RX_DMA                            |
| 1          | 0          | 1            | RB_UEPn_RX_TOG[0]=0, use buffer UEPn_RX_DMA RB_UEPn_RX_TOG[0]=1, use buffer UEPn_TX_DMA |
| 0          | 1          | 0            | The first address of the transmit (IN) buffer is UEPn_TX_DMA.                           |
| 0          | 1          | 1            | RB_UEPn_TX_TOG[0]=0, use buffer UEPn_TX_DMA RB_UEPn_TX_TOG[0]=1, use buffer UEPn_RX_DMA |

22.2.2.4 Endpoint n buffer start address (R32\_UEP0\_DMA)

|   | Bit    | Name            | Access | Description                         | Reset value |
|---|--------|-----------------|--------|-------------------------------------|-------------|
| ĺ | [31:0] | R32_UEPn_DMA[31 | RW     | Endpoint 0 buffer start address.    | v           |
|   | [31.0] | :0]             | KW     | The address must be 4-byte aligned. | Λ           |

22.2.2.5 USB Endpoint n transmit buffer start address (R32\_UEPn\_TX\_DMA) (n=1-15)

| Bit    | Name           | Access | Description                           | Reset value |
|--------|----------------|--------|---------------------------------------|-------------|
| [31:0] | R32_UEPn_TX_DM | RW     | Endpoint n send buffer start address. | Y           |
| [31:0] | A[31:0]        | IXVV   | The address must be 4-byte aligned.   | Λ           |

22.2.2.6 USB Endpoint n receive buffer start address (R32\_UEPn\_RX\_DMA) (n=1-15)

| Bit    | Reserved        | Access | Description                                   | Reset value |
|--------|-----------------|--------|-----------------------------------------------|-------------|
| [31:0] | R32_UEPn_RX_DM[ | RW     | Endpoint n receives the buffer start address. | X           |

| 31:0]A | The address must be 4-byte aligned. |  |
|--------|-------------------------------------|--|
| _      | , ,                                 |  |

#### 22.2.2.7 Endpoint n maximum length packet register (R16\_UEPn\_MAX\_LEN) (n=0-15)

| Bit     | Reserved        | Access | Description                       | Reset value |
|---------|-----------------|--------|-----------------------------------|-------------|
| [15:11] | Reserved        | RO     | Reserved                          | 0           |
| [10:0]  | UEPn_MAX_LEN[10 | RW     | The maximum packet length of data | xxxxh       |
|         | [0:             |        | received by endpoint n.           |             |

Note: This maximum packet length determines the maximum length of data that the endpoint can receive. Data beyond this length will be discarded and will not be written to the buffer.

22.2.2.8 Endpoint n transmit length register (R16 UEPn T LEN) (n=0-15)

| Bit    | Reserved         | Access | Description                                   | Reset value |
|--------|------------------|--------|-----------------------------------------------|-------------|
|        |                  |        | Set the number of data bytes to be sent by    |             |
| [10:0] | UEPn_T_LEN[10:0] | RW     | USB endpoint n. For the control endpoint (0), | X           |
|        |                  |        | the lower 7 bits are valid.                   |             |

22.2.2.9 Endpoint n transmit control register (R8 UEPn TX CTRL) (n=0-15)

| Bit   | Name                    | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                 | Reset value |
|-------|-------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [7:6] | Reserved                | RO     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                    | 0           |
| 5     | RB_UEP_T_TOG_<br>AUTO   | RW     | Synchronization trigger bit auto toggle enable, which can be modified by software:  0: No automatic toggle, can be switched manually;  1: For non-synchronous endpoints,  MASK_UEP_T_TOG [0] is automatically toggled after data transmission is successful. For synchronous endpoints,  MASK_UEP_T_TOG is automatically decremented by 1 after data transmission is successful.  Note: This bit of endpoint 0 is reserved. | 0           |
| [4:3] | MASK_UEP_T_T<br>OG[1:0] | RW     | Synchronization trigger bit prepared by the transmitter of USB endpoint n (Handling IN transaction): 00: Transmit DATA0; 01: Transmit DATA1; 10: Transmit DATA2; 11: Transmit MDATA.                                                                                                                                                                                                                                        | 0           |
| 2     | Reserved                | RO     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                    | 00b         |
| [1:0] | MASK_UEP_T_R<br>ES[1:0] | RW     | Response control by the sender of endpoint n to IN transaction: 00: Data ready and expecting ACK; 01: Reserved; 10: Answer NAK or busy;                                                                                                                                                                                                                                                                                     | 00Ь         |

|  | 11: Response STALL or error. |  |
|--|------------------------------|--|
|  |                              |  |
|  |                              |  |

22.2.2.10 Endpoint n receive control register (R8\_UEPn\_RX\_CTRL) (n=0-15)

| Bit   | Name                  | Access | Description                                                                                                                                                                                                                    | Reset value |
|-------|-----------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [7:6] | Reserved              | RO     | Reserved                                                                                                                                                                                                                       | 0           |
| 5     | RB_UEP_R_TOG_A<br>UTO | RO     | Synchronization trigger bit auto toggle enable:  0: No automatic toggle, can be switched manually;  1: Automatically toggle  MASK_UEP_R_TOG [0] after data reception is successful.  Note: This bit of endpoint 0 is reserved. | 0           |
| [4:3] | MASK_UEP_R_TOG [1:0]  | RW     | Sync trigger bit prepared by receiver of USB endpoint n (Processing OUT transaction): 00: Expect DATA0; 01: Expect DATA1; 10: Expect DATA2; 11: Expect MDATA. Invalid for isochronous transfer.                                | 0           |
| 2     | Reserved              | RO     | Reserved                                                                                                                                                                                                                       | 00b         |
| [1:0] | MASK_UEP_R_RES [1:0]  | RW     | Receiver of endpoint n responds to OUT transaction control: 00: Data ready and expect ACK; 01: Respond to NYET; 10: Answer NAK or busy; 11: Response STALL or error. Not valid for real time/isochronous transfers.            | 00b         |

#### 22.2.3 USB Host Register

In USB host mode, the chip provides a set of bidirectional host endpoints, including a sending endpoint OUT and a receiving endpoint IN, the maximum length of a data packet is 1024 bytes (Synchronous transfer), and supports control transfer, interrupt transfer, bulk transfer and real-time/simultaneous transmission.

Each USB transaction initiated by the host endpoint always automatically sets the RB\_UIF\_TRANSFER interrupt flag after processing. The application can directly query or query and analyze the interrupt flag register R8\_USB\_INT\_FG in the USB interrupt service routine, and perform corresponding processing according to each interrupt flag; and, if RB\_UIF\_TRANSFER is valid, then continue to analyze the USB interrupt status register R8\_USB\_INT\_ST, process accordingly according to the response PID identification MASK UIS H RES of the current USB transfer transaction.

If the synchronization trigger bit (RB\_UH\_R\_TOG) of the IN transaction of the host receiving endpoint is set in advance, then RB\_U\_TOG\_OK or RB\_UIS\_TOG\_OK can be used to judge whether the synchronization

trigger bit of the currently received data packet matches the synchronization trigger bit of the host receiving endpoint. If synchronized, the data is valid; if the data is not synchronized, the data should be discarded. After each USB send or receive interrupt is processed, the synchronization trigger bit of the corresponding host endpoint should be modified correctly to synchronize the data packet sent next time and detect whether the data packet received next time is synchronized; in addition, by setting RB UH T AUTO TOG and RB UH R AUTO TOG can automatically flip the corresponding synchronization trigger bit after successful transmission or successful reception.

The USB host token setting register R8 UH EP PID is used to set the endpoint number of the target device to be operated and the token PID packet identification of this USB transfer transaction. The data corresponding to the SETUP token and the OUT token is provided by the host sending endpoint, the data to be sent is in the R16 UH TX DMA buffer, and the length of the data to be sent is set in R16 UH TX LEN; the data corresponding to the IN token is returned by the target device to the host for reception Endpoint, the received data is stored in the R16 UH RX DMA buffer, and the received data length is stored in R16 USB RX LEN.

Table 22-3 Host registers

| Name              | Access address | Description                                     | Reset value |
|-------------------|----------------|-------------------------------------------------|-------------|
| R8_UHOST_CTRL     | 0x40023401     | USB host control register                       | 0x00        |
| R32_UH_CONFIG     | 0x40023410     | USB host endpoint configuration register        | 0x00000000  |
| R32_UH_EP_TYPE    | 0x40023414     | USB host endpoint type register                 | 0x00000000  |
| R32_UH_RX_DMA     | 0x40023424     | USB host receive buffer start address           | 0x0000XXXX  |
| R32_UH_TX_DMA     | 0x40023464     | USB host transmit buffer start address          | 0x0000XXXX  |
| R16_UH_RX_MAX_LEN | 0x400234A0     | USB host receive maximum length packet register | 0xXXXX      |
| R8_UH_EP_PID      | 0x400234E0     | USB host token setup register                   | 0x00        |
| R8_UH_RX_CTRL     | 0x400234E3     | USB host receive endpoint control register      | 0x00        |
| R16_UH_TX_LEN     | 0x400234E4     | USB host transmit length register               | 0xXXXX      |
| R8_UH_TX_CTRL     | 0x400234E6     | USB host transmit endpoint control Register     | 0x00        |
| R16_UH_SPLIT_DATA | 0x400234E8     | USB host transmit data of the SPLIT packet      | 0xXXXX      |

22.2.3.1 USB Host Control Register (R8 UHOST CTRL)

| Bit | Name           | Access | Description                                                                                                                                                                                                                                  | Reset value |
|-----|----------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| 7   | RB_UH_SOF_EN   | RW     | Automatically generate SOF packet enable control bit:  0: Do not generate SOF packets;  1: The host automatically generates a SOF packet.  This bit is automatically cleared by hardware when changing from connected to disconnected state. | 0           |
| 6   | RB_UH_SOF_FREE | RO     | Bus Idle.                                                                                                                                                                                                                                    | 0           |
| 5   | Reserved       | RO     | Reserved.                                                                                                                                                                                                                                    | 0           |
| 4   | RB_UH_PHY_SUS  | RW     | The USB-PHY is in a suspended state, the                                                                                                                                                                                                     | 0           |

|   | PENDM                    |    | internal USB-PLL will be turned off,                                                                                                                         |   |
|---|--------------------------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
|   |                          |    | active low.                                                                                                                                                  |   |
| 3 | RB_UH_REMOTE_<br>WKUP    | RW | Wake up remotely.                                                                                                                                            | 0 |
| 2 | RB_UH_TX_BUS_<br>RESUME  | RW | In host mode, it means that the host wakes up the device. After the software pulls it high for 50ns, the hardware automatically sends a 30ms wake-up signal. | 0 |
| 1 | RB_UH_TX_BUS_<br>SUSPEND | RW | The USB host sends a suspend signal, which needs to be pulled up by software for 10ms.                                                                       | 0 |
| 0 | RB_UH_TX_BUS_<br>RESET   | RW | The USB host sends a bus reset signal, which needs to be pulled up by software for 10ms.                                                                     | 0 |

Note: The reset time is determined by the high-level duration of RB\_UH\_TX\_BUS\_RESET (Recommended at least 10ms, and the speed type is directly inquired after 10ms). If the host wakes up the device, after bUH\_TX\_BUS\_RESUME is pulled high, the hardware automatically sends a wake-up signal (K) for 30ms, and bUH\_TX\_BUS\_RESUME needs to be cleared manually so as not to affect the next host suspend (bUH\_TX\_BUS\_RESUME remains high for at least 50ns).

22.2.3.2 USB Host Endpoint Configuration Control Register (R32\_UH\_CONFIG)

| Bit      | Name           | Access | Description           | Reset value |
|----------|----------------|--------|-----------------------|-------------|
| [31: 19] | Reserved       | RO     | Reserved              | 0           |
|          |                |        | Host receive enable:  |             |
| 18       | RB_UH_EP_RX_EN | RW     | 1: Disable;           | 0           |
|          |                |        | 0: Enable.            |             |
| [17:4]   | Reserved       | RO     | Reserved              | 0           |
|          |                |        | Host transmit enable: |             |
| 3        | RB_UH_EP_TX_EN | RW     | 1: Disable;           | 0           |
|          |                |        | 0: Enable.            |             |
| [2:0]    | Reserved       | RO     | Reserved              | 0           |

22.2.3.3 USB Host Endpoint Type Register (R32 UH EP TYPE)

| Bit     | Name                 | Access | Description                                                                       | Reset value |
|---------|----------------------|--------|-----------------------------------------------------------------------------------|-------------|
| [31:19] | Reserved             | RO     | Reserved                                                                          | 0           |
| [18]    | RB_UH_EP_RX_TY<br>PE | RW     | Host Rx endpoint type 0: Asynchronous transmission; 1: Synchronized transmission. | 0           |
| [17:4]  | Reserved             | RO     | Reserved                                                                          | 0           |
| [3]     | RB_UH_EP_TX_TY<br>PE | RW     | Host Tx endpoint type 0: Asynchronous transmission; 1: Synchronized transmission. | 0           |
| [2:0]   | Reserved             | RO     | Reserved                                                                          | 0           |

22.2.3.4 USB Host Receive Buffer Start Address (R32\_UH\_RX\_DMA)

| Bit     | Name                    | Access | Description                                                                                        | Reset value |
|---------|-------------------------|--------|----------------------------------------------------------------------------------------------------|-------------|
| [31:17] | Reserved                | RO     | Reserved                                                                                           | 0           |
| [16:0]  | R16_UH_RX_DMA[1<br>6:0] | RW     | Start address of the host endpoint Rx buffer, the lowest 2 bits are fixed to 0 (4-byte alignment). | X           |

22.2.3.5 USB Host Transmit Buffer Start Address (R32 UH TX DMA)

| Bit     | Name                 | Access | Description                                                               | Reset value |
|---------|----------------------|--------|---------------------------------------------------------------------------|-------------|
| [31:17] | Reserved             | RO     | Reserved                                                                  | 0           |
| [16:0]  | R16_UH_TX_DMA[16 :0] | RW     | Host endpoint Tx buffer start address (4-byte alignment is not required). | X           |

22.2.3.6 USB Host Receive Maximum Length Packet Register (R16 UH RX MAX LEN)

| Bit     | Name                 | Access | Description                                                      | Reset value |
|---------|----------------------|--------|------------------------------------------------------------------|-------------|
| [15:11] | Reserved             | RO     | Reserved                                                         | 0           |
| [10:0]  | UH_RX_MAX_LEN[1 0:0] | RW     | The maximum packet length of data received by the host endpoint. | xxxxh       |

Note: This maximum packet size determines the maximum length of data that the endpoint can receive, and data beyond this length will be discarded.

22.2.3.7 USB Host Token Setup Register (R8 UH EP PID)

| Bit   | Name                | Access | Description                                                            | Reset value |  |
|-------|---------------------|--------|------------------------------------------------------------------------|-------------|--|
| [7:4] | MASK_UH_TOKEN[3 :0] | RW     | Set the token PID identifier of this USB transfer transaction.         | 0           |  |
| [3:0] | MASK_UH_ENDP[3:0    | RW     | Set the endpoint number of the target device to be operated this time. | 0           |  |

22.2.3.8 USB Host Receive Endpoint Control Register (R8\_UH\_RX\_CTRL)

| Bit | Name            | Access | Description                                                                                                                                                                                                                                                                            | Reset value |
|-----|-----------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| 7   | Reserved        | RO     | Reserved                                                                                                                                                                                                                                                                               | 0           |
| 6   | RB_UH_R_DATA_NO | RW     | 0: Expect data packet (IN); 1: Not expect data packets, used for operating high-speed HUB in host mode.                                                                                                                                                                                | 0           |
| 5   | RB_UH_R_AUTO_TO | RW     | Synchronization trigger bit auto toggle enable:  0: No automatic toggle, can be switched manually;  1: For asynchronous transfer, the corresponding MASK_UH_R_TOG[0] will be automatically toggled after data reception is successful; for synchronous transfer, MASK UH R TOG will be | 0           |

|       |                       |    | automatically decremented by 1 after data reception is successful. |   |
|-------|-----------------------|----|--------------------------------------------------------------------|---|
|       |                       |    | Synchronization trigger bit expected by                            |   |
|       |                       |    | the master receiver (Handling the IN                               |   |
|       |                       |    | transaction),                                                      |   |
| [4:3] | MASK_UH_R_TOG         | RW | 00: Expect DATA0;                                                  | 0 |
|       |                       |    | 01: Expect DATA1;                                                  |   |
|       |                       |    | 10: Expect DATA2;                                                  |   |
|       |                       |    | 11: Expect MDATA.                                                  |   |
|       |                       |    | 0: Transmit a response after receiving                             |   |
|       |                       | RW | data successfully;                                                 |   |
| 2     | RB UH R RES NO        |    | 1: No acknowledgment, for real-                                    | 0 |
| 2     | KD_UII_K_KES_NO       | KW | time/isochronous transfers other than                              | U |
|       |                       |    | endpoint. MASK_UEP_R_RES is                                        |   |
|       |                       |    | ignored at this time.                                              |   |
|       |                       |    | Master receiver response control bits to                           |   |
| [1:0] | MASK UH R RES[1:      |    | IN transactions:                                                   |   |
|       | MASK_UH_K_KES[1.   0] | RW | 00: reply ACK;                                                     | 0 |
|       | V]                    |    | Not valid for real-time/isochronous                                |   |
|       |                       |    | transfers.                                                         |   |

22.2.3.9 USB Host Transmit Length Register (R16\_UH\_TX\_LEN)

| Bit     | Name              | Access | Description                             | Reset value |
|---------|-------------------|--------|-----------------------------------------|-------------|
| [15:11] | Reserved          | RO     | Reserved                                | 0           |
| [10:0]  | R16_UH_TX_LEN[10: | RW     | Set the data bytes that the USB host    | v           |
| [10.0]  | 0]                | IX VV  | transmit endpoint is ready to transmit. | Λ           |

22.2.3.10 USB Host Transmit Endpoint Control Register (R8\_UH\_TX\_CTRL)

| Bit   | Name            | Access | Description                                                                                                                                                                                                                                      | Reset value |
|-------|-----------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| 7     | Reserved        | RO     | Reserved                                                                                                                                                                                                                                         | 0           |
| 6     | RB_UH_T_DATA_NO | RW     | O: Transmit data packets (OUT/SETUP);     1: Do not send data packets (PING/SPLIT).                                                                                                                                                              | 0           |
| 5     | RB_UH_T_AUTO_TO | RW     | Synchronization trigger bit auto toggle enable, which can be modified by software:  0: No automatic toggle, can be switched manually;  1: For asynchronous transfer,  MASK_UH_T_TOG[0] is automatically toggled after data is sent successfully. | 0           |
| [4:3] | MASK_UH_T_TOG   | RW     | Sync trigger bit prepared by USB host transmitter (Handling SETUP/OUT transactions) 00: Transmit DATA0;                                                                                                                                          | 0           |

|       |                     |    | 01: Transmit DATA1;<br>10: Transmit DATA2;                                                                                                                                                                                        |   |
|-------|---------------------|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
|       |                     |    | 11: Transmit MDATA.                                                                                                                                                                                                               |   |
| 2     | RB_UH_T_RES_NO      | RW | 0: Expect a response after sending data successfully; 1: No acknowledgment, for real-time/isochronous transfers other than endpoint0. MASK_UEP_T_RES is ignored at this time.                                                     | 0 |
| [1:0] | MASK_UH_T_RES[1: 0] | RW | USB Host transmitter response control bits to SETUP/OUT transactions 00: Expect to reply ACK; 01: Expect to answer NYET; 10: expect to answer NAK or busy; 11: Expect to answer STALL or error. Invalid for isochronous transfer. | 0 |

22.2.3.11 USB Host Transmit SPLIT Packet Data (R16\_UH\_SPLIT\_DATA)

| Bit     | Name          | Access | Description                                                                                                                   | Reset value |
|---------|---------------|--------|-------------------------------------------------------------------------------------------------------------------------------|-------------|
| [15:12] | Reserved      | RO     | Reserved                                                                                                                      | 0           |
| [11:0]  | UH_SPLIT_DATA | RW     | Data content of the SPLIT packet sent by the host endpoint, the lower 12 bits are valid, and the upper 4 bits are fixed to 0. | 0xxxh       |

# Chapter 23 USB Full-speed Host/Device Controller (USBFS/OTG FS)

This chapter applies to the whole family of CH32F20x, CH32V20x, CH32V30x and CH32V31x.

#### 23.1 USB Controller Introduction

The chip is embedded with a USB controller and transceiver, and the features include:

- Dual-role device controller, supporting USB Host function and USB Device function.
- Compliant with the On-The-Go Supplement to the USB2.0 specification, both host and device modes support USB2.0 full-speed 12Mbps or low-speed 1.5Mbps.
- Support software HNP and SRP protocols.
- Support USB control transfer, batch transfer, interrupt transfer, synchronous/real-time transfer.
- Supports data packets up to 64 bytes, built-in FIFO, supports interrupts and DMA.

#### 23.2 Register Description

The USB registers are divided into 3 parts, and some registers are multiplexed in the host and device modes.

- USB global registers
- USB device control registers
- USB host control registers

#### 23.2.1 Global Register Description

Table 23-1 USB OTG registers

| Name           | Access address | Description                       | Reset value |
|----------------|----------------|-----------------------------------|-------------|
| R8_USB_CTRL    | 0x50000000     | USB control register              | 0x06        |
| R8_USB_INT_EN  | 0x50000002     | USB interrupt enable register     | 0x00        |
| R8_USB_DEV_AD  | 0x50000003     | USB Device address register       | 0x00        |
| R8_USB_MIS_ST  | 0x50000005     | USB miscellaneous status register | 0xXX        |
| R8_USB_INT_FG  | 0x50000006     | USB interrupt flag register       | 0x20        |
| R8_USB_INT_ST  | 0x50000007     | USB interrupt status register     | 0xXX        |
| R16_USB_RX_LEN | 0x50000008     | USB receive length register       | 0x0XXX      |
| R32_USB_OTG_CR | 0x50000054     | USB OTG control register          | 0x00000000  |
| R32_USB_OTG_SR | 0x50000058     | USB OTG status register           | 0x0000000X  |

23.2.1.1 USB Control Register (R8\_USB\_CTRL)

| Bit | Name                | Access | Description                                                    | Reset value |
|-----|---------------------|--------|----------------------------------------------------------------|-------------|
| 7   | RB_UC_HOST_M<br>ODE | RW     | USB operating mode selection: 0: Device mode; 1: Host mode.    | 0           |
| 6   | RB_UC_LOW_SPE<br>ED | RW     | USB bus signal transfer rate selection: 0: 12Mbps; 1: 1.5Mbps. | 0           |

|       | RB_UC_DEV_PU_  |      | USB device enable and internal pull-up resistor control in USB device mode: |   |
|-------|----------------|------|-----------------------------------------------------------------------------|---|
| 5     | EN             | RW   | 1: Enable USB device transfer and enable the                                | 0 |
|       |                |      | internal pull-up resistor.                                                  |   |
| [5:4] | MASK_UC_SYS_C  | RW   | See the table below to configure the USB                                    | 0 |
| [3.4] | TRL            | 1000 | system.                                                                     |   |
|       |                |      | Auto pause enable bit before USB transfer                                   |   |
|       |                |      | completed interrupt flag is not cleared:                                    |   |
|       | RB UC INT BUS  |      | 0: Not pause;                                                               |   |
| 3     | Y              | RW   | 1: Auto pause before UIF_TRANSFER is                                        | 0 |
|       | 1              |      | cleared, auto respond busy NAK in device                                    |   |
|       |                |      | mode, and auto pause subsequent transfers in                                |   |
|       |                |      | host mode.                                                                  |   |
|       |                |      | USB protocol processor software reset                                       |   |
|       | RB UC RESET SI |      | control:                                                                    |   |
| 2     | E              | RW   | 0: No reset;                                                                | 1 |
|       | L              |      | 1: Forcibly reset the USB protocol processor                                |   |
|       |                |      | (SIE), which needs to be cleared by software.                               |   |
|       |                |      | USB FIFO and interrupt flags clear:                                         |   |
| 1     | RB_UC_CLR_ALL  | RW   | 0: Not clear;                                                               | 1 |
|       |                |      | 1: Forced clearing and clearing.                                            |   |
|       |                |      | DMA and DMA interrupt control for USB:                                      |   |
| 0     | RB_UC_DMA_EN   | RW   | 0: Disable DMA;                                                             | 0 |
|       |                |      | 1: Enable DMA function and DMA interrupt.                                   |   |

The USB system control combination is composed of RB\_UC\_HOST\_MODE and MASK\_UC\_SYS\_CTRL:

Table 23-2 USB System control combination

| RB_UC_HOST_MODE | MASK_UC_SYS_CTRL | USB system control description                     |
|-----------------|------------------|----------------------------------------------------|
| 0               | 00               | Disable the USB device function, turn off the      |
| Ů               | 00               | internal pull-up resistor.                         |
|                 |                  | Enable the USB device function, close the          |
| 0               | 01               | internal pull-up resistor, and need to add an      |
|                 |                  | external pull-up.                                  |
|                 |                  | Enable USB device function, enable internal        |
|                 | 1,,              | 1.5K pull-up resistor. This pull-up resistor takes |
| 0               | 1x               | precedence over the pull-down resistor and can     |
|                 |                  | also be used in GPIO mode.                         |
| 1               | 00               | USB host mode, normal working state.               |
| 1               | 0.1              | USB host mode, forcing DP/DM to output SE0         |
|                 | 01               | state.                                             |
| 1               | 10               | USB host mode, forces DP/DM to output J state.     |
| 1               | 11               | USB host mode, force DP/DM to output K             |
| I               | 11               | state/wake up.                                     |

23.2.1.2 USB Interrupt Enable Register (R8\_USB\_INT\_EN)

| Bit | Name            | Access | Description                                                                                                                                                                                                  | Reset value |
|-----|-----------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| 7   | Reserved        | RO     | Reserved                                                                                                                                                                                                     | 0           |
| 6   | RB_UIE_DEV_NAK  | RW     | USB device mode, receive NAK interrupt:  0: Disable interrupt; 1: Enable interrupt.                                                                                                                          | 0           |
| 5   | RB_U_1WIRE_MODE | RW     | USB 1-wire mode enable: 0: Disable USB 1-wire mode; 1: Enable USB 1-wire mode.  Note: Only for CH32F20x_D8C, CH32V30x_D8, CH32V30x_D8C, CH32V31x_D8C lot numbers where the penultimate sixth digit is not 0. | 0           |
| 4   | RB_UIE_FIFO_OV  | RW     | FIFO overflow interrupt:  0: Disable interrupt; 1: Enable interrupt.                                                                                                                                         | 0           |
| 3   | RB_UIE_HST_SOF  | RW     | USB host mode, SOF timing interrupt:  0: Disable interrupt; 1: Enable interrupt.                                                                                                                             | 0           |
| 2   | RB_UIE_SUSPEND  | RW     | USB bus suspend or wakeup event interrupt:  0: Disable interrupt; 1: Enable interrupt.                                                                                                                       | 0           |
| 1   | RB_UIE_TRANSFER | RW     | USB transfer complete interrupt:  0: Disable interrupt; 1: Enable interrupt.                                                                                                                                 | 0           |
| 0   | RB_UIE_DETECT   | RW     | USB host mode, USB device connect or disconnect event interrupt:  0: Disable interrupt; 1: Enable interrupt.                                                                                                 | 0           |
| 0   | RB_UIE_BUS_RST  | RW     | USB device mode, USB bus reset event interrupt:  0: Disable interrupt; 1: Enable interrupt.                                                                                                                  | 0           |

23.2.1.3 USB Device Address Register (R8 USB DEV AD)

| - |       |               |        | <u> </u>                                |             |
|---|-------|---------------|--------|-----------------------------------------|-------------|
|   | Bit   | Name          | Access | Description                             | Reset value |
| İ | 7     | RB_UDA_GP_BIT | RW     | USB general-purpose flag, user-defined. | 0           |
| ĺ |       |               |        | Host mode: current operated USB device  |             |
| ı | [6:0] | MASK_USB_ADDR | RW     | address;                                | 0           |
| ı |       |               |        | Device Mode: USB own address.           |             |

23.2.1.4 USB Miscellaneous Status Register (R8\_USB\_MIS\_ST)

| Bit | Name            | Access | Description                                                                                                                                                                                             | Reset value |
|-----|-----------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| 7   | RB_UMS_SOF_PRES | RO     | SOF packet presage status in USB host mode:  0: No SOF packet is transmitted;  1: SOF packet is about to be transmitted, if there are other USB packets at this time, it will be automatically delayed. | X           |

| RB_UMS_SOF_ACT   RO   mode: 0: Transmit complete or idle; 1: SOF packet is being transmitted.   USB protocol handler free: 0: Busy, USB transfer in progress; 1 1: The protocol device is free.   USB receive FIFO data ready: 0: The receive FIFO is not empty.   USB bus reset: 0: The current USB bus is in a non-reset state; 1: The current USB bus is in a non-reset state; 1: The current USB bus is in reset state.   USB suspend: 0: The USB bus is in a non-suspend state; 1: The USB bus is in a suspended state, and there is no USB activity for a period of time.   In USB host mode, level state of the DM pin when the device is just connected to the USB port is used to judge the speed: 0: Low level/full-speed; 1: High level/low-speed.   USB device attach status for the port in USB host mode: 0: The port has no USB device connected; 0 1: The port has been connected to a USB   USB host mode: 0: The port has been connected to a USB   USB host mode: 0: The port has been connected to a USB   USB host mode: 0: The port has been connected to a USB   USB host mode: 0: The port has been connected to a USB   USB host mode: 0: The port has no USB device connected; 0 1: The port has been connected to a USB   USB host mode: 0: The port has been connected to a USB   USB host mode: 0: The port has been connected to a USB   USB host mode: 0: The port has been connected to a USB   USB host mode: 0: The port has been connected to a USB   USB host mode: 0: The port has been connected to a USB   USB host mode: 0: The port has been connected to a USB   USB host mode: 0: The port has been connected to a USB   USB host mode: 0: The port has been connected to a USB   USB host mode: 0: The port has been connected to a USB   USB host mode: 0: The port has been connected to a USB   USB host mode: 0: The port has been connected to a USB   USB host mode: 0: The port has been connected to a USB   USB host mode: 0: The port has been connected to a USB   USB host mode: 0: The port has been connected to a USB   USB host mode: 0: The port has been conne   |   |                  |     | COE 1 C LICE 1 .                          |   |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|------------------|-----|-------------------------------------------|---|
| 6 RB_UMS_SOF_ACT RO 0: Transmit complete or idle; 1: SOF packet is being transmitted.  USB protocol handler free: 0: Busy, USB transfer in progress; 1: The protocol device is free.  USB receive FIFO data ready: 0: The receive FIFO is empty; 1: The receive FIFO is not empty.  USB bus reset: 0: The current USB bus is in a non-reset state; 1: The current USB bus is in reset state.  USB suspend: 0: The USB bus is in a non-suspend state; 1: The USB bus is in a suspended state, and there is no USB activity for a period of time.  RB_UMS_DM_LEVE L  RO RB_UMS_DM_LEVE L  RO RB_UMS_DM_LEVE L  RO RB_UMS_DEV_ATTA CH  RO RB_UMS_DEV_ATTA CH  RO RB_UMS_DEV_ATTA CH  RO RB_UMS_DEV_ATTA CH  RO RB_UMS_DEV_ATTA CH  RO RB_UMS_DEV_ATTA CH  RO RB_UMS_DEV_ATTA CH  RO RB_UMS_DEV_ATTA CH  RO RB_UMS_DEV_ATTA CH  RO RB_UMS_DEV_ATTA CH  RO RB_UMS_DEV_ATTA CH  RO RB_UMS_DEV_ATTA CH  RO RB_UMS_DEV_ATTA CH  RO RB_UMS_DEV_ATTA CH  RO RB_UMS_DEV_ATTA CH  RO RB_UMS_DEV_ATTA CH  RO RB_UMS_DEV_ATTA CH  RO RB_UMS_DEV_ATTA CH  RO RB_UMS_DEV_ATTA CH  RO RB_UMS_DEV_ATTA CH  RO RB_UMS_DEV_ATTA CH  RO RB_UMS_DEV_ATTA CH  RO RB_UMS_DEV_ATTA CH  RO RB_UMS_DEV_ATTA CH  RO RB_UMS_DEV_ATTA CH  RO RB_UMS_DEV_ATTA CH  RO RB_UMS_DEV_ATTA CH  RO RB_UMS_DEV_ATTA CH  RO RB_UMS_DEV_ATTA CH  RO RB_UMS_DEV_ATTA CH  RO RB_UMS_DEV_ATTA CH  RO RB_UMS_DEV_ATTA CH  RO RB_UMS_DEV_ATTA CH  RO RB_UMS_DEV_ATTA CH  RO RB_UMS_DEV_ATTA CH  RO RB_UMS_DEV_ATTA CH  RO RB_UMS_DEV_ATTA CH  RO RB_UMS_DEV_ATTA CH  RO RD RB_UMS_DEV_ATTA CH  RO RD RB_UMS_DEV_ATTA CH  RO RD RB_UMS_DEV_ATTA CH  RO RD RB_UMS_DEV_ATTA CH  RO RD RB_UMS_DEV_ATTA CH  RD RD RB_UMS_DEV_ATTA CH  RD RD RB_UMS_DEV_ATTA CH  RD RB_UMS_DEV_ATTA CH  RD RB_UMS_DEV_ATTA CH  RD RB_UMS_DEV_ATTA CH  RD RB_UMS_DEV_ATTA CH  RD RB_UMS_DEV_ATTA CH  RD RB_UMS_DEV_ATTA CH  RD RB_UMS_DEV_ATTA CH  RD RB_UMS_DEV_ATTA CH  RD RB_UMS_DEV_ATTA CH  RD RB_UMS_DEV_ATTA CH  RD RB_UMS_DEV_ATTA CH  RD RB_UMS_DEV_ATTA CH  RD RB_UMS_DEV_ATTA CH  RD RB_UMS_DEV_ATTA CH  RD RB_UMS_DEV_ATTA CH  RD RB_UMS_DEV_ATTA CH  RD RB_UMS_DEV_ATTA CH  RD RB_UMS_ |   |                  | RO  | SOF packet transfer status in USB host    | X |
| 1: SOF packet is being transmitted.  USB protocol handler free:  0: Busy, USB transfer in progress; 1: The protocol device is free.  USB receive FIFO data ready: 0: The receive FIFO is mpty; 1: The receive FIFO is not empty.  USB bus reset: 0: The current USB bus is in a non-reset state; 1: The current USB bus is in a non-reset state; 1: The current USB bus is in a suspended state; 1: The USB bus is in a suspended state; 1: The USB bus is in a suspended state, and there is no USB activity for a period of time.  In USB host mode, level state of the DM pin when the device is just connected to the USB port is used to judge the speed: 0: Low level/full-speed; 1: High level/low-speed.  USB device attach status for the port in USB host mode: 0: The port has no USB device connected; 1: The port has no USB device connected; 1: The port has been connected to a USB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 6 | RB_UMS_SOF_ACT   |     |                                           |   |
| USB protocol handler free:  1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |   |                  |     | •                                         |   |
| S RB_UMS_SIE_FREE RO 0: Busy, USB transfer in progress; 1 1: The protocol device is free.  USB receive FIFO data ready: 0: The receive FIFO is empty; 0 1: The receive FIFO is not empty.  USB bus reset: 0: The current USB bus is in a non-reset state; 1: The current USB bus is in a non-reset state; 1: The USB bus is in a non-suspend state; 1: The USB bus is in a suspended state, and there is no USB activity for a period of time.  RB_UMS_DM_LEVE L  RB_UMS_DM_LEVE L  RB_UMS_DM_LEVE L  RB_UMS_DM_LEVE L  RB_UMS_DEV_ATTA CH RO CH CH CH CH CH CH CH CH CH CH CH CH CH                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |                  |     |                                           |   |
| 1: The protocol device is free.  USB receive FIFO data ready: 0: The receive FIFO is empty; 1: The receive FIFO is not empty.  USB bus reset: 0: The current USB bus is in a non-reset state; 1: The current USB bus is in reset state.  USB suspend: 0: The USB bus is in a non-suspend state; 1: The USB bus is in a non-suspend state; and there is no USB activity for a period of time.  RB_UMS_DM_LEVE L  RO  RB_UMS_DM_LEVE L  RO  RB_UMS_DM_LEVE L  RO  RB_UMS_DM_LEVE L  RO  RB_UMS_DM_LEVE L  RO  RB_UMS_DM_LEVE L  RO  RB_UMS_DEV_ATTA CH  RO  RB_UMS_DEV_ATTA CH  RO  RB_UMS_DEV_ATTA CH  RO  RB_UMS_DEV_ATTA CH  RO  RD  RB_UMS_DEV_ATTA CH  RO  RB_UMS_DEV_ATTA CH  RO  RO  RB_UMS_DEV_ATTA CH  RO  RO  RB_UMS_DEV_ATTA CH  RO  RO  RB_UMS_DEV_ATTA CH  RO  RO  RB_UMS_DEV_ATTA CH  RO  RO  RB_UMS_DEV_ATTA CH  RO  RO  RB_UMS_DEV_ATTA CH  RO  RO  RB_UMS_DEV_ATTA CH  RO  RO  RB_UMS_DEV_ATTA CH  RO  RO  RB_UMS_DEV_ATTA CH  RO  RO  RB_UMS_DEV_ATTA CH  RO  RO  RO  RB_UMS_DEV_ATTA CH  RO  RO  RO  RB_UMS_DEV_ATTA CH  RO  RO  RO  RB_UMS_DEV_ATTA CH  RO  RO  RO  RO  RO  RO  RB_UMS_DEV_ATTA CH  RO  RO  RO  RO  RO  RO  RO  RO  RB_UMS_DEV_ATTA CH  RO  RO  RO  RO  RO  RO  RO  RO  RO  R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |                  |     | 1                                         | , |
| 4 RB_UMS_R_FIFO_RD Y RO Color The receive FIFO data ready: 0: The receive FIFO is empty; 1: The receive FIFO is not empty.  USB bus reset: 0: The current USB bus is in a non-reset state.  USB suspend: 0: The USB bus is in a non-suspend state; 1: The USB bus is in a non-suspend state; 1: The USB bus is in a suspended state, and there is no USB activity for a period of time.  In USB host mode, level state of the DM pin when the device is just connected to the USB port is used to judge the speed: 0: Low level/full-speed; 1: High level/low-speed.  ORD RB_UMS_DEV_ATTA CH RO RB_UMS_DEV_ATTA CH RO USB receive FIFO data ready: 0: The receive FIFO is empty; 0 The receive FIFO is empty; 0 The receive FIFO is empty; 0 The receive FIFO is empty; 0 The receive FIFO is empty; 0 The receive FIFO is empty; 0 The receive FIFO is empty; 0 The receive FIFO is empty; 0 The receive FIFO is empty; 0 The receive FIFO is empty; 0 The receive FIFO is empty; 0 The receive FIFO is empty; 0 The receive FIFO is empty; 0 The receive FIFO is empty; 0 The receive FIFO is empty; 0 The receive FIFO is empty; 0 The receive FIFO is empty; 0 The receive FIFO is empty; 0 The receive FIFO is empty; 0 The receive FIFO is empty; 0 The receive FIFO is empty; 0 The receive FIFO is empty; 0 The receive FIFO is empty; 0 The receive FIFO is empty; 0 The receive FIFO is empty; 0 The receive FIFO is empty; 0 The receive FIFO is empty; 0 The receive FIFO is not empty.  USB bus reset: 0 The current USB bus is in a non-reset state.  X  IT He post bus is in a non-reset state.  X  USB device attach status for the port in USB host mode: 0 The port has no USB device connected; 1 The port has been connected to a USB                                                                                                                                                                                                                                                                                                                                                                      | 5 | RB_UMS_SIE_FREE  | RO  |                                           | 1 |
| 4 RB_UMS_R_FIFO_RD Y  RO 0: The receive FIFO is empty; 1: The receive FIFO is not empty.  USB bus reset: 0: The current USB bus is in a non-reset state; 1: The current USB bus is in reset state.  USB suspend: 0: The USB bus is in a non-suspend state; 1: The USB bus is in a suspended state, and there is no USB activity for a period of time.  RB_UMS_DM_LEVE L  RO RO RB_UMS_DM_LEVE L  RO RB_UMS_DM_LEVE L  RO RB_UMS_DM_LEVE L  RO RB_UMS_DM_LEVE L  RO RB_UMS_DM_LEVE L  RO RB_UMS_DEV_ATTA CH  RO RB_UMS_DEV_ATTA CH  RO USB device attach status for the port in USB host mode: 0: The port has no USB device connected; 1: The port has been connected to a USB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |   |                  |     | •                                         |   |
| 4 Y  1: The receive FIFO is empty; 1: The receive FIFO is not empty.  USB bus reset: 0: The current USB bus is in a non-reset state; 1: The current USB bus is in reset state.  USB suspend: 0: The USB bus is in a non-suspend state; 1: The USB bus is in a suspended state, and there is no USB activity for a period of time.  In USB host mode, level state of the DM pin when the device is just connected to the USB port is used to judge the speed: 0: Low level/full-speed; 1: High level/low-speed.  USB device attach status for the port in USB host mode: 0: The port has no USB device connected; 1: The port has been connected to a USB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |   | RB UMS R FIFO RD |     |                                           |   |
| 1: The receive FIFO is not empty.  USB bus reset: 0: The current USB bus is in a non-reset state.  USB suspend: 0: The USB bus is in reset state.  USB suspend: 0: The USB bus is in a non-suspend state; 1: The USB bus is in a suspended state, and there is no USB activity for a period of time.  In USB host mode, level state of the DM pin when the device is just connected to the USB port is used to judge the speed: 0: Low level/full-speed; 1: High level/low-speed.  USB device attach status for the port in USB host mode: 0: The port has no USB device connected; 0: The port has been connected to a USB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 4 |                  | RO  | 0: The receive FIFO is empty;             | 0 |
| RB_UMS_BUS_RESE T  RO  0: The current USB bus is in a non-reset state; 1: The current USB bus is in reset state.  USB suspend: 0: The USB bus is in a non-suspend state; 1: The USB bus is in a suspended state, and there is no USB activity for a period of time.  In USB host mode, level state of the DM pin when the device is just connected to the USB port is used to judge the speed: 0: Low level/full-speed; 1: High level/low-speed.  USB device attach status for the port in USB host mode: 0: The port has no USB device connected; 1: The port has been connected to a USB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |   | 1                |     | 1: The receive FIFO is not empty.         |   |
| T RO state;  1: The current USB bus is in reset state.  USB suspend: 0: The USB bus is in a non-suspend state; 1: The USB bus is in a suspended state, and there is no USB activity for a period of time.  In USB host mode, level state of the DM pin when the device is just connected to the USB port is used to judge the speed: 0: Low level/full-speed; 1: High level/low-speed.  USB device attach status for the port in USB host mode: 0: The port has no USB device connected; 1: The port has been connected to a USB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |   |                  |     | USB bus reset:                            |   |
| T state;  1: The current USB bus is in reset state.  USB suspend: 0: The USB bus is in a non-suspend state; 1: The USB bus is in a non-suspend state; 1: The USB bus is in a suspended state, and there is no USB activity for a period of time.  In USB host mode, level state of the DM pin when the device is just connected to the USB port is used to judge the speed: 0: Low level/full-speed; 1: High level/low-speed.  USB device attach status for the port in USB host mode: 0: The port has no USB device connected; 1: The port has been connected to a USB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 2 | RB_UMS_BUS_RESE  | DO. | 0: The current USB bus is in a non-reset  | X |
| USB suspend:  0: The USB bus is in a non-suspend state;  1: The USB bus is in a suspended state, and there is no USB activity for a period of time.  In USB host mode, level state of the DM pin when the device is just connected to the USB port is used to judge the speed:  0: Low level/full-speed; 1: High level/low-speed.  USB device attach status for the port in USB host mode:  0: The port has no USB device connected; 1: The port has been connected to a USB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 3 | T                | RO  | state;                                    |   |
| 0: The USB bus is in a non-suspend state; 1: The USB bus is in a suspended state, and there is no USB activity for a period of time.  In USB host mode, level state of the DM pin when the device is just connected to the USB port is used to judge the speed: 0: Low level/full-speed; 1: High level/low-speed.  USB device attach status for the port in USB host mode: 0: The port has no USB device connected; 1: The port has been connected to a USB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |   |                  |     | 1: The current USB bus is in reset state. |   |
| 2 RB_UMS_SUSPEND RO 1: The USB bus is in a suspended state, and there is no USB activity for a period of time.  In USB host mode, level state of the DM pin when the device is just connected to the USB port is used to judge the speed:  0 C Low level/full-speed; 1: High level/low-speed.  USB device attach status for the port in USB host mode:  0 CH RB_UMS_DEV_ATTA CH RO 0: The port has no USB device connected; 1: The port has been connected to a USB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |   |                  |     | USB suspend:                              |   |
| and there is no USB activity for a period of time.  In USB host mode, level state of the DM pin when the device is just connected to the USB port is used to judge the speed:  0: Low level/full-speed; 1: High level/low-speed.  USB device attach status for the port in USB host mode:  0: The port has no USB device connected; 1: The port has been connected to a USB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |   |                  |     | 0: The USB bus is in a non-suspend state; |   |
| of time.  In USB host mode, level state of the DM pin when the device is just connected to the USB port is used to judge the speed:  0: Low level/full-speed; 1: High level/low-speed.  USB device attach status for the port in USB host mode:  0: The port has no USB device connected; 1: The port has been connected to a USB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 2 | RB_UMS_SUSPEND   | RO  | 1: The USB bus is in a suspended state,   | 0 |
| In USB host mode, level state of the DM pin when the device is just connected to the USB port is used to judge the speed:  0: Low level/full-speed; 1: High level/low-speed.  USB device attach status for the port in USB host mode:  0: The port has no USB device connected; 1: The port has been connected to a USB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |   |                  |     | and there is no USB activity for a period |   |
| pin when the device is just connected to the USB port is used to judge the speed: 0: Low level/full-speed; 1: High level/low-speed.  USB device attach status for the port in USB host mode: 0: The port has no USB device connected; 1: The port has been connected to a USB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |   |                  |     | of time.                                  |   |
| the USB port is used to judge the speed:  0: Low level/full-speed; 1: High level/low-speed.  USB device attach status for the port in USB host mode: 0: The port has no USB device connected; 1: The port has been connected to a USB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                  |     | In USB host mode, level state of the DM   |   |
| RO the USB port is used to judge the speed:  0: Low level/full-speed;  1: High level/low-speed.  USB device attach status for the port in  USB host mode:  0: The port has no USB device connected;  1: The port has been connected to a USB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |   |                  |     | pin when the device is just connected to  |   |
| 0: Low level/full-speed; 1: High level/low-speed.  USB device attach status for the port in USB host mode: 0: The port has no USB device connected; 1: The port has been connected to a USB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 1 |                  | RO  | the USB port is used to judge the speed:  | 0 |
| 1: High level/low-speed.  USB device attach status for the port in USB host mode:  0: The port has no USB device connected; 1: The port has been connected to a USB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |   | L                |     | 0: Low level/full-speed;                  |   |
| USB device attach status for the port in USB host mode: 0: The port has no USB device connected; 1: The port has been connected to a USB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |   |                  |     | 1: High level/low-speed.                  |   |
| 0 RB_UMS_DEV_ATTA CH RO USB host mode: 0: The port has no USB device connected; 1: The port has been connected to a USB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |   |                  |     |                                           |   |
| CH RO 0: The port has no USB device connected; 0  1: The port has been connected to a USB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0 |                  |     | _                                         |   |
| 1: The port has been connected to a USB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |   |                  | RO  | 0: The port has no USB device connected:  | 0 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   | CH               |     |                                           |   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |                  |     | device.                                   |   |

23.2.1.5 USB Interrupt Flag Register (R8\_USB\_INT\_FG)

| Bit | Name           | Access | Description                             | Reset value |
|-----|----------------|--------|-----------------------------------------|-------------|
|     |                |        | In USB device mode, NAK response        |             |
|     |                |        | status:                                 |             |
| 7   | RB_U_IS_NAK    | RO     | 0: No NAK response;                     | 0           |
|     |                |        | 1: Respond to NAK during the current    |             |
|     |                |        | USB transfer process.                   |             |
|     |                |        | Current USB transfer DATA0/1 sync flag  |             |
| 6   | RB_U_TOG_OK    | RO     | match status:                           | 0           |
|     |                |        | 0: Not synchronized; 1: Synchronized.   |             |
|     |                |        | USB Protocol Handler free:              |             |
| 5   | RB_U_SIE_FREE  | RO     | 0: Busy, USB transfer in progress;      | 1           |
|     |                |        | 1: USB idle.                            |             |
| 4   | RB UIF FIFO OV | RW     | USB FIFO overflow interrupt flag, write | 0           |
|     | KB_OII_FIFO_OV | IXVV   | 1 to clear:                             | 0           |

|   |                 |    | 0: No event;                                |   |
|---|-----------------|----|---------------------------------------------|---|
|   |                 |    | 1: FIFO overflow trigger.                   |   |
| 3 | RB_UIF_HST_SOF  | RW | SOF timer interrupt flag in USB host        | 0 |
|   |                 |    | mode, write 1 to clear:                     |   |
|   |                 |    | 0: No event;                                |   |
|   |                 |    | 1: SOF packet transmission completion       |   |
|   |                 |    | trigger.                                    |   |
|   | RB_UIF_SUSPEND  | RW | USB bus suspend or wake-up event            | 0 |
| 2 |                 |    | interrupt flag, write 1 to clear:           |   |
|   |                 |    | 0: No event;                                |   |
|   |                 |    | 1: Triggered by USB suspend event or        |   |
|   |                 |    | wake-up event.                              |   |
|   | RB_UIF_TRANSFER | RW | USB transfer completion interrupt flag,     | 0 |
| 1 |                 |    | write 1 to clear:                           |   |
|   |                 |    | 0: No event;                                |   |
|   |                 |    | 1: Trigger when a USB transfer is           |   |
|   |                 |    | completed.                                  |   |
|   | RB_UIF_DETECT   | RW | In USB host mode, USB device connect        | 0 |
| 0 |                 |    | or disconnect event interrupt flag, write 1 |   |
|   |                 |    | to clear:                                   |   |
|   |                 |    | 0: No event;                                |   |
|   |                 |    | 1: Detected USB device connection or        |   |
|   |                 |    | disconnection trigger.                      |   |
|   | RB_UIF_BUS_RST  | RW | In USB device mode, USB bus reset event     | 0 |
|   |                 |    | interrupt flag bit, write 1 to clear:       |   |
|   |                 |    | 0: No event;                                |   |
|   |                 |    | 1: USB bus reset event trigger.             |   |

23.2.1.6 USB Interrupt Status Register (R8\_USB\_INT\_ST)

| Bit   | Name           | Access | Description                                                                                                                                    | Reset value |
|-------|----------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| 7     | RB_UIS_IS_NAK  | RO     | In USB device mode, NAK response status, same as RB_U_IS_NAK:  0: No NAK response;  1: Respond to NAK during the current USB transfer process. | 0           |
| 6     | RB_UIS_TOG_OK  | RO     | Current USB transmission DATA0/1 synchronization flag match status, same as RB_U_TOG_OK:  0: Not synchronized; 1: Synchronized.                | 0           |
| [5:4] | MASK_UIS_TOKEN | RO     | In device mode, the token PID identifier of the current USB transfer transaction.                                                              | XXb         |
| [3:0] | MASK_UIS_ENDP  | RO     | In device mode, the endpoint number of the current USB transfer transaction.                                                                   | XXXXb       |
|       | MASK_UIS_H_RES | RO     | In host mode, the response PID identifier of the current USB transmission                                                                      | XXXXb       |

| transaction, 0000 means the device has |  |
|----------------------------------------|--|
| no response or timed out; other values |  |
| indicate the response PID.             |  |

MASK\_UIS\_TOKEN is used to identify the token PID of the current USB transfer transaction in the USB device mode: 00 means OUT packet; 01 reserved; 10 means IN packet; 11 means SETUP packet.

MASK\_UIS\_H\_RES is only valid in host mode. In the host mode, if the host sends the OUT/SETUP token packet, the PID is the handshake packet ACK/NAK/STALL, or the device has no response/timeout. If the host sends an IN token packet, the PID is the PID of the data packet (DATA0/DATA1) or the PID of the handshake packet.

23.2.1.7 USB Receive Length Register (R16\_USB\_RX\_LEN)

| Bit   | Name           | Access | Description                                                   | Reset value |
|-------|----------------|--------|---------------------------------------------------------------|-------------|
| [9:0] | R16_USB_RX_LEN | RO     | The current number of data bytes received by the USB endpoint | X           |

23.2.1.8 USB OTG Control Register (R32 USB OTG CR)

| Bit    | Name                   | Access | Description                                                                                        | Reset value |
|--------|------------------------|--------|----------------------------------------------------------------------------------------------------|-------------|
| [31:6] | Reserved               | RO     | Reserved                                                                                           | 0           |
| 5      | RB_CR_SESS_VTH         | RW     | OTG session valid threshold voltage setting: 0: SESS_VLD level is 0.8V; 1: SESS_VLD level is 1.4V. | 0           |
| 4      | RB_CR_VBUS_VTH         | RW     | OTG VBUS threshold voltage setting: 0: VBUS_VLD level is 4.8V; 1: VBUS_VLD level is 4.4V.          | 0           |
| 3      | RB_CR_OTG_EN           | RW     | OTG function enable: 0: Disable; 1: Enable.                                                        | 0           |
| 2      | RB_CR_IDPU             | RW     | USB_OTG_ID pin pull-up enable: 0: Disable; 1: Enable.                                              | 0           |
| 1      | RB_CR_CHARGE_VB<br>US  | RW     | OTG VBUS charge enable: 0: Disable; 1: Enable.                                                     | 0           |
| 0      | RB_CR_DISCHAR_V<br>BUS | RW     | OTG VBUS discharge enable: 0: Disable; 1: Enable.                                                  | 0           |

Note: This register is only applicable to CH32V305, CH32V307, CH32F205 and CH32F207

23.2.1.9 USB OTG Control Register (R32\_USB\_OTG\_SR)

| Bit    | Name           | Access | Description                                                        | Reset value |
|--------|----------------|--------|--------------------------------------------------------------------|-------------|
| [31:4] | Reserved       | RO     | Reserved                                                           | 0           |
| 3      | RB_SR_ID_DIG   | RO     | OTG ID flag: 0: A device; 1: B device.                             | 0           |
| 2      | RB_SR_SESS_END | RO     | OTG session end valid flag 0: Invalid; 1: Valid.                   | 0           |
| 1      | RB_SR_SESS_VLD | RO     | OTG session valid flag 0: Invalid, the session valid level is less | 0           |

|   |                |    | than the threshold voltage;                  |   |
|---|----------------|----|----------------------------------------------|---|
|   |                |    | 1: Valid, the session valid level is greater |   |
|   |                |    | than the threshold voltage.                  |   |
|   |                |    | OTG VBUS input level                         |   |
|   |                |    | 0: VBUS voltage is less than the             |   |
| 0 | RB_SR_VBUS_VLD | RO | threshold voltage;                           | X |
|   |                |    | 1: VBUS voltage is greater than the          |   |
|   |                |    | threshold voltage.                           |   |

Note: This register is only applicable to CH32V305, CH32V307, CH32F205 and CH32F207

#### 23.2.2 Device Register Description

In USB device mode, the USB OTG module provides 8 sets of bidirectional endpoint configuration registers with endpoint numbers 0-7, which can map the configuration of endpoint numbers 8-15. The maximum packet length of all endpoints except endpoint 3 is 64 bytes. The maximum packet length of the endpoints is 1023 bytes (Synchronous transmission).

- Endpoint 0 is the default endpoint and supports control transmission. Sending and receiving share a 64-byte data buffer
- Endpoints 1-15 can be configured with independent 64-byte send and receive buffers or dual 64-byte data buffers, supporting bulk transfers, interrupt transfers, and real-time/synchronous transfers.

Each group of endpoints has a control register R8\_UEPn\_CTRL and a send length register R16\_UEPn\_T\_LEN, which are used to set the synchronization trigger bit of the endpoint, the response to the OUT transaction and the IN transaction, and the length of the transmitted data.

The roles of the USB OTG module host and device are determined by the state of the OTG\_FS\_ID pin. When the OTG\_FS\_ID pin is floating, its built-in pull-up resistor will make the RB\_SR\_ID\_DIG bit of the USB OTG status register R32\_USB\_OTG\_SR set to 1. At this time, the controller should be initialized as a B device. When the OTG\_FS\_ID pin is grounded, the RB\_SR\_ID\_DIG bit of the USB OTG status register R32\_USB\_OTG\_SR is 0 at this time, and the controller should be initialized as an A device.

When the B device starts a session, it ensures that the level of VBUS is lower than V<sub>SESS\_VLD,min</sub> according to RB\_SR\_SESS\_VLD of the OTG status register R32\_USB\_OTG\_SR. If this bit is 0, a new session can be started. If this bit is 1, the RB\_CR\_DISCHAR\_VBUS bit of the OTG control register R32\_USB\_OTG\_CR can be set to 1 to discharge, so that VBUS is less than the session threshold level.

As a Class B device, it needs to take power from VBUS, and an external conversion circuit is required, as shown in Figure 23-1.



Figure 23-1 OTG Class B device connection

The USB bus pull-up resistor necessary as a USB device can be set by software at any time to enable or not. When RB\_UC\_DEV\_PU\_EN in the USB control register R8\_USB\_CTRL is set to 1, the controller is set according to the speed of RB\_UD\_LOW\_SPEED, which is the DP/DM pin of the USB bus internally. Connect a pull-up resistor and enable the USB device function.

When a USB bus reset, USB bus suspend or wake-up event is detected, or when the USB successfully processes data transmission or data reception, the USB protocol processor will set the corresponding interrupt flag, and if the interrupt enable is turned on, it will also generate a corresponding interrupt request. The application can directly query or query and analyze the interrupt flag register R8 USB INT FG in the USB interrupt service routine, and perform corresponding processing according to RB UIF BUS RST and RB UIF SUSPEND; and, if RB UIF TRANSFER is valid, then it is necessary to continue to analyze the USB interrupt status register R8 USB INT ST, according to the current endpoint number MASK UIS ENDP and the current transaction token PID identify MASK UIS TOKEN for corresponding processing. If the synchronization trigger bit RB UEP R TOG of the OUT transaction of each endpoint is set in advance, then RB U TOG OK or RB UIS TOG OK can be used to judge whether the synchronization trigger bit of the currently received data packet matches the synchronization trigger bit of the endpoint. If the data is synchronized, the data valid; if the data is out of sync, the data should be discarded. After each USB send or receive interrupt is processed, the synchronization trigger bit of the corresponding endpoint should be modified correctly to detect whether the next data packet sent or received next time is synchronously detected; in addition, setting RB UEP T AUTO TOG or RB UEP R AUTO TOG enables to automatically flip the corresponding synchronization trigger bit after successful transmission or reception.

The data to be sent by each endpoint is in its own buffer, and the length of the data to be sent is independently set in R8\_UEPn\_T\_LEN; the data received by each endpoint is in its own buffer, but the length of the received data is in the USB receive length. In the register R8\_USB\_RX\_LEN, it can be distinguished according to the current endpoint number when the USB receives an interrupt.

Table 23-3 Device registers

| Name            | Address    | Description                                 | Reset value |
|-----------------|------------|---------------------------------------------|-------------|
| R8_UDEV_CTRL    | 0x50000001 | USB device physical port control register   | 0xX0        |
| R8_UEP4_1_MOD   | 0x5000000C | Endpoint 1(9)/4(8/12) mode control register | 0x00        |
| R8_UEP2_3_MOD   | 0x5000000D | Endpoint 2(10)/3(11) mode control register  | 0x00        |
| R8_UEP5_6_MOD   | 0x5000000E | Endpoint 5(13)/6(14) mode control register  | 0x00        |
| R8_UEP7_MOD     | 0x5000000F | Endpoint 7(15) mode control register        | 0x00        |
| R32_UEP0_DMA    | 0x50000010 | Endpoint 0 buffer start address             | 0xXXXXXXXX  |
| R32_UEP1_DMA    | 0x50000014 | Endpoint 1(9) buffer start address          | 0xXXXXXXXX  |
| R32_UEP2_DMA    | 0x50000018 | Endpoint 2 (10) buffer start address        | 0xXXXXXXXX  |
| R32_UEP3_DMA    | 0x5000001C | Endpoint 3 (11) buffer start address        | 0xXXXXXXXXX |
| R32_UEP4_DMA    | 0x50000020 | Endpoint 4 (8/12) buffer start address      | 0xXXXXXXXXX |
| R32_UEP5_DMA    | 0x50000024 | Endpoint 5(13) buffer start address         | 0xXXXXXXXX  |
| R32_UEP6_DMA    | 0x50000028 | Endpoint 6(14) buffer start address         | 0xXXXXXXXXX |
| R32_UEP7_DMA    | 0x5000002C | Endpoint 7(15) buffer start address         | 0xXXXXXXXXX |
| R8_UEP0_T_LEN   | 0x50000030 | Endpoint 0 transmit length register         | 0xXX        |
| R8_UEP0_TX_CTRL | 0x50000032 | Endpoint 0 transmit control register        | 0x00        |
| R8_UEP0_RX_CTRL | 0x50000033 | Endpoint 0 receive control register         | 0x00        |
| R8_UEP1_T_LEN   | 0x50000034 | Endpoint 1(9) transmit length register      | 0xXX        |
| R8_UEP1_TX_CTRL | 0x50000036 | Endpoint 1(9) transmit control register     | 0x00        |
| R8_UEP1_RX_CTRL | 0x50000037 | Endpoint 1(9) receive control register      | 0x00        |
| R8_UEP2_T_LEN   | 0x50000038 | Endpoint 2(10) transmit length register     | 0xXX        |
| R8_UEP2_TX_CTRL | 0x5000003A | Endpoint 2(10) transmit control register    | 0x00        |
| R8_UEP2_RX_CTRL | 0x5000003B | Endpoint 2(10) receive control register     | 0x00        |
| R8_UEP3_T_LEN   | 0x5000003C | Endpoint 3(11) transmit length register     | 0xXX        |
| R8_UEP3_TX_CTRL | 0x500003E  | Endpoint 3(11) transmit control register    | 0x00        |
| R8_UEP3_RX_CTRL | 0x500003F  | Endpoint 3(11) receive control register     | 0x00        |
| R8_UEP4_T_LEN   | 0x50000040 | Endpoint 4 (8/12) transmit length register  | 0xXX        |
| R8_UEP4_TX_CTRL | 0x50000042 | Endpoint 4 (8/12) transmit control register | 0x00        |
| R8_UEP4_RX_CTRL | 0x50000043 | Endpoint 4 (8/12) receive control Register  | 0x00        |
| R8_UEP5_T_LEN   | 0x50000044 | Endpoint 5(13) transmit length register     | 0xXX        |
| R8_UEP5_TX_CTRL | 0x50000046 | Endpoint 5(13) transmit control register    | 0x00        |
| R8_UEP5_RX_CTRL | 0x50000047 | Endpoint 5(13) receive control register     | 0x00        |
| R8_UEP6_T_LEN   | 0x50000048 | Endpoint 6(14) transmit length register     | 0xXX        |
| R8_UEP6_TX_CTRL | 0x5000004A | Endpoint 6(14) transmit control register    | 0x00        |
| R8_UEP6_RX_CTRL | 0x5000004B | Endpoint 6(14) receive control register     | 0x00        |
| R8_UEP7_T_LEN   | 0x5000004C | Endpoint 7(15) transmit length register     | 0xXX        |
| R8_UEP7_TX_CTRL | 0x5000004E | Endpoint 7(15) transmit control register    | 0x00        |
| R8_UEP7_RX_CTRL | 0x5000004F | Endpoint 7(15) receive control register     | 0x00        |

# 23.2.2.1 USB Device Physical Port Control Register (R8\_UDEV\_CTRL)

| Bit | Name            | Access                      | Description                               | Reset value |
|-----|-----------------|-----------------------------|-------------------------------------------|-------------|
|     |                 |                             | USB device port UD+/UD- pin internal      |             |
|     |                 | pull-down resistor control: |                                           |             |
| 7   | RB UD PD DIS    | RW                          | 0: Enable internal pull-down;             | 1           |
|     | KD_UD_ID_DIS    | IXVV                        | 1: Disable internal pull-down.            | 1           |
|     |                 |                             | Can be used in GPIO mode to provide pull- |             |
|     |                 |                             | down resistors.                           |             |
| 6   | Reserved        | RO                          | Reserved                                  | 0           |
| 5   | RB_UD_DP_PIN    | RO                          | Current UD+ pin status:                   | X           |
| 3   |                 | KO                          | 0: Low level; 1: High level.              |             |
| 4   | DD LID DM DIN L | D.O.                        | Current UD-pin status:                    | X           |
| 4   | RB_UD_DM_PIN    | RO                          | 0: Low level; 1: High level.              |             |
| 3   | Reserved        | RO                          | Reserved                                  | 0           |
|     |                 |                             | USB Device physical port low speed mode   | 0           |
|     | RB_UD_LOW_SP    | DW                          | enable:                                   |             |
| 2   | EED             | RW                          | 0: 12Mbps full-speed mode;                |             |
|     |                 |                             | 1: 1.5Mbps low-speed mode.                |             |
| 1   | DD LID CD DIT   | DW                          | USB device mode general-purpose flag,     | 0           |
| 1   | 1 RB_UD_GP_BIT  | RW                          | user-defined.                             |             |
|     | DD LID DODT E   |                             | USB Device physical port enable:          | 0           |
| 0   | RB_UD_PORT_E    | RW                          | 0: Disable physical port;                 |             |
|     | N               |                             | 1: Enable physical port.                  |             |

23.2.2.2 Endpoint 1(9)/4(8/12) Mode Control Register (R8 UEP4 1 MOD)

| Bit | Name         | Access | Description                                    | Reset value |
|-----|--------------|--------|------------------------------------------------|-------------|
| 7   | RB_UEP1_RX_E | RW     | 0: Endpoint 1(9) reception disabled;           | 0           |
| /   | N            | KW     | 1: Enable endpoint 1(9) to receive (OUT).      | 0           |
| 6   | RB_UEP1_TX_E | RW     | 0: Disable endpoint 1(9) transmission;         | 0           |
| 0   | N            | KW     | 1: Enable endpoint 1(9) transmission (IN).     | U           |
| 5   | Reserved     | RO     | Reserved                                       | 0           |
| 4   | RB_UEP1_BUF_ | RW     | Endpoint 1(9) data buffer mode control.        | 0           |
| 4   | MOD          |        |                                                |             |
| 3   | RB_UEP4_RX_E | RW     | 0: Disable endpoint 4 (8/12) reception;        | 0           |
|     | N            | IXVV   | 1: Enable endpoint 4 (8/12) reception (OUT).   |             |
| 2   | RB_UEP4_TX_E | RW     | 0: Endpoint 4 (8/12) transmission disabled;    | 0           |
|     | N            | IX VV  | 1: Enable endpoint 4 (8/12) transmission (IN). | U           |
| 1   | Reserved     | RO     | Reserved                                       | 0           |
| 0   | RB_UEP4_BUF_ | RW     | Endpoint 4 (8/12) data buffer mode control.    | 0           |
|     | MOD          | IX VV  | Enupoint + (6/12) data buffer filode control.  | U<br>       |

Note: The endpoint 1 configuration option maps endpoint 9, and the endpoint 4 configuration option maps endpoints 8 and 12.

23.2.2.3 Endpoint 2(10)/3(11) Mode Control Register (R8\_UEP2\_3\_MOD)

| Bit | Name | Access | Description | Reset value |
|-----|------|--------|-------------|-------------|
|-----|------|--------|-------------|-------------|

| 7 | RB UEP3 RX EN  | RW | 0: Disable endpoint 3 (11) reception;         | 0 |
|---|----------------|----|-----------------------------------------------|---|
|   |                |    | 1: Enable endpoint 3 (11) reception (OUT).    | - |
| 6 | RB UEP3 TX EN  | RW | 0: Disable endpoint 3 (11) transmission;      | 0 |
| 0 | KD_UEF3_IA_EN  | KW | 1: Enable endpoint 3 (11) transmission (IN).  | U |
| 5 | Reserved       | RO | Reserved                                      | 0 |
| 4 | RB_UEP3_BUF_M  | DW | F., d., i., 2(11) deta harffan an de en atual | 0 |
| 4 | OD             | RW | Endpoint 3(11) data buffer mode control.      | U |
| 2 | DD HED2 DW EN  | DW | 0: Disable endpoint 2 (10) reception;         | 0 |
| 3 | RB_UEP2_RX_EN  | RW | 1: Enable endpoint 2 (10) reception (OUT).    | 0 |
|   | DD LIEDA TV EN | DW | 0: Disable endpoint 2 (10) transmission;      | 0 |
| 2 | RB_UEP2_TX_EN  | RW | 1: Enable endpoint 2 (10) transmission (IN).  | 0 |
| 1 | Reserved       | RO | Reserved                                      | 0 |
| 0 | RB_UEP2_BUF_M  | DW | Finding 2(10) data language 4 1               | 0 |
| 0 | OD             | RW | Endpoint 2(10) data buffer mode control.      | 0 |

Note: The endpoint 2 configuration options map to endpoint 10, and the endpoint 3 configuration options map to endpoint 11.

23.2.2.4 Endpoint 5(13)/6(14) Mode Control Register (R8\_UEP5\_6\_MOD)

| Bit | Name            | Access | Description                                  | Reset value |
|-----|-----------------|--------|----------------------------------------------|-------------|
| 7   | DD LIEDA DV EN  | DW     | 0: Disable endpoint 6 (14) reception;        | 0           |
| /   | RB_UEP6_RX_EN   | RW     | 1: Enable endpoint 6 (14) reception (OUT).   | 0           |
| 6   | 6 RB_UEP6_TX_EN | RW     | 0: Disable endpoint 6(14) transmission;      | 0           |
| 0   |                 | KVV    | 1: Enable endpoint 6 (14) transmission (IN). | U           |
| 5   | Reserved        | RO     | Reserved                                     | 0           |
| 4   | RB_UEP6_BUF_MOD | RW     | Endpoint 6(14) data buffer mode control.     | 0           |
|     |                 |        | 0: Disable endpoint 5(13) reception;         |             |
| 3   | RB_UEP5_RX_EN   | RW     | 1: Enable endpoint 5 (13) reception          | 0           |
|     |                 |        | (OUT).                                       |             |
|     |                 |        | 0: Disable endpoint 5(13) transmission;      |             |
| 2   | RB_UEP5_TX_EN   | RW     | 1: Enable endpoint 5(13) transmission        | 0           |
|     |                 |        | (IN).                                        |             |
| 1   | Reserved        | RO     | Reserved                                     | 0           |
| 0   | RB_UEP5_BUF_MOD | RW     | Endpoint 5(13) data buffer mode control.     | 0           |

Note: The endpoint 5 configuration options map to endpoint 13, and the endpoint 6 configuration options map to endpoint 14.

23.2.2.5 Endpoint 7(15) Mode Control Register (R8\_UEP7\_MOD)

|       | <del></del>  |        | <u> </u>                                    |             |
|-------|--------------|--------|---------------------------------------------|-------------|
| Bit   | Name         | Access | Description                                 | Reset value |
| [7:4] | Reserved     | RO     | Reserved                                    | 0           |
| 2     | RB_UEP7_RX_E | RW     | 0: Disable endpoint 7 (15) reception;       | 0           |
| 3     | 3 N          | KW     | 1: Enable endpoint 7(15) reception (OUT).   |             |
| ,     | RB_UEP7_TX_E | DW     | 0: Disable endpoint 7(15) transmission;     | 0           |
| 2     | N            | RW     | 1: Enable endpoint 7(15) transmission (IN). | 0           |
| 1     | Reserved     | RO     | Reserved                                    | 0           |

| 0 | RB_UEP7_BUF_<br>MOD | RW | Endpoint 7(15) data buffer mode control. | 0 |
|---|---------------------|----|------------------------------------------|---|
|---|---------------------|----|------------------------------------------|---|

*Note: The endpoint 7 configuration option maps to endpoint 15.* 

The data buffer mode of USB endpoints 1-15 is configured by the combination of RB\_UEPn\_RX\_EN and RB\_UEPn\_TX\_EN and RB\_UEPn\_BUF\_MOD, please refer to Table 23-4 for details. Among them, in the dual 64-byte buffer mode, the first 64-byte buffer will be selected according to RB\_UEP\_\*\_TOG=0 during USB data transmission, and the last 64-byte buffer will be selected according to RB\_UEP\_\*\_TOG=1, and RB\_UEP\_\*\_AUTO\_TOG=1 can be set to realize automatic switching. Note: During synchronous transmission, when (RB\_UEPn\_RX\_EN, RB\_UEPn\_TX\_EN, RB\_UEPn\_BUF\_MOD) are only (1,0,0) or (0,1,0), endpoint 3 supports a maximum of 1023 bytes.

Table 23-4 Endpoint n buffer mode (n=1 - 7)

| RB_UEPn<br>_RX_EN | RB_UEPn<br>_TX_EN | RB_UEPn<br>_BUF_M<br>OD | Description: R16_UEPn_DMA is the starting address arranged from low to high                                                                                                                                                                                                                                                                                                                                                                       |
|-------------------|-------------------|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0                 | 0                 | X                       | The endpoint is disabled and the R16_UEPn_DMA buffer is not used.                                                                                                                                                                                                                                                                                                                                                                                 |
| 1                 | 0                 | 0                       | Single 64-byte receive buffer (OUT).                                                                                                                                                                                                                                                                                                                                                                                                              |
| 1                 | 0                 | 1                       | Dual 64-byte receive buffer (OUT), selected by RB_UEP_R_TOG.                                                                                                                                                                                                                                                                                                                                                                                      |
| 0                 | 1                 | 0                       | Single 64-byte transmit buffer (IN).                                                                                                                                                                                                                                                                                                                                                                                                              |
| 0                 | 1                 | 1                       | Dual 64-byte transmit buffer (IN), selected by RB_UEP_T_TOG.                                                                                                                                                                                                                                                                                                                                                                                      |
| 1                 | 1                 | 0                       | A single 64-byte receive buffer (OUT), a single 64-byte transmit buffer (IN).                                                                                                                                                                                                                                                                                                                                                                     |
| 1                 | 1                 | 1                       | Dual 64-byte receive buffer (OUT), selected by RB_UEP_R_TOG, Dual 64-byte transmit buffer (IN), selected by RB_UEP_T_TOG. All 256 bytes are arranged as follows: UEPn_DMA+0 address: endpoint receiving address when RB_UEP_R_TOG=0; UEPn_DMA+64 address: endpoint receiving address when RB_UEP_R_TOG=1; UEPn_DMA+128 address: endpoint sending address when RB_UEP_T_TOG=0; UEPn_DMA+192 address: endpoint sending address when RB_UEP_T_TOG=1. |

Note: The configuration options in Table 21-4 support n=1-7, and endpoint 8-15 configuration maps endpoint 1-7 configuration.

23.2.2.6 Endpoint n buffer start address (R32 UEPn DMA) (n=0 - 7)

| Bit    | Name        | Access | Description                      | Reset Value |
|--------|-------------|--------|----------------------------------|-------------|
| [31:0] | R8_UEPn_DMA | RW     | Endpoint n buffer start address. | X           |

|  | The address must be 4-byte aligned. |  |
|--|-------------------------------------|--|

Note: 1. The length of the buffer for receiving data  $\geq = min$  (maximum packet length that may be received + 2 bytes, 64 bytes).

23.2.2.7 Endpoint n Transmit Length Register (R16\_UEPn\_T\_LEN) (n=0 - 7)

| ĺ | Bit   | Name          | Access | Description                                                                                    | Reset value |
|---|-------|---------------|--------|------------------------------------------------------------------------------------------------|-------------|
|   | [9:0] | R8_UEP3_T_LEN | RW     | Sets the number of bytes of data that USB endpoint 3 is ready to send.                         | X           |
|   | [7:0] | R8_UEPn_T_LEN | RW     | Set the number of data bytes that the USB endpoint n is ready to send (n=0, 1, 2, 4, 5, 6, 7). | X           |

Note 1. Endpoint sending length configuration supports endpoint0 to endpoint7, which can be mapped to configure the sending of endpoint8 to endpoint15.

23.2.2.8 Endpoint n Control Register (R8\_UEPn\_TX\_CTRL) (n=0 - 7)

| Bit   | Name                  | Access | Description                                                                                                                                                                                                                                                                                 | Reset value |
|-------|-----------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [7:4] | Reserved              | RO     | Reserved                                                                                                                                                                                                                                                                                    | 0           |
| 3     | RB_UEP_T_AUTO_<br>TOG | RW     | Synchronization trigger bit auto toggle enable:  0: No automatic toggle, can be switched manually;  1: After the data is sent successfully, the corresponding synchronization trigger bit is automatically toggled.  Note: This bit is reserved for endpoint 0.                             | 0           |
| 2     | RB_UEP_T_TOG          | RW     | Synchronization trigger bit prepared by the transmitter of USB endpoint n (handling IN transaction):  0: Transmit DATA0; 1: Transmit DATA1.                                                                                                                                                 | 0           |
| [1:0] | MASK_UEP_T_RES        | RW     | Response control by the transmitter of endpoint n to IN transaction:  00: DATA0/DATA1 data is ready and ACK is expected;  01: Reply to DATA0/DATA1 and expect no response, for real-time/synchronous transmission of non-endpoint 0;  10: Answer NAK or busy;  11: Response STALL or error. | 00Ъ         |

Note: Endpoint configuration supports 0-7 endpoints, which can be mapped to configure endpoints 8-15 endpoints.

23.2.2.9 Endpoint n Control Register (R8 UEPn RX CTRL) (n=0-7)

| Bit   | Name     | Access | Description | Reset value |
|-------|----------|--------|-------------|-------------|
| [7:4] | Reserved | RO     | Reserved    | 0           |

<sup>2.</sup> Endpoint DMA configuration supports 0-7 endpoints, and can map and configure endpoints 8-15 endpoints.

<sup>2.</sup> The host sends a maximum of 1023 bytes (for isochronous endpoints)

| 3     | RB_UEP_R_AUTO_<br>TOG | RW | Synchronization trigger bit auto toggle enable:  0: No automatic toggle, can be switched manually;  1: Automatically toggle the corresponding synchronization trigger bit after the data is successfully received.  Note: This bit is reserved for endpoint 0. | 0   |
|-------|-----------------------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| 2     | MASK_UEP_R_TOG        | RW | Sync trigger bit expected by receiver of USB endpoint n (Handling OUT transaction): 0: DATA0 is expected; 1: DATA1 is expected.                                                                                                                                | 0   |
| [1:0] | MASK_UEP_R_RES        | RW | Receiver of endpoint n responds to OUT transaction control: 00: reply ACK; 01: timeout/no response, for real-time/synchronous transmission of non-endpoint 0; 10: Answer NAK or busy; 11: Response STALL or error.                                             | 00Ь |

Note: Endpoint configuration supports 0-7 endpoints, which can be mapped to configure endpoints 8-15.

### 23.2.3 USB Host Register

In USB OTG host mode, the chip provides a set of bidirectional host endpoints, including a sending endpoint OUT and a receiving endpoint IN, the maximum length of a data packet is 1023 bytes, and supports control transfer, interrupt transfer, bulk transfer and real-time/ synchronous transmission.

In USB OTG host mode, if the controller cannot provide 5V power for VUBS, an external charge pump is required. If the application board can provide 5V power, the analog switch can be used to control the on and off of VBUS, as shown in Figure 23-2.



Figure 23-2 OTG Class A device connection

Each USB transaction initiated by the host endpoint always automatically sets the RB\_UIF\_TRANSFER interrupt flag after processing. The application can directly query or query and analyze the interrupt flag register R8\_USB\_INT\_FG in the USB interrupt service routine, and perform corresponding processing according to each interrupt flag; and, if RB\_UIF\_TRANSFER is valid, then continue to analyze the USB interrupt status register R8\_USB\_INT\_ST, process accordingly according to the response PID identification MASK UIS H RES of the current USB transfer transaction.

If the synchronization trigger bit (RB\_UH\_R\_TOG) of the IN transaction of the host receiving endpoint is set in advance, then RB\_U\_TOG\_OK or RB\_UIS\_TOG\_OK can be used to judge whether the synchronization trigger bit of the currently received data packet matches the synchronization trigger bit of the host receiving endpoint. If synchronized, the data is valid; if the data is not synchronized, the data should be discarded. After each USB send or receive interrupt is processed, the synchronization trigger bit of the corresponding host endpoint should be modified correctly to synchronize the data packet sent next time and detect whether the data packet received next time is synchronized; in addition, setting RB\_UEP\_AUTO\_TOG and RB\_UH\_R\_AUTO\_TOG enables to automatically flip the corresponding synchronization trigger bit after successful transmission or reception.

The USB host token setting register R8\_UH\_EP\_PID is used to set the endpoint number of the target device to be operated and the token PID packet identification of this USB transfer transaction. The data corresponding to the SETUP token and the OUT token is provided by the host sending endpoint, the data to be sent is in the R16\_UH\_TX\_DMA buffer, and the length of the data to be sent is set in R16\_UH\_TX\_LEN; the data corresponding to the IN token is returned by the target device to the host for reception Endpoint, the received data is stored in the R16\_UH\_RX\_DMA buffer, the received data length is stored in R16\_USB\_RX\_LEN, and the maximum packet length that the host endpoint can receive needs to be written to the R16\_UH\_RX\_MAX\_LEN register in advance.

Table 23-5 Host registers

| Name          | Access address | Description                                 | Reset value |
|---------------|----------------|---------------------------------------------|-------------|
| R8_UHOST_CTRL | 0x50000001     | USB host physical port control register     | 0xX0        |
| R32_UH_EP_MOD | 0x5000000D     | USB host endpoint mode control register     | 0x00        |
| R16_UH_RX_DMA | 0x50000018     | USB host receive buffer start address       | X           |
| R16_UH_TX_DMA | 0x5000001C     | USB host transmit buffer start address      | X           |
| R16_UH_SETUP  | 0x50000036     | USB host auxiliary setup register           | 0x00        |
| R8_UH_EP_PID  | 0x50000038     | USB host token setup register               | 0x00        |
| R8_UH_RX_CTRL | 0x5000003B     | USB host receive endpoint control register  | 0x00        |
| R16_UH_TX_LEN | 0x5000003C     | USB host transmit length register           | X           |
| R8_UH_TX_CTRL | 0x5000003E     | USB host transmit endpoint control register | 0x00        |

22.2.3.1 USB Host Physical Port Control Register (R8\_UHOST\_CTRL)

| Bit | Name            | Access | Name                                        | Reset value |
|-----|-----------------|--------|---------------------------------------------|-------------|
|     |                 |        | Internal pull-down resistor control for     |             |
|     |                 |        | USB host port UD+/UD- pins:                 |             |
| 7   | DD 1111 DD DIG  | RW     | 0: Enable internal pull-down;               | 1           |
| /   | RB_UH_PD_DIS    | KW     | 1: Disable internal pull-down.              | 1           |
|     |                 |        | Can be used in GPIO mode to provide         |             |
|     |                 |        | pull-down resistors.                        |             |
| 6   | Reserved        | RO     | Reserved                                    | 0           |
|     |                 |        | Current UD+ pin status:                     |             |
| 5   | RB_UH_DP_PIN    | RO     | 0: Low level;                               | X           |
|     |                 |        | 1: High level.                              |             |
|     |                 |        | Current UD-pin status:                      |             |
| 4   | RB_UH_DM_PIN    | RO     | 0: Low level;                               | X           |
|     |                 |        | 1: High level.                              |             |
| 3   | Reserved        | RO     | Reserved                                    | 0           |
|     |                 |        | USB host port low-speed mode enable:        |             |
| 2   | RB_UH_LOW_SPEED | RW     | 0: Select 12Mbps full-speed mode;           | 0           |
|     |                 |        | 1: Select 1.5Mbps low-speed mode.           |             |
|     |                 |        | USB host mode bus reset control:            |             |
| 1   | RB_UH_BUS_RESET | RW     | 0: End output;                              | 0           |
|     |                 |        | 1: Force output USB bus reset.              |             |
|     |                 |        | USB host port enable:                       |             |
|     |                 |        | 0: Disable the host port;                   |             |
| 0   | RB_UH_PORT_EN   | RW     | 1: Enable the host port.                    | 0           |
|     |                 |        | This bit is automatically cleared to 0 when |             |
|     |                 |        | the USB device is disconnected.             |             |

22.2.3.2 USB Host Endpoint Mode Control Register (R32\_UH\_EP\_MOD)

| Bit | Name           | Access | Description                         | Reset value |
|-----|----------------|--------|-------------------------------------|-------------|
| 7   | Reserved       | RO     | Reserved                            | 0           |
| 6   | RB_UH_EP_TX_EN | RW     | Host transmission endpoint transmit | 0           |

|       |                |       | (SETUP/OUT) enable:                        |   |
|-------|----------------|-------|--------------------------------------------|---|
|       |                |       | 0: Disable endpoint transmit;              |   |
|       |                |       | 1: Enable endpoint transmit.               |   |
| 5     | Reserved       | RO    | Reserved                                   | 0 |
| 4     | RB_UH_EP_TBUF_ | RW    | Host transmission endpoint transmit buffer | 0 |
| 4     | MOD            | IX VV | mode control.                              | U |
|       |                |       | Host reception endpoint receive (IN)       |   |
| 3     | RB_UH_EP_RX_EN | RW    | enable:                                    | 0 |
| 3     |                |       | 0: Disable endpoint receive;               |   |
|       |                |       | 1: Enable endpoint receive.                |   |
| [2:1] | Reserved       | RO    | Reserved                                   | 0 |
| 0     | RB_UH_EP_RBUF_ | RW    | USB host reception endpoint receive buffer | 0 |
| U 0   | MOD            | IX VV | mode control                               | U |

The host transmit endpoint buffer mode is controlled by the combination of RB UH EP TX EN and RB UH EP TBUF MOD, refer to the table below.

Description: Take R16 UH TX DMA as the starting RB UH EP TX RB UH EP TBUF **EN MOD** address

Table 23-6 Host transmit buffer mode

The endpoint is disabled and the R16 UH TX DMA 0 X buffer is not used. 1 0 Single 64-byte transmit buffer (SETUP/OUT). Dual 64-byte transmit buffer, selected by RB UH T TOG: When RB UH T TOG=0, select the first 64-byte 1 1 buffer; The last 64-byte buffer selected when RB UH T TOG=1.

The host receive endpoint data buffer mode is controlled by the combination of RB\_UH\_EP\_RX\_EN and RB UH EP RBUF MOD, refer to the table below.

Table23-7 Host receive buffer mode

| RB_UH_EP_RX_EN | RB_UH_EP_RBUF_MOD | Structure description: R16_UH_TX_DMA is the starting address                                                                                                        |
|----------------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0              | X                 | The endpoint is disabled and the R16_UH_RX_DMA buffer is not used.                                                                                                  |
| 1              | 0                 | Single 64-byte receive buffer (IN).                                                                                                                                 |
| 1              | 1                 | Dual 64-byte receive buffers, selected by RB_UH_R_TOG: When RB_UH_R_TOG=0, select the first 64-byte buffer; The last 64-byte buffer is selected when RB_UH_R_TOG=1. |

### USB Host Receive Buffer Start Address (R16\_UH\_RX\_DMA)

| Bit    | Name          | Access | Description                                                                                                            | Reset value |
|--------|---------------|--------|------------------------------------------------------------------------------------------------------------------------|-------------|
| [15:0] | R16_UH_RX_DMA | RW     | Host endpoint data receive buffer start address.  The lower 15 bits are valid, and the address must be 4-byte aligned. | X           |

USB Host Transmit Buffer Start Address (R16 UH TX DMA)

| Bit    | Name          | Access | Description                                                                                                         | Reset value |
|--------|---------------|--------|---------------------------------------------------------------------------------------------------------------------|-------------|
| [15:0] | R16_UH_TX_DMA | RW     | Host endpoint data send buffer start address.  The lower 15 bits are valid, and the address must be 4-byte aligned. | X           |

22.2.3.3 USB Host Auxiliary Setup Register (R16 UH SETUP)

| Bit     | Name                 | Access | Description                                                                                                                                                           | Reset value |
|---------|----------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [15:11] | Reserved             | RO     | RO Reserved                                                                                                                                                           |             |
| 10      | RB_UH_PRE_PID<br>_EN | RW     | Low-speed preamble packet PRE PID enable:  0: Disable low-speed preamble packets;  1: Enable, used to communicate with low-speed USB devices through an external HUB. | 0           |
| [9:3]   | Reserved             | RO     | Reserved                                                                                                                                                              | 0           |
| 2       | RB_UH_SOF_EN         | RW     | Auto generate SOF packet enable: 0: Disable the automatic SOF function; 1: The host automatically generates a SOF package.                                            | 0           |
| [1:0]   | Reserved             | RO     | Reserved                                                                                                                                                              | 0           |

22.2.3.4 USB Host Token Setup Register (R8\_UH\_EP\_PID)

| Bit   | Name           | Access | Description                              | Reset value |
|-------|----------------|--------|------------------------------------------|-------------|
| [7.4] | MACK III TOKEN | DW     | Set the token PID identifier of this USB | 0           |
| [7:4] | MASK_UH_TOKEN  | RW     | transfer transaction.                    | U           |
| [2,0] | MACK THE ENDO  | RW     | Set the endpoint number of the target    | 0           |
| [3:0] | MASK_UH_ENDP   | KW     | device to be operated this time.         | 0           |

22.2.3.5 USB Host Receive Endpoint Control Register (R8\_UH\_RX\_CTRL)

| Bit   | Name                 | Access | Description                                                                                | Reset value |
|-------|----------------------|--------|--------------------------------------------------------------------------------------------|-------------|
| [7:4] | Reserved             | RO     | Reserved                                                                                   | 0           |
| 3     | RB_UH_R_AUTO_T<br>OG | RW     | Synchronization trigger bit auto toggle enable:  0: Manual control synchronization trigger | 0           |

|   |             |    | bit (RB_UH_R_TOG);  1: Automatically toggle the corresponding expected synchronization trigger bit (RB_UH_R_TOG) after successful data reception.                                           |   |
|---|-------------|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| 2 | RB_UH_R_TOG | RW | Synchronization trigger bit prepared by the Master Receiver (Handling IN Transactions):  0: Acknowledge ACK;  1: no response, for real-time/synchronous transmission of non-zero endpoints. | 0 |
| 1 | Reserved    | RO | Reserved                                                                                                                                                                                    | 0 |
| 0 | RB_UH_R_RES | RO | Master Receiver Response Control Bits to IN Transactions: 0: Acknowledge ACK; 1: No response, for real-time/synchronous transmission of non-zero endpoints.                                 | 0 |

22.2.3.6 USB Host Transmit Length Register (R16\_UH\_TX\_LEN)

| Bit    | Name          | Access | Description                                                                          | Reset value |
|--------|---------------|--------|--------------------------------------------------------------------------------------|-------------|
| [16:0] | R16_UH_TX_LEN | RW     | Set the number of bytes of data that the USB host sending endpoint is ready to send. | X           |

22.2.3.7 USB Host Transmit Endpoint Control Register (R8\_UH\_TX\_CTRL)

| Bit   | Name                 | Access                                                                                                                          | Description                                                                                                                                                                                                                             | Reset value |
|-------|----------------------|---------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [7:4] | Reserved             | RO                                                                                                                              | Reserved                                                                                                                                                                                                                                | 0           |
| 3     | RB_UH_T_AUTO_T<br>OG | RO                                                                                                                              | Synchronization trigger bit auto toggle enable:  0: Manual control synchronization trigger bit (RB_UH_T_TOG);  1: Automatically toggle the corresponding synchronization trigger bit (RB_UH_T_TOG) after the data is sent successfully. | 0           |
| 2     | RB_UH_T_TOG          | Sync trigger bit prepared by USB host transmitter (handling SETUP/OUT RW transactions):  0: Transmit DATA0;  1: Transmit DATA1. |                                                                                                                                                                                                                                         | 0           |
| 1     | Reserved             | RO                                                                                                                              | Reserved                                                                                                                                                                                                                                | 0           |
| 0     | RB_UH_T_RES          | RW                                                                                                                              | USB Host transmitter response control to SETUP/OUT transactions:  0: ACK is expected;  1: Expect no response, for real-                                                                                                                 | 0           |

|  | time/synchronous transmission of non-zero |  |
|--|-------------------------------------------|--|
|  | endpoints.                                |  |

## Chapter 24 Controller Area Network (CAN)

#### This chapter applies to the whole family of CH32F20x, CH32V20x, CH32V30x and CH32V31x.

Controller Area Network is a high-performance communication protocol for serial data communication. The CAN controller provides a complete implementation of the CAN protocol, supporting CAN protocols 2.0A and 2.0B. The CAN controller can be used to construct a powerful local area network to realize safe distributed real-time control, process a large number of data packets with a small CPU load, and has a wide range of applications in the industrial and automotive fields.

#### 24.1 Main Features

- Compatible with CAN specification 2.0A and 2.0B
- Programmable transfer rate up to 1Mbit/s
- Support time-triggered communication function to avoid low-priority message blocking
- Support 3 transmitting mailboxes, the priority of transmitting messages can be determined by the message identifier or the order of transmitting requests, and can record the time stamp of the SOF moment of sending the message
- Support 2 receive FIFOs with 3-level mailbox depth, 28 message filter groups can be configured, high-capacity products CAN1 and CAN2 share 28 filters, each filter group can be configured as 32 or 16-bit mode, mask bit or identifier list mode, which can minimize the software's intervention in packet filtering, flexible FIFO overflow processing, and can record the time stamp of the SOF moment of the received packet
- Occupies 4 interrupt vectors, each interrupt source can be configured independently

### 24.2 CAN Controller Operating Mode

The CAN controller can operate the SLEEP or INRQ bits in the register CAN\_CTLR to switch between the initialization mode, sleep mode and normal mode.

#### 24.2.1 Initialization Mode

After reset, CAN works in sleep mode by default to reduce power consumption. At this time, the sending and receiving of messages is prohibited, the internal pull-up resistor of the TX pin is enabled, and the TX pin outputs a recessive bit. The INRQ bit in the register CAN\_CTLR is set to 1, and the CAN controller is requested to enter the initialization mode. When the INAK bit of the register CAN\_STATR is automatically set to 1, the initialization state is successfully entered. Similarly, clear the INRQ bit in the register CAN\_CTLR to request the CAN controller to exit the initialization mode. When the INAK bit of the register CAN\_STATR is automatically cleared to 0, the initialization state is successfully exited.

The filter group can be initialized in the non-initialization mode, but the FINIT bit of the register CAN\_FCTLR must be set to 1, and the reception of the message is prohibited at this time.

#### 24.2.2 Sleep Mode

Set the SLEEP bit in the CAN\_CTLR register to 1 to request the CAN controller to enter the sleep mode. When the SLAK bit of the CAN\_STATR register is automatically set to 1, the CAN successfully enters the sleep mode. At this time, the clock of the CAN controller stops, but the mailbox register is still accessible.

To enter the initialization mode from sleep mode, the SLEEP bit of CAN\_CTLR must be cleared to 0 and the INRQ bit to 1. When the INAK bit of the register CAN\_STATR is automatically set to 1, the switch to the initialization state is completed.

To enter normal mode from sleep mode, the SLEEP bit of CAN\_CTLR must be cleared to 0. When the SLAK bit of the register CAN\_STATR is automatically cleared to 0, the normal mode is entered.



Figure 24-1 CAN working mode switch

#### 24.3 CAN Controller Test Mode

In the initialization mode, operate the SILM and LBKM bits of the register CAN\_BTIMR to select a test mode, and then exit the initialization mode and enter the test mode by clearing the INRQ bit of the register CAN CTLR. There are 3 test modes: silent mode, loopback mode and silent loopback mode.

#### 24.3.1 Silent Mode

Setting the SILM bit in register CAN\_BTIMR to 1 can optionally enter silent mode. In this mode, the CAN controller can receive, but cannot send messages to the outside world. It is always in a recessive bit to the outside world, which can avoid affecting the bus, but the message can be received by the controller of the node where it is located. Usually, silent mode is used for the status analysis of the CAN bus.

#### 24.3.2 Loopback Mode

By setting the LBKM bit of the register CAN\_BTIMR to 1, the loopback mode can be selected. In this mode, the CAN controller can send external messages, but cannot receive external messages, but the sent messages can be received by the controller of the node where it is located, and the reception filtering mechanism is effective. Usually, loopback mode is used for transceiver testing of CAN controllers.

#### 24.3.3 Silent Loopback Mode

Setting the SILM and LBKM bits in register CAN\_BTIMR to 1 can optionally enter silent loopback mode. This mode is usually used for the closed self-test of the CAN controller. In this mode, it has no effect on the CAN bus, the RX pin is disconnected from the bus, and the TX pin is set to a recessive bit.

Silent mode Silent loopback mode Loopback mode CAN CAN CAN Receive Send Receive Receive Send =1 =1 **CANTX CANRX** CANTX CANRX **CANTX CANRX** 

Figure 24-2 CAN 3 test modes of the bus

### 24.4 MCU Working State of CAN Controller in Debug Mode

When the MCU enters the debug mode, the core is in a suspended state, but it can be determined whether the CAN controller is in a normal operation or a stop state through the configuration bits in the debug module.

## 24.5 CAN Controller Functional Description

#### 24.5.1 Transmit Processing Flow

The transmit processing flow is as follows: If there are vacant mailboxes among the 3 sending mailboxes, the application layer software only has written access to the registers of the vacant mailboxes, and operates the registers CAN\_TXMIRx, CAN\_TXMDTRx, CAN\_TXMDLRx and CAN\_TXMDHRx, and can set the message identifier, message length, time stamp, and message data. After the data is ready, the TXRQ bit of the register CAN\_TXMIRx is set to 1 to request transmission, the mailbox enters the registered state, and the priority is queued; once it becomes the highest priority mailbox, it becomes the scheduled transmission state and waits for the CAN bus to be idle; when the CAN bus is idle When the message is scheduled to be sent, the message of the mailbox will enter the sending state immediately; after the message is sent, the mailbox will become a vacant mailbox again, and the RQCP and TXOK bits of the register CAN\_TSTATR are set to 1 to indicate that the sending is successful; if the arbitration fails during sending, the ALST of the register CAN\_TSTATR Set to 1, TERR set to 1 if an error is sent.

#### 24.5.2 Transmit Priority

The transmit priority can be determined by the identifier or the order of sending requests. The TXFP position of the register CAN\_CTLR is 1 and sent according to the order of sending requests. According to the order of sending requests, it is mainly used for segmented sending; the TXFP bit is cleared to 0 and sent according to the priority of the identifier. In order, the smaller the identifier is, the higher the priority is. In the case of the same identifier, the mailbox with the lower number has a higher priority.

#### 24.5.3 Transmit Abort Processing

If the ABRQ bit in the register CAN\_TSTATR is set, the transmission request can be aborted. When the mailbox status is registered or scheduled to send, the sending request is directly aborted; when the mailbox is in the sending state, the abort request may succeed (Stop sending) or fail (Sending complete), and the result can be queried by the TXOK bit in the CAN\_TSTATR register.

#### 24.5.4 Time-based Trigger Mode

When the traditional CAN communication bus is busy, it is easy to cause low-priority messages to be blocked for a long time, and even cannot meet the requirements of its time limit. In order to solve the bottleneck, related protocols based on time-triggered mode have been introduced. Such protocols have a certain scale of application in the industry, and the functions based on time-triggered mode are the application of such protocols.

There are 2 modes to choose from in the time-triggered mode. To use this mode, the automatic retransmission function needs to be turned off. The default mode and enhanced mode are selected by configuring the MODE bit of the CAN TTCTLR register. Set the TTCM and NART bits of the register CAN CTLR to 1, enable the time-triggered mode and disable automatic retransmission. The MODE bit of the CAN TTCTLR register defaults to 0. At this time, it works in the default mode, and the internal timer is activated to generate timestamps of the transmit and receive mailboxes. The timer accumulates at the CAN bit time, and the internal timer is sampled and generates a timestamp at the sample point position of the received and transmitted frame start bits. If the enhanced mode is used, the MODE bit of the CAN TTCTLR register needs to be set to 1 to enable the enhanced mode. Using this mode, there must be 3 or more nodes in the entire CAN network, one of which sends the time reference, and the other nodes receive the time stamp of the reference node, they reset the internal counter by writing 1 to the TIMRST bit of the CAN TTCTLR register to synchronize the internal counter. So that in addition to the node that sends the time reference, the rest of the CAN nodes achieve time synchronization. Afterwards, write the data to be sent to the sending mailbox, configure the time trigger count value (TIMCNT of the CAN TTCNT register) and the internal counter count end value (TIMCMV of the CAN TTCTLR register) of each node in turn. The time-triggered count value and the final count value of the internal counter are determined by the CAN nodes, the CAN communication rate and the number of data bits in a frame. After the configuration is completed, each node waits for the internal counter to count to the timetriggered count value, and then triggers the sending action.

#### 24.5.5 Receive Processing Flow

The reception of CAN bus messages is completed by the controller hardware without the intervention of the MCU, which reduces the processing load of the MCU. The received messages are stored in 2 FIFOs with 3-level mailbox depth according to the setting of the register CAN\_FAFIFOR. If the application layer needs to obtain the message, it can only read the valid received message through the receiving FIFO mailbox.

Initially, the receiving FIFO is empty, and the value of FMR[1:0] in the receiving FIFO register CAN\_RFIFOx is binary 00b. After receiving a valid receiving message, it becomes the registered 1 state, and the controller automatically sets the FMR[1:0] in the receiving FIFO register CAN\_RFIFOx to binary 01b; if the mailbox data registers CAN\_RXMDLRx and CAN\_RXMDHRx are read at this time, the mailbox is released by setting the RFOM bit of the receiving FIFO register CAN\_RFIFOx to 1, and the receiving FIFO state becomes empty again; if the mailbox is not released in the registered 1 state, after the next valid receiving message is received, the receiving FIFO state switches to the registered 2 state; at this time, the FMR[1:0] of the receiving FIFO register CAN\_RFIFOx is automatically set to binary 10b. If the mailbox data register is read and the mailbox is released, then the state returns to registered 1; if the mailbox is not released in the registered 2 state, the receiving FIFO enters the registered 3 state; also in the registered 3 state, the message is read and the mailbox

is released, then the registered 2 state is returned; if the registered 3 state is not If the mailbox is released, when the next valid packet is received, packet loss will inevitably occur.

Valid message Valid message Valid message Valid message Registered Registered Registered received received received received **Empty** Overflow FMP=00b FMP=11b FMP=01b FMP=11b FMP=10b FOVR=0 F0VR=1 Release Mailbo Release Mailbo Release Mailbox Release Mailbox FOVR=0 FOVR=0 FOVR=0 RFOM=1 RFOM=1 RFOM=1 RFOM=1 Valid message received

Figure 24-3 Receive FIFO state switching diagram

In the case of message loss above, that is, the receiving FIFO is full, and the message overflow causes the message to be lost. The FOVR bit of the receiving FIFO register CAN\_RFIFOx will be automatically set to 1 by hardware for overflow query. When the RFLM bit of the register CAN\_CTLR is set to 1, the receiving FIFO locking function is enabled, and the discarded message is a new received message; when the RFLM bit of the register CAN\_CTLR is cleared to 0, the receiving FIFO locking function is disabled. Among the 3 original messages of the receiving FIFO, the last received message will be overwritten by the new message. When the relevant bit of the register CAN\_INTENR is set, an interrupt can be generated when the state of the receiving FIFO is switched, so as to process the received message more efficiently, see section 24.6 CAN interrupt for details.

#### 24.5.6 Received Message Identifier Filtering

There are up to 28 filter groups in the module. By setting the filter group, each CAN node can receive the packets that meet the filtering rules, and the packets that do not meet the filtering rules are discarded by hardware without software intervention.

Each filter bank consists of 2 32-bit registers CAN\_FxR0 and CAN\_FxR1. The bit width of the filter group can be independently configured as a 32-bit filter or 2 16-bit filters by setting each bit of the register CAN\_FSCFGR. Each filter group can be configured as mask bit or identifier list mode by setting each bit of register CAN\_FMCFGR, and each filter group can be enabled or disabled by setting each bit of register CAN\_FWR. Setting each bit of the register CAN\_FAFIFOR can select which receive FIFO the message that passes the filter is stored in.

As shown in Table 24-1 below, in the mask bit mode, the 2 registers are the identifier register and the mask register, which need to be used together. Each bit of the identifier register indicates that the expected value of the corresponding bit is dominant or recessive. Each bit of the register indicates whether the corresponding bit needs to be consistent with the expected value of the corresponding identifier register bit.

| Identifier | CAN FxR1[31:24] | CAN FxR1[23:16]       | CAN FxR1[15:8] | CAN FxR1[7:0]       |  |
|------------|-----------------|-----------------------|----------------|---------------------|--|
| register   | CAN_TAKT[51.24] | CAN_TART[23.10]       | CAN_TART[13.6] | CAN_PARI[7.0]       |  |
| Mask bit   | CAN FxR2[31:24] | CAN EvD2[22,16]       | CAN EvD2[15.0] | CAN FxR2[7:0]       |  |
| register   | CAN_FXR2[31:24] | CAN_FxR2[23:16]       | CAN_FxR2[15:8] | CAN_FXR2[7:0]       |  |
| Map        | STID[10:3]      | STID[2:0] EXID[17:13] | EXID[12:5]     | EXID[4:0] IDE RTR 0 |  |

Table 24-1 32-bit mask bit mode

In the identifier list mode, both registers are used as identifier registers, and each bit of the received message identifier must be consistent with one of the registers to pass the filter.

|   |                        |                 | 10010 2 1 2 0 2 010 1001101111 |                |                     |
|---|------------------------|-----------------|--------------------------------|----------------|---------------------|
|   | Identifier<br>register | CAN_FxR1[31:24] | CAN_FxR1[23:16]                | CAN_FxR1[15:8] | CAN_FxR1[7:0]       |
|   | Mask bit register      | CAN_FxR2[31:24] | CAN_FxR2[23:16]                | CAN_FxR2[15:8] | CAN_FxR2[7:0]       |
| I | Man                    | STID[10·3]      | STID[2:0] EXID[17:13]          | EXID[12:5]     | EXID[4:0] IDE RTR 0 |

Table 24-2 32-bit identifier list mode

In 16-bit mode, the register group is divided into 4 registers, and the mask bit mode of each group of filters can have 2 filters, each of which contains a 16-bit identifier register and a 16-bit mask register; all 4 registers are used as identifier registers in identifier list mode.

Identifier register n CAN FxR1[15:8] CAN FxR1[7:0] Mask bit register n CAN FxR1[31:24] CAN FxR1[23:16] Identifier register n+1 CAN FxR2[7:0] CAN FxR2[15:8] Mask bit register n+1 CAN FxR2[31:24] CAN FxR2[23:16] Map STID[10:3] STID[2:0] **RTR IDE** EXID[17:15]

Table 24-3 16-bit mask bit mode

| Table | 24-4 | 16-hit    | identifier | list mode |
|-------|------|-----------|------------|-----------|
| Tane  | /4-4 | 1 ()-1)11 | паенине    | HSI IHOOG |

| Identifier register n   | CAN_FxR1[15:8]  | CAN_FxR1[7:0]   |     |     |             |  |
|-------------------------|-----------------|-----------------|-----|-----|-------------|--|
| Mask bit register n     | CAN_FxR1[31:24] | CAN_FxR1[23:16] |     |     |             |  |
| Identifier register n+1 | CAN_FxR2[15:8]  | CAN_FxR2[7:0]   |     |     |             |  |
| Mask bit register n+1   | CAN_FxR2[31:24] | CAN_FxR2[23:16] |     |     |             |  |
| Map                     | STID[10:3]      | STID[2:0]       | RTR | IDE | EXID[17:15] |  |

When the message enters the FIFO mailbox, it will be read and stored by the application program. Usually, the application program distinguishes the message data according to the message identifier. The CAN controller provides a filter number for the messages filtered by different filters in the receiving FIFO, and the number is stored in FMI[7:0] of the CAN\_RXMDTRx register, regardless of whether the filter group is enabled or not. The numbering scheme is detailed in the example in Figure 24-4.

When a packet can be filtered by multiple filters, the filter number stored in the receiving mailbox determines which filter number is stored according to the filter priority rules. The filter priority rules are as follows:

- All 32-bit filters have higher priority than 16-bit filters
- For filters of the same width, the filter of the identifier list has higher priority than the filter of the mask bit pattern
- Filters with the same width and pattern, filters with smaller numbers have higher priority

As shown in Figure 24-5: When receiving a message, the identifier is first matched and filtered with the 32-bit identifier list pattern filter. If there is no match, the 32-bit masked bit pattern filter will be matched and filtered. If there is no match, the 16-bit identifier list pattern filter will be matched and filtered. If there is no match, the 16-bit masked bit pattern filter will be matched and filtered. Finally, if there is no match, the message will be discarded. If there is a match, the message will be stored in the mailbox of the receiving FIFO. The identifier number is stored in the FMI in the CAN\_RXMDTRx register.

Filter group Filter Filter group Filter FIFO0 FIFO1 number number number number 0123 0 0 32-bit shield mode 16-bit list mode 1 2 3 4 4 5 2 4 16-bit list mode 16-bit shield mode 3 32-bit list mode 6 7 6 32-bit list mode Disabled 16-bit 5 9 32-bit shield mode 8 shield Mode Disabled 16-bit 9 10 7 32-bit shield mode 9 11 shield Mode 11 12 32-bit list mode 32-bit list mode 8 12 13 14 10 16-bit shield mode 13 32-bit list mode

Figure 24-4 Example of filter number

Figure 24-5 Filter example



#### 24.5.7 Error Handling

The CAN controller relies on the status error register CAN\_ERRSR for error management on the bus. The TEC and REC in the status error register CAN\_ERRSR represent the sending and receiving error count values

respectively, which increase with the increase of the sending and receiving errors and decrease when the sending and receiving is successful. The stability of the CAN bus can be judged according to their values.

When the TEC and REC in the status error register CAN\_ERRSR are less than 128, the current CAN node is in an error active state, can normally participate in bus communication, and sends an active error flag when an error is detected.

When the TEC and REC in the status error register CAN\_ERRSR are greater than 127, the current CAN node is in an error passive state, and when an error is detected, it is not allowed to issue an active error flag, but only a passive error flag.

When the TEC in the status error register CAN\_ERRSR is greater than 255, the current CAN node enters the offline state.

When the bus monitors the occurrence of 11 consecutive recessive bits for 128 times, it restores to the active state of the error. The restoration method is affected by the ABOM bit in the main control register CAN\_CTLR. If ABOM is set to 1, the hardware automatically exits the offline state. If ABOM is 0, the software needs to operate the INRQ bit to enter the initialization mode, and then exit the initialization to exit the offline state.



Figure 24-6 CAN error state switch diagram

### **24.5.8 Bit Timing**

According to the CAN bus standard, each bit time is divided into 4 segments: synchronization segment, propagation time segment, phase buffer segment 1 and phase buffer segment 2. These segments consist of minimum time units Tq. The CAN controller monitors CAN bus changes by sampling and synchronizes by the edge of the frame start bit

The CAN controller redivides the above 4 segments into 3 segments, which are:

- Synchronization segment (SS): That is, the synchronization segment in the CAN standard, which is fixed as a minimum time unit. Under normal circumstances, the expected bit transition occurs within this time period.
- Bit segment 1 (BS1): Contains the propagation time period and phase buffer period 1 in the CAN standard, can be set to contain 1 to 16 minimum time units, and can be automatically extended to compensate for positive phase drift due to frequency accuracy errors at different nodes on the CAN bus. The time period

ends at the sampling point location.

• Bit segment 2 (BS2): that is, the phase buffer section 2 in the CAN standard, which can be set to 1 to 8 minimum time units, and can be automatically shortened to compensate for negative phase drift due to frequency accuracy errors at different nodes on the CAN bus.

The resynchronization jump width (SJW) is the upper limit of the minimum number of time units that can be extended and reduced in each bit, and the range can be set to 1 to 4 minimum time units.

The above parameters can be configured in the CAN bus timing register CAN BTIMR.

Figure 24-7 The jump appears in BS1



As shown in Figure 24-7, the SJW is 2, and the bus level transition is detected in the time period 1, then the length of the time period 1 needs to be extended, and the maximum SJW is extended, thereby delaying the position of the sampling point.

Figure 24-8 The jump appears in BS2



As shown in Figure 24-8, the SJW is 2, and the bus level transition is detected in the time period 2, so it is necessary to reduce the length of the time period 2 and reduce the SJW at the maximum, so as to advance the position of the sampling point.

The CAN baud rate is calculated by the following formula:

CANbps = 
$$\frac{\text{tpclk1}}{(\text{TS1[3:0]} + 1 + \text{TS2[2:0]} + 1 + 1) \times \text{BRP[9:0]}}$$

Here tpclk1 is the PB1 clock cycle and BRP[9:0], TS1[3:0], TS2[2:0] are the corresponding bits of the CANx BTIMR register.

### 24.6 CAN Interrupt

The CAN controller has 4 interrupt vectors, which are transmit interrupt, FIFO\_0 interrupt, FIFO\_1 interrupt, error and state change interrupt.

Setting the CAN interrupt enable register CAN\_INTENR can enable or disable each interrupt source.

The sending interrupt is generated by the event that the sending mailbox becomes empty. After the interrupt occurs, query the RQCP0, RQCP1 and RQCP2 bits of the register CAN\_TSTATR to determine which mailbox becomes empty.

FIFO0 interrupt is generated by receiving new message, receiving mailbox full and overflow event. After the interrupt occurs, query the FMP0, FULL0 and FOVER0 bits of register CAN\_RFIFO0 to determine which mailbox becomes empty event.

FIFO1 interrupt is generated by receiving new message, receiving mailbox full and overflow event. After the interrupt occurs, query the FMP1, FULL1 and FOVER1 bits of register CAN\_RFIFO1 to determine which mailbox becomes empty event.

Error and state change interrupts are generated by error, wakeup, and sleep events.



Figure 24-9 CAN interrupt logic diagram

# 24.7 Register Description

The registers related to the CAN controller must be manipulated in 32-bit words. In order to avoid the influence of the current node on the entire CAN bus, the application software can only modify the bit timing register CAN\_BTIMR in the initialization mode.

Table 24-5 CAN1 registers

| Name            | Access address | Description                                    | Reset value |
|-----------------|----------------|------------------------------------------------|-------------|
| R32_CAN1_CTLR   | 0x40006400     | CAN1 master control register                   | 0x00010002  |
| R32_CAN1_STATR  | 0x40006404     | CAN1 master status register                    | 0x00000X02  |
| R32_CAN1_TSTATR | 0x40006408     | CAN1 transmit status register                  | 0x1C000000  |
| R32_CAN1_RFIFO0 | 0x4000640C     | CAN1 receive FIFO0 control and status register | 0x00000000  |
| R32_CAN1_RFIFO1 | 0x40006410     | CAN1 receive FIFO1 control and status register | 0x00000000  |
| R32_CAN1_INTENR | 0x40006414     | CAN1 interrupt enable register                 | 0x00000000  |
| R32_CAN1_ERRSR  | 0x40006418     | CAN1 error status register                     | 0x00000000  |
| R32_CAN1_BTIMR  | 0x4000641C     | CAN1 bit timing register                       | 0x01230000  |
| R32_CAN1_TTCTLR | 0x40006420     | CAN1 time trigger control register             | 0x0000FFFF  |
| R32_CAN1_TTCNT  | 0x40006424     | CAN1 time trigger count value register         | 0x00000000  |

Table 24-6 CAN2 registers

| Name            | Access address | Description                                    | Reset value |
|-----------------|----------------|------------------------------------------------|-------------|
| R32_CAN2_CTLR   | 0x40006800     | CAN2 master control register                   | 0x00010002  |
| R32_CAN2_STATR  | 0x40006804     | CAN2 master status register                    | 0x00000X02  |
| R32_CAN2_TSTATR | 0x40006808     | CAN2 transmit status register                  | 0x1C000000  |
| R32_CAN2_RFIFO0 | 0x4000680C     | CAN2 receive FIFO0 control and status register | 0x00000000  |
| R32_CAN2_RFIFO1 | 0x40006810     | CAN2 receive FIFO1 control and status register | 0x00000000  |
| R32_CAN2_INTENR | 0x40006814     | CAN2 interrupt enable register                 | 0x00000000  |
| R32_CAN2_ERRSR  | 0x40006818     | CAN2 error status register                     | 0x00000000  |
| R32_CAN2_BTIMR  | 0x4000681C     | CAN2 bit timing register                       | 0x01230000  |
| R32_CAN2_TTCTLR | 0x40006820     | CAN2 time trigger control register             | 0x0000FFFF  |
| R32_CAN2_TTCNT  | 0x40006824     | CAN2 time trigger count value register         | 0x00000000  |

Table 24-7 CAN1 mailbox registers

| Table 24-7 Cravi manoox registers |                |                                                     |             |  |  |  |  |
|-----------------------------------|----------------|-----------------------------------------------------|-------------|--|--|--|--|
| Name                              | Access address | Description                                         | Reset value |  |  |  |  |
| R32_CAN1_TXMIR0                   | 0x40006580     | CAN1 Tx mailbox0 identifier register                | X           |  |  |  |  |
| R32_CAN1_TXMDTR0                  | 0x40006584     | CAN1 Tx mailbox0 data length and timestamp register | X           |  |  |  |  |
| R32_CAN1_TXMDLR0                  | 0x40006588     | CAN1 Tx mailbox0 data low register                  | X           |  |  |  |  |
| R32_CAN1_TXMDHR0                  | 0x4000658C     | CAN1 Tx mailbox0 data high register                 | X           |  |  |  |  |
| R32_CAN1_TXMIR1                   | 0x40006590     | CAN1 Tx mailbox1 identifier register                | X           |  |  |  |  |

| R32_CAN1_TXMDTR1 | 0x40006594 | CAN1 Tx mailbox1 data length and timestamp register      | X |
|------------------|------------|----------------------------------------------------------|---|
| R32_CAN1_TXMDLR1 | 0x40006598 | CAN1 Tx mailbox1 data low register                       | X |
| R32_CAN1_TXMDHR1 | 0x4000659C | CAN1 Tx mailbox1 data high register                      | X |
| R32_CAN1_TXMIR2  | 0x400065A0 | CAN1 Tx mailbox2 identifier register                     | X |
| R32_CAN1_TXMDTR2 | 0x400065A4 | CAN1 Tx mailbox2 data length and timestamp register      | X |
| R32_CAN1_TXMDLR2 | 0x400065A8 | CAN1 Tx mailbox2 data low register                       | X |
| R32_CAN1_TXMDHR2 | 0x400065AC | CAN1 Tx mailbox2 data high register                      | X |
| R32_CAN1_RXMIR0  | 0x400065B0 | CAN1 Rx FIFO0 mailbox identifier register                | X |
| R32_CAN1_RXMDTR0 | 0x400065B4 | CAN1 Rx FIFO0 mailbox data length and timestamp register | X |
| R32_CAN1_RXMDLR0 | 0x400065B8 | CAN1 Rx FIFO0 mailbox data low register                  | X |
| R32_CAN1_RXMDHR0 | 0x400065BC | CAN1 Rx FIFO0 mailbox data high register                 | X |
| R32_CAN1_RXMIR1  | 0x400065C0 | CAN1 Rx FIFO1 mailbox identifier register                | X |
| R32_CAN1_RXMDTR1 | 0x400065C4 | CAN1 Rx FIFO1 mailbox data length and timestamp register | X |
| R32_CAN1_RXMDLR1 | 0x400065C8 | CAN1 Rx FIFO1 mailbox data low register                  | X |
| R32_CAN1_RXMDHR1 | 0x400065CC | CAN1 Rx FIFO1 mailbox data high register                 | X |

Table 24-8 CAN2 Mailbox registers

| Name             | Access address | Description                                              | Reset Value |
|------------------|----------------|----------------------------------------------------------|-------------|
| R32_CAN2_TXMIR0  | 0x40006980     | CAN2 Tx mailbox0 identifier register                     | X           |
| R32_CAN2_TXMDTR0 | 0x40006984     | CAN2 Tx mailbox0 data length and timestamp register      | X           |
| R32_CAN2_TXMDLR0 | 0x40006988     | CAN2 Tx mailbox0 data low register                       | X           |
| R32_CAN2_TXMDHR0 | 0x4000698C     | CAN2 Tx mailbox0 data high register                      | X           |
| R32_CAN2_TXMIR1  | 0x40006990     | CAN2 Tx mailbox1 identifier register                     | X           |
| R32_CAN2_TXMDTR1 | 0x40006994     | CAN2 Tx mailbox1 data length and timestamp register      | X           |
| R32_CAN2_TXMDLR1 | 0x40006998     | CAN2 Tx mailbox1 data low register                       | X           |
| R32_CAN2_TXMDHR1 | 0x4000699C     | CAN2 Tx mailbox1 data high register                      | X           |
| R32_CAN2_TXMIR2  | 0x400069A0     | CAN2 Tx mailbox2 identifier register                     | X           |
| R32_CAN2_TXMDTR2 | 0x400069A4     | CAN2 Tx mailbox2 data length and timestamp register      | X           |
| R32_CAN2_TXMDLR2 | 0x400069A8     | CAN2 Tx mailbox2 data low register                       | X           |
| R32_CAN2_TXMDHR2 | 0x400069AC     | CAN2 Tx mailbox2 data high register                      | X           |
| R32_CAN2_RXMIR0  | 0x400069B0     | CAN2 Rx FIFO0 mailbox identifier register                | X           |
| R32_CAN2_RXMDTR0 | 0x400069B4     | CAN2 Rx FIFO0 mailbox data length and timestamp register | X           |
| R32_CAN2_RXMDLR0 | 0x400069B8     | CAN2 Rx FIFO0 mailbox data low register                  | X           |
| R32_CAN2_RXMDHR0 | 0x400069BC     | CAN2 Rx FIFO0 mailbox data high register                 | X           |
| R32_CAN2_RXMIR1  | 0x400069C0     | CAN2 Rx FIFO1 mailbox identifier register                | X           |
| R32_CAN2_RXMDTR1 | 0x400069C4     | CAN2 Rx FIFO1 mailbox data length and timestamp register | X           |

| R32_CAN2_RXMDLR1 | 0x400069C8 | CAN2 Rx FIFO1 mailbox data low register  | X |
|------------------|------------|------------------------------------------|---|
| R32 CAN2 RXMDHR1 | 0x400069CC | CAN2 Rx FIFO1 mailbox data high register | X |

Table 24-9 CAN1 Filter registers

| Name             | Access address | Description                           | Reset value |
|------------------|----------------|---------------------------------------|-------------|
| R32_CAN1_FCTLR   | 0x40006600     | CAN1 filter master control register   | 0x2A1C0E01  |
| R32_CAN1_FMCFGR  | 0x40006604     | CAN1 filter mode register             | 0x00000000  |
| R32_CAN1_FSCFGR  | 0x4000660C     | CAN1 filter bit width register        | 0x00000000  |
| R32_CAN1_FAFIFOR | 0x40006614     | CAN1 filter FIFO association register | 0x00000000  |
| R32_CAN1_FWR     | 0x4000661C     | CAN1 filter activation register       | 0x00000000  |
| R32_CAN1_F0R1    | 0x40006640     | CAN1 filter Bank0 register 1          | X           |
| R32_CAN1_F0R2    | 0x40006644     | CAN1 filter Bank0 register 2          | X           |
| R32_CAN1_F1R1    | 0x40006648     | CAN1 filter Bank1 register 1          | X           |
| R32_CAN1_F1R2    | 0x4000664C     | CAN1 filter Bank1 register 2          | X           |
| R32_CAN1_F2R1    | 0x40006650     | CAN1 filter Bank2 register 1          | X           |
| R32_CAN1_F2R2    | 0x40006654     | CAN1 filter Bank2 register 2          | X           |
| R32_CAN1_F3R1    | 0x40006658     | CAN1 filter Bank3 register 1          | X           |
| R32_CAN1_F3R2    | 0x4000665C     | CAN1 filter Bank3 register 2          | X           |
| R32_CAN1_F4R1    | 0x40006660     | CAN1 filter Bank4 register 1          | X           |
| R32_CAN1_F4R2    | 0x40006664     | CAN1 filter Bank4 register 2          | X           |
| R32_CAN1_F5R1    | 0x40006668     | CAN1 filter Bank5 register 1          | X           |
| R32_CAN1_F5R2    | 0x4000666C     | CAN1 filter Bank5 register 2          | X           |
| R32_CAN1_F6R1    | 0x40006670     | CAN1 filter Bank6 register 1          | X           |
| R32_CAN1_F6R2    | 0x40006674     | CAN1 filter Bank6 register 2          | X           |
| R32_CAN1_F7R1    | 0x40006678     | CAN1 filter Bank7 register 1          | X           |
| R32_CAN1_F7R2    | 0x4000667C     | CAN1 filter Bank7 register 2          | X           |
| R32_CAN1_F8R1    | 0x40006680     | CAN1 filter Bank8 register 1          | X           |
| R32_CAN1_F8R2    | 0x40006684     | CAN1 filter Bank8 register 2          | X           |
| R32_CAN1_F9R1    | 0x40006688     | CAN1 filter Bank9 register 1          | X           |
| R32_CAN1_F9R2    | 0x4000668C     | CAN1 filter Bank9 register 2          | X           |
| R32_CAN1_F10R1   | 0x40006690     | CAN1 filter Bank10 register 1         | X           |
| R32_CAN1_F10R2   | 0x40006694     | CAN1 filter Bank10 register 2         | X           |
| R32_CAN1_F11R1   | 0x40006698     | CAN1 filter Bank11 register 1         | X           |
| R32_CAN1_F11R2   | 0x4000669C     | CAN1 filter Bank11 register 2         | X           |
| R32_CAN1_F12R1   | 0x400066A0     | CAN1 filter Bank12 register 1         | X           |
| R32_CAN1_F12R2   | 0x400066A4     | CAN1 filter Bank12 register 2         | X           |
| R32_CAN1_F13R1   | 0x400066A8     | CAN1 filter Bank13 register 1         | X           |
| R32_CAN1_F13R2   | 0x400066AC     | CAN1 filter Bank13 register 2         | X           |
| R32_CAN1_F14R1   | 0x400066B0     | CAN1 filter Bank14 register 1         | X           |
| R32_CAN1_F14R2   | 0x400066B4     | CAN1 filter Bank14 register 2         | X           |
| R32_CAN1_F15R1   | 0x400066B8     | CAN1 filter Bank15 register 1         | X           |
| R32_CAN1_F15R2   | 0x400066BC     | CAN1 filter Bank15 register 2         | X           |
| R32_CAN1_F16R1   | 0x400066C0     | CAN1 filter Bank16 register 1         | X           |
| R32_CAN1_F16R2   | 0x400066C4     | CAN1 filter Bank16 register 2         | X           |
| R32_CAN1_F17R1   | 0x400066C8     | CAN1 filter Bank17 register 1         | X           |

| R32_CAN1_F17R2 | 0x400066CC | CAN1 filter Bank17 register 2 | X |
|----------------|------------|-------------------------------|---|
| R32_CAN1_F18R1 | 0x400066D0 | CAN1 filter Bank18 register 1 | X |
| R32_CAN1_F18R2 | 0x400066D4 | CAN1 filter Bank18 register 2 | X |
| R32_CAN1_F19R1 | 0x400066D8 | CAN1 filter Bank19 register 1 | X |
| R32_CAN1_F19R2 | 0x400066DC | CAN1 filter Bank19 register 2 | X |
| R32_CAN1_F20R1 | 0x400066E0 | CAN1 filter Bank20 register 1 | X |
| R32_CAN1_F20R2 | 0x400066E4 | CAN1 filter Bank20 register 2 | X |
| R32_CAN1_F21R1 | 0x400066E8 | CAN1 filter Bank21 register 1 | X |
| R32_CAN1_F21R2 | 0x400066EC | CAN1 filter Bank21 register 2 | X |
| R32_CAN1_F22R1 | 0x400066F0 | CAN1 filter Bank22 register 1 | X |
| R32_CAN1_F22R2 | 0x400066F4 | CAN1 filter Bank22 register 2 | X |
| R32_CAN1_F23R1 | 0x400066F8 | CAN1 filter Bank23 register 1 | X |
| R32_CAN1_F23R2 | 0x400066FC | CAN1 filter Bank23 register 2 | X |
| R32_CAN1_F24R1 | 0x40006700 | CAN1 filter Bank24 register 1 | X |
| R32_CAN1_F24R2 | 0x40006704 | CAN1 filter Bank24 register 2 | X |
| R32_CAN1_F25R1 | 0x40006708 | CAN1 filter Bank25 register 1 | X |
| R32_CAN1_F25R2 | 0x4000670C | CAN1 filter Bank25 register 2 | X |
| R32_CAN1_F26R1 | 0x40006710 | CAN1 filter Bank26 register 1 | X |
| R32_CAN1_F26R2 | 0x40006714 | CAN1 filter Bank26 register 2 | X |
| R32_CAN1_F27R1 | 0x40006718 | CAN1 filter Bank27 register 1 | X |
| R32_CAN1_F27R2 | 0x4000671C | CAN1 filter Bank27 register 2 | X |

# 24.7.1 CANx Master Control Register (CANx\_CTLR) (x=1/2)

Offset address: 0x00

| 31        | 30 | 29 | 28 | 27      | 26 | 25 | 24      | 23       | 22       | 21       | 20       | 19       | 18   | 17        | _16_ |
|-----------|----|----|----|---------|----|----|---------|----------|----------|----------|----------|----------|------|-----------|------|
|           |    |    |    |         |    | F  | Reserve | ed       |          |          |          |          |      |           | DBF  |
| 15        | 14 | 13 | 12 | 11      | 10 | 9  | 8       | 7        | 6        | 5        | 4        | 3        | 2    | 1         | 0    |
| RESE<br>T |    |    | F  | Reserve | ed |    |         | TTC<br>M | ABO<br>M | AWU<br>M | NAR<br>T | RFL<br>M | TXFP | SLEE<br>P | INRQ |

| Bit     | Name     | Access | Description                                                                                                                                                                                                                                   | Reset value |
|---------|----------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:17] | Reserved | RO     | Reserved                                                                                                                                                                                                                                      | 0           |
| 16      | DBF      | RW     | Debug whether to disable CAN bus from working  0: When debugging, the CAN controller works normally;  1: During debugging, the CAN transceiver is prohibited, but the control and read and write operations of the receiving FIFO are normal. | 1           |
| 15      | RESET    | RW1Z   | CAN controller software reset request. Writing 0 to this bit is invalid 0: The CAN controller is in normal state; 1: Reset the CAN controller. After reset, the controller enters sleep mode, and then the                                    | 0           |

|        |          |      | hardware automatically clears it to 0.            |   |
|--------|----------|------|---------------------------------------------------|---|
| [14:8] | Reserved | RO   | Reserved                                          | 0 |
|        |          |      | Whether to allow time trigger mode                |   |
|        |          |      | 0: Disable time trigger mode;                     |   |
| 7      | TTCM     | RW   | 1: Enable time trigger mode.                      | 0 |
|        |          |      | The time trigger mode is mainly used with the     |   |
|        |          |      | TTCAN protocol.                                   |   |
|        |          |      | Offline automatic exit control                    |   |
|        |          |      | 0: The INRQ bit of the software operation         |   |
|        |          |      | register CAN_CTLR is required to be set to 1      |   |
|        |          |      | and then cleared to 0. After 11 consecutive       |   |
| 6      | ABOM     | RW   | implicit bits are detected 128 times, the offline | 0 |
|        |          |      | state is exited;                                  |   |
|        |          |      | 1: The hardware detects 11 consecutive            |   |
|        |          |      | implicit bits 128 times and automatically exits   |   |
|        |          |      | the offline state.                                |   |
|        |          |      | CAN controller automatic wake-up enable           |   |
|        |          |      | 0: Software operation is required to clear the    |   |
|        |          |      | SLEEP bit of the CAN_CTLR register to wake        |   |
| 5      | AWUM     | RW   | up the CAN controller;                            | 0 |
| 3      | AWUM     | K VV | 1: When a message is detected, the hardware       | U |
|        |          |      | automatically wakes up, and the SLEEP and         |   |
|        |          |      | SLAK bits of the register CAN_STATR are           |   |
|        |          |      | automatically cleared to 0.                       |   |
|        |          |      | The automatic packet retransmission function      |   |
|        | NART     |      | is disabled                                       |   |
|        |          |      | 0: The CAN controller keeps retransmitting        |   |
| 4      |          | RW   | until the transmission is successful;             | 0 |
|        |          |      | 1: No matter whether the transmission is          |   |
|        |          |      | successful or not, the message can only be sent   |   |
|        |          |      | once.                                             |   |
|        |          |      | Receive FIFO message lock mode enable             |   |
|        |          |      | 0: When the receiving FIFO overflows, the         |   |
|        |          |      | received mailbox message is not read out, and     |   |
|        |          |      | when the mailbox is not released, the new         |   |
| 3      | RFLM     | RW   | received message will overwrite the original      | Ω |
| 3      | KLIVI    | KW   | message;                                          | 0 |
|        |          |      | 1: When the receiving FIFO overflows, the         |   |
|        |          |      | received mailbox message is not read, and the     |   |
|        |          |      | newly received message is discarded when the      |   |
|        |          |      | mailbox is not released.                          |   |
|        |          |      | Send mailbox priority method selection            |   |
|        |          |      | 0: The priority is determined by the message      |   |
| 2      | TXFP     | RW   | identifier;                                       | 0 |
|        |          |      | 1: The priority is determined by the order in     |   |
|        |          |      | which the requests are sent.                      |   |

| 1 | SLEEP | RW | Sleep mode request 0: After the software clears to 0, the controller exits the sleep mode; 1: Set to 1 to request the CAN controller to enter sleep mode. After the current activity is completed, the controller enters sleep mode. If the AWUM bit is set to 1, the controller clears the SLEEP bit to 0 when a message is received.                                                                                                     | 1 |
|---|-------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| 0 | INRQ  | RW | Initialize mode request  0: Set to 0 to request the CAN controller to exit the initialization mode and enter the normal mode, and the hardware clears the INAK bit of the CAN_STATR register to 0;  1: Set to 1 to request the CAN controller to enter the initialization mode. After the current activity is completed, the controller enters the initialization mode, and the hardware sets the INAK bit of the register CAN_STATR to 1. | 0 |

# 24.7.2 CANx Master Status Register (CANx\_STATR) (x=1/2)

Offset Address: 0x04

| 31 | 30   | 29    | 28 | 27 | 26       | 25  | 24   | 23   | 22      | 21 | 20        | 19       | 18   | 17       | 16   |
|----|------|-------|----|----|----------|-----|------|------|---------|----|-----------|----------|------|----------|------|
|    |      |       |    |    |          |     | Rese | rved |         |    |           |          |      |          |      |
| 15 | 14   | 13    | 12 | 11 | 10       | 9   | 8    | 7    | 6       | 5  | 4         | 3        | 2    | 1        | 0    |
|    | Rese | erved |    | RX | SAM<br>P | RXM | TXM  | F    | Reserve | d  | SLA<br>KI | WKU<br>I | ERRI | SLA<br>K | INAK |

| Bit     | Name     | Access | Description                                                                                                                                                                                                                                                                                   | Reset value |
|---------|----------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:12] | Reserved | RO     | Reserved                                                                                                                                                                                                                                                                                      | 0           |
| 11      | RX       | RO     | Current actual level of CAN controller Rx pin.                                                                                                                                                                                                                                                | X           |
| 10      | SAMP     | RO     | Level of a receive bit on the CAN controller RX pin                                                                                                                                                                                                                                           | X           |
| 9       | RXM      | RO     | Rx mode query  0: CAN controller is not in Rx mode currently;  1: CAN controller is in Rx mode currently.                                                                                                                                                                                     | 0           |
| 8       | TXM      | RO     | Tx mode query 0: CAN controller is not in Tx mode currently; 1: CAN controller is in Tx mode currently.                                                                                                                                                                                       | 0           |
| [7:5]   | Reserved | RO     | Reserved                                                                                                                                                                                                                                                                                      | 0           |
| 4       | SLAKI    | RW1Z   | Sleep interrupt enable, that is, interrupt generation flag when the SLKIE bit in the CAN_INTENR register is set to 1, write 1 to clear it, and writing 0 is invalid.  0: When exiting sleep mode, it can be cleared by hardware or by software;  1: When entering sleep mode, an interrupt is | 0           |

|   |      |      | generated and the hardware is set to 1.                                                                                                                                                                                                            |   |
|---|------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| 3 | WKUI | RW1Z | Wake-up interrupt flag. When the WKUI bit in the CAN_INTENR register is set to 1, if the SOF bit is detected when the CAN controller is in sleep mode, the hardware will set it to 1. Set to 1 by software to clear to 0, and set to 0 is invalid. | 0 |
| 2 | ERRI | RW1Z | Error interrupt. When the ERRIE bit in the CAN_INTENR register is set to 1, an error and status change interrupt is generated. This bit is set to 1 and cleared to 0 by software, and set to 0 is invalid.                                         | 0 |
| 1 | SLAK | RO   | Sleep mode indication.  1: CAN controller is in sleep mode;  0: CAN controller is not in sleep mode.                                                                                                                                               | 1 |
| 0 | INAK | RO   | Initialization mode indication.  1: CAN controller is in initialization mode;  0: CAN controller is not in initialization mode.                                                                                                                    | 0 |

# 24.7.3 CANx Transmit Status Register (CANx\_TSTATR) (x=1/2)

Offset Address: 0x08

| 31        | 30       | 29       | 28       | 27        | 26        | 25        | 24        | 23        | 22 | 21      | 20 | 19        | 18        | 17        | 16        |
|-----------|----------|----------|----------|-----------|-----------|-----------|-----------|-----------|----|---------|----|-----------|-----------|-----------|-----------|
| LOW<br>2  | LOW<br>1 | LOW<br>0 | TME<br>2 | TME<br>1  | TME<br>0  | CODI      | E[1:0]    | ABR<br>Q2 | F  | Reserve | d  | TER<br>R2 | ALST<br>2 | TXO<br>K2 | RQC<br>P2 |
| 15        | 14       | 13       | 12       | 11        | 10        | 9         | 8         | 7         | 6  | 5       | 4  | 3         | 2         | 1         | 0         |
| ABR<br>Q1 | F        | Reserve  | d        | TER<br>R1 | ALST<br>1 | TXO<br>K1 | RQC<br>P1 | ABR<br>Q0 | F  | Reserve | d  | TER<br>R0 | ALST<br>0 | TXO<br>K0 | RQC<br>P0 |

| Bit | Name | Access | Description                                                                                                                               | Reset value |
|-----|------|--------|-------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| 31  | LOW2 | RO     | Lowest priority flag for Tx mailbox2  0: The priority of Tx mailbox2 is not the lowest;  1: Tx mailbox2 has the lowest priority.          | 0           |
| 30  | LOW1 | RO     | Lowest priority flag for Tx mailbox 1  0: The priority of Tx mailbox 1 is not the lowest;  1: The priority of Tx mailbox 1 is the lowest. | 0           |
| 29  | LOW0 | RO     | Lowest priority flag for Tx mailbox0  0: The priority of Tx mailbox0 is not the lowest;  1: The priority of Tx mailbox0 is the lowest.    | 0           |
| 28  | TME2 | RO     | Empty flag bit for Tx mailbox2  0: Tx mailbox2 has a message waiting to be sent;  1: No message waiting to be sent by the Tx mailbox2.    | 1           |
| 27  | TME1 | RO     | Empty flag bit for Tx mailbox1  0: Tx mailbox1 has a message waiting to be sent;  1: No message waiting to be sent by the Tx mailbox1.    | 1           |
| 26  | TME0 | RO     | Empty flag bit for Tx mailbox0                                                                                                            | 1           |

|         |          |      | 0: Tx mailbox0 has a message waiting to be sent; 1: No message waiting to be sent by the Tx mailbox0.                                                                                                                                     |   |
|---------|----------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| [25:24] | CODE     | RO   | Mailbox code When more than one mailbox is empty, it indicates the next empty mailbox number; when all mailboxes are empty, it indicates the mailbox number with the lowest priority.                                                     | 0 |
| 23      | ABRQ2    | RW1  | Send a send abort request for mailbox2. Set to 1 by software to abort the sending request of mailbox 2. When the sent message is cleared, the hardware clears it to 0. If mailbox 2 is cleared, the software is invalidated by setting 1. | 0 |
| [22:20] | Reserved | RO   | Reserved                                                                                                                                                                                                                                  | 0 |
| 19      | TERR2    | RW1Z | Tx mailbox2 transmit error. When Tx mailbox2 fails, this bit is automatically set to 1. Set to 1 by software to clear, software write 0 is invalid.                                                                                       | 0 |
| 18      | ALST2    | RW1Z | Tx mailbox 2 arbitration failure flag. When the Tx mailbox 2 has a low arbitration priority and fails to send, this bit is automatically set to 1. Set to 1 by software to clear, software write 0 is invalid.                            | 0 |
| 17      | TXOK2    | RW1Z | Tx mailbox 2 transmit OK.  0: The last transmission failed;  1: The last transmission was successful.  Set to 1 by software to clear, software write 0 is invalid.                                                                        | 0 |
| 16      | RQCP2    | RW1Z | Tx mailbox 2 request completion flag, this bit is automatically set to 1 when the sending or aborting request of sending mailbox 2 is completed. Set to 1 by software to clear, software write 0 is invalid.                              | 0 |
| 15      | ABRQ1    | RW1Z | Send a send abort request for mailbox 1. Set to 1 by software to abort the sending request of mailbox 1, and reset to 0 by hardware when the sent message is cleared. Software write 0 is invalid.                                        | 0 |
| [14:12] | Reserved | RO   | Reserved                                                                                                                                                                                                                                  | 0 |
| 11      | TERR1    | RW1Z | Tx mailbox1 transmit error. When Tx mailbox1 fails, this bit is automatically set to 1. Set to 1 by software to clear, software write 0 is invalid.                                                                                       | 0 |
| 10      | ALST1    | RW1Z | Tx mailbox1 arbitration failure flag. When the Tx mailbox1 has a low arbitration priority and fails to send, this bit is automatically set to 1.                                                                                          | 0 |
| 9       | TXOK1    | RW1Z | Tx mailbox1 transmit OK.  0: The last transmission failed;  1: The last transmission was successful.                                                                                                                                      | 0 |

|       |          |      | Set to 1 by software to clear software write 0 is                                                                                                                                                            |   |
|-------|----------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
|       |          |      | Set to 1 by software to clear, software write 0 is invalid.                                                                                                                                                  |   |
|       |          |      |                                                                                                                                                                                                              |   |
| 8     | RQCP1    | RW1Z | Tx mailbox1 request completion flag, this bit is automatically set to 1 when the sending or aborting request of sending mailbox 1 is completed.  Set to 1 by software to clear, software write 0 is invalid. | 0 |
| 7     | ABRQ0    | RW1Z | Send a send abort request for mailbox 0. Set to 1 by software to abort the sending request of mailbox 0, and reset to 0 by hardware when the sent message is cleared. Software write 0 is invalid.           | 0 |
| [6:4] | Reserved | RO   | Reserved                                                                                                                                                                                                     | 0 |
| 3     | TERR0    | RW1Z | Tx mailbox0 transmit error. When Tx mailbox0 fails, this bit is automatically set to 1. Set to 1 by software to clear, software write 0 is invalid.                                                          | 0 |
| 2     | ALST0    | RW1Z | Tx mailbox0 arbitration failure flag. When Tx mailbox0 has a low arbitration priority and fails to send, this bit is automatically set to 1. Set to 1 by software to clear, software write 0 is invalid.     | 0 |
| 1     | TXOK0    | RW1Z | Tx mailbox0 transmit OK.  1: The last transmission was successful;  0: The last transmission failed.  Set to 1 by software to clear, software write 0 is invalid.                                            | 0 |
| 0     | RQCP0    | RW1Z | Tx mailbox0 request completion flag. When the send or abort request of Tx mailbox0 is completed, this bit is automatically set to 1. Set to 1 by software to clear, software write 0 is invalid.             | 0 |

# 24.7.4 CANx Receive FIFO 0 Status Register (CANx\_RFIFO0) (x=1/2)

Offset address: 0x0C

| 31 | 30       | 29 | 28 | 27 | 26 | 25 | 24   | 23    | 22        | 21        | 20        | 19           | 18  | 17     | 16 |
|----|----------|----|----|----|----|----|------|-------|-----------|-----------|-----------|--------------|-----|--------|----|
|    |          |    |    |    |    |    | Rese | erved |           |           |           |              |     |        |    |
| 15 | 14       | 13 | 12 | 11 | 10 | 9  | 8    | 7     | 6         | 5         | 4         | 3            | 2   | 1      | 0  |
|    | Reserved |    |    |    |    |    |      |       | RFO<br>M0 | FOV<br>R0 | FULL<br>0 | Reser<br>ved | FMP | 0[1:0] |    |

| Bit    | Name     | Access | Description                                                                                 | Reset value |
|--------|----------|--------|---------------------------------------------------------------------------------------------|-------------|
| [31:6] | Reserved | RO     | Reserved                                                                                    | 0           |
|        |          |        | When the software sets this bit to 1, it releases                                           |             |
| 5      | RFOM0    | RW1Z   | the current mailbox message of the receiving FIFO 0, and automatically clears it to 0 after | 0           |
|        |          |        | the release, and software write 0 is invalid.                                               |             |

|       |           |      | Receive FIFO_0 overflow flag. When there are     |   |
|-------|-----------|------|--------------------------------------------------|---|
|       |           |      | 3 messages in FIFO_0, a new message is           |   |
| 4     | FOVR0     | RW1Z | received, and the hardware is set to 1. This bit | 0 |
|       |           |      | needs software to be set to 1 and cleared to 0,  |   |
|       |           |      | and software write 0 is invalid.                 |   |
|       | FULL0     |      | Receive FIFO_0 full flag. Set by hardware        |   |
| 3     |           | RW1Z | when there are 3 messages in FIFO_0. This bit    | 0 |
| 3     |           |      | needs software to be set to 1 and cleared to 0,  | U |
|       |           |      | and software write 0 is invalid.                 |   |
| 2     | Reserved  | RO   | Reserved                                         | 0 |
| [1:0] | FMP0[1:0] | RO   | Number of received FIFO_0 messages.              | 0 |

# 24.7.5 CANx Receive FIFO 1 Status Register (CANx\_RFIFO1) (x=1/2)

Offset address: 0x10

| 31 | 30       | 29 | 28 | 27 | 26 | 25 | 24   | 23    | 22        | 21        | 20        | 19           | 18  | 17     | 16 |
|----|----------|----|----|----|----|----|------|-------|-----------|-----------|-----------|--------------|-----|--------|----|
|    |          |    |    |    |    |    | Rese | erved |           |           |           |              |     |        |    |
| 15 | 14       | 13 | 12 | 11 | 10 | 9  | 8    | 7     | 6         | 5         | 4         | 3            | 2   | 1      | 0  |
|    | Reserved |    |    |    |    |    |      |       | RFO<br>M1 | FOV<br>R1 | FULL<br>1 | Reser<br>ved | FMP | 1[1:0] |    |

| Bit    | Name      | Access | Description                                                                                                                                                                                                           | Reset<br>value |
|--------|-----------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| [31:6] | Reserved  | RO     | Reserve.                                                                                                                                                                                                              | 0              |
| 5      | RFOM1     | RW1Z   | When the software sets this bit to 1, the current mailbox message of the receiving FIFO_1 is released, and it is automatically cleared to 0 after the release, and software write 0 is invalid.                       | 0              |
| 4      | FOVR1     | RW1Z   | Receive FIFO_1 overflow flag. When there are 3 messages in FIFO_1, a new message is received, and the hardware is set to 1. This bit needs software to be set to 1 and cleared to 0, and software write 0 is invalid. | 0              |
| 3      | FULL1     | RW1Z   | Receive FIFO_1 full flag. Set to 1 by hardware when there are 3 messages in FIFO_1. This bit needs software to be set to 1 and cleared to 0, and software write 0 is invalid.                                         | 0              |
| 2      | Reserved  | RF     | Reserved                                                                                                                                                                                                              | 0              |
| [1:0]  | FMP1[1:0] | RO     | Number of received FIFO_1 messages.                                                                                                                                                                                   | 0              |

## 24.7.6 CANx Interrupt Enable Register (CANx\_INTENR) (x=1/2)

Offset address: 0x14

| 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22        | 21        | 20 | 19 | 18 | 17 | _16_ |
|----------|----|----|----|----|----|----|----|----|-----------|-----------|----|----|----|----|------|
| Reserved |    |    |    |    |    |    |    |    | SLKI<br>E | WKU<br>IE |    |    |    |    |      |

| 15        | 14 | 13      | 12 | 11        | 10        | 9         | 8         | 7            | 6          | 5         | 4          | 3          | 2         | 1          | 0         |
|-----------|----|---------|----|-----------|-----------|-----------|-----------|--------------|------------|-----------|------------|------------|-----------|------------|-----------|
| ERRI<br>E | R  | Reserve | d  | LECI<br>E | BOFI<br>E | EPVI<br>E | EWG<br>IE | Reser<br>ved | FOV<br>IE1 | FFIE<br>1 | FMP<br>IE1 | FOV<br>IE0 | FFIE<br>0 | FMP<br>IE0 | TMEI<br>E |

| Bit     | Name     | Access | Description                                       | Reset value |  |  |  |  |  |
|---------|----------|--------|---------------------------------------------------|-------------|--|--|--|--|--|
| [31:18] | Reserved | RO     | Reserved                                          | 0           |  |  |  |  |  |
|         |          |        | Sleep interrupt enable.                           |             |  |  |  |  |  |
| 17      |          |        | 0: No interrupt is generated when entering        |             |  |  |  |  |  |
|         | SLKIE    | RW     | sleep state;                                      | 0           |  |  |  |  |  |
|         |          |        | 1: When entering the sleep state, an interrupt is |             |  |  |  |  |  |
|         |          |        | generated.                                        |             |  |  |  |  |  |
|         |          |        | Wake-up interrupt enable.                         |             |  |  |  |  |  |
|         |          |        | 0: No interrupt is generated when the CAN         |             |  |  |  |  |  |
| 16      | WKUIE    | RW     | controller wakes up;                              | 0           |  |  |  |  |  |
|         |          |        | 1: When the CAN controller is woken up, an        |             |  |  |  |  |  |
|         |          |        | interrupt is generated.                           |             |  |  |  |  |  |
|         |          |        | Error interrupt enable, CAN error interrupt       |             |  |  |  |  |  |
|         |          |        | always enable.                                    |             |  |  |  |  |  |
| 15      | ERRIE    | RW     | 0: No interrupt is generated when the CAN         | 0           |  |  |  |  |  |
| 13      | ERRICE   | 1000   | controller generates an error;                    |             |  |  |  |  |  |
|         |          |        | 1: When the CAN controller generates an error,    |             |  |  |  |  |  |
|         |          |        | an interrupt is generated.                        |             |  |  |  |  |  |
| [14:12] | Reserved | RF     | Reserved.                                         | 0           |  |  |  |  |  |
|         |          |        | Last error number interrupt enable.               |             |  |  |  |  |  |
|         |          |        | 0: When an error is detected, the hardware        |             |  |  |  |  |  |
|         | LECIE    |        | updates LEC[2:0], does not update the ERRI        |             |  |  |  |  |  |
| 11      |          | RW     | bit, and does not trigger an error interrupt;     | 0           |  |  |  |  |  |
|         |          |        | 1: When an error is detected, the hardware        |             |  |  |  |  |  |
|         |          |        | updates LEC[2:0], updates the ERRI bit to 1,      |             |  |  |  |  |  |
|         |          |        | and triggers an error interrupt.                  |             |  |  |  |  |  |
|         |          |        | Offline interrupt enable.                         |             |  |  |  |  |  |
|         |          |        | 0: When entering the offline state, the ERRI bit  |             |  |  |  |  |  |
| 10      | BOFIE    | RW     | will not be updated, and the error interrupt will | 0           |  |  |  |  |  |
|         | 20112    | 10     | not be triggered;                                 |             |  |  |  |  |  |
|         |          |        | 1: When entering the offline state, update the    |             |  |  |  |  |  |
|         |          |        | ERRI bit to 1, triggering an error interrupt.     |             |  |  |  |  |  |
|         |          |        | Error passive interrupt enable.                   |             |  |  |  |  |  |
|         |          |        | 0: When entering the error passive state, the     |             |  |  |  |  |  |
| 9       | EPVIE    | RW     | ERRI bit is not updated and the error interrupt   | 0           |  |  |  |  |  |
| ,       |          |        | is not triggered;                                 |             |  |  |  |  |  |
|         |          |        | 1: When entering the error passive state, update  | 1           |  |  |  |  |  |
|         |          |        | the ERRI bit to 1, triggering an error interrupt. |             |  |  |  |  |  |
|         |          |        | Error warning interrupt enable.                   |             |  |  |  |  |  |
| 8       | EWGIE    | RW     | 0: When the number of errors reaches the          | 0           |  |  |  |  |  |
|         |          |        | warning threshold, the ERRI bit will not be       |             |  |  |  |  |  |
|         |          |        | updated, and the error interrupt will not be      |             |  |  |  |  |  |

|                                       |            |       | triggered;                                                |   |
|---------------------------------------|------------|-------|-----------------------------------------------------------|---|
|                                       |            |       | 1: When the number of errors reaches the                  |   |
|                                       |            |       | warning threshold, update the ERRI bit to 1,              |   |
|                                       |            |       | triggering an error interrupt.                            |   |
| 7                                     | Reserved   | RF    | Reserved                                                  | 0 |
| , , , , , , , , , , , , , , , , , , , | 1100011100 | 142   | Receive FIFO 1 overflow interrupt enable.                 |   |
|                                       |            |       | 0: When FIFO 1 overflows, do not trigger                  |   |
| 6                                     | FOVIE1     | RW    | FIFO 1 interrupt;                                         | 0 |
|                                       | TOVILI     | IXVV  | 1: When FIFO 1 overflows, trigger FIFO 1                  | V |
|                                       |            |       | interrupt.                                                |   |
|                                       |            |       | Receive FIFO 1 full interrupt enable.                     |   |
|                                       |            |       | 0: When FIFO 1 is full, do not trigger FIFO 1             |   |
| 5                                     | FFIE1      | RW    |                                                           | 0 |
| 3                                     | TTIEI      | IX VV | interrupt; 1: When FIFO 1 is full, trigger FIFO 1         | U |
|                                       |            |       |                                                           |   |
|                                       |            |       | interrupt.  Receive FIFO 1 message registration interrupt |   |
|                                       |            |       | enable.                                                   |   |
|                                       |            |       |                                                           |   |
| 4                                     | FMPIE1     | RW    | 0: When FIFO_1 updates the FMP bit, and it is             | 0 |
|                                       |            |       | not 0, the FIFO_1 interrupt is not triggered;             |   |
|                                       |            |       | 1: When FIFO_1 updates the FMP bit and is not             |   |
|                                       |            |       | 0, trigger FIFO_1 interrupt.                              |   |
|                                       |            |       | Receive FIFO_0 overflow interrupt enable.                 |   |
| 3                                     | EOMEO      | DW    | 0: When FIFO_0 overflows, not trigger                     | 0 |
| 3                                     | FOVIE0     | RW    | FIFO_0 interrupt;                                         | U |
|                                       |            |       | 1: When FIFO_0 overflows, trigger FIFO_0                  |   |
|                                       |            |       | interrupt.                                                |   |
|                                       |            |       | Receive FIFO_0 full interrupt enable.                     |   |
|                                       | EFIEO      | DW    | 0: When FIFO_0 is full, not trigger FIFO_0                | 0 |
| 2                                     | FFIE0      | RW    | interrupt;                                                | 0 |
|                                       |            |       | 1: When FIFO_0 is full, trigger FIFO_0                    |   |
|                                       |            |       | interrupt.                                                |   |
|                                       |            |       | Receive FIFO_0 message registration interrupt             |   |
|                                       |            |       | enable.                                                   |   |
| 1                                     | FMPIE0     | RW    | 0: When FIFO_0 updates the FMP bit, and it is             | 0 |
|                                       |            |       | not 0, the FIFO_0 interrupt is not triggered;             |   |
|                                       |            |       | 1: When FIFO_0 updates the FMP bit and is not             |   |
|                                       |            |       | 0, trigger FIFO_0 interrupt.                              |   |
|                                       |            |       | Tx mailbox empty interrupt.                               |   |
|                                       | TMEIE      | D117  | 0: No interrupt is generated when the Tx                  | 0 |
| 0                                     |            | RW :  | mailbox is empty;                                         | 0 |
|                                       |            |       | 1: When the Tx mailbox is empty, an interrupt             |   |
|                                       |            |       | is generated.                                             |   |

# 24.7.7 CANx Error Status Register (CANx\_ERRSR) (x=1/2)

Offset Address: 0x18

| 31 | 30       | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22       | 21     | 20 | 19           | 18   | 17   | 16       |  |
|----|----------|----|----|----|----|----|----|----|----------|--------|----|--------------|------|------|----------|--|
|    | REC[7:0] |    |    |    |    |    |    |    | TEC[7:0] |        |    |              |      |      |          |  |
| 15 | 14       | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6        | 5      | 4  | 3            | 2    | 1    | 0        |  |
|    | Reserved |    |    |    |    |    |    |    | I        | EC[2:0 | )] | Reser<br>ved | BOFF | EPVF | EWG<br>F |  |

| Bit     | Name      | Access | Description                                        | Reset value |
|---------|-----------|--------|----------------------------------------------------|-------------|
|         |           |        | Receive error counter.                             |             |
|         |           |        | When the CAN receives an error, according to       |             |
|         |           |        | the error condition, the counter is incremented    |             |
| [31:24] | REC[7:0]  | RO     | by 1 or 8; after successful reception, the         | 0           |
|         | TELO[,.0] | RO     | counter is decreased by 1 or set to 120 (the error | v           |
|         |           |        | count value is greater than 127). When the         |             |
|         |           |        | counter value exceeds 127, the CAN enters the      |             |
|         |           |        | error passive state.                               |             |
|         |           |        | Transmit error counter.                            |             |
|         |           |        | When the CAN sends an error, according to the      |             |
|         |           |        | error condition, the counter is incremented by     |             |
| [23:16] | TEC[7:0]  | RO     | 1 or 8; after the transmission is successful, the  | 0           |
| [23.10] | 110[7.0]  | RO     | counter is decremented by 1 or set to 120 (the     | V           |
|         |           |        | error count value is greater than 127). When the   |             |
|         |           |        | counter value exceeds 127, the CAN enters the      |             |
|         |           |        | error passive state.                               |             |
| [15:7]  | Reserved  | RO     | Reserved                                           | 0           |
|         |           |        | Last error code.                                   |             |
|         |           |        | When detecting the sending error on the CAN        |             |
|         |           |        | bus, the controller will set according to the      |             |
|         |           |        | error condition, and set 000b when sending and     |             |
|         |           |        | receiving the message correctly.                   |             |
|         |           |        | 000: no error;                                     |             |
|         |           |        | 001: Bit stuffing error;                           |             |
| [6:4]   | LEC[2:0]  | RW     | 010: FORM format error;                            | 0           |
| [0.4]   | LEC[2.0]  | IX VV  | 011: ACK confirmation error;                       | U           |
|         |           |        | 100: recessive bit error;                          |             |
|         |           |        | 101: Dominant bit error;                           |             |
|         |           |        | 110: CRC error;                                    |             |
|         |           |        | 111: Software settings.                            |             |
|         |           |        | Usually when the application software reads        |             |
|         |           |        | the error, the code name is set to 111b, and the   |             |
|         |           |        | code name update can be detected.                  |             |
| 3       | Reserved  | RO     | Reserved                                           | 0           |
|         |           |        | Offline status flag.                               |             |
| 2       | DOEE      | PO.    | When the CAN controller enters the offline         | 0           |
|         | BOFF      | RO     | state, the hardware automatically sets it to 1;    | U           |
|         |           |        | when it exits the offline state, the hardware      |             |

|   |        |    | automatically clears it to 0.                   |   |  |  |  |
|---|--------|----|-------------------------------------------------|---|--|--|--|
|   |        |    | Error passive flag.                             |   |  |  |  |
| 1 | EDVE   | RO | When the transceiver error counter reaches the  |   |  |  |  |
| 1 | 1 EPVF |    | error passive threshold, that is, greater than  | 0 |  |  |  |
|   |        |    | 127, the hardware is set to 1.                  |   |  |  |  |
|   |        |    | Error warning flag bit.                         |   |  |  |  |
|   | EWGF   | RO | When the sending and receiving error counter    | 0 |  |  |  |
| 0 | EWGF   | KO | reaches the warning threshold, that is, greater | U |  |  |  |
|   |        |    | than or equal to 96, the hardware is set to 1.  |   |  |  |  |

# 24.7.8 CANx Bit Timing Register (CANx\_BTIMR) (x=1/2)

Offset address: 0x1C

| 31       | 30   | 29 | 28   | 27    | 26 | 25  | 24    | 23           | 22       | 21  | 20    | 19       | 18 | 17 | 16 |
|----------|------|----|------|-------|----|-----|-------|--------------|----------|-----|-------|----------|----|----|----|
| SILM     | LBKM |    | Rese | erved |    | SJW | [1:0] | Reser<br>ved | TS2[2:0] |     |       | TS1[3:0] |    |    |    |
| 15       | 14   | 13 | 12   | 11    | 10 | 9   | 8     | 7            | 6        | 5   | 4     | 3        | 2  | 1  | 0  |
| Reserved |      |    |      |       |    |     |       |              |          | BRP | [9:0] |          |    |    |    |

| Bit     | Name     | Access                 | Description                                     | Reset value |  |  |  |  |  |  |
|---------|----------|------------------------|-------------------------------------------------|-------------|--|--|--|--|--|--|
|         |          |                        | Silent mode setting.                            |             |  |  |  |  |  |  |
| 31      | SILM     | RW                     | 0: Exit silent mode;                            | 0           |  |  |  |  |  |  |
|         |          |                        | 1: Enter silent mode.                           |             |  |  |  |  |  |  |
|         |          | Loopback mode setting. |                                                 |             |  |  |  |  |  |  |
| 30      | LBKM     | RW                     | 0: Exit loopback mode;                          | 0           |  |  |  |  |  |  |
|         |          |                        | 1: Enter loopback mode.                         |             |  |  |  |  |  |  |
| [29:26] | Reserved | RO                     | Reserved                                        | 0           |  |  |  |  |  |  |
|         |          |                        | Defines the resync jump width setting value.    |             |  |  |  |  |  |  |
|         |          |                        | When implementing resynchronization, the        |             |  |  |  |  |  |  |
| [25,24] | CIW[1.0] | RW                     | upper limit of the minimum number of time       | 01b         |  |  |  |  |  |  |
| [25:24] | SJW[1:0] | KVV                    | units that can be extended and reduced in the   | 010         |  |  |  |  |  |  |
|         |          |                        | bit, the actual value is (SJW[1:0]+1), and the  |             |  |  |  |  |  |  |
|         |          |                        | range can be set to 1 to 4 minimum time units.  |             |  |  |  |  |  |  |
| 23      | Reserved | RO                     | Reserved                                        | 0           |  |  |  |  |  |  |
|         |          |                        | Time period 2 set value.                        |             |  |  |  |  |  |  |
| [22:20] | TS2[2:0] | RW                     | It defines how many minimum time units are      | 010b        |  |  |  |  |  |  |
| [22.20] | 132[2.0] | IX VV                  | occupied by time period 2, and the actual value | 0100        |  |  |  |  |  |  |
|         |          |                        | is (TS2[2:0]+1).                                |             |  |  |  |  |  |  |
|         |          |                        | Time period 1 set value.                        |             |  |  |  |  |  |  |
| [19:16] | TS1[3:0] | RW                     | It defines how many minimum time units are      | 0011b       |  |  |  |  |  |  |
| [17.10] | 151[5.0] | IX VV                  | occupied by time period 1, and the actual value | 00110       |  |  |  |  |  |  |
|         |          |                        | is (TS1[3:0]+1).                                |             |  |  |  |  |  |  |
| [15:10] | Reserved | RO                     | Reserved.                                       | 0           |  |  |  |  |  |  |
|         |          |                        | Minimum time unit length setting valueTq =      |             |  |  |  |  |  |  |
| [9:0]   | BRP[9:0] | RW                     | $(BRP[9:0]+1) \times t_{pelk}$                  | 0           |  |  |  |  |  |  |
|         |          |                        | Note: The CAN baud rate is calculated by the    |             |  |  |  |  |  |  |

|  | following formula:                   |  |
|--|--------------------------------------|--|
|  | CANbps=PCLK1/((TSI[3:0]+1+TS2[2:0]+1 |  |
|  | +1)*(BPR[9:0]+1))                    |  |

# 24.7.9 CANx Time Trigger Control Register (CANx\_TTCTLR) (x=1/2)

Offset address: 0x20

| 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24   | 23      | 22 | 21 | 20 | 19       | 18         | 17 | 16 |
|----------|----|----|----|----|----|----|------|---------|----|----|----|----------|------------|----|----|
| Reserved |    |    |    |    |    |    |      |         |    |    |    | MOD<br>E | TIMR<br>ST |    |    |
| 15       | 14 | 13 | 12 | 11 | 10 | 9  | 8    | 7       | 6  | 5  | 4  | 3        | 2          | 1  | 0  |
|          |    |    |    |    |    | Τ  | IMCM | IV[15:0 | )] |    |    |          |            |    |    |

| Bit     | Name         | Access | Description                                | Reset value |  |
|---------|--------------|--------|--------------------------------------------|-------------|--|
| [31:18] | Reserved     | RO     | Reserved                                   | 0           |  |
|         |              |        | Time-triggered mode selection.             |             |  |
| 17      | MODE         | RW     | 0: Default mode;                           | 0           |  |
|         |              |        | 1: Enhanced mode.                          | <u> </u>    |  |
|         |              |        | Internal counter reset control.            |             |  |
| 16      | TIMRST       | WZ     | Write 1 to reset the internal counter, the | 0           |  |
|         |              |        | hardware will automatically clear 0        |             |  |
| [15:0]  | TIMCMV[15:0] | RW     | Internal counter count end value           | ffffh       |  |

# 24.7.10 CANx Time Trigger Count Value Register (CANx\_TTCNT) (x=1/2)

Offset address: 0x24

| _31 | 30           | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-----|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|     | Reserved     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15  | 14           | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|     | TIMCNT[15:0] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit     | Name         | Access | Description                | Reset value |
|---------|--------------|--------|----------------------------|-------------|
| [31:16] | Reserved     | RO     | Reserve.                   | 0           |
| [15:0]  | TIMCNT[15:0] | RW     | time-triggered count value | 0           |

# 24.7.11 CANx Tx Mailbox Identifier Register (CANx\_TXMIRy) (x=1/2, y=0/1/2)

Offset address: 0x180, 0x190, 0x1A0

| 31         | 30                     | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20  | 19          | 18       | 17 | 16 |  |
|------------|------------------------|----|----|----|----|----|----|----|----|----|-----|-------------|----------|----|----|--|
|            | STID[10:0]/EXID[28:18] |    |    |    |    |    |    |    |    |    |     | EXID[17:13] |          |    |    |  |
| 15         | 14                     | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4   | 3           | 2        | 1  | 0  |  |
| EXID[12:0] |                        |    |    |    |    |    |    |    |    |    | IDE | RTR         | TXR<br>Q |    |    |  |

| Bit     | Name              | Access | Description                                 | Reset value |
|---------|-------------------|--------|---------------------------------------------|-------------|
| [31:21] | STID[10:0]/EXID[2 | RW     | The upper 11 bits of a standard or extended | X           |

|        | 8:18]      |    | identifier.                                     |   |
|--------|------------|----|-------------------------------------------------|---|
| [20:3] | EXID[17:0] | RW | The lower 18 bits of the extended identifier.   | X |
|        |            |    | Identifier selection flag.                      |   |
| 2      | IDE        | RW | 0: Standard identifiers;                        | X |
|        |            |    | 1: Extended identifier.                         |   |
|        |            |    | Remote frame selection flag.                    |   |
| 1      | RTR        | RW | 0: Data frame;                                  | X |
|        |            |    | 1: Remote frame.                                |   |
|        |            |    | Data transmission request flag.                 |   |
|        |            |    | When the software is set to 1, the data in the  |   |
| 0      | TXRQ       | RW | mailbox is requested to be sent. When the       | 0 |
|        |            |    | mailbox is empty after sending, the hardware is |   |
|        |            |    | cleared to 0.                                   |   |

# 24.7.12 CANx Tx Mailbox Data Length and Timestamp Register (CANx\_TXMDTRy) (x=1/2, y=0/1/2)

Offset address: 0x184, 0x194, 0x1A4

| 31 | 30         | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19  | 18 | 17 | 16 |
|----|------------|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|
|    | TIME[15:0] |    |    |    |    |    |    |    |    |    |    |     |    |    |    |
| 15 | 14         | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3   | 2  | 1  | 0  |
| ļ  | Reserved   |    |    |    |    |    |    |    |    |    |    | DLC |    | "  |    |

| Bit     | Name       | Access | Description                                                                                                                                                                                                                                                                    | Reset value |
|---------|------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:16] | TIME[15:0] | RW     | The 16-bit timer value used to send the message SOF time.                                                                                                                                                                                                                      | X           |
| [15:9]  | Reserved   | RO     | Reserved                                                                                                                                                                                                                                                                       | X           |
| 8       | TGT        | RW     | Message timestamp transmission selection flag. This bit is valid when TTCM is set to 1 and the message length is 8.  0: No timestamp is transmitted;  1: Transmit timestamp, the value is the immediate value of TIME[15:0], replacing the last 2 bytes of the 8-byte message. | X           |
| [7:4]   | Reserved   | RO     | Reserved                                                                                                                                                                                                                                                                       | X           |
| [3:0]   | DLC[3:0]   | RW     | Data length of data frame or remote frame request data length  The data length can be set from 0 to 8.                                                                                                                                                                         | X           |

### 24.7.13 CANx Tx Mailbox Data Low Register (CANx\_TXMDLRy) (x=1/2, y=0/1/2)

Offset address: 0x188, 0x198, 0x1A8

| 31 | 30         | 29 | 28   | 27     | 26 | 25 | 24 | 23         | 22 | 21 | 20   | 19     | 18 | 17 | 16 |
|----|------------|----|------|--------|----|----|----|------------|----|----|------|--------|----|----|----|
|    |            |    | DATA | 3[7:0] |    |    |    | DATA2[7:0] |    |    |      |        |    |    |    |
| 15 | 14         | 13 | 12   | 11     | 10 | 9  | 8  | 7          | 6  | 5  | 4    | 3      | 2  | 1  | 0  |
|    | DATA1[7:0] |    |      |        |    |    |    |            |    |    | DATA | 0[7:0] |    |    |    |

| Bit     | Name       | Access | Description                          | Reset value |
|---------|------------|--------|--------------------------------------|-------------|
| [31:24] | DATA3[7:0] | RW     | Transmit the content of data byte 3. | X           |
| [23:16] | DATA2[7:0] | RW     | Transmit the content of data byte 2. | X           |
| [15:8]  | DATA1[7:0] | RW     | Transmit the content of data byte 1. | X           |
| [7:0]   | DATA0[7:0] | RW     | Transmit the content of data byte 0. | X           |

# 24.7.14 CANx Tx Mailbox Data High Register (CANx\_TXMDHRy) (x=1/2, y=0/1/2)

Offset address: 0x18C, 0x19C, 0x1AC

| 31 | 30         | 29 | 28   | 27     | 26 | 25 | 24 | 23 | 22 | 21 | 20   | 19      | 18 | 17 | 16 |
|----|------------|----|------|--------|----|----|----|----|----|----|------|---------|----|----|----|
|    |            |    | DATA | 7[7:0] |    |    |    |    |    |    | DATA | .6[7:0] |    |    |    |
| 15 | 14         | 13 | 12   | 11     | 10 | 9  | 8  | 7  | 6  | 5  | 4    | 3       | 2  | 1  | 0  |
|    | DATA5[7:0] |    |      |        |    |    |    |    |    |    | DATA | 4[7:0]  |    |    |    |

| Bit     | Name       | Access | Description                      | Reset value |
|---------|------------|--------|----------------------------------|-------------|
| [31:24] | DATA7[7:0] | RW     | Send the content of data byte 7. | X           |
| [23:16] | DATA6[7:0] | RW     | Send the content of data byte 6. | X           |
| [15:8]  | DATA5[7:0] | RW     | Send the content of data byte 5. | X           |
| [7:0]   | DATA4[7:0] | RW     | Send the content of data byte 4. | X           |

### 24.7.15 CANx Rx Mailbox Identifier Register (CANx\_RXMIRy) (x=1/2, y=0/1)

Offset address: 0x1B0, 0x1C0

| 31 | 30                     | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20  | 19  | 18       | 17  | 16 |
|----|------------------------|----|----|----|----|----|----|----|----|----|-----|-----|----------|-----|----|
|    | STID[10:0]/EXID[28:18] |    |    |    |    |    |    |    |    |    |     | EX  | ID[17:   | 13] |    |
| 15 | 14                     | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4   | 3   | 2        | 1   | 0  |
|    | EXID[12:0]             |    |    |    |    |    |    |    |    |    | IDE | RTR | TXR<br>Q |     |    |

| Bit     | Name                       | Access | Description                                                  | Reset value |
|---------|----------------------------|--------|--------------------------------------------------------------|-------------|
| [31:21] | STID[10:0]<br>/EXID[28:18] | RO     | The upper 11 bits of a standard or extended identifier.      | X           |
| [20:3]  | EXIDL[17:0]                | RO     | The lower 18 bits of the extended identifier.                | X           |
|         | IDE                        | D.O.   | Identifier selection flag.                                   | 37          |
| 2       | IDE                        | RO     | Select standard identifiers;     Select extended identifier. | X           |
| 1       | RTR                        | RO     | Remote frame selection flag.                                 | X           |

| Ī |   |          | 0: Data frame; |                  |   |
|---|---|----------|----------------|------------------|---|
|   |   |          |                | 1: Remote frame. |   |
| I | 0 | Reserved | RO             | Reserved         | X |

# 24.7.16 CANx Rx Mailbox Data Length and Timestamp Register (CANx\_RXMDTRy) (x=1/2, y=0/1)

Offset address: 0x1B4, 0x1C4

| 31 | 30         | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22    | 21 | 20 | 19  | 18    | 17 | 16 |
|----|------------|----|----|----|----|----|----|------|-------|----|----|-----|-------|----|----|
|    | TIME[15:0] |    |    |    |    |    |    |      |       |    |    |     |       |    |    |
| 15 | 14         | 13 | 12 | 11 | 10 | 9  | 8  | 7    | 6     | 5  | 4  | 3   | 2     | 1  | 0  |
|    | FMI[7:0]   |    |    |    |    |    |    | Rese | erved |    |    | DLC | [3:0] |    |    |

| Bit     | Name       | Access | Description                                                                                | Reset value |
|---------|------------|--------|--------------------------------------------------------------------------------------------|-------------|
| [31:16] | TIME[15:0] | RO     | 16-bit timer value used to receive the SOF time of the message.                            | X           |
| [15:8]  | FMI[7:0]   | RO     | The filter number matched by the packet.                                                   | X           |
| [7:4]   | Reserved   | RO     | Reserved                                                                                   | X           |
| [3:0]   | DLC[3:0]   | RO     | Received message data length.  The data frame length is 0 to 8, and the remote frame is 0. | X           |

### 24.7.17 CANx Rx Mailbox Data Low Register (CANx\_RXMDLRy) (x=1/2, y=0/1)

Offset address: 0x1B8, 0x1C8

| 31 | 30         | 29 | 28   | 27     | 26 | 25 | 24 | 23 | 22         | 21 | 20   | 19     | 18 | 17 | 16 |  |
|----|------------|----|------|--------|----|----|----|----|------------|----|------|--------|----|----|----|--|
|    | DATA3[7:0] |    |      |        |    |    |    |    | DATA2[7:0] |    |      |        |    |    |    |  |
| 15 | 14         | 13 | 12   | 11     | 10 | 9  | 8  | 7  | 6          | 5  | 4    | 3      | 2  | 1  | 0  |  |
|    |            |    | DATA | 1[7:0] |    |    |    |    |            |    | DATA | 0[7:0] |    |    |    |  |

| Bit     | Name       | Access | Description                          | Reset value |
|---------|------------|--------|--------------------------------------|-------------|
| [31:24] | DATA3[7:0] | RO     | Data byte 3 of the received message. | X           |
| [23:16] | DATA2[7:0] | RO     | Data byte 2 of the received message. | X           |
| [15:8]  | DATA1[7:0] | RO     | Data byte 1 of the received message. | X           |
| [7:0]   | DATA0[7:0] | RO     | Data byte 0 of the received message. | X           |

# 24.7.18 CANx Rx Mailbox Data High Register (CANx\_RXMDHRy) (x=1/2, y=0/1)

Offset address: 0x1BC, 0x1CC

| 31 | 30         | 29 | 28   | 27     | 26 | 25 | 24 | 23 | 22 | 21 | 20   | 19      | 18 | 17 | 16 |
|----|------------|----|------|--------|----|----|----|----|----|----|------|---------|----|----|----|
|    | DATA7[7:0] |    |      |        |    |    |    |    |    |    | DATA | .6[7:0] |    |    |    |
| 15 | 14         | 13 | 12   | 11     | 10 | 9  | 8  | 7  | 6  | 5  | 4    | 3       | 2  | 1  | 0  |
|    |            |    | DATA | 5[7:0] |    |    |    |    |    |    | DATA | 4[7:0]  |    |    |    |

| Bit Name | Access | Description | Reset value |
|----------|--------|-------------|-------------|
|----------|--------|-------------|-------------|

| [31:24] | DATA7[7:0] | RO | Data byte 7 of the received message. | X |
|---------|------------|----|--------------------------------------|---|
| [23:16] | DATA6[7:0] | RO | Data byte 6 of the received message. | X |
| [15:8]  | DATA5[7:0] | RO | Data byte 5 of the received message. | X |
| [7:0]   | DATA4[7:0] | RO | Data byte 4 of the received message. | X |

# 24.7.19 CANx Filter Control Register (CANx\_FCTLR) (x=1/2)

Offset address: 0x200

| 31                   | 30 | 29 | 28 | 27 | 26 | 25 | 24   | 23    | 22      | 21 | 20 | 19 | 18        | 17 | 16 |
|----------------------|----|----|----|----|----|----|------|-------|---------|----|----|----|-----------|----|----|
|                      |    |    |    |    |    |    | Rese | erved |         |    |    |    |           |    |    |
| 15                   | 14 | 13 | 12 | 11 | 10 | 9  | 8    | 7     | 6       | 5  | 4  | 3  | 2         | 1  | 0  |
| Reserved CAN2SB[5:0] |    |    |    |    |    |    |      | I     | Reserve | d  |    |    | FINI<br>T |    |    |

| Bit     | Name Access |    | Description                                         | Reset value |
|---------|-------------|----|-----------------------------------------------------|-------------|
| [31:14] | Reserved    | RO | Reserved                                            | Reset value |
| [13:8]  | CAN2SB[5:0] | RW | CAN2 filter start bank (Value ranges from 1 to 27). | 01110b      |
| [7:1]   | Reserved    | RO | Reserved                                            | Reset value |
|         |             |    | Filter initialization mode enable flag.             |             |
| 0       | FINIT       | RW | 0: Filter bank is in normal mode;                   | 1           |
|         |             |    | 1: Filter bank is in initialization mode.           |             |

# 24.7.20 CANx Filter Mode Register (CANx\_FMCFGR) (x=1/2)

Offset address: 0x204

| 31 | 30   | 29    | 28 | _27       | 26        | 25        | 24        | 23        | 22        | 21        | 20        | 19        | 18        | 17        | 16        |
|----|------|-------|----|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|
|    | Rese | erved |    | FBM<br>27 | FBM<br>26 | FBM<br>25 | FBM<br>24 | FBM<br>23 | FBM<br>22 | FBM<br>21 | FBM<br>20 | FBM<br>19 | FBM<br>18 | FBM<br>17 | FBM<br>16 |
|    |      |       |    |           |           |           |           |           |           |           |           |           |           |           |           |
| 15 | 14   | 13    | 12 | 11        | 10        | 9         | 8         | 7         | 6         | 5         | 4         | 3         | 2         | 1         | 0         |

| Bit     | Name     | Access | Description                                                                                                                                                                                      | Reset value |
|---------|----------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:28] | Reserved | RO     | Reserved                                                                                                                                                                                         | 0           |
| [27:0]  | FBMx     | RW     | Working mode control of filter bank x. Only can be written when FINIT is 1.  0: The register of filter bank x is in mask bit mode;  1: The register of filter bank x is in identifier list mode. | 0000000h    |

Note: CAN1 uses bits [13:0], CAN2 uses bits [27:14].

### 24.7.21 CANx Filter Bit Width Register (CANx\_FSCFGR) (x=0/1)

Offset address: 0x20C

|           | Rese      | erved |      | FSC2<br>7 | FSC2<br>6 | FSC2<br>5 | FSC2<br>4 | FSC2 | FSC2<br>2 | FSC2 | FSC2<br>0 | FSC1<br>9 | FSC1<br>8 | FSC1<br>7 | FSC1<br>6 |
|-----------|-----------|-------|------|-----------|-----------|-----------|-----------|------|-----------|------|-----------|-----------|-----------|-----------|-----------|
| 15        | 14        | 13    | 12   | 11        | 10        | 9         | 8         | 7    | 6         | 5    | 4         | 3         | 2         | 1         | 0         |
| FSC1<br>5 | FSC1<br>4 | FSC1  | FSC1 | FSC1      | FSC1<br>0 | FSC9      | FSC8      | FSC7 | FSC6      | FSC5 | FSC4      | FSC3      | FSC2      | FSC1      | FSC0      |

| Bit     | Name             | Access | Description                                          | Reset value |
|---------|------------------|--------|------------------------------------------------------|-------------|
| [31:28] | Reserved         | RO     | Reserved                                             | 0           |
|         |                  |        | Bit width control bit of filter bank x. Only can be  |             |
| [27.0]  | ECC <sub>v</sub> | RW     | written when FINT is 1.                              | 0           |
| [27:0]  | [27:0] FSCx      | KW     | 0: The register of filter bank x is 2 16-bit;        | U           |
|         |                  |        | 1: The register of filter bank x is a single 32-bit. |             |

Note: CAN1 uses bits [13:0], CAN2 uses bits [27:14].

# 24.7.22 CANx Filter FIFO Association Register (CANx\_FAFIFOR) (x=1/2)

Offset address: 0x214

| 31    | 30    | 29    | 28    | 27        | 26        | 25        | 24        | 23   | 22        | 21        | 20        | 19        | 18        | 17        | 16        |
|-------|-------|-------|-------|-----------|-----------|-----------|-----------|------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|
|       | Rese  | erved |       | FFA2<br>7 | FFA2<br>6 | FFA2<br>5 | FFA2<br>4 | FFA2 | FFA2<br>2 | FFA2<br>1 | FFA2<br>0 | FFA1<br>9 | FFA1<br>8 | FFA1<br>7 | FFA1<br>6 |
| 15    | 14    | 13    | 12    | 11        | 10        | 9         | 8         | 7    | 6         | 5         | 4         | 3         | 2         | 1         | 0         |
| FFA15 | FFA14 | FFA13 | FFA12 | FFA11     | FFA10     | FFA9      | FFA8      | FFA7 | FFA6      | FFA5      | FFA4      | FFA3      | FFA2      | FFA1      | FFA0      |

| Bit     | Name     | Access | Description                                                                                                                                                          | Reset value |
|---------|----------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:28] | Reserved | RO     | Reserved                                                                                                                                                             | 0           |
| [27:0]  | FFAx     | RW     | Associated FIFO control of filter bank x. Only can be written when FINIT is 1.  0: Filter bank x is associated to FIFO_0;  1: Filter bank x is associated to FIFO_1. | 0           |

Note: CAN1 uses bits [13:0], CAN2 uses bits [27:14].

### 24.7.23 CANx Filter Activation Register (CANx\_FWR) (x=1/2)

Offset address: 0x21C

| 31         | 30         | 29         | 28         | 27         | 26         | 25         | 24         | 23         | 22         | 21         | 20         | 19         | 18         | 17         | 16         |
|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|
|            | Rese       | erved      |            | FACT<br>27 | FACT<br>26 | FACT<br>25 | FACT<br>24 | FACT<br>23 | FACT<br>22 | FACT<br>21 | FACT<br>20 | FACT<br>19 | FACT<br>18 | FACT<br>17 | FACT<br>16 |
| 15         | 14         | 13         | 12         | 11         | 10         | 9          | 8          | 7          | 6          | 5          | 4          | 3          | 2          | 1          | 0          |
| FACT<br>15 | FACT<br>14 | FACT<br>13 | FACT<br>12 | FACT<br>11 | FACT<br>10 | FACT<br>9  | FACT<br>8  | FACT<br>7  | FACT<br>6  | FACT<br>5  | FACT<br>4  | FACT<br>3  | FACT<br>2  | FACT<br>1  | FACT<br>0  |

| Bit     | Name     | Access | Description                                                                                 | Reset value |
|---------|----------|--------|---------------------------------------------------------------------------------------------|-------------|
| [31:28] | Reserved | RO     | Reserved                                                                                    | 0           |
| [27:0]  | FACTx    | RW     | Filter bank x activation control bit.  0: Filter bank x disabled;  1: Filter bank x active. | 0           |

Note: CAN1 uses bits [13:0], CAN2 uses bits [27:14].

# 24.7.24 CANx Filter Register for Filter Bank (CANx\_FiRy) (x=1, i=0-27, y=1/2)

Offset address: 0x240 to 0x31C

| 31   | 30   | 29   | 28   | 27   | 26   | 25   | 24   | 23   | 22   | 21   | 20   | 19   | 18   | 17   | 16   |
|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|
| FB31 | FB30 | FB29 | FB28 | FB27 | FB26 | FB25 | FB24 | FB23 | FB22 | FB21 | FB20 | FB19 | FB18 | FB17 | FB16 |
| 15   | 14   | 13   | 12   | 11   | 10   | 9    | 8    | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| FB15 | FB14 | FB13 | FB12 | FB11 | FB10 | FB9  | FB8  | FB7  | FB6  | FB5  | FB4  | FB3  | FB2  | FB1  | FB0  |

| Bit    | Name | Access | Description                                                                                                                                                                                                                                                                                                                                                                                           | Reset value |
|--------|------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:0] | FB   | WO     | Register flag bit in the filter bank. Only can be written when FINIT is 1.  In identifier mode:  0: Expected level of the corresponding bit is a dominant bit;  1: Expected level of the corresponding bit is a recessive bit.  In mask bit mode:  0: No need to be consistent with the corresponding identifier register bit;  1: Must be consistent with the corresponding identifier register bit. | 0           |

# **Chapter 25 Digital Video Port (DVP)**

This chapter applies to the whole family of CH32F20x, CH32V20x, CH32V30x and CH32V31x.

Digital Video Port (DVP), which supports the use of DVP interface timing to obtain image data streams, supports image data organized in original line and frame formats, such as YUV, RGB, etc., and also supports compressed image data such as JPEG format, which can receive high-speed parallel data stream output by external 8-bit, 10-bit and 12-bit camera modules.

#### 25.1 Main Features

- Configurable 8/10/12-bit data width mode
- Support YUV, RGB format data
- Support JPEG compression format data
- Built-in FIFO, support DMA transfer
- Support dual-buffered reception
- Support crop function
- Support continuous mode and snapshot mode

### 25.2 Functional Description

#### 25.2.1 Connected to the Sensor



- PLCK (Pixel clk): pixel clock, each clock corresponds to single pixel data (Uncompressed data). The PCLK clock output by the external DVP interface sensor supports a maximum of 96MHz.
- HSYNC (Horizontal synchronization): horizontal synchronization signal.
- VSYNC (Vertical synchronization): Frame synchronization signal.
- DATA: pixel data or compressed data, the bit width supports 8/10/12 bits.
- XCLK: The reference clock of the Sensor, which can be provided by the microcontroller or externally, generally using a crystal oscillator.
- I2C interface: The register used to configure the sensor, which can simulate the I2C timing communication through the controlled common GPIO port, or use the hardware I2C interface to operate.

V2. 4 438 WH

Table 25-1 DVP pins

| Name       | Signal Type Description |
|------------|-------------------------|
| PLCK       | Pixel clock input       |
| DATA[11:0] | Pixel data input        |
| VSYNC      | Frame sync signal input |
| HSYNC      | Line sync signal input  |

#### 25.2.2 Working Timing

There is a certain relationship between the digital signal data stream output by the commonly used DVP interface sensor module and the image size. The following is an example of image data.

As shown in Figure 25-2, the inside of the sensor is a complete image size of 3576\*1145. After internal scaling process, the final image data size output from the interface is 1920\*1080, and the image refresh rate is 25.

1920

1920

1 frame cycle

1 row cycle

1 second

1 sync

1 frame cycle

1 sync

1 frame cycle

1 row cycle = 1 frame cycle

1 row cycle = 3576 PCLK cycles

1 row cycle = 3576 PCLK cycles

25 frame cycles = 1 second

Figure 25-2 Timing description

PCLK is the transmission time of a pixel, so HSYNC is 3576 times more than PCLK. Among the 3576 pixels, only 1920 pixels are valid, and the sensor does not transmit data during the remaining 1656 pixels. VSYNC is a frame synchronization signal, so the VSYNC time is 3576\*1145 times of PCLK. Similarly, the sensor is transmitting data only during the 1920\*1080 effective pixel time. If the sensor is transmitting JPEG compressed data, the HSYNC signal may not be needed.

The relationship between DVP interface signal and image data is mainly based on the description of the selected sensor data sheet.

#### 25.2.3 RGB/YUV/JPEG Compressed Data Format Description

- RGB
  - 3 primary colors: red, green, blue
- YUV
  - The luminance signal Y, the chrominance signal U and V, Pb and Pr, Cb and Cr.
- JPEG (Joint Photographic Experts Group)

There is lossy compression, but the lost part is the part that is not easily perceptible by human vision, and the human eye is insensitive to the high-frequency information part of the computer color. Remove the visual redundant information (Spatial redundancy) and remove the redundant information of the data itself (Structural redundancy).

### 25.3 Application of Digital Video Port

#### 25.3.1 Digital Video Port Configuration Description

- 1) In the data reception of DVP, each frame of data is stored alternately by BUF0 and BUF1, starting from BUF0. For RGB and YUV data streams, the hardware resets and selects BUF0 every time the frame signal changes from an inactive level to an active level. When a line of data is full, BUF1 will be switched to realize alternate storage; for JPEG compressed data, the hardware will set the switching threshold of BUF0 and BUF1 according to the set DMA receive length.
- 2) When the data bus width is 10-bit or 12-bit, each time a data is received, the system will automatically unsigned-extend the data to 16-bit and then store it.
- 3) The R16\_DVP\_ROW\_NUM and R16\_DVP\_COL\_NUM registers must match the image size actually output by the sensor.
- 4) In video stream RGB mode, R16\_DVP\_COL\_NUM represents the number of valid PCLK cycles of 1-line data, and R16\_DVP\_ROW\_NUM represents the number of lines contained in a frame of image data; in image JPEG mode, R16\_DVP\_COL\_NUM is used to configure the DMA length, and in this mode, the R16\_DVP\_ROW\_NUM register cannot be used effectively.

#### 25.3.2 Digital Video Port Application Note

When using the digital image interface to receive image data, the DVP control registers must be correctly configured to match the mode of the image sensor. The specific operation steps are as follows:

- 1) Clear RB\_DVP\_ALL\_CLR and RB\_DVP\_RCV\_CLR using the R8\_DVP\_CR1 register.
- 2) Configure the image mode, data bit width, PCLK polarity, HSYNC polarity and VSYNC polarity through the R8\_DVP\_CR0 register to match the output of the sensor.
- 3) According to the effective image pixels output by the configured image sensor, configure the R16\_DVP\_ROW\_NUM and R16\_DVP\_COL\_NUM registers to match the output of the sensor. In the image JPEG mode, only configure the R16\_DVP\_COL\_NUM register.
- 4) Configure the DMA receive address through the R32 DVP DMA BUF0/1 register.
- 5) If the snapshot mode is used, the RB\_DVP\_CM field needs to be configured through the R8\_DVP\_CR1 register to enable the snapshot mode.
- 6) If the cropping mode is used, the RB\_DVP\_CROP and RB\_DVP\_FCRC fields need to be configured through the R8\_DVP\_CR1 register to enable the cropping function and control the frame capture rate. At the same time, configure the R16\_DVP\_HOFFCNT, R16\_DVP\_VST, R16\_DVP\_CAPCNT and R16\_DVP\_VLINE to set the size of the cropped image.

V2. 4 440 WH

- 7) According to the requirements, enable the corresponding interrupt through the R8\_DVP\_IER register, configure the interrupt priority through the interrupt controller NVIC or PFIC, and enable the DVP interrupt.
- 8) The DMA is enabled through the R8\_DVP\_CR1 register, and the DVP interface is enabled through the R8 DVP CR0 register.
- 9) Wait for the generation of the relevant receiving interrupt, and process the received data in time.

#### 25.3.3 Capture Mode Description

The DVP interface supports 2 capture modes: snapshot (Single frame) mode and continuous mode.

#### 25.3.3.1 Snapshot Mode

In this mode, only a single frame is captured (RB\_DVP\_CM is set to 1 in the R8\_DVP\_CR1 register). When the DVP interface is enabled, wait for the system to detect the start of the frame, and then start to sample the image data. After receiving a complete frame of data, the DVP interface will be turned off. (The RB\_DVP\_ENABLE field of the R8\_DVP\_CR0 register is cleared to 0). Figure 25-3 shows the single frame capture waveform in snapshot mode.

Frame 1 is captured

Frame 2 is not captured

Figure 25-3 Single frame capture waveform in Snapshot mode

#### 25.3.3.2 Continuous Mode

In this mode (RB\_DVP\_CM is cleared to 0 in the R8\_DVP\_CR1 register), after the DVP interface is enabled, each frame of data will be continuously sampled before the RB\_DVP\_ENABLE field of the R8\_DVP\_CR0 register is cleared to 0. The frame capture waveform in continuous mode is shown in Figure 25-4.



Figure 25-4 Frame capture waveform in continuous mode

#### 25.3.4 Cropping Function Description

DVP can use the crop function to cut a rectangular window from the received image. The starting coordinates

V2. 4 441 WH

of the rectangular window (X coordinate of the upper left corner of the rectangle R16\_DVP\_HOFFCNT, Y coordinate R16\_DVP\_VST) and window size (R16\_DVP\_CAPCNT represents the horizontal size, R16\_DVP\_VLINE represents the vertical size) are configurable. The coordinates and size of the cropping window are shown in Figure 25-5. The cropped window data capture waveform is shown in Figure 25-6.

Figure 25-5 Crop window coordinates and size



# 25.4 Register Description

Table 25-2 DVP registers

| Name             | Access address | Description                              | Reset value |
|------------------|----------------|------------------------------------------|-------------|
| R8_DVP_CR0       | 0x50050000     | DVP control register0                    | 0x00        |
| R8_DVP_CR1       | 0x50050001     | DVP control register1                    | 0x06        |
| R8_DVP_IER       | 0x50050002     | DVP interrupt enable register            | 0x00        |
| R16_DVP_ROW_NUM  | 0x50050004     | DVP row number configuration register    | 0x0000      |
| R16_DVP_COL_NUM  | 0x50050006     | DVP column number configuration register | 0x0000      |
| R32_DVP_DMA_BUF0 | 0x50050008     | DVP DMA address0 register                | 0x00000000  |
| R32_DVP_DMA_BUF1 | 0x5005000C     | DVP DMA address1 register                | 0x00000000  |
| R8_DVP_IFR       | 0x50050010     | DVP interrupt flag register              | 0x00        |
| R8_DVP_STATUS    | 0x50050011     | DVP receive FIFO status register         | 0x00        |
| R16_DVP_ROW_CNT  | 0x50050014     | DVP row count register                   | 0x0000      |

| R16_DVP_HOFFCNT | 0x50050018 | Horizontal displacement register for the start of the window | 0x0000     |
|-----------------|------------|--------------------------------------------------------------|------------|
| R16_DVP_VST     | 0x5005001A | Window start line number register                            | 0x0000     |
| R16_DVP_CAPCNT  | 0x5005001C | DVP capture count register                                   | 0x0000     |
| R16_DVP_VLINE   | 0x5005001E | DVP vertical line count register                             | 0x0000     |
| R32_DVP_DR      | 0x50050020 | DVP data register                                            | 0x00000000 |

# 25.4.1 DVP Control Register (R8\_DVP\_CR0)

Offset address: 0x00

| Bit   | Name               | Access | Description                                 | Reset value |  |  |
|-------|--------------------|--------|---------------------------------------------|-------------|--|--|
|       |                    |        | JPEG mode enable.                           |             |  |  |
| 6     | RB_DVP_JPEG        | RW     | 0: Raw data format;                         | 0           |  |  |
|       |                    |        | 1: JPEG compression format.                 |             |  |  |
|       |                    |        | DVP data bit width configuration.           |             |  |  |
| [5,4] | RB DVP MSK DAT MOD | RW     | 00: 8-bit mode;                             | 0           |  |  |
| [5:4] | KD_DVI_MSK_DAI_MOD | IX VV  | 01: 10-bit mode;                            | 0           |  |  |
|       |                    |        | 1x: 12-bit mode.                            |             |  |  |
|       |                    |        | PCLK polarity configuration.                |             |  |  |
| 3     | RB_DVP_P_POLAR     | RW     | 0: Sample data on the rising edge of PCLK;  | 0           |  |  |
|       |                    |        | 1: Sample data on the falling edge of PCLK. |             |  |  |
|       |                    |        | HSYNC polarity configuration.               |             |  |  |
| 2     | RB_DVP_H_POLAR     | RW     | 0: HSYNC high level data is valid;          | 0           |  |  |
|       |                    |        | 1: HSYNC low level data is valid.           |             |  |  |
|       |                    |        | VSYNC polarity configuration.               |             |  |  |
| 1     | RB_DVP_V_POLAR     | RW     | 0: VSYNC low level data is valid;           | 0           |  |  |
|       |                    |        | 1: VSYNC high level data is valid.          |             |  |  |
| 0     | RB DVP ENABLE      | DW     | DVP enable.                                 | 0           |  |  |
|       | KD_DVF_ENABLE      | RW     | 0: Disable DVP; 1: Enable DVP.              | U           |  |  |

# 25.4.2 DVP Control Register (R8\_DVP\_CR1)

Offset address: 0x01

| Bit   | Name        | Access | Description                                      | Reset value |
|-------|-------------|--------|--------------------------------------------------|-------------|
|       |             |        | DVP frame capture rate control.                  |             |
|       |             |        | 00: Capture all frames;                          |             |
| [7:6] | RB_DVP_FCRC | RW     | 01: Capture every other frame;                   | 0           |
|       |             |        | 10: Capture every third frame.                   |             |
|       |             |        | 11: Reserved                                     |             |
|       |             |        | Crop function control.                           |             |
| 5     | DD DVD CDOD | RW     | 0: Capture full image;                           | 0           |
| 3     | RB_DVP_CROP | KW     | 1: Capture only the data in the window specified | U           |
|       |             |        | by the clipping register.                        |             |
|       |             |        | Capture mode.                                    |             |
| 4     | RB_DVP_CM   | RW     | 0: Continuous mode;                              | 0           |
|       |             |        | 1: Snapshot mode.                                |             |

| 3 | RB_DVP_BUF_TOG    | RWT | Buffer address flag. Hardware control toggle, the software sets 1 to flip this bit, and writing 0 is invalid.  0: Data is stored at receive address 0; | 0 |  |
|---|-------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------|---|--|
|   |                   |     | 1: Data is stored at receive address 1.                                                                                                                |   |  |
| 2 | RB_DVP_RCV_CLR    | RW  | Receive logic reset control.  0: Cancel the reset operation;                                                                                           | 1 |  |
|   |                   |     | 1: Reset the receiving logic circuit.                                                                                                                  |   |  |
|   |                   | RW  | Flag and FIFO clear control, write 1 or write 0 by software:                                                                                           |   |  |
|   | RB_DVP_ALL_CLR    |     | 0: Cancel the reset operation;                                                                                                                         | l |  |
|   |                   |     | 1: Reset flag and FIFO.                                                                                                                                |   |  |
| 0 | RB DVP DMA ENABLE | RW  | DMA enable:                                                                                                                                            | 0 |  |
|   |                   |     | 0: Disable DMA; 1: Enable DMA.                                                                                                                         |   |  |

# 25.4.3 DVP Interrupt Enable Register (R8\_DVP\_IER)

Offset address: 0x02

| Bit   | Name               | Access | Description                                                                                                                                                                                                                                                                | Reset value |
|-------|--------------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [7:5] | Reserved           | RO     | Reserved                                                                                                                                                                                                                                                                   | -           |
| 4     | RB_DVP_IE_STP_FRM  | RW     | Frame stop interrupt enable. (Interrupt is generated when VSYNC changes from an active level to an inactive level.)  0: Disable frame stop interrupt;  1: Enable frame stop interrupt.                                                                                     | 0           |
| 3     | RB_DVP_IE_FIFO_OV  | RW     | Receive FIFO overflow interrupt enable.  0: Disable FIFO overflow interrupt;  1: Enable FIFO overflow interrupt.                                                                                                                                                           | 0           |
| 2     | RB_DVP_IE_FRM_DONE | RW     | Frame reception done interrupt enable. (Interrupt is generated when the counter reaches the ROW/COL_NUM configuration value, indicating that the last data has been written to RAM)  0: Disable frame reception done interrupt;  1: Enable frame reception done interrupt. | 0           |
| 1     | RB_DVP_IE_ROW_DONE | RW     | Row done interrupt enable. (Interrupt is generated when the counter reaches the COL_NUM configuration value)  0: Disable row done interrupt;  1: Enable row done interrupt.                                                                                                | 0           |
| 0     | RB_DVP_IE_STR_FRM  | RW     | New frame start interrupt enable. (Interrupt is generated when VSYNC changes from an inactive level to an active level, indicating that a new frame starts and data is coming.)  0: Disable new frame start interrupt;  1: Enable new frame start interrupt.               | 0           |

V2. 4 444 WCH°

# 25.4.4 DVP Row Number Configuration Register (R16\_DVP\_ROW\_NUM)

Offset address: 0x04

| Bit    | Name                 | Access | Description                                                                                                                            | Reset value |
|--------|----------------------|--------|----------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [15:0] | RB_DVP_ROW_NUM[15:0] |        | In RGB mode, it indicates the number of rows contained in a frame of image data. In JPEG mode, this register has no practical meaning. |             |

# 25.4.5 DVP Column Number Configuration Register (16\_DVP\_COL\_NUM)

Offset address: 0x06

| Bit   |    | Name                 | Access | Description                                                                                                                                     | Reset value |
|-------|----|----------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [15:0 | )] | RB_DVP_COL_NUM[15:0] |        | In RGB mode, indicates the number of PCLK cycles contained within a line of data. In JPEG mode, it is used to configure the DMA receive length. |             |

### 25.4.6 DVP DMA Address 0 Register (R32\_DVP\_DMA\_BUF0)

Offset address: 0x08

|   | Bit    | Name                  | Access | Description            | Reset value |
|---|--------|-----------------------|--------|------------------------|-------------|
| ĺ | [31:0] | RB_DVP_DMA_BUF0[31:0] | RW     | DMA receive address 0. | 0           |

# 25.4.7 DVP DMA Address 1 Register (R32\_DVP\_DMA\_BUF1)

Offset address: 0x0C

| ĺ | Bit    | Name                  | Access | Description            | Reset value |
|---|--------|-----------------------|--------|------------------------|-------------|
| ĺ | [31:0] | RB_DVP_DMA_BUF1[31:0] | RW     | DMA receive address 1. | 0           |

### 25.4.8 DVP Interrupt Flag Register (R8\_DVP\_IFR)

Offset Address: 0x10

| Bit   | Name               | Access | Description                                                              | Reset value |
|-------|--------------------|--------|--------------------------------------------------------------------------|-------------|
| [7:5] | Reserved           | RO     | Reserved.                                                                | -           |
| 4     | RB_DVP_IF_STP_FRM  | RW     | Frame stop interrupt flag, active high, clear by writing 0.              | 0           |
| 3     | RB_DVP_IF_FIFO_OV  | RW     | Receive FIFO overflow interrupt flag, active high, clear by writing 0.   | 0           |
| 2     | RB_DVP_IF_FRM_DONE | RW     | Frame receive completion interrupt flag, valid high, clear by writing 0. | 0           |
| 1     | RB_DVP_IF_ROW_DONE | RW     | Row done interrupt flag, active high, clear by writing 0.                | 0           |
| 0     | RB_DVP_IF_STR_FRM  | RW     | Frame start interrupt flag, active high, clear by writing 0.             | 0           |

# 25.4.9 DVP Receive FIFO Status Register (R8\_DVP\_STATUS)

Offset address: 0x11

| Bit   | Name                 | Access                 | Description                   | Reset value |
|-------|----------------------|------------------------|-------------------------------|-------------|
| 7     | Reserved             | RO                     | Reserved.                     | 0           |
| [6:4] | RB_DVP_FIFO_CNT[2:0] | RO                     | FIFO counter.                 | 0           |
| 3     | Reserved             | RO                     | Reserved.                     | 0           |
|       |                      |                        | FIFO overflow status.         |             |
| 2     | RB_DVP_FIFO_OV       | RO                     | 0: FIFO not overflow;         | 0           |
|       |                      |                        | 1: FIFO overflow.             |             |
|       |                      |                        | FIFO full status.             |             |
| 1     | RB_DVP_FIFO_FULL     | RO                     | 0: The FIFO is not full;      | 0           |
|       | 1:7                  | 1: The buffer is full. |                               |             |
|       |                      |                        | FIFO ready status.            |             |
| 0     | RB_DVP_FIFO_RDY      | RO                     | 0: No data in the FIFO;       | 0           |
|       |                      |                        | 1: There is data in the FIFO. |             |

### 25.4.10 DVP Row Count Register (R16\_DVP\_ROW\_CNT)

Offset address: 0x14

| ĺ | Bit    | Name                 | Access | Description                                                                                                                                                                               | Reset value |
|---|--------|----------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
|   | [15:0] | RB_DVP_ROW_CNT[15:0] | RO     | In actual reception, the number of rows contained in a frame of image data, this register is updated at the end of the frame.  In JPEG format, the value of this register has no meaning. | 0           |

# 25.4.11 DVP Horizontal Shift Register for the Start of the Window (R16\_DVP\_HOFFCNT)

Offset address: 0x18

| Bit    | Name                 | Access | Description                                  | Reset value |
|--------|----------------------|--------|----------------------------------------------|-------------|
|        |                      |        | Within the window line, each row needs to be |             |
| [15:0] | RB_DVP_HOFFCNT[15:0] | RW     | blanked for the number of PCLK cycles before | 0           |
|        |                      |        | capturing data. The lower 14 bits are valid. |             |

# 25.4.12 DVP Window Start Line Number Register (R16\_DVP\_VST)

Offset address: 0x1A

| Bit    | Name             | Access | Description                                                                                                           | Reset value |
|--------|------------------|--------|-----------------------------------------------------------------------------------------------------------------------|-------------|
| [15:0] | RB_DVP_VST[15:0] | RW     | The number of lines the image to start capturing, data before this line is not captured. The lower 13 bits are valid. |             |

### 25.4.13 DVP Capture Count Register (R16 DVP CAPCNT)

Offset address: 0x1C

| İ | Bit    | Name                | Access | Description                                                                                   | Reset value |
|---|--------|---------------------|--------|-----------------------------------------------------------------------------------------------|-------------|
| Ī | [15:0] | RB_DVP_CAPCNT[15:0] | RW     | The number of PCLK cycles to capture within the clipping window. The lower 14 bits are valid. | 0           |

# 25.4.14 DVP Vertical Line Count Register (R16\_DVP\_VLINE)

Offset address: 0x1E

| Bit    | Name               | Access | Description                                                                         | Reset value |
|--------|--------------------|--------|-------------------------------------------------------------------------------------|-------------|
| [15:0] | RB_DVP_VLINE[15:0] | RW     | The number of lines to capture within the crop window. The lower 14 bits are valid. | 0           |

# 25.4.15 DVP Data Register (R32\_DVP\_DR)

Offset address: 0x20

| Bit    | Name            | Access | Description                                                                                                                                                                                                        | Reset value |
|--------|-----------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:0] | RB_DVP_DR[31:0] | RO     | Each time the DVP interface receives 4 bytes of data, a DMA request is triggered, and the 4-byte deep FIFO can leave sufficient time for DMA transfers. It can effectively prevent the occurrence of DMA overflow. | 0           |

# **Chapter 26 Flexible Static Memory Controller (FSMC)**

#### This chapter applies to the whole family of CH32F20x and CH32V30x.

The flexible static memory controller (FSMC) supports a variety of static memory types and rich storage operation methods, and can expand different types of large-capacity static memory according to the needs of system applications.

#### **26.1 Main Features**

- Support to operate SRAM, ROM, NOR FLASH and PSRAM
- Support NAND FLASH operation, and built-in hardware ECC, can detect up to 8KByte data
- Support for synchronous device operation, such as PSRAM
- Support 8bit or 16bit data bus width
- Timing signals can be programmed by software

### **26.2 Functional Description**

#### 26.2.1 Module Structure

FSMC mainly includes HB bus interface, NOR memory controller, NAND memory controller and external device interface.

Figure 26-1 FSMC block diagram

### 26.2.2 External Device Address Mapping

The FSMC divides the memory block into 2 memory blocks with a fixed size of 16MByte according to the

address line, as shown in Figure 26-2.

Address Memory block Supported storage types

6000 0000h

Block 1

1x16MB

NOR/PSRAM

7000 0000h

Block 2

1x16MB

NAND flash

70FF FFFFFh

Figure 26-2 FSMC memory block

#### 26.2.2.1 NOR/PSRAM Address Mapping

Table 26-1 External memory address

| Data width | Address lines connected to memory                                                   | Maximum access memory space (bit) |
|------------|-------------------------------------------------------------------------------------|-----------------------------------|
| 8bit       | HADDR[23:0] is correspondingly connected to FSMC_A[23:0]                            | 16MBx8=128Mbit                    |
| 16bit      | HADDR[23:1] is correspondingly connected to FSMC_A[22:0], HADDR[0] is not connected | 16MB/2x16=128Mbit                 |

Note: Those with 100 pins support FSMC, and only support address and data line multiplexing mode.

NOR FLASH and PSRAM support unaligned access. For asynchronous mode, each operation requires an accurate address; for synchronous mode, only single address signal is issued, and then batches of data are sequentially processed through CLK. For NOR FLASH that supports unaligned batch access, the unaligned access mode of the memory can be set to the same mode as HB. If it cannot be set, the unaligned access mode is disabled, and the unaligned access request is divided into 2 consecutive access operations.

#### 26.2.2.2 NAND Address Mapping

NAND FLASH image and timing registers, see Table 26-2.

Table 26-2 Memory map and timing registers

| Start address | End address | FSMC memory block | Storage   | Timing register  |
|---------------|-------------|-------------------|-----------|------------------|
| 0x78000000    | 0x78FFFFFF  | Piece 2-NAND      | Attribute | FSMC_PATT2(0x6C) |
| 0x70000000    | 0x70FFFFFF  | FLASH             | General   | FSMC_PMEM2(0x68) |

The general and attribute space can be divided into address area (second 128KB area), command area (second

64KB area) and data area (first 64KB area) in the lower 256KB, see Table 26-3.

The software accesses the specific process of NAND FLASH by operating these 3 areas:

- Send read and write operation commands to NAND FLASH: the software can operate any address in the command area to send commands;
- Send the address to be operated to the NAND FLASH: the software can operate any address in the address
  area to send commands;
- Read and write data from NAND FLASH: software can operate any address in the data area to write or read data;

| Tubic 20 5 TVII (B) Inclinity block selection |              |                      |  |  |
|-----------------------------------------------|--------------|----------------------|--|--|
| Area                                          | HADDR[17:16] | Range                |  |  |
| Address area                                  | 1X           | 0x020000 to 0x03FFFF |  |  |
| Command area                                  | 01           | 0x010000 to 0x01FFFF |  |  |
| Data area                                     | 00           | 0x000000 to 0x00FFFF |  |  |

Table 26-3 NAND memory block selection

#### 26.2.3 NOR/PSRAM Controller

FSMC supports 8bit, 16bit and 32bit asynchronous operation SRAM and ROM, supports asynchronous mode and burst mode operation PSRAM, supports asynchronous mode and burst mode operation NOR FLASH. The output signals of all controllers change on the rising edge of the internal clock HCLK. For synchronous write mode (PSRAM), the output data changes on the falling edge of the memory clock (CLK). For details, refer to the synchronous transfer and asynchronous transfer timing diagrams. The read and write parameters of the memory can be configured by software, see Table 26-4.

| Parameters                      | Read and write                   | Parameter value range   |
|---------------------------------|----------------------------------|-------------------------|
| Address setup time Asynchronous |                                  | 1<< T <<16 (HB HCLK)    |
| Address hold time               | Asynchronous                     | 1<< T <<16 (HB HCLK)    |
| Data setup time                 | Asynchronous                     | 2<< T <<256 (HB HCLK)   |
| Bus recovery time               | Asynchronous or synchronous read | 1<< T <<16 (HB HCLK)    |
| Clock divider                   | Synchronous                      | 2<< T <<16 (HB HCLK)    |
| Data generation time            | Synchronous                      | 2<< T <<17 (Memory CLK) |

Table 26-4 Software controllable NOR/PSRAM read and write parameters

#### 26.2.3.1 External Memory Multiplexing Interface Signal

For NOR FLASH and PSRAM interfaces, see Table 26-5 and Table 26-6.

**FSMC Pins** Direction Description CLK Clock line (For synchronous burst mode only) Output A[23:16] Output Address line AD[15:0] Input / Output 16bit address/data line (Multiplexed) NE[1] Output Chip select line NOE Output Output enable NWE Write enable Output Latch Enable NL(NADV) Output

Table 26-5 Multiplexed NOR FLASH interface

| in the second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second second se | NWAIT | Input | Wait for signal line (Only for NOR FLASH) |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-------|-------------------------------------------|
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-------|-------------------------------------------|

Table 26-6 Multiplexed PSRAM interface

| FSMC Pins | Direction      | Description                                  |
|-----------|----------------|----------------------------------------------|
| CLK       | Output         | Clock line (For synchronous burst mode only) |
| A[23:16]  | Output         | Address line                                 |
| AD[15:0]  | Input / Output | 16bit address/data line (Alternate)          |
| NE[1]     | Output         | Chip select line                             |
| NOE       | Output         | Output enable                                |
| NWE       | Output         | write enable                                 |
| NL(NADV)  | Output         | Latch enable                                 |
| NWAIT     | Input          | Wait for signal line                         |
| NBL[1]    | Output         | High byte enable (NUB)                       |
| NBL[0]    | Output         | Low byte enable (NLB)                        |

Note: The signal with the prefix "N" means that it is active low.

### 26.2.3.2 Supported Memory and Operation Methods

See Table 26-7 for supported memories and operation methods.

Table 26-7 Supported memories and operation methods.

| Memory    | Mode               | HB data<br>width | Memory<br>width | Description                |
|-----------|--------------------|------------------|-----------------|----------------------------|
|           | Asynchronous read  | 8                | 16              |                            |
|           | Asynchronous read  | 16               | 16              |                            |
|           | Asynchronous write | 16               | 16              |                            |
| NOR FLASH | Asynchronous read  | 32               | 16              | Divided into 2 FSMC access |
|           | Asynchronous write | 32               | 16              | Divided into 2 FSMC access |
|           | Synchronous read   | 16               | 16              |                            |
|           | Synchronous read   | 32               | 16              | Divided into 2 FSMC access |
| PSRAM     | Asynchronous read  | 8                | 16              |                            |
|           | Asynchronous write | 8                | 16              | Use byte letter NBL[1:0]   |
|           | Asynchronous read  | 16               | 16              |                            |
|           | Asynchronous write | 16               | 16              |                            |
|           | Asynchronous read  | 32               | 16              | Divided into 2 FSMC access |
|           | Asynchronous write | 32               | 16              | Divided into 2 FSMC access |
|           | Synchronous read   | 16               | 16              |                            |
|           | Synchronous read   | 32               | 16              | Divided into 2 FSMC access |
|           | Synchronous write  | 8                | 16              | Use byte letter NBL[1:0]   |
|           | Synchronous write  | 16/32            | 16              |                            |
| SRAM and  | Asynchronous read  | 8/16/32          | 8/16            | Use byte letter NBL[1:0]   |
| ROM       | Asynchronous write | 8/16/32          | 8/16            | Use byte letter NBL[1:0]   |

### 26.2.3.3 NOR/PSRAM Timing Diagram of Asynchronous Transfer Address/Data Multiplexing

Note the following for asynchronous static memory (NOR FLASH and PSRAM) operations:

• When extended mode is enabled, read and write operations to memory using modes A, B, C, and D can be mixed.



Figure 26-3 Mode 1 read operation (Multiplexed)





Note: The last HCLK cycle of a write operation guarantees the hold time for address and data after the rising

V2. 4 452 WH

edge of NWE. Due to this HCLK cycle, the value of DATAST must be greater than zero (DATAST > 0).

Table 26-8 Mode 1 FSMC\_BCR1 bit field

| Bitx    | Name       | Configuration Value                           |
|---------|------------|-----------------------------------------------|
| [31:20] | Reserved   | 0x000                                         |
| 19      | CBURSTRW   | 0x0                                           |
| [18:16] | Reserved   | 0x0                                           |
| 15      | ASYNCWAIT  | It is 1 if the memory supports this function, |
| 13      | ASTINCWAIT | otherwise it is 0.                            |
| 14      | EXTMOD     | 0x0                                           |
| 13      | WAITEN     | 0x0                                           |
| 12      | WREN       | Set as needed                                 |
| 11      | WAITCFG    | No effect                                     |
| 10      | Reserved   | 0x0                                           |
| 9       | WAITPOL    | When bit15 is 1, it is meaningful             |
| 8       | BURSTEN    | 0x0                                           |
| 7       | Reserved   | 0x1                                           |
| 6       | FACCEN     | No effect                                     |
| [5:4]   | MWID       | Set as needed                                 |
| [3:2]   | MTYP       | Set as needed, excluding 0x2 (NOR FLASH)      |
| 1       | MUXEN      | 0x1                                           |
| 0       | MBKEN      | 0x1                                           |

Table 26-9 Mode 1 FSMC\_BTR1 bit field

| Bitx    | Name     | Configuration Value                                                                                                                     |  |
|---------|----------|-----------------------------------------------------------------------------------------------------------------------------------------|--|
| [31:30] | Reserved | 0x0                                                                                                                                     |  |
| [29:28] | ACCMOD   | No effect                                                                                                                               |  |
| [27:24] | DATLAT   | No effect                                                                                                                               |  |
| [23:20] | CLKDIV   | No effect                                                                                                                               |  |
| [19:16] | BUSTURN  | 0x0                                                                                                                                     |  |
| [15:8]  | DATAST   | Data setup time. The write operation is (DATAST+1 HCLK), and the read operation is (DATAST+3 HCLK). The minimum value of this bit is 1. |  |
| [7:4]   | ADDHLD   | Address hold time. (ADDHLD+1 HCLK)                                                                                                      |  |
| [3:0]   | ADDSET   | Address setup time. (ADDSET+1 HCLK).                                                                                                    |  |



Figure 26-5 Mode A read operation (Multiplexed)





Table 26-10 Mode A FSMC\_BCR1 bit field

| Bitx    | Name      | Configuration Value                           |  |  |
|---------|-----------|-----------------------------------------------|--|--|
| [31:20] | Reserved  | 0x000                                         |  |  |
| 19      | CBURSTRW  | 0x0                                           |  |  |
| [18:16] | Reserved  | 0x0                                           |  |  |
| 15      | ASYNCWAIT | It is 1 if the memory supports this function, |  |  |
| 13      | ASYNCWAII | otherwise it is 0.                            |  |  |
| 14      | EXTMOD    | 0x1                                           |  |  |
| 13      | WAITEN    | 0x0                                           |  |  |
| 12      | WREN      | Set as needed                                 |  |  |
| 11      | WAITCFG   | No effect                                     |  |  |
| 10      | Reserved  | 0x0                                           |  |  |
| 9       | WAITPOL   | When bit15 is 1, it is meaningful             |  |  |
| 8       | BURSTEN   | 0x0                                           |  |  |
| 7       | Reserved  | 0x1                                           |  |  |
| 6       | FACCEN    | No effect                                     |  |  |
| [5:4]   | MWID      | Set as needed                                 |  |  |
| [2,2]   | MEND      | Set as needed, excluding 0x2 (NOR             |  |  |
| [3:2]   | MTYP      | FLASH)                                        |  |  |
| 1       | MUXEN     | 0x1                                           |  |  |
| 0       | MBKEN     | 0x1                                           |  |  |

Table 26-11 Mode A FSMC\_BTR1 bit field

| Bitx    | Name             | Configuration Value                       |
|---------|------------------|-------------------------------------------|
| [31:30] | Reserved         | 0x0                                       |
| [29:28] | ACCMOD           | 0x0                                       |
| [27:24] | DATLAT           | No effect                                 |
| [23:20] | CLKDIV           | No effect                                 |
| [19:16] | BUSTYRN          | 0x0                                       |
|         |                  | Data setup time. The read operation is    |
| [15:8]  | DATAST           | (DATAST+3 HCLK). The minimum value        |
|         |                  | of this bit is 1.                         |
| [7:4]   | ADDHLD No effect |                                           |
| [2,0]   | ADDGET           | Address setup time. The read operation is |
| [3:0]   | ADDSET           | (ADDSET+1 HCLK).                          |

Table 26-12 Mode A FSMC\_BWTR1 bit field

| Bitx    | Name     | Configuration Value                                                        |
|---------|----------|----------------------------------------------------------------------------|
| [31:30] | Reserved | 0x0                                                                        |
| [29:28] | ACCMOD   | 0x0                                                                        |
| [27:24] | DATLAT   | No effect                                                                  |
| [23:20] | CLKDIV   | No effect                                                                  |
| [19:16] | BUSTURN  | 0x0                                                                        |
| [15:8]  | DATAST   | Data setup time. The write operation is (DATAST+1 HCLK). The minimum value |

|       |        | of this bit is 1.                                           |
|-------|--------|-------------------------------------------------------------|
| [7:4] | ADDHLD | Address hold time. (ADDHLD+1 HCLK)                          |
| [3:0] | ADDSET | Address setup time. The write operation is (ADDSET+1 HCLK). |

Memory operation cycle A[23:16] NADV NEx NOE High level NWE AD[15:0] Lower 16-bit address (BUSTURN+1) HCLK (ADDSET+1) HCLK (ADDHLD+1) HCLK Data sampling Data storage

Figure 26-7 Mode B read operation (multiplexed)





Table 26-13 Mode B FSMC\_BCR1 bit field

| Bitx    | Name     | Configuration Value |
|---------|----------|---------------------|
| [31:20] | Reserved | 0x000               |

| 19      | CBURSTRW  | 0x0                                           |
|---------|-----------|-----------------------------------------------|
| [18:16] | Reserved  | 0x0                                           |
| 15      | ASYNCWAIT | It is 1 if the memory supports this function, |
| 13      | ASTNOWALL | otherwise it is 0.                            |
| 14      | EXTMOD    | 0x1                                           |
| 13      | WAITEN    | 0x0                                           |
| 12      | WREN      | Set as needed                                 |
| 11      | WAITCFG   | No effect                                     |
| 10      | Reserved  | 0x0                                           |
| 9       | WAITPOL   | When bit15 is 1, it is meaningful.            |
| 8       | BURSTEN   | 0x0                                           |
| 7       | Reserved  | 0x1                                           |
| 6       | FACCEN    | 0x1                                           |
| [5:4]   | MWID      | Set as needed                                 |
| [3:2]   | MTYP      | 0x2(NOR FLASH)                                |
| 1       | MUXEN     | 0x1                                           |
| 0       | MBKEN     | 0x1                                           |

Table 26-14 Mode B FSMC\_BTR1 bit field

| Bitx    | Name     | Configuration Value                                        |
|---------|----------|------------------------------------------------------------|
| [31:30] | Reserved | 0x0                                                        |
| [29:28] | ACCMOD   | 0x1                                                        |
| [27:24] | DATLAT   | No effect                                                  |
| [23:20] | CLKDIV   | No effect                                                  |
| [19:16] | BUSTURN  | 0x0                                                        |
| [15.0]  | DATACT   | Data setup time. The read operation is                     |
| [15:8]  | DATAST   | (DATAST+3 HCLK). The minimum value of this bit is 1.       |
| [7:4]   | ADDHLD   | Address hold time. (ADDHLD+1 HCLK)                         |
| [3:0]   | ADDSET   | Address setup time. The read operation is (ADDSET+1 HCLK). |

Table 26-15 Mode B FSMC\_BWTR1 bit field

| Bitx    | Name     | Configuration Value                        |
|---------|----------|--------------------------------------------|
| [31:30] | Reserved | 0x0                                        |
| [29:28] | ACCMOD   | 0x1                                        |
| [27:24] | DATLAT   | No effect                                  |
| [23:20] | CLKDIV   | No effect                                  |
| [19:16] | BUSTURN  | 0x0                                        |
|         |          | Data setup time. The write operation is    |
| [15:8]  | DATAST   | (DATAST+1 HCLK). The minimum value         |
|         |          | of this bit is 1.                          |
| [7:4]   | ADDHLD   | Address hold time. (ADDHLD+1 HCLK)         |
| [3:0]   | ADDSET   | Address setup time. The write operation is |
| [5.0]   | ADDSET   | (ADDSET+1 HCLK).                           |



Figure 26-9 Mode C read operation (Multiplexed)





Table 26-16 Mode C FSMC\_BCR1 bit field

| Bitx    | Name     | Configuration Value |
|---------|----------|---------------------|
| [31:20] | Reserved | 0x000               |
| 19      | CBURSTRW | 0x0                 |

| [18:16] | Reserved  | 0x0                                           |
|---------|-----------|-----------------------------------------------|
| 1.5     | ASYNCWAIT | It is 1 if the memory supports this function, |
| 15      |           | otherwise it is 0.                            |
| 14      | EXTMOD    | 0x1                                           |
| 13      | WAITEN    | 0x0                                           |
| 12      | WREN      | Set as needed                                 |
| 11      | WAITCFG   | No effect                                     |
| 10      | Reserved  | 0x0                                           |
| 9       | WAITPOL   | When bit15 is 1, it is meaningful.            |
| 8       | BURSTEN   | 0x0                                           |
| 7       | Reserved  | 0x1                                           |
| 6       | FACCEN    | 0x1                                           |
| [5:4]   | MWID      | Set as needed                                 |
| [3:2]   | MTYP      | 0x2(NOR FLASH)                                |
| 1       | MUXEN     | 0x1                                           |
| 0       | MBKEN     | 0x1                                           |

### Table 26-17 Mode C FSMC\_BTR1 bit field

| Bitx    | Name     | Configuration Value                                                       |
|---------|----------|---------------------------------------------------------------------------|
| [31:30] | Reserved | 0x0                                                                       |
| [29:28] | ACCMOD   | 0x2                                                                       |
| [27:24] | DATLAT   | No effect                                                                 |
| [23:20] | CLKDIV   | No effect                                                                 |
| [19:16] | BUSTURN  | 0x0                                                                       |
| [15:8]  | DATAST   | Data setup time. The read operation is (DATAST+3 HCLK). The minimum value |
|         |          | of this bit is 1.                                                         |
| [7:4]   | ADDHLD   | Address hold time. (ADDHLD+1 HCLK)                                        |
| [3:0]   | ADDSET   | Address setup time. The read operation is (ADDSET+1 HCLK).                |

# Table 26-18 Mode C FSMC\_BWTR1 bit field

| Bitx    | Name     | Configuration Value                        |
|---------|----------|--------------------------------------------|
| [31:30] | Reserved | 0x0                                        |
| [29:28] | ACCMOD   | 0x2                                        |
| [27:24] | DATLAT   | No effect                                  |
| [23:20] | CLKDIV   | No effect                                  |
| [19:16] | BUSTURN  | 0x0                                        |
|         |          | Data setup time. The write operation is    |
| [15:8]  | DATAST   | (DATAST+1 HCLK). The minimum value         |
|         |          | of this bit is 1.                          |
| [7:4]   | ADDHLD   | Address hold time. (ADDHLD+1 HCLK)         |
| [3:0]   | ADDSET   | Address setup time. The write operation is |
|         |          | (ADDSET+1 HCLK).                           |



Figure 26-11 Mode D read operation (Multiplexed)





Figure 26-19 Mode D FSMC\_BCR1 bit field

| Bitx    | Name      | Configuration Value                                              |
|---------|-----------|------------------------------------------------------------------|
| [31:20] | Reserved  | 0x000                                                            |
| 19      | CBURSTRW  | 0x0                                                              |
| [18:16] | Reserved  | 0x0                                                              |
| 15      | ASYNCWAIT | It is 1 if the memory supports this function, otherwise it is 0. |
| 14      | EXTMOD    | 0x1                                                              |

| 13    | WAITEN   | 0x0                                |
|-------|----------|------------------------------------|
| 12    | WREN     | Set as needed                      |
| 11    | WAITCFG  | No effect                          |
| 10    | Reserved | 0x0                                |
| 9     | WAITPOL  | When bit15 is 1, it is meaningful. |
| 8     | BURSTEN  | 0x0                                |
| 7     | Reserved | 0x1                                |
| 6     | FACCEN   | Set as needed                      |
| [5:4] | MWID     | Set as needed                      |
| [3:2] | MTYP     | Set as needed                      |
| 1     | MUXEN    | 0x1                                |
| 0     | MBKEN    | 0x1                                |

Table 26-20 Mode D FSMC BTR1 bit field

| Bitx    | Name     | Configuration Value                       |
|---------|----------|-------------------------------------------|
| [31:30] | Reserved | 0x0                                       |
| [29:28] | ACCMOD   | 0x3                                       |
| [27:24] | DATLAT   | No effect                                 |
| [23:20] | CLKDIV   | No effect                                 |
| [19:16] | BUSTURN  | 0x0                                       |
| [15:8]  | DATAST   | Data setup time. The read operation is    |
|         |          | (DATAST+3 HCLK). The minimum value        |
|         |          | of this bit is 1.                         |
| [7:4]   | ADDHLD   | Address hold time. (ADDHLD+1 HCLK).       |
| [3:0]   | ADDSET   | Address setup time. The read operation is |
|         |          | (ADDSET+1 HCLK).                          |

Table 26-21 Mode D FSMC BWTR1 bit field

| Bitx    | Name     | Configuration Value                                                                          |
|---------|----------|----------------------------------------------------------------------------------------------|
| [31:30] | Reserved | 0x0                                                                                          |
| [29:28] | ACCMOD   | 0x3                                                                                          |
| [27:24] | DATLAT   | 0x0                                                                                          |
| [23:20] | CLKDIV   | 0x0                                                                                          |
| [19:16] | BUSTYRN  | 0x0                                                                                          |
| [15:8]  | DATAST   | Data setup time. The write operation is (DATAST+1 HCLK). The minimum value of this bit is 1. |
| [7:4]   | ADDHLD   | Address hold time. (ADDHLD+1 HCLK).                                                          |
| [3:0]   | ADDSET   | Address set time. The write operation is (ADDSET+1 HCLK).                                    |

### 26.2.3.4 Timing diagram of NOR/PSRAM synchronous transfer address/data multiplexing

Data delay and NOR FLASH delay should be noted that the DATALAT value must be consistent with the definition in the NOR FLASH configuration register. The clock period when the NADV signal is low is not counted in the delay parameter. The DATLAT parameter of the FSMC can be DATALAT+2 or DATALAT+3.

V2. 4 461 WH

For special memories, the NWAIT signal will be generated during the data retention period, and DATLAT needs to be set to the minimum value. For other memories, the NWAIT signal will not be generated during the data hold time phase, the data hold time of FSMC and memory must be set consistently.

For a single batch transmission, it should be noted that the memory configuration bit is synchronized in batch mode. If 16bit data is transmitted, FSMC will perform a batch transmission with a length of 1. If 32bit data is transmitted, the FSMC is divided into 2 times of 16bit transmission, and the length of an execution is 1. 2 batch transfers.

In NOR FLASH synchronous batch mode access, after the hold time (DATLAT+1 CLK), if the NWAIT signal is detected to be low, the FSMC needs to insert a wait period before NWAIT becomes high. When NWAIT becomes high, FSMC considers the data valid. During the wait state insertion period controlled by the NWAIT signal, the controller will continue to send clock pulses to the memory, hold the chip select signal and output the valid signal, while ignoring the invalid data signal. In bulk transfer mode, the NWAIT signal of NOR FLASH selects 2 timing configurations by configuring the WAITCFG bit.



Figure 26-13 Synchronous bus multiplexing read operations (Multiplexed)

Table 26-22 FSMC\_BCR1 bit field (Synchronous read mode)

| Bitx    | Name      | Configuration Value |
|---------|-----------|---------------------|
| [31:20] | Reserved  | 0x000               |
| 19      | CBURSTRW  | No effect           |
| [18:16] | Reserved  | 0x0                 |
| 15      | ASYNCWAIT | 0x0                 |
| 14      | EXTMOD    | 0x0                 |
| 13      | WAITEN    | 0x0                 |
| 12      | WREN      | No effect           |
| 11      | WAITCFG   | Set as needed       |
| 10      | Reserved  | 0x0                 |
| 9       | WAITPOL   | Set as needed       |
| 8       | BURSTEN   | 0x1                 |
| 7       | Reserved  | 0x1                 |
| 6       | FACCEN    | Set as needed       |
| [5:4]   | MWID      | Set as needed       |
| [3:2]   | MTYP      | 0x1or 0x2           |
| 1       | MUXEN     | 0x1                 |
| 0       | MBKEN     | 0x1                 |

Table 26-23 FSMC\_BTR1 bit field (Synchronous read mode)

| Bitx    | Name     | Configuration Value |
|---------|----------|---------------------|
| [31:30] | Reserved | 0x0                 |
| [29:28] | ACCMOD   | 0x0                 |
| [27:24] | DATLAT   | Data latch time     |
| [23:20] | CLKDIV   | 0x0: Reserved       |
|         |          | 0x1: CLK=2 HCLK     |
| [19:16] | BUSTURN  | No effect           |
| [15:8]  | DATAST   | No effect           |
| [7:4]   | ADDHLD   | No effect           |
| [3:0]   | ADDSET   | No effect           |



Figure 26-14 Synchronous bus multiplexing write operations (Multiplexed)

Table 26-24 FSMC\_BCR1 bit field (Synchronous write mode)

| Bitx    | Name      | Configuration Value                           |
|---------|-----------|-----------------------------------------------|
| [31:20] | Reserved  | 0x000                                         |
| 19      | CBURSTRW  | 0x1                                           |
| [18:16] | Reserved  | 0x0                                           |
| 15      | ASYNCWAIT | 0x0                                           |
| 14      | EXTMOD    | 0x0                                           |
| 13      | WA ITENI  | It is 1 if the memory supports this function, |
| 13      | WAITEN    | 0 otherwise it is 0.                          |
| 12      | WREN      | 0x1                                           |
| 11      | WAITCFG   | 0x0                                           |
| 10      | Reserved  | 0x0                                           |
| 9       | WAITPOL   | Set as needed                                 |
| 8       | BURSTEN   | No effect                                     |
| 7       | Reserved  | 0x1                                           |
| 6       | FACCEN    | Set as needed                                 |

| [5:4] | MWID  | Set as needed |
|-------|-------|---------------|
| [3:2] | MTYP  | 0x1           |
| 1     | MUXEN | 0x1           |
| 0     | MBKEN | 0x1           |

Table 26-25 FSMC\_BTR1 bit field (Synchronous write mode)

| Bitx    | Name     | Configuration Value |
|---------|----------|---------------------|
| [31:30] | Reserved | 0x0                 |
| [29:28] | ACCMOD   | 0x0                 |
| [27:24] | DATLAT   | Data latch time     |
| [22,20] | CLKDIV   | 0x0: Reserved       |
| [23:20] |          | 0x1: CLK=2 HCLK     |
| [19:16] | BUSTURN  | No effect           |
| [15:8]  | DATAST   | No effect           |
| [7:4]   | ADDHLD   | No effect           |
| [3:0]   | ADDSET   | No effect           |

# 26.2.4 NAND FLASH controller

FSMC supports 8bit and 16bit operation of NAND FLASH. FSMC can generate multiple address cycles as needed. In theory, FSMC has no limit to the capacity of NAND FLASH. The read and write parameters of NAND FLASH can be configured by software, see Table 26-26.

Table 26-26 Software controllable NAND read and write parameters

| Parameter                                        | Function                                                                                                    | Read and write | Parameter value range |
|--------------------------------------------------|-------------------------------------------------------------------------------------------------------------|----------------|-----------------------|
| Memory setup time                                | Time to setup the address before sending command                                                            | read/write     | 1<< T <<256 (HB HCLK) |
| Memory wait time                                 | Minimum duration to send a command                                                                          | read/write     | 1<< T <<256 (HB HCLK) |
| Memory hold time                                 | Time to hold the address at the end of command transmission, also the data hold time during write operation | read/write     | 1<< T <<255 (HB HCLK) |
| Memory data bus<br>high resistance<br>state time | The data bus remains high resistance state time after initiating a write operation                          | write          | 0<< T <<255 (HB HCLK) |

# **26.2.4.1** External Memory Interface Signals

8bit and 16bit NAND FLASH interface, see Table 26-27, Table 26-28.

Table 26-27 8-bit NAND FLASH

| FSMC Pin | Direction | Description                       |
|----------|-----------|-----------------------------------|
| A[17]    | Output    | Address latch enable signal (ALE) |

| A[16]  | Output       | Command latch enable signal (CLE)                 |
|--------|--------------|---------------------------------------------------|
| D[7:0] | Input/output | 8-bit bidirectional address/data multiplexing bus |
| NCE[2] | Output       | Chip select line                                  |
| NOE    | Output       | Output enable                                     |
| NWE    | Output       | Write enable                                      |
| NWAIT  | Input        | Wait signal line                                  |

Table 26-28 16-bit NAND FLASH

| FSMC Pins | Direction    | Description                                        |  |  |  |  |  |
|-----------|--------------|----------------------------------------------------|--|--|--|--|--|
| A[17]     | Output       | Address latch enable signal (ALE)                  |  |  |  |  |  |
| A[16]     | Output       | Command latch enable signal (CLE)                  |  |  |  |  |  |
| D[15:0]   | Input/output | 16-bit bidirectional address/data multiplexing bus |  |  |  |  |  |
| NCE[2]    | Output       | Chip select line                                   |  |  |  |  |  |
| NOE       | Output       | Output enable                                      |  |  |  |  |  |
| NWE       | Output       | Write enable                                       |  |  |  |  |  |
| NWAIT     | Input        | Wait signal line                                   |  |  |  |  |  |

# 26.2.4.2 Supported Memory and Operation Methods

See Table 26-29 for supported memories and operation methods.

Table 26-29 Supported memory and operation modes

| Memory        | Mode HB data Memory width width |    |    | Description                |
|---------------|---------------------------------|----|----|----------------------------|
|               | Asynchronous read               | 8  | 8  |                            |
|               | Asynchronous write              | 8  | 8  |                            |
| 8bit          | Asynchronous read               | 16 | 8  | Divided into 2 FSMC access |
| NAND          | Asynchronous write              | 16 | 8  | Divided into 2 FSMC access |
|               | Asynchronous read               | 32 | 8  | Divided into 4 FSMC access |
|               | Asynchronous write              | 32 | 8  | Divided into 4 FSMC access |
|               | Asynchronous read               | 8  | 16 |                            |
| 161.4         | Asynchronous read               | 16 | 16 |                            |
| 16bit<br>NAND | Asynchronous write              | 16 | 16 |                            |
| INAND         | Asynchronous read               | 32 | 16 | Divided into 2 FSMC access |
|               | Asynchronous write              | 32 | 16 | Divided into 2 FSMC access |

# 26.2.4.3 NAND FLASH Timing Diagram (Including pre-wait function)

NAND FLASH operation timing control, involving FSMC\_PMEM2 and FSMC\_PATT2 timing registers, each register contains 4 parameters. The 3 parameters MEMHOLD, MEMWAIT and ATTSET correspond to the number of HCLK cycles in the 3 stages of operating the NAND FLASH, and the MEMHIZ parameter corresponds to the timing when the FSMC starts to drive the data bus. NAND FLASH controller general memory space access timing, see Figure 26-15.

V2. 4 466 WH



Figure 26-15 NAND FLASH controller general purpose memory access timing

# 26.2.4.4 NAND FLASH Operating Procedure

The command latch enables signal (CLE) and address latch enable signal (ALE) of NAND FLASH are driven by FSMC address lines A16 and A17 respectively. Therefore, when sending commands or addresses to NAND FLASH operations, it is necessary to perform a write operation on the specified address of the storage space. The read operation process of NAND FLASH is as follows:

- 1) Configure the PWID, PTYP, PWAITEN and PBKEN of the FSMC\_PCR2, FSMC\_PMEM2 and FSMC\_PATT2 registers according to the NAND FLASH characteristics to be operated.
- Write a command byte in the general storage space. During the period when NWE is low, CLE outputs a high level. At this time, the command byte is recognized as a command by NAND FLASH, and the command is latched. The subsequent page read operation does not need to send the command repeatedly.
- Then, by writing 4 bytes to the memory space, it is used as the starting address of the read operation. During the period when NWE is low, ALE outputs high level, and 4 bytes are recognized by NAND FLASH as the starting address of the read operation at this time. When operating the attribute storage space, the FSMC can be made to generate different timings and realize some NAND FLASH pre-wait functions.
- 4) Before the FSMC controller starts a new operation, it needs to wait for the R/NB signal of the NAND FLASH to become a high level. During the wait period, the FSMC controller needs to keep the NCE signal at a low level.
- 5) The FSMC controller can read the memory page byte by byte from the NAND FLASH by operating the general memory space.

### 26.2.4.5 NAND FLASH Pre-wait Function

For some special NAND FLASHs, after the last address byte is input, the R/NB signal changes to a low level, see Figure 26-16. In the figure (1) is the CPU write byte command 0x00 to 0x70010000; in the figure (2) the CPU writes the NAND FLASH address A7-A0 to 0x70020000; in the figure (3) the CPU writes the NAND FLASH address A15-A8 to 0x70020000; (4) in the figure is the address A23-A16 to 0x70020000 of the CPU writing NAND FLASH; (5) in the figure is the address A31-A24 to 0x70020000 of the CPU writing NAND

V2. 4 467 WCH<sup>®</sup>

FLASH;



Figure 26-16 Special operation on NAND FLASH

When using this function, the timing of tWB is guaranteed by configuring the MEMHOLD bit in the FSMC\_PMEM2 register. After reading and writing operations to NAND FLASH, the FSMC controller will insert (MEMHOLD+1) HCLK between the rising edge of the NEW signal and the next operation. Keep the delay. In order to solve this problem, the attribute space is used to configure the ATTHOLD value so that it conforms to the timing of tWB, and at the same time, it is necessary to keep MEMHOLD at a minimum value. At this time, only when writing the last byte of the NAND FLASH address, the FSMC controller needs to write the attribute storage space, and the rest of the NAND FLASH read and write operations use the general storage space.

#### 26.2.4.6 NAND FLASH ECC Features

FSMC's NAND FLASH controller includes an error correction code calculation hardware module, which can effectively reduce the software workload of the CPU when processing error correction codes. When the ECC module reads and writes NAND FLASH, it supports correction of 1 bit error and detection of 2-bit errors in every 256, 512, 1024, 2048, 4096 or 8192 bytes. The page size corresponds to the valid bits of the ECC result, see Table 26-30. After the ECC calculation circuit is enabled, the ECC module monitors the data bus and read/write signals (NCE and NWE) of the NAND FLASH. Pay attention to the following when using ECC:

- When accessing the NAND FLASH, the data appearing on the D[15:0] bus is latched and used for ECC calculations.
- After the specified number of bytes have been written into or read from the NAND FLASH, the software reads the ECC value from the FSMC\_ECCR2 register. To calculate ECC again, first clear ECCEN to 0, and then write 1 to re-enable ECC calculation.

Table 26-30 The page size corresponds to the valid bits of the ECC result

| ECCPS[2:0] | Page size (bytes) | ECC significant bit |
|------------|-------------------|---------------------|
| 000        | 256               | ECC[21:0]           |
| 001        | 512               | ECC[23:0]           |
| 010        | 1024              | ECC[25:0]           |
| 011        | 2048              | ECC[27:0]           |
| 100        | 4096              | ECC[29:0]           |
| 101        | 8192              | ECC[31:0]           |

# **26.3 Register Description**

Table 26-31 FSMC registers

| Name Access address |            | Description                                   | Reset value |  |  |  |  |
|---------------------|------------|-----------------------------------------------|-------------|--|--|--|--|
| R32_FSMC_BCR1       | 0xA0000000 | SRAM/NOR-Flash chip select control register 1 | 0x000030DX  |  |  |  |  |
| R32_FSMC_BTR1       | 0xA0000004 | SRAM/NOR-Flash chip select timing register 1  | 0x0FFFFFFF  |  |  |  |  |
| R32_FSMC_PCR2       | 0xA0000060 | NAND-Flash control register 2                 | 0x00000018  |  |  |  |  |
| R32_FSMC_SR2        | 0xA0000064 | FIFO status and interrupt register 2          | 0x00000040  |  |  |  |  |
| R32_FSMC_PMEM2      | 0xA0000068 | General purpose memory timing register 2      | 0xFCFCFCFC  |  |  |  |  |
| R32_FSMC_PATT2      | 0xA000006C | Attribute memory timing register 2            | 0xFCFCFCFC  |  |  |  |  |
| R32_FSMC_ECCR2      | 0xA0000074 | ECC result register 2                         | 0x00000000  |  |  |  |  |
| R32_FSMC_BWTR1      | 0xA0000104 | SRAM/NOR-Flash write timing register 1        | 0x0FFFFFFF  |  |  |  |  |

# 26.3.1 SRAM/NOR-Flash Chip Select Control Register 1 (FSMC\_BCR1)

Offset address: 0x00

|   | 31                | 30             | 29         | 28       | 27          | 26           | 25          | 24           | 23           | 22          | 21  | 20     | 19   | 18     | 17        | 16        |
|---|-------------------|----------------|------------|----------|-------------|--------------|-------------|--------------|--------------|-------------|-----|--------|------|--------|-----------|-----------|
|   | Reserved          |                |            |          |             |              |             | CBUR<br>STRW | F            | Reserve     | d   |        |      |        |           |           |
| • | 15                | 14             | 13         | 12       | 11          | 10           | 9           | 8            | 7            | 6           | 5   | 4      | 3    | 2      | 1         | 0         |
|   | ASY<br>NCW<br>AIT | EXT<br>M<br>OD | WAIT<br>EN | WRE<br>N | WAIT<br>CFG | Reser<br>ved | WAIT<br>POL | BUR<br>STEN  | Reser<br>ved | FAC<br>C EN | MWI | D[1:0] | MTYF | P[1:0] | MUX<br>EN | MBK<br>EN |

| Bit     | Name      | Access | Description                                 | Reset value |
|---------|-----------|--------|---------------------------------------------|-------------|
| [31:20] | Reserved  | RO     | Reserved                                    | 0           |
|         |           |        | Bulk write enable.                          |             |
| 19      | CBURSTRW  | RW     | 0: Write operation is in asynchronous mode; | 0           |
|         |           |        | 1: Write operation is in synchronous mode.  |             |
| [18:16] | Reserved  | RO     | Reserved                                    | 0           |
|         |           |        | Wait signal during asynchronous transfer.   |             |
|         |           |        | 0: Disable wait signal during asynchronous  |             |
| 15      | ASYNCWAIT | RW     | transfer;                                   | 0           |
|         |           |        | 1: Enable wait signal during asynchronous   |             |
|         |           |        | transfer.                                   |             |
| 14      | EXTMOD    | RW     | Extended mode enable.                       | 0           |

|          |                    |          | 0: Disable writing to use FSMC_BWTR;              |             |
|----------|--------------------|----------|---------------------------------------------------|-------------|
|          |                    |          | 1: Enable writing to use FSMC_BWTR.               |             |
|          |                    |          | Wait enable. When the flash memory is in bulk     |             |
|          |                    |          | transfer mode, this bit controls whether the wait |             |
| 13       | WAITEN             | RW       | signal is inserted according to the NWAIT signal. | 1           |
|          |                    |          | 0: Disable NWAIT signal;                          |             |
|          |                    |          | 1: Enable NWAIT signal.                           |             |
|          |                    |          | Write enable.                                     |             |
| 12       | WREN               | RW       | 0: Disable FSMC to write to the memory;           | 1           |
|          |                    |          | 1: Enable FSMC to write to the memory.            |             |
|          |                    |          | Wait timing configuration.                        |             |
|          |                    |          | 0: NWAIT signal is valid one data cycle before    |             |
| 11       | WAITCFG            | RW       | the wait state;                                   | 0           |
|          |                    |          | 1: NWAIT signal is valid during the wait state.   |             |
| 10       | Reserved           | RO       | Reserved                                          | 0           |
| 10       | Reserved           | RO       | Wait signal polarity.                             | 0           |
| 9        | WAITPOL            | RW       | 0: NWAIT is active low;                           | 0           |
| ,        | WAITIOL            | IXVV     | 1: NWAIT is active high.                          | U           |
|          |                    |          | Bulk mode enable.                                 |             |
| 8        | BURSTEN            | RW       | 0: Disable bulk mode;                             | 0           |
| o        | BURSTEN            | Kvv      | 1: Enable bulk mode.                              | U           |
| 7        | Reserved           | RO       | Reserved                                          | 1           |
| /        | Reserved           | KO       | NOR FLASH access enable.                          | 1           |
| 6        | FACCEN             | RW       | 0: Disable access to NOR FLASH;                   | 1           |
|          | TACCEN             | Kvv      | 1: Enable access to NOR FLASH.                    | 1           |
|          |                    |          | Data bus width.                                   |             |
|          |                    |          |                                                   |             |
| F.5. 4.7 | MWHD[1 0]          | DW       | 11: Reserved;                                     | 011         |
| [5:4]    | MWID[1:0]          | RW       | 10: Reserved;                                     | 01b         |
|          |                    |          | 01: 16 bits;                                      |             |
|          |                    |          | 00: 8 bits.                                       |             |
|          |                    |          | Memory type.                                      |             |
| F2 23    | NAMES AND STATE OF | DIII     | 11: Reserved;                                     |             |
| [3:2]    | MTYP[1:0]          | RW       | 10: NOR FLASH;                                    | reset value |
|          |                    |          | 01: PSRAM;                                        |             |
|          |                    |          | 00: SRAM, ROM.                                    |             |
|          | MINEN              | DITT     | Address/data multiplexing enable.                 |             |
| 1        | MUXEN              | RW       | 0: Address/data are not multiplexed;              | reset value |
|          |                    |          | 1: Address/data multiplexing.                     |             |
|          |                    | <b>n</b> | Memory block enable.                              | _           |
| 0        | MBKEN              | RW       | 0: Disable the corresponding memory block;        | reset value |
|          |                    |          | 1: Enable the corresponding memory block.         |             |

# 26.3.2 SRAM/NOR-Flash Chip Select Timing Register 1 (FSMC\_BTR1)

Offset address: 0x04

 $31 \quad 30 \quad 29 \quad 28 \quad 27 \quad 26 \quad 25 \quad 24 \quad 23 \quad 22 \quad 21 \quad 20 \quad 19 \quad 18 \quad 17 \quad 16$ 

| Rese        | rved | ACCM | OD[1:0] |    | DATLAT[3:0] |   |   |      | CLKD    | IV[3:0] |   | BUSTURN[3:0] |         |   |   |  |
|-------------|------|------|---------|----|-------------|---|---|------|---------|---------|---|--------------|---------|---|---|--|
| 15          | 14   | 13   | 12      | 11 | 10          | 9 | 8 | 7    | 6       | 5       | 4 | 3            | 2       | 1 | 0 |  |
| DATAST[7:0] |      |      |         |    |             |   | I | ADDH | LD[3:0] | ]       |   | ADDS         | ET[3:0] |   |   |  |

| Bit     | Name         | Access | Description                                      | Reset value |  |  |  |
|---------|--------------|--------|--------------------------------------------------|-------------|--|--|--|
| [31:30] | Reserved     | RO     | Reserved                                         | 0           |  |  |  |
|         |              |        | Asynchronous access mode.                        |             |  |  |  |
|         |              |        | 00: Mode A;                                      |             |  |  |  |
| [29:28] | ACCMOD[1:0]  | RW     | 01: Mode B;                                      | 00b         |  |  |  |
|         |              |        | 10: Mode C;                                      |             |  |  |  |
|         |              |        | 11: Mode D.                                      |             |  |  |  |
|         |              |        | Data latch time. For synchronous bulk mode       |             |  |  |  |
|         |              |        | (only for NOR FLASH)                             |             |  |  |  |
|         |              |        | 0000: The first data latch time is 2 CLK clocks; |             |  |  |  |
| [27:24] | DATLAT[3:0]  | RW     |                                                  | 1111b       |  |  |  |
| . ,     |              |        | 1110: The first data latch time is 16 CLK        |             |  |  |  |
|         |              |        | clocks;                                          |             |  |  |  |
|         |              |        | 1111: The first data latch time is 17 CLK        |             |  |  |  |
|         |              |        | clocks.                                          |             |  |  |  |
|         |              |        | Clock divider ratio (CLK signal). This           |             |  |  |  |
|         |              |        | parameter has no effect when accessing           |             |  |  |  |
|         | CLKDIV[3:0]  |        | asynchronous NOR FLASH, SRAM and                 |             |  |  |  |
| 500 007 |              |        | ROM.                                             |             |  |  |  |
| [23:20] |              | RW     | 0000: Reserved;                                  | 1111b       |  |  |  |
|         |              |        | 0001: 1 CLK cycle = 2 HCLK cycles;               |             |  |  |  |
|         |              |        |                                                  |             |  |  |  |
|         |              |        | 1110: 1 CLK cycle = 15 HCLK cycles;              |             |  |  |  |
|         |              |        | 1111: 1 CLK cycle = 16 HCLK cycles.              |             |  |  |  |
|         |              |        | Bus recovery time. (only for NOR FLASH)          |             |  |  |  |
| [19:16] | BUSTURN[3:0] | RW     | 0000: bus recovery time = 1 HCLK cycle;          | 1111b       |  |  |  |
| [19.10] | BUSTURN[3.0] | IX VV  | 1110: bus recovery time = 15 HCLK cycles;        | 11110       |  |  |  |
|         |              |        | 1111: bus recovery time = 16 HCLK cycles.        |             |  |  |  |
|         |              |        | Data hold time.                                  |             |  |  |  |
|         |              |        | 00000000: Reserved;                              |             |  |  |  |
|         |              |        | 00000001: data hold time = 2 HCLK cycles;        |             |  |  |  |
|         |              |        |                                                  |             |  |  |  |
|         |              |        | 11111110: data hold time = 255 HCLK cycles;      |             |  |  |  |
|         |              |        | 11111111: data hold time = 256 HCLK cycles.      |             |  |  |  |
| [15:8]  | DATAST[7:0]  | RW     | For the data retention time of each memory       | 0xFF        |  |  |  |
|         |              |        | type and access method, refer to the             |             |  |  |  |
|         |              |        | corresponding charts (see Figures 26-3 to 26-    |             |  |  |  |
|         |              |        | 12).                                             |             |  |  |  |
|         |              |        | For example: For Mode 1 and Mode A, when         |             |  |  |  |
|         |              |        | DATAST=1 during a read operation: Data           |             |  |  |  |

|       |             |    | retention time = DATAST + 3 = 4 HCLK clock cycles.  Address hold time. (Only for asynchronous                                                                                                                                                                                                                                                                                                                                                              |       |
|-------|-------------|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| [7:4] | ADDHLD[3:0] | RW | operations) 0000: Address hold time = 1 HCLK cycle; 1110: Address hold time = 15 HCLK cycles; 1111: Address hold time = 16 HCLK cycles.                                                                                                                                                                                                                                                                                                                    | 1111b |
| [3:0] | ADDSET[3:0] | RW | Address setup time. (Only for asynchronous operations) 0000: Address setup time = 1 HCLK cycle; 1110: Address setup time = 15 HCLK cycles; 1111: Address setup time = 16 HCLK cycles. For the data retention time of each memory type and access method, refer to the corresponding charts (see Figures 26-3 to 26-12). For example: For Mode 1 and Mode A, when DATAST=1 during a read operation: Data retention time = DATAST + 3 = 4 HCLK clock cycles. | 1111b |

# 26.3.3 NAND-Flash Control Register 2 (FSMC\_PCR2)

Offset address: 0x60

| 3  | 1                  | 30 | 29 | 28 | 27   | 26   | 25        | 24   | 23     | 22   | 21        | 20          | 19           | 18    | 17  | 16     |
|----|--------------------|----|----|----|------|------|-----------|------|--------|------|-----------|-------------|--------------|-------|-----|--------|
|    | Reserved           |    |    |    |      |      |           |      | -      |      | -         |             | EC           | CPS[2 | :0] | TAR[3] |
| 1: | 5                  | 14 | 13 | 12 | 11   | 10   | 9         | 8    | 7      | 6    | 5         | 4           | 3            | 2     | 1   | 0      |
|    | TAR[2:0] TCLR[3:0] |    |    |    | Rese | rved | ECC<br>EN | PWII | D[1:0] | PTYP | PBK<br>EN | PWA<br>ITEN | Reser<br>ved |       |     |        |

| Bit     | Name                                        | Access | Description           | Reset value |
|---------|---------------------------------------------|--------|-----------------------|-------------|
| [31:20] | Reserved                                    | RO     | Reserved              | 0           |
|         |                                             |        | ECC page size.        |             |
|         |                                             |        | 000: 256Byte;         |             |
|         |                                             |        | 001: 512Byte;         |             |
| [19:17] | ECCPS[2:0] RW 010: 1024Byte; 011: 2048Byte; | DW     | 010: 1024Byte;        | 0           |
| [19.17] |                                             | U      |                       |             |
|         | 100: 4096                                   |        | 100: 4096Byte;        |             |
|         |                                             |        | 101: 8192Byte;        |             |
|         |                                             |        | 111: Reserved.        |             |
|         |                                             |        | ALE to RE delay.      |             |
| F16.121 | TAD[2.0]                                    | RW     | 0000: 1 HCLK cycle;   | 0           |
| [16:13] | TAR[2:0]                                    | I KVV  |                       | U           |
|         |                                             |        | 1110: 15 HCLK cycles; |             |

|        |           |    | 1111: 16 HCLK cycles.                      |     |
|--------|-----------|----|--------------------------------------------|-----|
|        |           |    | CLE to RE delay.                           |     |
|        |           |    | 0000: 1 HCLK cycle;                        |     |
| [12:9] | TCLR[3:0] | RW |                                            | 0   |
|        |           |    | 1110: 15 HCLK cycles;                      |     |
|        |           |    | 1111: 16 HCLK cycles.                      |     |
| [8:7]  | Reserved  | RO | Reserved                                   | 0   |
|        |           |    | ECC enable.                                |     |
| 6      | ECCEN     | RW | 0: Disable ECC;                            | 0   |
|        |           |    | 1: Enable ECC.                             |     |
|        |           |    | Data bus width.                            |     |
|        |           |    | 00: 8 bits;                                |     |
| [5:4]  | PWID[1:0] | RW | 01: 16 bits;                               | 01b |
|        |           |    | 10: Reserved;                              |     |
|        |           |    | 11: Reserved.                              |     |
|        |           |    | Memory Type.                               |     |
| 3      | PTYP      | RW | 0: Reserved;                               | 1   |
|        |           |    | 1: NAND flash memory.                      |     |
|        |           |    | NAND memory enable.                        |     |
| 2      | PBKEN     | RW | 0: Disable the corresponding memory block; | 0   |
|        |           |    | 1: Enable the corresponding memory block.  |     |
|        |           |    | Wait function enable.                      |     |
| 1      | PWAITEN   | RW | 0: Disable;                                | 0   |
|        |           |    | 1: Enable.                                 |     |
| 0      | Reserved  | RO | Reserved                                   | 0   |

# 26.3.4 FIFO Status and Interrupt Registers 2 (FSMC\_SR2)

Offset address: 0x64

| 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24        | 23    | 22 | 21   | 20    | 19 | 18 | 17 | 16 |
|----------|----|----|----|----|----|----|-----------|-------|----|------|-------|----|----|----|----|
|          |    |    |    |    |    |    | Rese      | erved |    |      |       |    |    |    |    |
| 15       | 14 | 13 | 12 | 11 | 10 | 9  | 8         | 7     | 6  | 5    | 4     | 3  | 2  | 1  | 0  |
| Reserved |    |    |    |    |    |    | FEM<br>PT |       |    | Rese | erved |    |    |    |    |

| Bit    | Name     | Access | Description        | Reset value |
|--------|----------|--------|--------------------|-------------|
| [31:7] | Reserved | RO     | Reserved           | 0           |
|        |          |        | FIFO empty flag.   |             |
| 6      | FEMPT    | RO     | 0: FIFO not empty; | 1           |
|        |          |        | 1: FIFO empty.     |             |
| [5:0]  | Reserved | RO     | Reserved           | 0           |

# 26.3.5 General-purpose Memory Timing Registers 2 (FSMC\_PMEM2)

Offset address: 0x68

| _31          | 30            | 29 | 28 | 27 | 26 | 25 | 24 | 23            | 22 | 21 | 20    | 19      | 18 | 17 | 16 |  |
|--------------|---------------|----|----|----|----|----|----|---------------|----|----|-------|---------|----|----|----|--|
| MEMHIZx[7:0] |               |    |    |    |    |    |    | MEMHOLDx[7:0] |    |    |       |         |    |    |    |  |
| 15           | 14            | 13 | 12 | 11 | 10 | 9  | 8  | 7             | 6  | 5  | 4     | 3       | 2  | 1  | 0  |  |
|              | MEMWAITx[7:0] |    |    |    |    |    |    |               |    | N  | ЛЕMSI | ETx[7:0 | 0] |    |    |  |

| Bit     | Name          | Access | Description                                                                                                                                                                                           | Reset value |
|---------|---------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:24] | MEMHIZx[7:0]  | RW     | High-impedance time of the general memory data bus.  00000000: NAND FLASH is 0 HCLK cycles;  11111110: NAND FLASH is 254 HCLK cycles; 11111111: NAND FLASH is 255 HCLK cycles.                        | 0xFC        |
| [23:16] | MEMHOLDx      | RW     | General memory hold time. 00000000: Reserved; 00000001: 1 HCLK cycle; 11111110: 254 HCLK cycles; 11111111: 255 HCLK cycles.                                                                           | 0xFC        |
| [15:8]  | MEMWAITx[7:0] | RW     | General memory wait time. (Need to add the wait period introduced by the NWAIT signal going low) 000000000: Reserved; 00000001: 2 HCLK cycles; 11111110: 255 HCLK cycles; 111111111: 256 HCLK cycles. | 0xFC        |
| [7:0]   | MEMSETx[7:0]  | RW     | General memory setup time.  000000000: NAND FLASH 2 HCLK cycles;  11111110: NAND FLASH 256 HCLK cycles; 11111111: NAND FLASH 257 HCLK cycles.                                                         | 0xFC        |

# 26.3.6 Attribute Memory Timing Register 2 (FSMC\_PATT2)

Offset address: 0x6C

| 31            | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20    | 19     | 18 | 17 | 16 |
|---------------|----|----|----|----|----|----|----|----|----|----|-------|--------|----|----|----|
| ATTHIZx[7:0]  |    |    |    |    |    |    |    |    |    | A  | TTHO  | LDx[7: | 0] |    |    |
| 15            | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4     | 3      | 2  | 1  | 0  |
| ATTWAITx[7:0] |    |    |    |    |    |    |    |    |    |    | ATTSE | Tx[7:0 | ]  |    |    |

| Bit     | Name         | Access | Description                                           | Reset value |
|---------|--------------|--------|-------------------------------------------------------|-------------|
| [31:24] | ATTHIZx[7:0] | RW     | High-impedance time of the attribute memory data bus. | 0xFC        |

|         |               |    | 11111111: 255 HCLK cycles;                   |      |  |
|---------|---------------|----|----------------------------------------------|------|--|
|         |               |    | 11111110: 254 HCLK cycles;                   |      |  |
|         |               |    |                                              |      |  |
|         |               |    | 00000000: 0 HCLK cycles.                     |      |  |
|         |               |    | Attribute memory hold time.                  |      |  |
|         |               |    | 11111111: 255 HCLK cycles;                   |      |  |
|         |               |    | 11111110: 254 HCLK cycles;                   |      |  |
| [23:16] | ATTHOLDx[7:0] | RW | , , , , , , , , , , , , , , , , , , , ,      | 0xFC |  |
|         |               |    | 00000001: 1 HCLK cycle;                      |      |  |
|         |               |    | 00000000: Reserved.                          |      |  |
|         |               |    |                                              |      |  |
|         |               |    | Attribute memory wait time. (Need to add the |      |  |
|         |               |    | wait period introduced by the NWAIT signal   |      |  |
|         |               | RW | going low)                                   |      |  |
| [15:8]  | ATTWAITx[7:0] |    | 00000000: 1 HCLK cycle;                      | 0xFC |  |
| ` '     |               |    | 00000001: 2 HCLK cycles;                     |      |  |
|         |               |    |                                              |      |  |
|         |               |    | 11111111: 256 HCLK cycles;                   |      |  |
|         |               |    | 11111110: 255 HCLK cycles.                   |      |  |
|         |               |    | Attribute memory setup time.                 |      |  |
|         |               |    | 00000000: 1 HCLK cycle;                      |      |  |
| [7:0]   | ATTSETx[7:0]  | RW |                                              | 0xFC |  |
|         |               |    | 11111110: 255 HCLK cycles;                   |      |  |
|         |               |    | 11111111: 256 HCLK cycles.                   |      |  |

# 26.3.7 ECC Result Register2 (FSMC\_ ECCR2)

Offset address: 0x74

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24   | 23     | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|------|--------|----|----|----|----|----|----|----|
|    |    |    |    |    |    |    | ECC[ | 31:16] |    |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8    | 7      | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    | _  |    |    |    | ECC  | [15:0] |    |    |    |    |    |    |    |

| Bit    | Name      | Access | Description            | Reset value |
|--------|-----------|--------|------------------------|-------------|
| [31:0] | ECC[31:0] | RO     | ECC calculation result | 0           |

# 26.3.8 SRAM/NOR-Flash Write Timing Register1 (FSMC\_BWTR1)

Offset address: 0x104

| 31   | 30          | 29 | 28         | 27 | 26 | 25 | 24   | 23    | 22     | 21 | 20 | 19   | 18      | 17     | 16 |
|------|-------------|----|------------|----|----|----|------|-------|--------|----|----|------|---------|--------|----|
| Rese | erved       |    | MOD<br>:0] |    |    |    | Rese | erved |        |    |    | E    | BUSTY   | RN[3:0 | )] |
| 15   | 14          | 13 | 12         | 11 | 10 | 9  | 8    | 7     | 6      | 5  | 4  | 3    | 2       | 1      | 0  |
|      | DATAST[7:0] |    |            |    |    |    | 1    | ADDH  | LD[3:0 | ]  |    | ADDS | ET[3:0] |        |    |

| 1 | Bit | Name | Access | Description | Reset value |
|---|-----|------|--------|-------------|-------------|
|---|-----|------|--------|-------------|-------------|

| [31:30] | Reserved     | RO    | Reserved                              | 0     |  |
|---------|--------------|-------|---------------------------------------|-------|--|
|         |              |       | Access mode. (Valid when EXTMOD is 1) |       |  |
|         |              |       | 00: Access mode A;                    |       |  |
| [29:28] | ACCMOD[1:0]  | RW    | 01: Access mode B;                    | 00b   |  |
|         |              |       | 10: Access mode C;                    |       |  |
|         |              |       | 11: Access mode D.                    |       |  |
| [27:20] | Reserved     | RO    | Reserved                              | 1111b |  |
|         |              |       | Bus recovery time.                    |       |  |
|         | BUSTYRN[3:0] |       | 0000: 1 HCLK cycle;                   |       |  |
| [19:16] |              | RW    | 0001: 2 HCLK cycles;                  | 1111b |  |
| [19.10] |              | IX VV |                                       | 11110 |  |
|         |              |       | 1110: 15 HCLK cycles;                 |       |  |
|         |              |       | 1111: 16 HCLK cycles.                 |       |  |
|         | DATAST[7:0]  |       | Data retention time.                  |       |  |
|         |              |       | 00000000: Reserved;                   |       |  |
| [15:8]  |              | RW    | 00000001: 2 HCLK cycles;              | 0xFF  |  |
| [13:8]  |              |       |                                       | UXFF  |  |
|         |              |       | 11111110: 255 HCLK cycles;            |       |  |
|         |              |       | 11111111: 256 HCLK cycles.            |       |  |
|         |              |       | Address hold time.                    |       |  |
|         |              |       | 0000: Reserved;                       |       |  |
| [7:4]   | ADDHLD[3:0]  | RW    | 0001: 2 HCLK cycles;                  | 1111b |  |
| [/.4]   | ADDIILD[3.0] | IXVV  |                                       | 11110 |  |
|         |              |       | 1110: 15 HCLK cycles;                 |       |  |
|         |              |       | 1111: 16 HCLK cycles.                 |       |  |
|         |              |       | Address setup time.                   |       |  |
|         |              |       | 0000: 1 HCLK cycle;                   |       |  |
| [3:0]   | ADDSET[3:0]  | RW    | 0001: 2 HCLK cycles;                  | 1111b |  |
| [5.0]   | 7100001[3.0] | IXVV  |                                       | 11110 |  |
|         |              |       | 1110: 15 HCLK cycles;                 |       |  |
|         |              |       | 1111: 16 HCLK cycles.                 |       |  |

# **Chapter 27 Ethernet Transceiver (ETH)**

## This chapter applies to the whole family of CH32F20x, CH32V20x, CH32V30x and CH32V31x.

The "Ethernet transceiver" mentioned in this chapter is a proper term, which means the Ethernet (Ethernet) data link layer transceiver inside the microcontroller, the communication rate is up to gigabit per second (1Gbps), it is a communication peripheral. The "MAC" mentioned in this chapter refers to the role name of the Ethernet transceiver at the data link layer and is a component of the Ethernet transceiver.

Ethernet transceiver (Ethernet Transceiver MAC) is an important high-speed communication component of microcontroller, which allows microcontroller to access Ethernet at Gigabit connection speed to achieve extremely fast data communication.

# 27.1 CH32F207, CH32V307, CH32V317 Product

#### **27.1.1 Main Features**

The MAC of CH32V307 and CH32F207 chips supports MII/RMII/RGMII interface and has a built-in 10Mbps PHY; CH32V317 chip supports Ethernet controller MAC and built-in 10Mbps/100Mbps PHY.

Ethernet MAC controls PHY through SMI interface, and the timing of the interface is automatically realized by MAC, without the need for users to generate it through software. The RGMII interface supports the phase inversion of the transmission clock and the relative data delay, with a maximum delay of 4 nanoseconds.

Ethernet MAC supports Ethernet of standard IEEE802.3 protocol, magic frame and specific wake-up frame. The DMA controller matched with Ethernet transceiver manages data receiving and dispatching and carries memory in the form of descriptors. The number of descriptors is determined by the user according to the communication density. The DMA controller can write the received data into the memory space specified by descriptors or retrieve the data to be sent at a speed of 32 bits. In addition, the MAC of Ethernet transceiver also supports IEEE1588 precise time protocol.

### 27.1.1.1 MAC Features

- Support MII/RMII/RGMII interface
- RGMII supports transmit clock delay and inversion
- Support full-duplex and half-duplex, support 10M/100M/1000Mbps data transfer rate
- Support automatic insertion of frame header sequence and SFD
- Support automatic insertion and check CRC
- Support automatic calculation and verification of the checksum of IP/ICMP/TCP/UDP protocol packets
- Support sending frame length control
- Support sending gap adjustment
- Support VLAN frame
- Support perfect address filtering and HSAH filtering of frame receiving addresses
- Support frame sending address filtering
- Support multicast broadcast frame reception control
- Support promiscuous mode
- Support SMI management interface (one set each for RGMII and MII)
- Support magic frame and custom wake-up frame to wake up microcontroller
- Support dedicated Ethernet wake-up interrupt entry

- Support data loopback at the link layer
- CH32V307 and CH32F207 chip applications can be selected from Ethernet controller MAC+built-in 10Mbps PHY or external 1Gbps PHY.
- The application of CH32V317 chip is Ethernet controller MAC+with built-in 10Mbps/100Mbps PHY.

#### **27.1.1.2 DMA Features**

- 32-bit wide MAC dedicated DMA
- Minimize CPU operations
- Support access to RAM in a byte-aligned manner
- Manage send and receive buffers in the form of descriptors
- Part of the status feedback sent by the receiver is in the descriptor
- Can dynamically modify descriptors and buffers that are not in use
- Support manual stop or start
- Support chained or ringed formal connection descriptors
- Support multiple interrupt sources such as transceiver completion interrupt

#### 27.1.1.3 MMC Module Features

- Support manual reset, stop or freeze
- Multiple counters supporting multiple counting modes for sending and receiving
- Support multiple interrupts

## **27.1.1.4 PTP Module Features**

- Support IEEE 1588 protocol
- Support to automatically save the current moment when sending and receiving
- Come with a 32-bit second timer and a 32-bit signed sub-second timer
- Support to adjust the time in 2 ways: fine adjustment and coarse adjustment
- Single interrupt source
- Support PPS output

## 27.1.1.5 Internal 10M Physical Layer Features

- Support 10BASE-T
- Management via SMI interface
- Support MDIX automatic rollover
- Support differential pair p/n polarity flip of MDI interface
- Support manual reset
- Support data loopback at the physical layer
- Support half-duplex, full-duplex

## 27.1.1.6 Internal 10M/100M Physical Layer Features (For CH32V317)

- Support 10BASE-T and 100BASE-TX and auto-negotiation
- Support Auto-MDIX switching TX/RX and automatic identification of positive and negative signal lines
- Support RMII interface mode
- Support WOL network wake-up support
- Support interrupt function
- Support half-duplex, full-duplex

V2. 4 478 WH

#### Two network status LEDs

#### **27.1.2 Overview**

Ethernet transceivers work at the data link layer and physical layer in the OSI seven-layer model. If a data transmission rate greater than 10Mbps needs to be achieved, an external 100M or 1000M physical layer chip (PHY) is required to achieve physical connection. In order to establish the communication of protocols such as IP, TCP and UDP in the widely used Ethernet, the user also needs to implement the TCP/IP protocol stack in software. The Ethernet transceiver is composed of a media access control layer (MAC), a matching DMA and their control registers, and a 10M physical layer.



Figure 27-1 Position of Ethernet Transceivers in OSI Model and TCP/IP Model

The MAC of the Ethernet transceiver is designed according to the specifications of the IEEE802.3 protocol, and is equipped with a 32-bit wide DMA to ensure that the data can be quickly forwarded from the network cable to the memory of the microcontroller. The Ethernet transceiver has powerful and complete DMA control registers, MAC control registers and mode control registers. The microcontroller's CPU operates the registers of the Ethernet transceiver through the HB bus. The Ethernet transceiver is connected to the gigabit Ethernet physical layer through the RGMII interface. If only the speed of 100M Ethernet is required, it can be connected to the 100M Ethernet physical layer through the MII or RMII interface. The pins of the MII, RMII and RGMII interfaces of the Ethernet transceiver are multiplexed, see section 27.3 for details. The Ethernet transceiver manages the Ethernet physical layer through the SMI interface. When using an Ethernet transceiver, the clock of the HB bus cannot be lower than 50MHz.

MII DMA control & Media access Operation ΗВ Control MAC 802.3 RMII mode register status registers **RGMII** Checksum offload PTP **IEEE1588** 125MHz **External PHY PMT** MMC MDC MAC control **MDIO** registers Ethernet DMA RAM MDI Magnetics 10 BASE-T PHY

Figure 27-2 Block diagram of Ethernet Transceiver

In addition, the Ethernet transceiver also supports the IEEE1588 Precision Time Protocol (PTP) to provide precise time data for microcontroller systems or off-chip.

# 27.1.3 Ethernet transceiver pinouts and configuration

The microcontroller supports 3 MII interfaces, namely Standard MII, RMII and RGMII. The MII/RMII interface is dedicated to 10M and 100M Ethernet physical layers, and the RGMII interface can be used for 10M, 100M and Gigabit Ethernet. The following table shows the distribution of standard MII, RMII and RGMII interfaces and internal physical layers on package pins.

Table 27-1 Media independent interface of microcontroller, media dependent interface with built-in physical layer and other related pinouts and required configuration

|        | <u> </u>  | and other related pr | nouts una requ | irea comigaran |                       |
|--------|-----------|----------------------|----------------|----------------|-----------------------|
| Pinout | RGMII     | RGMII pin            | MII            | RMII           | MII/RMII pin          |
|        |           | configuration        |                |                | configuration         |
| D. O   | TYOLIA    |                      |                | DIO            | Push-pull multiplexed |
| PA2    | TXCLK     |                      | MI             | DIO            | output                |
| DC1    | DWCTI     | El .: .              | 3.6            | DC             | Push-pull multiplexed |
| PC1    | RXCTL     | Floating input       | M              | DC             | output                |
| PC0    | RXCLK     | Floating input       |                |                |                       |
| PA1    | RXD3      | Floating input       | RX_CLK         | REF_CLK        | Floating input        |
|        |           | Push-pull            |                |                |                       |
| PA7    | PA7 TXD0  | multiplexed          | RX_DV          | CRS_DV         | Floating input        |
|        |           | output               |                |                |                       |
|        |           | Push-pull            |                |                |                       |
| PC4    | TXD1      | multiplexed          | RXD0           | RXD0           | Floating input        |
|        |           | output               |                |                |                       |
|        |           | Push-pull            |                |                |                       |
| PC5    | TXD2      | multiplexed          | RXD1           | RXD1           | Floating input        |
|        |           | output               |                |                |                       |
|        |           | Push-pull            |                |                |                       |
| PB0    | TXD3      | multiplexed          | RXD2           |                | Floating input        |
|        |           | output               |                |                |                       |
| PB1    | 125MHz_IN | Floating input       | RXD3           |                | Floating input        |

| PB10 |       |                                    | RXER           |                  | Floating input               |  |  |  |
|------|-------|------------------------------------|----------------|------------------|------------------------------|--|--|--|
| PC3  | RXD1  | Floating input                     | TX_CLK         |                  | Floating input               |  |  |  |
| PB11 |       | TX_EN TX_EN Push-pull moutp        |                |                  |                              |  |  |  |
| PB12 | MDC   | Push-pull<br>multiplexed<br>output | TXD0           | TXD0             | Push-pull multiplexed output |  |  |  |
| PB13 | MDIO  | Push-pull<br>multiplexed<br>output | TXD1           | TXD1             | Push-pull multiplexed output |  |  |  |
| PC2  | RXD0  | Floating input                     | TXD2           |                  | Push-pull multiplexed output |  |  |  |
| PB8  |       |                                    | TXD3           |                  | Push-pull multiplexed output |  |  |  |
| PA0  | RXD2  | Floating input                     | CRS            |                  | Floating input               |  |  |  |
| PA3  | TXCTL | Push-pull<br>multiplexed<br>output | COL            |                  | Floating input               |  |  |  |
| PB5  |       | PPS_OUT (I                         | Push-pull mult | iplexed output)  |                              |  |  |  |
| PC6  |       | 10BASE-T_RX                        | _p (no IO conf | iguration requir | red)                         |  |  |  |
| PC7  |       | 10BASE-T_RX                        | _n (no IO conf | iguration requir | ed)                          |  |  |  |
| PC8  |       | 10BASE-T_TX                        | _p (no IO conf | iguration requir | ed)                          |  |  |  |
| PC9  |       | 10BASE-T_TX                        | _n (no IO conf | iguration requir | ed)                          |  |  |  |

# 27.1.4 Physical Layer (PHY) Management and Data Interaction

The MAC of the Ethernet transceiver manages the PHY through the site management interface (SMI interface), and uses the media independent interface (MII interface) to exchange data with the PHY. The MII interfaces supported by the microcontroller include standard MII (Usually written as MII), reduced MII (RMII) and reduced Gigabit MII (RGMII). The microcontroller uses different pins to bring out the SMI interface in MII/RMII mode and in RGMII mode.

## 27.1.4.1 SMI Interface

The SMI interface is a serial communication interface. It uses MDC (Clock line) and MDIO (Data line) to access the registers of the PHY to manage the PHY, and can manage up to 32 PHY chips. Where MDC is the clock line, which is kept low when idle, and MDIO is the data line. The read and write operations of SMI and the composition of the frame are dominated by the MAC, and the user only needs to write the address and data. The relevant registers are the MII address register (R32\_ETH\_MACMIIAR) and the MII data register (R32\_ETH\_MACMIIDR).

## 27.1.4.1.1 Frame Format

The format of the SMI interface management frame is shown in Table 27-2 below.

Table 27-2 SMI Frame Format

|       | Preamble | STR | OP | PHY ADR | REG ADR | T  | DATA            | P |
|-------|----------|-----|----|---------|---------|----|-----------------|---|
| Read  | 32 x "1" | 01  | 10 | PPPPP   | RRRRR   | Z0 | DDDDDDDDDDDDDDD | Z |
| Write | 32 x "1" | 01  | 01 | PPPPP   | RRRRR   | 10 | DDDDDDDDDDDDDDD | Z |

The fields of the management frame are defined as follows:

- 1) Preamble: Preamble, consisting of 32 "1"s, used for MAC and PHY synchronization;
- 2) STR: start character, fixed to "01";
- 3) OP: operator, read as "10", written as "01";
- 4) PHY ADR: physical layer address, 5 bits;
- 5) REG ADR: register address, 5 bits;
- 6) T: Converter, 2 bits, used to switch the control of the MDIO line between the MAC and the PHY. During the read operation, the MAC maintains a high impedance to the MDIO line, and the PHY maintains a high impedance to the first bit, pulls down on the second bit, and obtains control of the MDIO; during a write operation, the MAC first sets the MDIO line high and then pulls it down. PHY maintains a high-impedance state for MDIO, and MAC maintains control over MDIO;
- 7) DATA: data field, 16 bits, data read and written by MAC to PHY, MSB first;
- 8) P: Both MAC and PHY maintain a high-impedance state for MDIO, but the pull-up resistor of PHY will pull MDIO high.

# 27.1.4.1.2 Read and Write Timing

Writing to the PHY register operates as follows:

When the user sets the MII write bit (ETH\_MACMIIAR:MW) and the busy bit (ETH\_MACMIIAR: MB), the SMI interface will send the PHY address and register address to the PHY, and then send the data (ETH\_MACMIIDR). In the process of sending data through the SMI interface, the values of the MII address register and MII data register cannot be modified; during this process, the busy bit remains high, and the write operation to the MII address register or MII data register will be ignored, and the entire transmission is affected. When the write operation is completed, the SMI interface will clear the busy bit, and the user can judge the end of the write operation according to the busy bit. The write part of Figure 27-3.

The operation of reading the PHY register is as follows:

When the user sets the MII busy bit of the MII address register (ETH\_MACMIIAR) of the Ethernet MAC and keeps the MII write bit reset, the SMI interface sends the PHY address and register address, and performs the operation of reading the PHY register. During the entire transfer process, the user cannot modify the contents of the MII address register and the MII data register. During the transfer, the busy bit remains high, and writes to the MII address register or the MII data register will be ignored and will not affect the correct completion of the entire transfer. After the read operation is completed, the SMI interface will clear the busy bit and write the data read back from the PHY into the MII data register. The read section of Figure 27-3.

MDIO 32 1's 0 1 0 1 AAA A3 A2 A1 A0 R4 R3 R2 R1 R0 D15 D14 D0 Preamble of frame Code PHY address Register address Turn around data

Write Data to PHY

Read Data to PHY

Data to PHY

Data to PHY

Data to PHY

Figure 27-3 SMI interface read and write time diagram

#### 27.1.4.1.3 SMI Clock

Generally speaking, the SMI clock needs to be kept in a fixed range to ensure that the SMI clock actually needs to be received by the PHY. For details, refer to the manual of the PHY chip selected by the user.

The SMI clock frequency is divided from the HB clock by the CR field of the MII address register (ETH\_MACMIIAR). The following table shows the frequency division relationship between SMI clock and HB clock. By default, divide by 42 is selected.

|              | , i                          |             |  |  |
|--------------|------------------------------|-------------|--|--|
|              | Range of AHB clocks suitable | SMI clock   |  |  |
|              | for matching                 |             |  |  |
| 0000Ь        | Above 60MHz                  | HB clock/42 |  |  |
| 0010b        | 20-35MHz                     | HB clock/16 |  |  |
| 0011b        | 35-60MHz                     | HB clock/26 |  |  |
| other values | meaningless                  |             |  |  |

Table 27-3 Frequency division relationship between SMI clock and HB clock

#### 27.1.4.2 MII/RMII Interface

#### 27.1.4.2.1 Overview

Media Independent Interface (MII) is the interface for data communication between MAC and PHY. According to the speed and the number of leads, there are standard MII, RMII, GMII, RGMII and SGMII. The media independent interface generally has a group of receiving and transmitting, and each group is composed of a clock line, a number of data lines and auxiliary lines. The supported MII interfaces are: standard MII/RMII supports 10M and 100M physical layers, and RGMII supports 10M, 100M and 100M physical layers. Since the physical layers commonly used in the market are generally 10M/100M auto-negotiation physical layer, 10M/100M/1000M auto-negotiation physical layer, users should use standard MII/RMII interface when using 10M/100M auto-negotiation physical layer, and when using 10M/100M auto-negotiation physical layer /100M/1000M physical layer, users should use RGMII interface.

In general, the clock and data in the transmit direction (At the beginning of TX) of the media independent interface are sent by the MAC, and the clock and data in the receive direction (At the beginning of RX) are sent by the PHY, but the RMII clock is common. For the pin wiring in the same direction, pay attention to the equal-length wiring. For specific wiring points, please refer to the Layout manual of the physical layer chip selected by the user or Section 27.1.4.2.2 in this manual.

V2. 4 483 WCH

# 27.1.4.2.2 Pins

MII Pins and functions of the interface are as follows:

Table 27-4 MII Interface pins and functions

| Pins | Features                         |  |  |  |
|------|----------------------------------|--|--|--|
| TXC  | Transmit clock (2.5MHz or 25MHz) |  |  |  |
| TXEN | Transmit data enable             |  |  |  |
| TXD0 |                                  |  |  |  |
| TXD1 | Transmit data lines [0:3]        |  |  |  |
| TXD2 |                                  |  |  |  |
| TXD3 |                                  |  |  |  |
| RXC  | Receive clock (2.5MHz or 25MHz)  |  |  |  |
| RXDV | Received data valid              |  |  |  |
| RXER | Received data error              |  |  |  |
| RXD0 |                                  |  |  |  |
| RXD1 | Receive data lines [0:3]         |  |  |  |
| RXD2 |                                  |  |  |  |
| RXD3 |                                  |  |  |  |
| COL  | Collision detection              |  |  |  |
| CRS  | Carrier detect                   |  |  |  |

Figure 27-4 shows how the MAC and PHY are connected using the definition of the MII interface.

Figure 27-4 Ethernet transceiver using MII interface, how to wire MAC and PHY



The pins and functions of the RMII interface are as follows:

Table 27-5 Pins and functions of the RMII interface

| Pins    | Features                       |  |  |  |  |  |  |
|---------|--------------------------------|--|--|--|--|--|--|
| CLK_REF | Receive/transmit clock (50MHz) |  |  |  |  |  |  |
| TXEN    | Transmit data enable           |  |  |  |  |  |  |
| TXD0    | T                              |  |  |  |  |  |  |
| TXD1    | Transmit data lines [0:1]      |  |  |  |  |  |  |
| CRSDV   | Received data valid            |  |  |  |  |  |  |
| RXD0    | Receive data lines [0:1]       |  |  |  |  |  |  |

RXD1

When using the RMII interface, the transceiver clocks share the same line for transmission, and the clock frequency is fixed at 50MHz. When RMII is used at a rate of 10Mbps, RX and TX sample data every 10 cycles, and the data line needs to retain data for 10 cycles; MAC and PHY need to use the same clock source. The MCO output of the MAC can be connected to the external clock source input pin of the PHY. Figure 27-5 shows how the MAC and PHY are wired when using the RMII interface.

TXD[1:0]

TX\_EN

RXD[1:0]

RXDV

MDC

MDC

MDIO

REF\_CLK

Clock source

Figure 27-5 Wiring diagram of MAC and PHY when using RMII interface

Note: The Ethernet transceiver needs to input the externally provided REF\_CLK 50MHz clock frequency from the RXC pin.

## 27.1.4.2.3 Timing

Difference in timing between RMII and MII:

- The clock of RMII is fixed at 50MHz, while the transceiver clock of MII works at 2.5MHz or 25MHz depending on the actual connection speed;
- RMII transceivers share the same clock line;
- RMII is a 2-bit data line, while MII is a 4-bit data line.

Figure 27-6 shows the timing of RMII and MII.



Figure 27-6 Timing diagram of MII and RMII

#### 27.1.4.3 RGMII interface

#### 27.1.4.3.1 Pins

The pins and functions of the RGMII are as follows

Table 27-6 RGMII pins and functions

| ·     | phis and functions        |  |  |  |
|-------|---------------------------|--|--|--|
| Pins  | Features                  |  |  |  |
| TXC   | Transmit clock            |  |  |  |
| TXCTL | Transmit data control     |  |  |  |
| TXD0  |                           |  |  |  |
| TXD1  | Transmit data lines [0:3] |  |  |  |
| TXD2  | Transmit data mies [0.5]  |  |  |  |
| TXD3  |                           |  |  |  |
| RXC   | Receive clock             |  |  |  |
| RXCTL | Receive data control      |  |  |  |
| RXD0  |                           |  |  |  |
| RXD1  | Receive data lines[0:3]   |  |  |  |
| RXD2  | receive data mes[0.3]     |  |  |  |
| RXD3  |                           |  |  |  |

Note: 1. TXCTL/RXCTL is used in the Ethernet transceiver of this microcontroller as a valid signal for sending and receiving data;

## 27.1.4.3.2 Timing

RGMII works in 10M and 100M rate modes, and the timing is similar to MII; when working in gigabit, the clock of RGMII is 125MHz, and the double-edge sampling method is adopted. RGMII does not support half-duplex.

Since RGMII uses double-edge sampling and operates at a clock frequency of 125MHz, circuit designers should be aware of signal integrity issues.

The clock received by the receiver of the RGMII should lag the data by 90° to ensure correct sampling. Ethernet transceivers are designed to transmit clock delay output and phase inversion.

Figure 27-7 RGMII timing diagram



# 27.1.4.4 Considerations When Using Internal 10M and 100M Physical Layers

27.1.4.4.1 Considerations When Using Internal 10M Physical Layer (Only for CH32F207, CH32V307)

V2. 4 486 WCH<sup>\*</sup>

<sup>2.</sup> RGMII has an independent SMI interface.

When the internal physical layer enable bit of the extension register is set, all MII-related configurations will be ignored, the read and write of the SMI interface will be directly mapped to the internal physical layer, and the physical layer address written by the SMI interface will be ignored. Users can access the internal physical layer registers to get the physical layer connection status, see Section 27.1.8.5 for details.

# 27.1.4.4.2 Considerations When Using Internal 10/100M Physical Layer (Only for CH32V317)

The internal 10/100M physical layer is configured by the Control register (address 0x00) and Auto-Negotiation Advertisement (address 0x04) registers, the relevant configuration bits have been turned on by default, for the relevant registers, please refer to the CH182DS2 manual.

The 10/100M Ethernet transceiver uses the RMII interface with MAC and internal PHY wiring as shown below:



Pin distribution and configuration related to RMII interface used by 10/100M Ethernet transceiver are shown in the following table (the following pins are only used for EHT):

| Pin  | RMII  | Pin configuration of RMII    |
|------|-------|------------------------------|
| PE7  | RSTB  | Push-pull multiplex output   |
| PE8  | TXEN  | Push-pull multiplex output   |
| PE9  | CRSDV | Floating input               |
| PE10 | TXD1  | Push-pull multiplex output   |
| PE11 | TXD0  | Push-pull multiplex output   |
| PE12 | TXC   | Push-pull multiplex output   |
| PE13 | RXD1  | Floating input               |
| PE14 | RXD0  | Floating input               |
| PE15 | MDC   | Push-pull multiplex output   |
| PD8  | MDIO  | Push-pull multiplex output / |
|      |       | Floating input               |

## 27.1.4.5 Clock generation and output

# 27.1.4.5.1 Peripheral clock source configuration



Figure 27-8 Ethernet peripheral clock tree

The clock of the internal 10M Ethernet physical layer is provided by PLL3 and must be 60MHz. When using the internal physical layer, the second bit of the extension register needs to be set. After setting, the settings related to MII/RMII/RGMII are invalid.

When using MII, the transceiver clock is provided by the external physical layer, which is 2.5MHz or 25MHz. When using RMII, REF\_CLK is the only clock, which is input to the microcontroller from the RXC pin, and is fixed at 50MHz. When using RMII, the 23rd bit in the AFIO remapping register needs to be set.

When using RGMII, the MAC needs a clock with a frequency of 125MHz, which is generated by the VCO of the internal PLL2/PLL3 (The VCO output is twice the output frequency of the PLL) or an external input, and the 125MHz clock is input through the EXT\_125M pin. The transmit clock of RGMII is generated by the MAC, and the receive clock is generated by the PHY. To turn on RGMII, you need to set bit 3 in the extension registers, set bit 22 in the second configuration register of RCC, and select the appropriate 125MHz clock source in [21:20]. For details, see EVT routines on the official website.

#### 27.1.4.5.2 MCO Output

It is known that MCO supports output of 8 clocks, namely HSE, HSI, system clock frequency, PLLCLK/2, PLL2CLK, PLL3CLK, PLL3CLK/2 and XTI. Users can use MCO to output the frequency required in the application, such as 25MHz clock required by common physical layer chips to save a crystal. The output frequency of the MCO should not be greater than 100MHz.

# 27.1.5 IEEE802.3 and IEEE1588

The IEEE802.3 protocol and its supplementary protocols constitute the official standard of the current Ethernet, which defines all aspects of the currently used Ethernet in detail. We can think of Ethernet as part of the physical layer and data link layer in the OSI model. This section discusses the parts that users need to use in the IEEE802.3 protocol from the application point of view, that is, the frame format and the content related to the MAC address. At the same time, the Ethernet transceiver of the microcontroller also supports the IEEE1588 Precision Time Protocol, which will also be discussed in part in this article.

In the Ethernet model constructed by the IEEE802.3 protocol, the data transmission unit is an Ethernet frame. Ethernet frames have different encoding forms when transmitted on different media at different rates. After receiving, they are decoded by the physical layer and sent to the MAC through the MII interface. After the MAC checksum is filtered, it is extracted by the TCP/IP protocol stack. Application information is sent to different application processes.

#### 27.1.5.1 Frame Format

The frame format of an Ethernet frame is shown in Table 27-7.

**Target** Source Preamble SFD Data field **CRC** Length/Type address address 7 Bytes 6 Bytes 6 Bytes 2 Bytes 46-1500 Bytes 1Byte 4 Bytes

Total length: 64 to 1518 bytes plus 8 bytes of physical layer header (Preamble and SFD)

Table 27-7 Normal Ethernet frame format

Preamble: 56-bit (7 bytes) alternating low-level and high-level jumps, the value is fixed, which is 0xAA-0xAA-0xAA-0xAA-0xAA-0xAA in hexadecimal. This field is used for clock synchronization. This field is added/removed automatically by the hardware and the user does not need to care about it.

SFD: Frame start delimiter, 8 bits (1 byte), the value is 10101011b, SFD is used to remind the receiver that this is the last opportunity to synchronize the clock, followed by the target address. This byte is automatically added/removed by the hardware, and the user does not need to care about it.

Destination address: The device that sends this frame wants to receive the device address of this frame, and the address here refers to the hardware address, also known as the MAC address, which is assigned by the IEEE for the manufacturer, globally unique, 6-byte (48-bit). The MAC addresses of WCH microcontrollers have been programmed into the devices when they left the factory. The transmission of the address follows the principle of the least significant bit first.

Source Address: The hardware address of the device that sent this frame. The source address must be a unicast address.

Length/Type: 2 bytes, Ethernet is generally used as a type, and is also used as a length in the IEEE802.3 standard. It is demarcated by 1536 (i.e. 0x0600). The protocol above 1536 indicates which upper-layer protocol the data part is organized according to, for example, 0x0806 means ARP, 0x0800 means IPv4, 0x86dd means IPv6; below 1536 means data length.

Data field: Minimum 46 bytes, maximum 1500 bytes. When the data field is less than 46 bytes, you need to add padding to 46 bytes, and if it exceeds 1500 bytes, please create another frame. The data field is loaded with the data that needs to be actually sent.

CRC: Cyclic Redundancy Check, the CRC32 check is used here.

## 27.1.5.2 Frame Transmitting

When the Ethernet transceiver sends a data frame, its dedicated DMA controller takes out the data to be sent from the RAM specified by the transmit descriptor (Trans descript in Section 27.1.4.1.1) and pushes it into the MAC through the dedicated data bus. The filling level of the FIFO will be returned to the DMA controller. When all the data to be sent is sent, the DMA controller will send a data start signal to the MAC, and the MAC will start sending; read the data from the FIFO and send pilot, SFD, and sends actual data to MII interface

(RMII/RGMII); after the DMA controller sends the data end signal to the MAC, the MAC adds the automatically calculated CRC.

The MAC will calculate the checksum for the checksum field according to the type of the frame sent by the configured automatic device, and replace the value of the original checksum field. This feature can be turned off.

The MAC will automatically add the CRC32 check to the padding, or it can be set to not add the CRC check bit. According to the provisions of the IEEE802.3 protocol, the length of the data field is not less than 46 bytes. When the MAC detects that the data field to be sent is shorter than 46 bytes, it will automatically add padding after the number field. If automatic padding is selected, then The CRC32 checksum must be added, ignoring the register configuration. The CRC32 verification formula used by the MAC is as follows:

$$G(x) = x^{32} + x^{26} + x^{23} + x^{22} + x^{16} + x^{12} + x^{11} + x^{10} + x^8 + x^7 + x^5 + x^4 + x^2 + x + 1$$

When the IEEE 1588 (PTP) function is enabled, the MAC will save the current timestamp in the descriptor when sending an Ethernet frame, but will overwrite some information at the same time, and the user can read the timestamp and complete the descriptor in time to receive the interrupt.

#### 27.1.5.3 Frame Receiving

When the Ethernet transceiver receives the Ethernet frame, the Ethernet frame enters the MAC from MII, RMII or RGMII, first enters the FIFO in the MAC, and then is forwarded to the buffer in the RAM by the DMA. The MAC will filter and check the Ethernet frame. The filtering includes perfect address filtering and HASH filtering. The inspection then typically performs frame length, IP/ICMP/TCP/UDP checks and CRC checks on frames that do not pass the filtering or checks are marked out by the descriptor or dropped, and packets that exceed the length may be choked off.

With the IEEE 1588 (PTP) function enabled, the MAC will save the current timestamp in the descriptor when the frame is received, but at the same time it will overwrite part of the information, so the user can read the timestamp and complete the descriptor in time to receive the interrupt.

## 27.1.5.4 Frame Filtering

Use the MAC frame filter to perform perfect filtering or HASH filtering on the destination MAC address and source MAC address of the received frame, and can set the frame that does not pass the filtering to be discarded, received, or marked in the receive descriptor. Please read the description of the MAC frame filter register (R32\_ETH\_MACFFR) for this function. The MAC has 4 built-in MAC address registers, of which MAC address register 0 is used by default to store its own MAC address, and the remaining 3 MAC address registers can be used for perfect filtering, compared with the source address or destination address of the received frame. After setting R32\_ETH\_MACFFR:RA, all received frames will be received, but the corresponding status will be marked in the status field of the first word of the descriptor after that, if R32\_ETH\_MACFFR:PM is set, there will have a similar effect, but the state will not be marked. After setting R32\_ETH\_MACFFR: DAIF/SAIF, the result will be flipped. Those that pass the filtering will be discarded or marked, and those that do not pass the filtering will be transferred to the buffer in RAM.

#### 27.1.5.4.1 Unicast Filtering

The MAC uses the HPF bit and the HU bit to determine whether the unicast frame is HASH filtering or perfect address filtering.

## 27.1.5.4.2 Multicast Filtering

The MAC uses the HPF bit and the HM bit to determine whether the multicast frame is HASH filtered or perfect address filtering. When the PAM bit is set, all multicast packets can pass through the filter.

# 27.1.5.4.3 Broadcast Filtering

By setting the BFD bit, the MAC can block all broadcast packets.

# 27.1.5.4.4 Source Address Filtering Selection

The MAC address register can be enabled by setting the AE bit in the MAC address register, while setting the SA bit determines whether the MAC address register is to be compared as a source or target address sample.

## 27.1.5.4.5 **Summary**

The filter settings for target address and source address are shown in Table 27-8 and Table 27-9 respectively.

Table 27-8 Acceptance of the setting of each bit of R32\_ETH\_MACFFR to the target MAC address of the received frame

|           |   |    |   | 100  | civeu ma |     |                                  |
|-----------|---|----|---|------|----------|-----|----------------------------------|
| Frame     | M | PF | U | DAIF | M        | PAM | Effect                           |
| type      |   |    |   |      |          |     |                                  |
| Broadcast | 1 | -  | - | -    | -        | -   | Pass                             |
| frame     | 0 | -  | - | -    | 1        | -   | Fail (BFD set)                   |
|           | 1 | -  | - | -    | -        | -   | All frames pass                  |
|           | 0 | -  | 0 | 0    | -        | -   | Pass when perfect filter matches |
|           | 0 | -  | 0 | 1    | -        | -   | Fail when perfect filter matches |
| Unicast   | 0 | 0  | 1 | 0    | -        | -   | Pass when HSAH filter matches    |
| frame     | 0 | 0  | 1 | 1    | -        | -   | Fail when HSAH filter matches    |
|           | 0 | 1  | 1 | 0    | -        | -   | Pass when perfect filter or HSAH |
|           |   |    |   |      |          |     | filter matches                   |
|           | 0 | 1  | 1 | 1    | -        | -   | Fail when perfect filter or HSAH |
|           |   |    |   |      |          |     | filter matches                   |
|           | 1 | -  | - | -    | -        | -   | Pass                             |
|           | - | -  | - | -    | -        | 1   | Pass                             |
|           | 0 | -  | _ | 0    | 0        | 0   | Pass when perfect filter matches |
|           | 0 | 0  | - | 0    | 1        | 0   | Pass when HSAH filter matches    |
| Multicast | 0 | 1  | - | 0    | 1        | 0   | Pass when perfect filter or HSAH |
| frame     |   |    |   |      |          |     | filter matches                   |
|           | 0 | -  | - | 1    | 0        | 0   | Fail when perfect filter matches |
|           | 0 | 0  | - | 1    | 1        | 0   | Fail when HSAH filter matches    |
|           | 0 | 1  | - | 1    | 1        | 0   | Fail when perfect filter or HSAH |
|           |   |    |   |      |          |     | filter matches                   |

Table 27-9 Acceptance of the setting of each bit of R32\_ETH\_MACFFR to the source MAC address of the received frame

| Frame<br>Type | RA | SAIF | SAF | Effect          |
|---------------|----|------|-----|-----------------|
| Unicast       | 1  | -    | -   | All frames pass |

| frame | 0 | 0 | 0 | Passes on perfect filter match, marks but does not discard failed frames   |
|-------|---|---|---|----------------------------------------------------------------------------|
|       | 0 | 1 | 0 | Do not pass on perfect filter match, mark but do not discard failed frames |
|       | 0 | 0 | 1 | Pass when perfect filter matches, discard failed frames                    |
|       | 0 | 1 | 1 | Fail when perfect filter matches, discard failed frames                    |

Note: "-" indicates that the setting of this bit is of no concern.

#### 27.1.5.5 MMC

The function of the management counter (MMC) is mainly to count the receiving and sending status of various instruction frames and the running status of the MAC. It can generate settings and generate interrupts. In general, we can get the number of currently received good frames by receiving the "good" frame counter (MMCRGUFCR), get the number of successfully sent frames by sending the "good" frame counter (MMCTGFCR), and get the number of frames successfully sent by receiving the CRC error frame counter (MMCRFCECR) to check whether there is a frame with CRC error received, in general, if the data is correct but the CRC is wrong, it can be considered that there is a problem with the RGMII line layout.

Users need to be clear about a concept: what kind of frame is a "good" frame. Under normal circumstances, as long as a frame starts to send, its frame length meets the requirements (Automatic padding is turned on), and automatic CRC calculation is turned on, then it will be a "good" frame. And a frame is received, as long as its CRC is correct, the frame length is within the Ethernet frame length range, the frame length and the value of the length field are the same (If the length type field indicates the length), or there is no misalignment, then it will be considered a "good" received frame.

## 27.1.5.6 PMT

#### 27.1.5.6.1 Overview

The function of the PMT (Power management) part is to wake up the microcontroller from a low-power mode via Ethernet. The Gigabit Ethernet controller supports 2 types of frames to wake up the system, magic frames and (Remote) wake-up frames. When Ethernet receives these 2 kinds of frames, because the microcontroller is in low-power mode, it does not necessarily generate a receive interrupt, even if it is legal, but if it is recognized by the MAC's magic frame and wake-up frame, it will generate PMT interrupt, PMT interrupt is a separate interrupt from the Ethernet interrupt. By querying the PMT control and status registers, you can find out which Ethernet frame generated the interrupt.

# **27.1.5.6.2** Magic Frame

The magic frame (Magic package, also called magic data packet) defined by AMD is a commonly used Ethernet frame to wake up the microcontroller. It has a fixed and special frame format, that is, the target network card can receive it through frame filtering. It can be encapsulated into a broadcast frame, and there are 6 consecutive bytes of full height (OXFF) in the frame, followed by the MAC address of the target network card repeated 16 times. This combination can exist anywhere in the frame, so magic frames can be encapsulated into Mac frames or IP packets or even UDP packets. Below is the format of the magic frame. xx xx xx xx xx xx xx (Unlimited previous data, even no previous data)—ff ff ff ff ff ff 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02 84 c2 e4 01 02 02

### **27.1.5.6.3** Wakeup Frame

Due to the limitation of the format of the magic frame, the format of the (Remote) wakeup frame can be defined by the user. As long as the Ethernet frame passes through the remote wakeup frame filter register (ETH\_MACRWUFFR) group, it is regarded as a wakeup frame. Users can define the wakeup frame that meets their needs by setting the remote wakeup frame filter register group. It should be noted that the remote wakeup frame filter register group has only single address entry, the user can write data to it through 8 consecutive write operations, and then read the data originally written into the remote wakeup frame filter register by reading data 8 consecutive times.

The structure of the remote wakeup frame filter register group is as follows:

Filter register 0 Filter byte mask of register 0 Filter register 1 Filter byte mask of register 1 Filter register 2 Filter byte mask of register 2 Filter register 3 Filter byte mask of register 3 Filter 3 Filter 2 Filter 1 Filter 0 Filter register 4 Reserved Reserved Reserved Reserved command command command command Filter 3 offset Filter 2 offset Filter 1 offset Filter register 5 Filter 0 offset Filter 1 CRC-16 Filter 0 CRC-16 Filter register 6 Filter register 7 Filter 3 CRC-16 Filter 2 CRC-16

Table 27-10 Structure of the remote wakeup frame filtering register bank

As can be seen from the above table, the four fields of the filter register, byte mask, command, offset, and filter, work together to determine whether a frame is a remote wake-up frame. In fact, four different frames that meet the requirements can be set.

The highest bit of the 32-bit byte mask must be 0. Bit[30:0] corresponds to the first 31 bytes of data defined by the offset field. If any bit is set to 1, it indicates that the corresponding byte participates in CRC- 16 parity, and up to 31 bytes participate in calculation;

The highest bit of the 4-bit command field indicates what kind of frame it works on. 1 is only valid for multicast addresses, 0 is only valid for unicast addresses; the 2nd and 1st bits of the command field are reserved, and bit 0 is Enable bit, set high to enable this set of filters;

The offset field indicates how many bytes are offset from the beginning of the frame to calculate the CRC16 value. The minimum value is 12. If the offset field is 12, the CRC16 value is calculated starting from the 13th byte at the beginning. (Parametric model using CRC-16-IBM with default parameters)

The filter stores the value of the CRC result that the user expects to calculate. The MAC will compare the value of the CRC16 calculated by itself with the value in this field. If they are consistent, it will be regarded as a (remote) wake-up frame. If used If the wake-up frame interrupt and PMT interrupt are disabled, a PMT interrupt will also be generated.

In addition, according to the bit definition of the PMT control status register, if the GU bit is set, the unicast frame that passes the frame filter will also be considered a wake-up frame.

#### 27.1.5.7 IEEE1588 PTP

#### 27.1.5.7.1 PTP Principle and Implementation

The IEEE1588 standard defines a set of precise protocols for acquiring time, and its goal is to achieve time synchronization within 10 microseconds of error. The original NTP protocol can already achieve time synchronization at the level of 200 microseconds, but in fact this level cannot meet the time synchronization requirements in the field of industrial automation, so the Network Precision Clock Synchronization Committee

drafted the PTP protocol, which was approved by the IEEE Standards Committee at the end of 2002 as the IEEE1588 standard.

The implementation of the PTP protocol requires both the host and the slave to accurately record the time when the MAC receives and sends Ethernet frames, which requires both the host and the slave to have their own set of high-precision time counters. Then, the master and slave supporting PTP perform time synchronization through a set of procedures, and the slave can obtain the time difference between itself and the master and correct it. The following figure shows the process of master-slave time synchronization:



Figure 27-9 IEEE1588 PTP protocol synchronization message timing diagram

Step-by-step description:

- The master sends a syn message to the slave, and the slave receives this message and records the local time t<sub>2</sub> when the syn message is received;
- The master sends a follow\_up message to the slave, including the master time t<sub>1</sub> when the master sends the syn message;
- The slave sends a delay req message to the master, and the slave records the sending time t<sub>3</sub>;
- The master sends a delay\_resq message to the slave, including the reception time t<sub>4</sub> of the delay\_req message;

In actual use, the host sends out a syn message every 2 seconds, and every other syn message can be regarded as the follow\_up message of the previous syn message, and they will all be accompanied by the sending time of the last syn message. Through this process, the slave can know the delay time Tdelay from the master network to the slave network, and then calculate the time offset between the master time and the slave time.

Tdelay = 
$$\frac{(t_2-t_1)+(t_4-t_3)}{2}$$

The time sent by either host minus the offset is the host's time.

The synchronization process of PTP is generally implemented through the UDP protocol, of course, the user can also implement a custom protocol. PTP is highly dependent on the latency stability of the intranet.

#### 27.1.5.7.2 Local Time Update and Correction

In order to implement the PTP host, the device needs to have a high-precision time counter locally, at least to the nanosecond level. The PTP module of the microcontroller's Gigabit Ethernet counter has a 32-bit counter in seconds, and a 31-bit sub-second counter. When the sub-second counter overflows, it will cause the second

counter to increment automatically, so the resolution of the local time. The rate can be done around 0.46 nanoseconds.

There are 2 ways to update the local time, namely coarse correction and fine correction. The update timing of the coarse correction mode is determined externally. When the time update is required, the time update bit (PTPTSCR: TSSTU) of the time stamp control register is set, and the PTP module of the microcontroller subtracts or adds the value of the timestamp update registers (TSHUR, TSLUR) to the second counter and sub-second counter. Coarse correction is a simpler and more convenient time update mechanism, but less precise.

The fine correction time update method is more commonly used. The update process is as follows:



Figure 27-10 Process for updating time using fine correction

The way to use the fine correction mode requires a clear understanding of the system frequency and the fine correction process. Different from the coarse correction mode, the timing of the update event in the fine correction mode is the overflow of the accumulator (32 bits, not listed in the register list. The Accumulator register in the figure) overflows, and the accumulator will automatically increment the number register in each system clock cycle. The value of (PTPTSAR, Addend register in the figure) will generate a time update event once it overflows, that is, the value of the sub-second auto-increment register (PTPSSIR, Constant Value in the figure) will be added to the sub-second counter (Sub-second register), complete time update. The second counter is incremented when the sub-second counter overflows. In fact, the time for the sub-second counter to increment by one bit is  $1/(2^31)=0.46566128730...$ nanoseconds. The user needs to ensure that the time spent on the accumulator overflow is exactly equal to the value of the sub-second auto-increment register multiplied by the sub-second the time for the counter to increment by one bit.

The correction of local time is relatively simple. Set the time correction bit (PTPTSCR: TSSTI) of the time stamp control register, and the value of the second counter and sub-second counter will be replaced by the value of the time stamp update counter (TSHUR, TSLUR).

## 27.1.6 DMA Operation

### 27.1.6.1 Overview

In an Ethernet transceiver, data enters the FIFO from the MII interface and is then transferred into RAM by DMA. Even for the largest ordinary Ethernet frame, the data part reaches the maximum 1500 bytes, and it only

takes about tens of microseconds to receive and transmit. Even with the receiving detection of the MAC, the DMA transfer time and the frame interval time are counted, a frame needs to be processed by the CPU in 100us. The advantages of Ethernet transceivers are fast speed and large throughput. In order to maintain this advantage, it is necessary to minimize the intervention of the CPU in the process of receiving and sending Ethernet frames. Here, a dedicated DMA for Ethernet transceivers is used.

The DMA used by Ethernet is 32-bit, and it is managed by the CPU through 2 data structures: traditional control and status registers, and receive and transmit descriptors. Since the DMA is 32 bits wide, the base address of the transceiver descriptor queue in RAM is required to be aligned with 4 bytes. There is no alignment requirement for the receive/transmit buffer.

# 27.1.6.2 DMA Descriptor

Users use traditional peripherals mainly by writing the control bits of the register, and by reading the status register to obtain the status and return information of the peripheral. These registers are independent of the core, space outside of SRAM and non-volatile memory, and actually exist, and can be called "hardware registers". Traditional communication peripherals, such as USART or SPI, have a data register to temporarily store the data sent and received, and a set of DMA to store all received data in a specific address space.

The Ethernet transceiver is different from the traditional communication transceiver because of its extremely high data transmission speed, great data throughput and unique data frame organization. The Ethernet transceiver receives a large amount of data as densely as possible. It must store the received data stream in a separate memory space in units of frames, and complete the receiving and sending operations by itself, so that the CPU can read it with a minimum of operations. And dispose of these data, release the corresponding memory space, and ensure that the DMA controller and the CPU will not conflict with the memory usage rights. The single size of the buffer that is opened up to temporarily store the Ethernet frame in the memory is generally set to the maximum packet length of the Ethernet frame. IEEE802.3 stipulates that it is 1518 bytes (Including the source-end hardware address, length or type field and CRC32 calibration). The number of buffers for sending and receiving Ethernet frames is determined by the user according to the frequency of actual interaction and the memory resources of the microcontroller.

The buffer of the Ethernet frame is organized in the form of a queue. In the receiving direction, the Ethernet frame is written into the memory by DMA through the MAC, and is read and dequeued by the CPU; in the sending direction, the Ethernet frame is written to the memory and queued by the CPU, read by DMA and pushed into the transmit FIFO and out of the queue. The depth of the queue is the number of buffers. Different from ordinary communication peripherals, the starting address and number of the buffer of the Ethernet frame are not fixed in a certain register, but are managed by a special type of data structure, which is stored in the memory. A single such data structure unit manages a buffer, which holds the start address, length of the buffer, the settings that the DMA controller needs to make when calling this buffer, the send status of the write-back when the DMA send is completed, and the next such data structure the address of. This data structure plays the role of the traditional communication peripheral control register and status register, but the actual location is in the memory, so it can be called "software register", and the official name is "DMA descriptor".

DMA descriptors are divided into 2 types: sending and receiving, and each format is fixed. The storage structure of DMA descriptors is divided into 2 types, one is linked list form, that is, the fourth word of each descriptor is the address of the next descriptor, and the DMA controller will directly read the next descriptor from TDes3/RDes3. The other is a ring structure, where all descriptors must be closely arranged, DMA control takes a descriptor from the end of the current descriptor, when the DMA controller detects the TER/RER bit of TDes4/RDes4, i.e., from the beginning of the descriptor list. The address of the descriptor array must be 4-byte aligned, and the size of a single descriptor is 16 bytes.

Figure 27-11 A buffer allocation scheme which describes the ring structure and the chain structure for

0



# reference when users allocate space.

# 27.1.6.2.1 Transmit DMA Descriptor

31

Figure 27-11 shows the structure of the transmit descriptor.

Table 27-11 Structure of the transmit descriptor



It can be seen from the above table that the send descriptor is composed of 4 32-bit words, namely TDes0, TDes1, TDes2 and TDes3, of which TDes9 is used for control and return transmission status, TDes1 is used to indicate the transmission length, and TDes2 is used to indicate the transmission buffer. The position of the zone or the low bit of the return transmit timestamp, TDes3 is used to indicate the address for the second transmit buffer (When TCH is not set) or the address of the next descriptor (When TCH is set), timestamp is enabled When it is sent, the high bit of the IEEE1588 timestamp will be returned. Each 32-bit word is described below.

Table 27-12 Definitions of TDes0 bits

|     |    |    |    |    | Table . | 2/-12 | Demmi | 10113 01 | IDC | o ons |     |    |     |     |     |
|-----|----|----|----|----|---------|-------|-------|----------|-----|-------|-----|----|-----|-----|-----|
| 31  | 30 | 29 | 28 | 27 | 26      | 25    | 24    | 23:2     | 2   | 21    | 19  | 19 | :18 | 17  | 16  |
| OWN | IC | LS | FS | DC | DP      | TTE   | Res   | CIC      |     | TER   | TCH | R  | es  | TSS | IHE |
|     |    |    |    |    |         |       |       |          |     |       |     |    |     |     |     |
| 15  | 14 | 13 | 12 | 11 | 10      | 9     | 8     | 7        | 6   | 5     | 4   | 3  | 2   | 1   | 0   |

V2. 4 497 **WCH**\*

|    |     |     |      |       |     | 1       |      |       |       |    |     |    |
|----|-----|-----|------|-------|-----|---------|------|-------|-------|----|-----|----|
| EC | TT  | PP. | IDE  | TCA   | NIC | 100     | EC   | 17T   | 00    | ED | TIE | DD |
| H. |     | HH  | IPE  | I C A |     | 1 ( ( ) | H( ' | I V H | ( ( ' |    | LIH | DB |
| LO | 0 1 | 11  | 11 1 | LCI   | 110 | LCC     |      | V I   |       |    | O1  | טט |
|    |     |     |      |       |     |         |      |       |       |    |     |    |

| Bit   | Name     | Description                                                          |
|-------|----------|----------------------------------------------------------------------|
|       |          | Descriptor own                                                       |
|       |          | This bit indicates who occupies this descriptor.                     |
|       |          | 0: This descriptor is owned by the CPU, and the CPU can modify       |
|       |          | the value of this descriptor;                                        |
|       |          | 1: This descriptor is owned by the DMA, and the CPU cannot           |
| 31    | OWN      | modify this descriptor.                                              |
| 31    | OWIN     | When this bit is 0, it is set to 1 by the CPU after the CPU          |
|       |          | completes the operation on the descriptor and buffer. When this      |
|       |          | bit is 1, 0 is automatically written by the DMA after the DMA        |
|       |          | completes the operation on the descriptor and the buffer. In this    |
|       |          | way, the user software and hardware complete the operation           |
|       |          | handover of the descriptor and the receive/transmit buffer.          |
|       |          | Transmission completed interrupt enable                              |
| 30    | IC       | When this bit is set, the transmission interrupt bit flag            |
|       |          | (ETH_DMASR: TS) will be set after the current frame is sent.         |
|       |          | Last segment                                                         |
| 29    | LS       | This bit is set to indicate that the buffer indicated by this        |
|       |          | descriptor contains the end of the frame.                            |
|       |          | First segment                                                        |
| 28    | FS       | This bit is set to indicate that the buffer indicated by this        |
|       |          | descriptor contains the beginning of the frame.                      |
|       |          | Disable automatic CRC calculation                                    |
|       |          | When this bit is set, the DMA controller will not calculate the      |
| 27    | DC       | CRC32 value of the Ethernet frame, and no value will be              |
|       |          | appended to the end of the frame. This bit is only valid when the    |
|       |          | FS bit is set. Also, the setting of the DP bit takes precedence over |
|       |          | this bit.                                                            |
|       |          | Disable auto-padding                                                 |
|       |          | When this bit is set, the DMA controller will not add auto-          |
| 26    | DP       | padding for Ethernet frames less than 64 bytes. When this bit is     |
| 20    |          | 0, DMA will automatically add padding and CRC value to               |
|       |          | Ethernet frames less than 64 bytes, regardless of whether DC is      |
|       |          | set.                                                                 |
|       |          | Timestamp transmission enable                                        |
|       |          | On the premise that ETH_PTPTSCR: TSE is set, the DMA                 |
| 25    | TTE      | controller will enable the IEEE1588 timestamp function in the        |
|       |          | Ethernet frame indicated by the face descriptor after this bit is    |
|       |          | set. This bit is only valid when FS is set.                          |
| 24    | Reserved | Reserved                                                             |
|       |          | Checksum and insert control                                          |
| 23:22 | CIC      | 00: Prohibit insertion of checksum;                                  |
|       |          | 01: Only enable the calculation and insertion of IP header           |
|       |          | checksum;                                                            |

|       |          | 10: Reserved;                                                                                                                                                                                                                                                                                                                                     |
|-------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |          | 11: Enable calculation and insertion of IP header checksum and payload checksum, enable calculation of pseudo-header                                                                                                                                                                                                                              |
|       |          | checksum.                                                                                                                                                                                                                                                                                                                                         |
|       |          | Transmit descriptor end flag setting                                                                                                                                                                                                                                                                                                              |
| 21    | TER      | Users set this bit to indicate to the DMA controller that the current transmit descriptor is the last descriptor of the transmit descriptor array. The DMA controller will next read the first descriptor in the transmit descriptor array.                                                                                                       |
|       |          | Next descriptor addresses valid                                                                                                                                                                                                                                                                                                                   |
| 20    | ТСН      | This bit is set to indicate that the second address is the address of the next descriptor and not the address of the next buffer. When this bit is set, the value of TBS2 has no effect. This bit is only valid when the FS bit is set. The TER bit has higher priority than this bit.                                                            |
| 19:18 | Reserved | Reserved                                                                                                                                                                                                                                                                                                                                          |
|       |          | Transmit timestamp status                                                                                                                                                                                                                                                                                                                         |
| 17    | TSS      | DMA controller sets this bit to indicate that the transmit                                                                                                                                                                                                                                                                                        |
|       |          | timestamp is captured and stored in TDes2 and TDes3.                                                                                                                                                                                                                                                                                              |
| 16    | ІНЕ      | IP header error DMA controller checks the IP header according to the received data: for IPv4, the DMA controller checks whether the length field of the header is correct; for IPv6, the DMA controller checks whether the header is 40 bytes. In addition, the IP protocol type must be the same as the type/length field in the Ethernet frame. |
| 15    | ES       | Error summary Set by the DMA controller if an error occurs while sending a frame. The ES bit is set when one of the following bits is set: UF[TDES0:1] data underflow error bits; IPE[TDES0:12] IP data error bits; FF[TDES0:13] frame empty bits; JT[TDES0:14] Jabber timeout bits; IHE[TDES0:16] IP header error bits.                          |
| 14    | JT       | Jabber timeout When this bit is set, a jabber timeout error occurs at the MAC transmitter. This bit is only set when the JD bit (ETH_MACCR:22) is not set.                                                                                                                                                                                        |
| 13    | FF       | Frame flushed This bit is set to indicate that the DMA controller clears the frame from FIFO due to the command issued by the CPU.                                                                                                                                                                                                                |
| 12    | IPE      | IP payload error The MAC compares the total packet length in the IPv4 or IPv6 header of the received TCP/UDP/ICMP packet with the actual packet length, and set this bit if they are inconsistent.                                                                                                                                                |
| 11    | LCA      | Lose carrier                                                                                                                                                                                                                                                                                                                                      |
|       |          | I.                                                                                                                                                                                                                                                                                                                                                |

V2. 4 499 WCH<sup>®</sup>

|     |       | This bit is set to indicate that a carrier loss occurs when the frame  |
|-----|-------|------------------------------------------------------------------------|
|     |       | is sent, that is, the CSR signal is invalid. This bit only works in    |
|     |       | half-duplex mode.                                                      |
|     |       | No carrier                                                             |
| 1.0 | 1.7.0 | This bit indicates that the carrier sense signal of the physical layer |
| 10  | NC    | is invalid when the frame is sent. This bit only works in half-        |
|     |       | duplex mode.                                                           |
|     |       | Late collision                                                         |
| 9   | LCO   | This bit indicates that the frame collided after sending the           |
|     |       | preamble. This bit only works in half-duplex mode.                     |
|     |       | Excessive collisions                                                   |
|     |       | This bit indicates that a collision of more than 16 bits occurs        |
| 8   | EC    | when the frame is sent. If the RD bit in MACCR is set, this bit        |
|     |       | indicates that only one collision is sent. This bit only works in      |
|     |       | half-duplex mode.                                                      |
| 7   | VF    | VLAN frame. Set when sending VLAN frames.                              |
|     |       | Collision counter                                                      |
| 6:3 | CC    | These bits indicate how many collisions the frame had when it          |
| 0.3 |       | was sent. No effect when EC is set. These bits only works in half-     |
|     |       | duplex mode.                                                           |
|     |       | Excessive deferral                                                     |
| 2   | EC    | This bit is set to indicate that when the DC in MACCR is set, the      |
| 2   | LC    | transmission of the frame fails due to the delay of more than          |
|     |       | 24288 bits. This bit only works in half-duplex mode.                   |
|     |       | UF data underflow error                                                |
|     |       | When the DMA controller fetches data from the specified RAM            |
| 1   | UF    | and finds that the buffer is empty, the transmission enters the        |
|     |       | suspended state, and sets this bit and the relevant bit of the         |
|     |       | DMASR register.                                                        |
|     |       | Deferred bit                                                           |
| 0   | DB    | This bit is set to indicate that the transmission fails due to carrier |
|     |       | occupancy. This bit only works in half-duplex mode.                    |

## Table 27-13 Definitions of TDes1 bits

|    |          |    |    |    | 10010 | -, 10 |    |    |      | 01 0100 |    |    |    |    |    |
|----|----------|----|----|----|-------|-------|----|----|------|---------|----|----|----|----|----|
| 31 | 30       | 29 | 28 | 27 | 26    | 25    | 24 | 23 | 22   | 21      | 20 | 19 | 18 | 17 | 16 |
| R  | Reserve  | ed |    |    |       |       |    |    | TBS2 |         |    |    |    |    |    |
|    |          |    |    |    |       |       |    |    |      |         |    |    |    |    |    |
| 15 | 14       | 13 | 12 | 11 | 10    | 9     | 8  | 7  | 6    | 5       | 4  | 3  | 2  | 1  | 0  |
| F  | Reserved |    |    | •  | •     |       |    |    | TBS1 |         |    |    |    |    |    |

| Bit   | Name     | Description                    |
|-------|----------|--------------------------------|
| 31:29 | Reserved | Reserved                       |
| 28:16 | TBS2     | Size of the transmit buffer 2. |
| 15:13 | Reserved | Reserved                       |

| 12:0 | TBS1 | Size of the transmit buffer 1. |
|------|------|--------------------------------|
|------|------|--------------------------------|

#### Table 27-14 Definitions of TDes2 bits

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24   | 23     | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|------|--------|----|----|----|----|----|----|----|
|    |    |    |    |    |    | -  | ГВАО | 1/TTSI | _  |    |    |    |    |    |    |

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8   | 7     | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|-----|-------|---|---|---|---|---|---|---|
|    |    |    |    |    |    | ] | BAD | 1/TTS | L |   |   |   |   |   |   |

| Bit  | Name       | Description                                                                                                                                                                                                                                                                                                        |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | TBAD1/TTSL | All 32 bits of TDes2 are used as a whole unit to store the address of the transmit buffer 1. When IEEE1588 mode is enabled, TDes2 is used to store the timestamp returned by the MAC at the end of transmission, and the MAC clears the OWN bit (TDes0: 31). This field stores the lower 32 bits of the timestamp. |

## Table 27-15 Definitions of TDes3 bits

| TDAD2/TTSH |  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 20 | 17 | 16 |
|------------|--|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| IDAD2/TISH |  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8    | 7      | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|------|--------|---|---|---|---|---|---|---|
|    |    |    |    |    |    | Τ | DAD2 | 2/TTSI | Н |   |   |   |   |   |   |

| Bit  | Name       | Description                                                                                                                                                                                                                                                                                                                                                        |
|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | TDAD2/TTSH | This field is used to store the address of the next descriptor. When TCH is not set, this field stores the address of the transmit buffer 2. When IEEE1588 mode is enabled, TDes3 is used to store the timestamp returned by the MAC at the end of transmission, and the MAC clears the OWN bit (TDes0: 31). This field stores the upper 32 bits of the timestamp. |

## 27.1.6.2.2 Receive DMA Descriptor

Table 27-16 Receive descriptor structure

31

| RDes0 | OWM(31)      |                                                              | State (30:0)                |              |             |                            |  |  |  |  |
|-------|--------------|--------------------------------------------------------------|-----------------------------|--------------|-------------|----------------------------|--|--|--|--|
| RDes1 | Control (31) | Reserved (30:29)                                             | Buffer 2-byte count (28:16) | RER (15:14)  | Reserved 13 | Buffer 1 byte count (12:0) |  |  |  |  |
| RDes2 |              |                                                              | Buffer 1 address,           | timestamp lo | ow          |                            |  |  |  |  |
| RDes3 |              | Buffer 2 address, address of next descriptor, timestamp high |                             |              |             |                            |  |  |  |  |

It can be seen from the above figure that the receiving descriptor is also composed of 4 32-bit words, of which the first 32-bit word mainly returns the state when receiving, the second 32-bit word contains the received data length, and the third 32-bit word defines the address of the receive buffer or the low order of the return timestamp, the fourth 32-bit word is the address of the second buffer (RCH is not set), the address of the next buffer (RCH is set) or Returns the high order bit of the timestamp.

The meanings of bits of the receive descriptor are as follows:

Table 27-17 Definitions of RDes0

| 31  | 30  | 29:16 |
|-----|-----|-------|
| OWN | AFM | FL    |

| 15 | 14 | 13  | 12 | 11 | 10   | 9  | 8  | 7     | 6   | 5  | 4   | 3  | 2  | 1  | 0   |
|----|----|-----|----|----|------|----|----|-------|-----|----|-----|----|----|----|-----|
| ES | DE | SAF | LE | OE | VLAN | FS | LS | IPHCE | LCO | PT | RWT | RE | DE | CE | PCE |

| Bit   | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | OWN  | Descriptor own This bit indicates who occupies this descriptor.  0: This descriptor is owned by the CPU, and the CPU can modify the value of this descriptor;  1: This descriptor is owned by the DMA, and the CPU cannot modify this descriptor.  When this bit is 0, it is set to 1 by the CPU after the CPU completes the operations on the descriptor and buffer. When this bit is 1, 0 is automatically written by the DMA after the DMA completes the operations on the descriptor and buffer. In this way, the operation handover of the descriptor and the receive/transmit buffer between the user software and the hardware is completed. |
| 30    | AFM  | Destination address filter fail  This flag is set if the received frame does not pass the MAC's target address filter.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 29:16 | FL   | Frame length This field is valid when ES (RDes0:15) is 0. When LS (RDes0:8) is 1, this field indicates the length of the frame received by the DMA controller, including the CRC. When LS is 0, this field indicates the cumulative length sent to the memory by the DMA controller so far, the unit is in bytes.                                                                                                                                                                                                                                                                                                                                   |
| 15    | ES   | Error summary  Set when the MAC detects any of the following errors:  CE[RDes0:1]: CRC error;  RE[RDes0:3]: Receive error;  RWT[RDes0:4]: Watchdog timeout;  IPHCE[RDes0:7]: Jumbo frame (note that it is necessary to distinguish whether it is a jumbo frame or an IP header error when reporting IPHCE);  OE[RDes0:11]: Overflow error;  DE[RDes0:14]: Descriptor error.                                                                                                                                                                                                                                                                         |
| 14    | DE   | Descriptor error This bit is set to indicate that the buffer indicated by the descriptor is cut off as                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

|    |       | the buffer indicated by the descriptor cannot fit the current frame, and the DMA does not occupy the next descriptor. This bit is only valid when the LS bit                                                                                                                                                                                         |
|----|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    |       | (RDes0 [8]) is set.                                                                                                                                                                                                                                                                                                                                  |
| 13 | SAF   | Source address filter fail This bit is set to indicate that the frame does not pass the source address filter of the MAC.                                                                                                                                                                                                                            |
| 12 | LE    | Length error Set to indicate that the actual received frame length does not match the length indicated in the Ethernet Type/Length field. This bit is only valid when FT (RDes0 [5]) is set.                                                                                                                                                         |
| 11 | OE    | Overflow error Set to indicate that the received frame is corrupted due to an overflow of the receive FIFO.                                                                                                                                                                                                                                          |
| 10 | VLAN  | VLAN tag Set to indicate that a VLAN frame is received.                                                                                                                                                                                                                                                                                              |
| 9  | FS    | First descriptor This bit indicates that this descriptor contains the beginning of the frame.                                                                                                                                                                                                                                                        |
| 8  | LS    | Last descriptor  It indicates that this descriptor contains the end of the frame.                                                                                                                                                                                                                                                                    |
| 7  | ІРНСЕ | IP header checksum error This bit is set to indicate that there is an error in the IPv4 or IPv6 header. The specific reasons may be:  1. The protocol indicated by the Ethernet frame type/length field is inconsistent with the actual IP version;  2. The IP header checksum is incorrect;  3. The length indicated by the IP header is incorrect. |
| 6  | LCO   | Late collision Set to indicate that a late collision occurs. This bit only works in half-duplex mode.                                                                                                                                                                                                                                                |
| 5  | FT    | Frame type indication bit.  1 indicates that the received frame is an Ethernet type encapsulated frame (RFC 894).  0 indicates that the received frame is an IEEE802.3 type encapsulated frame (RFC1042). This bit is invalid when the frame length is less than 14 bytes.  Note: Refer to Table 27-18 for the special meaning of FT.                |
| 4  | RWT   | Receive watchdog timeout  Set to indicate that when the current frame is received, the watchdog times out and the current frame is truncated.                                                                                                                                                                                                        |
| 3  | RE    | Receive error Set to indicate that the RX_ERR signal is valid when RX_DV is valid in the process of receiving a frame.                                                                                                                                                                                                                               |
| 2  | DE    | Dribble bit error Set to indicate that the length of the frame received by the MAC is not multiples of the 8-bit frame, and the period may be missed.                                                                                                                                                                                                |
| 1  | СЕ    | CRC error This bit is set to indicate that the received frame has a CRC check error. This                                                                                                                                                                                                                                                            |

V2. 4 503 WCH°

|   |     | bit is valid only when the LS bit (RDes0 [8]) is set.                        |
|---|-----|------------------------------------------------------------------------------|
|   |     | Payload checksum error                                                       |
| 0 | PCE | This bit is set to indicate that the TCP/UDP/ICMP packet received by the MAC |
|   |     | does not match the value indicated in the checksum field.                    |

It can be seen that the verification mechanism is implemented in the receiving process of the MAC. In fact, the data length of this layer is described at the Ethernet frame layer (Data link layer), network layer (IPv4/IPv6) and transport layer (TCP/UDP/SCTP), and some check measures are taken to ensure the correctness of the data content. The 0<sup>th</sup>, 5<sup>th</sup> and 7<sup>th</sup> bits of Des0 are related to the checksum of the data, which is summarized in the following table.

Table 27-18 Relationship between the value of Des0:7/5/0 and the status of the received frame

| RDES0:7 | RDES0:5 | RDES0:0 | F.,                                                                                              |  |  |  |  |  |  |  |
|---------|---------|---------|--------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| IPHCE   | FT      | PCE     | Frame status                                                                                     |  |  |  |  |  |  |  |
| 1       | 1       | 1       | For IP frames, there are parity errors at the IP layer and the transport layer.                  |  |  |  |  |  |  |  |
| 1       | 1       | 0       | For IP frames, there is a check error at the IP layer.                                           |  |  |  |  |  |  |  |
| 1       | 0       | 1       | For IP frames, there is a check error at the transport layer.                                    |  |  |  |  |  |  |  |
| 1       | 0       | 0       | For IP frames, no checksum errors were detected.                                                 |  |  |  |  |  |  |  |
| 0       | 1       | 1       | Non-IP frame, no inspection detection performed.                                                 |  |  |  |  |  |  |  |
| 0       | 1       | 0       | Reserved                                                                                         |  |  |  |  |  |  |  |
| 0       | 0       | 1       | For IP frames, unsupported transport layer protocols, no IP layer checksum errors were detected. |  |  |  |  |  |  |  |
| 0       | 0       | 0       | Frames whose length/type fields are less than 0x0600.                                            |  |  |  |  |  |  |  |

| RDes0:5                       | RDes0:7                                   | RDes0:0                            |                                                                                                           |  |  |  |  |  |  |  |
|-------------------------------|-------------------------------------------|------------------------------------|-----------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| Frame Type Indicator Bit (FT) | IP header checksum error flag bit (IPHCE) | Load<br>checksum<br>error<br>(PCE) | Frame status                                                                                              |  |  |  |  |  |  |  |
| 1                             | 0                                         | 0                                  | IP type frame, IP header not detected and load checksum error                                             |  |  |  |  |  |  |  |
| 1                             | 0                                         | 1                                  | IP type frame, load checksum error                                                                        |  |  |  |  |  |  |  |
| 1                             | 1                                         | 0                                  | IP type frame, IP header checksum error                                                                   |  |  |  |  |  |  |  |
| 1                             | 1                                         | 1                                  | IP type frame, IP header checksum error, load checksum error                                              |  |  |  |  |  |  |  |
| 0                             | 0                                         | 0                                  | IEEE802.3 Type Encapsulated Frame (RFC1042)                                                               |  |  |  |  |  |  |  |
| 0                             | 0                                         | 1                                  | IP type frame, IP header checksum error not detected, not detected because load checksum is not supported |  |  |  |  |  |  |  |
| 0                             | 1                                         | 1                                  | Not an IP type frame (e.g. ARP frame)                                                                     |  |  |  |  |  |  |  |
| 0                             | 1                                         | 0                                  | Reserved                                                                                                  |  |  |  |  |  |  |  |

Table 27-19 Definitions of RDes1 bits

| 31  | 30         | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22  | 21 | 20 | 19 | 18 | 17 | 16 |
|-----|------------|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|
| DIC | C Reserved |    |    |    |    |    |    |    | RBS | 2  |    |    |    |    |    |

| 15  | 14  | 13  | 12 | 11   | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|-----|-----|----|------|----|---|---|---|---|---|---|---|---|---|---|
| RER | RCH | Res |    | RBS1 |    |   |   |   |   |   |   |   |   |   |   |

| Bit   | Name     | Description                                                                                                                                                                                                                    |
|-------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | DIC      | Disable reception completion interrupt setting bit.                                                                                                                                                                            |
| 30:29 | Reserved | Unused.                                                                                                                                                                                                                        |
| 28:16 | RBS2     | Receive buffer 2 size.                                                                                                                                                                                                         |
| 15    | RER      | End receive descriptor flag. It indicates that the current descriptor is the last descriptor. The DMA controller will go back to the Descriptor Pair Column Base Address Register (ETH_DMARDLAR) to fetch the next descriptor. |
| 14    | RCH      | Next receive descriptor address valid bit. This bit is set to indicate that in the last 32-bit word is the address of the next receive descriptor, otherwise the address of the second buffer.                                 |
| 13    | Reserved | Unused.                                                                                                                                                                                                                        |
| 12:0  | RBS1     | Receive buffer 1 size.                                                                                                                                                                                                         |

#### Table 27-20 Definitions of RDes2 bits

|    | Table 27-20 Definitions of KDes2 bits                               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|----|---------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 31 | 30                                                                  | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|    | RBAD1/RTSL                                                          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|    |                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15 | 15   14   13   12   11   10   9   8   7   6   5   4   3   2   1   0 |    |    |    |    |    |    |    |    |    |    |    |    |    | 0  |
|    | RBAD1/RTSL                                                          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit  | Name      | Description                                                                                                                                                                                                                                                    |
|------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RBAD/RTSL | All 32 bits of RDes2 are used as a whole unit to store the address of the receive buffer. When IEEE1588 mode is enabled, RDes2 is also used to store the timestamp returned by the MAC at the end of reception, and the MAC will clear the OWN bit (RDes0:31). |

## Table 27-21 Definitions of RDes3 bits

| 31                                                                  | 30         | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|---------------------------------------------------------------------|------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|                                                                     | RDAD2/RTSH |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|                                                                     |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15   14   13   12   11   10   9   8   7   6   5   4   3   2   1   0 |            |    |    |    |    |    |    |    |    |    |    |    |    | 0  |    |
| RDAD2/RTSH                                                          |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit  | Name      | Description                                                                                                                                                                                                                                  |
|------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RDAD/RTSH | Used to store the address of the next buffer when RCR is set, otherwise used to store the address of the second buffer. When IEEE1588 mode is enabled, RDes3 is used to store the timestamp returned by the MAC at the end pf reception, and |

| the MAC will clear the OWN bit (RDes0:31). This field stores |
|--------------------------------------------------------------|
| the upper 32 bits of the timestamp.                          |

#### 27.1.6.3 Data Cache Alignment

Since both the transceiver buffer and the transceiver descriptor are called by the DMA controller and exist in the RAM space, and the DMA is 32-bit, it is necessary to ensure that their start addresses are aligned in 4 bytes when setting the transceiver descriptor queue, but setting the buffer does not require this forcibly.

In order to improve efficiency, it is most appropriate that an Ethernet frame is received by a buffer. For example, setting the buffer to 1518 bytes can accommodate the largest Ethernet ordinary frame, including source-end address field, length type field, Data padding field and CRC field. It should be noted that the maximum frame length of the tagged VLAN frame is 4 bytes longer than the general Ethernet frame, that is, 1522 bytes. If the user wants to achieve 4-byte alignment, a buffer can be 1524 bytes.

#### 27.1.6.4 DMA Transceiver Configuration

The data received and sent is automatically dumped and pushed by the DMA, but if a fatal error is encountered, the DMA will stop and update the DMA status register. The user needs to manually start the DMA after initializing the DMA to continue running.

#### 27.1.6.4.1 Transmit DMA Configuration

The steps for the DMA controller to establish the operating mechanism are as follows:

- Set up the transmit buffer queue and fill the transmit buffer with the content to be sent. Set up the transmit descriptor queue, fill in the fields of the transmit descriptor, set OWN, and deliver the management right of the transmit descriptor to the DMA controller; register the initial address of the descriptor in the DMATDLAR register;
- 2) Set the ST bit (DMAOMR: 13) to enable DMA;
- 3) In Run mode, the DMA descriptor will automatically read the content of the transmit descriptor, and push the data to the transmit FIFO according to the address and length indicated by it. After finishing the DMA, it will read the next transmit descriptor immediately following the chain structure for the next transmission. When the DMA controller detects that the OWM bit is not set, resulting in no access to the transmit descriptor or other normal errors, it will terminate the transfer and set the TBUS bit (DMASR: 2) or other bits (Other than errors caused by OWN being 0) and the NIS bit (DMASR:16) is set.
- 4) A single frame is not allowed to span multiple descriptors; a frame must be clearly associated with a descriptor and a buffer.
- 5) If the MAC turns on the IEEE1588 PTP mode, after the DMA controller pushes the data to the FIFO, the MAC will write the transmit timestamp to TDes2 and TDes3, and reset the OWN bit.
- 6) After sending a frame, if the transmit descriptor enables the transmit completion interrupt (Set TDes1:31), the DMA controller will set the transmit completion interrupt flag (DMASR:0), and then continue to fetch the next transmit descriptor.

The following figure shows the default process of transmission.



Figure 27-11 Process of transmission

#### 27.1.6.4.2 Receive DMA Configuration

The steps to establish a DMA receive flow mechanism are as follows:

- Set the transmit buffer queue and descriptor queue, and set up the bits of each field of the receive descriptor; register the initial address of the descriptor in the DMARDLAR register; set the OWN bit to give the descriptor use permission to the DMA controller;
- 2) Set the SR bit to start the receiving process;
- When the receive flow mechanism is running, the DMA controller obtains the next descriptor, checks the receiving descriptor configuration, and when the FIFO receives the next frame, performs multiple checks such as filtering and identifying the frame content, and forwards the frame data to the buffer specified by the symbol, writes the descriptor status field and obtains the next receiving descriptor, and reports the receiving completion interrupt. If the frame does not pass the filtering, it will be marked or discarded. If the frame has a checksum error, CRC error or the frame is too short, it will be marked. If the frame is too long, it may be cut off or receive a watchdog timeout error. The DMA controller will stop the receiving process when it encounters a fatal error such as the unavailability of the receive descriptor, and the user needs to pay special attention;
- 4) The user needs to enable at least one receive completion interrupt, and restore the used receive descriptor to the standby state in the Ethernet interrupt function to ensure that the receive process can run

- uninterrupted. The user can pass the address of the data buffer to be processed in the interrupt function, or handle some abnormal events that interrupt the receiving process.
- 5) If the PTP timestamp is enabled, the DMA controller dumps the data and writes the descriptor status field, and also writes the current timestamp into the last 2 words of the descriptor. The user should read the timestamp in time and complete the buffer address and the next descriptor address originally written in the last 2 words.

The following figure shows the default flow mechanism of reception:



Figure 27-12 Process of reception

#### 27.1.7 Interrupt

The Ethernet transceiver has 2 interrupt vectors, one is the Ethernet wake-up event and the other is the normal transceiver event. When a wake-up frame or magic frame is detected, an Ethernet wake-up event is triggered. Common Ethernet transceiver interrupt events include DMA interrupt and ETH interrupt.

#### 27.1.7.1 DMA Interrupt

DMA interrupts can be roughly divided into 2 groups, namely normal interrupts (NIS) and abnormal interrupts (AIS). Abnormal interrupts generally mean abnormal data transmission and reception, which requires special attention. When processing interrupts, users need to retrieve all interrupt flag bits and process all generated interrupt sources. The following figure is a schematic diagram of the interrupt of the Ethernet transceiver.

V2. 4 508 WCH<sup>\*</sup>

TIE <u>M</u>MCI TBUS PMTI TBUIE. TSTI NIS. RIE ERIE FBES FBEIE **TPSS** TPSSIE. TJTS TITIE ROS TUS TUIE RBU RBUIE. RPSS RPSSIE RWTS. ETS ETIE

Figure 27-13 Interrupt schematic

The DMA interrupt is the most important interrupt in the Ethernet transceiver. Generally, user logic needs to rely on interrupts to receive frames, confirm that the frames are sent, or deal with the interrupted transceiver logic in time.

#### **27.1.7.2 ETH Interrupt**

The ETH interrupt mainly includes the time alarm trigger of PTP, the sending and receiving count to a certain set value of the MMC register, and the PMT. The usefulness of ETH is mainly functional, not very complex and important relative to DMA interrupts. Users can use PTP interrupt for alarm clock, MMC interrupt for speed measurement, or PMT interrupt for remote wake-up. In addition, ETH also supports interrupts when the state of the built-in physical layer connection changes.

#### 27.1.7.3 PMT Interrupt

The reason why the PMT interrupt is raised separately and reiterated is that this interrupt has an independent interrupt vector and needs to be paid attention to when using it.

#### 27.1.8 Register Description

Table 27-22 Ethernet registers

MAC control register address mapping

| Name              | Offset Address | Description                     | Reset Value |
|-------------------|----------------|---------------------------------|-------------|
| R32_ETH_MACCR     | 0x40028000     | MAC control register            | 0x00000000  |
| R32_ETH_MACFFR    | 0x40028004     | Frame filter register           | 0x00000000  |
| R32_ETH_MACHTHR   | 0x40028008     | Hash value list register high   | 0x00000000  |
| R32_ETH_MACHTLR   | 0x4002800C     | Hash value list register low    | 0x00000000  |
| R32_ETH_MACMIIAR  | 0x40028010     | MII address register            | 0x00000000  |
| R32_ETH_MACMIIDR  | 0x40028014     | MII data register               | 0x00000000  |
| R32_ETH_MACFCR    | 0x40028018     | MAC flow control register       | 0x00000000  |
| R32_ETH_MACVLAN   | 0x4002801C     | VLAN tag register               | 0x00000000  |
| R32_ETH_MACRWUFFR | 0x40028028     | Wake-up frame filter register   | 0x00000000  |
| R32_ETH_MACPMTCSR | 0x4002802C     | PMT control and status Register | 0x00000000  |

| R32_ETH_MACSR   | 0x40028038 | MAC interrupt status register         | 0x00000000 |
|-----------------|------------|---------------------------------------|------------|
| R32_ETH_MACIMR  | 0x4002803C | MAC interrupt mask register           | 0x00000000 |
| R32_ETH_MACA0HR | 0x40028040 | MAC address register 0 high 32 bits   | 0x8000FFFF |
| R32_ETH_MACA0LR | 0x40028044 | MAC address register 0 low 32 bits    | 0xFFFFFFFF |
| R32_ETH_MACA1HR | 0x40028048 | MAC address register 1 high 32 bits   | 0x0000FFFF |
| R32_ETH_MACA1LR | 0x4002804C | MAC address register 1 low 32 bits    | 0xFFFFFFFF |
| R32_ETH_MACA2HR | 0x40028050 | MAC address register 2 high 32 bits   | 0x0000FFFF |
| R32_ETH_MACA2LR | 0x40028054 | MAC address register 2 low 32 bits    | 0xFFFFFFFF |
| R32_ETH_MACA3HR | 0x40028058 | MAC address register 3 high 32 bits   | 0x0000FFFF |
| R32_ETH_MACA3LR | 0x4002805C | MAC address register 3 low 32 bits    | 0xFFFFFFF  |
| R32_ETH_MACCFG0 | 0x40028098 | MAC software reset control register 0 | 0x00000000 |

## MMC control register address mapping, note: the addresses are not consecutive

| Name                | Address    | Description                                              | Reset Value |
|---------------------|------------|----------------------------------------------------------|-------------|
| R32_ETH_MMCCR       | 0x40028100 | MMC control register                                     | 0x00000000  |
| R32_ETH_MMCRIR      | 0x40028104 | MMC receive register                                     | 0x00000000  |
| R32_ETH_MMCTIR      | 0x40028108 | MMC transmit interrupt register                          | 0x00000000  |
| R32_ETH_MMCRIMR     | 0x4002810C | MMC receive interrupt mask register                      | 0x00000000  |
| R32_ETH_MMCTIMR     | 0x40028110 | MMC transmit interrupt mask register                     | 0x00000000  |
| R32_ETH_MMCTGFSCCR  | 0x4002814C | MMC transmit good frame counter after single conflict    | 0x00000000  |
| R32_ETH_MMCTGFMSCCR | 0x40028150 | MMC transmit good frame counter after multiple conflicts | 0x00000000  |
| R32_ETH_MMCTGFCR    | 0x40028168 | MMC transmit good frame count register                   | 0x00000000  |
| R32_ETH_MMCRFCECR   | 0x40028194 | MMC receive CRC error frame count register               | 0x00000000  |
| R32_ETH_MMCRFAECR   | 0x40028198 | MMC receive alignment error frame counter register       | 0x00000000  |
| R32_ETH_MMCRGUFCR   | 0x400281C4 | MMC receive good unicast frame count register            | 0x00000000  |

# IEEE1588 (PTP) register address mapping

| Name             | Address    | Description                        | Reset Value |
|------------------|------------|------------------------------------|-------------|
| R32_ETH_PTPTSCR  | 0x40028700 | PTP timestamp control register     | 0x00000000  |
| R32_ETH_PTPSSIR  | 0x40028704 | PTP subsecond increment register   | 0x00000000  |
| R32_ETH_PTPTSHR  | 0x40028708 | PTP timestamp register high        | 0x00000000  |
| R32_ETH_PTPTSLR  | 0x4002870C | PTP timestamp register low         | 0x00000000  |
| R32_ETH_PTPTSHUR | 0x40028710 | PTP timestamp update register high | 0x00000000  |
| R32_ETH_PTPTSLUR | 0x40028714 | PTP timestamp update register low  | 0x00000000  |
| R32_ETH_PTPTSAR  | 0x40028718 | PTP timestamp adder register       | 0x00000000  |
| R32_ETH_PTPTTHR  | 0x4002871C | PTP target register high           | 0x00000000  |
| R32_ETH_PTPTTLR  | 0x40028720 | PTP target register low            | 0x00000000  |

DMA register address mapping. Note: The addresses are not consecutive

| Name              | Address    | Description                              | Reset Value |
|-------------------|------------|------------------------------------------|-------------|
| R32_ETH_DMABMR    | 0x40029000 | DMA bus mode register                    | 0x00000001  |
| R32_ETH_DMATPDR   | 0x40029004 | DMA transmit query register              | 0x00000000  |
| R32_ETH_DMARPTR   | 0x40029008 | DMA receive query register               | 0x00000000  |
| R32_ETH_DMARDLAR  | 0x4002900C | DMA receive descriptor address register  | 0x00000000  |
| R32_ETH_DMATDLAR  | 0x40029010 | DMA transmit descriptor address register | 0x00000000  |
| R32_ETH_DMASR     | 0x40029014 | DMA status register                      | 0x00000000  |
| R32_ETH_DMAOMR    | 0x40029018 | DMA operation mode register              | 0x00000000  |
| R32_ETH_DMAIER    | 0x4002901C | DMA interrupt enable register            | 0x00000000  |
| R32_ETH_DMAMFBOCR | 0x40029020 | DMA lost frame register                  | 0x00000000  |
| R32_ETH_DMACHTDR  | 0x40029048 | DMA current transmit descriptor register | 0x00000000  |
| R32_ETH_DMACHRDR  | 0x4002904C | DMA current receive descriptor register  | 0x00000000  |
| R32_ETH_DMACHTBAR | 0x40029050 | DMA current transmit buffer register     | 0x00000000  |
| R32_ETH_DMACHRBAR | 0x40029054 | DMA current receive buffer register      | 0x00000000  |

#### Internal 10M physical layer register address

| Name       | Offset Address | Description                                 | Reset Value |
|------------|----------------|---------------------------------------------|-------------|
| BMCR       | 0x00           | Basic control register                      | 0x2100      |
| BMSR       | 0x01           | Basic status register                       | 0x1809      |
| ETH_ANLPAR | 0x05           | Auto-negotiation linker capability register | 0x0001      |
| PHY_SR     | 0x10           | Physical layer status register              | 0x0000      |
| PHY_MDIX   | 0x1E           | Auto-flip register                          | 0x0000      |

Note: the offset address of the internal physical layer registers is used in the SMI interface

## 27.1.8.1 MAC Control Registers

## 27.1.8.1.1 MAC Control Register (R32\_ETH\_MACCR)

| 31 | 30     | 29  | 28 | 27 | 26      | 25 | 24  | 23   | 22 | 21 | 20 | 19 | 18     | 17  | 16  |
|----|--------|-----|----|----|---------|----|-----|------|----|----|----|----|--------|-----|-----|
|    | TCD[2: | 0]  |    | ]  | Reserve | d  | ,   | WD   | JD | PI | PR | ]  | FG[2:0 | )]  | CSD |
| 15 | 14     | 13  | 12 | 11 | 10      | 9  | 8   | 7    | 6  | 5  | 4  | 3  | 2      | 1   | 0   |
| FE | S[1:0] | ROD | LM | DM | IPCO    | RD | Res | APCS | В  | L  | DC | TE | RE     | TCF | Res |

| Name    | Name     | Access | Description                                             | Reset Value |  |
|---------|----------|--------|---------------------------------------------------------|-------------|--|
|         |          |        | Transmit clock delay field, this field is used to delay |             |  |
|         |          |        | the transmit clock. The MAC controller delays the       |             |  |
| [31:29] | TCD[2:0] | RW     | output of the transmit clock selected by the CES bit    | 0           |  |
|         |          |        | (ETH_MACCR[1]). Delay time calculation formula:         |             |  |
|         |          |        | Tdalay=TCD(ETH_MACCR[31:29])*0.5ns.                     |             |  |
| [28:24] | Reserved | RO     | Reserved                                                | 0           |  |
| 22      | WD       | DW     | Watchdog setting.                                       |             |  |
| 23      | WD       | RW     | 0: The MAC opens the watchdog, and can only accept      | 0           |  |

| 22      | JD       | RW | Ethernet frames with a maximum size of 2048 bytes, and the super-long part will be cut off;  1: MAC closes the door dog, and can receive Ethernet frames with a maximum size of 16384 bytes.  Jabber setting.  0: If the user tries to send an Ethernet frame with a length of more than 2048 bytes, the MAC will close the transmitter; | 0 |
|---------|----------|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
|         |          |    | 1: The MAC closes the Jabber timer, and can send up to 16384 bytes of Ethernet frames.  Built-in 10MPHY transmit drive bias current setting                                                                                                                                                                                              |   |
| 21      | PI       | RW | bits. 0: Rated drive; 1: Energy-saving sending.                                                                                                                                                                                                                                                                                          | 0 |
| 20      | PR       | RW | Built-in 10MPHY on-chip 50-ohm resistor pull-up to open the setting bit.  0: On-chip 50-ohm resistor disconnected;  1: On-chip 50-ohm resistor connected.c                                                                                                                                                                               | 0 |
| [19:17] | IFG[2:0] | RW | Frame gap setting, used to set the shortest time gap between sending 2 frames.  000: 96-bit time;  001: 88-bit time;  010: 80-bit time;  100: 64-bit time;  101: 56-bit time;  111: 48-bit time;                                                                                                                                         | 0 |
| 16      | Reserved | RO | Reserved                                                                                                                                                                                                                                                                                                                                 | 0 |
| [15:14] | FES[1:0] | RW | Ethernet speed setting.  00: 10Mbit/s;  01: 100Mbit/s;  10: 1Gbit/s;  11: Reserved, unused.                                                                                                                                                                                                                                              | 0 |
| 13      | Reserved | RO | Reserved                                                                                                                                                                                                                                                                                                                                 | 0 |
| 12      | LM       | RW | Self-loop mode enable. Setting this bit enables self-loop mode.                                                                                                                                                                                                                                                                          | 0 |
| 11      | DM       | RW | Duplex mode enable. Setting this bit enables full duplex mode.                                                                                                                                                                                                                                                                           | 0 |
| 10      | IPCO     | RW | IPv4 checksum check enable.  0: Disable the checksum verification function of IPv4 at the receiving end, and the corresponding PCE and PHCE flags are always 0. See the definition of each bit of the receive descriptor;  1: Enable IPv4 checksum verification, the MAC controller will check the TCP, UDP and ICMP                     | 0 |

|       |          |      | headers.                                                  |   |
|-------|----------|------|-----------------------------------------------------------|---|
| [9:8] | Reserved | RO   | Unused.                                                   | 0 |
|       |          |      | Padding & CRC auto-stripping enable.                      |   |
|       |          |      | 0: The MAC does not modify the contents of the frame;     |   |
|       |          |      | 1: The MAC removes the Pad/FCS field from the frame       |   |
| 7     | APCS     | RW   | only if the length/type field value is less than or equal | 0 |
|       |          |      | to 1500 bytes. If the Length/Type field is greater than   |   |
|       |          |      | or equal to 1501 bytes, the frame contents are not        |   |
|       |          |      | changed.                                                  |   |
| [6:4] | Reserved | RO   | Unused                                                    | 0 |
|       |          |      | Transmit enable.                                          |   |
|       |          |      | 0: Disable the transmitter, and no frame will be          |   |
| 3     | TE       | RW   | transmitted after the MAC finishes sending the current    | 0 |
|       |          |      | frame;                                                    |   |
|       |          |      | 1: Enable the MAC transmitter.                            |   |
|       |          |      | Receive enable.                                           |   |
| 2     | RE       | . RW | 0: Disable the receiver, and no frame will be received    | 0 |
| 2     | KL       | IXVV | after the MAC finishes receiving the current frame;       | U |
|       |          |      | 1: Enable the MAC receiver.                               |   |
|       |          |      | Transmit clock toggle setting.                            |   |
|       |          |      | 0: TXC selected by TCES is directly used as the           |   |
| 1     | TCF      | RW   | GTX_CLK output by the chip;                               | 0 |
|       |          |      | 1: Use the inversion of TXC selected by TCES as the       |   |
|       |          |      | GTX_CLK output by the chip.                               |   |
| 0     | Reserved | RO   | Reserved                                                  | 0 |

# 27.1.8.1.2 MAC Frame Filter Register (R32\_ETH\_MACFFR)

| 31 | 30  | 29   | 28  | 27 | 26  | 25 | 24 | 23      | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|-----|------|-----|----|-----|----|----|---------|----|----|----|----|----|----|----|
| RA |     | ,    |     |    |     |    | R  | Reserve | d  |    |    |    |    |    |    |
|    | 1.4 | - 10 | 1.0 |    | 4.0 |    |    |         |    |    |    |    |    |    |    |
| 15 | 14  | 13   | 12  | 11 | 10  | 9  | 8  | 7       | 6  | 5  | 4  | 3  | 2  | 1  | 0  |

| Bit     | Name     | Access | Description                                               | Reset Value |
|---------|----------|--------|-----------------------------------------------------------|-------------|
|         |          |        | Receive all                                               |             |
|         |          |        | 0: MAC only forwards frames that have passed the          |             |
| 31      | RA       | RW     | filter to the receive queue;                              | 0           |
|         |          |        | 1: The MAC forwards all received frames to the receive    |             |
|         |          |        | queue, regardless of whether they pass the filter or not. |             |
| [30:11] | Reserved | RO     | Reserved                                                  | 0           |
|         |          |        | HASH filter or perfect filter                             |             |
| 10      | HPF      | RW     | 0: On the premise that HM or HU is set, as long as it     | 0           |
| 10      | пгг      | ΚW     | meets the HASH filter, it can pass the address filter;    | 0           |
|         |          |        | 1: Determine which filtering method is used in            |             |

|       |      |    | unicast/multicast mode according to the value of HM or HU.                                                                                                                                                                                                                                                                                                                                                           |     |
|-------|------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| 9     | SAF  | RW | Source address filter  0: MAC marks frames that do not pass the source MAC address filtering;  1: MAC will directly discard frames that do not pass the source MAC address filtering.                                                                                                                                                                                                                                | 0   |
| 8     | SAIF | RW | Source address filter result inverted.  0: If the source address of the received frame is inconsistent with the source address enabled in the MAC address register, it is considered to have failed the source address filter;  1: If the source address of the received frame is consistent with the source address enabled in the MAC address register, it is considered to have failed the source address filter. | 0   |
| [7:6] | PCF  | RW | Flow control frames pass control. 00/01: The MAC does not forward any flow control frames to the application; 10: MAC forwards all flow control frames to the application, including flow control frames that fail the address filter; 11: MAC only forwards flow control frames that pass the address filter.                                                                                                       | 00Ь |
| 5     | BFD  | RW | Broadcast frame reception control  0: Receive all broadcast frames;  1: Discard all broadcast frames.                                                                                                                                                                                                                                                                                                                | 0   |
| 4     | PAM  | RW | Pass all multicast frame control.  0: Whether the multicast frame can pass filtering depends on the value of HM;  1: All multicast frames can be filtered by address.                                                                                                                                                                                                                                                | 0   |
| 3     | DAIF | RW | Destination MAC address filter results inverted control.  0: The filter result takes effect normally;  1: For multicast frames and unicast frames, whether the result of the filter passing is reversed before it takes effect.                                                                                                                                                                                      | 0   |
| 2     | НМ   | RW | Multicast frame filter mode  0: Perfect address filtering;  1: HSAH address filtering.                                                                                                                                                                                                                                                                                                                               | 0   |
| 1     | HU   | RW | Unicast frame filter mode  0: Perfect address filtering;  1: HSAH address filtering.                                                                                                                                                                                                                                                                                                                                 | 0   |
| 0     | PM   | RW | Promiscuous mode enable All frames pass the address filter without marking the result of the filter.                                                                                                                                                                                                                                                                                                                 | 0   |

V2. 4 514 WCH°

## 27.1.8.1.3 Hash List Register (R32\_ETH\_MACHTHR, R32\_ETH\_MACHTLR)

Offset Address: 0x08

| 31 | 30                   | 29 | 28 | 27 | 26 | 25 | 24   | 23     | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----------------------|----|----|----|----|----|------|--------|----|----|----|----|----|----|----|
|    | HTH[31:16]           |    |    |    |    |    |      |        |    |    |    |    |    |    |    |
| 15 | 14                   | 13 | 12 | 11 | 10 | 9  | 8    | 7      | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |                      |    |    |    |    |    | НТН  | [15:0] |    |    |    |    |    |    |    |
| (  | Offset Address: 0x0C |    |    |    |    |    |      |        |    |    |    |    |    |    |    |
| 31 | 30                   | 29 | 28 | 27 | 26 | 25 | 24   | 23     | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|    |                      |    |    |    |    |    | HTL[ | 31:16] |    |    |    |    |    |    |    |
| 15 | 14                   | 13 | 12 | 11 | 10 | 9  | 8    | 7      | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |                      |    |    |    |    |    | HTL[ | 31:15] |    |    |    |    |    |    |    |

| ĺ | Bit    | Name      | Access | Description            | Reset Value |
|---|--------|-----------|--------|------------------------|-------------|
|   | [31:0] | HTH[31:0] | RW     | Hash list high 32 bits | 0           |
| I | [31:0] | HTL[31:0] | RW     | Hash list low 32 bits  | 0           |

# 27.1.8.1.4 MII Address Register (R32\_ETH\_MACMIIAR)

Offset Address: 0x10

| 31 | 30 | 29      | 28 | 27 | 26 | 25 | 24     | 23    | 22 | 21           | 20 | 19      | 18 | 17 | 16 |
|----|----|---------|----|----|----|----|--------|-------|----|--------------|----|---------|----|----|----|
|    |    |         |    |    |    |    | Rese   | erved |    |              |    |         |    |    |    |
| 15 | 14 | 13      | 12 | 11 | 10 | 9  | 8      | 7     | 6  | 5            | 4  | 3       | 2  | 1  | 0  |
|    | -  | PA[4:0] | ]  |    |    | N  | MR[4:0 | ]     |    | Reser<br>ved | (  | CR[2:0] | ]  | MW | МВ |

| Bit     | Name     | Access | Description                                                                                                                      | Reset Value |
|---------|----------|--------|----------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:16] | Reserved | RO     | Unused.                                                                                                                          | 0           |
| [15:11] | PA[4:0]  | RW     | Physical layer address. The user writes the physical layer address to be operated into this field.                               | 0           |
| [10:6]  | MR[4:0]  | RW     | Physical layer register address field. The user writes the register address to be operated into this field.                      | 0           |
| 5       | Reserved | RO     | Unused.                                                                                                                          | 0           |
| [4:2]   | CR[2:0]  | RW     | Clock range setting. Users, please keep it as 000b, so that the MII frequency is divided by 42 of the main frequency.            | 0           |
| 1       | MW       | RW     | Read and write setting.  0: Read the physical layer;  1: Write to the physical layer.                                            | 0           |
| 0       | МВ       | RW1Z   | MII busy flag. This bit is set by the user, indicating that the hardware is instructed to start reading or writing. The physical | 0           |

V2. 4 515 WCH<sup>®</sup>

| address, register address and data field should remain |
|--------------------------------------------------------|
| unchanged during reading and writing. After the        |
| hardware clears this bit, the operation is completed.  |

# 27.1.8.1.5 MII Data Register (R32\_ETH\_MACMIIDR)

Offset Address: 0x14

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24   | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|------|-------|----|----|----|----|----|----|----|
|    |    |    |    |    |    |    | Rese | erved |    |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8    | 7     | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    |    | MD[  | 15:0] |    |    |    |    | _  |    |    |

| Bit     | Name     | Access | Description                                                 | Reset Value |
|---------|----------|--------|-------------------------------------------------------------|-------------|
| [31:16] | Reserved | RO     | Reserved.                                                   | 0           |
|         |          |        | MII operation data. This field is used to store the data to |             |
| [15:0]  | MD[15:0] | RW     | be read from the physical layer through the MII interface,  | 0           |
|         |          |        | or to store the data written to the physical layer.         |             |

# 27.1.8.1.6 MAC Flow Control Register (R32\_ETH\_MACFCR)

Offset address: 0x18

| `  | OHBC C | iaar ebb | . 0/110 |    |      |       |     |       |    |    |    |          |      |      |     |
|----|--------|----------|---------|----|------|-------|-----|-------|----|----|----|----------|------|------|-----|
| 31 | 30     | 29       | 28      | 27 | 26   | 25    | 24  | 23    | 22 | 21 | 20 | 19       | 18   | 17   | 16  |
|    |        | ,        |         |    |      | ,     | PT[ | 15:0] |    |    |    |          |      | ,    |     |
| 15 | 14     | 13       | 12      | 11 | 10   | 9     | 8   | 7     | 6  | 5  | 4  | 3        | 2    | 1    | 0   |
|    |        |          |         |    | Rese | erved |     |       |    |    |    | UPF<br>D | RFCE | TFCE | FCB |

| Bit      | Name     | Access | Description                                                                                                                                                                                                                                       | Reset Value |
|----------|----------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:16]  | PT[15:0] | RW     | Pause interval. This field is used to control the value of<br>the Pause time field, and the unit is the time it takes for                                                                                                                         |             |
| F1.7. 43 | D I      | D.O.   | the current MII interface to send 64 bytes.                                                                                                                                                                                                       | 0           |
| [15:4]   | Reserved | RO     | Unused.                                                                                                                                                                                                                                           | 0           |
| 3        | UPFD     | RW     | Unicast Pause frame detection.  0: The MAC only receives Pause frames with the unique address defined by the protocol specification;  1: The MAC also detects whether the Pause frame is a unicast address defined in the MAC address register 0. | 0           |
| 2        | RFCE     | RW     | Receive flow control enable.  0: The MAC does not parse the Pause frame;  1: The MAC parses the Pause frame and turns off the transmitter for a while.                                                                                            | 0           |
| 1        | TFCE     | RW     | Transmit flow control enable.  0: MAC closes sending flow control and does not send Pause frames;                                                                                                                                                 | 0           |

V2. 4 516 WCH°

|   |     |      | 1: MAC enables sending flow control and can send       |   |
|---|-----|------|--------------------------------------------------------|---|
|   |     |      | Pause frames.                                          |   |
|   |     |      | Flow control busy flag. This bit can be set to send a  |   |
|   |     |      | Pause frame, which is cleared by hardware after the    |   |
| 0 | FCB | RW1Z | transmission is completed. When operating on the       | 0 |
|   |     |      | entire MACFCR register, it is necessary to ensure that |   |
|   |     |      | the FCB bit is 0.                                      |   |

# 27.1.8.1.7 VLAN Tag Register (MACVLAN)

Offset address: 0x1C

| 31 | 30           | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16    |
|----|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|
|    |              |    |    |    |    |    |    |    |    |    |    |    |    |    | VLANT |
| 15 | 14           | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0     |
|    | VLANTI[15:0] |    |    |    |    |    |    |    |    |    |    |    |    |    |       |

| Bit     | Name         | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                       | Reset Value |
|---------|--------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:17] | Reserved     | RO     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                          | 0           |
| 16      | VLANT[15:0]  | RW     | Tag compare control.  0: Compare all 16-bit data of the 15th and 16th bytes of the VLAN frame with the VLANTI field;  1: Only use the [11:0] bits of the 15th and 16th bytes of the VLAN frame and compare them with the corresponding bits of the VLANTI field.                                                                                                                                                                  | 0           |
| [15:0]  | VLANTI[15:0] | RW     | Label vs. sample domain. According to the IEEE 802.1 protocol, bits [15:13] of the VLAN frame are the user priority, [12] is the canonical format indicator, and bits [11:0] of the VLAN identifier field.  If VLANTI is all 0, then the MAC will no longer care about the 15th and 16th bytes of the VLAN frame, and when the 13th and 14th bytes are 0x8100 (pay attention to the size end), it will be judged as a VLAN frame. | 0           |

## 27.1.8.1.8 Wake-up Frame Filter Register (R32\_MACRWUFFR)

| 31 | 30           | 29 | 28 | 27 | 26 | 25 | 24   | 23     | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|--------------|----|----|----|----|----|------|--------|----|----|----|----|----|----|----|
|    |              |    |    |    |    | R  | WUFF | R[31:1 | 6] |    |    |    |    |    |    |
| 15 | 14           | 13 | 12 | 11 | 10 | 9  | 8    | 7      | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    | RWUFFR[15:0] |    |    |    |    |    |      |        |    |    |    |    |    |    |    |

| Ï | Bit    | Name         | Access | Description                                                                                                     | Reset Value |
|---|--------|--------------|--------|-----------------------------------------------------------------------------------------------------------------|-------------|
| ĺ | [31:0] | RWUFFR[31:0] | lRW .  | The wake-up frame filter register is actually 8 different registers, and 8 consecutive read operations can read | 1 0         |

|  | out all registers, and 8 consecutive write operations can  |  |
|--|------------------------------------------------------------|--|
|  | be written into all 8 registers. The description of each   |  |
|  | bit of these 8 registers is described in Section 27.5.6.3. |  |

# 27.1.8.1.9 PMT Control and Status Register (R32\_ETH\_MACPMTCSR)

Offset address: 0x2C

| 31    | 30       | 29 | 28 | 27 | 26 | 25 | 24   | 23    | 22  | 21  | 20   | 19   | 18  | 17  | 16 |
|-------|----------|----|----|----|----|----|------|-------|-----|-----|------|------|-----|-----|----|
| WFFRP |          |    | ·  |    |    |    |      | Reser | ved |     |      |      |     |     |    |
| 15    | 14       | 13 | 12 | 11 | 10 | 9  | 8    | 7     | 6   | 5   | 4    | 3    | 2   | 1   | 0  |
|       | Reserved |    |    |    |    |    | Rese | erved | WFR | MPR | Rese | rved | WFE | MPE | PD |

| Bit     | Name     | Access | Description                                                                                                                                                                                                                                                           | Reset Value |
|---------|----------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| 31      | WFFRP    | RW1Z   | Wake-up frame filter register pointer reset. Setting this bit clears the MACRWUFFR register all the way to zero. This bit is automatically cleared on a clock cycle.                                                                                                  | 0b          |
| [30:10] | Reserved | RO     | Reserved.                                                                                                                                                                                                                                                             |             |
| 9       | GU       | RW     | Global unicast. Setting this bit causes the MAC to consider all unicast frames that pass the filter to be wake-up frames.                                                                                                                                             | 0b          |
| [8:7]   | Reserved | RO     | Reserved.                                                                                                                                                                                                                                                             |             |
| 6       | WFR      | RC     | Wake-up frame received flag. This bit is set when a wake-up frame is received. Read it and it will be cleared automatically.                                                                                                                                          | 0b          |
| 5       | MPR      | RC     | Magic frame received flag. This bit is set when a magic frame is received. Read it and it will be cleared automatically.                                                                                                                                              | 0b          |
| [4:3]   | Reserved | RO     | Reserved.                                                                                                                                                                                                                                                             |             |
| 2       | WFE      | RW     | Wake-up frame enable. Setting this bit allows a PMT event to be generated when a wake-up frame is received.                                                                                                                                                           | 0b          |
| 1       | MPE      | RW     | Magic frame enable. Setting this bit allows a PMT event to be generated when a magic frame is received.                                                                                                                                                               | 0b          |
| 0       | PD       | RW1Z   | Power-down control. Setting this bit will put the MAC into power-down mode: all other frames are discarded until it receives a wake-up frame or magic frame, and the MAC is automatically cleared after wake-up. Before setting this bit, WFE or MPE needs to be set. | 0b          |

# 27.1.8.1.10 MAC Interrupt Status Register (R32\_ETH\_MACSR)

Offset address: 0x38

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16

Reserved

| 15 | 14 | 13     | 12  | 11 | 10 | 9    | 8      | 7   | 6     | 5     | 4    | 3    | 2 | 1     | 0  |
|----|----|--------|-----|----|----|------|--------|-----|-------|-------|------|------|---|-------|----|
|    |    | Reserv | ved |    |    | TSTS | Reserv | ved | MMCTS | MMCRS | MMCS | PMTS | R | eserv | ed |

| Bit     | Name     | Access | Description                                                                                                                                                                                                                | Reset Value |
|---------|----------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:10] | Reserved | RO     | Reserved                                                                                                                                                                                                                   | 0           |
| 9       | TSTS     | RC     | Timestamp trigger interrupt flag. When the time set by the PTP system clock is reached, this flag will be set.                                                                                                             | 0           |
| [8:7]   | Reserved | RO     | Reserved                                                                                                                                                                                                                   | 0           |
| 6       | MMCTS    | RO     | MMC transmit interrupt flag. This bit is set when any interrupt is generated in the MMCTIR register in the MMC register bank. This bit is also cleared when all the MMCTIR registers in the MMC register bank are cleared. | 0           |
| 5       | MMCRS    | RO     | MMC receive interrupt flag. This bit is set when any interrupt is generated in the MMCRIR register in the MMC register bank. This bit is also cleared when the MMCRIR registers in the MMC register bank are all cleared.  | 0           |
| 4       | MMCS     | RO     | MMC status flag. When MMCTS or MMCRS is set, this bit is triggered. When MMCTS and MMCRS are all cleared, this bit is cleared.                                                                                             |             |
| 3       | PMTS     | RO     | PMT status flag. In power-down mode, if the MAC receives a magic frame or wake-up frame wakes up the MAC, this bit will be set. After clearing the WFR and MPR bits, this bit is cleared.                                  | 0           |
| [2:0]   | Reserved | RO     | Reserved                                                                                                                                                                                                                   | 0           |

# 27.1.8.1.11 MAC Interrupt Mask Register (R32\_ETH\_MACIMR)

Offset Address: 0x3C

| 31       | 30 | 29 | 28 | 27 | 26        | 25 | 24   | 23      | 22 | 21 | 20        | 19 | 18      | 17 | 16 |
|----------|----|----|----|----|-----------|----|------|---------|----|----|-----------|----|---------|----|----|
|          |    |    |    |    |           |    | Rese | erved   |    |    |           |    |         |    |    |
| 15       | 14 | 13 | 12 | 11 | 10        | 9  | 8    | 7       | 6  | 5  | 4         | 3  | 2       | 1  | 0  |
| Reserved |    |    |    |    | TSTI<br>M |    | R    | leserve | d  |    | PMTI<br>M | F  | Reserve | d  |    |

| Bit     | Name     | Access | Description                                                                             | Reset Value |
|---------|----------|--------|-----------------------------------------------------------------------------------------|-------------|
| [31:10] | Reserved | RO     | Reserved                                                                                | 0           |
| 9       | TSTIM    | RW     | Timestamp interrupt mask. Setting this bit disables generation of timestamp interrupts. | 0           |
| [8:4]   | Reserved | RO     | Reserved                                                                                | 0           |
| 3       | PMTIM    | RW     | PMT interrupt mask. Setting this bit will mask the PMT interrupt.                       | 0           |

| [2:0 | [2:0] Reserved RO Reserved                                                             |         |         |  |  |  |  |  |   |  |   |  |  | (  | )  |
|------|----------------------------------------------------------------------------------------|---------|---------|--|--|--|--|--|---|--|---|--|--|----|----|
|      |                                                                                        |         |         |  |  |  |  |  |   |  |   |  |  |    |    |
|      | 27.1.8.1.12 MAC Address Register 0 High 32 Bits (R32_ETH_MACA0HR) Offset Address: 0x40 |         |         |  |  |  |  |  |   |  |   |  |  |    |    |
| (    | Jiiset                                                                                 | Address | s: 0x40 |  |  |  |  |  |   |  |   |  |  |    |    |
| 31   | 31 30 29 28 27 26 25 24 23 22 21 20 19 18                                              |         |         |  |  |  |  |  |   |  |   |  |  | 17 | 16 |
|      |                                                                                        | -       |         |  |  |  |  |  | - |  | - |  |  |    |    |

|   |    |    | _  |    |    |    |   |   |         |    |   |   | _ | _ |   |   |
|---|----|----|----|----|----|----|---|---|---------|----|---|---|---|---|---|---|
|   | МО |    |    |    |    |    |   | F | Reserve | ed |   |   |   |   |   |   |
|   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7       | 6  | 5 | 4 | 3 | 2 | 1 | 0 |
| ļ |    |    |    |    |    |    |   |   |         |    |   |   |   |   |   |   |

MACA0H[15:0]

| Bit     | Name         | Access | Description                                           | Reset Value |
|---------|--------------|--------|-------------------------------------------------------|-------------|
| 31      | МО           | RO     | Always 1.                                             | 1           |
| [30:16] | Reserved     | RO     | Reserved                                              | 0           |
| [15:0]  | MACA0H[15:0] | RW     | High 16 bits of the MAC address, that is, 47:32 bits. | 0xFFFF      |

# 27.1.8.1.13 MAC Address Register 0 Low 32 Bits (R32\_ETH\_MACA0LR)

Offset Address: 0x44

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24    | 23       | 22 | 21 | 20 | 19          | 18 | 17 | 16 |
|----|----|----|----|----|----|----|-------|----------|----|----|----|-------------|----|----|----|
|    | 1  |    |    |    | 1  | N  | IACA0 | L[31:1   | 6] |    |    |             |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8     | 7        | 6  | 5  | 4  | 3           | 2  | 1  | 0  |
|    |    |    |    |    |    |    | MACA  | OT [15:0 | )] |    |    | · · · · · · |    |    |    |

| Bit    | Name         | Access | Description                                                                                                                               | Reset Value |
|--------|--------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:0] | MACA0L[31:0] | RW     | Low 32 bits of the MAC address, namely 31:0 bits. In general, the address of the MAC address register 0 is the address of the MAC itself. |             |

## 27.1.8.1.14 MAC Address Register 1 High 32 Bits (R32\_ETH\_MACA1HR)

| 31 | 30  | 29 | 28 | 27  | 26     | 25 | 24 | 23 | 22     | 21 | 20   | 19    | 18 | 17 | 16 |
|----|-----|----|----|-----|--------|----|----|----|--------|----|------|-------|----|----|----|
| AE | SA  |    |    | MBC | C[5:0] |    |    |    |        |    | Rese | erved |    |    |    |
| 15 | 14  | 13 | 12 | 11  | 10     | 9  | 8  | 7  | 6      | 5  | 4    | 3     | 2  | 1  | 0  |
|    | MAC |    |    |     |        |    |    |    | <br>)] |    |      |       |    |    |    |

| Bit | Name | Access | Description                                                                                                                         | Reset Value |
|-----|------|--------|-------------------------------------------------------------------------------------------------------------------------------------|-------------|
| 31  | AE   | RW     | Address filter enable. 0: The address filter ignores MAC address 1. 1: The address filter uses MAC address 1 for perfect filtering; | 0           |
| 30  | SA   | RW     | Address role selection.                                                                                                             | 0           |

|           |              |       | O. MAC address 1 is used to some                              |           |
|-----------|--------------|-------|---------------------------------------------------------------|-----------|
|           |              |       | 0: MAC address 1 is used to compare with the                  |           |
|           |              |       | destination address of the received frame;                    |           |
|           |              |       | 1: MAC address 1 is used to compare with the source           |           |
|           |              |       | address of the received frame.                                |           |
|           |              |       | Mask word control. Each bit of the MBC is used to             |           |
|           |              |       | correspond to a certain byte of the masked MAC                |           |
|           |              |       | address 1, and is used to prohibit a certain byte of the      |           |
|           |              |       | MAC address 1 from participating in the comparison of         |           |
|           |              |       | the source address or the destination address of the          |           |
|           |              |       | received frame.                                               |           |
|           |              |       | R32_ETH_MACA1HR[29] is set to mask                            |           |
|           |              |       | MACA1H[15:8];                                                 |           |
|           |              |       | R32_ETH_MACA1HR[28] is set to mask                            |           |
| F20, 2.43 | MDCI7 01     | DIV   | MACA1H[7:0];                                                  | 0         |
| [29:24]   | MBC[5:0]     | RW    | R32_ETH_MACA1HR[27] is set to mask                            | 0         |
|           |              |       | MACA1L[31:24];                                                |           |
|           |              |       | R32 ETH MACA1HR[26] is set to mask                            |           |
|           |              |       | MACA1L[23:16];                                                |           |
|           |              |       | R32 ETH MACA1HR[25] is set to mask                            |           |
|           |              |       | MACA1L[15:8];                                                 |           |
|           |              |       | R32 ETH MACA1HR[24] is set to mask                            |           |
|           |              |       | MACA1L[7:0].                                                  |           |
|           |              |       | Note: The functions of R32 ETH MACA1HR[29:27]                 |           |
|           |              |       | should be enabled or disabled simultaneously.                 |           |
| [23:16]   | Reserved     | RO    | Reserved                                                      | 0         |
| [15:0]    | MACA1H       | RW    | High 16 bits of the MAC address, that is, 47:32 bits.         | 0xFFFF    |
| [15.0]    | 1,1111011111 | 10,11 | 111511 10 516 51 tile 1111 10 tittal 105, 1111 15, 17.32 516. | JAI 1 1 1 |

# 27.1.8.1.15 MAC Address Register 1 Low 32 Bits (R32\_ETH\_MACA1LR)

Offset Address: 0x4C

| 31 | 30           | 29 | 28 | 27 | 26 | 25 | 24    | 23     | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|--------------|----|----|----|----|----|-------|--------|----|----|----|----|----|----|----|
|    |              |    |    |    |    | N  | IACA1 | L[31:1 | 6] |    |    |    |    |    |    |
| 15 | 14           | 13 | 12 | 11 | 10 | 9  | 8     | 7      | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    | MACA1L[15:0] |    |    |    |    |    |       |        |    |    |    |    |    |    |    |

| ĺ | Bit    | Name           | Access | Description                                       | Reset Value |
|---|--------|----------------|--------|---------------------------------------------------|-------------|
| ĺ | [21.0] | MACA 11 [21.0] | DW     | I 221-4fd- MAC -lll-21.01-4-                      | 0xFFFFFFF   |
| ١ | [31:0] | MACA1L[31:0]   | KW     | Low 32 bits of the MAC address, namely 31:0 bits. | F           |

## 27.1.8.1.16 MAC Address Register 2 High 32 Bits (R32\_ETH\_MACA2HR)

|   | 31 | 30 | 29 | 28 | 27  | 26     | 25 | 24 | 23 | 22 | 21 | 20   | 19   | 18 | 17 | 16 |
|---|----|----|----|----|-----|--------|----|----|----|----|----|------|------|----|----|----|
| I | AE | SA |    |    | MBC | C[5:0] |    |    |    |    |    | Rese | rved |    |    |    |

## MACA2H[15:0]

| Bit     | Name         | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Reset value |
|---------|--------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| 31      | AE           | RW     | Address filter enable. 0: The address filter ignores the MAC address 2. 1: The address filter uses MAC address 2 for perfect filtering.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0           |
| 30      | SA           | RW     | Address role selection.  0: MAC address 2 is used to compare with the destination address of the received frame;  1: MAC address 2 is used to compare with the source address of the received frame.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0           |
| [29:24] | MBC[5:0]     | RW     | Mask word control. Each bit of the MBC is used to correspond to a certain byte of the masked MAC address 2, and is used to prohibit a certain byte of the MAC address 2 from participating in the comparison of the source address or the destination address of the received frame.  R32_ETH_MACA2HR[29] is set to mask MACA2H[15:8];  R32_ETH_MACA2HR[28] is set to mask MACA2H[7:0];  R32_ETH_MACA2HR[27] is set to mask MACA2L[31:24];  R32_ETH_MACA2HR[26] is set to mask MACA2L[23:16];  R32_ETH_MACA2HR[25] is set to mask MACA2L[15:8];  R32_ETH_MACA2HR[24] is set to mask MACA2L[15:8];  R32_ETH_MACA2HR[24] is set to mask MACA2L[7:0].  Note: The functions of R32_ETH_MACA2HR[29:27] should be enabled or disabled simultaneously. | 0           |
| [23:16] | Reserved     | RO     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0           |
| [15:0]  | MACA2H[15:0] | RW     | High 16 bits of the MAC address, that is, 47:32 bits.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 0xFFFF      |

## 27.1.8.1.17 MAC Address Register 2 Low 32 Bits (R32\_ETH\_MACA2LR)

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24    | 23      | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|-------|---------|----|----|----|----|----|----|----|
|    |    |    |    |    |    | N  | IACA2 | L[31:1  | 6] |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8     | 7       | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    | N  | ЛАСА2 | 2L[15:0 | )] |    |    |    |    |    |    |

| Bit    | Name         | Access | Description                                         | Reset value |
|--------|--------------|--------|-----------------------------------------------------|-------------|
| [31:0] | MACA2L[31:0] | RW     | Low 32 bits of the MAC address, that is, 31:0 bits. | 0xFFFFFFF   |

# 27.1.8.1.18 MAC Address Register 3 High 32 Bits (R32\_ETH\_MACA3HR)

| 31 | 30 | 29 | 28 | 27  | 26     | 25 | 24    | 23      | 22 | 21 | 20   | 19   | 18 | 17 | 16 |
|----|----|----|----|-----|--------|----|-------|---------|----|----|------|------|----|----|----|
| AE | SA |    |    | MBC | C[5:0] |    |       |         |    |    | Rese | rved | ,  |    |    |
| 15 | 14 | 13 | 12 | 11  | 10     | 9  | 8     | 7       | 6  | 5  | 4    | 3    | 2  | 1  | 0  |
|    |    |    |    |     |        | N  | ЛАСАЗ | 3H[15:0 | 0] |    |      |      |    |    |    |

| Bit     | Name         | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Reset Value    |
|---------|--------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 31      | AE           | RW     | Address filter enable.  0: The address filter ignores the MAC address 3;  1: The address filter uses MAC address 3 for perfect filtering.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0b             |
| 30      | SA           | RW     | Address role selection.  0: MAC address 3 is used to compare with the destination address of the received frame;  1: MAC address 3 is used to compare with the source address of the received frame.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 0ь             |
| [29:24] | MBC[5:0]     | RW     | Mask word control. Each bit of the MBC is used to correspond to a certain byte of the masked MAC address 3, and is used to prohibit a certain byte of the MAC address 3 from participating in the comparison of the source address or the destination address of the received frame.  R32_ETH_MACA3HR[29] is set to mask MACA3H[15:8];  R32_ETH_MACA3HR[28] is set to mask MACA3H[7:0];  R32_ETH_MACA3HR[27] is set to mask MACA2L[31:24];  R32_ETH_MACA3HR[26] is set to mask MACA2L[23:16];  R32_ETH_MACA3HR[25] is set to mask MACA3L[15:8];  R32_ETH_MACA3HR[24] is set to mask MACA3L[15:0].  Note: The functions of R32_ETH_MACA3HR[29:27] should be enabled or disabled simultaneously. | 000000Ь        |
| [23:16] | Reserved     | RO     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                |
| [15:0]  | MACA3H[15:0] | RW     | High 16 bits of the MAC address, that is, 47:32 bits.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 0xFFFFFFF<br>F |

## 27.1.8.1.19 MAC Address Register 3 Low 32 Bits (R32\_ETH\_MACA3LR)

Offset address: 0x5C

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24    | 23     | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|-------|--------|----|----|----|----|----|----|----|
|    |    | -  |    | -  |    | M  | IACA3 | L[31:1 | 6] |    |    |    |    |    |    |
|    |    |    |    |    |    |    |       |        |    |    |    |    |    |    | _  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8     | 7      | 6  | 5  | 4  | 3  | 2  | 1  | 0  |

| Bit    | Name         | Access | Description                                         | Reset Value    |
|--------|--------------|--------|-----------------------------------------------------|----------------|
| [31:0] | MACA3L[31:0] | RW     | Low 32 bits of the MAC address, that is, 31:0 bits. | 0xFFFFFFF<br>F |

## 27.1.8.1.20 MAC Software Reset Control Register (R32\_ETH\_MACCFG0)

Offset address: 0x98

| `                 | JIISCE U          | iddi C55 | . UA)U            |    |    |    |      |       |      |       |    |    |    |    |    |
|-------------------|-------------------|----------|-------------------|----|----|----|------|-------|------|-------|----|----|----|----|----|
| 31                | 30                | 29       | 28                | 27 | 26 | 25 | 24   | 23    | 22   | 21    | 20 | 19 | 18 | 17 | 16 |
| MAC<br>RX_<br>RST | MAC<br>TX_R<br>ST |          | DMA<br>TX_R<br>ST |    |    |    |      |       | Rese | erved |    |    |    |    |    |
| 15                | 14                | 13       | 12                | 11 | 10 | 9  | 8    | 7     | 6    | 5     | 4  | 3  | 2  | 1  | 0  |
|                   | ·                 | ·        |                   |    |    | ·  | Rese | erved |      | ·     |    |    |    | ·  |    |

| Bit    | Name        | Access | Description                                        | Reset Value |
|--------|-------------|--------|----------------------------------------------------|-------------|
|        |             |        | MAC receive reset control:                         |             |
| 31     | MACRX RST   | RW     | 0: Not reset;                                      | 0           |
| 31     | MACKA_KS1   | IXVV   | 1: Reset.                                          | U           |
|        |             |        | This bit is automatically cleared after one cycle. |             |
|        |             |        | MAC transmit reset control:                        |             |
| 30     | MACTX RST   | RW     | 0: Not reset;                                      | 0           |
| 30     | MACIA_KSI   | KVV    | 1: Reset.                                          | U           |
|        |             |        | This bit is automatically cleared after one cycle. |             |
|        |             |        | DMA receive reset control:                         |             |
| 29     | DMARX RST   | RW     | 0: Not reset;                                      | 0           |
| 29     | DIVIARA_RS1 | KVV    | 1: Reset.                                          | U           |
|        |             |        | This bit is automatically cleared after one cycle. |             |
|        |             |        | DMA transmit reset control:                        |             |
| 28     | DMATX RST   | RW     | 0: Not reset;                                      | 0           |
| 20     | DIVIALA_KS1 | KVV    | 1: Reset.                                          | 0           |
|        |             |        | This bit is automatically cleared after one cycle. |             |
| [27:0] | Reserved    | RO     | Reserved                                           | 0           |

Note: The R32\_ETH\_MACCFG0 register is only applicable to the products of CH32F207, CH32V307 and CH32V317 whose last digit is not 0.

V2. 4 524 WCH<sup>®</sup>

## 27.1.8.2 MMC registers

# 27.1.8.2.1 MMC Control Register (R32\_ETH\_MMCCR)

Offset address: 0x0100

| 31 | 30 | 29 | 28 | 27 | 26   | 25   | 24   | 23    | 22 | 21 | 20 | 19  | 18  | 17  | 16 |
|----|----|----|----|----|------|------|------|-------|----|----|----|-----|-----|-----|----|
|    |    |    |    |    |      |      | Rese | erved |    |    |    |     |     |     |    |
| 15 | 14 | 13 | 12 | 11 | 10   | 9    | 8    | 7     | 6  | 5  | 4  | 3   | 2   | 1   | 0  |
|    |    |    |    |    | Rese | rved |      |       |    |    |    | MCF | ROR | CSR | CR |

| Bit    | Name     | Access | Description                                                                                                                                                                                                                          | Reset Value |
|--------|----------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:4] | Reserved | RO     | Reserved                                                                                                                                                                                                                             | 0           |
| 3      | MCF      | RW     | Counter freeze control. Setting this bit will freeze all MMC counter values. Resetting this bit will restore the count of each counter. Setting ROR while frozen and then reading any counter will cause that counter to be cleared. | 0           |
| 2      | ROR      | RW     | Reset control on read. Setting this bit will clear the value of the counter after reading either counter.                                                                                                                            | 0           |
| 1      | CSR      | RW     | Counter roll stop. Setting this bit causes the counter to increment to its maximum value and stop without auto-zeroing.                                                                                                              | 0           |
| 0      | CR       | RW1Z   | Counter reset control. Setting this bit will reset all counters. This bit is automatically cleared after single system cycle.                                                                                                        |             |

## 27.1.8.2.2 MMC Receive Interrupt Register (R32\_ETH\_MMCRIR)

| 31 | 30 | 29 | 28 | 27   | 26    | 25   | 24    | 23 | 22 | 21    | 20 | 19 | 18     | 17        | 16           |
|----|----|----|----|------|-------|------|-------|----|----|-------|----|----|--------|-----------|--------------|
|    |    |    |    |      |       | Rese | erved |    |    |       |    |    |        | RGU<br>FS | Reser<br>ved |
| 15 | 14 | 13 | 12 | 11   | 10    | 9    | 8     | 7  | 6  | 5     | 4  | 3  | 2      | 1         | 0            |
|    |    |    | -  | Rese | erved |      |       | -  |    | RFCES |    | ]  | Reserv | ed        |              |

| Bit     | Name     | Access | Name                                                                            | Reset Value |
|---------|----------|--------|---------------------------------------------------------------------------------|-------------|
| [31:18] | Reserved | RO     | Reserved                                                                        | 0           |
| 17      | RGUFS    | RC     | This bit is set when more than half of the good frames are received.            | 0           |
| [16:6]  | Reserved | RO     | Reserved                                                                        | 0           |
| 5       | RFCES    | RC     | This bit is set when more than half of the frames with CRC errors are received. | 0           |
| 4:0     | Reserved | RO     | Reserved                                                                        | 0           |

## 27.1.8.2.3 MMC Transmit Interrupt Register (R32\_ETH\_MMCTIR)

Offset address: 0x0108

| 31 | 30       | 29 | 28 | 27   | 26    | 25 | 24 | 23 | 22 | 21   | 20 | 19 | 18      | 17 | 16 |
|----|----------|----|----|------|-------|----|----|----|----|------|----|----|---------|----|----|
|    |          |    |    | Rese | erved |    |    |    |    | TGFS |    | F  | Reserve | d  |    |
| 15 | 14       | 13 | 12 | 11   | 10    | 9  | 8  | 7  | 6  | 5    | 4  | 3  | 2       | 1  | 0  |
|    | Reserved |    |    |      |       |    |    |    |    |      |    |    |         |    |    |

| Bit     | Name     | Access | Description                                                 | Reset Value |
|---------|----------|--------|-------------------------------------------------------------|-------------|
| [31:22] | Reserved | RO     | Reserved                                                    | 0           |
| 21      | TGFS     | RC     | This bit is set when more than half of the frames are sent. | 0           |
| [20:0]  | Reserved | RO     | Reserved                                                    | 0           |

## 27.1.8.2.4 MMC Receive Interrupt Mask Register (R32\_ETH\_MMCRIMR)

Offset address: 0x010C

| 31                      | 30 | 29 | 28 | 27 | 26 | 25   | 24    | 23 | 22 | 21 | 20 | 19 | 18 | 17        | 16           |
|-------------------------|----|----|----|----|----|------|-------|----|----|----|----|----|----|-----------|--------------|
|                         |    |    |    |    |    | Rese | erved |    |    |    |    |    |    | RGU<br>FM | Reser<br>ved |
| 15                      | 14 | 13 | 12 | 11 | 10 | 9    | 8     | 7  | 6  | 5  | 4  | 3  | 2  | 1         | 0            |
| Reserved RFCEM Reserved |    |    |    |    |    |      |       |    |    |    | ed |    |    |           |              |

| Bit     | Name     | Access | Description                                             | Reset Value |
|---------|----------|--------|---------------------------------------------------------|-------------|
| [31:18] | Reserved | RO     | Reserved                                                | 0           |
|         |          |        | Receive a good frame half interrupt mask. Setting this  |             |
| 17      | RGUFM    | RW     | bit will mask the interrupt generated when the received | 0           |
|         |          |        | frame counter reaches half the value.                   |             |
| [16:6]  | Reserved | RO     | Reserved                                                | 0           |
|         |          |        | Receive CRC error frame half interrupt mask. Setting    |             |
| 5       | RFCEM    | RW     | this bit will mask the interrupt that occurs when the   | 0           |
| 3       | KFCEWI   | KW     | frame counter value reaches half the value of the frame | 0           |
|         |          |        | counter that receives a CRC error.                      |             |
| [4:0]   | Reserved | RO     | Reserved                                                | 0           |

## 27.1.8.2.5 MMC Transmit Interrupt Mask Register (R32\_ETH\_MMCTIMR)

| 31            | 30       | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22      | 21 | 20 | 19 | 18 | 17 | 16 |
|---------------|----------|----|----|----|----|----|----|----|---------|----|----|----|----|----|----|
| Reserved TGFM |          |    |    |    |    |    |    |    | Reserve | ed |    |    |    |    |    |
| 15            | 14       | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6       | 5  | 4  | 3  | 2  | 1  | 0  |
|               | Reserved |    |    |    |    |    |    |    |         |    |    |    |    |    |    |

| Bit Name Access Description Reset Value |
|-----------------------------------------|
|-----------------------------------------|

| [31:22] | Reserved | RO | Reserved                                            | 0 |
|---------|----------|----|-----------------------------------------------------|---|
|         |          |    | Transmit good frame half interrupt mask.            |   |
| 21      | TGFM     | RW | Setting this bit will mask the interrupt generated  | 0 |
|         |          |    | when the sent frame counter reaches half the value. |   |
| [20:0]  | Reserved | RO | Reserved                                            | 0 |

# $27.1.8.2.6\ MMC\ Transmit\ Good\ Frame\ after\ Single\ Conflict\ Counter\ (R32\_ETH\_MMCTGFSCCR)$

Offset address: 0x014C

| 31 | 30            | 29 | 28 | 27 | 26 | 25 | 24    | 23      | 22  | 21 | 20 | 19 | 18 | 17 | 16 |
|----|---------------|----|----|----|----|----|-------|---------|-----|----|----|----|----|----|----|
|    |               |    |    |    |    | T  | GFSCC | CR[31:1 | [6] |    |    |    |    |    |    |
| 15 | 14            | 13 | 12 | 11 | 10 | 9  | 8     | 7       | 6   | 5  | 4  | 3  | 2  | 1  | 0  |
|    | TGFSCCR[15:0] |    |    |    |    |    |       |         |     |    |    |    |    |    |    |

| Bit    | Name          | Access | Description                                                 | Reset Value |
|--------|---------------|--------|-------------------------------------------------------------|-------------|
|        |               |        | This field contains the number of frames successfully       |             |
| [31:0] | TGFSCCR[31:0] | RO     | sent after a single conflict in half-duplex mode, i.e., the | 0           |
|        |               |        | counter of good frames sent after a single conflict.        |             |

# 27.1.8.2.7 MMC Transmit Good Frame Counter after Multiple Conflicts (R32\_ETH\_MMCTGFMSCCR)

Offset address: 0x0150

| `               | J11501 1 | iddi C55 | · OAOIS | , 0 |    |    |    |    |    |    |    |    |    |    |    |
|-----------------|----------|----------|---------|-----|----|----|----|----|----|----|----|----|----|----|----|
| 31              | 30       | 29       | 28      | 27  | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| TGFMSCCR[31:16] |          |          |         |     |    |    |    |    |    |    |    |    |    |    |    |
| 15              | 14       | 13       | 12      | 11  | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|                 |          |          |         |     |    |    |    |    |    |    |    |    |    |    |    |

| TGFMSCCR[15:0] |
|----------------|
|                |

| Bit    | Name           | Access | Description                                                                                                                                                                         | Reset Value |
|--------|----------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:0] | TGFMSCCR[31:0] | RO     | This field contains the number of frames successfully<br>sent after more than one conflict in half-duplex mode,<br>i.e., a counter of good frames sent after multiple<br>conflicts. | 0           |

#### 27.1.8.2.8 MMC Transmit Good Frame Count Register (R32\_ETH\_MMCTGFCR)

| 31  | 30    | 29  | 28 | 27 | 26  | 25 | 24   | 23      | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-----|-------|-----|----|----|-----|----|------|---------|----|----|----|----|----|----|----|
|     |       |     |    |    |     |    | TGFC | [31:16] |    |    |    |    |    |    |    |
| 1.5 | - 1.4 | 1.0 | 10 |    | 1.0 | 0  | 0    |         |    |    |    |    | 2  | 1  | 0  |
| 15  | 14    | 13  | 12 | 11 | 10  | 9  | 8    |         | 6  | 5  | 4  | 3  | 2  | 1  | 0  |

| ĺ | Bit    | Name       | Access | Description                              | Reset Value |
|---|--------|------------|--------|------------------------------------------|-------------|
| ĺ | [31:0] | TGFC[31:0] | RO     | Count of correct frames sent by the MAC. | 0           |

#### 27.1.8.2.9 MMC Receive Frame with CRC Error Count Register (R32\_ETH\_MMCRFCECR)

Offset address: 0x0194

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24     | 23      | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|--------|---------|----|----|----|----|----|----|----|
|    | ,  |    | ,  |    |    | R  | RFCEC! | R[31:10 | 6] |    | ,  |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8      | 7       | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    | -  |    | -  |    | I  | RFCEC  | R[15:0  | )] | -  |    |    | -  | -  |    |

| Name         | Access | Description     | Reset Value                                    |
|--------------|--------|-----------------|------------------------------------------------|
| RFCECR[31:0] | RO     | •               | 0                                              |
|              |        | RFCECR[31:0] RO | Counter of frames received by the MAC with CRC |

#### 27.1.8.2.10 MMC Receive Frame with Alignment Error Count Register (R32\_ETH\_MMCRFAECR)

Offset address: 0x0198

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24    | 23      | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|-------|---------|----|----|----|----|----|----|----|
|    |    |    |    |    |    | R  | RFAEC | R[31:10 | 6] |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8     | 7       | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    |    |       |         |    |    |    |    |    |    |    |

| Bit    | Name         | Access | Description                                | Reset Value |
|--------|--------------|--------|--------------------------------------------|-------------|
| [31:0] | RFAECR[31:0] | RO     | Counter of frames received by the MAC with | 0           |
| [31.0] | KIALCK[31.0] | RO     | alignment errors.                          |             |

#### 27.1.8.2.11 MMC Receive Good Frame Count Register (R32\_ETH\_MMCRGUFCR)

Offset address: 0x01C4

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24    | 23      | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|-------|---------|----|----|----|----|----|----|----|
|    | ,  |    |    |    |    | R  | GUFC  | R[31:1  | 6] |    | ,  |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8     | 7       | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    | F  | RGUFC | CR[15:0 | )] |    |    |    |    |    |    |

| ĺ | Bit    | Name         | Access | Description                                      | Reset Value |
|---|--------|--------------|--------|--------------------------------------------------|-------------|
| ĺ | [31:0] | RGUFCR[31:0] | RO     | The number of normal frames received by the MAC. | 0           |

## 27.1.8.3 IEEE 1588 (PTP) registers

## 27.1.8.3.1 PTP Timestamp Control Register (R32\_ETH\_PTPTSCR)

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|-------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|

|    |    |    |    |      |       |   | Rese | erved |   |       |       |       |       |       |     |
|----|----|----|----|------|-------|---|------|-------|---|-------|-------|-------|-------|-------|-----|
| 15 | 14 | 13 | 12 | 11   | 10    | 9 | 8    | 7     | 6 | 5     | 4     | 3     | 2     | 1     | 0   |
|    |    |    |    | Rese | erved |   |      |       |   | TSARU | TSITE | TSSTU | TSSTI | TSFCU | TSE |

| Bit    | Name     | Access | Description                                                                                                                                                                                                                                                                   | Reset Value |
|--------|----------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:6] | Reserved | RO     | Reserved                                                                                                                                                                                                                                                                      | 0           |
| 5      | TSARU    | RW     | Addend register update control. When this bit is set, the value of the addend register will be added to the accumulator. This bit is used in fine tuning mode. This bit is automatically cleared after the accumulator is incremented. This bit can only be set when it is 0. | 0           |
| 4      | TSITE    | RW     | Timestamp interrupt trigger enable. When this bit is set, an interrupt will be generated when the PTP system time reaches the value set in the target time register.                                                                                                          | 0           |
| 3      | TSSTU    | RW     | System time update control. When this bit is set, the PTP system time will be added to the value in the update register. This bit is automatically cleared after the update is complete.                                                                                      | 0           |
| 2      | TSSTI    | RW     | Timestamp initialization control. When this bit is set, the system time of the PTP will be replaced with the value in the update register. This bit is automatically cleared after the update is complete.                                                                    | 0           |
| 1      | TSFCU    | RW     | Update mode selection.  0: Coarse mode;  1: Fine adjustment mode.                                                                                                                                                                                                             | 0           |
| 0      | TSE      | RW     | Additional timestamp enable.  0: No timestamp is added to the descriptor;  1: Add a timestamp to the descriptor at the end of reception or transmission.                                                                                                                      | 0           |

# 27.1.8.3.2 PTP Subsecond Increment Register (R32\_ETH\_PTPSSIR)

| 31 | 30 | 29 | 28   | 27   | 26 | 25 | 24   | 23    | 22 | 21 | 20   | 19     | 18 | 17 | 16 |
|----|----|----|------|------|----|----|------|-------|----|----|------|--------|----|----|----|
|    |    |    |      |      |    |    | Rese | erved |    |    |      |        |    |    |    |
| 15 | 14 | 13 | 12   | 11   | 10 | 9  | 8    | 7     | 6  | 5  | 4    | 3      | 2  | 1  | 0  |
|    |    |    | Rese | rved |    |    |      |       |    |    | STSS | I[7:0] |    |    |    |

| Bit    | Name       | Access | Description                                                                                                | Reset Value |
|--------|------------|--------|------------------------------------------------------------------------------------------------------------|-------------|
| [31:8] | Reserved   | RO     | Reserved                                                                                                   | 0           |
| [7:0]  | STSSI[7:0] | I RW   | Sub-second step value. In coarse mode, the PTP system time will automatically increase by this value every | OOh         |

| main frequency cycle. In the fine adjustment mode,  |  |
|-----------------------------------------------------|--|
| when the accumulator overflows, the PTP system time |  |
| will automatically increase by this value.          |  |

## 27.1.8.3.3 PTP Timestamp Register High (R32\_ETH\_PTPTSHR)

Offset address: 0x0708

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24    | 23     | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|-------|--------|----|----|----|----|----|----|----|
|    |    |    |    |    | 1  |    | STS[3 | 31:16] |    |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8     | 7      | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    |    | STS[  | [15:0] |    |    |    |    |    |    |    |

| Bit    | Name       | Access | Description                                         | Reset Value |
|--------|------------|--------|-----------------------------------------------------|-------------|
| [31:0] | TSHR[31:0] | RO     | PTP system time value, real-time value, in seconds. | 0           |

## 27.1.8.3.4 PTP Timestamp Register Low (R32\_ETH\_PTPTSLR)

Offset address: 0x070C

| 31    | 30 | 29 | 28 | 27 | 26 | 25 | 24   | 23     | 22  | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|------|--------|-----|----|----|----|----|----|----|
| STPNS |    |    |    |    |    |    | ST   | SS[30: | 16] |    |    |    |    |    |    |
| 15    | 14 | 13 | 12 | 11 | 10 | 9  | 8    | 7      | 6   | 5  | 4  | 3  | 2  | 1  | 0  |
|       |    |    |    | 10 |    |    | STSS | [15:0] |     |    |    |    |    |    |    |

| Bit    | Name       | Access | Description                                       | Reset Value |
|--------|------------|--------|---------------------------------------------------|-------------|
| 31     | STPNS      | RO     | System time positive/negative flag. 1: Negative;  | 0           |
|        |            |        | 0: Positive.                                      |             |
|        |            |        | PTP system time value, real-time value, in sub-   |             |
| [30:0] | STSS[30:0] | RO     | seconds, i.e., about 0.46ns. When STSS overflows, | 0           |
|        |            |        | STS increments by 1s.                             |             |

## 27.1.8.3.5 PTP Timestamp Update Register High 32 Bits (R32\_ETH\_PTPTSHUR)

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24   | 23      | 22 | 21  | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|------|---------|----|-----|----|----|----|----|----|
|    |    |    |    |    | ,  | ,  | TSUS | [31:16] | ,  |     | ,  | ,  | ,  | ,  |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8    | 7       | 6  | 5   | 4  | 3  | 2  | 1  | 0  |
|    |    |    | -  |    |    |    | TSUS | [15:0]  |    | · · |    |    |    | ·  |    |

| Bit    | Name | Access | Description                                                                                                                                                 | Reset Value |
|--------|------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:0] | TSUS | RW     | Timestamp update second value, which is used to replace the high bit of the PTP system time or the second value representing its addition or subtraction to | 0           |

| 1 |  | the system time  |  |
|---|--|------------------|--|
| 1 |  | the system time. |  |

## 27.1.8.3.6 PTP Timestamp Update Register Low 32 Bits (R32\_ETH\_PTPTSLUR)

Offset address: 0x0714

TSUP TSUSS[30:16] NS 

**TSUSS** 

| Bit    | Name        | Access                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Description                                                                                                       | Reset Value |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|-------------|
| 31     | TSUPNS      | Timestamp update positive/negative flag. When the update time method is to use TSUS and TSUSS to directly replace the PTP system time, TSUPNS should be 0; when the update time method is to use TSUS and TSUSS to add or subtract the original PTP system time value, TSUPNS is 1, indicating that the PTP system Subtract TSUS and TSUSS from the time base, and 0 means add TSUS and TSUSS to the PTP system time.  Timestamp update sub-second value, which is used to replace the high bit of the PTP system time or a sub- | 0                                                                                                                 |             |
| [30:0] | TSUSS[30:0] | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | replace the high bit of the PTP system time or a sub-<br>second value that represents its addition or subtraction | 0           |

## 27.1.8.3.7 PTP Timestamp Adder Register (R32\_ETH\_PTPTSAR)

Offset address: 0x0718

TSA[31:16] 

TSA[15:0]

| Bit    | Name      | Access | Description                                                                                                                                                                                                                         | Reset Value |
|--------|-----------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:0] | TSA[31:0] | RW     | Timestamp adder value. This register is only used in fine tuning mode. The value of TSA is added to the accumulator every system cycle, and if the accumulator overflows, it will trigger a system time update in fine tuning mode. | 0           |

#### 27.1.8.3.8 PTP Target Time Register High 32 Bits (R32 ETH PTPTTHR)

Offset address: 0x071C

TTSH[31:16]

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8    | 7      | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|------|--------|---|---|---|---|---|---|---|
|    |    |    |    |    |    |   | TTSH | [15:0] |   |   |   |   |   |   |   |

| Bit    | Name       | Access | Description                                                                                                                                           | Reset Value |
|--------|------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:0] | TTSH[31:0] |        | Target time in seconds. If the PTP system time reaches or exceeds this value and the associated interrupt is enabled, an interrupt will be generated. |             |

## 27.1.8.3.9 PTP Target Time Register Low 32 Bits (R32\_ETH\_PTPTTLR)

Offset address: 0x0720

| 31 | 30         | 29 | 28 | 27 | 26 | 25 | 24    | 23      | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|------------|----|----|----|----|----|-------|---------|----|----|----|----|----|----|----|
|    |            |    |    |    |    |    | TTSL[ | [31:16] |    |    |    |    |    |    |    |
| 15 | 14         | 13 | 12 | 11 | 10 | 9  | 8     | 7       | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    | TTSL[15:0] |    |    |    |    |    |       |         |    |    |    |    |    |    |    |

| Bit    | Name       | Access | Description                                                                                                                                           | Reset Value |
|--------|------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:0] | TTSL[31:0] |        | Target time sub-second value. An interrupt is generated if the PTP system time reaches or exceeds this value and the associated interrupt is enabled. |             |

## **27.1.8.4 DMA Control Registers**

# 27.1.8.4.1 DMA Bus Mode Register (R32\_ETH\_DMATPDR)

| 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24   | 23    | 22 | 21      | 20 | 19 | 18           | 17 | 16 |
|----------|----|----|----|----|----|----|------|-------|----|---------|----|----|--------------|----|----|
|          |    | -  |    | -  |    | -  | Rese | erved | -  | -       |    | -  |              |    |    |
| 15       | 14 | 13 | 12 | 11 | 10 | 9  | 8    | 7     | 6  | 5       | 4  | 3  | 2            | 1  | 0  |
| Reserved |    |    |    |    |    |    |      |       | Γ  | OSL[4:0 | )] |    | Reser<br>ved | SR |    |

| Bit    | Name     | Access | Description                                                                                                                                                                                                                                                                                                                                                                     | Reset Value |
|--------|----------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:7] | Reserved | RO     | Reserved                                                                                                                                                                                                                                                                                                                                                                        | 0           |
| [6:2]  | DSL[4:0] | RW     | Descriptor hop length These bits define the jump distance in words (32 bits) between 2 descriptors that are not connected in a chained structure. The address hop is the address difference from the end of the current descriptor to the beginning of the next descriptor. When the DSL field is 0, the DMA considers the descriptors to be contiguous under a ring structure. | 0           |

| 1 | Reserved | RO | Reserved                                                                                                                                                                                                                                                                                                                                          | 0 |
|---|----------|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| 0 | SR       | RW | Software Reset When set to 1, the MAC's DMA controller resets the internal registers and logic circuits of all subsystems of the MAC. This bit is automatically cleared after the reset operation is completed for the different clock domain modules inside the MAC. Before rewriting the MAC's registers, you should ensure that this bit is 0. | 1 |

## 27.1.8.4.2 DMA Transmit Query Register (R32\_ETH\_DMATPDR)

Offset address: 0x1004

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24   | 23      | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|------|---------|----|----|----|----|----|----|----|
|    |    |    |    |    |    |    | TPDR | [31:16] |    |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8    | 7       | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    |    |      |         |    |    |    |    |    |    |    |

| Bit    | Name       | Access | Description                                                                                                                                                                                             | Reset Value |
|--------|------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:0] | TPDR[31:0] | RW     | Transmit query commands. The user initiates a suspended transmit process by writing any value to this register. After restarting the transmission process, this register will be automatically cleared. | 0           |

# 27.1.8.4.3 DMA Receive Query Register (R32\_ETH\_DMARPDR)

Offset address: 0x1008

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24   | 23      | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|------|---------|----|----|----|----|----|----|----|
|    |    |    |    |    |    |    | RPDR | [31:16] |    |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8    | 7       | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    | '  | '  |    |    | '  | RPDR | R[15:0] |    |    |    |    |    |    |    |

| Bit    | Name       | Access | Description                                                                                                                                                                                                                                                        | Reset Value |
|--------|------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:0] | RPDR[31:0] | RW     | Receive query commands. The receiving process may be interrupted by various accidents, and the user needs to write any value to this register to restart the receiving process. After restarting the receive process, this register will be automatically cleared. | 0           |

# 27.1.8.4.4 DMA Receive Descriptor Address Register (R32\_ETH\_DMARDLAR)

Offset address: 0x100C

|    |    |    |    |    |    | F | RDLAF | R[31:16 | ] |   |   |   |   |   |   |
|----|----|----|----|----|----|---|-------|---------|---|---|---|---|---|---|---|
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8     | 7       | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|    |    |    |    |    |    |   | RDLA  | R[15:0] |   |   |   |   |   |   |   |

| Bit    | Name        | Access | Description                                                                                                                                                                        | Reset Value |
|--------|-------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:0] | RDLAR[31:0] | RW     | This register is used to store the address of the first received DMA descriptor. Note that descriptors require 16-byte alignment, so the last 4 bits of this register should be 0. | 0           |

# 27.1.8.4.5 DMA Transmit Descriptor Address Register (R32\_ETH\_DMATDLAR)

Offset address: 0x1010

| 31 | 30           | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|    | TDLAR[31:16] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15 | 14           | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    | TDLAR[15:0]  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit    | Name        | Access | Description                                                                                                                                                                        | Reset Value |
|--------|-------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:0] | TDLAR[31:0] | RW     | This register is used to store the address of the first transmit DMA descriptor. Note that descriptors require 16-byte alignment, so the last 4 bits of this register should be 0. | 0           |

# 27.1.8.4.6 DMA Status Register (R32\_ETH\_DMASR)

| 31  | 30  | 29   | 28   | 27    | 26  | 25       | 24      | 23       | 22 | 21      | 20  | 19   | 18       | 17   | 16  |
|-----|-----|------|------|-------|-----|----------|---------|----------|----|---------|-----|------|----------|------|-----|
| PLS | Res | TSTS | PMTS | MMCS  | Res | F        | EBS[2:0 | )]       | -  | ΓPS[2:0 | )]  | F    | RPS[2:0  | )]   | NIS |
| 15  | 14  | 13   | 12   | 11    | 10  | 9        | 8       | 7        | 6  | 5       | 4   | 3    | 2        | 1    | 0   |
| AIS | ERS | FBES | Rese | erved | ETS | RWT<br>S | RPSS    | RBU<br>S | RS | TUS     | ROS | TJTS | TBU<br>S | TPSS | TS  |

| Bit | Name     | Access | Description                                               | Reset Value |
|-----|----------|--------|-----------------------------------------------------------|-------------|
|     |          |        | Internal 10M physical layer connection status. This bit   |             |
| 31  | PLS      |        | is set to indicate that the physical layer connection is  | 0           |
|     |          |        | up or down. Or write 1 to clear.                          |             |
| 30  | Reserved | RO     | Reserved                                                  | 0           |
|     |          | RO     | Timestamp trigger status. This bit will be set when an    |             |
| 29  | TSTS     |        | interrupt event occurs in the PTP section, or an          | 0           |
| 29  | 1313     |        | interrupt will be generated if the PTP interrupt is       | U           |
|     |          |        | enabled. This bit is automatically cleared after clearing |             |

|         |          |      | all flag bits in the PTP section.                                                                                                                                                                                                                                                                                                                                                                                                                                              |      |
|---------|----------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| 28      | PMTS     | RO   | PMT trigger status. This bit will be set when an interrupt event is generated in the PMT part, and an interrupt will be generated if the PMT interrupt is enabled. This bit is automatically cleared after clearing all flag bits in the PMT section.                                                                                                                                                                                                                          | 0    |
| 27      | MMCS     | RO   | MMC trigger status. This bit will be set when an interrupt event is generated in the MMC part, and an interrupt will be generated if the MMC interrupt is enabled. This bit is automatically cleared after clearing all flag bits in the MMC section.                                                                                                                                                                                                                          | 0    |
| 26      | Reserved | RO   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0    |
| [25:23] | EBS[2:0] | RO   | Error status. This field indicates the type of bus error that caused it. This field is only valid when the DMASR[13] bit is set.  DMASR[23]:0: Error sending DMA forwarding data;  1: Error receiving DMA forwarding data;  DMASR[24]:0: Error reading data forwarding;  RO 1: Error writing data forwarding;  DMASR[25]:0: Error accessing descriptor;  1: Error accessing data cache.                                                                                        | 0    |
| [22:20] | TPS[2:0] | RO   | Transmit process status. This field is used to indicate the status of the current transmit DMA.  000: Stop. Receive reset or stop sending command;  001: Run. Fetching the send descriptor;  010: Run. Waiting for status information;  011: Run. Reading the transmit buffer data and pushing it into the FIFO;  100,101: Reserved;  110: Pause. The transmit descriptor is not available or the transmit buffer data underflows;  111: Run. Closing the transmit descriptor. | 000Ь |
| [19:17] | RPS[2:0] | RO   | Receive process status. This field is used to indicate the current state of receiving DMA.  000: Stop. Receive reset or stop sending command;  001: Run. Fetching the receive descriptor;  010: Reserved;  011: Run. Waiting to receive data packets;  100: Pause. The receive descriptor is not available;  101: Run. Closing the receive descriptor;  110: Reserved;  111: Run. Pushing the received data from the FIFO into the memory.                                     | 000Ь |
| 16      | NIS      | RW1Z | Normal interrupt summary. With interrupts enabled in<br>the DMAIER register, if any of the following bits are<br>set, the NIS bit will also be set.                                                                                                                                                                                                                                                                                                                            | 0    |

|         |          |      | -DMASR[0]: Send interrupt; -DMASR[2]: The transmit buffer is not available; -DMASR[6]: Receive interrupt; -DMASR[14]: Early receive interrupt; -DMASR[31]:Internal 10M physical layer connection state change The NIS bit is sticky, when the corresponding interrupt status bit that causes NIS location 1 is cleared, the NIS                                                                                                                                                                                                                                                                                                                                                                               |   |
|---------|----------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| 15      | AIS      | RW1Z | bit must also be cleared by writing 1.  Abort interrupt summary. With interrupts enabled in the DMAIER register, the AIS bit will also be set if any of the following bits are set.  -DMASR[1]: The transmission is stopped;  -DMASR[3]: Transmit Jabber timeout;  -DMASR[4]: Receive FIFO overflow;  -DMASR[5]: Transmit data underflow;  -DMASR[7]: The receive buffer is not available;  -DMASR[8]: The reception is stopped;  -DMASR[9]: Receive watchdog timeout;  -DMASR[10]: Send early;  -DMASR[13]: Bus error;  The AIS bit is a sticky bit, and when the corresponding interrupt status bit that caused AIS location 1 is cleared to zero, the AIS bit must also be cleared to zero by writing a 1. | 0 |
| 14      | ERS      | RW1Z | Early receive status. When this bit is set, it means that the DMA has filled the first buffer when the data frame is received, but the complete frame has not been received yet. After RS is set, the ERS bit is automatically cleared.                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0 |
| 13      | FBES     | RW1Z | Bus error. When this bit is set, it indicates that a bus error was sent. See [25:23] bits for specific reasons. When this bit is set, the corresponding DMA controller will close the bus access.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0 |
| [12:11] | Reserved | RO   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0 |
| 10      | ETS      | RW1Z | Early transmit status. When set, it indicates that the transmit frame has been fully pushed into the FIFO.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0 |
| 9       | RWTS     | RW1Z | Watchdog time-out status. When set, it indicates that the frame length has exceeded 2048 bytes.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0 |
| 8       | RPSS     | RW1Z | Receive process stop status. This bit is set to indicate that the receive process has stopped.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0 |
| 7       | RBUS     | RW1Z | Receive buffer unavailable status. This bit is set to indicate that the permission to receive the descriptor belongs to the CPU, the DMA cannot be obtained, and the receiving process has been suspended. The user needs to release the descriptor and fill the RPDR                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0 |

|   |      |      | register with a value to resume the receive flow. The DMA will retry to acquire the descriptor when the next frame is received.                                                                                                                                                                        |   |
|---|------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| 6 | RS   | RW1Z | Receive completed status. This bit is set to indicate that the reception of a frame has been completed, and the frame information is also updated into the descriptor.                                                                                                                                 | 0 |
| 5 | TUS  | RW1Z | Transmit data underflow status. This bit is set to indicate that the transmit buffer under flowed the transmit data while transmitting the frame. At this point the sending process is halted and the data underflow error bit is set.                                                                 | 0 |
| 4 | ROS  | RW1Z | Receive status overflow. This bit is set to indicate that a data overflow has occurred in the receive buffer.                                                                                                                                                                                          | 0 |
| 3 | TJTS | RW1Z | Transmit Jabber timer timeout status. This bit is set to indicate that the transmitter is too busy, transmission has stopped, and the descriptor's Jabber timeout bit has been set.                                                                                                                    | 0 |
| 2 | TBUS | RW1Z | Transmit buffer unavailable status bit. This bit is set to indicate that the transmit descriptor is occupied by the CPU, the DMA cannot be acquired, and the transmit process has been suspended. Bits [22:20] show the current transmit status. The application needs to release the send descriptor. | 0 |
| 1 | TPSS | RW1Z | Transmit process stop status. This bit is set to indicate that the transmission process has stopped.                                                                                                                                                                                                   | 0 |
| 0 | TS   | RW1Z | Transmit completed status. This bit is set to indicate that the transmission of a frame has been completed, and the ownership of the descriptor has been returned to the CPU.                                                                                                                          | 0 |

# 27.1.8.4.7 DMA Operation Mode Register (R32\_ETH\_DMAOMR)

| 31                    | 30                   | 29 | 28 | 27 | 26 | 25 | 24    | 23   | 22  | 21   | 20   | 19   | 18    | 17  | 16 |
|-----------------------|----------------------|----|----|----|----|----|-------|------|-----|------|------|------|-------|-----|----|
| Reserved DTC Reserved |                      |    |    |    |    |    | erved |      | TSF | FTF  |      | Rese | erved |     |    |
| 15                    | 14                   | 13 | 12 | 11 | 10 | 9  | 8     | 7    | 6   | 5    | 4    | 3    | 2     | 1   | 0  |
| Rese                  | Reserved ST Reserved |    |    |    |    |    | FEF   | FUGF |     | Rese | rved |      | SR    | Res |    |

| Bit     | Name     | Access | Description                                                                                                                                                             | Reset Value |
|---------|----------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:27] | Reserved | RO     | Reserved                                                                                                                                                                | 0           |
| 26      | DTCEFD   | RW     | Discard TCP/IP checksum error frame disable 0: If the FEF bit is 0, the MAC will discard all frames with errors; 1: When an error is found in the checksum of protocols | 0           |

| discarded.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |         |          |      | such as TCP/IP/ICMP/UDP, the frame will not be          |   |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|----------|------|---------------------------------------------------------|---|
| Carrell   Reserved   RO   Reserved   Ro   Transmit store and forward.   O: After the data written into the FIFO in the sending process reaches a certain value, the sending will be started;   1: The sending process will start sending after the complete frame is written into the FIFO.   O: After sending process will start sending after the complete frame is written into the FIFO.   O: After sending process will start sending after the complete frame is written into the FIFO.   O: After sending the current frame, the sending process enters the stop transmission.   O: After sending the current frame, the sending process enters the stop state;   1: Put the sending process in the running state.   O: After sending process in the running state.   O: Reserved   O: Forward error frame.   O: Receive FIFO discards frames with errors.   O: Receive FIFO discards frames with errors.   O: The receive FIFO discards all frames less than 64   bytes in length;   O: The receive FIFO discards all frames less than 64   bytes in length;   1: The receive FIFO forwards a frame whose length is too short.   O: After forwarding the currently received frame, the receiving DMA enters the stop mode, and the next transmission starts from the current receiving descriptor from the current position or fetches the receiving descriptor from the current position or fetches the receiving descriptor from the identifier header position.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |         |          |      |                                                         |   |
| Transmit store and forward. 0: After the data written into the FIFO in the sending process reaches a certain value, the sending will be started; 1: The sending process will start sending after the complete frame is written into the FIFO.  20 FTF RW Transmit FIFO empty control. Setting this bit will reset the transmit FIFO.  [19:14] Reserved RO Reserved 0  Start or stop transmission. 0: After sending the current frame, the sending process enters the stop state; 1: Put the sending process in the running state.  [12:8] Reserved RO Reserved 0  Forward error frame. 0: Receive FIFO discards frames with errors. 1: All frames are forwarded to the DMA except for frames that are too short.  Forward too short frame. 0: The receive FIFO discards all frames less than 64 bytes in length; 1: The receive FIFO forwards a frame whose length is too short.  [5:2] Reserved RO Reserved 0  Start or stop reception. 0: After forwarding the currently received frame, the receiving DMA enters the stop mode, and the next transmission starts from the current receiving descriptor position; 1: Open the receiving process, DMA fetches the receiving descriptor from the current position or fetches the receiving descriptor from the identifier header position.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | [25,22] | Dagamyad | DO.  |                                                         | 0 |
| 21 TSF  RW  RW    Complete frame is written into the FIFO in the sending process reaches a certain value, the sending will be started;   I: The sending process will start sending after the complete frame is written into the FIFO.    Transmit FIFO empty control. Setting this bit will reset the transmit FIFO.    Process reaches a certain value, the sending after the complete frame is written into the FIFO.    RW   Reserved   RW   Reserved   RO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | [23:22] | Reserved | RO   |                                                         | U |
| TSF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |         |          |      |                                                         |   |
| 20 FTF RW Transmit FIFO empty control. Setting this bit will reset the transmit FIFO empty control. Setting this bit will reset the transmit FIFO.  20 FTF RW Transmit FIFO empty control. Setting this bit will reset the transmit FIFO.  3 ST RW Start or stop transmission.  3 ST RW Start or stop transmission.  4 O After sending the current frame, the sending process enters the stop state;  5 I: Put the sending process in the running state.  5 FEF RW ARW Start or stop transmission.  6 FUGF RW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START OF ARW START |         |          |      |                                                         |   |
| 1: The sending process will start sending after the complete frame is written into the FIFO.  20 FTF RW Transmit FIFO empty control. Setting this bit will reset the transmit FIFO.  [19:14] Reserved RO Reserved 0  Start or stop transmission.  0: After sending the current frame, the sending process enters the stop state; 1: Put the sending process in the running state.  [12:8] Reserved RO Reserved 0  Forward error frame.  0: Receive FIFO discards frames with errors. 1: All frames are forwarded to the DMA except for frames that are too short.  Forward too short frame. 0: The receive FIFO discards all frames less than 64 bytes in length; 1: The receive FIFO forwards a frame whose length is too short.  [5:2] Reserved RO Reserved 0  Start or stop reception. 0: After forwarding the currently received frame, the receiving DMA enters the stop mode, and the next transmission starts from the current receiving descriptor position; 1: Open the receiving process, DMA fetches the receiving descriptor from the current position or fetches the receiving descriptor from the identifier header position.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 21      | TSF      | RW   |                                                         | 0 |
| complete frame is written into the FIFO.    Transmit FIFO empty control. Setting this bit will reset the transmit FIFO.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |         |          |      | ,                                                       |   |
| Transmit FIFO empty control. Setting this bit will reset the transmit FIFO.  RW  Reserved  RO  Reserved  O  Start or stop transmission.  O: After sending the current frame, the sending process enters the stop state;  1: Put the sending process in the running state.  RO  Reserved  O  Reserved  O  Forward error frame.  O: Receive FIFO discards frames with errors.  1: All frames are forwarded to the DMA except for frames that are too short.  Forward too short frame.  O: The receive FIFO discards all frames less than 64 bytes in length;  1: The receive FIFO forwards a frame whose length is too short.  [5:2] Reserved  RO  Reserved  O  Start or stop reception.  O: After forwarding the currently received frame, the receiving DMA enters the stop mode, and the next transmission starts from the current receiving descriptor position;  1: Open the receiving process, DMA fetches the receiving descriptor from the identifier header position.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |         |          |      |                                                         |   |
| the transmit FIFO.  [19:14] Reserved  RO Reserved  O Start or stop transmission.  O: After sending the current frame, the sending process enters the stop state; 1: Put the sending process in the running state.  [12:8] Reserved  RO Reserved  O: Receive FIFO discards frames with errors. 1: All frames are forwarded to the DMA except for frames that are too short.  Forward too short frame. 0: The receive FIFO discards all frames less than 64 bytes in length; 1: The receive FIFO forwards a frame whose length is too short.  [5:2] Reserved  RO Reserved  O Start or stop reception. 0: After forwarding the currently received frame, the receiving DMA enters the stop mode, and the next transmission starts from the current receiving descriptor position; 1: Open the receiving process, DMA fetches the receiving descriptor from the identifier header position.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |         |          |      |                                                         |   |
| the transmit FIFO.  RO Reserved 0  Start or stop transmission.  0: After sending the current frame, the sending process enters the stop state; 1: Put the sending process in the running state.  RO Reserved 0  Forward error frame. 0: Receive FIFO discards frames with errors. 1: All frames are forwarded to the DMA except for frames that are too short.  Forward too short frame. 0: The receive FIFO discards all frames less than 64 bytes in length; 1: The receive FIFO forwards a frame whose length is too short.  [5:2] Reserved RO Reserved 0  Start or stop reception. 0: After forwarding the currently received frame, the receiving DMA enters the stop mode, and the next transmission starts from the current receiving descriptor position; 1: Open the receiving process, DMA fetches the receiving descriptor from the current position or fetches the receiving descriptor from the identifier header position.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 20      | FTF      | RW   |                                                         | 0 |
| Start or stop transmission.  O: After sending the current frame, the sending process enters the stop state;  1: Put the sending process in the running state.  [12:8] Reserved RO Reserved  Forward error frame.  O: Receive FIFO discards frames with errors.  1: All frames are forwarded to the DMA except for frames that are too short.  Forward too short frame.  O: The receive FIFO discards all frames less than 64 bytes in length;  1: The receive FIFO forwards a frame whose length is too short.  [5:2] Reserved RO Reserved  O Start or stop reception.  O: After forwarding the currently received frame, the receiving DMA enters the stop mode, and the next transmission starts from the current receiving descriptor position;  1: Open the receiving process, DMA fetches the receiving descriptor from the identifier header position.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |         |          |      |                                                         | - |
| 13 ST RW 0: After sending the current frame, the sending process enters the stop state; 1: Put the sending process in the running state.  [12:8] Reserved RO Reserved 0 Forward error frame. 0: Receive FIFO discards frames with errors. 1: All frames are forwarded to the DMA except for frames that are too short. Forward too short frame. 0: The receive FIFO discards all frames less than 64 bytes in length; 1: The receive FIFO forwards a frame whose length is too short.  [5:2] Reserved RO Reserved 0 Start or stop reception. 0: After forwarding the currently received frame, the receiving DMA enters the stop mode, and the next transmission starts from the current receiving descriptor position; 1: Open the receiving process, DMA fetches the receiving descriptor from the current position or fetches the receiving descriptor from the identifier header position.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | [19:14] | Reserved | RO   | Reserved                                                | 0 |
| 13 S1 RW enters the stop state; 1: Put the sending process in the running state.  [12:8] Reserved RO Reserved 0: Receive FIFO discards frames with errors. 1: All frames are forwarded to the DMA except for frames that are too short.  Forward too short frame. 0: The receive FIFO discards all frames less than 64 bytes in length; 1: The receive FIFO forwards a frame whose length is too short.  [5:2] Reserved RO Reserved 0 Start or stop reception. 0: After forwarding the currently received frame, the receiving DMA enters the stop mode, and the next transmission starts from the current receiving descriptor position; 1: Open the receiving process, DMA fetches the receiving descriptor from the current position or fetches the receiving descriptor from the identifier header position.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |         |          |      | Start or stop transmission.                             |   |
| enters the stop state;  1: Put the sending process in the running state.  [12:8] Reserved  RO Reserved  0: Receive FIFO discards frames with errors.  1: All frames are forwarded to the DMA except for frames that are too short.  Forward too short frame.  0: The receive FIFO discards all frames less than 64  bytes in length;  1: The receive FIFO forwards a frame whose length is too short.  [5:2] Reserved  RO Reserved  O Start or stop reception.  0: After forwarding the currently received frame, the receiving DMA enters the stop mode, and the next transmission starts from the current receiving descriptor position;  1 SR  RW descriptor position;  1: Open the receiving process, DMA fetches the receiving descriptor from the current position or fetches the receiving descriptor from the identifier header position.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 13      | ST       | RW   | 0: After sending the current frame, the sending process | 0 |
| Test   Reserved   RO   Reserved   Roward error frame.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 13      | 51       | 1000 | enters the stop state;                                  | V |
| FEF  RW  RW  O: Receive FIFO discards frames with errors.  1: All frames are forwarded to the DMA except for frames that are too short.  Forward too short frame.  O: The receive FIFO discards all frames less than 64 bytes in length;  1: The receive FIFO forwards a frame whose length is too short.  [5:2] Reserved  RO  Reserved  O: The receive FIFO forwards a frame whose length is too short.  O: After forwarding the currently received frame, the receiving DMA enters the stop mode, and the next transmission starts from the current receiving descriptor position;  1: Open the receiving process, DMA fetches the receiving descriptor from the current position or fetches the receiving descriptor from the identifier header position.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |         |          |      | 1: Put the sending process in the running state.        |   |
| 7 FEF  RW  0: Receive FIFO discards frames with errors. 1: All frames are forwarded to the DMA except for frames that are too short.  Forward too short frame. 0: The receive FIFO discards all frames less than 64  bytes in length; 1: The receive FIFO forwards a frame whose length is too short.  [5:2] Reserved  RO  Reserved  O  Start or stop reception. 0: After forwarding the currently received frame, the receiving DMA enters the stop mode, and the next transmission starts from the current receiving descriptor position; 1: Open the receiving process, DMA fetches the receiving descriptor from the current position or fetches the receiving descriptor from the identifier header position.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | [12:8]  | Reserved | RO   | Reserved                                                | 0 |
| 1: All frames are forwarded to the DMA except for frames that are too short.  Forward too short frame.  0: The receive FIFO discards all frames less than 64  bytes in length;  1: The receive FIFO forwards a frame whose length is too short.  [5:2] Reserved  RO Reserved  O: The receive FIFO forwards a frame whose length is too short.  [5:2] Reserved  O: After forwarding the currently received frame, the receiving DMA enters the stop mode, and the next transmission starts from the current receiving descriptor position;  1: Open the receiving process, DMA fetches the receiving descriptor from the current position or fetches the receiving descriptor from the identifier header position.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |         |          |      | Forward error frame.                                    |   |
| 1: All frames are forwarded to the DMA except for frames that are too short.  Forward too short frame.  0: The receive FIFO discards all frames less than 64 bytes in length;  1: The receive FIFO forwards a frame whose length is too short.  [5:2] Reserved  RO Reserved  O: Start or stop reception.  O: After forwarding the currently received frame, the receiving DMA enters the stop mode, and the next transmission starts from the current receiving descriptor position;  1: Open the receiving process, DMA fetches the receiving descriptor from the current position or fetches the receiving descriptor from the identifier header position.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 7       | DDD      | DW   | 0: Receive FIFO discards frames with errors.            | 0 |
| Forward too short frame.  0: The receive FIFO discards all frames less than 64  RW bytes in length;  1: The receive FIFO forwards a frame whose length is too short.  [5:2] Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | /       | FEF      | KW   | 1: All frames are forwarded to the DMA except for       | U |
| 0: The receive FIFO discards all frames less than 64 bytes in length; 1: The receive FIFO forwards a frame whose length is too short.  [5:2] Reserved RO Reserved O Start or stop reception. 0: After forwarding the currently received frame, the receiving DMA enters the stop mode, and the next transmission starts from the current receiving descriptor position; 1 SR RW descriptor position; 1: Open the receiving process, DMA fetches the receiving descriptor from the current position or fetches the receiving descriptor from the identifier header position.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |         |          |      | frames that are too short.                              |   |
| 6 FUGF RW bytes in length; 1: The receive FIFO forwards a frame whose length is too short.  [5:2] Reserved RO Reserved 0  Start or stop reception. 0: After forwarding the currently received frame, the receiving DMA enters the stop mode, and the next transmission starts from the current receiving descriptor position; 1 SR RW descriptor position; 1: Open the receiving process, DMA fetches the receiving descriptor from the current position or fetches the receiving descriptor from the identifier header position.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |         |          |      | Forward too short frame.                                |   |
| 1: The receive FIFO forwards a frame whose length is too short.  [5:2] Reserved  RO Reserved  O Start or stop reception.  0: After forwarding the currently received frame, the receiving DMA enters the stop mode, and the next transmission starts from the current receiving descriptor position;  1 SR  RW descriptor position;  1: Open the receiving process, DMA fetches the receiving descriptor from the current position or fetches the receiving descriptor from the identifier header position.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |         |          |      | 0: The receive FIFO discards all frames less than 64    |   |
| too short.  [5:2] Reserved  RO Reserved  O Start or stop reception.  O: After forwarding the currently received frame, the receiving DMA enters the stop mode, and the next transmission starts from the current receiving descriptor position;  1 SR  RW descriptor position;  1: Open the receiving process, DMA fetches the receiving descriptor from the current position or fetches the receiving descriptor from the identifier header position.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 6       | FUGF     | RW   | bytes in length;                                        | 0 |
| [5:2] Reserved  RO Reserved  Start or stop reception.  0: After forwarding the currently received frame, the receiving DMA enters the stop mode, and the next transmission starts from the current receiving descriptor position;  1 SR  RW descriptor position;  1: Open the receiving process, DMA fetches the receiving descriptor from the current position or fetches the receiving descriptor from the identifier header position.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |         |          |      | 1: The receive FIFO forwards a frame whose length is    |   |
| Start or stop reception.  0: After forwarding the currently received frame, the receiving DMA enters the stop mode, and the next transmission starts from the current receiving  1 SR RW descriptor position;  1: Open the receiving process, DMA fetches the receiving descriptor from the current position or fetches the receiving descriptor from the identifier header position.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |         |          |      | too short.                                              |   |
| 0: After forwarding the currently received frame, the receiving DMA enters the stop mode, and the next transmission starts from the current receiving  1 SR RW descriptor position; 0  1: Open the receiving process, DMA fetches the receiving descriptor from the current position or fetches the receiving descriptor from the identifier header position.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | [5:2]   | Reserved | RO   | Reserved                                                | 0 |
| receiving DMA enters the stop mode, and the next transmission starts from the current receiving  RW descriptor position;  1 Open the receiving process, DMA fetches the receiving descriptor from the current position or fetches the receiving descriptor from the identifier header position.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |         |          |      | Start or stop reception.                                |   |
| transmission starts from the current receiving  RW descriptor position;  1: Open the receiving process, DMA fetches the receiving descriptor from the current position or fetches the receiving descriptor from the identifier header position.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |         |          |      | 0: After forwarding the currently received frame, the   |   |
| 1 SR RW descriptor position; 0 1: Open the receiving process, DMA fetches the receiving descriptor from the current position or fetches the receiving descriptor from the identifier header position.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |         |          |      | receiving DMA enters the stop mode, and the next        |   |
| 1: Open the receiving process, DMA fetches the receiving descriptor from the current position or fetches the receiving descriptor from the identifier header position.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |         |          |      | transmission starts from the current receiving          |   |
| 1: Open the receiving process, DMA fetches the receiving descriptor from the current position or fetches the receiving descriptor from the identifier header position.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 1       | SR       | RW   | descriptor position;                                    | 0 |
| receiving descriptor from the current position or fetches the receiving descriptor from the identifier header position.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |         |          |      |                                                         |   |
| fetches the receiving descriptor from the identifier header position.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |         |          |      |                                                         |   |
| header position.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |         |          |      |                                                         |   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |         |          |      |                                                         |   |
| o Reserved 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0       | Reserved | RO   | Reserved                                                | 0 |

# 27.1.8.4.8 DMA Interrupt Enable Register (R32\_ETH\_DMAIER)

Offset address: 0x101C

| 31   | 30  | 29   | 28   | 27   | 26   | 25   | 24    | 23      | 22  | 21   | 20   | 19   | 18    | 17    | 16   |
|------|-----|------|------|------|------|------|-------|---------|-----|------|------|------|-------|-------|------|
| PLE  |     |      |      |      |      |      | R     | eserved | l   |      |      |      |       |       | NISE |
| 15   | 14  | 13   | 12   | 11   | 10   | 9    | 8     | 7       | 6   | 5    | 4    | 3    | 2     | 1     | 0    |
| AISE | ERS | FBES | Rese | rved | ETIE | RWTE | RPSIE | RBUIE   | RIE | TUIE | ROIE | ТЛТЕ | TBUIE | TPSIE | TIE  |

| Bit     | Name     | Access | Description                                             | Reset Value                           |
|---------|----------|--------|---------------------------------------------------------|---------------------------------------|
| 31      | PLE      | RW     | Internal 10M physical layer connection state change     | 0                                     |
| 31      | PLE      | KW     | interrupt enable.                                       | U                                     |
| [30:17] | Reserved | RO     | Reserved                                                | 0                                     |
|         |          |        | Normal interrupt enable. Enabling this bit will enable  |                                       |
|         |          |        | the following interrupts.                               |                                       |
| 16      | NISE     | RW     | -DMASR[0]: Transmit interrupt;                          | 0                                     |
| 10      | NISE     | ΚW     | -DMASR[2]: Transmit buffer unavailable;                 | U                                     |
|         |          |        | -DMASR[6]: Receive interrupt;                           |                                       |
|         |          |        | -DMASR[14]: Early receive interrupt.                    |                                       |
|         |          |        | Abnormal interrupt. Enabling this bit will enable the   |                                       |
|         |          |        | following interrupts.                                   |                                       |
|         |          |        | -DMASR[1]: The sending process is stopped;              |                                       |
|         |          |        | -DMASR[3]: Send Jabber timeout;                         |                                       |
|         |          |        | -DMASR[4]: Receive FIFO overflow;                       |                                       |
| 15      | AISE     | RW     | -DMASR[5]: transmit data underflow;                     | 0                                     |
|         |          |        | -DMASR[7]: Send buffer unavailable;                     |                                       |
|         |          |        | -DMASR[8]: The receiving process is stopped;            |                                       |
|         |          |        | -DMASR[9]: Receive watchdog timeout;                    |                                       |
|         |          |        | -DMASR[10]: Early transmit;                             |                                       |
|         |          |        | -DMASR[13]: Bus error.                                  |                                       |
|         |          |        | Early receive interrupt enable. Enable this bit to      |                                       |
| 14      | ERS      | RW     | generate an early receive interrupt. NISE must be set.  | 0                                     |
|         |          |        | AISE must be set.                                       |                                       |
| 13      | FBES     | RW     | Bus fatal error interrupt enable. Enable this bit to    | 0                                     |
| 13      | LDES     | KVV    | generate a bus error interrupt. AISE must be set.       | U                                     |
| [12:11] | Reserved | RO     | Reserved                                                | 0                                     |
| 10      | ETIE     | DW     | Early transmit interrupt enable. Enable this bit to     | 0                                     |
| 10      | ETIE     | RW     | generate an early transmit interrupt. AISE must be set. | 0                                     |
|         |          |        | Receive watchdog interrupt enable. Enable this bit to   |                                       |
| 9       | RWTIE    | RW     | generate a receive watchdog timeout interrupt. AISE     | 0                                     |
|         |          |        | must be set.                                            |                                       |
| 8       | RPSIE    | RW     | Receive process stop interrupt enable. Enable this bit  | 0                                     |
| 0       | KrSiE    | IXVV   | to generate a receive process stop interrupt.           | U                                     |
|         |          |        | Receive buffer unavailable interrupt enable. Enable     |                                       |
| 7       | RBUIE    | RW     | this bit to generate a receive buffer unavailable       | 0                                     |
|         |          |        | interrupt. AISE must be set.                            |                                       |
|         |          |        | Receive completed interrupt enable bit. Enable this bit |                                       |
| 6       | RIE      | RW     | to generate receive completed interrupt. NISE must be   | 0                                     |
|         |          |        | set.                                                    |                                       |
|         |          |        | Transmit underflow interrupt enable. Enable this bit to |                                       |
| 5       | TUIE     | RW     | generate a transmit underflow interrupt. AISE must be   | 0                                     |
|         |          |        | set.                                                    |                                       |
| 4       | ROIE     | RW     | Receive overflow interrupt. Enable this bit to generate | 0                                     |
| 4       | KOIE     | 17.44  | a receive overflow interrupt. AISE must be set.         | · · · · · · · · · · · · · · · · · · · |

| 3 | TJTIE | RW | Transmit Jabber timeout interrupt enable. Enable this bit to generate transmit Jabber timeout interrupt. AISE must be set.        | 0 |
|---|-------|----|-----------------------------------------------------------------------------------------------------------------------------------|---|
| 2 | TBUIE | RW | Transmit buffer unavailable interrupt enable. Enable this bit to generate transmit buffer unavailable interrupt. NISE must be set | 0 |
| 1 | TPSIE | RW | Transmit process stop interrupt enable. Enable this bit to generate transmit process stop interrupt. AISE must be set.            |   |
| 0 | TIE   | RW | Transmit completed interrupt enable. Enable this bit to generate transmit completed interrupt. NISE must be set.                  |   |

# 27.1.8.4.9 DMA Lost Frame Register (R32\_ETH\_DMAMFBOCR)

Offset address: 0x1020

| 31        | 30      | 29 | 28       | 27 | 26                      | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16       |
|-----------|---------|----|----------|----|-------------------------|----|----|----|----|----|----|----|----|----|----------|
| F         | Reserve | d  | OFO<br>C |    | MFA[10:0]               |    |    |    |    |    |    |    |    |    | OMF<br>C |
| 15        | 14      | 13 | 12       | 11 | 11 10 9 8 7 6 5 4 3 2 1 |    |    |    |    |    |    |    |    |    |          |
| MFC[15:0] |         |    |          |    |                         |    |    |    |    |    |    |    |    |    |          |

| Bit     | Name       | Access | Description                                            | Reset Value |
|---------|------------|--------|--------------------------------------------------------|-------------|
| [31:29] | Reserved   | RO     | Reserved                                               | 0           |
| 28      | OFOC       | RZ     | The overflow bit of the FIFO overflow counter.         | 0           |
| [27:17] | MFA[10:0]  | RZ     | Frames lost by the application.                        | 0           |
| 16      | OMFC       | RZ     | Missing frame counter overflow.                        | 0           |
| [15.0]  | MFC[15:0]  | RZ     | Lost frame counter. This field indicates the number of | 0           |
| [15:0]  | MIFC[13.0] | KZ     | frames lost due to unavailability of receive buffers.  | U           |

# 27.1.8.4.10 DMA Current Transmit Descriptor Register (R32\_ETH\_DMACHTDR)

| 31 | 30           | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|    | HTDAR[31:16] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15 | 14           | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    | HTDAR[15:0]  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit    | Name        | Access | Description                                                                                                           | Reset Value |
|--------|-------------|--------|-----------------------------------------------------------------------------------------------------------------------|-------------|
| [31:0] | HTDAR[31:0] | RO     | This register value points to the transmit descriptor currently in use. This register is updated in real time by DMA. |             |

### 27.1.8.4.11 DMA Current Receive Descriptor Register (R32\_ETH\_DMACHRDR)

Offset address: 0x104C

| 31 | 30           | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|    | HRDAR[31:16] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15 | 14           | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit    | Name        | Access | Description                                                                                                          | Reset Value |
|--------|-------------|--------|----------------------------------------------------------------------------------------------------------------------|-------------|
| [31:0] | HRDAR[31:0] |        | This register value points to the receive descriptor currently in use. This register is updated in real time by DMA. |             |

### 27.1.8.4.12 DMA Current Transmit Buffer Register (R32\_ETH\_DMACHTBAR)

Offset address: 0x1050

| 31 | 30           | 29 | 28 | 27 | 26 | 25 | 24   | 23      | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|--------------|----|----|----|----|----|------|---------|----|----|----|----|----|----|----|
|    | HTBAR[31:16] |    |    |    |    |    |      |         |    |    |    |    |    |    |    |
| 15 | 14           | 13 | 12 | 11 | 10 | 9  | 8    | 7       | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |              |    |    |    |    |    | HTBA | R[15:0] | ]  |    |    | '  |    |    |    |

| Bit    | Name        | Access | Description                                                                                                       | Reset Value |
|--------|-------------|--------|-------------------------------------------------------------------------------------------------------------------|-------------|
| [31:0] | HTBAR[31:0] |        | This register value points to the transmit buffer currently in use. This register is updated in real time by DMA. |             |

### 27.1.8.4.13 DMA Current Receive Buffer Register (R32\_ETH\_DMACHRBAR)

Offset address: 0x1054

| 31 | 30           | 29 | 28 | 27 | 26 | 25 | 24   | 23     | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|--------------|----|----|----|----|----|------|--------|----|----|----|----|----|----|----|
|    | HRBAR[31:16] |    |    |    |    |    |      |        |    |    |    |    |    |    |    |
| 15 | 14           | 13 | 12 | 11 | 10 | 9  | 8    | 7      | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |              |    |    |    |    |    | HRBA | R[15:0 | ]  |    |    |    |    |    |    |

| Ï | Bit    | Name        | Access | Description                                                                                                      | Reset Value |
|---|--------|-------------|--------|------------------------------------------------------------------------------------------------------------------|-------------|
|   | [31:0] | HRBAR[31:0] | RO     | This register value points to the receive buffer currently in use. This register is updated in real time by DMA. | 0           |

### 27.1.8.5 Internal 10M Physical Layer Register Address

### 27.1.8.5.1 Basic Control Register (BMCR)

| Bit | Name | Access | Description | Reset Value |
|-----|------|--------|-------------|-------------|
|-----|------|--------|-------------|-------------|

| 15      | Reset                       | RW/SC | 0: Normal operation;<br>1: PHY reset.                    | 0 |
|---------|-----------------------------|-------|----------------------------------------------------------|---|
| 14      | Loopback                    | RW    | 0: Normal operation; 1: Enable loopback.                 | 0 |
| 13      | Speed Selection             | RO    | 0: 10Mb/s;                                               | 0 |
| 12      | Auto-Negotiation            | RW    | 0: Disable auto-negotiation; 1: Enable auto-negotiation. | 1 |
| [11:10] | Reserved                    | RO    | Reserved                                                 | 0 |
| 9       | Restart<br>Auto-Negotiation | RW/SC | 0: Normal operation; 1: Restart auto-negotiation.        | 0 |
| 8       | Duplex Mode                 | RW    | 0: Half-duplex;<br>1: Full-duplex.                       | 1 |
| 7       | Collision Test              | RW    | 0: Normal operation; 1: Conflict test enabled.           | 0 |
| [6:0]   | Reserved                    | RO    | Reserved                                                 | 0 |

# 27.1.8.5.2 Basic Status Register (BMSR)

Offset address: 0x01

| Bit    | Name             | Access | Description                                   | Reset Value |  |  |  |  |
|--------|------------------|--------|-----------------------------------------------|-------------|--|--|--|--|
| [15:6] | Reserved         | RO     | Reserved                                      | 0           |  |  |  |  |
| 5      | Auto-Negotiation | RO     | 0: Auto-negotiation not completed;            | 0           |  |  |  |  |
| 5      | Complete         | KO     | 1: Auto-negotiation completed.                | U           |  |  |  |  |
| [4:3]  | Reserved         | RO     | Reserved                                      | 0           |  |  |  |  |
| 2      | Link             | DO.    | 0: Physical layer has not established a link; | 0           |  |  |  |  |
| 2      | Link             | RO     | 1: Physical layer establishes a link.         | 0           |  |  |  |  |
| [1:0]  | Reserved         | RO     | Reserved                                      | 0           |  |  |  |  |

# 27.1.8.5.3 Auto-Negotiation Linker Capability Register(R16\_ETH\_ANLPAR)

| Bit | Name     | Access | Description                                                                                                                                  | Reset Value |
|-----|----------|--------|----------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| 15  | NP       | RO     | Next page bit.  0: Transmit basic capability data page;  1: Transmit protocol details data page.                                             | 0           |
| 14  | ACK      | RO     | 0: No answer; 1: The linker acknowledges receipt of the capability data word from the local node.                                            | 0           |
| 13  | RF       | RO     | 0: The linker is not indicating a remote fault; 1: The linker is indicating a remote fault.                                                  | 0           |
| 12  | Reserved | RO     | Reserved                                                                                                                                     | 0           |
| 11  | ASYPAUSE | RO     | 0: The linker does not support asymmetric flow control.<br>When Auto-Negotiation is enabled, this bit reflects the<br>linker's capabilities; | 0           |

|       |               |    | 1: The linker supports asymmetric flow control.                                                                                                                            |        |
|-------|---------------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|
| 10    | PAUSE         | RO | 0: The linker does not support flow control; 1: The linker supports flow control. When Auto-Negotiation is enabled, this bit reflects the linker's capabilities.           | 0      |
| 9     | 100Base-T4    | RO | 0: 100Base-T4 is not supported by the linker; 1: 100Base-T4 is supported by the linker.                                                                                    | 0      |
| 8     | 100Base-TX-FD | RO | 0: 100Base-TX full duplex is not supported by the linker; 1: 100Base-TX full duplex is supported by the linker.                                                            | 0      |
| 7     | 100Base-TX    | RO | 0: 100Base-TX is not supported by the linker; 1: 100Base-TX is supported by the linker. This bit is also set after a 100Base-TX link is established by parallel detection. | 0      |
| 6     | 10Base-T-FD   | RO | 0: 10Base-TX full duplex is not supported by the linker; 1: 10Base-TX full duplex is supported by the linker.                                                              | 0      |
| 5     | 10Base-T      | RO | 0: 10Base-T is not supported by the linker; 1: 10Base-T is supported by the linker. This bit is also set after a 10 Base-T link is established by parallel detection.      | 0      |
| [4:0] | SELECT[4:0]   | RO | Binary encoding node selector for the linker, currently only CSMA/CD <00001> is specified.                                                                                 | 00001b |

## 27.1.8.5.4 Physical Layer Status Register (PHYSR)

Offset address: 0x10

| Bit    | Name          | Access | Description                      | Reset Value |  |  |  |  |  |
|--------|---------------|--------|----------------------------------|-------------|--|--|--|--|--|
| [15:4] | Reserved      | RO     | Reserved                         | 0           |  |  |  |  |  |
| 3      | Loophools 10M | RO     | 0: Normal mode;                  | 0           |  |  |  |  |  |
| 3      | Loopback_10M  | KO     | 1: PHY works in 10M self-loop.   |             |  |  |  |  |  |
| ,      | Ev11 10M      | D.O.   | 0: Half-duplex mode;             | 0           |  |  |  |  |  |
| 2      | Full_10M      | RO     | 1: PHY works at 10M full-duplex. | 0           |  |  |  |  |  |
| [1:0]  | Reserved      | RO     | Reserved                         | 0           |  |  |  |  |  |

## 27.1.8.5.5 Auto-flip Register (MDIX)

Offset Address: 0x1E

| Bit    | Name     | Access | Description                 | Reset Value |
|--------|----------|--------|-----------------------------|-------------|
| [15:4] | Reserved | RO     | Reserved                    | 0           |
|        |          |        | 1x: Reserved;               |             |
| [3:2]  | P/N      | RW     | 00: P/N polarity is normal; | 0           |
|        |          |        | 01: P/N polarity reversed.  |             |
|        |          |        | 00: Automatic;              |             |
| [1:0]  | T/R      | RW     | 01: MDIX;                   | 0           |
|        |          |        | 1x: MDI.                    |             |

### 27.2 For CH32F208, CH32V203, CH32V208 Product

#### 27.2.1 Introduction to Ethernet controller

The device integrates MAC, PHY, and DMA Ethernet controllers, compatible with the IEEE802.3 protocol. The internal DMA receives and transmit data to the system RAM. The PHY physical layer is a 10Mbit/s Ethernet transceiver. Several network PHY registers are available, and the receive/transmit performance can be set.

Regarding the bottom operation of the network, the subroutine library is provided mainly for application support, and the registers are not introduced in detail.

#### Main features:

- Support full-duplex and half-duplex.
- Support short-packet padding settings.
- Support CRC setting and padding.
- Support jumbo frame reception.
- Support different filter mode combinations.
- Support pause frame transmitting and setting.
- Support auto-negotiation mechanism.
- Support DMA for receiving and transmitting data.
- PHY transceiver is compatible with 10BASE-T, and the transmit module supports energy-saving mode.
- Built-in 50ohm transfer impedance matching resistor, also can be connected externally.
- Provide a globally unique MAC address assigned by IEEE.

### 27.2.2 Register Description

Table 27-23 Ethernet controller registers

| Name           | Offset Address | Description                                | Reset Value |
|----------------|----------------|--------------------------------------------|-------------|
| R8_ETH_EIE     | 0x40028003     | Interrupt enable register                  | 0x00        |
| R8_ETH_EIR     | 0x40028004     | Interrupt flag register                    | 0x00        |
| R8_ETH_ESTAT   | 0x40028005     | Status register                            | 0x00        |
| R8_ETH_ECON2   | 0x40028006     | PHY analog parameter setting register      | 0x0A        |
| R8_ETH_ECON1   | 0x40028007     | Receive/transmit control register          | 0x00        |
| R32_ETH_TX     | 0x40028008     | Transmit DMA control register              | 0xXXXXXXXX  |
| R16_ETH_ETXST  | 0x40028008     | Transmit DMA buffer start address register | 0xXXXX      |
| R16_ETH_ETXLN  | 0x4002800A     | Transmission length register               | 0xXXXX      |
| R32_ETH_RX     | 0x4002800C     | Receive DMA control register               | 0x00000000  |
| R16_ETH_ERXST  | 0x4002800C     | Receive DMA buffer start address register  | 0x0000      |
| R16_ETH_ERXLN  | 0x4002800E     | Reception length register                  | 0x0000      |
| R32_ETH_HTL    | 0x40028010     | Hash table low register                    | 0x484EA033  |
| R32_ETH_HTH    | 0x40028014     | Hash table high register                   | 0x5000EF97  |
| R32_ETH_MACON  | 0x40028018     | Receive filter control register            | 0x10000000  |
| R8_ETH_ERXFCON | 0x40028018     | Receive packet filter control register     | 0x00        |
| R8_ETH_MACON1  | 0x40028019     | Mac layer flow control register            | 0x00        |

| R8_ETH_MACON2   | 0x4002801A | Mac layer packet control register      | 0x00       |
|-----------------|------------|----------------------------------------|------------|
| R8_ETH_MABBIPG  | 0x4002801B | Minimum packet interval register       | 0x10       |
| R32_ETH_TIM     | 0x4002801C | Flow control pause frame time register | 0xXXXXXXXX |
| R16_ETH_EPAUS   | 0x4002801C | Flow control pause frame time register | 0xXXXX     |
| R16_ETH_MAMXFL  | 0x4002801E | Maximum receive packet length register | 0x0000     |
| R16_ETH_MIRD    | 0x40028020 | MII read register                      | 0x1100     |
| R32_ETH_MIWR    | 0x40028024 | MII write register                     | 0x00000000 |
| R8_ETH_MIREGADR | 0x40028024 | MII address register                   | 0x00       |
| R8_ETH_MISTAT   | 0x40028025 | MII status register                    | 0x00       |
| R16_ETH_MIWR    | 0x40028026 | MII write register                     | 0x0000     |
| R32_ETH_MAADRL  | 0x40028028 | MAC address low register               | 0xXXXXXXXX |
| R16_ETH_MAADRH  | 0x4002802C | MAC address high register              | 0xXXXX     |

27.2.2.1 Interrupt Enable Register (R8\_ETH\_EIE)

| Bit | Name              | Access | Description                         | Reset value |
|-----|-------------------|--------|-------------------------------------|-------------|
|     |                   |        | Ethernet interrupt enable           |             |
| 7   | RB_ETH_EIE_INTIE  | RW     | 0: Interrupt disabled;              | 0           |
|     |                   |        | 1: Interrupt enabled.               |             |
|     |                   |        | Receive completed interrupt enable  |             |
| 6   | RB_ETH_EIE_RXIE   | RW     | 0: Interrupt disabled;              | 0           |
|     |                   |        | 1: Interrupt enabled.               |             |
| 5   | Reserved          | RO     | Reserved                            | 0           |
|     |                   |        | Link change interrupt enable        |             |
| 4   | RB_ETH_EIE_LINKIE | RW     | 0: Interrupt disabled;              | 0           |
|     |                   |        | 1: Interrupt enabled.               |             |
|     |                   |        | Transmit completed interrupt enable |             |
| 3   | RB_ETH_EIE_TXIE   | RW     | 0: Interrupt disabled;              | 0           |
|     |                   |        | 1: Interrupt enabled.               |             |
|     |                   |        | Built-in 50ohm impedance matching   |             |
| 2   | DD ETH FIE D ENGO | DW     | resistor enable                     | 0           |
| 2   | RB_ETH_EIE_R_EN50 | RW     | 0: On-chip resistor disconnected;   | 0           |
|     |                   |        | 1: On-chip resistor connected.      |             |
|     |                   |        | Transmit error interrupt enable     |             |
| 1   | RB_ETH_EIE_TXERIE | RW     | 0: Interrupt disabled;              | 0           |
|     |                   |        | 1: Interrupt enabled.               |             |
|     |                   |        | Receive error interrupt enable      |             |
| 0   | RB_ETH_EIE_RXERIE | RW     | 0: Interrupt disabled;              | 0           |
|     |                   |        | 1: Interrupt enabled.               |             |

### 27.2.2.2 Interrupt Flag Register (R8\_ETH\_EIR)

| Bit | Name            | Access | Description            | Reset value |
|-----|-----------------|--------|------------------------|-------------|
| 7   | Reserved        | RO     | Reserved               | 0           |
| 6   | RB_ETH_EIR_RXIF | RW1    | Receive completed flag | 0           |
| 5   | Reserved        | RO     | Reserved               | 0           |

| 4 | RB_ETH_EIR_LINKIF | RW1 | Link change flag        | 0 |
|---|-------------------|-----|-------------------------|---|
| 3 | RB_ETH_EIR_TXIF   | RW1 | Transmit completed flag | 0 |
| 2 | Reserved          | RO  | Reserved                | 0 |
| 1 | RB_ETH_EIR_TXERIF | RW1 | Transmit error flag     | 0 |
| 0 | RB_ETH_EIR_RXERIF | RW1 | Receive error flag      | 0 |

### 27.2.2.3 Status Register (R8\_ETH\_ESTAT)

| Bit | Name                  | Access | Description                               | Reset value |
|-----|-----------------------|--------|-------------------------------------------|-------------|
| 7   | RB_ETH_ESTAT_INT      | RW1    | Interrupt                                 | 0           |
| 6   | RB_ETH_ESTAT_BUFER    | RW1    | Buffer error                              | 0           |
| 5   | RB_ETH_ESTAT_RXCRCER  | RO     | Receive CRC error                         | 0           |
| 4   | RB_ETH_ESTAT_RXNIBBLE | RO     | Receive nibble error                      | 0           |
| 3   | RB_ETH_ESTAT_RXMORE   | RO     | Receive more than the set maximum packets | 0           |
| 2   | RB_ETH_ESTAT_RXBUSY   | RO     | Receive in progress                       | 0           |
| 1   | RB_ETH_ESTAT_TXABRT   | RO     | Transmission interrupted by MCU           | 0           |
| 0   | Reserved              | RO     | Reserved                                  | 0           |

### 27.2.2.4 PHY Analog Parameter Setting Register (R8\_ETH\_ECON2)

| Bit   | Name                                     | Access | Description                                                                        | Reset value |
|-------|------------------------------------------|--------|------------------------------------------------------------------------------------|-------------|
| [7:4] | Reserved                                 | RO     | Reserved                                                                           | 0000Ь       |
| [3:1] | RB_ETH_ECON2_RX<br>RB_ETH_ECON2_MU<br>ST | RW     | Reserved. Must write 110b.                                                         | 110b        |
| 0     | RB_ETH_ECON2_TX                          | RW     | Transmitter energy-saving driver control 0: Rated driver. 1: Energy-saving driver. | 0           |

## 27.2.2.5 Receive/Transmit Control Register (R8\_ETH\_ECON1)

| Bit   | Name                   | Access | Description                           | Reset value |
|-------|------------------------|--------|---------------------------------------|-------------|
|       | RB ETH ECON1 TX        |        | Transmit module reset                 |             |
| 7     | RST                    | RW     | 0: Not reset.                         | 0           |
|       | KS1                    |        | 1: Reset the transmit module.         |             |
|       | DD ETH ECON1 DV        |        | Receive module reset                  |             |
| 6     | RB_ETH_ECON1_RX<br>RST | RW     | 0: Not reset.                         | 0           |
|       | KSI                    |        | 1: Reset the receive module.          |             |
| [5:4] | Reserved               | RO     | Reserved                              | 00b         |
|       |                        |        | Transmit start. Cleared automatically |             |
| 3     | RB_ETH_ECON1_TX        | RW     | after the transmission is completed.  | 0           |
| 3     | RTS                    | K W    | 0: No effect;                         | U           |
|       |                        |        | 1: Start transmission.                |             |
|       | DD ETH ECOM DV         |        | Receive enable                        |             |
| 2     | RB_ETH_ECON1_RX        | RW     | 0: Receive disabled.                  | 0           |
|       | EN                     |        | 1: Receive enabled.                   |             |
| [1:0] | Reserved               | RO     | Reserved                              | 0           |

### 27.2.2.6 Transmit DMA Buffer Address Register (R16\_ETH\_ETXST)

| Bit    | Name                | Access | Description                                                                                  | Reset value |
|--------|---------------------|--------|----------------------------------------------------------------------------------------------|-------------|
| [15:0] | R16_ETH_ETXST[15:0] | RW     | Transmit DMA buffer start address Low 15 bits are valid. The address must be 4-byte aligned. | X           |

### 27.2.2.7 Transmission Length (R16\_ETH\_ETXLN)

| Bit    | Name               | Access | Description         | Reset value |
|--------|--------------------|--------|---------------------|-------------|
| [15:0] | R16_ETH_ETXLN[15:0 | RW     | Transmission length | X           |

### 27.2.2.8 Receive DMA Buffer Address Register (R16\_ETH\_ERXST)

| Bit    | Name                    | Access | Description                                                                                 | Reset value |
|--------|-------------------------|--------|---------------------------------------------------------------------------------------------|-------------|
| [15:0] | R16_ETH_ERXST[1<br>5:0] | RW     | Receive DMA buffer start address Low 15 bits are valid. The address must be 4-byte aligned. | X           |

### 27.2.2.9 Reception Length Register (R16\_ETH\_ERXLN)

|   | Bit    | Name                 | Access | Description      | Reset value |
|---|--------|----------------------|--------|------------------|-------------|
| Ī | [15:0] | R16_ETH_ERXLN[1 5:0] | RO     | Reception length | 0           |

### 27.2.2.10 Hash Table Low Register (R32\_ETH\_HTL)

| Bit     | Name        | Access | Description       | Reset value |
|---------|-------------|--------|-------------------|-------------|
| [31:24] | R8_ETH_EHT3 | RW     | Hash Table byte 3 | X           |
| [23:16] | R8_ETH_EHT2 | RW     | Hash Table byte 2 | X           |
| [15:8]  | R8_ETH_EHT1 | RW     | Hash Table byte 1 | X           |
| [7:0]   | R8_ETH_EHT0 | RW     | Hash Table byte 0 | X           |

### 27.2.2.11 Hash Table High Register (R32\_ETH\_HTH)

| Bit     | Name             | Access | Description       | Reset value |
|---------|------------------|--------|-------------------|-------------|
| [31:24] | R8_ETH_EHT7[7:0] | RW     | Hash Table byte 7 | X           |
| [23:16] | R8_ETH_EHT6[7:0] | RW     | Hash Table byte 6 | X           |
| [15:8]  | R8_ETH_EHT5[7:0] | RW     | Hash Table byte 5 | X           |
| [7:0]   | R8_ETH_EHT4[7:0] | RW     | Hash Table byte 4 | X           |

### 27.2.2.12 Receive Filter Control Register (R8\_ETH\_ERXFCON)

| Bit | Name                    | Access | Description                                                                                                           | Reset value |
|-----|-------------------------|--------|-----------------------------------------------------------------------------------------------------------------------|-------------|
| 7   | RB_ETH_ERXFCON_U<br>CEN | RW     | Unicast match filter settings  0: Discard all unicast packets.  1: Receive packets with matching destination address. | 0           |
| 6   | Reserved                | RO     | Reserved                                                                                                              | 0           |

| 5 | RB_ETH_ERXFCON_C<br>RCEN | RW | CRC checksum filter settings 0: Discard packets with CRC errors. 1: Receive packets with CRC errors.                  | 0 |
|---|--------------------------|----|-----------------------------------------------------------------------------------------------------------------------|---|
| 4 | RB_ETH_ERXFCON_E<br>N    | RW | Receive filtering enable  0: Disable the receive filtering function.  1: Enable the receive filtering function.       | 0 |
| 3 | RB_ETH_ERXFCON_M<br>PEN  | RW | Magic packet filter settings 0: Discard magic packets. 1: Receive magic packets.                                      | 0 |
| 2 | RB_ETH_ERXFCON_H TEN     | RW | Hash table matching filter settings 0: Discard hash table match packets. 1: Receive packets with matching hash table. | 0 |
| 1 | RB_ETH_ERXFCON_M<br>CEN  | RW | Multicast packet matching filter settings 0: Discard all multicast packets. 1: Receive all multicast packets.         | 0 |
| 0 | RB_ETH_ERXFCON_B<br>CEN  | RW | Broadcast packet matching filter settings 0: Discard all broadcast packets. 1: Receive all broadcast packets.         | 0 |

# 27.2.2.13 Mac Layer Flow Control Register (R8\_ETH\_MACON1)

| Bit   | Name                     | Access | Description                                | Reset value |
|-------|--------------------------|--------|--------------------------------------------|-------------|
| [7:6] | Reserved                 | RO     | Reserved                                   | 0           |
|       |                          |        | Pause frame setting. Active at full-duplex |             |
|       |                          |        | 00: Stop transmitting pause frame;         |             |
|       | RB ETH MACON1 FC         |        | 01: Transmit a pause frame, and then stop  |             |
| [5:4] | EN EN                    | RW     | transmitting;                              | 0           |
|       | EN                       |        | 10: Periodically transmit pause frames;    |             |
|       |                          |        | 11: Transmit 0 timer pause frame, and      |             |
|       |                          |        | then stop transmitting.                    |             |
|       | RB_ETH_MACON1_TX PAUS    | RW     | Transmit pause frame enable control        | 0           |
| 3     |                          |        | 0: Not transmit pause frame;               |             |
|       |                          |        | 1: Transmit enabled.                       |             |
|       | RB_ETH_MACON1_RX<br>PAUS | RW     | Receive pause frame enable                 |             |
| 2     |                          |        | 0: Not receive pause frame;                | 0           |
|       |                          |        | 1: Receive enabled.                        |             |
|       |                          |        | Control frame setting                      |             |
| 1     | RB_ETH_MACON1_PA         | RW     | 0: Control frame will be filtered;         | 0           |
| 1     | SSALL                    | IX VV  | 1: Control frame that is not filtered will | U           |
|       |                          |        | be written to the buffer.                  |             |
|       | DD ETH MACONI M          |        | MAC layer receive enable                   |             |
| 0     | RB_ETH_MACON1_M          | RW     | 0: MAC does not receive data;              | 0           |
|       | ARXEN                    | l      | 1: MAC receive enabled.                    |             |

### 27.2.2.14 Mac Layer Packet Control Register (R8\_ETH\_MACON2)

| Bit   | Name                          | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Reset value |
|-------|-------------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [7:5] | RB_ETH_MACON2_PA<br>DCFG[2:0] | RW     | Short packet fill setting:  000: No short packet padding;  001: All short packets are padded with 0 to 60 bytes, then 4 bytes of CRC;  010: No short packet padding;  011: All short packets are filled with 0 to 64 bytes, then 4 bytes CRC;  100: No short packet padding;  101: VLAN network packets detected with field 0x8100 are automatically filled with 0 to 64 bytes, otherwise short packets are filled with 60 bytes of 0 and then 4 bytes of CRC after filling;  110: No short packets are filled;  111: All short packets are filled with 0 to 64 bytes, then 4-byte CRC. | 000Ь        |
| 4     | RB_ETH_MACON2_TX<br>CRCEN     | RW     | Transmit add CRC control  0: Hardware does not pad CRC;  1: Hardware pads CRC.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 0           |
| 3     | RB_ETH_MACON2_PH<br>DREN      | RW     | Special 4 bytes are not involved in CRC.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0           |
| 2     | RB_ETH_MACON2_HF<br>RMEN      | RW     | Jumbo frame received enable 0: Disabled to receive jumbo frame; 1: Enable to receive jumbo frame.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0           |
| 1     | Reserved                      | RO     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0           |
| 0     | RB_ETH_MACON2_FU<br>LDPX      | RW     | Ethernet communication mode  0: Half-duplex;  1: Full-duplex.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 0           |

### 27.2.2.15 Minimum Packet Interval Register (R8\_ETH\_MABBIPG)

| Bit   | Name                | Access | Description                             | Reset value |
|-------|---------------------|--------|-----------------------------------------|-------------|
| 7     | Reserved            | RO     | Reserved                                | 0           |
| [6:0] | R8_ETH_MABBIPG[6:0] | RW     | Minimum number of packet interval bytes | 0010000b    |

### 27.2.2.16 Flow Control Pause Frame Time Register (R16\_ETH\_EPAUS)

| Bit    | Name                | Access | Description                   | Reset value |
|--------|---------------------|--------|-------------------------------|-------------|
| [15:0] | R16_ETH_EPAUS[15:0] | RW     | Flow control pause frame time | XXXXh       |

### 27.2.2.17 Maximum Receive Packet Length Register (R16\_ETH\_MAMXFL)

| İ | Bit    | Name                 | Access | Description                   | Reset value |
|---|--------|----------------------|--------|-------------------------------|-------------|
| I | [15:0] | R16_ETH_MAMXFL[15:0] | RW     | Maximum receive packet length | 0000h       |

### 27.2.2.18 MII Read Register (R16\_ETH\_MIRD)

| ĺ | Bit    | Name               | Access | Description       | Reset value |
|---|--------|--------------------|--------|-------------------|-------------|
| Ĭ | [15:0] | R16_ETH_MIRD[15:0] | RW     | MII read register | 0x1100      |

#### 27.2.2.19 MII Address Register (R8\_ETH\_MIREGADR)

| Bit   | Name                      | Access | Description          | Reset value |
|-------|---------------------------|--------|----------------------|-------------|
| [7:5] | Reserved                  | RO     | Reserved             | 000b        |
| [4:0] | RB_ETH_MIREGADR_<br>MIRDL | RW     | PHY register address | 00000Ь      |

### 27.2.2.20 MII Status Register (R8\_ETH\_MISTAT)

| Bit   | Name           | Access | Description               | Reset value |
|-------|----------------|--------|---------------------------|-------------|
| [7:1] | Reserved       | RO     | Reserved                  | 0000000ь    |
|       |                |        | MII register status       |             |
| 0     | R8_ETH_MII_STA | RO     | 0: Read MII register;     | 0           |
|       |                |        | 1: Write to MII register. |             |

### 27.2.2.21 MII Write Register (R16\_ETH\_MIWR)

| Bit    | Bit Name Acce |    | Description        | Reset value |
|--------|---------------|----|--------------------|-------------|
| [15:0] | R16_ETH_MIWR  | WO | MII write register | 0000h       |

### 27.2.2.22 MAC Address Register (R32 ETH MAADRL, R16 ETH MAADRH)

| Bit    | Name                     | Access | Description              | Reset value   |
|--------|--------------------------|--------|--------------------------|---------------|
| [31:0] | R32_ETH_MAADRL<br>[31:0] | RW     | MAC Address bytes 1 to 4 | XXXXXXX<br>Xh |
| [15:0] | R16_ETH_MAADRH<br>[31:0] | RW     | MAC Address bytes 5 to 6 | XXXXh         |

Note: The contents of the internal 10M physical layer related registers are detailed in 27.1.8.5 Internal 10M physical layer related register address section.

### 27.2.3 Operation Guide

### 1. Initialization

- (1) Configure the safe register to enter safe mode. Enable Ethernet clock and power.
- (2) Enable the corresponding interrupt, which is optional. Enable impedance matching resistor.
- (3) Configure the receive filter mode, CRC function, MAC address.
- (4) Set the buffer.
- (5) Start receiving and enable interrupt.

#### 2. Transmit data

- (1) Write to R16 ETH ETXLN data length.
- (2) Write to R16 ETH ETXST data address.
- (3) Enable RB ETH ECON1 TXRTS to start transmitting.

#### 3. Receive data

(1) Preset the receive address and enable the reception.

- (2) Use the interrupt or query the receive completed status.
- (3) Read R16\_ETH\_ERXLN reception length.
- (4) Update R16\_ETH\_ERXST receiving address.

For specific applications, please use based on the Ethernet protocol stack library, and refer to the provided network application routines.

V2. 4 551 WCH<sup>®</sup>

# **Chapter 28 SDIO Interface (SDIO)**

#### This chapter applies to the whole family of CH32F20x, CH32V20x, CH32V30x and CH32V31x.

The "SDIO" mentioned separately in this chapter refers to a communication interface on the microcontroller designed to operate external memory cards such as SD cards or other devices, and is a peripheral of the microcontroller. The SDIO of the microcontroller is directly mounted on the HB bus, and the clock is directly provided by HCLK, which can achieve higher communication speed. The SDIO of the microcontroller is used as the SDIO host, and the controlled devices are also collectively referred to as SDIO devices. In applications, SDIO is generally used to read and write SD cards, TF cards or eMMC particles, or to control other devices that use SDIO as a communication interface, such as Wi-Fi/4G modules.

#### 28.1 Main Features

#### 28.1.1 Features

- Support SD card, SDIO card and MMC card
- 1-bit, 4-bit and 8-bit bus support
- The clock of SDIO can reach half of HCLK at maximum
- Compatible with MMC Specification 4.5
- Compatible with SD card specification 2.0, SDIO card specification 2.0
- Not compatible with SPI or QSPI

#### **28.1.2** Overview

The SDIO of the microcontroller supports communication with memory such as SD cards or MMC cards. It needs to be clear that SDIO only provides a set of clocks, data and command control sequences required to realize the single command transmission of SD cards and MMC cards. The sequence and combination of commands need to be determined by the user through the program. In addition, for various memory cards, SDIO can only realize the function of reading and writing, and the function of the file system provided by the file system needs to be realized by the user to build the file system through the program.

SDIO is different from the QSPI interface. It has no chip select pin and has an extra CMD pin. CMD can be regarded as a special data line, which is specially used to transmit commands and responses; SDIO is available in 1-bit, 4-bit and 8-bit data line widths; the SDIO clock generally works at a frequency below 400KHz during configuration. When the data transmission is officially performed, it can be configured as the maximum clock supported by the SDIO device. The maximum SDIO clock output supported by the microcontroller is Half of HCLK, according to the protocol, when the clock received by the SDIO device is greater than a certain threshold, the waveform peaks of the clock line, data line and command line need to be reduced to save the time-consuming of waveform rising and falling.

Unlike SD cards, SDIO cards often refer to non-storage devices such as WIFI/Bluetooth modules and 4G modules that use SDIO interfaces. If there is no special instruction, the content described in this chapter must be applicable to SD card, and the content only applicable to SDIO card or MMC card will be specially pointed out. In the description of this chapter, the SD card is regarded as the potential operation object first, followed by the SDIO card, and finally the MMC card.

#### 28.2 Interface and Clock

SDIO receives the control of the CPU through the HB bus. There is a FIFO interface in the SDIO register. The CPU or DMA obtains or generates data by reading and writing the FIFO. SDIO is directly clocked by HCLK, and has an interrupt entry that supports multiple interrupt sources. The pins directly controlled by SDIO are SDIO\_CK, SDIO\_CMD, SDIO\_D [7:0], which are connected to SDIO devices through several pins. SDIO is a host-dominated communication interface, and all transfers must be initiated by the microcontroller.

#### 28.2.1 Peripheral Structure

The structure of SDIO is shown in Figure 28-1.



Figure 28-1 SDIO structure diagram

SDIO is a peripheral that the microcontroller directly operates the SDIO device as a host. It is roughly composed of 5 modules: HB interface, clock control part, CMD line control part, data line control part and control register part. SDIO is a half-duplex for peripherals, the CPU writes the commands and data to be sent to the control register, and the command line and data line control module is responsible for pushing the command or data to the IO and adding CRC. The data flow of SDIO is responsible for the transfer from RAM to SDIO FIFO by general-purpose DMA. SDIO FIFO has 32 32-bit sizes.

### 28.2.2 Pins and Configuration

The pins that need to be configured for SDIO and their modes are shown in Table 28-1.

**GPIO** SDIO alternate function Required pin mode Required speed PC[8:11] Push-pull alternate output SDIO D[0:3] 50MHz PC12 SDIO CK Push-pull alternate output 50MHz PD2 SDIO CMD Push-pull alternate output 50MHz PB8 SDIO D4 Push-pull alternate output 50MHz PB9 SDIO D5 Push-pull alternate output 50MHz

Table 28-1 SDIO pin configuration

| PC6 | SDIO_D6 | Push-pull alternate output | 50MHz |
|-----|---------|----------------------------|-------|
| PC7 | SDIO_D7 | Push-pull alternate output | 50MHz |

Note: The SDIO\_CK pin should be configured as a float input when in slave mode, and slave mode is only available for CH32F20x\_D8, CH32F20x\_D8C, CH32V30x\_D8, CH32V30x\_D8C, and CH32V31x\_D8C products where the penultimate sixth digit of the lot number is not 0.

#### 28.2.3 Clock

The clock pin of SDIO is SDIO\_CK, and its output clock is obtained by dividing the frequency of HCLK, and the frequency dividing coefficient can be configured as any integer value between 2 and 261. SDIO devices generally only support a single bus mode with a clock of up to 400kHz during initialization. After initialization, the host generally initiates a switch to a low voltage operation, and at the same time increases the clock to the maximum clock that both the microcontroller and the SDIO device can accept. Different versions and speed grades of SD cards support different clock speeds and switching processes, and users need to understand for themselves.

#### 28.2.4 Command Path State Machine

The command workflow of SDIO follows the state machine shown in the figure below.



Figure 28-2 Command path state machine

#### 28.2.5 Data Path State Machine

The data workflow of SDIO follows the state machine shown in the figure below.



Figure 28-3 Data path state machine

## 28.3 SDIO Protocol Description

The communication on SDIO is based on transmission as the smallest unit. Each transmission always starts with the host sending a command on the CMD line. After some commands are sent, the SDIO device will also send a piece of data on the CMD line to reply to the host, which is called "Response", sometimes accompanied by the transmission of data, the transmission of data is on the D line. The format of commands and responses is fixed, and the definition of each field is determined according to different commands or responses. Responses and data transfers need to be issued or stopped within a specified time after the end of the command or response, otherwise a timeout error will be generated.

The purpose of this section is to let users have a preliminary understanding of the details of some specifications necessary to use SDIO in a relatively small space, and it does not guarantee detailed and timely updates. The SDIO of the microcontroller only guarantees that it implements the hardware operation basis of the SD 2.0, SDIO 2.0 and MMC 4.5 specifications, and does not necessarily support the functions defined in the higher version specifications, such as double-edge sampling. Users should carry out SDIO interactive programming based on SD specification, SDIO specification and MMC specification when doing specific development.

### 28.3.1 Bus Timing

The transmission of the SD card is initiated by the host initiating the CMD. The SD card may not reply with a response, but may reply with a short response and a long response, and some responses will be accompanied by data transmission. In the communication of the SDIO card or MMC card, there may also be a situation where the SDIO device actively reports an interruption. The timing is shown in the group of figures below.

V2. 4 555 WCH<sup>\*</sup>

Figure 28-4 SDIO no response timing and no data timing (Taking SD card as an example)



Figure 28-5 SDIO multi-block read timing (Taking SD card as an example)



Figure 28-6 SDIO multi-block write timing (Taking SD card as an example)



From host to cardFrom card to host

Data from card to host

Stop command

Stop data transmission

Command

Response

Data Flow

Data stop
operation

Data stop
operation

Figure 28-7 SDIO data stream read timing (Taking SDIO card as an example)

Figure 28-8 SDIO data stream write timing (Taking SDIO card as an example)



#### **28.3.2** Command

Most SDIO transfers start with a command (CMD), through which the SDIO host informs the device of its intentions. The format of the command is as follows.

Bit/Field Transmission Command End Start bit Command index CRC7 bit name bit parameters Rank/Width 47 [39:8] / 32 bits 46 [45:40] / 6 bits [7:1] / 7 bits 0 Value 0b1b X X X 1b

Table 28-2 Command format

### 4 types of commands:

- 1) Broadcast command (bc): sent to all cards on the bus, no response returned;
- 2) Broadcast command with response (bcr): sent to all cards on the bus, and a response is returned;
- 3) Point-to-point command (ac): issued to a specific card, but no data transmission;
- 4) Point-to-point command with data transmission (adtc): issued to a specific card with data transmission attached.

Below are some commonly used commands.

### 28.3.2.1 Basic Command

Basic commands are some of the more basic functions supported by the SD card.

Table 28-3 SD Card Basic Commands

| Table 26-3 SD Card Basic Collinialids |      |                                                                           |                         |                              |                                                  |  |
|---------------------------------------|------|---------------------------------------------------------------------------|-------------------------|------------------------------|--------------------------------------------------|--|
| Command index                         | Туре | Parameter                                                                 | Response format         | Abbreviation                 | Description                                      |  |
| CMD0                                  | bc   | [31:0] stuff bits are meaningless.                                        | None                    | GO_IDLE_STATE                | Reset all cards to IDLE state                    |  |
| CMD2                                  | bcr  | [31:0] stuff bits are meaningless.                                        | R2                      | ALL_SEND_CID                 | All cards reply<br>to CID                        |  |
| CMD3                                  | ber  | [31:0] stuff bits are meaningless.                                        | R6                      | SEND_RELATIVE_ADDR           | Reply to new<br>RCA                              |  |
| CMD7                                  | ac   | [31:16] RCA;<br>[15:0] stuff bits<br>are meaningless.                     | R1b<br>Selected<br>Card | SELECT/DESELECT_CARD         | Check or uncheck a card                          |  |
| CMD8                                  | bcr  | [31:12] reserved bits; [11:8] powered; [7:0] check mode.                  | R7                      | SEND_IF_COND                 | Send SD card interface conditions.               |  |
| CMD9                                  | ac   | [31:16] RCA;<br>[15:0] stuff bits<br>are meaningless.                     | R2                      | SEND_CSD                     | Require CSD.                                     |  |
| CMD10                                 | ac   | [31:16] RCA;<br>[15:0] stuff bits<br>are meaningless.                     | R2                      | SEND_CID                     | Require CID。                                     |  |
| CMD11                                 | ac   | [31:0] stuff bits are meaningless.                                        | R1                      | VOLATGE_SWITCH               | Switch to 1.8V.                                  |  |
| CMD12                                 | ac   | [31:0] stuff bits are meaningless.                                        | R1b                     | STOP_TRANSMISSION            | Force the card to stop transmission;             |  |
| CMD13                                 | ac   | [31:16] RCA;<br>[15] stuff bits are<br>meaningless;<br>[14:0] stuff bits. | R1                      | SEND_STATUS/SEND_TASK_STATUS | Transmit Status<br>or Task Status<br>Register    |  |
| CMD15                                 | ac   | [31:16] RCA,<br>[15:0] stuff bits<br>are meaningless.                     | None                    | GO_INACTIVE_STATE            | The card is required to enter the INACTIVE mode; |  |

### 28.3.2.2 Erase Command

The SD card is also a FLASH structure, and the FLASH needs to be erased before writing, but the SD card integrates erasing logic. If it is found that there is no erasure before executing the write command, it will automatically supplement the erasing operation. In many cases, especially before large batch writes, it can help to improve efficiency if the erase is actively performed.

Table 28-4 SD Card Erase Command [1]

| Command index | Туре | Parameter                           | Response format | Abbreviation       | Description                                |
|---------------|------|-------------------------------------|-----------------|--------------------|--------------------------------------------|
| CMD32         | ac   | [31:0] address to start erasing [2] | R1              | ERASE_WR_BLK_START | Set the first<br>address for<br>erasing    |
| CMD33         | ac   | [31:0] address to start erasing [2] | R1              | ERASE_WR_BLK_END   | Set the first<br>address for<br>erasing    |
| CMD38         | ac   | [31:0] erase mode                   | R1b             | ERASE              | The parameter is 0, that is, ordinary wipe |

Note 1: The erase command here is the erase command of SD card defined by SD protocol specification, and the erase command of SDIO card and MMC card is different from this.

Note 2: Currently commonly used SDHC/SDXC (2GB to 2TB) level erase address written by the card must be a block address, that is, 512-byte alignment.

#### 28.3.2.3 Block Read Command

Table 28-5 SD Card block read command [1]

| Command index | Туре | Parameter                                         | Response format | Abbreviation        | Description                                          |
|---------------|------|---------------------------------------------------|-----------------|---------------------|------------------------------------------------------|
| CMD16         | ac   | [31:0] block length                               | R1              | SET_BLOCKLEN        | write block length, 512                              |
| CMD17         | adtc | [31:0] address of a single block [1]              | R1              | READ_SINGLE_BLOCK   | Set the start address of a single read               |
| CMD18         | adtc | [31:0] address of a single block [1]              | R1              | READ_MULTIPLE_BLOCK | Set the start address of a single read               |
| CMD19         | adtc | [31:0] reserved bits                              | R1              | SEND_TUNING_BLOCK   | Send a 64-byte sequence representing the mode change |
| CMD20         | ac   | [31:28] reserved bits [27:0] speed control bits   | R1b             | SPEED_CLASS_CONTROL | speed control class                                  |
| CMD22         | ac   | [31:6] reserved bits<br>[5:0] extended<br>address | R1              | ADDRESS_EXTENSION   | SDUC will be used.                                   |
| CMD23         | ac   | [31:0] block counter                              | R1              | SET_BLOCK_COUNT     | block counter                                        |

Note: The erasing address written by the SDHC/SDXC (2GB to 2TB) level cards commonly used at present must be a block address, that is, 512-byte alignment.

#### 28.3.2.4 Write Command for Block Transfer

Table 28-6 SD Card block read command [1]

| Command index | Туре | Parameter                           | Response format | Abbreviation         | Description                                    |  |
|---------------|------|-------------------------------------|-----------------|----------------------|------------------------------------------------|--|
| CMD16         | ac   | [31:0] block length                 | R1              | SET_BLOCKLEN         | write block length, 512                        |  |
| CMD24         | adtc | [31:0] block address                | R1              | WRITE_BLOCK          | Set the start address of a single block write  |  |
| CMD25         | adtc | [31:0] addresses of multiple blocks | R1              | WRITE_MULTIPLE_BLOCK | Set the start address of multiple blocks write |  |
| CMD27         | adtc | [31:0] stuff bits                   | R1              | PROGRAM_CSD          | Programmable word programming for CSD          |  |

Note: The erasing address written by the SDHC/SDXC (2GB to 2TB) level cards commonly used at present must be a block address, that is, 512-byte alignment.

#### 28.3.3 Response

As a necessary reply from the SDIO device to the host, the response is also transmitted on the CMD line and must be replied within a specified time. The response transmission is high-order first and low-order last. The length of the response and the definition of each bit and each field are determined by the type of response, but all responses start with a fixed 0 start bit, followed by a fixed 0 transmission Direction bit [1]. All responses have a stop bit at the end, fixed at 1[1]. There are roughly 7 kinds of responses, SD card supports R1 / R1b / R2 / R3 / R6 / R7, SDIO card also supports R4 / R5, see the format below.

### 28.3.3.1 R1 Response

Normal response, the total length is 48 bits, with CRC7, and the card status field is 32 bits. The format is as follows.

Table 28-7 R1 response

| Bit/Field name | Start bit | Transmission bit | Response index   | Card Status      | CRC7           | End<br>bit |
|----------------|-----------|------------------|------------------|------------------|----------------|------------|
| Rank/Width     | 47        | 46               | [45:40] / 6 bits | [39:8] / 32 bits | [7:1] / 7 bits | 0          |
| value          | 0b        | 0b               | Follow CMD Index | X                | X              | 1b         |

### **28.3.3.2** R1b Response

The format of R1b is the same as that of R1, but a busy signal can be added after the response, that is, the data line D2 is clamped. The host needs to deal with it after receiving the busy signal (Detecting that SDIO\_D2 is low).

#### 28.3.3.3 R2 Response

Responses to specific commands, the total length is 136 bits, the CRC7 is included in the card status field, and the card status field is 128 bits. The card status field stores the value of the CID register or CSD register. The CID register is generally used as the reply to CMD2/CMD10, and the CSD register is generally used as the reply to CMD9. For the specific meaning of the CID/CSD register, see the section 28.4.2 Device Registers. It should be noted that R2 will only reply to the [127:1] segment of the CID/CSD register. The reserved bit [2] of the CID/CSD [0] fixed to 1 is occupied by the end bit, and the end bit is also fixed to 1. The format is as follows.

Bit/Field Start Transmission Command index Card status End bit name bit bit Rank/Width 135 134 0 [133:128] / 6 bits [127:1] / 127 bits 0b 111111b CID/CSD Value 0b1b

Table 28-8 R2 response

### 28.3.3.4 R3 Response

Reply to the dedicated response of the OCR register, the total length is 48 bits, and there is no CRC7. The OCR register is generally used as a reply to ACMD41. The format is as follows.

| Table 20 7 To Tesponse |       |              |                  |                  |                |         |  |  |  |  |
|------------------------|-------|--------------|------------------|------------------|----------------|---------|--|--|--|--|
| Bit/Field              | Start | Transmission | Command index    | Card Status      | Reserved       | End bit |  |  |  |  |
| name                   | bit   | bit          | Command midex    | Caru Status      | Reserved       | End on  |  |  |  |  |
| Rank/Width             | 47    | 46           | [45:40] / 6 bits | [39:8] / 32 bits | [7:1] / 7 bits | 0       |  |  |  |  |
| Value                  | 0b    | 0b           | 111111b          | OCR              | 1111111b       | 1b      |  |  |  |  |

Table 28-9 R3 response

#### 28.3.3.5 R4 Response

In response to the response of CMD5, reply to the special response of OCR and related registers, with a total length of 48 bits and a CRC7. R4 is used in SDIO card, the format is as follows.

Table 28-10 R4 response

| Bit/Field name   | Bit position | Width (bit) | value    |
|------------------|--------------|-------------|----------|
| Start bit        | 47           | 1           | 0b       |
| Transmission bit | 46           | 1           | 0b       |
| Reserve          | [45:40]      | 6           | 111111b  |
| Card ready       | 39           | 1           | X        |
| IO number of     | [38:36]      | 3           | X        |
| functions        |              |             |          |
| Current register | [35]         | 1           | X        |
| Stuff bits       | [34:33]      | 2           | 00b      |
| S18A             | 32           | 1           | X        |
| IO OCR           | [31:8]       | 24          | OCR      |
| CRC field        | [7:1]        | 7           | 1111111b |
| End bit          | 0            | 1           | 1b       |

Note: The format of MMC card R4 is different from SDIO card.

#### 28.3.3.6 R5 Response

A dedicated response to CMD5, with a total length of 48 bits and a CRC7. R5 is used in SDIO card, the format is as follows.

Table 28-11 R5 response

| Bit/Field name | Start<br>bit | Transmission bit | Command index | Stuff bit | Response format | Read and write data | CRC7  | End<br>bit |
|----------------|--------------|------------------|---------------|-----------|-----------------|---------------------|-------|------------|
| Rank           | 47           | 46               | [45:40]       | [39:24]   | [23:16]         | [15:8]              | [7:1] | 0          |
| width          | 1            | 1                | 6             | 16        | 8               | 8                   | 7     | 1          |
| Value          | 0b           | 0b               | 110100b       | 0000h     | X               | X                   | X     | 1b         |

Note: The format of MMC card R5 is different from SDIO card.

### **28.3.3.7 R6 Response**

Reply to the special response of RCA, with a total length of 48 bits and a CRC7. The format is as follows.

Table 28-12 R6 response

| Bit/Field | Start bit | Transmission | Command Card RCA |              | Card status bit      | CRC7  | End |
|-----------|-----------|--------------|------------------|--------------|----------------------|-------|-----|
| name      |           | bit          | index            | 04744 711077 | 0.01.0 0.000.00 0.10 | OTCO, | bit |
| rank      | 47        | 46           | [45:40]          | [39:24]      | [23:8]               | [7:1] | 0   |
| Width     | 1         | 1            | 6                | 16           | 16                   | 7     | 1   |
| Value     | 0b        | 0b           | 000011b          | X            | X                    | X     | 1b  |

#### 28.3.3.8 R7 Response

In response to the dedicated response of CMD8, it indicates the information of the supported voltage, with a total length of 48 bits, with CRC7, and the format is as follows.

Table 28-13 R7 response

| Bit/Field name | Start<br>bit | Transmission bit | Command index | Reserved<br>bit | PCIe<br>1V2<br>support | PCIe response | Accepted Voltage | Check<br>Feedback | CRC7  | End<br>bit |
|----------------|--------------|------------------|---------------|-----------------|------------------------|---------------|------------------|-------------------|-------|------------|
| Bit position   | 47           | 46               | [45:40]       | [39:22]         | 21                     | 20            | [19:16]          | [15:8]            | [7:1] | 0          |
| Width          | 1            | 1                | 6             | 18              | 1                      | 1             | 4                | 8                 | 7     | 1          |
| Value          | 0b           | 0b               | 001000b       | 00000h          | X                      | X             | X                | X                 | X     | 1b         |

#### 28.3.4 Data Transfer

Data transfer is carried out on the data line SDIO\_D, which has 3 widths of 1/4/8 bits. During data transfer, the start bit of a clock is generally at the front, the high bit of each byte is in the front, and the low bit is in the back. For the block transfer mode only supported by the SD card, the data transfer of each block is followed by a CRC.

Enable the RANDOM\_LEN\_EN bit, configure the byte length indicated by DBLOCKSIZE2, configure the total length of the transferred data indicated by R32\_SDIO\_DLEN, enable the DTEN bit, and fill in the data to the R32\_SDIO\_FIFO, then you can complete the transfer of the block of any byte length with CRC checksum. (Note: Only applicable to CH32F20x\_D8, CH32F20x\_D8C, CH32V30x\_D8, CH32V30x\_D8C, CH32V31x\_D8C products where the sixth last digit of the batch number is not 0)

The MMC card also supports the data streaming transfer mode, at this time no CRC is attached. the following figure shows the format of the data transfer.

Figure 28-9 SD card single bus data transfer byte format



Figure 28-10 SD card 4 bus data transfer byte format



Figure 28-11 SD card single bus data transfer in a 512-bit word format





Figure 28-12 SD card 4 bus data transfer in a 512-bit word format

### 28.3.5 Slave Mode

Turning on the SLV\_MODE bit means that it is in the state of waiting for commands from the host, with received command parameters placed in RESP1 and received command indexes placed in RESP2, while automatically answering to the host with an R1 type of answer, with the answer parameter being the value of CMDARG.

Data sent and received in slave mode refer to master mode, but the slave can use the SLV\_FORCE\_ERR bit to force a data block CRC error, thus indicating an undesired data read or write.

Note: (1) The slave supports only the R1 type of answer, and the command indexes and parameter meanings used for master-slave communication are defined by the software;

(2) Slave mode is only available for CH32F20x\_D8, CH32F20x\_D8C, CH32V30x\_D8, CH32V30x\_D8C, and CH32V31x\_D8C products with the penultimate sixth digit of the lot number that is not zero.

### 28.4 Application

#### 28.4.1 Device Initialization and Device Registers

#### 28.4.1.1 OCR

The Operation Conditions Register stores some information about the power supply voltage and related status bits of the SD card. The relevant bits are defined in the following table.

| Bit | Bit definition                 | Description                           |
|-----|--------------------------------|---------------------------------------|
| 0-3 | Reserved                       |                                       |
| 4   | Reserved                       |                                       |
| 5   | Reserved                       |                                       |
| 6   | Reserved                       |                                       |
| 7   | Reserved for low voltage range | C                                     |
| 8   | Reserved                       | Supported VDD voltage range in volts. |
| 9   | Reserved                       |                                       |
| 10  | Reserved                       |                                       |
| 11  | Reserved                       |                                       |
| 12  | Reserved                       |                                       |

Table 28-14 OCR bit definitions

| 13  | Reserved                        |                                                                    |
|-----|---------------------------------|--------------------------------------------------------------------|
| 14  | Reserved                        |                                                                    |
| 15  | 2.7-2.8                         |                                                                    |
| 16  | 2.8-2.9                         |                                                                    |
| 17  | 2.9-3.0                         |                                                                    |
| 18  | 3.0-3.1                         |                                                                    |
| 19  | 3.1-3.2                         |                                                                    |
| 20  | 3.2-3.3                         |                                                                    |
| 21  | 3.3-3.4                         |                                                                    |
| 22  | 3.4-3.5                         |                                                                    |
| 23  | 3.5-3.6                         |                                                                    |
| 24  | accept switching to 1.8V        |                                                                    |
| 25- | Reserved                        |                                                                    |
| 26  | Reserved                        |                                                                    |
| 27  | Over 2TB support status bit     |                                                                    |
| 28  | Reserved                        |                                                                    |
| 29  | UHS-II card status bits         | This bit is set to indicate that the card supports the UHS-II      |
| 29  | OTIS-II card status ofts        | interface.                                                         |
| 30  | Card capacity status (CCS)      | This bit is set to indicate that the card capacity is greater than |
|     | Cara capacity status (CCS)      | 2GB.                                                               |
| 31  | Card power-on status bit (busy) | This bit is set when the card is powered up. After power-on, other |
|     | cara power on states on (ousy)  | bits have meaning.                                                 |

#### 28.4.1.2 CID

CID stores some identifying information.

Table 28-15 CID bit definitions

| Bit/Field name        | Abbreviation | Width | Bit position |
|-----------------------|--------------|-------|--------------|
| Manufacturer ID       | MID          | 8     | [127:120]    |
| App ID                | OID          | 16    | [119:104]    |
| Product Name          | PNM          | 40    | [103:64]     |
| Product Revision      | PRV          | 8     | [63:56]      |
| Product Serial Number | PSN          | 32    | [55:24]      |
| Reserved              | None         | 4     | [23:20]      |
| Date of Manufacture   | MDT          | 12    | [19:8]       |
| CRC7                  | CRC          | 7     | [7:1]        |
| Fixed bit, always 1   | None         | 1     | [0]          |

### 28.4.1.3 CSD

The CSD register stores the characteristic data of the SD card. Taking the most commonly used SDHC and SDXC cards of the second version of the CSD as an example, the definitions of each field are as follows.

Table 28-16 CSD bit definitions

|                | Read and           |       |               |       |              |  |  |  |  |  |  |  |  |
|----------------|--------------------|-------|---------------|-------|--------------|--|--|--|--|--|--|--|--|
| Name           | Abbreviation       | Width | Value         | write | Bit position |  |  |  |  |  |  |  |  |
| CSD version    | CSD_STRUCTURE      | 2     | 01b           | RO    | [127:126]    |  |  |  |  |  |  |  |  |
| Reserved       | None               | 6     | 00_0000b      | RO    | [125120      |  |  |  |  |  |  |  |  |
| Reading        | TAAC               | 8     | 0Eh           | RO    | [119:112]    |  |  |  |  |  |  |  |  |
| access time    | TAAC               | 8     | OEII          | KO    | [119.112]    |  |  |  |  |  |  |  |  |
| Reading        |                    |       |               |       |              |  |  |  |  |  |  |  |  |
| access time in | NSAC               | 8     | 00h           | RO    | [111:104]    |  |  |  |  |  |  |  |  |
| clock cycles   |                    |       |               |       |              |  |  |  |  |  |  |  |  |
| Maximum data   |                    |       |               |       |              |  |  |  |  |  |  |  |  |
| transmission   | TRAN_SPEED         | 8     | 32h5Ah0Bh2Bh  | RO    | [103:96]     |  |  |  |  |  |  |  |  |
| speed          |                    |       |               |       |              |  |  |  |  |  |  |  |  |
| Card           |                    |       |               |       |              |  |  |  |  |  |  |  |  |
| command        | CCC                | 12    | X1X1101101X1b | RO    | [95:84]      |  |  |  |  |  |  |  |  |
| class          |                    |       |               |       |              |  |  |  |  |  |  |  |  |
| Maximum        |                    |       |               |       |              |  |  |  |  |  |  |  |  |
| length of read | READ_BL_LEN        | 4     | 9             | RO    | [83:80]      |  |  |  |  |  |  |  |  |
| data block     |                    |       |               |       |              |  |  |  |  |  |  |  |  |
| Allow block    | READ BL PARTIAL    | 1     | 0             | RO    | [79]         |  |  |  |  |  |  |  |  |
| partial read   | 16010_55_11111111  | -     |               | 110   | [, -]        |  |  |  |  |  |  |  |  |
| block write    | WRITE BLK MISALIGN | 1     | 0             | RO    | [78]         |  |  |  |  |  |  |  |  |
| misalignment   |                    | _     |               |       | [, ~]        |  |  |  |  |  |  |  |  |
| block read     | READ BLK MISALIGN  | 1     | 0             | RO    | [77]         |  |  |  |  |  |  |  |  |
| misaligned     |                    | _     |               |       | []           |  |  |  |  |  |  |  |  |
| Executed       | DSR IMP            | 1     | X             | RO    | [76]         |  |  |  |  |  |  |  |  |
| DSR            | _                  |       |               |       |              |  |  |  |  |  |  |  |  |
| Reserved       | None               | 6     | 00_000b       | RO    | [75:70]      |  |  |  |  |  |  |  |  |
| Device size    | C_SIZE             | 22    | XXXXXXh       | RO    | [69:48]      |  |  |  |  |  |  |  |  |
| Reserved       | None               | 1     | 0             | RO    | [47]         |  |  |  |  |  |  |  |  |
| Single block   | ERASE BLK EN       | 1     | 1             | RO    | [46]         |  |  |  |  |  |  |  |  |
| erase enable   |                    |       |               |       | L .          |  |  |  |  |  |  |  |  |
| Erase sector   | SECTOR SIZE        | 7     | 7Fh           | RO    | [45:39]      |  |  |  |  |  |  |  |  |
| size           | _                  |       |               |       |              |  |  |  |  |  |  |  |  |
| Write-protect  | WP GRP SIZE        | 7     | 0000000Ь      | RO    | [38:32]      |  |  |  |  |  |  |  |  |
| group size     |                    |       |               |       |              |  |  |  |  |  |  |  |  |
| Write Protect  | WP GRP ENABLE      | 1     | 0             | RO    | [31]         |  |  |  |  |  |  |  |  |
| Group Enable   |                    |       |               | 7.0   |              |  |  |  |  |  |  |  |  |
| Reserved       | None               | 2     | 00b           | RO    | [30:29]      |  |  |  |  |  |  |  |  |
| Write speed    | R2W FACTOR         | 3     | 010b          | RO    | [28:26]      |  |  |  |  |  |  |  |  |
| factor         | _                  |       |               |       |              |  |  |  |  |  |  |  |  |
| Maximum        | HADADE DE LEST     | _     |               | D.C.  | F0.5.003     |  |  |  |  |  |  |  |  |
| write data     | WRITE_BL_LEN       | 4     | 9             | RO    | [25:22]      |  |  |  |  |  |  |  |  |
| block length   | White by Barrie    | 4     |               | D.O.  | FO.17        |  |  |  |  |  |  |  |  |
| Allow block    | WRITE_BL_PARTIAL   | 1     | 0             | RO    | [21]         |  |  |  |  |  |  |  |  |

| partial writes             |                    |   |          |        |         |
|----------------------------|--------------------|---|----------|--------|---------|
| Reserved                   | None               | 5 | 00000b   | RO     | [20:16] |
| file format group          | FILE_FORMAT_GRP    | 1 | 0        | RO     | [15]    |
| Copy sign                  | TMP_WRITE_PROTECT  | 1 | X        | RW OTP | [14]    |
| Permanent write protection | PERM_WRITE_PROTECT | 1 | X        | RW OTP | [13]    |
| Temporary write protection | TMP_WRITE_PROTECT  | 1 | X        | RW     | [12]    |
| File format                | FILE_FOMAT         | 2 | 00b      | RO     | [11:10] |
| Reservef                   | None               | 2 | 00b      | RO     | [9:8]   |
| CRC                        | CRC                | 7 | 0000000Ь | RW     | [7:1]   |
| Not used,<br>must use 1    | None               | 1 | 1b       | RO     | [0]     |

#### 28.4.1.4 RCA

The relative card address register stores the address of the card, which is 16 bits, and the default value is 0.

### 28.4.2 Voltage Switch

In the later stage of SD card initialization, it is necessary to switch the interface level, and switch the IO level of the clock line, data line and command line of the SD card to the 1.8V level. For devices whose slew rate is not good enough, using a lower-level standard can help increase the frequency. However, the power supply voltage of SD does not necessarily change, and only SD cards with low voltage power supply appear in the newer version of the protocol.

The steps for switching the voltage are shown in the figure below.

Figure 28-13 Voltage switch sequence



#### 28.4.3 Clock Switch

During initialization, the clock of the SD card is only 400KHz. After the voltage switch is completed, the clock can be increased to a higher level. For example, the first speed of the SDHC card UHS-I mode, the bus clock can reach 80MHz. In view of the IO output capability of the microcontroller, the clock should be limited to 50MHz.

## 28.5 Interrupt

### 28.5.1 SDIO Interrupt

SDIO supports a variety of interrupt sources. As shown in the interrupt enable register (R32 SDIO IER), there are 24 situations that can trigger interrupts, and users can enable them as appropriate.

### 28.5.2 SDIO Device Interrupt

It should be noted that not only SDIO peripherals can report interrupts to the CPU, but also external SDIO cards and MMC cards can report interrupts to SDIO peripherals. In 4-bit bus mode, the interrupt line is D1, and in 8-bit bus mode, the interrupt line is D7, active low. If SDIO detects that D1 or D7 is low level in the idle state, it should read the status register or interrupt flag register of the SDIO device to respond to the interrupt in time. The CPU can get whether the SDIO host receives an interrupt through the SDIOIT bit of the R32\_SDIO\_STA register.

Table 28-17 SDIO registers

# 28.6 Register Description

| Name             | Address    | Description                 | Reset Value |
|------------------|------------|-----------------------------|-------------|
| R32_SDIO_POWER   | 0x40018000 | Power register              | 0x00000000  |
| R32_SDIO_CLKCR   | 0x40018004 | Clock register              | 0x00000000  |
| R32_SDIO_ARG     | 0x40018008 | Command parameter register  | 0x00000000  |
| R32_SDIO_CMD     | 0x4001800C | Command register            | 0x00000000  |
| R32_SDIO_RESPCMD | 0x40018010 | Response register           | 0x00000000  |
| R128_SDIO_RESPX  | 0x40018014 | Response parameter register | 0x00000000  |
| R32_SDIO_DTIMER  | 0x40018024 | Data timing register        | 0x00000000  |
| R32_SDIO_DLEN    | 0x40018028 | Data length register        | 0x00000000  |
| R32_SDIO_DCTLR   | 0x4001802C | Data control register       | 0x00000000  |
| R32_SDIO_DCOUNT  | 0x40018030 | Data count register         | 0x00000000  |
| R32_SDIO_STA     | 0x40018034 | Status register             | 0x00000000  |
| R32_SDIO_ICR     | 0x40018038 | Interrupt clear register    | 0x00000000  |
| R32_SDIO_MASK    | 0x4001803C | Interrupt enable register   | 0x00000000  |
| R32_SDIO_FIFOCNT | 0x40018048 | FIFO counter                | 0x00000000  |
| R32_SDIO_DCTRL2  | 0x40018060 | Data control register 2     | 0x00000000  |
| R32_SDIO_FIFO    | 0x40018080 | FIFO register               | 0x00000000  |

### 28.6.1 Power Register (R32 SDIO POWER)

| 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20   | 19          | 18 | 17 | 16 |
|----------|----|----|----|----|----|----|----|----|----|----|------|-------------|----|----|----|
| Reserved |    |    |    |    |    |    |    |    |    |    |      |             |    |    |    |
| 15       | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4    | 3           | 2  | 1  | 0  |
| Reserved |    |    |    |    |    |    |    |    |    |    | PWR0 | CTRL[<br>0] |    |    |    |

| Bit Name Access Description Reservation | et value |
|-----------------------------------------|----------|
|-----------------------------------------|----------|

| [31:2] | Reserved     | RO | Reserved                                   | 0 |
|--------|--------------|----|--------------------------------------------|---|
|        |              |    | Power control:                             |   |
|        |              |    | 00: Power down, clock stops;               |   |
| [1:0]  | PWRCTRL[1:0] | RW | 01: Reserved;                              | 0 |
|        |              |    | 10: Reserved power-on status;              |   |
|        |              |    | 11: Power-on, the card clock is turned on; |   |

# 28.6.2 Clock Register (R32\_SDIO\_CLKCR)

| 31           | 30          | 29          | 28         | 27 | 26         | 25         | 24        | 23          | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|-------------|-------------|------------|----|------------|------------|-----------|-------------|----|----|----|----|----|----|----|
|              | Reserved    |             |            |    |            |            |           |             |    |    |    |    |    |    |    |
| 15           | 14          | 13          | 12         | 11 | 10         | 9          | 8         | 7           | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Reser<br>ved | HWF<br>C_EN | NEGE<br>DGE | WIDE<br>:0 |    | BYP<br>ASS | PWR<br>SAV | CLK<br>EN | CLKDIV[7:0] |    |    |    |    |    |    |    |

| Bit     | Name        | Access                                                     | Description                                                                                                                                                                              | Reset Value |  |  |  |  |
|---------|-------------|------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--|--|--|--|
| [31:15] | Reserved    | RO                                                         | Reserved                                                                                                                                                                                 | 0           |  |  |  |  |
| [14]    | HWFC_EN     | RW                                                         | Hardware flow control enable. TXFIFOE and RXFIFOF signals have effect after this bit is set.  0: Disable hardware flow control;  1: Enable hardware flow control.                        | 0           |  |  |  |  |
| [13]    | NEGEDGE     | RW                                                         | SDIO_CK phase selection.  0: SDIO_CK is generated on the rising edge of HCLK;  1: SDIO_CK is generated on the falling edge of HLCK.                                                      | 0           |  |  |  |  |
| [12:11] | WIDBUS[1:0] | RW                                                         | Bus width configuration.  00: 1-bit bus mode, use SDIO_D0;  01: 4-bit bus mode, use SDIO_D[3:0];  10: 8-bit bus mode, use SDIO_D[7:0];  11: Not used.                                    | 0           |  |  |  |  |
| [10]    | BYPASS      | Clock bypass enable. 0: SDIO_CK is obtained after divider; |                                                                                                                                                                                          |             |  |  |  |  |
| [9]     | PWRSAV      | RW                                                         | Free clock state configuration. After this bit is set, SDIO_CK output is disabled when bus is free, to save power.  0: SDIO_CK is always output;  1: SDIO_CK is only output when needed. |             |  |  |  |  |
| [8]     | CLKEN       | RW                                                         | Clock enable.  0: SDIO_CK output is disabled;  1: SDIO_CK output is enabled.                                                                                                             | 0           |  |  |  |  |
| [7:0]   | CLKDIV      | RW                                                         | Clock frequency division factor. This field                                                                                                                                              | 0           |  |  |  |  |

| represents the relationship between SDIO_CK and |  |
|-------------------------------------------------|--|
| HCLK. SDIO_CK=HCLK/(CLKDIV+2). Note             |  |
| that SDIO_CK should be lower than 400kHz        |  |
| during initialization.                          |  |
| Note: The minimum setting value of CLKDIV[7:0]  |  |
| is 1.                                           |  |

Note: (1) The clock configuration register is used to control SDIO\_CK related parameters. It should be noted that this register cannot be changed during the period of reading and writing data to 7 HCLK cycles.

(2) No need to configure clock register in slave mode.

## 28.6.3 Command Parameter Register (R32\_SDIO\_ARG)

Offset address: 0x08

| 31 | 30                                    | 29 | 28 | 27 | 26 | 25 | 24   | 23     | 22  | 21 | 20 | 19 | 18 | 17 | 16 |
|----|---------------------------------------|----|----|----|----|----|------|--------|-----|----|----|----|----|----|----|
|    |                                       |    |    |    |    | С  | MDAR | G[31:1 | [6] |    |    |    |    |    |    |
| 15 | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |    |    |    |    |    |      |        |     |    | 0  |    |    |    |    |
|    | CMDARG[15:0]                          |    |    |    |    |    |      |        |     |    |    |    |    |    |    |

| ĺ | Bit    | Name   | Access | Description                                                                                                                                                                                                                                 | Reset Value |
|---|--------|--------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
|   | [31:0] | CMDARG |        | Master mode: Command parameter field. This field stores the parameters in the command, which will be sent to the CMD line as part of the command.  Slave mode: 32-bit response parameter register to which the slave replies to the answer. | 0           |

# 28.6.4 Command Register (R32\_SDIO\_CMD)

| 31  | 30         | 29       | 28                 | 27                  | 26         | 25           | 24          | 23         | 22          | 21 | 20 | 19    | 18     | 17 | 16 |
|-----|------------|----------|--------------------|---------------------|------------|--------------|-------------|------------|-------------|----|----|-------|--------|----|----|
|     |            |          |                    |                     | -          |              | Rese        | erved      | -           | -  | -  |       | -      | -  |    |
| 15  | 14         | 13       | 12                 | 11                  | 10         | 9            | 8           | 7          | 6           | 5  | 4  | 3     | 2      | 1  | 0  |
| Res | ATAC<br>MD | NIE<br>N | ENC<br>MDC<br>ompl | SDIO<br>Suspe<br>nd | CPS<br>MEN | WAIT<br>PEND | WAIT<br>INT | WAIT<br>1: | RESP[<br>0] |    | C  | MDINI | DEX[5: | 0] |    |

| Bit     | Name        | Access | Description                                                                                     | Reset Value |
|---------|-------------|--------|-------------------------------------------------------------------------------------------------|-------------|
| [31:15] | Reserved    | RO     | Reserved                                                                                        | 0           |
| [14]    | ATACMD      | RW     | Carry out CE-ATA command. If this bit is set, CPSM will go to CMD61.                            | 0           |
| [13]    | NIEN        | RW     | Not enable CE-ATA interrupt setting. If this bit is set, CE-ATA will not generate an interrupt. | 0           |
| [12]    | ENCMDCompl  | RW     | Enable CMD completed signal enable. If this bit is set, command completion will be signaled.    | 0           |
| [11]    | SDIOSuspend | RW     | Suspend command. If this bit is set, a suspend signal will be sent. Applies to SDIO cards only. | 0           |
| [10]    | CPSMEN      | RW     | CPSM (Command Path State Machine) enable. If                                                    | 0           |

|       |               |    | set, CPSM is enabled.                               |   |  |
|-------|---------------|----|-----------------------------------------------------|---|--|
|       |               | RW | Command wait control. If this bit is set, the CPSM  |   |  |
| [9]   | WAITPEND      |    | will wait for the data transfer to complete before  | 0 |  |
|       |               |    | sending the command.                                |   |  |
|       | WAITINT       |    | Command wait interrupt control. If this bit is set, |   |  |
| [8]   |               | RW | the CPSM will turn off the timeout control and      | 0 |  |
|       |               |    | wait for an interrupt to be generated.              |   |  |
|       | WAITRESP[1:0] |    | Response type. This field indicates the type of     |   |  |
|       |               |    | response the CPSM expects to receive.               |   |  |
|       |               |    | 00: No response, wait for the CMDSENT flag;         |   |  |
| [7,6] |               | DW | 01: Short response, wait for CMDREND or             | 0 |  |
| [7:6] |               | RW | CCRCFAIL flag;                                      | U |  |
|       |               |    | 10: No response, wait for the CMDSENT flag;         |   |  |
|       |               |    | 11: Long response, wait for CMDREND or              |   |  |
|       |               |    | CCRCFAIL flag;                                      |   |  |
| [5,0] | CMDINDEV[5,0] | RW | Command index. This field indicates the specific    |   |  |
| [5:0] | CMDINDEX[5:0] | KW | command value.                                      | 0 |  |

# 28.6.5 Response Register (R32\_SDIO\_RESPCMD)

Offset address: 0x10

| 31 | 30       | 29 | 28 | 27 | 26 | 25 | 24   | 23    | 22 | 21 | 20 | 19   | 18  | 17 | 16 |
|----|----------|----|----|----|----|----|------|-------|----|----|----|------|-----|----|----|
|    |          |    |    |    |    |    | Rese | erved |    |    |    |      |     |    |    |
| 15 | 14       | 13 | 12 | 11 | 10 | 9  | 8    | 7     | 6  | 5  | 4  | 3    | 2   | 1  | 0  |
|    | Reserved |    |    |    |    |    |      |       |    |    |    | RESF | CMD |    |    |

| Bit    | Name         | Name Access Description |                                                              |         |  |  |  |
|--------|--------------|-------------------------|--------------------------------------------------------------|---------|--|--|--|
| [31:6] | Reserved     | RO                      | Reserved                                                     | 0       |  |  |  |
| [5:0]  | RESPCMD[5:0] | RO                      | This field records the index value of the received response. | 000000ь |  |  |  |

28.6.6 Response Parameter Register (R128 SDIO RESPX)

| ĺ | Bit     | Name        | Access | Description                                                                                                                                                                                                                                                                                                            | Reset Value |
|---|---------|-------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
|   | [127:0] | CARDSTATUSx | RO     | Master mode: When the response is a long response, the whole 128 bits indicate the card status; when the response is a short response, the lower 32 bits indicate the card status. the SDIO peripheral receives the highest bit of the card status first and stores it starting from the lowest bit of R128_SDIO_RESX. | 0           |

# 28.6.6.1 Response Parameter Register High 32 Bits (R128\_SDIO\_RESP1[127:96])

Offset address: 0x14

CARDSTATUS1

| _15 | 14 | 13 | 12 | 11 | 10 | 9 | 8     | 7     | 6      | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|---|-------|-------|--------|---|---|---|---|---|---|
|     |    |    |    |    |    | ( | CARDS | TATUS | <br>S1 |   |   |   |   |   |   |

| Bit    | Name        | Access | Description                                                                                                                                                                                                                                                                          | Reset Value |
|--------|-------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:0] | CARDSTATUS1 | RO     | Master mode: card status [127:96]; Slave mode: command parameters received by the receive command.  Note: Slave mode is only available for CH32F20x_D8, CH32F20x_D8C, CH32V30x_D8, CH32V30x_D8C, and CH32V31x_D8C with the penultimate sixth digit of the lot number not being zero. | 0           |

### 28.6.6.2 Response Parameter Register Second High 32 Bits (R128\_SDIO\_RESP2[95:64])

Offset address: 0x18

| 31 | 30 | 29 | 28 | 27 | 26 | 25  | 24   | 23          | 22     | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|-----|------|-------------|--------|----|----|----|----|----|----|
|    |    |    |    |    |    | CAR | DSTA | rus2[9      | 5:80]  |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8    | 7           | 6      | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    | CAR | DSTA | -<br>ΓUS2[7 | 79:64] |    |    |    |    |    |    |

| Bit    | Name        | Access | Description                                                                                                                                                                                                                                                                           | Reset Value |
|--------|-------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:0] | CARDSTATUS2 | RO     | Master mode: Card status [95:64]; Slave mode: Index of the command received by the receive command.  Note: Slave mode is only available for CH32F20x_D8, CH32F20x_D8C, CH32V30x_D8, CH32V30x_D8C, and CH32V31x_D8C with the penultimate sixth digit of the lot number not being zero. | 0           |

### 28.6.6.3 Response Parameter Register Second Low 32 Bits (R128\_SDIO\_RESP3[63:32])

Offset address: 0x1C

| 31 | 30 | 29 | 28 | 27 | 26 | 25  | 24   | 23             | 22     | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|-----|------|----------------|--------|----|----|----|----|----|----|
|    |    |    |    |    |    | CAR | DSTA | ΓUS3[ <i>ϵ</i> | 53:48] |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8    | 7              | 6      | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    | CAR | DSTA | ΓUS3[4         | 18:32] |    |    |    |    |    |    |

| İ | Bit    | Name        | Access | Description                       | Reset Value |
|---|--------|-------------|--------|-----------------------------------|-------------|
| ĺ | [31:0] | CARDSTATUS3 | RO     | Master mode: Card status [63:32]. | 0           |

### 28.6.6.4 Response Parameter Register Low 32 Bits (R128\_SDIO\_RESP4[31:0])

| 31 | 30 | 29 | 28 | 27 | 26 | 25  | 24   | 23     | 22    | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|-----|------|--------|-------|----|----|----|----|----|----|
|    |    |    |    |    |    | CAR | DSTA | ΓUS4[3 | 1:16] |    |    |    |    |    |    |

| 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8     | 7     | 6     | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|-----|-------|-------|-------|---|---|---|---|---|---|
|    |    |    |    |    |    | CAI | RDSTA | TUS4[ | 15:0] |   |   |   |   |   |   |

| ĺ | Bit    | Name        | Access | Description                      | Reset Value |
|---|--------|-------------|--------|----------------------------------|-------------|
|   | [31:0] | CARDSTATUS4 | RO     | Master mode: Card status [31:0]; | 0           |

### 28.6.7 Data Timing Register (R32\_SDIO\_DTIMER)

Offset address: 0x24

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24     | 23     | 22  | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|--------|--------|-----|----|----|----|----|----|----|
|    |    |    |    |    |    | D  | ATATIN | мE[31: | 16] |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8      | 7      | 6   | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    | D  | ATATI  | ME[15  | :0] |    |    |    |    |    |    |

|   | Bit    | Name     | Access | Description                                     | Reset Value |
|---|--------|----------|--------|-------------------------------------------------|-------------|
| I | [31:0] | DATATIME | RW     | Data timeout period. SDIO_CK cycle as the unit. | 0           |

# 28.6.8 Data Length Register (R32\_SDIO\_DLEN)

Offset address: 0x28

| 31 | 30 | 29 | 28      | 27 | 26 | 25 | 24 | 23 | 22 | 21   | 20    | 19      | 18 | 17 | 16 |
|----|----|----|---------|----|----|----|----|----|----|------|-------|---------|----|----|----|
|    |    |    | Reserve | ed |    |    |    |    | Γ  | ATAL | ENGTI | H[24:10 | 6] |    |    |
| 15 | 14 | 13 | 12      | 11 | 10 | 9  | 8  | 7  | 6  | 5    | 4     | 3       | 2  | 1  | 0  |
|    |    |    |         |    |    |    |    |    |    |      |       |         |    |    |    |

| Bit     | Name              | Access | Description                                          | Reset Value |  |  |  |  |
|---------|-------------------|--------|------------------------------------------------------|-------------|--|--|--|--|
| [31:25] | Reserved          | RO     | Reserved                                             | 0           |  |  |  |  |
|         |                   |        | Data length. The value of this field is loaded into  |             |  |  |  |  |
|         |                   |        | the transfer counter when a transfer is started. For |             |  |  |  |  |
|         | DATALENGTH[24: 0] |        | block transfers, the value of this field must be an  |             |  |  |  |  |
| [24:0]  |                   | RW     | integer multiple of the block size. The block size   | 0           |  |  |  |  |
|         |                   |        | is defined by the SDIO device and stored in          |             |  |  |  |  |
|         |                   |        | R32_SDIO_DCTLR[7:4]. Common values are               |             |  |  |  |  |
|         |                   |        | 512B, etc.                                           |             |  |  |  |  |

## 28.6.9 Data Control Register (R32\_SDIO\_DCTRL)

| 31 | 30       | 29 | 28 | 27 | 26        | 25         | 24          | 23   | 22   | 21     | 20  | 19        | 18         | 17        | 16       |
|----|----------|----|----|----|-----------|------------|-------------|------|------|--------|-----|-----------|------------|-----------|----------|
|    |          |    |    |    |           |            | Rese        | rved |      |        |     |           |            |           |          |
| 15 | 14       | 13 | 12 | 11 | 10        | 9          | 8           | 7    | 6    | 5      | 4   | 3         | 2          | 1         | 0        |
|    | Reserved |    |    |    | RWM<br>OD | RWS<br>TOP | RWS<br>TART | DB   | LOCK | SIZE[3 | :0] | DMAE<br>N | DTM<br>ODE | DTDI<br>R | DTE<br>N |

| Ï | Bit     | Name     | Access | Description | Reset Value |
|---|---------|----------|--------|-------------|-------------|
|   | [31:12] | Reserved | RO     | Reserved    | 0           |

| [11]  | SDIOEN          | RW | SDIO enable. When this bit is set, the DPSM can perform some operations specific to the SDIO card.                                                                                                                                                                                                                   | 0 |
|-------|-----------------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| [10]  | RWMOD           | RW | Read wait mode.  0: Stop SDIO_CK control read wait;  1: Use SDIO D2 to control read wait.                                                                                                                                                                                                                            | 0 |
| [9]   | RWSTOP          | RW | Read wait stop. If the RWSTART bit is set, the read wait will be stopped.                                                                                                                                                                                                                                            | 0 |
| [8]   | RWSTART         | RW | Read wait start. Setting this bit will perform a read wait operation.                                                                                                                                                                                                                                                | 0 |
| [7:4] | DBLOCKSIZE[3:0] | RW | Data block size. This field stores the size of the data block, and the block transfer length must be defined before using the block transfer. The value that can be written in this field is between 0 and 1110b, which indicates that the block transfer length is $2^{\text{BLKLEN}}$ (Between 0 and 16384 bytes). | 0 |
| [3]   | DMAEN           | RW | DMA enable. 0: Disable DMA; 1: Enable DMA.                                                                                                                                                                                                                                                                           | 0 |
| [2]   | DTMODE          | RW | Data mode. Set this bit to configure the transfer mode.  0: Block transfer;  1: Stream transfer.  Note: The 4-bit and 8-bit bus mode of streaming transmission only supports products with the last six digits of batch numbers of CH32F20x_D8, CH32F20x_D8C, CH32V30x_D8C, and CH32V31x_D8C not being 0.            | 0 |
| [1]   | DTDIR           | RW | Data direction. Set this bit to configure the transfer direction.  0: From controller to card;  1: From card to controller.                                                                                                                                                                                          | 0 |
| [0]   | DTEN            | RW | Data enable. Set this bit to start data transfer.  Specific process: after setting this bit, DPSM enters the process of Wait_S or Wait_R (Depending on the data direction).                                                                                                                                          | 0 |

## 28.6.10 Data Count Register (R32\_SDIO\_DCOUNT)



| ĺ | Bit     | Name     | Access | Description | Reset Value |
|---|---------|----------|--------|-------------|-------------|
|   | [31:25] | Reserved | RO     | Reserved    | 0           |

|        |                 |    | Data count. The value of the transmission length      |   |
|--------|-----------------|----|-------------------------------------------------------|---|
| [24:0] | DATACOUNT[24:0] | RO | register will be loaded into this counter when a      | 0 |
| [24.0] | DATACOUNT[24.0] | KO | transfer is initiated and decremented as the transfer | U |
|        |                 |    | progresses.                                           |   |

# 28.6.11 Status Register (R32\_SDIO\_STA)

| 31               | 30               | 29        | 28        | 27         | 26              | 25               | 24              | 23              | 22         | 21              | 20               | 19               | 18               | 17               | 16           |
|------------------|------------------|-----------|-----------|------------|-----------------|------------------|-----------------|-----------------|------------|-----------------|------------------|------------------|------------------|------------------|--------------|
|                  |                  |           | Rese      | ved        |                 |                  |                 | CEAT<br>AEND    | SDIO<br>IT | RXD<br>AVL      | TXD<br>AVL       | RXFI<br>FOE      | TXFI<br>FOE      | RXFI<br>FOF      | TXFI<br>FOF  |
| 15               | 14               | 13        | 12        | 11         | 10              | 9                | 8               | 7               | 6          | 5               | 4                | 3                | 2                | 1                | 0            |
| RXFI<br>FOH<br>F | TXF<br>IFO<br>HE | RXA<br>CT | TXAC<br>T | CMDA<br>CT | DBC<br>KEN<br>D | STBI<br>TER<br>R | DAT<br>AE<br>ND | CM<br>DSE<br>NT |            | RXO<br>VER<br>R | TXU<br>NDE<br>RR | DTI<br>MEO<br>UT | CTI<br>MEO<br>UT | DCR<br>CFAI<br>L | CCRC<br>FAIL |

| Bit     | Name     | Access | Description                                                                            | Reset Value |
|---------|----------|--------|----------------------------------------------------------------------------------------|-------------|
| [31:24] | Reserved | RO     | Reserved                                                                               | 0           |
| [23]    | CEATAEND | RO     | When this bit is set, CMD61 receives the CE-ATA completed signal.                      | 0           |
| [22]    | SDIOIT   | RO     | When this bit is set, SDIO receives a device interrupt.                                | 0           |
| [21]    | RXDAVL   | RO     | When this bit is set, data in the Rx FIFO is valid.                                    | 0           |
| [20]    | TXDAVL   | RO     | When this bit is set, data in the Tx FIFO is valid.                                    | 0           |
| [19]    | RXFIFOE  | RO     | When this bit is set, the Rx FIFO is empty.                                            | 0           |
| [18]    | TXFIFOE  | RO     | When this bit is set, the Tx FIFO is empty.                                            | 0           |
| [17]    | RXFIFOF  | RO     | When this bit is set, the Rx FIFO is full.                                             | 0           |
| [16]    | TXFIFOF  | RO     | When this bit is set, the Tx FIFO is full.                                             | 0           |
| [15]    | RXFIFOHF | RO     | When this bit is set, the Rx FIFO is half full.                                        | 0           |
| [14]    | TXFIFOHE | RO     | When this bit is set, the Tx FIFO is half empty.                                       | 0           |
| [13]    | RXACT    | RO     | When this bit is set, data is being received.                                          | 0           |
| [12]    | TXACT    | RO     | When this bit is set, data is being transmitted.                                       | 0           |
| [11]    | CMDACT   | RO     | When this bit is set, a command is being transmitted.                                  | 0           |
| [10]    | DBCKEND  | RO     | When this bit is set, the data block has been sent or received and the CRC has passed. | 0           |
| [9]     | STBITERR | RO     | When this bit is set, no start signal is detected on all data lines in wide bus mode.  | 0           |
| [8]     | DATAEND  | RO     | When this bit is set, the data transfer is complete (The transfer counter is zero).    | 0           |
| [7]     | CMDSENT  | RO     | When this bit is set, the command has been sent.                                       | 0           |
| [6]     | CMDREND  | RO     | When this bit is set, the response has been received and the CRC is successful.        | 0           |
| [5]     | RXOVERR  | RO     | When this bit is set, the Rx FIFO overflows.                                           | 0           |
| [4]     | TXUNDERR | RO     | When this bit is set, the transmit FIFO underflows.                                    | 0           |
| [3]     | DTIMEOUT | RO     | When this bit is set, the data times out.                                              | 0           |
| [2]     | CTIMEOUT | RO     | When this bit is set, the command timeout exceeds 64 SDIO_CK cycles.                   | 0           |

| [1] | DCRCFAIL | l RO | When this bit is set, a data block has been sent or received but the CRC failed. | 0 |
|-----|----------|------|----------------------------------------------------------------------------------|---|
| [0] | CCRCFAIL | l RO | When this bit is set, the response has been received but<br>the CRC has failed.  | 0 |

# 28.6.12 Interrupt Clear Register (R32\_SDIO\_ICR)

| 31       | 30 | 29      | 28 | 27 | 26               | 25                | 24 | 23                | 22               | 21               | 20                | 19                | 18                | 17                | 16                |
|----------|----|---------|----|----|------------------|-------------------|----|-------------------|------------------|------------------|-------------------|-------------------|-------------------|-------------------|-------------------|
| Reserved |    |         |    |    |                  |                   |    | CEAT<br>AEN<br>DC | SDIOI<br>TC      | Reserved         |                   |                   |                   |                   |                   |
| 15       | 14 | 13      | 12 | 11 | 10               | 9                 | 8  | 7                 | 6                | 5                | 4                 | 3                 | 2                 | 1                 | 0                 |
|          | I  | Reserve | ed |    | DBC<br>KEN<br>DC | STBI<br>TERR<br>C |    | CMDS<br>ENTC      | CMD<br>REN<br>DC | RXO<br>VER<br>RC | TXU<br>NDE<br>RRC | DTIM<br>EOUT<br>C | CTI<br>MEO<br>UTC | DCR<br>CFAI<br>LC | CCR<br>CFAI<br>LC |

| Bit     | Name      | Access | Description                                                      | Reset Value |
|---------|-----------|--------|------------------------------------------------------------------|-------------|
| [31:24] | Reserved  | RO     | Reserved                                                         | 0           |
| [23]    | CEATAENDC | RW     | Setting this bit clears the CEATAEND bit in the status register. | 0           |
| [22]    | SDIOITC   | RW     | Setting this bit clears the SDIOIT bit in the status register.   | 0           |
| [21:11] | Reserved  | RW     | Reserved                                                         | 0           |
| [10]    | DBCKENDC  | RW     | Setting this bit clears the DBCKEND bit in the status register.  | 0           |
| [9]     | STBITERRC | RW     | Setting this bit clears the STBITERR bit in the status register. | 0           |
| [8]     | DATAENDC  | RW     | Setting this bit clears the DATAEND bit in the status register.  | 0           |
| [7]     | CMDSENTC  | RW     | Setting this bit clears the CMDSENT bit in the status register.  | 0           |
| [6]     | CMDRENDC  | RW     | Setting this bit clears the CMDREND bit in the status register.  | 0           |
| [5]     | RXOVERRC  | RW     | Setting this bit clears the RXOVERR bit in the status register.  | 0           |
| [4]     | TXUNDERRC | RW     | Setting this bit clears the TXUNDERR bit in the status register. | 0           |
| [3]     | DTIMEOUTC | RW     | Setting this bit clears the DTIMEOUT bit in the status register. | 0           |
| [2]     | CTIMEOUTC | RW     | Setting this bit clears the CTIMEOUT bit in the status register. | 0           |
| [1]     | DCRCFAILC | RW     | Setting this bit clears the DCRCFAIL bit in the status register. | 0           |
| [0]     | CCRCFAILC | RW     | Setting this bit clears the CCRCFAIL bit in the status register. | 0           |

V2. 4 576 WH

# 28.6.13 Interrupt Enable Register (R32\_SDIO\_MASK)

| 31       | 30   | 29  | 28     | 27   | 26  | 25   | 24  | 23                 | 22           | 21               | 20               | 19                | 18  | 17                | 16                |
|----------|------|-----|--------|------|-----|------|-----|--------------------|--------------|------------------|------------------|-------------------|-----|-------------------|-------------------|
| Reserved |      |     |        |      |     |      |     | CEAT<br>AEND<br>IE | SDIO<br>ITIE | RXD<br>AVLI<br>E | TXD<br>AVLI<br>E | RXFI<br>FOEI<br>E |     | RXFI<br>FOFI<br>E | TXFI<br>FOFI<br>E |
| 15       | 14   | 13  | 12     | 11   | 10  | 9    | 8   | 7                  | 6            | 5                | 4                | 3                 | 2   | 1                 | 0                 |
| RXFI     | TXFI | RXA | TT 1 C | CMDA | DBC | STBI | DAT | CMD                | CMD          | RXO              | TXU              | DTI               | CTI | DCR               | CCR               |

| Bit            | Name        | Access  | Description                                                 | Reset |
|----------------|-------------|---------|-------------------------------------------------------------|-------|
| Dit            | Name        | riccess | Description                                                 | Value |
| [31:24]        | Reserved    | RO      | Reserved                                                    | 0     |
| [22]           | CEATAENDIE  | RW      | After this bit is set, the status register will generate an | 0     |
| [23]           | CEATAENDIE  | KW      | interrupt when the CEATAEND bit is set.                     | U     |
| [22]           | SDIOITIE    | RW      | After this bit is set, the status register will generate an | 0     |
| [22]           | SDIOTTE     | IX VV   | interrupt when the SDIOIT bit is set.                       | U     |
| [21]           | RXDAVLIE    | RW      | After this bit is set, the status register will generate an | 0     |
| [21]           | KADAVLIE    | IX VV   | interrupt when the RXDAVL bit is set.                       | U     |
| [20]           | TXDAVLIE    | RW      | After this bit is set, the status register will generate an | 0     |
| [20]           | IADAVLIE    | KW      | interrupt when the TXDAVL bit is set.                       | U     |
| [19]           | RXFIFOEIE   | RW      | After this bit is set, the status register will generate an | 0     |
| [19]           | KAFIFOEIE   | KW      | interrupt when the RXFIFOE bit is set.                      | U     |
| F1 0 7         | TVEIEOEIE   | RW      | After this bit is set, the status register will generate an | 0     |
| [18]           | TXFIFOEIE   | KW      | interrupt when the TXFIFOE bit is set.                      | 0     |
| [17]           | DALECEIE    | DW      | After this bit is set, the status register will generate an | 0     |
| [17]           | RXFIFOFIE   | RW      | interrupt when the RXFIFOF bit is set.                      | 0     |
| F1.61          | TVEIECEIE   | DW      | After this bit is set, the status register will generate an | 0     |
| [16]           | TXFIFOFIE   | RW      | interrupt when the TXFIFOF bit is set.                      | 0     |
| [1.5]          | DALECHEIE   | DW      | After this bit is set, the status register will generate an | 0     |
| [15]           | RXFIFOHFIE  | RW      | interrupt when the RXFIFOHF bit is set.                     | 0     |
| Γ1 <i>Ι</i> /1 | TVEIEOLIEIE | RW      | After this bit is set, the status register will generate an | 0     |
| [14]           | TXFIFOHEIE  | KW      | interrupt when the TXFIFOHE bit is set.                     | U     |
| [12]           | DVACTIE     | DW      | After this bit is set, the status register will generate an | 0     |
| [13]           | RXACTIE     | RW      | interrupt when the RXACT bit is set.                        | 0     |
| [12]           | TVACTIE     | DW      | After this bit is set, the status register will generate an | 0     |
| [12]           | TXACTIE     | RW      | interrupt when the TXACT bit is set.                        | 0     |
| F1.17          | CMD A CTIE  | DIV     | After this bit is set, the status register will generate an | 0     |
| [11]           | CMDACTIE    | RW      | interrupt when the CMDACT bit is set.                       | 0     |
| F1.03          | DDGKENDIE   | DW      | After this bit is set, the status register will generate an | 0     |
| [10]           | DBCKENDIE   | RW      | interrupt when the DBCKEND bit is set.                      | 0     |
| [0]            | CTDITEDDIE  | DW      | After this bit is set, the status register will generate an | 0     |
| [9]            | STBITERRIE  | RW      | interrupt when the STBITERR bit is set.                     | 0     |
| F03            | DATAENDE    | DW      | After this bit is set, the status register will generate an | 0     |
| [8]            | DATAENDIE   | RW      | interrupt when the DATAEND bit is set.                      | 0     |

|      |             |       | ,                                                                                                  |                                       |
|------|-------------|-------|----------------------------------------------------------------------------------------------------|---------------------------------------|
| [7]  | CMDSENTIE   | RW    | After this bit is set, the status register will generate an interrupt when the CMDSENT bit is set. | 0                                     |
|      |             |       | After this bit is set, the status register will generate an                                        |                                       |
| [6]  | CMDRENDIE   | RW    | interrupt when the CMDREND bit is set.                                                             | 0                                     |
| F.53 | DYOVEDDIE   | DIV   | After this bit is set, the status register will generate an                                        | 0                                     |
| [5]  | RXOVERRIE   | RW    | interrupt when the RXOVERR bit is set.                                                             | 0                                     |
| [4]  | TVINDEDDIE  | DW    | After this bit is set, the status register will generate an                                        | 0                                     |
| [4]  | TXUNDERRIE  | RW    | interrupt when the TXUNDERR bit is set.                                                            | U                                     |
| [3]  | DTIMEOUTIE  | RW    | After this bit is set, the status register will generate an                                        | 0                                     |
| [2]  | DINNEOUTE   | ICVV  | interrupt when the DTIMEOUT bit is set.                                                            | 0                                     |
| [2]  | CTIMEOUTIE  | RW    | After this bit is set, the status register will generate an                                        | 0                                     |
| [2]  | CTIVILOCTIL | 10.11 | interrupt when the CTIMEOUT bit is set.                                                            | · · ·                                 |
| [1]  | DCRCFAILIE  | RW    | After this bit is set, the status register will generate an                                        | 0                                     |
| [1]  | Detterribil | 1011  | interrupt when the DCRCFAIL bit is set.                                                            | · · · · · · · · · · · · · · · · · · · |
| [0]  | CCRCFAILIE  | RW    | After this bit is set, the status register will generate an                                        | 0                                     |
| [0]  | CCRCITHELE  | 1000  | interrupt when the CCRCFAIL bit is set.                                                            | J                                     |

# 28.6.14 FIFO Count Register (R32\_SDIO\_FIFOCNT)

Offset address: 0x48

| 31 | 30               | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|    | FIFOCOUNT[31:16] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15 | 14               | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    | FIFOCOUNT[15:0]  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| The FIFO contains the number of words (32 bits) that have not been written to or read from the FIFO. When setting R32_SDIO_DCTLR: R32_SDIO_DCTLR, if the DPSM is idle, the | ĺ | Bit    | Name            | Access | Description                                                                                                                                                                                                                                                                                                                | Reset Value |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|--------|-----------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| FIFO counter will load the transfer length value from R32_SDIO_TLEN, if this value is not divisible by 4, the last 1 to 3 bytes will be treated as a word.                 |   | [31:0] | FIFOCOUNT[31:0] | RO     | The FIFO contains the number of words (32 bits) that have not been written to or read from the FIFO. When setting R32_SDIO_DCTLR: R32_SDIO_DCTLR, if the DPSM is idle, the FIFO counter will load the transfer length value from R32_SDIO_TLEN, if this value is not divisible by 4, the last 1 to 3 bytes will be treated | 0           |

# 28.6.15 FIFO Data Control Register (R32\_SDIO\_DCTRL2)

| 31 | 30  | 29     | 28 | 27 | 26                       | 25                        | 24               | 23 | 22   | 21     | 20      | 19 | 18 | 17 | 16                        |
|----|-----|--------|----|----|--------------------------|---------------------------|------------------|----|------|--------|---------|----|----|----|---------------------------|
|    |     | Reserv | ed |    | SLV_<br>CK_P<br>HAS<br>E | SLV_<br>FOR<br>CE_E<br>RR | SLV_<br>MOD<br>E |    |      | ]      | Reserve | ed |    |    | RAN<br>DOM<br>_LEN<br>_EN |
| 15 | 14  | 13     | 12 | 11 | 10                       | 9                         | 8                | 7  | 6    | 5      | 4       | 3  | 2  | 1  | 0                         |
|    | Res | erved  |    |    |                          |                           |                  | Ι  | BLOC | CKSIZI | Ξ2      |    |    |    |                           |

| Bit     | Name              | Access | Description                                                                                                                                                                                                                                                                                                | Reset Value |
|---------|-------------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:27] | Reserved          | R0     | Reserved                                                                                                                                                                                                                                                                                                   | 0           |
| [26]    | SLV_CK_PHASE      | RW     | Phase selection bit when outputting DATA from mode when SLV_MODE is 1:  0: Outputs DATA on the rising edge of the internal SDCK;  1: outputs DATA on the falling edge of the internal SDCK.  When SLV_MODE is 0:  0: DTEN bit writes 0 to clear the FIFO;  1: DTEN bit writes 0 without clearing the FIFO. |             |
| [25]    | SLV_FORCE_ERR     | RW     | Software forced data block CRC error in slave mode 0: Use hardware correct CRC value; 1: Software forced data block CRC is the wrong value.                                                                                                                                                                | 0           |
| [24]    | SLV_MODE          | RW     | Slave mode enable bit: 0: The controller operates in host mode; 1: The controller CPSM and DPSM work in slave mode.                                                                                                                                                                                        | 0           |
| [23:17] | Reserved          | R0     | Reserved                                                                                                                                                                                                                                                                                                   | 0           |
| [16]    | RANDOM_LEN_E<br>N | RW     | Data block arbitrary byte length enable bit: 0: The data block can only be 2 DBLOCKSIZE bytes; 1: The data block can be any length from 0 to 2048 in DBLOCKSIZE2.                                                                                                                                          | 0           |
| [15:12] | Reserved          | R0     | Reserved                                                                                                                                                                                                                                                                                                   | 0           |
| [11:0]  | DBLOCKSIZE2       | RW     | The data block length field for arbitrary byte length mode.                                                                                                                                                                                                                                                | 0           |

Note: The R32\_SDIO\_DCTRL2 register is only available for CH32F20x\_D8, CH32F20x\_D8C, CH32V30x\_D8, CH32V30x\_D8C, and CH32V31x\_D8C lot numbers that do not have a zero in the penultimate sixth bit.

### 28.6.16 FIFO (R32\_SDIO\_FIFO)



| Bit    | Name           | Access | Description                                                                                                                                                        | Reset Value |
|--------|----------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:0] | FIFOData[31:0] | RW     | FIFO data field. Reading and writing this field will read the received data or send the pending data. The SDIO FIFO has a total of 32 words (One word is 32 bits). | 0           |

# **Chapter 29 Random Number Generator (RNG)**

This chapter applies to the whole family of CH32F20x, CH32V20x, CH32V30x and CH32V31x.

Random number generator (RNG), based on continuous analog noise, provides 32-bit random numbers when the host reads data

#### 29.1 Main Features

- Can generate 32-bit random numbers
- Error management is possible
- Can be disabled individually to reduce power consumption



Figure 29-1 RNG block diagram

# 29.2 Functional Description

The random transmitter is implemented using an analog circuit that generates a seed for a linear feedback shift register (RNG\_LFSR) for generating 32-bit random numbers. RNG\_LFSR provides clock information at a constant frequency by a dedicated clock (PLL48CLK), so the quality of random numbers is related to the HCLK clock. When a large number of seeds are introduced into RNG\_LFSR, the content of RNG\_LFSR will be transferred to the data register (RNG\_DR).

#### 29.2.1 RNG Operations

RNG operation procedure:

- 1) If the interrupt is enabled, by setting the IE bit in the RNG\_CR register (The interrupt is generated when a random number is ready or an error occurs).
- 2) Random number generation is enabled by configuring the RNGEN bit in the RNG\_CR register, while the analog section, RNG LFSR and error detector are activated.
- 3) If the interrupt is enabled, every time an interrupt is generated, the SEIS and CEIS bits in the RNG\_SR register are 0 to confirm that no error occurs and that DRDY is 1 to confirm that the random number is

V2. 4 581 WH

ready. The contents of the RNG\_DR register can then be read.

#### 29.2.2 Error Management

RNG errors include clock errors and seed errors. When a clock error occurs, the RNG can no longer generate random numbers. At this time, it is necessary to check whether the clock controller is configured correctly and whether the RNG clock can be provided, and then clear the CEIS bit. When the CECS bit is 0, the RNG can work normally. When a clock error occurs, it has no effect on the last random number and can be used normally. When a seed error occurs, the value in the RNG\_DR register cannot use the random number at this time. If the RNG is to be reused, the SEIS bit needs to be cleared first, then the RNGEN bit is cleared and set to 1, and the RNG is reinitialized and restarted.

### 29.3 Register Description

Table 29-1 RNG registers

| Name       | Address    | Description          | Reset value |
|------------|------------|----------------------|-------------|
| R32_RNG_CR | 0x40023C00 | RNG control register | 0x00000000  |
| R32_RNG_SR | 0x40023C04 | RNG status register  | 0x00000000  |
| R32_RNG_DR | 0x40023C08 | RNG data register    | 0x00000000  |

#### 29.3.1 RNG Control Register (RNG CR)

Offset address: 0x00

| 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24   | 23   | 22 | 21 | 20 | 19        | 18   | 17    | 16 |
|----------|----|----|----|----|----|----|------|------|----|----|----|-----------|------|-------|----|
|          |    |    |    |    |    |    | Rese | rved |    |    |    |           |      |       |    |
| 15       | 14 | 13 | 12 | 11 | 10 | 9  | 8    | 7    | 6  | 5  | 4  | 3         | 2    | 1     | 0  |
| Reserved |    |    |    |    |    |    |      |      |    |    | IE | RNG<br>EN | Rese | erved |    |

| Bit    | Name     | Access | Description                         | Reset value |
|--------|----------|--------|-------------------------------------|-------------|
| [31:4] | Reserved | RO     | Reserved                            | 0           |
|        |          |        | Interrupt enable:                   |             |
| 3      | IE       | RW     | 0: Disable RNG interrupt.           | 0           |
|        |          |        | 1: Enable RNG interrupt.            |             |
|        |          |        | Random number generator enable:     |             |
| 2      | RNGEN    | RW     | 0: Disable random number generator. | 0           |
|        |          |        | 1: Enable random number generator.  |             |
| [1:0]  | Reserved | RW     | Reserved                            | 0           |

### 29.3.2 RNG Status Register (RNG\_SR)

| 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21   | 20   | 19   | 18   | 17   | 16   |
|----------|----|----|----|----|----|----|----|----|----|------|------|------|------|------|------|
| Reserved |    |    |    |    |    |    |    |    |    |      |      |      |      |      |      |
| 15       | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5    | 4    | 3    | 2    | 1    | 0    |
| Reserved |    |    |    |    |    |    |    |    |    | CEIS | Rese | rved | SECS | CECS | DRDY |

| Bit    | Name     | Access | Description                                                    | Reset Value |
|--------|----------|--------|----------------------------------------------------------------|-------------|
| [31:7] | Reserved | RO     | Reserved                                                       | 0           |
|        |          |        | Seed error interrupt status (This bit is set at the same time  |             |
|        |          |        | as SECS)                                                       |             |
| 6      | SEIS     | RW     | 0: No inverted error sequence detected.                        | 0           |
|        | SLIS     | ICW    | 1: One of the following error sequences is detected:           | V           |
|        |          |        | - more than 64 identical consecutive bits;                     |             |
|        |          |        | - more than 32 consecutive alternating 0's and 1's.            |             |
|        |          |        | Clock error interrupt status (This bit is set at the same time |             |
| 5      | CEIS     | RW     | as CECS)                                                       | 0           |
| 3      | CEIS     | KW     | 0: PLL48CLK clock detected correctly                           | U           |
|        |          |        | 1: PLL48CLK clock not detected correctly                       |             |
| [4:3]  | MODE4    | RW     | Reserved                                                       | 0           |
|        |          |        | Seed error current status                                      |             |
|        |          |        | 0: No error sequence detected;                                 |             |
| 2      | SECS     | RO     | 1: One of the following error sequences was detected:          | 0           |
|        |          |        | - more than 64 identical consecutive bits;                     |             |
|        |          |        | - more than 32 consecutive alternating 0s and 1s.              |             |
|        |          |        | Clock error current status                                     |             |
| 1      | CECS     | RO     | 0: PLL48CLK clock detected correctly                           | 0           |
|        |          |        | 1: PLL48CLK clock not detected correctly                       |             |
|        |          |        | Data ready (This bit is cleared after reading RNG_DR)          |             |
|        |          |        | 0: RNG_DR register is invalid, this random number is not       |             |
| 0      | DRDY     | RO     | available                                                      | 0           |
|        |          |        | 1: RNG_DR register is valid, this random number is             |             |
|        |          |        | available                                                      |             |

## 29.3.3 RNG Data Register (RNG\_DR)

| 31 | 30                                    | 29 | 28 | 27 | 26 | 25 | 24    | 23     | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|---------------------------------------|----|----|----|----|----|-------|--------|----|----|----|----|----|----|----|
|    |                                       |    |    |    |    | Rì | NDATA | [31:16 | ]  |    |    |    |    |    |    |
| 15 | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |    |    |    |    |    |       |        |    |    |    |    |    |    |    |
| 13 | 11                                    |    |    |    | 10 |    |       |        |    |    |    |    |    |    |    |

| Bit    | Name   | Access | Description          | Reset Value |
|--------|--------|--------|----------------------|-------------|
| [31:0] | RNDATA | RO     | 32-bit random number | 0           |

# **Chapter 30 Operational Amplifier (OPA)**

This chapter applies to the whole family of CH32F20x, CH32V20x, CH32V30x and CH32V31x.

The Operational Amplifier Module (OPA) contains 4 independently configurable operational amplifiers. The input and output of each op-amp are connected to the I/O port, and the input pin can be selected, and the output pin can be optionally configured to the general-purpose I/O port or multiplexed as the I/O of the ADC sampling channel.

#### 30.1 Main Features

- Input pin selectable
- The output pin can select general I/O port or ADC sampling channel

### **30.2 Functional Description**

Set OPAx\_EN to enable the corresponding OPAx, configure OPAx\_MODE to select the output channel of OPAx as ADC sampling channel or ordinary I/O port, configure OPAx\_PSEL, select the positive input pin of OPAx, configure OPAx NSEL, select OPAx the negative input pin.

Note: For the detailed input and output pins of each OPA, please refer to the pin description in the datasheet. Fogure 30-1 OPA structure block diagram



Note: For detailed specifications of each OPA, please refer to the corresponding model's data sheet.

# **30.3 Register Description**

Table 30-1 OPA register

| Name         | Address    | Description          | Reset value |
|--------------|------------|----------------------|-------------|
| R32_OPA_CTLR | 0x40023804 | OPA control register | 0x00000000  |

# 30.3.1 OPA Control Register (OPA\_CTLR)

| 31        | 30        | 29        | 28  | 27        | 26        | 25        | 24  | 23        | 22        | 21        | 20  | 19        | 18        | 17        | 16  |
|-----------|-----------|-----------|-----|-----------|-----------|-----------|-----|-----------|-----------|-----------|-----|-----------|-----------|-----------|-----|
|           | Reserved  |           |     |           |           |           |     |           |           |           |     |           |           |           |     |
| 15        | 14        | 13        | 12  | 11        | 10        | 9         | 8   | 7         | 6         | 5         | 4   | 3         | 2         | 1         | 0   |
| PSEL<br>4 | NSEL<br>4 | MOD<br>E4 | EN4 | PSEL<br>3 | NSEL<br>3 | MOD<br>E3 | EN3 | PSEL<br>2 | NSEL<br>2 | MOD<br>E2 | EN2 | PSEL<br>1 | NSEL<br>1 | MOD<br>E1 | EN1 |

| Bit     | Name     | Access | Description                                                                                                                                         | Reset Value |
|---------|----------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:16] | Reserved | RO     | Reserved                                                                                                                                            | 0           |
| 15      | PSEL4    | RW     | OPA4 positive input selection 0: CH0P. 1: CH1P. Note: Applied for CH32F20x_D8, CH32F20x_D8C, CH32V30x_D8, CH32V30x_D8C and CH32V31x_D8C.            | 0           |
| 14      | NSEL4    | RW     | OPA4 negative input selection 0: CH0N. 1: CH1N. Note: Applied for CH32F20x_D8, CH32F20x_D8C, CH32V30x_D8, CH32V30x_D8C and CH32V31x_D8C.            | 0           |
| 13      | MODE4    | RW     | OPA4 output channel selection 0: OPA4_OUT0. 1: OPA4_OUT1.  Note: Applied for CH32F20x_D8, CH32F20x_D8C, CH32V30x_D8, CH32V30x_D8C and CH32V31x_D8C. | 0           |
| 12      | EN4      | RW     | OPA4 enable 0: Disable OPA4. 1: Enable OPA4. Note: Applied for CH32F20x_D8, CH32F20x_D8C, CH32V30x_D8, CH32V30x_D8C.                                | 0           |
| 11      | PSEL3    | RW     | OPA3 positive input selection 0: CH0P. 1: CH1P. Note: Applied for CH32F20x_D8, CH32F20x_D8C, CH32V30x_D8, CH32V30x_D8C and CH32V31x_D8C.            | 0           |
| 10      | NSEL3    | RW     | OPA3 negative input selection 0: CH0N. 1: CH1N.                                                                                                     | 0           |

|   |       |    | Note: Applied for CH32F20x_D8, CH32F20x_D8C, |   |
|---|-------|----|----------------------------------------------|---|
|   |       |    | CH32V30x_D8, CH32V30x_D8C and CH32V31x_D8C.  |   |
|   |       |    | OPA3 output channel selection                |   |
|   |       |    | 0: OPA3_OUT0.                                |   |
| 9 | MODE3 | RW | 1: OPA3_OUT1.                                | 0 |
|   |       |    | Note: Applied for CH32F20x_D8, CH32F20x_D8C, |   |
|   |       |    | CH32V30x_D8, CH32V30x_D8C and CH32V31x_D8C.  |   |
|   |       |    | OPA3 enable                                  |   |
|   |       |    | 0: Disable OPA3.                             |   |
| 8 | EN3   | RW | 1: Enable OPA3.                              | 0 |
|   |       |    | Note: Applied for CH32F20x_D8, CH32F20x_D8C, |   |
| l |       |    | CH32V30x_D8, CH32V30x_D8C and CH32V31x_D8C.  |   |
|   |       |    | OPA2 positive input selection                |   |
| 7 | PSEL2 | RW | 0: CH0P.                                     | 0 |
|   |       |    | 1: CH1P.                                     |   |
|   |       |    | OPA2 negative input selection                |   |
| 6 | NSEL2 | RW | 0: CH0N.                                     | 0 |
|   |       |    | 1: CH1N.                                     |   |
|   |       |    | OPA2 output channel selection                |   |
| 5 | MODE2 | RW | 0: OPA2_OUT0.                                | 0 |
|   |       |    | 1: OPA2_OUT1.                                |   |
|   |       |    | OPA2 enable                                  |   |
| 4 | EN2   | RW | 0: Disable OPA2.                             | 0 |
|   |       |    | 1: Enable OPA2.                              |   |
|   |       |    | OPA1 positive input selection                |   |
| 3 | PSEL1 | RW | 0: CH0P.                                     | 0 |
|   |       |    | 1: CH1P.                                     |   |
|   |       |    | OPA1 negative input selection                |   |
| 2 | NSEL1 | RW | 0: CH0N.                                     | 0 |
|   |       |    | 1: CH1N.                                     |   |
|   |       |    | OPA1 output channel selection                |   |
| 1 | MODE1 | RW | 0: OPA1_OUT0.                                | 0 |
|   |       |    | 1: OPA1_OUT1.                                |   |
|   |       |    | OPA1 enable                                  |   |
| 0 | EN1   | RW | 0: Disable OPA1.                             | 0 |
|   |       |    | 1: Enable OPA1.                              |   |

V2. 4 586 WCH°

# **Chapter 31 Electronic Signature (ESIG)**

#### This chapter applies to the whole family of CH32F20x, CH32V20x, CH32V30x and CH32V31x.

The electronic signature contains chip identification information: The capacity of the flash memory area and the unique identification. It is programmed into the system storage area of the memory module by the manufacturer at the factory, and can be read by SWD (SDI) or application code.

### 31.1 Functional Description

Flash memory area capacity: Indicates the available size of the current chip user application program.

Unique ID: 96-bit binary code, unique to any microcontroller; users can only read and access but cannot modify it. This unique identification information can be used as the security password, encryption key, product serial number, etc. of the microcontroller (Product) to improve the system security mechanism or indicate identity information.

Users of the above content can conduct read access according to 8/16/32 bits.

### 31.2 Register Description

Table 31-1 ESIG registers

| Name            | Access Address | Description             | Reset value |
|-----------------|----------------|-------------------------|-------------|
| R16_ESIG_FLACAP | 0x1FFFF7E0     | Flash capacity register | 0xXXXX      |
| R32_ESIG_UNIID1 | 0x1FFFF7E8     | UID register 1          | 0xXXXXXXXX  |
| R32_ESIG_UNIID2 | 0x1FFFF7EC     | UID register 2          | 0xXXXXXXXX  |
| R32_ESIG_UNIID3 | 0x1FFFF7F0     | UID register 3          | 0xXXXXXXXX  |

#### 31.2.1 Flash Capacity Register (ESIG\_FLACAP)

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 FLACAP[15:0]

| Bit   | Name      | Access | Description                                                   | Reset Value |
|-------|-----------|--------|---------------------------------------------------------------|-------------|
| [15:0 | FLASHSIZE | RO     | Flash capacity, in unit of Kbyte Example: 0x0080 = 128 Kbytes | X           |

#### 31.2.2 UID Register (ESIG UNIID1)

| 31 | 30         | 29 | 28 | 27 | 26 | 25 | 24   | 23      | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|------------|----|----|----|----|----|------|---------|----|----|----|----|----|----|----|
|    |            |    |    |    |    |    | U_ID | [31:16] |    |    |    |    |    |    |    |
| 15 | 14         | 13 | 12 | 11 | 10 | 9  | 8    | 7       | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    | U_ID[15:0] |    |    |    |    |    |      |         |    |    |    |    |    |    |    |

|   | Bit    | Name       | Access | Description         | Reset Value |
|---|--------|------------|--------|---------------------|-------------|
| ĺ | [31:0] | U_ID[31:0] | RO     | Bits 0 to 31 of UID | X           |

# 31.2.3 UID Register (ESIG\_UNIID2)

| 31 | 30          | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|    | U_ID[63:48] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15 | 14          | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    | U_ID[47:32] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit    | Name        | Access | Descriptor           | Reset Value |
|--------|-------------|--------|----------------------|-------------|
| [31:0] | U_ID[63:32] | RO     | Bits 32 to 63 of UID | X           |

# 31.2.4 UID Register (ESIG\_UNIID3)

| 31 | 30          | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|    | U_ID[95:80] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15 | 14          | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    | U_ID[79:64] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| İ | Bit    | Name        | Access | Descriptor           | Reset Value |
|---|--------|-------------|--------|----------------------|-------------|
| İ | [31:0] | U_ID[95:64] | RO     | Bits 64 to 95 of UID | X           |

# **Chapter 32 Flash Memory and User Option Bytes**

This chapter applies to the whole family of CH32F20x, CH32V20x, CH32V30x and CH32V31x.

### 32.1 Flash Memory Organization

The internal flash memory organization structure of the chip is as follows (Taking xVCT6 as an example):

Block Name Address Range Size(byte) 0x08000000 to 0x080000FF Page 0 256 Page 1 0x08000100 to 0x080001FF 256 0x08000200 to 0x080002FF 256 Page 2 0x08000300 to 0x080003FF 256 Page 3 Main Page 4 0x08000400 to 0x080004FF 256 0x08000500 to 0x080005FF 256 memory Page 5 0x08000600 to 0x080006FF 256 Page 6 0x08000700 to 0x080007FF Page 7 256 Page 1919 0x08077F00 to 0x08077FFF 256 System boot loader Information 0x1FFF8000 to 0x1FFFEFFF 28K storage block User option bytes 0x1FFFF800 to 0x1FFFF87F 128

Table 32-1 Flash memory organization structure

Note:

- 1) The main memory area is used for the user's application program storage, and the write protection is divided in unit of 4K bytes (32 pages). Except for the locked "Vendor Configuration Word" area before delivery which is inaccessible to users, other areas can be operated by users under certain conditions.
- 2) When carrying out FLASH-related operations, it is strongly recommended that the system main frequency is not greater than 120M.

If the actual application must require the use of system mains frequency greater than 120M, it should be noted that:

In the non-zero-wait area FLASH and zero-wait area FLASH, user word read/write and vendor configuration word and Boot area read, the following operations need to be done, firstly, HCLK is divided into two (Related peripheral clocks are also divided at the same time, the impact needs to be evaluated), and then restored after the FLASH operation is completed to ensure that the FLASH access clock frequency does not exceed 60Mhz (FLASH\_CTLR register bit[25]-SCKMOD can configure FLASH access clock frequency as system clock or half of system clock, the default configuration of this bit is half of system clock).

# 32.2 Flash Memory Programming and Safety

#### 32.2.1 Two Program/Erase Methods

• Standard programming: This method is the default programming method (Compatible method). In this mode, the CPU executes programming in a single 2-byte manner, and executes erasure and entire chip erasure operations in a single 4K byte

• Fast programming: This method uses page operation (recommended). After unlocking through a specific sequence, a single 256-byte program, 256-byte erase, 32K-byte erase, and full chip erase are performed.

Note: FLASH erase related functions can only be placed in the zero-wait area FLASH.

#### 32.2.2 Security-preventing against Illegal Access (Read, write and erase)

- Page write protection
- Read protection

Under the read protection state:

- 1) The main memory pages 0-15 (4K bytes) are automatically write-protected and are not controlled by the FLASH\_WPR register; when the read protection status is released, all main memory pages will be controlled by the FLASH\_WPR register.
- 2) The main memory cannot be erased or programmed in the system boot code area, SWD or SDI mode, and RAM area, except for the entire chip erasure. User option byte area can be erased or programmed. If you try to release the read protection (program user word), the chip will automatically erase the entire user area

#### 32.3 Flash Enhanced Read Mode

FLASH enhanced reading mode is suitable for running in FLASH by user sequence (the user-generated CODE space exceeds the code size space configured by user-selected word RAM\_CODE\_MOD[1:0] bits). Turning on this mode can improve the access efficiency of FLASH. To start this mode, set the EHMOD bit in the FLASH\_CTLR register, and then read the EHMODS bit, which means that the enhanced reading mode has taken effect. To close this mode, clear the EHMOD bit first, and then set the RSENACT to 1. At the same time, the access clock frequency can be selected by configuring the SCKMOD bit in the FLASH\_CTLR register. *Note: When using FLASH Enhanced Read Mode, the following points should be noted:* 

- 1) Before performing any mode of erasing or programming on FLASH (Including unlocking user word programming such as read protection), you must exit the enhanced read mode, otherwise the erasing and programming operations will fail;
- 2) Before entering the stop mode, you must exit the enhanced read mode, otherwise it may cause an abnormal stop mode;
- 3) After power reset and system reset, the chip is controlled by hardware to automatically exit the enhanced read mode.

# 32.4 Register Description

Table 32-2 FLASH registers

| Name             | Access address | Description             | Reset value |
|------------------|----------------|-------------------------|-------------|
| R32_FLASH_KEYR   | 0x40022004     | FPEC key register       | 0xXXXXXXXX  |
| R32_FLASH_OBKEYR | 0x40022008     | OBKEY register          | 0xXXXXXXXX  |
| R32_FLASH_STATR  | 0x4002200C     | Status register         | 0x00000000  |
| R32_FLASH_CTLR   | 0x40022010     | Control register        | 0x00008080  |
| R32_FLASH_ADDR   | 0x40022014     | Address register        | 0x00000000  |
| R32_FLASH_OBR    | 0x4002201C     | Selection word register | 0xXXXXXXXX  |

| R32_FLASH_WPR      | 0x40022020 | Write protection register | 0xXXXXXXXX |
|--------------------|------------|---------------------------|------------|
| R32_FLASH_MODEKEYR | 0x40022024 | Extension key register    | 0xXXXXXXXX |

## 32.4.1 FPEC Key Register (FLASH\_KEYR)

Offset address: 0x04

| 31 | 30          | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|    | KEYR[31:16] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15 | 14          | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    | KEYR[15:0]  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit    | Name       | Access | Description                                 | Reset Value |
|--------|------------|--------|---------------------------------------------|-------------|
|        |            |        | FPEC key, the unlock key used to enter FPEC |             |
|        |            |        | includes:                                   |             |
| [31:0] | KEYR[31:0] | WO     | RDPRT key = $0x000000A5$ .                  | X           |
|        |            |        | KEY1 = 0x45670123.                          |             |
|        |            |        | KEY2 = 0xCDEF89AB.                          |             |

## 32.4.2 OBKEY Register (FLASH\_OBKEYR)

Offset address: 0x08

| 31 | 30            | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|---------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|    | OBKEYR[31:16] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|    |               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15 | 14            | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |

| Bit    | Name Access Description |    | Reset value                                                                |   |
|--------|-------------------------|----|----------------------------------------------------------------------------|---|
| [31:0] | OBKEYR[31:0]            | WO | Selection word key, used to input the selection word key to release OBWRE. | X |

# 32.4.3 Status Register (FLASH\_STATR)

| 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24     | 23           | 22  | 21               | 20           | 19           | 18        | 17  | 16 |
|----------|----|----|----|----|----|----|--------|--------------|-----|------------------|--------------|--------------|-----------|-----|----|
|          |    |    |    |    |    |    |        | Reserved     |     |                  |              |              |           |     |    |
| 15       | 14 | 13 | 12 | 11 | 10 | 9  | 8      | 7            | 6   | 5                | 4            | 3            | 2         | 1   | 0  |
| Reserved |    |    |    |    |    |    | EHMODS | Reser<br>ved | ЕОР | WRP<br>RT<br>ERR | Reser<br>ved | Reser<br>ved | WRB<br>SY | BSY |    |

| Bit    | Name     | Access | Description                                                                              | Reset value |
|--------|----------|--------|------------------------------------------------------------------------------------------|-------------|
| [31:8] | Reserved | RO     | Reserved                                                                                 | 0           |
| 7      | EHMODS   | RO     | FLASH enhanced read mode enable status bit:  0: FLASH Enhanced Read Mode is not enabled; | 0           |

|   |          |     | 1: FLASH Enhanced Read Mode is enabled.                                                                                                                                                                                                                                                                |   |
|---|----------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| 6 | Reserved | RO  | Reserved                                                                                                                                                                                                                                                                                               | 0 |
| 5 | ЕОР      | RW1 | End of operation. Write 1 to clear it.  The bit is set by hardware every time it is successfully erased or programmed.                                                                                                                                                                                 | 0 |
| 4 | WRPRTERR | RW1 | Write protection error. Write 1 to clear it. The bit is set by hardware when the write protection address is programmed.                                                                                                                                                                               | 0 |
| 3 | Reserved | RO  | Reserved.                                                                                                                                                                                                                                                                                              | 0 |
| 2 | Reserved | RO  | Reserved                                                                                                                                                                                                                                                                                               | 0 |
| 1 | WRBSY    | RO  | This bit is used during fast page programming to indicate that programming data is being written.  During page programming, this bit is set to '1' when data is written, and it is automatically cleared to '0' by hardware. If this bit is '0', it means that the next data is allowed to be written. | 0 |
| 0 | BSY      | RO  | Busy: 0: Operation completion; 1: Flash memory operation is in the process.                                                                                                                                                                                                                            | 0 |

Note: When performing the programming operation, you need to make sure that the STRT bit in the FLASH\_CTLR register is set to 0.

## 32.4.4 Control Register (FLASH\_CTLR)

| 31        | 30   | 29   | 28        | 27           | 26        | 25         | 24           | 23           | 22              | 21         | 20       | 19           | 18        | 17   | 16   |
|-----------|------|------|-----------|--------------|-----------|------------|--------------|--------------|-----------------|------------|----------|--------------|-----------|------|------|
|           |      |      |           |              |           | SCK<br>MOD | EHM<br>OD    | Reser<br>ved | RSE<br>NAC<br>T | PGST<br>RT | Rese     | rved         | BER3<br>2 | FTER | FTPG |
| 15        | 14   | 13   | 12        | 11           | 10        | 9          | 8            | 7            | 6               | 5          | 4        | 3            | 2         | 1    | 0    |
| FLO<br>CK | Rese | rved | EOPI<br>E | Reser<br>ved | ERRI<br>E | OBW<br>RE  | Reser<br>ved | LOC<br>K     | STR<br>T        | OBER       | OBP<br>G | Reser<br>ved | MER       | PER  | PG   |

| Bit     | Name     | Access | Description                                                                                                                                                                                                                            | Reset Value |
|---------|----------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:26] | Reserved | RO     | Reserved                                                                                                                                                                                                                               | 0           |
| 25      | SCKMOD   | RW     | FLASH access clock configuration:  0: FLASH access clock frequency = SYSCLK/2;  1: FLASH access clock frequency = SYSCLK.  Note: FLASH access clock frequency cannot be more than 60 MHz.  This bit is a normal unlock + quick unlock. | 0           |
| 24      | EHMOD    | RW     | FLASH enhanced read mode: This mode can improve access efficiency when the program runs in FLASH.  0: Turn off the FLASH enhanced read mode, which needs to be operated together with the RSEN_ACT bit. To exit, first clear the       | 0           |

|         |          |      | ENHANCE_MOD bit to 0, and then set                |   |
|---------|----------|------|---------------------------------------------------|---|
|         |          |      | RSEN_ACT to 1;                                    |   |
|         |          |      | 1: Enable FLASH enhanced read mode.               |   |
|         |          |      | This bit is a normal unlock + quick unlock.       |   |
| 23      | Reserved | RO   | Reserved                                          | 0 |
|         |          |      | To exit the enhanced read mode, the hardware      |   |
|         |          |      | will automatically clear it.                      |   |
|         |          |      | It needs to be operated together with the         |   |
| 22      | RSENACT  | WO   | ENHANCE_MOD bit.                                  | 0 |
|         |          |      | To exit, first clear the ENHANCE_MOD bit          |   |
|         |          |      | to 0, and then set RSEN_ACT to 1.                 |   |
|         |          |      | This bit is a normal unlock.                      |   |
|         |          |      | Start.                                            |   |
| 21      | PGSTRT   | RW0  | Set to 1 to start a page programming, which       | 0 |
| 21      | PGSTRI   | RWU  | is automatically cleared by hardware.             | U |
|         |          |      | This bit is a normal unlock.                      |   |
| [20:19] | Reserved | RO   | Reserved                                          | 0 |
| 10      | DED 22   | DW   | Perform a 32KB erase.                             | 0 |
| 18      | BER32    | RW   | This bit is a normal unlock + quick unlock.       | 0 |
|         |          |      | Perform a fast page (256Byte) erase               |   |
| 17      | FTER     | RW   | operation.                                        | 0 |
|         |          |      | This bit is a normal unlock + quick unlock.       |   |
| 1.6     | ETTD C   | DIII | Perform a fast page programming operation.        | 0 |
| 16      | FTPG     | RW   | This bit is a normal unlock + quick unlock.       | 0 |
|         |          |      | Fast programming lock.                            |   |
|         |          |      | Only '1' can be written. When this bit is '1', it |   |
|         |          |      | means that the fast programming/erasure           |   |
| 1.5     | FLOCK    | DW/1 | mode is not available. After detecting the        |   |
| 15      | FLOCK    | RW1  | correct unlock sequence, the hardware will        | 1 |
|         |          |      | clear this bit to '0'. Set 1 by software, and     |   |
|         |          |      | relock it                                         |   |
|         |          |      | This bit is a normal unlock.                      |   |
| [14:13] | Reserved | RO   | Reserved                                          | 0 |
|         |          |      | EOP interrupt enable (EOP is set in the           |   |
|         |          |      | FLASH_STATR register)                             |   |
| 12      | EOPIE    | RW   | 0: Disable to generate interrupt;                 | 0 |
|         |          |      | 1: Enable to generate interrupt.                  |   |
|         |          |      | This bit is a normal unlock.                      |   |
| 11      | Reserved | RO   | Reserved                                          | 0 |
|         |          |      | Error status interrupt enable                     |   |
|         |          |      | (PGERR/WRPRTERR is set in the                     |   |
|         |          |      | FLASH STATR register):                            | _ |
| 10      | ERRIE    | RW   | 0: Disable to generate interrupt;                 | 0 |
|         |          |      | 1: Enable to generate interrupt.                  |   |
|         |          |      | This bit is a normal unlock.                      |   |
| 9       | OBWRE    | RW0  | User option bytes lock; cleared by software:      | 0 |
|         |          | •    | j =,,                                             | _ |

|   |          |     | 0: Re-lock the user option bytes after cleared   |   |
|---|----------|-----|--------------------------------------------------|---|
|   |          |     | by software;                                     |   |
|   |          |     | 1: User option bytes can be programmed. It       |   |
|   |          |     | needs to be set by hardware after the correct    |   |
|   |          |     | sequence is written to the FLASH OBKEYR          |   |
|   |          |     | register.                                        |   |
|   |          |     | This bit is a normal unlock.                     |   |
| 8 | Reserved | RO  | Reserved                                         | 0 |
|   |          |     | Lock. Only '1' can be written. When this bit     |   |
|   |          |     | is '1', it means that FPEC and FLASH CTLR        |   |
|   |          |     | are locked and cannot be written. After          |   |
|   |          |     | detecting the correct unlock sequence, the       |   |
| 7 | LOCK     | RW1 | hardware will clear this bit to '0'.             | 1 |
|   |          |     | After an unsuccessful unlock operation, this     |   |
|   |          |     | bit will not change until the next system reset. |   |
|   |          |     | This bit is a normal unlock.                     |   |
|   |          |     | Start. Set to 1 to start an erase/program        |   |
|   |          |     | operation, and the hardware will                 |   |
| 6 | STRT     | RW1 | automatically clear it to 0 (BSY becomes '0').   | 0 |
|   |          |     | This bit is a normal unlock.                     |   |
|   |          |     | Execute the user option bytes erasure            |   |
| 5 | OBER     | RW  | This bit is a normal unlock.                     | 0 |
|   |          |     | Execute the user option bytes programming        |   |
| 4 | OBPG     | RW  | This bit is a normal unlock.                     | 0 |
| 3 | Reserved | RO  | Reserved                                         | 0 |
|   |          |     | Execute the whole erasure operation (Erasing     |   |
| 2 | MER      | RW  | the whole user area).                            | 0 |
|   |          |     | This bit is a normal unlock.                     |   |
|   |          |     | Execute the standard page (4KB) erasure          |   |
| 1 | PER      | RW  | operation.                                       | 0 |
|   |          |     | This bit is a normal unlock.                     |   |
| _ |          |     | Execute the standard programming operation.      |   |
| 0 | PG       | RW  | This bit is a normal unlock.                     | 0 |
|   |          |     |                                                  |   |

## 32.4.5 Address Register (FLASH\_ADDR)

| 31         | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| FAR[31:16] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15         | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| FAR[15:0]  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit    | Name      | Access | Description                                                                    | Reset Value |
|--------|-----------|--------|--------------------------------------------------------------------------------|-------------|
| [31:0] | FAR[31:0] | WO     | Flash address, the programming address when programming, and the erasing start | 0           |

| address when erasing.                             |  |
|---------------------------------------------------|--|
| When the BSY bit in the FLASH_STATR               |  |
| register is '1', this register cannot be written. |  |

## 32.4.6 Option Byte Register (FLASH\_OBR)

| 31       | 30 | 29 | 28 | 27 | 26 | 25             | 24   | 23      | 22 | 21                | 20          | 19             | 18        | 17        | 16 |
|----------|----|----|----|----|----|----------------|------|---------|----|-------------------|-------------|----------------|-----------|-----------|----|
|          |    |    |    |    |    |                | Rese | rved    |    |                   |             |                |           |           |    |
| 15       | 14 | 13 | 12 | 11 | 10 | 9              | 8    | 7       | 6  | 5                 | 4           | 3              | 2         | 1         | 0  |
| Reserved |    |    |    |    | -  | _COD<br>DD[2:0 | I    | Reserve | d  | STAN<br>DY<br>RST | STOP<br>RST | IW<br>DG<br>SW | RDP<br>RT | OBE<br>RR |    |

| Bit     |      | Name               | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Reset Value |
|---------|------|--------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:10] | R    | Reserved           | RO     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 0           |
| [9:8]   | USER | SRAM_CO<br>DE_MODE | RO     | 00x: CODE-192KB + RAM-128KB 01x: CODE-224KB + RAM-96KB 10x: CODE-256KB + RAM-64KB 110: CODE-128KB + RAM-192KB 111: CODE-288KB + RAM-32KB Note: (1) Applied for CH32V303RC, CH32V303VC, CH32V307VC, CH32V307WC, CH32V307VC, CH32V317VC, CH32V317WC, CH32V317SC. (2) 110b applies only to products where the penultimate sixth digit of the lot number is not zero.  00x: CODE-128KB + RAM-64KB 01x: CODE-144KB + RAM-48KB 1xx: CODE-160KB + RAM-32KB Note: Applied for CH32V20x_D8W, CH32V20x_D8 and CH32F20x_D8W. | X           |
| [7:5]   |      | Reserved           | RO     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | X           |
| 4       |      | STANDY_<br>RST     | RO     | System reset control in Standby mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | X           |
| 3       | 1    | STOP_RST           | RO     | System reset control in Stop mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | X           |
| 2       |      | IWDG_SW            | RO     | Independent watchdog (IWDG) hardware enable bit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 1           |
| 1       | ]    | RDPRT              | RO     | Read protection.  0: Current read protection of flash is invalid; 1: Current read protection of flash is valid.                                                                                                                                                                                                                                                                                                                                                                                                   | 1           |

| 0 | OBERR | RO | Option byte error.  0: Option byte matches its inverted code.  1: Option byte does not match its inverted code. | 0 |
|---|-------|----|-----------------------------------------------------------------------------------------------------------------|---|
|---|-------|----|-----------------------------------------------------------------------------------------------------------------|---|

Note: USER and RDPRT are loaded from the user option byte area after system reset.

#### 32.4.7 Write Protection Register (FLASH\_WPR)

Offset address: 0x20

| 31 | 30         | 29 | 28 | 27 | 26 | 25 | 24  | 23     | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|------------|----|----|----|----|----|-----|--------|----|----|----|----|----|----|----|
|    | WRP[31:16] |    |    |    |    |    |     |        |    |    |    |    |    |    |    |
| 15 | 14         | 13 | 12 | 11 | 10 | 9  | 8   | 7      | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |            |    |    |    |    |    | WRP | [15:0] |    |    |    |    |    |    |    |

| Bit    | Name             | Access | Description                                       | Reset Value |
|--------|------------------|--------|---------------------------------------------------|-------------|
|        |                  |        | Flash write protection.                           |             |
|        |                  |        | 0: Write protection valid;                        |             |
| [31:0] | [31:0] WRP[31:0] |        | 1: Write protection invalid.                      | X           |
|        |                  |        | Each bit represents the write protection state of |             |
|        |                  |        | 4-Kbytes (16 pages) memory.                       |             |

Note: WPR is loaded from the user option byte area after system reset.

### 32.4.8 Extension Key Register (FLASH\_MODEKEYR)

Offset address: 0x24

| 31 | 30              | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|    | MODEKEYR[31:16] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15 | 14              | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    | MODEKEYR[15:0]  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit    | Name           | Access | Description                                                                                                 | Reset value |
|--------|----------------|--------|-------------------------------------------------------------------------------------------------------------|-------------|
| [31:0] | MODEKEYR[31:0] | WO     | Enter the following sequence to unlock the fast program/erase mode:  KEY1 = 0x45670123;  KEY2 = 0xCDEF89AB. | X           |

### 32.5 Flash Operation Procedure

#### 32.5.1 Read Operation

Direct addressing is in the general address space, and the user can access the content of the flash memory module and get the corresponding data through any read operation of 8/16/32-bit data.

#### 32.5.2 Flash Memory Unlock

After the system reset, the flash memory controller (FPEC) and FLASH\_CTLR register will be locked and cannot be accessed. The flash memory controller module can be unlocked by writing the sequence to the

#### FLASH KEYR register.

Unlock sequence:

- 1) Write KEY1 = 0x45670123 to the FLASH KEYR register (Must operate KEY1 first);
- 2) Write KEY2 = 0xCDEF89AB to the FLASH KEYR register (Must operate KEY2 secondly).

The above operations must be performed sequentially and continuously. Otherwise, it is an error operation, which will lock the FPEC module and FLASH\_CTLR register and generate a bus error until the next system reset.

The flash memory controller (FPEC) and the FLASH\_CTLR register can be locked again by setting the "LOCK" bit in the FLASH\_CTLR register to 1.

#### 32.5.3 Main Memory Standard Programming

You can write 2 bytes each time through the standard programming. When the PG bit in the FLASH\_CTLR register is '1', a programming will be started every time a halfword (2 bytes) is written to the flash memory address. When any non-halfword data is written, FPEC will generate a bus error. During the programming process, the BSY bit is '1'. After the programming is completed, the BSY bit is '0' and the EOP bit is '1'.

Note: When the BSY bit is '1', writing to any register will be disabled.



Figure 32-1 FLASH programming

- 1) Check the LOCK bit in the FLASH\_CTLR register. If it is 1, you need to perform the "Release Flash Memory Lock" operation.
- 2) Set the PG bit in the FLASH CTLR register to '1' to enable the standard programming mode.
- 3) Write the half word to be programmed to the designated flash memory address (Even address).
- 4) When the BYS bit changes to '0' or the EOP bit in the FLASH\_STATR register to be '1', it indicates the end of programming. Clear the EOP bit to 0.
- 5) Check the FLASH\_STATR register to see if there is an error, or read the programming address data for verification.
- 6) To continue programming, you can repeat steps 3-5, end programming and clear the PG bit to 0.

#### 32.5.4 Main Memory Standard Erase

The flash memory can be erased in the standard pages (4K bytes) or in whole chips.



Figure 32-2 FLASH page erase

- 1) Check the LOCK bit in the FLASH\_CTLR register. If it is 1, you need to perform the "Release Flash Memory Lock" operation.
- 2) Set the PEG bit in the FLASH CTLR register to '1' to enable the standard page erasure mode.
- 3) Write the page heading address of the page to be erased to the FLASH ADDR register.
- 4) Set the STRT bit in the FLASH CTLR register to '1' to start an erase action.
- 5) When the BSY bit changes to '0' or the EOP bit in the FLASH\_STATR register to be '1', it indicates the end of erasure. Clear the EOP bit to 0.
- 6) Read the page of erasure page for verification.
- 7) To erase the standard page continuously, you can repeat steps 3-5 to end erasing and clear the PEG bit to 0. *Note: After erasing is successful, word read 0xe339e339, half word read 0xe339, even address byte read 0x39, odd address read 0xe3.*



Figure 32-3 FLASH whole chip erase

- 1) Check the LOCK bit in the FLASH\_CTLR register. If it is 1, you need to perform the "Release Flash Memory Lock" operation.
- 2) Set the MEG bit in the FLASH CTLR register to '1' to enable the whole chip erasure mode.
- 3) Set the STRT bit in the FLASH CTLR register to '1' to start an erasure action.
- 4) When the BSY bit changes to '0' or the EOP bit in the FLASH\_STATR register to be '1', it indicates the end of erasure. Clear the EOP bit to 0.
- 5) Read the data of the erasure page for verification.
- 6) Clear the MER bit to 0.

### 32.5.5 Fast Programming Mode Unlock

The quick programming mode operation can be unlocked by writing the sequence to the FLASH\_MODEKEYR register. After unlocking, the FLOCK bit of the FLASH\_CTLR register will be cleared to 0, indicating that quick erasure and programming operations can be made. Set 1 by the software through the "FLOCK" bit of FLASH\_CTLR register.

Unlock sequence:

- 1) Write KEY1 = 0x45670123 to the FLASH\_MODEKEYR register;
- 2) Write KEY2 = 0xCDEF89AB to the FLASH MODEKEYR register.

The above operations must be continuously made in sequence. Otherwise, it will be locked in case of wrong operation, and will be re-unlocked until the next system reset.

Note: For the quick programming operation, it needs to release the 2 layers of "LOCK" and "FLOCK".

#### 32.5.6 Main Memory Fast Programming

The fast programming (256 bytes) is made according to the page.

- 1) Check the LOCK bit in the FLASH\_CTLR register, if it is '1', you need to perform the "Release Flash memory lock" operation.
- 2) Check the FLOCK bit in the FLASH\_CTLR register, if it is '1', you need to perform the "fast programming mode unlock" operation.
- 3) Check the BSY bit in the FLASH STATR register to confirm that there are no other programming operations

in progress.

- 4) Set the FTPG bit in the FLASH CTLR register to '1' to enable fast page programming mode.
- 5) Use 32-bit mode to write data to the FLASH address, for example \*(uint32 t\*)0x8000000 = 0x12345678;
- 6) Wait for the WR BSY of the FLASH STATR register to be '0' and write the next data.
- 7) Repeat steps 5-6 a total of 64 times.
- 8) Set the PG START bit of the FLASH CTLR register to '1' to start fast page programming.
- 9) Wait for the BSY bit to become '0' or the EOP bit of the FLASH\_STATR register to be '1' to indicate that a fast page programming is completed, and clear the EOP bit to 0.
- 10) Read the FLASH\_STATR register to know if there is an error, or read the programming address data for verification.
- 11) To continue fast page programming, steps 5-10 can be repeated, and the FTPG bit will be cleared to 0 when the programming ends.

#### 32.5.7 Main Memory Fast Erasure

Quick erasure is also performed according to the pages (256 bytes).

- 1) Check the LOCK bit in the FLASH\_CTLR register, if it is 1, you need to perform the "Release Flash Memory" operation.
- 2) Check the FLOCK bit in the FLASH\_CTLR register, if it is 1, you need to perform the "fast programming mode unlock" operation.
- 3) Check the BSY bit in the FLASH\_STATR register to confirm that there are no other programming operations in progress.
- 4) Set the FTER bit in the FLASH CTLR register to '1' to enable the fast page erase (256 bytes) mode function.
- 5) Write the first address of the fast erase page to the FLASH ADDR register.
- 6) Set the STRT bit in the FLASH CTLR register to '1' to start a fast page erase (256 bytes) action.
- 7) Wait for the BSY bit to become '0' or the EOP bit of the FLASH\_STATR register to be '1' to indicate the end of erasing, and clear the EOP bit to 0.
- 8) Read the FLASH\_STATR register to know if there is an error, or read and erase the page address data verification.
- 9) To continue the fast page erasing, you can repeat steps 5-8, and clear the FTER bit to 0 when the erasing ends.

Note: After erasing is successful, word read - 0xe339e339, half word read - 0xe339, even address byte read - 0x39, odd address read 0xe3.

Fast Erase erases in blocks (32K bytes).

- 1) Check the LOCK bit in the FLASH\_CTLR register, if it is 1, you need to perform the "unlock the flash memory" operation.
- 2) Check the FLOCK bit in the FLASH\_CTLR register, if it is 1, you need to perform the "fast programming mode unlock" operation.
- 3) Check the BSY bit in the FLASH\_STATR register to confirm that there are no other programming operations in progress.
- 4) Set the BER32 bit in the FLASH\_CTLR register to '1' to enable the fast block erase (32K bytes) mode function.
- 5) Write the first address of the flash erase block to the FLASH ADDR register.
- 6) Set the STRT bit in the FLASH CTLR register to '1' to start a fast block erase (32K bytes) action.
- 7) Wait for the BSY bit to become '0' or the EOP bit in the FLASH\_STATR register to be '1' to indicate the

end of erasing, and clear the EOP bit to 0.

- 8) Query the FLASH\_STATR register to see if there is an error, or read and erase the page address data verification.
- 9) To continue fast page erasing, you can repeat steps 5-8, and clear the BER32 bit to 0 after erasing.

Note: After erasing is successful, word read - 0xe339e339, half word read - 0xe339, even address byte read - 0x39, odd address read 0xe3.

### 32.6 User Option Bytes

The User Option Bytes are solidified in FLASH and will be reloaded into the corresponding register after the system reset, and the user can erase and program at will. The user option word information block has a total of 8 bytes (4 bytes for write protection, 1 byte for read protection, 1 byte for configuration options, 2 bytes for user data storage), and each bit has the inverted code bit for checking during loading. The structure and meaning of the selected word information are described below.

Table 32-3 32-bit option bytes format division

| [31:24]                | [23:16]        | [15:8]                 | [7:0]           |
|------------------------|----------------|------------------------|-----------------|
| Inverse code of option | Ontion bytes 1 | Inverse code of option | Ontion butos () |
| bytes 1                | Option bytes 1 | bytes 0                | Option bytes 0  |

Table 32-4 User option bytes information structure

| Address    | [31:24] | [23:16] | [15:8] | [7:0] |
|------------|---------|---------|--------|-------|
| 0x1FFFF800 | nUSER   | USER    | nRDPR  | RDPR  |
| 0x1FFFF804 | nData1  | Data1   | nData0 | Data0 |
| 0x1FFFF808 | nWRPR1  | WRPR1   | nWRPR0 | WRPR0 |
| 0x1FFFF80C | nWRPR3  | WRPR3   | nWRPR2 | WRPR2 |

|      | Name/B | yte      | Description                                                                                                                                                                                                                                                                                                                                                                    | Reset value |
|------|--------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
|      | RDPF   | <b>.</b> | Read protection control. It configures whether the code in the flash memory can be read.  0xA5: If this byte is 0xA5 (nRDP must be 0x5A), it means that the current code is in a non-read protected state and can be read;  Other values: Code read protection status, unreadable; pages 0 to 15 pages (4K) will be automatically write-protected and not controlled by WRPR0. | 0xA5        |
| USER | [7:5]  | xx1b     | 00x: CODE-192KB + RAM-128KB<br>01x: CODE-224KB + RAM-96KB<br>10x: CODE-256KB + RAM-64KB<br>110: CODE-128KB + RAM-192KB<br>111: CODE-288KB + RAM-32KB<br>Note: (1) Applied for CH32V303RC, CH32V303VC,<br>CH32V307RC, CH32V307WC, CH32V307VC,<br>CH32F203RC, CH32F203VC, CH32F207VC,<br>CH32V317VC, CH32V317WC, CH32V317SC.                                                     | x           |

|   |          |               | (2) The 110b applies only to products where the penultimate sixth digit of the lot number is not zero.  00x: CODE-128KB + RAM-64KB  01x: CODE-144KB + RAM-48KB  1xx: CODE-160KB + RAM-32KB  Note: Applied for CH32V20x_D8W, CH32V20x_D8 and CH32F20x_D8W series chip.                                                                                                                                                                                                                                                                       |                |
|---|----------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| İ | [4:3]    | Reserved      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 11b            |
|   | 2        | STANDYR<br>ST | System reset control in Standby mode:  0: Enable; system is reset when entering Standby mode;  1: Disable; system is not reset when entering Standby mode.                                                                                                                                                                                                                                                                                                                                                                                  | 1              |
|   | 1        | STOPRST       | System reset control in Stop mode:  0: Enable; system will be reset when entering Stop mode;  1: Disable; system will not be reset when entering Stop Mode.                                                                                                                                                                                                                                                                                                                                                                                 | 1              |
|   | 0        | IWDGSW        | Independent watchdog (IWDG) hardware enable: 0: The IWDG function is enabled by software (Depends on the LSI clock); 1: The IWDG function is enabled by software, and disabled by hardware.                                                                                                                                                                                                                                                                                                                                                 | 1              |
| I | Data0–D  | ata1          | Saving the user's data 2 bytes.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0xFFFF         |
|   | RPR0 - V |               | Write protection control. Each bit is used to control the write protection status of 1 sector (4Kbytes/sector) in main memory:  0: Enable write protection;  1: Disable write protection.  4 bytes are used to protect a total of 480K bytes of main memory.  WRP0: Sectors 0-7 memory write protection control;  WRP1: Sectors 8-15 memory write protection control;  WRP2: Sectors 16-23 memory write protection control;  WRP3: Bits 0-6 provide write protection for sectors 24-30; bit 7 provides write protection for sectors 31-119. | 0xFFFFFFF<br>F |

#### 32.6.1 User Option Bytes Unlock

The user option bytes operation can be unlocked by writing the sequence to the FLASH\_OBKEYR register. After unlocking, the OBWRE bit in the FLASH\_CTLR register will be set to 1, indicating that user option bytes can be erased and programmed. By setting the OBWRE bit in the FLASH\_CTLR register, it will be cleared to 0 by software to lock again.

#### Unlocking sequence

- 1) Write KEY1 = 0x45670123 to the FLASH OBKEYR register;
- 2) Write KEY2 = 0xCDEF89AB to the FLASH\_OBKEYR register.

Note: The user needs to unlock the 2 layers: "LOCK" and "OBWRE" for word selection.

#### 32.6.2 User Option Bytes Programming

It only supports the standard programming mode. The half word (2 bytes) is written at a time. In the actual process, when programming the user option bytes, FPEC only uses the low byte in the half-word, and automatically calculates the high byte (The high byte is the inverse code of the low byte), and then starts the programming operation. Ensure that byte in the user option bytes and its inverse code are always correct.

- 1) Check the LOCK bit in the FLASH\_CTLR register. If it is 1, you need to perform the "Release Flash Memory Lock" operation.
- 2) Check the BSY bit in the FLASH\_STATR register to ensure that there is no other programming operation in progress.
- 3) Check the OBWRE bit in the FLASH\_CTLR register. If it is 0, you need to perform the "User Option Bytes Unlock" operation.
- 4) Set the OBPG bit in the FLASH CTLR register to '1'.
- 5) Write the half word (2 bytes) to be programmed to the designated address.
- 6) When the BSY bit changes to '0' or the EOP bit in the FLASH\_STATR register to be '1', it indicates the end of programming. Clear the EOP bit to 0.
- 7) Read the programming address data for verification.
- 8) To continue programming, you can repeat steps 5-7, end programming and clear the OBPG bit to 0.

Note: When the "read protection" in the option bytes is modified and becomes "non-protected", the main memory area will be erased automatically once. If you modify the selections other than "read protection", the entire chip erasure operation will not occur.

#### 32.6.3 User Option Bytes Erasure

Erase the entire 128-byte user option bytes area directly.

- 1) Check the LOCK bit in the FLASH\_CTLR register. If it is 1, you need to perform the "Release Flash Memory Lock" operation.
- 2) Check the BSY bit in the FLASH\_STATR register to ensure that there is no programming operation in progress.
- 3) Check the OBWRE bit in the FLASH\_CTLR register. If it is 0, you need to perform the "User Option Bytes Unlock" operation.
- 4) Set the OBER bit in the FLASH\_CTLR register to '1', then set the STRT bit in the FLASH\_CTLR register to '1', to enable the user option bytes erasure.
- 5) When the BSY bit changes to '0' or the EOP bit in the FLASH\_STATR register to be '1', it indicates the end of erasure. Clear the EOP bit to 0.
- 6) Read the erasure address data for verification.
- 7) Clear the OBER bit.

Note: After erasing is successful, word read - 0xe339e339, half word read - 0xe339, byte read - 0x39.

#### 32.6.4 Read Protection Release

The read protection of flash memory is determined by the user option bytes. Read the FLASH\_OBR register. When the RDPRT bit is '1', it means that the current flash memory is in the read protection state, and the flash memory operation is subject to a series of safety protections in the read protection state. The process of releasing the read protection is as follows:

1) Erase the entire User Option Bytes area. At this time, the read protection field RDPR will become 0xFF,

and the read protection will be still valid.

- 2) The user option bytes programming and writes the correct RDPR code 0xA5 to release the read protection of the flash memory. (This step will first cause the system to automatically perform a whole chip erasure operation on the flash memory).
- 3) Perform a power-on reset to reload the selection byte (Including the new RDPR code), and the read protection is released at this time.

#### 32.6.5 Write Protection Release

The write protection of flash memory is determined by the user option bytes. Read the FLASH\_WPR register. Each bit represents 4K bytes of flash memory space. When the bit is '1', it means the non-write-protected state, and '0' means write-protected. The process of releasing write-protected is as follows:

- 1) Erase the whole user option bytes area.
- 2) Write the correct RDPR code 0xA5, and the read access is allowed;
- 3) Perform a system reset and reload the selection byte (Including the new WRPR[3:0] byte) to release the write protection.

# **Chapter 33 Extended Configuration**

### 33.1 Extended Configuration

The system provides an EXTEN extended configuration unit (EXTEN\_CTR register). This unit uses HB clock, and it is only reset when system reset occurs. It mainly includes the following extended control bit functions:

- 1) Adjust the internal voltage: LDOTRIM and ULLDOTRIM fields select default values, which can be modified when tuning performance and power consumption.
- 2) PLL clock selection: The HSIPRE field cooperates with the original clock configuration register to provide the option of dividing or not dividing the HSI clock as PLL input clock.
- 3) Lock-up monitor: When the LKUPEN field is enabled, the Lock-up monitor of the system will be enabled. Once a Lock-up condition occurs, the system will perform software reset, and the LKUPRESET field will be set to 1. It can be cleared by writing 1 after reading.
- 4) USBD internal resistor and transfer rate control: For USB full-speed device controller (USBD), the internal pull-up resistor (1.5KΩ) is enabled/disabled by configuring the USBDPU field. An external pull-up resistor is needed to be connected to USB pin (UD-pin when in low-speed mode, UD+ pin when in full-speed mode) when the internal pull-up resistor is disabled. The USBDLS field can be used to configure the current USB device speed mode.
- 5) ETH module 10M Ethernet and 1000M Ethernet RGMII interface enable control: 10M Ethernet can be enabled by configuring ETH\_10M, and 1000M Ethernet RGMII interface can be enabled by configuring ETH RGMII.
- 6) HSE oscillator control in low-power mode: It can be used to control whether HSE oscillates in low-power mode.

Note: For different types of MCUs, the extend register bits are defined differently, please refer to the description of EXTEN CTR for details.

# 33.2 Register Description

Table 33-1 EXTEN register

| Name             | Access address | Description                             | Reset value |
|------------------|----------------|-----------------------------------------|-------------|
| R32_EXTEN_CTR    | 0x40023800     | Configuration extend control register   | 0x00000A40  |
| R32_EXTEN_CTR2   | 0x40023808     | Configuration extend control register 2 | 0x00000000  |
| R32_FEATURE_SIGN | 0x1FFFF7D0     | Feature information sign register       | 0xE339XXXX  |

### 33.2.1 Configure Extended Control Register (EXTEN\_CTR)

| 31 | 30      | 29 | 28          | 27 | 26          | 25          | 24   | 23          | 22 | 21           | 20         | 19          | 18         | 17             | 16         |
|----|---------|----|-------------|----|-------------|-------------|------|-------------|----|--------------|------------|-------------|------------|----------------|------------|
|    |         |    |             |    |             |             | Rese | erved       |    |              |            |             |            |                |            |
| 15 | 14      | 13 | 12          | 11 | 10          | 9           | 8    | 7           | 6  | 5            | 4          | 3           | 2          | 1              | 0          |
| R  | Leserve | d  | HSE<br>KPLP |    | TRIM<br>:0] | ULI<br>TRIM |      | LKU<br>PRST |    | Reser<br>ved | HSI<br>PRE | RGM<br>IION | ETH1<br>0M | USB<br>D<br>PU | USBD<br>LS |

| Bit     | Name     | Access | Description | Reset value |
|---------|----------|--------|-------------|-------------|
| [31:13] | Reserved | RO     | Reserved    | 0           |

|         | 4                                                                                                                                                                               |    | ·                                                                                                                                                                                                                           |     |  |  |  |  |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--|--|--|--|
| [12]    | HSEPLP                                                                                                                                                                          | RW | HSE oscillator control in low-power mode: 0: HSE does not oscillate in low-power mode; 1: HSE keeps oscillating in low-power mode.  Note: Applies for CH32V20x_D8, CH32V20x_D8W and CH32F20x_D8W.                           | 0   |  |  |  |  |
| [11:10] | Adjust digital core voltage value, LDO voltage value  11:10] LDOTRIM[1:0]  RW  Adjust digital core voltage value, LDO voltage value  00: 1.3V;  01: 1.2V;  10: 1.1V;  11: 1.0V. |    |                                                                                                                                                                                                                             |     |  |  |  |  |
| [9:8]   | ULLDOTRIM[1:0]                                                                                                                                                                  | RW | Adjust ULLDO voltage value in low-power mode                                                                                                                                                                                | 10b |  |  |  |  |
| 7       | LKUPRST  RW1  COCKUP reset:  0: Normal;  1: LOCKUP occurs and causes system reset.  Write 1 to clear it.                                                                        |    |                                                                                                                                                                                                                             |     |  |  |  |  |
| 6       | LKUPEN  RW  LKUPEN  RW  LCCKUP monitor function:  0: Disable; 1: Enable. System reset occurs and set the LOCKUP RESET bit when lock-up occurs.                                  |    |                                                                                                                                                                                                                             |     |  |  |  |  |
| 5       | Reserved                                                                                                                                                                        | RO | Reserved                                                                                                                                                                                                                    | 0   |  |  |  |  |
| 4       | HSIPRE                                                                                                                                                                          | RW | HSI clock: (Only can be written when PLL is disabled.)  0: HSI clock divided by 2 selected as PLL input clock;  1: HSI clock selected as PLL input clock.                                                                   | 0   |  |  |  |  |
| 3       | RGMIION                                                                                                                                                                         | RW | 1000M Ethernet RGMII interface enable and clock enable: 0: 1000M Ethernet RGMII interface disabled, and clock disabled; 1: 1000M Ethernet RGMII interface enabled, and clock enabled. Note: Applies for CH32F207, CH32V307. | 0   |  |  |  |  |
| 2       | 10M Ethernet enable and clock enable: 0: 10M Ethernet disabled, and clock disabled; 1: 10M Ethernet enabled, and clock enabled.                                                 |    |                                                                                                                                                                                                                             |     |  |  |  |  |
| 1       | USBD internal pull-up resistor enable:  0: Disable (An external pull-up resistor is                                                                                             |    |                                                                                                                                                                                                                             |     |  |  |  |  |
| 0       | USBDLS                                                                                                                                                                          | RW | USBD operating mode selection:                                                                                                                                                                                              | 0   |  |  |  |  |

|  | 0: Full-speed mode; |  |
|--|---------------------|--|
|  | 1: Low-speed mode.  |  |

### 33.2.2 Configuration Extended Control Register 2 (EXTEN\_CTR)

Offset address: 0x08

| 31 | 30 | 29 | 28 | 27 | 26   | 25    | 24   | 23   | 22 | 21 | 20 | 19                | 18                | 17                | 16                |
|----|----|----|----|----|------|-------|------|------|----|----|----|-------------------|-------------------|-------------------|-------------------|
|    |    |    |    |    |      |       | Rese | rved |    |    |    |                   |                   |                   |                   |
| 15 | 14 | 13 | 12 | 11 | 10   | 9     | 8    | 7    | 6  | 5  | 4  | 3                 | 2                 | 1                 | 0                 |
|    |    |    |    |    | Rese | erved |      |      |    |    |    | OPA4<br>_HS<br>MD | OPA3<br>_HS<br>MD | OPA2<br>_HS<br>MD | OPA1<br>_HS<br>MD |

| Bit    | Name      | Access                       | Description                       | Reset value |
|--------|-----------|------------------------------|-----------------------------------|-------------|
| [31:4] | Reserved  | R0                           | Reserved                          | 0           |
|        |           | OPA4 high-speed mode enable: |                                   |             |
| [3]    | OPA4_HSMD | RW                           | 0: OPA4 disables high-speed mode; | 0           |
|        |           |                              | 1: OPA4 enables high-speed mode.  |             |
|        |           |                              | OPA3 high-speed mode enable:      |             |
| [2]    | OPA3_HSMD | RW                           | 0: OPA3 disables high-speed mode; | 0           |
|        |           |                              | 1: OPA3 enables high-speed mode.  |             |
|        |           |                              | OPA2 high-speed mode enable:      |             |
| [1]    | OPA2_HSMD | RW                           | 0: OPA2 disables high-speed mode; | 0           |
|        |           |                              | 1: OPA2 enables high-speed mode.  |             |
|        |           |                              | OPA1 high-speed mode enable:      |             |
| [0]    | OPA1_HSMD | RW                           | 0: OPA1 disables high-speed mode; | 0           |
|        |           |                              | 1: OPA1 enables high-speed mode.  |             |

Note: The EXTEN\_CTR2 register is only available for CH32F20x\_D8, CH32F20x\_D8C, CH32V30x\_D8, CH32V30x D8C, and CH32V31x D8C lot numbers that do not have a zero in the penultimate sixth bit.

### 33.2.3 Feature Information Sign Register (EXTEN\_CTR)

| 31 | 30       | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20      | 19 | 18 | 17 | 16         |
|----|----------|----|----|----|----|----|----|----|----|----|---------|----|----|----|------------|
|    | Reserved |    |    |    |    |    |    |    |    |    |         |    |    |    |            |
| 15 | 14       | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4       | 3  | 2  | 1  | 0          |
|    | Reserved |    |    |    |    |    |    |    |    | R  | eserved | l  |    |    | VLEVE<br>L |

| Bit     | Name     | Access | Description                                                           | Reset value |
|---------|----------|--------|-----------------------------------------------------------------------|-------------|
| [31:16] | Reserved | RO     | Reserved                                                              | 0xE339      |
| [15:8]  | Reserved | RO     | The bit[15:8] reset value is the inverse of the bit[7:0] reset value. | X           |
| [7:1]   | Reserved | RO     | Reserved                                                              | 0x7F        |
| 0       | VLEVEL   | RO     | VDD supports minimum supply voltage: 0: 1.8V;                         | X           |

| ı   |  | 1.2 47    |  |
|-----|--|-----------|--|
| - 1 |  | 1. 2.4 V. |  |

Note: Only applicable to products where bit[7:0] reset value is inverted with bit[15:8] reset value. If not inverted, VDD supports a minimum supply voltage of 2.4V.

# **Chapter 34 Debug Support (DBG)**

#### 34.1 Main Features

This register allows the MCU to be configured in the debug state. Includes:

- Counters supporting Independent Watchdog (IWDG)
- Counters supporting Window Watchdog (WWDG)
- Counter supporting timer
- Support for I2CSMBus timeout control
- Support for bxCAN communication

## 34.2 Register Description

### 34.2.1 RISC-V Debug MCU Configuration Register (DBGMCU CR)

Offset address: 0x7C0 (CSR)

| 31                | 30 | 29 | 28                | 27    | 26                                 | 25   | 24                | 23                 | 22                | 21                | 20                | 19                | 18          | 17   | 16                |
|-------------------|----|----|-------------------|-------|------------------------------------|------|-------------------|--------------------|-------------------|-------------------|-------------------|-------------------|-------------|------|-------------------|
|                   |    |    | Rese              | erved |                                    |      |                   | TIM1<br>0_ST<br>OP | TIM9<br>_STO<br>P | CAN<br>2_ST<br>OP | CAN<br>1_ST<br>OP | TIM8<br>_STO<br>P |             |      | TIM5<br>_STO<br>P |
| 15                | 14 | 13 | 12                | 11    | 10                                 | 9    | 8                 | 7                  | 6                 | 5                 | 4                 | 3                 | 2           | 1    | 0                 |
| TIM4<br>_STO<br>P |    |    | TIM1<br>_STO<br>P | SMB   | I2C1_<br>SMB<br>US_T<br>IME<br>OUT | DG_S | IWD<br>G_ST<br>OP |                    | F                 | Reserve           | d                 |                   | STAN<br>DBY | STOP | SLEE<br>P         |

| Bit     | Name       | Access | Description                                                                                                                                                              | Reset value |
|---------|------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:24] | Reserved   | RW     | Reserved                                                                                                                                                                 |             |
| 23      | TIM10_STOP | RW     | Timer 10 debug stop bit. The counter stops when the core enters the debug state.  0: Timer 10's counter is still working normally;  1: Timer 10's counter stops working. | 0           |
| 22      | TIM9_STOP  | RW     | Timer 9 debug stop bit. The counter stops when the core enters the debug state.  0: Timer 9's counter is still working normally;  1: Timer 9's counter stops working.    | 0           |
| 21      | CAN2_STOP  | RW     | CAN2 debug stop bit. CAN2 stops when the core enters the debug state.  0: CAN2 still operates normally;  1: CAN2's receive register does not continue to receive data.   | 0           |
| 20      | CAN1_STOP  | RW     | CAN1 debug stop bit. CAN1 stops when the core enters the debug state.  0: CAN1 still operates normally;  1: CAN1's receive register does not continue to receive data.   | 0           |

|    |            |        | Timer 8 debug stop bit. The counter stops when the core |   |  |  |
|----|------------|--------|---------------------------------------------------------|---|--|--|
|    |            |        | enters the debug state.                                 |   |  |  |
| 19 | TIM8_STOP  | RW     | 0: Timer 8's counter is still working normally;         | 0 |  |  |
|    |            |        | 1: Timer 8's counter stops working.                     |   |  |  |
|    |            |        | Timer 7 debug stop bit. The counter stops when the core |   |  |  |
|    |            |        | enters the debug state.                                 |   |  |  |
| 18 | TIM7_STOP  | RW     | 0: Timer 7's counter is still working normally;         | 0 |  |  |
|    |            |        | 1: Timer 7's counter is sun working normany,            |   |  |  |
|    |            |        | Timer 6 debug stop bit. The counter stops when the core |   |  |  |
|    |            |        | enters the debug state.                                 |   |  |  |
| 17 | TIM6_STOP  | RW     | 0: Timer 6's counter is still working normally;         | 0 |  |  |
|    |            |        | 1: Timer 6's counter stops working.                     |   |  |  |
|    |            |        | Timer 5 debug stop bit. The counter stops when the core |   |  |  |
|    |            |        |                                                         |   |  |  |
| 16 | TIM5_STOP  | RW     | enters the debug state.                                 | 0 |  |  |
|    |            |        | 0: Timer 5's counter is still working normally;         |   |  |  |
|    |            |        | 1: Timer 5's counter stops working.                     |   |  |  |
|    |            |        | Timer 4 debug stop bit. The counter stops when the core |   |  |  |
| 15 | TIM4_STOP  | RW     | enters the debug state.                                 | 0 |  |  |
|    |            |        | 0: Timer 4's counter is still working normally;         |   |  |  |
|    |            |        | 1: Timer 4's counter stops working.                     |   |  |  |
|    | TIM3_STOP  |        | Timer 3 debug stop bit. The counter stops when the core |   |  |  |
| 14 |            | RW     | enters the debug state.                                 | 0 |  |  |
|    |            |        | 0: Timer 3's counter is still working normally;         |   |  |  |
|    |            |        | 1: Timer 3's counter stops working.                     |   |  |  |
|    | TIM2_STOP  |        | Timer 2 debug stop bit. The counter stops when the core |   |  |  |
| 13 |            | RW     | enters the debug state.                                 | 0 |  |  |
| 10 |            | 22     | 0: Timer 2's counter is still working normally;         | Ů |  |  |
|    |            |        | 1: Timer 2's counter stops working.                     |   |  |  |
|    |            |        | Timer 1 debug stop bit. The counter stops when the core |   |  |  |
| 12 | TIM1 STOP  | RW     | enters the debug state.                                 | 0 |  |  |
| 12 |            | 10,11  | 0: Timer 1's counter is still working normally;         | Ü |  |  |
|    |            |        | 1: Timer 1's counter stops working.                     |   |  |  |
|    |            |        | SMBUS timeout mode debug stop bit. Stops SMBUS          |   |  |  |
| 11 | I2C2_SMBUS | RW     | timeout mode when the core enters debug state.          | 0 |  |  |
| 11 | _TIMEOUT   | IX VV  | 0: Same as normal mode operation;                       | O |  |  |
|    |            |        | 1: Freezes the SMBUS timeout control.                   |   |  |  |
|    |            |        | SMBUS timeout mode debug stop bit. Stops SMBUS          |   |  |  |
| 10 | I2C1_SMBUS | RW     | timeout mode when the core enters debug state.          | 0 |  |  |
| 10 | _TIMEOUT   | 17. 44 | 0: Same as normal mode operation;                       | U |  |  |
|    |            |        | 1: freezes the SMBUS timeout control.                   |   |  |  |
|    |            |        | WWDG debug stop bit. The debug WWDG stops               |   |  |  |
| Ω  | WWDG STOP  | RW     | working when the core enters the debug state.           | Ω |  |  |
| 9  | WWDG_STOP  | IV VV  | 0: WWDG counter is still working normally;              | 0 |  |  |
|    |            |        | 1: WWDG counter stops working.                          |   |  |  |
| 0  | IWDC STOP  | DW     | IWDG debug stop bit. The debug IWDG stops working       | 0 |  |  |
| 8  | IWDG_STOP  | RW     | when the core enters the debug state.                   | 0 |  |  |

|       |          |    | 0: IWDG counter is still working normally;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |   |
|-------|----------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
|       |          |    | 1: IWDG counter stops working.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |
| [7:3] | Reserved | RW | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0 |
| 2     | STANDBY  | RW | Debug the Standby mode bits.  0: (FCLK off, HCLK off) The entire digital circuitry section is powered down.  1: (FCLK on, HCLK on) The digital circuitry section is not powered down, and the FCLK and HCLK clocks are clocked by the internal RL oscillator. Alternatively, the microcontroller exits STANDBY mode and reset by generating a system reset is the same.  From the software point of view, exiting STANDBY mode is the same as a reset (Except that some status bits indicate that the microcontroller has just exited from STANDBY state).                                                                                                               | 0 |
| 1     | STOP     | RW | Debug stop mode bits.  0: (FCLK off, HCLK off) When in STOP mode, the clock controller disables all clocks (Including HCLK and FCLK). When exiting from STOP mode, the clock configuration is the same as after reset (The microcontroller is clocked by an 8 MHz internal RC oscillator (HIS)). Therefore, the software must reconfigure the clock control system to start the PLL, crystal, etc.  1: (FCLK on, HCLK on) When in Stop mode, the FCLK and HCLK clocks are provided by the internal RC oscillator. When exiting Stop mode, software must reconfigure the clock system to start the PLL, crystal, etc. (Same operation as when configuring this bit to 0). | 0 |
| 0     | SLEEP    | RW | Debug sleep mode bits.  0: (FCLK on, HCLK off) In sleep mode, FCLK is provided by the originally configured system clock, and HCLK is off. Since Sleep mode does not reset the configured clock system, the software does not need to reconfigure the clock system when exiting from Sleep mode.  1: (FCLK on, HCLK on) In Sleep mode, both FCLK and HCLK clocks are provided by the originally configured system clock.                                                                                                                                                                                                                                                 | 0 |

Note: Applicable to CH32V20x, CH32V30x and CH32V31x series. After the system enters the debug mode, the chip has a certain peripheral, the debug module has the function to configure the peripheral, and the debug MCU configuration register has the configuration bits corresponding to the peripheral.

### 34.2.2 ARM Debug MCU Configuration Register (DBGMCU\_CR)

| 31                                 | 30                | 29                | 28   | 27                | 26 | 25                | 24                | _23                | 22                | _21                | 20                | 19   | 18                | 17   | 16                                 |
|------------------------------------|-------------------|-------------------|------|-------------------|----|-------------------|-------------------|--------------------|-------------------|--------------------|-------------------|------|-------------------|------|------------------------------------|
|                                    |                   |                   | Rese | erved             |    |                   |                   | TIM1<br>0_ST<br>OP | TIM9<br>_STO<br>P |                    | TIM8<br>_STO<br>P |      | TIM6<br>_STO<br>P |      | I2C2_<br>SMB<br>US_T<br>IME<br>OUT |
| 15                                 | 14                | 13                | 12   | 11                | 10 | 9                 | 8                 | 7                  | 6                 | 5                  | 4                 | 3    | 2                 | 1    | 0                                  |
| I2C1_<br>SMB<br>US_T<br>IME<br>OUT | CAN<br>1_ST<br>OP | TIM4<br>_STO<br>P |      | TIM2<br>_STO<br>P |    | WW<br>DG_S<br>TOP | IWD<br>G_ST<br>OP |                    | CE_M<br>DE        | TRA<br>CE_I<br>OEN | Rese              | rved | STAN<br>DBY       | STOP | SLEE<br>P                          |

| Bit     | Name                   | Access | Description                                                                                                                                                                                                 | Reset value |
|---------|------------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| [31:24] | Reserved               | RW     | Reserved                                                                                                                                                                                                    |             |
| 23      | TIM10_STOP             | RW     | Timer 10 debug stop bit. The counter stops when the core enters the debug state.  0: Timer 10's counter is still working normally;                                                                          | 0           |
| 22      | TIM9_STOP              | RW     | 1: Timer 10's counter stops working.  Timer 9 debug stop bit. The counter stops when the core enters the debug state.  0: Timer 9's counter is still working normally;  1: Timer 9's counter stops working. | 0           |
| 21      | CAN2_STOP              | RW     | CAN2 debug stop bit. CAN2 stops when the core enters the debug state.  0: CAN2 still operates normally;  1: CAN2's receive register does not continue to receive data.                                      | 0           |
| 20      | TIM8_STOP              | RW     | Timer 8 debug stop bit. The counter stops when the core enters the debug state.  0: Timer 8's counter is still working normally;  1: Timer 8's counter stops working.                                       | 0           |
| 19      | TIM7_STOP              | RW     | Timer 7 debug stop bit. The counter stops when the core enters the debug state.  0: Timer 7's counter is still working normally;  1: Timer 7's counter stops working.                                       | 0           |
| 18      | TIM6_STOP              | RW     | Timer 6 debug stop bit. The counter stops when the core enters the debug state.  0: Timer 6's counter is still working normally;  1: Timer 6's counter stops working.                                       | 0           |
| 17      | TIM5_STOP              | RW     | Timer 5 debug stop bit. The counter stops when the core enters the debug state.  1: Timer 5's counter stops working.  0: Timer 5's counter is still working normally.                                       | 0           |
| 16      | I2C2_SMBUS_<br>TIMEOUT | RW     | SMBUS timeout mode debug stop bit. Stops SMBUS timeout mode when the core enters debug state.  0: Same as normal mode operation;  1: Freezes the SMBUS timeout control.                                     | 0           |

| 15    | I2C1_SMBUS_<br>TIMEOUT | RW | SMBUS timeout mode debug stop bit. Stops SMBUS timeout mode when the core enters debug state.  0: Same as normal mode operation;  1: freezes the SMBUS timeout control.                                                                                                                                                                                                                                                                          | 0  |
|-------|------------------------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| 14    | CAN1_STOP              | RW | CAN1 debug stop bit. CAN1 stops when the core enters the debug state.  0: CAN1 still operates normally;  1: CAN1's receive register does not continue to receive data.                                                                                                                                                                                                                                                                           | 0  |
| 13    | TIM4_STOP              | RW | Timer 4 debug stop bit. The counter stops when the core enters the debug state.  0: Timer 4's counter is still working normally;  1: Timer 4's counter stops working.                                                                                                                                                                                                                                                                            | 0  |
| 12    | TIM3_STOP              | RW | Timer 3 debug stop bit. The counter stops when the core enters the debug state.  0: Timer 3's counter is still working normally;  1: Timer 3's counter stops working.                                                                                                                                                                                                                                                                            | 0  |
| 11    | TIM2_STOP              | RW | Timer 2 debug stop bit. The counter stops when the core enters the debug state.  0: Timer 2's counter is still working normally;  1: Timer 2's counter stops working.                                                                                                                                                                                                                                                                            | 0  |
| 10    | TIM1_STOP              | RW | Timer 1 debug stop bit. The counter stops when the core enters the debug state.  0: Timer 1's counter is still working normally;  1: Timer 1's counter stops working.                                                                                                                                                                                                                                                                            | 0  |
| 9     | WWDG_STOP              | RW | Window watchdog debug stop bit. The debug window watchdog stops working when the core enters the debug state.  1: The window watchdog counter stops working.  0: The window watchdog counter is still working normally.                                                                                                                                                                                                                          | 0  |
| 8     | IWDG_STOP              | RW | Independent watchdog debug stop bit. The watchdog stops when the core enters the debug state.  0: The watchdog counter is still working normally;  1: The watchdog counter stops working.                                                                                                                                                                                                                                                        | 0  |
| [7:6] | TRACE_MODE             | RW | Trace pin assignment control bit. This bit is used in conjunction with TRACE_IOEN.  When TRACE_IOEN = 0:  xx: No trace pins are assigned (Default state).  When TRACE_IOEN = 1:  00: asynchronous mode is used for the trace pins.  01: The trace pin uses synchronous mode and has a data length of 1.  10: The trace pin uses synchronous mode and has a data length of 2.  11: the trace pin is in synchronous mode and the data length is 4. | XX |
| 5     | TRACE_IOEN             | RW | Trace pin assignment enable bit. This bit is used in conjunction with TRACE_MODE.  0: No trace pin is assigned (Default state).                                                                                                                                                                                                                                                                                                                  | 0  |

|       |          |       | 1: Assign the trace pin.                                             |   |
|-------|----------|-------|----------------------------------------------------------------------|---|
| [4:3] | Reserved | RW    | Reserved                                                             | 0 |
| []    |          | 1211  | Debug the standby mode bits.                                         |   |
|       |          |       | 0: (FCLK off, HCLK off) The entire digital circuitry section is      |   |
|       |          |       | powered down.                                                        |   |
|       |          |       | 1: (FCLK on, HCLK on) The digital circuitry section is not           |   |
|       |          |       | powered down, and the FCLK and HCLK clocks are clocked by            |   |
| 2     | STANDBY  | RW    | [-                                                                   | 0 |
|       |          |       | exits STANDBY mode and reset by generating a system reset is         |   |
|       |          |       | the same.                                                            |   |
|       |          |       | From the software point of view, exiting STANDBY mode is the         |   |
|       |          |       | same as a reset (Except that some status bits indicate that the      |   |
|       |          |       | microcontroller has just exited from STANDBY state).                 |   |
|       |          |       | Debug stop mode bits.                                                |   |
|       |          |       | 0: (FCLK off, HCLK off) When in STOP mode, the clock                 |   |
|       |          |       | controller disables all clocks (including HCLK and FCLK).            |   |
|       |          |       | When exiting from STOP mode, the clock configuration is the          |   |
|       |          |       | same as after reset (the microcontroller is clocked by an 8 MHz      |   |
| 1     | CTOD     | DW    | internal RC oscillator (HIS)). Therefore, the software must          |   |
| 1     | STOP     | RW    | reconfigure the clock control system to start the PLL, crystal, etc. |   |
|       |          |       | 1: (FCLK on, HCLK on) When in stop mode, the FCLK and                |   |
|       |          |       | HCLK clocks are provided by the internal RC oscillator. When         |   |
|       |          |       | exiting stop mode, software must reconfigure the clock system        |   |
|       |          |       | to start the PLL, crystal, etc. (Same operation as when              |   |
|       |          |       | configuring this bit to 0).                                          |   |
|       |          |       | Debug sleep mode bits.                                               |   |
|       |          |       | 0: (FCLK on, HCLK off) In sleep mode, FCLK is provided by            |   |
|       |          |       | the originally configured system clock, and HCLK is off. Since       |   |
| 0     | SLEEP    | RW    | sleep mode does not reset the configured clock system, the           |   |
|       | SEEE     | IX VV | software does not need to reconfigure the clock system when          | U |
|       |          |       | exiting from sleep mode.                                             |   |
|       |          |       | 1: (FCLK on, HCLK on) In sleep mode, both FCLK and HCLK              |   |
|       |          |       | clocks are provided by the originally configured system clock.       |   |

Note: Applicable to CH32F20x series. When the system enters debug mode, the chip has a certain peripheral, the debug module has the function to configure that peripheral, and the debug MCU configuration register has the configuration bits corresponding to that peripheral.