

# User Manual

**APM32F103x4x6x8xB**

Arm® Cortex® -M3 based 32-bit MCU

Version: V1.8

# Contents

|          |                                                         |           |
|----------|---------------------------------------------------------|-----------|
| <b>1</b> | <b>Introduction and Document Description Rules.....</b> | <b>6</b>  |
| 1.1      | Introduction.....                                       | 6         |
| 1.2      | Document Description Rules .....                        | 6         |
| <b>2</b> | <b>System Architecture .....</b>                        | <b>9</b>  |
| 2.1      | Full Name and Abbreviation Description of Terms.....    | 9         |
| 2.2      | System Architecture Block Diagram .....                 | 9         |
| 2.3      | Memory Mapping .....                                    | 11        |
| 2.4      | Startup Configuration .....                             | 11        |
| <b>3</b> | <b>FLASH Memory .....</b>                               | <b>13</b> |
| 3.1      | Full Name and Abbreviation Description of Terms.....    | 13        |
| 3.2      | Main Characteristics.....                               | 13        |
| 3.3      | Flash Memory Structure.....                             | 13        |
| 3.4      | Flash Memroy Functional Description .....               | 14        |
| 3.5      | Option Byte Register Functional Description.....        | 16        |
| 3.6      | FMC Register Address Mapping .....                      | 17        |
| 3.7      | FMC Register Functional Description .....               | 18        |
| <b>4</b> | <b>Reset and Clock Management (RCM) .....</b>           | <b>22</b> |
| 4.1      | Full Name and Abbreviation Description of Terms.....    | 22        |
| 4.2      | Reset Functional Description .....                      | 22        |
| 4.3      | Functional Description of Clock Management.....         | 24        |
| 4.4      | Register Address Mapping .....                          | 29        |
| 4.5      | Register Functional Description .....                   | 30        |
| <b>5</b> | <b>Power Management Unit (PMU).....</b>                 | <b>42</b> |
| 5.1      | Full Name and Abbreviation Description of Terms.....    | 42        |
| 5.2      | Introduction.....                                       | 42        |
| 5.3      | Structure Block Diagram .....                           | 43        |
| 5.4      | Functional Description .....                            | 43        |
| 5.5      | Register Address Mapping .....                          | 47        |
| 5.6      | Register Functional Description .....                   | 47        |
| <b>6</b> | <b>Backup Register (BAKPR) .....</b>                    | <b>50</b> |
| 6.1      | Introduction.....                                       | 50        |
| 6.2      | Main Characteristics.....                               | 50        |
| 6.3      | Functional Description .....                            | 50        |
| 6.4      | Register Address Mapping .....                          | 51        |
| 6.5      | Register Functional Description .....                   | 51        |

|           |                                                             |           |
|-----------|-------------------------------------------------------------|-----------|
| <b>7</b>  | <b>Nested Vector Interrupt Controller (NVIC) .....</b>      | <b>54</b> |
| 7.1       | Full Name and Abbreviation Description of Terms.....        | 54        |
| 7.2       | Introduction.....                                           | 54        |
| 7.3       | Main Characteristics.....                                   | 54        |
| 7.4       | Interrupt and Exception Vector Table.....                   | 54        |
| <b>8</b>  | <b>External Interrupt and Event Controller (EINT) .....</b> | <b>57</b> |
| 8.1       | Introduction.....                                           | 57        |
| 8.2       | Functional Description .....                                | 57        |
| 8.3       | Register Address Mapping.....                               | 59        |
| 8.4       | Register Functional Description.....                        | 59        |
| <b>9</b>  | <b>Direct Memory Access (DMA).....</b>                      | <b>62</b> |
| 9.1       | Full Name and Abbreviation Description of Terms.....        | 62        |
| 9.2       | Introduction.....                                           | 62        |
| 9.3       | Main Characteristics.....                                   | 62        |
| 9.4       | Functional Description .....                                | 63        |
| 9.5       | Register Address Mapping.....                               | 67        |
| 9.6       | Register Functional Description.....                        | 67        |
| <b>10</b> | <b>Debug MCU (DBGMCU).....</b>                              | <b>71</b> |
| 10.1      | Full Name and Abbreviation Description of Terms.....        | 71        |
| 10.2      | Introduction.....                                           | 71        |
| 10.3      | Main Characteristics.....                                   | 71        |
| 10.4      | Functional Description .....                                | 72        |
| 10.5      | Register Address Mapping.....                               | 73        |
| 10.6      | Register Functional Description .....                       | 73        |
| <b>11</b> | <b>General-Purpose Input/Output Pin (GPIO) .....</b>        | <b>75</b> |
| 11.1      | Full Name and Abbreviation Description of Terms.....        | 75        |
| 11.2      | Main Characteristics.....                                   | 75        |
| 11.3      | Structure Block Diagram .....                               | 76        |
| 11.4      | Functional Description .....                                | 76        |
| 11.5      | Register Address Mapping.....                               | 79        |
| 11.6      | Register Functional Description .....                       | 80        |
| <b>12</b> | <b>Alternate Function Input/Output Pin (AFIO) .....</b>     | <b>83</b> |
| 12.1      | Introduction.....                                           | 83        |
| 12.2      | Functional Description .....                                | 83        |
| 12.3      | Register Address Mapping.....                               | 86        |
| 12.4      | Register Functional Description .....                       | 86        |
| <b>13</b> | <b>Timer Overview .....</b>                                 | <b>92</b> |

|           |                                                                    |            |
|-----------|--------------------------------------------------------------------|------------|
| 13.1      | Full Name and Abbreviation Description of Terms.....               | 92         |
| 13.2      | Timer Category and Main Difference .....                           | 92         |
| <b>14</b> | <b>Advanced Timer (TMR1).....</b>                                  | <b>95</b>  |
| 14.1      | Introduction.....                                                  | 95         |
| 14.2      | Main Characteristics.....                                          | 95         |
| 14.3      | Structure Block Diagram .....                                      | 96         |
| 14.4      | Functional Description .....                                       | 96         |
| 14.5      | Register Address Mapping.....                                      | 112        |
| 14.6      | Register Functional Description .....                              | 113        |
| <b>15</b> | <b>General-purpose Timer (TMR2/3/4) .....</b>                      | <b>130</b> |
| 15.1      | Introduction.....                                                  | 130        |
| 15.2      | Main Characteristics.....                                          | 130        |
| 15.3      | Structure Block Diagram .....                                      | 131        |
| 15.4      | Functional Description .....                                       | 131        |
| 15.5      | Register Address Mapping.....                                      | 143        |
| 15.6      | Register Functional Description .....                              | 144        |
| <b>16</b> | <b>Watchdog Timer (WDT) .....</b>                                  | <b>158</b> |
| 16.1      | Introduction.....                                                  | 158        |
| 16.2      | Independent Watchdog Timer (IWDT) .....                            | 158        |
| 16.3      | Window Watchdog Timer (WWDT) .....                                 | 159        |
| 16.4      | IWDT Register Address Mapping.....                                 | 161        |
| 16.5      | IWDT Register Functional Description.....                          | 161        |
| 16.6      | WWDT Register Address Mapping .....                                | 162        |
| 16.7      | WWDT Register Functional Description .....                         | 163        |
| <b>17</b> | <b>Real-time Clock (RTC) .....</b>                                 | <b>164</b> |
| 17.1      | Full Name and Abbreviation Description of Terms.....               | 164        |
| 17.2      | Main Characteristics.....                                          | 164        |
| 17.3      | Structure Block Diagram .....                                      | 164        |
| 17.4      | Functional Description .....                                       | 164        |
| 17.5      | Register Address Mapping.....                                      | 165        |
| 17.6      | Register Functional Description .....                              | 166        |
| <b>18</b> | <b>Universal Synchronous/Asynchronous Transceiver (USART) ....</b> | <b>170</b> |
| 18.1      | Full Name and Abbreviation Description of Terms.....               | 170        |
| 18.2      | Introduction.....                                                  | 170        |
| 18.3      | Main Characteristics.....                                          | 170        |
| 18.4      | Functional Description .....                                       | 171        |
| 18.5      | Register Address Mapping.....                                      | 183        |

|           |                                                             |            |
|-----------|-------------------------------------------------------------|------------|
| 18.6      | Register Functional Description .....                       | 184        |
| <b>19</b> | <b>Internal Integrated Circuit Interface (I2C) .....</b>    | <b>190</b> |
| 19.1      | Full Name and Abbreviation Description of Terms.....        | 190        |
| 19.2      | Introduction.....                                           | 190        |
| 19.3      | Main Characteristics.....                                   | 190        |
| 19.4      | Structure Block Diagram .....                               | 191        |
| 19.5      | Functional Description .....                                | 192        |
| 19.6      | Register Address Mapping.....                               | 198        |
| 19.7      | Register Functional Description .....                       | 198        |
| <b>20</b> | <b>Internal Integrated Circuit Interface (I2C3/4) .....</b> | <b>206</b> |
| 20.1      | Introduction.....                                           | 206        |
| 20.2      | Functional Description .....                                | 206        |
| 20.3      | Register Address Mapping.....                               | 216        |
| 20.4      | Register Functional Description .....                       | 218        |
| <b>21</b> | <b>Serial Peripheral Interface (SPI) .....</b>              | <b>237</b> |
| 21.1      | Full Name and Abbreviation Description of Terms.....        | 237        |
| 21.2      | Introduction.....                                           | 237        |
| 21.3      | Main Characteristics.....                                   | 237        |
| 21.4      | Functional Description .....                                | 238        |
| 21.5      | Register Address Mapping.....                               | 247        |
| 21.6      | Register Functional Description .....                       | 248        |
| <b>22</b> | <b>Four-line Serial Peripheral Interface (QSPI) .....</b>   | <b>254</b> |
| 22.1      | Introduction.....                                           | 254        |
| 22.2      | Main Characteristics.....                                   | 254        |
| 22.3      | Functional Description .....                                | 254        |
| 22.4      | Register Address Mapping.....                               | 263        |
| 22.5      | Register Functional Description .....                       | 263        |
| <b>23</b> | <b>Controller area network (CAN) .....</b>                  | <b>274</b> |
| 23.1      | Full Name and Abbreviation Description of Terms.....        | 274        |
| 23.2      | Introduction.....                                           | 274        |
| 23.3      | Main Characteristics.....                                   | 274        |
| 23.4      | Functional Description .....                                | 275        |
| 23.5      | Register Address Mapping.....                               | 283        |
| 23.6      | Register Functional Description .....                       | 283        |
| <b>24</b> | <b>Full-speed USBD Interface Device (USBD).....</b>         | <b>298</b> |
| 24.1      | Introduction.....                                           | 298        |
| 24.2      | Functional Description .....                                | 298        |

|                                                              |            |
|--------------------------------------------------------------|------------|
| 24.3 Register Address Mapping .....                          | 298        |
| 24.4 Register Functional Description .....                   | 299        |
| <b>25 Analog-to-digital Converter (ADC) .....</b>            | <b>308</b> |
| 25.1 Full Name and Abbreviation Description of Terms.....    | 308        |
| 25.2 Introduction.....                                       | 309        |
| 25.3 Main Characteristics.....                               | 309        |
| 25.4 Functional Description .....                            | 310        |
| 25.5 Register Address Mapping.....                           | 319        |
| 25.6 Register Functional Description .....                   | 320        |
| <b>26 Cyclic Redundancy Check Computing Unit (CRC) .....</b> | <b>328</b> |
| 26.1 Introduction.....                                       | 328        |
| 26.2 Functional Description .....                            | 328        |
| 26.3 Register Address Mapping.....                           | 328        |
| 26.4 Register Functional Description .....                   | 328        |
| <b>27 Floating-point unit (FPU).....</b>                     | <b>330</b> |
| 27.1 Introduction.....                                       | 330        |
| 27.2 Functional Description .....                            | 330        |
| 27.3 Register Address Mapping.....                           | 333        |
| 27.4 Register Functional Description .....                   | 333        |
| <b>28 Chip Electronic Signature .....</b>                    | <b>336</b> |
| 28.1 Capacity Register of Main Memory Area .....             | 336        |
| 28.2 96-bit Unique Chip ID.....                              | 336        |
| <b>29 Version History .....</b>                              | <b>338</b> |

# 1 Introduction and Document Description Rules

## 1.1 Introduction

This user manual provides application developers with all the information about how to use MCU (micro-controller) system architecture, memory and peripherals.

For information about Arm® Cortex®-M3 core, please refer to Arm® Cortex®-M3 technical reference manual; please refer to the corresponding datasheet for detailed data such as model information, dimension and electrical characteristics of the device; for all MCU series models, please refer to the corresponding data manual for memory mapping, peripheral existence and their number.

It is hereby declared that Geehy Semiconductor Co., Ltd., hereinafter refer to as "Geehy".

## 1.2 Document Description Rules

### 1.2.1 "Register Functional Description" Rules

- (1) Control (CTRL) registers are all "set to 1 and cleared by software", unless otherwise specified.
- (2) The control registers are usually followed by verb abbreviations to make a distinction. The verbs can be: EN-Enable, CFG-Configure, D-Disable, SET-Setup and SEL-Select
- (3) The state register abbreviation is usually followed by FLG to make a difference.
- (4) The value and data registers usually include V, VALUE, D and DATA, which are not followed by verbs, such as: xxPSC and CNT.

### 1.2.2 Full Name and Abbreviation Description of Terms

Table 1 Abbreviation and Description of R/W Modes

| R/W mode                | Description                                                                                                         | Abbreviation |
|-------------------------|---------------------------------------------------------------------------------------------------------------------|--------------|
| read/write              | Software can read and write this bit.                                                                               | R/W          |
| read-only               | Software can only read this bit.                                                                                    | R            |
| write-only              | Software can only write this bit, and after reading this bit, the reset value will be returned.                     | W            |
| read/clear              | The software can read this bit and clear it by writing 1. Writing 0 has no effect on this bit.                      | RC_W1        |
| read/clear              | The software can read this bit and clear it by writing 0. Writing 1 has no effect on this bit.                      | RC_W0        |
| read/clear by read      | The software can read this bit, reading this bit will automatically clear it to 0, and writing this bit is invalid. | RC_R         |
| read/set                | The software can read and set this bit, and writing 0 has no effect on this bit.                                    | R/S          |
| read-only write trigger | The software can read this bit and writing 0 or 1 can trigger an event but has no effect on the value of this bit.  | RT_W         |

| R/W mode | Description                                                                               | Abbreviation |
|----------|-------------------------------------------------------------------------------------------|--------------|
| toggle   | The software can flip this bit only by writing 1 and writing 0 has no effect on this bit. | T            |

Table 2 Functional Description and Full Name and Abbreviation of Terms of Commonly Used Registers

| Full name in English | English abbreviation |
|----------------------|----------------------|
| Enable               | EN                   |
| Disable              | D                    |
| Clear                | CLR                  |
| Select               | SEL                  |
| Configure            | CFG                  |
| Contrl               | CTRL                 |
| Controller           | C                    |
| Reset                | RST                  |
| Stop                 | STOP                 |
| Set                  | SET                  |
| Load                 | LD                   |
| Calibration          | CAL                  |
| Initialize           | INIT                 |
| Error                | ERR                  |
| Status               | STS                  |
| Ready                | RDY                  |
| Software             | SW                   |
| Hardware             | HW                   |
| Source               | SRC                  |
| System               | SYS                  |
| Peripheral           | PER                  |
| Address              | ADDR                 |
| Direction            | DIR                  |
| Clock                | CLK                  |
| Input                | I                    |
| Output               | O                    |
| Interrupt            | INT                  |
| Data                 | DATA                 |
| Size                 | SIZE                 |

| Full name in English | English abbreviation |
|----------------------|----------------------|
| Divider              | DIV                  |
| Prescaler            | PSC                  |
| Multiplier           | MUL                  |
| Period               | PRD                  |

Table 3 Full Name and Abbreviation of Modules

| Full name in English                                    | English abbreviation |
|---------------------------------------------------------|----------------------|
| External Memory Controller                              | EMMC                 |
| Static Memory Controller                                | SMC                  |
| Dynamic memory Controller                               | DMC                  |
| Reset and Clock Management Unit                         | RCM                  |
| Power Management Unit                                   | PMU                  |
| Backup Register                                         | BAKPR                |
| Nested Vector Interrupt Controller                      | NVIC                 |
| External Interrupt /Event Controller                    | EINT                 |
| Direct Memory Access                                    | DMA                  |
| Debug MCU                                               | DBG MCU              |
| General-Purpose Input Output Pin                        | GPIO                 |
| Alternate Function Input Output Pin                     | AFIO                 |
| Timer                                                   | TMR                  |
| Watchdog Timer                                          | WDT                  |
| Independent Watchdog Timer                              | IWDT                 |
| Windows Watchdog Timer                                  | WWDT                 |
| Real-Time Clock                                         | RTC                  |
| Universal Synchronous Asynchronous Receiver Transmitter | USART                |
| Inter-integrated Circuit Interface                      | I2C                  |
| Serial Peripheral Interface                             | SPI                  |
| Inter-IC Sound Interface                                | I2S                  |
| Quad Serial Peripheral Interface                        | QSPI                 |
| Controller Area Network                                 | CAN                  |
| Secure Digital Input and Output                         | SDIO                 |
| Universal Serial Bus Full-Speed Device                  | USBD                 |
| Analog-to-Digital Converter                             | ADC                  |
| Digital-to-Analog Converter                             | DAC                  |

| Full name in English                     | English abbreviation |
|------------------------------------------|----------------------|
| Cyclic Redundancy Check Calculation Unit | CRC                  |
| Float Point Unit                         | FPU                  |

## 2 System Architecture

### 2.1 Full Name and Abbreviation Description of Terms

Table 4 Full Name and Abbreviation Description of Terms of System Architecture

| Full name in English          | English abbreviation |
|-------------------------------|----------------------|
| Advanced High-Performance Bus | AHB                  |
| Advanced Peripheral Bus       | APB                  |

### 2.2 System Architecture Block Diagram

The main system consists of four driving units and four passive units. The four driving units are DCode bus (D-bus), system bus (S-bus) and general DMA, which are connected to Arm® Cortex®-M3 core. The four passive units are internal SRAM, internal flash memory, EMMC and bridge from AHB to APB (AHB/APBx). AHB/APBx connects all APB devices.

These are connected through a multi-level AHB bus architecture, as shown in the figure below:

Figure 1 System Architecture of APM32F103x4x6x8xB Series Products



Note:

- (1) Only APM32F103xB D version products have FPU floating point operating module.
- (2) Only APM32F103VBT6 and APM32F103V8T6 products have QSPI.
- (3) Only APM32F103xB D version products have I2C3/4.,
- (4) Only APM32F103x8xB E version products have CAN2,
- (5) USBD1/2 use the same pin and address, so these two USBDs cannot be used at the same time, that is, only one USBD can be used at the same time.

## 2.3 Memory Mapping

The memory mapping address is totally 4GB address. The assigned addresses include the core (including core peripherals), on-chip Flash (including main memory area, system memory area and option bytes), on-chip SRAM, EMMC and bus peripherals (including AHB and APB peripherals). Please refer to the data manual of the corresponding model for specific information of various addresses.

### 2.3.1 Embedded SRAM

Built-in static SRAM. It can access by byte, half word (16 bits) or full word (32 bits). The start address of SRAM is 0x2000 0000.

### 2.3.2 Bit Band

Arm® Cortex® -M3 memory is mapped with two bit-band areas, and it maps each word in the alias memory area to a bit in the bit-band memory. Write a word to the alias memory and there will be the same effect as the read-change-write operation on the target of the bit-band area. Both peripheral register and SRAM are mapped into a bit band area, and it is allowed to perform single bit-band write and read operations.

The following gives a mapping formula:

$$\text{bit\_word\_addr} = \text{bit\_band\_base} + (\text{byte\_offset} \times 32) + (\text{bit\_number} \times 4)$$

Please see Arm® Cortex®-M3 Technical Reference Manual for details

## 2.4 Startup Configuration

Since the CPU of Arm® Cortex®-M3 core CPU obtains reset vector from ICode Bus (instruction bus), the startup can only start from the code area, and the typical is Flash memory boot. However, APM32 MCU series realizes a special mechanism. By configuring the BOOT[1:0] pin parameters, there are three different startup modes, namely, the system can not only start from Flash memory or system memory, but also start from the built-in SRAM. The memory selected as the start zone is determined by the selected startup mode.

Table 5 Startup Mode Configuration and Access Mode

| Startup mode selection<br>pin |       | Startup mode                 | Access mode                                                                                                                                                                              |
|-------------------------------|-------|------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BOOT1                         | BOOT0 |                              |                                                                                                                                                                                          |
| X                             | 0     | Main flash memory<br>(Flash) | The main flash memory is mapped to the boot space, but it can still be accessed at its original address, that is, the contents of the flash memory can be accessed in two address areas. |
| 0                             | 1     | System memory                | The system memory is mapped to the boot space (0x0000 0000), but it can still be accessed at its original address.                                                                       |
| 1                             | 1     | Built-in SRAM                | SRAM can be accessed only at the starting address.                                                                                                                                       |

Note:

- (6) The boot space address is 0x0000 0000
- (7) The original address of Flash is 0x0800 0000
- (8) The original address of system memory is 0x1FFF F000
- (9) The starting address of SRAM is 0x2000 0000

The user can select the startup mode after reset by setting the states of BOOT1 and BOOT0 pins. BOOT pin should keep the user's required startup configuration in standby mode. When exiting from the standby mode, the value of boot pin will be latched.

If you choose to start from built-in SRAM, you must use NVIC's exception table and offset register to remap the vector table to SRAM when writing the application code.

### **Embedded startup program**

The embedded startup program is written on the production line by Geehy and stored in the system memory area; the Flash memory can be reprogrammed by using USRAT1 to enable the startup program.

## 3 FLASH Memory

This chapter mainly introduces the storage structure, read, erase, write, read/write protection, unlock/lock characteristics of Flash, and the involved register functional description.

### 3.1 Full Name and Abbreviation Description of Terms

Table 6 Full Name and Abbreviation Description of Terms

| Full name in English    | English abbreviation |
|-------------------------|----------------------|
| Flash Memory Controller | FMC                  |

### 3.2 Main Characteristics

- (1) Flash memory structure
  - Contain main memory area and information block
  - The capacity of main memory area is up to 128KB
  - The information block is divided into system memory area and option byte
  - The capacity of the system memory area is 2KB, for storing BootLoader program, 96-bit unique UID, and main memory area capacity information
  - The capacity of the option byte area is 16Bytes
- (2) Functional Description
  - Read Flash
  - Page/mass erase Flash
  - Write Flash
  - Read/Write protection Flash
  - Configure option bytes

### 3.3 Flash Memory Structure

Table 7 Flash Memory Structure of APM32F103x4/x6/x8/xB Series Products

| Block             | Name               | Address area            | Size (byte) |
|-------------------|--------------------|-------------------------|-------------|
| Main memory area  | Page 0             | 0x0800 0000–0x0800 03FF | 1K          |
| Main memory area  | Page 1             | 0x0800 0400–0x0800 07FF | 1K          |
| Main memory area  | Page 2             | 0x0800 0800–0x0800 0BFF | 1K          |
| Main memory area  | Page 3             | 0x0800 0C00–0x0800 0FFF | 1K          |
| Main memory area  | ...                | ...                     | ...         |
| Main memory area  | Page 127           | 0x0801 FC00–0x0801 FFFF | 1K          |
| Information block | System memory area | 0x1FFF F000–0x1FFF F7FF | 2K          |
| Information block | Option byte        | 0x1FFF F800–0x1FFF F80F | 16          |

Note: The number of pages in the main memory block of APM32F103x4/x6/x8/xB series products is related to the Flash capacity of specific product.

## 3.4 Flash Memory Functional Description

Describe the operation of main memory and information block (including system memory area and option byte), including read, write, erase and read/write protection.

Reading Flash includes main memory block and information block, while the erase, write, read/write are introduced separately; the system memory area has been written before the product leaves the factory and cannot be modified by the user. The erase, write, and read/write protection of the module will not be introduced.

### 3.4.1 Read Flash

Flash memory can be directly addressed, and reading Flash is affected by the following configuration:

#### Wait cycle

Different waiting cycles should be configured for different system clocks:

- 0 wait cycle:  $0 < \text{system clock} \leq 24\text{MHz}$
- 1 wait cycle:  $24\text{MHz} < \text{system clock} \leq 48\text{MHz}$
- 2 wait cycles:  $48\text{MHz} < \text{system clock} \leq 72\text{MHz}$
- 3 wait cycles:  $72\text{MHz} < \text{system clock} \leq 96\text{MHz}$

#### Prefetch buffer

It can improve the reading speed and every time it is reset, the prefetch buffer will be automatically opened; the read interface with prefetch buffer is  $2 \times 64$  bits for APM32F103x4x6x8xB series. It can be configured only when the system clock is consistent with AHB clock and is less than 24MHz, and can be used only when the system clock is consistent with AHB clock.

#### Half-cycle access

When the power consumption needs to be optimized, half-cycle access can be used; at this time, Only the system clock and AHB clock consistent and system clock less than 24 MHZ to configure open or closed.

### 3.4.2 Main Memory Block

#### 3.4.2.1 Erase main memory block

FMC supports page erase and mass erase (full erase) to initialize the contents of the main memory area to high level (the data is represented as 0xFFFF). Before writing to Flash, users are advised to erase the write address page. If the data of write address is not 0xFFFF, a programming error will be triggered.

#### Main memory page erase

Page erase is an independent erase according to the main memory area page selected by the program, which will not have any impact on the page not selected for erasure.

After the correct page erase (or Flash write operation) is completed, OCF of FMC\_STS register will be set. If OCIE interrupt is enabled, an operation completion interrupt will be triggered. Users need to note that the page to be erased must be a valid page (the valid address of the main memory area and the address without write protection).

### Main memory mass erase

The mass erase operation will erase all the contents in the main storage area of Flash, and the mass erase operation will erase all the data in the main memory area, so the users need to pay special attention when using it to avoid the loss of important data caused by misoperation.

#### 3.4.2.2 Main memory block of write

FMC supports the writing of 16-bit (half word) data in the main memory area. You can select Debug, BootLoader, program running in SRAM, and directly reading the erased page to judge whether the erasing is successful.

In order to ensure correct writing, it is necessary to check whether the destination address has been erased before writing; if it is not erased, the written data will be invalid and PEF bit of FMC\_STS register will be set to "1". If the destination address has write protection, the written data is invalid and a write protection error will be triggered (WPEF bit of FMC\_STS is set to "1").

#### 3.4.2.3 Main memory block of read/write protection

Read/write protection of the flash is used to prevent illegal reading/modification of the main memory area code or data, and it is controlled by the read/write protection configuration byte of option byte. For APM32F103x4x6x8xB series products, the basic unit of read/write protection is 4 pages (i.e. 4KBytes).

##### Read protection

Internal Flash protection level can be set by modifying the value of option byte READPROT. The debugger is always connected to JTAG/SWD interface to set read protection, which takes effect after power-on reset; otherwise, it will not take effect after the system is powered on and reset. When the READPROT value is any value except 0xA5, enable read protection and the content of main memory block cannot be read; when the READPROT value is 0xA5, the protection is released and the content of main memory block can be read; when the read protection is removed, a main memory mass erase operation will be triggered to prevent illegal read after the protection is degraded.

##### Write protection

Write protection control can be conducted for the corresponding page of the main memory block by configuring the value of write protection option byte WRP0/1/2/3. After the write protection is turned on, the content on the corresponding page of the main memory area cannot be modified in any way.

#### 3.4.2.4 Main memory block of unlock/lock

FMC\_CTRL1 of the reset FMC will be locked by hardware, and then FMC\_CTRL1 can't be directly written, and the corresponding value must be written to FMC\_KEY according to the correct sequence to unlock FMC. The KEY value is as follows:

- KEY1=0x45670123
- KEY2=0xCDEF89AB

The wrong writing sequence or wrong value will cause the program to enter the hardware wrongly. At this time, FMC will be locked, and all FMC operations will be invalid until it is reset next time. The users can also lock FMC through software by writing "1" to LOCK bit of the control register 2 (FMC\_CTRL2).

In each Flash programming operation, the users must follow the steps of "Flash unlock - program by user - Flash lock", so as to avoid the risk that user code/data is accidentally modified due to the Flash unlocking after the Flash

programming operation.

### 3.4.3 Option Byte

#### 3.4.3.1 Erase option byte

Support erase function. After the correct option byte erase (or option byte write operation) is completed, OCF of FMC\_STS register will be set. If OCIE interrupt is enabled, an operation completion interrupt will be triggered.

#### 3.4.3.2 Write option byte

Eight configurable bytes of option bytes all support writing function.

#### 3.4.3.3 Write protection of option byte

Defaultly, the option byte is always readable and write protected. To perform write operation (program/erase) for the option byte block, first write the correct key sequence (the same as that of locking) in FMC\_OBKEY, and then allow the write operation of option byte block; the OBWEN bit of FMC\_CTRL2 register indicates write enabled; clear this bit and write operation will be disabled.

#### 3.4.3.4 Unlock/Lock option byte

After the system reset, the option byte is locked by default. Only when the option byte is unlocked correctly, can it be modified. The difference between option byte unlocking and flash unlocking is that FMC\_OBKEY register rather than FMC\_KEY register writes the KEY value. The option byte does not support "software lock". The user should pay special attention to that every time after the value of the option byte is modified, the system must be reset to make it effective.

## 3.5 Option Byte Register Functional Description

The option byte provides some optional functions for users, and it mainly consists of 8 configurable bytes and corresponding bit complement. Every time the system is reset, the option byte area will be reloaded to the FMC\_OBCS and FMC\_WRTPROT register (the option byte will only take effect each time they are reloaded to FMC). In the process of reloading, if a certain configurable byte does not match its bit complement, an option byte error (OBE bit of FMC\_OBCS register is set to "1") will be triggered, and this byte will be set to "0xFF". The information of 16 bytes in the option byte area is shown in the table below.

Table 8 Option Bytes

| Address     | Option byte | Initial value | R/W | Functional description                                                                                                                                                                                                       |
|-------------|-------------|---------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x1FFF F800 | READPROT    | 0xA5          | R/W | Read protection configuration                                                                                                                                                                                                |
| 0x1FFF F801 | nREADPROT   | 0x5A          | R   | READPROT bit complement                                                                                                                                                                                                      |
| 0x1FFF F802 | UOB         | 0xFF          | R/W | User option byte<br>Bit 0: WDTSEL<br>0: Hardware watchdog<br>1: Software watchdog<br>Bit 1: nRSTSTOP<br>0: Reset occurs when entering the Stop mode<br>1: Reset does not occur when entering the Stop mode<br>Bit 2: nRSTSTB |

| Address     | Option byte | Initial value | R/W | Functional description                                                                                                    |
|-------------|-------------|---------------|-----|---------------------------------------------------------------------------------------------------------------------------|
|             |             |               |     | 0: Reset occurs when entering the Standby mode<br>1: Do not generate reset bit [3:7] when entering Standby mode: Reserved |
| 0xFFFF F803 | nUOB        | 0x00          | R   | UOB bit complement                                                                                                        |
| 0xFFFF F804 | Data0       | 0xFF          | R/W | User data byte 0                                                                                                          |
| 0xFFFF F805 | nData0      | 0x00          | R   | Data0 bit complement                                                                                                      |
| 0xFFFF F806 | Data1       | 0xFF          | R/W | User data byte 1                                                                                                          |
| 0xFFFF F807 | nData1      | 0x00          | R   | Data bit complement                                                                                                       |
| 0xFFFF F808 | WRP0        | 0xFF          | R/W | Write protection configuration 0                                                                                          |
| 0xFFFF F809 | nWRP0       | 0x00          | R   | WRP0 bit complement                                                                                                       |
| 0xFFFF F80A | WRP1        | 0xFF          | R/W | Write protection configuration 1                                                                                          |
| 0xFFFF F80B | nWRP1       | 0x00          | R   | WRP1 bit complement                                                                                                       |
| 0xFFFF F80C | WRP2        | 0xFF          | R/W | Write protection configuration 2                                                                                          |
| 0xFFFF F80D | nWRP2       | 0x00          | R   | WRP2 bit complement                                                                                                       |
| 0xFFFF F80E | WRP3        | 0xFF          | R/W | Write protection configuration 3                                                                                          |
| 0xFFFF F80F | nWRP3       | 0x00          | R   | WRP3 bit complement                                                                                                       |

Note: When the configurable byte and its bit complement value are "0xFF", the match will not be verified in the reloading process

Table 9 Write Protection WRPx Function Description of Main Memory Area

| Product capacity                         | Functional description                                                                                                                                                                                                                                      |
|------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| APM32F103x4x6 small capacity (1KB/page)  | Each bit in WRPx controls the write protection of 4KB (4 pages) address of the main memory area<br>0: Write protection is turned on<br>1: Write protection is not turned on<br>WRP0: Page 0-31                                                              |
| APM32F103x8xB series products (1KB/page) | Each bit in WRPx controls the write protection of 4KB (4 pages) address of the main memory area<br>0: Write protection is turned on<br>1: Write protection is not turned on<br>WRP0: Page 0-31<br>WRP1: Page 32-63<br>WRP2: Page 64-95<br>WRP3: Page 96-127 |

Note: Flash read/write protection configuration is independent of each other. Removing the write protection will not force the loss of the contents of the main memory area, but keep them as they are.

### 3.6 FMC Register Address Mapping

Base address: 0x40022000

Table 10 FMC Register Address Mapping

| Register name | Description          | Offset address |
|---------------|----------------------|----------------|
| FMC_CTRL1     | Control register 1   | 0x00           |
| FMC_KEY       | Key register         | 0x04           |
| FMC_OBKEY     | Option byte register | 0x08           |
| FMC_STS       | State register       | 0x0C           |

| Register name | Description                        | Offset address |
|---------------|------------------------------------|----------------|
| FMC_CTRL2     | Control register 2                 | 0x10           |
| FMC_ADDR      | Flash address register             | 0x14           |
| FMC_OBCS      | Option byte control/state register | 0x1C           |
| FMC_WRTPROT   | Write protection register          | 0x20           |

## 3.7 FMC Register Functional Description

### 3.7.1 Control register 1 (FMC\_CTRL1)

Offset address: 0x00

Reset value: 0x0000 0030

| Field | Name  | R/W | Description                                                                                                                                                                                                    |
|-------|-------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0   | WS    | R/W | Wait State Configure<br>000: 0 wait cycle, 0<system clock≤24MHz<br>001: 1 wait cycle: 24MHz<system clock≤48MHz<br>010: 2 wait cycles, 48MHz<system clock≤72MHz<br>011: 3 wait cycles, 72MHz<system clock≤96MHz |
| 3     | HCAEN | R/W | Flash Half Cycle Access Enable<br>0: Disable<br>1: Enable                                                                                                                                                      |
| 4     | PBEN  | R/W | Prefetch Buffer Enable<br>0: Disable<br>1: Enable                                                                                                                                                              |
| 5     | PBSF  | R   | Prefetch Buffer Status Flag<br>0: In closed state<br>1: In enabled state                                                                                                                                       |
| 31:6  |       |     | Reserved                                                                                                                                                                                                       |

### 3.7.2 Key register 1 (FMC\_KEY)

Offset address: 0x04

Reset value: 0xFFFFFFFF XXXX

| Field | Name | R/W | Description                                                                                                                                                            |
|-------|------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0  | KEY  | W   | FMC Key<br>Writing the keys represented by these bits can unlock FMC. These bits can only perform write operation, and 0 is returned when read operation is performed. |

### 3.7.3 Option byte key register (FMC\_OBKEY)

Offset address: 0x08

Reset value: 0xFFFFFFFF XXXX

| Field | Name  | R/W | Description                                                                                                                                                                                               |
|-------|-------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0  | OBKEY | W   | Option Byte Key<br>Writing the keys represented by these bits can unlock the option byte write operation. These bits can only perform write operation and 0 is returned when read operation is performed. |

### 3.7.4 State register (FMC\_STS)

Offset address: 0x0C

Reset value: 0x0000 0000

| Field | Name     | R/W | Description                                                                                                                                                             |
|-------|----------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | BUSYF    | R   | Busy Flag<br>This bit indicates that a flash operation is in progress. These bits can only perform write operation, and 0 is returned when read operation is performed. |
| 1     | Reserved |     |                                                                                                                                                                         |
| 2     | PEF      | R/W | Programming Error Flag<br>This bit will be set by software when the value before the address is edited is not "0xFFFF".                                                 |
| 3     | Reserved |     |                                                                                                                                                                         |
| 4     | WPEF     | R/W | Write Protection Error Flag<br>This bit will be set by hardware when programming the write protection address in FLASH.                                                 |
| 5     | OCF      | R/W | Operation Complete Flag<br>This bit will be set by hardware when read/write operation in FLASH is completed.                                                            |
| 31:6  | Reserved |     |                                                                                                                                                                         |

### 3.7.5 Control register 2 (FMC\_CTRL2)

Offset address: 0x10

Reset value: 0x0000 0080

| Field | Name     | R/W | Description                                                                                                                                           |
|-------|----------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | PG       | R/W | Program<br>Set this bit to 1 to program Flash.                                                                                                        |
| 1     | PAGEERA  | R/W | Page Erase<br>Set this bit to 1 to erase the page.                                                                                                    |
| 2     | MASSERA  | R/W | Mass Erase<br>Set this bit to 1 to erase the mass.                                                                                                    |
| 3     | Reserved |     |                                                                                                                                                       |
| 4     | OBP      | R/W | Option Byte Program<br>Set this bit to 1 to program the option byte.                                                                                  |
| 5     | OBE      | R/W | Option Byte Erase<br>Set this bit to 1 to erase the option byte.                                                                                      |
| 6     | STA      | R/W | Start Erase<br>This bit can be only set to 1 by software, and can be reset by clearing STS_BUSYF bit.                                                 |
| 7     | LOCK     | R/W | Lock<br>This bit can be written to 1 only, and when this bit is set to 1, it means that FMC and CTRL2 registers are locked.                           |
| 8     | Reserved |     |                                                                                                                                                       |
| 9     | OBWEN    | R/W | Option Byte Write Enable<br>When this bit is set to 1, the option byte can be programmed.                                                             |
| 10    | ERRIE    | R/W | Error interrupt Enable<br>0: Interrupt is disabled<br>1: Interrupt is enabled<br>When STS_PEF=1 or STS_WPEF=1, set this bit to generate an interrupt. |

| Field | Name     | R/W | Description                                                                                                                                                                                    |
|-------|----------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11    | Reserved |     |                                                                                                                                                                                                |
| 12    | OCIE     | R/W | Operation Complete Interrupt Enable<br>0: Operation completion interrupt is disabled<br>1: Operation completion interrupt is enabled<br>When STS_OCF=1, set this bit to generate an interrupt. |
| 31:13 | Reserved |     |                                                                                                                                                                                                |

### 3.7.6 Address register (FMC\_ADDR)

Offset address: 0x14

Reset value: 0x0000 0000

The register is changed to currently/finally used address by hardware; in page erasing, the register needs to be configured by software.

| Field | Name | R/W | Description                                                                                                                                                   |
|-------|------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0  | ADDR | W   | Flash Address<br>In programming operation, the bit is written to the address to be programmed; in page erasing, this bit is written to the page to be erased. |

### 3.7.7 Option byte control/state register (FMC\_OBCS)

Offset address: 0x1C

Reset value: 0x03FF FFFF

The reset value of the register is related to the value in the written option byte; the reset value of OBE bit is related to the result whether the value of the loaded option byte is consistent with its bit complement.

| Field | Name     | R/W | Description                                                                                                                                          |
|-------|----------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | OBE      | R   | Option Byte Error<br>1: The loaded option byte does not match its bit complement. The option byte and its bit complement are forced to write to 0xFF |
| 1     | READPROT | R   | Read Protection<br>1: Indicate that the flash memory is in read protection state                                                                     |
| 9:2   | UOB      | R   | User Option Byte<br>Here include the user option byte loaded by OBL<br>Bit 2: WDTSEL<br>Bit 3: RSTSTOP<br>Bit 4: RSTSTDB<br>Bit [9:5]: Unused        |
| 17:10 | DATA0    | R   | Data0                                                                                                                                                |
| 25:18 | DATA1    | R   | Data1                                                                                                                                                |
| 31:26 | Reserved |     |                                                                                                                                                      |

### 3.7.8 Write protection register (FMC\_WRTPROT)

Offset address: 0x20

Reset value: 0xFFFF FFFF

| Field | Name    | R/W | Description                                |
|-------|---------|-----|--------------------------------------------|
| 31:0  | WRTPROT | R   | Write Protection<br>0: Valid<br>1: Invalid |

## 4 Reset and Clock Management (RCM)

### 4.1 Full Name and Abbreviation Description of Terms

Table 11 Full Name and Abbreviation Description of Terms

| Full name in English       | English abbreviation |
|----------------------------|----------------------|
| Reset and Clock Management | RCM                  |
| Reset                      | RST                  |
| Power-On Reset             | POR                  |
| Power-Down Reset           | PDR                  |
| High Speed External Clock  | HSECLK               |
| Low Speed External Clock   | LSECLK               |
| High Speed Internal Clock  | HSICLK               |
| Low Speed Internal Clock   | LSICLK               |
| Phase Locked Loop          | PLL                  |
| Main clock output          | MCO                  |
| Calibrate                  | CAL                  |
| Trim                       | TRM                  |
| Wakeup                     | WUP                  |
| Automatic Wakeup           | AWUP                 |
| Backup                     | BAKP                 |
| Low Power                  | LPWR                 |
| Clock Security System      | CSS                  |
| Non Maskable Interrupt     | NMI                  |

### 4.2 Reset Functional Description

The supported reset is divided into three forms, namely, system reset, power reset and backup area reset.

#### 4.2.1 System Reset

##### 4.2.1.1 "System reset" reset source

The reset source is divided into external reset source and internal reset source.

External reset source:

- Low level on NRST pin.

Internal reset source:

- Window watchdog termination count (WWDT reset)
- Independent watchdog termination count (IWDT reset)

- Software reset (SW reset)
- Low-power management reset
- Power reset

A system reset will occur in case of any of the above events. Besides, the reset event source can be identified by viewing the reset flag bit in RCM\_CSTS (control/state register).

Generally speaking, when the system is reset, all registers except the registers in RCM\_CSTS (control/state register) reset flag bit and backup area will be reset to the reset state.

### Software reset

Software can be reset by putting SYSRESETREQ in Arm® Cortex®-M3 interrupt application and reset control register to "1".

### Low-power management reset

Low-power management may reset in two cases, one is when entering the standby mode, and the other is when entering the stop mode. In these two cases, if RSTSTDB bit (in standby mode) or RSTSTOP bit (in stop mode) in user selection byte is cleared, the system will be reset rather than entering the standby or stop mode.

For more information about user option bytes, refer to "Flash memory".

#### 4.2.1.2 "System Reset" reset circuit

The reset source is used in the NRST pin, which remains low in reset process.

The internal reset source generates a delay of at least 20 $\mu$ s pulse on the NRST pin through the pulse generator, which causes the NRST to maintain the level to generate reset; the external reset source directly pulls down the NRST pin level to generate reset.

The "system reset" reset circuit is shown in the figure below.

Figure 2 "System Reset" Reset Circuit



#### 4.2.2 Power Reset

##### "Power reset" reset source

"Power reset" reset source is as follows:

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

A power reset will occur in case of any of the above events.

Power reset will reset all registers except that in backup area.

#### 4.2.3 Backup Domain Reset

##### "Backup domain reset" reset source

"Backup domain reset" reset source is as follows:

- Software reset, set BDRST bit in RCM\_BDCTRL
- $V_{DD}$  or  $V_{BAT}$  is powered on when  $V_{DD}$  or  $V_{BAT}$  is powered down

A backup domain reset will occur in case of any of the above events.

The backup area reset has two special resets, which only affect backup area.

### 4.3 Functional Description of Clock Management

Clock sources of the whole system are: HSECLK, LSECLK, HSICLK, LSICLK, PLL. For the characteristics of the clock source, please refer to the relevant chapter of "Electrical Characteristics" in the data manual.

#### 4.3.1 External Clock Source

The external clock signal includes HSECLK (high-speed external clock signal) and LSECLK (low-speed external clock signal).

There are two kinds of external clock sources:

- External crystal/ceramic resonator
- External clock of user

The hardware configuration of the two kinds of clock sources is shown in the figure below.

Figure 3 HSECLK/LSECLK Clock Source Hardware Configuration

| Clock source              | Hardware configuration |
|---------------------------|------------------------|
| External clock            |                        |
| Crystal/ceramic resonator |                        |

In order to reduce the distortion of clock output and shorten the start-up stabilization time, the crystal/ceramic resonator and load capacitor must be as close to the oscillator pin as possible. The value of load capacitance ( $C_{L1}$ ,  $C_{L2}$ ) must be adjusted according to the selected oscillator.

#### 4.3.1.1 HSECLK high-speed external clock signal

HSECLK clock signal is generated by HSECLK external crystal/ceramic resonator and HSECLK external clock two kinds of clock sources.

Table 12 Clock Source Generating HSECLK

| Name                                                | Instruction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| External clock source (HSECLK bypass)               | <p>Provide clock to MCU through OSC_IN pin.<br/>The signal can be generated by ordinary function signal transmitter (in debugging), crystal oscillator and other signal generators; the waveform can be square wave, sine wave or triangle wave with 50% duty cycle, and the maximum frequency is up to 25MHz.<br/>For hardware connection, it must be connected to OSC_IN pin, ensuring OSC_OUT pin is suspended; for MCU configuration, the user can select this mode by setting HSEBCFG and HSEEN bits in RCM_CTRL.</p>                                                                                       |
| External crystal/ceramic resonator (HSECLK crystal) | <p>The clock is provided to MCU by the resonator, and the resonator includes crystal resonator and ceramic resonator.<br/>The frequency range is 4-16MHz.<br/>When needing to connect OSC_IN and OSC_OUT to the resonator, start and close by setting the HSEEN bit in clock control register RCM_CTRL.<br/>HSERDYFLG bit in RCM_CTRL is used to indicate whether the high-speed external oscillator is stable. After startup, the clock is not released until this bit is set to "1" by hardware. If interrupt is allowed in RCM_INT (clock interrupt register), corresponding interrupt will be generated.</p> |

#### 4.3.1.2 LSECLK low-speed external clock signal

LSECLK clock signal is generated by LSECLK external crystal/ceramic resonator and LSECLK external clock two kinds of clock sources.

Table 13 Clock Source Generating LSECLK

| Name                                                | Instruction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| External clock source (LSECLK bypass)               | The clock is provided to MCU through OSC32_IN pin.<br>The signal can be generated by ordinary function signal transmitter (in debugging), crystal oscillator and other signal generators; the waveform can be square wave, sine wave or triangle wave with 50% duty cycle, and the signal frequency needs to be 32.768kHz.<br>For hardware connection, it must be connected to OSC32_IN pin, ensuring OSC32_OUT pin is suspended; for MCU configuration, the user can select this mode by setting LSEBCFG and LSEEN bits in RCM_BDCTRL (backup domain control register). |
| External crystal/ceramic resonator (LSECLK crystal) | The clock is provided to MCU by the resonator, and the resonator includes crystal resonator and ceramic resonator.<br>The frequency is 32.768kHz.<br>OSC32_IN、OSC32_OUT needs to be connected to the oscillator which can be enabled and disabled through LSEEN bit in RCM_BDCTRL.<br>LSERDYFLG in RCM_BDCTRL indicates whether LSECLK crystal oscillator is stable. At startup stage, LSECLK clock signal is not released until this bit is set to "1" by hardware. If it is allowed in the clock interrupt register, an interrupt request can be generated.            |

#### 4.3.2 Internal Clock Source

The internal clock includes HSICLK (high-speed internal clock signal) and LSICLK (low-speed internal clock signal).

##### 4.3.2.1 HSICLK high-speed internal clock signal

HSICLK clock signal is generated by internal 8MHz RC oscillator.

The RC oscillator frequency of different chips is different, and that of the same chip may be different with the change of temperature and voltage; the HSICLK clock frequency of each chip has been calibrated to 1% ( $25^{\circ}\text{C}, V_{DD}=V_{DDA}=3.3\text{V}$ ) by the manufacturer before leaving the factory. When the system is reset, the value calibrated by the manufacturer will be loaded to RCM\_CTRL; in addition, the users can further adjust the frequency by setting HSITRM in RCM\_CTRL according to the application environment (temperature and voltage) of the site.

HSIRDYFLG bit can be used to indicate whether HSICLK RC oscillator is stable. In the clock startup process, HSICLK RC output clock is not released until the HSIRDYFLG bit is set to 1 by hardware. HSICLK RC can be started or closed by HSIEN bit in RCM\_CTRL.

Compared with HSECLK crystal oscillator, RC oscillator can provide system clock without any external device; the start time of RC oscillator is shorter than that of HSECLK crystal oscillator; even after calibration, its clock frequency accuracy is still inferior to that of HSECLK crystal oscillator.

##### 4.3.2.2 LSICLK low-speed internal clock signal

###### Main characteristics of LSICLK

LSICLK is generated by RC oscillator, within the range of 40kHz (30kHz and 60kHz). The frequency may change along with the change of temperature and voltage. It can keep running in stop and standby mode and provide clock for independent watchdog and automatic wake-up unit.

LSICLK can be started or closed by LSIVEN bit in RCM\_CSTS. LSIRDYFLG bit

in RCM\_CSTS indicates whether the low-speed internal oscillator is stable. At startup stage, the clock is not released until this bit is set to "1" by hardware. If it is allowed in RCM\_INT (clock interrupt register), LSICLK interrupt request will be generated.

#### 4.3.3 PLL (Phase Locked Loop)

The internal PLL can be used to double the frequency of HSICLK output clock or HSECLK crystal output clock.

HSICLK/2 or HSECLK can be selected as PLL input clock source, and output PLLCLK after PLL frequency multiplication (frequency multiplication factor can be selected). The clock source and multiplication factor should be selected before being activated. Once PLL is activated, the selection cannot be changed.

When PLL is ready and PLL interrupt in RCM\_INT (clock interrupt register) is allowed, PLL can send interrupt request.

#### 4.3.4 Clock Tree

Figure 4 APM32F103x4x6x8xB Clock Tree



Note:

- (1) HCLK means AHB clock.
- (2) PCLK1 and PCLK2 are clock signal connected to the peripheral of APB1 and APB2 respectively.
- (3) FCLK is running clock of Arm® Cortex®-M3.
- (4) The frequency of AHB, APB2 (high-speed APB) and APB1 (low-speed APB) domains can be configured through multiple prescalers. Besides, the maximum frequency of AHB and APB2 domain is 96MHz, while the maximum allowable frequency of APB1 is 48MHz.
- (5) When HSICLK is used as the input of PLL clock, the maximum frequency of the system clock is 64MHz.
- (6) When USBD is used, PLL must be set to output 48/72/96MHz clock, which is used to provide 48MHz USBDCLK clock after the frequency is divided by USBD frequency divider.
- (7) When needing to run the peripheral connected to AHB and APB, it is required to turn on the corresponding enable end to make the peripheral get the clock signal.
- (8) SysTick (system timer) can be provided by the clock signal after frequency division of HCLK8. Different clock sources can be selected by setting SysTick control and status register.
- (9) Frequency assignment of all TMRx\_CLK (timer clocks) is automatically set by the hardware according to the following two situations:
  - If the corresponding APB prescaler factor is 1, the clock frequency of the timer is the same as that of the APB bus.
  - Otherwise, the clock frequency of the timer will be set to twice the frequency of the APB bus connected to it.
- (10) Besides, the frequency of TMRx ( $x=2,3,4$ ) clock signals is divided by APB1, and the frequency of TMRx ( $x=1$ ) clock signal is divided by APB2.

#### 4.3.5 Clock Source Selection of RTC

HSECLK/128, LSECLK or LSICLK can be selected as RTCCLK clock source by setting RTCSRSEL bit in RCM\_BDCTRL. The selection of clock source can be changed only when the backup domain is reset.

Because LSECLK is in the backup domain, and HSECLK and LSICLK are not in the backup domain, different clocks will be selected as the RTC clock source; the working condition of clock sources are different, and see the following table for details:

Table 14 Working Condition of RTC When RTC Selects Different Clock Sources

| Clock source                                               | Working condition                                                                                                                                                                                                                                                               |
|------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LSECLK is selected as RTC clock                            | As long as $V_{BAT}$ maintains power supply, RTC will continue to work even if $V_{DD}$ is powered off                                                                                                                                                                          |
| LSICLK is selected as automatic wake-up unit (WAKEUP) unit | If $V_{DD}$ is powered off, AWUP state cannot be guaranteed.                                                                                                                                                                                                                    |
| HSECLK/128 as RTC clock                                    | If the $V_{DD}$ is powered off or the internal voltage regulator is turned off (the power supply of 1.6V domain is cut off), the RTC state is uncertain, so the BPWEN bit (cancel the write protection of backup area) of PMU_CTRL (power control register) must be set to "1". |

#### 4.3.6 Clock Source Selection of IWDT

When IWDT (independent watchdog) is opened, LSICLK oscillator will be

opened by force, and when it is stable, the clock signal will be provided to IWDT. After LSICLK is opened by force, it will always be open and cannot be closed.

#### 4.3.7 Clock Source Selection of MCO

When the corresponding GPIO port register is configured with corresponding function, the clock signal can be selected to be output to MCO pin by MCOSEL in configuration register RCM\_CFG (clock configuration register). See the clock tree or MCOSEL instructions for specific clock signal.

#### 4.3.8 Clock Source Selection of SYSCLK

After system reset, HSICLK oscillator is selected as the system clock, which cannot be stopped. If you want to switch the SYSCLK clock source, you must wait until the destination clock source is ready (i.e. the destination clock source is stable). The target clock source can be HSECLK and PLLCLK, and the clock source of PLLCLK can be HSECLK and HSICLK/2.

The state bit of RCM\_CFG can indicate the ready clock and selected SYSCLK clock source.

#### 4.3.9 CSS Clock Security System

In order to prevent MCU from normal operation due to external crystal oscillator short circuit, MCU can activate CSS clock security system through software.

After the security system is activated, if the HSECLK oscillator is used as the system clock directly or indirectly (used as the PLL input clock and PLL is used as the system clock), the external HSECLK oscillator will be turned off when the HSECLK clock fails, and the system clock will automatically switch to HSICLK. At this time, the PLL which selects HSECLK as the clock input and as the system clock input source will also be turned off.

Note: When CSS is activated by software and HSECLK clock fails, CSS interrupt and NMI (non-maskable interrupt) will be generated. Since NMI is executed continuously before CSS interrupt is cleared, CSSFLG bit in RCM\_INT register shall be set to clear the interrupt.

### 4.4 Register Address Mapping

Table 15 RCM Register Address Mapping

| Register name | Description                           | Offset address |
|---------------|---------------------------------------|----------------|
| RCM_CTRL      | Clock control register                | 0x00           |
| RCM_CFG       | Clock configuration register          | 0x04           |
| RCM_INT       | Clock interrupt register              | 0x08           |
| RCM_APB2RST   | APB2 peripheral reset register        | 0x0C           |
| RCM_APB1RST   | APB1 peripheral reset register        | 0x10           |
| RCM_AHBCLEN   | AHB peripheral clock enable register  | 0x14           |
| RCM_APB2CLKEN | APB2 peripheral clock enable register | 0x18           |
| RCM_APB1CLKEN | APB1 peripheral clock enable register | 0x1C           |
| RCM_BDCTRL    | Backup domain control register        | 0x20           |
| RCM_CSTS      | Control/State register                | 0x24           |

## 4.5 Register Functional Description

### 4.5.1 Clock control register (RCM\_CTRL)

Offset address: 0x00

Reset value: 0x0000 XX83; X means undefined

Access: Access in the form of word, half word and byte, without wait cycle

| Field | Name      | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------|-----------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | HSIEN     | R/W | <p>High Speed Internal Clock Enable<br/>Set to 1 or cleared by software.</p> <p>HSICLK is an RC oscillator. When one of the following conditions occurs, it will be set to 1 by the hardware: power-on start, software reset, wake-up from standby mode, wake-up from stop mode, failure of external high-speed clock source (as system clock or providing system clock through PLL). When HSICLK is used as system clock or provides system clock through PLL, this bit cannot be cleared.</p> <p>0: HSICLK RC oscillator is disabled<br/>1: HSICLK RC oscillator is turned on</p> |
| 1     | HSIRDYFLG | R   | <p>High Speed Internal Clock Ready Flag</p> <p>0: HSICLK RC oscillator is not stable<br/>1: HSICLK RC oscillator is stable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 2     |           |     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 7:3   | HSITRM    | R/W | <p>High Speed Internal Clock Trim</p> <p>The product has been calibrated to <math>8\text{MHz}\pm1\%</math> when leaving the factory. However, it changes as the temperature and voltage changes, but the frequency of HSICLK RC oscillator can be adjusted by HSITRM.</p>                                                                                                                                                                                                                                                                                                           |
| 15:8  | HSICAL    | R   | <p>High Speed Internal Clock Calibrate</p> <p>It will be calibrated to <math>8\text{MHz}\pm1\%</math> before leaving the factory. When the system is started up, the calibration parameters will be automatically written to the register.</p>                                                                                                                                                                                                                                                                                                                                      |
| 16    | HSEEN     | R/W | <p>High Speed External Clock Enable</p> <p>When entering the standby or stop mode, this bit is cleared by hardware and HSECLK is turned off; when HSECLK is used as system clock source or the system clock is provided through PLL, this bit cannot be cleared.</p> <p>0: HSECLK is disabled<br/>1: HSECLK is enabled</p>                                                                                                                                                                                                                                                          |
| 17    | HSERDYFLG | R   | <p>High Speed External Clock Ready Flag</p> <p>When HSECLK is stable, this bit is set to 1 by hardware and cleared by software.</p> <p>0: HSECLK is not stable<br/>1: HSECLK is stable</p>                                                                                                                                                                                                                                                                                                                                                                                          |
| 18    | HSEBCFG   | R/W | <p>High Speed External Clock Bypass Configure</p> <p>Bypass mode refers to the mode in which external clock is used as the HSECLK clock source; otherwise the resonator is used as the HSECLK clock source.</p> <p>0: Non-bypass mode<br/>1: Bypass mode</p>                                                                                                                                                                                                                                                                                                                        |
| 19    | CSSEN     | R/W | <p>Clock Security System Enable</p> <p>0: Disable<br/>1: Enable, enable the clock detector when HSECLK is stable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 23:20 |           |     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

| Field | Name      | R/W | Description                                                                                                                                                                                                                                                                                                                                                 |
|-------|-----------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 24    | PLLEN     | R/W | <p>PLL Enable<br/>When entering the standby or stop mode, this bit is cleared by the hardware; when PLLCLK has been configured (or in the process of configuration) as the clock source of the system clock, this bit cannot be cleared; in other cases, it can be set to 1 or cleared by the software.</p> <p>0: PLL is disabled<br/>1: PLL is enabled</p> |
| 25    | PLLRDYFLG | R   | <p>PLL Clock Ready Flag<br/>PLL is set to 1 by hardware after it is locked.</p> <p>0: PLL is unlocked<br/>1: PLL is locked</p>                                                                                                                                                                                                                              |
| 31:26 | Reserved  |     |                                                                                                                                                                                                                                                                                                                                                             |

#### 4.5.2 Clock configuration register (RCM\_CFG)

Offset address: 0x04

Reset value: 0x0000 0000

All bits of this register are set or cleared by software.

Access: Access in the form of word, half word and byte, with 0 to two wait cycles.

One or two wait cycles are inserted only when the access occurs during clock switching.

| Field | Name       | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0   | SYSCLKSEL  | R/W | <p>System Clock Source Select<br/>When returning from stop or standby mode or the HSECLK directly or indirectly used as system clock fails, the hardware selects HSICLK as system clock by force (if the clock security system has been started)</p> <p>00: HSICLK is used as system clock<br/>01: HSECLK is used as system clock<br/>10: PLLCLK is used as system clock<br/>11: Reserved</p>                                                                                                                              |
| 3:2   | SCLKSELSTS | R   | <p>System Clock Selection Status<br/>Indicate which clock source is used as system clock; set to 1 or cleared by the hardware.</p> <p>00: HSICLK is used as system clock<br/>01: HSECLK is used as system clock<br/>10: PLLCLK is used as system clock<br/>11: Reserved</p>                                                                                                                                                                                                                                                |
| 7:4   | AHPSC      | R/W | <p>AHB Clock Prescaler Factor Configure<br/>0xxx: No frequency division for SYSCLK<br/>1000: SYSCLK two-divided frequency<br/>1001: SYSCLK four-divided frequency<br/>1010: SYSCLK eight-divided frequency<br/>1011: SYSCLK 16-divided frequency<br/>1100: SYSCLK 64-divided frequency<br/>1101: SYSCLK 128-divided frequency<br/>1110: SYSCLK 256-divided frequency<br/>1111: SYSCLK 512-divided frequency<br/>Note: When the prescaler factor of AHB clock is greater than 1, Flash prefetch buffer must be enabled.</p> |
| 10:8  | APB1PSC    | R/W | APB1 Clock Prescaler Factor Configure<br>0xx: No frequency division for HCLK                                                                                                                                                                                                                                                                                                                                                                                                                                               |

| Field | Name      | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------|-----------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |           |     | 100: HCLK 2-divided frequency<br>101: HCLK 4-divided frequency<br>110: HCLK 8-divided frequency<br>111: HCLK 16-divided frequency<br>Note: Software must ensure APB1 clock frequency is not greater than 48MHz.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 13:11 | APB2PSC   | R/W | APB1 Clock Prescaler Factor<br>0xx: No frequency division for HCLK<br>100: HCLK 2-divided frequency<br>101: HCLK 4-divided frequency<br>110: HCLK 8-divided frequency<br>111: HCLK 16-divided frequency                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 15:14 | ADCPSC    | R/W | ADC Clock Prescaler Factor Configure<br>Used as ADC clock after the frequency is divided by PCLK2.<br>00: PCLK2 2 divided frequency<br>01: PCLK2 4 divided frequency<br>10: PCLK2 6 divided frequency<br>11: PCLK2 8 divided frequency                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 16    | PLLSRCSEL | R/W | PLL Clock Source Select<br>This bit can be changed only when PLL is closed.<br>0: HSICLK 2 is used as PLL clock source after frequency division<br>1: HSECLK is used as PLL clock source                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 17    | PLLHSEPSC | R/W | HSECLK Prescaler Factor for PLL Clock Source<br>This bit can be changed only when PLL is closed.<br>0: No frequency division for HSECLK<br>1: HSECLK2 frequency division                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 21:18 | PLLMULCFG | R/W | PLL Multiplication Factor Configure<br>The output frequency of PLL cannot exceed 96MHz, and this bit can be changed only when PLL is closed.<br>0000: PLLCLK 2-multiple frequency output<br>0001: PLLCLK 3-multiple frequency output<br>0010: PLLCLK 4-multiple frequency output<br>0011: PLLCLK 5-multiple frequency output<br>0100: PLLCLK 6-multiple frequency output<br>0101: PLLCLK 7-multiple frequency output<br>0110: PLLCLK 8-multiple frequency output<br>0111: PLLCLK 9-multiple frequency output<br>1000: PLLCLK 10-multiple frequency output<br>1001: PLLCLK 11-multiple frequency output<br>1010: PLLCLK 12-multiple frequency output<br>1011: PLLCLK 13-multiple frequency output<br>1100: PLLCLK 14-multiple frequency output<br>1101: PLLCLK 15-multiple frequency output<br>1110: PLLCLK 16-multiple frequency output<br>1111: PLLCLK 16-multiple frequency output |
| 23:22 | USBDPSC   | R/W | USBD1/2 Prescaler Factor Configure<br>USBDCLK can only be 48MHz, and the appropriate division factor shall be selected according to the clock system. Before enabling USBDCLK in RCM_APB1CLKEN register, this bit must be configured. If USBDCLK is enabled, the bit cannot be changed.<br>0: PLLCLK is used as USBD1/2 clock after 1.5 divided frequency<br>1: PLLCLK is directly used as USBD1/2 clock<br>2: PLLCLK is used as USBD1/2 clock after 2 divided frequency<br>3: Reserved                                                                                                                                                                                                                                                                                                                                                                                              |

| Field | Name     | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------|----------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 26:24 | MCOSEL   | R/W | <p>Main Clock Output Select<br/>           0xx: No clock output<br/>           100: Output SYSLCK<br/>           101: Output HSICLK<br/>           110: Output HSECLK<br/>           111: Output PLLCLK/2<br/>           Note:<br/>           1. The clock output may be truncated when starting and switching the MCO clock source.<br/>           2. When the system clock is output to the MCO pin, please ensure that the output clock frequency is not greater than 50MHz (maximum frequency of I/O port).</p> |
| 27    | FPUPSC   | R/W | <p>FPU Clock Prescaler Factor Configure<br/>           0: HCLK is used as FPU clock<br/>           1: HCLK is used as FPU clock after 2 divided frequency</p>                                                                                                                                                                                                                                                                                                                                                       |
| 31:28 | Reserved |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

#### 4.5.3 Clock interrupt register (RCM\_INT)

Offset address: 0x08

Reset value: 0x0000 0000

Access: Access in the form of word, half word and byte, without wait cycle.

| Field | Name      | R/W | Description                                                                                                                                                                                                                                                                                                                           |
|-------|-----------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | LSIRDYFLG | R   | <p>LSICLK Ready Interrupt Flag<br/>           When LSICLK is stable and LSIRDYEN bit is set to 1, this bit will be set to 1 by hardware; when LSIRDYCLR is set to 1 by software, this bit will be cleared.<br/>           0: No LSICLK ready interrupt<br/>           1: LSICLK ready interrupt occurred</p>                          |
| 1     | LSERDYFLG | R   | <p>LSECLK Ready Interrupt Flag<br/>           When LSECLK is stable and LSERDYEN bit is set to 1, this bit will be set to 1 by hardware; when LSERDYCLR is set to 1 by software, this bit will be cleared.<br/>           0: No LSECLK ready interrupt<br/>           1: LSECLK ready interrupt occurred</p>                          |
| 2     | HSIRDYFLG | R   | <p>HSICLK Ready Interrupt Flag<br/>           When HSICLK is stable and HSIRDYEN bit is set to 1, this bit will be set to 1 by hardware; when HSIRDYCLR is set to 1 by software, this bit will be cleared.<br/>           0: No HSICLK ready interrupt<br/>           1: HSICLK ready interrupt occurred</p>                          |
| 3     | HSERDYFLG | R   | <p>HSECLK Ready Interrupt Flag<br/>           When HSECLK is stable and HSERDYEN bit is set to 1, this bit will be set to 1 by hardware; when HSERDYCLR is set to 1 by software, this bit will be cleared.<br/>           0: No HSECLK ready interrupt<br/>           1: HSECLK ready interrupt occurred</p>                          |
| EN    | PLLRDYFLG | R   | <p>PLL Ready Interrupt Flag<br/>           When PLL is stable and PLLRDYEN bit is set to 1, this bit will be set to 1 by hardware; when PLLRDYCLR is set to 1 by software, this bit will be cleared.<br/>           0: No clock ready interrupt caused by PLL locked<br/>           1: Clock ready interrupt caused by PLL locked</p> |
| 6:5   | Reserved  |     |                                                                                                                                                                                                                                                                                                                                       |

| Field | Name      | R/W | Description                                                                                                                                                                                                                                                   |
|-------|-----------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7     | CSSFLG    | R   | Clock Security System Interrupt Flag<br>When HSECLK fails, set to 1 by hardware; set to 1 by software, this bit is cleared by CSSCLR.<br>0: No security system interrupt caused by HSECLK failure<br>1: Security system interrupt is caused by HSECLK failure |
| 8     | LSIRDYEN  | R/W | LSICLK Ready Interrupt Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                                      |
| 9     | LSERDYEN  | R/W | LSECLK Ready Interrupt Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                                      |
| 10    | HSIRDYEN  | R/W | HSICLK Ready Interrupt Enable<br>0: Disable<br>1: Enable.                                                                                                                                                                                                     |
| 11    | HSERDYEN  | R/W | HSCKE Ready Interrupt Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                                       |
| 12    | PLLRDYEN  | R/W | PLL Ready Interrupt Enable<br>Enable PLL ready interrupt.<br>0: Disable<br>1: Enable                                                                                                                                                                          |
| 15:13 |           |     | Reserved                                                                                                                                                                                                                                                      |
| 16    | LSIRDYCLR | W   | LSICLK Ready Interrupt Clear<br>0: Invalid<br>1: Clear                                                                                                                                                                                                        |
| 17    | LSERDYCLR | W   | LSECLK Ready Interrupt Clear<br>Clear LSECLK ready interrupt flag bit<br>0: No effect<br>1: Clear                                                                                                                                                             |
| 18    | HSIRDYCLR | W   | HSICLK Ready Interrupt Clear<br>Clear HSI ready interrupt flag bit.<br>0: No effect<br>1: Clear                                                                                                                                                               |
| 19    | HSERDYCLR | W   | HSECLK Ready Interrupt Clear<br>Clear HSECLK ready interrupt flag bit<br>0: No effect<br>1: Clear                                                                                                                                                             |
| 20    | PLLRDYCLR | W   | PLL Ready Interrupt Clear<br>0: No effect<br>1: Clear                                                                                                                                                                                                         |
| 22:21 |           |     | Reserved                                                                                                                                                                                                                                                      |
| 23    | CSSCLR    | W   | Clock Security System Interrupt Clear<br>Clear clock security system interrupt flag bit.<br>0: No effect<br>1: Clear                                                                                                                                          |
| 31:24 |           |     | Reserved                                                                                                                                                                                                                                                      |

#### 4.5.4 APB2 peripheral reset register (RCM\_APB2RST)

Offset address: 0x0C

Reset value: 0x0000 0000

Access: Access in the form of word, half word and byte, without wait cycle.

All bits can be reset or cleared by software.

| Field | Name      | R/W | Description                                              |
|-------|-----------|-----|----------------------------------------------------------|
| 0     | AFIORST   | R/W | Alternate Function I/O Reset<br>0: No effect<br>1: Reset |
| 1     |           |     | Reserved                                                 |
| 2     | PARST     | R/W | IO Port A Reset<br>0: No effect<br>1: Reset              |
| 3     | PBRST     | R/W | IO Port B Reset<br>0: No effect<br>1: Reset              |
| 4     | PCRST     | R/W | IO Port C Reset<br>0: No effect<br>1: Reset              |
| 5     | PDRST     | R/W | IO Port D Reset<br>0: No effect<br>1: Reset              |
| 6     | PERST     | R/W | IO Port E Reset<br>0: No effect<br>1: Reset              |
| 8:7   |           |     | Reserved                                                 |
| 9     | ADC1RST   | R/W | ADC1 Reset<br>0: No effect<br>1: Reset                   |
| 10    | ADC2RST   | R/W | ADC2 Reset<br>0: No effect<br>1: Reset                   |
| 11    | TMR1RST   | R/W | Timer 1 Reset<br>0: No effect<br>1: Reset                |
| 12    | SPI1RST   | R/W | SPI1 Reset<br>0: No effect<br>1: Reset                   |
| 13    |           |     | Reserved                                                 |
| 14    | USART1RST | R/W | USART1 Reset<br>0: No effect<br>1: Reset                 |
| 31:15 |           |     | Reserved                                                 |

#### 4.5.5 APB1 peripheral reset register (RCM\_APB1RST)

Offset address: 0x10

Reset value: 0x0000 0000

Access: Access in the form of word, half word and byte, without wait cycle

| Field | Name    | R/W | Description                               |
|-------|---------|-----|-------------------------------------------|
| 0     | TMR2RST | R/W | Timer 2 Reset<br>0: No effect<br>1: Reset |

| Field | Name      | R/W | Description                                                                  |
|-------|-----------|-----|------------------------------------------------------------------------------|
| 1     | TMR3RST   | R/W | Timer 3 Reset<br>0: No effect<br>1: Reset                                    |
| 2     | TMR4RST   | R/W | Timer 4 Reset<br>Set to 1 or cleared by software<br>0: No effect<br>1: Reset |
| 10:3  | Reserved  |     |                                                                              |
| 11    | WWDTRST   | R/W | Window Watchdog Reset<br>0: No effect<br>1: Reset                            |
| 13:12 | Reserved  |     |                                                                              |
| 14    | SPI2RST   | R/W | SPI2 Reset<br>0: No effect<br>1: Reset                                       |
| 16:15 | Reserved  |     |                                                                              |
| 17    | USART2RST | R/W | USART2 Reset<br>0: No effect<br>1: Reset                                     |
| 18    | USART3RST | R/W | USART3 Reset<br>0: No effect<br>1: Reset                                     |
| 20:19 | Reserved  |     |                                                                              |
| 21    | I2C1RST   | R/W | I2C1 Reset<br>0: No effect<br>1: Reset                                       |
| 22    | I2C2RST   | R/W | I2C2 Reset<br>0: No effect<br>1: Reset                                       |
| 23    | USBDRST   | R/W | USBD1/2 Reset<br>0: No effect<br>1: Reset                                    |
| 24    | Reserved  |     |                                                                              |
| 25    | CAN1RST   | R/W | CAN1 Reset<br>0: No effect<br>1: Reset                                       |
| 26    | CAN2RST   | R/W | CAN2 Reset<br>0: No effect<br>1: Reset                                       |
| 27    | BAKPRST   | R/W | Backup Interface Reset<br>0: No effect<br>1: Reset                           |
| 28    | PMURST    | R/W | Power Management Unit Interface Reset<br>0: No effect<br>1: Reset            |
| 29    | DACRST    | R/W | DAC Reset<br>0: No effect<br>1: Reset                                        |

| Field | Name | R/W | Description |
|-------|------|-----|-------------|
| 31:30 |      |     | Reserved    |

#### 4.5.6 AHB peripheral clock enable register (RCM\_AHBCLKEN)

Offset address: 0x14

Reset value: 0x0000 0014

Access: Access in the form of word, half word and byte, without wait cycle

All bits can be reset or cleared by software.

Only when the peripheral clock is enabled, can the value of the peripheral register be read; otherwise the value read is 0.

| Field | Name   | R/W | Description                                                                                            |
|-------|--------|-----|--------------------------------------------------------------------------------------------------------|
| 0     | DMAEN  | R/W | DMA Clock Enable<br>0: Disable<br>1: Enable                                                            |
| 1     |        |     | Reserved                                                                                               |
| 2     | SRAMEN | R/W | SRAM Interface Clock Enable<br>Enable SRAM clock in sleep mode.<br>0: Disable<br>1: Enable             |
| 3     | FPUEN  | R/W | FPU Clock Enable<br>0: Disable<br>1: Enable                                                            |
| 4     | FMCEN  | R/W | FMC Clock Enable<br>Enable the flash interface circuit clock in sleep mode.<br>0: Disable<br>1: Enable |
| 5     | QSPIEN | R/W | QSPI Clock Enable<br>0: Disable<br>1: Enable                                                           |
| 6     | CRCEN  | R/W | CRC Clock Enable<br>0: Disable<br>1: Enable                                                            |
| 31:7  |        |     | Reserved                                                                                               |

#### 4.5.7 APB2 peripheral clock enable register (RCM\_APB2CLKEN)

Offset address: 0x18

Reset value: 0x0000 0000

Access: Access in the form of word, half word and byte

All bits can be reset or cleared by software.

Generally there is no access wait cycle; however, when the peripheral on the APB2 bus is accessed, the waiting state will be inserted until the APB2 peripheral access ends.

Only when the peripheral clock is enabled, can the value of the peripheral register be read; otherwise the value read is 0.

| Field | Name   | R/W | Description                                                    |
|-------|--------|-----|----------------------------------------------------------------|
| 0     | AFIOEN | R/W | Alternate Function I/O Clock Enable<br>0: Disable<br>1: Enable |

| Field | Name     | R/W | Description                                             |
|-------|----------|-----|---------------------------------------------------------|
| 1     | Reserved |     |                                                         |
| 2     | PAEN     | R/W | I/O Port A Clock Enable<br>0: Disable<br>1: Enable      |
| 3     | PBEN     | R/W | I/O Port B Clock Enable<br>0: Disable<br>1: Enable      |
| 4     | PCEN     | R/W | I/O Port C Clock Enable<br>0: Disable<br>1: Enable      |
| 5     | PDEN     | R/W | I/O Port D Clock Enable<br>0: Disable<br>1: Enable      |
| 6     | PEEN     | R/W | I/O Port E Clock Enable<br>0: Disable<br>1: Enable      |
| 8:7   | Reserved |     |                                                         |
| 9     | ADC1EN   | R/W | ADC 1 Interface Clock Enable<br>0: Disable<br>1: Enable |
| 10    | ADC2EN   | R/W | ADC 2 Interface Clock Enable<br>0: Disable<br>1: Enable |
| 11    | TMR1EN   | R/W | TMR1 Timer Clock Enable<br>0: Disable<br>1: Enable      |
| 12    | SPI1EN   | R/W | SPI 1 Clock Enable<br>0: Disable<br>1: Enable           |
| 13    | Reserved |     |                                                         |
| 14    | USART1EN | R/W | USART1 Clock Enable<br>0: Disable<br>1: Enable          |
| 31:15 | Reserved |     |                                                         |

#### 4.5.8 APB1 peripheral clock enable register (RCM\_APB1CLKEN)

Offset address: 0x1C

Reset value: 0x0000 0000

Access: Access in the form of word, half word and byte

All bits can be reset or cleared by software.

Generally there is no access wait cycle; however, when the peripheral on the APB1 bus is accessed, the waiting state will be inserted until the APB1 peripheral access ends.

Only when the peripheral clock is enabled, can the value of the peripheral register be read; otherwise the value read is 0.

| Field | Name     | R/W | Description                                             |
|-------|----------|-----|---------------------------------------------------------|
| 0     | TMR2EN   | R/W | Timer 2 Clock Enable<br>0: Disable<br>1: Enable         |
| 1     | TMR3EN   | R/W | Timer 3 Clock Enable<br>0: Disable<br>1: Enable         |
| 2     | TMR4EN   | R/W | Timer 4 Clock Enable<br>0: Disable<br>1: Enable         |
| 10:3  | Reserved |     |                                                         |
| 11    | WWDTEN   | R/W | Window Watchdog Clock Enable<br>0: Disable<br>1: Enable |
| 13:12 | Reserved |     |                                                         |
| 14    | SPI2EN   | R/W | SPI 2 Clock Enable<br>0: Disable<br>1: Enable           |
| 16:15 | Reserved |     |                                                         |
| 17    | USART2EN | R/W | USART 2 Clock Enable<br>0: Disable<br>1: Enable         |
| 18    | USART3EN | R/W | USART 3 Clock Enable<br>0: Disable<br>1: Enable         |
| 20:19 | Reserved |     |                                                         |
| 21    | I2C1EN   | R/W | I2C1/3 Clock Enable<br>0: Disable<br>1: Enable          |
| 22    | I2C2EN   | R/W | I2C2/4 Clock Enable<br>0: Disable<br>1: Enable          |
| 23    | USBDEN   | R/W | USBD1/2 Clock Enable<br>0: Disable<br>1: Enable         |
| 24    | Reserved |     |                                                         |
| 25    | CAN1EN   | R/W | CAN1 Clock Enable<br>0: Disable<br>1: Enable            |
| 26    | CAN2EN   | R/W | CAN2 Clock Enable<br>0: Disable<br>1: Enable            |

| Field | Name     | R/W | Description                                                             |
|-------|----------|-----|-------------------------------------------------------------------------|
| 27    | BAKPEN   | R/W | Backup Interface Clock Enable<br>0: Disable<br>1: Enable                |
| 28    | PMUEN    | R/W | Power Management Unit Interface Clock Enable<br>0: Disable<br>1: Enable |
| 31:29 | Reserved |     |                                                                         |

#### 4.5.9 Backup domain control register (RCM\_BDCTRL)

Offset address: 0x20

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

Access: Access in the form of word, half word and byte. When the register is accessed continuously, the waiting state will be inserted.

Note: Only when BPWEN bit in PMU\_CTRL is set to 1, can LSEEN, LSEBCFG, RTCSRSEL and RTCCLKEN be changed.

| Field | Name      | R/W | Description                                                                                                                                                                                                                                                                                                                           |
|-------|-----------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | LSEEN     | R/W | Low-Speed External Clock Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                                            |
| 1     | LSERDYFLG | R   | Low-Speed External Clock Ready Flag<br>When LSECLK is stable, this bit is set to 1 by hardware, and when it is unstable, it is cleared by hardware.<br>0: Not ready<br>1: Ready                                                                                                                                                       |
| 2     | LSEBCFG   | R/W | Low-Speed External Clock Bypass Mode Configure<br>Bypass mode refers to the mode in which external clock is used as the LSECLK clock source; otherwise the resonator is used as the LSECLK clock source.<br>0: Non-bypass mode<br>1: Bypass mode                                                                                      |
| 7:3   | Reserved  |     |                                                                                                                                                                                                                                                                                                                                       |
| 9:8   | RTCSRSEL  | R/W | RTC Clock Source Select<br>First set the BDRST bit to reset the backup domain, and then select the RTC clock source. It is impossible to directly configure the register to modify.<br>00: No clock<br>01: LSECLK is used as RTC clock<br>10: LSICLK is used as RTC clock<br>11: HSECLK used as RTC clock after 128 divided frequency |
| 14:10 | Reserved  |     |                                                                                                                                                                                                                                                                                                                                       |
| 15    | RTCCLKEN  | R/W | RTC Clock Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                                                           |
| 16    | BDRST     | R/W | Backup Domain Software Reset<br>0: Reset is not activated<br>1: Reset the whole backup domain                                                                                                                                                                                                                                         |
| 31:17 | Reserved  |     |                                                                                                                                                                                                                                                                                                                                       |

#### 4.5.10 Control/State register (RCM\_CSTS)

Offset address: 0x24

Reset value: 0x0C00 0000

Except reset flag, all are cleared by system reset, and reset flag can only be cleared by power reset.

Access: Access in the form of word, half word and byte. When the register is accessed continuously, the waiting state will be inserted.

| Field | Name       | R/W | Description                                                                                                                                                                                                              |
|-------|------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | LSIEN      | R/W | Low-Speed Internal Oscillator Enable<br>Set to 1 or cleared by software.<br>0: Disable<br>1: Enable                                                                                                                      |
| 1     | LSIRDYFLG  | R   | Low-Speed Internal Oscillator Ready Flag<br>When LSICLK is stable, this bit is set to 1 by hardware, and when it is unstable, it is cleared by hardware.<br>0: Not ready<br>1. Ready                                     |
| 23:2  | Reserved   |     |                                                                                                                                                                                                                          |
| 24    | RSTFLGCLR  | R/W | Reset Flag Clear<br>The reset flag is cleared by setting to 1 by software, including RSTFLGCLR.<br>0: No effect<br>1: Clear the reset flag                                                                               |
| 25    | Reserved   |     |                                                                                                                                                                                                                          |
| 26    | NRSTFLG    | R/W | NRST PIN Reset Occur Flag<br>When NRST pin is reset, it is set to 1 by hardware and cleared by software by writing RSTFLGCLR bit.<br>0: No NRST pin reset<br>1: NRST pin reset occurred                                  |
| 27    | PODRSTFLG  | R/W | POR/PDR Reset Occur Flag<br>Set to 1 by hardware; cleared by software by writing RSTFLGCLR bit.<br>0: No power-on/power-down reset occurs<br>1: Power-on/power-down reset occurs                                         |
| 28    | SWRSTFLG   | R/W | Software Reset Occur Flag<br>Set to 1 by hardware; cleared by software by writing RSTFLGCLR bit.<br>0: No occurrence<br>1: Occurred                                                                                      |
| 29    | IWDTRSTFLG | R/W | Independent Watchdog Reset Occur Flag<br>When independent watchdog reset occurs in V <sub>DD</sub> area, it is set to 1 by hardware and cleared by software by writing RSTFLGCLR bit.<br>0: No occurrence<br>1: Occurred |
| 30    | WWDTRSTFLG | R/W | Window Watchdog Reset Occur Flag<br>When window watchdog is reset, it is set to 1 by hardware and cleared by software by writing RSTFLGCLR bit.<br>0: No occurrence<br>1: Occurred                                       |
| 31    | LPWRRSTFLG | R/W | Low Power Reset Occur Flag<br>When low-power management is reset, it is set to 1 by hardware and cleared by software by writing RSTFLGCLR bit.<br>0: No occurrence<br>1: Occurred                                        |

## 5 Power Management Unit (PMU)

The APM32F103x4x6x8 voltage regulator provides 1.5V power supply and the APM32F103xB voltage regulator provides 1.6V power supply.

### 5.1 Full Name and Abbreviation Description of Terms

Table 16 Full Name and Abbreviation Description of Terms

| Full name in English   | English abbreviation |
|------------------------|----------------------|
| Power Management Unit  | PMU                  |
| Power On Reset         | POR                  |
| Power Down Reset       | PDR                  |
| Power Voltage Detector | PVD                  |

### 5.2 Introduction

The power supply is the basis for stable operation of a system. The working voltage is 2.0~3.6V. It can provide 1.6V power supply through the built-in voltage regulator. If the main power  $V_{DD}$  is powered down, it can supply power to the backup power supply area through  $V_{BAT}$ .

## 5.3 Structure Block Diagram

Figure 5 Power Supply Control Structure Block Diagram



## 5.4 Functional Description

### 5.4.1 Power Domain

The power domain of the product includes: V<sub>DD</sub> power domain, V<sub>DPA</sub> power domain, 1.6V power domain and backup power domain.

#### 5.4.1.1 V<sub>DD</sub> power domain

Power supply is provided through V<sub>DD</sub>/V<sub>SS</sub> pins to power the voltage regulator, standby circuit, IWDT, HSECLK, I/O (except PC13, PC14, PC15 pins) and wake-up logic.

#### Voltage regulator

Power can be supplied to 1.6V power domain in the following operating modes:

- Normal mode: in this mode, 1.6V power supply area runs at full power
- Stop mode: In this mode, 1.6V power supply area works in low power state, all clocks are off, and peripherals stop working
- Standby mode: In this mode, the 1.6V power supply area stops power supply, and except for the standby circuit, the content of register and SRAM will be lost

#### 5.4.1.2 $V_{DDA}$ power domain

Power the ADC, HSICLK, LSICLK, TempSensor, PLL and reset module through  $V_{DDA}/V_{SSA}$  and  $V_{REF+}/V_{REF-}$  pins.

##### Independent ADC power supply and reference voltage

Independent ADC power supply can improve conversion accuracy, and the specific power pins are as follows:

- $V_{DDA}$ : Power pin of ADC
- $V_{SSA}$ : Independent power ground pin
- $V_{REF+}/V_{REF-}$ : ADC reference voltage pin

#### 5.4.1.3 1.6V power domain

The core, Flash, SRAM and digital peripherals are powered by voltage regulator.

#### 5.4.1.4 Backup power domain

When  $V_{DD}$  exists, the backup power supply area is powered by  $V_{DD}$ . When  $V_{DD}$  is powered down, the backup power supply area is powered by  $V_{BAT}$ , which is used to save the content of backup register and maintain RTC function. Power the LSECLK crystal oscillator, RTC, backup register and RCM\_BDCTRL register, PC13, PC14 and PC15.

### 5.4.2 Power Management

#### 5.4.2.1 Power-on/power-down reset (POR and PDR)

When the  $V_{DD}/V_{DDA}$  is detected to be lower than the watermark voltage  $V_{POR}$  and  $V_{PDR}$ , the chip will automatically maintain the reset state. The waveform diagrams of power-on reset and power-down reset are as follows. For POR, PDR, hysteresis voltage and hysteresis time, please refer to the "Datasheet".

Figure 6 Power-on Reset and Power-down Reset Oscillogram



#### 5.4.2.2 Power voltage detector (PWD)

A watermark can be set for PWD to monitor whether  $V_{DD}/V_{DDA}$  is higher or lower than the watermark. If interrupt is enabled, the interrupt can be triggered to

process  $V_{DD}/V_{DDA}$  exceeding the watermark in advance. The usage of PVD is as follows:

- (1) Set the PVDEN bit of the configuration register PMU\_CTRL to 1 to enable PVD
- (2) Select the voltage watermark of PVD for the PLSEL[2:0] bit of the configuration register PMU\_CTRL
- (3) The PVDOFLG bit of the configuration register PMU\_CSTS indicates the value of  $V_{DD}$  is higher or lower than the watermark of PVD
- (4) When it is detected that  $V_{DD}/V_{DDA}$  is lower or higher than the watermark of PVD, PVD interrupt will be generated

The watermark waveform of PVD is shown below. Please see "Datasheet" for PVD watermark and hysteresis voltage.

Figure 7 PVD Watermark Level Oscilloscope



### 5.4.3 Power Consumption Control

#### 5.4.3.1 Reduce the power consumption in low-power mode

There are three low-power modes: sleep mode, stop mode and standby mode. The power consumption is reduced by closing the core and clock source and setting the voltage regulator.

The power consumption, wake-up start time, wake-up mode and data storage of each low-power mode are different; the lower the power consumption is, the longer the wake-up time is, the less the wake-up mode is, the less the data saved are after wake-up; users can choose the most appropriate low-power mode according to their needs. The following table shows the difference among three low-power modes.

Table 17 Difference among "Sleep Mode, Stop Mode and Standby Mode"

| Mode  | Instruction                                                                                     | Entry mode           | Wake-up mode  | Voltage regulator | Effect on 1.6V area clock                                                             | Effect on $V_{DD}$ area clock |
|-------|-------------------------------------------------------------------------------------------------|----------------------|---------------|-------------------|---------------------------------------------------------------------------------------|-------------------------------|
| Sleep | Arm® Cortex®-M3 core stops, and all peripherals including the core peripheral are still working | Call WFI instruction | Any interrupt | Open              | Only the core clock is turned off and it has no effect on other clocks and ADC clocks | None                          |
|       |                                                                                                 | Call WFE instruction | Wake-up event | Open              |                                                                                       | None                          |

| Mode    | Instruction             | Entry mode                                          | Wake-up mode                                                                           | Voltage regulator               | Effect on 1.6V area clock      | Effect on V <sub>DD</sub> area clock              |
|---------|-------------------------|-----------------------------------------------------|----------------------------------------------------------------------------------------|---------------------------------|--------------------------------|---------------------------------------------------|
| Stop    | All clocks have stopped | PDDSCFG and LPDSCFG bits +SLEEPDEEP bit +WFI or WFE | Anny external interrupt                                                                | Turn on or be in low-power mode | Close clocks of all 1.6V areas | The oscillator of HSICLK and HSECLK is turned off |
| Standby | 1.6V power off          | PDDSCFG bit +SLEEPDEEP bit +WFI or WFE              | Rising edge of WKUP pin, RTC alarm clock event, external reset on NRST pin, IWDT reset | Off                             |                                |                                                   |

### Sleep mode

The characteristics of sleep mode are shown in the table below

Table 18 Characteristics of Sleep Mode

| Characteristics | Instruction                                                                                                                                                                                                                                                                                                       |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Enter           | Enter the sleep mode immediately by executing WFI or WFE instructions; When SLEEPONEINT is set to 0 and WFI or WFE instruction is executed, the system will enter the sleep mode immediately; when SLEEPONEINT is set to 1, the system will exit the interrupt program and then enter the sleep mode immediately. |
| Wake-up         | If WFI instruction is executed to enter the sleep mode, wake up by any interrupt; If WFE instruction is executed to enter the sleep mode, wake up through an event.                                                                                                                                               |
| Sleep           | The core stops working, all peripherals are still running, and the data in the core registers and memory before sleep are saved.                                                                                                                                                                                  |
| Wake-up delay   | None                                                                                                                                                                                                                                                                                                              |
| After wake-up   | If the system is woken up by interrupt, it will first enter the interrupt, then exit the interrupt, and then execute the program after WFI instruction. If the system is woken up by event, it will directly execute the program after WFE instruction.                                                           |

### Stop mode

The characteristics of stop mode are shown in the table below:

Table 19 Characteristics of Stop Mode

| Characteristics | Instruction                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Enter           | SLEEPDEEP bit of the core register is set to 1, PDDSCFG bit of the register PMU_CTRL is set to 0, and when executing WFI or WFE instruction, the system will enter the stop mode immediately; When LPDSCFG bit of the register PMU_CTRL is set to 0, the voltage regulator is working in normal mode; when LPDSCFG bit of the register PMU_CTRL is set to 1, the voltage regulator is working in low-power mode. |
| Wake-up         | If WFI instruction is executed to enter the sleep mode, wake up by any interrupt; If WFE instruction is executed to enter the sleep mode, wake up through an event.                                                                                                                                                                                                                                              |
| Stop            | The core will stop working, the peripheral will stop working, and the data in the core register and memory before stop will be saved.                                                                                                                                                                                                                                                                            |
| Wake-up delay   | HSICLK oscillator wake-up time + voltage regulator wake-up time from low-power mode.                                                                                                                                                                                                                                                                                                                             |
| After wake-up   | If the system is woken up by interrupt, it will first enter the interrupt, then exit the interrupt, and then execute the program after WFI instruction. If the system is woken up by event, it will directly execute the program after WFE instruction.                                                                                                                                                          |

### Standby mode

The characteristics of standby mode are shown in the table below:

Table 20 Characteristics of Standby Mode

| Characteristics | Instruction                                                                                                                                                                                                             |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Enter           | SLEEPDEEP bit of the core register is set to 1, PDDSCFG bit of the register PMU_CTRL is set to 1, WUEFLG bit is set to 0 and when executing WFI or WFE instruction, the system will enter the standby mode immediately. |
| Wake-up         | Wake up by rising edge of WKUP pin, RTC alarm clock, wake-up, tamper event or NRST pin external reset and IWDT reset.                                                                                                   |
| Standby         | The core will stop working, the peripheral will stop working, and the data in the core register and memory will be lost.                                                                                                |
| Wake-up delay   | Chip reset time.                                                                                                                                                                                                        |
| After wake-up   | The program starts executing from the beginning.                                                                                                                                                                        |

#### 5.4.3.2 Reduce the power consumption in run mode

In the run mode, the power consumption can be reduced by reducing the system clock, closing or reducing the peripheral clock on the APB/AHB bus.

### 5.5 Register Address Mapping

Table 21 PMU Register Address Mapping Table

| Register name | Description                  | Offset address |
|---------------|------------------------------|----------------|
| PMU_CTRL      | Power control register       | 0x00           |
| PMU_CSTS      | Power control/state register | 0x04           |

### 5.6 Register Functional Description

#### 5.6.1 Power control register (PMU\_CTRL)

Offset address: 0x00

Reset value: 0x0000 0000 (cleared when waking up from standby mode)

| Field | Name     | R/W   | Description                                                                                                                                                                                                                                       |
|-------|----------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | LPDSCFG  | R/W   | Low Power Deepsleep Configure<br>Configure the working state of the voltage regulator in stop mode.<br>0: Enable<br>1: Low-power mode                                                                                                             |
| 1     | PDDSCFG  | R/W   | Power Down Deep Sleep Configure<br>When the CPU enters deep sleep, configure the voltage regulator state in standby and stop modes.<br>0: The voltage regulator is controlled by LPDSCFG bit when entering the stop mode<br>1: Enter standby mode |
| 2     | WUFLGCLR | RC_W1 | Wakeup Flag Clear<br>0: Invalid<br>1: Clear the wake-up flag after 2 system clock cycles by writing 1                                                                                                                                             |
| 3     | SBFLGCLR | RC_W1 | Standby Flag Clear<br>0: Invalid<br>1: Write 1 to clear the standby flag                                                                                                                                                                          |

| Field | Name     | R/W | Description                                                                                                                                                                                              |
|-------|----------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4     | PVDEN    | R/W | Power Voltage Detector Enable<br>0: Disable<br>1: Enable                                                                                                                                                 |
| 7:5   | PLSEL    | R/W | watermarkPVD Level Select<br>0x0: 2.2V<br>0x1: 2.3V<br>0x2: 2.4V<br>0x3: 2.5V<br>0x4: 2.6V<br>0x5: 2.7V<br>0x6: 2.8V<br>0x7: 2.9V<br>Note: See "Datasheet" for detailed instructions                     |
| 8     | BPWEN    | R/W | Backup Domain Write Access Enable<br>Backup area refers to RTC and backup register; write access is disabled after reset, and is allowed after writing 1.<br>0: Write is disabled<br>1: Write is enabled |
| 31:9  | Reserved |     |                                                                                                                                                                                                          |

### 5.6.2 Power control/state register (PMU\_CSTS)

Offset address: 0x04

Reset value: 0x0000 0000 (not cleared when waking up from standby mode)

Compared with the standard APB read, it requires extra APB cycle to read this register

| Field | Name     | R/W | Description                                                                                                                                                                                                                                                                                                                                                      |
|-------|----------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | WUEFLG   | R   | Wakeup Event Flag<br>This bit is set by hardware, indicating whether wake-up event or RTC alarm clock wake-up event occurs on WKUP pin<br>0: Not occur<br>1: Occurred<br>Note: Enable the WKUP pin, and an event will be detected when the WKUP pin is at high level.                                                                                            |
| 1     | SBFLG    | R   | Standby Flag<br>This bit is set to 1 by hardware, and can only be cleared by POR/PDR (power-on/power-down reset) or by setting the SBFLGCLR bit of the power supply control register (PMU_CTRL).<br>0: Not enter the standby mode<br>1: Enter the standby mode                                                                                                   |
| 2     | PVDOFLG  | R   | PVD Output Flag<br>Indicate whether $V_{DD}/V_{DDA}$ is higher than the PVD watermark selected by PLSEL[2:0]<br>This bit is valid only when PVD is enabled by PVDEN bit.<br>0: $V_{DD}/V_{DDA}$ higher than PVD watermark<br>1: $V_{DD}/V_{DDA}$ lower than PVD watermark<br>Note: This bit is 0 after reset or when entering the standby mode (PVD stops work). |
| 7:3   | Reserved |     |                                                                                                                                                                                                                                                                                                                                                                  |

| Field | Name     | R/W | Description                                                                                                                                                                                                                                                                                   |
|-------|----------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8     | WKUPCFG  | R/W | <p>WKUP Pin Configure</p> <p>When WKUP is used as a normal I/O, the event on WKUP pin cannot wake up the CPU in standby mode; it can wake up CPU only when it is not used as a normal I/O.</p> <p>0: Configure normal I/O<br/>1: Can wake MCU</p> <p>Note: Clear this bit in system reset</p> |
| 31:9  | Reserved |     |                                                                                                                                                                                                                                                                                               |

## 6 Backup Register (BAKPR)

### 6.1 Introduction

The backup register can be used to store 20 bytes of data, including 10 16-bit registers. When  $V_{DD}$  is closed, the backup domain will be maintained power-on by  $V_{BAT}$ .

Wake up the system in standby mode. If the system is reset or the power supply is reset, the backup register will not be reset. BAKPR control register manages tamper detection and RTC check.

After BAKP is reset, access to the backup register and RTC will be disabled, and the backup domain (BAKPR) will be protected from possible accidental write access. If you want to re-enable the access to the backup register and RTC, operate according to the following steps:

- Enable the power supply and standby interface clock by setting PMU and BAKP bits in RCM\_APB1CLKEN register
- Enable the access to the backup register and RTC by setting BPWEN bit in PMU\_CTRL power control register

### 6.2 Main Characteristics

- Include 20-byte data register
- The state/control register is used to manage the tamper detection pull-up input with interrupt function
- Check register, which can store RTC calibration value
- Output the RTC calibration clock, RTC alarm clock pulse or second pulse on tamper pin PC13 (TAMPER) (when the pin is not used for tamper detection)

### 6.3 Functional Description

#### 6.3.1 Tamper Detection

Judge whether tamper event is generated according to whether the signal on the TAMPER pin changes. Tamper detection event can reset all data backup registers. In order to avoid the loss of tamper events, detect the signal and also detect the edge detection signal and tamper detection enable bit so that the tamper events before detection can be detected. When the TPALCFG bit is set, if the tamper pin is already at a effective level before enabling, an additional tamper event will be generated after the tamper pin is enabled. If TPIEN bit of BAKPR\_CSTS register is also set, an interrupt will be generated when an tamper detection event occurs.

Disable the tamper pin after an tamper event is detected and cleared. If you want to re-enable the tamper detection function, to avoid that there is still tamper detection event on tamper pin when the software writes backup data BAKPR\_DATAx register, it is required to set TPFCFG bit of BAKPR\_CTRL register (equivalent to tamper pin detection) before writing the backup data BAKPR\_DATAx register.

Note: The tamper detection is still active when  $V_{DD}$  is powered off. The tamper pin should be externally connected to the correct level to prevent the reset data backup register from being reset.

### 6.3.2 RTC Calibration

Enable RTC calibration by configuring the CALCOEN bit of RTC clock calibration BAKPR\_CLKCAL register.

RTC clock can be output to the tamper pin through 64 divided frequency.

## 6.4 Register Address Mapping

Table 22 BAKPR Register Address Mapping

| Register name        | Description                    | Offset address |
|----------------------|--------------------------------|----------------|
| BAKPR_DATAx(x=1..10) | Backup data register x         | 0x04+4(x-1)    |
| BAKPR_CLKCAL         | RTC clock calibration register | 0x2C           |
| BAKPR_CTRL           | Backup control register        | 0x30           |
| BAKPR_CSTS           | Backup control/state register  | 0x34           |

## 6.5 Register Functional Description

Peripheral registers can be accessed by half word (16 bits) or word (32 bits).

### 6.5.1 Backup data register x (BAKPR\_DATAx) (x=1...10)

Offset address: From 0x04 to 0x28

Reset value: 0x0000 0000

| Field | Name | R/W | Description                                                                                                                                                                                                                                        |
|-------|------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0  | DATA | R/W | User Backup Data<br>In the presence of V <sub>BAT</sub> power supply, BAKPR_DATAx register cannot be reset through power reset, system reset and standby mode wake-up reset, and can only be reset by resetting the backup domain or tamper event. |

### 6.5.2 RTC clock calibration register (BAKPR\_CLKCAL)

Offset address: 0x2C

Reset value: 0x0000 0000

| Field | Name     | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|----------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6:0   | CALVALUE | R/W | Calibration Value Setup<br>Reduce RTC clock by skipping the clock pulse count of RTC, to realize calibration. This value indicates the pulse count of multiple clocks that will be ignored every 2 <sup>20</sup> clock pulses, which can be slowed down from 0 to 121ppm.                                                                                                                      |
| 7     | CALCOEN  | R/W | Calibration Clock Output Enable<br>0: No output<br>1: For the RTC clock after the tamper pin outputs 64 divided frequency, if LSECLK is 32.768KHz, the output signal frequency is 512Hz. When the CALCOEN bit is set, the tamper detection function needs to be turned off to avoid unnecessary tamper signal detected.<br>Note: This bit will be cleared when V <sub>DD</sub> is powered off. |
| 8     | ASPOEN   | R/W | Alarm or Second Pulse Output Enable<br>0: Disable<br>1: Output RTC entry alarm or second pulse signal on tamper pin<br>The duration of output pulse is one RTC clock cycle; when setting the ASPOEN bit, the tamper detection function should be disabled.<br>Note: This bit can be cleared only by backup domain reset.                                                                       |

| Field | Name    | R/W | Description                                                                                                                                                                                                                                                |
|-------|---------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9     | ASPOSEL | R/W | Alarm or Second Pulse Output Select<br>This bit can select the tamper pin to output RTC second pulse signal or alarm pulse signal<br>0: Output RTC alarm pulse<br>1: Output RTC second pulse<br>Note: This bit can be cleared only by backup domain reset. |
| 31:10 |         |     | Reserved                                                                                                                                                                                                                                                   |

### 6.5.3 Backup control register (BAKPR\_CTRL)

Offset address: 0x30

Reset value: 0x0000 0000

| Field | Name    | R/W | Description                                                                                                                                                         |
|-------|---------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | TPFCFG  | R/W | TAMPER Pin Function Configure<br>0: Tamper pin is used as general-purpose IO port<br>1: Tamper pin is shared in tamper detection                                    |
| 1     | TPALCFG | R/W | TAMPER Pin Active Level Configure<br>Select the effective level detected by the tamper pin to reset all the data backup registers.<br>0: High level<br>1: Low level |
| 31:2  |         |     | Reserved                                                                                                                                                            |

Note: Setting TPALCFG and TPFCFG bits at the same time is always secure. However, a false tamper event will be generated if both are cleared at the same time. Therefore, it is recommended to change the state of TPALCFG bit only when TPFCFG is 0.

### 6.5.4 Backup control/state register (BAKPR\_CSTS)

Offset address: 0x34

Reset value: 0x0000 0000

| Field | Name  | R/W | Description                                                                                                                                                                                                                      |
|-------|-------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | TECLR | W   | Tamper Event Flag Clear<br>This bit is write-only, and the read-out value is 0<br>0: Invalid<br>1: Clear the tamper detection event flag and reset the tamper detection function                                                 |
| 1     | TICLR | W   | Tamper Interrupt Flag Clear<br>This bit is write-only, and the read-out value is 0<br>0: Invalid<br>1: Clear the tamper detection interrupt and interrupt flag                                                                   |
| 2     | TPIEN | R/W | TAMPER Pin Interrupt Enable<br>This bit is reset only after system reset or wake-up from standby mode.<br>Tamper interrupt cannot wake up the system core in low-power mode.<br>0: Disable<br>1: Enable (TPFCFG bit must be set) |
| 7:3   |       |     | Reserved                                                                                                                                                                                                                         |

| Field | Name     | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------|----------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8     | TEFLG    | R   | <p>TAMPER Event Occur Flag<br/>           This bit is set by hardware when an tamper event is detected and it can be cleared by writing 1 to TECLR bit<br/>           0: No tamper event<br/>           1: Tamper event detected<br/>           Note: The tamper event can reset all backup data registers. If the bit is 1, all backup data registers will remain reset, and the backup data cannot be written successfully.</p> |
| 9     | TRGIFLG  | R   | <p>TAMPER Interrupt Occur Flag<br/>           When the TPIEN bit is set and an tamper event is detected, this bit is set by hardware and cleared by writing 1 to the TICLR bit; this bit is reset only after the system is reset or woken up from standby mode.<br/>           0: No tamper interrupt<br/>           1: Tamper interrupt occurred</p>                                                                             |
| 31:10 | Reserved |     |                                                                                                                                                                                                                                                                                                                                                                                                                                   |

## 7 Nested Vector Interrupt Controller (NVIC)

### 7.1 Full Name and Abbreviation Description of Terms

Table 23 Full Name and Abbreviation Description of Terms

| Full name in English   | English abbreviation |
|------------------------|----------------------|
| Non Maskable Interrupt | NMI                  |

### 7.2 Introduction

The Cortex-M3 core in the product integrates nested vectored interrupt controller (NVIC), which is closely coupled with the core, and can handle exceptions and interrupts and power management control efficiently and with low delay. Please see *Cortex-M3 Technical Reference Manual* for more instructions about NVIC.

### 7.3 Main Characteristics

- 49 maskable interrupt channels (excluding 16 Arm® Cortex®-M3 interrupt lines)
- 16 programmable priority levels (use 4-bit interrupt priority level)
- Low-delay exception and interrupt processing
- Power management control
- Realization of system control register

### 7.4 Interrupt and Exception Vector Table

Table 24 APM32F103x4x6x8xB Interrupt and Exception Vector Table

| Exception type | Vector No. | Priority   | Vector address          | Description                                      |
|----------------|------------|------------|-------------------------|--------------------------------------------------|
| -              | -          | -          | 0x0000_0000             | Reserved                                         |
| Reset          | -          | -3         | 0x0000_0004             | Reset                                            |
| NMI            | -          | -2         | 0x0000_0008             | Non-maskable interrupt                           |
| HardFault      | -          | -1         | 0x0000_000C             | Various hardware faults                          |
| MemMange       | -          | Can be set | 0x0000_0010             | Memory management                                |
| BusFault       | -          | Can be set | 0x0000_0014             | -                                                |
| UsageFault     | -          | Can be set | 0x0000_0018             | -                                                |
| -              | -          | -          | 0x0000_001C~0x0000_002B | Reserved                                         |
| SVCall         | -          | Can be set | 0x0000_002C             | SWI instruction realizes system service revoking |
| Debug Monitor  | -          | Can be set | 0x0000_0030             | Debug monitor                                    |
| -              | -          | Can be set | 0x0000_0034             | Reserved                                         |
| PendSV         | -          | Can be set | 0x0000_0038             | Pending system service request                   |
| SysTick        | -          | Can be set | 0x0000_003C             | System tick timer                                |
| WWDT           | 0          | Can be set | 0x0000_0040             | Window watchdog interrupt                        |

| Exception type    | Vector No. | Priority   | Vector address | Description                                             |
|-------------------|------------|------------|----------------|---------------------------------------------------------|
| PVD               | 1          | Can be set | 0x0000_0044    | Power voltage detection interrupt                       |
| TAMPER            | 2          | Can be set | 0x0000_0048    | Tamper detection interrupt                              |
| RTC               | 3          | Can be set | 0x0000_004C    | RTC interrupt                                           |
| FLASH             | 4          | Can be set | 0x0000_0050    | Flash memory global interrupt                           |
| RCM               | 5          | Can be set | 0x0000_0054    | RCM interrupt                                           |
| EINT0             | 6          | Can be set | 0x0000_0058    | EINT Line 0 interrupt                                   |
| EINT1             | 7          | Can be set | 0x0000_005C    | EINT Line 1 interrupt                                   |
| EINT2             | 8          | Can be set | 0x0000_0060    | EINT Line 2 interrupt                                   |
| EINT3             | 9          | Can be set | 0x0000_0064    | EINT Line 3 interrupt                                   |
| EINT4             | 10         | Can be set | 0x0000_0068    | EINT Line 4 interrupt                                   |
| DMA_CH1           | 11         | Can be set | 0x0000_006C    | DMA channel 1 global interrupt                          |
| DMA_CH2           | 12         | Can be set | 0x0000_0070    | DMA channel 2 global interrupt                          |
| DMA_CH3           | 13         | Can be set | 0x0000_0074    | DMA channel 3 global interrupt                          |
| DMA_CH4           | 14         | Can be set | 0x0000_0078    | DMA channel 4 global interrupt                          |
| DMA_CH5           | 15         | Can be set | 0x0000_007C    | DMA channel 5 global interrupt                          |
| DMA_CH6           | 16         | Can be set | 0x0000_0080    | DMA channel 6 global interrupt                          |
| DMA_CH7           | 17         | Can be set | 0x0000_0084    | DMA channel 7 global interrupt                          |
| ADC1/2            | 18         | Can be set | 0x0000_0088    | ADC1 and ADC2 global interrupt                          |
| USBD1_HP_CAN1_TX  | 19         | Can be set | 0x0000_008C    | USBD1 high-priority interrupt/CAN1 sending interrupt    |
| USBD1_LP_CAN1_RX0 | 20         | Can be set | 0x0000_0090    | USBD1 low-priority interrupt/CAN1 receiving 0 interrupt |
| CAN1_RX1          | 21         | Can be set | 0x0000_0094    | CAN1 receiving 1 interrupt                              |
| CAN1_SCE          | 22         | Can be set | 0x0000_0098    | CAN1 SCE interrupt                                      |
| EINT9_5           | 23         | Can be set | 0x0000_009C    | EINT line [9:5] interrupt                               |
| TMR1_BRK          | 24         | Can be set | 0x0000_00A0    | TMR1 braking interrupt                                  |
| TMR1_UP           | 25         | Can be set | 0x0000_00A4    | TMR1 update interrupt                                   |
| TMR1_TRG_COM      | 26         | Can be set | 0x0000_00A8    | TMR1 trigger and communication interrupt                |
| TMR1_CC           | 27         | Can be set | 0x0000_00AC    | TMR1 capture comparison interrupt                       |
| TMR2              | 28         | Can be set | 0x0000_00B0    | TMR2 interrupt                                          |
| TMR3              | 29         | Can be set | 0x0000_00B4    | TMR3 interrupt                                          |
| TMR4              | 30         | Can be set | 0x0000_00B8    | TMR4 interrupt                                          |
| I2C1_EV           | 31         | Can be set | 0x0000_00BC    | I2C1 event interrupt                                    |
| I2C1_ER           | 32         | Can be set | 0x0000_00C0    | I2C1 error interrupt                                    |
| I2C2_EV           | 33         | Can be set | 0x0000_00C4    | I2C2 event interrupt                                    |
| I2C2_ER           | 34         | Can be set | 0x0000_00C8    | I2C2 error interrupt                                    |

| Exception type    | Vector No. | Priority   | Vector address | Description                                             |
|-------------------|------------|------------|----------------|---------------------------------------------------------|
| SPI1              | 35         | Can be set | 0x0000_00CC    | SPI1 interrupt                                          |
| SPI2              | 36         | Can be set | 0x0000_00D0    | SPI2 interrupt                                          |
| USART1            | 37         | Can be set | 0x0000_00D4    | USART1 interrupt                                        |
| USART2            | 38         | Can be set | 0x0000_00D8    | USART2 interrupt                                        |
| USART3            | 39         | Can be set | 0x0000_00DC    | USART3 interrupt                                        |
| EINT15_10         | 40         | Can be set | 0x0000_00E0    | EINT line [15:10] interrupt                             |
| RTC_Alarm         | 41         | Can be set | 0x0000_00E4    | RTC alarm interrupt                                     |
| USBD_WakeUP       | 42         | Can be set | 0x0000_00E8    | USBD wake-up interrupt                                  |
| FPU               | 43         | Can be set | 0x0000_00EC    | FPU interrupt                                           |
| QSPI              | 44         | Can be set | 0x0000_00F0    | QSPI interrupt                                          |
| USBD2_HP_CAN2_TX  | 45         | Can be set | 0x0000_00F4    | USB2 high-priority interrupt/CAN2 sending interrupt     |
| USBD2_LP_CAN1_RX0 | 46         | Can be set | 0x0000_00F8    | USBD2 low-priority interrupt/CAN2 receiving 0 interrupt |
| CAN2_RX1          | 47         | Can be set | 0x0000_00FC    | CAN2 receiving 1 interrupt                              |
| CAN2_SCE          | 48         | Can be set | 0x0000_0100    | CAN2 SCE interrupt                                      |

## 8 External Interrupt and Event Controller (EINT)

### 8.1 Introduction

The interrupts/events contain internal interrupt/event and external interrupt/event. In this manual, external interrupt refers to the interrupt/event caused by I/O pin input signal, which is EINTx in interrupt vector table; other interrupts are internal interrupts/events.

The events can be divided into hardware events and software events. Hardware events are generated by external/core hardware signals, while software events are generated by instructions.

Interrupts need to go through the interrupt handler function to realize the work to be processed, while events do not need to go through interrupt handler function, and the preset work can be triggered by hardware. The external events output pulse through events such as GPIO, while the internal events trigger another TMR to work, for example, through update event of one TMR.

### 8.2 Functional Description

#### 8.2.1 "External Interrupt And Event" Classification and Difference Points

"External interrupt and event" can be classified into external hardware interrupt, external hardware event, external software event and external software interrupt according to trigger source, configuration and execution process. The difference points are shown in the table below:

Table 25 "External Interrupt and Event" Classification and Difference Points

| Name                        | Trigger source                                                   | Configuration and execution process                                                                                                                                                                                                                                                                                                                                                                                            |
|-----------------------------|------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| External hardware interrupt | External signal                                                  | (1) Set the trigger mode, allow the interrupt request, and enable corresponding peripheral interrupt line (enable in NVIC);<br>(2) When an edge consistent with the configuration is generated on the external interrupt line, an interrupt request will be generated, and the corresponding suspend bit will be set to 1. Write 1 to the corresponding bit of the pending register and the interrupt request will be cleared. |
| External hardware event     | External signal                                                  | (1) Set the trigger mode and enable the event line;<br>(2) When an edge consistent with the configuration is generated on the external interrupt line, one event request pulse will be generated, and the corresponding pending bit will not be set to 1.                                                                                                                                                                      |
| External software request   | Software interrupt register/transmission event (SEV) instruction | (1) Enable the event line;<br>(2) Write 1 to the software interrupt event register of the corresponding event line to generate an event request pulse, and the corresponding pending bit will not be set to 1.                                                                                                                                                                                                                 |
| External software interrupt | Software interrupt register                                      | (1) Allow interrupt request, and enable the corresponding peripheral interrupt line (enable in NVIC);<br>(2) Write 1 to the software interrupt event register of the corresponding event line to generate an interrupt request, the corresponding pending bit will be set to 1; write 1 to the corresponding bit of the pending register and the interrupt request will be cleared.                                            |

## 8.2.2 Core Wake-up

Using WFI and WFE instructions can make the core stop working. When WFI instruction is used, any interrupt can wake up the core; when WFE instruction is used, the core can be waken up by event.

When interrupt is used for wake-up, the interrupt handler function will be triggered, and normal interrupt configuration can wake up the core. When an event is used to wake up the core, the interrupt handler function will not be triggered, which will reduce the wake-up time, and the configuration method is:

- (1) It can trigger an internal interrupt (internal hardware event) but cannot trigger the interrupt handler function for wake-up
  - It can enable an internal interrupt in the peripheral, but cannot enable the corresponding interrupt in NVIC to avoid triggering the interrupt handler function
  - Enable SEVONPEND bit in the system controller of the core, and execute WFE instruction to make the core enter sleep mode
  - Generate an interrupt to wake up the core; when the core recovers from WFE, it is required to clear the pending bit of corresponding peripheral interrupt and the pending bit of peripheral NVIC interrupt channel (clear the pending register in the NVIC interrupt)
- (2) Wake up through EINT line events (external hardware event)
  - Configure EINT line as the event mode
  - Execute WFE instruction to make the core enter the sleep mode
  - Generate an interrupt to wake up the core; when the CPU recovers from WFE, since the pending bit of corresponding event line is not set, it is unnecessary to clear the interrupt pending bit of corresponding peripheral or the NVIC interrupt channel pending bit

### 8.2.2.1 Event wake-up

**It can trigger an internal interrupt (internal hardware event) but cannot trigger the interrupt handler function for wake-up**

- (1) Enable an internal interrupt in the peripheral, but do not enable the corresponding interrupt in NVIC to avoid triggering the interrupt handler function;
- (1) Enable SEVONPEND bit in the system controller of the core, and execute WFE instruction to make the core enter sleep mode;
- (2) Generate an interrupt to wake up the core; when the core recovers from WFE, it is required to clear the pending bit of corresponding peripheral interrupt and the pending bit of peripheral NVIC interrupt channel (clear the pending register in the NVIC interrupt).

**Wake up through EINT line events (external hardware event)**

- (1) Configure EINT line as the event mode;
- (2) Execute WFE instruction to make the core enter the sleep mode;
- (3) Generate an interrupt to wake up the core; when the CPU recovers from WFE, since the pending bit of corresponding event line is not set, it is unnecessary to clear the interrupt pending bit of corresponding peripheral or the NVIC interrupt channel pending bit.

### 8.2.3 External Interrupt and Event Line Mapping

Table 26 External Interrupt and Event Line Mapping

| External Interrupt and Event Channel Name | External Interrupt and Event Line No. |
|-------------------------------------------|---------------------------------------|
| PA0/PB0/PC0/PE0                           | EINT 0                                |
| PA1/PB1/PC1/PE1                           | EINT 1                                |
| ...                                       | ...                                   |
| PA15/PB15/PC15/PE15                       | EINT 15                               |
| PVD output                                | EINT 16                               |
| RTC Alarm event                           | EINT 17                               |
| USBD wake-up event                        | EINT 18                               |
| Reserved                                  | EINT 19                               |
| Reserved                                  | EINT 20                               |
| Reserved                                  | EINT 21                               |
| Reserved                                  | EINT 22                               |
| Reserved                                  | EINT 23                               |
| Reserved                                  | EINT 24                               |
| Reserved                                  | EINT 25                               |
| Reserved                                  | EINT 26                               |
| Reserved                                  | EINT 27                               |
| Reserved                                  | EINT 28                               |
| Reserved                                  | EINT 29                               |
| Reserved                                  | EINT 30                               |
| Reserved                                  | EINT 31                               |

## 8.3 Register Address Mapping

Table 27 External Interrupt/Event Controller Register Mapping

| Register name | Description                                     | Offset address |
|---------------|-------------------------------------------------|----------------|
| EINT_IMASK    | Interrupt mask register                         | 0x00           |
| EINT_EMASK    | Event mask register                             | 0x04           |
| EINT_RTEN     | Enable the rising edge to trigger the register  | 0x08           |
| EINT_FTEN     | Enable the falling edge to trigger the register | 0x0C           |
| EINT_SWINTE   | Software interrupt event register               | 0x10           |
| EINT_IPEND    | Interrupt pending register                      | 0x14           |

## 8.4 Register Functional Description

### 8.4.1 Interrupt mask register (EINT\_IMASK)

Offset address: 0x00

Reset value: 0x0000 0000

| Field | Name   | R/W | Description                                            |
|-------|--------|-----|--------------------------------------------------------|
| 18:0  | IMASKx | R/W | Interrupt Request Mask on Line x<br>0: Mask<br>1: Open |
| 31:19 |        |     | Reserved                                               |

#### 8.4.2 Event mask register (EINT\_EMASK)

Offset address: 0x04

Reset value: 0x0000 0000

| Field | Name   | R/W | Description                                        |
|-------|--------|-----|----------------------------------------------------|
| 18:0  | EMASKx | R/W | Event Request Mask on Line x<br>0: Mask<br>1: Open |
| 31:19 |        |     | Reserved                                           |

#### 8.4.3 Enable the rising edge trigger selection register (EINT\_RTEN)

Offset address: 0x08

Reset value: 0x0000 0000

| Field | Name  | R/W | Description                                                                                                  |
|-------|-------|-----|--------------------------------------------------------------------------------------------------------------|
| 18:0  | RTENx | R/W | Rising Trigger Event Enable of Line x<br>0: Disable (interrupt and event)<br>1: Enable (interrupt and event) |
| 31:19 |       |     | Reserved                                                                                                     |

Note: Since the external wake-up lines are edge triggered, there should be no burr signal on these lines; when writing EINT\_RTEN register, if the rising edge signal is on the external interrupt line, it will not be recognized and the set pending bit will not be set; in the same interrupt line, the rising edge trigger and falling edge trigger can be set at the same time.

#### 8.4.4 Enable the falling edge trigger selection register (EINT\_FTEN)

Offset address: 0x0C

Reset value: 0x0000 0000

| Field | Name  | R/W | Description                                                                                                   |
|-------|-------|-----|---------------------------------------------------------------------------------------------------------------|
| 18:0  | FTENx | R/W | Falling Trigger Event Enable of Line x<br>0: Disable (interrupt and event)<br>1: Enable (interrupt and event) |
| 31:19 |       |     | Reserved                                                                                                      |

Note: Since the external wake-up lines are edge triggered, there should be no burr signal on these lines; when writing EINT\_FTEN register, if the rising edge signal is on the external interrupt line, it will not be recognized and the set pending bit will not be set; in the same interrupt line, the rising edge trigger and falling edge trigger can be set at the same time.

#### 8.4.5 Software interrupt event register (EINT\_SWINTE)

Offset address: 0x10

Reset value: 0x0000 0000

| Field | Name     | R/W | Description                                                                                                                                                                                                                                                                                       |
|-------|----------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 18:0  | SWINTEX  | R/W | <p>Software Interrupt Event on Line x</p> <p>When this bit is 0, the pending bit of EINT_IPEND can be set by writing 1. If this interrupt is enabled in EINT_IMASK, then an interrupt will be generated.</p> <p>Note: Write 1 in corresponding bit of EINT_IPEND and this bit can be cleared.</p> |
| 31:19 | Reserved |     |                                                                                                                                                                                                                                                                                                   |

#### 8.4.6 Interrupt pending register (EINT\_IPEND)

Offset address: 0x14

Reset value: 0xXXXX XXXX

| Field | Name     | R/W   | Description                                                                                                                                                                                                                                                                                                                          |
|-------|----------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 18:0  | IPENDx   | RC_W1 | <p>Interrupt Pending Occur of Line x Flag</p> <p>Whether the selected trigger request occurs</p> <p>0: None</p> <p>1: Occurred</p> <p>This bit will be set when a selective edge trigger request occurs on the external interrupt line. It can be cleared by changing the polarity of edge detection or by writing 1 to the bit.</p> |
| 31:19 | Reserved |       |                                                                                                                                                                                                                                                                                                                                      |

## 9 Direct Memory Access (DMA)

### 9.1 Full Name and Abbreviation Description of Terms

Table 28 Full Name and Abbreviation Description of Terms

| Full name in English | English abbreviation |
|----------------------|----------------------|
| Global               | G                    |
| Transfer             | T                    |
| Half                 | H                    |
| Complete             | C                    |
| Error                | E                    |
| Channel              | CH                   |
| Circular             | CIR                  |
| Peripheral           | PER                  |
| Increment            | I                    |
| Memory               | M                    |
| Priority             | PRI                  |
| Number               | N                    |
| Address              | ADDR                 |

### 9.2 Introduction

DMA (Direct Memory Access) can realize high-speed data transmission between peripheral devices and memory or between memory and memory without CPU intervention, thus saving CPU resources for other operations.

The product has a DMA controller, with seven channels. Each channel can manage multiple DMA requests, but each channel can only respond to one DMA request at the same time. Each channel can set priority, and the arbiter can coordinate the priority of corresponding DMA requests of each DMA channel according to the priority of the channels.

### 9.3 Main Characteristics

- (1) DMA has seven channels
- (2) There are three data transmission modes: peripheral to memory, memory to peripheral, memory to memory
- (3) Each channel has a special hardware DMA request for connection
- (4) Support software priority and hardware priority when multiple requests occur at the same time
- (5) Each channel has three event flags and independent interrupts
- (6) Support circular transmission mode

(7) The number of data transmission is programmable, up to 65535

## 9.4 Functional Description

### 9.4.1 DMA Request

If the peripheral or memory needs to use DMA to transmit data, it is required to first send DMA request and wait for DMA approval before data transmission.

DMA has seven channels. Each channel is connected with different peripherals, and each channel has three event flags (DMA half transmission, DMA transmission completion and DMA transmission error). The logic of the three event flags may become a separate interrupt request, and they all support software triggering.

When multiple peripherals request the same channel, it is required to configure the corresponding register to turn on or off the request of each peripheral, so as to ensure that only one peripheral request can be turned on in a channel.

Table 29 DMA Request Mapping Table

| Peripheral | Channel 1 | Channel 2 | Channel 3           | Channel 4                         | Channel 5 | Channel 6             | Channel 7            |
|------------|-----------|-----------|---------------------|-----------------------------------|-----------|-----------------------|----------------------|
| TMR1       | —         | TMR1_CH1  | TMR1_CH2            | TMR1_CH4<br>TMR1_TRIG<br>TMR1_COM | TMR1_UP   | TMR1_CH3              | —                    |
| TMR2       | TMR2_CH3  | TMR2_UP   | —                   | —                                 | TMR2_CH1  | —                     | TMR2_CH2<br>TMR2_CH4 |
| TMR3       | —         | TMR3_CH3  | TMR3_CH4<br>TMR3_UP | —                                 | —         | TMR3_CH1<br>TMR3_TRIG | —                    |
| TMR4       | TMR4_CH1  | —         | —                   | TMR4_CH2                          | TMR4_CH3  | —                     | TMR4_UP              |
| ADC1       | ADC1      | —         | —                   | —                                 | —         | —                     | —                    |
| SPI        | —         | SPI1_RX   | SPI1_TX             | SPI_RX                            | SPI_TX    | —                     | —                    |
| USART      | —         | USART3_TX | USART3_RX           | USART1_TX                         | USART1_RX | USART2_RX             | USART2_TX            |
| I2C        | —         | —         | —                   | I2C2_TX                           | I2C2_RX   | I2C1_TX               | I2C1_RX              |
| QSPI       | —         | —         | —                   | QSPI_RX                           | QSPI_TX   | —                     | —                    |

### 9.4.2 DMA channel

#### 9.4.2.1 Transmission data are programmable

The data transmitted by DMA are programmable, up to 65535, and the transmission data bit width of peripherals and memory can be set by configuring PERSIZE bit and MEMSIZE bit of DMA\_CHCFGx register.

#### 9.4.2.2 Transmission width and alignment method are programmable

Programmable data transmission width DMA transmission operations:

Figure 8 Transmission Width with Source of 8bits and Target of 8bits



Figure 9 Transmission Width with Source of 8bits and Target of 16bits



Figure 10 Transmission Width with Source of 8bits and Target of 32bits



Figure 11 Transmission Width with Source of 32bits and Target of 8bits



Figure 12 Transmission Width with Source of 16bits and Target of 16bits



Figure 13 Transmission Width with Source of 16bits and Target of 32bits



Figure 14 Transmission Width with Source of 32bits and Target of 16bits



#### 9.4.2.3 Address setting

The transmission address supports two modes: fixed mode and pointer increment mode.

##### Transmission address pointer increment mode

The automatic pointer increment of peripheral and memory is completed through the PERIMODE bit and MIMODE bit of configuration register DMA\_CHCFGx. The next address to be transmitted is the one by adding the increment to the previous address. The increment depends on the selected data width.

#### 9.4.2.4 Transmission mode

There are two channel configuration modes: non-circular mode and circular mode.

##### Non-circular mode

When the data transmission is finished, the DMA operation will not be performed any more, and the new DMA transmission will be started. When the DMA channel is not working, the register DMA\_CHNDATAx will rewrite the transmission value.

##### Circular mode

After data transmission, the content of the register DMA\_CHNDATAx will be automatically reloaded to the previously configured value, and the peripheral address register DMA\_CHPADDRx and the memory address register DMA\_CHMADDRx will also be reloaded as the initial base address.

The configuration method is as follows:

- Set the CIRMODE bit of the configuration register DMA\_CHCFGx to 1 to turn on the circular mode;
- This mode is used to process continuous peripheral requests. When the number of data transmission becomes 0, it will automatically return to the initial value and continue DMA operation until the CIRMODE bit is cleared and the system exits the circular mode.

#### 9.4.2.5 DMA request priority setting

##### Arbitrator

When multiple DMA channel requests occur, an arbiter is needed to manage the response sequence. Management is divided into two stages: the first stage is software stage, which is divided into the highest, high, medium and low priority; the second stage is hardware stage, and under the condition of the same software priority, the lower the channel number is, the higher the priority is.

#### 9.4.2.6 Transmission direction

Support three directions: from memory to memory, from memory to peripheral, and from peripheral to memory.

If the write operation (target address) is performed on the memory, the memory includes internal SRAM, external RAM supported by EMMC (such as external SRAM, SDRAM) and NORFLASH; if the read operation (source address) is performed on the memory, the address includes internal FLASH, internal SRAM, RAM supported by EMMC, and NORFLASH.

Examples of "from memory to memory" configuration are as follows:

- The M2MMODE bit of the configuration register DMA\_CHCFGx is set to put the memory to the memory mode;
- The DMA operation in this mode is performed under the condition of no peripheral request. The CHEN bit of the configuration register DMA\_CHCFGx is set to 1, and after the channel is opened, the data transmission will start and when the transmission quantity register DMA\_CHNDATAx becomes 0, the transmission is over.

### 9.4.3 Interrupt

Each DMA channel has three types of interrupt events, which are half transmission (HT), transmission completion (TC) and transmission error (TE).

- (1) The interrupt event flag bit for half transmission is HTFLG, and the interrupt enable control bit is HTINTEN
- (2) The interrupt event flag bit for transmission completion is TCFLG, and the interrupt enable control bit is TCINTEN
- (3) The interrupt event flag bit for transmission error is TERRFLG, and the interrupt enable control bit is TERRINTEN

## 9.5 Register Address Mapping

Table 30 Register Address Mapping

| Register name | Description                                  | Offset address |
|---------------|----------------------------------------------|----------------|
| DMA_INTSTS    | DMA interrupt state register                 | 0x00           |
| DMA_INTFCLR   | DMA interrupt flag reset register            | 0x04           |
| DMA_CHCFGx    | DMA Channel x configuration register         | 0x08+20 x      |
| DMA_CHNDATAx  | DMA Channel x transmission quantity register | 0x0C+20 x      |
| DMA_CHPADDRx  | DMA Channel x peripheral address register    | 0x10+20 x      |
| DMA_CHMADDRx  | DMA Channel x memory address register        | 0x14+20 x      |

## 9.6 Register Functional Description

### 9.6.1 DMA interrupt state register (DMA\_INTSTS)

Offset address: 0x00

Reset value: 0x0000 0000

| Field                 | Name     | R/W | Description                                                                                                                                                                                                                                                                  |
|-----------------------|----------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 24,20,16,<br>12,8,4,0 | GINTFLGx | R   | Channel x Global Interrupt Occur Flag(x=1...7)<br>Indicate whether TC, HT or TE interrupt is generated on the channel; these bits are set to 1 by hardware; write 1 and clear on the corresponding bit of DMA_INTFCLR.<br>0: Not generate<br>1: Generate                     |
| 25,21,17,<br>13,9,5,1 | TCFLGx   | R   | Channel x All Transfer Complete Flag(x=1..7)<br>Indicate whether the transmission completion interrupt (TC) is generated on the channel; these bits are set to 1 by hardware; write 1 and clear on the corresponding bit of DMA_INTFCLR.<br>0: Not completed<br>1: Completed |

| Field                  | Name     | R/W | Description                                                                                                                                                                                                                                                           |
|------------------------|----------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 26,22,18,<br>14,10,6,2 | HTFLGx   | R   | Channel x Half Transfer Complete Flag(x=1..7)<br>Indicate whether the half transmission interrupt (HT) is generated on the channel; these bits are set to 1 by hardware; write 1 and clear on the corresponding bit of DMA_INTFCLR.<br>0: Not generate<br>1: Generate |
| 27,23,19,<br>15,11,7,3 | TERRFLGx | R   | Channel x Transfer Error Occur Flag(x=1..7)<br>Indicate whether the transmission error interrupt (TE) is generated on the channel; these bits are set to 1 by hardware; write 1 and clear on the corresponding bit of DMA_INTFCLR.<br>0: Not generate<br>1: Generate  |
| 31:28                  | Reserved |     |                                                                                                                                                                                                                                                                       |

### 9.6.2 DMA interrupt flag reset register (DMA\_INTFCLR)

Offset address: 0x04

Reset value: 0x0000 0000

| Field                      | Name                 | R/W | Description                                                                                                                                                                                        |
|----------------------------|----------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 24,20,16,12,<br>8,4,0      | GINTCLR <sub>x</sub> | R/W | Channel x Global Interrupt Occur Flag Clear(x=1..7)<br>Clear the corresponding GINTFLG, TCFLG, HTFLG and TERRFLG flags in the interrupt state register.<br>0: Invalid<br>1: Clear the GINTFLG flag |
| 25,21,<br>17,13,<br>9,5,1  | TCCLR <sub>x</sub>   | R/W | Channel x Transfer Complete Clear(x=1..7)<br>Clear the corresponding TCFLG flag in interrupt state register.<br>0: Invalid<br>1: Clear the TCFLG flag                                              |
| 26,22<br>18,14,<br>10,6,2  | HTCLR <sub>x</sub>   | R/W | Channel x Half Transfer Complete Clear(x=1..7)<br>Clear the corresponding HTFLG flag in interrupt state register.<br>0: Invalid<br>1: Clear the HTFLG flag                                         |
| 27,23,<br>19,15,<br>11,7,3 | TERRCLR <sub>x</sub> | R/W | Channel x Transfer Error Occur Clear(x=1..7)<br>Clear the corresponding TERRFLG flag in interrupt state register.<br>0: Invalid<br>1: Clear the TERRFLG flag                                       |
| 31:28                      | Reserved             |     |                                                                                                                                                                                                    |

### 9.6.3 DMA Channel x configuration register (DMA\_CHCFG<sub>x</sub>) (x=1..7)

Offset address: 0x08+20 x (channel number-1)

Reset value: 0x0000 0000

| Field | Name    | R/W | Description                                                        |
|-------|---------|-----|--------------------------------------------------------------------|
| 0     | CHEN    | R/W | DMA Channel Enable<br>0: Disable<br>1: Enable                      |
| 1     | TCINTEN | R/W | All Transfer Complete Interrupt Enable<br>0: Disable<br>1: Enable  |
| 2     | HTINTEN | R/W | Half Transfer Complete Interrupt Enable<br>0: Disable<br>1: Enable |

| Field | Name      | R/W | Description                                                                                                                                                    |
|-------|-----------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3     | TERRINTEN | R/W | Transfer Error Occur Interrupt Enable<br>0: Disable<br>1: Enable                                                                                               |
| 4     | DIRCFG    | R/W | Data Transfer Direction Configure<br>0: Read from peripheral to memory<br>1: Read from memory to peripheral                                                    |
| 5     | CIRMODE   | R/W | Circular Mode Enable<br>0: Disable<br>1: Enable                                                                                                                |
| 6     | PERIMODE  | R/W | Peripheral Address Increment Mode Enable<br>0: Disable<br>1: Enable                                                                                            |
| 7     | MIMODE    | R/W | Memory Address Increment Mode Enable<br>0: Disable<br>1: Enable                                                                                                |
| 9:8   | PERSIZE   | R/W | Peripheral Data Size Configure<br>00: 8 bits<br>01: 16 bits<br>10: 32 bits<br>11: Reserved<br>Note: It cannot be configured to 00 when I2C3/4 is used by user. |
| 11:10 | MEMSIZE   | R/W | Memory Data Size Configure<br>00: 8 bits<br>01: 16 bits<br>10: 32 bits<br>11: Reserved<br>Note: It cannot be configured to 00 when I2C3/4 is used by user.     |
| 13:12 | CHPL      | R/W | Channel Priority Level Configure<br>00: Low<br>01: Medium<br>10: High<br>11: Highest                                                                           |
| 14    | M2MMODE   | R/W | Memory to Memory Mode Enable<br>0: Disable<br>1: Enable                                                                                                        |
| 31:15 |           |     | Reserved                                                                                                                                                       |

#### 9.6.4 DMA Channel x transmission quantity register (DMA\_CHNDATAx) (x=1...7)

Offset address: 0x0C+20 x (channel number-1)  
Reset value: 0x0000 0000

| Field | Name     | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------|----------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0  | NDATAT   | R/W | <p>Number of Data to Transfer Setup<br/>This register indicates the number of bytes to be transmitted. The number of data transmission ranges from 0 to 65535.</p> <p>This register can only be written when the channel is not working; once the channel is enabled, the register will be read-only, indicating the number of remaining bytes to be transmitted.</p> <p>The register will decrease after each DMA is transmitted; when the data transmission is completed, the register will change to 0, or when the channel is configured to auto reload mode, it will be automatically reloaded to the previously configured value; if the register is 0, data transmission will not occur regardless of whether the channel is turned on or not.</p> |
| 31:16 | Reserved |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

### 9.6.5 DMA Channel x peripheral address register (DMA\_CHPADDRx) (x=1...7)

Offset address: 0x10+20 x (channel number-1)

Reset value: 0x0000 0000

This register cannot be written when the channel is turned on (CHEN=1 for DMA\_CHCFGx).

| Field | Name    | R/W | Description                                                                                                                                                                                                                                                                                                                   |
|-------|---------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0  | PERADDR | R/W | <p>Peripheral Basic Address Setup<br/>When PERSIZE= '01' (16 bits) and PERADDR[0] bit is not used, it will be aligned with 16-bit address automatically during transmission.<br/>When PERSIZE= '10' (32 bits) and PERADDR[1:0] bit is not used, it will be aligned with 32-bit address automatically during transmission.</p> |

### 9.6.6 DMA Channel x memory address register (DMA\_CHMADDRx) (x=1...7)

Offset address: 0x14+20 x (channel number-1)

Reset value: 0x0000 0000

This register cannot be written when the channel is turned on (CHEN=1 for DMA\_CHCFGx).

| Field | Name    | R/W | Description                                                                                                                                                                                                                                                                                                               |
|-------|---------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0  | MEMADDR | R/W | <p>Memory Basic Address Setup<br/>When MEMSIZE= '01' (16 bits) and MEMADDR[0] bit is not used, it will be aligned with 16-bit address automatically during transmission.<br/>When MEMSIZE= '10' (32 bits) and MEMADDR[1:0] bit is not used, it will be aligned with 32-bit address automatically during transmission.</p> |

## 10 Debug MCU (DBGMCU)

### 10.1 Full Name and Abbreviation Description of Terms

Table 31 Full Name and Abbreviation Description of Terms

| Full name in English        | English abbreviation |
|-----------------------------|----------------------|
| Frame Clock                 | FCLK                 |
| Serial Wire/JTAG Debug Port | SWJ-DP               |

### 10.2 Introduction

APM32F10x MCU series uses Arm® Cortex®-M3 core, and Arm® Cortex®-M3 core includes hardware debug module and supports complex debug operation. During debugging, the module can make the running core stop at breakpoint, and achieve the effect of querying the internal state of the core and the external state of the system, and after the query is completed, the core and peripheral operation can be restored to continue to execute the program.

Two debug interfaces are supported:

- Serial interface
- JTAG debug interface

Note: The hardware debug interface included in Arm® Cortex®-M3 core is subset of Arm CoreSight development tool set. Please refer to Cortex®-M3 (Version r1p1) technical reference manual (TRM) and CoreSight development tool set (Version r1p0) TRM for more information about debug function of Arm® Cortex®-M3 core.

### 10.3 Main Characteristics

- (1) Replace the core to access AHB bus matrix
- (2) Flexible debug pin assignment
- (3) MCU debug box (support low-power mode, control peripheral clock, etc.)

Figure 15 APM32F10xxx Level and Arm® Cortex® -M3 Level Debugging Block Diagram



## 10.4 Functional Description

### 10.4.1 Debug Pin Function Configuration

- (1) Realize the on-line programming and debugging of the chip
- (2) Using KEIL/IAR and other software to achieve on-line debugging, downloading and programming
- (3) Flexible implementation of production of off-line programmer

Table 32 Pin Function Configuration

| SWJ-CFG[2:0] | Configured as dedicated pin for debugging           | I/O port assignment of SWJ interface |                 |           |           |            |
|--------------|-----------------------------------------------------|--------------------------------------|-----------------|-----------|-----------|------------|
|              |                                                     | PA13/JTMS/SWDIO                      | PA14/JTCK/SWCLK | PA15/JTDI | PB3/JTDO  | PB4/JNTRST |
| Others       | Disable                                             | Reserved                             |                 |           |           |            |
| 100          | Both JTAG-DP interface and SW-DP interface disabled | Reserved                             |                 |           |           |            |
| 010          | JTAG-DP interface disabled, SW-DP interface enabled | Dedicated                            | Dedicated       | Reserved  |           |            |
| 001          | All SWJ pins (JTAG-DP+SW-DP)<br>Except JNTRST pin   | Dedicated                            | Dedicated       | Dedicated | Dedicated | Reserved   |
| 000          | All SWJ pins (JTAG-DP+SW-DP)<br>Reset state         | Dedicated                            | Dedicated       | Dedicated | Dedicated | Dedicated  |

Note: The items that cannot be tested in running mode can be observed and tested in detail

### 10.4.2 ID Code

#### 10.4.2.1 MCU device ID code

APM32F MCU series includes a MCU ID code. It can be accessed with JTAG or SW debug interface or user code.

#### 10.4.2.2 Boundary scan TAP

##### JTAG ID code

The boundary scan TAP of APM32F MCU series integrates JTAG ID code.

#### 10.4.2.3 Arm® Cortex®-M3 TAP

Arm® Cortex®-M3 TAP has a JTAG ID code, which is 0x4BA00477.

#### 10.4.2.4 Arm® Cortex®-M3 JEDEC-106 ID code

Arm® Cortex®-M3 has a JEDEC-106 ID code. It is located in 4KB ROM table in which the internal PPB bus address is 0xE00FF000\_0xE00FFFFF.

## 10.5 Register Address Mapping

Table 33 Register Address Mapping

| Register name | Description                      | Offset address |
|---------------|----------------------------------|----------------|
| DBGMCU_IDCODE | Device ID register               | 0xE004 2000    |
| DBGMCU_CFG    | Debug MCU configuration register | 0xE004 2004    |

## 10.6 Register Functional Description

### 10.6.1 Device ID register (DBGMCU\_IDCODE)

Address: 0xE004 2000

Only support 32-bit access

Reset value: 0xXXXX XXXX, X=undefined bit

| Field | Name | R/W | Description                                                                                                                                                                                                                      |
|-------|------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11:0  | EQR  | R   | Equipment Recognition<br>For APM32F10x MCU series:<br>APM32F103x4x6x8xB series products: 0x410;<br>The debugger/programming tool identifies chips by QR (11:0).                                                                  |
| 15:12 |      |     | Reserved                                                                                                                                                                                                                         |
| 31:16 | WVR  | R   | Wafer Version Recognition<br>For APM32F10x MCU series:<br>APM32F103x4x6x8xB series products:<br>Revision A=0x0000;<br>Revision B=0x2000;<br>Revision Z=0x2001;<br>Revision Y=0x2003;<br>This domain identifies wafer information |

### 10.6.2 Debug MCU configuration register (DBGMCU\_CFG)

This register can configure MCU in debug mode. It includes the counter supporting timer and watchdog, low-power mode, CAN communication and assignment tracking pin.

address: 0xE004 2004

Only support 32-bit access

Reset value: 0x0000 0000 (not affected by system reset, only power-on reset)

| Field | Name            | R/W | Description                                                                                                                        |
|-------|-----------------|-----|------------------------------------------------------------------------------------------------------------------------------------|
| 0     | SLEEP_CLK_STS   | R/W | Configure clock status when MCU is debugged in sleep mode<br>0: FCLK ON, HCLK OFF<br>1: FCLK ON, HCLK ON, provided by system clock |
| 1     | STOP_CLK_STS    | R/W | Configure clock status when MCU is debugged in stop mode<br>0: FCLK OFF, HCLK OFF<br>1: FCLK ON, HCLK ON, provided by HSICLK       |
| 2     | STANDBY_CLK_STS | R/W | Configure clock status when MCU is debugged in standby mode<br>0: FCLK OFF, HCLK OFF<br>1: FCLK ON, HCLK ON, provided by HSICLK    |
| 4:3   |                 |     | Reserved                                                                                                                           |

| Field | Name                      | R/W | Description                                                                                                                                                                                                                                                            |
|-------|---------------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5     | TRACE_IOEN                | R/W | Trace Debug Pin Enable<br>0: Tracking debug pin disabled<br>1: Tracking debug pin enabled                                                                                                                                                                              |
| 7:6   | TRACE_MODE                | R/W | Trace Debug Pin Mode Configure<br>Tracking debug pin mode can be configured only when TRACE_IOEN=1:<br>00: Asynchronous mode<br>01: Synchronous mode, the data length is 1<br>10: Synchronous mode, the data length is 2<br>11: Synchronous mode, the data length is 4 |
| 8     | IWDT_STS                  | R/W | Configure Independent Watchdog Work Status When Core Is in Halted<br>0: Work normally<br>1: Stop working                                                                                                                                                               |
| 9     | WWDT_STS                  | R/W | Configure Window Watchdog Work Status When Core Is in Halted<br>0: Work normally<br>1: Stop working                                                                                                                                                                    |
| 13:10 | TMRx_STS                  | R/W | Configure Timer x Work Status When Core Is in Halted (x=1...4)<br>0: Work normally<br>1: Stop working                                                                                                                                                                  |
| 14    | CAN1_STS                  | R/W | Configure CAN1 Work Status When Core Is in Halted<br>0: Work normally<br>1: Freeze the receiver transmitter of CAN1                                                                                                                                                    |
| 15    | I2C1_SMBUS_TIMEOUT_UT_STS | R/W | Configure I2C1_SMBUS_TIMEOUT Work Status When Core Is in Halted<br>0: Work normally<br>1: Freeze the timeout mode of SMBUS                                                                                                                                             |
| 16    | I2C2_SMBUS_TIMEOUT_UT_STS | R/W | Configure I2C2_SMBUS_TIMEOUT Work Status When Core Is in Halted<br>0: Work normally<br>1: Freeze the timeout mode of SMBUS                                                                                                                                             |
| 20:17 |                           |     | Reserved                                                                                                                                                                                                                                                               |
| 21    | CAN2_STS                  | R/W | Configure CAN2 Work Status When Core Is in Halted<br>0: Work normally<br>1: Freeze the receiver transmitter of CAN2                                                                                                                                                    |
| 31:22 |                           |     | Reserved                                                                                                                                                                                                                                                               |

## 11 General-Purpose Input/Output Pin (GPIO)

### 11.1 Full Name and Abbreviation Description of Terms

Table 34 Full Name and Abbreviation Description of Terms

| Full name in English                | English abbreviation |
|-------------------------------------|----------------------|
| P-channel Metal Oxide Semiconductor | P-MOS                |
| N-channel Metal Oxide Semiconductor | N-MOS                |

### 11.2 Main Characteristics

GPIO port can configure the following functions through 32-bit configuration register (GPIOx\_CFGLOW/GPIOx\_CFGHIG) and two 32-bit data registers GPIOx\_IDATA/GPIOx\_ODATA):

- (1) Input mode
  - Analog input
  - Floating input
  - Pull-up input
  - Pull-down input
- (2) Output mode
  - Push-pull output
  - Open-drain output
  - Configurable maximum output rate
- (3) Multiplexing mode
  - Push-pull multiplexing function
  - Open-drain multiplexing function
- (4) GPIO can be used as external interrupt/wake-up line
- (5) Support locking I/O configuration function

## 11.3 Structure Block Diagram

Figure 16 GPIO Structure Block Diagram



Figure 17 5V GPIO-compatible Structure Block Diagram



(1) V<sub>DD\_FT</sub> is different from V<sub>DD</sub>, and V<sub>DD\_FT</sub> is special for FT GPIO pin.

## 11.4 Functional Description

Each pin of GPIO can be configured as pull-up, pull-down, floating and analog input, or push-pull/open-drain output input mode and multiplexing function through software. All GPIO interfaces have external interrupt capability.

### 11.4.1 IO Status during Reset and just after Reset

If the multiplexing function is not enabled during and after GPIO reset, the I/O port will be configured as floating input mode, and in such case the pull-up/pull-down resistor is disabled in input mode. After reset, the JTAG pin is put in the

input pull-up or pull-down mode, and the specific configuration is as follows:

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

### 11.4.2 Input Mode

In the input mode, it can be set as pull-up, pull-down, floating and analog input.

When GPIO is configured as input mode, all GPIO pins have internal weak pull-up and weak pull-down resistors, which can be activated or disconnected.

#### Pull-up, pull-down, and floating modes

In (pull-up, pull-down, floating) input mode

- Schmitt trigger is opened
- Disable output buffer
- Connect weak pull-up and pull-down resistors according to different input configurations
- The input data register GPIOx\_IDATA captures the data on I/O pin in each APB2 clock cycle
- Read I/O state through the input data register GPIOx\_IDATA

The initial level state of the floating input mode is uncertain and is easy to be disturbed by the outside; when connecting the equipment, it is determined by the external input level (except for the very high impedance).

The initial level state of pull-up/pull-down input mode is high level if pull-up, and low level if pull-down; when connecting the equipment, it is determined by the external input level and load impedance.

#### Analog input mode

In analog input mode

- Disable output buffer
- The input of Schmitt trigger is disabled, and the output value of Schmitt trigger is forced to be 0
- Weak pull-up and pull-down resistors are disabled
- The value of port input state register is 0

Figure 18 Input Mode Structure



### 11.4.3 Output Mode

In the output mode, it can be set as push-pull output and open-drain output.

When GPIO is configured as the output pin, the output speed of the port can be configured and the output drive mode (push-pull / open-drain) can be selected.

In output mode

- Schmitt trigger is opened,
- Activate output buffer
- Weak pull-up and pull-down resistors are disabled
- Push-pull mode:
  - Double MOS transistor works by turns and the output data register can control the high and low level of I/O output
  - Read the finally written value through the output data register GPIOx\_ODATA
- Open-drain mode:
  - Only N-MOS works, and the output data register can control I/O output high resistance state or low level
  - Read the actual I/O state through the input data register GPIOx\_IDATA

Figure 19 I/O Structure in Output Mode



#### 11.4.4 Multiplexing Mode

In multiplexing mode, it can be set as push-pull multiplexing and open-drain multiplexing

In push-pull/open-drain multiplexed mode

- Open the output buffer
- Output buffer is driven by peripheral
- Activate schmitt trigger input
- Weak pull-up and pull-down resistors are disabled
- The data on the I/O pin is sampled in each APB2 clock cycle and stored in the port input state register
- In open-drain mode, the actual state of I/O can be read through input data register GPIOx\_IDATA
- In push-pull mode, the last written value is read through output data register GPIOx\_ODATA

Figure 20 I/O Structure in Multiplexing Mode



#### 11.4.5 External Interrupt/Wake-up Line

All GPIO ports have external interrupt function. If you want to use external interrupt line, the port must be configured as input mode.

#### 11.4.6 Bit Set and Bit Clear

Software does not need to disable interrupt when programming some bits of GPIOx\_IDATA. (The function of changing one or more bits in APB2 write operation can be implemented by setting the bit to be changed in GPIOx\_BSC and BSC register to 1.

#### 11.4.7 GPIO Locking Function

Locking function can be used in power driver module. The locking mechanism of GPIO can protect the configuration of I/O port. I/O configuration can be locked by configuring the lock register (GPIOx\_LOCK). When a port bit executes the locking program, the configuration of port bit cannot be modified before the next reset.

### 11.5 Register Address Mapping

Table 35 GPIO Register Address Mapping

| Register name | Description                      | Offset address |
|---------------|----------------------------------|----------------|
| GPIOx_CFGLOW  | Port configuration low register  | 0x00           |
| GPIOx_CFGHIG  | Port configuration high register | 0x04           |
| GPIOx_IDATA   | Port input data register         | 0x08           |
| GPIOx_ODATA   | Port output data register        | 0x0C           |
| GPIOx_BSC     | Port bit set/clear register      | 0x10           |
| GPIOx_BC      | Port bit clear register          | 0x14           |
| GPIOx_LOCK    | Port configuration lock register | 0x18           |

## 11.6 Register Functional Description

These peripheral registers must be operated by word (32 bits).

### 11.6.1 Low 8-bit port configuration register (GPIOx\_CFGLOW) (x=A..E)

Offset address: 0x00

Reset value: 0x4444 4444

| Field                                                            | Name       | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------------------------------------------------------------|------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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] | R/W | Port x Pin y Mode Configure (y=0...7)<br>00: Input mode (state after reset)<br>01: Output mode, the maximum output speed is 10MNz<br>10: Output mode, the maximum output speed is 2MNz<br>11: Output mode, the maximum output speed is 50MNz<br>See the data manual for the definition of maximum output speed.                                                                                                                  |
| 31:30<br>27:26<br>23:22<br>19:18<br>15:14<br>11:10<br>7:6<br>3:2 | CFGy[1:0]  | R/W | Port x Pin y Function Configure (y=0...7)<br>In input (MODE[1:0]=00) mode:<br>00: Analog input mode<br>01: Floating input mode (state after reset)<br>10: Pull-up/Pull-down input mode<br>11: Reserved<br>In output mode (MODE[1:0]>00):<br>00: General push-pull output mode<br>01: General open-drain output mode<br>10: Push-pull output mode of multiplexing function<br>11: Open-drain output mode of multiplexing function |

### 11.6.2 High 8-bit port configuration register (GPIOx\_CFGLOW) (x=A..E)

Offset address: 0x04

Reset value: 0x4444 4444

| Field                                                            | Name       | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------------------------------------------------------------|------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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] | R/W | Port x Pin y Mode Configure (y=8...15)<br>00: Input mode (state after reset)<br>01: Output mode, the maximum output speed is 10MNz<br>10: Output mode, the maximum output speed is 2MNz<br>11: Output mode, the maximum output speed is 50MNz<br>See the data manual for the definition of maximum output speed.                                                                                                                  |
| 31:30<br>27:26<br>23:22<br>19:18<br>15:14<br>11:10<br>7:6<br>3:2 | CFGy[1:0]  | R/W | Port x Pin y Function Configure (y=8...15)<br>In input (MODE[1:0]=00) mode:<br>00: Analog input mode<br>01: Floating input mode (state after reset)<br>10: Pull-up/Pull-down input mode<br>11: Reserved<br>In output mode (MODE[1:0]>00):<br>00: General push-pull output mode<br>01: General open-drain output mode<br>10: Push-pull output mode of multiplexing function<br>11: Open-drain output mode of multiplexing function |

### 11.6.3 Port input data register (GPIOx\_IDATA) (x=A...E)

Offset address: 0x08

Reset value: 0x0000 XXXX

| Field | Name     | R/W | Description                                                                                                                                                                        |
|-------|----------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0  | IDATAy   | R   | Portx Pin y Input Data (y=0...15)<br>These bits are read-only and can be read out only in the form of word.<br>0: Input signal is at low level<br>1: Input signal is at high level |
| 31:16 | Reserved |     |                                                                                                                                                                                    |

### 11.6.4 Port output data register (GPIOx\_ODATA) (x=A..E)

Offset address: 0x0C

Reset value: 0x0000 0000

| Field | Name     | R/W | Description                                                                                                                                                                                                                                                             |
|-------|----------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0  | ODATAy   | R/W | Portx Pin y Output Data (y=0...15)<br>These bits are readable and writable and can be operated only in the form of word.<br>0: Output low level<br>1: Output high level<br>Note: For PIOx_BSC (x=A...E), each ODATAy bit can be set/cleared independently respectively. |
| 31:16 | Reserved |     |                                                                                                                                                                                                                                                                         |

### 11.6.5 Port bit set/clear register (GPIOx\_BSC) (x=A..E)

Offset address: 0x10

Reset value: 0x0000 0000

This register is write-only and can be accessed only in the form of word.

| Field | Name | R/W | Description                                                                                                                                                                                                                                   |
|-------|------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0  | BSy  | W   | Port x Pin y Set bit y (y=0...15)<br>These bits are used to affect the corresponding ODATAy bits.<br>0: No effect<br>1: Set the corresponding ODATAy bits to 1                                                                                |
| 31:16 | BCy  | W   | Port x Pin y Clear bit (y=0...15)<br>These bits are used to affect the corresponding ODATAy bits.<br>0: No effect<br>1: Corresponding ODATAy bit is cleared<br>Note: BSy bit will work if the corresponding bits of both BSy and BCy are set. |

### 11.6.6 Port bit clear register (GPIOx\_BC) (x=A..E)

Offset address: 0x14

Reset value: 0x0000 0000

| Field | Name     | R/W | Description                                                                                                                                                                                                                              |
|-------|----------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0  | BCy      | W   | Port x Pin y Clear bit y (y=0...15)<br>These bits are used to affect the corresponding ODATAy bits.<br>0: No effect<br>1: Corresponding ODATAy bit is cleared<br>These bits are write-only and can be accessed only in the form of word. |
| 31:16 | Reserved |     |                                                                                                                                                                                                                                          |

### 11.6.7 Port configuration lock register (GPIOx\_LOCK) (x=A...E)

This register protects the configuration of GPIO from being modified by mistake during the running of the program. If the GPIO configuration is modified again, it can be modified only after the system is reset. When configuring GPIO locking function, it is necessary to write the specified sequence to the register to start the GPIO locking function.

Offset address: 0x18

Reset value: 0x0000 0000

| Field | Name     | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------|----------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0  | LOCKy    | R/W | <p>Port x Pin y Lock bit y Configure (y=0...15)<br/>           These bits decide whether to lock the port configuration.<br/>           0: The configuration of Port x Pin y is not locked<br/>           1: The configuration of Port x Pin y is locked<br/>           These bits can be read and written, but can only be written when LOCKKEY=0.</p>                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 16    | LOCKKEY  | R/W | <p>Lock key value<br/>           0: Not activated<br/>           1: Lock protection activated; GPIOx_LOCK register is locked before the system is reset next time<br/>           This bit can be read out at any time, and it can be written into the sequence modification through the lock key<br/>           Sequence of write lock key value:<br/>           Write 1<br/>           Write 0<br/>           Write 1<br/>           Read 0<br/>           Read 1<br/>           Read 1 (the last read can be ignored, but can be used to confirm that the lock key has been activated.)<br/>           Note: In the lock key value sequence, the value of LOCKy cannot be changed, and no error (e.g. sequence error, read error) can activate the lock protection.</p> |
| 31:17 | Reserved |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

## 12 Alternate Function Input/Output Pin (AFIO)

### 12.1 Introduction

In addition to the general I/O function, the I/O port can also be used as the interface of various peripheral functions. In order to make full use of the peripheral I/O pins of the product, the product supports the multiplexing function. It can not only realize multiple functions on the same pin (only one function can be realized at the same time), but also remap a certain function to other I/O (the originally supported function is no longer supported).

### 12.2 Functional Description

#### 12.2.1 Alternate Function of I/O Pin

In order to make full use of peripheral I/O pins, some multiplexing functions can be remapped to other idle pins to maximize the utilization of pin resources.

Table 36 Corresponding Port Configuration of Multiplexing Function

| Multiplexing function               | Configure for port bit configuration register                                                                 |
|-------------------------------------|---------------------------------------------------------------------------------------------------------------|
| Multiplexing input function         | Configure as input mode and the input pin must be driven externally                                           |
| Multiplexing output function        | Configure as multiplexing function output mode                                                                |
| Bidirectional multiplexing function | Configure as multiplexing function output function, and the input driver is configured as floating input mode |

Note:

- (1) Through the GPIO controller programming, use the software to simulate the multiplexing function input pin, then the port is set to the multiplexing function output mode, and the pin is driven by software through the GPIO controller.
- (2) When the multiplexing function is output, the pin is disconnected from the output register and connected with the output signal of the on-chip peripheral. If the peripheral is not activated after connection, the output of the pin will be uncertain.

##### 12.2.1.1 Input mode configuration

When I/O port is used as input mode of multiplexing function, except that the weak pull-up and pull-down resistors are disabled, the port configuration is the same as that of general input function.

See corresponding chapters in GPIO for details of corresponding mode configuration.

##### 12.2.1.2 Output mode configuration

When the I/O port is used as the output mode of multiplexing function (push-pull or open-drain), like the general output function, the output mode can be set as push-pull output and open-drain output, but the output buffer is driven by the signal of the built-in peripheral.

See corresponding chapters in GPIO for details of corresponding mode configuration.

Note: When software simulates multiplexing function input pin, the I/O port should be configured as multiplexing function output mode.

##### 12.2.1.3 Bidirectional multiplexing function configuration

When bidirectional multiplexing function is used, the I/O port must be configured

as multiplexing function output mode (push-pull or open-drain), while the input driver should be configured as floating input mode.

See corresponding chapters in GPIO for details of corresponding mode configuration.

### 12.2.2 Peripheral Pin Configuration

At this time, since the peripheral pin may have different functions, the I/O port configuration of the pin is different.

Table 37 TMR Pin Configuration

| TMR pin      | Configure                      | I/O port configuration        |
|--------------|--------------------------------|-------------------------------|
| TMR1_CHx     | Input capture channel x        | Floating input                |
|              | Output comparison channel x    | Push-pull multiplexing output |
| TMR1_CHxN    | Complementary output channel x | Push-pull multiplexing output |
| TMR1_BKIN    | Braking input                  | Floating input                |
| TMR1_ETR     | External trigger clock input   | Floating output               |
| TMR2/3/4_CHx | Input capture channel x        | Floating input                |
|              | Output comparison channel x    | Push-pull multiplexing output |
| TMR2/3/4_ETR | External trigger clock input   | Floating input                |

Table 38 USART Pin Configuration

| USRAT pin  | Configure                    | I/O port configuration          |
|------------|------------------------------|---------------------------------|
| USRATx_TX  | Full duplex mode             | Push-pull multiplexing output   |
|            | Half duplex synchronous mode | Push-pull multiplexing output   |
| USARTx_RX  | Full duplex mode             | Floating input or pull-up input |
|            | Half duplex synchronous mode | Unused, can be used as GPIO     |
| USARTx_CK  | Synchronous mode             | Push-pull multiplexing output   |
| USARTx_RTS | Hardware flow control        | Push-pull multiplexing output   |
| USARTx_CTS | Hardware flow control        | Floating input or pull-up input |

Table 39 SPI Pin Configuration

| SPI pin   | Configure                                   | I/O port configuration          |
|-----------|---------------------------------------------|---------------------------------|
| SPIx_SCK  | Master mode                                 | Push-pull multiplexing output   |
|           | Slave mode                                  | Floating input                  |
| SPIx_MOSI | Full duplex mode/master mode                | Push-pull multiplexing output   |
|           | Full duplex mode/slave mode                 | Floating input or pull-up input |
|           | Simple bidirectional data cable/master mode | Push-pull multiplexing output   |
|           | Simple bidirectional data cable/slave mode  | Unused, can be used as GPIO     |
| SPIx_MISO | Full duplex mode/master mode                | Floating input or pull-up input |
|           | Full duplex mode/slave mode                 | Push-pull multiplexing output   |

| SPI pin  | Configure                                   | I/O port configuration                             |
|----------|---------------------------------------------|----------------------------------------------------|
|          | Simple bidirectional data cable/master mode | Unused, can be used as GPIO                        |
|          | Simple bidirectional data cable/slave mode  | Push-pull multiplexing output                      |
| SPIx_NSS | Hardware master/save mode                   | Floating input or pull-up input or pull-down input |
|          | Hardware master mode/NSS output enable      | Push-pull multiplexing output                      |
|          | Software mode                               | Unused, can be used as GPIO                        |

Table 40 I2S Pin Configuration

| I2S pin  | Configure   | I/O port configuration                             |
|----------|-------------|----------------------------------------------------|
| I2Sx_WS  | Master mode | Push-pull multiplexing output                      |
|          | Slave mode  | Floating input                                     |
| I2Sx_CK  | Master mode | Push-pull multiplexing output                      |
|          | Slave mode  | Floating input                                     |
| I2Sx_SD  | Transmitter | Push-pull multiplexing output                      |
|          | Receiver    | Floating input or pull-up input or pull-down input |
| I2Sx_MCK | Master mode | Push-pull multiplexing output                      |
|          | Slave mode  | Unused, can be used as GPIO                        |

Table 41 I2C Pin Configuration

| I2C pin  | Configure | I/O port configuration         |
|----------|-----------|--------------------------------|
| I2Cx_SCL | I2C clock | Open-drain multiplexing output |
| I2Cx_SDA | I2C data  | Open-drain multiplexing output |

Table 42 CAN Pin Configuration

| CAN pin | I/O port configuration          |
|---------|---------------------------------|
| CAN_TX  | Push-pull multiplexing output   |
| CAN_RX  | Floating input or pull-up input |

Table 43 USBD Pin Configuration

| USBD pin        | I/O port configuration                                                                                              |
|-----------------|---------------------------------------------------------------------------------------------------------------------|
| USBD_DM/USBD_DP | After the USBD module is enabled, the pin will be automatically connected to the internal USBD transmitter receiver |

This table is only applicable to small-capacity, medium-capacity and large-capacity products.

Table 44 SDIO Pin Configuration

| SDIO pin    | I/O port configuration        |
|-------------|-------------------------------|
| SDIO_CK     | Push-pull multiplexing output |
| SDIO_CMD    | Push-pull multiplexing output |
| SDIO[D7:D0] | Push-pull multiplexing output |

Table 45 ADC/DAC Pin Configuration

| ADC/DAC pin | I/O port configuration |
|-------------|------------------------|
| ADC/DAC     | Analog input           |

### 12.2.3 Remapping Function Configuration

Generally speaking, after the system reset, the pin will be given a default function; then if the user needs to multiplex other functions of the pin, as long as the peripheral is enabled, the multiplexing function can be activated. However, in addition that some peripheral functions need to be enabled, software programming is also needed to map the signal to the port, that is, assign the pin address, so that the peripheral function can be used in the pin.

The multiplexing function and remapping address table of pins are shown in the data manual.

#### 12.2.3.1 OSC32\_IN (OUT) pin is configured as GPIO

When not entering the standby mode or V<sub>DD</sub> is not used for power supply, when LSECLK oscillator is closed, the pin OSC32\_IN/OSC32\_OUT can be used as general I/O port PC14/PC15, namely, LSECLK function is prior to general I/O function.

#### 12.2.3.2 OSC\_IN (OUT) pin is configured as GPIO

In package products with less than 100 pins, the user can set AFIO\_REMAP1/2 (multiplexing remapping and debug I/O configuration register) to realize the remapping of general I/O PD0/PD1 to external oscillator pin OSC\_IN/OSC\_OUT. Then PD0 and PD1 cannot be used to generate external interrupt time.

## 12.3 Register Address Mapping

Table 46 AFIO Register Address Mapping

| Register name | Description                                     | Offset address |
|---------------|-------------------------------------------------|----------------|
| AFIO_EVCTRL   | Event control register                          | 0x00           |
| AFIO_REMAP1   | Multiplexing remapping configuration register 1 | 0x04           |
| AFIO_EINTSEL1 | External interrupt configuration register 1     | 0x08           |
| AFIO_EINTSEL2 | External interrupt configuration register 2     | 0x0C           |
| AFIO_EINTSEL3 | External interrupt configuration register 3     | 0x10           |
| AFIO_EINTSEL4 | External interrupt configuration register 4     | 0x14           |
| AFIO_REMAP2   | Multiplexing remapping configuration register 2 | 0x18           |

## 12.4 Register Functional Description

For the register AFIO\_EVCTRL, before read and write operation of AFIO\_REMAP1/2 and AFIO\_EINTSELx, AFIO clock shall be opened first. APB2 peripheral clock enable register (RCM\_APB2CLKEN). These peripheral registers must be operated by word (32 bits).

#### 12.4.1 Event control register (AFIO\_EVCTRL)

Offset address: 0x00

Reset value: 0x0000 0000

| Field | Name     | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------|----------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0   | PINSEL   | R/W | Portx Piny Select(x=A...E) (y=0...15)<br>Select the pin for outputting EVENTOUT signal of the core.<br>0000: Select Px0<br>0001: Select Px1<br>0010: Select Px2<br>0011: Select Px3<br>0100: Select Px4<br>0101: Select Px5<br>0110: Select Px6<br>0111: Select Px7<br>1000: Select Px8<br>1001: Select Px9<br>1010: Select Px10<br>1011: Select Px11<br>1100: Select Px12<br>1101: Select Px13<br>1110: Select Px14<br>1111: Select Px15 |
| 6:4   | PORTSEL  | R/W | Portx Select (x=A...E)<br>Select the port for outputting EVENTOUT signal of the core.<br>000: Select PA<br>001: Select PB<br>010: Select PC<br>011: Select PD<br>100: Select PE                                                                                                                                                                                                                                                           |
| 7     | EVOEN    | R/W | Event Output Enable<br>0: Disable<br>1: Enable the EVENTOUT of the core to connect to Port x Pin y selected by PORTSEL[2:0] and PINSEL[3:0].                                                                                                                                                                                                                                                                                              |
| 31:8  | Reserved |     |                                                                                                                                                                                                                                                                                                                                                                                                                                           |

#### 12.4.2 Multiplexing remapping register 1 (AFIO\_REMAP1)

Offset address: 0x04

Reset value: 0x0000 0000

| Field | Name      | R/W | Description                                                                                                                             |
|-------|-----------|-----|-----------------------------------------------------------------------------------------------------------------------------------------|
| 0     | SPI1RMP   | R/W | SPI1 Remap Configure<br>0: No remapping<br>NSS—PA4, SCKPA5, MISO—PA6, MOSI—PA7<br>1: Remapping<br>NSS—PA15, SCK—PB3, MISO—PB4, MOSI—PB5 |
| 1     | I2C1RMP   | R/W | I2C1 Remap Configure<br>0: No remapping<br>SCL—PB6, SDA—PB7<br>1: Remapping<br>SCL—PB8, SDA—PB9                                         |
| 2     | USART1RMP | R/W | USART1 TX and RX Remap Configure<br>0: No remapping<br>TX—PA9, RX—PA10                                                                  |

| Field | Name      | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|-----------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |           |     | 1: Remapping<br>TX—PB6, RX—PB7                                                                                                                                                                                                                                                                                                                                                                |
| 3     | USART2RMP | R/W | USART2 CTS, RTS, CK, TX and RX Remap Configure<br>0: No remapping<br>CTS—PA0, RTS—PA1, TX—PA2, RX—PA3, CK—PA4<br>1: Remapping<br>CTS—PD3, RTS—PD4, TX—PD5, RX—PD6, CK—PD7                                                                                                                                                                                                                     |
| 5:4   | USART3RMP | R/W | USART3 CTS, RTS, CK, TX and RX Remap Configure<br>00: No remapping<br>TX—PB10, RX—PB11, CK—PB12, CTS—PB13, RTS—PB14<br>01: Partial remapping<br>TX—PC10, RX—PC11, CK—PC12, CTS—PB13, RTS—PB14<br>10: No effect<br>11: Complete remapping<br>TX—PD8, RX—PD9, CK—PD10, CTS—PD11, RTS—PD12                                                                                                       |
| 7:6   | TMR1RMP   | R/W | TMR1 Remap Configure<br>00: No remapping<br>ETR—PA12, CH1—PA8, CH2—PA9, CH3—PA10, CH4—PA11, BKIN—PB12, CH1N—PB13, CH2N—PB14, CH3N—PB15<br>01: Partial mapping<br>ETR—PA12, CH1—PA8, CH2—PA9, CH3—PA10, CH4—PA11, BKIN—PA6, CH1N—PA7, CH2N—PB0, CH3N—PB1<br>10: No effect<br>11: Complete mapping<br>ETR—PE7, CH1—PE9, CH2—PE11, CH3—PE13, CH4—PE14, BKIN—PE15, CH1N—PE8, CH2N—PE10, CH3N—PE12 |
| 9:8   | TMR2RMP   | R/W | TMR2 Remap Configure<br>00: No remapping<br>CH1/ETR—PA0, CH2—PA1, CH3—PA2, CH4—PA3<br>01: Partial remapping<br>CH1/ETR—PA15, CH2—PB3, CH3—PA2, CH4—PA3<br>10: Partial remapping<br>CH1/ETR—PA0, CH2—PA1, CH3—PB10, CH4—PB11<br>11: Complete remapping<br>CH1/ETR—PA15, CH2—PB3, CH3—PB10, CH4—PB11                                                                                            |
| 11:10 | TMR3RMP   | R/W | TMR3 Remap Configure<br>00: No remapping<br>CH1—PA6, CH2—PA7, CH3—PB0, CH4—PB1<br>01: No effect<br>10: Partial mapping<br>CH1—PB4, CH2—PB5, CH3—PB0, CH4—PB1<br>11: Complete mapping<br>CH1—PC6, CH2—PC7, CH3—PC8, CH4—PC9<br>Note: Remapping does not affect TMR3_ETR on PE0.                                                                                                                |
| 12    | TMR4RMP   | R/W | TMR4 Remap Configure<br>0: No remapping<br>TMR4_CH1—PB6, TMR4_CH2—PB7, TMR4_CH3—PB8,<br>TMR4_CH4—PB9<br>1: Complete mapping                                                                                                                                                                                                                                                                   |

| Field | Name              | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------|-------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |                   |     | TMR4_CH1—PD12 , TMR4_CH2—PD13 , TMR4_CH3—PD14, TMR4_CH4—PD15<br>Note: Remapping does not affect TMR4_ETR on PE0.                                                                                                                                                                                                                                                                                                                                   |
| 14:13 | CAN1RMP           | R/W | CAN1 Remap Configure<br>00: CAN1_RX mapped to PA11, CAN1_TX mapped to PA12<br>01: No effect<br>10: CAN1_RX mapped to PB8, CAN1_TX mapped to PB9 (cannot be used for package of Pin 36)<br>11: CAN1_RX mapped to PD0, CAN1_TX mapped to PD1                                                                                                                                                                                                         |
| 15    | PD01RMP           | R/W | Port D0/Port D1 mapping on OSC_IN/OSC_OUT Configure<br>This function can only be used for package of Pins 36, 48 and 64 (PD0 and PD1 appear on 100-pin package without remapping).<br>0: No remapping for PD0 and PD1<br>1: PD0 mapped to OSC_IN, PD1 mapped to OSC_OUT<br>When the main oscillator HSECLK is not used (the system runs in internal 8MHz resistance-capacitance oscillator), PD0 and PD1 can be mapped to OSC_IN and OSC_OUT pins. |
| 16    | Reserved          |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 17    | ADC1_ETRGINJC_RMP | R/W | ADC1 External Trigger Injected Conversion Remapping Configure<br>0: External trigger of ADC1 injected conversion is connected to EINT15<br>1: Reserved                                                                                                                                                                                                                                                                                             |
| 18    | ADC1_ETRGREGC_RMP | R/W | ADC1 External Trigger Regular Conversion Remapping Configure<br>0: External trigger of ADC1 regular conversion is connected to EINT11<br>1: Reserved                                                                                                                                                                                                                                                                                               |
| 19    | ADC2_ETRGINJC_RMP | R/W | ADC2 External Trigger Injected Conversion Remapping Configure<br>0: External trigger of ADC2 injected conversion is connected to EINT15<br>1: Reserved                                                                                                                                                                                                                                                                                             |
| 20    | ADC2_ETRGREGC_RMP | R/W | ADC2 External Trigger Regular Conversion Remapping Configure<br>0: External trigger of ADC2 regular conversion is connected to EINT11<br>1: Reserved                                                                                                                                                                                                                                                                                               |
| 21    | Reserved          |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 22    | CAN2RMP           | R/W | CAN2 Remap Configure<br>0: No remapping<br>CAN2_RX—PB12, CAN2_TX—PB13<br>1: Remapping<br>CAN2_RX—PB5, CAN2_TX—PB6                                                                                                                                                                                                                                                                                                                                  |
| 23    | Reserved          |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 26:24 | SWJCFG            | W   | Serial Wire JTAG Configure<br>Configure SWJ and tracking multiplexing function I/O as debugging I/O or normal I/O, applicable when GPIO is not enough. These bits can only be written by software (read these bits and undefined values will be returned).<br>SWJ (serial line JTAG) supports JTAG or SWD to access the debugging port of Cortex. The default state after system reset is SWJ enabled but without tracking function;               |

| Field | Name     | R/W | Description                                                                                                                                                                                     |
|-------|----------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |          |     | 000: Complete SWJ (JTAG-DP+SW-DP)<br>001: Complete SWJ (JTAG-DP+SW-DP) but without NJTRST<br>010: JTAG-DP disabled, SW-DP enabled<br>100: JTAG-DP disabled, SW-DP disabled<br>Others: No effect |
| 31:27 | Reserved |     |                                                                                                                                                                                                 |

#### 12.4.3 External interrupt input source selection register 1 (AFIO\_EINTSEL1)

Offset address: 0x08

Reset value: 0x0000 0000

| Field | Name       | R/W | Description                                                                                                                                            |
|-------|------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0  | EINTx[3:0] | R/W | EINTx Input Source Select (x=0...3)<br>0000: PA[x] pin<br>0001: PB[x] pin<br>0010: PC[x] pin<br>0011: PD[x] pin<br>0100: PE[x] pin<br>Others: Reserved |
| 31:16 | Reserved   |     |                                                                                                                                                        |

#### 12.4.4 External interrupt input source selection register 2 (AFIO\_EINTSEL2)

Offset address: 0x0C

Reset value: 0x0000 0000

| Field | Name       | R/W | Description                                                                                                                                           |
|-------|------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0  | EINTx[3:0] | R/W | EINTx Input Source Select(x=4...7)<br>0000: PA[x] pin<br>0001: PB[x] pin<br>0010: PC[x] pin<br>0011: PD[x] pin<br>0100: PE[x] pin<br>Others: Reserved |
| 31:16 | Reserved   |     |                                                                                                                                                       |

#### 12.4.5 External interrupt input source selection configuration register 3 (AFIO\_EINTSEL3)

Offset address: 0x10

Reset value: 0x0000 0000

| Field | Name       | R/W | Description                                                                                                                                            |
|-------|------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0  | EINTx[3:0] | R/W | EINTx Input Source Select(x=8...11)<br>0000: PA[x] pin<br>0001: PB[x] pin<br>0010: PC[x] pin<br>0011: PD[x] pin<br>0100: PE[x] pin<br>Others: Reserved |
| 31:16 | Reserved   |     |                                                                                                                                                        |

### 12.4.6 External interrupt input source selection register 4 (AFIO\_EINTSEL4)

Offset address: 0x14

Reset value: 0x0000 0000

| Field | Name       | R/W | Description                                                                                                                                             |
|-------|------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0  | EINTx[3:0] | R/W | EINTx Input Source Select(x=12...15)<br>0000: PA[x] pin<br>0001: PB[x] pin<br>0010: PC[x] pin<br>0011: PD[x] pin<br>0100: PE[x] pin<br>Others: Reserved |
| 31:16 |            |     | Reserved                                                                                                                                                |

## 13 Timer Overview

### 13.1 Full Name and Abbreviation Description of Terms

Table 47 Full Name and Abbreviation Description of Terms

| Full name in English | English abbreviation |
|----------------------|----------------------|
| Timer                | TMR                  |
| Update               | U                    |
| Request              | R                    |
| Event                | EV                   |
| Capture              | C                    |
| Compare              | C                    |
| Length               | LEN                  |

### 13.2 Timer Category and Main Difference

In this series of products, there are three types of timers: advanced timer, general-purpose timer and basic timer (watchdog timer and system tick timer are described in other chapters).

The advanced timer includes the functions of general-purpose timer and basic timer. The advanced timer has four capture/comparison channels, supports timing function, input capture and output comparison function, braking and complementary output function, and is a 16-bit timer that can count up/down.

The function of general-purpose timer is simpler than that of advanced timer. The main differences are the total number of channels, the number of complementary output channel groups and the braking function.

The basic timer is a timer that can only realize timing function and has no external interface.

The main differences of timers included in the products are shown in the table below:

Table 48 Main Differences among Timers Included in the Products

| Item          | Specific content/Category  | Advanced timer               | General-purpose timer        |
|---------------|----------------------------|------------------------------|------------------------------|
| Name          | —                          | TMR1                         | TMR2/3/4                     |
| Timebase unit | Counter                    | 16 bits                      | 16 bits                      |
|               | Prescaler                  | 16 bits                      | 16 bits                      |
|               | Count mode                 | Up<br>Down<br>Center-aligned | Up<br>Down<br>Center-aligned |
| Channel       | Input channel              | 4                            | 4                            |
|               | Capture/Comparison channel | 4                            | 4                            |

| Item     | Specific content/Category    | Advanced timer | General-purpose timer |
|----------|------------------------------|----------------|-----------------------|
|          | Output channel               | 7              | 4                     |
|          | Complementary output channel | 3 groups       | 0                     |
| Function | General DMA request          | OK             | OK                    |
|          | PWM mode                     | Yes            | Yes                   |
|          | Single-pulse mode            | Yes            | Yes                   |
|          | Forced output mode           | Yes            | Yes                   |
|          | Dead zone insertion          | Yes            | None                  |

### Timer term

Table 49 Definitions and Terms of Pins

| Name                                | Description                               |
|-------------------------------------|-------------------------------------------|
| TMRx_ETR                            | External trigger signal of Timer x        |
| TMRx_CH1、TMRx_CH2、TMRx_CH3、TMRx_CH4 | Channel 1/2/3/4 of Timer x                |
| TMRx_ChN                            | Complementary output channel y of Timer x |
| TMRx_BKIN                           | Braking signal of Timer x                 |

Table 50 Definitions and Terms of Internal Signals

| Name            | Description                                       |
|-----------------|---------------------------------------------------|
| ETR             | TMRx_ETR external trigger signal                  |
| ETRF            | External trigger filter                           |
| ETRP            | External trigger prescaler                        |
| -               |                                                   |
| ITR, ITR0, ITR1 | Internal trigger                                  |
| TRGI            | Clock/Trigger/Slave mode controller trigger input |
| TIF_ED          | Timer input filter edge detection                 |
| --              |                                                   |
| CK_PSC          | Prescaler clock                                   |
| CK_CNT          | Counter clock                                     |
| PSC             | Prescaler                                         |
| CNT             | Counter                                           |
| AUTORLD         | Auto reload register                              |
| --              |                                                   |
| TIx, TI1        | Timer input                                       |
| TIxF, TI1F,     | Timer input filter                                |
| TI1_ED          | Timer input edge detection                        |
| TIxFPx, TI1FP1  | Timer input filter polarity                       |
| ICx, IC1        | Input capture                                     |

| Name           | Description                        |
|----------------|------------------------------------|
| ICxPS, IC1PS   | Input capture prescaler            |
| TRC            | Trigger capture                    |
| BRK            | Braking signal                     |
| -              | -                                  |
| OCx, OC1       | Timer output comparison channel    |
| OCxREF, OC1REF | Output comparison reference signal |
| -              | -                                  |
| TGI            | Trigger interrupt                  |
| BI             | Braking interrupt                  |
| CCxI, CC1I     | Capture/Comparison interrupt       |
| UEV            | Update event                       |
| UIFLG          | Update interrupt flag              |

## 14 Advanced Timer (TMR1)

### 14.1 Introduction

The advanced timer takes the time base unit as the core, and has the functions of input capture, output comparison and braking input, including a 16-bit auto reload counter. Compared with other timers, the advanced timer supports complementary output, repeat count and programmable dead zone insertion function, and is more suitable for motor control.

### 14.2 Main Characteristics

- (1) Timebase unit
  - Counter: 16-bit counter, count-up, count-down and Center-aligned count
  - Prescaler: 16-bit programmable prescaler
  - Repeat counter: 16-bit repeat counter
  - Auto reloading function
- (2) Clock source selection
  - Internal clock
  - External input
  - External trigger
  - Internal trigger
- (3) Input capture function
  - Counting function
  - PWM input mode (measurement of pulse width, frequency and duty cycle)
  - Encoder interface mode
- (4) Output comparison function
  - PWM output mode
  - Forced output mode
  - Single-pulse mode
  - Complementary output and dead zone insertion
- (5) Timing function
- (6) Braking function
- (7) Master/Slave mode controller of timer
  - Timers can be synchronized and cascaded
  - Support multiple slave modes and synchronization signals
- (8) Interrupt output and DMA request event
  - Update event (counter overrun/underrun, counter initialization)
  - Trigger event (counter start, stop, internal/external trigger)
  - Capture/Comparison event
  - Braking signal input event

## 14.3 Structure Block Diagram

Figure 21 Advanced Timer Structure Block Diagram



## 14.4 Functional Description

### 14.4.1 Clock Source Selection

The advanced timer has four clock sources

#### Internal clock

It is TMRx\_CLK from RCM, namely the driving clock of the timer; when the slave mode controller is disabled, the clock source CK\_PSC of the prescaler is driven by the internal clock CK\_INT.

#### External clock mode 1

The trigger signal generated from the input channel TI1/2/3/4 of the timer after polarity selection and filtering is connected to the slave mode controller to control the work of the counter. Besides, the pulse signal generated by the input of Channel 1 after double-edge detection of the rising edge and the falling edge is logically equal or the future signal is TI1F\_ED signal, namely double-edge signal of TIF\_ED. Specially the PWM input can only be input by TI1/2.

#### External clock mode 2

After polarity selection, frequency division and filtering, the signal from external trigger interface (ETR) is connected to slave mode controller through trigger input selector to control the work of counter.

### **Internal trigger input**

The timer is set to work in slave mode, and the clock source is the output signal of other timers. At this time, the clock source has no filtering, and the synchronization or cascading between timers can be realized. The master mode timer can reset, start, stop or provide clock for the slave mode timer.

#### **14.4.2 Timebase Unit**

The time base unit in the advanced timer contains four registers

- Counter register (CNT) 16 bits
- Auto reload register (AUTORLD) 16 bits
- Prescaler register (PSC) 16 bits
- Repeat count register (REPCNT) 8 bits

Repeat count register is unique to advanced timer.

### **Counter CNT**

There are three counting modes for the counter in the advanced timer

- Count-up mode
- Count-down mode
- Center-aligned mode

### **Count-up mode**

Set to the count-up mode by CNTDIR bit of configuration control register (TMRx\_CTRL1).

When the counter is in count-up mode, the counter will count up from 0; every time a pulse is generated, the counter will increase by 1 and when the value of the counter (TMRx\_CNT) is equal to the value of the auto reload (TMRx\_AUTORLD), the counter will start to count again from 0, a count-up overrun event will be generated, and the value of the auto reload (TMRx\_AUTORLD) is written in advance.

When the counter overruns, an update event will be generated. At this time, the repeat count shadow register, the auto reload shadow register and the prescaler buffer will be updated. The update event can be disabled by UD bit of configuration control register TMRx\_CTRL1.

The figure below is Timing Diagram when Division Factor is 1 or 2 in Count-up Mode

Figure 22 Timing Diagram when Division Factor is 1 or 2 in Count-up Mode



### Count-down mode

Set to the count-down mode by CNTDIR bit of configuration control register (TMRx\_CTRL1).

When the counter is in count-down mode, the counter will start to count down from the value of the auto reload (TMRx\_AUTORLD); every time a pulse is generated, the counter will decrease by 1 and when it becomes 0, the counter will start to count again from (TMRx\_AUTORLD), meanwhile, a count-down overrun event will be generated, and the value of the auto reload (TMRx\_AUTORLD) is written in advance.

When the counter overruns, an update event will be generated. At this time, the repeat count shadow register, the auto reload shadow register and the prescaler buffer will be updated. The update event can be disabled by configuring the UD bit of the TMRx\_CTRL1 register.

Figure 23 Timing Diagram when Division Factor is 1 or 2 in Count-down Mode



### Center-aligned mode

Set to the Center-aligned mode by CNTDIR bit of configuration control register (TMRx\_CTRL1).

When the counter is in Center-aligned mode, the counter counts up from 0 to the value of auto reload (TMRx\_AUTORLD), then counts down to 0 from the value of the auto reload (TMRx\_AUTORLD), which will repeat; in counting up, when the counter value is (AUTORLD-1), a counter overrun event will be generated; in counting down, when the counter value is 1, a counter underrun event will be generated.

Figure 24 Timing Diagram when Division Factor is 1 or 2 in Center-aligned Mode



### Repeat counter REPCNT

There is no repeat counter REPCNT in the basic/general-purpose timer, which means that when the overrun event or underrun event occurs in the basic/general-purpose timer, an update event will be generated directly; while in the advanced timer, because of the existence of the repeat counter, when an overrun/unerrrun event occurs to the advanced timer, the update event will be generated only when the value of the repeat counter is 0.

For example, if the advanced timer needs to generate an update event when an overrun/underrun event occurs, the value of the repeat counter should be set to 0.

If the repeat counter function is used in the count-up mode, every time the counter counts up to AUTORLD, an overrun event will occur. At this time, the value of the repeat counter will be decreased by 1, and an update event will be generated until the value of the repeat counter is 0.

That is, when  $N+1$  ( $N$  is the value of repeat counter) overrun/underrun events occur, an update event will be generated.

Figure 25 Timing Diagram when Setting REPCNT=2 in Count-up Mode



### Prescaler PSC

The prescaler is 16 bits and programmable, and it can divide the clock frequency of the counter to any value between 1 and 65536 (controlled by TMRx\_PSC register), and after frequency division, the clock will drive the counter CNT to count. The prescaler has a buffer, which can be changed during running.

### 14.4.3 Input Capture

#### Input capture channel

The advanced timer has four independent capture/comparison channels, each of which is surrounded by a capture/comparison register.

In the input capture, the measured signal will enter from the external pin T1/2/3/4 of the timer, first pass through the edge detector and input filter, and then into the capture channel. Each capture channel has a corresponding capture register. When the capture occurs, the value of the counter CNT will be latched in the capture register CCx. Before entering the capture register, the signal will pass through the prescaler, which is used to set how many events to capture at a time.

#### Input capture application

Input capture is used to capture external events, and can give the time flag to indicate the occurrence time of the event and measure the pulse jump edge events (measure the frequency or pulse width), for example, if the selected edge appears on the input pin, the TMRx\_CCx register will capture the current value of the counter and the CCxIFLG bit of the state register TMRx\_STS will be set to 1; if CCxIEN=1, an interrupt will be generated.

In capture mode, the timing, frequency, cycle and duty cycle of a waveform can be measured. In the input capture mode, the edge selection is set to rising edge detection. When the rising edge appears on the capture channel, the first capture occurs, at this time, the value of the counter CNT will be latched in the capture register CCx; at the same time, it will enter the capture interrupt, a capture will be recorded in the interrupt service program and the value will be

recorded. When the next rising edge is detected, the second capture occurs, the value of counter CNT will be latched in capture register CCx again, at this time, it will enter the capture interrupt again, the value of capture register will be read, and the cycle of this pulse signal will be obtained through capture.

#### 14.4.4 Output Comparison

There are eight modes of output comparison: freeze, channel x is valid level when matching, channel x is invalid level when matching, flip, force is invalid, force is valid, PWM1 and PWM2 modes, which are configured by OCxMOD bit in TMRx\_CCMx register and can control the waveform of output signal in output comparison mode.

##### Output comparison application

In the output comparison mode, the position, polarity, frequency and time of the pulse generated by the timer can be controlled.

When the value of the counter is equal to that of the capture/comparison register, the channel output can be set as high level, low level or flip by configuring the OCxMOD bit in TMRx\_CCMx register and the CCxPOL bit in the output polarity TMRx\_CCEN register.

When CCxIFLG=1 in TMRx\_STS register, if CCxIEN=1 in TMRx\_DIEN register, an interrupt will be generated; if CCDSEL=1 in TMRx\_CTRL2 register, DMA request will be generated.

#### 14.4.5 PWM Output Mode

PWM mode is an adjustable pulse signal output by the timer. The pulse width of the signal is determined by the value of the comparison register CCx, and the cycle is determined by the value of the auto reload AUTORLD.

PWM output mode contains PWM mode 1 and PWM mode 2; PWM mode 1 and PWM mode 2 are divided into count-up, count-down and center alignment counting; in PWM mode 1, if the value of the counter CNT is less than the value of the comparison register CCx, the output level will be valid; otherwise, it will be invalid.

Set the timing diagram in PWM1 mode when CCx=5, AUTORLD=7

Figure 26 PWM1 Count-up Mode Timing Diagram



Figure 27 PWM1 Count-down Mode Timing Diagram



Figure 28 PWM1 Center-aligned Mode Timing Diagram



In PWM mode 2, if the value of the counter CNT is less than that of the comparison register CCx, the output level will be invalid; otherwise, it will be valid.

Set the timing diagram in PWM2 mode when CCx=5, AUTORLD=7

Figure 29 PWM2 Count-up Mode Timing Diagram



Figure 30 PWM2 Count-down Mode Timing Diagram



Figure 31 PWM2 Center-aligned Mode Timing Diagram



#### 14.4.6 PWM Input Mode

PWM input mode is a particular case of input capture.

In PWM input mode, as only TI1FP1 and TI1FP2 are connected to the slave mode controller, input can be performed only through the channels TMRx\_CH1 and TMRx\_CH2, which need to occupy the capture registers of CH1 and CH2.

In the PWM input mode, the PWM signal enters from TMRx\_CH1, and the signal will be divided into two channels, one can measure the cycle and the other can measure the duty cycle. In the configuration, it is only required to set the polarity of one channel, and the other will be automatically configured with the opposite polarity.

In this mode, the slave mode controller should be configured as the reset mode (SMFSEL bit of TMRx\_SMCTRL register)

Figure 32 PWM Input Mode Timing Diagram



#### 14.4.7 Single-pulse Mode

The single-pulse mode is a special case of timer comparison output, and is also a special case of PWM output mode.

Set SPMEN bit of TMRx\_CTRL1 register, and select the single-pulse mode. After the counter is started, a certain number of pulses will be output before the update event occurs. When an update event occurs, the counter will stop counting, and the subsequent PWM waveform output will no longer be changed.

After a certain controllable delay, a pulse with controllable pulse width is generated in single-pulse mode through the program. The delay time is defined by the value of TMRx\_CCx register; in the count-up mode, the delay time is CCx and the pulse width is AUTORLD-CCx; in the count-down mode, the delay time is AUTORLD-CCx and the pulse width is CCx.

Figure 33 Timing Diagram in Single-pulse Mode



#### 14.4.8 Impact of the Register on Output Waveform

The following registers will affect the level of the timer output waveform. For details, please refer to "Register Functional Description".

- (1) CCxEN and CCxNEN bits in TMRx\_CCEN register
  - CCxNEN=0 and CCxEN=0: The output is turned off (output disabled, invalid state)
  - CCxNEN=1 and CCxEN=1: The output is turned on (output enabled, normal output)
- (2) MOEN bit in TMRx\_BDT register
  - MOEN=0: Idle mode
  - MOEN=1: Run mode
- (3) OCxOIS and OCxNOIS bits in TMRx\_CTRL2 register
  - OCxOIS=0 and OCxNOIS=0: When idle (MOEN=0), the output level after the dead zone is 0
  - OCxOIS=1 and OCxNOIS=1: When idle (MOEN=0), the output level after the dead zone is 1
- (4) RMOS bit in TMRx\_BDT register
  - Application environment of RMOS: In corresponding complementary channel and timer are in run mode (MOEN=1), the timer is not working (CCxEN=0, CCxNEN=0) or is working (CCxEN=1, CCxNEN=1)
- (5) IMOS bit in TMRx\_BDT register
  - Application environment of IMOS: In corresponding complementary channel and timer are in idle mode (MOEN=0), the timer is not working (CCxEN=0, CCxNEN=0) or is working (CCxEN=1, CCxNEN=1)
- (6) CCxPOL and CCxNPOL bits of TMRx\_CCEN register
  - CCxPOL=0 and CCxNPOL=0: Output polarity, high level is valid
  - CCxPOL=1 and CCxNPOL=1: Output polarity, the low level is valid

The following figure lists the register structure relationships that affect the output waveform

Figure 34 Register Structural Relationship Affecting Output Waveform



#### 14.4.9 Braking Function

The signal source of braking is clock fault event and external input interface.

Besides, the BRKEN bit in TMRx\_BDT register can enable the braking function, and the BRKPOL bit can configure the polarity of braking input signal.

When a braking event occurs, the output pulse signal level can be modified according to the state of the relevant control bit.

Figure 35 Braking Event Timing Diagram



#### 14.4.10 Complementary Output and Dead Zone Insertion

Complementary output is particular output of advanced timer, and the advanced timer has three groups of complementary output channels. The insertion dead time is used to generate complementary output signals to ensure that the two-way complementary signals of channels will not be valid at the same time. The dead time is set according to the output device connected to the timer and its characteristics

The duration of the dead zone can be controlled by configuring DTS bit of TMRx\_BDT register

Figure 36 Complementary Output of Insertion with Dead Zone



#### 14.4.11 Forced Output Mode

In the forced output mode, the comparison result is ignored, and the corresponding level is directly output according to the configuration instruction.

- CCxSEL=00 for TMRx\_CCMx register, set CCx channel as output
- OCxMOD=100/101 for TMRx\_CCMx register, set to force OCxREF signal to invalid/valid state

In this mode, the corresponding interrupt and DMA request will still be generated.

#### 14.4.12 Encoder Interface Mode

The encoder interface mode is equivalent to an external clock with direction selection. In the encoder interface mode, the content of the timer can always indicate the position of the encoder.

The selection methods of encoder interface is as follows:

- By setting SMFSEL bit of TMRx\_SMCTRL register, set the counter to count on the edge of TI1 channel /TI2 channel, or count on the edge of TI1 and TI2 at the same time.
- Select the polarity of TI1 and TI2 by setting the CC1POL and CC2POL bits of TMRx\_CCEN register.
- Select to filter or not by setting the IC1F and IC2F bits of TMRx\_CCM1 register.

The two input TI1 and TI2 can be used as the interface of incremental encoder. The counter is driven by the effective jump of the signals TI1FP1 and TI2FP2 after filtering and edge selection in TI1 and TI2.

The count pulse and direction signal are generated according to the input signals of TI1 and TI2

- The counter will count up/down according to the jumping sequence of the input signal.
- Set CNTDIR of control register TMRx\_CTRL1 to be read-only (CNTDIR will be re-calculated due to jumping of any input end).

The change mechanism of counter count direction is shown in the figure below

Table 51 Relationship between Count Direction and Encoder

| Effective edge           |              | Count only in TI1 |            | Count only in TI2 |            | Count in both TI1 and TI2 |            |
|--------------------------|--------------|-------------------|------------|-------------------|------------|---------------------------|------------|
| Level of relative signal |              | High              | Low        | High              | Low        | High                      | Low        |
| TI1FP1                   | Rising edge  | —                 |            | Count down        | Count up   | Count down                | Count up   |
|                          | Falling edge | —                 |            | Count up          | Count down | Count up                  | Count down |
| TI2FP2                   | Rising edge  | Count up          | Count down | —                 |            | Count up                  | Count down |
|                          | Falling edge | Count down        | Count up   | —                 |            | Count down                | Count up   |

The external incremental encoder can be directly connected with MCU, not needing external interface logic, so the comparator is used to convert the differential output of the encoder to digital signal to increase the immunity from noise interference.

Among the following examples:

- IC1FP1 is mapped to TI1
- IC2FP2 is mapped to TI2
- Neither IC1FP1 nor IC2FP2 is reverse phase
- The input signal is valid at the rising edge and falling edge
- Enable the counter

Figure 37 Counter Operation Example in Encoder Mode



For example, when TI1 is at low level, and TI2 is in rising edge state, the counter will count up.

Figure 38 Example of Encoder Interface Mode of IC1FP1 Reversed Phase



For example, when TI1 is at low level, and the rising edge of TI2 jumps, the counter will count down.

#### 14.4.13 Slave Mode

TMRx timer can synchronize external trigger

- Reset mode
- Gated mode
- Trigger mode

SMFSEL bit in TMRx\_SMCTRL register can be set to select the mode.

SMFSEL=100 set the reset mode, SMFSEL=101 set the gated mode, SMFSEL=110 set the trigger mode.

In the reset mode, when a trigger input event occurs, the counter and prescaler will be initialized, and the rising edge of the selected trigger input (TRGI) will reinitialize the counter and generate a signal to update the register.

In the gated mode, the enable of the counter depends on the high level of the selected input. When the trigger input is high, the clock of the counter will be started. Once the trigger input becomes low, the counter will stop (but not be reset). The start and stop of the counter are controlled.

In the trigger mode, the enable of the counter depends on the event on the selected input, the counter is started (but is not reset) at the rising edge of the trigger input, and only the start of the counter is controlled.

#### 14.4.14 Timer Interconnection

Each timer of TMRx can be connected with each other to realize synchronization or cascading between timers. It is required to configure one timer in master mode and the other timer in slave mode.

When the timer is in master mode, it can reset, start, stop and provide clock source for the counter of the slave mode timer.

Figure 39 Timer 1 Master/Slave Mode Example



When the timers are interconnected:

- A timer can be used as the prescaler of other register
- Another register can be started by the enable signal of a timer
- Another register can be started by the update event of a timer
- Another register can be selected by the enable of a timer
- Two timers can be synchronized by an external trigger

#### 14.4.15 Interrupt and DMA Request

The timer can generate an interrupt when an event occurs during operation

- Update event (counter overrun/underrun, counter initialization)
- Trigger event (counter start, stop, internal/external trigger)
- Capture/Comparison event
- Braking signal input event

Some internal interrupt events can generate DMA requests, and special interfaces can enable or disable DMA requests.

#### 14.4.16 Debug mode

The TMR1 can be configured in debug mode and choose to stop or continue to work. It depends on the TMR1\_STS bit of DBGMCU\_CFG register in DBGMCU module.

#### 14.4.17 Clear OCxREF Signal when External Events Occur

This function is used for output comparison and PWM mode.

In one channel, the high level of ETRF input port will reduce the signal of OCxREF to low level, and the OCxCEN bit in capture/comparison register TMRx\_CCMx is set to 1, and OCxREF signal will remain low until the next update event.

Set TMRx to PWM mode, close the external trigger prescaler, and disable the

external trigger mode 2; when ETRF input is high, set OCxCEN=0, and the output OCxREF signal is shown in the figure below.

Figure 40 OCxREF Timing Diagram



Set TMRx to PWM mode, close the external trigger prescaler, and disable the external trigger mode 2; when ETRF input is high, set OCxCEN=1, and the output OCxREF signal is shown in the figure below.

Figure 41 OCxREF Timing Diagram



## 14.5 Register Address Mapping

In the following table, all registers of the advanced timer are mapped to a 16-bit addressable (address) space.

Table 52 Advanced Timer Register Address Mapping

| Register name | Description                        | Offset address |
|---------------|------------------------------------|----------------|
| TMRx_CTRL1    | Control register 1                 | 0x00           |
| TMRx_CTRL2    | Control register 2                 | 0x04           |
| TMRx_SMCTRL   | Slave mode control register        | 0x08           |
| TMRx_DIEN     | DMA/Interrupt enable register      | 0x0C           |
| TMRx_STS      | State register                     | 0x10           |
| TMRx_CEG      | Control event generation register  | 0x14           |
| TMRx_CCM1     | Capture/Comparison mode register 1 | 0x18           |
| TMRx_CCM2     | Capture/Comparison mode register 2 | 0x1C           |
| TMRx_CCEN     | Capture/Comparison enable register | 0x20           |
| TMRx_CNT      | Counter register                   | 0x24           |

| Register name | Description                             | Offset address |
|---------------|-----------------------------------------|----------------|
| TMRx_PSC      | Prescaler register                      | 0x28           |
| TMRx_AUTORLD  | Auto reload register                    | 0x2C           |
| TMRx_REPCNT   | Repeat count register                   | 0x30           |
| TMRx_CC1      | Channel 1 capture/comparison register   | 0x34           |
| TMRx_CC2      | Channel 2 capture/comparison register   | 0x38           |
| TMRx_CC3      | Channel 3 capture/comparison register   | 0x3C           |
| TMRx_CC4      | Channel 4 capture/comparison register   | 0x40           |
| TMRx_BDT      | Braking and dead zone register          | 0x44           |
| TMRx_DCTRL    | DMA control register                    | 0x48           |
| TMRx_DMADDR   | DMA address register of continuous mode | 0x4C           |

## 14.6 Register Functional Description

### 14.6.1 Control register 1 (TMRx\_CTRL1)

Offset address: 0x00

Reset value: 0x0000

| Field | Name   | R/W | Description                                                                                                                                                                                                                                                                                                                                                 |
|-------|--------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | CNTEN  | R/W | <p>Counter Enable<br/>0: Disable<br/>1: Enable</p> <p>When the timer is configured as external clock, gated mode and encoder mode, it is required to write 1 to the bit by software to start regular work; when it is configured as the trigger mode, it can be written to 1 by hardware.</p>                                                               |
| 1     | UD     | R/W | <p>Update Disable<br/>Update event can cause AUTORLD, PSC and CCx to generate the value of update setting.<br/>0: Update event is allowed (UEV)<br/>An update event can occur in any of the following situations:<br/>The counter overruns/underruns;<br/>Set UEG bit;<br/>Update generated by slave mode controller.<br/>1: Update event is disabled</p>   |
| 2     | URSSEL | R/W | <p>Update Request Source Select<br/>If interrupt or DMA is enabled, the update event can generate update interrupt or DMA request. Different update request sources can be selected through this bit.<br/>0: The counter overruns or underruns<br/>Set UEG bit;<br/>Update generated by slave mode controller.<br/>1: The counter overruns or underruns</p> |
| 3     | SPMEN  | R/W | <p>Single Pulse Mode Enable<br/>When an update event is generated, the output level of the channel can be changed; in this mode, the CNTEN bit will be cleared, the counter will be stopped, and the output level of the channel will not be changed.<br/>0: Disable<br/>1: Enable</p>                                                                      |

| Field | Name   | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|--------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4     | CNTDIR | R/W | <p>Counter Direction<br/>This bit is read-only when the counter is configured as Center-aligned mode or encoder mode.<br/>0: Count up<br/>1: Count down</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 6:5   | CAMSEL | R/W | <p>Center Aligned Mode Select<br/>In the Center-aligned mode, the counter counts up and down alternately; otherwise, it will only count up or down. Different Center-aligned modes affect the timing of setting the output comparison interrupt flag bit of the output channel to 1; when the counter is disabled (CNTEN=0), select the Center-aligned mode.</p> <p>00: Edge alignment mode<br/>01: Center-aligned mode 1 (the output comparison interrupt flag bit of output channel is set to 1 when counting down)<br/>10: Center-aligned mode 2 (the output comparison interrupt flag bit of output channel is set to 1 when counting up)<br/>11: Center-aligned mode 3 (the output comparison interrupt flag bit of output channel is set to 1 when counting up/down)</p> |
| 7     | ARPEN  | R/W | <p>Auto-reload Preload Enable<br/>When the buffer is disabled, the program modification TMRx_AUTORLD will immediately modify the values loaded to the counter; when the buffer is enabled, the program modification TMRx_AUTORLD will modify the values loaded to the counter in the next update event.</p> <p>0: Disable<br/>1: Enable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 9:8   | CLKDIV | R/W | <p>Clock Divide Factor<br/>For the configuration of dead time and digital filter, CK_INT provides the clock, and the dead time and the clock of the digital filter can be adjusted by setting this bit.</p> <p>00: <math>t_{DTS}=t_{CK\_INT}</math><br/>01: <math>t_{DTS}=2 \times t_{CK\_INT}</math><br/>10: <math>t_{DTS}=4 \times t_{CK\_INT}</math><br/>11: Reserved</p>                                                                                                                                                                                                                                                                                                                                                                                                   |
| 15:10 |        |     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

#### 14.6.2 Control register 2 (TMRx\_CTRL2)

Offset address: 0x04

Reset value: 0x0000

| Field | Name   | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|--------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | CCPEN  | R/W | <p>Capture/Compare Preloaded Enable<br/>This bit affects the change of CCxEN, CCxNEN and OCxMOD values. When preloading is disabled, the program modification will immediately affect the timer setting; When preloading is enabled, it is only updated after COMG is set, so as to affect the setting of timer; this bit only works on channels with complementary output.</p> <p>0: Disable<br/>1: Enable</p> |
| 1     |        |     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                        |
| 2     | CCUSEL | R/W | <p>Capture/compare Control Update Select)<br/>only when the capture/comparison preload is enabled (CCPEN=1), and it works only for complementary output channel.</p> <p>0: It can only be updated by setting COMG bit<br/>1: It can be updated by setting COMG bit or rising edge on TRGI</p>                                                                                                                   |

| Field | Name    | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|---------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3     | CCDSEL  | R/W | Capture/compare DMA Select<br>0: Send DMA request of CCx when CCx event occurs<br>1: Send DMA request of CCx when an update event occurs                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 6:4   | MMSEL   | R/W | Master Mode Signal Select<br>The signals of timers working in master mode can be used for TRGO, which affects the work of timers in slave mode and cascaded with master timer, and specifically affects the configuration of timers in slave mode.<br>000: Reset; the reset signal of master mode timer is used for TRGO<br>001: Enable; the counter enable signal of master mode timer is used for TRGO<br>010: Update; the update event of master mode timer is used for TRGO<br>011: Comparison pulses; when the master mode timer captures/compares successfully (CCxIFLG=1), a pulse signal is output for TRGO<br>100: Comparison mode 1; OC1REF is used to trigger TRGO<br>101: Comparison mode 2; OC2REF is used to trigger TRGO<br>110: Comparison mode 3; OC3REF is used to trigger TRGO<br>111: Comparison mode 4; OC4REF is used to trigger TRGO |
| 7     | TI1SEL  | R/W | Timer Input 1 Selection<br>0: TMRx_CH1 pin is connected to TI1 input<br>1: TMRx_CH1, TMRx_CH2 and TMRx_CH3 pins are connected to TI1 input after exclusive                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 8     | OC1OIS  | R/W | OC1 Output Idle State Configure<br>Only the level state after the dead time of OC1 is affected when MOEN=0 and OC1N is realized.<br>0: OC1=0<br>1: OC1=1<br>Note: When LOCKCFG bit in TMRx_BDT register is at the Level 1, 2 or 3, this bit cannot be modified.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 9     | OC1NOIS | R/W | OC1N Output Idle State Configure<br>Only the level state after the dead time of OC1 is affected when MOEN=0 and OC1N is realized.<br>0: OC1N=0<br>1: OC1N=1<br>Note: When LOCKCFG bit in TMRx_BDT register is at the Level 1, 2 or 3, this bit cannot be modified.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 10    | OC2OIS  | R/W | Configure OC2 output idle state. Refer to OC1OIS bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 11    | OC2NOIS | R/W | Configure OC2N output idle state. Refer to OC1NOIS bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 12    | OC3OIS  | R/W | Configure OC3 output idle state. Refer to OC1OIS bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 13    | OC3NOIS | R/W | Configure OC3N output idle state. Refer to OC1NOIS bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 14    | OC4OIS  | R/W | Configure OC4 output idle state. Refer to OC1OIS bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 15    |         |     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

### 14.6.3 Slave mode control register (TMRx\_SMCTRL)

Offset address: 0x08

Reset value: 0x0000

| Field | Name   | R/W | Description                                                                                                                                                                       |
|-------|--------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0   | SMFSEL | R/W | Select the slave mode function (Slave Mode Function Select)<br>000: Disable the slave mode, the timer can be used as master mode timer to affect the work of slave mode timer; if |

| Field | Name   | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|--------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |        |     | <p>CTRL1_CNTEN=1, the prescaler is directly driven by the internal clock.</p> <p>001: Encoder mode 1; according to the level of TI1FP1, the counter counts at the edge of TI2FP2.</p> <p>010: Encoder mode 2; according to the level of TI2FP2, the counter counts at the edge of TI1FP1.</p> <p>011: Encoder mode 3; according to the input level of another signal, the counter counts at the edge of TI1FP1 and TI2FP2.</p> <p>100: Reset mode; the slave mode timer resets the counter after receiving the rising edge signal of TRGI and generates the signal to update the register.</p> <p>101: Gated mode; the slave mode timer starts the counter to work after receiving the TRGI high level signal; it stops the counter when receiving TRGI low level; when receiving TRGI high level signal again, the timer will continue to work; the counter is not reset during the whole period.</p> <p>110: Trigger mode, the slave mode timer starts the counter to work after receiving the rising edge signal of TRGI.</p> <p>111: External clock mode 1; select the rising edge signal of TRGI as the clock source to drive the counter to work.</p> |
| 3     |        |     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 6:4   | TRGSEL | R/W | <p>Trigger Input Signal Select</p> <p>In order to avoid false edge detection when changing the bit value, it must be changed when SMFSEL=0.</p> <p>000: Internal trigger ITR0</p> <p>001: Internal trigger ITR1</p> <p>010: Internal trigger ITR2</p> <p>011: Internal trigger ITR3</p> <p>100: Channel 1 input edge detector TIF_ED</p> <p>101: Channel 1 post-filtering timer input TI1FP1</p> <p>110: Channel 2 post-filtering timer input TI2FP2</p> <p>111: External trigger input (ETRF)</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 7     | MSMEN  | R/W | <p>Master/slave Mode Enable</p> <p>0: Invalid</p> <p>1: Enable the master/slave mode</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 11:8  | ETFCFG | R/W | <p>External Trigger Filter Configure</p> <p>0000: Filter disabled, sampling by f<sub>DTs</sub></p> <p>0001: DIV=1, N=2</p> <p>0010: DIV=1, N=4</p> <p>0011: DIV=1, N=8</p> <p>0100: DIV=2, N=6</p> <p>0101: DIV=2, N=8</p> <p>0110: DIV=4, N=6</p> <p>0111: DIV=4, N=8</p> <p>1000: DIV=8, N=6</p> <p>1001: DIV=8, N=8</p> <p>1010: DIV=16, N=5</p> <p>1011: DIV=16, N=6</p> <p>1100: DIV=16, N=8</p> <p>1101: DIV=32, N=5</p> <p>1110: DIV=32, N=6</p> <p>1111: DIV=32, N=8</p> <p>Sampling frequency=timer clock frequency/DIV; the filter length=N, and a jump is generated by every N events.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

| Field | Name   | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|--------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:12 | ETPCFG | R/W | <p>External Trigger Prescaler Configure<br/>The ETR (external trigger input) signal becomes ETRP after frequency division. The signal frequency of ETRP is at most 1/4 of TMRxCLK frequency; when ETR frequency is too high, the ETRP frequency must be reduced through frequency division.</p> <p>00: The prescaler is disabled;<br/>01: ETR signal 2 divided frequency<br/>10: ETR signal 4 divided frequency<br/>11: ETR signal 8 divided frequency</p> |
| 14    | ECEN   | R/W | <p>External Clock Enable Mode2<br/>0: Disable<br/>1: Enable</p> <p>Setting ECEN bit has the same function as selecting external clock mode 1 to connect TRGI to ETRF; slave mode (reset, gating, trigger) can be used at the same time with external clock mode 2, but TRGI cannot be connected to ETRF in such case; when external clock mode 1 and external clock mode 2 are enabled at the same time, the input of external clock is ETRF.</p>          |
| 15    | ETPOL  | R/W | <p>External Trigger Polarity Configure<br/>This bit decides whether the external trigger ETR is reversed.<br/>0: The external trigger ETR is not reversed, and the high level or rising edge is valid<br/>1: The external trigger ETR is reversed, and the low level or falling edge is valid</p>                                                                                                                                                          |

Table 53 TMRx Internal Trigger Connection

| Slave timer | ITR1 (TS=001) | ITR2 (TS=010) | ITR3 (TS=011) |
|-------------|---------------|---------------|---------------|
| TMR1        | TMR2          | TMR3          | TMR4          |

#### 14.6.4 DMA/Interrupt enable register (TMRx\_DIEN)

Offset address: 0x0C

Reset value: 0x0000

| Field | Name   | R/W | Description                                                                   |
|-------|--------|-----|-------------------------------------------------------------------------------|
| 0     | UIEN   | R/W | <p>Update interrupt Enable<br/>0: Disable<br/>1: Enable</p>                   |
| 1     | CC1IEN | R/W | <p>Capture/Compare Channel1 Interrupt Enable<br/>0: Disable<br/>1: Enable</p> |
| 2     | CC2IEN | R/W | <p>Capture/Compare Channel2 Interrupt Enable<br/>0: Disable<br/>1: Enable</p> |
| 3     | CC3IEN | R/W | <p>Capture/Compare Channel3 Interrupt Enable<br/>0: Disable<br/>1: Enable</p> |
| 4     | CC4IEN | R/W | <p>Capture/Compare Channel4 Interrupt Enable<br/>0: Disable<br/>1: Enable</p> |
| 5     | COMIEN | R/W | <p>COM Interrupt Enable<br/>0: Disable<br/>1: Enable</p>                      |
| 6     | TRGIEN | R/W | <p>Trigger interrupt Enable<br/>0: Disable</p>                                |

| Field | Name   | R/W | Description                                                            |
|-------|--------|-----|------------------------------------------------------------------------|
|       |        |     | 1: Enable                                                              |
| 7     | BRKIEN | R/W | Break interrupt Enable<br>0: Disable<br>1: Enable                      |
| 8     | UDIEN  | R/W | Update DMA Request Enable<br>0: Disable<br>1: Enable                   |
| 9     | CC1DEN | R/W | Capture/Compare Channel1 DMA Request Enable<br>0: Disable<br>1: Enable |
| 10    | CC2DEN | R/W | Capture/Compare Channel2 DMA Request Enable<br>0: Disable<br>1: Enable |
| 11    | CC3DEN | R/W | Capture/Compare Channel3 DMA Request Enable<br>0: Disable<br>1: Enable |
| 12    | CC4DEN | R/W | Capture/Compare Channel4 DMA Request Enable<br>0: Disable<br>1: Enable |
| 13    | COMDEN | R/W | COM DMA Request Enable<br>0: Disable<br>1: Enable                      |
| 14    | TRGDEN | R/W | Trigger DMA Request Enable<br>0: Disable<br>1: Enable                  |
| 15    |        |     | Reserved                                                               |

#### 14.6.5 State register (TMRx\_STS)

Offset address: 0x10

Reset value: 0x0000

| Field | Name    | R/W   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|---------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | UIFLG   | RC_W0 | Update Event Interrupt Generate Flag<br>0: Update event interrupt does not occur<br>1: Update event interrupt occurs<br><br>When the counter value is reloaded or reinitialized, an update event will be generated. The bit is set to 1 by hardware and cleared by software; update events are generated in the following situations:<br>(1) UD=0 on TMRx_CTRL1 register, and when the value of the repeat counter overruns/underruns, an update event will be generated;<br>(2) URSSEL=0 and UD=0 on TMRx_CTRL1 register, configure UEG=1 on TMRx_CEG register to generate update event, and the counter needs to be initialized by software;<br>(3) URSSEL=0 and UD=0 on TMRx_CTRL1 register, generate update event when the counter is initialized by trigger event. |
| 1     | CC1IFLG | RC_W0 | Capture/Compare Channel1 Interrupt Flag<br><b>When the capture/comparison channel 1 is configured as output:</b><br>0: No matching occurred<br>1: The value of TMRx_CNT matches the value of TMRx_CC1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

| Field | Name     | R/W   | Description                                                                                                                                                                                                                                                                                                  |
|-------|----------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |          |       | <b>When the capture/comparison channel 1 is configured as input:</b><br>0: Input capture did not occur<br>1: Input capture occurred<br>When capture event occurs, the bit is set to 1 by hardware, and it can be cleared by software or cleared when reading TMRx_CC1 register.                              |
| 2     | CC2IFLG  | RC_W0 | Captuer/Compare Channel2 Interrupt Flag<br>Refer to STS_CC1IFLG                                                                                                                                                                                                                                              |
| 3     | CC3IFLG  | RC_W0 | Capture/Compare Channel3 Interrupt Flag<br>Refer to STS_CC1IFLG                                                                                                                                                                                                                                              |
| 4     | CC4IFLG  | RC_W0 | Captuer/Compare Channel4 Interrupt Flag<br>Refer to STS_CC1IFLG                                                                                                                                                                                                                                              |
| 5     | COMIFLG  | RC_W0 | COM Event Interrupt Generate Flag<br>0: COM event does not occur<br>1: COM interrupt waits for response<br>After COM event is generated, this bit is set to 1 by hardware and cleared by software.                                                                                                           |
| 6     | TRGIFLG  | RC_W0 | Trigger Event Interrupt Generate Flag<br>0: Trigger event interrupt did not occur<br>1: Trigger event interrupt occurred<br>After Trigger event is generated, this bit is set to 1 by hardware and cleared by software.                                                                                      |
| 7     | BRKIFLG  | RC_W0 | Brake Event Interrupt Generate Flag<br>0: Brake event does not occur<br>1: Brake event occurs<br>When brake input is valid, this bit is set to 1 by hardware; when brake input is invalid, this bit can be cleared by software.                                                                              |
| 8     |          |       | Reserved                                                                                                                                                                                                                                                                                                     |
| 9     | CC1RCFLG | RC_W0 | Capture/compare Channel1 Repetition Capture Flag<br>0: Repeat capture does not occur<br>1: Repeat capture occurs<br>The value of the counter is captured to TMRx_CC1 register, and CC1IFLG=1; this bit is set to 1 by hardware and cleared by software only when the channel is configured as input capture. |
| 10    | CC2RCFLG | RC_W0 | Capture/compare Channel2 Repetition Capture Flag<br>Refer to STS_CC1RCFLG                                                                                                                                                                                                                                    |
| 11    | CC3RCFLG | RC_W0 | Capture/compare Channel3 Repetition Capture Flag<br>Refer to STS_CC1RCFLG                                                                                                                                                                                                                                    |
| 12    | CC4RCFLG | RC_W0 | Capture/compare Channel4 Repetition Capture Flag<br>Refer to STS_CC1RCFLG                                                                                                                                                                                                                                    |
| 15:13 |          |       | Reserved                                                                                                                                                                                                                                                                                                     |

#### 14.6.6 Control event generation register (TMRx\_CEG)

Offset address: 0x14

Reset value: 0x0000

| Field | Name | R/W | Description                                                                                                                                                  |
|-------|------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | UEG  | W   | Update Event Generate<br>0: Invalid<br>1: Initialize the counter and generate the update event<br>This bit is set to 1 by software, and cleared by hardware. |

| Field | Name  | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------|-------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |       |     | Note: When an update event is generated, the counter of the prescaler will be cleared, but the prescaler factor remains unchanged. In the count-down mode, the counter reads the value of TMRx_AUTORLD; in Center-aligned mode or count-up mode, the counter will be cleared.                                                                                                                                                                                                                                                                                                                                                                      |
| 1     | CC1EG | W   | Capture/Compare Channel1 Event Generation<br>0: Invalid<br>1: Capture/Comparison event is generated<br>This bit is set to 1 by software and cleared automatically by hardware.<br>If Channel 1 is in output mode,<br>When CC1IFLG=1, if CC1IEN and CC1DEN bits are set, the corresponding interrupt and DMA request will be generated.<br>If Channel 1 is in input mode<br>The value of the capture counter is stored in TMRx_CC1 register;<br>configure CC1IFLG=1, and if CC1IEN and CC1DEN bits are also set, the corresponding interrupt and DMA request will be generated; at this time, if CC1IFLG=1, it is required to configure CC1RCFLG=1. |
| 2     | CC2EG | W   | Capture/Compare Channel2 Event Generation<br>Refer to CC1EG description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 3     | CC3EG | W   | Capture/Compare Channel3 Event Generation<br>Refer to CC1EG description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 4     | CC4EG | W   | Capture/Compare Channel4 Event Generation<br>Refer to CC1EG description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 5     | COMG  | W   | Capture/Compare Control Update Event Generate<br>0: Invalid<br>1: Capture/Comparison update event is generated<br>This bit is set to 1 by software and cleared automatically by hardware.<br>Note: COMG bit is valid only in complementary output channel.                                                                                                                                                                                                                                                                                                                                                                                         |
| 6     | TEG   | W   | Trigger Event Generate<br>0: Invalid<br>1: Trigger event is generated<br>This bit is set to 1 by software and cleared automatically by hardware.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 7     | BEG   | W   | Brake Event Generate<br>0: Invalid<br>1: Brake event is generated<br>This bit is set to 1 by software and cleared automatically by hardware.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 15:8  |       |     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

#### 14.6.7 Capature/Comparison mode register 1 (TMRx\_CCM1)

Offset address: 0x18

Reset value: 0x0000

The timer can be configured as input (capture mode) or output (comparison mode) by CCxSEL bit. The functions of other bits of the register are different in input and output modes, and the functions of the same bit are different in output mode and input mode. The OCx in the register describes the function of the channel in the output mode, and the ICx in the register describes the function of the channel in the input mode.

##### Output comparison mode:

| Field | Name   | R/W | Description                                                                                                                                                                                                                                             |
|-------|--------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0   | CC1SEL | R/W | Capture/Compare Channel 1 Selection<br>This bit defines the input/output direction and the selected input pin.<br>00: CC1 channel is output<br>01: CC1 channel is input, and IC1 is mapped on TI1<br>10: CC1 channel is input, and IC1 is mapped on TI2 |

| Field | Name   | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|--------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |        |     | <p>11: CC1 channel is input, and IC1 is mapped on TRC, and only works in internal trigger input<br/>           Note: This bit can be written only when the channel is closed (TMRx_CCEN register CC1EN=0).</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 2     | OC1FEN | R/W | <p>Output Compare Channel1 Fast Enable<br/>           0: Disable<br/>           1: Enable<br/>           This bit is used to improve the response of the capture/comparison output to the trigger input event.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 3     | OC1PEN | R/W | <p>Output Compare Channel1 Preload Enable<br/>           0: Preloading function is disabled; write the value of TMRx_CC1 register through the program and it will work immediately.<br/>           1: Preloading function is enabled; write the value of TMRx_CC1 register through the program and it will work after an update event is generated.<br/>           Note: When the protection level is 3 and the channel is configured as output, this bit cannot be modified. When the preload register is uncertain, PWM mode can be used only in single pulse mode (SPMEN=1); otherwise, the following output comparison result is uncertain.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 6:4   | OC1MOD | R/W | <p>Output Compare Channel1 Mode Configure<br/>           000: Freeze The output comparison has no effect on OC1REF<br/>           001: The output value is high when matching. When the value of counter CNT matches the value CCx of capture comparison register, OC1REF will be forced to be at high level<br/>           010: The output value is low when matching. When the value of the counter matches the value of the capture comparison register, OC1REF will be forced to be at low level<br/>           011: Output flaps when matching. When the value of the counter matches the value of the capture comparison register, flap the level of OC1REF<br/>           100: The output is forced to be low Force OC1REF to be at low level<br/>           101: The output is forced to be high. Force OC1REF to be at high level<br/>           110: PWM mode 1 (set to high when the counter value&lt;output comparison value; otherwise, set to low)<br/>           111: PWM mode 2 (set to high when the counter value&gt;output comparison value; otherwise, set to low)<br/>           Note: When the protection level is 3 and the channel is configured as output, this bit cannot be modified. In PWM modes 1 and 2, the OC1REF level changes when the comparison result changes or when the output comparison mode changes from freeze mode to PWM mode.</p> |
| 7     | OC1CEN | R/W | <p>Output Compare Channel1 Clear Enable<br/>           0: OC1REF is unaffected by ETRF input.<br/>           1: When high level of ETRF input is detected, OC1REF=0</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 9:8   | CC2SEL | R/W | <p>Capture/Compare Channel2 Select<br/>           This bit defines the input/output direction and the selected input pin.<br/>           00: CC2 channel is output<br/>           01: CC2 channel is input, and IC2 is mapped on TI2<br/>           10: CC2 channel is input, and IC2 is mapped on TI1<br/>           11: CC2 channel is input, and IC2 is mapped on TRC, and only works in internal trigger input<br/>           Note: This bit can be written only when the channel is closed (TMRx_CCEN register CC2EN=0).</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 10    | OC2FEN | R/W | Output Compare Channel2 Preload Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 11    | OC2PEN | R/W | Output Compare Channel2 Buffer Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 14:12 | OC2MOD | R/W | Output Compare Channel1 Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 15    | OC2CEN | R/W | Output Compare Channel2 Clear Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

**Input capture mode:**

| Field | Name   | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------|--------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0   | CC1SEL | R/W | Capture/Compare Channel 1 Select<br>00: CC1 channel is output<br>01: CC1 channel is input, and IC1 is mapped on TI1<br>10: CC1 channel is input, and IC1 is mapped on TI2<br>11: CC1 channel is input, and IC1 is mapped on TRC, and only works in internal trigger input<br>Note: This bit can be written only when the channel is closed (TMRx_CCEN register CC1EN=0).                                                                                                                                                                           |
| 3:2   | IC1PSC | R/W | Input Capture Channel 1 Prescaler Configure<br>00: PSC=1<br>01: PSC=2<br>10: PSC=4<br>11: PSC=8<br>PSC is prescaled factor, which triggers capture once every PSC events.                                                                                                                                                                                                                                                                                                                                                                          |
| 7:4   | IC1F   | R/W | Input Capture Channel 1 Filter Configuration<br>0000: Filter disabled, sampling by f <sub>TTS</sub><br>0001: DIV=1, N=2<br>0010: DIV=1, N=4<br>0011: DIV=1, N=8<br>0100: DIV=2, N=6<br>0101: DIV=2, N=8<br>0110: DIV=4, N=6<br>0111: DIV=4, N=8<br>1000: DIV=8, N=6<br>1001: DIV=8, N=8<br>1010: DIV=16, N=5<br>1011: DIV=16, N=6<br>1100: DIV=16, N=8<br>1101: DIV=32, N=5<br>1110: DIV=32, N=6<br>1111: DIV=32, N=8<br>Sampling frequency=timer clock frequency/DIV; the filter length=N, indicating that a jump is generated by every N events. |
| 9:8   | CC2SEL | R/W | Capture/Compare Channel 2 Select<br>00: CC2 channel is output<br>01: CC2 channel is input, and IC2 is mapped on TI1<br>10: CC2 channel is input, and IC2 is mapped on TI2<br>11: CC2 channel is input, and IC2 is mapped on TRC, and only works in internal trigger input<br>Note: This bit can be written only when the channel is closed (TMRx_CCEN register CC2EN=0).                                                                                                                                                                           |
| 11:10 | IC2PSC | R/W | Input Capture Channel 2 Prescaler Configuration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 15:12 | IC2F   | R/W | Input Capture Channel 2 Filter Configuration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

#### 14.6.8 Capture/Comparison mode register 2 (TMRx\_CCM2)

Offset address: 0x1C

Reset value: 0x0000

Refer to the description of the above CCM1 register.

**Output comparison mode:**

| Field | Name   | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|--------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0   | CC3SEL | R/W | <p>Capture/Compare Channel 1 Selection<br/>           This bit defines the input/output direction and the selected input pin.<br/>           00: CC3 channel is output<br/>           01: CC3 channel is input, and IC3 is mapped on TI3<br/>           10: CC3 channel is input, and IC3 is mapped on TI4<br/>           11: CC3 channel is input, and IC3 is mapped on TRC, and only works in internal trigger input<br/>           Note: This bit can be written only when the channel is closed (TMRx_CCEN register CC3EN=0).</p> |
| 2     | OC3FEN | R/W | <p>Output Compare Channel3 Fast Enable<br/>           0: Disable<br/>           1: Enable<br/>           This bit is used to improve the response of the capture/comparison output to the trigger input event.</p>                                                                                                                                                                                                                                                                                                                    |
| 3     | OC3PEN | R/W | Output Compare Channel3 Preload Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 6:4   | OC3MOD | R/W | Output Compare Channel3 Mode Configure                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 7     | OC3CEN | R/W | <p>Enable clear of output comparison channel 3 (Output Compare Channel3 Clear Enable)<br/>           0: OC3REF is unaffected by ETRF input.<br/>           1: When high level of ETRF input is detected, OC1REF=0</p>                                                                                                                                                                                                                                                                                                                 |
| 9:8   | CC4SEL | R/W | <p>Capture/Compare Channel 4 Selection<br/>           This bit defines the input/output direction and the selected input pin.<br/>           00: CC4 channel is output<br/>           01: CC4 channel is input, and IC4 is mapped on TI4<br/>           10: CC4 channel is input, and IC4 is mapped on TI3<br/>           11: CC4 channel is input, and IC4 is mapped on TRC, and only works in internal trigger input<br/>           Note: This bit can be written only when the channel is closed (TMRx_CCEN register CC4EN=0).</p> |
| 10    | OC4FEN | R/W | Output Compare Channel4 Preload Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 11    | OC4PEN | R/W | Output Compare Channel4 Buffer Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 14:12 | OC4MOD | R/W | Output Compare Channel4 Mode Configure                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 15    | OC4CEN | R/W | Output Compare Channel4 Clear Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

#### Input capture mode:

| Field | Name   | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|--------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0   | CC3SEL | R/W | <p>Capture/Compare Channel 3 Select<br/>           00: CC3 channel is output<br/>           01: CC3 channel is input, and IC3 is mapped on TI3<br/>           10: CC3 channel is input, and IC3 is mapped on TI4<br/>           11: CC3 channel is input, and IC3 is mapped on TRC, and only works in internal trigger input<br/>           Note: This bit can be written only when the channel is closed (TMRx_CCEN register CC3EN=0).</p> |
| 3:2   | IC3PSC | R/W | <p>Input Capture Channel 3 Prescaler Configuration<br/>           00: PSC=1<br/>           01: PSC=2<br/>           10: PSC=4<br/>           11: PSC=8<br/>           PSC is prescaled factor, which triggers capture once every PSC events.</p>                                                                                                                                                                                            |

| Field | Name   | R/W | Description                                                                                                                                                                                                                                                                                                                                                              |
|-------|--------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:4   | IC3F   | R/W | Input Capture Channel 3 Filter Configuration                                                                                                                                                                                                                                                                                                                             |
| 9:8   | CC4SEL | R/W | Capture/Compare Channel 4 Select<br>00: CC4 channel is output<br>01: CC4 channel is input, and IC4 is mapped on TI4<br>10: CC4 channel is input, and IC4 is mapped on TI3<br>11: CC4 channel is input, and IC4 is mapped on TRC, and only works in internal trigger input<br>Note: This bit can be written only when the channel is closed (TMRx_CCEN register CC4EN=0). |
| 11:10 | IC4PSC | R/W | Input Capture Channel 4 Perscaler Configuration                                                                                                                                                                                                                                                                                                                          |
| 15:12 | IC4F   | R/W | Input Capture Channel 4 Filter Configuration                                                                                                                                                                                                                                                                                                                             |

#### 14.6.9 Capture/Comparison enable register (TMRx\_CCEN)

Offset address: 0x20

Reset value: 0x0000

| Field | Name    | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|---------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | CC1EN   | R/W | Capture/Compare Channel1 Output Enable<br><b>When the capture/comparison channel 1 is configured as output:</b><br>0: Output is disabled<br>1: Output is enabled<br><b>When the capture/comparison channel 1 is configured as input:</b><br>This bit determines whether the value CNT of the counter can be captured and enter TMRx_CC1 register<br>0: Capture is disabled<br>1: Capture is enabled                                                           |
| 1     | CC1POL  | R/W | Capture/Compare Channel1 Output Polarity Configure<br><b>When CC1 channel is configured as output:</b><br>0: OC1 high level is valid<br>1: OC1 low level is valid<br><b>When CC1 channel is configured as input:</b><br>0: Phase not reversed: select IC1 signal as th trigger or capture signal<br>1: Phase revered, select reverse signal of IC1 as the trigger or capture signal<br>Note: When the protection level is 2 or 3, this bit cannot be modified |
| 2     | CC1NEN  | R/W | Capture/Compare Channel1 Complementary Output Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                                                                                                                                               |
| 3     | CC1NPOL | R/W | Capture/Compare Channel1 Complementary Output Polarity<br>0: OC1N high level is valid<br>1: OC1N low level is valid<br>Note: When the protection level is 2 or 3, this bit cannot be modified                                                                                                                                                                                                                                                                 |
| 4     | CC2EN   | R/W | Capture/Compare Channel2 Output Enable<br>Refer to CCEN_CC1EN                                                                                                                                                                                                                                                                                                                                                                                                 |
| 5     | CC2POL  | R/W | Capture/Compare Channel2 Output Polarity Configure<br>Refer to CCEN_CC1POL                                                                                                                                                                                                                                                                                                                                                                                    |
| 6     | CC2NEN  | R/W | Capture/Compare Channel1 Complementary Output Enable<br>Refer to CCEN_CC1NEN                                                                                                                                                                                                                                                                                                                                                                                  |
| 7     | CC2NPOL | R/W | Capture/Compare Channel2 Complementary Output Polarity Configure<br>Refer to CCEN_CC1NPOL                                                                                                                                                                                                                                                                                                                                                                     |

| Field | Name    | R/W | Description                                                                               |
|-------|---------|-----|-------------------------------------------------------------------------------------------|
| 8     | CC3EN   | R/W | Capture/Compare Channel3 Output Enable<br>Refer to CCEN_CC1EN                             |
| 9     | CC3POL  | R/W | Capture/Compare Channel3 Output Polarity Configure<br>Refer to CCEN_CC1POL                |
| 10    | CC3NEN  | R/W | Capture/Compare Channel3 Complementary Output Enable<br>Refer to CCEN_CC1NEN              |
| 11    | CC3NPOL | R/W | Capture/Compare Channel3 Complementary Output Polarity Configure<br>Refer to CCEN_CC1NPOL |
| 12    | CC4EN   | R/W | Capture/Compare Channel4 Output Enable<br>Refer to CCEN_CC1EN                             |
| 13    | CC4POL  | R/W | Capture/Compare Channel4 Output Polarity<br>Refer to CCEN_CC1POL                          |
| 15:14 |         |     | Reserved                                                                                  |

#### 14.6.10 Counter register (TMRx\_CNT)

Offset address: 0x24

Reset value: 0x0000

| Field | Name | R/W | Description   |
|-------|------|-----|---------------|
| 15:0  | CNT  | R/W | Counter Value |

#### 14.6.11 Prescaler register (TMRx\_PSC)

Offset address: 0x28

Reset value: 0x0000

| Field | Name | R/W | Description                                                                          |
|-------|------|-----|--------------------------------------------------------------------------------------|
| 15:0  | PSC  | R/W | Prescaler Value<br>Clock frequency of counter ( $CK_{CNT}$ ) = $f_{CK\_PSC}/(PSC+1)$ |

#### 14.6.12 Auto reload register (TMRx\_AUTORLD)

Offset address: 0x2C

Reset value: 0xFFFF

| Field | Name    | R/W | Description                                                                              |
|-------|---------|-----|------------------------------------------------------------------------------------------|
| 15:0  | AUTORLD | R/W | Auto Reload Value<br>When the value of auto reload is empty, the counter will not count. |

#### 14.6.13 Repeat count register (TMRx\_REPCNT)

Offset address: 0x30

Reset value: 0x0000

| Field | Name   | R/W | Description                                                                                                                                                                                                                                                                                       |
|-------|--------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0   | REPCNT | R/W | Repetition Counter Value<br>When the count value of the repeat counter is reduced to 0, an update event will be generated, and the counter will start counting again from the REPCNT value; the new value newly written to this register is valid only when an update event occurs in next cycle. |
| 15:8  |        |     | Reserved                                                                                                                                                                                                                                                                                          |

#### 14.6.14 Channel 1 capture/comparison register (TMRx\_CC1)

Offset address: 0x34

Reset value: 0x0000

| Field | Name | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0  | CC1  | R/W | <p>Capture/Compare Channel 1 Value</p> <p><b>When the capture/comparison channel 1 is configured as input mode:</b><br/>CC1 contains the counter value transmitted by the last input capture channel 1 event.</p> <p><b>When the capture/comparison channel 1 is configured as output mode:</b><br/>CC1 contains the current load capture/comparison register value</p> <p>Compare the value CC1 of the capture and comparison channel 1 with the value CNT of the counter to generate the output signal on OC1.</p> <p>When the output comparison preload is disabled (OC1PEN=0 for TMRx_CCM1 register), the written value will immediately affect the output comparison results;</p> <p>If the output comparison preload is enabled (OC1PEN=1 for TMRx_CCM1 register), the written value will affect the output comparison result when an update event is generated.</p> |

#### 14.6.15 Channel 2 capture/comparison register (TMRx\_CC2)

Offset address: 0x38

Reset value: 0x0000

| Field | Name | R/W | Description                                                     |
|-------|------|-----|-----------------------------------------------------------------|
| 15:0  | CC2  | R/W | <p>Capture/Compare Channel 2 Value</p> <p>Refer to TMRx_CC1</p> |

#### 14.6.16 Channel 3 capture/comparison register (TMRx\_CC3)

Offset address: 0x3C

Reset value: 0x0000

| Field | Name | R/W | Description                                                     |
|-------|------|-----|-----------------------------------------------------------------|
| 15:0  | CC3  | R/W | <p>Capture/Compare Channel 3 Value</p> <p>Refer to TMRx_CC1</p> |

#### 14.6.17 Channel 4 capture/comparison register (TMRx\_CC4)

Offset address: 0x40

Reset value: 0x0000

| Field | Name | R/W | Description                                                     |
|-------|------|-----|-----------------------------------------------------------------|
| 15:0  | CC4  | R/W | <p>Capture/Compare Channel 4 Value</p> <p>Refer to TMRx_CC1</p> |

#### 14.6.18 Brake and dead zone register (TMRx\_BDT)

Offset address: 0x44

Reset value: 0x0000

Note: According to the lock setting, AOEN, BRKPOL, BRKEN, IMOS, RMOS and DTS[7:0] bits all can be write-protected, and it is necessary to configure them when writing to TMRx\_BDT register for the first time.

| Field | Name | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0   | DTS  | R/W | <p>Dead Time Setup</p> <p>DT is the dead duration, and the relationship between DT and register DTS is as follows:</p> <p>DTS[7:5]=0xx=&gt;DT=DTS[7:0]×T<sub>DTS</sub>, T<sub>DTS</sub>=TDTS;</p> <p>DTS[7:5]=10x=&gt;DT= (64+DTS[5:0]) ×T<sub>DTS</sub>, T<sub>DTS</sub>=2×T<sub>DTS</sub>;</p> <p>DTS[7:5]=110=&gt;DT= (32+DTS[4:0]) ×T<sub>DTS</sub>, T<sub>DTS</sub>=8×T<sub>DTS</sub>;</p> <p>DTS[7:5]=111=&gt;DT= (32+DTS[4:0]) ×T<sub>DTS</sub>, T<sub>DTS</sub>=16×T<sub>DTS</sub>;</p> <p>For example: assuming T<sub>DTS</sub>=125ns (8MHZ), the dead time setting is as follows:</p> <p>If the step time is 125ns, the dead time can be set from 0 to 15875ns;</p> <p>If the step time is 250ns, the dead time can be set from 16us to 31750ns;</p> |

| Field | Name    | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------|---------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |         |     | If the step time is 1us, the dead time can be set from 32us to 63us;<br>If the step time is 2us, the dead time can be set from 64us to 126us.<br>Note: Once LOCK level (LOCKCFG bit in TMRx_BDT register) is set to 1, 2 or 3, these bits cannot be modified.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 9:8   | LOCKCFG | R/W | <p>Lock Write Protection Mode Configuration<br/>           00: Without Lock write protection level; the register can be written directly<br/>           01: Lock write protection level 1<br/>           It cannot be written to DTS, BRKEN, BRKPOL and AOEN bits of TMRx_BDT, and OCxOIS and OCxNOIS bits of TMRx_CTRL2 register.<br/>           02: Lock write protection level 2<br/>           It is not allowed to write to all bits with protection level 1 and write to the CCxPOL and OCxNPOL bits in TMRx_CCEN register and the RMOS and IMOS bits in TMRx_BDT register.<br/>           11: Lock write protection level 3<br/>           It is not allowed to write to all bits with protection level 2, and write to the OCxMOD and OCxPEN bits of TMRx_CCMx register.<br/>           Note: After system reset, the lock write protect bit can only be written once.</p> |
| 10    | IMOS    | R/W | <p>Idle Mode Off-state Configure<br/>           Idle mode means MOEN=0; closed means CcxEN=0; this bit describes the impact of different values for this bit on the output waveform when MOEN=0 and CcxEN changes from 0 to 1.<br/>           0: OCx/OCxN output is disabled<br/>           1: If CCxEN=1, the invalid level is output during the dead time (the specific level value is affected by the polarity configuration), and the idle level is output after the dead time</p>                                                                                                                                                                                                                                                                                                                                                                                             |
| 11    | RMOS    | R/W | <p>Configure the off state in run mode<br/>           Run mode means MOEN=1; closed means CcxEN=0; this bit describes the impact of different values for this bit on the output waveform when MOEN=1 and CcxEN changes from 0 to 1.<br/>           0: OCx/OCxN output is disabled<br/>           1: OCx/OCxN first outputs invalid level (the specific level value is affected by the polarity configuration)</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 12    | BRKEN   | R/W | <p>Brake Function Enable<br/>           0: Disable<br/>           1: Enable<br/>           Note: When the protection level is 1, this bit cannot be modified.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 13    | BRKPOL  | R/W | <p>Brake Polarity Configure<br/>           0: The brake input BRK is valid at low level<br/>           1: The brake input BRK is valid at high level<br/>           Note: When the protection level is 1, this bit cannot be modified. Writing to this bit requires an APB clock delay before it can be used.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 14    | AOEN    | R/W | <p>Automatic Output Enable<br/>           0: MOEN can only be set to 1 by software<br/>           1: MOEN can be set to 1 by software or be automatically set to 1 in next update event (braking input is ineffective)<br/>           Note: When the protection level is 1, this bit cannot be modified.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 15    | MOEN    | R/W | <p>PWM Main Output Enable<br/>           0: Disable the output of OCx and OCxN or force the output of idle state<br/>           1: When CCxEN and CCxNEN bits of the TMRx_CCEN register are set, turn on OCx and OCxN output<br/>           When the brake input is valid, it is cleared by hardware asynchronously.<br/>           Note: Setting to 1 by software or setting to 1 automatically depends on AOEN bit of the TMRx_BDT register.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                 |

#### 14.6.19 DMA control software (TMRx\_DCTRL)

Offset address: 0x48

Reset value: 0x0000

| Field | Name   | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|--------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4:0   | DBADDR | R/W | <p>DMA Base Address Setup<br/>These bits define the base address of DMA in continuous mode (when reading or writing TMRx_DMADDR register), and DBADDR is defined as the offset from the address of TMRx_CTRL1 register:</p> <p>00000: TMRx_CTRL1<br/>00001: TMRx_CTRL2<br/>00010: TMRx_SMCTRL<br/>.....</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 7:5   |        |     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 12:8  | DBLEN  | R/W | <p>DMA Burst Transfer Length Setup<br/>These bits define the transfer length and transfer times of DMA in continuous mode. The data transferred can be 16 bits and 8 bits.<br/>When reading/writing TMRx_DMADDR register, the timer will conduct a continuous transmission;</p> <p>00000: Transmission once<br/>00001: Transmission twice<br/>00010: Transmission for three times<br/>.....<br/>10001: Transmission for 18 times<br/>The transmission address formula is as follows:<br/>Transmission address=TMRx_CTRL1 address (slave address)<br/>+DBADDR+DMA index; DMA index=DBLEN<br/>For example: DBLEN=7, DBADDR=TMR1_CTRL1 (slave address) means the address of the data to be transmitted, while the address +DBADDR+7 of TMRx_CTRL1 means the address of the data to be written/read,<br/>Data transmission will occur to: TMRx_CTRL1 address + seven registers starting from DBADDR.<br/>The data transmission will change according to different DMA data length:<br/>(1) When the transmission data is set to 16 bits, the data will be transmitted to seven registers<br/>(2) When the transmission data is set to 8 bits, the data of the first register is the MSB bit of the first data, the data of the second register is the LSB bit of the first data, and the data will still be transmitted to seven registers.</p> |
| 15:13 |        |     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

#### 14.6.20 DMA address register of continuous mode (TMRx\_DMADDR)

Offset address: 0x4C

Reset value: 0x0000

| Field | Name   | R/W | Description                                                                                                                                                                                                                                                                                                                                                                       |
|-------|--------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0  | DMADDR | R/W | <p>DMA Register for Burst Transfer<br/>Read or write operation access of TMRx_DMADDR register may lead to access operation of the register in the following address:<br/>TMRx_CTRL1 address + (DBADDR+DMA index) ×4<br/>Wherein:<br/>"TMRx_CTRL1 address" is the address of control register 1 (TMRx_CTRL1);<br/>"DBADDR" is the base address defined in TMRx_DCTRL register;</p> |

| Field | Name | R/W | Description                                                                                                        |
|-------|------|-----|--------------------------------------------------------------------------------------------------------------------|
|       |      |     | "DMA index" is the offset automatically controlled by DMA, and it depends on DBLEN defined in TMRx_DCTRL register. |

## 15 General-purpose Timer (TMR2/3/4)

### 15.1 Introduction

The general-purpose timer takes the time base unit as the core, and has the functions of input capture and output comparison, and can be used to measure the pulse width, frequency and duty cycle, and generate the output waveform. It includes a 16-bit auto reload counter (realize count-up, count-down and Center-aligned count).

The timer and timer are independent of each other, and they can achieve synchronization and cascading.

### 15.2 Main Characteristics

- (1) Timebase unit
  - Counter: 16-bit counter, count-up, count-down and Center-aligned count.
  - Prescaler: 16-bit programmable prescaler
  - Auto reloading function
- (2) Clock source selection
  - Internal clock
  - External input
  - External trigger
  - Internal trigger
- (3) Input capture function
  - Counting function
  - PWM input
  - Encoder interface mode
- (4) Output comparison function
  - PWM output mode
  - Forced output mode
  - Single-pulse mode
- (5) Master/Slave mode controller of timer
  - Timers can be synchronized and cascaded
  - Support multiple slave modes and synchronization signals
- (6) Interrupt and DMA request event
  - Update event (counter overrun/underrun, counter initialization)
  - Trigger event (counter start, stop, internal/external trigger)
  - Input capture
  - Output comparison

## 15.3 Structure Block Diagram

Figure 42 General-purpose Timer Structure Block Diagram



## 15.4 Functional Description

### 15.4.1 Clock Source Selection

The general-purpose timer has four clock sources

#### Internal clock

It is TMRx\_CLK from RCM, namely the driving clock of the timer; when the slave mode controller is disabled, the clock source CK\_PSC of the prescaler is driven by the internal clock CK\_INT.

#### External clock mode 1

The trigger signal generated from the input channel TI1/2/3/4 of the timer after polarity selection and filtering is connected to the slave mode controller to control the work of the counter. Besides, the pulse signal generated by the input of Channel 1 after double-edge detection of the rising edge and the falling edge is logically equal or the future signal is TI1F\_ED signal, namely double-edge signal of TIF\_ED. Specially the PWM input can only be input by TI1/2.

#### External clock mode 2

After polarity selection, frequency division and filtering, the signal from external

trigger interface (ETR) is connected to slave mode controller through trigger input selector to control the work of counter.

### Internal trigger input

The timer is set to work in slave mode, and the clock source is the output signal of other timers. At this time, the clock source has no filtering, and the synchronization or cascading between timers can be realized. The master mode timer can reset, start, stop or provide clock for the slave mode timer.

## 15.4.2 Timebase Unit

The time base unit in the general-purpose timer contains four registers

- Counter register (CNT) 16 bits
- Auto reload register (AUTORLD) 16 bits
- Prescaler register (PSC) 16 bits

### Counter CNT

There are three counting modes for the counter in the general-purpose timer

- Count-up mode
- Count-down mode
- Center-aligned mode

### Count-up mode

Set to the count-up mode by CNTDIR bit of configuration control register (TMRx\_CTRL1).

When the counter is in count-up mode, the counter will count up from 0; every time a pulse is generated, the counter will increase by 1 and when the value of the counter (TMRx\_CNT) is equal to the value of the auto reload (TMRx\_AUTORLD), the counter will start to count again from 0, a count-up overrun event will be generated, and the value of the auto reload (TMRx\_AUTORLD) is written in advance.

When the counter overruns, an update event will be generated. At this time, the auto reload shadow register and the prescaler buffer will be updated. The update event can be disabled by UD bit of configuration control register TMRx\_CTRL1.

The figure below is Timing Diagram when Division Factor is 1 or 2 in Count-up Mode

Figure 43 Timing Diagram when Division Factor is 1 or 2 in Count-up Mode



### Count-down mode

Set to the count-down mode by CNTDIR bit of configuration control register (TMRx\_CTRL1).

When the counter is in count-down mode, the counter will start to count down from the value of the auto reload (TMRx\_AUTORLD); every time a pulse is generated, the counter will decrease by 1 and when it becomes 0, the counter will start to count again from (TMRx\_AUTORLD), meanwhile, a count-down overrun event will be generated, and the value of the auto reload (TMRx\_AUTORLD) is written in advance.

When the counter overruns, an update event will be generated. At this time, the auto reload shadow register and the prescaler buffer will be updated. The update event can be disabled by configuring the UD bit of the TMRx\_CTRL1 register.

Figure 44 Timing Diagram when Division Factor is 1 or 2 in Count-down Mode



### Center-aligned mode

Set to the Center-aligned mode by CNTDIR bit of configuration control register (TMRx\_CTRL1).

When the counter is in Center-aligned mode, the counter counts up from 0 to the value of auto reload (TMRx\_AUTORLD), then counts down to 0 from the value of the auto reload (TMRx\_AUTORLD), which will repeat; in counting up, when the counter value is (AUTORLD-1), a counter overrun event will be generated; in counting down, when the counter value is 1, a counter underrun event will be generated.

Figure 45 Timing Diagram when Division Factor is 1 or 2 in Center-aligned Mode



### Prescaler PSC

The prescaler is 16 bits and programmable, and it can divide the clock frequency of the counter to any value between 1 and 65536 (controlled by TMRx\_PSC register), and after frequency division, the clock will drive the counter CNT to count. The prescaler has a buffer, which can be changed during running.

#### 15.4.3 Input Capture

##### Input capture channel

The general-purpose timer has four independent capture/comparison channels, each of which is surrounded by a capture/comparison register.

In the input capture, the measured signal will enter from the external pin T1/2/3/4 of the timer, first pass through the edge detector and input filter, and then into the capture channel. Each capture channel has a corresponding capture register. When the capture occurs, the value of the counter CNT will be latched in the capture register CCx. Before entering the capture register, the signal will pass through the prescaler, which is used to set how many events to capture at a time.

##### Input capture application

Input capture is used to capture external events, and can give the time flag to indicate the occurrence time of the event and measure the pulse jump edge events (measure the frequency or pulse width), for example, if the selected edge appears on the input pin, the TMRx\_CCx register will capture the current value of the counter and the CCxIFLG bit of the state register TMRx\_STS will be set to 1; if CCxIEN=1, an interrupt will be generated.

In capture mode, the timing, frequency, cycle and duty cycle of a waveform can be measured. In the input capture mode, the edge selection is set to rising edge detection. When the rising edge appears on the capture channel, the first capture occurs, at this time, the value of the counter CNT will be latched in the capture register CCx; at the same time, it will enter the capture interrupt, a capture will be recorded in the interrupt service program and the value will be recorded. When the next rising edge is detected, the second capture occurs, the value of counter CNT will be latched in capture register CCx again, at this time, it will enter the capture interrupt again, the value of capture register will be read, and the cycle of this pulse signal will be obtained through capture.

#### 15.4.4 Output Comparison

There are eight modes of output comparison: freeze, channel x is valid level when matching, channel x is invalid level when matching, flip, force is invalid, force is valid, PWM1 and PWM2 modes, which are configured by OCxMOD bit in TMRx\_CCMx register and can control the waveform of output signal in output comparison mode.

##### Output comparison application

In the output comparison mode, the position, polarity, frequency and time of the pulse generated by the timer can be controlled.

When the value of the counter is equal to that of the capture/comparison register, the channel output can be set as high level, low level or flip by configuring the OCxMOD bit in TMRx\_CCMx register and the CCxPOL bit in the output polarity TMRx\_CCEN register.

When CCxIFLG=1 in TMRx\_STS register, if CCxIEN=1 in TMRx\_DIEN register, an interrupt will be generated; if CCDSEL=1 in TMRx\_CTRL2 register, DMA request will be generated.

#### 15.4.5 PWM Output Mode

PWM mode is an adjustable pulse signal output by the timer. The pulse width of the signal is determined by the value of the comparison register CCx, and the cycle is determined by the value of the auto reload AUTORLD.

PWM output mode contains PWM mode 1 and PWM mode 2; PWM mode 1 and PWM mode 2 are divided into count-up, count-down and center alignment counting; in PWM mode 1, if the value of the counter CNT is less than the value of the comparison register CCx, the output level will be valid; otherwise, it will be invalid.

Set the timing diagram in PWM1 mode when CCx=5, AUTORLD=7

Figure 46 PWM1 Count-up Mode Timing Diagram



Figure 47 PWM1 Count-down Mode Timing Diagram



Figure 48 PWM1 Center-aligned Mode Timing Diagram



In PWM mode 2, if the value of the counter CNT is less than that of the comparison register CCx, the output level will be invalid; otherwise, it will be valid.

Set the timing diagram in PWM2 mode when CCx=5, AUTORLD=7

Figure 49 PWM2 Count-up Mode Timing Diagram



Figure 50 PWM2 Count-down Mode Timing Diagram



Figure 51 PWM2 Center-aligned Mode Timing Diagram



#### 15.4.6 PWM Input Mode

PWM input mode is a particular case of input capture.

In PWM input mode, as only TI1FP1 and TI1FP2 are connected to the slave mode controller, input can be performed only through the channels TMRx\_CH1 and TMRx\_CH2, which need to occupy the capture registers of CH1 and CH2.

In the PWM input mode, the PWM signal enters from TMRx\_CH1, and the signal will be divided into two channels, one can measure the cycle and the other can measure the duty cycle. In the configuration, it is only required to set the polarity of one channel, and the other will be automatically configured with the opposite polarity.

In this mode, the slave mode controller should be configured as the reset mode (SMFSEL bit of TMRx\_SMCTRL register)

Figure 52 PWM Input Mode Timing Diagram



### 15.4.7 Single-pulse Mode

The single-pulse mode is a special case of timer comparison output, and is also a special case of PWM output mode.

Set SPMEN bit of TMRx\_CTRL1 register, and select the single-pulse mode. After the counter is started, a certain number of pulses will be output before the update event occurs. When an update event occurs, the counter will stop counting, and the subsequent PWM waveform output will no longer be changed.

After a certain controllable delay, a pulse with controllable pulse width is generated in single-pulse mode through the program. The delay time is defined by the value of TMRx\_CCx register; in the count-up mode, the delay time is CCx and the pulse width is AUTORLD-CCx; in the count-down mode, the delay time is AUTORLD-CCx and the pulse width is CCx.

Figure 53 Timing Diagram in Single-pulse Mode



#### 15.4.8 Forced Output Mode

In the forced output mode, the comparison result is ignored, and the corresponding level is directly output according to the configuration instruction.

- CCxSEL=00 for TMRx\_CCMx register, set CCx channel as output
- OCxMOD=100/101 for TMRx\_CCMx register, set to force OCxREF signal to invalid/valid state

In this mode, the corresponding interrupt and DMA request will still be generated.

#### 15.4.9 Encoder Interface Mode

The encoder interface mode is equivalent to an external clock with direction selection. In the encoder interface mode, the content of the timer can always indicate the position of the encoder.

The selection methods of encoder interface is as follows:

- By setting SMFSEL bit of TMRx\_SMCTRL register, set the counter to count on the edge of TI1 channel /TI2 channel, or count on the edge of TI1 and TI2 at the same time.
- Select the polarity of TI1 and TI2 by setting the CC1POL and CC2POL bits of TMRx\_CCEN register.
- Select to filter or not by setting the IC1F and IC2F bits of TMRx\_CCM1 register.

The two input TI1 and TI2 can be used as the interface of incremental encoder. The counter is driven by the effective jump of the signals TI1FP1 and TI2FP2 after filtering and edge selection in TI1 and TI2.

The count pulse and direction signal are generated according to the input signals of TI1 and TI2

- The counter will count up/down according to the jumping sequence of the input signal
- Set CNTDIR of control register TMRx\_CTRL1 to be read-only (CNTDIR will be re-calculated due to jumping of any input end)

The change mechanism of counter count direction is shown in the figure below

Table 54 Relationship between Count Direction and Encoder

| Effective edge           |              | Count only in TI1 |            | Count only in TI2 |            | Count in both TI1 and TI2 |            |
|--------------------------|--------------|-------------------|------------|-------------------|------------|---------------------------|------------|
| Level of relative signal |              | High              | Low        | High              | Low        | High                      | Low        |
| TI1FP1                   | Rising edge  | —                 |            | Count down        | Count up   | Count down                | Count up   |
|                          | Falling edge |                   |            | Count up          | Count down | Count up                  | Count down |
| TI2FP2                   | Rising edge  | Count up          | Count down | —                 |            | Count up                  | Count down |
|                          | Falling edge | Count down        | Count up   |                   |            | Count down                | Count up   |

The external incremental encoder can be directly connected with MCU, not needing external interface logic, so the comparator is used to convert the differential output of the encoder to digital signal to increase the immunity from noise interference.

Among the following examples,

- IC1FP1 is mapped to TI1
- IC2FP2 is mapped to TI2
- Neither IC1FP1 nor IC2FP2 is reverse phase
- The input signal is valid at the rising edge and falling edge
- Enable the counter

Figure 54 Counter Operation Example in Encoder Mode



For example, when TI1 is at low level, and TI2 is in rising edge state, the counter will count up.

Figure 55 Example of Encoder Interface Mode of IC1FP1 Reversed Phase



For example, when TI1 is at low level, and the rising edge of TI2 jumps, the counter will count down.

#### 15.4.10 Slave Mode

TMRx timer can synchronize external trigger

- Reset mode
- Gated mode
- Trigger mode

SMFSEL bit in TMRx\_SMCTRL register can be set to select the mode

SMFSEL=100 set the reset mode, SMFSEL=101 set the gated mode,  
SMFSEL=110 set the trigger mode.

In the reset mode, when a trigger input event occurs, the counter and prescaler will be initialized, and the rising edge of the selected trigger input (TRGI) will reinitialize the counter and generate a signal to update the register.

In the gated mode, the enable of the counter depends on the high level of the selected input. When the trigger input is high, the clock of the counter will be started. Once the trigger input becomes low, the counter will stop (but not be reset). The start and stop of the counter are controlled.

In the trigger mode, the enable of the counter depends on the event on the selected input, the counter is started (but is not reset) at the rising edge of the trigger input, and only the start of the counter is controlled.

#### 15.4.11 Timer Interconnection

See TMR1 Timer Interconnection for details

#### 15.4.12 Interrupt and DMA Request

The timer can generate an interrupt when an event occurs during operation

- Update event (counter overrun/underrun, counter initialization)
- Trigger event (counter start, stop, internal/external trigger)
- Capture/Comparison event

Some internal interrupt events can generate DMA requests, and special interfaces can enable or disable DMA requests.

### 15.4.13 Debug mode

The TMR2/3/4 can be configured in debug mode and choose to stop or continue to work. It depends on the TMRx\_STS bit of DBGMCU\_CFG register in DBGMCU module.

### 15.4.14 Clear OCxREF Signal when External Events Occur

This function is used for output comparison and PWM mode.

In one channel, the high level of ETRF input port will reduce the signal of OCxREF to low level, and the OCxCEN bit in capture/comparison register TMRx\_CCMx is set to 1, and OCxREF signal will remain low until the next update event.

Set TMRx to PWM mode, close the external trigger prescaler, and disable the external trigger mode 2; when ETRF input is high, set OCxCEN=0, and the output OCxREF signal is shown in the figure below.

Figure 56 OCxREF Timing Diagram



Set TMRx to PWM mode, close the external trigger prescaler, and disable the external trigger mode 2; when ETRF input is high, set OCxCEN=1, and the output OCxREF signal is shown in the figure below.

Figure 57 OCxREF Timing Diagram



## 15.5 Register Address Mapping

In the following table, all registers of the general-purpose timer are mapped to a 16-bit addressable (address) space.

Table 55 General-purpose Timer Register Address Mapping

| Register name | Description                             | Offset address |
|---------------|-----------------------------------------|----------------|
| TMRx_CTRL1    | Control register 1                      | 0x00           |
| TMRx_CTRL2    | Control register 2                      | 0x04           |
| TMRx_SMCTRL   | Slave mode control register             | 0x08           |
| TMRx_DIEN     | DMA/Interrupt enable register           | 0x0C           |
| TMRx_STS      | State register                          | 0x10           |
| TMRx_CEG      | Control event generation register       | 0x14           |
| TMRx_CCM1     | Capture/Comparison mode register 1      | 0x18           |
| TMRx_CCM2     | Capture/Comparison mode register 2      | 0x1C           |
| TMRx_CCEN     | Capture/Comparison enable register      | 0x20           |
| TMRx_CNT      | Counter register                        | 0x24           |
| TMRx_PSC      | Prescaler register                      | 0x28           |
| TMRx_AUTORLD  | Auto reload register                    | 0x2C           |
| TMRx_CC1      | Channel 1 capture/comparison register   | 0x34           |
| TMRx_CC2      | Channel 2 capture/comparison register   | 0x38           |
| TMRx_CC3      | Channel 3 capure/comparison register    | 0x3C           |
| TMRx_CC4      | Channel 4 capture/comparison register   | 0x40           |
| TMRx_DCTRL    | DMA control register                    | 0x48           |
| TMRx_DMADDR   | DMA address register of continuous mode | 0x4C           |

## 15.6 Register Functional Description

### 15.6.1 Control register 1 (TMRx\_CTRL1)

Offset address: 0x00

Reset value: 0x0000

| Field | Name  | R/W | Description                                                                                                                                                                                                                                                                                                                                               |
|-------|-------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | CNTEN | R/W | <p>Counter Enable<br/>0: Disable<br/>1: Enable</p> <p>When the timer is configured as external clock, gated mode and encoder mode, it is required to write 1 to the bit by software to start regular work; when it is configured as the trigger mode, it can be written to 1 by hardware.</p>                                                             |
| 1     | UD    | R/W | <p>Update Disable<br/>Update event can cause AUTORLD, PSC and CCx to generate the value of update setting.<br/>0: Update event is allowed (UEV)<br/>An update event can occur in any of the following situations:<br/>The counter overruns/underruns;<br/>Set UEG bit;<br/>Update generated by slave mode controller.<br/>1: Update event is disabled</p> |

| Field | Name   | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|--------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2     | URSSEL | R/W | <p>Update Request Source Select<br/>If interrupt or DMA is enabled, the update event can generate update interrupt or DMA request. Different update request sources can be selected through this bit.</p> <p>0: The counter overruns or underruns<br/>Set UEG bit<br/>Update generated by slave mode controller<br/>1: The counter overruns or underruns</p>                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 3     | SPMEN  | R/W | <p>Single Pulse Mode Enable<br/>When an update event is generated, the output level of the channel can be changed; in this mode, the CNTEN bit will be cleared, the counter will be stopped, and the output level of the channel will not be changed.</p> <p>0: Disable<br/>1: Enable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 4     | CNTDIR | R/W | <p>Counter Direction.<br/>When the counter is configured in central alignment mode or encoder mode, the bit is read-only.</p> <p>0: Count up<br/>1: Count down</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 6:5   | CAMSEL | R/W | <p>Center Aligned Mode Select<br/>In the Center-aligned mode, the counter counts up and down alternately; otherwise, it will only count up or down. Different Center-aligned modes affect the timing of setting the output comparison interrupt flag bit of the output channel to 1; when the counter is disabled (CNTEN=0), select the Center-aligned mode.</p> <p>00: Edge alignment mode<br/>01: Center-aligned mode 1 (the output comparison interrupt flag bit of output channel is set to 1 when counting down)<br/>10: Center-aligned mode 2 (the output comparison interrupt flag bit of output channel is set to 1 when counting up)<br/>11: Center-aligned mode 3 (the output comparison interrupt flag bit of output channel is set to 1 when counting up/down)</p> |
| 7     | ARPEN  | R/W | <p>Auto-reload Preload Enable<br/>When the buffer is disabled, the program modification TMRx_AUTORLD will immediately modify the values loaded to the counter; when the buffer is enabled, the program modification TMRx_AUTORLD will modify the values loaded to the counter in the next update event.</p> <p>0: Disable<br/>1: Enable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 9:8   | CLKDIV | R/W | <p>Clock Divide Factor<br/>For the configuration of dead time and digital filter, CK_INT provides the clock, and the dead time and the clock of the digital filter can be adjusted by setting this bit.</p> <p>00: <math>t_{DTS}=t_{CK\_INT}</math><br/>01: <math>t_{DTS}=2 \times t_{CK\_INT}</math><br/>10: <math>t_{DTS}=4 \times t_{CK\_INT}</math><br/>11: Reserved</p>                                                                                                                                                                                                                                                                                                                                                                                                   |
| 15:10 |        |     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

### 15.6.2 Control register 2 (TMRx\_CTRL2)

Offset address: 0x04

Reset value: 0x0000

| Field | Name | R/W | Description |
|-------|------|-----|-------------|
| 2:0   |      |     | Reserved    |

| Field | Name   | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|--------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3     | CCDSEL | R/W | Capture/compare DMA Select<br>0: Send DMA request of CCx when CCx event occurs<br>1: Send DMA request of CCx when an update event occurs                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 6:4   | MMSEL  | R/W | Master Mode Signal Select<br>The signals of timers working in master mode can be used for TRGO, which affects the work of timers in slave mode and cascaded with master timer, and specifically affects the configuration of timers in slave mode.<br>000: Reset; the reset signal of master mode timer is used for TRGO<br>001: Enable; the counter enable signal of master mode timer is used for TRGO<br>010: Update; the update event of master mode timer is used for TRGO<br>011: Comparison pulses; when the master mode timer captures/composes successfully (CCxIFLG=1), a pulse signal is output for TRGO<br>100: Comparison mode 1; OC1REF is used to trigger TRGO<br>101: Comparison mode 2; OC2REF is used to trigger TRGO<br>110: Comparison mode 3; OC3REF is used to trigger TRGO<br>111: Comparison mode 4; OC4REF is used to trigger TRGO |
| 7     | TI1SEL | R/W | Timer Input 1 Selection<br>0: TMRx_CH1 pin is connected to TI1 input<br>1: TMRx_CH1, TMRx_CH2 and TMRx_CH3 pins are connected to TI1 input after exclusive                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 15:8  |        |     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

### 15.6.3 Slave mode control register (TMRx\_SMCTRL)

Offset address: 0x08

Reset value: 0x0000

| Field | Name   | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------|--------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0   | SMFSEL | R/W | Slave Mode Function Select<br>000: Disable the slave mode, the timer can be used as master mode timer to affect the work of slave mode timer; if CTRL1_CNTEN=1, the prescaler is directly driven by the internal clock.<br>001: Encoder mode 1; according to the level of TI1FP1, the counter counts at the edge of TI2FP2.<br>010: Encoder mode 2; according to the level of TI2FP2, the counter counts at the edge of TI1FP1.<br>011: Encoder mode 3; according to the input level of another signal, the counter counts at the edge of TI1FP1 and TI2FP2.<br>100: Reset mode; the slave mode timer resets the counter after receiving the rising edge signal of TRGI and generates the signal to update the register.<br>101: Gated mode; the slave mode timer starts the counter to work after receiving the TRGI high level signal; it stops the counter when receiving TRGI low level; when receiving TRGI high level signal again, the timer will continue to work; the counter is not reset during the whole period.<br>110: Trigger mode, the slave mode timer starts the counter to work after receiving the rising edge signal of TRGI.<br>111: External clock mode 1; select the rising edge signal of TRGI as the clock source to drive the counter to work. |
| 3     |        |     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 6:4   | TRGSEL | R/W | Trigger Input Signal Select                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

| Field | Name   | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|--------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |        |     | <p>In order to avoid false edge detection when changing the bit value, it must be changed when SMFSEL=0.</p> <ul style="list-style-type: none"> <li>000: Internal trigger ITR0</li> <li>001: Internal trigger ITR1</li> <li>010: Internal trigger ITR2</li> <li>011: Internal trigger ITR3</li> <li>100: Channel 1 input edge detector TIF_ED</li> <li>101: Channel 1 post-filtering timer input TI1FP1</li> <li>110: Channel 2 post-filtering timer input TI2FP2</li> <li>111: External trigger input (ETRF)</li> </ul>                                                                              |
| 7     | MSMEN  | R/W | <p>Master/slave Mode Enable</p> <p>0: Invalid</p> <p>1: Enable the master/slave mode</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 11:8  | ETFCFG | R/W | <p>External Trigger Filter Configure</p> <p>0000: Filter disabled, sampling by f<sub>DTS</sub></p> <p>0001: DIV=1, N=2</p> <p>0010: DIV=1, N=4</p> <p>0011: DIV=1, N=8</p> <p>0100: DIV=2, N=6</p> <p>0101: DIV=2, N=8</p> <p>0110: DIV=4, N=6</p> <p>0111: DIV=4, N=8</p> <p>1000: DIV=8, N=6</p> <p>1001: DIV=8, N=8</p> <p>1010: DIV=16, N=5</p> <p>1011: DIV=16, N=6</p> <p>1100: DIV=16, N=8</p> <p>1101: DIV=32, N=5</p> <p>1110: DIV=32, N=6</p> <p>1111: DIV=32, N=8</p> <p>Sampling frequency=timer clock frequency/DIV; the filter length=N, and a jump is generated by every N events.</p> |
| 13:12 | ETPCFG | R/W | <p>External Trigger Prescaler Configure</p> <p>The ETR (external trigger input) signal becomes ETRP after frequency division. The signal frequency of ETRP is at most 1/4 of TMRxCLK frequency; when ETR frequency is too high, the ETRP frequency must be reduced through frequency division.</p> <p>00: The prescaler is disabled;</p> <p>01: ETR signal 2 divided frequency</p> <p>10: ETR signal 4 divided frequency</p> <p>11: ETR signal 8 divided frequency</p>                                                                                                                                |
| 14    | ECEN   | R/W | <p>External Clock Enable Mode2</p> <p>0: Disable</p> <p>1: Enable</p> <p>Setting ECEN bit has the same function as selecting external clock mode 1 to connect TRGI to ETRF; slave mode (reset, gating, trigger) can be used at the same time with external clock mode 2, but TRGI cannot be connected to ETRF in such case; when external clock mode 1 and external clock mode 2 are enabled at the same time, the input of external clock is ETRF.</p>                                                                                                                                               |
| 15    | ETPOL  | R/W | <p>External Trigger Polarity Configure</p> <p>This bit decides whether the external trigger ETR is reversed.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

| Field | Name | R/W | Description                                                                                                                                                                    |  |
|-------|------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|       |      |     | 0: The external trigger ETR is not reversed, and the high level or rising edge is valid<br>1: The external trigger ETR is reversed, and the low level or falling edge is valid |  |

Table 56 TMRx Internal Trigger Connection

| Slave timer | ITR0 (TS=000) | ITR1 (TS=001) | ITR2 (TS=010) | ITR3 (TS=011) |
|-------------|---------------|---------------|---------------|---------------|
| TMR2        | TMR1          | -             | TMR3          | TMR4          |
| TMR3        | TMR1          | TMR2          | -             | TMR4          |
| TMR4        | TMR1          | TMR2          | TMR3          | -             |

#### 15.6.4 DMA/Interrupt enable register (TMRx\_DIEN)

Offset address: 0x0C

Reset value: 0x0000

| Field | Name   | R/W | Description                                                            |  |
|-------|--------|-----|------------------------------------------------------------------------|--|
| 0     | UIEN   | R/W | Update interrupt Enable<br>0: Disable<br>1: Enable                     |  |
| 1     | CC1IEN | R/W | Capture/Compare Channel1 Interrupt Enable<br>0: Disable<br>1: Enable   |  |
| 2     | CC2IEN | R/W | Capture/Compare Channel2 Interrupt Enable<br>0: Disable<br>1: Enable   |  |
| 3     | CC3IEN | R/W | Capture/Compare Channel3 Interrupt Enable<br>0: Disable<br>1: Enable   |  |
| 4     | CC4IEN | R/W | Capture/Compare Channel4 Interrupt Enable<br>0: Disable<br>1: Enable   |  |
| 5     |        |     | Reserved                                                               |  |
| 6     | TRGIEN | R/W | interrupt Enable<br>0: Disable<br>1: Enable                            |  |
| 7     |        |     | Reserved                                                               |  |
| 8     | UDIEN  | R/W | Update DMA Request Enable<br>0: Disable<br>1: Enable                   |  |
| 9     | CC1DEN | R/W | Capture/Compare Channel1 DMA Request Enable<br>0: Disable<br>1: Enable |  |
| 10    | CC2DEN | R/W | Capture/Compare Channel2 DMA Request Enable<br>0: Disable<br>1: Enable |  |
| 11    | CC3DEN | R/W | Capture/Compare Channel3 DMA Request Enable<br>0: Disable<br>1: Enable |  |
| 12    | CC4DEN | R/W | Capture/Compare Channel4 DMA Request Enable<br>0: Disable              |  |

| Field | Name   | R/W | Description                                           |
|-------|--------|-----|-------------------------------------------------------|
|       |        |     | 1: Enable                                             |
| 13    |        |     | Reserved                                              |
| 14    | TRGDEN | R/W | Trigger DMA Request Enable<br>0: Disable<br>1: Enable |
| 15    |        |     | Reserved                                              |

### 15.6.5 State register (TMRx\_STS)

Offset address: 0x10

Reset value: 0x0000

| Field | Name    | R/W   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|---------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | UIFLG   | RC_W0 | Update Event Interrupt Generate Flag<br>0: Update event interrupt does not occur<br>1: Update event interrupt occurs<br><br>When the counter value is reloaded or reinitialized, an update event will be generated. The bit is set to 1 by hardware and cleared by software; update events are generated in the following situations:<br>(1) UD=0 on TMRx_CTRL1 register, and when overruns/underruns, an update event will be generated;<br>(2) URSSEL=0 and UD=0 on TMRx_CTRL1 register, configure UEG=1 on TMRx_CEG register to generate update event, and the counter needs to be initialized by software;<br>(3) URSSEL=0 and UD=0 on TMRx_CTRL1 register, generate update event when the counter is initialized by trigger event. |
| 1     | CC1IFLG | RC_W0 | Capture/Compare Channel1 Interrupt Flag<br><b>When the capture/comparison channel 1 is configured as output:</b><br>0: No matching occurred<br>1: The value of TMRx_CNT matches the value of TMRx_CC1<br><b>When the capture/comparison channel 1 is configured as input:</b><br>0: Input capture did not occur<br>1: Input capture occurred<br>When capture event occurs, the bit is set to 1 by hardware, and it can be cleared by software or cleared when reading TMRx_CC1 register.                                                                                                                                                                                                                                                |
| 2     | CC2IFLG | RC_W0 | Capture/Compare Channel2 new Interrupt Flag<br>Refer to STS_CC1IFLG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 3     | CC3IFLG | RC_W0 | Capture/Compare Channel3 Interrupt Flag<br>Refer to STS_CC1IFLG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 4     | CC4IFLG | RC_W0 | Capture/Compare Channel4 Interrupt Flag<br>Refer to STS_CC1IFLG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 5     |         |       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 6     | TRGIFLG | RC_W0 | Trigger Event Interrupt Generate Flag<br>0: Trigger event interrupt did not occur<br>1: Trigger event interrupt occurred<br>After Trigger event is generated, this bit is set to 1 by hardware and cleared by software.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 8:7   |         |       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

| Field | Name     | R/W   | Description                                                                                                                                                                                                                                                                                                  |
|-------|----------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9     | CC1RCFLG | RC_W0 | Capture/compare Channel1 Repetition Capture Flag<br>0: Repeat capture does not occur<br>1: Repeat capture occurs<br>The value of the counter is captured to TMRx_CC1 register, and CC1IFLG=1; this bit is set to 1 by hardware and cleared by software only when the channel is configured as input capture. |
| 10    | CC2RCFLG | RC_W0 | Capture/compare Channel2 Repetition Capture Flag<br>Refer to STS_CC1RCFLG                                                                                                                                                                                                                                    |
| 11    | CC3RCFLG | RC_W0 | Capture/compare Channel3 Repetition Capture Flag<br>Refer to STS_CC1RCFLG                                                                                                                                                                                                                                    |
| 12    | CC4RCFLG | RC_W0 | Capture/compare Channel4 Repetition Capture Flag<br>Refer to STS_CC1RCFLG                                                                                                                                                                                                                                    |
| 15:13 |          |       | Reserved                                                                                                                                                                                                                                                                                                     |

### 15.6.6 Control event generation register (TMRx\_CEG)

Offset address: 0x14

Reset value: 0x0000

| Field | Name  | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|-------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | UEG   | W   | Update Event Generate<br>0: Invalid<br>1: Initialize the counter and generate the update event<br>This bit is set to 1 by software, and cleared by hardware.<br>Note: When an update event is generated, the counter of the prescaler will be cleared, but the prescaler factor remains unchanged. In the count-down mode, the counter reads the value of TMRx_AUTORLD; in Center-aligned mode or count-up mode, the counter will be cleared.                                                                                                                                                                                                  |
| 1     | CC1EG | W   | Capture/Compare Channel1 Event Generation<br>0: Invalid<br>1: Capture/Comparison event is generated<br>This bit is set to 1 by software and cleared automatically by hardware.<br>If Channel 1 is in output mode<br>When CC1IFLG=1, if CC1IEN and CC1DEN bits are set, the corresponding interrupt and DMA request will be generated.<br>If Channel 1 is in input mode<br>The value of the capture counter is stored in TMRx_CC1 register; configure CC1IFLG=1, and if CC1IEN and CC1DEN bits are also set, the corresponding interrupt and DMA request will be generated; at this time, if CC1IFLG=1, it is required to configure CC1RCFLG=1. |
| 2     | CC2EG | W   | Capture/Compare Channel2 Event Generation<br>Refer to CC1EG description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 3     | CC3EG | W   | Capture/Compare Channel3 Event Generation<br>Refer to CC1EG description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 4     | CC4EG | W   | Capture/Compare Channel4 Event Generation<br>Refer to CC1EG description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 5     |       |     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

| Field | Name | R/W | Description                                                                                                                                      |
|-------|------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------|
| 6     | TEG  | W   | Trigger Event Generate<br>0: Invalid<br>1: Trigger event is generated<br>This bit is set to 1 by software and cleared automatically by hardware. |
| 15:7  |      |     | Reserved                                                                                                                                         |

### 15.6.7 Capature/Comparison mode register 1 (TMRx\_CCM1)

Offset address: 0x18

Reset value: 0x0000

The timer can be configured as input (capture mode) or output (comparison mode) by CCxSEL bit. The functions of other bits of the register are different in input and output modes, and the functions of the same bit are different in output mode and input mode. The OCX in the register describes the function of the channel in the output mode, and the ICx in the register describes the function of the channel in the input mode.

#### Output comparison mode:

| Field | Name   | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|--------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0   | CC1SEL | R/W | Capture/Compare Channel 1 Selection<br>This bit defines the input/output direction and the selected input pin.<br>00: CC1 channel is output<br>01: CC1 channel is input, and IC1 is mapped on TI1<br>10: CC1 channel is input, and IC1 is mapped on TI2<br>11: CC1 channel is input, and IC1 is mapped on TRC, and only works in internal trigger input<br>Note: This bit can be written only when the channel is closed (TMRx_CCEN register CC1EN=0).                                                                                                                                                                                                                                                                                                          |
| 2     | OC1FEN | R/W | Output Compare Channel1 Fast Enable<br>0: Disable<br>1: Enable<br>This bit is used to improve the response of the capture/comparison output to the trigger input event.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 3     | OC1PEN | R/W | Output Compare Channel1 Preload Enable<br>0: Preloading function is disabled; write the value of TMRx_CC1 register through the program and it will work immediately.<br>1: Preloading function is enabled; write the value of TMRx_CC1 register through the program and it will work after an update event is generated.<br>Note: When the protection level is 3 and the channel is configured as output, this bit cannot be modified. When the preload register is uncertain, PWM mode can be used only in single pulse mode (SPMEN=1); otherwise, the following output comparison result is uncertain.                                                                                                                                                        |
| 6:4   | OC1MOD | R/W | Output Compare Channel1 Mode Configure<br>000: Freeze The output comparison has no effect on OC1REF<br>001: The output value is high when matching. When the value of counter CNT matches the value CCx of capture comparison register, OC1REF will be forced to be at high level<br>010: The output value is low when matching. When the value of the counter matches the value of the capture comparison register, OC1REF will be forced to be at low level<br>011: Output flaps when matching. When the value of the counter matches the value of the capture comparison register, flap the level of OC1REF<br>100: The output is forced to be low Force OC1REF to be at low level<br>101: The output is forced to be high. Force OC1REF to be at high level |

| Field | Name   | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------|--------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |        |     | 110: PWM mode 1 (set to high when the counter value<output comparison value; otherwise, set to low)<br>111: PWM mode 2 (set to high when the counter value>output comparison value; otherwise, set to low)<br>Note: When the protection level is 3 and the channel is configured as output, this bit cannot be modified. In PWM modes 1 and 2, the OC1REF level changes when the comparison result changes or when the output comparison mode changes from freeze mode to PWM mode. |
| 7     | OC1CEN | R/W | Output Compare Channel1 Clear Enable<br>0: OC1REF is unaffected by ETRF input.<br>1: When high level of ETRF input is detected, OC1REF=0                                                                                                                                                                                                                                                                                                                                            |
| 9:8   | CC2SEL | R/W | Capture/Compare Channel2 Select<br>This bit defines the input/output direction and the selected input pin.<br>00: CC2 channel is output<br>01: CC2 channel is input, and IC2 is mapped on TI2<br>10: CC2 channel is input, and IC2 is mapped on TI1<br>11: CC2 channel is input, and IC2 is mapped on TRC, and only works in internal trigger input<br>Note: This bit can be written only when the channel is closed (TMRx_CCEN register CC2EN=0).                                  |
| 10    | OC2FEN | R/W | Output Compare Channel2 Preload Enable                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 11    | OC2PEN | R/W | Output Compare Channel2 Buffer Enable                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 14:12 | OC2MOD | R/W | Output Compare Channel1 Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 15    | OC2CEN | R/W | Output Compare Channel2 Clear Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                |

#### Input capture mode:

| Field | Name   | R/W | Description                                                                                                                                                                                                                                                                                                                                                              |
|-------|--------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0   | CC1SEL | R/W | Capture/Compare Channel 1 Select<br>00: CC1 channel is output<br>01: CC1 channel is input, and IC1 is mapped on TI1<br>10: CC1 channel is input, and IC1 is mapped on TI2<br>11: CC1 channel is input, and IC1 is mapped on TRC, and only works in internal trigger input<br>Note: This bit can be written only when the channel is closed (TMRx_CCEN register CC1EN=0). |
| 3:2   | IC1PSC | R/W | Input Capture Channel 1 Prescaler Configure<br>00: PSC=1<br>01: PSC=2<br>10: PSC=4<br>11: PSC=8<br>PSC is prescaled factor, which triggers capture once every PSC events.                                                                                                                                                                                                |
| 7:4   | IC1F   | R/W | Input Capture Channel 1 Filter Configuration<br>0000: Filter disabled, sampling by f <sub>DTS</sub><br>0001: DIV=1, N=2<br>0010: DIV=1, N=4<br>0011: DIV=1, N=8<br>0100: DIV=2, N=6<br>0101: DIV=2, N=8<br>0110: DIV=4, N=6<br>0111: DIV=4, N=8<br>1000: DIV=8, N=6<br>1001: DIV=8, N=8                                                                                  |

| Field | Name   | R/W | Description                                                                                                                                                                                                                                                                                                                                                              |
|-------|--------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |        |     | 1010: DIV=16, N=5<br>1011: DIV=16, N=6<br>1100: DIV=16, N=8<br>1101: DIV=32, N=5<br>1110: DIV=32, N=6<br>1111: DIV=32, N=8<br>Sampling frequency=timer clock frequency/DIV; the filter length=N, indicating that a jump is generated by every N events.                                                                                                                  |
| 9:8   | CC2SEL | R/W | Capture/Compare Channel 2 Select<br>00: CC2 channel is output<br>01: CC2 channel is input, and IC2 is mapped on TI1<br>10: CC2 channel is input, and IC2 is mapped on TI2<br>11: CC2 channel is input, and IC2 is mapped on TRC, and only works in internal trigger input<br>Note: This bit can be written only when the channel is closed (TMRx_CCEN register CC2EN=0). |
| 11:10 | IC2PSC | R/W | Input Capture Channel 2 Perscaler Configuration                                                                                                                                                                                                                                                                                                                          |
| 15:12 | IC2F   | R/W | Input Capture Channel 2 Filter Configuration                                                                                                                                                                                                                                                                                                                             |

### 15.6.8 Capture/Comparison mode register 2 (TMRx\_CCM2)

Offset address: 0x1C

Reset value: 0x0000

Refer to the description of the above CCM1 register.

#### Output comparison mode:

| Field | Name   | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------|--------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0   | CC3SEL | R/W | Capture/Compare Channel 1 Selection<br>This bit defines the input/output direction and the selected input pin.<br>00: CC3 channel is output<br>01: CC3 channel is input, and IC3 is mapped on TI3<br>10: CC3 channel is input, and IC3 is mapped on TI4<br>11: CC3 channel is input, and IC3 is mapped on TRC, and only works in internal trigger input<br>Note: This bit can be written only when the channel is closed (TMRx_CCEN register CC3EN=0). |
| 2     | OC3FEN | R/W | Output Compare Channel3 Fast Enable<br>0: Disable<br>1: Enable<br>This bit is used to improve the response of the capture/comparison output to the trigger input event.                                                                                                                                                                                                                                                                                |
| 3     | OC3PEN | R/W | Output Compare Channel3 Preload Enable                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 6:4   | OC3MOD | R/W | Output Compare Channel3 Mode Configure                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 7     | OC3CEN | R/W | Output Compare Channel3 Clear Enable<br>0: OC3REF is unaffected by ETRF input.<br>1: When high level of ETRF input is detected, OC1REF=0                                                                                                                                                                                                                                                                                                               |

| Field | Name   | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------|--------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9:8   | CC4SEL | R/W | Capture/Compare Channel 4 Selection<br>This bit defines the input/output direction and the selected input pin.<br>00: CC4 channel is output<br>01: CC4 channel is input, and IC4 is mapped on TI4<br>10: CC4 channel is input, and IC4 is mapped on TI3<br>11: CC4 channel is input, and IC4 is mapped on TRC, and only works in internal trigger input<br>Note: This bit can be written only when the channel is closed (TMRx_CCEN register CC4EN=0). |
| 10    | OC4FEN | R/W | Output Compare Channel4 Preload Enable                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 11    | OC4PEN | R/W | Output Compare Channel4 Buffer Enable                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 14:12 | OC4MOD | R/W | Output Compare Channel4 Mode Configure                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 15    | OC4CEN | R/W | Output Compare Channel4 Clear Enable                                                                                                                                                                                                                                                                                                                                                                                                                   |

#### Input capture mode:

| Field | Name   | R/W | Description                                                                                                                                                                                                                                                                                                                                                              |
|-------|--------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0   | CC3SEL | R/W | Capture/Compare Channel 3 Select<br>00: CC3 channel is output<br>01: CC3 channel is input, and IC3 is mapped on TI3<br>10: CC3 channel is input, and IC3 is mapped on TI4<br>11: CC3 channel is input, and IC3 is mapped on TRC, and only works in internal trigger input<br>Note: This bit can be written only when the channel is closed (TMRx_CCEN register CC3EN=0). |
| 3:2   | IC3PSC | R/W | Input Capture Channel 3 Perscaler Configuration<br>00: PSC=1<br>01: PSC=2<br>10: PSC=4<br>11: PSC=8<br>PSC is prescaled factor, which triggers capture once every PSC events.                                                                                                                                                                                            |
| 7:4   | IC3F   | R/W | Input Capture Channel 3 Filter Configuration                                                                                                                                                                                                                                                                                                                             |
| 9:8   | CC4SEL | R/W | Capture/Compare Channel 4 Select<br>00: CC4 channel is output<br>01: CC4 channel is input, and IC4 is mapped on TI4<br>10: CC4 channel is input, and IC4 is mapped on TI3<br>11: CC4 channel is input, and IC4 is mapped on TRC, and only works in internal trigger input<br>Note: This bit can be written only when the channel is closed (TMRx_CCEN register CC4EN=0). |
| 11:10 | IC4PSC | R/W | Input Capture Channel 4 Perscaler Configuration                                                                                                                                                                                                                                                                                                                          |
| 15:12 | IC4F   | R/W | Input Capture Channel 4 Filter Configuration                                                                                                                                                                                                                                                                                                                             |

#### 15.6.9 Capture/Comparison enable register (TMRx\_CCEN)

Offset address: 0x20

Reset value: 0x0000

| Field | Name  | R/W | Description                                                                                                                                                                                                                |
|-------|-------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | CC1EN | R/W | Capture/Compare Channel1 Output Enable<br>When the capture/comparison channel 1 is configured as output:<br>0: Output is disabled<br>1: Output is enabled<br>When the capture/comparison channel 1 is configured as input: |

| Field | Name     | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|----------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |          |     | This bit determines whether the value CNT of the counter can be captured and enter TMRx_CC1 register<br>0: Capture is disabled<br>1: Capture is enabled                                                                                                                                                                                                                                                                                         |
| 1     | CC1POL   | R/W | Capture/Compare Channel1 Output Polarity Configure<br>When CC1 channel is configured as output:<br>0: OC1 high level is valid<br>1: OC1 low level is valid<br>When CC1 channel is configured as input:<br>0: Phase not reversed: select IC1 signal as th trigger or capture signal<br>1: Phase revered, select reverse signal of IC1 as the trigger or capture signal<br>Note: When the protection level is 2 or 3, this bit cannot be modified |
| 3:2   | Reserved |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 4     | CC2EN    | R/W | Capture/Compare Channel2 Output Enable<br>Refer to CCEN_CC1EN                                                                                                                                                                                                                                                                                                                                                                                   |
| 5     | CC2POL   | R/W | Capture/Compare Channel2 Output Polarity Configure<br>Refer to CCEN_CC1POL                                                                                                                                                                                                                                                                                                                                                                      |
| 7:6   | Reserved |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 8     | CC3EN    | R/W | Capture/Compare Channel3 Output Enable<br>Refer to CCEN_CC1EN                                                                                                                                                                                                                                                                                                                                                                                   |
| 9     | CC3POL   | R/W | Capture/Compare Channel3 Output Polarity Configure<br>Refer to CCEN_CC1POL                                                                                                                                                                                                                                                                                                                                                                      |
| 11:10 | Reserved |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 12    | CC4EN    | R/W | Capture/Compare Channel4 Output Enable<br>Refer to CCEN_CC1EN                                                                                                                                                                                                                                                                                                                                                                                   |
| 13    | CC4POL   | R/W | Capture/Compare Channel4 Output Polarity<br>Refer to CCEN_CC1POL                                                                                                                                                                                                                                                                                                                                                                                |
| 15:14 | Reserved |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

Table 57 Output Control Bit of Standard OCx Channel

| CCxEN bit | OCx output state                     |
|-----------|--------------------------------------|
| 0         | Output is disabled (OCx=0, OCx_EN=0) |
| 1         | OCx=OCxREF+polarity, OCx_EN=1        |

Note: The state of external I/O pin connected to the standard OCx channel depends on the state of the OCx channel and the GPIO and AFIO registers.

### 15.6.10 Counter register (TMRx\_CNT)

Offset address: 0x24

Reset value: 0x0000

| Field | Name | R/W | Description   |
|-------|------|-----|---------------|
| 15:0  | CNT  | R/W | Counter Value |

### 15.6.11 Prescaler register (TMRx\_PSC)

Offset address: 0x28

Reset value: 0x0000

| Field | Name | R/W | Description                                                                          |
|-------|------|-----|--------------------------------------------------------------------------------------|
| 15:0  | PSC  | R/W | Prescaler Value<br>Clock frequency of counter ( $CK\_CNT$ ) = $f_{CK\_PS}$ / (PSC+1) |

### 15.6.12 Auto reload register (TMRx\_AUTORLD)

Offset address: 0x2C

Reset value: 0xFFFF

| Field | Name    | R/W | Description                                                                              |
|-------|---------|-----|------------------------------------------------------------------------------------------|
| 15:0  | AUTORLD | R/W | Auto Reload Value<br>When the value of auto reload is empty, the counter will not count. |

### 15.6.13 Channel 1 capture/comparison register (TMRx\_CC1)

Offset address: 0x34

Reset value: 0x0000

| Field | Name | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0  | CC1  | R/W | Capture/Compare Channel 1 Value<br><b>When the capture/comparison channel 1 is configured as input mode:</b><br>CC1 contains the counter value transmitted by the last input capture channel 1 event.<br><b>When the capture/comparison channel 1 is configured as output mode:</b><br>CC1 contains the current load capture/comparison register value<br>Compare the value CC1 of the capture and comparison channel 1 with the value CNT of the counter to generate the output signal on OC1.<br>When the output comparison preload is disabled (OC1PEN=0 for TMRx_CCM1 register), the written value will immediately affect the output comparison results;<br>If the output comparison preload is enabled (OC1PEN=1 for TMRx_CCM1 register), the written value will affect the output comparison result when an update event is generated. |

### 15.6.14 Channel 2 capture/comparison register (TMRx\_CC2)

Offset address: 0x38

Reset value: 0x0000

| Field | Name | R/W | Description                                          |
|-------|------|-----|------------------------------------------------------|
| 15:0  | CC2  | R/W | Capture/Compare Channel 2 Value<br>Refer to TMRx_CC1 |

### 15.6.15 Channel 3 capture/comparison register (TMRx\_CC3)

Offset address: 0x3C

Reset value: 0x0000

| Field | Name | R/W | Description                                          |
|-------|------|-----|------------------------------------------------------|
| 15:0  | CC3  | R/W | Capture/Compare Channel 3 Value<br>Refer to TMRx_CC1 |

### 15.6.16 Channel 4 capture/comparison register (TMRx\_CC4)

Offset address: 0x40

Reset value: 0x0000

| Field | Name | R/W | Description                                          |
|-------|------|-----|------------------------------------------------------|
| 15:0  | CC4  | R/W | Capture/Compare Channel 4 Value<br>Refer to TMRx_CC1 |

### 15.6.17 DMA control software (TMRx\_DCTRL)

Offset address: 0x48

Reset value: 0x0000

| Field | Name   | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------|--------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4:0   | DBADDR | R/W | <p>DMA Base Address Setup<br/>           These bits define the base address of DMA in continuous mode (when reading or writing TMRx_DMADDR register), and DBADDR is defined as the offset from the address of TMRx_CTRL1 register:</p> <ul style="list-style-type: none"> <li>00000: TMRx_CTRL1</li> <li>00001: TMRx_CTRL2</li> <li>00010: TMRx_SMCTRL</li> <li>.....</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 7:5   |        |     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 12:8  | DBLEN  | R/W | <p>DMA Burst Transfer Length Setup<br/>           These bits define the transfer length and transfer times of DMA in continuous mode. The data transferred can be 16 bits and 8 bits.<br/>           When reading/writing TMRx_DMADDR register, the timer will conduct a continuous transmission;</p> <ul style="list-style-type: none"> <li>00000: Transmission once</li> <li>00001: Transmission twice</li> <li>00010: Transmission for three times</li> <li>.....</li> <li>10001: Transmission for 18 times</li> </ul> <p>The transmission address formula is as follows:<br/>           Transmission address=TMRx_CTRL1 address (slave address)<br/>           +DBADDR+DMA index; DMA index=DBLEN<br/>           For example: DBLEN=7, DBADDR=TMR1_CTRL1 (slave address) means the address of the data to be transmitted, while the address +DBADDR+7 of TMRx_CTRL1 means the address of the data to be written/read,<br/>           Data transmission will occur to: TMRx_CTRL1 address + seven registers starting from DBADDR.<br/>           The data transmission will change according to different DMA data length:<br/>           (1) When the transmission data is set to 16 bits, the data will be transmitted to seven registers<br/>           (2) When the transmission data is set to 8 bits, the data of the first register is the MSB bit of the first data, the data of the second register is the LSB bit of the first data, and the data will still be transmitted to seven registers.</p> |
| 15:13 |        |     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

### 15.6.18 DMA address register of continuous mode (TMRx\_DMADDR)

Offset address: 0x4C

Reset value: 0x0000

| Field | Name   | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|--------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0  | DMADDR | R/W | <p>DMA Register for Burst Transfer<br/>           Read or write operation access of TMRx_DMADDR register may lead to access operation of the register in the following address:<br/>           TMRx_CTRL1 address + (DBADDR+DMA index) ×4<br/>           Wherein:<br/>           "TMRx_CTRL1 address" is the address of control register 1 (TMRx_CTRL1);<br/>           "DBADDR" is the base address defined in TMRx_DCTRL register;<br/>           "DMA index" is the offset automatically controlled by DMA, and it depends on DBLEN defined in TMRx_DCTRL register.</p> |

## 16 Watchdog Timer (WDT)

### 16.1 Introduction

The watchdog is used to monitor system failures caused by software errors. There are two watchdog devices on the chip: independent watchdog and window watchdog, which improve the security, and make the time more accurate and the use more flexible.

The independent watchdog will reset only when the counter is reduced to 0, and the value of refresh counter will not be reset until it is not reduced to 0.

The window watchdog will reset when the counter decreases to 0x3F. When the count value of the counter is before the window value of the configuration register, the refresh counter will also be reset.

### 16.2 Independent Watchdog Timer (IWDT)

#### 16.2.1 Introduction

The independent watchdog consists of an 8-bit prescaler IWDT\_PSC, 12-bit count-down counter, 12-bit reload register IWDT\_CNTRLD, key register IWDT\_KEY and state register IWDT\_STS.

The independent watchdog has an independent clock source, and even if the master clock fails, it is still valid.

The independent watchdog is applicable to the situations where an independent environment is required but the accuracy requirement is not high.

#### 16.2.2 Structure Block Diagram

Figure 58 Independent Watchdog Structure Block Diagram



Note: The watchdog function is in the V<sub>DD</sub> power supply area and can work normally in the shutdown or standby mode.

### 16.2.3 Functional Description

#### 16.2.3.1 Key register

Write 0xCCCC in the key register to enable the independent watchdog, then the counter starts to count down, and when the counter counts to 0x000, a reset will be generated.

Write 0xAAAA in the key register, and the value of the reload register will be reloaded to the counter to prevent the watchdog from resetting.

Write 0x5555 in the key register to rewrite the value of the prescaler register and the reload register.

#### 16.2.3.2 Register access protection

The prescaler register and reload register have the function of write protection. If you want to rewrite these two registers, you need to write 0X5555 in the key register. If you write other value in the key register, the protection of the register will be started again.

Write 0xAAAA to the key register and the write protection function will also be enabled.

#### 16.2.3.3 Hardware watchdog

After the "hardware watchdog" function is enabled, and the system is powered on and reset, the watchdog will run automatically. If 0xAAAA is not written to the key register, reset will be generated after the counter finishes counting.

#### 16.2.3.4 Debug mode

The independent watchdog can be configured in debug mode and choose to stop or continue to work. Depend on IWDT\_STS bit of DBGMCU register.

## 16.3 Window Watchdog Timer (WWDT)

### 16.3.1 Introduction

The window watchdog contains a 7-bit free-running down counter, prescaler and control register WWDT\_CTRL, configuration register WWDT\_CFG and state register WWDT\_STS.

The window watchdog clock comes from PCLK1, and the counter clock is obtained from the CK counter clock through frequency division by prescaler (configured by the configuration register).

The window watchdog is applicable when precise timing is needed.

### 16.3.2 Structure Block Diagram

Figure 59 Window Watchdog Structure Block Diagram



### 16.3.3 Functional Description

Enable window watchdog timer; the reset conditions are:

- When the counter count is less than 0x40, a reset will be generated.
- The reload counter will be reset before the counter counts to the value of the window register.

After reset, the watchdog is always closed and the watchdog can be enabled only by setting the WWDTEN bit of WWDT\_CTRL control register.

The counter of window watchdog is in free state. When the watchdog is disabled, the counter will continue to count down. The counter must be reloaded between the value of window register and 0x40 to avoid reset.

Setting the EWIEN bit of the configuration register can enable the early wake-up interrupt. When the count reaches 0x40, the interrupt will be generated. Entering the interrupt service program (ISTS) can be used to prevent the window watchdog from resetting. EWIEN interrupt can be cleared by writing 0 in the state register.

The unique window of the window watchdog timer can effectively monitor whether the program is faulty. For example, assuming that the running time of a program segment is T, and the value of the window register is slightly less than (TR-T), if there is no reload register in the window, it means that the program is faulty, and when the counter counts to 0x3F, it will generate reset.

Figure 60 Window Watchdog Timing Diagram



The calculation formula of window watchdog timer timeout is as follows:

$$T_{WWDT} = T_{PCLK1} \times 2^{WTB} \times (T[5:0]+1)$$

Wherein:

- $T_{WWDT}$ : WWDT timeout
- $T_{PCLK1}$ : Clock cycle of APB1 in ms

Minimum/Maximum timeout when PCLK1=48MHZ

| WTB | Minimum timeout value | Maximum timeout value |
|-----|-----------------------|-----------------------|
| 0   | 84.75μs               | 5.46ms                |
| 1   | 170.25μs              | 10.92ms               |
| 2   | 341.25μs              | 21.84ms               |
| 3   | 682.5μs               | 43.6875ms             |

## 16.4 IWDT Register Address Mapping

Table 58 IWDT Register Mapping

| Register name | Description             | Offset address |
|---------------|-------------------------|----------------|
| IWDT_KEY      | Key register            | 0x00           |
| IWDT_PSC      | Prescaler register      | 0x04           |
| IWDT_CNTRLD   | Counter reload register | 0x08           |
| IWDT_STS      | State register          | 0x0C           |

## 16.5 IWDT Register Functional Description

These peripheral registers can be operated by half word (16 bits) or word (32 bits).

### 16.5.1 Key register (IWDT\_KEY)

Offset address: 0x00

Reset value: 0x0000 0000 (reset in standby mode)

| Field | Name | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------|------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0  | KEY  | W   | Allow Access IWDT Register Key Value<br>Writing 0x5555 means enabled access to IWDT_PSC and IWDT_CNTRLD registers;<br>When the software writes 0xAAAA, it means to execute the reload counter, and a certain interval is required to prevent the watchdog from resetting.<br>Write 0xCCCC and the watchdog will be enabled (the hardware watchdog is unrestricted by this command word);<br>This register is write-only and the read-out value is 0x0000. |
| 31:16 |      |     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

### 16.5.2 Prescaler register (IWDT\_PSC)

Offset address: 0x04

Reset value: 0x0000 0000

| Field | Name | R/W | Description                                                                                                                                                                         |
|-------|------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0   | PSC  | R/W | Prescaler Factor Configure<br>Support write protection function; when writing 0x5555 in the IWDT_KEY register, it is allowed to access the register; in the process of writing this |

| Field | Name | R/W | Description                                                                                                                                                                                                                                                                                                                   |
|-------|------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |      |     | register, only when IWDT_STS register PSCUFLG=0, can the prescaler factor be changed; in the process of reading this register, only when PSCUFLG=0, can the read-out value of PSC register be valid.<br>000: PSC=4<br>001: PSC=8<br>010: PSC=16<br>011: PSC=32<br>100: PSC=64<br>101: PSC=128<br>110: PSC=256<br>111: PSC=256 |
| 31:3  |      |     | Reserved                                                                                                                                                                                                                                                                                                                      |

### 16.5.3 Counter reload register (IWDT\_CNTRLD)

Offset address: 0x08

Reset value: 0x0000 0FFF(reset in standby mode)

| Field | Name   | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|--------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11:0  | CNTRLD | R/W | Watchdog Counter Reload Value Setup<br>It supports write protection function and defines the value loaded to the watchdog counter when 0xAAAA is written by IWDT_KEY register; in the process of writing this register, this register can be modified only when CNTUFLG=0. In the process of reading this register, when CNTUFLG=0 in IWDT_STS register, the read value is valid.<br>The watchdog timeout cyclecan be calculated by the reload value and clock prescaled value. |
| 31:12 |        |     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

### 16.5.4 State register (IWDT\_STS)

Offset address: 0x0C

Reset value: 0x0000 0000 (not reset in standby mode)

| Field | Name    | R/W | Description                                                                                                                                                                                                                                                             |
|-------|---------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | PSCUFLG | R   | Watchdog Prescaler Factor Update Flag<br>When the prescaler factor is updated, it is set to 1 by hardware; after the prescaler factor is updated, the bit is cleared by hardware; the prescaler factor is updated only when the PSCUFLG bit is cleared.                 |
| 1     | CNTUFLG | R   | Watchdog Counter Reload Value Update Flag<br>When the counter reload value is updated, it is set to 1 by hardware; after the counter reload value is updated, the bit is cleared by hardware; the counter reload value is updated only when the CNTUFLG bit is cleared. |
| 31:2  |         |     | Reserved                                                                                                                                                                                                                                                                |

## 16.6 WWDT Register Address Mapping

Table 59 WWDT Register Mapping

| Register name | Description            | Offset address |
|---------------|------------------------|----------------|
| WWDT_CTRL     | Control register       | 0x00           |
| WWDT_CFG      | Configuration register | 0x04           |
| WWDT_STS      | State register         | 0x08           |

## 16.7 WWDT Register Functional Description

These peripheral registers can be operated by half word (16 bits) or word (32 bits).

### 16.7.1.1 Control register (WWDT\_CTRL)

Offset address: 0x00

Reset value: 0x0000 007F

| Field | Name     | R/W | Description                                                                                                                                                                                                                                         |
|-------|----------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6:0   | CNT      | R/W | <p>Counter Value Setup<br/>This counter is 7 bits, and CNT6 is the most significant bit<br/>These bits are used to store the counter value of the watchdog.<br/>When the count value decreases from 0x40 to 0x3F, WWDT reset will be generated.</p> |
| 7     | WWDTEN   | R/S | <p>Window Watchdog Enable<br/>This bit is set to 1 by software and can be cleared by hardware only after reset. When WWDTEN=1, WWDT can generate a reset.<br/>0: Disable<br/>1: Enable</p>                                                          |
| 31:8  | Reserved |     |                                                                                                                                                                                                                                                     |

### 16.7.1.2 Configuration register (WWDT\_CFG)

Offset address: 0x04

Reset value: 0x0000 007F

| Field | Name     | R/W | Description                                                                                                                                                                                                                 |
|-------|----------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6:0   | WIN      | R/W | <p>Window Value Setup<br/>This window value is 7 bits, which is used to compare with the down counter.</p>                                                                                                                  |
| 8:7   | TBPSC    | R/W | <p>Timer Base Prescaler Factor Configure<br/>Divide the frequency on the basis of PCLK1/4096<br/>00: No frequency division<br/>01: Two-divided frequency<br/>10: Four-divided frequency<br/>11: Eight-divided frequency</p> |
| 9     | EWIEN    | R/S | <p>Early Wakeup Interrupt Enable<br/>0: No effect<br/>1: When the counter value reaches 0x40, an interrupt will be generated; this interrupt is cleared by hardware after reset.</p>                                        |
| 31:10 | Reserved |     |                                                                                                                                                                                                                             |

### 16.7.1.3 State register (WWDT\_STS)

Offset address: 0x08

Reset value: 0x0000 0000

| Field | Name     | R/W   | Description                                                                                                                                                                                                                                  |
|-------|----------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | EWIFLG   | RC_W0 | <p>Early Wakeup Interrupt Occur Flag<br/>0: No occur<br/>1: When the counter value reaches 0x40, it is set to 1 by hardware; if the interrupt is not enabled, the bit will also be set to 1; it can be cleared by writing 0 by software.</p> |
| 31:1  | Reserved |       |                                                                                                                                                                                                                                              |

## 17 Real-time Clock (RTC)

### 17.1 Full Name and Abbreviation Description of Terms

Table 60 Full Name and Abbreviation Description of Terms

| Full name in English | English abbreviation |
|----------------------|----------------------|
| Second               | SEC                  |
| Alarm                | ALR                  |
| Overflow             | OVR                  |
| Prescaler            | PSC                  |
| Time Basic Clock     | TBCLK                |

### 17.2 Main Characteristics

Real-time clock (RTC) is a timer that automatically switches to backup power supply after main power failure to maintain the operation.

- Timebase unit
- Programmable 32bit counter
- Multiple interrupt control
- Automatic wakeup of low power

### 17.3 Structure Block Diagram

Figure 61 RTC Structure Block Diagram



### 17.4 Functional Description

#### 17.4.1 Timebase Unit

##### Clock source

RTC has three clock sources RTC\_CLK:

- External LSECLK crystal oscillator

- External HSECLK crystal oscillator 128 divided frequency
- Internal LSICLK

Different clock sources are configured through RCM peripheral of clock controller.

### Prescaler

The RTC prescaler contains a 20-bit programmable frequency divider, which can be programmed to generate RTC time reference of up to 1 second.

#### 17.4.2 RTC Register Configuration

In order to prevent counting exception caused by accidental write in RTC register, RTC adopts write protection mechanism. Only when the write protection is removed, can the register with write protection function be operated.

When configuring RTC clock, it's required to set BPWEN bit of the power control register (PMU\_CTRL) to "1"; configure CFGMFLG bit of RTC\_CSTS register to make the RTC enter the configuration mode so that the RTC\_PSCRLD, RTC\_CNT and RTC\_ALR registers can be configured; clear CFGMFLG bit of RTC\_CSTS register to exit the configuration mode.

The write operation to any register of RTC can be performed only after the previous write operation is finished (judge by querying RTC\_CSTS OCFLG).

#### 17.4.3 Programmable Alarm Clock

As a real-time clock, RTC integrates the alarm clock function internally, and it runs mainly through alarm clock register and counter, and configures the alarm clock time through register RTC\_ALR; after the alarm clock function is enabled, when the counter value is equal to the alarm clock value, it will be triggered and the alarm clock flag will be set. If the alarm clock interrupt is enabled, the interrupt processing will be triggered, and through the configuration of external line 17 interrupt, RTC alarm clock can be used to wake up low power consumption.

#### 17.4.4 RTC Output

RTC can output the internal RTC second pulse, alarm clock signal and calibration clock to the outside through PC13 pin, and select the output pulse by configuring BAKPR\_CLKCAL register.

#### 17.4.5 Interrupt

RTC can generate second interrupt, alarm clock interrupt and overrun interrupt. When 20-bit prescaler overrun, alarm clock event and 32-bit counter overrun are generated, the corresponding state flag bit will be pending and the corresponding interrupt can be generated by configuring RTC\_CTRL register.

### 17.5 Register Address Mapping

Table 61 RTC Register Address Mapping

| Register name | Description                               | Offset address |
|---------------|-------------------------------------------|----------------|
| RTC_CTRL      | RTC control register                      | 0x00           |
| RTC_CSTS      | RTC control/state register                | 0x04           |
| RTC_PSCRLDH   | High bit of RTC prescaler reload register | 0x08           |

| Register name | Description                              | Offset address |
|---------------|------------------------------------------|----------------|
| RTC_PSCRLDL   | Low bit of RTC prescaler reload register | 0x0C           |
| RTC_PSCH      | High bit of RTC prescaler register       | 0x10           |
| RTC_PSCL      | Low bit of RTC prescaler register        | 0x14           |
| RTC_CNTH      | High bit of RTC counter register         | 0x18           |
| RTC_CNTL      | Low bit of RTC counter register          | 0x1C           |
| RTC_ALRH      | High bit of RTC alarm value register     | 0x20           |
| RTC_ALRL      | Low bit of RTC alarm value register      | 0x24           |

## 17.6 Register Functional Description

### 17.6.1 RTC control register (RTC\_CTRL)

Offset address: 0x00

Reset value: 0x0000

| Field | Name     | R/W | Description                                          |
|-------|----------|-----|------------------------------------------------------|
| 0     | SECIEN   | R/W | Second Interrupt Enable<br>0: Disable<br>1: Enable   |
| 1     | ALRIEN   | R/W | Alarm Interrupt Enable<br>0: Disable<br>1: Enable    |
| 2     | OVRIEN   | R/W | Overflow Interrupt Enable<br>0: Disable<br>1: Enable |
| 15:3  | Reserved |     |                                                      |

### 17.6.2 RTC control/state register (RTC\_CSTS)

Offset address: 0x04

Reset value: 0x0020

| Field | Name     | R/W   | Description                                                                                                                                                                                                                                                                                                                   |
|-------|----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | SECFLG   | RC_W0 | Second Signal Condition Met Flag<br>This flag can provide a periodic signal (usually 1 second) for the RTC counter.<br>When the 32-bit programmable prescaler overruns, it is set to 1 by hardware and the RTC counter will add by 1; it can be only cleared by writing 0 by software.<br>0: No second flag<br>1: Second flag |
| 1     | ALRFLG   | RC_W0 | Alarm Occur Flag<br>When the counter reaches RTC_ALR value, it is set to 1 by hardware; it can be only cleared by writing 0 by software.<br>0: No alarm clock<br>1: Alarm clock                                                                                                                                               |
| 2     | OVRFLG   | RC_W0 | Overflow Occur Flag<br>When the counter overruns, it is set to 1 by hardware; it can be only cleared by writing 0 by software.<br>0: No overrun<br>1: 32-bit programmable counter overrun                                                                                                                                     |
| 3     | RSYNCFLG | RC_W0 | Registers Synchronized Flag                                                                                                                                                                                                                                                                                                   |

| Field | Name     | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|----------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |          |     | <p>When RTC_CNT, RTC_PSCRLD and RTC_ALR registers have been synchronized, it is set to 1 by hardware; it can be cleared by writing 0 by software.</p> <p>After the APB1 clock is reset or stopped, this bit must be cleared by software, and the user program can correctly read out the values of RTC_CNT, RTC_PSCRLD and RTC_ALR only when it is set to 1 by hardware.</p> <p>0: Not synchronized<br/>1: Synchronized</p> |
| 4     | CFGMFLG  | R/W | <p>Configure Mode Enable Flag</p> <p>Write operation can be performed for RTC_CNT, RTC_ALR or RTC_PSCRLD registers only after writing 1 by software and entering the configuration mode; exit the configuration mode after writing 0 by software.</p> <p>0: Exit configuration mode (start to update RTC register)<br/>1: Enable configuration mode</p>                                                                     |
| 5     | OCFLG    | R   | <p>RTC Operation Complete Flag</p> <p>Indicate the state of last write of RTC register.</p> <p>0: Uncompleted; next write operation cannot be executed<br/>1: Completed; next write operation can be executed</p>                                                                                                                                                                                                           |
| 15:6  | Reserved |     |                                                                                                                                                                                                                                                                                                                                                                                                                             |

### 17.6.3 RTC prescaler reload register (RTC\_PSCRLD)

This register saves the cycle count value of RTC prescaler, and only when the OCFLG value is 1, can the write operation be performed.

#### High bit of RTC prescaler load register (RTC\_PSCRLDH)

Offset address: 0x08

Reset value: 0x0000

| Field | Name           | R/W | Description                                                                                                                                                                                          |
|-------|----------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0   | PSCRLDH[19:16] | W   | <p>RTC Prescaler Reload Value High Setup</p> <p>These bits can be used to define the frequency of time base clock according to the following formula:</p> $f_{TBCLK} = f_{RTCCLK} / (RLD[19:0] + 1)$ |
| 15:4  | Reserved       |     |                                                                                                                                                                                                      |

#### Low bit of RTC prescaler load register (RTC\_PSCRLDL)

Offset address: 0x0C

Reset value: 0x8000

| Field | Name          | R/W | Description                                                                                                                                                                                         |
|-------|---------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0  | PSCRLDL[15:0] | W   | <p>RTC Prescaler Reload Value Low Setup</p> <p>These bits can be used to define the frequency of time base clock according to the following formula:</p> $f_{TBCLK} = f_{RTCCLK} / (RLD[19:0] + 1)$ |

Note: If the input clock frequency is 32.768kHz ( $f_{RTCCLK}$ ), write 7FFFh in this register to obtain a signal with a cycle of 1 second.

#### 17.6.4 RTC prescaler register (RTC\_PSC)

This register saves the value of RTC\_PSCRLD, which is read-only, and can be reloaded by hardware when RTC\_PSCRLD or RTC\_CNT register changes.

##### High bit of RTC prescaler register (RTC\_PSCH)

Offset address: 0x10

Reset value: 0x0000

| Field | Name        | R/W | Description                    |
|-------|-------------|-----|--------------------------------|
| 3:0   | PSCH[19:16] | R   | RTC Clock Prescaler High Setup |
| 15:4  | Reserved    |     |                                |

##### Low bit of RTC prescaler register (RTC\_PSCL)

Offset address: 0x14

Reset value: 0x8000

| Field | Name       | R/W | Description                   |
|-------|------------|-----|-------------------------------|
| 15:0  | PSCL[15:0] | R   | RTC Clock Prescaler Low Setup |

#### 17.6.5 RTC counter register (RTC\_CNT)

When the OCFLG value is 1, write operation is allowed; when read operation is performed, the count value (system time) in the counter will be returned directly.

##### High bit of RTC counter register (RTC\_CNTH)

Offset address: 0x18

Reset value: 0x0000

| Field | Name        | R/W | Description            |
|-------|-------------|-----|------------------------|
| 15:0  | CNTH[31:16] | R/W | RTC Counter High Setup |

##### Low bit of RTC counter register (RTC\_CNTL)

Offset address: 0x1C

Reset value: 0x0000

| Field | Name       | R/W | Description           |
|-------|------------|-----|-----------------------|
| 15:0  | CNTL[15:0] | R/W | RTC Counter Low Setup |

#### 17.6.6 RTC alarm clock value register (RTC\_ALR)

Write operation can be performed when OCFLG value is 1.

##### High bit of RTC alarm clock value register (RTC\_ALRH)

Offset address: 0x20

Reset value: 0xFFFF

| Field | Name        | R/W | Description                |
|-------|-------------|-----|----------------------------|
| 15:0  | ALRH[31:16] | W   | RTC Alarm Value High Setup |

### Low bit of RTC alarm clock value register (RTC\_ALRL)

Offset address: 0x24

Reset value: 0xFFFF

| Field | Name       | R/W | Description               |
|-------|------------|-----|---------------------------|
| 15:0  | ALRL[15:0] | W   | RTC Alarm Value Low Setup |

# 18 Universal Synchronous/Asynchronous Transceiver (USART)

## 18.1 Full Name and Abbreviation Description of Terms

Table 62 Full Name and Abbreviation Description of Terms

| Full name in English  | English abbreviation |
|-----------------------|----------------------|
| Clear to Send         | CTS                  |
| Request to Send       | RTS                  |
| Most Significant Bit  | MSB                  |
| Least Significant Bit | LSB                  |
| Guard                 | GRD                  |
| Overrun               | OVR                  |

## 18.2 Introduction

USART (universal synchronous/asynchronous transceiver) is a serial communication device that can flexibly exchange full-duplex and half-duplex data with external devices, and meets the requirements of external devices for industry standard NRZ asynchronous serial data format. USART also provides a wide range of baud rate for selection and supports multiprocessor communication.

USART not only supports standard asynchronous transceiver mode, but also supports some other serial data exchange modes, such as LIN protocol, smart card protocol, IrDA SIR ENDEC specification and hardware flow control mode.

USART also supports DMA function to realize high-speed data communication.

## 18.3 Main Characteristics

- (1) Full duplex asynchronous communication
- (2) Single-line half-duplex communication
- (3) NRZ standard format
- (4) Characteristics of programmable serial port:
  - Data bit: 8 or 9 bits
  - Check bits: Even parity check, odd parity check, no check
  - Support 0.5, 1, 1.5 and 2 stop bits
- (5) Check control
  - Transmit the check bit
  - Check the received data
- (6) Independent transmitter and receiver enable bit
- (7) programmable baud rate generator, with baud rate of up to 4.5Mbits/s

- (8) Multiprocessor communication:
  - If the address does not match, it will enter the silent mode
  - Wake up from silent mode through idle bus detection or address flag detection
- (9) Synchronous transmission mode
- (10) Generation and detection of LIN break frame
- (11) Support the smart card interface of ISO7816-3 standard
- (12) Support IrDA protocol
- (13) Support hardware flow control
- (14) DMA can be used for continuous communication
- (15) State flag bit:
  - Transmission detection flag: The transmit register is empty, the receive register is not empty, and transmission is completed
  - Error detection flag: Overrun error, noise error, parity error, frame error
- (16) Multiple interrupt sources:
  - The transmit register is empty
  - Transmission is completed
  - CTS changed
  - The receive register cannot be empty
  - Overload error
  - Bus idle
  - Parity error
  - LIN break detection
  - Noise error
  - Overrun error
  - Frame error

## 18.4 Functional Description

Table 63 USART Pin Description

| Pin        | Type                                             | Description                                                                                          |
|------------|--------------------------------------------------|------------------------------------------------------------------------------------------------------|
| USART_RX   | Input                                            | Data receiving                                                                                       |
| USART_TX   | Output<br>I/O (single-line mode/smart card mode) | Data transmission<br>When the transmitter is enabled and does not transmit data, the default is high |
| USART_CK   | Output                                           | Clock output                                                                                         |
| USART_nRTS | Input                                            | Request to send in hardware flow control mode                                                        |
| USART_nCTS | Output                                           | Clear to send in hardware flow control mode                                                          |
| IrDA_RDI   | Input                                            | Data input in IrDA mode                                                                              |
| IrDA_TDO   | Output                                           | Data output in IrDA mode                                                                             |

#### 18.4.1 Single-line Half-duplex Communication

HDEN bit of USART\_CTRL3 register determines whether to enter the single-line half-duplex mode.

When USART enters single-line half-duplex mode:

- The CLKEN and LINMEN bit of USART\_CTRL2 register, and IREN and SCEN bits of USART\_CTRL3 register must be cleared.
- RX pin is disabled.
- TX pin should be configured as open-drain output and connected with RX pin inside the chip.
- Sending data and receiving data can not be carried out at the same time. The data cannot be received before they are sent. If needing to receive data, enabling receiving can be turned on only after TXCFLG bit of USART\_STS register is set to 1.
- If there is data conflict on the bus, software management is needed to allocate the communication process.

#### 18.4.2 Frame Format

The frame format of data frame is controlled by USART\_CTRL1 register

- DBLCFG bit controls the character length, which can be set to 8 or 9 bits.
- PCEN bit controls to enable the check bit or not.
- PCFG bit controls the parity bit to be odd or even.

Table 64 Frame Format

| DBLCFG bit | PCEN bit | USART data frame                                        |
|------------|----------|---------------------------------------------------------|
| 0          | 0        | Start bit+8-bit data+stop bit                           |
| 0          | 1        | Start bit+7-bit data+odd-even parity check bit+stop bit |
| 1          | 0        | Start bit+9-bit data+stop bit                           |
| 1          | 1        | Start bit+8-bit data+odd-even parity check bit+stop bit |

##### Configurable stop bit

Four different stop bits can be configured through STOPCFG bit of USART\_CTRL2 register.

- 1 stop bit: Default stop bit.
- 0.5 stop bit: Used when receiving data in smart card mode.
- 2 stop bits: Used in normal mode, single-line mode and hardware flow control mode.
- 1.5 stop bits: Used when sending and receiving data in smart card mode.

##### Check bit

PCFG bit of USART\_CTRL1 determines the parity check bit; when PCFG=0, it is even parity check, on the contrary, it is odd parity check.

- Even check: When the number of frame data and check bit 1 is even, the even check bit is 0; otherwise it is 1.
- Odd check: When the number of frame data and check bit 1 is even, the odd check bit is 1; otherwise it is 0.

### 18.4.3 Transmitter

When TXEN bit of the register USART\_CTRL1 is set, the transmit shift register will output data through TX pin and the corresponding clock pulses will be output through CK pin.

#### 18.4.3.1 Character Transmit

During transmitting period of USART, the least significant bit of the data will be moved out by TX pin first. In this mode, USART\_DATA register has a buffer between the internal bus and the transmitter shift register.

A data frame is composed of the start bit, character and stop bit, so there is a low-level start bit in front of each character; then there is a high-level stop bits the number of which is configurable.

##### Transmission configuration steps

- Set UEN bit of USART\_CTRL1 register to enable USART.
- Decide the word length by setting DBLCFG bit of USART\_CTRL1 register.
- Decide the number of stop bits by setting STOPCFG bit of USART\_CTRL2 register.
- If multi-buffer communication is selected, DMA should be enabled in USART\_CTRL3 register.
- Set the baud rate of communication in USART\_BR register.
- Enable TXEN bit in USART\_CTRL1 register, and transmit an idle frame.
- Wait for TXBEFLG bit of USART\_STS register to be set to 1.
- Write data to USART\_DATA register (if DMA is not enabled, repeat steps 7-8 for each byte to be sent).
- Wait for TXCFLG bit of USART\_STS register to be set to 1, indicating transmission completion.

Note: TXEN bit cannot be reset during data transmission; otherwise, the data on TX pin will be destroyed, which is because if the baud rate generator stops counting, the data being transmitted will be lost.

#### 18.4.3.2 Single-byte communication

TXBEFLG bit can be cleared by writing USART\_DATA register. When the TXBEFLG bit is set by hardware, the shift register will receive the data transferred from the data transmit register, then the data will be transmitted, and the data transmit register will be cleared. The next data can be written in the data register without covering the previous data.

- (1) If TXBEIEN in USART\_CTRL1 register is set to 1, an interrupt will be generated.
- (2) If USART is in the state of transmitting data, write to the data register to save the data to the DATA register, and transfer the data to the shift register at the end of the current data transmission.
- (3) If USART is in idle state, write to the data register, put the data into the shift register, start transmitting data, and set TXBEFLG bit to 1.
- (4) When a data transmission is completed and TXBEFLG bit is set, TXCFLG bit will be set to 1; at this time if TXCIEN bit in USART\_CTRL1 register is set to 1, an interrupt will be generated.

- (5) After the last data is written in the USART\_DATA register, before entering the low-power mode or before closing the USART module, wait to set TXCFLG to 1.

#### 18.4.3.3 Break frame

The break frames are considered to receive 0 in a frame period. Setting TXBF bit of USART\_CTRL1 register can transmit a break frame, and the length of the break frame is determined by DBLCFG bit of USART\_CTRL1 register. If the TXBF bit is set, after completion of transmission of current data, the TX line will transmit a break frame, and after completion of transmission of break frame, the TXBF bit will be reset. At the end of the break frame, the transmitter inserts one or two stop bits to respond to the start bit.

Note: If the TXBF bit is reset before transmission of the break frame starts, the break frame will not be transmitted. To transmit two consecutive break frames, the TXBF bit should be set after the stop bit of the previous break symbol.

#### 18.4.3.4 Idle frame

The idle frame is regarded as a complete data frame composed entirely of 1, followed by the start bit of the next frame containing the data. Set TXEN bit of USART\_CTRL1 register to 1 and one idle frame can be set before the first data frame.

### 18.4.4 Receiver

#### 18.4.4.1 Character receiving

During receiving period of USART, RX pin will first introduce the least significant bit of the data. In this mode, USART\_DATA register has a buffer between the internal bus and the receiver shift register. The data is transmitted to the buffer bit by bit. When fully receiving the data, the corresponding receiver register is not empty, then the user can read USART\_DATA.

#### Receiving configuration steps

- Set UEN bit of USART\_CTRL1 register to enable USART.
- Decide the word length by setting DBLCFG bit of USART\_CTRL1 register.
- Decide the number of stop bits by setting STOPCFG bit of USART\_CTRL2 register.
- If multi-buffer communication is selected, DMA should be enabled in USART\_CTRL3 register.
- Set the baud rate of communication in USART\_BR register.
- Set RXEN bit of USART\_CTRL1 to enable receiving.

Note:

- (1) RXEN bit cannot be reset during data receiving period; otherwise, the bytes being received will be lost.
- (2) In the process when the receiver is receiving a data frame, if overrun error, noise error or frame error is detected, the error flag will be set to 1.
- (3) When data is transferred from the shift register to USART\_DATA register, the RXBNEFLG bit of USART\_STS will be set by hardware.
- (4) An interrupt will be generated if RXBNEIEN bit is set.
- (5) In single buffer mode, the RXBNEFLG bit can be cleared by reading USART\_DATA register by software or by writing 0.
- (6) In multi-buffer mode, after each byte is received, RXBNEFLG bit of USART\_STS register will be set to 1, and DMA will read the data register to clear it.

#### 18.4.4.2 Break frame

When the receiver receives a break frame, USART will handle it as receiving a frame error.

#### 18.4.4.3 Idle frame

When the receiver receives an idle frame, USART will handle it as receiving an ordinary data frame; if IDLEIEN bit of USART\_CTRL1 is set, an interrupt will be generated.

#### 18.4.4.4 Overrun error

When RXBNEFLG bit of USART\_STS register is set to 1 and a new character is received at the same time, an overrun error will be caused. Only after RXEN is reset, can the data be transferred from the shift register to DATA register. RXBNEFLG bit will be set to 1 after receiving the byte. This bit needs to be reset before receiving the next data or serving the previous DMA request; otherwise, an overrun error will be caused.

##### When an overrun error occurs

- USART\_STS OVREFLG bit set to 1.
- The data in DATA register will not be lost.
- The data in the shift register received before will be overwritten, but the data received later will not be saved.
- If RXBNEIEN bit of USART\_CTRL1 is set to 1, an interrupt will be generated.
- When OVREFLG bit is set to 1, it means that the data has been lost. There are two possibilities:
  - When RXBNEFLG=1, the previous valid data is still on DATA register, and can be read.
  - When RXBNEFLG=0, there is no valid data in DATA register.
- The OVREFLG bit can be reset through read operation for USART\_STS and USART\_DATA registers.

#### 18.4.4.5 Noise error

When noise is detected in receiving process of the receiver:

- Set NE flag on the rising edge of RXBNEFLG bit of USART\_STS register.
- Invalid data is transmitted from the shift register to USART\_DATA register.

#### 18.4.4.6 Frame error

If the stop bit is not received and recognized at the expected receiving time due to excessive noise or lack of synchronization, a frame error will be detected.

When a frame error is detected in receiving process of the receiver:

- (1) Set the FEFLG bit of USART\_STS register.
- (2) Invalid data is transmitted from the shift register to USART\_DATA register.
- (3) In single byte communication, there is no interrupt, but in multi-buffer communication, an interrupt will be generated by setting the ERRien bit of USART\_CTRL3 register.

#### 18.4.5 Baud Rate Generator

The baud rate division factor (USARTDIV) is a 16-digit number consisting of 12-digit integer part and 4-digit decimal part. Its relationship with the system clock:

$$\text{Baud rate} = \text{PCLK}/16 \times (\text{USARTDIV})$$

The system clock of USART2/3 is PCLK1, and that of USART1 is PCLK2. USART can be enabled only after the clock control unit enables the system clock.

#### 18.4.6 Multi-processor Communication

In multi-processor communication, multiple USARTs are connected to form a network. In this network, two devices communicate with each other, and the mute mode can be enabled for other devices not participating in the communication in order to reduce the burden of USART. In mute mode, no receive state bit will be set and all receive interrupts are disabled.

When mute mode is enabled, there are two ways to exit the mute mode:

- WUPMCFG bit is cleared and the bus is idle to exit the mute mode.
- WUPMCFG bit is set and after receiving the address flag, it can exit the mute mode.

##### Idle bus detection (WUPMCFG=0)

When RXMUTEEN is set to 1, USART enters the mute mode, and it can be waken up from the mute mode when an idle frame is detected, meanwhile, the RXMUTEEN bit will be cleared by the hardware. RXMUTEEN can also be cleared by software.

Figure 62 Idle Bus Exit Mute Mode



##### Address flag detection (WUPMCFG=1)

If the address flag bit is 1, this byte is regarded as the address. The storage address of lower four bits of the address bytes will first be compared with its own address when the receiver receives the address byte. If the addresses do not match, the receiver will enter the mute mode. If the addresses match, the receiver will wake up from the mute mode and be ready to receive the next byte. If the address byte is received again after exiting the mute mode, but the address does not match its own address, the receiver will enter the mute mode again.

Figure 63 Address Flag Exit Mute Mode



#### 18.4.7 Synchronous Mode

The synchronous mode supports full duplex synchronous serial communication in master mode, and has one more signal line USART\_CK which can output synchronous clock than the asynchronous mode.

CLKEN bit of USART\_CTRL2 register decides whether to enter the synchronous mode.

When USART enters the synchronous mode:

- The LINMEN bit of USART\_CTRL2 register, and IREN, HDEN and SCEN bits of USART\_CTRL3 register must be cleared.
- The start bit and stop bit of data frame have no clock output.
- Whether the last data bit of data frame generates USART\_CK clock is decided by the LBCPOEN bit of USART\_CTRL2 register.
- The clock polarity of USART\_CK is decided by CPOL bit of USART\_CTRL2 register.
- The phase of USART\_CK is decided by the CPHA bit of USART\_CTRL2.
- The external CK clock cannot be activated when the bus is idle or the frame is disconnected.

Figure 64 USART Synchronous Transmission Example



Figure 65 USART Synchronous Transmission Timing Diagram (DBLCFG=0)



Figure 66 USART Synchronous Transmission Timing Diagram (DBLCFG=1)



#### 18.4.8 LIN Mode

LINMEN bit of USART\_CTRL2 register decides whether to enter LIN mode.

When entering LIN mode:

- All data frames are 8 data bits and 1 stop bit.
- The CLKEN bit and STOPCFG bit of USART\_CTRL2 register and IREN bit, HDEN bit and SCEN bit of USART\_CTRL3 register need to be cleared.

In LIN master mode, USART can generate break frame, and the detection length of break frame can be set to 10 bits and 11 bits through LBDLCFG bit of USART\_CTRL2. The break frame detection circuit is independent of USART receiver, and no matter in idle state or in data transmission state, RX pin can detect the break frame, and LBDFLG bit of USART\_STS register is set to 1; at this time, if LBDIEN bit of USART\_CTRL2 is enabled, an interrupt will be generated.

### Detection of break frame in idle state

In idle state, if a break frame is detected on RX pin, the receiver will receive a data frame of 0 and generate FEFLG.

Figure 67 Break Frame Detection in Idle State



### Detection of break frame in data transmission state

In the process of data transmission, if the RX pin detects the break frame, the currently transmitted data frame will generate FEFLG.

Figure 68 Break Frame Detection in Data Transmission State



### 18.4.9 Smart Card Mode

Smart card mode is a single-line half-duplex communication mode. The interface supports ISO7816-3 standard protocol and can control the reading and writing of smart cards that meet the standard protocol.

SCEN bit of USART\_CTRL3 register decides whether to enter the smart card mode.

When USART enters the smart card mode:

- The LINMEN bit of USART\_CTRL2 register, and IREN and HDEN bits of USART\_CTRL3 register must be cleared.
- The data frame format is 8 data bits and 1 check bit, and 0.5 or 1.5 stop bits are used. (To avoid switching between two configurations, it is recommended to use 1.5 stop bits when transmitting and receiving data)

- CLKEN bit of USART\_CTRL2 can be set to provide clocks for smart card.
- During the communication, when the receiver detects a parity error, in order to inform the transmitter that the data has not been received successfully, the data line will be pulled down after half a baud rate clock, and keep pulling down for one baud rate clock.
- The break frame has no meaning in smart card mode. A 00h data with frame error will be regarded as a data instead of break symbol.

Figure 69 ISO7816-3 Standard Protocol



#### 18.4.10 Infrared (IrDA SIR) Function Mode

IrDA mode is a half-duplex protocol, transmitting and receiving data can not be carried out at the same time, and the delay between data transmitting and receiving should be more than 10ms.

IREN bit of USART\_CTRL3 register decides whether to enter the IrDA mode.

When USART enters the IrDA mode:

- The CLKEN bit, STOPCFG bit and LINMEN bit of USART\_CTRL2 register and HDEN bit and SCEN bit of USART\_CTRL3 register must be cleared.
- The data frame uses 1 stop bit and the baud rate is less than 115200Hz.
- Using infrared pulse (RZI) indicates logic 0, so in normal mode, its pulse width is 3/16 baud rate cycles. When IrDA is in low power mode, it is recommended that the pulse width be greater than three DIV frequency division clocks so as to ensure that this pulse can be detected by IrDA normally.

Figure 70 IrDA Mode Block Diagram



#### 18.4.11 Hardware Flow Control

The function of hardware flow control is to control the serial data flow between two devices through nCTS pin and nRTS pin.

Figure 71 Hardware Flow Control between Two USARTs



##### CTS flow control

CTSEN bit of USART\_CTRL3 register determines whether CTS flow control is enabled. If CTS flow control is enabled, the transmitter will detect whether the data frame of nCTS pin can be sent. If TXBEFLG bit=0 for USART\_STS register and nCTS is pulled to low level, the data frame can be sent. If nCTS becomes high during transmission, the transmitter will stop transmitting after the current data frame is transmitted.

##### RTS flow control

RTSEN bit of USART\_CTRL3 register determines whether RTS flow control is enabled. If RTS flow control is enabled, when the receiver receives data, nRTS will be pulled to low level. When a data frame is received, nRTS will become high to inform the transmitter to stop transmitting data frame.

#### 18.4.12 DMA Multi-processor Communication

USART can access the data buffer in DMA mode in order to reduce the burden of processors.

##### Transmission in DMA mode

DMATXEN bit of USART\_CTRL3 register determines whether to transmit in DMA mode. When transmitting by DMA, the data in the designated SRAM will be transmitted to the buffer by DMA.

Configuration steps of transmission by DMA:

- Clear the TXCFLG bit of USART\_STS register.
- Set the address of SRAM memory storing data as DMA source address.
- Set the address of USART\_DATA register as DMA destination address.
- Set the number of data bytes to be transmitted.
- Set channel priority.

- Set interrupt enable.
- Enable DMA channel.
- Wait for TXCFLG bit of USART\_STS register to be set to 1, indicating transmission completion.

### Receive in DMA mode

DMARXEN bit of USART\_CTRL3 register determines whether to receive by DMA. When receiving by DMA, every time one byte is received, the data in the receive buffer will be transmitted to the designated SRAM area by DMA.

Configuration steps of receiving by DMA:

- Set the address of USART\_DATA register as DMA source address.
- Set the address of SRAM memory storing data as DMA destination address.
- Set the number of data bytes to be transmitted.
- Set channel priority.
- Set interrupt enable.
- Enable DMA channel.

### 18.4.13 Interrupt Request

Table 65 USART Interrupt Request

| Interrupt event                      | Event flag bit | Enable bit |
|--------------------------------------|----------------|------------|
| The receive register cannot be empty | RXBNEFLG       | RXBNEIEN   |
| Overload error                       | OVREFLG        |            |
| Line idle is detected                | IDLEFLG        | IDLEIEN    |
| Odd-even parity error                | PEFLG          | PEIEN      |
| LIN break frame flag                 | LBDFLG         | LBDIEN     |
| Receiving error in DMA mode          | Noise error    | ERRIEN     |
|                                      | Overrun error  |            |
|                                      | Frame error    |            |
| Data transmit register is empty      | TXBEFLG        | TXBEIEN    |
| Transmission is completed            | TXCFLG         | TXCIEN     |
| CTS flag                             | CTSFLG         | CTSIEN     |

All interrupt requests of USART are connected to the same interrupt controller, and the interrupt requests have logical or relational before they are sent to the interrupt controller.

Figure 72 USART Interrupt Mapping



#### 18.4.14 Comparison of USART Supporting Functions

Table 66 Comparison of USART Supporting Functions

| USART mode                       | USART1 | USART2 | USART3 |
|----------------------------------|--------|--------|--------|
| Asynchronous mode                | √      | √      | √      |
| Hardware flow control            | √      | √      | √      |
| Multi-buffer communication (DMA) | √      | √      | √      |
| Multi-processor communication    | √      | √      | √      |
| Synchronous                      | √      | √      | √      |
| Smart card                       | √      | √      | √      |
| Half duplex (single-line mode)   | √      | √      | √      |
| IrDA                             | √      | √      | √      |
| LIN                              | √      | √      | √      |

Note: "√" means this function is supported, while "—" means that this function is not supported.

## 18.5 Register Address Mapping

Table 67 USART Register Address Mapping

| Register name | Description        | Offset address |
|---------------|--------------------|----------------|
| USART_STS     | State register     | 0x00           |
| USART_DATA    | Data register      | 0x04           |
| USART_BR      | Baud rate register | 0x08           |
| USART_CTRL1   | Control register 1 | 0x0C           |
| USART_CTRL2   | Control register 2 | 0x10           |

| Register name | Description                            | Offset address |
|---------------|----------------------------------------|----------------|
| USART_CTRL3   | Control register 3                     | 0x14           |
| USART_GTPSC   | Protection time and prescaler register | 0x18           |

## 18.6 Register Functional Description

### 18.6.1 State register (USART\_STS)

Offset address: 0x00

Reset value: 0x00C0

| Field | Name     | R/W   | Description                                                                                                                                                                                                                                                                                                                                      |
|-------|----------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | PEFLG    | R     | Parity Error Occur Flag<br>0: No error<br>1: Parity error occurs<br>In the receiving mode, when a parity error occurs, set to 1 by hardware;<br>This bit can be cleared by software; after setting of RXBNEFLG, first read USART_STS register, and then read USART_DATA register to complete clearing.                                           |
| 1     | FEFLG    | R     | Frame Error Occur Flag<br>0: No frame error<br>1: A frame error or break symbol appeared<br>When there is synchronous dislocation, too much noise or break symbol, set to 1 by hardware;<br>This bit can be cleared by software; first read USART_STS register, and then read USART_DATA register to complete clearing.                          |
| 2     | NEFLG    | R     | Noise Error Occur Flag<br>0: No noise<br>1: There is noise error<br>When there is noise error, set to 1 by hardware;<br>This bit can be cleared by software; first read USART_STS register, and then read USART_DATA register to complete clearing.                                                                                              |
| 3     | OVREFLG  | R     | Overrun Error Occur Flag<br>0: Overrun error<br>1: Overrun error occurred<br>When the RXBNEFLG bit is set and the data in the shift register is to be transmitted to the receiver register, set to 1 by hardware;<br>This bit can be cleared by software; first read USART_STS register, and then read USART_DATA register to complete clearing. |
| 4     | IDLEFLG  | R     | IDLE Line Detected Flag<br>0: Idle bus is not detected<br>1: Idle bus is detected<br>When idle bus is detected, set to 1 by hardware;<br>This bit can be cleared by software; first read USART_STS register, and then read USART_DATA register to complete clearing.                                                                             |
| 5     | RXBNEFLG | RC_W0 | Receive Data Buffer Not Empty Flag<br>0: The receive data buffer is empty<br>1: The receive data buffer is not empty<br>When the data register receives the data transmitted by the receiver shift register, set to 1 by hardware;<br>This bit can be cleared by software; read USART_DATA to clear, or write 0 to this bit to clear it.         |

| Field | Name    | R/W   | Description                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|---------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6     | TXCFLG  | RC_W0 | <p>Transmit Data Complete Flag<br/>0: transmitting data is not completed<br/>1: transmitting data is completed</p> <p>After the last frame of data is sent and the TXBEFLG is set, set to 1 by hardware;</p> <p>This bit can be cleared by software; first read USART_STS register, and then write USART_DATA register to complete clearing; or this bit can be cleared by writing 0 to it.</p> |
| 7     | TXBEFLG | R     | <p>Transmit Data Buffer Empty Flag<br/>0: The transmit data buffer is not empty<br/>1: The transmit data buffer is empty</p> <p>When the shift register receives the data transmitted by the transmitter data register, set to 1 by hardware;</p> <p>This bit can be cleared by software; write USART_DATA register to complete clearing.</p>                                                   |
| 8     | LBDFLG  | RC_W0 | <p>LIN Break Detected Flag<br/>0: LIN break not detected<br/>1: LIN break detected</p> <p>When LIN break is detected, set to 1 by hardware;</p> <p>This bit can be cleared by software; or cleared by writing 0 to this bit.</p>                                                                                                                                                                |
| 9     | CTSFLG  | RC_W0 | <p>CTS Change Flag<br/>0: No change on nCTS state line<br/>1: There is change on nCTS state line</p> <p>If the CTSEN bit is set, when switching to the nCTS input, set to 1 by hardware;</p> <p>This bit can be cleared by software; or cleared by writing 0 to this bit.</p>                                                                                                                   |
| 31:10 |         |       | Reserved                                                                                                                                                                                                                                                                                                                                                                                        |

### 18.6.2 Data register (USART\_DATA)

Offset address: 0x04

Reset value: 0xFFFF XXXX, X=undefined bit

| Field | Name | R/W | Description                                                                                                                                                                                                                                                                                    |
|-------|------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8:0   | DATA | R/W | <p>Data Value<br/>Transmit or receive the data value; read data when receiving data, and write data to the register when transmitting data.</p> <p>When the parity bit is enabled, for 9 data bits, the 8th bit of DATA is parity bit; for 8 data bits, the 7th bit of DATA is parity bit.</p> |
| 31:9  |      |     | Reserved                                                                                                                                                                                                                                                                                       |

### 18.6.3 Baud rate register (USART\_BR)

Offset address: 0x08

Reset value: 0x0000

| Field | Name      | R/W | Description                                                                                                                                 |
|-------|-----------|-----|---------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0   | FBR[3:0]  | R/W | <p>Fraction of USART Baud Rate Divider factor<br/>The decimal part of USART baud rate division factor is determined by these four bits.</p> |
| 15:4  | IBR[15:4] | R/W | <p>Integer of USART Baud Rate Divider factor<br/>The integral part of USART baud rate division factor is determined by these 12 bits.</p>   |
| 31:16 |           |     | Reserved                                                                                                                                    |

#### 18.6.4 Control register 1 (USART\_CTRL1)

Offset address: 0x0C

Reset value: 0x0000

| Field | Name     | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|----------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | TXBF     | R/W | <p>Transmit Break Frame<br/>0: Not transmit<br/>1: Will transmit</p> <p>This bit can be set by software and cleared by hardware when the stop bit of the break frame is transmit.</p>                                                                                                                                                                                                                                                       |
| 1     | RXMUTEEN | R/W | <p>Receive Mute Mode Enable<br/>0: Normal working mode<br/>1: Mute mode</p> <p>This bit is set or cleared by software, or cleared by hardware when wake-up sequence is detected.</p> <p>USART must receive a data before it is put in the mute mode, so that it can be detected and awakened by idle bus.</p> <p>In the wake-up of address flag detection, if the RXBNEFLG bit is set, the RXMUTEEN bit cannot be modified by software.</p> |
| 2     | RXEN     | R/W | <p>Receive Enable<br/>0: Disable<br/>1: Enable, and start to detect the start bit on RX pin</p>                                                                                                                                                                                                                                                                                                                                             |
| 3     | TXEN     | R/W | <p>Transmit Enable<br/>0: Disable<br/>1: Enable</p> <p>Except in smart card mode, if there is a 0 pulse on this bit at any time of transmitting data, an idle bus will be transmitted after the current data is transmitted.</p> <p>After this bit is set, the data will be transmitted after one-bit time.</p>                                                                                                                             |
| 4     | IDLEIEN  | R/W | <p>IDLE Interrupt Enable<br/>0: Disable<br/>1: Generate an interrupt when IDLEFLG is set</p>                                                                                                                                                                                                                                                                                                                                                |
| 5     | RXBNEIEN | R/W | <p>Receive Buffer Not Empty Interrupt Enable<br/>0: Disable<br/>1: Generate an interrupt when OVREFLG or RXBNEFLG is set</p>                                                                                                                                                                                                                                                                                                                |
| 6     | TXCIEN   | R/W | <p>Transmit Complete Interrupt Enable<br/>0: Disable<br/>1: Generate an interrupt when TXCFLG is set</p>                                                                                                                                                                                                                                                                                                                                    |
| 7     | TXBEIEN  | R/W | <p>Transmit Buffer Empty Interrupt Enable<br/>0: Interrupt generation is disabled<br/>1: Generate an interrupt when TXBEFLG is set</p>                                                                                                                                                                                                                                                                                                      |
| 8     | PEIEN    | R/W | <p>Parity Error interrupt Enable<br/>0: Interrupt generation is disabled<br/>1: Generate an interrupt when PEFLG is set</p>                                                                                                                                                                                                                                                                                                                 |
| 9     | PCFG     | R/W | <p>Odd/Even Parity Configure<br/>0: Even parity check<br/>1: Odd parity check</p> <p>The selection will not take effect until the current transmission of bytes is completed.</p>                                                                                                                                                                                                                                                           |
| 10    | PCEN     | R/W | <p>Parity Control Enable<br/>0: Disable<br/>1: Enable</p> <p>If this bit is set, a check bit will be inserted in the most significant bit when transmitting data; when receiving data, check whether the check bit of the received data is correct.</p>                                                                                                                                                                                     |

| Field | Name    | R/W | Description                                                                                                                                                                    |
|-------|---------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |         |     | The check control will not take effect until the current transmission of bytes is completed.                                                                                   |
| 11    | WUPMCFG | R/W | Wakeup Method Configure<br>0: Idle bus wakeup<br>1: Address tag wakeup                                                                                                         |
| 12    | DBLCFG  | R/W | Data Bits Length Configure<br>0: 1 start bit, 8 data bits, n stop bits<br>1: 1 start bit, 9 data bits, n stop bits<br>This bit cannot be modified during transmission of data. |
| 13    | UEN     | R/W | USART Enable<br>0: USART frequency divider and output are disabled<br>1: USART module is enabled                                                                               |
| 31:14 |         |     | Reserved                                                                                                                                                                       |

### 18.6.5 Control register 2 (USART\_CTRL2)

Offset address: 0x10

Reset value: 0x0000 0000

| Field | Name      | R/W | Description                                                                                                                                                                                                              |
|-------|-----------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0   | ADDR[3:0] | R/W | USART Device Node Address Setup<br>This bit is valid only in the mute mode of multiprocessor communication, and decides to enter the mute mode or wake up according to whether the detected address tags are consistent. |
| 4     |           |     | Reserved                                                                                                                                                                                                                 |
| 5     | LBDLCFG   | R/W | LIN Break Detection Length Configure<br>0: 10 bits<br>1: 11 bits                                                                                                                                                         |
| 6     | LBDIEN    | R/W | LIN Break Detection Interrupt Enable<br>0: Disable<br>1: Generate an interrupt when LBDFLG bit is set.                                                                                                                   |
| 7     |           |     | Reserved                                                                                                                                                                                                                 |
| 8     | LBCPOEN   | R/W | Last Bit Clock Pulse Output Enable<br>0: Not output from CK<br>1: Output from CK<br>This bit is valid only in synchronous mode.                                                                                          |
| 9     | CPHA      | R/W | Clock Phase Configure<br>This bit indicates on the edge of which clock sampling is conducted<br>0: The first<br>1: The second<br>This bit is valid only in synchronous mode.                                             |
| 10    | CPOL      | R/W | Clock Polarity Configure<br>The state of CK pin when USART is in idle state<br>0: Low level<br>1: High level<br>This bit is valid only in synchronous mode.                                                              |
| 11    | CLKEN     | R/W | Clock Enable (CK pin)<br>0: Disable<br>1: Enable                                                                                                                                                                         |
| 13:12 | STOPCFG   | R/W | STOP Bit Configure<br>00: 1 stop bit<br>01: 0.5 stop bit<br>10: 2 stop bit                                                                                                                                               |

| Field | Name   | R/W | Description                                |
|-------|--------|-----|--------------------------------------------|
|       |        |     | 11: 1.5 stop bit                           |
| 14    | LINMEN | R/W | LIN Mode Enable<br>0: Disable<br>1: Enable |
| 31:15 |        |     | Reserved                                   |

Note: These three bits (CPOL, CPHA and LBCPOEN) cannot be changed after transmission is enabled.

### 18.6.6 Control register 3 (USART\_CTRL3)

Offset address: 0x14

Reset value: 0x0000

| Field | Name     | R/W | Description                                                                                                                                                                                                                                                                                                                          |
|-------|----------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | ERRIEN   | R/W | Error interrupt Enable<br>0: Disable<br>1: Enable; when DMARXEN is set and one among FEFLG, OVREFLG or NEFLG is set, an interrupt will be generated.                                                                                                                                                                                 |
| 1     | IREN     | R/W | IrDA Function Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                                                      |
| 2     | IRLPEN   | R/W | IrDA Low-power Mode Enable<br>0: Normal mode<br>1: Low-power mode                                                                                                                                                                                                                                                                    |
| 3     | HDEN     | R/W | Half-duplex Mode Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                                                   |
| 4     | SCNACKEN | R/W | NACK Transmit Enable During Parity Error in Smartcard Function<br>0: NACK is not sent<br>1: Transmit NACK                                                                                                                                                                                                                            |
| 5     | SCEN     | R/W | Smartcard Function Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                                                 |
| 6     | DMARXEN  | R/W | DMA Receive Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                                                        |
| 7     | DMATXEN  | R/W | DMA Transmit Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                                                       |
| 8     | RTSEN    | R/W | RTS Hardware Flow Control Function Enable<br>0: Disable<br>1: Enable RTS interrupt<br>RTS: Require To Send, which is output signal, indicating it has been ready to receive.<br>Request is made to receive data only when there is space in the receive buffer; when data can be received, RTS output is pulled to low level.        |
| 9     | CTSEN    | R/W | CTS Hardware Flow Control Function Enable<br>0: Disable<br>1: Enable<br>CTS: Clear To Send, which is input signal<br>When CTS input signal is at low level, the data can be sent; otherwise, the data cannot be sent; if CTS signal is pulled to high during data transmission, the data transmission will be stopped after the data |

| Field | Name   | R/W | Description                                                                                                                                      |
|-------|--------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------|
|       |        |     | transmission is completed; if write operation is performed for the data register when CTS is high, the data will not be sent until CTS is valid. |
| 10    | CTSIEN | R/W | CTS Interrupt Enable<br>0: Disable<br>1: Generate an interrupt when CTSFLG is set                                                                |
| 31:11 |        |     | Reserved                                                                                                                                         |

### 18.6.7 Protection time and prescaler register (USART\_GTPSC)

Offset address: 0x18

Reset value: 0x0000

| Field | Name | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------|------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0   | PSC  | R/W | Prescaler Factor Setup<br>Divide the frequency and provide clock for the system clock respectively; in different working modes, the valid bits of PSC have difference, specifically as follows:<br>In infrared low-power mode:<br>PSC[7:0] is valid.<br>00000000: Reserved<br>00000001: 1 divided frequency<br>00000010: 2 divided frequency<br>.....<br>11111111: 255 divided frequency<br>In infrared normal mode:<br>PSC can only be set to 00000001<br>In smart card mode:<br>PSC[7:5] invalid, PSC[4:0] valid<br>00000: Reserved<br>00001: 2 divided frequency<br>00010: 4 divided frequency<br>00011: 6 divided frequency<br>.....<br>11111: 62 divided frequency<br>This bit does not exist on UART4 and UART5. |
| 15:8  | GRDT | R/W | Guard Time Value Setup<br>After transmitting data, TXCFLG can be set only after the protection time; the time unit is baud clock; which can be applied to smart card mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 31:16 |      |     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

## 19 Internal Integrated Circuit Interface (I2C)

### 19.1 Full Name and Abbreviation Description of Terms

Table 68 Full Name and Abbreviation Description of Terms

| Full name in English        | English abbreviation |
|-----------------------------|----------------------|
| Serial Data                 | SDA                  |
| Serial Clock                | SCL                  |
| System Management Bus       | SMBus                |
| Clock                       | CLK                  |
| Serial Clock High           | SCLH                 |
| Serial Clock Low            | SCLL                 |
| Address Resolution Protocol | ARP                  |
| Negative Acknowledgement    | NACK                 |
| Packet Error Checking       | PEC                  |
| Address Resolution Protocol | ARP                  |

### 19.2 Introduction

I2C is a short-distance bus communication protocol. In physical implementation, I2C bus is composed of two signal lines (SDA and SCL) and a ground wire. These two signal lines can be used for bidirectional transmission.

- Two signal lines, SCL clock line and SDA data line. SCL provides timing for SDA, and SDA transmits/receives data in series.
- Both SCL and SDA signal lines are bidirectional
- The ground is common when the two systems use I2C bus for communication.

### 19.3 Main Characteristics

- (4) Multi-master function
- (5) The master can generate the clock, start bit and stop bit
- (6) Slave function
  - Programmable I2C address detection
  - Double-address mode
  - Detection stop bit
- (7) 7-bit and 10-bit addressing mode
- (8) Response to broadcast
- (9) Two communication speeds
  - Standard mode
  - Fast mode

- (10) Programmable clock extension
- (11) State flag
  - Transmitter/Receiver mode flag
  - Flag for end of byte transmission
  - Flag of busy bus
- (12) Error flag
  - Arbitration loss
  - Acknowledgment error
  - Wrong start bit or stop bit detected
- (13) Interrupt source
  - Address/Data communication succeeded
  - Error interrupt
- (14) Support DMA function
- (15) Programmable PEC
  - Final transmission in transmission mode
  - PEC error check after the last byte is received
- (16) SMBus specific function
  - Hardware PEC
  - Address resolution protocol

## 19.4 Structure Block Diagram

Figure 73 I2C Structure Block Diagram



The interface can be configured to the following modes:

- Slave transmitting
- Slave receiving
- Master transmitting
- Master receiving

In the initial state of I2C interface, the working mode is slave mode. After I2C interface sends the start signal, it will automatically switch from slave mode to master mode.

## 19.5 Functional Description

Table 69 Description of Special Terms of I2C Bus

| Special terms    | Instruction                                                                                                                                                                 |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Transmitter      | Device transmitting data to the bus                                                                                                                                         |
| Receiver         | Device receiving data from the bus                                                                                                                                          |
| Master           | Device that initiates data transmission, generates clock signals and ends data transmission                                                                                 |
| Slave            | Device addressed by master                                                                                                                                                  |
| Multiple masters | Multiple masters that control the bus at the same time without destroying information                                                                                       |
| Synchronous      | The process of synchronizing the clock signals between two or more devices                                                                                                  |
| Arbitration      | If more than one master tries to control the bus at the same time, only one master can control the bus, and the information of the controlled master will not be destroyed. |

### 19.5.1 I2C Physical Layer

The commonly used connection modes between I2C communication devices are shown in the figure below

Figure 74 Commonly Used I2C Communication Connection Diagram



### Characteristics of physical layer

- (1) Bus supporting multiple devices (signal line shared by multiple devices), which, in I2C communication bus, can connect multiple communication masters and communication slaves.

- (2) An I2C bus only uses two bus lines, namely, a bidirectional serial data line (SDA) and a serial clock line (SCL). The data line is used for data transmission, and the clock line is used for synchronous receiving and transmission of data.
- (3) Each device connected to the bus has an independent address (seven or ten bits), and the master addresses and accesses the slave device according to the address of the device.
- (4) The bus needs to connect the pull-up resistor to the power supply. When I2C bus is idle, the output is in high-impedance state. When all devices are idle, the output is in high-impedance state, and the pull-up resistor pulls the bus to high level.
- (5) Three communication modes: Standard mode (up to 100KHz), fast mode (up to 400KHz), and fast mode plus (up to 1MHz)
- (6) When multiple masters use the bus at the same time, to prevent the data conflict, the bus arbitration mode is adopted to determine which device occupies the bus
- (7) Can program setup and hold time, and program the high-level time and low-level time of SCL in I2C.

### 19.5.2 I2C Protocol Layer

#### Characteristics of protocol layer

- (1) Data is transmitted in the form of frame, and each frame is composed of 1 byte (8 bits).
- (2) In the rising edge phase of SCL, SDA needs to keep stable and SDA changes during the period when SCL is low.
- (3) In addition to data frame, I2C bus also has start signal, stop signal and acknowledge signal.
  - Start bit: During the stable high level period of SCL, a falling edge of SDA starts transmission.
  - Stop bit: During the stable high level period of SCL, a rising edge of SDA stops transmission.
  - Acknowledge bit: Used to indicate successful transmission of one byte. After the bus transmitter (regardless of the master or slave) transmits 8-bit data, SDA will release (from output to input). During the ninth clock pulse, the receiver will pull down SDA to respond to the received data.

#### I2C communication reading and writing process

Figure 75 Master Writes Data to Slave



Figure 76 Master Reads Data from Slave



Remarks:

- (1) : This data is transferred from master to slave
- (2) S: Start signal
- (3) SLAVE ADDRESS: Slave address
- (4) : This data is transferred from slave to master
- (5) R/W: Selection bit of transmission direction
- (6) 1: Read
- (7) 0: Write
- (8) P: Stop signal

After the start signal is generated, all slaves will wait for the slave address signal sent by the master. In I2C bus, the address of each device is unique. When the address signal matches the device address, the slave will be selected, and the unselected slave will ignore the future data signal.

### **When the master direction is writing data**

After broadcasting the address and receiving the acknowledge signal, the master will transmit data to the slave, and the data length is one byte. Every time the master sends one byte of data, it needs to wait for the acknowledge signal transmitted by the slave. After all the bytes have been transmitted, the master will transmit a stop signal (STOP) to the slave, indicating that the transmission is completed.

### **When the master direction is reading data**

After broadcasting the address and receiving the acknowledge signal, the slave will transmit data to the master. The size of the data package is 8 bits. Every time the slave sends one byte of data, it needs to wait for the acknowledge signal of the master. When the master wants to stop receiving data, it needs to return a non-acknowledge signal to the slave, then the slave will stop transmitting the data automatically.

#### **19.5.3 Data Validity**

In the process of data transmission, the data on SDA line must be stable when the clock signal SCL is at high level. Only when the SCL is at the low level, can the level state of SDA be changed, and the bit transmission of each data needs a clock pulse.

Figure 77 SDA Timing Diagram



#### 19.5.4 Start and Stop Signals

All data transfer must have start signal (START) and stop signal (STOP).

Figure 78 START signal is defined as: when SCL is at high level, SDA will convert from high level to low level



Figure 79 STOP signal is defined as: when SCL is at high level, SDA will convert from low level to high level



#### 19.5.5 Arbitration

Arbitration is also used to solve the bus control conflict in case of multiple masters. The arbitration process takes place on the master and has nothing to do with the slave.

The master can start transmission only when the bus is idle. Two masters may generate an effective START signal on the bus within the shortest hold time of the START signal. In this situation, it is required by arbitration to decide which master completes the transmission.

Arbitration is conducted by bit. During each arbitration, when SCL is high, each master will check whether the SDA level is the same as that sent by itself. The arbitration process needs to last for many bits. Theoretically, if two masters transmit exactly the same content, they can successfully transmit without arbitration failure. If one master transmits high level, but it is detected that SDA is at low level, an arbitration failure error will occur, the SDA output of the master will be closed, and the other master will complete its own transmission.

Figure 80 SDA Timing Diagram



Note: Master 1 arbitration failure

### 19.5.6 SMBus Specific Function

System management bus (SMBus) is a simple single-end double-wire bus, which can meet the requirements of lightweight communication.

SMBus is commonly used in computer motherboard, mainly for power transmission ON/OFF instructions. SMBus is the derivative bus of I2C. It is mainly used for communication of low-bandwidth devices on computer motherboard, and power-related chip.

#### Address resolution protocol

SMBus specification includes an address resolution protocol, which can realize dynamic address assignment. The dynamic identification hardware and software enable the bus to support hot plug-in, and the bus devices are automatically identified and assigned with the unique addresses,

#### SMBus alarm

SMBus alarm is an optional signal with an interrupt line for pins that are sacrificed to extend their control ability

### 19.5.7 Error Flag Bit

Table 70 The following several error flag bits exist in I2C communication

| Error flag bit                             | Description of error flag bit                                                                                                                                                                                                              |
|--------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Answer error flag bit (AEFLG)              | No answer received                                                                                                                                                                                                                         |
| Bus error flag bit (BERRFLG)               | An external stop or start condition is detected                                                                                                                                                                                            |
| Arbitration loss flag bit (ALFLG)          | Arbitration loss is detected by the interface                                                                                                                                                                                              |
| Overrun/Underrun error flag bit (OVRURFLG) | In slave mode, the received data is not read out, the next data has arrived, and an overrun error occurs. The transmitting data clock has arrived, but the data has not been written into the DATA register, and an underrun error occurs. |
| Timeout or Tow error flag bit (TTEFLG)     | SCL is pulled down for more than a certain time                                                                                                                                                                                            |
| PEC comparison error flag bit (PECEFLG)    | CRC values are not equal                                                                                                                                                                                                                   |

### 19.5.8 Message Error Check (PEC)

I2C module has a PEC module, which checks the message of I2C data by CRC-8 calculator. The CRC-8 polynomial used by the calculator is:  $C(x)=X^8+X^2+X+1$ .

When PECEN bit is set to 1 and PEC function is enabled, PEC module will calculate all data sent by I2C bus, including address data.

### 19.5.9 DMA Mode

According to the software process of I2C, when the transmitter register is empty or the receiver register is full, MCU needs to write or read bytes, then we can complete the operation more quickly through the DMA function of I2C.

#### DMA transmission

Set the DMAEN bit in I2C\_CTRL2 register to enable the DMA mode. When the transmitter register is empty (TXBEFLG is set to 1), the data will be directly loaded from the memory area to the DATA register through DMA.

#### DMA receiving

Set DMAEN bit in I2C\_CTRL2 register to enable DMA mode. When the receiving register is full (RXBNEFLG is set to 1), DMA will transmit the data in DATA register to the set memory area.

### 19.5.10 I2C Interrupt

Table 71 I2C Interrupt Request

| Interrupt event                                        | Event flag bit | Interrupt control bit |
|--------------------------------------------------------|----------------|-----------------------|
| Transmitting start bit completed                       | STARTFLG       | EVIEN                 |
| Transmission completed/Address matching address signal | ADDRFLG        |                       |
| 10-bit address head segment transmission completed     | ADDR10FLG      |                       |
| Received stop signal                                   | STOPFLG        |                       |
| Data byte transmission completed                       | BT CFLG        |                       |
| Receive buffer not empty                               | RXBNEFLG       | EVIEN and BUFIEN      |
| Transmit buffer empty                                  | TXBEFLG        |                       |
| Bus error                                              | BERRFLG        | ERRIEN                |
| Arbitration loss                                       | ALFLG          |                       |
| Answer failed                                          | AEFLG          |                       |
| Overrun/Underrun                                       | OVRURFLG       |                       |
| PEC error                                              | PECEFLG        |                       |
| Timeout or Tlow error                                  | TTEFLG         |                       |
| SMBus alert                                            | ALERTEN        |                       |

## 19.6 Register Address Mapping

Table 72 I2C Register Address Mapping

| Register name | Description                   | Offset address |
|---------------|-------------------------------|----------------|
| I2C_CTRL1     | Control register 1            | 0x00           |
| I2C_CTRL2     | Control register 2            | 0x04           |
| I2C_SADDR1    | Slave address register 1      | 0x08           |
| I2C_SADDR2    | Slave address register 2      | 0x0C           |
| I2C_DATA      | Data register                 | 0x10           |
| I2C_STS1      | State register 1              | 0x14           |
| I2C_STS2      | State register 2              | 0x18           |
| I2C_CLKCTRL   | Master clock control register | 0x1C           |
| I2C_RISETMAX  | Maximum rising time register  | 0x20           |
| I2C_SWITCH    | I2C Switch register           | 0x100          |

## 19.7 Register Functional Description

### 19.7.1 Control register 1 (I2C\_CTRL1)

Offset address: 0x00

Reset value: 0x0000

| Field | Name    | R/W | Description                                                                                                                                      |
|-------|---------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | I2CEN   | R/W | I2C Enable<br>0: Disable<br>1: Enable                                                                                                            |
| 1     | SMBEN   | R/W | SMBus Mode Enable<br>0: I2C mode<br>1: SMBus mode                                                                                                |
| 2     |         |     | Reserved                                                                                                                                         |
| 3     | SMBTCFG | R/W | SMBus Type Configure<br>0: SMBus device<br>1: SMBus master                                                                                       |
| 4     | ARPEN   | R/W | ARP Enable<br>0: Disable<br>1: Enable<br>If SMBTCFG=0, use the default address of SMBus device<br>If SMBTCFG=1, use the primary address of SMBus |
| 5     | PECEN   | R/W | PEC Enable<br>0: Disable<br>1: Enable                                                                                                            |
| 6     | SRBEN   | R/W | Slave Responds Broadcast Enable<br>0: Disable<br>1: Enable<br>Note: The broadcast address is 0x00                                                |

| Field | Name        | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|-------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7     | CLKSTRETCHD | R/W | <p>Slave Mode Clock Stretching Disable<br/>0: Enable<br/>1: Disable</p> <p>In slave mode, enabling extending the low-level time of the clock can avoid overrun and underrun errors.</p>                                                                                                                                                                                                                                     |
| 8     | START       | R/W | <p>Start Bit Transfer<br/>This bit can be set to 1 and cleared by software; when transmitting the start bit or I2CEN=0, it is cleared by hardware.<br/>0: Not transmit<br/>1: Transmit</p>                                                                                                                                                                                                                                  |
| 9     | STOP        | R/W | <p>Stop Bit Transfer<br/>This bit can be set to 1 or cleared by software; when transmitting the stop bit, it is cleared by hardware; when timeout error is detected, it is set to 1 by hardware.<br/>0: Not transmit<br/>1: Transmit</p>                                                                                                                                                                                    |
| 10    | ACKEN       | R/W | <p>Acknowledge Transfer Enable<br/>This bit can be set to 1 or cleared by software; when I2CEN=0, it is cleared by hardware.<br/>0: Not transmit<br/>1: Transmit</p>                                                                                                                                                                                                                                                        |
| 11    | ACKPOS      | R/W | <p>Acknowledge /PEC Position Configure<br/>This bit can be set to 1 or cleared by software; when I2CEN=0, it is cleared by hardware.<br/>0: When receiving current byte, whether transmitting NACK/ACK, whether PEC is in shift register<br/>1: When receiving next byte, whether transmitting NACK/ACK and whether PEC is in the next byte of shift register</p>                                                           |
| 12    | PEC         | R/W | <p>Packet Error Check Transfer Enable<br/>This bit can be set to 1 or cleared by software; when transmitting PEC, or transmitting the start bit and stop bit, or when I2CEN=0, it is cleared by hardware.<br/>0: Disable<br/>1: Enable</p>                                                                                                                                                                                  |
| 13    | ALERTEN     | R/W | <p>SMBus Alert Enable<br/>This bit can be set to 1 or cleared by software; when I2CEN=0, it is cleared by software.<br/>0: Release the SMBAlert pin to make it higher, and remind to transmit the response address header immediately after transmitting the NACK signal<br/>1: Drive SMBAlert pin to make it lower, and remind to transmit the response address header immediately after transmitting the ACKEN signal</p> |
| 14    |             |     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 15    | SWRST       | R/W | <p>Software Configure I2C under Reset State<br/>0: Not reset<br/>1: Reset; before I2C reset, ensure that I2C pin is released and the bus is in idle state.</p>                                                                                                                                                                                                                                                              |

### 19.7.2 Control register 2 (I2C\_CTRL2)

Offset address: 0x04

Reset value: 0x0000

| Field | Name     | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|----------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5:0   | CLKFCFG  | R/W | <p>I2C Clock Frequency Configure<br/>           The clock frequency is the clock of I2C module, namely, the clock input from APB bus.</p> <p>0: Disable<br/>           1: Disable<br/>           2: 2MHz<br/>           ...<br/>           50: 50MHz<br/>           Greater than 100100: Disable.<br/>           Minimum clock frequency of I2C bus: the standard mode is 1MHz, and the fast mode is 4MHz.</p> |
| 7:6   | Reserved |     |                                                                                                                                                                                                                                                                                                                                                                                                                |
| 8     | ERRIEN   | R/W | <p>Error Interrupt Enable<br/>           0: Disable<br/>           1: When the position 1 of any of the following state register is enabled, the interrupt will be generated: SMBALTFGL, TTEFLG, PECEFLG, OVRURFLG, AEFLG, ALFLG, and STS1_BERRFLG</p>                                                                                                                                                         |
| 9     | EVIEN    | R/W | <p>Event Interrupt Enable<br/>           0: Disable<br/>           1: When the position 1 of any of the following state registers is enabled, the interrupt will be generated: STARTFLG, ADDRFLG, ADDR10FLG, STOPFLG, BT CFLG, TXBEFLG is set to 1 and BUFIEN is set to 1, RXBNEFLG is set to 1 and BUFIEN is set to 1.</p>                                                                                    |
| 10    | BUFIEN   | R/W | <p>Buffer Interrupt Enable<br/>           0: Disable<br/>           1: Enable; when the bit of any of the following state register is set to 1, the interrupt will be generated: TXBEFLG and RXBNEFLG</p>                                                                                                                                                                                                      |
| 11    | DMAEN    | R/W | <p>DMA Requests Enable<br/>           0: Disable<br/>           1: When TXBEFLG=1 or RXBNEFLG=1, enable DMA request</p>                                                                                                                                                                                                                                                                                        |
| 12    | LTCFG    | R/W | <p>DMA Last Transfer Configure<br/>           Configure whether the EOT of the next DMA is the last transmission received, and only used for the master receiving mode.</p> <p>0: No<br/>           1: Yes</p>                                                                                                                                                                                                 |
| 15:13 | Reserved |     |                                                                                                                                                                                                                                                                                                                                                                                                                |

### 19.7.3 Slave address register 1 (I2C\_SADDR1)

Offset address: 0x08

Reset value: 0x0000

| Field | Name      | R/W | Description                                                                                                                                                               |
|-------|-----------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | ADDR[0]   | R/W | <p>Slave Address Setup<br/>           When the address mode is 7 bits, the bit is invalid; when the address mode is 10 bits, this bit is 0 bit of the address.</p>        |
| 7:1   | ADDR[7:1] | R/W | <p>Slave Address Setup<br/>           Slave address bit. 7:1</p>                                                                                                          |
| 9:8   | ADDR[9:8] | R/W | <p>Slave Address Setup<br/>           When the address mode is 7 bits, the bit is invalid; when the address mode is 10 bits, this bit is the 9: 8 bit of the address.</p> |
| 14:10 | Reserved  |     |                                                                                                                                                                           |

| Field | Name    | R/W | Description                                                                       |
|-------|---------|-----|-----------------------------------------------------------------------------------|
| 15    | ADDRLEN | R/W | Slave Address Length Configure<br>0: 7-bit address mode<br>1: 10-bit address mode |

#### 19.7.4 Slave address register 2 (I2C\_SADDR2)

Offset address: 0x0C

Reset value: 0x0000

| Field | Name       | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | ADDRNUM    | R/W | Slave Address Number Configure<br>In the slave 7-bit address mode, it can be configured to identify the single-address mode and double-address mode; only ADDR1 is identified in single-address mode; both ADDR1 and ADDR2 can be identified in double-address mode<br>Single or double address registers can be identified in 7-bit address mode, specifically as follows:<br>0: Identify one address (ADDR1)<br>1: Identify two addresses (ADDR1 and ADDR2) |
| 7:1   | ADDR2[7:1] | R/W | Slave Dual Address Mode Address Setup<br>bit 7:1 of the address in double-address mode                                                                                                                                                                                                                                                                                                                                                                        |
| 15:8  |            |     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

#### 19.7.5 Data register (I2C\_DATA)

Offset address: 0x10

Reset value: 0x0000

| Field | Name | R/W | Description                                                                                                                                                     |
|-------|------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0   | DATA | R/W | Data Register<br>In I2C transmission mode, write the data to be transmit to this register;<br>in I2C receiving mode, read the received data from this register. |
| 15:8  |      |     | Reserved                                                                                                                                                        |

#### 19.7.6 State register 1 (I2C\_STS1)

Offset address: 0x14

Reset value: 0x0000

| Field | Name     | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------|----------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | STARTFLG | R   | Start Bit Transfer Finished Flag<br>0: Not transmit<br>1: Transmit<br>When the start bit is sent, this bit can be set to 1 by hardware; this bit can be cleared after the software first reads STS1 register and then writes the DATA register; when I2CEN=0, it can be cleared by hardware.                                                                                                                                     |
| 1     | ADDRFLG  | R   | Address Transfer Complete /Receive Match Flag<br>Whether the matching address is received in slave mode:<br>0: Not received<br>1: Received<br>Whether finishing transmitting the address in master mode:<br>0: Not completed<br>1: Completed<br>The bit is set to 1 by hardware; this bit can be cleared after the software first reads STS1 register and then reads STS2 register; when I2CEN=0, it can be cleared by hardware. |
| 2     | BTCFLG   | R   | Byte Transfer Complete Flag<br>0: Not completed<br>1: Completed                                                                                                                                                                                                                                                                                                                                                                  |

| Field | Name      | R/W   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------|-----------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |           |       | <p>When receiving data, if failing to read the data received in DATA register, and a new data is received then, set to 1 by hardware;</p> <p>When transmitting data, if the DATA register is empty, to transmit the data in the shift register, set to 1 by hardware.</p> <p>This bit can be cleared after the software first reads STS1 register, and then reads or writes the DATA register; this bit can be cleared by hardware by transmitting a start bit or stop bit during the transmission, or when I2CEN=0.</p>                                                                            |
| 3     | ADDR10FLG | R     | <p>10-Bit Address Header Transmit Flag</p> <p>0: Not transmit</p> <p>1: transmit</p> <p>The bit is set to 1 by hardware; this bit can be cleared after the software first reads STS1 register and then writes the DATA register; when I2CEN=0, it can be cleared by hardware.</p>                                                                                                                                                                                                                                                                                                                   |
| 4     | STOPFLG   | R     | <p>Stop Bit Detection Flag</p> <p>0: Not detected</p> <p>1: Detected</p> <p>If ACKEN=1, after one answer, when the slave detects the stop bit on the bus, it will be set to 1 by hardware;</p> <p>This bit can be cleared after the software first reads STS1 register and then writes CTRL1 register; when I2CEN=0, it can be cleared by hardware.</p>                                                                                                                                                                                                                                             |
| 5     |           |       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 6     | RXBNEFLG  | R     | <p>Receive Buffer Not Empty Flag</p> <p>0: The receive buffer is empty</p> <p>1: The receive buffer is not empty</p> <p>This bit can be set to 1 by hardware when there is data in DATA register; When BTCFLG is set to 1, since the data register is still full, the RXBNEFLG bit cannot be cleared by reading DATA register;</p> <p>This bit can be cleared after the software reads and writes DATA register; when I2CEN=0, it can be cleared by hardware.</p>                                                                                                                                   |
| 7     | TXBEFLG   | R     | <p>Transmit Buffer Empty Flag</p> <p>0: The transmit buffer is not empty</p> <p>1: The transmit buffer is empty</p> <p>This bit can be set to 1 by hardware when the content of DATA register is empty;</p> <p>When the software writes the first data to the DATA register, it will immediately move the data to the shift register, then the data in the DATA register is empty and this bit cannot be cleared;</p> <p>This bit can be cleared after the software writes data to DATA register; after transmitting the start bit or stop bit, or when I2CEN=0, it can be cleared by hardware.</p> |
| 8     | BERRFLG   | RC_W0 | <p>Bus Error Flag</p> <p>0: No bus error</p> <p>1: Bus error occurred</p> <p>Bus error means exception of start bit or stop bit; when an error is detected, this bit can be set to 1 by hardware; this bit can be cleared after the software writes 0; when I2CEN=0, it can be cleared by hardware.</p>                                                                                                                                                                                                                                                                                             |
| 9     | ALFLG     | RC_W0 | <p>Master Mode Arbitration Lost Flag</p> <p>0: No arbitration loss</p> <p>1: In case of arbitration loss, I2C interface will automatically switch back to slave mode</p> <p>"Arbitration loss in master mode" means the master loses the control of buses; this bit is set to 1 by hardware; this bit can be cleared after the software writes 0; when I2CEN=0, it is cleared by hardware.</p>                                                                                                                                                                                                      |
| 10    | AEFLG     | RC_W0 | <p>Acknowledge Error Flag</p> <p>0: No acknowledgment error</p> <p>1: Acknowledgment error occurred</p> <p>This bit can be set to 1 by hardware; this bit can be cleared after the software writes 0; when I2CEN=0, it can be cleared by hardware.</p>                                                                                                                                                                                                                                                                                                                                              |
| 11    | OVRURFLG  | RC_W0 | <p>Overrun/Underrun Flag</p> <p>0: Not occur</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

| Field | Name      | R/W   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------|-----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |           |       | <p>1: Occurred<br/>This bit can be set to 1 by hardware when CLKSTRETCHD=1 and one of the following conditions is met:<br/>(1) In the slave receiving mode, when the data in the DATA register is not read out, but a new data is received (this data will be lost), overrun occurs;<br/>(2) In the slave transmission mode, no data is written in the data register but it still needs to transmit data (the same data is sent twice), and then underrun occurs.<br/>This bit can be cleared by writing 0 by software; or be cleared by hardware when I2CEN=0.</p>                                                          |
| 12    | PECEFLG   | RC_W0 | <p>PEC Error in Reception Flag<br/>0: No PEC error: when ACKEN=1, after receiving PEC, the receiver will return ACKEN<br/>1: There is PEC error; regardless of the value of ACKEN, as long as PEC is received, the receiver will return NACK<br/>This bit can be cleared by writing 0 by software; or be cleared by hardware when I2CEN=0.</p>                                                                                                                                                                                                                                                                               |
| 13    | Reserved  |       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 14    | TTEFLG    | RC_W0 | <p>Timeout or Tlow Error Flag<br/>0: No timeout error<br/>1: When a timeout error occurs, in slave mode, the slave is reset and the bus is released; in master mode, the hardware transmit the stop bit.<br/>This bit can be set to 1 by hardware when timeout error occurs in any of the following situations:<br/>(1) SCL maintains low level for more than 25ms;<br/>(2) SCL low-level extension time of the main device is more than 10ms;<br/>(3) SCL low-level extension time of the slave device is more than 25ms.<br/>This bit can be cleared by writing 0 by software; or be cleared by hardware when I2CEN=0.</p> |
| 15    | SMBALTFLG | RC_W0 | <p>SMBus Alert Occur Flag<br/>0: SMBus master mode, without alarm;<br/>SMBus slave mode, without alarm, SMBAlert pin level unchanged<br/>1: SMBus master mode, with an alarm generated on the pin;<br/>SMBus slave mode, receiving an alarm, causing SMBAlert pin level to become low<br/>This bit can be set to 1 by hardware; this bit can be cleared after the software writes 0; when I2CEN=0, it can be cleared by hardware.</p>                                                                                                                                                                                        |

### 19.7.7 State register 2 (I2C\_STS2)

Offset address: 0x18

Reset value: 0x0000

| Field | Name      | R/W | Description                                                                                                                                                                                                                                                                                                           |
|-------|-----------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | MSFLG     | R   | <p>Master Slave Mode Flag<br/>0: Slave mode<br/>1: Master mode<br/>This bit can be set to 1 by hardware when I2C is configured as master mode;<br/>This bit can be cleared by hardware when one of the following conditions is met:<br/>(1) Stop bit is generated<br/>(2) Bus arbitration is lost<br/>(3) I2CEN=0</p> |
| 1     | BUSBSYFLG | R   | <p>Bus Busy Flag<br/>0: The bus is idle (no communication)<br/>1: The bus is busy (in the progress of communication)<br/>This bit can be set to 1 by hardware when SDA or SCL is at low level; cleared by hardware after the stop bit is generated.</p>                                                               |

| Field | Name        | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------|-------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2     | TRFLG       | R   | <p>Transmitter / Receiver Mode Flag<br/>           0: The device is in receiver mode (read)<br/>           1: The device is in transmitter mode (write)<br/>           Decide the bit value according to R/W bit;<br/>           This bit can be cleared by hardware when one of the following conditions is met:<br/>           (1) Stop bit is generated<br/>           (2) Repeated start bit is generated<br/>           (3) Bus arbitration loss<br/>           (4) I2CEN=0</p> |
| 3     | Reserved    |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 4     | GDCALLFLG   | R   | <p>Slave Mode Received General Call Address Flag<br/>           0: Failed to receive the broadcast address<br/>           1: Received broadcast address<br/>           This bit can be set to 1 by hardware; and be cleared by hardware when one of the following conditions is met:<br/>           (1) Stop bit is generated<br/>           (2) Repeated start bit is generated<br/>           (3) I2CEN=0</p>                                                                      |
| 5     | SMBDADDRFLG | R   | <p>SMBus Device Received Default Address Flag in Slave Mode<br/>           0: Failed to receive the default address<br/>           1: Received the default address when ARPEN=1<br/>           This bit can be set to 1 by hardware; and be cleared by hardware when one of the following conditions is met:<br/>           (1) Stop bit is generated<br/>           (2) Repeated start bit is generated<br/>           (3) I2CEN=0</p>                                              |
| 6     | SMMHADDR    | R   | <p>SMBus Device Received Master Header Flag in Slave Mode<br/>           0: Failed to receive the master head address<br/>           1: Received the master head address when SMBTSEL=1 and ARPEN=1<br/>           This bit can be set to 1 by hardware; and be cleared by hardware when one of the following conditions is met:<br/>           (1) Stop bit is generated<br/>           (2) Repeated start bit is generated<br/>           (3) I2CEN=0</p>                          |
| 7     | DUALADDRFLG | R   | <p>Slave Mode Received Dual Address Match Flag<br/>           0: The received address matches the content of ADDR1 register<br/>           1: The received address matches the content of ADDR2 register<br/>           This bit can be set to 1 by hardware; and be cleared by hardware when one of the following conditions is met:<br/>           (1) Stop bit is generated<br/>           (2) Repeated start bit is generated<br/>           (3) I2CEN=0</p>                     |
| 15:8  | PECVALUE    | R   | <p>Save Packet Error Checking Value<br/>           When PECEN=1, the internal PEC value is saved in PECVALUE.</p>                                                                                                                                                                                                                                                                                                                                                                    |

### 19.7.8 Master clock control register (I2C\_CLKCTRL)

Offset address: 0x1C

Reset value: 0x0000

| Field | Name        | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------|-------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11:0  | CLKS [11:0] | R/W | Clock Setup in Fast/Standard Master Mode<br>In I2C standard mode or SMBus mode:<br>$T_{high} = \text{CLKS} \times T_{PCLK1}$<br>$T_{low} = \text{CLKS} \times T_{PCLK1}$<br>In I2C fast mode:<br>When FDUTYCFG=0:<br>$T_{high} = \text{CLKS} \times T_{PCLK1}$<br>$T_{low} = 2 \times \text{CLKS} \times T_{PCLK1}$<br>When FDUTYCFG=1:<br>$T_{high} = 9 \times \text{CLKS} \times T_{PCLK1}$<br>$T_{low} = 16 \times \text{CLKS} \times T_{PCLK1}$ |
| 13:12 | Reserved    |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 14    | FDUTYCFG    | R/W | Fast Mode Duty Cycle Configure<br>Here define the duty cycle=tlow/thigh<br>0: SCLK duty cycle is 2<br>1: SCLK duty cycle is 16/9                                                                                                                                                                                                                                                                                                                    |
| 15    | SPEEDCFG    | R/W | Master Mode Speed Configure<br>0: Standard mode<br>1: Fast mode                                                                                                                                                                                                                                                                                                                                                                                     |

### 19.7.9 Maximum rising time register (I2C\_RISETMAX)

Offset address: 0x20

Reset value: 0x0002

| Field | Name     | R/W | Description                                                                                                                            |
|-------|----------|-----|----------------------------------------------------------------------------------------------------------------------------------------|
| 5:0   | RISETMAX | R/W | Master Mode Maximum Rise Time in Fast/Standard Mode<br>The time unit is TPCLK1, and RISETMAX is the maximum rising time of SCL plus 1. |
| 15:6  | Reserved |     |                                                                                                                                        |

### 19.7.10 I2C switch register (I2C\_SWITCH)

Offset address: 0x100

Reset value: 0x0000\_0000

| Field | Name     | R/W | Description                                                  |
|-------|----------|-----|--------------------------------------------------------------|
| 0     | SWITCH   | R/W | I2C Switch<br>0: I2C uses I2C1/I2C2<br>1: I2C uses I2C3/I2C4 |
| 31:1  | Reserved |     |                                                              |

## 20 Internal Integrated Circuit Interface (I2C3/4)

This module applies only to APM32F103xB D version.

### 20.1 Introduction

I2C bus is a two-wire serial interface, which consists of serial data line (SDA) and serial clock (SCL). These lines transmit information between devices connected to the bus. Each device is identified by a unique address and can work as a "transmitter" or "receiver", depending on the function of the device. When performing data transmission, the device can also be regarded as a master or slave. The master is the device that initiates data transmission on the bus and generates clock signals to enable the transmission. At this time, any device that is addressed is considered as slave.

I2C can run in standard mode (data rate is from 0 to 100 kb/s), fast mode (data rate is less than or equal to 400 kb/s), fast mode plus (data rate is less than or equal to 1000 kb/s), and high-speed mode (data rate is less than or equal to 3.4 kb/s).

I2C can only communicate with the devices in these modes as long as they are connected to the bus. Besides, the high-speed mode and fast-mode devices are downward compatible. For example, in a hybrid speed bus system, the high-speed mode devices can communicate with the devices in fast mode and standard mode. In the I2C bus system of 0-100kb/s, the fast-speed mode device can communicate with the standard mode device.

An example of high-speed mode devices is LCD display, high-bit count ADC and high-capacity EEPROM. These devices usually need to transmit mass data. Most maintenance and control applications, namely, the common use of I2C bus, usually operate at 100 kHz (in standard and fast-speed mode).

### 20.2 Functional Description

- Double-line I2C serial interface - consists of a serial data line (SDA) and a serial clock (SCL).
- Three speeds:
  - Standard mode (0 to 100 Kb/s)
  - Fast-speed mode ( $\leq$  400 Kb/s) or fast mode +( $\leq$  1000 Kb/s)
  - High-speed mode ( $\leq$  3.4 Mb/s)
- Clock synchronization
- Master or slave I2C operation
- 7 or 10-bit address
- 7 or 10-bit combined transmission
- Bulk transfer mode
- Ignore CBUS address (used for sharing I2C old address of I2C bus)
- Transmitting and receiving buffers
- Bit and byte waiting at the speeds of processing all buses
- Programmable SDA hold time ( $T_{HD: DAT}$ )
- Bus clear characteristics
- Dedicated transmit FIFO and receive FIFO; FIFO depth is 8, and FIFO bit width is 8 bits

#### 20.2.1 I2C Protocol

##### Start (START) and stop (STOP) conditions

When the bus is idle, both SCL and SDA signals are pulled up through the

external pull-up resistor on the bus. If the master wants to start transmission on the bus, it shall issue the start condition. This is defined as the high-low conversion of SDA signal, and SCL is 1. If the master wants to terminate the transmission, it shall issue the stop condition. This is defined as the low-high conversion of SDA line, and SCL is 1. The figure below shows the timing of start and stop conditions. When data is transmitted on the bus, SDA line must be stable if SCL is 1.

Figure 81 Start (START) and Stop (STOP) Conditions



### Addressing slave protocol

Two address formats: 7-bit address format and 10-bit address format

#### 7-bit address format

In the 7-bit address format, when bit 0 (R/W) is set to 0, the master writes to the slave. When the bit 0 (R/W) is set to 1, the master reads from the slave.

Figure 82 7-bit Address Format



#### 10-bit address format

In the 10 bit address format, two bytes are needed to transmit the 10 bit address. The transmission of the first byte contains the following bit definitions. The first five bits (bits 7:3) notify the slave that this is a 10-bit transmission, they are followed by the next two bits (bits 2:1) setting the slave address bits 9:8, and LSB bit (bit 0) as R/W bit. The second byte of the transmission sets the bits 7:0 of the slave address.

Figure 83 10-bit Address Format



### Bit definition of I2C in the first byte

Table 73 I2C Pin definition

| Slave address | R/W bit | Description                                                                                             |
|---------------|---------|---------------------------------------------------------------------------------------------------------|
| 0000 000      | 0       | Broadcast call address. I2C puts the data in the receive buffer and triggers a broadcast call interrupt |
| 0000 000      | 1       | Start bit                                                                                               |
| 0000 001      | X       | CBUS address. I2C ignores these addresses                                                               |
| 0000 010      | X       | Reserved                                                                                                |
| 0000 011      | X       | Reserved                                                                                                |
| 0000 1xx      | X       | High-speed master (master) code                                                                         |
| 1111 1xx      | X       | Reserved                                                                                                |
| 1111 0xx      | X       | 10-bit slave address.                                                                                   |
| 0001 000      | X       | Reserved                                                                                                |
| 0001 100      | X       | Reserved                                                                                                |
| 1100 001      | X       | Reserved                                                                                                |

### Transmit and receive protocol

As the master transmitter or master receiver, the master can initiate the data transmission and receiving between buses. The slave responds to the requests from the master to transmit data to the bus or receive data from the bus.

### Master transmitter and slave receiver

All data are transmitted in byte format, and the number of bytes of each data for transmission is unrestricted. After the master transmit address and R/W bit or the master transmit data byte to the slave, the slave receiver must respond with acknowledgment signal (ACK). When the slave receiver does not respond to the ACK pulse, the master will abort the transfer by transmitting a stop condition. The slave must keep the SDA line in high bit so that the master can abort the transfer. See the following figure for details.

Figure 84 Master Transmitter and Slave Receiver



### Master receiver and slave transmitter

If the master is receiving the data as shown in the figure below, after receiving one byte of data (except the last byte), the master will use an acknowledgment impulse to respond to the slave transmitter. Not transmitting acknowledgment pulse is a way for the master receiver to inform the slave transmitter that this is the last byte. The slave transmitter abandons the SDA line after detecting no acknowledgment (NACK) so that the master transmitter can issue the stop (STOP) condition.

Figure 85 Master Receiver Protocol



The slave transmitter abandons the SDA line after detecting no acknowledgment (NACK) so that the master transmitter can issue the stop (STOP) condition. This is the same as the start condition, except that it occurs after the ACK pulse. When running in the master mode, I2C can communicate

with the same slave through transmission in different directions.

### TXFIFO management and start (START), stop (STOP), and restart (RSTAEN)

Whenever TXFIFO becomes empty, the component will generate a stop (STOP) point on the bus. If the restart function is enabled, the component will generate a restart when the transmission direction in the TXFIFO command changes from read to write, and vice versa. If restart is not enabled, a stop will be generated in this case, and then a start will be generated.

The following timing diagram describes the behavior of I2C when TXFIFO becomes empty when it is running as the master transmitter.

Figure 86 I2C Timing Diagram "Taking TXFIFO as Master Transmitter"



The following timing diagram describes the behavior of I2C when TXFIFO becomes empty when it is running as the master receiver.

Figure 87 I2C Timing Diagram "Taking TXFIFO as Master Receiver"



### 20.2.2 Multi-master Arbitration

I2C bus protocol allows multiple masters to reside on the same bus. When there are two masters on the same I2C bus, if both masters attempt to control the bus by generating start condition at the same time, there will be an arbitration program.

Once a master controller (such as MCU) controls the bus, no other master controller can control the bus until the first master controller transmit a stop condition and the bus is idle.

Arbitration takes place on SDA line, while SCL line is 1. When another master transmits 0, the master transmits 1, the arbitration is lost and its data output phase is closed. The master that lost the arbitration can continue to generate the clock until the end of the byte transmission. If both masters are processing the same slave, arbitration may enter the data phase.

Once it is detected that it has lost arbitration with another master, I2C will stop

generating SCL (IC\_CLK\_oe).

Figure 88 Timing of Arbitration of Two Master Controllers on the Bus



For high-speed mode, since each master is programmed with a unique high-speed main code, arbitration cannot enter the data phase. The 8-bit code is defined by the system designer and is set by writing it into the high-speed master mode code address register HSMC. Since these codes are unique, only one master code can win arbitration, which occurs at the end of high-speed master code transmission. The control of the bus is determined by the address or master code and the data sent by the competing master, so there is neither a central master nor any priority order on the bus.

Arbitration is not allowed between restart condition and data bit, stop condition and data bit, restart condition and stop condition.

### 20.2.3 Clock Synchronization

When two or more masters attempt to transmit information on the bus at the same time, they must arbitrate and synchronize the SCL clock. Data is only valid in the high cycle of the SCL clock. Clock synchronization is performed by connecting lines to SCL signal. When the master converts the SCL clock to 0, the master starts to count the low time of the SCL clock, and converts the SCL clock signal to 1 at the beginning of the next clock cycle. However, if another master maintains the SCL line at 0, the master will enter a high wait state until the SCL clock row is converted to 1.

Then, all masters will report their high time, and the master with the shortest high time converts the SCL line to 0. Then, the master calculates its low time, and the one with the longest low time forces the other master to enter a high wait state. Therefore, a synchronized SCL clock will be generated. Or the slave can maintain the SCL line in a low position to slow down the timing on the I2C bus.

### 20.2.4 IC\_CLK Frequency Configuration

When I2C is configured as standard speed (SS), fast speed (FS)/fast mode plus (FM+) or high-speed (HS) master control, the registers must be set before any I2C bus service occurs to ensure correct I/O timing.

Registers in different modes are shown in the table below:

Table 74 Register in Different Modes

| Mode                                       | Register       |
|--------------------------------------------|----------------|
| Standard speed (SS) mode                   | SSCHC<br>SSCLC |
| Fast speed (FS)/fast speed mode plus (FM+) | HSCHC<br>HSCLC |
| High speed (HS)                            | HSCHC<br>HSCLC |

#### Minimum high and low count in SS, FS, FM+ and HS mode

When I2C is working as I2C master, in transmitting and receiving transmission:

- (1) The value of SSCLC and FSCLC registers must be greater than LSSSL+7.
- (2) The value of SSCHC and FSCHC registers must be greater than LSSSL+5.
- (3) If this component is programmed to support HS, the value of HSCLC register must be greater than HSSL+7.
- (4) If this component is programmed to support HS, the value of HSCLC register must be greater than HSSL+5.

Details about I2C high and low counts are as follows:

- (1) The minimum value of IC\_\*\_SPKLEN+7 of \*\_LCNT register is the time required to drive SDA after I2C is on the negative edge of SCL.
- (2) The minimum value of IC\_\*\_SPKLEN+5 of \*\_HCNT register is the time required to collect SDA samples because I2C is in the high-cycle period of SCL.
- (3) I2C adds a loop to the programmed \*\_LCNT value to generate the low cycle of SCL clock, which is because of the count logic of SCL low count to (\*\_LCNT+1).
- (4) I2C adds IC\_\*\_SPKLEN+7 loop to the programmed \*\_HCNT value to generate the high cycle of SCL clock, which is because of the following factors.
  - Count logic of SCL high count to (\*\_HCNT+1).
  - The digital filtering applied to SCL line will lead to delay of spklen+2IC\_clk cycle,
  - The filtering includes metastable removal and programmable peak suppression of SDA and SCL edges.
  - When I2C drives SCL from 1 to 0, the SCL high time is completed, and internal logic delay of three IC\_CLK cycles will be generated. Therefore, the minimum SCL low time that I2C can achieve is nine IC\_CLK cycles (7+1+1), while the minimum SCL high time is thirteen IC\_CLK cycles (6+1+3+3).

Note: The total high and low time of SCL generated by I2C master is also affected by the rising time and falling time of SCL line, as shown in the figure and equation. It should be noted that the rising and falling time parameters of SCL vary with external factors, such as:

- IO driver characteristics
- Pull-up resistance

- Total capacitance on SCL line, etc.

Figure 89 Rising and Falling Time Parameter Configuration Diagram



## 20.2.5 Operation Mode

### 20.2.5.1 Slave mode operation

#### Initial Configuration

To use I2C as a slave device, perform the following steps:

- (1) Disable I2C by writing "0" to bit 0 of CTRL1 register
- (2) Write SLAADDR register (bit 9:0) to set slave address. This is the address of the I2C response
- (3) Write to CTRL0 register to specify which type of addressing (7 or 10 bits, set by bit 3) is supported by writing "0" to bit 6 (IC\_SLAVE\_DISABLE) and writing "0" to bit 0 (MST), and enable I2C in slave only mode.
- (4) I2C is enabled by writing "1" to bit 0 of CTRL1 register.

#### Single-byte slave transmitter operation

When another I2C master on the bus addresses I2C and requests data, I2C will act as a slave transmitter, and the following steps will occur:

- (1) Another I2C master starts I2C transmission, and its address matches the slave address in SLAADDR register of I2C.
- (2) I2C confirms the transmitting address and identifies the transmission direction to indicate that it is a slave transmitter.
- (3) I2C enables the RRIF interrupt (bit 5 of the RIS register) and keeps the SCL line low. It is in wait state until the software responds. If the RRIF interrupt has been masked because the INTEN [5] register (RRIE bit field) is set to 0, it is recommended that the hardware and/or software timing program be used to indicate that the CPU reads the RIS register periodically.

- The read operation indicating that RIS [5] (RRIF bit field) is set to 1 must be regarded as the equivalent operation of the enabled RRIF interrupt.
  - Then the software must operate to satisfy I2C transmission.
  - The timing interval used should be 10 times of the fastest SCL clock cycle that I2C can handle. For example, for 400 kb/s, the timing interval is 25 $\mu$ s.
- (4) If there is any data in the transmit FIFO before the read request is received, I2C enables the Tx ABRT interrupt (Bit 6 of the RIS register) to refresh the old data from the transmit FIFO. If the Tx-ABRT interrupt is masked, since the INTEN[6] register (TAIE bit field) is set to 0, it is recommended that the timing program (described in the previous step) or similar program be used again to read the RIS register.
- Read indicating that Bit 6 (TAIF) is set to 1 must be regarded equivalent to the enabled TAIF interrupt.
  - The software does not need further operation.
  - The timing interval used should be similar to the time interval described for RIS[5] register in the previous step.
- (5) The software writes the data to the DATA register (by writing '0' to Bit 8).
- (6) Before the program, the software must clear the RRIF and TAIF interrupts (Bit 5 and Bit 6 respectively) of RIS register. If the RRIF and/or TAIF interrupts are masked, when the RRIF or TAIF bit is read to 1, clear of the RIS register will have been performed.
- (7) I2C releases SCL and transmits bytes.
- (8) The master can retain the I2C mainline by issuing the restart (RSTAEN) condition or release the mainline by transmitting a stop (STOP) condition.

### **Single-byte slave receiver operation**

When another I2C master on the mainline addresses I2C and transmit data, I2C acts as a slave receiver, to perform the following steps:

- (1) Another I2C master starts an I2C transmission with the address in SLAADDR register that matches I2C slave address.
- (2) I2C confirms the address sent and identifies the direction of the transmission to indicate that I2C acts as a slave receiver.
- (3) I2C receives the bytes transmitted and puts them in the receive buffer.
- (4) I2C enables RFFIF interrupt (RIS[2] register). Since the INTEN[2] register is set to 0 or the TFT is set to a value greater than 0, if the RFFIF interrupt has been masked, it is recommended to implement a timing program for the periodic reading of STS1 register. The reading operation of the STS1 register with Bit 3 (RFNEF) set to 1 must be considered by the software as equivalent to the RFFIF interrupt enabled.
- (5) The software can read bytes (Bit 7:0) from DATA register.
- (6) Another master can retain the I2C mainline by issuing the restart (RSTAEN) condition or release the mainline by transmitting a stop (STOP) condition.

### Slave transmission operation of bulk transmission

In the standard I2C protocol, all transmissions are single-byte transmission, and responds to the remote master read request by writing a byte to the FIFO of the slave. When the slave (slave transmitter) responds to a read request from the remote master (master receiver), at least one entry should be put in the TXFIFO of the slave transmitter. I2C is used to process more data in TXFIFO, so that the subsequent read requests can get more data without causing any interrupt.

Finally, this eliminates the possibility of occurrence of major delay between data interrupts every time only one entry is placed in TXFIFO.

This mode occurs only when I2C acts as a slave transmitter. If the remote master confirms the data sent by the slave and there is no data in the TXFIFO of the slave, I2C will keep the row in low bit while transmitting the read request interrupt (RRIF) and wait for the data to be written into the TXFIFO before the data is sent to the remote master.

If the RRIF interrupt is masked, since Bit 5 (RRIE) of the ISTS register is set to 0, it is recommended to use a timing program to activate periodic reading of the RIS register. The read operation of RIS with Bit 5 (RRIF) restored to 1 must be regarded as equivalent read operation to the RRIF interrupt mentioned in this section.

RRIF interrupts are triggered when reading requests. Like interrupts, they must be cleared when exiting the interrupt service processing routine (ISR). ISR allows you to write one or more bytes to TXFIFO. During transmission of these bytes to the master, if the master confirms the last byte, the slave must issue a RRIF again, which is because the master is requesting more data.

If knows in advance that the remote master is requesting an n-byte data packet, when another master addresses I2C and requests data, TXFIFO can be written in n bytes, and the remote master receives it as a continuous data stream. For example, the I2C slave will continue to transmit data to the remote master as long as the remote master is confirming the sent data and there is data available in TXFIFO. There is no need to keep the SCL row in low bit or issue a RRIF again.

If the remote master wants to receive n bytes from I2C, but writes the bytes greater than n into TXFIFO, when the slave completes transmitting the requested n bytes, the master will clear TXFIFO and ignore any redundant bytes.

I2C generates a transfer abort (TAIF) event to indicate the clearing of TXFIFO in this case. When ACK/NACK is needed, if NACK is received, the remote master will have all the required data. At this time, the state machine of the slave issues a flag to clear the remaining data in TXFIFO. This flag is transmitted to the processor bus clock domain where the FIFO is located, and the content of TXFIFO is cleared.

### 20.2.5.2 Master mode operation

#### Initial Configuration

As the master of I2C, the destination address and address format can be changed without disabling I2C. The slave requires that the component be disabled before making any changes to the addressing.

- (1) Write 0 to Bit 0 of CTRL1 register to disable I2C.

- (2) When the device is slave (Bit 3), write to CTRL0 register to set the maximum speed mode (Bit 2:1) supported by slave operation, and specify whether I2C starts transmission in 7/10-bit addressing mode.
- (3) Write the address of the I2C device to be addressed to the TARADDR register. It also indicates I2C will execute the general call or start byte command. The speed required for the transmission (7-bit or 10-bit address) initiated by the I2C master controller is controlled by the MAM bit field (Bit 12).
- (4) Apply only to transmission in high-speed mode. Write the main code required by I2C to HSMC register. The main code is defined by the programmer.
- (5) Write 1 to Bit 0 of CTRL1 register to enable I2C.
- (6) Now write the transmission direction and data to be sent to the DATA register. If the DATA register is written before I2C is enabled, the data and commands will be lost with the clearing of buffer when I2C is not enabled.

### 20.2.6 Spike Suppression

I2C contains programmable peak suppression logic, which meets the requirements of I2C bus specification for SS/FS and HS modes.

This logic is based on the counter that monitors the input signals (SCL and SDA). Each signal has a separate counter (SCL and SDA). The number of IC\_CLK cycles can be programmed by the user, and the frequency of IC\_CLK and related peak length specifications should be considered in the calculation.

Each counter will be activated whenever the input signal value is changed. One of the following situations will occur, depending on the behavior of the input signal:

The input signal remains unchanged until the counter reaches the count limit. When this situation happens, the internal version of the signals will be updated with the input value and the counter will be reset and stopped. The counter will not restart until a new change to the input signal is detected.

Before the counter reaches the count limit, the input signal will change again. When this situation happens, the counter will be reset and stopped, but the internal version of the signal will not be updated. The counter remains in stop state until a new change on the input signal is detected.

The width of these registers is 8 bits, which can be read and written through APB interface. However, they can be written only when I2C is disabled. The minimum value that can be programmed into these registers is 1. If you attempt to write a value less than 1, 1 will be written.

## 20.3 Register Address Mapping

Table 75 I2C3/4 Register Address Mapping

| Register name | Description                  | Offset address |
|---------------|------------------------------|----------------|
| CTRL0         | Control register             | 0x00           |
| TARADDR       | Destination address register | 0x04           |
| SLAADDR       | Slave address register       | 0x08           |

| Register name | Description                                                                           | Offset address |
|---------------|---------------------------------------------------------------------------------------|----------------|
| HSMC          | Master address register                                                               | 0x0C           |
| DATA          | Data command register                                                                 | 0x10           |
| SSCHC         | SCL high-bit counter register of standard-speed I2C clock                             | 0x14           |
| SSCLC         | SCL low-bit counter register of standard-speed I2C clock                              | 0x18           |
| FSCHC         | SCL high-bit counter register of I2C clock of fast-speed mode or fast-speed plus mode | 0x1C           |
| FSCLC         | SCL low-bit counter register of I2C clock of fast-speed mode or fast-speed plus mode  | 0x20           |
| HSCHC         | SCL high-bit counter register of high-speed mode I2C clock                            | 0x24           |
| HSCLC         | SCL low-bit counter register of high-speed mode I2C clock                             | 0x28           |
| ISTS          | Interrupt state register                                                              | 0x2C           |
| INTEN         | Interrupt enable register                                                             | 0x30           |
| RIS           | Original interrupt state register                                                     | 0x34           |
| RFT           | Transmit FIFO watermark register                                                      | 0x38           |
| TFT           | Receive FIFO watermark register                                                       | 0x3C           |
| ICF           | Clear combined and single interrupt register                                          | 0x40           |
| RFUIC         | Clear RFUIT interrupt register                                                        | 0x44           |
| RFOIC         | Clear RFOIF interrupt register                                                        | 0x48           |
| TFOIC         | Clear TFOIF interrupt register                                                        | 0x4C           |
| RRIC          | Clear RRIF interrupt register                                                         | 0x50           |
| TAIC          | Clear TAIF interrupt register                                                         | 0x54           |
| RDIC          | Clear RDIF interrupt register                                                         | 0x58           |
| AIC           | Clear ACTIF interrupt register                                                        | 0x5C           |
| STPDIC        | Clear STPDIF interrupt register                                                       | 0x60           |
| STADIC        | Clear STADIF interrupt register                                                       | 0x64           |
| GCIC          | Clear GCIF interrupt register                                                         | 0x68           |
| CTRL1         | Start the register                                                                    | 0x6C           |
| STS1          | State register                                                                        | 0x70           |
| TFL           | Transmit FIFO stock register                                                          | 0x74           |
| RFL           | Receive FIFO stock register                                                           | 0x78           |
| SDAHOLD       | SDA hold time register                                                                | 0x7C           |
| TAS           | Transfer abort source register                                                        | 0x80           |
| SDNO          | Generate slave data NACK register                                                     | 0x84           |
| DMACTRL       | DMA control register                                                                  | 0x88           |
| DTDL          | DMA transmitting data level register                                                  | 0x8C           |
| DRDL          | DMA receive data level register                                                       | 0x90           |
| SDADLY        | SDA setup register                                                                    | 0x94           |
| GCA           | ACK general call register                                                             | 0x98           |

| Register name | Description                                    | Offset address |
|---------------|------------------------------------------------|----------------|
| STS2          | Enable state register                          | 0x9C           |
| LSSL          | SS, FS or FM+ spike suppression limit register | 0xA0           |
| HSSL          | HS spike suppression limit register            | 0xA4           |

## 20.4 Register Functional Description

### 20.4.1 I2C control register (CTRL0)

Offset address: 0x00

Reset value: 0x3E

| Field | Name   | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------|--------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | MST    | R/W | Master mode controller<br>Whether this bit controls 2C master<br>1: Enable master mode<br>0: Disable master mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 2:1   | SPEED  | R/W | I2C operating speed<br>These bits control the speed of I2C operation; it can be set only when I2C is operated in master mode. Hardware can prevent illegal values written by software. These bits must be properly programmed for the slave mode as they are used to capture the correct narrow band filter value according to the speed mode.<br>The programming value of this register can only be between 1 and 3; otherwise, the hardware will update the value of this register to 3.<br>01: Standard mode (100kbit/s)<br>10: Fast-speed mode (<=400kbit/s) or fast-speed mode+ (<=1000Kbit/s)<br>11: High-speed mode (3.4Mbit/s)                                                                                                                                                                               |
| 3     | SAM    | R/W | Select the addressing mode<br>0: 7-bit addressing mode<br>1: 10-bit addressing mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 4     |        |     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 5     | RSTAEN | R/W | Transmitting the repeat start bit allowed<br>0: Transmitting repeat start bit not supported.<br>1: Transmitting repeat start bit supported.<br>Confirm whether RSTAEN can be sent when it acts as a master. Some older slaves do not support processing RSTAEN; however, RSTAEN is used in some I2C operations. When restart is disabled, the main program is disabled to perform the following functions:<br>transmit a start byte (START BYTE)<br>Perform any high-speed mode operation<br>High-speed mode operation<br>Perform direction changes in combination mode<br>Perform read operation with 10-bit address<br>By replacing RSTAEN with stop and following START, discompose the operation into multiple I2C transmissions. If the above operation is performed, Bit 6 (TAIF) of RIS register will be set. |
| 6     | SLADIS | R/W | Enable the slave mode<br>0: Slave mode enabled<br>1: Slave mode disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

| Field | Name  | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|-------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |       |     | This bit controls whether I2C has disabled its slave. After the reset is applied, you can choose to enable or disable the slave, which means that the software does not need to configure the slave. By default, the slave is always enabled (also in reset state). If you need to disable it after reset, set this bit to 1. If this bit is set (the slave is disabled), I2C will only run as the master and will not perform any operation that requires the slave. |
| 7     | DSA   | R/W | In slave mode:<br>1: (ENABLED): As long as it is addressed, the slave will issue STPDIF interrupt<br>0: (DISABLED): The slave always issues STPDIF interrupt<br>Note: During general call addressing, if DSA=1b1, this slave will not issue STPDIF interrupt, even if the slave responds to the general call addressing by generating ACK. STPDIF interrupt is generated only when the transmission address matches the slave address (SAR).                          |
| 8     | TFEIC | R/W | This bit controls the generation of TFEIF interrupts, as described in the RIS register.<br>1 (ENABLED): Control generation of TFEIF interrupt<br>0 (DISABLED): Default behavior of TFEIF interrupt                                                                                                                                                                                                                                                                    |
| 9     | RFFIE | R   | This bit controls whether I2C maintains the bus when RXFIFO is full<br>1: (ENABLED): Maintain the bus when RX_FIFO is full<br>0: (DISABLED): Overrun when RX_FIFO is full                                                                                                                                                                                                                                                                                             |
| 10    | DSMA  | R   | In master mode:<br>1: (ENABLED): Enable STPDIF interrupt only when the master is running<br>0: (DISABLED): Enable STPDIF interrupt regardless of whether the master is running                                                                                                                                                                                                                                                                                        |
| 31:11 |       |     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

#### 20.4.2 I2C destination address register (TARADDR)

Offset address: 0x4

Reset value: 0x1055

| Field | Name | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------|------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8:0   | ADDR | R/W | This is the destination address of any master transaction. In GENERAL_CALL, these bits will be ignored. To generate START_BYTE, the CPU only needs to write these bits once. If ADDR and SAR are the same, they can transmit to themselves, but FIFOs are shared between master and slave, and they cannot transmit to themselves. Only support simplex mode, and do not support duplex mode. The master cannot transmit information to itself; it can only transmit to one slave. |
| 10:9  | STA  | R/W | If the GCEN bit is set to 1, it indicates I2C performs the broadcast or start byte command.<br>1: START_BYTE: start byte transmission<br>0: GENERAL_CALL: broadcast byte transmission                                                                                                                                                                                                                                                                                              |
| 11    | GCEN | R/W | This bit indicates whether the software executes the device ID, or general call, or start byte command.<br>1: (ENABLED): Enable the program transmitted by GENERAL_CALL or START_BYTE<br>0: (DISABLED): Disable the program transmitted by GENERAL_CALL or START_BYTE                                                                                                                                                                                                              |

| Field | Name     | R/W | Description                                                                                                                                                                                                                      |
|-------|----------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12    | MAM      | R/W | When I2C is the master, this bit is configured to start its transmission in 7-bit or 10-bit addressing mode.<br>1: (ADDR_10BITS): Addressing 10-bit transmission format<br>0: (ADDR_7BITS): Addressing 7-bit transmission format |
| 31:13 | Reserved |     |                                                                                                                                                                                                                                  |

#### 20.4.3 I2C slave address register (SLAADDR)

Offset address: 0x8

Reset value: 0x055

| Field | Name     | R/W | Description                                                                                                                                                                                                                                              |
|-------|----------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9:0   | SAR      | R/W | When I2C runs as a slave, SLAADDR will save the slave address. For 7-bit addressing, only use SLAADDR[6:0]. This register can write only when I2C interface is disabled, corresponding to CTRL1[0] register set to 0. Writing is invalid in other cases. |
| 31:10 | Reserved |     |                                                                                                                                                                                                                                                          |

#### 20.4.4 Main address register (HSMC)

Offset address: 0xC

Reset value: 0x7

| Field | Name     | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------|----------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0   | HSMC     | R/W | This bit field saves the value of I2C HS mode main code. The HS mode master code is a reserved 8-bit code (00001xxx) and is not used for slave addressing or other purposes. Each master has its own unique main code; in the same I2C bus system, up to 8 high-speed mode masters can be provided. The valid values range from 0 to 7. This register disappears and returns 0, and becomes read-only. This register can write only when I2C interface is disabled, corresponding to CTRL1[0] register set to 0. Writing is invalid in other cases. |
| 31:3  | Reserved |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

#### 20.4.5 Data command register (DATA)

Offset address: 0x10

Reset value: 0x00

| Field | Name | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0   | DATA | R/W | This register contains the data to be transmitted or received on the I2C bus. Reading this bit when writing is invalid. When reading this bit, the value returned by these bits is the data received on the I2C interface.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 8     | CMD  | W   | This bit controls to perform read or write operations.<br>When I2C acts as a slave, this bit will not control the direction. When it is the master, it controls the direction.<br>When you enter a command in TXFIFO, this bit will distinguish write and read commands. In slave receiving mode, this bit is useless. In slave transmitting mode, "0" means to transmit the data in DATA. When writing this bit, you should remember that if you attempt to perform a read operation after transmitting a general call command, a TAIF interrupt (Bit 6 of the RIS register) will be caused, unless Bit 11 (GCEN) of the TARADDR register has been cleared. If "1" is written to this bit after receiving the RRIF interrupt, a TAIF interrupt will occur.<br>0: Sequence data byte receiving, Main write command<br>1: Main read command |

| Field | Name     | R/W | Description                                                   |
|-------|----------|-----|---------------------------------------------------------------|
| 9     | STOP     | R/W | This bit controls stopping transmitting or receiving of data. |
| 31:10 | Reserved |     |                                                               |

#### 20.4.6 SCL high-bit counter register of standard-speed I2C clock (SSCHC)

Offset address: 0x14

Reset value: 0x190

| Field | Name     | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|----------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:0  | CNT      | R/W | <p>This register must be set before any I2C bus transaction to ensure the correct input/output (I/O) time. This register sets the high 16 bits of the SCL clock counter in standard speed mode. For more information, please see "IC_CLK Frequency Configuration".</p> <p>This register can only write when I2C interface is disabled (CTRL1[0] register is 0). Writing is invalid in other cases. The minimum effective value is 6; the hardware can prevent writing values less than this value, and if you attempt to set a value, the set value of the result is 6. For the design of APB_DATA_WIDTH=16, the programming sequence is very important for ensuring correct operation of I2C. First program the lower byte. Then program the upper byte.</p> |
| 31:14 | Reserved |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

#### 20.4.7 SCL low-bit counter register of standard-speed I2C clock (SSCLC)

Offset address: 0x18

Reset value: 0x1D6

| Field | Name     | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|----------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:0  | CNT      | R/W | <p>This register must be set before any I2C bus transaction to ensure the correct input/output (I/O) time. This register sets the low 16 bits of the SCL clock counter in standard speed mode. For more information, please refer to "IC_CLK Frequency Configuration". This register can only write when I2C interface is disabled (CTRL1[0] register is 0). Writing is invalid in other cases. The minimum effective value is 8; the hardware can prevent writing values less than this value, and if you attempt to set a value, the set value of the result is 8. For the design of APB_DATA_WIDTH=16, the programming sequence is very important for ensuring correct operation of I2C. First program the lower byte, and then program the upper byte.</p> |
| 31:14 | Reserved |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

#### 20.4.8 SCL high-bit counter register of I2C clock of fast-speed mode or fast-speed plus mode (FSCHC)

Offset address: 0x1C

Reset value: 0x3C

| Field | Name | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------|------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:0  | CNT  | R/W | <p>This register must be set before any I2C bus transaction to ensure the correct input/output (I/O) time. This register sets the high 16 bits of the SCL clock counter in fast speed mode or fast speed plus mode. It is used to transmit the main code and START BYTE or General CALL in fast speeed mode. For more information, please see "IC_CLK Frequency Configuration". This register is 0 when reset, and becomes read-only. This register can only write when I2C interface is disabled (CTRL1[0] register is 0). The minimum effective value is 6; the hardware can prevent writing values less than this value, and if you attempt to set a value, it is set to 6. For the design of APB_DATA_WIDTH=16, the programming sequence is very</p> |

| Field | Name | R/W | Description                                                                                                 |
|-------|------|-----|-------------------------------------------------------------------------------------------------------------|
|       |      |     | important for ensuring correct operation of I2C. First program the lower byte. Then program the upper byte. |
| 31:14 |      |     | Reserved                                                                                                    |

#### 20.4.9 SCL low-bit counter register of I2C clock of fast-speed mode or fast-speed plus mode (FSCLC)

Offset address: 0x20

Reset value: 0x82

| Field | Name | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:0  | CNT  | R/W | This register must be set before any I2C bus transaction to ensure the correct input/output (I/O) time. This register sets the high 16 bits of the SCL clock counter in fast speed mode or fast speed plus mode. It is used to transmit the main code and START BYTE or General CALL in fast speeed mode. For more information, please see "IC_CLK Frequency Configuration". This register is 0 when reset, and becomes read-only. This register can only write when I2C interface is disabled (CTRL1[0] register is 0), and write is ineffective in other cases. The minimum effective value is 8; the hardware can prevent writing values less than this value, and if you attempt to set a value, the set value of the result is 8. For the design of APB_DATA_WIDTH=16, the programming sequence is very important for ensuring correct operation of I2C. First program the lower byte. Then program the upper byte. If the value is less than 8, the count value will be changed to 8. |
| 31:14 |      |     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

#### 20.4.10 SCL high-bit counter register of high-speed mode I2C clock (HSCHC)

Offset address: 0x24

Reset value: 0x6

| Field | Name | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------|------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:0  | CNT  | R/W | This register must be set before any I2C bus transaction to ensure the correct input/output (I/O) time. This register sets the high 16 bits of the SCL clock counter in high-speed mode. Please see "IC_CLK Frequency Configuration". Setting of this register depends on the bus. It is 60ns when 100pF is loaded; 120ns when 400pF is loaded. This register is 0 when reset, and becomes read-only. This register can only write when I2C interface is disabled (CTRL1[0] register is 0), and write is ineffective in other cases. The minimum effective value is 6; the hardware can prevent writing values less than this value, and if you attempt to set a value, the final set value is 6. For the design of APB_DATA_WIDTH=16, the programming sequence is very important for ensuring correct operation of I2C. First program the lower byte. Then program the upper byte. |
| 31:14 |      |     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

#### 20.4.11 SCL low-bit counter register of high-speed mode I2C clock (HSCLC)

Offset address: 0x28

Reset value: 0x10

| Field | Name     | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------|----------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:0  | CNT      | R/W | This register must be set before any I2C bus transaction to ensure the correct input/output (I/O) time. This register sets the low 16 bits of the SCL clock counter in high-speed mode. For more information, please see "IC_CLK Frequency Configuration". Setting of this register depends on the bus. It is 160ns when 100pF is loaded; 320ns when 400pF is loaded. This register is 0 when reset, and becomes read-only. This register can only write when I2C interface is disabled (CTRL1[0] register is 0), and write is ineffective in other cases. The minimum effective value is 8; the hardware can prevent writing values less than this value, and if you attempt to set a value, the final set value is 8. For the design of APB_DATA_WIDTH=16, the programming sequence is very important for ensuring correct operation of I2C. First program the lower byte. Then program the upper byte. If the value is less than 8, the count value will be changed to 8. |
| 31:14 | Reserved |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

#### 20.4.12 I2C interrupt state register (INTSTS)

Offset address: 0x2C

Reset value: 0x00

| Field | Name   | R/W | Description                                                                                                                                |
|-------|--------|-----|--------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | RFUIF  | R   | For detailed description of RFUIF bit, please see RIS.<br>1: RFUIF interrupt in active state<br>0: RFUIF interrupt in inactive state       |
| 1     | RFOIF  | R   | For detailed description of RFOIF bit, please see RIS.<br>1: RFOIF interrupt in active state<br>0: RFOIF interrupt in inactive state       |
| 2     | RFFIF  | R   | For detailed description of RFFIF bit, please see RIS.<br>1: RFFIF interrupt in active state<br>0: RFFIF interrupt in inactive state       |
| 3     | TFOIF  | R   | For detailed description of TFOIF bit, please see RIS.<br>1: TFOIF interrupt in active state<br>0: TFOIF interrupt in inactive state       |
| 4     | TFEIF  | R   | For detailed description of TFEIF bit, please see RIS.<br>1: TFEIF interrupt in active state<br>0: TFEIF interrupt in inactive state       |
| 5     | RRIF   | R   | For detailed description of RRIF bit, please see RIS.<br>1: RRIF interrupt in active state<br>0: RRIF interrupt in inactive state          |
| 6     | TAIF   | R   | For detailed description of TAIF bit, please see RIS.<br>1: TAIF interrupt in active state<br>0: TAIF interrupt in inactive state          |
| 7     | RDIF   | R   | For detailed description of RDIF bit, please see RIS.<br>1: RDIF interrupt in active state<br>0: RDIF interrupt in inactive state          |
| 8     | ACTIF  | R   | For detailed description of R_ACTIF bit, please see RIS.<br>1: R_ACTIF interrupt in active state<br>0: R_ACTIF interrupt in inactive state |
| 9     | STPDIF | R   | For detailed description of STPDIF bit, please see RIS.<br>1: STPDIF interrupt in active state<br>0: STPDIF interrupt in inactive state    |
| 10    | STADIF | R   | For detailed description of STADIF bit, please see RIS.<br>1: STADIF interrupt in active state                                             |

| Field | Name    | R/W | Description                                                                                                                                |
|-------|---------|-----|--------------------------------------------------------------------------------------------------------------------------------------------|
|       |         |     | 0: STADIF interrupt in inactive state                                                                                                      |
| 11    | GCIF    | R   | For detailed description of GCIF bit, please see RIS.<br>1: GCIF interrupt in active state<br>0: GCIF interrupt in inactive state          |
| 12    | RSTADIF | R   | For detailed description of RSTADIF bit, please see RIS.<br>1: RSTADIF interrupt in active state<br>0: RSTADIF interrupt in inactive state |
| 13    | MOHIF   | R   | For detailed description of MOHIF bit, please see RIS.<br>1: MOHIF interrupt in active state<br>0: MOHIF interrupt in inactive state       |
| 31:14 |         |     | Reserved                                                                                                                                   |

#### 20.4.13 I2C interrupt enable register (INTEN)

Offset address: 0x30

Reset value: 0x8FF

| Field | Name   | R/W | Description                                                                         |
|-------|--------|-----|-------------------------------------------------------------------------------------|
| 0     | RFUIE  | R/W | This bit enables RFUIF interrupt in the ISTS register.<br>1: Enable<br>0: Disable   |
| 1     | RFOIE  | R/W | This bit enables RFOIF interrupt in the ISTS register.<br>1: Enable<br>0: Disable   |
| 2     | RFFIE  | R/W | This bit enables RFFIF interrupt in the ISTS register.<br>1: Enable<br>0: Disable   |
| 3     | TFOIE  | R/W | This bit enables TFOIF interrupt in the ISTS register.<br>1: Enable<br>0: Disable   |
| 4     | TFEIFE | R/W | This bit enables TFEIF interrupt in the ISTS register.<br>1: Enable<br>0: Disable   |
| 5     | RRIE   | R/W | This bit enables RRIF interrupt in the ISTS register.<br>1: Enable<br>0: Disable    |
| 6     | TAIE   | R/W | This bit enables TAIF interrupt in the ISTS register.<br>1: Enable<br>0: Disable    |
| 7     | RDIE   | R/W | This bit enables RDIF interrupt in the ISTS register.<br>1: Enable<br>0: Disable    |
| 8     | ACTIE  | R/W | This bit enables R_ACTIF interrupt in the ISTS register.<br>1: Enable<br>0: Disable |
| 9     | STPDIE | R/W | This bit enables STPDIF interrupt in the ISTS register.<br>1: Enable<br>0: Disable  |
| 10    | STADIE | R/W | This bit enables STADIF interrupt in the ISTS register.<br>1: Enable<br>0: Disable  |

| Field | Name     | R/W | Description                                                                      |
|-------|----------|-----|----------------------------------------------------------------------------------|
| 11    | GCIE     | R/W | This bit enables GCIF interrupt in the ISTS register.<br>1: Enable<br>0: Disable |
| 31:12 | Reserved |     |                                                                                  |

#### 20.4.14 I2C original interrupt state register (RIS)

Offset address: 0x34

Reset value: 0x00

| Field | Name  | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|-------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | RFUIF | R   | Set when the receive buffer is empty and the processor attempts to read the receive buffer from the DATA register. If the module is disabled (CTRL1[0]=0), this bit holds its level until the master state machine or slave state machine enters the idle state. When I2CEN becomes 0, this interrupt will be cleared.<br>1: RFUIF interrupt in active state<br>0: RFUIF interrupt in inactive state                                                                                                                                                            |
| 1     | RFOIF | R   | If the receive buffer has been fully filled, it is set to the IC_RX_BUFFER_DEPTH and receives another byte from the external I2C device. I2C confirms this, but any data bytes received after FIFO is full will be lost. If the module is disabled (CTRL1[0]=0), this bit holds its level until the master state machine or slave state machine enters the idle state. When I2CEN becomes 0, this interrupt will be cleared.<br>1: RFOIF interrupt in active state<br>0: RFOIF interrupt in inactive state                                                      |
| 2     | RFFIF | R   | Set when the receive buffer reaches or exceeds the RFT watermark in the RFT register. When the buffer level is below the watermark, the hardware automatically clears it. If the module is disabled (CTRL1[0] = 0), refresh the RX FIFO and save it in the reset; therefore, the RX FIFO is not full. Once CTRL1 Bit 0 is programmed to 0, this bit will be cleared regardless of the activity to continue.<br>1: RFFIF interrupt in active state<br>0: RFFIF interrupt in inactive state                                                                       |
| 3     | TFOIF | R   | If the transmit buffer is filled to 16 and the processor attempts to issue another I2C command by writing to the DATA register, it is set during transmission. When the module is disabled, this bit holds its level until the master or slave state machine enters the idle state. When I2CEN becomes 0, this interrupt will be cleared.<br>1: TFOIF interrupt in active state<br>0: TFOIF interrupt in inactive state                                                                                                                                         |
| 4     | TFEIF | R   | According to the TFEIC selection in CTRL0 register, the behavior of TFEIF interrupt state is different.<br>When TFEIC=0: this bit is set to 1 when the transmit buffer is at or below the watermark set in the TFT register.<br>When TFEIC=1: when the transmit buffer is at or below the watermark value set in the TFT register, this bit is set to 1, and the transmission of address/data from the internal shift register of the latest pop-up command is completed.<br>When the buffer level exceeds the watermark, the hardware automatically clears it. |

| Field | Name   | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------|--------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |        |     | <p>When CTRL1[0] is set to 0, TXFIFO is refreshed and saved in reset. The TXFIFO here appears to have no data, so this bit is set to 1, provided it is active in the master or slave state machine. When there is no more activity, and I2CEN=0, this bit is set to 0.</p> <p>1: TFEIF interrupt in active state<br/>0: TFEIF interrupt in inactive state</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 5     | RRIF   | R   | <p>This bit is set to 1 when I2C acts as a slave server and another I2C master attempts to read data from I2C. I2C keeps the I2C bus in the waiting state (SCL=0) until the interrupt is served, which means that the slave machine has been addressed by the remote master requesting data transmission. The processor must respond to the interrupt and write the requested data to the DATA register. This bit is set to 0 after the processor reads IC_CLRRIF register.</p> <p>1: RRIF interrupt in active state<br/>0: RRIF interrupt in inactive state</p>                                                                                                                                                                                                                                                                                                                         |
| 6     | TAIF   | R   | <p>This bit indicates that if I2C acts as an I2C transmitter, it cannot complete the expected operation of transmit FIFO content. This situation can occur on either the I2C master or the I2C slave, which is called "transfer abort".</p> <p>When this bit is set to 1, the TAS register indicates the cause of the transfer abort.</p> <p>Note: I2C only refreshes/resets/clears TX_FIFO when any event tracked by the TAS register causes the transfer abort. Before reading the register IC_CLTAIF, TXFIFO keeps this refresh state. After performing this read, TXFIFO can receive more data bytes from APB interface.</p> <p>1: TAIF interrupt in active state<br/>0: TAIF interrupt in inactive state</p>                                                                                                                                                                        |
| 7     | RDIF   | R   | <p>This bit masks the RDIF interrupt in the ISTS register.</p> <p>1: RDIF interrupt unmasked<br/>0: RDIF interrupt masked</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 8     | ACTIF  | R   | <p>This bit captures I2C activity and remains set until it is cleared. There are four ways to clear it:</p> <ul style="list-style-type: none"> <li>I2C is disabled;</li> <li>Read AIC register;</li> <li>Read ICF register;</li> <li>System reset.</li> </ul> <p>Once this bit is set, it remains set unless one of these four ways is used to clear it. Even if the I2C module is idle, this bit remains set until cleared, indicating that there is activity on the bus.</p> <p>1: RAW_INTR_ACTIF interrupt in active state<br/>0: RAW_INTR_ACTIF interrupt in inactive state</p> <p>When I2C acts as a slave transmitter, if the master does not confirm the bytes transmitted, set the bit to 1. This occurs in the last byte transmitted, indicating that the transmission has been completed.</p> <p>1: RDIF interrupt in active state<br/>0: RDIF interrupt in inactive state</p> |
| 9     | STPDIF | R   | <p>Indicate whether a stop condition has occurred on the I2C interface, regardless of the I2C running in slave or master mode.</p> <p>In slave mode:</p> <p>If CTRL0 register DSA=1b1, the STPDIF interrupt is only issued when the slave machine is addressed.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

| Field | Name    | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|---------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |         |     | <p>Note: During general call addressing, if DSA=1b1, this slave will not issue an STPDIF interrupt, even if the slave responds to the general call addressing by generating an ACK.</p> <p>STPDIF interrupt is generated only when the transmission address matches the slave address (SAR).</p> <p>If CTRL0 register DSA=1b0, the STOP DET interrupt will be issued regardless of whether it is addressed.</p> <p>In master mode:</p> <p>If CTRL0 register DSMA=1b1, the STPDIF interrupt will be issued only when the master is active.</p> <p>If CTRL0 register DSMA=1b0, the STPDIF interrupt will be issued regardless of whether the master is active.</p> <p>1: STPDIF interrupt in active state<br/>0: STPDIF interrupt in inactive state</p> |
| 10    | STADIF  | R   | <p>Indicate whether a start (START) or restart (RSTAEN) condition has occurred on the I2C interface, regardless of the I2C running in slave or master mode.</p> <p>1: STADIF interrupt in active state<br/>0: STADIF interrupt in inactive state</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 11    | GCIF    | R   | <p>Set only when a general call addressing is received and the address is confirmed. It remains set until it is cleared by disabling I2C or when the CPU reads Bit 0 of the GCIC register. I2C stores the received data in the Rx buffer.</p> <p>1: GCIF interrupt in active state<br/>0: GCIF interrupt in inactive state</p>                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 12    | RSTADIF | R   | <p>Indicate whether a restart (RSTAEN) condition occurs on the I2C interface when I2C is operating in slave mode and addressing the slave. Enable only when IC_SLV_RSTADIF_EN=1. Note: However, in high-speed mode or during initial byte transmission, restart before the address field according to I2C protocol. In this case, when a restart is issued, the slave is not addressing slave, so I2C will not generate RSTADIF interrupt.</p> <p>1: RSTADIF interrupt in active state<br/>0: RSTADIF interrupt in inactive state</p>                                                                                                                                                                                                                 |
| 13    | MOHIF   | R   | <p>Indicate whether master holds bus, and whether TXFIFO is empty. Enable only when I2C_DYNAMIC_TAR_UPDATE=1 and IC_EMPTYFIFO_HOLD_MASTER_EN=1.</p> <p>1: MOHIF interrupt is active<br/>0: MOHIF interrupt is inactive</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 31:14 |         |     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

#### 20.4.15 I2C receiver FIFO watermark register (RFT)

Offset address: 0x38

Reset value: 0x00

| Field | Name | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------|------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0   | RFT  | R/W | <p>The receive FIFO watermark controls the data bits that trigger the RFFIF interrupt (Bit 2 in RIS register). If it is greater than this value, the interrupt will be triggered. The valid range is 0-255, but the hardware does not allow setting this value to be greater than the buffer depth. If you try to do this, the actual value will be the maximum depth of the buffer. The value 0 sets the watermark of 1 bit, and the value 255 sets the watermark of 256 bits.</p> |
| 31:8  |      |     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

#### 20.4.16 I2C transmit FIFO watermark register (TFT)

Offset address: 0x3C

Reset value: 0x00

| Field | Name     | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|----------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0   | TFT      | R/W | The transmit FIFO watermark controls trigger TFEIF interrupt (Bit 4 in RIS register); the interrupt will be triggered if the value is less than this value. The valid range is 0-255, and the additional restriction is that it cannot be set to be greater than the buffer depth. If you try to do this, the actual value will be the maximum depth of the buffer. The value 0 sets the watermark of 0 bit, and the value 255 sets the watermark of 255 bits. |
| 31:8  | Reserved |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

#### 20.4.17 Clear combined and single interrupt register (ICF)

Offset address: 0x40

Reset value: 0x00

| Field | Name     | R/W | Description                                                                                                                                                                                                                                                                                           |
|-------|----------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | ICF      | R   | Read this register to clear the combined interrupt, all separate interrupts, and TAS registers. This bit does not clear the interrupts that can be cleared by hardware, but clears the interrupts that can be cleared by software.<br>For clearing TAS exception, refer to Bit 9 of the TAS register. |
| 31:1  | Reserved |     |                                                                                                                                                                                                                                                                                                       |

#### 20.4.18 Clear RFUIF interrupt register (RFUIC)

Offset address: 0x44

Reset value: 0x00

| Field | Name     | R/W | Description                                                              |
|-------|----------|-----|--------------------------------------------------------------------------|
| 0     | RFUIC    | R   | Read this register to clear the RFUIF interrupt (Bit 0) of RIS register. |
| 31:1  | Reserved |     |                                                                          |

#### 20.4.19 Clear RFOIF interrupt register (RFOIC)

Offset address: 0x48

Reset value: 0x00

| Field | Name     | R/W | Description                                                              |
|-------|----------|-----|--------------------------------------------------------------------------|
| 0     | RFOIC    | R   | Read this register to clear the RFOIF interrupt (Bit 1) of RIS register. |
| 31:1  | Reserved |     |                                                                          |

#### 20.4.20 Clear TFOIF interrupt register (TFOIC)

Offset address: 0x4C

Reset value: 0x00

| Field | Name     | R/W | Description                                                              |
|-------|----------|-----|--------------------------------------------------------------------------|
| 0     | TFOIC    | R   | Read this register to clear the TFOIF interrupt (Bit 3) of RIS register. |
| 31:1  | Reserved |     |                                                                          |

#### 20.4.21 Clear RRIF interrupt register (RRIC)

Offset address: 0x50

Reset value: 0x00

| Field | Name     | R/W | Description                                                            |
|-------|----------|-----|------------------------------------------------------------------------|
| 0     | RRIC     | R   | Read this register to clear the RRIF interrupt (Bit 5) of RIS register |
| 31:1  | Reserved |     |                                                                        |

#### 20.4.22 Clear TAIF interrupt register (TAIC)

Offset address: 0x54

Reset value: 0x00

| Field | Name     | R/W | Description                                                                                                                                                                                                                                                           |
|-------|----------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | TAIC     | R   | Read this register to clear the TAIF interrupt (Bit 6) of RIS register and TAS register. This can also release the TXFIFO from the refresh/reset state, thus allowing more writes to the TXFIFO. For clearing TAS exception, refer to MSTDIS bit of the TAS register. |
| 31:1  | Reserved |     |                                                                                                                                                                                                                                                                       |

#### 20.4.23 Clear RDIF interrupt register (RDIC)

Offset address: 0x58

Reset value: 0x00

| Field | Name     | R/W | Description                                                             |
|-------|----------|-----|-------------------------------------------------------------------------|
| 0     | RDIC     | R   | Read this register to clear the RDIF interrupt (Bit 7) of RIS register. |
| 31:1  | Reserved |     |                                                                         |

#### 20.4.24 Clear ACTIF interrupt register (AIC)

Offset address: 0x5C

Reset value: 0x00

| Field | Name     | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|----------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | AIC      | R   | If I2C is no longer active, read this register to clear the ACTIF interrupt. If the I2C module is still active on the bus, continue to set the ACTIF interrupt bit. If the module is disabled and there is no other activity on the bus, the hardware will automatically clear this interrupt bit. Read this register to obtain the value of ACTIF interrupt state (Bit 8) of RIS register. |
| 31:1  | Reserved |     |                                                                                                                                                                                                                                                                                                                                                                                             |

#### 20.4.25 Clear STPDIF interrupt register (STPDIC)

Offset address: 0x60

Reset value: 0x00

| Field | Name     | R/W | Description                                                               |
|-------|----------|-----|---------------------------------------------------------------------------|
| 0     | STPDIC   | R   | Read this register to clear the STPDIF interrupt (Bit 9) of RIS register. |
| 31:1  | Reserved |     |                                                                           |

#### 20.4.26 Clear STADIF interrupt register (STADIC)

Offset address: 0x64

Reset value: 0x00

| Field | Name     | R/W | Description                                                                |
|-------|----------|-----|----------------------------------------------------------------------------|
| 0     | STADIC   | R   | Read this register to clear the STADIF interrupt (Bit 10) of RIS register. |
| 31:1  | Reserved |     |                                                                            |

#### 20.4.27 Clear GCIF interrupt register (GCIC)

Offset address: 0x68

Reset value: 0x00

| Field | Name     | R/W | Description                                                              |
|-------|----------|-----|--------------------------------------------------------------------------|
| 0     | GCIC     | R   | Read this register to clear the GCIF interrupt (Bit 11) of RIS register. |
| 31:1  | Reserved |     |                                                                          |

#### 20.4.28 I2C start register (CTRL1)

Offset address: 0x6c

Reset value: 0x00

| Field | Name     | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|----------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | I2CEN    | R/W | <p>Control to enable I2C or not<br/>           0: Disable I2C (TX and RX FIFO remain in erased state)<br/>           1: Enable I2C</p> <p>When I2C is active, the software can disable it. However, it must be ensured that I2C is correctly disabled. A program is recommended in the "disable I2C" description. When I2C is disabled, the following may occur:</p> <ul style="list-style-type: none"> <li>TXFIFO and RXFIFO refresh</li> <li>The state bit in the ISTS register is still active until I2C enters the idle (IDLE) state.</li> <li>If the module is transmitting, it will stop and delete the content of the transmit buffer after the current transmission is completed. If the module is receiving, I2C will stop the current transmission at the end of the current byte and will not confirm the transmission.</li> </ul> |
| 1     | ABR      | R/W | <p>After setting, the controller enables the transfer abort.<br/>           0: Abort is not started or has been completed<br/>           1: Abort operation in progress</p> <p>By setting this bit, the software can abort I2C transfer in master mode. The software can only set this bit when enabling (I2CEN) has been set; otherwise, the controller will ignore any write to the abort (ABR) bit. Once set, the software cannot clear the abort bit. In response to the abort, the controller issues a STOP and refreshes the TXFIFO after the current transmission is completed, and then sets the TX_ABORT interrupt after the abort operation. The abort bit is automatically cleared after the abort operation.</p>                                                                                                                  |
| 2     | TCB      | R/W | <p>1: Even if TXFIFO has data for transmission, it will also block transmission of the data on I2C bus.<br/>           0: When the first data in TXFIFO is available, the data will be automatically transmitted on I2C bus.</p> <p>Note: When TXFIFO is empty (STS1[2]==1) and the master is in idle state (STS1[5]==0), set TCB bit and the master will stop executing the command. Command in TXFIFO will not be executed before TCB bit is set.</p>                                                                                                                                                                                                                                                                                                                                                                                       |
| 31:3  | Reserved |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

#### 20.4.29 I2C state register (STS1)

Offset address: 0x70

Reset value: 0x06

This is a read-only register, used to indicate current transmission state and FIFO state. The state register can read at any time. There is no field request interrupt in this register. When I2C is disabled by writing 0 to Bit 0 of CTRL1 register: Bit 1 and bit 2 are set to 0, Bit 3 and Bit 10 are set to 0. When the master or slave state machine is idle and I2CEN=0: Bit 5 and Bit 6 are set to 0

| Field | Name  | R/W | Description                                                                                                                                                                                                                                     |
|-------|-------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | ACTF  | R   | I2C active state<br>1: I2C in active state<br>0: I2C in idle state                                                                                                                                                                              |
| 1     | TFNFF | R   | Transmit FIFO not full. Set when the transmit FIFO contains one or more idle positions; clear when FIFO is full.<br>1: TXFIFO not full<br>0: TXFIFO full                                                                                        |
| 2     | TEFF  | R   | Transmit FIFO is completely empty. When the transmit FIFO is completely empty, set this bit. When it contains one or more valid entries, clear this field. This bit field does not request interrupt.<br>1: TXFIFO empty<br>0: TXFIFO not empty |
| 3     | RFNEF | R   | Receive FIFO is not empty. Set this bit when the receive FIFO contains one or more entries; clear it when the receive FIFO is empty.<br>1: Rx FIFO not empty<br>0: Rx FIFO empty                                                                |
| 4     | RFFF  | R   | Receive FIFO is completely full. Set this field when Receive FIFO is completely full. Clear this field when receive FIFO contains one or more empty positions.<br>1: RXFIFO full<br>0: RXFIFO not full                                          |
| 5     | MAF   | R   | Master in active state. Set this bit when the master is not in idle state.<br>1: The master is not idle<br>0: The master is idle                                                                                                                |
| 6     | SAF   | R   | Slave in active state. Set this bit when the slave is not in idle (IDLE) state.<br>1: The slave is not idle<br>0: The slave is idle                                                                                                             |
| 31:7  |       |     | Reserved                                                                                                                                                                                                                                        |

#### 20.4.30 I2C transmit FIFO stock register (TFL)

Offset address: 0x74

Reset value: 0x00

| Field | Name | R/W | Description                                                                          |
|-------|------|-----|--------------------------------------------------------------------------------------|
| 3:0   | TFL  | R   | Data volume in transmit FIFO<br>Include the quantity of valid data in transmit FIFO. |
| 31:4  |      |     | Reserved                                                                             |

#### 20.4.31 I2C receive FIFO stock register (RFL)

Offset address: 0x78

Reset value: 0x00

| Field | Name | R/W | Description                                                                        |
|-------|------|-----|------------------------------------------------------------------------------------|
| 3:0   | RFL  | R   | Data volume in receive FIFO<br>Include the quantity of valid data in receive FIFO. |
| 31:4  |      |     | Reserved                                                                           |

#### 20.4.32 I2C SDA hold time register (SDAHOLD)

Offset address: 0x7C

Reset value: 0x01

| Field | Name   | R/W | Description                                                                                      |
|-------|--------|-----|--------------------------------------------------------------------------------------------------|
| 15:0  | TXHOLD | R/W | When I2C is used as a transmitter, set the required SDA hold time with IC_CLK cycle as the unit. |
| 23:16 | RXHOLD | R/W | When I2C is used as a receiver, set the required SDA hold time with IC_CLK cycle as the unit.    |
| 31:24 |        |     | Reserved                                                                                         |

#### 20.4.33 I2C transmitter abort source register (TAS)

Offset address: 0x80

Reset value: 0x00

| Field | Name    | R/W | Description                                                                                                                                                                                                                                                                                                                                                                         |
|-------|---------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | AD7NA   | R   | This field indicates that the Master is in 7-bit addressing mode and the sent address is not confirmed by any slave.<br>1: This abort is generated by NOACK of 7-bit address<br>0: This abort not generated                                                                                                                                                                         |
| 1     | AD10NA1 | R   | This field indicates that the Master is in 10-bit addressing mode, and no slave confirms the first byte of the 10-bit address.<br>1: No first byte of ACKed 10-bit address of any slave<br>0: There is slave response                                                                                                                                                               |
| 2     | AD10NA2 | R   | This field indicates that the Master is in 10-bit addressing mode and the second address byte of this 10-bit addressing is not confirmed by any slave.<br>1: No byte 2 of ACKed 10-bit address of any slave<br>0: There is response.                                                                                                                                                |
| 3     | TDNA    | R   | This field indicates only master mode field. When the master receives the address acknowledgment, and it transmits the data byte after the address, it indicates that it has not received the acknowledgment from the remote slave.<br>1: The addressed slave does not acknowledge (ACKed) the transmitted data<br>0: The addressed slave acknowledged (ACKed) the transmitted data |
| 4     | GCNA    | R   | This field indicates that I2C in the master mode has sent a General Call, and no slave on the bus has acknowledged the General Call.<br>1: No slave informs responding with ACKed<br>0: A slave responds with ACKed                                                                                                                                                                 |
| 5     | GCR     | R   | This field indicates that I2C in the master mode transmits a General Call, but the user programs the bytes after the General Call as bus read (DATA[9] is set to 1).<br>1: Connected to the bus read after GCALL<br>0: Failed to connect to the bus read after GCALL                                                                                                                |
| 6     | HSAD    | R   | This field indicates that the master is in high-speed mode and the high-speed master code (error behavior) has been confirmed.<br>1: In HS mode, it is informed that the HS master code has been received (ACKed)<br>0: In HS mode, it is not informed that the HS master code has been received (ACKed) - the scene does not exist                                                 |
| 7     | SNR     | R   | This field indicates that the master has sent a start (START) byte and the start byte has been acknowledged (error behavior).<br>1: ACK of start byte detected                                                                                                                                                                                                                      |

| Field | Name    | R/W | Description                                                                                                                                                                                                                                                                                                                                                                  |
|-------|---------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |         |     | 0: ACK of start byte not detected                                                                                                                                                                                                                                                                                                                                            |
| 8     | RNR10B  | R   | This field indicates that restart is disabled (IC_RESTART_EN bit (CTRL0[5])=0), and the master transmit a read instruction in 10-bit addressing mode.<br>1: When restart is disabled, the master attempts to read in 10-bit addressing mode<br>0: When restart is disabled, the master does not attempt to read in 10-bit addressing mode                                    |
| 9     | MSTDIS  | R   | This field indicates that the user attempts to start the master operation when the master mode is disabled.<br>1: The user starts the master operation when MASTER is disabled<br>0: The user does not start the master operation when MASTER is disabled                                                                                                                    |
| 10    | ARBLOST | R   | This field specifies that the master loses arbitration, and if TAS[14] is also set, the slave transmitter loses the arbitration.<br>1: The master or slave transmitter loses arbitration<br>0: The master or slave transmitter does not lose arbitration and there is no exception                                                                                           |
| 11    | LFTF    | R   | This field specifies that the slave receives a read instruction and there are some data in TXFIFO, so the slave transmit a TAIF interrupt to refresh the old data in TXFIFO.<br>1: Refresh the existing data in TX-FIFO after the slave machine obtains the read instruction<br>0: Refresh the existing data in TX-FIFO after the slave machine obtains the read instruction |
| 12    | SAL     | R   | This field specifies that the slave loses arbitration<br>1: The slave transmitter loses arbitration<br>0: The slave transmitter does not lose arbitration                                                                                                                                                                                                                    |
| 13    | SRI     | R   | This field indicates that slave read done.<br>1: The slave read done<br>0: The slave does not read done                                                                                                                                                                                                                                                                      |
| 14    | USRARB  | R   | This field indicates that the slave loses the bus when transmitting data to the remote master.<br>At the same time, set TAS [12].<br>1: The slave loses the bus<br>0: The slave does not lose the bus                                                                                                                                                                        |
| 15    | FLUCNT  | R   | When the processor responds to the request of transmitting data to a remote master in save mode, the user writes 1 in the CMD (Bit 8) of the DATA register.<br>1: The slave attempts to transmit to remote master in read mode<br>0: The slave does not attempt to transmit to remote master in read mode                                                                    |
| 31:16 |         |     | Reserved                                                                                                                                                                                                                                                                                                                                                                     |

#### 20.4.34 Generate slave data NACK register (SDNO)

Offset address: 0x84

Reset value: 0x00

| Field | Name | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------|------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | NACK | R/W | <p>Generate NACK.</p> <p>This NACK generation occurs only when I2C is slave receiver. If this register is set to 1, it can generate a NACK only after receiving a data byte; therefore, data transmission is aborted and the received data will not be pushed to the receive buffer. When the register is set to 0, it generates NACK/ACK under normal conditions.</p> <p>1 (ENABLED): Only NACK is generated when the slave receiver receives data</p> <p>0 (DISABLED): Normal response after the slave receiver receives data</p> |
| 31:1  |      |     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

#### 20.4.35 DMA control register (DMACTRL)

Offset address: 0x88

Reset value: 0x00

| Field | Name | R/W | Description                                                                                                                                                                                                                                                          |
|-------|------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | RXEN | R/W | <p>Receive DMA enable: This bit is used to enable/disable receive FIFO DMA channel.</p> <p>1: Enable receive FIFO DMA channel<br/>0: Disable receive FIFO DMA channel</p> <p>Note: The width of DMA data configured by the user can only be 16 bits and 32 bits.</p> |
| 1     | TXEN | R/W | <p>Transmit DMA enable: This bit is used to enable/disable the transmit FIFO DMA channel.</p> <p>1: Enable FIFO DMA channel<br/>0: Disable FIFO DMA channel</p> <p>Note: The width of DMA data configured by the user can only be 16 bits and 32 bits.</p>           |
| 31:2  |      |     | Reserved                                                                                                                                                                                                                                                             |

#### 20.4.36 DMA transmitting data level register (DTDL)

Offset address: 0x8C

Reset value: 0x00

| Field | Name | R/W | Description                                                                                                                                                                                                                                              |
|-------|------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0   | DTDL | R/W | When the number of bytes in the transmit FIFO is less than or equal to the value indicated by this bit field, transmit the data level . This bit field controls the level of DMA request issued by the transmission logic. It equals to watermark level. |
| 31:3  |      |     | Reserved                                                                                                                                                                                                                                                 |

#### 20.4.37 DMA receive data level register (DRDL)

Offset address: 0x90

Reset value: 0x00

| Field | Name | R/W | Description                                                                                                                                                                                                           |
|-------|------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0   | DRDL | R/W | Data level when the number of bytes in the receive FIFO is greater than the value indicated by this bit field; this field controls the level that the receive logic transmit DMA request, The watermark level=DRDL+1. |
| 31:3  |      |     | Reserved                                                                                                                                                                                                              |

#### 20.4.38 I2C SDA setup register (SDADLY)

Offset address: 0x94

Reset value: 0x64

| Field | Name     | R/W | Description                                                                                                                                                                   |
|-------|----------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8:0   | SDADLY   | R/W | SDA setup<br>It is suggested that if the required delay is 1000ns, for 10 MHz IC_CLK frequency, SDADLY should be programmed to be 11. The minimum input value of SDADLY is 2. |
| 31:9  | Reserved |     |                                                                                                                                                                               |

#### 20.4.39 I2C ACK General Call register (GCA)

Offset address: 0x98

Reset value: 0x01

| Field | Name     | R/W | Description                                                                                                                                                                                               |
|-------|----------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | GCA      | R/W | ACK General Call<br>When it is set to 1, I2C will respond with ACK when receiving General Call. Otherwise, I2C will respond with NACK.<br>1: General Call generates ACK<br>0: General Call generates NACK |
| 31:1  | Reserved |     |                                                                                                                                                                                                           |

#### 20.4.40 I2C enable state register (STS2)

Offset address: 0x9C

Reset value: 0x00

| Field | Name  | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|-------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | I2CEN | R   | I2CEN Status. This bit always reflects the value driven on the output port I2CEN.<br>1: Enable I2C<br>0: Disable I2C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 1     | SDWB  | R   | Disable the slave when busy<br>This bit indicates whether a potential or active slave operation is aborted because Bit 0 of the CTRL1 register is set from 1 to 0. When CPU writes 0 to CTRL1 register, set this bit, meanwhile:<br>(a) Address byte of slave transmitter operation received by I2C from remote master.<br>(b) Address and data bytes of slave operation from remote master.<br>When it is read as 1, it is regarded that I2C executes a NACK by force in any link of I2C transmission, regardless of whether the I2C address matches the slave address in I2C (SLAADDR register), or whether the transmission is completed before CTRL1 is set to 0, but it has not been yet effective.<br>Note: If the remote I2C master aborts the transmission before it has a chance to issue (NACK) on the I2C bus, and CTRL1[0] is set to 0, this bit is also set to 1. When it is read as 0, and the master is active or the I2C bus is idle, I2C is considered disabled.<br>Note: When I2CEN (Bit 0) is read as 0, the CPU can safely read this bit.<br>1 (ACTIVE): Disable when the slave is active<br>0 (INACTIVE): Disable when the slave is idle |

| Field | Name     | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|----------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2     | SRDL     | R   | <p>Slave received data lost (Slave Received Data Lost)<br/> This bit indicates that the slave I2C transmits and receives the abort operation because Bit 0 of CTRL1 is set from 1 to 0. When read as 1, I2C is considered to be actively involved in an aborted I2C transmission (with a matching address), and the data transmitted by I2C has been input even if NACK has responded to the data byte.</p> <p>Note: If the remote I2C master aborts the transmission with stop (STOP) condition before I2C has a chance to NACK the transmission, and CTRL1[0] is set to 0, this bit is also set to 1. When it is read as 0, I2C is considered disabled and does not actively participate in the data phase of the slave receiver transmission.</p> <p>Note: When I2CEN (Bit 0) is read as 0, the CPU can safely read this bit.<br/> 1: Slave RX data lost<br/> 0: Slave RX data not lost</p> |
| 31:3  | Reserved |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

#### 20.4.41 I2C SS, FS or FM+ spike suppression limit register (LSSSL)

Offset address: 0xA

Reset value: 0x05

| Field | Name     | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|----------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0   | LSSSL    | R/W | This register must be set before any I2C bus transaction to ensure stable operation. This register sets the duration (measured with IC_CLK cycle) of the longest spike filtered by the spike suppression logic in the SCL or SDA line. This register can only be written when I2C interface is disabled, corresponding to CTRL1[0] register set to 0. Writing at other time is invalid. The minimum effective value is 1; the value that hardware prevents writing is less than this value. If you attempt to tamper with this value, the result is set to 1. |
| 31:8  | Reserved |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

#### 20.4.42 I2C HS spike suppression limit register (HSSSL)

Offset address: 0xA4

Reset value: 0x01

| Field | Name     | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------|----------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0   | HSSSL    | R/W | This register must be set during any I2C bus transaction to ensure stable operation. This register sets the duration (measured with IC_CLK cycle) of the longest spike filtered by the spike suppression logic in the SCL or SDA line; this register can write only when I2C interface is disabled, corresponding to CTRL1[0] register set to 0. Writing at other time is invalid. The minimum effective value is 1; the value that hardware prevents writing is less than this value. If you attempt to tamper with this value, the result is set to 1. |
| 31:8  | Reserved |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

## 21 Serial Peripheral Interface (SPI)

### 21.1 Full Name and Abbreviation Description of Terms

Table 76 Full Name and Abbreviation Description of Terms

| Full name in English  | English abbreviation |
|-----------------------|----------------------|
| Most Significant Bit  | MSB                  |
| Least Significant Bit | LSB                  |
| Master Out Slave In   | MOSI                 |
| Master In Slave Out   | MISO                 |
| Serial Clock          | SCK                  |
| Serial Data           | SD                   |
| Master Clock          | MCK                  |
| Word Select           | WS                   |
| Pulse-code Modulation | PCM                  |
| Inter-IC Sound        | I2S                  |
| Transmit              | TX                   |
| Receive               | RX                   |
| Busy                  | BSY                  |

### 21.2 Introduction

Serial peripheral interface (SPI) provides data transmitting and receiving functions based on SPI protocol, which allows chips to communicate with external devices in half duplex, full duplex, synchronous and serial modes, and can work in master or slave mode.

### 21.3 Main Characteristics

#### 21.3.1 Main Characteristics of SPI

- (1) Master and slave operation with 3-wire full duplex synchronous transmission and receiving
- (2) Simplex synchronous transmission can be realized by two wires (the third bidirectional data line can be included/not included)
- (3) Select 8-bit or 16-bit transmission frame format
- (4) Support multiple master device mode
- (5) Support special transmission and receiving mark and can trigger interrupt
- (6) Have SPI bus busy state flag
- (7) Fast communication of master/slave communication, up to 18MHz
- (8) Clock polarity and phase are programmable

- (9) Data sequence is programmable; select MSB or LSB first
- (10) Interrupt can be triggered by master mode fault, overrun and CRC error flag
- (11) Have DMA transmit and receive buffers
- (12) Calculation, transmission and verification can be conducted through hardware CRC

## 21.4 Functional Description

### 21.4.1 Description of SPI Signal Line

Table 77 SPI Signal Line Description

| Pin name | Description                                                                                                                                                                                                                                                                                                                |
|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SCK      | Master device: SPI clock outputs<br>Slave device: SPI clock inputs                                                                                                                                                                                                                                                         |
| MISO     | Master device: Input the pin and receive data<br>Slave device: Output the pin and send data<br>Data direction: From slave device to master device                                                                                                                                                                          |
| MOSI     | Master device: Output the pin and send data<br>Slave device: Input the pin and receive data<br>Data direction: From master device to slave device                                                                                                                                                                          |
| NSS      | Software NSS mode: NSS pin can be used for other purposes.<br>Hardware NSS mode of master device:<br>NSS outputs, in single-master mode,<br>NSS OFF output: Operation of multiple master environments is allowed,<br>Slave hardware NSS mode: The NSS signal is set to low level as the chip selection signal of the slave |

### 21.4.2 Phase and Polarity of Clock Signal

The clock polarity and clock phase are CPOL and CPHA bits of SPI\_CTRL1 register.

Clock polarity CPOL means the level signal of SCK signal line when SPI is in idle state.

- When CPOL=0, SCK signal line is in idle state and at low level
- When CPOL=1, SCK signal line is in idle state and at high level

Clock phase CPHA means the sampling moment of data

- When CPHA=0, the signal on MOSI or MISO data line will be sampled by the "odd edge" on SCK clock line.
- When CPHA=1, the signal on MOSI or MISO data line will be sampled by the "even edge" on SCK clock line.

SPI can be divided into four modes according to the states of clock phase CPHA and clock polarity CPOL.

Table 78 Four Modes of SPI

| SPI mode | CPHA | CPOL | Sampling moment | Idle SCK clock |
|----------|------|------|-----------------|----------------|
| 0        | 0    | 0    | Odd edge        | Low level      |
| 1        | 0    | 1    | Odd edge        | High level     |
| 2        | 1    | 0    | Even edge       | Low level      |
| 3        | 1    | 1    | Even edge       | High level     |

### 21.4.3 Data Frame Format

Set MSB or LSB to be first by configuring LSBSEL bit in SPI\_CTRL1 register. Select to transmit/receive in 8/16-bit data frame format by configuring DFLSEL bit in SPI\_CTRL1 register.

### 21.4.4 NSS Mode

Software NSS mode: Select to enable or disable this mode by configuring SSEN bit of SPI\_CTRL1 register, and the internal NSS signal level is driven by ISSEL bit of SPI\_CTRL1 register.

Hardware NSS mode:

- Turn on NSS output: When SPI is in master mode, enable SSOEN bit, NSS pin will be pulled to low level and SPI will automatically enter the slave mode.
- Turn off NSS output: Operation is allowed in multiple master environments.

### 21.4.5 SPI Mode

#### 21.4.5.1 SPI master mode

In master mode, generate serial clock on SCK pin

Master mode configuration

- Configure MSMSEL=1 in SPI\_CTRL1 register
- Select the polarity and phase by configuring CPOL and CPHA bits in SPI\_CTRL1 register.
- Select 8/16-bit data frame format by configuring DFLSEL bit in SPI\_CTRL1 register
- Select LSB or MSB first by configuring LSBSEL in SPI\_CTRL1 register
- NSS configuration:
  - NSS pin works in input mode: in hardware mode, it is required to connect NSS pin to high level during the entire data frame transmission; in software mode, it is required to set SSEN bit and ISSEL bit in SPI\_CTRL1 register
  - NSS works in output mode and it is required to configure SSOEN bit of SPI\_CTRL2 register
- Enable SPI by configuring SPIEN bit in SPI\_CTRL1 register

In master mode: MOSI pin is data output, which MISO is data input

#### 21.4.5.2 SPI slave mode

In slave mode, SCK pin receives the serial clock transmitted from the master device

Configuration of slave mode

- Configure MSMSEL=0 in SPI\_CTRL1 register
- Select the polarity and phase by configuring CPOL and CPHA bits in SPI\_CTRL1 register.
- Select 8/16-bit data frame format by configuring DFLSEL bit in SPI\_CTRL1 register
- Select LSB or MSB first by configuring LSBSEL in SPI\_CTRL1 register
- NSS configuration:
  - In hardware mode: NSS pin must be at low level in the whole data frame transmission process
  - In software mode: Set SSEN bit in SPI\_CTRL1 register and clear ISSEL bit
- Enable SPI by configuring SPIEN bit in SPI\_CTRL1 register

In slave mode: MOSI pin is data input, which MISO is data output

#### 21.4.5.3 Half-duplex communication of SPI

##### One clock line and one bidirectional data line

- Enable this mode by setting BMEN of SPI\_CTRL1 register
- Control the data line to be input or output by setting BMOEN bit of SPI\_CTRL1 register
- SCK pin is used as clock, MOSI pin is used in master device to transmit data, and MISO pin is used in slave device to transmit data

#### 21.4.5.4 Simplex communication of SPI

##### One clock line and one unidirectional data line

In this mode, SPI module can only receive or only transmit

Transmit-only mode:

- Data are transmitted on Transmit pin (MOSI in master mode, MISO in slave mode)
- Then the receive pin can be used as general I/O (MISO in master mode, MOSI in slave mode).

Receive-only mode:

- In master mode, enable SPI to initiate communication, clear SPEN pin of SPI\_CTRL1 register, and it will stop receiving data immediately, not needing to read BSYFLG flag (always 1).
- Slave mode: When NSS is pulled to low level, SPI will receive all the time as long as SCK has clock pulse.

In receive-only mode, SPI output can be closed by setting RXOMEN bit in SPI\_CTRL1 register. At this time, release the transmit pin (MOSI in master mode, MISO in slave mode), which can be used for other functions.

#### 21.4.6 Data Transmit and Receive Process in Different SPI Modes

Table 79 Run Mode of SPI

| Mode                                           | Configure        | Data pin                         |
|------------------------------------------------|------------------|----------------------------------|
| Full duplex mode of master device              | BMEN=0, RXOMEN=0 | MOSI Transmits; MISO receives    |
| Unidirectional receiving mode of master device | BMEN=0, RXOMEN=1 | MOSI is not used; MISO receives  |
| Bidirectional Transmit mode of master device   | BMEN=1, BMOEN=1  | MOSI Transmits; MISO is not used |
| Bidirectional receiving mode of master device  | BMEN=1, BMOEN=0  | MOSI is not used; MISO receives  |

| Mode                                          | Configure        | Data pin                              |
|-----------------------------------------------|------------------|---------------------------------------|
| Full duplex mode of slave device              | BMEN=0, RXOMEN=0 | MOSI receives, and MISO transmits     |
| Unidirectional receiving mode of slave device | BMEN=0, RXOMEN=1 | MOSI receives, while MISO is not used |
| Bidirectional Transmit mode of slave device   | BMEN=1, BMOEN=1  | MOSI is not used, and MISO transmits  |
| Bidirectional receiving mode of slave device  | BMEN=1, BMOEN=0  | MOSI receives, while MISO is not used |

Figure 90 Connection in Full Duplex Mode



Figure 91 Connection in Simplex Mode (the master is used for receiving, while the slave is used for transmitting)



Figure 92 Connection in Simplex Mode (the master only transmits, while the slave receives)



Figure 93 Bidirectional Line Connection



#### 21.4.6.1 Transmitting and receiving of processed data

##### Data transmission

After the mode configuration is completed, the SPI module is enabled to remain idle.

**Master mode:** The software writes a data frame to the transmit buffer, and the transmission process starts

**Slave mode:** The SCK signal on the SCK pin starts to jump, while the NSS pin level is low, and the transmission process starts (before starting data transmission, make sure that the data has been written to the transmit buffer in advance).

When SPI is transmitting a data frame, it will load the data frame from the data buffer to the shift register, and then start to transmit data. After one bit of data frame is sent, TXBEFLG is set to 1. If you need to continue to transmit data, the software needs to wait until TXBEFLG=1 writes data to the SPI\_DATA register. (TXBEFLG flag is set to 1 by hardware and cleared by software).

##### Data receiving

BSYFLG flag is always set to 1 in the data transmission process.

At the last edge of the sampling clock, the received data is transferred from the shift register to the receive buffer; set the RXBNEFLG flag, and the software reads the data in data register (SPI\_DATA) to obtain the content of the receive buffer; if RXBNEIEN bit of SPI\_CTRL2 register is set, an interrupt will be generated, and after data is read, the BSYFLG flag will be automatically cleared.

#### 21.4.6.2 Full duplex transmitting and receiving mode in master/slave device

##### Full duplex mode in master device

- After writing data to SPI\_DATA register (transmit buffer), data transmission starts.
- When SPI transmits the first bit of data, the data is transferred from the transmit buffer to the shift register and then transferred to the MOSI pin serially according to the sequence.
- The data received on MISO pin is serially transferred to SPI\_DATA register (receive buffer) according to the sequence.

Transmitting and receiving are synchronous.

### Full duplex mode under slave device

- When the slave device receives the clock signal and the first data bit appears on the MOSI pin, data transmission starts, and the subsequent data bits will be transferred to the shift register in turn.
- When SPI Transmits the first bit of data, the data is transferred from the transmit buffer to the shift register, and then transferred to the MISO pin serially according to the sequence.
- The software must ensure that the data to be sent is written before the SPI master device starts to transmit data.

Transmitting and receiving are synchronous

### Full duplex transmitting and receiving process under master/slave device

- (1) Enable SPI module: Configure SPIEN=1 of SPI\_CTRL1 register.
- (2) Write the first data to be sent to SPI\_DATA register, and the TXBEFLG flag will be cleared.
- (3) Wait until TXBEFLG flag bit is set to 1 (control by hardware), and write the second data bit to be sent.
- (4) Wait until RXBNEFLG flag bit is set to 1 (control by hardware), read the first received data in the SPI\_DATA register, at the same time, clear the RXBNEFLG flag (cleared by software). Repeat the operation, and Transmit and receive data at the same time.
- (5) Wait until RXBNEFLG=1 and receive the last data.
- (6) Wait until TXBEFLG=1 and close SPI module after BSYFLG=0.

#### 21.4.6.3 Bidirectional Transmitting mode of master/slave device

##### Bidirectional transmission of master device

- Write data to SPI\_DATA register, and the transmission starts
- The data in the transmit buffer is transferred to the shift register in parallel, and then transferred to the MOSI pin serially according to the sequence.

##### Bidirectional transmission of slave device

- When the slave device receives the clock signal and the first data bit appears on the MISO pin, data transmission starts.
- At the same time, the data to be sent by the transmit buffer is transferred to the shift register in parallel, and then sent to the MISO pin in serial (before data transmission, make sure that the data has been written to the transmit buffer in advance).

##### Bidirectional transmission process of master/slave device

- (1) Enable SPI module: Configure SPIEN=1 of SPI\_CTRL1 register.
- (2) Write the first data to be sent to SPI\_DATA register, and the TXBEFLG flag will be cleared.
- (3) Wait until TXBEFLG=1, write the second data, repeat the operation and send the subsequent data
- (4) After writing the last data, wait for TXBEFLG=1 and BSYFLG=0 and transmission is completed

#### 21.4.6.4 One-way/Two-way receiving mode under master/slave device

- (1) Enable SPI module: Configure SPIEN=1 of SPI\_CTRL1 register.
- (2) In the master device: Generate SCK clock immediately, and continuously receive data before SPI is closed.
- (3) Slave device: When SPI master device pulls down NSS and generates clock, receive data.
- (4) Wait until the RXBNEFLG flag is set to 1, read data through SPI\_DATA, and repeat the operation to receive data.

#### 21.4.7 CRC Function

SPI module contains two CRC computing units, which are used for data receiving and data transmission respectively.

CRC computing unit is used to define polynomials in SPI\_CRCPOLY register.

Enable CRC computing by configuring CRCEN bit in SPI\_CTRL1 register; at the same time, reset the CRC register (SPI\_RXCRC and SPI\_TXCRC).

To obtain the CRC value of transmission calculation, after the last data is written to the transmit buffer, it is required to set CRCNXT bit of SPI\_CTRL1; indicate that the hardware Transmits the CRC value after the last data is sent, and the CRCNXT bit will be cleared; at the same time, compare the values of CRC and SPI\_RXCRC, and if they do not match, it is required to set CRCEFLG bit of SPI\_STS register, and afterERRIEN bit of SPI\_CTRL2 register is set, an interrupt will occur.

Note:

- (1) If SPI is under slave device and CRC function is used, CRC computing will continue when NSS pin is at high level. For example, when the master device communicates with multiple slave devices alternately, the above situation will occur, so it is necessary to avoid faulty operation of CRC.
- (2) In the process of a slave device from being unselected (NSS is at high level) to being selected (NSS is at low level 0), it is required to clear the CRC value at both ends of the master and slave devices to keep the next CRC computing results of the master and slave devices synchronized.
- (3) When SPI is in slave mode, CRC computing can be enabled after the clock is stable.
- (4) When the SPI clock frequency is too high, the CPU operation will affect the SPI bandwidth. It is recommended to use DMA mode to avoid the reduction of SPI speed.
- (5) When the SPI clock frequency is too high, during the CRC transmission period, the CPU utilization frequency is reduced, and the function call is disabled in the CRC transmission process to avoid errors when receiving the last data and CRC.
- (6) When NSS hardware mode is used in slave mode, NSS pin should be kept low during data transmission and CRC transmission period.

#### Sequence of clearing CRC values

- (1) SPI Disable (SPIEN=0)
- (2) Clear CRCEN bit
- (3) Set CRCEN bit to 1
- (4) Enable SPI (SPIEN=1)

#### 21.4.8 DMA Function

For high-speed data transmission, the request/response DMA mechanism in SPI improves the system efficiency and can transfer data to SPI transmit buffer promptly, and the receive buffer can read the data in time to prevent overflow.

When SPI only Transmits data, it is only needed to enable DMA transmission channel; when SPI only receives data, it is only needed to enable DMA receiving channel.

DMA function of SPI mode can be enabled by configuring TXDEN and RXDEN bits of SPI\_CTRL2 register.

- When Transmitting: When TXBEFLG flag bit is set to 1, issue the DMA request, DMA controller writes data to SPI\_DATA register, and then the TXBEFLG flag bit will be cleared.
- When receiving: When setting RXBNEFLG flag bit to 1, issue the DMA request, DMA controller reads data from SPI\_DATA register, and then RXBNEFLG flag bit is cleared.

By monitoring BSYFLG flag bit, confirm whether SPI communication is over after DMA has transferred all data to be sent in Transmitting mode, which can avoid damaging the transmission of last data.

#### DMA function with CRC

By the end of communication, if SPI enables both CRC operation and DMA function, Transmiting and receiving of CRC bytes will be completed automatically.

At the end of data and CRC transmission, if CRCEFLG flag bit of SPI\_STS register is set to 1, it indicates that an error occurred during transmission.

#### 21.4.9 SPI Disable

After data transmission is over, end the communication by closing SPI module. In some configurations, if SPI is closed before data transmission is completed, data transmission error may be caused. Different methods are required in different operation modes to close SPI

#### Full duplex mode under master/slave device

- (1) Wait until RXBNEFLG flag bit is set to 1, and receive the last data
- (2) Wait until TXBEFLG flag bit is set to 1
- (3) Wait for clearing BSYFLG flag bit
- (4) Disable SPI (set SPIEN=0 of SPI\_CTRL1 register)

#### One-way/Two-way receive-only mode under master/slave device

- (1) Wait No. n-1 RXBNEFLG flag bit is set to 1
- (2) Wait for one SPI clock cycle before SPI is closed (set SPIEN=0 of SPI\_CTRL1 register)
- (3) Before entering the stop mode, wait until the last RXBNEFLG flag bit is set to 1

#### Receive-only/Two-way receiving mode in slave mode

SPI can be closed at any time (set SPIEN=0 of SPI\_CTRL1 register) and it will be closed when the transmission is over. If you want to enter the stop mode, wait until BSYFLG flag bit is cleared.

## 21.4.10 SPI Interrupt

### 21.4.10.1 State flag bit

There are three flag bits for fully monitoring the state of SPI bus

#### Transmit buffer empty flag TXBEFLG

TXBEFLG=1 indicates that the transmit buffer bit is empty, and the next data to be sent can be written. When the data is written to SPI\_DATA register, clear the TXBEFLG flag bit.

#### Receive buffer non-empty flag RXBNEFLG

RXBNEFLG=1 indicates that the receive buffer contains valid data and the data can be read through SPI\_DATA register; then clear the RXBNEFLG flag

#### Busy flag BSYFLG

BSYFLG flag is set and cleared by hardware, which can indicate the state of SPI communication layer. When BSYFLG=1, it indicates SPI is communicating, but in the two-line receiving mode under the master device, BSYFLG=0 during the period of receiving of data.

BSYFLG flag can be used to detect whether transmission is over to avoid damaging the last transmitted data.

BSYFLG flag bit can be used to avoid conflict when writing data in multi-master mode.

BSYFLG flag will be cleared when the transmission ends (except for continuous communication in master mode), SPI is closed and the master mode fails.

BSYFLG=0 between data item and data item when communication is discontinuous.

When communication is continuous:

- In master mode: BSYFLG=1 in the whole transmission process
- In save mode: BSYFLG is kept low within one SCK clock cycle between transmission of each data

Note: It is best to use TXBEFLG and RXBNEFLG flags to process the transmitting and receiving of each data item.

### 21.4.10.2 Error flag bit

#### Master mode error MEFLG

MEFLG is an error flag bit. The master mode error occurs when: in hardware NSS mode, the NSS pin of the master device is pulled down; in software NSS mode, ISSEL bit is cleared; MEFLG bit is set automatically.

Influence of master mode failure: MEFLG is set to 1, and SPI interrupt is generated whenERRIEN is set; SPIEN is cleared (output stops, SPI interface is closed); MSMSEL is cleared and the device is forced into the slave mode.

Operation of clearing the MEFLG flag bit: When MEFLG flag bit is set to 1, it is required to read or write SPI\_STS register, and then write to SPI\_CTRL1

register.

When the MEFLG flag bit is 1, it is not allowed to set the SPIEN and MSMSEL bits

### Overrun error OVRFLG

Overrun error: After the master device Transmits the data, the RXBNEFLG flag bit is still 1, which indicates that the overrun error occurred. Then OVRFLG bit is set to 1, and if the ERRien bit is also set, an interrupt will be generated.

After an overrun error occurs, the data in the receive buffer is not the data sent by the master device, and then the read data in SPI\_DATA register is the data not read before, while the data sent later will not be read.

OVRFLG flag can be cleared by reading SPI\_DATA register and SPI\_STS register according to the sequence.

### CRC error flag CRCEFLG

By setting CRCEN bit of SPI\_CTRL1 register, start CRC computing, CRC error flag, and check whether the received data is valid.

When the value sent by SPI\_TXCRC register does not match the value in SPI\_RXCRC register, a CRC error will be generated, and CRCEFLG flag bit in SPI\_STS register will be set to 1.

CRCEFLG can be cleared by writing 0 to CRCEFLG bit of SPI\_STS register.

Table 80 SPI Interrupt Request

| Interrupt flag | Interrupt event               | Enable control bit | Clearing method                                                |
|----------------|-------------------------------|--------------------|----------------------------------------------------------------|
| TXBEFLG        | Transmit buffer empty flag    | TXBEIEN            | Write SPI_DATA register                                        |
| RXBNEFLG       | Receive buffer non-empty flag | RXBNEIEN           | Read SPI_DATA register                                         |
| MEFLG          | Mastermode failure event      | ERRIEN             | Read/Write SPI_STS register, and then write SPI_CTRL1 register |
| OVRFLG         | Overrun error flag            |                    | Read SPI_DATA register, and then read SPI_STS register         |
| CRCEFLG        | CRC error flag                |                    | Write 0 to CRCEFLG bit                                         |

## 21.5 Register Address Mapping

Table 81 SPI Register Address Mapping

| Register name | Description                 | Offset address |
|---------------|-----------------------------|----------------|
| SPI_CTRL1     | SPI control register 1      | 0x00           |
| SPI_CTRL2     | SPI control register 2      | 0x04           |
| SPI_STS       | SPI state register          | 0x08           |
| SPI_DATA      | SPI data register           | 0x0C           |
| SPI_CRCPOLY   | SPI CRC polynomial register | 0x10           |

| Register name | Description               | Offset address |
|---------------|---------------------------|----------------|
| SPI_RXCRC     | SPI receive CRC register  | 0x14           |
| SPI_TXCRC     | SPI transmit CRC register | 0x18           |

## 21.6 Register Functional Description

These peripheral registers can be operated by half word (16 bits) or word (32 bits).

### 21.6.1 SPI control register 1 (SPI\_CTRL1)

Offset address: 0x00

Reset value: 0x0000

| Field | Name   | R/W | Description                                                                                                                                                                                                                                              |
|-------|--------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | CPHA   | R/W | <p>Clock Phase Configure<br/>This bit indicates on the edge of which clock to start sampling<br/>0: On the edge of No. 1 clock<br/>1: On the edge of No. 2 clock<br/>Note: This bit cannot be modified during communication.</p>                         |
| 1     | CPOL   | R/W | <p>Clock Polarity Configure<br/>Level state maintained by SCK when SPI is in idle state.<br/>0: Low level<br/>1: High level<br/>Note: This bit cannot be modified during communication</p>                                                               |
| 2     | MSMCFG | R/W | <p>Master/Slave Mode Configure<br/>0: Configure as slave mode<br/>1: Configure as master mode<br/>Note: This bit cannot be modified during communication</p>                                                                                             |
| 5:3   | BRSEL  | R/W | <p>Baud Rate Divider Factor Select<br/>000: DIV=2<br/>001: DIV=4<br/>010: DIV=8<br/>011: DIV=16<br/>100: DIV=32<br/>101: DIV=64<br/>110: DIV=128<br/>111: DIV=256<br/>Baud rate=FPCLK/DIV<br/>Note: This bit cannot be modified during communication</p> |
| 6     | SPIEN  | R/W | <p>SPI Device Enable<br/>0: Disable<br/>1: Enable<br/>Note: When SPI device is closed, please operate according to the process of closing SPI.</p>                                                                                                       |
| 7     | LSBSEL | R/W | <p>LSB First Transfer Select<br/>0: First Transmit the most significant bit (MSB)<br/>1: First Transmit the least significant bit (LSB)</p>                                                                                                              |
| 8     | ISSEL  | R/W | <p>Internal Slave Device Select<br/>When CTRL1_SSEN=1 (software NSS mode), select internal NSS level by configuring the bit<br/>0: Internal NSS is low<br/>1: Internal NSS is high</p>                                                                   |

| Field | Name   | R/W | Description                                                                                                                                                                                                                                                                                                                                                                              |
|-------|--------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9     | SSEN   | R/W | Software Slave Device Enable<br>0: Software NSS mode is disabled, and the internal NSS level is determined by external NSS pin<br>1: Software NSS mode is enabled, and the internal NSS level is determined by external NSS pin                                                                                                                                                          |
| 10    | RXOMEN | R/W | Receive Only Mode Enable<br>0: Transmit and receive at the same time<br>1: Receive-only mode<br>RXOMEN bit and BMEN bit together determine the transmission direction in the two-line and two-way mode. In the configuration of multiple slave devices, in order to avoid data transmission conflict, it is necessary to set RXOMEN bit to 1 on the slave devices that are not accessed. |
| 11    | DFLSEL | R/W | Data Frame Length Format Select<br>0: 8-bit data frame format<br>1: 16-bit data frame format<br>Only when SPIEN=0, can this bit be written to change the data frame length.                                                                                                                                                                                                              |
| 12    | CRCNXT | R/W | CRC Transfer Next Enable<br>0: The next transmitted data is from transmit buffer<br>1: The next transmitted data is from CRC register<br>Note: After the last data is written to SPI_DATA register, set CRCNXT bit immediately.                                                                                                                                                          |
| 13    | CRCEN  | R/W | CRC Calculate Enable<br>0: Disable<br>1: Enable<br>CRC check function only applies to full duplex mode; only when SPIEN=0, can this bit be changed.                                                                                                                                                                                                                                      |
| 14    | BMOEN  | R/W | Bidirectional Mode Output Enable<br>0: Disable, namely, receive-only mode<br>1: Enable, namely, transmit-only mode<br>When BMEN=1, namely, in single-line/double-line mode, this bit decides the transmission direction of transmission line.                                                                                                                                            |
| 15    | BMEN   | R/W | Bidirectional Mode Enable<br>0: Double-line unidirectional mode<br>1: Single-line bidirectional mode<br>Single-line two-way transmission means: the transmission between MOSI pin of data master and MISO pin of slave                                                                                                                                                                   |

### 21.6.2 SPI control register 2 (SPI\_CTRL2)

Offset address: 0x04

Reset value: 0x0000

| Field | Name  | R/W | Description                                                                                                                          |
|-------|-------|-----|--------------------------------------------------------------------------------------------------------------------------------------|
| 0     | RXDEN | R/W | Receive Buffer DMA Enable<br>When RXDEN=1, once RXBNEFLG flag is set, DMA request will be issued.<br>0: Disable<br>1: Enable         |
| 1     | TXDEN | R/W | Transmit Buffer DMA Enable<br>When this bit is set, once TXBEFLG flag is set, DMA request will be issued.<br>0: Disable<br>1: Enable |

| Field | Name     | R/W | Description                                                                                                                                                                                                         |
|-------|----------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2     | SSOEN    | R/W | SS Output Enable<br>SS output in master mode<br>0: SS output is disabled, and it can work in multi-master mode.<br>1: SS output is enabled, and it cannot work in multi-master mode.<br>Note: Not used in I2S mode. |
| 4:3   | Reserved |     |                                                                                                                                                                                                                     |
| 5     | ERRIEN   | R/W | Error interrupt Enable<br>0: Disable<br>1: Enable<br>When an error occurs, ERRIEN bit controls whether to generate the interrupt.                                                                                   |
| 6     | RXBNEIEN | R/W | Receive Buffer Not Empty Interrupt Enable<br>0: Disable<br>1: Allowed<br>When RXBNEFLG flag bit is set to 1, an interrupt request will be generated                                                                 |
| 7     | TXBEIEN  | R/W | Transmit Buffer Empty Interrupt Enable<br>0: Disable<br>1: Enable<br>When TXBEFLG flag bit is set to 1, an interrupt request will be generated                                                                      |
| 15:8  | Reserved |     |                                                                                                                                                                                                                     |

### 21.6.3 SPI state register (SPI\_STS)

Offset address: 0x08

Reset value: 0x0002

| Field | Name     | R/W   | Description                                                                                                                                                                                                                                                                       |
|-------|----------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | RXBNEFLG | R     | Receive Buffer Not Empty Flag<br>0: Empty<br>1: Not empty                                                                                                                                                                                                                         |
| 1     | TXBEFLG  | R     | Transmit Buffer Empty Flag<br>0: Not empty<br>1: Empty                                                                                                                                                                                                                            |
| 2     | SCHDIR   | R     | Sound Channel Direction Flag<br>0: Indicate that the left channel is transmitting or receiving the required data<br>1: Indicate that the right channel is transmitting or receiving the required data<br>Note: Not used in SPI mode, without left and right channels in PCM mode. |
| 3     | UDRFLG   | R     | Underrun Occur Flag<br>0: Not occur<br>1: Occurred<br>This flag bit is set by hardware, and it can be cleared by writing 0 to this bit by software.<br>Not used in SPI mode                                                                                                       |
| 4     | CRCEFLG  | RC_W0 | CRC Error Occur Flag<br>This bit indicates whether the received CRC value matches the value of RXCRC register<br>0: Match<br>1: Not match                                                                                                                                         |

| Field | Name   | R/W | Description                                                                                                                                                            |
|-------|--------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |        |     | This bit is set by hardware, can be cleared by writing 0 to this bit by software, and is not used in I2S mode.                                                         |
| 5     | MEFLG  | R   | Mode Error Occur Flag<br>0: Not occur<br>1: Occurred<br>This bit is set by hardware, can be cleared by writing 0 to this bit by software, and is not used in I2S mode. |
| 6     | OVRFLG | R   | Overrun Occur Flag<br>0: Not occur<br>1: Occurred<br>This bit is set by hardware, and it can be cleared by writing 0 to this bit by software.                          |
| 7     | BSYFLG | R   | SPI Busy Flag<br>0: SPI is idle<br>1: SPI is communicating<br>It is set or cleared by hardware.                                                                        |
| 15:8  |        |     | Reserved                                                                                                                                                               |

#### 21.6.4 SPI data register (SPI\_DATA)

Offset address: 0x0C

Reset value: 0x0000

| Field | Name | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0  | DATA | R/W | Transmit Receive Data register<br>When writing this register, the data will be written to the transmit buffer; when reading this register, the data in receive buffer will be read.<br>The size of the buffer is consistent with the length of the data frame, that is, for 8-bit data, only DATA[7:0] is used when Transmitting and receiving data, and DATA[15:8] is invalid; for 16-bit data, DATA[15:0] will be used when Transmitting and receiving data. |

#### 21.6.5 SPI CRC polynomial register (SPI\_CRCPOLY)

Offset address: 0x10

Reset value: 0x0007

| Field | Name    | R/W | Description                                                                                                                                 |
|-------|---------|-----|---------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0  | CRCPOLY | R/W | CRC Polynomial Value Setup<br>This register contains CRC polynomial of CRC computing, which can be modified, and the reset value is 0x0007. |

#### 21.6.6 SPI receive CRC register (SPI\_RXCRC)

Offset address: 0x14

Reset value: 0x0000

| Field | Name  | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------|-------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0  | RXCRC | R   | Receive Data CRC Value<br>The CRC data of receive data calculated by hardware are stored in this register; the bits and the length of data frames are consistent, that is, if the received data are 8 bits, the CRC computing is made based on CRC8; if the received data are 16 bits, the CRC computing is made based on CRC16.<br>When CECEN is set, the hardware clears the register.<br>Note: When BSYFLG bit is set to 1, the value of reading RXCRC register may be wrong. |

### 21.6.7 SPI transmit CRC register (SPI\_TXCRC)

Offset address: 0x18

Reset value: 0x0000

| Field | Name  | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|-------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0  | TXCRC | R   | <p>Transmit Data CRC Value<br/>           The CRC data of sent data calculated by hardware are stored in this register; the bits and the length of data frames are consistent, that is, if the sent data are 8 bits, the CRC computing is based on CRC8; if the sent data are 16 bits, the CRC computing is based on CRC16.<br/>           When CECEN is set, the hardware clears the register.<br/>           Note: When BSYFLG bit is set to 1, the value of reading RXCRC register may be wrong.</p> |

### 21.6.8 SPI\_I2S configuration register (SPI\_I2SCFG)

Offset address: 0x1C

Reset value: 0x0000

| Field | Name    | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|---------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | CHLEN   | R/W | <p>Channel Length Configure<br/>           The channel length refers to the data bits per audio channel<br/>           0: 16-bit width<br/>           1: 32-bit width<br/>           The vocal tract length can be configured successfully only when the vocal tract length is greater than the data length; otherwise, the hardware will automatically adjust the vocal tract length; this bit can only be configured when I2SEN=0, and is not used in SPI mode.</p> |
| 2:1   | DATALEN | R/W | <p>Configure the Length of the sData to Be Transferred<br/>           00: 16-bit data length<br/>           01: 24-bit data length<br/>           10: 32-bit data length<br/>           11: Not allowed<br/>           This bit can only be configured when I2SEN=0, and is not used in SPI mode.</p>                                                                                                                                                                 |
| 3     | CPOL    | R/W | <p>Idle State Clock Polarity Configure<br/>           0: Low level<br/>           1: High level<br/>           This bit can only be configured when I2SEN=0, and is not used in SPI mode.</p>                                                                                                                                                                                                                                                                         |
| 5:4   | I2SSSEL | R/W | <p>I2S Standard Selection<br/>           00: I2S Philips standard<br/>           01: High-byte alignment standard (left alignment)<br/>           10: Low-byte alignment standard (right alignment)<br/>           11: PCM standard<br/>           This bit can only be configured when I2SEN=0, and is not used in SPI mode.</p>                                                                                                                                     |
| 6     |         |     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 7     | PFSSEL  | R/W | <p>PCM Frame Synchronization Mode Select<br/>           0: Synchronization of short frames<br/>           1: Synchronization of long frames<br/>           Apply only to PCM standard (I2SSSEL=11); this bit can only be configured when I2SEN=0, and is not used in SPI mode.</p>                                                                                                                                                                                    |

| Field | Name     | R/W | Description                                                                                                                                                                                                                                                  |
|-------|----------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9:8   | I2SMOD   | R/W | I2S Master/Slave Transmit/Receive Mode Configure<br>00: Slave device transmits<br>01: Slave device receives<br>10: Master device transmits<br>11: Master device receives<br>Note: This bit can only be configured when I2SEN=0, and is not used in SPI mode. |
| 10    | I2SEN    | R/W | I2S Enable<br>0: I2S is disable<br>1: I2S is enabled<br>Note: It is not used in SPI mode.                                                                                                                                                                    |
| 11    | MODESEL  | R/W | SPI/I2S Mode Select<br>0: Select SPI mode<br>1: Select I2S mode<br>Note: This bit can be set only when SPI or I2S is closed.                                                                                                                                 |
| 15:12 | Reserved |     |                                                                                                                                                                                                                                                              |

## 22 Four-line Serial Peripheral Interface (QSPI)

This module applies only to APM32F103VBT6 and APM32F103V8T6.

### 22.1 Introduction

QSPI is a serial data bus interface, which consists of clock (SCLK), chip select signal (CS), and four data lines (IO[0:3]). Connect single, double or four-line external SPI Flash storage media. The interface has four transmission modes: send and receive, send only, receive only, and EEPROM read. The transmission mode is controlled by software.

### 22.2 Main Characteristics

QSPI has programmable clock polarity and clock phase. Inegrate FIFO used for transmitting and receiving, with FIFO depth of 8, and FIFO bit width of 32-bit, with four transmission modes, support transmission of data frame from 1 bit to 16 bits, support hardware or software to control the chip selection signal line; in the four -line transmission mode, support clock extension, variable instruction length, address length, wait cycle, and data frame size; when receiving serial data, the programmable delay of sampling time can achieve higher sampling ratio of serial data bits.

### 22.3 Functional Description

#### 22.3.1 Transfer Modes

This chapter discusses the operation of QSPI in different modes when data are transmitted on the serial bus. The transmission mode (TXMODE) is determined by TXMODE of the control register 1 (QSPI\_CTRL1).

#### 22.3.2 Transmit and Receive

When TXMODE=2'b00, both transmit and receive logic are valid. When the data is written to the transmit FIFO and the number of data is greater than the FIFO transmitting watermark (TFTH of QSPI\_TFTL register), the transmission will start. The serial data is sent to the sending data line and reaches the target device. Meanwhile, The data on the receive data line will be sent from the receiving shift register to the receive FIFO.

Figure 94 QSPI Transmit FIFO State in Transmitting and Receiving State





## Transmit only

When TXMODE=2'b01, only the transmitting logic unit is valid. The receiving logic unit is invalid, when the data is written to the transmit FIFO and the number of data is greater than the FIFO transmitting watermark (TFTH of QSPI\_TFTL register), the transmission will start, and the serial data will be sent to the transmitting data line and reach the target device. Data on the receive data line will be ignored. Therefore, no data is stored in the receive FIFO.

The following figure shows the FIFO level before the serial transfer starts and after the transfer is completed respectively. In this example, two data words are transferred from QSPI in a continuous transfer form to an external serial device.

Figure 95 QSPI Transmit FIFO State in Transmitting State



## Receive only

When TXMODE=2'b10, only the receiving logic unit is valid, and the transmitting logic unit is invalid. No data will be sent. The data on the receive data line will be sent from the receiving shift register to the receive FIFO. To start a transmission, an invalid data should be written to the transmit FIFO.

The following figure shows the FIFO level before the serial transfer starts and after the transfer is completed respectively. In this example, QSPI continuously receives two data from an external serial device.

Figure 96 QSPI Transmit FIFO State in Receive-only State



### 22.3.2.1 EEPROM (electrically erasable programmable read-only memory) read

When TXMODE=2'b11, the transmitted data is used to send the instruction/address to the corresponding external device. Three data frames (8-bit instruction code, 8-bit high address, and 8-bit low address) are usually required. In the process of transmitting data, the receiving logic unit will not capture any data on the receiving data line until the transmit FIFO is empty. Namely, when the transmit FIFO is empty, the receive logic unit starts to become effective and starts to receive data until the number of data frames received by QSPI is equal to the value of NDF field in QSPI\_CTRL2 register plus one.

The following figure shows the FIFO level before the serial transfer starts and after the transfer is completed respectively. In this example, QSPI continuously receives two data from an external serial device.

Figure 97 FIFO State in EEPROM Read Transmission Mode



### 22.3.3 Data Transfer

Data transfer is started by external master. After entering the transmit FIFO, the number of valid data will be more than the TFTH number of QSPI\_TFTL register, and an external slave device will be selected. When data is being transmitted, the register state is set as the BUSY flag. A new external transfer can be tried only after the BUSY flag is cleared.

### 22.3.4 Clock Ratio

#### Overview of clock ratios

QSPI works in an oversampling structure. For the master mode of operation, the clock (sclk\_out) cycle of peripheral device is a multiple core clock (qspi\_clk).

#### Description of clock ratios

When the QSPI macro cell is set as a master device, the maximum frequency (sclk\_out) of the bit rate clock is half the qspi\_clk frequency. This allows shift control logic to capture data at one clock edge of sclk\_out and derive data at the opposite edge.

Sclk\_out frequency can be obtained from the following formula:

$$F_{\text{sclk\_out}} = F_{\text{ssi\_CLK}} / \text{SCKDIV}$$

The SCKDIV programmable register is kept within a range with an average value of 0-65,534. Assuming SCKDIV=0, sclk\_out will be disabled.

sclk\_out line can be switched only when an active transfer is in progress. During the rest of the time, as defined by the serial protocol of its operation, it will stay idle.

The figure below shows the maximum ratio between sclk\_out and qspi\_clk.



#### Overview of maximum ratios

The frequency ratio rule between (sclk\_out/sclk\_in) bit rate and QSPI peripheral device clock (qspi\_clk) is summarized as follows:

$$F_{\text{qspi\_clk}} \geq 2 \times (\text{maximum } F_{\text{sclk\_out}})$$

### 22.3.5 Receive and Transmit FIFO Buffers

#### Overview of receive and transmit FIFO buffers

The FIFO buffer used by QSPI is an internal Class-D trigger. The serial specification states that the length of a serial transfer (data frame) is 4-32 bits, so the length of transmit and receive FIFO buffer is fixed at 32 bits. Data frames less than 32 bits must be right aligned when they are written to the transmit FIFO buffer. The shift control logic will automatically right align the data received by the receive FIFO buffer. QSPI\_TFTL determines the level of FIFO entries that generate interrupts.

AHB sends the read instruction to QSPI data register (QSPI\_DATA) and the data will pop up from the receive FIFO. When the number of FIFO entries is greater than or equal to FIFO watermark plus 1, FIFO full interrupt request (qspi\_rxf\_intr) will occur to receive FIFO. The watermark that is set by the programmable register QSPI\_RFTL determines the level of FIFO entries that generate interrupts.

The watermark allows to send an instruction of which the FIFO will be empty to the processor. When the receive shift logic attempts to transfer data to the nearly full receive FIFO, an receive FIFO excess interrupt will be generated. Then, the newly received data will be lost. If you attempt to read data from an empty receive FIFO, a receive FIFO underrun interrupt will be generated. In such case, the processor will be warned that the read data is invalid.

## 22.3.6 Receive Data (RXD) Sampling Delay

### Overview of receive data (RXD) sampling delay

When QSPI is set as the master, other logics can be included in the design to delay the default sampling time of the received data signal. Additional logic helps to increase the maximum achievable frequency of the serial bus.

### Description of receive data (RXD) sample delay

The delay on the round-trip route between the `sclk_out` signal issued by the master and the RXD signal sent by the slave can be considered as the timing of the received signal-as seen by the master-has left the normal sampling time. This situation is illustrated by the following legend:

Figure 99 Received Data (RXD) Sample Delay Description



The slave uses the `sclk_out` signal issued by the master as the gate in order to obtain the data of the RXD signal mapped to the serial bus. The Slave device's delay for the signal issued by `sclk_out` in routing and sampling can mean that the RXD bit is not stable to the correct value before the master collects the RXD signal sample. The following figure shows how the routing delay of an RXD signal generates an incorrect RXD value at the default time of the master acquisition port. If there is no received sample delay logic, it is required to improve the baud rate of transfer to ensure that the installation time of the received data signal is within the range, which will result in reduction of the frequency of the serial interface.

When the RXD sample delay logic is included, the delay value can be dynamically edited to change the sampling time of RXD signal from the default value to the number of cycles of `qspi_clk`. RXD sample delay logic can be set to

use both the positive and negative edges of qspi\_clk to collect RXD signal samples. This will increase the number of sampling points in one sclk\_out cycle, and help to satisfy timing of higher frequency. QSPI uses QSPI\_RSD register to change the sampling point of RXD signal.

Figure 100 Collection of RXD Signal Samples with QSPI



### 22.3.7 QSPI Interrupt

#### 22.3.7.1 QSPI interrupt description

##### **qspi\_txe\_intr**

It is set when the transmit FIFO is less than or equal to its watermark. The watermark that is set by the programmable register QSPI\_RFTL determines the level of FIFO entries that generate interrupts. When data is written to the transmit FIFO buffer, the interrupt will be cleared by hardware to exceed the watermark level.

##### **qspi\_txo\_intr**

It is set when an AHB access attempts to write to a fully written transmit FIFO. After set, the data written from AHB will be ignored. Before the transmit FIFO overrun interrupt clear register (QSPI\_TFOIC) is read, the interrupt still remains set.

##### **qspi\_rxf\_intr**

When the receive FIFO is equal to or greater than its watermark, it will be set and the lower prevention service is required. The watermark that is set by the programmable register QSPI\_RFTL determines the level of FIFO entries that

generate interrupts. When data is read from the receive FIFO buffer, the interrupt will be cleared by hardware to exceed the watermark level.

#### **qspi\_rxo\_intr**

It is set when the receive logic attempts to put data in the fully written receive FIFO. When set, the newly received data will be ignored. Before the receive FIFO overrun interrupt clear register (QSPI\_RFOIC) is read, the interrupt still remains set.

#### **qspi\_rxu\_intr**

It is set when an AHB access attempts to read from an empty receive FIFO. After set, read as zero from the receive FIFO. Before the receive FIFO underrun interrupt clear register (QSPI\_RFUIC) is read, the interrupt still remains set.

#### **qspi\_mst\_intr**

Present only when the QSPI component is set as a serial master device. When the serial master on another serial bus selects the QSPI master as the serial slave and actively transfers data, the interrupt is set. This will notify the processor of possible contention on the serial bus. Before the multi-master interrupt clear register (QSPI\_MIC) is read, the interrupt still remains set.

### **22.3.8 Enhanced SPI Mode**

#### **22.3.8.1 Enhanced SPI mode write operation**

QSPI write operation can be divided into three phases, namely, instruction phase, address phase and data phase.

##### **The following register locations are used for a write operation**

QSPI\_CTRL1 [FRF] specifies frame transmission format.

QSPI\_CTRL3 [INSLEN] specifies instruction length.

QSPI\_CTRL3 [ADDRLEN] specifies address length.

QSPI\_CTRL1 [DFS] specifies data length.

Only when both the instruction and address are written to the data register, QSPI will start a write transmission.

To initiate a Quad write operation, FRF of QSPI\_CTRL1 must be set to 10, which means that the type of transfer is set. For each write instruction, the data will be transferred in the specified format of FRF bit of QSPI\_CTRL1.

The followings are some possible situations of enhanced SPI mode write operation:

- Case A: Both the instruction and address are transmitted in standard SPI format
- Case B: The instruction is transmitted in standard format, while the address is transmitted in enhanced SPI format
- Case C: Both the instruction and address are transmitted in enhanced SPI format

#### **Enhanced SPI mode read operation**

QSPI read operation can be divided into four phases, namely, instruction phase, address phase, wait cycle and data phase.

The wait cycle can be programmed with WAITCYC of QSPI\_CTRL3. The wait cycle is used to lock and change the slave mode, from input to output, and can vary with the devices. For a read operation, QSPI sends the instruction and control data at one time, and after receiving the NDF (QSPI\_CTRL2 register) number of data frame, disable the slave selection signal. To initiate a Quad read operation, FRF of QSPI\_CTRL1 is set to 00/01/10 respectively. This will set the type of transfer, and the data of each read instruction will be transferred in the specified form in FRF of QSPI\_CTRL1.

The followings are four possible situations of enhanced SPI mode write operation:

- Case A: Both the instruction and address are transmitted in standard SPI format
- Case B: The instruction is transmitted in standard format, while the address is transmitted in enhanced SPI format
- Case C: Both the instruction and address are transmitted in enhanced SPI format
- Case D: There is no instruction read and address read transmission

### Clock extension function

When QSPI and external SPI devices are transmitting data, since the software may not guarantee the timeliness of transmission, the transmit FIFO may be empty when QSPI is sending data, so no valid data can be sent and overrun error will occur. When receiving, the receive FIFO may be full, the subsequent data could not be received normally and overrun error will occur. To avoid the above problems, the software must abandon the transmission and restart a transmission. To handle the above problems, QSPI provides clock extension function. If the transmit FIFO is empty by the end of one transmission of sending data, QSPI will close the clock signal. When there are enough data (the data volume is higher than the transmit data watermark TFTH) in the transmit FIFO, QSPI will output the clock signal again and continue the transmission. If the receive FIFO has been full by the end of receiving of data, QSPI will close the clock signal until the data in the receive FIFO is read (the data volume is lower than the receive data watermark value QSPI\_RFTL). Set bit30 in QSPI\_CTRL3 register and the clock extension function can be enabled or disabled. If the clock extension function is enabled, the length of the transmitted data frame must be filled in the QSPI\_CTRL2 register.

### 22.3.9 DMA Function

This function is only applying for APM32F103VBT6 E Version and APM32F103V8T6 E Version products.

For high-speed data transmission, the request/response DMA mechanism in QSPI improves the system efficiency.

DMA function of QSPI mode can be enabled by configuring RDMAEN and TDMAEN bits of QSPI\_DMACTRL register.

- When Transmitting: when the valid data in the Transmit FIFO level register QSPI\_TFL is equal or lower than the DMATDL configuration value, a DMA request is generated.
- When receiving: when the valid data in the receive FIFO level register QSPI\_RFL is equal or higher than the DMARDL configuration value, a DMA request is generated.

## 22.4 Register Address Mapping

Table 82 QSPI Register Address Mapping Table

| Register name | Description                                    | Offset address |
|---------------|------------------------------------------------|----------------|
| QSPI_CTRL1    | Control register 1                             | 0x00           |
| QSPI_CTRL2    | Control register 2                             | 0x04           |
| QSPI_SSIEN    | Enable register                                | 0x08           |
| QSPI_SLAEN    | Slave enable register                          | 0x10           |
| QSPI_BR       | Baud rate register                             | 0x14           |
| QSPI_TFTL     | Transmit FIFO watermark level register         | 0x18           |
| QSPI_RFTL     | Receive FIFO watermark level register          | 0x1C           |
| QSPI_TFL      | Transmit FIFO level register                   | 0x20           |
| QSPI_RFL      | Receive FIFO level register                    | 0x24           |
| QSPI_STS      | State register                                 | 0x28           |
| QSPI_INTEN    | Interrupt enable register                      | 0x2C           |
| QSPIISTS      | Interrupt state register                       | 0x30           |
| QSPI_RIS      | Original interrupt state register              | 0x34           |
| QSPI_TFOIC    | Transmit FIFO overrun interrupt clear register | 0x38           |
| QSPI_RFOIC    | Receive FIFO overrun interrupt clear register  | 0x3C           |
| QSPI_RFUIC    | Receive FIFO underrun interrupt clear register | 0x40           |
| QSPI_MIC      | Multi-master interrupt clear register          | 0x44           |
| QSPI_ICF      | Interrupt clear register                       | 0x48           |
| QSPI_DMACTRL  | DMA control register                           | 0x4C           |
| QSPI_DMATDL   | DMA transmit data level register               | 0x50           |
| QSPI_DMARDL   | DMA receive data level register                | 0x54           |
| QSPI_DATA     | Data register                                  | 0x60           |
| QSPI_RSD      | RX sample delay register                       | 0xF0           |
| QSPI_CTRL3    | Control register                               | 0xF4           |
| QSPI_IOSW     | IO switch register                             | 0x200          |

## 22.5 Register Functional Description

### 22.5.1 Control register 1 (QSPI\_CTRL1)

Offset address: 0x00

Reset value: 0x0000 4007

Description: This register controls the transmission of serial data. When QSPI is started, it is not possible to write to this register. Enable or disable QSPI by writing QSPI\_CTRL2 register.

| Field | Name   | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|--------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4:0   | DFS    | R/W | <p>Data Frame Size<br/>           Select the data frame length. When the data frame size is programmed to be less than 32 bits, the receive data will be automatically right aligned by the receiving logic, and the high bit will be filled with the receive FIFO zero. Before writing the transmit FIFO, the transmission data must be right adjusted. The transmission logic ignores the unused high bits when transferring data.</p> <p>If SPI_FRF =01, the value of DFS must be a multiple of 2<br/>           If SPI_FRF =10, the value of DFS must be a multiple of 4:</p> <ul style="list-style-type: none"> <li>0x0 (DFS_01_BIT): Reserved</li> <li>0x1 (DFS_02_BIT): Reserved</li> <li>0x2 (DFS_03_BIT): Reserved</li> <li>0x3 (DFS_04_BIT): 04-bit serial data transmission</li> <li>0x4 (DFS_05_BIT): 05-bit serial data transmission</li> <li>0x5 (DFS_06_BIT): 06-bit serial data transmission</li> <li>0x6 (DFS_07_BIT): 07-bit serial data transmission</li> <li>0x7 (DFS_08_BIT): 08-bit serial data transmission</li> <li>0x8 (DFS_09_BIT): 09-bit serial data transmission</li> <li>0x9 (DFS_10_BIT): 10-bit serial data transmission</li> <li>0xA (DFS_11_BIT): 11-bit serial data transmission</li> <li>0xB (DFS_12_BIT): 12-bit serial data transmission</li> <li>0xC (DFS_13_BIT): 13-bit serial data transmission</li> <li>0xD (DFS_14_BIT): 14-bit serial data transmission</li> <li>0xE (DFS_15_BIT): 15-bit serial data transmission</li> <li>0xF (DFS_16_BIT): 16-bit serial data transmission</li> <li>0x10 (DFS_17_BIT): 17-bit serial data transmission</li> <li>0x11 (DFS_18_BIT): 18-bit serial data transmission</li> <li>0x12 (DFS_19_BIT): 19-bit serial data transmission</li> <li>0x13 (DFS_20_BIT): 20-bit serial data transmission</li> <li>0x14 (DFS_21_BIT): 21-bit serial data transmission</li> <li>0x15 (DFS_22_BIT): 22-bit serial data transmission</li> <li>0x16 (DFS_23_BIT): 23-bit serial data transmission</li> <li>0x17 (DFS_24_BIT): 24-bit serial data transmission</li> <li>0x18 (DFS_25_BIT): 25-bit serial data transmission</li> <li>0x19 (DFS_26_BIT): 26-bit serial data transmission</li> <li>0x1A (DFS_27_BIT): 27-bit serial data transmission</li> <li>0x1B (DFS_28_BIT): 28-bit serial data transmission</li> <li>0x1C (DFS_29_BIT): 29-bit serial data transmission</li> <li>0x1D (DFS_30_BIT): 30-bit serial data transmission</li> <li>0x1E (DFS_31_BIT): 31-bit serial data transmission</li> <li>0x1F (DFS_32_BIT): 32-bit serial data transmission</li> </ul> |
| 7:5   |        |     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 8     | CPHA   | R/W | <p>Clock Phase<br/>           0: Data sampling starts from the edge of the first clock<br/>           1: Data sampling starts from the edge of the second clock.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 9     | CPOL   | R/W | <p>Clock Polarity<br/>           0: In idle state, the clock is at low level and effective<br/>           1: In idle state, the clock is at high level and effective</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 11:10 | TXMODE | R/W | Transmission Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

| Field | Name  | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|-------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |       |     | <p>Select the transmission mode of serial communication. This field does not affect the repeatability of the transmission, and only indicates whether the receive or transmit data is valid.</p> <p>In the transmit-only mode, the data received from external device is invalid and is not stored in the receive FIFO memory.</p> <p>In the receive-only mode, the data sent is invalid. After the first write to the transmit FIFO, the same word will be retransmitted during transmission.</p> <p>In the transmit and receive mode, both the transmit and receive data are valid. The data received from the external device are stored in the receive FIFO memory.</p> <p>00 (TX_AND_RX): Transmit and receive; not applicable to enhanced SPI operation mode</p> <p>01 (TX_ONLY): Receive-only mode; or write in enhanced SPI operation mode</p> <p>10 (RX_ONLY): Receive-only mode; or read in enhanced SPI operation mode</p> <p>11 (EEPROM_READ): EEPROM read mode; not applicable to enhanced SPI operation mode</p> |
| 13:12 |       |     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 14    | SSTEN | R/W | <p>Chip Selection Reversal Enable</p> <p>When working in normal SPI mode and the clock phase (SCPH) is 0, this register controls the chip selection signal line between data frames</p> <p>When 0x1 is between continuous frames, the chip selection signal line will be reversed; when the chip selection signal line is at high level, the level of CLK signal will be default value.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 21:15 |       |     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 23:22 | FRF   | R/W | <p>Frame Format</p> <p>Select the data frame format to send/receive data</p> <p>00 (SPI_STANDARD): Standard SPI mode</p> <p>01 (SPI_DUAL): Dual SPI mode</p> <p>10 (SPI_QUAD): Quad SPI mode</p> <p>11: Reserved</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 31:24 |       |     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

### 22.5.2 Control register 2 (QSPI\_CTRL2)

Offset address: 0x04

Reset value: 0x0000 0000

| Field | Name | R/W | Description                                                                                                                                                                                                                                                                                                                           |
|-------|------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0  | NDF  | R/W | <p>Number of Data Frame</p> <p>When TXMODE=10 or TXMODE=11, the register field sets the number of data frames continuously received by QSPI. QSPI continues to receive serial data until the number of data frames received equals the register value plus 1, so that you can receive up to 64KB data in continuous transmission.</p> |
| 31:16 |      |     | Reserved                                                                                                                                                                                                                                                                                                                              |

### 22.5.3 Enable register (QSPI\_SSIEN)

Offset address: 0x08

Reset value: 0x0000 0000

| Field | Name     | R/W | Description                                                                                                                                                                                                                                                                                |
|-------|----------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | EN       | R/W | QSPI Enable<br>Enable or disable all QSPI operations. When it is disabled, all serial transmissions will stop immediately. When the device is disabled, the transmit and receive FIFO buffers will be cleared. When enabled, it will be impossible to program some QSPI control registers. |
| 31:1  | Reserved |     |                                                                                                                                                                                                                                                                                            |

#### 22.5.4 Slave enable register (QSPI\_SLAEN)

Offset address: 0x10

Reset value: 0x0000 0000

| Field | Name     | R/W | Description                             |
|-------|----------|-----|-----------------------------------------|
| 0     | SLAEN    | R/W | Slave Enable<br>0: Disable<br>1: Enable |
| 31:1  | Reserved |     |                                         |

#### 22.5.5 Baud rate register (QSPI\_BR)

Offset address: 0x14

Reset value: 0x0000 0000

| Field | Name     | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|----------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0  | CLKDIV   | R/W | SSI Clock Divider<br>The LSB of this field is always set to 0, unaffected by write operation, which ensures that an even number is stored in this register. If this value is 0, the serial output clock (sclk_out) will be disabled. Output frequency of Sclk_out is obtained by the following equation:<br>$F_{sclk\_out} = F_{qspi\_clk}/SCKDIV$<br>SCKDIV is any even number between 2 and 65534.<br>Example:<br>When $F_{qspi\_clk} = 3.6864\text{MHz}$ and $SCKDIV = 2$<br>$F_{sclk\_out} = 3.6864/2 = 1.8432\text{MHz}$ |
| 31:16 | Reserved |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

#### 22.5.6 Transmit FIFO watermark level register (QSPI\_TFTL)

Offset address: 0x18

Reset value: 0x0000 0000

| Field | Name     | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------|----------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0   | TFT      | R/W | Transmit FIFO Watermark<br>Transmit FIFO controller triggers the control of interrupt entry level (or lower). FIFO depth can be set within the range of 8-256; the size of this register is the same as the number of address bits needed to access FIFO. If you attempt to set this value to be greater than or equal to the depth of the FIFO, this field will not be written and will stay at its current value. When the number of transmit FIFO entries is less than or equal to this value, the transmit FIFO empty interrupt will be triggered. |
| 15:3  | Reserved |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 18:16 | TFTH     | R/W | Transmit Start FIFO Level<br>Used to control the entry level in the transmit FIFO, above which the transmission will start on the serial line. This register can be used to ensure that there are enough data in the transmit FIFO before the write operation starts on the serial line. These fields are only valid for the master operation mode.                                                                                                                                                                                                    |

| Field | Name | R/W | Description |
|-------|------|-----|-------------|
| 31:19 |      |     | Reserved    |

### 22.5.7 Receive FIFO watermark level register (QSPI\_RFTL)

Offset address: 0x1C

Reset value: 0x0000 0000

| Field | Name | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------|------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0   | RFT  | R/W | Receive FIFO Watermark<br>Receive FIFO controller triggers the control of interrupt entry level (or higher). FIFO depth can be set within the range of 8-256; the size of this register is the same as the number of address bits needed to access FIFO. If you attempt to set this value to be greater than the depth of the FIFO, this field will not be written and will stay at its current value. When the number of receive FIFO entries is greater than or equal to this value plus 1, the receive FIFO full interrupt will be triggered. |
| 31:3  |      |     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

### 22.5.8 Transmit FIFO level register (QSPI\_TFL)

Offset address: 0x20

Reset value: 0x0000 0000

| Field | Name | R/W | Description                                                                         |
|-------|------|-----|-------------------------------------------------------------------------------------|
| 2:0   | TFL  | R/W | Transmit FIFO Level<br>Include the quantity of valid data entries in transmit FIFO. |
| 31:3  |      |     | Reserved                                                                            |

### 22.5.9 Receive FIFO level register (QSPI\_RFL)

Offset address: 0x24

Reset value: 0x0000 0000

| Field | Name | R/W | Description                                                                       |
|-------|------|-----|-----------------------------------------------------------------------------------|
| 2:0   | RFL  | R/W | Receive FIFO Level<br>Include the quantity of valid data entries in receive FIFO. |
| 31:3  |      |     | Reserved                                                                          |

### 22.5.10 State register (QSPI\_STS)

Offset address: 0x28

Reset value: 0x0000 0006

| Field | Name  | R/W | Description                                                                                                                                                                                                                                                                                         |
|-------|-------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | BUSYF | R/W | SSI Busy Flag<br>When it is set, it means serial transmission is in progress; when it is cleared, it means QSPI is in idle or disabled state.<br>0 (INACTIVE): QSP is in idle or disabled state<br>1 (ACTIVE): QSP is actively transmitting data                                                    |
| 1     | TFNF  | R/W | Flag That Transmit FIFO Is Not Full<br>Set when the transmit FIFO contains one or more idle positions; clear when FIFO is full.<br>0 (FULL): Transmit FIFO full<br>1 (NOT_FULL): Transmit FIFO not full                                                                                             |
| 2     | TFEF  | R/W | Flag of Empty Transmit FIFO<br>When the transmit FIFO is completely empty, set this bit. When the transmit FIFO contains one or more valid entries, clear this bit. This bit field does not request interrupt.<br>0 (NOT_EMPTY): Transmit FIFO not empty<br>1 (EMPTY): Transmit FIFO has been empty |

| Field | Name  | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------|-------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3     | RFNEF | R/W | Flag That The Receive FIFO Is Not Empty<br>Set when the receive FIFO contains one or more entries; clear when the receive FIFO is empty. The software can poll this bit to completely clear the receive FIFO.<br>0 (EMPTY): Receive FIFO has been empty<br>1 (NOT_EMPTY): Receive FIFO not empty                                                                                                                                 |
| 4     | RFFF  | R/W | Flag That The Receive FIFO Is Full<br>When the receive FIFO is completely full, set this bit. When the receive FIFO contains one or more empty positions, this bit will be cleared.<br>0 (NOT_FULL): Receive FIFO not full<br>1 (FULL): Receive FIFO full                                                                                                                                                                        |
| 5     |       |     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 6     | DCEF  | R/W | Data Conflict Error Flag<br>Related only when QSPI is configured as the master. When the QSPI master is in the process of transmission, if other master enables ss_in_n input, the bit will be set. This will inform the processor that the last data transmission is stopped before it is completed. This bit is cleared when read.<br>0 (NO_ERROR_CONDITION): No error<br>1 (TX_COLLISION_ERROR): Transmit data conflict error |
| 31:7  |       |     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                         |

### 22.5.11 Interrupt enable register (QSPI\_INTEN)

Offset address: 0x2C

Reset value: 0x0000 007F

| Field | Name  | R/W | Description                                                                                                                                                                                             |
|-------|-------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | TFEIE | R/W | Transmission Interrupt Enable<br>0 (MASKED): qspi_txe_intr interrupt mask<br>1 (UNMASKED): qspi_txe_intr interrupt enable                                                                               |
| 1     | TFOIE | R/W | Transmit FIFO Overrun Interrupt Enable<br>0 (MASKED): qspi_txo_intr interrupt mask<br>1 (UNMASKED): qspi_txo_intr interrupt enable                                                                      |
| 2     | RFUIE | R/W | Receive FIFO Underrun Interrupt Enable<br>0 (MASKED): qspi_rxu_intr interrupt mask<br>1 (UNMASKED): qspi_rxu_intr interrupt enable                                                                      |
| 3     | RFOIE | R/W | Receive FIFO Overrun Interrupt Enable<br>0 (MASKED): qspi_rxo_intr interrupt mask<br>1 (UNMASKED): qspi_rxo_intr interrupt enable                                                                       |
| 4     | RFFIE | R/W | Receive FIFO Full Interrupt Enable<br>0 (MASKED): qspi_rxf_intr interrupt mask<br>1 (UNMASKED): qspi_rxf_intr interrupt enable                                                                          |
| 5     | MSTIE | R/W | Multi-master Contention Interrupt Enable<br>0 (MASKED): qspi_mst_intr interrupt mask<br>1 (UNMASKED): qspi_mst_intr interrupt enable<br>If QSPI is set to serial master, this bit field does not exist. |
| 31:6  |       |     | Reserved                                                                                                                                                                                                |

### 22.5.12 Interrupt state register (QSPIISTS)

Offset address: 0x30

Reset value: 0x0000 0000

| Field | Name  | R/W | Description                                                                                                                                                                   |
|-------|-------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | TFEIF | R   | Transmit FIFO Empty Interrupt State<br>0 (INACTIVE): Interrupt inactivated after qspi_txe_intr is masked<br>1 (ACTIVE): Interrupt activated after qspi_txe_intr is masked     |
| 1     | TFOIF | R   | Transmit FIFO Overrun Interrupt State<br>0 (INACTIVE): Interrupt inactivated after qspi_txo_intr is masked<br>1 (ACTIVE): Interrupt activated after qspi_txo_intr is masked   |
| 2     | RFUIF | R   | Receive FIFO Underrun Interrupt State<br>0 (INACTIVE): Interrupt inactivated after qspi_rxu_intr is masked<br>1 (ACTIVE): Interrupt activated after qspi_rxu_intr is masked   |
| 3     | RFOIF | R   | Receive FIFO Overrun Interrupt State<br>0 (INACTIVE): Interrupt inactivated after qspi_rxo_intr is masked<br>1 (ACTIVE): Interrupt activated after qspi_rxo_intr is masked    |
| 4     | RFFIF | R   | Receive FIFO Full Interrupt State<br>0 (INACTIVE): Interrupt inactivated after qspi_rxf_intr is masked<br>1 (ACTIVE): Interrupt activated after qspi_rxf_intr is masked       |
| 5     | MSTIF | R   | Multi-master Contention Interrupt State<br>0 (INACTIVE): Interrupt inactivated after qspi_mst_intr is masked<br>1 (ACTIVE): Interrupt activated after qspi_mst_intr is masked |
| 31:6  |       |     | Reserved                                                                                                                                                                      |

### 22.5.13 Raw interrupt state register (QSPI\_RIS)

Offset address: 0x34

Reset value: 0x0000 0000

| Field | Name  | R/W | Description                                                                                                                                                                       |
|-------|-------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | TFEIF | R   | Transmit FIFO Empty Raw Interrupt State<br>0 (INACTIVE): qspi_txe_intr interrupt is inactivated before masked<br>1 (ACTIVE): qspi_txe_intr interrupt is activated before masked   |
| 1     | TFOIF | R   | Transmit FIFO Overrun Raw Interrupt State<br>0 (INACTIVE): qspi_txo_intr interrupt is inactivated before masked<br>1 (ACTIVE): qspi_txo_intr interrupt is activated before masked |
| 2     | RFUIF | R   | Receive FIFO Underrun Raw Interrupt State<br>0 (INACTIVE): qspi_rxu_intr interrupt is inactivated before masked<br>1 (ACTIVE): qspi_rxu_intr interrupt is activated before masked |
| 3     | RXOIR | R   | Receive FIFO Overrun Raw Interrupt State<br>0 (INACTIVE): qspi_rxo_intr interrupt is inactivated before masked<br>1 (ACTIVE): qspi_rxo_intr interrupt is activated before masked  |
| 4     | RXFIR | R   | Receive FIFO Full Raw Interrupt State<br>0 (INACTIVE): Interrupt inactivated after qspi_rxf_intr is masked<br>1 (ACTIVE): Interrupt activated after qspi_rxf_intr is masked       |
| 5     | MSTIR | R   | Multi-master Contention Raw Interrupt State<br>0 (INACTIVE): Interrupt inactivated after qspi_mst_intr is masked<br>1 (ACTIVE): Interrupt activated after qspi_mst_intr is masked |
| 31:6  |       |     | Reserved                                                                                                                                                                          |

### 22.5.14 Transmit FIFO overrun interrupt clear register (QSPI\_TFOIC)

Offset address: 0x38

Reset value: 0x0000 0000

| Field | Name  | R/W | Description                                                                                                                                                                           |
|-------|-------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | TFOIC | R   | Clear Transmit FIFO Overrun Interrupt<br>This register reflects the state of the interrupt and reads and clears the qspi_txo_intr interrupt from this register, and write is invalid. |
| 31:1  |       |     | Reserved                                                                                                                                                                              |

### 22.5.15 Receive FIFO overrun interrupt clear register (QSPI\_RFOIC)

Offset address: 0x3C

Reset value: 0x0000 0000

| Field | Name  | R/W | Description                                                                                                                                                             |
|-------|-------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | RFOIC | R   | Clear Receive FIFO Overrun Interrupt<br>This register reflects the state of the interrupt. Read and clear qspi_rxo_intr interrupt from this register; write is invalid. |
| 31:1  |       |     | Reserved                                                                                                                                                                |

### 22.5.16 Receive FIFO underrun interrupt clear register (QSPI\_RFUIC)

Offset address: 0x40

Reset value: 0x0000 0000

| Field | Name  | R/W | Description                                                                                                                                            |
|-------|-------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | RFUIC | R   | Clear Receive FIFO Underrun Interrupt<br>This register reflects the state of the interrupt. Read and clear qspi_rxu_intr interrupt from this register. |
| 31:1  |       |     | Reserved                                                                                                                                               |

### 22.5.17 Multi-master interrupt clear register (QSPI\_MIC)

Offset address: 0x44

Reset value: 0x0000 0000

| Field | Name | R/W | Description                                                                                                                                              |
|-------|------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | MIC  | R   | Clear Multi-master Contention Interrupt<br>This register reflects the state of the interrupt. Read and clear qspi_mst_intr interrupt from this register. |
| 31:1  |      |     | Reserved                                                                                                                                                 |

### 22.5.18 Interrupt clear register (QSPI\_ICF)

Offset address: 0x48

Reset value: 0x0000 0000

| Field | Name | R/W | Description                                                                                                                                                                            |
|-------|------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | ICF  | R   | Clear Interrupt<br>If any interrupt below is in active state, set this register.<br>Read and qspi_txo_intr, qspi_rxu_intr, qspi_rxo_intr and qspi_mst_intr interrupts will be cleared. |
| 31:1  |      |     | Reserved                                                                                                                                                                               |

### 22.5.19 DMA control register (QSPI\_DMACTRL)

Offset address: 0x4C

Reset value: 0x0000 0000

| Field | Name     | R/W | Description                                    |
|-------|----------|-----|------------------------------------------------|
| 0     | RDMAEN   | R/W | Receive DMA enable<br>0: Disable<br>1: Enable  |
| 1     | TDMAEN   | R/W | Transmit DMA enable<br>0: Disable<br>1: Enable |
| 31:2  | Reserved |     |                                                |

### 22.5.20 DMA transmit data level register(QSPI\_DMATDL)

Offset address: 0x50

Reset value: 0x0000 0000

| Field | Name     | R/W | Description                                                                                                                                                                                                        |
|-------|----------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0   | DMATDL   | R/W | Transmit data level, when the valid data in the transmit FIFO is less than or equal to the value configured by DMATDL, a DMA request is generated, which is valid when TDMAEN=1.<br>The configuration range is 0-7 |
| 31:3  | Reserved |     |                                                                                                                                                                                                                    |

### 22.5.21 DMA receive data level register(QSPI\_DMARDL)

Offset address: 0x54

Reset value: 0x0000 0000

| Field | Name     | R/W | Description                                                                                                                                                                                                         |
|-------|----------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0   | DMARDL   | R/W | Receive data level, when the valid data in the receive FIFO is greater than or equal to the value configured by DMARDL, a DMA request is generated, which is valid when RDMAEN=1.<br>The configuration range is 0-7 |
| 31:3  | Reserved |     |                                                                                                                                                                                                                     |

### 22.5.22 Data register (QSPI\_DATA)

Offset address: 0x60

Reset value: 0x0000 0000

| Field | Name | R/W | Description                                                                                                                                                                                |
|-------|------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0  | DATA | R/W | Data<br>When writing this register, the data must be right adjusted; read data and the data will be right aligned automatically.<br>Read=Receive FIFO buffer<br>Write=Transmit FIFO buffer |

### 22.5.23 RX sample delay register (QSPI\_RSD)

Offset address: 0xF0

Reset value: 0x0000 0000

| Field | Name     | R/W | Description                                                                                                                                                     |
|-------|----------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0   | RSD      | R/W | Receive Data (RXD) Sampling Delay<br>This register is used for sampling of delay RXD input port. Each value represents the single qspi_clk delay on RXD sample. |
| 15:8  | Reserved |     |                                                                                                                                                                 |

| Field | Name | R/W | Description                                                                                                                                                                                                                                                  |
|-------|------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16    | RSE  | R/W | Receivie Data (RXD) Sampling Edge.<br>This register is used to confirm the sampling edge of RXD signal with qspi_clk. Then set this bit to 1, and use the negative edge of qspi_clk to sample the input data; otherwise, use the positive edge for sampling. |
| 31:17 |      |     | Reserved                                                                                                                                                                                                                                                     |

### 22.5.24 Control register 3 (QSPI\_CTRL3)

Offset address: 0xF4

Reset value: 0x0000 0000

| Field | Name    | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|---------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0   | IAT     | R/W | Address and instruction of transmission format<br>Select that QSPI transmits the instruction/address in standard SPI mode or the SPI mode selected in the ctrl0.spi_ff field.<br>00 (TT0): Transmit the instruction and address in standard SPI mode<br>01 (TT1): Transmit the instruction in standard SPI mode<br>Transmit the address in QSPI_CTRL1.SPI_FRF specified mode.<br>10 (TT2): Transmit the instruction and address in SPI_FRF specified mode<br>11 (TT3): Reserved                                                                                                                                                                                                                                                                                                             |
| 5:2   | ADDRLEN | R/W | The Address Length of Transfer<br>Transmission will start only after these bits have been compiled to FIFO.<br>0x0 (ADDR_L0): No address.<br>0x1 (ADDR_L4): 4-bit address length.<br>0x2 (ADDR_L8): 8-bit address length.<br>0x3 (ADDR_L12): 12-bit address length.<br>0x4 (ADDR_L16): 16-bit address length.<br>0x5 (ADDR_L20): 20-bit address length.<br>0x6 (ADDR_L24): 24-bit address length.<br>0x7 (ADDR_L28): 28-bit address length.<br>0x8 (ADDR_L32): 32-bit address length.<br>0x9 (ADDR_L36): 36-bit address length.<br>0xA (ADDR_L40): 40-bit address length.<br>0xB (ADDR_L44): 44-bit address length.<br>0xC (ADDR_L48): 48-bit address length.<br>0xD (ADDR_L52): 52-bit address length.<br>0xE (ADDR_L56): 56-bit address length.<br>0xF (ADDR_L60): 60-bit address length. |
| 7:6   |         |     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 9:8   | INSLEN  | R/W | Length of Instructions in QUAD Mode<br>00 (INST_L0): No instruction<br>01 (INST_L4): 4 -bit instruction<br>10 (INST_L8): 8 -bit instruction<br>11 (INST_L16): 16 -bit instruction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 10    |         |     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 15:11 | WAITCYC | R/W | The number of clocks to wait before transmitting/receiving data in QUAD mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 29:16 |         |     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

| Field | Name | R/W | Description                                                                                                                                                                                                                                                                        |
|-------|------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 30    | CSEN | R/W | Clock Stretching Enable<br>SPI transmission capacity. If written, FIFO will become empty, and QSPI will extend the clock until FIFO has enough data to continue to transmit.<br>If read, receive FIFO will become full, and QSPI will stop the clock until data is read from FIFO. |
| 31    |      |     | Reserved                                                                                                                                                                                                                                                                           |

### 22.5.25 IO switch register (QSPI\_IOSW)

Offset address: 0x200

Reset value: 0x0000 0000

| Field | Name | R/W | Description                                                                                     |
|-------|------|-----|-------------------------------------------------------------------------------------------------|
| 0     | IOSW | R/W | If this bit is set to "1", IO will be remapped to SPI2 and USART3 will switch to remap to QSPI. |
| 31:1  |      |     | Reserved                                                                                        |

## 23 Controller area network (CAN)

APM32F103x4x6 and APM32F103x8 D version products only have one CAN, while APM32F103x8xB E version products have two CANs.

### 23.1 Full Name and Abbreviation Description of Terms

Table 83 Full Name and Abbreviation Description of Terms

| Full name in English     | English abbreviation |
|--------------------------|----------------------|
| First Input First Output | FIFO                 |
| Request                  | REQ                  |

### 23.2 Introduction

CAN is abbreviation of Controller Area Network, and is serial communication protocol of ISO international standardization and supports CAN Protocol 2.0A and 2.0B. In CAN protocol, the sender sends the message to all receivers in the form of broadcast. When the node receives the message, it will go through the filter group and decide whether the message is needed according to the identifier. This design saves the CPU overhead.

### 23.3 Main Characteristics

- (1) Support CAN protocol 2.0A and 2.0B
- (2) The maximum baud rate of communication is 1Mbit/s
- (3) Transmission function
  - There are three transmitting mailboxes
  - The priority of transmitting message can be configured
  - Record the transmission time
- (4) Receiving function
  - Have two receive FIFO with three depth levels
  - Have 14 filter groups.
  - Record the receiving time
- (5) Memory
  - CAN1 and USBD1 share 512Byte SRAM
  - CAN2 and USBD2 share 512Byte SRAM
  - CAN1 and USBD2 are used at the same time
  - CAN2 and USBD1 are used at the same time
  - CAN1 and CAN2 are used at the same time

## 23.4 Functional Description

### 23.4.1 Characteristics of CAN Physical Layer

There can be multiple communication nodes on the CAN bus, each node consists of a CAN controller and a transceiver. The controller and transceiver are connected through CAN\_TX and CAN\_RX to transmit logic signals; the transceiver and bus are connected through CAN\_High and CAN\_Low to transmit differential signals.

### 23.4.2 Message Structure

Figure 101 Standard Data Frame



Figure 102 Extended Data Frame



Note:

- (1) Frame start: used to inform each node that there will be data for transmission.
- (2) Arbitration segment: It is used to decide which message can be transmitted when multiple messages are transmitted. Main content of this segment is ID information, the ID in standard format is 11 bits, and the ID in extended format is 29 bits.
- (3) Control segment: The main content of this segment is data length code (DLC), which is used to indicate how many bytes the data segment has in the message. The data segment has up to 8 bytes.
- (4) Data segment: Include the data information to be sent by the node.
- (5) CRC segment: CRC check code is used to ensure correct transmission of the messages.
- (6) ACK segment: This segment includes ACK slot bit and ACK delimiter bit. The transmitting node in ACK slot sends recessive bits, while the receiving node sends the dominant bit in this bit to acknowledge.
- (7) Frame end: Seven recessive bits sent by the transmitting nodes are used to indicate the end.

### 23.4.3 Working Mode

CAN has three main working modes: initialization mode, normal mode and sleep mode.

#### 23.4.3.1 Initialization mode

Set the INITREQ bit of the configuration register CAN\_MCTRL to 1 to request to

enter the initialization mode; clear the INITFLG bit to confirm entering the initialization mode.

Clear the INITREQ bit of the configuration register CAN\_MCTRL to request to exit the initialization mode; clear the INITFLG bit to confirm exiting the initialization mode.

Message receiving and transmitting is disabled in initialization mode.

#### 23.4.3.2 Normal mode

Clear the INITREQ bit of the configuration register CAN\_MCTRL through software to request to enter the normal mode from the initialization mode; wait for the hardware to clear the INITFLG bit to enter the normal mode.

Message receiving and transmitting is allowed in normal mode.

#### 23.4.3.3 Sleep mode

Set the SLEEPREQ bit of the configuration register CAN\_MCTRL to 1 to request to enter the sleep mode.

The clock of CAN stops work in sleep mode, the software can normally access the mailbox register, and the CAN is in low-power state.

### 23.4.4 Communication Mode

There are four communication modes: silent mode, loopback mode, silent loopback mode and normal mode. Different communication modes can be selected only in initialization mode.

#### 23.4.4.1 Silent mode

Set the SILMEN bit of the configuration register CAN\_BITTIM to 1 and select the silent mode.

In this mode, only recessive bit (logic 1)can be transmitted to the bus, while the dominant bit (logic 0) cannot be transmitted, and the data can be received from the bus.

Figure 103 CAN Works in Silent Mode



#### 23.4.4.2 Loopback mode

Set the LBKMEN bit of the configuration register CAN\_BITTIM to 1 and select

the loopback mode.

In this mode, the transmitted data are directly transmitted to the input end for receiving, the data are not received from the bus, and all data can be transmitted to the bus.

Figure 104 CAN Works in Loopback Mode



#### 23.4.4.3 Loopback silent mode

Set the LBKMEN and SILMEN bits of the configuration register CAN\_BITTIM to 1 and select the loopback silent mode.

In this mode, the transmitted data are directly transmitted to the input end for receiving, and the data are not received from the bus; only recessive bit (logic 1) can be transmitted to the bus, while the dominant bit (logic 0) cannot be transmitted.

Figure 105 CAN Works in Silent Loopback Mode



#### 23.4.4.4 Normal mode

In this mode, data can be transmitted to the bus and be received from the bus.

Figure 106 CAN Works in Normal Mode



## 23.4.5 Data Transmission

### 23.4.5.1 Conversion of transmitting mailbox state

Conversion process of transmitting mailbox state:

- (1) First select an empty mailbox to set, submit the transmitting request to the CAN bus controller by setting the TXMREQ bit of the configuration register CAN\_TXMIDx to 1, and then the mailbox immediately enters the registration state.
- (2) When multiple mailboxes are in the registered state, conduct priority scheduling. When a mailbox has the highest priority, it will enter the predetermined state.
- (3) When the message in the transmitting mailbox is transmitted to the bus, it will enter the transmitting state.
- (4) After the message is transmitted successfully, the mailbox will become idle again.

### 23.4.5.2 Transmitting priority

When multiple messages are waiting for transmitting, determine the transmitting sequence through the TXFPCFG bit of the configuration register CAN\_MCTRL:

- When the TXFPCFG bit is set to 0, the priority is determined by the message identifier, the identifier is the lowest, the priority is the highest, the identifier is equal, and the message with small mailbox number will be transmitted first
- When the TXFPCFG bit is set to 1, the priority will be determined by the sequence of transmitting request

### 23.4.5.3 Abort

Transmit the abort request by setting the ABREQFLG bit of the configuration register CAN\_TXSTS to 1.

If the mailbox is in registered or predetermined state, stop transmitting the request immediately; if the mailbox is in the transmitting state, there are two conditions: one is that the mailbox is successfully transmitted, the mailbox becomes empty, in such case, the TXSUSFLG bit of the CAN\_TXSTS register is set to 1 by hardware; the other is that the mailbox fails to transmit, the mailbox becomes predetermined and the transmitting request is aborted.

### 23.4.5.4 Automatic retransmission is disabled

Generally, in time triggered communication mode, automatic retransmission should be disabled.

In the mode that the automatic retransmission is disabled, the message is transmitted only once, and no matter what the result is (success, error or

arbitration loss), the hardware will not transmit the message again automatically.

When the transmitting process is finished, set the REQCFLG bit of the CAN\_TXSTS register to 1, and the transmitting result will be on the TXSUSFLG, ARBLSTFLG and TXERRFLG bits

## 23.4.6 Data Receiving

### 23.4.6.1 Receive FIFO

CAN has two receive FIFOs, each FIFO has three mailboxes, the FMNUM[1:0] bit of the register CAN\_RXF reflects the number of messages currently stored; set the RFOM bit to 1 to release the output mailbox of receive FIFO; FFULLFLG is the full state flag bit; FOVRFLG is overrun state flag bit.

### 23.4.6.2 Receive FIFO state conversion

At the beginning FIFO is in empty state, and after receiving the message, it will become registered.

When FIFO is in registered state and three mailboxes are full, after receiving next effective message, it will enter the overrun state, and there are two situations for loss of messages in overrun state:

- If FIFO lock function is disabled, the finally received message will be covered by new message
- If FIFO lock function is enabled, the newly received message will be discarded

## 23.4.7 Filtering Mechanism

Function of the filter: The receiving node decides whether the message is needed according to the message identifier, and only the required message will be received after filtering. CAN controller has 14 filter groups.

### 23.4.7.1 Bit width

Each group of filters can configure two kinds of bit width.

Figure 107 One 32-bit Filter

| ID      | CAN_FiBANK1[31:24] |  | CAN_FiBANK1[23:16] |              | CAN_FiBANK1[15:8] |  | CAN_FiBANK1[7:0] |               |             |   |
|---------|--------------------|--|--------------------|--------------|-------------------|--|------------------|---------------|-------------|---|
| mapping | STDID[10:3]        |  | STDID[2:0]         | EXTID[17:13] | EXTID[12:5]       |  | EXTID[4:0]       | IDTYP<br>ESEL | TXRFR<br>EQ | 0 |

Figure 108 Two 16-bit Filters

| ID      | CAN_FiBANK1[15:8] |  | CAN_FiBANK1[7:0] |             |               | CAN_FiBANK2[15:8] |             | CAN_FiBANK2[7:0] |             |               |                  |
|---------|-------------------|--|------------------|-------------|---------------|-------------------|-------------|------------------|-------------|---------------|------------------|
| mapping | STDID[10:3]       |  | STDID<br>[2:0]   | TXRF<br>REQ | IDTYP<br>ESEL | EXTID<br>[17:15]  | STDID[12:5] | STDID<br>[2:0]   | TXRF<br>REQ | IDTYP<br>ESEL | EXTID<br>[17:15] |

### 23.4.7.2 Filtering mode

#### Mask bit mode

In this mode, it is only required to use some bits of the message identifier as a list to form the mask, and the message ID should be the same as the mask, and then the message can be received

Table 84 Mask Bit Mode Example

|      |   |   |   |   |   |   |   |   |       |
|------|---|---|---|---|---|---|---|---|-------|
| ID   | 1 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | ..... |
| Mask | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | ..... |

|             |   |   |   |   |   |   |   |   |       |
|-------------|---|---|---|---|---|---|---|---|-------|
| <b>ID</b>   | 1 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | ..... |
| Screened ID | 1 | X | 1 | 1 | 0 | X | X | 0 | ..... |

### Identifier list mode

In this mode, each bit of the message ID needs to be the same as the filter identifier, and then the message can be received.

Table 85 Identifier List Mode Example

|             |   |   |   |   |   |   |   |   |   |
|-------------|---|---|---|---|---|---|---|---|---|
| <b>ID</b>   | 1 | 1 | 1 | 0 | 1 | 0 | 0 | 1 | 1 |
| ID          | 1 | 1 | 1 | 0 | 1 | 0 | 0 | 1 | 1 |
| Screened ID | 1 | 1 | 1 | 0 | 1 | 0 | 0 | 1 | 1 |

### 23.4.7.3 Filter priority

The priority rules are as follows:

- The priority of the filter with width of 32 bits is higher than that with width of 16 bits
- Under the condition of the same bit width, the priority of the identifier list mode is higher than that of mask bit mode
- Under the condition of the same bit width and mode, the priority of the small filtering number is high

### 23.4.8 Bit Timing and Baud Rate

#### 23.4.8.1 Bit timing

The CAN peripheral bit timing of APM32 contains three segments: synchronization segment (SYNC\_SEG), time segment 1 (BS1) and time segment 2 (BS2), and the sampling points are at the junction of BS1 and BS2 segments.

- Synchronization segment (SYNC\_SEG): This bit occupies one time cell
- Time segment 1 (BS1): This segment occupies one to 16 time cells, and it contains PROP\_SEG and PHASE\_SEG1 in CAN standard
- Time segment 2 (BS2): This segment occupies one to eight time cells, and it represents PHASE\_SEG2 in CAN standard

#### 23.4.8.2 Calculation of baud rate

Time of BS1 segment:  $T_{S1}=T_q \cdot (TIMSEG1[3:0]+1)$

Time of BS2 segment:  $T_{S2}=T_q \cdot (TIMSEG2[2:0]+1)$

Time of one data bit:  $T_{1bit}=T_q+T_{S1}+T_{S2}$

Baud rate =  $1/T_{1bit}$

$T_q = (BRPSC+1) * TPCLK$

### 23.4.9 Error Management

Transmit the error counter through the TXERRCNT bit of the configuration register CAN\_ERRSTS and receive the error counter through the RXERRCNT bit of the register CAN\_ERRSTS to reflect the error management of CAN bus.

Control the generation of interrupt in error state through the ERRIEN bit of the configuration register CAN\_INTEN.

#### 23.4.9.1 Bus-off recovery

When the TXERRCNT of the CAN error state register is greater than 255, the CAN bus controller will enter the bus-off state, then the BOFLG bit of the

register CAN\_ERRSTS is set to 1, and in this state, the CAN bus controller cannot receive and transmit messages.

Decide the bus-off recovery mode through the ALBOFFM bit of the configuration register CAN\_MCTRL:

- If the ALBOFFM bit is set to 1, once the hardware detects 11 continuous recessive bits for 128 times, it will exit the bus-off state automatically;
- If the ALBOFFM bit is set to 0, after the software requests to enter and then exit the initialization mode, it will exit the bus-off state.

### 23.4.10 Interrupt

#### Events generating transmitting interrupt:

- The hardware sets REQCFLG0 bit of the register CAN\_TXSTS to 1, and the transmitting mailbox 0 becomes idle
- The hardware sets REQCFLG1 bit of the register CAN\_TXSTS to 1, and the transmitting mailbox 1 becomes idle
- The hardware sets REQCFLG2 bit of the register CAN\_TXSTS to 1, and the transmitting mailbox 2 becomes idle

#### Events generating FIFO0 interrupt:

- Set the FMNUM0[1:0] bit of the register CAN\_RXF0 to a number rather than 0 by the hardware, and FIFO0 will receive a new message
- Set the FFULLFLG0 bit of the register CAN\_RXF0 to 1 by the hardware, and FIFO0 will be full
- Set the FOVRFLG0 bit of the register CAN\_RXF0 to 1 by the hardware and FIFO0 will overrun

#### Events generating FIFO1 interrupt:

- Set the FMNUM1[1:0] bit of the register CAN\_RXF1 to a number rather than 0 by the hardware, and FIFO1 will receive a new message
- Set the FFULLFLG1 bit of the register CAN\_RXF1 to 1 by the hardware, and FIFO1 will be full
- Set the FOVRFLG1 bit of the register CAN\_RXF1 to 1 by the hardware and FIFO1 will overrun

#### Events generating state change and error interrupt:

- Set the SLEEPEN bit of the register CAN\_INTEN to 1 by the hardware and it will enter the sleep mode
- Set the WUPIEN bit of the register CAN\_INTEN to 1 by the hardware and interrupt enable will be woken up
- Set the ERRWFLG bit of the register CAN\_ERRSTS to 1 by the hardware, and it means that the number of errors has reached the watermark

- Set the ERRPFLG bit of the register CAN\_ERRSTS to 1 by the hardware, and it means that the number of errors has reached the watermark of passive error
- Set the LERRC[2:0] bit of the register CAN\_ERRSTS by the hardware, and it indicates the condition of last error

Figure 109 Event Flag and Interrupt Generation



## 23.5 Register Address Mapping

CAN1 base address: 0x4000\_6400

CAN2 base address: 0x4000\_6800

Note: Except base address, the register and offset addresses of CAN1 and CAN2 are exactly the same.

Table 86 CAN Register Address Mapping

| Register name | Description                                  | Offset address      |
|---------------|----------------------------------------------|---------------------|
| CAN_MCTRL     | CAN main control register                    | 0x00                |
| CAN_MSTS      | CAN main state register                      | 0x04                |
| CAN_TXSTS     | CAN transmit state register                  | 0x08                |
| CAN_RXF0      | CAN receive FIFO 0 register                  | 0x0C                |
| CAN_RXF1      | CAN receive FIFO 1 register                  | 0x10                |
| CAN_INTEN     | CAN interrupt enable register                | 0x14                |
| CAN_ERRSTS    | CAN error state register                     | 0x18                |
| CAN_BITTIM    | CAN bit timing register                      | 0x1C                |
| CAN_TXMIDx    | Transmitting mailbox identifier register     | 0x180, 0x190, 0x1A0 |
| CAN_TXDLENx   | Transmitting mailbox data length register    | 0x184, 0x194, 0x1A4 |
| CAN_TXMDLx    | Transmitting mailbox low-byte data register  | 0x188, 0x198, 0x1A8 |
| CAN_TXMDHx    | Transmitting mailbox high-byte data register | 0x18C, 0x19C, 0x1AC |
| CAN_RXMIDx    | Receive FIFO mailbox identifier register     | 0x1B0, 0x1C0        |
| CAN_RXDLENx   | Receive FIFO mailbox data length register    | 0x1B4, 0x1C4        |
| CAN_RXMDLx    | Receive FIFO mailbox low-byte data register  | 0x1B8, 0x1C8        |
| CAN_RXMDHx    | Receive FIFO mailbox high-byte data register | 0x1BC, 0x1CC        |
| CAN_FCTRL     | CAN filter main control register             | 0x200               |
| CAN_FMCFG     | CAN filter mode register                     | 0x204               |
| CAN_FSCFG     | CAN filter bit width register                | 0x20C               |
| CAN_FFASS     | CAN filter FIFO association register         | 0x214               |
| CAN_FACT      | CAN filter activation register               | 0x21C               |
| CAN_FIBANKx   | Register x of CAN filter group i             | 0x240..0x2AC        |

## 23.6 Register Functional Description

### 23.6.1 CAN control and state register

#### 23.6.1.1 CAN main control register (CAN\_MCTRL)

Offset address: 0x00

Reset value: 0x0001 0002

| Field | Name     | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------|----------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | INITREQ  | R/W | Request to Enter Initialization Mode<br>0: Enter the normal work mode from the initialization mode<br>1: Enter the initialization mode from the normal work mode                                                                                                                                                                                                                                                                                                             |
| 1     | SLEEPREQ | R/W | Request to Enter Sleep Mode<br>0: Exit the sleep mode<br>1: Request to enter the sleep mode.<br>If the AWUPCFG bit is set to 1, when the RX signal detects CAN message, this bit will be cleared by hardware; after reset, reset this bit to 1; after reset, it will enter the sleep mode.                                                                                                                                                                                   |
| 2     | TXFPCFG  | R/W | Transmit FIFO Priority Configure<br>This bit is used to determine which parameters determine the transmission priority when multiple messages are waiting for transmission.<br>0: Determined by the message identifier<br>1: Determined by the sequence of transmission request                                                                                                                                                                                              |
| 3     | RXFLOCK  | R/W | Receive FIFO Locked Mode Configure<br>This bit is used to determine whether FIFO is locked when receiving overrun, and how to deal with the next received message when the message of the receive FIFO has not been read out.<br>0: Unlocked; If the message of the receive FIFO is not read out, the next received message will cover the original message<br>1: Locked; when the message of the received FIFO is not read out, the next received message will be discarded |
| 4     | ARTXMD   | R/W | Automatic Retransmission Message Disable<br>0: Automatic retransmission is enabled, and the message will be retransmitted automatically until it is transmitted successfully<br>1: Automatic retransmission is disabled and the message is transmitted only once                                                                                                                                                                                                             |
| 5     | AWUPCFG  | R/W | Automatic Wakeup Mode Configure<br>0: Software wakes up the sleep mode by clearing the SLEEPREQ bit of the CAN_MCTRL register<br>1: Hardware wakes up the sleep mode by detecting CAN message                                                                                                                                                                                                                                                                                |
| 6     | ALBOFFM  | R/W | Automatic Leaving Bus-Off Status Condition Management<br>0: After the software resets the INITREQ bit of the CAN_MCTRL register to 1 and then clears it, when the hardware detects 11 continuous recessive bits for 128 times, it will exit from the bus-off state<br>1: When the hardware detects 11 continuous recessive bits for 128 times, it will exit from the bus-off state automatically                                                                             |
| 14:7  |          |     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 15    | SWRST    | R/S | Software Reset CAN<br>0: Work normally<br>1: CAN is reset by force, and after reset, CAN enters the sleep mode; the hardware will clear this bit automatically                                                                                                                                                                                                                                                                                                               |
| 16    | DBGFRZE  | R/W | Debug Freeze<br>0: Invalid<br>1: During debugging, CAN cannot receive/transmit, but it still can read and write and control the receive FIFO normally                                                                                                                                                                                                                                                                                                                        |
| 31:17 |          |     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

### 23.6.1.2 CAN main state register (CAN\_MSTS)

Offset address: 0x04

Reset value: 0x0000 0C02

| Field | Name    | R/W | Description                                                                                                                                                                                                                                  |
|-------|---------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | INITFLG | R   | Being Initialization Mode Flag<br>This bit is set to 1 or cleared by hardware.<br>1: Exit the initialization mode<br>1: Being in the initialization mode; this bit is confirmation for initialization request bit of the CAN_MCTRL register. |

| Field | Name      | R/W   | Description                                                                                                                                                                                                                                                                                                                  |
|-------|-----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1     | SLEEPFLG  | R     | Being Sleep Mode Flag<br>This bit is set to 1 or cleared by hardware<br>0: Exit the sleep mode<br>1: Being in the sleep mode; this bit is confirmation for sleep moderequest bit of the CAN_MCTRL register.                                                                                                                  |
| 2     | ERRIFLG   | RC_W1 | Error Interrupt Occur Flag<br>This bit is set to 1 by hardware and written to 1 and cleared by software.<br>0: Not occur<br>1: Occurred                                                                                                                                                                                      |
| 3     | WUPIFLG   | RC_W1 | Wakeup Interrupt Occur Flag<br>When entering the sleep mode and detecting SOP wake-up, the bit is set to 1 by hardware; it is written to 1 and cleared by software.<br>0: Failed to wake up from the sleep mode<br>1: Woke up from the sleep mode                                                                            |
| 4     | SLEEPIFLG | RC_W1 | Being Sleep Mode Interrupt Flag<br>When entering the sleep mode, this bit is set to 1 by hardware and corresponding interrupt will be triggered; when exiting the sleep mode, this bit is cleared by hardware and is written as 1 and cleared by software.<br>0: Failed to enter the sleep mode<br>1: Entered the sleep mode |
| 7:5   |           |       | Reserved                                                                                                                                                                                                                                                                                                                     |
| 8     | TXMFLG    | R     | Being Transmit Mode Flag<br>0: CAN is not in transmission mode<br>1: CAN is in transmission mode                                                                                                                                                                                                                             |
| 9     | RXMFLG    | R     | Being Receive Mode Flag<br>0: CAN is not in receiving mode<br>1: CAN is in receiving mode                                                                                                                                                                                                                                    |
| 10    | LSAMVALUE | R     | CAN Rx Pin Last Sample Value                                                                                                                                                                                                                                                                                                 |
| 11    | RXSIGL    | R     | CAN Rx Pin Signal Level                                                                                                                                                                                                                                                                                                      |
| 31:12 |           |       | Reserved                                                                                                                                                                                                                                                                                                                     |

### 23.6.1.3 CAN transmitting state register (CAN\_TXSTS)

Offset address: 0x08

Reset value: 0x1C00 0000

| Field | Name      | R/W   | Description                                                                                                                                                                                                                                                                                                                   |
|-------|-----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | REQCFLG0  | RC_W1 | Mailbox 0 Request Completed Flag<br>When the last transmission or abortion request of the mailbox 0 is completed, this bit is set to 1 by hardware; when receiving the transmission request, this bit is cleared by hardware; it is written to 1 or cleared by software.<br>0: Being transmitted<br>1: Transmission completed |
| 1     | TXSUSFLG0 | RC_W1 | Mailbox 0 Transmission Success Flag<br>When mailbox 0 attempts to transmit successfully, this bit is set to 1 by hardware; and written to 1 and cleared by software.<br>0: Last transmission attempt failed<br>1: Last transmission attempt succeeded                                                                         |

| Field | Name       | R/W   | Description                                                                                                                                                                                                                                                                                                                             |
|-------|------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2     | ARBLSTFLG0 | RC_W1 | <p>Mailbox 0 Arbitration Lost Flag<br/>When the mailbox 0 loses arbitration, this bit is set to 1 by hardware; and written to 1 and cleared by software.<br/>0: Meaningless<br/>1: Lost</p>                                                                                                                                             |
| 3     | TXERRFLG0  | RC_W1 | <p>Mailbox 0 Transmission Error Flag<br/>When mailbox 0 fails to transmit, this bit is set to 1 by hardware; and written to 1 and cleared by software.<br/>0: Meaningless<br/>1: Failed to transmit</p>                                                                                                                                 |
| 6:4   | Reserved   |       |                                                                                                                                                                                                                                                                                                                                         |
| 7     | ABREQFLG0  | R/S   | <p>Mailbox 0 Abort Request Flag<br/>If there is no message waiting for transmitting in mailbox 0, this bit is ineffective.<br/>0: The transmitting message of mailbox 0 is cleared, and this bit is cleared by hardware<br/>1: Set this bit to 1 to abort the transmission request of mailbox 0</p>                                     |
| 8     | REQCFLG1   | RC_W1 | <p>Mailbox 1 Request Completed Flag<br/>When the last request of mailbox 1 is transmitted or aborted, this bit is set to 1 by hardware; When receiving the transmission request, this bit is cleared by hardware, and written to 1 and cleared by software.<br/>0: Being transmitted<br/>1: Transmission completed</p>                  |
| 9     | TXSUSFLG1  | RC_W1 | <p>Mailbox 1 Transmission Success Flag<br/>When mailbox 1 attempts to transmit successfully, this bit is set to 1 by hardware; and written to 1 and cleared by software.<br/>0: Last transmission attempt failed<br/>1: Last transmission attempt succeeded</p>                                                                         |
| 10    | ARBLSTFLG1 | RC_W1 | <p>Mailbox 1 Arbitration Lost Flag<br/>When the mailbox 1 loses arbitration, this bit is set to 1 by hardware; and written to 1 and cleared by software.<br/>0: Meaningless<br/>1: Lost</p>                                                                                                                                             |
| 11    | TXERRFLG1  | RC_W1 | <p>Mailbox 1 Transmission Error Flag<br/>When mailbox 1 fails to transmit, this bit is set to 1 by hardware; and written to 1 and cleared by software.<br/>0: Meaningless<br/>1: Failed to transmit</p>                                                                                                                                 |
| 14:12 | Reserved   |       |                                                                                                                                                                                                                                                                                                                                         |
| 15    | ABREQFLG1  | R/S   | <p>Mailbox 1 Abort Request Flag<br/>If there is no message waiting for transmitting in mailbox 1, this bit is ineffective.<br/>0: The transmitting message of mailbox 1 is cleared, and this bit is cleared by hardware<br/>1: Set this bit to 1 to abort the transmission request of mailbox 1</p>                                     |
| 16    | REQCFLG2   | RC_W1 | <p>Mailbox 2 Request Completed Flag<br/>When the last transmission or abortion request of the mailbox 2 is completed, this bit is set to 1 by hardware; when receiving the transmission request, this bit is cleared by hardware; it is written to 1 or cleared by software.<br/>0: Being transmitted<br/>1: Transmission completed</p> |

| Field | Name       | R/W   | Description                                                                                                                                                                                                                                                                                                          |
|-------|------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 17    | TXSUSFLG2  | RC_W1 | <p>Mailbox 2 Transmission Success Flag<br/>When mailbox 2 attempts to transmit successfully, this bit is set to 1 by hardware; and written to 1 and cleared by software.<br/>0: Last transmission attempt failed<br/>1: Last transmission attempt succeeded</p>                                                      |
| 18    | ARBLSTFLG2 | RC_W1 | <p>Mailbox 2 Arbitration Lost Flag<br/>When the mailbox 2 loses arbitration, this bit is set to 1 by hardware; and written to 1 and cleared by software.<br/>0: Meaningless<br/>1: Lost</p>                                                                                                                          |
| 19    | TXERRFLG2  | RC_W1 | <p>Mailbox 2 Transmission Error Flag<br/>When mailbox 2 fails to transmit, this bit is set to 1 by hardware; and written to 1 and cleared by software.<br/>0: Meaningless<br/>1: Failed to transmit</p>                                                                                                              |
| 22:20 | Reserved   |       |                                                                                                                                                                                                                                                                                                                      |
| 23    | ABREQFLG2  | R/S   | <p>Mailbox 2 Abort Request Flag<br/>If there is no message waiting for transmitting in mailbox 2, this bit is ineffective.<br/>0: The transmitting message of mailbox 2 is cleared, and this bit is cleared by hardware<br/>1: Set this bit to 1 to abort the transmission request of mailbox 2</p>                  |
| 25:24 | EMNUM[1:0] | R     | <p>Empty Mailbox Number<br/>This bit is applicable when there is empty mailbox. When all the transmitting mailboxes are empty, it means the number of the transmitting mailbox with the lowest priority; when the mailbox is not empty but not all empty, it means the number of next mailbox to be transmitted.</p> |
| 26    | TXMEFLG0   | R     | <p>Transmit Mailbox 0 Empty Flag<br/>When the transmitting mailbox 0 is empty, this bit is set to 1 by hardware.<br/>0: There is message to be transmitted in mailbox 0<br/>1: There is no message to be transmitted in mailbox 0</p>                                                                                |
| 27    | TXMEFLG1   | R     | <p>Transmit Mailbox 1 Empty Flag<br/>When the transmitting mailbox 1 is empty, this bit is set to 1 by hardware.<br/>0: There is message to be transmitted in mailbox 1<br/>1: There is no message to be transmitted in mailbox 1</p>                                                                                |
| 28    | TXMEFLG2   | R     | <p>Transmit Mailbox 2 Empty Flag<br/>When the transmitting mailbox 2 is empty, this bit is set to 1 by hardware.<br/>0: There is message to be transmitted in mailbox 2<br/>1: There is no message to be transmitted in mailbox 2</p>                                                                                |
| 29    | LOWESTP0   | R     | <p>The Lowest Transmission Priority Flag For Mailbox 0<br/>0: Meaningless<br/>1: The priority of mailbox 0 is the lowest among those mailboxes waiting to transmit messages<br/>Note: If there is only one mailbox waiting, LOWESTP[2:0] is cleared.</p>                                                             |
| 30    | LOWESTP1   | R     | <p>The Lowest Transmission Priority Flag For Mailbox 1<br/>0: Meaningless<br/>1: The priority of mailbox 1 is the lowest among those mailboxes waiting to transmit messages</p>                                                                                                                                      |

| Field | Name     | R/W | Description                                                                                                                                                            |
|-------|----------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | LOWESTP2 | R   | The Lowest Transmission Priority Flag For Mailbox 2<br>0: Meaningless<br>1: The priority of mailbox 2 is the lowest among those mailboxes waiting to transmit messages |

#### 23.6.1.4 CAN receive FIFO 0 register (CAN\_RXF0)

Offset address: 0x0C

Reset value: 0x0000 0000

| Field | Name        | R/W   | Description                                                                                                                                                                                                                                                                                                                                                     |
|-------|-------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0   | FMNUM0[1:0] | R     | The number of Message in receive FIFO0<br>These bits are used to reflect the number of messages stored in current receive FIFO0. Every time a new message is received, add 1 to FMNUM0 bit; every time the mailbox message is released and outputted, subtract 1 from FMNUM0 bit.                                                                               |
| 2     |             |       | Reserved                                                                                                                                                                                                                                                                                                                                                        |
| 3     | FFULLFLG0   | RC_W1 | Receive FIFO0 Full Flag<br>When there are three messages in FIFO0, it means the FIFO0 has been full; this bit is set to 1 by hardware and written to 1 and cleared by software.<br>0: Not full<br>1: Full                                                                                                                                                       |
| 4     | FOVRFLG0    | RC_W1 | Receive FIFO 0 Overrun Flag<br>When there are three messages in FIFO0 and then a new message is received, it means the FIFO0 overrun; this bit is set to 1 by hardware and written to 1 and cleared by software.<br>0: No overrun<br>1: Overrun is generated                                                                                                    |
| 5     | RFOM0       | R/S   | Release Receive FIFO0 Output Mailbox to Receive Message<br>This bit is set to 1 by hardware and cleared by software. If there is no message in FIFO, this bit is invalid. When FIFO contains more than two messges, the output mailbox must be first released to access the second message.<br>0: Meaningless<br>1: Release the output mailbox of receive FIFO0 |
| 31:6  |             |       | Reserved                                                                                                                                                                                                                                                                                                                                                        |

#### 23.6.1.5 CAN receive FIFO 1 register (CAN\_RXF1)

Offset address: 0x10

Reset value: 0x0000 0000

| Field | Name        | R/W   | Description                                                                                                                                                                                                                                                                       |
|-------|-------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0   | FMNUM1[1:0] | R     | The number of Message in receive FIFO1<br>These bits are used to reflect the number of messages stored in current receive FIFO1. Every time a new message is received, add 1 to FMNUM1 bit; every time the mailbox message is released and outputted, subtract 1 from FMNUM1 bit. |
| 2     |             |       | Reserved                                                                                                                                                                                                                                                                          |
| 3     | FFULLFLG1   | RC_W1 | Receive FIFO0 Full Flag<br>When there are three messages in FIFO1, it means the FIFO1 has been full; this bit is set to 1 by hardware and written to 1 and cleared by software.<br>0: Not full<br>1: Full                                                                         |

| Field | Name     | R/W   | Description                                                                                                                                                                                                                                                                                                                                                                    |
|-------|----------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4     | FOVRFLG1 | RC_W1 | <p>Receive FIFO1 Overrun Flag<br/> When there are three messages in FIFO1 and then a new message is received, it means the FIFO1 overrun ; this bit is set to 1 by hardware and written to 1 and cleared by software.</p> <p>0: No overrun<br/> 1: Overrun is generated</p>                                                                                                    |
| 5     | RROM1    | R/S   | <p>Release Receive FIFO1 Output Mailbox to Receive Message<br/> This bit is set to 1 by hardware and cleared by software. If there is no message in FIFO, this bit is invalid. When FIFO contains more than two messges, the output mailbox must be first released to access the second message.</p> <p>0: Meaningless<br/> 1: Release the output mailbox of receive FIFO1</p> |
| 31:6  | Reserved |       |                                                                                                                                                                                                                                                                                                                                                                                |

### 23.6.1.6 CAN interrupt enable register (CAN\_INTEN)

Offset address: 0x14

Reset value: 0x0000 0000

| Field | Name      | R/W | Description                                                                                                                                                                                                                                                                               |
|-------|-----------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | TXMEIEN   | R/W | <p>Transmit Mailbox Empty Interrupt Enable<br/> When REQCFLGx bit is set to 1, it means transmission has been completed, and the transmitting mailbox is empty; if this bit is set to 1, an interrupt will be generated.</p> <p>0: No interrupt<br/> 1: Interrupt generated</p>           |
| 1     | FMIEN0    | R/W | <p>Interrupt Enable When The Number Of FIFO0 Message Is Not 0<br/> When FMNUM0[1:0] bit of FIFO 0 is not zero, it means that the number of messages in FIFO0 is not zero; if this bit is set to 1, an interrupt will be generated.</p> <p>0: No interrupt<br/> 1: Interrupt generated</p> |
| 2     | FFULLIENO | R/W | <p>FIFO0 Full Interrupt Enable<br/> When the FFULLFLG0 bit of FIFO0 is set to 1, it means that the message of FIFO0 is full; if this bit is set to 1, an interrupt will be generated.</p> <p>0: No interrupt<br/> 1: Interrupt generated</p>                                              |
| 3     | FOVRIENO  | R/W | <p>FIFO0 Overrun Interrupt Enable<br/> When the FOVRFLG0 bit of FIFO0 is set to 1, it means that the FIFO0 has been overloaded; if this bit is set to 1, an interrupt will be generated.</p> <p>0: No interrupt<br/> 1: Interrupt generated</p>                                           |
| 4     | FMPIEN1   | R/W | <p>Interrupt Enable when the number of FIFO1 Message is not 0<br/> When FMNUM1[1:0] bit of FIFO 1 is not zero, it means that the number of messages in FIFO1 is not zero; if this bit is set to 1, an interrupt will be generated.</p> <p>0: No interrupt<br/> 1: Interrupt generated</p> |

| Field | Name      | R/W | Description                                                                                                                                                                                                                                                                          |
|-------|-----------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5     | FFULLIEN1 | R/W | <p>FIFO1 Full Interrupt Enable<br/>When the FFULLFLG1 bit of FIFO1 is set to 1, it means that the message of FIFO1 is full; if this bit is set to 1, an interrupt will be generated.<br/>0: No interrupt<br/>1: Interrupt generated</p>                                              |
| 6     | FOVRIEN1  | R/W | <p>FIFO1 Overrun Interrupt Enable<br/>When the FOVRFLG1 bit of FIFO1 is set to 1, it means that the FIFO1 has been overloaded; if this bit is set to 1, an interrupt will be generated.<br/>0: No interrupt<br/>1: Interrupt generated</p>                                           |
| 7     |           |     | Reserved                                                                                                                                                                                                                                                                             |
| 8     | ERRWIEN   | R/W | <p>Error Warning Interrupt Enable<br/>When ERRWFLG bit is set to 1, an error warning will occur; if this bit is set to 1, ERRIFLG shall be set and a warning error interrupt will be generated.<br/>0: ERRIFLG bit is not set<br/>1: ERRIFLG bit is set to 1</p>                     |
| 9     | ERRPIEN   | R/W | <p>Error Passive Interrupt Enable<br/>When ERRPFLG bit is set to 1, a passive error will occur; if this bit is set to 1, ERRIFLG shall be set and a passive error interrupt will be generated.<br/>0: ERRIFLG bit is not set<br/>1: ERRIFLG bit is set to 1</p>                      |
| 10    | BOFFIEN   | R/W | <p>Bus-Off Interrupt Enable<br/>When BOFFFLG bit is set to 1, bus-off will occur; if this bit is set to 1, ERRIFLG shall be set and an bus-off error interrupt will be generated.<br/>0: ERRIFLG bit is not set<br/>1: ERRIFLG bit is set to 1</p>                                   |
| 11    | LECIEN    | R/W | <p>Last Error Code Interrupt Enable<br/>When an error is detected and the hardware sets LERRC[2:0], the last error code is recorded. If this bit set to 1, the ERRIFLG is set to generate the last error interrupt.<br/>0: ERRIFLG bit is not set<br/>1: ERRIFLG bit is set to 1</p> |
| 14:12 |           |     | Reserved                                                                                                                                                                                                                                                                             |
| 15    | ERRIEN    | R/W | <p>Error interrupt Enable<br/>When the corresponding error state register is set to 1, if this bit is set to 1, an error interrupt will be generated.<br/>0: No interrupt<br/>1: Interrupt generated</p>                                                                             |
| 16    | WUPIEN    | R/W | <p>Wakeup Interrupt Enable<br/>When WUPINT bit is set to 1, if this bit is set to 1, a wake-up interrupt will be generated.<br/>0: No interrupt<br/>1: Interrupt generated</p>                                                                                                       |
| 17    | SLEEPPIEN | R/W | <p>Sleep Interrupt Enable<br/>When SLEEPIFLG bit is set to 1, if this bit is set to 1, a sleep interrupt will be generated.<br/>0: No interrupt<br/>1: Interrupt generated</p>                                                                                                       |

| Field | Name | R/W | Description |
|-------|------|-----|-------------|
| 31:18 |      |     | Reserved    |

### 23.6.1.7 CAN error state register (CAN\_ERRSTS)

Offset address: 0x18

Reset value: 0x0000 0000

| Field | Name     | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------|----------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | ERRWFLG  | R   | <p>Error Warning Occur Flag<br/>When the value of the receiving error counter or transmitting error counter <math>\geq 96</math>, this bit is set to 1 by hardware.<br/>0: No error alarm<br/>1: Error alarm occurred</p>                                                                                                                                                                                                                 |
| 1     | ERRPFLG  | R   | <p>Error Passive Occur Flag<br/>When the value of the receiving error counter or transmitting error counter <math>\geq 127</math>, this bit is set to 1 by hardware.<br/>0: No passive error appears<br/>1: Passive error appears</p>                                                                                                                                                                                                     |
| 2     | BOFLG    | R   | <p>Enter Bus-Off Flag<br/>When the value of the transmitting error counter TXERRCNT is greater than 255, CAN will enter the bus-off state and this bit is set to 1 by hardware.<br/>0: CAN not in bus-off state<br/>1: CAN in bus-off state</p>                                                                                                                                                                                           |
| 3     |          |     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 6:4   | LERRC    | R/W | <p>Record Last Error Code<br/>When the error on CAN bus is detected, it is set by hardware according to the error category; when the message is transmitted or received correctly, this bit is cleared by hardware.<br/>000: No error<br/>001: Bit stuffing error<br/>010: Form (Form) error<br/>011: Acknowledgment (ACK) error<br/>100: Recessive bit error<br/>101: Dominant bit error<br/>110: CRC error<br/>111: Set by software</p> |
| 15:7  |          |     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 23:16 | TXERRCNT | R   | <p>Least Significant Byte Of The 9-Bit Transmit Error Counter<br/>The counter is implemented according to the transmission part of fault definition mechanism of CAN protocol.</p>                                                                                                                                                                                                                                                        |
| 31:24 | RXERRCNT | R   | <p>Receive Error Counter<br/>The receiving error counter is implemented according to the receiving part of fault definition mechanism of CAN protocol. When receiving error occurs, according to the condition of error, add 1 or 8 to the counter, and subtract 1 after receiving successfully. When the value of the counter is greater than 127, set the counter value to 120.</p>                                                     |

### 23.6.1.8 CAN bit timing register (CAN\_BITTIM)

Offset address: 0x1C

Reset value: 0x0123 0000

| Field | Name  | R/W | Description                      |
|-------|-------|-----|----------------------------------|
| 9:0   | BRPSC | R/W | Baud Rate Prescaler Factor Setup |

|       |          |     |                                                                                                                                  |
|-------|----------|-----|----------------------------------------------------------------------------------------------------------------------------------|
|       |          |     | Time cell $t_q = (BRPSC+1) \times t_{PCLK}$                                                                                      |
| 15:10 | Reserved |     |                                                                                                                                  |
| 19:16 | TIMSEG1  | R/W | Time Segment 1 Setup<br>Time occupied by time period 1 $t_{BS1} = t_{CAN} \times (TIMSEG1+1)$ .                                  |
| 22:20 | TIMSEG2  | R/W | Time Segment 2 Setup<br>Time occupied by time period 2 $t_{BS2} = t_{CAN} \times (TIMSEG2+1)$ .                                  |
| 23    | Reserved |     |                                                                                                                                  |
| 25:24 | RSYNJW   | R/W | Resynchronization Jump Width<br>Time that CAN hardware can extend or shorten in this bit $t_{RJW} = t_{CAN} \times (RSYNJW+1)$ . |
| 29:26 | Reserved |     |                                                                                                                                  |
| 30    | LBKMEN   | R/W | Loop Back Mode Enable<br>0: Disable<br>1: Enable                                                                                 |
| 31    | SILMEN   | R/W | Silent Mode Enable<br>0: Normal state<br>1: Silent mode                                                                          |

Note: When CAN is in initialization mode, this register can be accessed only by software

### 23.6.2 CAN mailbox register

This section describes the transmitting and receiving mailbox registers.

The transmitting and receiving mailboxes are almost the same except the following examples:

- FMIDX domain of CAN\_RXDLENx register;
- The receiving mailbox is read-only;
- The transmitting mailbox is writable only when it is empty, and if the corresponding TXMEFLG bit of CAN\_TXSTS register is 1, it means the transmitting mailbox is empty.

There are three transmitting mailboxes and two receiving mailboxes in total. Each receiving mailbox is FIFO with three levels of depth, and can only access the message that is received first in FIFO.

#### 23.6.2.1 Transmitting mailbox identifier register (CAN\_TXMIDx) (x=0..2)

Offset address: 0x180, 0x190, 0x1A0

Reset value: 0xFFFF XXXX, X=undefined bit (except Bit 0, TXMREQ=0 after reset)

| Field | Name        | R/W | Description                                                                                                                                                                                                   |
|-------|-------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | TXMREQ      | R/W | Transmit Mailbox Data Request<br>0: When the data in the mailbox is transmitted, the mailbox is empty and this bit is cleared by hardware<br>1: Software writes 1, to enable request to transmit mailbox data |
| 1     | TXRFREQ     | R/W | Transmit Remote Frame Request<br>0: Data frame<br>1: Remote frame                                                                                                                                             |
| 2     | IDTYPESEL   | R/W | Identifier Type Select<br>0: Standard identifier<br>1: Extended identifier                                                                                                                                    |
| 20:3  | EXTID[17:0] | R/W | Extended Identifier Setup<br>Low byte of extended identity label.                                                                                                                                             |

| Field | Name                     | R/W | Description                                                                                                                                                                                |
|-------|--------------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:21 | STDID[10:0]/EXTID[28:18] | R/W | Standard Identifier Or Extended Identifier<br>According to the content of IDTYPESEL bit, these bits are standard identifier STDID[10:0] and high byte EXTID[28:18] of extended identifier. |

Note: 1. When its mailbox is in the state of waiting for transmission, this register is write-protection

2. This register realizes transmission request control function (No. 0 bit) - the reset value is 0

### 23.6.2.2 Transmitting mailbox data length register (CAN\_TXDLENx) (x=0..2)

When the mailbox is not idle, all bits of this register are write-protected.

Offset address: 0x184, 0x194, 0x1A4

Reset value: 0XXXXX XXXX

| Field | Name   | R/W | Description                     |
|-------|--------|-----|---------------------------------|
| 3:0   | DLCODE | R/W | Transmit Data Length Code Setup |
| 31:4  |        |     | Reserved                        |

### 23.6.2.3 Transmitting mailbox low-byte data register (CAN\_TXMDLx) (x=0..2)

When the mailbox is not idle, all bits of this register are write-protected, and the message contains 0 to 7-byte data and starts from the byte 0.

Offset address: 0x188, 0x198, 0x1A8

Reset value: 0XXXXX XXXX

| Field | Name      | R/W | Description                |
|-------|-----------|-----|----------------------------|
| 7:0   | DATABYTE0 | R/W | Data Byte 0 of the Message |
| 15:8  | DATABYTE1 | R/W | Data Byte 1 of the Message |
| 23:16 | DATABYTE2 | R/W | Data Byte 2 of the Message |
| 31:24 | DATABYTE3 | R/W | Data Byte 3 of the Message |

### 23.6.2.4 Transmitting mailbox high-byte data register (CAN\_TXMDHx) (x=0..2)

When the mailbox is not idle, all bits of this register are write-protected.

Offset address: 0x18C, 0x19C, 0x1AC

Reset value: Undefined bit

| Field | Name      | R/W | Description                |
|-------|-----------|-----|----------------------------|
| 7:0   | DATABYTE4 | R/W | Data Byte 4 of the Message |
| 15:8  | DATABYTE5 | R/W | Data Byte 5 of the Message |
| 23:16 | DATABYTE6 | R/W | Data Byte 6 of the Message |
| 31:24 | DATABYTE7 | R/W | Data Byte 7 of the Message |

### 23.6.2.5 Receive FIFO mailbox identifier register (CAN\_RXMIDx) (x=0..1)

Offset address: 0x1B0, 0x1C0

Reset value: Undefined bit

| Field | Name    | R/W | Description                                                           |
|-------|---------|-----|-----------------------------------------------------------------------|
| 0     |         |     | Reserved                                                              |
| 1     | RFTXREQ | R   | Remote Frame Transmission Request<br>0: Data frame<br>1: Remote frame |

| Field | Name                     | R/W | Description                                                                                                                                                                                |
|-------|--------------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2     | IDTYPESEL                | R   | Identifier Type Select<br>0: Standard identifier<br>1: Extended identifier                                                                                                                 |
| 20:3  | EXTID[17:0]              | R   | Extended Identifier Setup<br>Low byte of extended identifier.                                                                                                                              |
| 31:21 | STDID[10:0]/EXTID[28:18] | R   | Standard Identifier Or Extended Identifier<br>According to the content of IDTYPESEL bit, these bits are standard identifier STDID[10:0] and high byte EXTID[28:18] of extended identifier. |

Note: All receiving mailbox registers are read-only.

### 23.6.2.6 Receive FIFO mailbox data length register (CAN\_RXDLENx) (x=0..1)

Offset address: 0x1B4, 0x1C4

Reset value: 0xXXXXXX XXXX

| Field | Name     | R/W | Description                                                                                                                   |
|-------|----------|-----|-------------------------------------------------------------------------------------------------------------------------------|
| 3:0   | DLCODE   | R   | Receive Data Length Code Setup<br>This bit represents the data length in the frame; for remote frame, DLCODE is constantly 0. |
| 7:4   | Reserved |     |                                                                                                                               |
| 15:8  | FMIDX    | R   | Filter Match Index Setup                                                                                                      |
| 31:16 | Reserved |     |                                                                                                                               |

Note: All receiving mailbox registers are read-only.

### 23.6.2.7 Receive FIFO mailbox low-byte data register (CAN\_RXMDLx) (x=0..1)

Offset address: 0x1B8, 0x1C8; the message contains 0 to 8-byte data, which starts from the byte 0.

Reset value: 0xXXXXXX XXXX

| Field | Name      | R/W | Description                |
|-------|-----------|-----|----------------------------|
| 7:0   | DATABYTE0 | R   | Data Byte 0 of the Message |
| 15:8  | DATABYTE1 | R   | Data Byte 1 of the Message |
| 23:16 | DATABYTE2 | R   | Data Byte 2 of the Message |
| 31:24 | DATABYTE3 | R   | Data Byte 3 of the Message |

Note: All receiving mailbox registers are read-only.

### 23.6.2.8 Receive FIFO mailbox high-byte data register (CAN\_RXMDHx) (x=0..1)

Offset address: 0x1BC, 0x1CC

Reset value: Undefined bit

| Field | Name      | R/W | Description                                             |
|-------|-----------|-----|---------------------------------------------------------|
| 7:0   | DATABYTE4 | R   | Data Byte 0 of the Message                              |
| 15:8  | DATABYTE5 | R   | Data byte 5 of the message (Data Byte 0 of the Message) |
| 23:16 | DATABYTE6 | R   | Data byte 6 of the message (Data Byte 0 of the Message) |

| Field | Name      | R/W | Description                                             |
|-------|-----------|-----|---------------------------------------------------------|
| 31:24 | DATABYTE7 | R   | Data byte 7 of the message (Data Byte 0 of the Message) |

Note: All receiving mailbox registers are read-only.

### 23.6.3 CAN filter register

#### 23.6.3.1 CAN filter control register (CAN\_FCTRL)

Offset address: 0x200

Reset value: 0x2A1C 0E01

| Field | Name    | R/W | Description                                                         |
|-------|---------|-----|---------------------------------------------------------------------|
| 0     | FINITEN | R/W | Filter Init Mode Enable<br>0: Normal mode<br>1: Initialization mode |
| 31:1  |         |     | Reserved                                                            |

Note: The non-reserved bit of this register is completely controlled by software.

#### 23.6.3.2 CAN filter mode configuration register (CAN\_FMCFG)

Offset address: 0x204

Reset value: 0x0000 0000

| Field | Name   | R/W | Description                                                                                                       |
|-------|--------|-----|-------------------------------------------------------------------------------------------------------------------|
| 13:0  | FMCFGx | R/W | Filter Mode Configure<br>The value of x is within 0-13.<br>0: Identifier mask bit mode<br>1: Identifier list mode |
| 31:14 |        |     | Reserved                                                                                                          |

Note: Only when CAN\_FCTRL (FINITEN =1) is set to make the filter in initialization mode, can this register be written.

#### 23.6.3.3 CAN filter bid width configuration register (CAN\_FSCFG)

Offset address: 0x20C

Reset value: 0x0000 0000

| Field | Name   | R/W | Description                                                                                      |
|-------|--------|-----|--------------------------------------------------------------------------------------------------|
| 13:0  | FSCFGx | R/W | Filterx Scale Configure<br>The value of x is within 0-13.<br>0: Two 16 bits<br>1: Single 32 bits |
| 31:14 |        |     | Reserved                                                                                         |

Note: Only when CAN\_FCTRL (FINITEN =1) is set to make the filter in initialization mode, can this register be written.

#### 23.6.3.4 CAN filter FIFO association register (CAN\_FFASS)

Offset address: 0x214

Reset value: 0x0000 0000

| Field | Name   | R/W | Description                                                                                                                |
|-------|--------|-----|----------------------------------------------------------------------------------------------------------------------------|
| 0     | FFASS0 | R/W | Configure Filter0 Associated with FIFO<br>0: The filter is associated with FIFO0<br>1: The filter is associated with FIFO1 |
| 1     | FFASS1 | R/W | Configure Filter1 Associated with FIFO<br>Refer to FFASS0 for specific description.                                        |

| Field | Name    | R/W | Description                                                                          |
|-------|---------|-----|--------------------------------------------------------------------------------------|
| 2     | FFASS2  | R/W | Configure Filter2 Associated with FIFO<br>Refer to FFASS0 for specific description.  |
| 3     | FFASS3  | R/W | Configure Filter3 Associated with FIFO<br>Refer to FFASS0 for specific description.  |
| 4     | FFASS4  | R/W | Configure Filter4 Associated with FIFO<br>Refer to FFASS0 for specific description.  |
| 5     | FFASS5  | R/W | Configure Filter5 Associated with FIFO<br>Refer to FFASS0 for specific description.  |
| 6     | FFASS6  | R/W | Configure Filter6 Associated with FIFO<br>Refer to FFASS0 for specific description.  |
| 7     | FFASS7  | R/W | Configure Filter7 Associated with FIFO<br>Refer to FFASS0 for specific description.  |
| 8     | FFASS8  | R/W | Configure Filter8 Associated with FIFO<br>Refer to FFASS0 for specific description.  |
| 9     | FFASS9  | R/W | Configure Filter9 Associated with FIFO<br>Refer to FFASS0 for specific description.  |
| 10    | FFASS10 | R/W | Configure Filter10 Associated with FIFO<br>Refer to FFASS0 for specific description. |
| 11    | FFASS11 | R/W | Configure Filter11 Associated with FIFO<br>Refer to FFASS0 for specific description. |
| 12    | FFASS12 | R/W | Configure Filter12 Associated with FIFO<br>Refer to FFASS0 for specific description. |
| 13    | FFASS13 | R/W | Configure Filter13 Associated with FIFO<br>Refer to FFASS0 for specific description. |
| 31:14 |         |     | Reserved                                                                             |

Note: Only when CAN\_FCTRL (FINITEN =1) is set to make the filter in initialization mode, can this register be written.

### 23.6.3.5 CAN filter activation register (CAN\_FACT)

Offset address: 0x21C

Reset value: 0x0000 0000

| Field | Name  | R/W | Description                                               |
|-------|-------|-----|-----------------------------------------------------------|
| 0     | FACT0 | R/W | Filter0 Active<br>0: Disable<br>1: Active                 |
| 1     | FACT1 | R/W | Filter1 Active<br>Refer to FACT0 for specific description |
| 2     | FACT2 | R/W | Filter3 Active<br>Refer to FACT0 for specific description |
| 3     | FACT3 | R/W | Filter3 Active<br>Refer to FACT0 for specific description |
| 4     | FACT4 | R/W | Filter4 Active<br>Refer to FACT0 for specific description |
| 5     | FACT5 | R/W | Filter5 Active<br>Refer to FACT0 for specific description |
| 6     | FACT6 | R/W | Filter6 Active<br>Refer to FACT0 for specific description |
| 7     | FACT7 | R/W | Filter7 Active<br>Refer to FACT0 for specific description |

| Field | Name   | R/W | Description                                                |
|-------|--------|-----|------------------------------------------------------------|
| 8     | FACT8  | R/W | Filter8 Active<br>Refer to FACT0 for specific description  |
| 9     | FACT9  | R/W | Filter9 Active<br>Refer to FACT0 for specific description  |
| 10    | FACT10 | R/W | Filter10 Active<br>Refer to FACT0 for specific description |
| 11    | FACT11 | R/W | Filter11 Active<br>Refer to FACT0 for specific description |
| 12    | FACT12 | R/W | Filter12 Active<br>Refer to FACT0 for specific description |
| 13    | FACT13 | R/W | Filter13 Active<br>Refer to FACT0 for specific description |
| 31:14 |        |     | Reserved                                                   |

### 23.6.3.6 Register x of CAN filter group x (CAN\_FiBANKx) (i = 0..13; x=1..2)

Offset address: 0x240..0x2AC

Reset value: 0xFFFF XXXX

| Field | Name       | R/W | Description                                                                                                                                                                                                                                                            |
|-------|------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0  | FBIT[31:0] | R/W | Filter Bits Setup<br>Identifier list mode:<br>0: FBITx bit is dominant bit<br>1: FBITx is recessive bit<br>Identifier mask bit mode:<br>0: FBITx is not used for comparison<br>1: FBITx must match<br>Note: The value of x is 0~31, indicating the bit number of FBIT. |

Note: There are 14 sets of filters in product: i=0..13. Each set of filters consists of two 32-bit registers and CAN\_FiBANK[2:1]. The corresponding filter registers can be modified only when the corresponding FACTx bit of CAN\_FACT register is cleared or the FINITEN bit of CAN\_FCTRL register is 1.

## 24 Full-speed USBD Interface Device (USBD)

### 24.1 Introduction

The peripheral meets the protocol standards and technical specifications of full-speed USB2.0 interface device, and realizes the interface docking between USBD bus and APB1 bus. At the same time, the peripheral also has the functions of configurable up to 8 endpoints, synchronous transmission and endpoint double buffering mechanism, CRC check, USBD suspension/restoration operation and frame lock clock pulse generation.

Note:

- (1) Since APM32F103x4x6 and APM32F103x8 D version only have the CAN1, USBD1 and CAN1 share a dedicated 512-byte SRAM memory for data sending and receiving, and USBD2 and CAN1 each have a dedicated 512-byte SRAM memory for data sending and receiving. Therefore, USBD1 and CAN1 cannot be used at the same time, but USBD2 and CAN1 can be used at the same time, and then CAN1 needs remap.
- (2) Since APM32F103x8xB E version has two CANs, CAN1 and UABD2 can be used as the same time, and CAN2 and USBD1 can be used at the same time.

### 24.2 Functional Description

USBD module realizes the communication interface function between the MCU and the PC which conform to USB2.0 interface protocol. In the process of realizing this function, a shared private data buffer directly accessible to USBD peripheral is used. The size of this data buffer is determined by the number of configured endpoints and the maximum data packet size of different endpoints. Up to 8 bidirectional or 16 one-way endpoints can be used. Each endpoint can use 512 bytes at most. The format of data frame for USBD and PC communication is completed by hardware.

Different endpoints need to have an independent buffer description block, which is used to describe the buffer address, size and byte length of the transmitted data of the endpoint. By responding to the USBD interrupt, and judging the setting of the endpoint state register in the interrupt, the chip core enters different interrupt processing sub-functions, to process the services that the endpoint needs, and transmit corresponding types of data.

### 24.3 Register Address Mapping

Table 87 USBD Register Address Mapping

| Register name       | Description                                           | Offset address    |
|---------------------|-------------------------------------------------------|-------------------|
| USBD_CTRL           | USBD control register                                 | 0x40              |
| USBD_INTSTS         | USBD interrupt state register                         | 0x44              |
| USBD_FRANUM         | USBD frame state register                             | 0x48              |
| USBD_ADDR           | USBD device address register                          | 0x4C              |
| USBD_BUFFTB         | USBD packet buffer description table address register | 0x50              |
| USBD_SWITCH         | USBD switch register                                  | 0x100             |
| USBD_EPn(n=[0...7]) | USBD endpoint n register                              | From 0x00 to 0x1C |

| Register name | Description                         | Offset address        |
|---------------|-------------------------------------|-----------------------|
| USBD_TXADDRn  | Send buffer address register n      | [USBD_BUFFTB]+n×16    |
| USBD_TXCNTn   | Send data byte number register n    | [USBD_BUFFTB]+n×16+4  |
| USBD_RXADDRn  | Receive buffer address register n   | [USBD_BUFFTB]+n×16+8  |
| USBD_RXCNTn   | Receive data byte number register n | [USBD_BUFFTB]+n×16+12 |

## 24.4 Register Functional Description

The registers of USBD module have the following three categories:

- (1) General-purpose register: Interrupt register and control register;
- (2) Endpoint register: Endpoint configuration register and state register;
- (3) Buffer description table register: Register used to determine the packet storage address.

The base address of the buffer description table registers is specified by USBD\_BUFFTB register, and the base address of all other registers is the base address 0x4000 5C00 of USBD module. Since the APB1 bus is 32-bit addressable, the addresses of all 16-bit registers are aligned according to 32-bit word. The same address alignment method is also used for the packet buffer memory areas starting from 0x4000 6000.

### 24.4.1 General-purpose Register

It is used to define the working mode of USBD module, interrupt processing, device address and reading of current frame number.

#### 24.4.1.1 USBD control register (USBD\_CTRL)

Offset address: 0x40

Reset value: 0x0003

| Field | Name    | R/W | Description                                                                                                                                                                                                                                                                                                                                          |
|-------|---------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | FORRST  | R/W | Force USBD Reset<br>Reset USBD by force, and before it is cleared by software, USBS always remains in reset state.<br>0: Clear<br>1: Reset by force                                                                                                                                                                                                  |
| 1     | PWRDOWN | R/W | Power Down<br>This mode is used to thoroughly close the USBD module. When this bit is set to 1, the USBD module cannot be used.<br>0: Open<br>1: Closed                                                                                                                                                                                              |
| 2     | LPWREN  | R/W | Lowpower Mode Enable<br>After this mode is turned on, when USBD is suspended, the system clock will stop or decrease to a certain frequency, and other static power consumption will be turned off except for the power supply of external pull-up resistor.<br>Any wake-up event of USBD can clear this bit.<br>0: Normal mode<br>1: Low-power mode |

| Field | Name     | R/W | Description                                                                                                                                                                                      |
|-------|----------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3     | FORSUS   | R/W | Force Suspend<br>When there is no data communication on USBD bus for 3ms, SUSP interrupt will be triggered, then the software needs to set this bit to 1.<br>0: Invalid<br>1: Pend USBD by force |
| 4     | WUPREQ   | R/W | Wakeup Request<br>Send the wake-up request to PC master. If this bit remains valid within 1ms to 15ms, the master will wake up the USBD.<br>0: Invalid<br>1: Valid                               |
| 7:5   | Reserved |     |                                                                                                                                                                                                  |
| 8     | ESOFIEN  | R/W | Expected Start of Frame Interrupt Enable<br>0: Disable<br>1: Enable                                                                                                                              |
| 9     | SOFIEN   | R/W | Start of Frame Interrupt Enable<br>0: Disable<br>1: Enable                                                                                                                                       |
| 10    | RSTIEN   | R/W | USBD Reset Interrupt Enable<br>0: Disable<br>1: Enable                                                                                                                                           |
| 11    | SUSIEN   | R/W | Suspend Mode Interrupt Enable<br>0: Disable<br>1: Enable                                                                                                                                         |
| 12    | WUPIEN   | R/W | Wakeup interrupt Enable<br>0: Disable<br>1: Enable                                                                                                                                               |
| 13    | ERRIEN   | R/W | Error interrupt Enable<br>0: Disable<br>1: Enable                                                                                                                                                |
| 14    | PMAOUIEN | R/W | Packet Memory Area Over / Underrun Interrupt Enable<br>0: Disable<br>1: Enable                                                                                                                   |
| 15    | CTRIEN   | R/W | Correct Transfer Interrupt Enable<br>0: Disable<br>1: Enable                                                                                                                                     |

#### 24.4.1.2 USBD interrupt state register (USBD\_INTSTS)

Offset address: 0x44

Reset value: 0x0000

The application program confirms the interrupt request event by reading the interrupt source state information of this register.

When an interrupt event occurs, the corresponding bit will be set by the hardware. If the corresponding bit in USBD\_CTRL is also set, an interrupt will be generated. After the interrupt is executed, the corresponding state bit will be cleared. It should be noted that when multiple interrupt flags are set, only one interrupt is generated.

USBD module has two-way interrupt request sources: high priority and low priority. The former interrupt request cannot be masked, while the latter can be masked. After identifying which endpoint the interrupt request is from, call the corresponding interrupt service program.

Each bit is described in detail below:

| Field | Name      | R/W   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------|-----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0   | EPID[3:0] | R     | <p>Endpoint Identifier</p> <p>The application program reads the processing sequence of interrupt request through software. The processing sequence is determined by the endpoint number (the smaller the endpoint number is, the higher the priority is). The priority is written by hardware.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 4     | DOT       | R     | <p>Transmission direction (Direction of Transaction)</p> <p>The application program reads this bit through the software to learn the transmission direction of the pending interrupt, so as to access the corresponding operation of CTFT or CTFR bit in USBD_EPn, and this bit is written by hardware according to the transmission direction.</p> <p>The IN packet means that the data are transmitted from the USBD module to the PC master, while the OUT packet is the opposite. When the packet is pending, it means the data transmission is completed.</p> <p>0: The CTFT bit of the corresponding endpoint is set, which means that an IN packet is pending.</p> <p>1: The CTFR bit of the corresponding endpoint is set, which means that an OUT packet is pending. If the CTFT bit is set at the same time, it means that both OUT packet and IN packet are pending at the same time.</p> |
| 7:5   | Reserved  |       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 8     | ESOFLG    | RC_W0 | <p>Expected start of frame flag (Expected Start of Frame Flag)</p> <p>When the USBD module does not receive the expected SOF packet, it is set by hardware.</p> <p>0: Clear</p> <p>1: Failed to receive the expected SOF packet</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 9     | SOFLG     | RC_W0 | <p>Start of frame flag (Start Of Frame Flag)</p> <p>It indicates the start of a new USBD frame, and when the USBD module detects the SOF packet on the bus, it will be set by hardware.</p> <p>0: Clear</p> <p>1: SOF packet is detected</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 10    | RSTREQ    | RC_W0 | <p>Reset request (USBD Reset Request)</p> <p>The application program is readable and writable, only valid when writing 0, and set by hardware.</p> <p>0: Clear</p> <p>1: Reset signal is detected</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 11    | SUSREQ    | RC_W0 | <p>Module pending request (Suspend Mode Request)</p> <p>It indicates a pending request from the USBD bus, which is set by hardware when there is no signal transmission on the USBD line for more than 3ms.</p> <p>0: Clear</p> <p>1: Pending interrupt occurred</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 12    | WUPREQ    | RC_W0 | <p>Wake-up request (Wakeup Request)</p> <p>If the USBD module is pending and detects a wake-up signal, it will be set by hardware.</p> <p>0: Clear</p> <p>1: Wake-up signal is detected</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 13    | ERRFLG    | RC_W0 | <p>Transmission error interrupt (Failure Of Transfer Flag)</p> <p>When NANS (master answer timeout)/CRC/BST (bit stuffing error)/FVIO (frame format error) occurs, it is set by hardware.</p> <p>0: Clear</p> <p>1: Transmission error occurred</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| Field | Name   | R/W   | Description                                                                                                                                                                                                                                      |
|-------|--------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14    | PMOFLG | RC_W0 | Packet buffer overrun flag (Packet Memory Overflow Flag)<br>When the request to access the USBD packet buffer is sent but the MCU does not respond for a long time, it will be set by hardware.<br>0: Clear<br>1: Packet buffer overrun occurred |
| 15    | CTFLG  | R     | Correct transfer flag (Correct Transfer Flag)<br>This bit is set by hardware after the endpoint completes data transmission once correctly.<br>0: Meaningless<br>1: Data transmission is completed correctly                                     |

#### 24.4.1.3 USBD frame state register (USBD\_FRANUM)

Offset address: 0x48

Reset value: 0x0XXX; X means undefined value

| Field | Name         | R/W | Description                                                                                                                                                                                   |
|-------|--------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10:0  | FRANUM[10:0] | R   | Frame Sequence Number<br>Record the 11-bit frame code of the latest SOF packet, and the serial number will automatically increase as the quantity of transmit frames of the master increases. |
| 12:11 | LSOFNUM[1:0] | R   | Continuous Lost SOF Number<br>Record the number of SOF packets lost in the start of consecutive frame, and this bit is cleared when the SOF packet is received again.                         |
| 13    | LOCK         | R   | Lock<br>If USBD continuously detects two or more SOP packets, it will be set by hardware, then the frame counter will stop counting until the USBD is reset or the bus is pending.            |
| 14    | RXDMSTS      | R   | Receive Data-Line Status<br>It indicates the state of USBD D- (Data minus) data line, and can detect whether the wake-up condition appears in pending state.                                  |
| 15    | RXDPSSTS     | R   | Receive Data+ Line Status<br>It indicates the state of USBD D+ (Data plus) data line, and can detect whether the wake-up condition appears in pending state.                                  |

#### 24.4.1.4 USBD device address register (USBD\_ADDR)

Offset address: 0x4C

Reset value: 0x0000

| Field | Name      | R/W | Description                                                                                                      |
|-------|-----------|-----|------------------------------------------------------------------------------------------------------------------|
| 6:0   | ADDR[6:0] | R/W | Device Address<br>Record the address value assigned by USBD master for the device in the process of enumeration. |
| 7     | USBDEN    | R/W | USBD Enable<br>Enable USBD.<br>0: Disable<br>1: Enable                                                           |
| 15:8  |           |     | Reserved                                                                                                         |

#### 24.4.1.5 USBD packet buffer description table address register (USBD\_BUFFTB)

Offset address: 0x50

Reset value: 0x0000 0000

| Field | Name | R/W | Description |
|-------|------|-----|-------------|
| 2:0   |      |     | Reserved    |

| Field | Name   | R/W | Description                                                                      |
|-------|--------|-----|----------------------------------------------------------------------------------|
| 15:3  | BUFFTB | R/W | Buffer Table<br>Record the start address of the packet buffer description table. |
| 31:16 |        |     | Reserved                                                                         |

#### 24.4.1.6 USBD switch register (USBD\_SWITCH)

Offset address: 0x100

Reset value: 0x0000

| Field | Name      | R/W | Description                                                                                                                                                    |
|-------|-----------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | SWITCH[0] | R/W | USBD Switch<br>The default is 0.<br>0: USBD1 is used<br>1: USBD2 is used; then it can be used with CAN at the same time (Pins PA11 and PA12 are used by USBD). |
| 15:1  |           |     | Reserved                                                                                                                                                       |

#### 24.4.2 Endpoint Register

Each endpoint has corresponding USBD\_EPn (n=0...7) registers to store various state information of the endpoint.

##### 24.4.2.1 USBD endpoint n register (USBD\_EPn) (n=0 to 7)

Offset address: 0x00 to 0x1C

Reset value: 0x0000

When the endpoint register receives USBD bus reset or the FORRST of USBD\_CTRL is set, except that CTFT and CTFR bits remain unchanged for data transmission, other bits will be reset.

Each bit is described in detail below:

| Field | Name       | R/W   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0   | ADDR[3:0]  | R/W   | Endpoint Address<br>Before an endpoint is enabled, the application program must set these four bits as an address.                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 5:4   | TXSTS[1:0] | T     | Status Bits for Transmission Transfers<br>This bit is used to identify the current state of the endpoint, and the sending state code table indicates all states. The application program is readable and writable; write 0 and this bit is invalid; write 1 to flip this bit.                                                                                                                                                                                                                                                                                         |
| 6     | TXDTOG     | T     | Data Toggle for Transmission Transfers<br>(1) For asynchronous endpoints, it is used to indicate the Toggle bit of the next data packet to be transmitted:<br>0: DATA0<br>1: DATA1<br>(2) For double-buffer endpoints, it can be used for packet buffer exchange.<br>(3) For synchronous endpoints, as only DATA0 is transmitted, this bit is only used to support packet buffer exchange. The hardware sets the bit after receiving the data packet.<br>The application program is readable and writable; write 0 and this bit is invalid; write 1 to flip this bit. |
| 7     | CTFT       | RC_W0 | Correct Transfer Flag for Transmission<br>This bit is set by hardware after a correct IN packet is transmitted.<br>0: Clear this bit and it is meaningless to read out                                                                                                                                                                                                                                                                                                                                                                                                |

| Field | Name   | R/W   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|--------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |        |       | 1: IN packet is transmitted correctly. Writing is invalid<br>The application program is readable and writable; write 0 and this bit is valid; write 1 and this bit is invalid.                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 8     | KIND   | R/W   | Endpoint Kind<br>Please refer to the definition table of special types of endpoints for specific definitions.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 10:9  | TYPE   | R/W   | Endpoint Type<br>Please refer to the definition table of endpoint types for specific definitions.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 11    | SETUP  | R     | Setup Transaction Completed<br>It indicates whether the packet that currently completes transmission is SETUP packet. After the USBD module receives a correct SETUP packet, it is set by hardware.<br>0: No<br>1: Yes<br>Note: This bit can be modified only when CTFR is 0, and cannot be modified when CTFR is 1.                                                                                                                                                                                                                                                                                        |
| 13:12 | RXSTS  | T     | Status Bits for Reception Transfers<br>This bit is used to identify the current state of the endpoint, and the receiving state code table indicates all states. The application program is readable and writable; write 0 and this bit is invalid; write 1 to flip this bit.                                                                                                                                                                                                                                                                                                                                |
| 14    | RXDTOG | T     | Data Toggle for Reception Transfers<br>(1) For asynchronous endpoints, flag the Toggle bit of the next data packet that is expected to be received, and it is set by hardware:<br>0: DATA0<br>1: DATA1<br>(2) For control endpoint, after receiving the SETUP packet, it is cleared by hardware.<br>(3) For double-buffer endpoints, it is used for the exchange of double buffers.<br>(4) For synchronous endpoints, it is only used for the exchange of double buffers, without flipping.<br>The application program is readable and writable; write 0 and this bit is invalid; write 1 to flip this bit. |
| 15    | CTFR   | RC_W0 | Correct receiving flag bit (Correct Transfer Flag for Reception)<br>This bit is set by hardware after OUT or SETUP packet is received correctly.<br>0: Clear<br>1: Packet is received correctly<br>The application program is readable and writable; write 0 and this bit is valid; write 1 and this bit is invalid.                                                                                                                                                                                                                                                                                        |

Table 88 Receive State Codes

| RXSTS[1:0] | Description                                                             |
|------------|-------------------------------------------------------------------------|
| 00         | DISABLED: All receiving requests are ignored by the endpoint.           |
| 01         | STALL: The endpoint responds to all receive requests with STALL packet. |
| 10         | NAK: The endpoint responds to all receive requests with NAK packet.     |
| 11         | VALID: The endpoint can be used for receiving.                          |

Table 89 Endpoint Type Codes

| TYPE[1:0] | Description                   |
|-----------|-------------------------------|
| 00        | BULK: Bulk endpoint           |
| 01        | CONTROL: Control endpoint     |
| 10        | ISO: Synchronous endpoint     |
| 11        | INTERRUPT: Interrupt endpoint |

Table 90 Definition of Special Types of Endpoints

| The value of TYPE | Meaning of KIND                 |
|-------------------|---------------------------------|
| 00 (BULK)         | DBL_BUF: Double-buffer endpoint |
| 01 (CONTROL)      | STATUS_OUT                      |
| Other             | Unused                          |

Table 91 Transmit State Codes

| TXSTS | Description                                                          |
|-------|----------------------------------------------------------------------|
| 00    | DISABLED: All sending requests are ignored by the endpoint.          |
| 01    | STALL: The endpoint responds to all send requests with STALL packet. |
| 10    | NAK: The endpoint responds to all send requests with NAK packet.     |
| 11    | VALID: The endpoint can be used for sending.                         |

#### 24.4.3 Buffer Register

The buffer description table is located in the packet buffer to configure the address and size of the packet buffer shared by the USBD module and the MCU core.

##### 24.4.3.1 Transmit buffer address register n (USBD\_TXADDRn) (n=0 to 7)

Offset address: [USBD\_BUFFTB]+n×16

Local address of USBD: [USBD\_BUFFTB]+n×8

| Field | Name | R/W | Description                                                                                                                                        |
|-------|------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     |      |     | Reserved                                                                                                                                           |
| 15:1  | ADDR | R/W | Transmission Buffer Address<br>Record the starting address of the buffer where the data to be sent is located when the next IN packet is received. |

##### 24.4.3.2 Sending data byte number register n (USBD\_TXCNTn) (n=0 to 7)

Offset address: [USBD\_BUFFTB]+n×16+4

Local address of USBD: [USBD\_BUFFTB]+n×8+2

| Field | Name | R/W | Description                                                                                                     |
|-------|------|-----|-----------------------------------------------------------------------------------------------------------------|
| 9:0   | CNT  | R/W | Transmission Byte Count<br>This bit records the data byte count to be transmitted when receiving next IN group. |
| 15:10 |      |     | Reserved                                                                                                        |

Note: The double buffer and synchronous IN endpoint have two USBD\_TXCNT registers: USBD\_TXCNT\_1 and USBD\_TXCNT\_0, and the content is as follows:

| Field | Name     | R/W | Description                                                                                            |
|-------|----------|-----|--------------------------------------------------------------------------------------------------------|
| 9:0   | CNT_0    | R/W | Transmission Byte Count0<br>Record the data byte count to be transmitted when receiving next IN group. |
| 15:10 | Reserved |     |                                                                                                        |
| 25:16 | CNT_1    | R/W | Transmission Byte Count1<br>Record the data byte count to be transmitted when receiving next IN group. |
| 31:26 | Reserved |     |                                                                                                        |

#### 24.4.3.3 Receive buffer address register n (USBD\_RXADDRn) (n=0 to 7)

Offset address: [USBD\_BUFFTB]+n×16+8

Local address of USBD: [USBD\_BUFFTB]+n×8+4

| Field | Name     | R/W | Description                                                                                                                          |
|-------|----------|-----|--------------------------------------------------------------------------------------------------------------------------------------|
| 0     | Reserved |     |                                                                                                                                      |
| 15:1  | ADDR     | R/W | Reception Buffer Address<br>Record the starting address of the buffer used to save data when receiving the next OUT or SETUP packet. |

#### 24.4.3.4 Receive data byte register n (USBD\_RXCNTn) (n=0 to 7)

Offset address: [USBD\_BUFFTB]+n×16+12

Local address of USBD: [USBD\_BUFFTB]+n×8+6

It is used to store two parameters that need to be used when receiving packets:  
the buffer size of receiving packets and the number of bytes actually received by USBD.

| Field | Name    | R/W | Description                                                                                                                                                                      |
|-------|---------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9:0   | CNT     | R   | Received byte number (Reception Byte Count)<br>It is written by the USBD module to record the actual number of bytes of the latest OUT or SETUP packet received by the endpoint. |
| 14:10 | BLKNUM  | R/W | Number of memory blocks (Number of Blocks)<br>Record the number of memory blocks allocated, which determines the size of the packet buffer.                                      |
| 15    | BLKSIZE | R/W | Memory block size (Block Size)<br>Determine the size of memory block, which determines the buffer size.<br>0: Two bytes<br>1: 32 bytes                                           |

Note: The double buffer and synchronous IN endpoint have two USBD\_RXCNT registers: USBD\_RXCNT\_1 and USBD\_RXCNT\_0, and the content is as follows:

| Field | Name       | R/W | Description                                                                                                                                 |
|-------|------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------|
| 9:0   | CNT_0[9:0] | R   | Received byte number (Reception Byte Count)<br>Record the actual number of bytes of the latest OUT or SETUP group received by the endpoint. |
| 14:10 | BLKNUM_0   | R/W | Number of memory blocks (Number of Blocks)<br>Record the number of memory blocks allocated, which determines the size of the packet buffer. |
| 15    | BLKSIZE_0  | R/W | Memory block size (Block Size)<br>Determine the size of memory block.<br>0: Two bytes<br>1: 32 bytes                                        |

| Field | Name      | R/W | Description                                                                                                                                 |
|-------|-----------|-----|---------------------------------------------------------------------------------------------------------------------------------------------|
| 25:16 | CNT_1     | R   | Received byte number (Reception Byte Count)<br>Record the actual number of bytes of the latest OUT or SETUP group received by the endpoint. |
| 30:26 | BLKNUM_1  | R/W | Number of memory blocks (Number of Blocks)<br>Record the number of memory blocks allocated.                                                 |
| 31    | BLKSIZE_1 | R/W | Memory block size (Block Size)<br>Determine the size of memory block.<br>0: Two bytes<br>1: 32 bytes                                        |

Table 92 Definition of Packet Buffer Sizes

| Value of BLKNUM[4:0] | Packet buffer size when BLKSIZE=0 | Size of packet buffer when BLKSIZE=1 |
|----------------------|-----------------------------------|--------------------------------------|
| 00000                | Not allowed to use                | 32byte                               |
| 00001                | 2 bytes                           | 64 bytes                             |
| 00010                | 4 bytes                           | 96 bytes                             |
| 00011                | 6 bytes                           | 128 bytes                            |
| ...                  | ...                               | ...                                  |
| 01111                | 30 bytes                          | 512 bytes                            |
| 10000                | 32byte                            | Reserved                             |
| 10001                | 34 bytes                          | Reserved                             |
| 10010                | 36 bytes                          | Reserved                             |
| ...                  | ...                               | ...                                  |
| 11110                | 60 bytes                          | Reserved                             |
| 11111                | 62 bytes                          | Reserved                             |

## 25 Analog-to-digital Converter (ADC)

### 25.1 Full Name and Abbreviation Description of Terms

Table 93 Full Name and Abbreviation Description of Terms

| Full name in English | English abbreviation |
|----------------------|----------------------|
| Analog watchdog      | AWD                  |
| Conversion           | C                    |
| Injected             | INJ                  |
| Regular              | REG                  |
| Start                | S                    |
| Scan                 | SCAN                 |
| Single               | SINGLE               |
| Automatic            | A                    |
| Group                | G                    |
| Discontinuous        | DISC                 |
| Count                | CNT                  |
| Dual                 | DUAL                 |
| Continuous           | C                    |
| Calibration          | CAL                  |
| Reset                | RST                  |
| Alignment            | ALIGN                |
| External             | EXT                  |
| Event                | E                    |
| Trigger              | TRG                  |
| Temperature          | T                    |
| Sensor               | S                    |
| Time                 | TIM                  |
| Sample               | SMP                  |
| Offset               | OF                   |
| High                 | H                    |
| Low                  | L                    |
| Threshold            | T                    |
| Sequence             | SEQ                  |

| Full name in English  | English abbreviation |
|-----------------------|----------------------|
| Length                | LEN                  |
| Regular Channels      | REG                  |
| Injected Channel      | INJ                  |
| Injected Group        | INJG                 |
| Automatic             | A                    |
| Conversion            | C                    |
| Analog Watchdog       | AWD                  |
| Discontinuous Mode    | DISC                 |
| Scan Mode             | SCAN                 |
| Continuous Conversion | CONT C               |
| Single Conversion     | SINGLE C             |
| External              | EXT                  |
| External Trigger      | EXTTRG               |
| Sample Time           | SMPTIM               |
| Sequence              | SEQ                  |
| Number                | NUM                  |

## 25.2 Introduction

Series products have two ADCs with 12-bit accuracy, and each ADC has up to 16 external channels and 2 internal channels. ADC1 and ADC2 have 16 external channels respectively, the A/D conversion mode of each channel has single, continuous, scan or discontinuous modes, and the ADC conversion results can be stored in 16-bit data register by left alignment or right alignment.

## 25.3 Main Characteristics

- (1) ADC power supply requirements: From 2.4V to 3.6V; the general power supply voltage is 3.3V.
- (2) ADC input range:  $V_{REF-} \leq V_{IN} \leq V_{REF+}$ .
- (3) 12-bit resolution
- (4) ADC conversion time
  - Formula:  $T_{CONV} = \text{sampling time} + 12.5 \text{ cycles}$
  - The sampling time is controlled by  $\text{SMPCYCCFGx}[2:0]$  bit, and the minimum sampling cycle is 1.5; when  $\text{ADCCLK}=14\text{MHz}$ , the sampling time is 1.5 cycles:  $T_{CONV}=1.5 \text{ cycles} + 12.5 \text{ cycles}=14 \text{ cycles}=1 \mu\text{s}$ .
- (5) Mode input channel category
  - External GPIO input channel
  - One internal temperature sensor (VSENSE) input channel

- One internal reference voltage (VREFINT) input channel
- (6) Channel conversion mode
  - Single channel conversion mode: single conversion mode, continuous conversion mode
  - Input channel classification: regular channel, injected channel
  - One-group channel conversion mode: scan mode, discontinuous mode and injected channel management
  - ADC mode: Independent ADC mode, and dual ADC mode
- (7) Trigger mode
  - On-chip timer signal trigger
  - External pin signal trigger
  - Software trigger
- (8) Data register
  - Regular data register
  - Injected data register
- (9) Interrupt
  - End of conversion interrupt
  - Analog watchdog interrupt
- (10) DMA request supporting regular data conversion
- (11) Data alignment
  - Configurable data alignment of DALIGNCFG bit of data register ADC\_CTRL2 is left or right alignment.
- (12) Self-calibration
  - Enable calibration by setting CAL bit of ADC\_CTRL2 register. CAL bit is set to 1 during calibration and is cleared by hardware after calibration; calibration shall be performed every time before power-on.

## 25.4 Functional Description

### 25.4.1 ADC Pins

Table 94 ADC Pins

| Name                            | Instruction                                                                                             | Signal type                                |
|---------------------------------|---------------------------------------------------------------------------------------------------------|--------------------------------------------|
| V <sub>REF+</sub>               | High-end/Positive electrode reference voltage used by ADC, 2.4V≤V <sub>REF+</sub> ≤V <sub>DDA</sub>     | Input, analog reference positive electrode |
| V <sub>DDA</sub> <sup>(1)</sup> | Equivalent to analog power supply of V <sub>DD</sub> and: 2.4V≤V <sub>DDA</sub> ≤V <sub>DD</sub> (3.6V) | Input, analog power supply                 |
| V <sub>REF-</sub>               | Low-end/Negative electrode reference voltage used by ADC, V <sub>REF-</sub> = V <sub>SSA</sub>          | Input, analog reference negative electrode |
| V <sub>SSA</sub> <sup>(1)</sup> | Equivalent to analog power supply of V <sub>ss</sub>                                                    | Input, analog power ground                 |
| ADCx_IN[15:0]                   | 16 analog input channels                                                                                | Analog input signal                        |

Note: 1. V<sub>DDA</sub> and V<sub>SSA</sub> should be connected to V<sub>DD</sub> and V<sub>ss</sub> respectively.

### 25.4.2 ADC Conversion Mode

The product has multiple built-in ADCs and channels (refer to the data manual for the specific number), which can be combined into a variety of conversion

modes.

Multiple built-in ADCs; according to the number of ADCs, the conversion mode can be classified into independent ADC mode and dual ADC mode; multiple built-in channels, which can be classified into two groups, namely regular channel and injected channel. The internal conversion mode of each group can be divided into scan mode and discontinuous mode; for the internal channels of each group, the conversion mode is divided into single conversion mode and continuous conversion mode.

In the application, according to the actual application requirements, the number of ADC, the number of conversion channels and the conversion mode of each channel, the ADC conversion mode meeting the requirements can be designed.

#### 25.4.2.1 Conversion mode of single ADC and single channel

##### Single ADC channel

Single ADC and single channel are not enabled by external trigger software. The conversion mode is single and continuous concurrent disabling of scan. The result of data conversion is right alignment. After the single ADC conversion is completed, the interrupt is triggered, and data is read in the interrupt service function, not using DMA transmission.

##### Single conversion mode

In this mode, for single channel, only one conversion is performed for this channel, and for multiple channels, only one conversion is performed for this group of channels .

This mode is started by the ADCEN bit of configuration register ADC\_CTRL2 or is started by external trigger.

After one conversion of regular channel is over, the converted data will be stored in 16-bit ADC\_REGDATA register, and EOCFLG bit will be set to 1. If configuration EOCIEN bit is set to 1, an interrupt will be generated.

After one conversion of injected channel is over, the converted data will be stored in 16-bit ADC\_INJDATA1 register, and INJEOCFLG bit will be set to 1. If configuration INJEOCIEN bit is set to 1, an interrupt will be generated.

Figure 110 Single Conversion Mode Timing Diagram



##### Continuous conversion mode

In this mode, for single channel, continuous conversion is conducted for this channel.

This mode is started by the ADCEN bit of configuration register ADC\_CTRL2 or is started by external trigger.

After the conversion of one regular channel is over, the converted data will be stored in 16-bit ADC\_REGDATA register, and EOCFLG bit will be set to 1. If configuration EOCIEN bit is set to 1, an interrupt will be generated.

After the conversion of one injected channel is over, the converted data will be stored in 16-bit ADC\_INJDATA1 register, and INJEOCFLG bit will be set to 1. If configuration INJEICIEN bit is set to 1, an interrupt will be generated.

Figure 111 Continuous Conversion Mode Timing Diagram



#### 25.4.2.2 Conversion mode of single ADC and one group of channels

##### Single ADC and multiple channels

Enable the scan mode under single-ADC multi-channel condition, the conversion is triggered by software rather than externally, the result of data conversion is right aligned, and the data of ADC conversion results are transmitted to the memory by DMA.

##### Classification of analog input channels

###### Regular channel group

- The regular group consists of 16 channels
- Regular channel conversion sequence is determined by the register ADC\_REGSEQx
- The total number of conversion channels of regular group is determined by REGSEQLEN[3:0] bit of configuration register ADC\_REGSEQ1

###### Injected channel group

- The injected group consists of 4 channels
- Injected channel conversion sequence is determined by the register ADC\_INJSEQ
- The total number of conversion channels of injected group is determined by INJSEQLEN[1:0] bit of configuration register ADC\_INJSEQ

###### Internal input channel

Temperature sensor:

- The temperature sensor is used to measure the internal temperature of the chip
- The temperature sensor selects ADC\_IN16 input channel
- Start through TSVREFEN bit of the configuration register ADC\_CTRL2

- Select sampling time

The temperature sensor is used to measure the contact temperature of the product. The sensor transmits the voltage value by ADC\_IN16 to ADC, and then the voltage value will be converted to a value by ADC.

## Configuration

- Enable ADC, select input channel
- Select sampling time (recommend 17.1us)
- Temperature sensor can be enabled by configuring the TSVREFEN bit in the ADC\_CTRL2 register
- Start conversion by configuring the ADCEN bit in the ADC\_CTRL2 register
- The conversion result can be read by accessed the ADC\_INJDATA register or ADC\_REGDATA register
- Convert the result to temperature T though the formula as:

$$T(\text{°C}) = 25 + \frac{V_{25} - V_{\text{sensor}}}{\text{Slope}}$$

Note:

- (1) V25: The value of Vsensor at 25°C, see the Datasheet for more details.
- (2) Slope: Average slope value of Vsensor and temperature (Unit: mV/°C), see the Datasheet for more details.
- (3) When configuring the start up time, the ADCEN bit and TSEN bit need to be configured at the same time.

Internal reference voltage  $V_{\text{REFINT}}$ :

- The internal reference voltage is used to provide a stable voltage output for ADC
- Internal reference voltage  $V_{\text{REFINT}}$  is used to select ADC\_IN17 input channel

## Channel conversion sequence

### Configuration of regular sequence registers:

- Configure REGSEQC1[4:0]~REGSEQC6[4:0] bits of the register ADC\_REGSEQ3 to set No. 1~6 conversion channels
- Configure REGSEQC7[4:0]~REGSEQC12[4:0] bits of the register ADC\_REGSEQ3 to set No. 7~12 conversion channels
- Configure REGSEQC13[4:0]~REGSEQC16[4:0] bits of the register ADC\_REGSEQ1 to set No. 13~16 conversion channels
- Configure REGSEQLEN[3:0] of the register ADC\_REGSEQ1 to set the number of channels for conversion

### Configuration of injected sequence register:

- Configure NJSEQC1[4:0]~INJSEQC4[4:0] bit of the register ADC\_INJSEQ to set No. 1~4 conversion channels
- Configure INJSEQLEN[1:0] of the register ADC\_INJSEQ to set the number of channels for conversion
- If the value of INJSEQLEN is less than 4, the conversion sequence will be different and start from (4-INJSEQLEN).

## Channel conversion mode

### Scan Mode

This mode is applicable to one group of channels, which is equivalent to a single conversion on each channel of one group of channels.

This mode is started by SCANEN bit of configuration register ADC\_CTRL1, and after startup, ADC scans all channels which are arranged according to the sequence register ADC\_REGSEQ or the ADC\_INJSEQ, and after each channel conversion is completed, it will be automatically converted to the next channel of the group.

If the configuration CONTCEN bit is set to 1, the conversion will continue from the first channel of the group when the last channel of the group completes conversion.

If the configuration DMAEN bit is set to 1, the DMA controller will transmit the converted data of regular channel to SRAM every time the channel conversion is completed.

Figure 112 Scan Mode Timing Diagram



### Discontinuous mode

This mode is suitable for a group of channels, which is equivalent to continuous conversion of multiple channels in a group of channels.

For regular groups, this mode is started by REGDISCEN bit of configuration register ADC\_CTRL1; after startup, conduct short sequence conversion of n channels ( $n \leq 8$ ), and n is determined by DISCNUMCFG[2:0] of configuration register ADC\_CTRL1; next round of conversion of n channels can be started through software control or external trigger source and when the conversion of all channels of this group is completed, EOCFLG bit will be set to 1.

For injected groups, this mode is enabled by INJDISCEN bit of configuration register ADC\_CTRL1; after startup, one channel will be converted according to the configuration sequence of the sequence register; conversion of next channels can be started by software control or external trigger source and when the conversion of all channels of this group is completed, EOCFLG bit and INJEOCFLG bit will be set to 1.

Figure 113 Discontinuous Mode Timing Diagram



### Injected channel management

**Trigger injection:** Start by clearing INJGACEN bit of the register ADC\_CTRL1 and configuring the SCANEN bit. If a software trigger or external trigger is generated during the conversion of regular group channels, the injected conversion will be triggered. At this time, the regular channel conversion will stop, the injected channel sequence will start conversion, and after the injected group channel conversion is completed, the regular group channel conversion will be recovered.

Figure 114 Trigger Injection Timing Diagram



**Automatic injection:** Start by INJGACEN bit of configuration register ADC\_CTRL1; after conversion of the regular group channels is completed, the injected group channels will start conversion automatically; in the automatic injection mode, external trigger of the injected group channels must be disabled; if the CONTCEN bit of the register ADC\_CTRL2 is also configured, all channels of regular group and injection group will convert continuously.

Figure 115 Automatic Injection Timing Diagram



#### 25.4.2.3 Conversion mode of dual-ADC and one group of channels

Two ADC module products use dual-ADC mode, ADC1 is the master ADC by default, while ADC2 is the slave ADC by default; dual-ADC mode is set by configuring DUALMCFG[2:0] bit of the ADC1\_CTRL1 register.

When the configuration is triggered by external event, it is required to set it to trigger only the master ADC, and then configure the slave ADC to be triggered by software. (External trigger of master and slave must occur at the same time)

**There are eight possible dual-ADC modes:**

##### (1) Simultaneous regular mode

The simultaneous regular mode means ADC1 and ADC2 convert a regular channel group at the same time. Two ADCs cannot convert one channel at the same time.

The external trigger event is determined by REGEXTTRGSEL[2:0] of the register ADC1\_CTRL2.

After ADC conversion, DMA transmission request will be generated, and converted data of ADC1 are stored in low 16 bits of the register ADC1\_REGDATA, while ADC2 converted data are stored in high 16 bits of the register ADC1\_REGDATA.

EOCFLG interrupt will be generated after all ADC regular channels are converted.

##### (2) Simultaneous injection mode

The simultaneous injection mode means ADC1 and ADC2 convert one injected channel group at the same time. Two ADCs cannot convert one channel at the same time.

The external trigger event is determined by INJGEXTTRGSEL[2:0] of the register ADC1\_CTRL2.

After ADC conversion is over, the converted data will be stroed in the register ADC\_INJDATAx.

INJE0CFLG interrupt will be generated after all ADC injected channels are converted.

##### (3) Fast cross mode

The fast cross mode means ADC1 and ADC2 collect a regular channel group alternately, with a short interval time.

The external trigger event is determined by REGEXTTRGSEL[2:0] of the

register ADC\_CTRL2; after the trigger is generated, ADC2 will be started, and ADC1 will be started after delay of seven ADC clock cycles.

The sampling time shall be less than seven ADC clock cycles.

#### (4) Slow cross mode

The slow cross mode means ADC1 and ADC2 collect a regular channel group alternately, with a long interval time.

The external trigger event is determined by REGEXTTRGSEL[2:0] of the register ADC\_CTRL2; after the trigger is generated, ADC2 will be started, and ADC1 will be started after delay of 14 ADC clock cycles.

The sampling time shall be less than 14 ADC clock cycles.

#### (5) Alternate trigger mode

The alternate trigger mode means ADC1 and ADC2 collect the injected channel group by turns.

The external trigger event is determined by INJGEXTTRGSEL[2:0] of the register ADC1\_CTRL2; after the trigger is generated, ADC1 will start conversion, and after all channels are converted, ADC2 will start conversion.

If discontinuous mode is enabled for ADC1 and ADC2, after triggered, ADC1 will start converting the first injected channel; after the second trigger is generated, ADC2 will start to convert the first injected channel and so on.

#### (6) Mixed simultaneous regular/injection mode

The mixed simultaneous regular/injection mode means after the simultaneous regular mode is interrupted, the simultaneous injection mode will be enabled.

In this mode, a sequence of the same length must be converted or a trigger interval time must be set to complete the conversion of a longer sequence.

#### (7) Mixed simultaneous regular + alternate trigger mode

The mixed simultaneous regular + alternate trigger mode means after the simultaneous regular mode is interrupted, the alternate trigger mode will be enabled.

In this mode, a sequence of the same length must be converted or a trigger interval time must be set to complete the conversion of a longer sequence.

#### (8) Mixed simultaneous injection + cross mode

The mixed simultaneous injection + cross mode means after the cross regular mode is interrupted, the simultaneous injection mode will be enabled.

### 25.4.3 External Trigger

Register configuration of external trigger is as follows:

- The external event trigger of regular group channel is enabled by REGEXTTRGSEL[2:0] bit of configuration register ADC\_CTRL2
- The external event trigger of injected group channel is started by INJGEXTTRGSEL[2:0] bit of configuration register ADC\_CTRL2.

Table 95 External Trigger of Regular Channel of ADC1 and ADC2

| Trigger source | REGEXTTRGSEL[2:0] | Trigger type                       |
|----------------|-------------------|------------------------------------|
| TMR1_CC1       | 000               | Internal signal from on-chip timer |

| Trigger source | REGEXTTRGSEL[2:0] | Trigger type                                    |
|----------------|-------------------|-------------------------------------------------|
| TMR1_CC2       | 001               |                                                 |
| TMR1_CC3       | 010               |                                                 |
| TMR2_CC2       | 011               |                                                 |
| TMR3_TRGO      | 100               |                                                 |
| TMR4_CC4       | 101               |                                                 |
| EINT Line 11   | 110               | External pin/internal signal from on-chip timer |
| REGSWSC        | 111               | Software control bit                            |

Table 96 External Trigger of Injected Channel of ADC1 and ADC2

| Trigger source | INJGEXTTRGSEL[2:0] | Trigger type                                    |
|----------------|--------------------|-------------------------------------------------|
| TMR1_TRGO      | 000                | Internal signal from on-chip timer              |
| TMR1_CC4       | 001                |                                                 |
| TMR2_TRGO      | 010                |                                                 |
| TMR2_CC1       | 011                |                                                 |
| TMR3_CC4       | 100                |                                                 |
| TMR4_TRGO      | 101                |                                                 |
| EINT Line 15   | 110                | External pin/internal signal from on-chip timer |
| INJSWSC        | 111                | Software control bit                            |

## 25.4.4 Data register

### 25.4.4.1 Regular data register

ADC\_REGDATA is a 32-bit ADC regular data register. In single-ADC mode, only the lower 16 bits are used to store the converted data. In dual-ADC mode, the lower 16 bits are used to store the converted data of ADC1 while the higher 16 bits are used to store the converted data of ADC2. The data are left aligned or right aligned.

It is determined by DALIGNCFG bit of configuration register ADC\_CTRL2 whether to use DMA transmission. There are at most 16 regular channels, but only one regular data register. Therefore, data coverage will occur in multi-channel conversion, and DMA transmission is needed at this time.

### 25.4.4.2 Injection data memory

ADC\_INJDATAx (x=1,2,3,4) is ADC injected data register, and there are four 32-bit registers, of which the low 16 bits are effective and the high 16 bits are reserved. There are at most four injected channels and four injection data registers, so data coverage will not occur in multi-channel conversion. The data are left aligned or right aligned.

## 25.4.5 Interrupt

### 25.4.5.1 End of conversion interrupt

#### Interrupt of end of conversion of regular group channels

An interrupt will be generated by the end of conversion of regular channels; read the value of the regular data register in the interrupt function.

Determine by EOCFLG bit of configuration register ADC\_STS.

### **Interrupt of end of conversion of injected group channels**

An interrupt will be generated after the conversion of injected channels is completed; read the value of the regular data register in the interrupt function.

Determine by INJEOCFLG bit of configuration register ADC\_STS.

#### **25.4.5.2 Analog watchdog interrupt**

If the input analog voltage is not within the watermark range, an analog watchdog interrupt will be generated.

Determine by configuring AWDFLG bit of the register ADC\_STS.

#### **25.4.6 DMA**

DMA request will be generated after the conversion of regular channels is completed; the converted data result can be transmitted to the memory from the ADC\_REGDATA register.

ADC1 can generate DMA request, and the conversion results of ADC2 are transmitted through the DMA function of ADC1.

### **25.5 Register Address Mapping**

Table 97 ADC Register Address Mapping Table

| Register name | Description                                 | Offset address |
|---------------|---------------------------------------------|----------------|
| ADC_STS       | ADC state register                          | 0x00           |
| ADC_CTRL1     | ADC control register 1                      | 0x04           |
| ADC_CTRL2     | ADC control register 2                      | 0x08           |
| ADC_SMPTIM1   | ADC sampling time register 1                | 0x0C           |
| ADC_SMPTIM2   | ADC sampling time register 2                | 0x10           |
| ADC_INJDOFx   | ADC injected channel data offset register x | 0x14-0x20      |
| ADC_AWDHT     | Analog watchdog high-watermark register     | 0x24           |
| ADC_AWDLT     | Analog watchdog low-watermark register      | 0x28           |
| ADC_REGSEQ1   | ADC regular sequence register 1             | 0x2C           |
| ADC_REGSEQ2   | ADC regular sequence register 2             | 0x30           |
| ADC_REGSEQ3   | ADC regular sequence register 3             | 0x34           |
| ADC_INJSEQ    | ADC injected sequence register              | 0x38           |
| ADC_INJDATAx  | ADC injected data register X                | 0x3C-0x48      |
| ADC_REGDATA   | ADC regular data register                   | 0x4C           |

## 25.6 Register Functional Description

### 25.6.1 ADC state register (ADC\_STS)

Offset address: 0x00

Reset value: 0x0000 000

| Field | Name      | R/W   | Description                                                                                                                                                                    |
|-------|-----------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | AWDFLG    | RC_W0 | Analog Watchdog Occur Flag<br>This bit is set to 1 by hardware and cleared by software, indicating whether an analog watchdog event occurs.<br>0: No occurrence<br>1: Occurred |
| 1     | EOCFLG    | RC_W0 | End Of Conversion Flag<br>0: Not completed<br>1: Completed                                                                                                                     |
| 2     | INJEOCFLG | RC_W0 | Injected Channel End Of Conversion Flag<br>0: Not completed<br>1: Completed                                                                                                    |
| 3     | INJCSFLG  | RC_W0 | Injected Channel Conversion Start Flag<br>0: Not start<br>1: Start                                                                                                             |
| 4     | REGCSFLG  | RC_W0 | Regular Channel Conversion Start Flag<br>0: Not start<br>1: Start                                                                                                              |
| 31:5  |           |       | Reserved                                                                                                                                                                       |

### 25.6.2 ADC control register 1 (ADC\_CTRL1)

Offset address: 0x04

Reset value: 0x0000 0000

| Field | Name     | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|----------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4:0   | AWDCHSEL | R/W | Analog Watchdog Channel Select<br>00000: ADC analog input channel 0<br>00001: ADC analog input channel 1<br>.....<br>01111: ADC analog input channel 15<br>10000: ADC analog input channel 16<br>10001: ADC analog input channel 17<br>Other value: Reserved<br>For this register, pay attention to the followings:<br>(1) The analog input channel 16 and channel 17 of ADC1 are connected to the temperature sensor and V <sub>REFINT</sub> in the chip respectively<br>(2) The analog input channel 16 and channel 17 of ADC2 are connected to V <sub>SS</sub> in the chip; |
| 5     | EOCIEN   | R/W | EOC Interrupt Enable<br>Used to enable the generation of interrupt after the conversion is completed.<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                                                                                                                                                                                                               |

| Field | Name       | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6     | AWDIEN     | R/W | Analog Watchdog Interrupt Enable<br>If the bit is set and in scan mode, when the watchdog detects that the value exceeds the watermark, an interrupt will be generated and the scan will be aborted.<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 7     | INJEOCIEN  | R/W | Interrupt Enable For Injected Channels End Of Conversion Flag<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 8     | SCANEN     | R/W | Scan Mode Enable<br>In the scan mode, convert the channel selected by ADC_REGSEQX or ADC_INJSEQX register.<br>0: Disable<br>1: Enable<br>Note: If EOCINTEN or INJEOCINTEN bit is set respectively, EOC or INJEOC interrupt will be generated only after the last channel is converted.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 9     | AWDSGLEN   | R/W | Enable The Watchdog On A Single Channel In Scan Mode<br>This channel is specified by AWDCHSEL[4:0] bit.<br>0: Enable on all channels<br>1: Enable on a single channel;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 10    | INJGACEN   | R/W | Automatic Injected Group Conversion Enable<br>Used to enable automatic conversion of injected channels after the conversion of regular channel group is completed.<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 11    | REGDISCEN  | R/W | Discontinuous Mode On Regular Channels Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 12    | INJDISCEN  | R/W | Discontinuous Mode On Injected Channels Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 15:13 | DISCNUMCFG | R/W | Discontinuous Mode Channel Number Configure<br>000: One channel<br>001: Two channels<br>.....<br>111: Eight channels                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 19:16 | DUALMCFG   | R/W | Dual ADC Mode Configure<br>0000: Independent mode<br>0001: Mixed synchronous regular + injected synchronous mode<br>0010: Mixed simultaneous regular + alternate trigger mode<br>0011: Mixed simultaneous injection + fast cross mode<br>0100: Mixed simultaneous injection + slow cross mode<br>0101: Injected simultaneous mode<br>0110: Regular simultaneous mode<br>0111: Fast cross mode<br>1000: Slow cross mode<br>1001: Alternate trigger mode<br>Others: Reserved<br>In ADC2, these bits are reserved bits; in dual ADC mode, changing the channel configuration will result in a restart condition, which will result in loss of synchronization. It is recommended to turn off dual ADC mode (i.e. configure as independent mode) before making any configuration changes. |

| Field | Name     | R/W | Description                                                                             |
|-------|----------|-----|-----------------------------------------------------------------------------------------|
| 21:20 | Reserved |     |                                                                                         |
| 22    | INJAWDEN | R/W | Enable the Analog Watchdog Function On the Injected Channels<br>0: Disable<br>1: Enable |
| 23    | REGAWDEN | R/W | Enable the Analog Watchdog Function On the Regular Channels<br>0: Disable<br>1: Enable  |
| 31:24 | Reserved |     |                                                                                         |

### 25.6.3 ADC control register 2 (ADC\_CTRL2)

Offset address: 0x08

Reset value: 0x0000 0000

| Field | Name          | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|---------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | ADCEN         | R/W | ADC Enable<br>(1) If this bit is set to 0, write 1 to power on ADC and start ADC conversion<br>(2) If this bit is set to 1, write 1 to start conversion<br>0: Disable ADC conversion and calibration and enter the power-down mode<br>1: Enable ADC and start conversion<br>Note: To prevent triggering wrong conversion, if another bit and this bit in this register are changed, conversion will not be triggered. |
| 1     | CONTCEN       | R/W | Continuous Conversion Mode Enable<br>0: Single conversion mode<br>1: Continuous conversion mode                                                                                                                                                                                                                                                                                                                       |
| 2     | CAL           | R/W | A/D Calibration<br>Calibration starts when this bit is set to 1 by software, and it is cleared by hardware when the calibration is completed.<br>0: Calibration is completed<br>1: Start calibration                                                                                                                                                                                                                  |
| 3     | CALRST        | R/W | Calibration Reset<br>This bit is set to 1 by software, and is cleared by hardware after the calibration register completes resetting.<br>0: It means resetting of calibration register is completed<br>1: Reset calibration register                                                                                                                                                                                  |
| 7:4   | Reserved      |     |                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 8     | DMAEN         | R/W | DMA Mode Enable<br>0: Disable<br>1: Enable<br>Note: Only ADC1 can generate DMA request.                                                                                                                                                                                                                                                                                                                               |
| 10:9  | Reserved      |     |                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 11    | DALIGNCFG     | R/W | Data Alignment Mode Configure<br>0: Right alignment<br>1: Left alignment                                                                                                                                                                                                                                                                                                                                              |
| 14:12 | INJGEXTTRGSEL | R/W | Select the External Trigger Event to Start the Injected Group Conversion<br>Trigger configuration of ADC1 and ADC2 is as follows:<br>000: TRGO event of timer 1<br>001: CC4 event of timer 1                                                                                                                                                                                                                          |

| Field | Name         | R/W | Description                                                                                                                                                                                                                                                                                                                                                         |
|-------|--------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |              |     | 010: TRGO event of timer 2<br>011: CC1 event of timer 2<br>100: CC4 event of timer 3<br>101: TRGO event of timer 4<br>110: EINT Line 15<br>111: INJSWSC                                                                                                                                                                                                             |
| 15    | INJEXTTRGEN  | R/W | Enable the External Trigger Conversion Mode of the Injected Channels<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                                     |
| 16    |              |     | Reserved                                                                                                                                                                                                                                                                                                                                                            |
| 19:17 | REGEXTTRGSEL | R/W | Select the External Trigger Event to Start the Regular Group Conversion<br>Trigger configuration of ADC1 and ADC2 is as follows:<br>000: CC1 event of timer 1<br>001: CC2 event of timer 1<br>010: CC3 event of timer 1<br>011: CC2 event of timer 2<br>100: TRGO event of timer 3<br>110: CC4 event of timer 4<br>110: EINT Line 11<br>111: REGSWSC                |
| 20    | REGEXTTRGEN  | R/W | Enable the External Trigger Conversion Mode of the Regular Channels<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                                      |
| 21    | INJSWSC      | R/W | Software Start Conversion Injected Channels<br>If INJSWSC is selected as trigger event in INJEXESEL[2:0] bit, this bit will be used to start conversion of a group of injected channel; this bit can be set to 1 and cleared by software, and be cleared by hardware after the conversion is started.<br>0: Reset state<br>1: Start conversion of injected channels |
| 22    | REGSWSC      | R/W | Software Start Conversion Regular Channels<br>If REGSWSC is selected as trigger event in REGEXTSEL[2:0] bit, this bit will be used to start conversion of a group of regular channel; this bit can be set to 1 and cleared by software, and be cleared by hardware after the conversion is started.<br>0: Reset state<br>1: Start conversion of regular channels    |
| 23    | TSVREFEN     | R/W | Temperature Sensor And V <sub>REFINT</sub> Channel Enable<br>This bit is valid only in ADC1.<br>This bit can be set to 1 and cleared by software; in the device with multiple ADCs, this bit only appears in ADC1.<br>0: Disable<br>1: Enable                                                                                                                       |
| 31:24 |              |     | Reserved                                                                                                                                                                                                                                                                                                                                                            |

#### 25.6.4 ADC sampling time register 1 (ADC\_SMPTIM1)

Offset address: 0x0C

Reset value: 0x0000 0000

| Field | Name        | R/W | Description                                           |
|-------|-------------|-----|-------------------------------------------------------|
| 2:0   | SMPCYCCFG10 | R/W | Channel 10 Sample Cycles Configure<br>000: 1.5 cycles |

| Field | Name        | R/W | Description                                                                                                                              |
|-------|-------------|-----|------------------------------------------------------------------------------------------------------------------------------------------|
|       |             |     | 001: 7.5 cycles<br>010: 13.5 cycles<br>011: 28.5 cycles<br>100: 41.5 cycles<br>101: 55.5 cycles<br>110: 71.5 cycles<br>111: 239.5 cycles |
| 5:3   | SMPCYCCFG11 | R/W | Channel 11 Sample Cycles Configure<br>Refer to the description of SMPCYCCFG10.                                                           |
| 8:6   | SMPCYCCFG12 | R/W | Channel 12 Sample Cycles Configure<br>Refer to the description of SMPCYCCFG10.                                                           |
| 11:9  | SMPCYCCFG13 | R/W | Channel 13 Sample Cycles Configure<br>Refer to the description of SMPCYCCFG10.                                                           |
| 14:12 | SMPCYCCFG14 | R/W | Channel 14 Sample Cycles Configure<br>Refer to the description of SMPCYCCFG10.                                                           |
| 17:15 | SMPCYCCFG15 | R/W | Channel 15 Sample Cycles Configure<br>Refer to the description of SMPCYCCFG10.                                                           |
| 20:18 | SMPCYCCFG16 | R/W | Channel 16 Sample Cycles Configure<br>Refer to the description of SMPCYCCFG10.                                                           |
| 23:21 | SMPCYCCFG17 | R/W | Channel 17 Sample Cycles Configure<br>Refer to the description of SMPCYCCFG10.                                                           |
| 31:24 |             |     | Reserved                                                                                                                                 |

### 25.6.5 ADC sampling time register 2 (ADC\_SMPTIM2)

Offset address: 0x10

Reset value: 0x0000 0000

| Field | Name       | R/W | Description                                                                   |
|-------|------------|-----|-------------------------------------------------------------------------------|
| 2:0   | SMPCYCCFG0 | R/W | Channel 0 Sample Cycles Configure<br>Refer to the description of SMPCYCCFG10. |
| 5:3   | SMPCYCCFG1 | R/W | Channel 1 Sample Cycles Configure<br>Refer to the description of SMPCYCCFG10. |
| 8:6   | SMPCYCCFG2 | R/W | Channel 2 Sample Cycles Configure<br>Refer to the description of SMPCYCCFG10. |
| 11:9  | SMPCYCCFG3 | R/W | Channel 3 Sample Cycles Configure<br>Refer to the description of SMPCYCCFG10. |
| 14:12 | SMPCYCCFG4 | R/W | Channel 4 Sample Cycles Configure<br>Refer to the description of SMPCYCCFG10. |
| 17:15 | SMPCYCCFG5 | R/W | Channel 5 Sample Cycles Configure<br>Refer to the description of SMPCYCCFG10. |
| 20:18 | SMPCYCCFG6 | R/W | Channel 6 Sample Cycles Configure<br>Refer to the description of SMPCYCCFG10. |
| 23:21 | SMPCYCCFG7 | R/W | Channel 7 Sample Cycles Configure<br>Refer to the description of SMPCYCCFG10. |
| 26:24 | SMPCYCCFG8 | R/W | Channel 8 Sample Cycles Configure<br>Refer to the description of SMPCYCCFG10. |
| 29:27 | SMPCYCCFG9 | R/W | Channel 9 Sample Cycles Configure<br>Refer to the description of SMPCYCCFG10. |
| 31:30 |            |     | Reserved                                                                      |

### 25.6.6 ADC injected channel data offset register x (ADC\_INJDOFx) (x=1..4)

Offset address: 0x14-0x20

Reset value: 0x0000 0000

| Field | Name    | R/W | Description                                                                                                                                                                                                                             |
|-------|---------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11:0  | INJDOFx | R/W | Data Offset For Injected Channel x<br>When converting the injected channels, these bits define the values to be subtracted from the original converted data, and the result of the conversion can be read in the ADC_INJDATAx register. |
| 31:12 |         |     | Reserved                                                                                                                                                                                                                                |

### 25.6.7 Analog watchdog high-threshold register (ADC\_AWDHT)

Offset address: 0x24

Reset value: 0x0000 0FFF

| Field | Name        | R/W | Description                    |
|-------|-------------|-----|--------------------------------|
| 11:0  | AWDHT[11:0] | R/W | Analog Watchdog High Threshold |
| 31:12 |             |     | Reserved                       |

### 25.6.8 Analog watchdog low-threshold register (ADC\_AWDLT)

Offset address: 0x28

Reset value: 0x0000 0000

| Field | Name        | R/W | Description                   |
|-------|-------------|-----|-------------------------------|
| 11:0  | AWDLT[11:0] | R/W | Analog Watchdog Low Threshold |
| 31:12 |             |     | Reserved                      |

### 25.6.9 ADC regular sequence register 1 (ADC\_REGSEQ1)

Offset address: 0x2C

Reset value: 0x0000 0000

| Field | Name      | R/W | Description                                                                                                                                                                                                               |
|-------|-----------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4:0   | REGSEQC13 | R/W | 13 <sup>th</sup> Conversion In Regular Sequence<br>Define the channel number of No. 13 conversion in regular sequence (0~17)                                                                                              |
| 9:5   | REGSEQC14 | R/W | 14 <sup>th</sup> Conversion In Regular Sequence<br>Refer to the description of REGSEQC13.                                                                                                                                 |
| 14:10 | REGSEQC15 | R/W | 15 <sup>th</sup> Conversion In Regular Sequence<br>Refer to the description of REGSEQC13.                                                                                                                                 |
| 19:15 | REGSEQC16 | R/W | 16 <sup>th</sup> Conversion In Regular Sequence<br>Refer to the description of REGSEQC13.                                                                                                                                 |
| 23:20 | REGSEQLEN | R/W | Regular Channel Sequence Length<br>These bits are defined by software as the number of channels in regular channel conversion sequence.<br>0000: One conversion<br>0001: Two conversions<br>.....<br>1111: 16 conversions |
| 31:24 |           |     | Reserved                                                                                                                                                                                                                  |

### 25.6.10 ADC regular sequence register 2 (ADC\_REGSEQ2)

Offset address: 0x30

Reset value: 0x0000 000

| Field | Name      | R/W | Description                                                                               |
|-------|-----------|-----|-------------------------------------------------------------------------------------------|
| 4:0   | REGSEQC7  | R/W | 7 <sup>th</sup> Conversion In Regular Sequence<br>Refer to the description of REGSEQC13.  |
| 9:5   | REGSEQC8  | R/W | 8 <sup>th</sup> Conversion In Regular Sequence<br>Refer to the description of REGSEQC13.  |
| 14:10 | REGSEQC9  | R/W | 9 <sup>th</sup> Conversion In Regular Sequence<br>Refer to the description of REGSEQC13.  |
| 19:15 | REGSEQC10 | R/W | 10 <sup>th</sup> Conversion In Regular Sequence<br>Refer to the description of REGSEQC13. |
| 24:20 | REGSEQC11 | R/W | 11 <sup>th</sup> Conversion In Regular Sequence<br>Refer to the description of REGSEQC13. |
| 29:25 | REGSEQC12 | R/W | 12 <sup>th</sup> Conversion In Regular Sequence<br>Refer to the description of REGSEQC13. |
| 31:30 |           |     | Reserved                                                                                  |

### 25.6.11 ADC regular sequence register 3 (ADC\_REGSEQ3)

Offset address: 0x34

Reset value: 0x0000 0000

| Field | Name     | R/W | Description                                                                              |
|-------|----------|-----|------------------------------------------------------------------------------------------|
| 4:0   | REGSEQC1 | R/W | 1 <sup>st</sup> Conversion In Regular Sequence<br>Refer to the description of REGSEQC13. |
| 9:5   | REGSEQC2 | R/W | 2 <sup>nd</sup> Conversion In Regular Sequence<br>Refer to the description of REGSEQC13. |
| 14:10 | REGSEQC3 | R/W | 3 <sup>rd</sup> Conversion In Regular Sequence<br>Refer to the description of REGSEQC13. |
| 19:15 | REGSEQC4 | R/W | 4 <sup>th</sup> Conversion In Regular Sequence<br>Refer to the description of REGSEQC13. |
| 24:20 | REGSEQC5 | R/W | 5 <sup>th</sup> Conversion In Regular Sequence<br>Refer to the description of REGSEQC13. |
| 29:25 | REGSEQC6 | R/W | 6 <sup>th</sup> Conversion In Regular Sequence<br>Refer to the description of REGSEQC13. |
| 31:30 |          |     | Reserved                                                                                 |

### 25.6.12 ADC injected sequence register (ADC\_INJSEQ)

Offset address: 0x38

Reset value: 0x0000 0000

| Field | Name     | R/W | Description                                                                                                                  |
|-------|----------|-----|------------------------------------------------------------------------------------------------------------------------------|
| 4:0   | INJSEQC1 | R/W | 1 <sup>st</sup> Conversion In Injected Sequence<br>Define the channel number of No. 1 conversion in injected sequence (0~17) |
| 9:5   | INJSEQC2 | R/W | 2 <sup>nd</sup> Conversion In Injected Sequence                                                                              |
| 14:10 | INJSEQC3 | R/W | 3 <sup>rd</sup> Conversion In Injected Sequence                                                                              |
| 19:15 | INJSEQC4 | R/W | 4 <sup>th</sup> Conversion In Injected Sequence                                                                              |

| Field | Name      | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------|-----------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 21:20 | INJSEQLEN | R/W | <p>Injected Channel Sequence Length<br/>           These bits are defined by software as the number of channels in injected channel conversion sequence, and the conversion sequence is:<br/> <math>\text{INJSEQC}_{(4-\text{INJSEQLEN})} \rightarrow \text{INJSEQ}_{(5-\text{INJSEQLEN})} \rightarrow \text{INJSEQC}_{(6-\text{INJSEQLEN})}</math><br/> <math>\rightarrow \text{INJSEQC}_{(7-\text{INJSEQLEN})}</math>; the details are as follows:</p> <ul style="list-style-type: none"> <li>00: One conversion, only converting INJSEQC4</li> <li>01: Two conversions; the conversion sequence is INJSEQC3→INJSEQC4</li> <li>10: Three conversions; the conversion sequence is INJSEQC2→INJSEQC3→INJSEQC4</li> <li>11: Four conversions; the conversion sequence is INJSEQC1→INJSEQC2→INJSEQC3→INJSEQC4</li> </ul> |
| 31:22 |           |     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

### 25.6.13 ADC injected data register x (ADC\_INJDATAx) (x= 1..4)

Offset address: 0x3C–0x48

Reset value: 0x0000 0000

| Field | Name    | R/W | Description                                                                                      |
|-------|---------|-----|--------------------------------------------------------------------------------------------------|
| 15:0  | INJDATA | R   | <p>Injected Conversion Data<br/>           Conversion result of injected channel, read-only.</p> |
| 31:16 |         |     | Reserved                                                                                         |

### 25.6.14 ADC regular data register (ADC\_REGDATA)

Offset address: 0x4C

Reset value: 0x0000 0000

| Field | Name     | R/W | Description                                                                                                                                                                                            |
|-------|----------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0  | REGDATA  | R   | <p>Regular Conversion Data<br/>           Conversion result of regular channel, read-only.</p>                                                                                                         |
| 31:16 | ADC2DATA | R   | <p>ADC2 Conversion Data<br/>           (1) This bit is valid in ADC1, indicating the result of ADC2 regular channel conversion in dual-ADC mode;<br/>           (2) In ADC2, this bit is reserved.</p> |

## 26 Cyclic Redundancy Check Computing Unit (CRC)

### 26.1 Introduction

The cyclic redundancy check (CRC) computing unit can get 32-bit CRC computing result by calculating the input data through a fixed generator polynomial, which is mainly used to detect or verify the correctness and integrity of the data after transmission or saving.

### 26.2 Functional Description

#### 26.2.1 Calculation Method

Use CRC-32 (Ethernet) polynomial: 0x4C11DB7

$$(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)$$

#### 26.2.2 Calculation Time

The calculation time is four AHB clock cycles.

Every time a new data is written, the result will be a combination of the last calculation result and the new calculation result. (Execute operation for the whole word). Write operation of CPU will be suspended during calculation, so that "Back-to-back" write or continuous "read" -"write" operation can be performed for the register CRC\_DATA.

### 26.3 Register Address Mapping

Table 98 CRC Computing Unit Register Address Mapping

| Register name | Description               | Offset address |
|---------------|---------------------------|----------------|
| DATA          | Data register             | 0x00           |
| INDATA        | Independent data register | 0x04           |
| CTRL          | Control register          | 0x08           |

### 26.4 Register Functional Description

CRC computing unit contains two data memories and one control memory.

#### 26.4.1 Data register (CRC\_DATA)

Offset address: 0x00

Reset value: 0xFFFF FFFF

| Field | Name | R/W | Description                                                                                                                                                                        |
|-------|------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0  | DATA | R/W | 32bit Data Register<br>It is used as a new data input port for CRC computing during write operation; when the read operation is executed, the result of CRC computing is returned. |

#### 26.4.2 Independent data register (CRC\_INDATA)

Offset address: 0x04

Reset value: 0x0000 0000

| Field | Name      | R/W | Description                                                                                                                                                           |
|-------|-----------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0   | INDATA    | R/W | Independent 8bit Data<br>It can be used to temporarily store 1-byte data; the CRC reset generated by RST bit of the register CRC_CTRL has no effect on this register. |
| 31:8  | Reserved. |     |                                                                                                                                                                       |

Note: This register does not take part in calculation and can store any data.

#### 26.4.3 Control register (CRC\_CTRL)

Offset address: 0x08

Reset value: 0x0000 0000

| Field | Name     | R/W | Description                                                                                                                                                               |
|-------|----------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | RST      | W   | Reset CRC Calculation Unit<br>After reset, set the data register as 0xFFFF FFFF, and this bit can only be written as 1 by software and automatically cleared by hardware. |
| 31:1  | Reserved |     |                                                                                                                                                                           |

## 27 Floating-point unit (FPU)

This module applies only to APM32F103xB D version.

### 27.1 Introduction

FPU (floating point unit) fully supports operations of single precision addition, subtraction, multiplication, division, multiplication, accumulation and square root. It also provides conversion between fixed-point and floating-point data formats, and floating-point constant instructions. FPU provides floating-point estimation function, which conforms to ANSI (American National Standards Institute)/IEEE (Institute of Electrical and Electronics Engineers) 754-2008 standard and IEEE binary floating-point algorithm standard , which is called IEEE 754 standard.

### 27.2 Functional Description

#### 27.2.1 Supported Algorithms

FPU only supports single precision and supports IEEE754 compliance, including algorithms of: CMP, SUM, SUB, PRDCT, MAC, DIV, INVSQRT, SUMSQ, DOT, conversion from floating point to integer and conversion from integer to floating point.

Table 99 FPU Supported Algorithm

| Term          | Definition                                                                                                                 |
|---------------|----------------------------------------------------------------------------------------------------------------------------|
| I2FP          | Conversion from integer to floating point                                                                                  |
| FP2I          | Conversion from floating point to integer                                                                                  |
| CMP (p, q)    | Comparison of p and q                                                                                                      |
| SUM (p, n)    | $SUM(p, n) = \sum_{(i=0, n)} pi = p0 + p1+..+pi+..+pn, 0 \leq n < 16$                                                      |
| SUB (p, n)    | $SUB(p, n) = p0 - \sum_{(i=0, n)} pi = p0 - p1-..-pi-..-pn, 0 \leq n < 16$                                                 |
| PRDCT (p, n)  | Product: $PRDCT(p, n) = \prod_{(i=0, n)} pi = p0 * p1 *..* pi *..* pn, 0 \leq n < 16$                                      |
| DIV (p, q)    | Division: $DIV(p, q) = \frac{p}{q}$                                                                                        |
| INVSQRT (p)   | Square Root: $INVSQRT(p) = \frac{1}{\sqrt{p}}$                                                                             |
| MAC (p, q, s) | Floating-Point Multiply-Add: $MAC(p, q, s) = p * q + s$                                                                    |
| SUMSQ (p, n)  | $\sum_{(i=1, n)} (pi)^2$ , wherein p is the vector of the length n, $0 \leq n < 16$                                        |
| DOT (p, q, n) | $\sum_{(i=1, n)} (pi * qi)$ , wherein p and q are the vector of the length n, $0 \leq n < 16$                              |
| SIN (x)       | $x \in (-\infty, +\infty)$ , wherein x is expressed in radian                                                              |
| COS (x)       | $x \in (-\infty, +\infty)$ , wherein x is expressed in radian                                                              |
| TAN (x)       | $x \in (-\infty, +\infty)$ , wherein x is expressed in radian                                                              |
| ASIN (x)      | $x \in [-1, +1]$ , wherein the output value is expressed in radian, and is in the interval of $[-\pi/2, +\pi/2]$           |
| ACOS (x)      | $x \in [-1, +1]$ , wherein the output value is expressed in radian, and is in the interval of $[0, \pi]$                   |
| ATAN (x)      | $x \in (-\infty, +\infty)$ , wherein the output value is expressed in radian, and is in the interval of $[-\pi/2, +\pi/2]$ |
| ATAN2 (y, x)  | $x, y \in (-\infty, +\infty)$ , wherein the output value is expressed in radian, and is in the interval of $[-\pi, +\pi]$  |

## 27.2.2 Software Programming

### 27.2.2.1 Programming process

It is recommended to use the relocatable library provided by us to connect the user program instead of programming on the basis of registers.

### 27.2.2.2 Single-operand operation

For FP2I, I2FP, INVSQRT, SIN, COS, TAN, ASIN, ACOS and ATAN, the recommended configuration is as follows:

- (1) Configure FPU\_CTRL register. Select the required operation mode and set the start (STR) bit. For INVSQRT mode, set the cycle index to improve the accuracy of FPU\_CTRL[7:6].
- (2) Write the operand to FPU\_FPI1
- (3) Flag of waiting for interrupt done or checking the FPUISTS register done (DONE)
- (4) Read the result from FPU\_FPO

### 27.2.2.3 Operation of two operands

**For DIV, the recommended configuration is as follows:**

- (1) Configure FPU\_CTRL register, select DIV mode and set the start (STR) bit.
- (2) Write the first operand to FPU\_FPI1
- (3) Write the second operand to FPU\_FPI1
- (4) Flag of waiting for interrupt done or checking the FPUISTS register done (DONE)
- (5) Read the result from FPU\_FPO

**For CMP, the recommended configuration is as follows:**

- (1) Configure FPU\_CTRL register, select CMP mode and set the start (STR) bit.
- (2) Write the first operand to FPU\_FPI1
- (3) Write the second operand to FPU\_FPI2
- (4) Flag of waiting for interrupt done or checking the FPUISTS register done (DONE)
- (5) Read the CMP result from FPUISTS[3:2]

**For ATAN2, the recommended configuration is as follows:**

- (1) Configure FPU\_CTRL register, select ATAN2 mode and set the start (STR) bit.
- (2) Write the first operand to FPU\_FPI1
- (3) Write the second operand to FPU\_FPI2

- (4) Flag of waiting for interrupt done or checking the FPU\_ISTS register done (DONE)
- (5) Read the result from FPU\_FPO

#### 27.2.2.4 Operation of three operands

**For MAC, the recommended configuration is as follows:**

- (1) Configure FPU\_CTRL register, select MAC mode and set the start (STR) bit.
- (2) Write the first operand to FPU\_FPI1
- (3) Write the second operand to FPU\_FPI2
- (4) Write the third operand to FPU\_FPI2
- (5) Flag of waiting for interrupt done or checking the FPU\_ISTS register done (DONE)
- (6) Read the result from FPU\_FPO

#### 27.2.2.5 Operation of n operands

**For SUM, SUB, PRDCT and SUMSQ, the recommended configuration is as follows:**

- (1) Configure FPU\_CTRL register, select the required mode, enter the value of n in the nLEN field and set the start (STR) bit.
- (2) Write the P0 operand to FPU\_FPI1
- (3) Write the operand of P1..n-1 to FPU\_FPI2
- (4) Flag of waiting for interrupt done or checking the FPU\_ISTS register done (DONE)
- (5) Read the result from FPU\_FPO

**For DOT, the recommended configuration is as follows:**

- (1) Configure FPU\_CTRL register, select DOT mode, enter the value of n in the nLEN field and set the start (STR) bit.
- (2) Write the P0 operand to FPU\_FPI1
- (3) Write the Q0 operand to FPU\_FPI2
- (4) Write the P1 operand to FPU\_FPI1
- (5) Write the Q1 operand to FPU\_FPI2
- (6) ...
- (7) Write the Pn-1 operand to FPU\_FPI1
- (8) Write the Qn-1 operand to FPU\_FPI2
- (9) Flag of waiting for interrupt done or checking the FPU\_ISTS register done (DONE)

(10) Read the result from FPU\_FPO

## 27.3 Register Address Mapping

Table 100 FPU Register Address Mapping

| Register name | Description                           | Offset address |
|---------------|---------------------------------------|----------------|
| FPU_CTRL      | Control register                      | 0x00           |
| FPU_ISTS      | Interrupt state register              | 0x04           |
| FPU_FPO       | Floating-point output value register  | 0x08           |
| FPU_FPI1      | Floating-point input value register 1 | 0x0C           |
| FPU_FPI2      | Floating-point input value register 2 | 0x10           |
| FPU_IM        | Interrupt mask register               | 0x14           |

## 27.4 Register Functional Description

### 27.4.1 Control register (FPU\_CTRL)

Offset address: 0x0

Reset value: 0x0000 0000

| Field | Name     | R/W | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------|----------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | STR      | R/W | Start FPU<br>0: No effect<br>1: Start FPU. This bit can be automatically cleared by hardware after startup.                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 5:1   | OP       | R/W | FPU Operation Mode<br>0: ASIN<br>1: ACOS<br>2: ATAN<br>3: ATAN2<br>4: SIN<br>5: COS<br>6: TAN<br>7~15. Reserved<br>16: SUM (p, n), Summation<br>17: SUMSQ (p, n), Sum of squares<br>18: SUB (p, n), Subtraction<br>19: PRDCT (p, n), Production<br>20: DOT (p, q, n), Dot Production<br>21: MAC (p, q, s), Floating-Point Multiply-Add<br>22: DIV (p, q), Division<br>23: INVSQRT (p), Square Root<br>24: CMP (p,q)<br>25: I2FP, conversion from integer to floating point<br>26: FP2I, conversion from floating point to integer<br>27~31: Reserved |
| 7:6   | ITERTION | R/W | Improve The Repetition Time of Accuracy Algorithm                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 11:8  | nLEN     | R/W | The Length of The Equation SUM (p, n), SUB (p, n), SUMSQ (p, n), PRDCT (p, n), and DOT (p, q, n).                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

| Field | Name | R/W | Description |
|-------|------|-----|-------------|
| 31:12 |      |     | Reserved    |

### 27.4.2 Interrupt state register (FPU\_ISTS)

Offset address: 0x4

Reset value: 0x0000 0000

| Field | Name      | R/W | Description                                                                                                                                                                             |
|-------|-----------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | DONE      | R/W | Flag of FPU Calculation Completion<br>0: FPU calculation uncompleted<br>1: FPU calculation completed                                                                                    |
| 1     | BUSY      | R/W | FPU Busy Flag<br>0: FPU in idle state<br>1: FPU in busy state This bit can be set by hardware after FPU runs, and automatically cleared by hardware after FPU completes calculation.    |
| 3:2   | CMPR[3:2] | R/W | Comparison Slgorithm Result<br>0: $a = b$ .<br>1: $a < b$ .<br>2: $a > b$ .<br>3: When one input value is not a number (NaN), it is unordered                                           |
| 4     | ZERO      | R/W | Zero Flag<br>0: Meaningless.<br>1: The calculation result is zero or is zero after round-off                                                                                            |
| 5     | INF       | R/W | Infinitely Great<br>0: Meaningless<br>1: The calculation result is infinitely great or is infinitely great after round-off                                                              |
| 6     | INVALID   | R/W | Floating-point Operation Is Invalid<br>0: Meaningless<br>1: Illegal input operation                                                                                                     |
| 7     | TINY      | R/W | The Calculation result Is Tiny<br>0: Meaningless.<br>1: After round-off, the floating point is a quantity less than the minimum normalized number, but not an exact zero.               |
| 8     | HUGE      | R/W | The Calculation Result Is Great.<br>0: Meaningless.<br>1: After round-off, the finite floating point result is a quantity greater than the maximum normalized number.                   |
| 9     | INEXACT   | R/W | The Calculation Result Is Not Accurate<br>0: Meaningless.<br>1: The integer or floating point output value is not equal to infinitely great accurate result                             |
| 10    | HUGEINT   | R/W | Great Integer Complement<br>0: Meaningless<br>1: After round-off, the integer result is a quantity greater than the maximum representable number of complement of two identical symbols |
| 11    | DIVBY0    | R/W | Division by Zero<br>0: Meaningless<br>1: Run the operation of division by zero                                                                                                          |
| 31:12 |           |     | Reserved                                                                                                                                                                                |

#### 27.4.3 Floating-point output value register (FPU\_FPO)

Offset address: 0x8

Reset value: 0x0000 0000

| Field | Name | R/W | Description                 |
|-------|------|-----|-----------------------------|
| 31:0  | FPO  | R   | Floating-point Output Value |

#### 27.4.4 Floating-point input value register 1 (FPU\_FPI1)

Offset address: 0xC

Reset value: 0x0000 0000

| Field | Name | R/W | Description                  |
|-------|------|-----|------------------------------|
| 31:0  | FPI1 | R/W | Floating-point Input Value 0 |

#### 27.4.5 Floating-point input value register 2 (FPU\_FPI2)

Offset address: 0x10

Reset value: 0x0000 0000

| Field | Name | R/W | Description                  |
|-------|------|-----|------------------------------|
| 31:0  | FPI2 | R   | Floating-point Input Value 1 |

#### 27.4.6 Interrupt mask register (FPU\_IM)

Offset address: 0x14

Reset value: 0x0000 0000

| Field | Name    | R/W | Description                                                                                                                  |
|-------|---------|-----|------------------------------------------------------------------------------------------------------------------------------|
| 0     | DONE    | R/W | Operation Completion Interrupt Mask<br>0: Operation completion interrupt enabled<br>1: Operation completion interrupt masked |
| 1     | INVALID | R/W | Operation Interrupt Mask Invalid<br>0: Invalid operation interrupt enabled<br>1: Invalid operation interrupt masked          |
| 31:2  |         |     | Reserved                                                                                                                     |

## 28 Chip Electronic Signature

The chip electronic signature includes flash capacity information of main memory and 96-bit unique chip ID, which have been written into the system memory area of the chip before leaving the factory, and are read-only and can not be modified by users.

### 28.1 Capacity Register of Main Memory Area

#### 28.1.1 Flash capacity register (16 bits)

Base address: 0x1FFF F7E0

Read-only, the value has been prepared before leaving the factory

| Field | Name   | R/W | Description                                                                                                                           |
|-------|--------|-----|---------------------------------------------------------------------------------------------------------------------------------------|
| 15:0  | F_SIZE | R   | Flash memory capacity (Flash Size)<br>Indicate the capacity of main memory area of the product (in KB).<br>For example: 0x0080=128 KB |

### 28.2 96-bit Unique Chip ID

Purposes of unique ID may be:

- As serial number (such as USBD character serial number or other terminal application)
- As a password; this unique identification can be used with software encryption and decryption algorithm to improve the security of the code in flash memory when writing the flash memory
- Used to activate the startup process with security mechanism
- The reference number provided by the identity is unique to any MCU series. Users cannot change the unique ID under no circumstances. According to different usage, users can choose to read the identity in byte, half word, or full word.

Base address: 0x1FFF F7E8

Offset address: 0x00

Read-only, the value has been prepared before leaving the factory

| Field | Name       | R/W | Description                    |
|-------|------------|-----|--------------------------------|
| 15:0  | U_ID[15:0] | R   | Unique identity flag 15:0 bits |

Offset address: 0x02

Read-only, the value has been prepared before leaving the factory

| Field | Name        | R/W | Description                     |
|-------|-------------|-----|---------------------------------|
| 15:0  | U_ID[31:16] | R   | Unique identity flag 31:16 bits |

Offset address: 0x04

Read-only, the value has been prepared before leaving the factory

| Field | Name        | R/W | Description                     |
|-------|-------------|-----|---------------------------------|
| 31:0  | U_ID[63:32] | R   | Unique identity flag 63:32 bits |

Offset address: 0x08

Read-only, the value has been prepared before leaving the factory

| <b>Field</b> | <b>Name</b> | <b>R/W</b> | <b>Description</b>              |
|--------------|-------------|------------|---------------------------------|
| 31:0         | U_ID[95:64] | R          | Unique identity flag 95:64 bits |

## 29 Version History

Table 101 Document Version History

| Date              | Version | Change History                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| February 12, 2020 | 1.0     | New                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| February 3, 2021  | 1.0     | Naming error of some registers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| April 25, 2021    | 1.1     | (1) Modify the reset value of "debug MCU device ID register" in DBGMCU module<br>(2) Modify TPYE of "USBD endpoint n register" to TYPE<br>(3) Modify GPIO section "Output Mode I/O Structure Diagram"                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| July 21, 2021     | 1.2     | (1) Modify the 7:6 bit description of DBGMCU_CFG<br>(2) Modify the number of maskable interrupt channels                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| August 9, 2021    | 1.3     | (1) Will be in the clock tree "4-16 MHZ LSICLK OSC" correction for "4-16 MHZ HSECLK"<br>(2) Added details of APM32F103xB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| March 15, 2022    | 1.4     | (1)Modify the contents of the CAN communication mode section<br>(2)Modify WDTSEL bit of Option Bytes in Flash module.<br>(3)Modify "SCLKSWSTS" to "SCLKSELSTS" in RCM.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| June 30, 2022     | 1.5     | (1)Modify the Arm trademark<br>(2)Add the statement                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| August 22, 2022   | 1.6     | (1) Modify the Reset registers and the Enable registers in RCM module<br>(2) Delete the RGSQT function from the FPU                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| April 12, 2023    | 1.7     | (1) "PCLK1=36MHz" changes into "PCLK1=48MHz", which is the condition of the timeout value in WWDT, and modifies the results.<br>(2) Replace the SMREQ with SLEEPREQ in the document<br>(3) Add the Version Recognition Number of "Device ID register" in DBGMCU module<br>(4) Add CAN2 description<br>(5) Add the description of the system diagram<br>(6) Modify maskable interrupt channel number and Interrupt and Exception Vector Table<br>(7) Modify the QSPI version model application instructions and add relevant descriptions of DMA functions;<br>(8) Add description of ADC temperature sensor<br>(9) Modify the edge alignment count to center alignment count in the PWM output mode of the timer chapter, and add a description of the debugging mode function<br>(10) Added version and model applicability instructions in USBD and CAN chapters, as well as shared instructions between USBD and CAN<br>(11) Modify number of bytes in the BAKPR module |

| Date             | Version | Change History                                                                                                                                     |
|------------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------|
|                  |         | (12) Modify the description of "complementary" in the option byte to "bit complement"                                                              |
| November 9, 2023 | 1.8     | (1) Modify the figure of GPIO Structure Block Diagram, Input Mode Structure , I/O Structure in Output Mode and I/O Structure in Multiplexing Mode. |

# Statement

This document is formulated and published by Geehy Semiconductor Co., Ltd. (hereinafter referred to as “Geehy”). The contents in this document are protected by laws and regulations of trademark, copyright and software copyright. Geehy reserves the right to make corrections and modifications to this document at any time. Please read this document carefully before using Geehy products. Once you use the Geehy product, it means that you (hereinafter referred to as the “users”) have known and accepted all the contents of this document. Users shall use the Geehy product in accordance with relevant laws and regulations and the requirements of this document.

## 1. Ownership

This document can only be used in connection with the corresponding chip products or software products provided by Geehy. Without the prior permission of Geehy, no unit or individual may copy, transcribe, modify, edit or disseminate all or part of the contents of this document for any reason or in any form.

The “极海” or “Geehy” words or graphics with “®” or “™” in this document are trademarks of Geehy. Other product or service names displayed on Geehy products are the property of their respective owners.

## 2. No Intellectual Property License

Geehy owns all rights, ownership and intellectual property rights involved in this document.

Geehy shall not be deemed to grant the license or right of any intellectual property to users explicitly or implicitly due to the sale or distribution of Geehy products or this document.

If any third party’s products, services or intellectual property are involved in this document, it shall not be deemed that Geehy authorizes users to use the aforesaid third party’s products, services or intellectual property, unless otherwise agreed in sales order or sales contract.

## 3. Version Update

Users can obtain the latest document of the corresponding models when ordering Geehy products.

If the contents in this document are inconsistent with Geehy products, the agreement in the sales order or the sales contract shall prevail.

#### 4. Information Reliability

The relevant data in this document are obtained from batch test by Geehy Laboratory or cooperative third-party testing organization. However, clerical errors in correction or errors caused by differences in testing environment may occur inevitably. Therefore, users should understand that Geehy does not bear any responsibility for such errors that may occur in this document. The relevant data in this document are only used to guide users as performance parameter reference and do not constitute Geehy's guarantee for any product performance.

Users shall select appropriate Geehy products according to their own needs, and effectively verify and test the applicability of Geehy products to confirm that Geehy products meet their own needs, corresponding standards, safety or other reliability requirements. If losses are caused to users due to the user's failure to fully verify and test Geehy products, Geehy will not bear any responsibility.

#### 5. Legality

USERS SHALL ABIDE BY ALL APPLICABLE LOCAL LAWS AND REGULATIONS WHEN USING THIS DOCUMENT AND THE MATCHING GEEHY PRODUCTS. USERS SHALL UNDERSTAND THAT THE PRODUCTS MAY BE RESTRICTED BY THE EXPORT, RE-EXPORT OR OTHER LAWS OF THE COUNTRIES OF THE PRODUCTS SUPPLIERS, GEEHY, GEEHY DISTRIBUTORS AND USERS. USERS (ON BEHALF OR ITSELF, SUBSIDIARIES AND AFFILIATED ENTERPRISES) SHALL AGREE AND PROMISE TO ABIDE BY ALL APPLICABLE LAWS AND REGULATIONS ON THE EXPORT AND RE-EXPORT OF GEEHY PRODUCTS AND/OR TECHNOLOGIES AND DIRECT PRODUCTS.

#### 6. Disclaimer of Warranty

THIS DOCUMENT IS PROVIDED BY GEEHY "AS IS" AND THERE IS NO WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, TO THE EXTENT PERMITTED BY APPLICABLE LAW.

GEEHY WILL BEAR NO RESPONSIBILITY FOR ANY DISPUTES ARISING FROM THE SUBSEQUENT DESIGN OR USE BY USERS.

#### 7. Limitation of Liability

IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING WILL GEEHY OR ANY OTHER PARTY WHO PROVIDE THE DOCUMENT "AS IS", BE LIABLE FOR DAMAGES, INCLUDING ANY GENERAL, SPECIAL, DIRECT, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OR INABILITY TO USE THE DOCUMENT (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY USERS OR THIRD PARTIES).

#### 8. Scope of Application

The information in this document replaces the information provided in all previous versions of the document.

© 2020-2023 Geehy Semiconductor Co., Ltd. - All Rights Reserved