



用户手册

User Manual

**MM32F0020**

基于Arm®Cortex®-M0内核的32位微控制器

---

版本：1.01

保留不通知的情况下，更改相关资料的权利

---

# 目录

|                                        |    |
|----------------------------------------|----|
| 目录.....                                | 1  |
| 附图目录 .....                             | 12 |
| 表格目录 .....                             | 16 |
| 1 系统和存储器架构 .....                       | 18 |
| 1.1 系统架构简介.....                        | 18 |
| 1.1.1 系统总线 .....                       | 19 |
| 1.1.2 总线矩阵 .....                       | 19 |
| 1.2 存储器介绍 .....                        | 19 |
| 1.2.1 存储器映像和寄存器编址.....                 | 19 |
| 1.2.2 内置的 SRAM .....                   | 21 |
| 1.2.3 闪存存储器概述 .....                    | 21 |
| 1.2.4 启动配置 .....                       | 21 |
| 1.2.5 引导程序 .....                       | 22 |
| 2 Embedded FLASH 嵌入式闪存 .....           | 23 |
| 2.1 简介 .....                           | 23 |
| 2.2 闪存构成与说明 .....                      | 23 |
| 2.2.1 闪存构成 .....                       | 23 |
| 2.2.2 选项字节说明.....                      | 24 |
| 2.2.3 保密空间说明.....                      | 26 |
| 2.3 闪存操作与流程 .....                      | 26 |
| 2.3.1 闪存读操作 .....                      | 26 |
| 2.3.2 闪存编程方式与操作流程.....                 | 26 |
| 2.3.3 对闪存块操作限制的解除与使能.....              | 29 |
| 2.3.4 对选项字节区块操作限制的解除与使能.....           | 30 |
| 2.3.5 主闪存块擦除 .....                     | 32 |
| 2.3.6 主闪存块编程 .....                     | 34 |
| 2.3.7 选项字节区块擦除.....                    | 35 |
| 2.3.8 选项字节区块编程.....                    | 36 |
| 2.3.9 闪存保护 .....                       | 37 |
| 2.4 寄存器.....                           | 39 |
| 2.4.1 寄存器总览 .....                      | 39 |
| 2.4.2 FLASH_ACR 闪存访问控制寄存器.....         | 39 |
| 2.4.3 FLASH_KEYR FPEC 键寄存器.....        | 40 |
| 2.4.4 FLASH_OPTKEYR 闪存 OPTKEY 寄存器..... | 41 |
| 2.4.5 FLASH_SR 闪存状态寄存器 .....           | 41 |
| 2.4.6 FLASH_CR 闪存控制寄存器 .....           | 42 |
| 2.4.7 FLASH_AR 闪存地址寄存器 .....           | 43 |
| 2.4.8 FLASH_OBR 选项字节寄存器.....           | 43 |
| 2.4.9 FLASH_WRPTR 写保护寄存器 .....         | 44 |
| 3 PWR 电源控制.....                        | 45 |

|       |                                  |    |
|-------|----------------------------------|----|
| 3.1   | 供电系统 .....                       | 45 |
| 3.1.1 | 模拟模块供电 .....                     | 45 |
| 3.1.2 | 数字模块供电 .....                     | 46 |
| 3.1.3 | VDD 域 .....                      | 46 |
| 3.1.4 | 1.5V 域 .....                     | 46 |
| 3.2   | 电源管理器 .....                      | 46 |
| 3.2.1 | POR 上电复位和 PDR 掉电复位 .....         | 46 |
| 3.2.2 | PVD 可编程电压监测器 .....               | 47 |
| 3.3   | 功耗控制 .....                       | 48 |
| 3.3.1 | 功耗控制概述 .....                     | 48 |
| 3.3.2 | 运行模式降低系统时钟 .....                 | 49 |
| 3.3.3 | 外设时钟的控制 .....                    | 49 |
| 3.3.4 | Sleep Mode 睡眠模式 .....            | 50 |
| 3.3.5 | Stop Mode 停机模式 .....             | 51 |
| 3.3.6 | DeepStop Mode 深度停机模式 .....       | 52 |
| 3.3.7 | Standby Mode 待机模式 .....          | 53 |
| 3.4   | 调试模式 .....                       | 55 |
| 3.5   | 电源控制寄存器 .....                    | 55 |
| 3.5.1 | PWR_CR 电源控制寄存器 .....             | 55 |
| 3.5.2 | PWR_CSR 电源控制/状态寄存器 .....         | 56 |
| 3.5.3 | PWR_CR1 电源控制寄存器 1 .....          | 57 |
| 3.5.4 | PWR_CFGR 电源配置寄存器 .....           | 58 |
| 4     | SYSCFG 系统控制器 .....               | 59 |
| 4.1   | 简介 .....                         | 59 |
| 4.2   | 寄存器 .....                        | 59 |
| 4.2.1 | 寄存器总览 .....                      | 59 |
| 4.2.2 | SYSCFG_CFGR 配置寄存器 .....          | 59 |
| 4.2.3 | SYSCFG_EXTICR1 外部中断配置寄存器 1 ..... | 60 |
| 4.2.4 | SYSCFG_EXTICR2 外部中断配置寄存器 2 ..... | 60 |
| 4.2.5 | SYSCFG_EXTICR3 外部中断配置寄存器 3 ..... | 61 |
| 4.2.6 | SYSCFG_EXTICR4 外部中断配置寄存器 4 ..... | 61 |
| 4.2.7 | SYSCFG_PADHYS PAD 配置寄存器 .....    | 62 |
| 5     | RCC 时钟和复位 .....                  | 63 |
| 5.1   | 复位单元 .....                       | 63 |
| 5.1.1 | 简介 .....                         | 63 |
| 5.1.2 | 功能框图 .....                       | 63 |
| 5.1.3 | 主要特征 .....                       | 63 |
| 5.1.4 | 功能描述 .....                       | 63 |
| 5.2   | 时钟单元 .....                       | 65 |
| 5.2.1 | 简介 .....                         | 65 |
| 5.2.2 | 功能框图 .....                       | 66 |
| 5.2.3 | 主要特征 .....                       | 66 |
| 5.2.4 | 功能描述 .....                       | 66 |
| 5.3   | 寄存器 .....                        | 73 |

|        |                                  |     |
|--------|----------------------------------|-----|
| 5.3.1  | 寄存器总览 .....                      | 73  |
| 5.3.2  | RCC_CR 时钟控制寄存器 .....             | 74  |
| 5.3.3  | RCC_CFGR 时钟配置寄存器 .....           | 75  |
| 5.3.4  | RCC_CIR 时钟中断寄存器 .....            | 77  |
| 5.3.5  | RCC_APB1RSTR APB1 外设复位寄存器 .....  | 79  |
| 5.3.6  | RCC_AHBENR AHB 外设时钟使能寄存器 .....   | 81  |
| 5.3.7  | RCC_APB1ENR APB1 外设时钟使能寄存器 ..... | 82  |
| 5.3.8  | RCC_CSR 控制状态寄存器 .....            | 84  |
| 5.3.9  | RCC_AHBRSTR AHB 外设复位寄存器 .....    | 86  |
| 5.3.10 | RCC_CFGR2 时钟配置寄存器 2 .....        | 87  |
| 5.3.11 | RCC_SYSCFG 系统配置寄存器 .....         | 87  |
| 5.3.12 | RCC_PLLCFGR PLL 配置寄存器 .....      | 88  |
| 6      | CRC 循环冗余校验计算单元 .....             | 90  |
| 6.1    | 简介 .....                         | 90  |
| 6.2    | 主要特征 .....                       | 90  |
| 6.3    | 功能描述 .....                       | 90  |
| 6.3.1  | 功能框图 .....                       | 90  |
| 6.3.2  | 功能概述 .....                       | 91  |
| 6.3.3  | 使用方法 .....                       | 91  |
| 6.4    | 寄存器 .....                        | 92  |
| 6.4.1  | 寄存器总览 .....                      | 92  |
| 6.4.2  | CRC_DR CRC 数据寄存器 .....           | 92  |
| 6.4.3  | CRC_IDR CRC 独立数据寄存器 .....        | 93  |
| 6.4.4  | CRC_CR CRC 控制寄存器 .....           | 93  |
| 6.4.5  | CRC_MIR CRC 中间数据寄存器 .....        | 94  |
| 7      | GPIO 通用端口 .....                  | 95  |
| 7.1    | 简介 .....                         | 95  |
| 7.2    | 主要特征 .....                       | 95  |
| 7.3    | 功能描述 .....                       | 96  |
| 7.3.1  | 功能框图 .....                       | 96  |
| 7.3.2  | GPIO 端口配置 .....                  | 96  |
| 7.3.3  | 复用功能 .....                       | 97  |
| 7.3.4  | GPIO 锁定机制 .....                  | 97  |
| 7.3.5  | 输入配置 .....                       | 98  |
| 7.3.6  | 输出配置 .....                       | 99  |
| 7.3.7  | 复用功能配置 .....                     | 99  |
| 7.3.8  | 模拟输入配置 .....                     | 100 |
| 7.3.9  | 外部时钟复用 GPIO 端口 .....             | 101 |
| 7.3.10 | NRST 复用功能重映射 .....               | 101 |
| 7.3.11 | SWD 复用功能重映射 .....                | 101 |
| 7.4    | GPIO 寄存器描述 .....                 | 101 |
| 7.4.1  | 寄存器总览 .....                      | 101 |
| 7.4.2  | GPIOx_CRL 端口配置低寄存器 .....         | 102 |
| 7.4.3  | GPIOx_CRH 端口配置高寄存器 .....         | 103 |

|        |                                           |     |
|--------|-------------------------------------------|-----|
| 7.4.4  | <code>GPIOx_IDR</code> 端口输入数据寄存器 .....    | 103 |
| 7.4.5  | <code>GPIOx_ODR</code> 端口输出数据寄存器 .....    | 104 |
| 7.4.6  | <code>GPIOx_BSRR</code> 端口设置/清除寄存器 .....  | 104 |
| 7.4.7  | <code>GPIOx_BRR</code> 端口位清除寄存器 .....     | 105 |
| 7.4.8  | <code>GPIOx_LCKR</code> 端口配置锁定寄存器 .....   | 105 |
| 7.4.9  | <code>GPIOx_DCR</code> 端口输出开漏控制寄存器 .....  | 106 |
| 7.4.10 | <code>GPIOx_AFRL</code> 端口复用功能低位寄存器 ..... | 106 |
| 7.4.11 | <code>GPIOx_AFRH</code> 端口复用功能高位寄存器 ..... | 107 |
| 8      | EXTI 中断和事件 .....                          | 108 |
| 8.1    | 简介 .....                                  | 108 |
| 8.2    | 主要特征 .....                                | 108 |
| 8.3    | 功能描述 .....                                | 109 |
| 8.3.1  | 功能框图 .....                                | 109 |
| 8.3.2  | 中断和异常向量 .....                             | 109 |
| 8.3.3  | 唤醒事件管理 .....                              | 111 |
| 8.3.4  | 中断功能描述 .....                              | 111 |
| 8.3.5  | 硬件中断输出 .....                              | 111 |
| 8.3.6  | 硬件事件输出 .....                              | 111 |
| 8.3.7  | 软件中断与事件输出 .....                           | 112 |
| 8.3.8  | 外部中断映射 .....                              | 112 |
| 8.4    | 寄存器描述 .....                               | 113 |
| 8.4.1  | 寄存器总览 .....                               | 113 |
| 8.4.2  | <code>EXTI_IMR</code> 中断屏蔽寄存器 .....       | 113 |
| 8.4.3  | <code>EXTI_EMR</code> 事件屏蔽寄存器 .....       | 113 |
| 8.4.4  | <code>EXTI_RTSR</code> 上升沿触发选择寄存器 .....   | 114 |
| 8.4.5  | <code>EXTI_FTSR</code> 下降沿触发选择寄存器 .....   | 114 |
| 8.4.6  | <code>EXTI_SWIER</code> 软件中断事件寄存器 .....   | 115 |
| 8.4.7  | <code>EXTI_PR</code> 软件中断事件挂起寄存器 .....    | 115 |
| 9      | ADC 模拟/数字转换 .....                         | 117 |
| 9.1    | 简介 .....                                  | 117 |
| 9.2    | 功能框图 .....                                | 117 |
| 9.3    | 主要特征 .....                                | 117 |
| 9.4    | 中断 .....                                  | 118 |
| 9.5    | 功能描述 .....                                | 119 |
| 9.5.1  | 时钟 .....                                  | 119 |
| 9.5.2  | 数据补偿 .....                                | 119 |
| 9.5.3  | 数据对齐 .....                                | 119 |
| 9.5.4  | 可编程分辨率 .....                              | 120 |
| 9.5.5  | 可编程采样时间 .....                             | 120 |
| 9.5.6  | 数据通道寄存器 .....                             | 121 |
| 9.5.7  | 通道选择 .....                                | 121 |
| 9.6    | ADC 开关 .....                              | 121 |
| 9.6.1  | 普通通道转换 .....                              | 121 |
| 9.6.2  | 任意通道转换 .....                              | 124 |

|        |                                            |     |
|--------|--------------------------------------------|-----|
| 9.6.3  | 注入通道转换.....                                | 127 |
| 9.6.4  | ADC 触发信号 .....                             | 129 |
| 9.6.5  | 模拟看门狗 .....                                | 129 |
| 9.6.6  | 内部电压传感器 .....                              | 129 |
| 9.7    | 寄存器.....                                   | 130 |
| 9.7.1  | 寄存器总览 .....                                | 130 |
| 9.7.2  | ADC_ADDATA 数据寄存器.....                      | 130 |
| 9.7.3  | ADC_ADCFG 配置寄存器 .....                      | 131 |
| 9.7.4  | ADC_ADCR 控制寄存器.....                        | 132 |
| 9.7.5  | ADC_ADCHS 通道选择寄存器.....                     | 135 |
| 9.7.6  | ADC_ADCMPR 模拟看门狗比较寄存器.....                 | 136 |
| 9.7.7  | ADC_ADSTA 状态寄存器 .....                      | 137 |
| 9.7.8  | ADC_ADDRn 通道数据寄存器( $n=0\sim 8$ ) .....     | 138 |
| 9.7.9  | ADC_ADSTA_EXT 扩展状态寄存器.....                 | 138 |
| 9.7.10 | ADC_CHANY0 任意通道的通道选择寄存器 0.....             | 139 |
| 9.7.11 | ADC_CHANY1 任意通道的通道选择寄存器 1.....             | 141 |
| 9.7.12 | ADC_ANY_CFG 任意通道配置寄存器 .....                | 142 |
| 9.7.13 | ADC_ANY_CR 任意通道控制寄存器.....                  | 143 |
| 9.7.14 | ADC_SMPR1 采样配置寄存器 1 .....                  | 145 |
| 9.7.15 | ADC_SMPR2 采样配置寄存器 2 .....                  | 145 |
| 9.7.16 | ADC_JOFRn 注入通道数据补偿寄存器( $n=0\sim 3$ ) ..... | 146 |
| 9.7.17 | ADC_JSQR 注入通道序列寄存器.....                    | 147 |
| 9.7.18 | ADC_JADDATA 注入数据寄存器.....                   | 148 |
| 9.7.19 | ADC_JDRn 注入通道数据寄存器( $n=0\sim 3$ ) .....    | 148 |
| 10     | TIM1 高级定时器 .....                           | 150 |
| 10.1   | 简介 .....                                   | 150 |
| 10.2   | 功能框图 .....                                 | 150 |
| 10.3   | 主要特征 .....                                 | 151 |
| 10.4   | 功能描述 .....                                 | 151 |
| 10.4.1 | 时钟 .....                                   | 151 |
| 10.4.2 | 重复计数器 .....                                | 156 |
| 10.4.3 | 输入捕获 .....                                 | 158 |
| 10.4.4 | 比较输出 .....                                 | 160 |
| 10.4.5 | 从模式 .....                                  | 172 |
| 10.4.6 | 定时器同步 .....                                | 175 |
| 10.4.7 | 定时器异或 .....                                | 177 |
| 10.4.8 | 调试模式 .....                                 | 179 |
| 10.4.9 | 中断 .....                                   | 179 |
| 10.5   | 寄存器描述 .....                                | 180 |
| 10.5.1 | TIM1_CR1 控制寄存器 1 .....                     | 181 |
| 10.5.2 | TIM1_CR2 控制寄存器 2 .....                     | 182 |
| 10.5.3 | TIM1_SMCR 从模式控制寄存器 .....                   | 183 |
| 10.5.4 | TIM1_DIER 中断使能寄存器 .....                    | 185 |
| 10.5.5 | TIM1_SR 状态寄存器 .....                        | 186 |

|         |                                        |     |
|---------|----------------------------------------|-----|
| 10.5.6  | TIM1_EGR 事件产生寄存器 .....                 | 188 |
| 10.5.7  | TIM1_CCMR1 捕获/比较模式寄存器 1.....           | 189 |
| 10.5.8  | TIM1_CCMR2 捕获/比较模式寄存器 2.....           | 193 |
| 10.5.9  | TIM1_CCER 捕获/比较使能寄存器 .....             | 197 |
| 10.5.10 | TIM1_CNT 计数器 .....                     | 199 |
| 10.5.11 | TIM1_PSC 预分频器 .....                    | 200 |
| 10.5.12 | TIM1_ARR 自动预装载寄存器.....                 | 200 |
| 10.5.13 | TIM1_RCR 重复计数寄存器 .....                 | 200 |
| 10.5.14 | TIM1_CCR1 捕获/比较寄存器 1.....              | 201 |
| 10.5.15 | TIM1_CCR2 捕获/比较寄存器 2.....              | 201 |
| 10.5.16 | TIM1_CCR3 捕获/比较寄存器 3.....              | 202 |
| 10.5.17 | TIM1_CCR4 捕获/比较寄存器 4 .....             | 202 |
| 10.5.18 | TIM1_BDTR 刹车和死区寄存器 .....               | 202 |
| 10.5.19 | TIM1_CCMR3 捕获/比较模式寄存器 3.....           | 204 |
| 10.5.20 | TIM1_CCR5 捕获/比较寄存器 5 .....             | 205 |
| 10.5.21 | TIM1_PDER PWM 移相使能寄存器 .....            | 205 |
| 10.5.22 | TIM1_CCRxFALL PWM 移相递减计数捕获/比较寄存器 ..... | 206 |
| 10.5.23 | TIM1_BKINF 刹车输入滤波寄存器 .....             | 207 |
| 11      | TIM3 通用定时器 .....                       | 209 |
| 11.1    | 简介 .....                               | 209 |
| 11.2    | 功能框图 .....                             | 209 |
| 11.3    | 主要特征 .....                             | 209 |
| 11.4    | 功能描述 .....                             | 210 |
| 11.4.1  | 时钟 .....                               | 210 |
| 11.4.2  | 输入捕获 .....                             | 215 |
| 11.4.3  | 比较输出 .....                             | 217 |
| 11.4.4  | 从模式 .....                              | 224 |
| 11.4.5  | 定时器同步 .....                            | 228 |
| 11.4.6  | 定时器异或 .....                            | 228 |
| 11.4.7  | 调试模式 .....                             | 229 |
| 11.4.8  | 中断 .....                               | 229 |
| 11.5    | 寄存器描述 .....                            | 229 |
| 11.5.1  | TIM3_CR1 控制寄存器 1 .....                 | 230 |
| 11.5.2  | TIM3_CR2 控制寄存器 2 .....                 | 231 |
| 11.5.3  | TIM3_SMCR 从模式控制寄存器 .....               | 232 |
| 11.5.4  | TIM3_DIER 中断使能寄存器 .....                | 235 |
| 11.5.5  | TIM3_SR 状态寄存器 .....                    | 236 |
| 11.5.6  | TIM3_EGR 事件产生寄存器 .....                 | 238 |
| 11.5.7  | TIM3_CCMR1 捕获/比较模式寄存器 1 .....          | 238 |
| 11.5.8  | TIM3_CCMR2 捕获/比较模式寄存器 2 .....          | 242 |
| 11.5.9  | TIM3_CCER 捕获/比较使能寄存器 .....             | 246 |
| 11.5.10 | TIM3_CNT 计数器 .....                     | 248 |
| 11.5.11 | TIM3_PSC 预分频器 .....                    | 248 |
| 11.5.12 | TIM3_ARR 自动预装载寄存器 .....                | 249 |

|         |                          |     |
|---------|--------------------------|-----|
| 11.5.13 | TIM3_CCR1 捕获/比较寄存器 1     | 249 |
| 11.5.14 | TIM3_CCR2 捕获/比较寄存器 2     | 250 |
| 11.5.15 | TIM3_CCR3 捕获/比较寄存器 3     | 250 |
| 11.5.16 | TIM3_CCR4 捕获/比较寄存器 4     | 250 |
| 11.5.17 | TIM3_OR 输入选项寄存器          | 251 |
| 12      | TIM14 基本定时器              | 252 |
| 12.1    | 简介                       | 252 |
| 12.2    | 功能框图                     | 252 |
| 12.3    | 主要特征                     | 252 |
| 12.4    | 功能描述                     | 253 |
| 12.4.1  | 时钟                       | 253 |
| 12.4.2  | 输入捕获                     | 254 |
| 12.4.3  | 比较输出                     | 255 |
| 12.4.4  | 调试模式                     | 258 |
| 12.4.5  | 中断                       | 258 |
| 12.5    | 寄存器描述                    | 259 |
| 12.5.1  | TIM14_CR1 控制寄存器 1        | 259 |
| 12.5.2  | TIM14_DIER 中断使能寄存器       | 260 |
| 12.5.3  | TIM14_SR 状态寄存器           | 260 |
| 12.5.4  | TIM14_EGR 事件产生寄存器        | 261 |
| 12.5.5  | TIM14_CCMR1 捕获/比较模式寄存器 1 | 262 |
| 12.5.6  | TIM14_CCER 捕获/比较使能寄存器    | 264 |
| 12.5.7  | TIM14_CNT 计数器            | 265 |
| 12.5.8  | TIM14_PSC 预分频器           | 266 |
| 12.5.9  | TIM14_ARR 自动预装载寄存器       | 266 |
| 12.5.10 | TIM14_CCR1 捕获/比较寄存器 1    | 266 |
| 12.5.11 | TIM14_BDTR 输出控制寄存器       | 267 |
| 13      | WWDG 窗口看门狗               | 268 |
| 13.1    | 简介                       | 268 |
| 13.2    | 功能框图                     | 268 |
| 13.3    | 主要特征                     | 268 |
| 13.4    | 功能描述                     | 269 |
| 13.5    | 窗口看门狗超时时间                | 270 |
| 13.6    | 寄存器描述                    | 270 |
| 13.6.1  | 控制寄存器 (WWDG_CR)          | 271 |
| 13.6.2  | 配置寄存器 (WWDG_CFGR)        | 271 |
| 13.6.3  | 状态寄存器 (WWDG_SR)          | 272 |
| 14      | IWDG 独立看门狗               | 273 |
| 14.1    | 简介                       | 273 |
| 14.2    | 功能框图                     | 274 |
| 14.3    | 主要特征                     | 274 |
| 14.4    | 功能描述                     | 275 |
| 14.4.1  | 流程框图                     | 276 |
| 14.4.2  | 独立看门狗超时时间                | 276 |

|         |                           |     |
|---------|---------------------------|-----|
| 14.4.3  | 中断 .....                  | 277 |
| 14.5    | 寄存器描述 .....               | 277 |
| 14.5.1  | 寄存器总览 .....               | 277 |
| 14.5.2  | IWDG_KR 键寄存器 .....        | 277 |
| 14.5.3  | IWDG_PR 预分频寄存器 .....      | 278 |
| 14.5.4  | IWDG_RLR 重装载寄存器 .....     | 279 |
| 14.5.5  | IWDG_SR 状态寄存器 .....       | 279 |
| 14.5.6  | IWDG_CR 控制寄存器 .....       | 280 |
| 14.5.7  | IWDG_IGEN 中断生成寄存器 .....   | 281 |
| 14.5.8  | IWDG_CNT 计数寄存器 .....      | 281 |
| 15      | UART 通用异步收发器 .....        | 282 |
| 15.1    | 简介 .....                  | 282 |
| 15.2    | 功能框图 .....                | 282 |
| 15.3    | 主要特征 .....                | 282 |
| 15.4    | 功能概述 .....                | 283 |
| 15.4.1  | UART 特性描述 .....           | 283 |
| 15.4.2  | 分数波特率发生器 .....            | 284 |
| 15.4.3  | 采样 .....                  | 284 |
| 15.4.4  | 容忍度 .....                 | 285 |
| 15.4.5  | 校验控制 .....                | 285 |
| 15.4.6  | 发送器 .....                 | 285 |
| 15.4.7  | 接收器 .....                 | 287 |
| 15.4.8  | 自动波特率检测 .....             | 288 |
| 15.4.9  | 九位数据通信 .....              | 289 |
| 15.4.10 | 多处理器通信 .....              | 289 |
| 15.4.11 | 单线半双工通信 .....             | 291 |
| 15.4.12 | 智能卡 .....                 | 291 |
| 15.4.13 | 红外 IrDA 功能 .....          | 293 |
| 15.5    | 中断 .....                  | 294 |
| 15.6    | 寄存器 .....                 | 295 |
| 15.6.1  | 寄存器总览 .....               | 295 |
| 15.6.2  | UART_TDR 发送数据寄存器 .....    | 295 |
| 15.6.3  | UART_RDR 接收数据寄存器 .....    | 296 |
| 15.6.4  | UART_CSR 当前状态寄存器 .....    | 296 |
| 15.6.5  | UART_ISR 中断状态寄存器 .....    | 297 |
| 15.6.6  | UART_IER 中断使能寄存器 .....    | 298 |
| 15.6.7  | UART_ICR 中断清除寄存器 .....    | 300 |
| 15.6.8  | UART_GCR 全局控制寄存器 .....    | 301 |
| 15.6.9  | UART_CCR 通用空制寄存器 .....    | 302 |
| 15.6.10 | UART_BRR 波特率寄存器 .....     | 303 |
| 15.6.11 | UART_FRA 分数波特率寄存器 .....   | 304 |
| 15.6.12 | UART_RXADDR 接收地址寄存器 ..... | 304 |
| 15.6.13 | UART_RXMASK 接收掩码寄存器 ..... | 305 |
| 15.6.14 | UART_SCR SCR 寄存器 .....    | 305 |

|         |                                 |     |
|---------|---------------------------------|-----|
| 15.6.15 | UART_IDLR IDLE 数据长度寄存器 .....    | 306 |
| 15.6.16 | UART_ABRCR 自动波特率寄存器 .....       | 306 |
| 15.6.17 | UART_IRDA 红外功能控制寄存器.....        | 307 |
| 16      | SPI_I2S 串行外设接口 .....            | 309 |
| 16.1    | SPI_I2S 功能框图 .....              | 309 |
| 16.2    | SPI_I2S 简述 .....                | 309 |
| 16.3    | SPI 功能描述 .....                  | 310 |
| 16.3.1  | 概述 .....                        | 310 |
| 16.3.2  | SPI 主要特征 .....                  | 312 |
| 16.3.3  | SPI 从模式 .....                   | 313 |
| 16.3.4  | SPI 主模式 .....                   | 314 |
| 16.3.5  | 波特率设置 .....                     | 315 |
| 16.3.6  | 中断 .....                        | 315 |
| 16.4    | I2S 功能描述 .....                  | 316 |
| 16.4.1  | I2S 主要特征 .....                  | 316 |
| 16.4.2  | I2S 总线接口 .....                  | 316 |
| 16.4.3  | 数据格式 .....                      | 317 |
| 16.4.4  | 通信标准 .....                      | 317 |
| 16.4.5  | 从模式 .....                       | 320 |
| 16.4.6  | 主模式 .....                       | 320 |
| 16.4.7  | 时钟预分频器 .....                    | 321 |
| 16.4.8  | 中断 .....                        | 323 |
| 16.5    | 寄存器 .....                       | 324 |
| 16.5.1  | 寄存器总览 .....                     | 324 |
| 16.5.2  | SPI_I2S_TXREG 发送数据寄存器 .....     | 324 |
| 16.5.3  | SPI_I2S_RXREG 接收数据寄存器 .....     | 324 |
| 16.5.4  | SPI_I2S_CSTAT 当前状态寄存器 .....     | 325 |
| 16.5.5  | SPI_I2S_INTSTAT 中断状态寄存器 .....   | 326 |
| 16.5.6  | SPI_I2S_INTEN 中断使能寄存器 .....     | 327 |
| 16.5.7  | SPI_I2S_INTCLR 中断清除寄存器 .....    | 328 |
| 16.5.8  | SPI_I2S_GCTL 全局控制寄存器 .....      | 329 |
| 16.5.9  | SPI_I2S_CCTL 通用控制寄存器 .....      | 331 |
| 16.5.10 | SPI_I2S_SPBRG 波特率发生器 .....      | 332 |
| 16.5.11 | SPI_I2S_RXDNR 接收数据个数寄存器 .....   | 333 |
| 16.5.12 | SPI_I2S_NSSR 从机片选寄存器 .....      | 333 |
| 16.5.13 | SPI_I2S_EXTCTL 数据控制寄存器 .....    | 333 |
| 16.5.14 | SPI_I2S_I2SCFGR I2S 配置寄存器 ..... | 334 |
| 17      | I2C 内部集成电路接口 .....              | 336 |
| 17.1    | 简介 .....                        | 336 |
| 17.2    | 主要特征 .....                      | 336 |
| 17.3    | 功能描述 .....                      | 337 |
| 17.3.1  | 功能框图 .....                      | 337 |
| 17.3.2  | 信号描述 .....                      | 338 |
| 17.3.3  | I2C 协议 .....                    | 338 |

|         |                                      |     |
|---------|--------------------------------------|-----|
| 17.3.4  | 工作模式 .....                           | 345 |
| 17.3.5  | 中断 .....                             | 350 |
| 17.4    | 寄存器.....                             | 351 |
| 17.4.1  | 寄存器总览 .....                          | 351 |
| 17.4.2  | I2C_CR 控制寄存器.....                    | 352 |
| 17.4.3  | I2C_TAR 目标地址寄存器.....                 | 354 |
| 17.4.4  | I2C_SAR 从地址寄存器.....                  | 355 |
| 17.4.5  | I2C_DR 数据命令寄存器 .....                 | 355 |
| 17.4.6  | I2C_SSHR 标准模式时钟高电平计数寄存器.....         | 355 |
| 17.4.7  | I2C_SSLR 标准模式时钟低电平计数寄存器.....         | 356 |
| 17.4.8  | I2C_FSHR 快速模式时钟高电平计数寄存器 .....        | 356 |
| 17.4.9  | I2C_FSLR 快速模式时钟低电平计数寄存器.....         | 357 |
| 17.4.10 | I2C_ISR 中断状态寄存器.....                 | 357 |
| 17.4.11 | I2C_IMR 中断屏蔽寄存器.....                 | 357 |
| 17.4.12 | I2C_RAWISR RAW 中断寄存器 .....           | 358 |
| 17.4.13 | I2C_RXTLR 接收阈值.....                  | 359 |
| 17.4.14 | I2C_TXTLR 发送阈值 .....                 | 360 |
| 17.4.15 | I2C_ICR 组合和独立中断清除寄存器 .....           | 360 |
| 17.4.16 | I2C_RX_UNDER 清除 RX_UNDER 中断寄存器 ..... | 361 |
| 17.4.17 | I2C_RX_OVER 清除 RX_OVER 中断寄存器 .....   | 361 |
| 17.4.18 | I2C_TX_OVER 清除 TX_OVER 中断寄存器 .....   | 361 |
| 17.4.19 | I2C_RD_REQ 清除 RD_REQ 中断寄存器 .....     | 362 |
| 17.4.20 | I2C_TX_ABRT 清除 TX_ABRT 中断寄存器 .....   | 362 |
| 17.4.21 | I2C_RX_DONE 清除 RX_DONE 中断寄存器 .....   | 363 |
| 17.4.22 | I2C_ACTIV 清除 ACTIVITY 中断寄存器 .....    | 363 |
| 17.4.23 | I2C_STOP 清除 STOP_DET 中断寄存器 .....     | 364 |
| 17.4.24 | I2C_START 清除 START_DET 中断寄存器 .....   | 364 |
| 17.4.25 | I2C_GC 清除 GEN_CALL 中断寄存器 .....       | 364 |
| 17.4.26 | I2C_ENR 使能寄存器 .....                  | 365 |
| 17.4.27 | I2C_SR 状态寄存器 .....                   | 365 |
| 17.4.28 | I2C_TXFLR 发送缓冲级别寄存器 .....            | 366 |
| 17.4.29 | I2C_RXFLR 接收缓冲级别寄存器 .....            | 367 |
| 17.4.30 | I2C_HOLD SDA 保持时间寄存器 .....           | 367 |
| 17.4.31 | I2C_SETUP SDA 建立时间寄存器 .....          | 367 |
| 17.4.32 | I2C_GCR 广播呼叫 ACK 寄存器 .....           | 368 |
| 17.4.33 | I2C_SLVMASK 从地址掩码寄存器 .....           | 368 |
| 17.4.34 | I2C_SLVRCVADDR 从器件接收地址寄存器 .....      | 369 |
| 18      | DBG 调试支持 .....                       | 370 |
| 18.1    | 简介 .....                             | 370 |
| 18.2    | 功能描述 .....                           | 370 |
| 18.2.1  | 功能框图 .....                           | 370 |
| 18.2.2  | SWD 内部上拉与下拉 .....                    | 371 |
| 18.2.3  | SWJ 调试端口 .....                       | 371 |
| 18.3    | ID 代码和锁定机制.....                      | 371 |

|        |                                               |     |
|--------|-----------------------------------------------|-----|
| 18.3.1 | 微控制器设备 ID 编码 .....                            | 371 |
| 18.3.2 | Cortex JEDEC-106 ID 编码 .....                  | 371 |
| 18.4   | SW 调试端口 .....                                 | 372 |
| 18.4.1 | SW 协议介绍 .....                                 | 372 |
| 18.4.2 | SW 协议序列 .....                                 | 372 |
| 18.4.3 | SW-DP 状态机 (Reset, Idle states, ID code) ..... | 373 |
| 18.4.4 | DP 和 AP 读 / 写访问 .....                         | 373 |
| 18.4.5 | SW-DP 寄存器 .....                               | 373 |
| 18.4.6 | SW-AP 寄存器 .....                               | 374 |
| 18.5   | MCU 调试模块 (DBGMCU) .....                       | 374 |
| 18.5.1 | 低功耗模式的调试支持 .....                              | 374 |
| 18.5.2 | 支持定时器、看门狗 .....                               | 375 |
| 18.6   | 寄存器 .....                                     | 375 |
| 18.6.1 | 寄存器总览 .....                                   | 375 |
| 18.6.2 | DBG_IDCODE ID 编码寄存器 .....                     | 375 |
| 18.6.3 | DBG_CR 控制寄存器 .....                            | 375 |
| 19     | Device Electronic Signature 器件电子签名 .....      | 378 |
| 19.1   | 简介 .....                                      | 378 |
| 19.2   | 寄存器描述 .....                                   | 378 |
| 19.2.1 | UID1 唯一标识码 .....                              | 378 |
| 19.2.2 | UID2 唯一标识码 .....                              | 379 |
| 19.2.3 | UID3 唯一标识码 .....                              | 379 |
| 20     | 修订记录 .....                                    | 380 |

## 附图目录

|                                        |     |
|----------------------------------------|-----|
| 图 1-1 系统架构框图 .....                     | 18  |
| 图 2-1 ISP 方式编程流程图 .....                | 28  |
| 图 2-2 IAP 编程流程 .....                   | 29  |
| 图 3-1 电源控制功能框图 .....                   | 45  |
| 图 3-2 上电复位和掉电复位波形图 .....               | 47  |
| 图 3-3 PVD 阈值波形图 .....                  | 48  |
| 图 3-4 Standby 模式唤醒滤波功能波形图 .....        | 54  |
| 图 5-1 复位功能框图 .....                     | 63  |
| 图 5-2 时钟树 .....                        | 66  |
| 图 5-3 高速晶振/陶瓷谐振器 .....                 | 67  |
| 图 5-4 外部高速输入时钟 .....                   | 67  |
| 图 6-1 CRC 功能框图 .....                   | 90  |
| 图 7-1 标准 I/O 端口 .....                  | 96  |
| 图 7-2 输入浮空/上拉/下拉配置 .....               | 98  |
| 图 7-3 输出配置 .....                       | 99  |
| 图 7-4 复用功能配置 .....                     | 100 |
| 图 7-5 模拟输入 .....                       | 101 |
| 图 8-1 EXTI 结构框图 .....                  | 109 |
| 图 9-1 ADC 系统框图 .....                   | 117 |
| 图 9-2 数据对齐方式 .....                     | 120 |
| 图 9-3 单次转换模式时序图 .....                  | 122 |
| 图 9-4 单周期扫描下使能通道转换时序图 (通道方向从高到低) ..... | 123 |
| 图 9-5 单周期扫描下使能通道转换时序图 (通道方向从低到高) ..... | 123 |
| 图 9-6 连续扫描模式使能通道转换时序图 (通道方向由低到高) ..... | 124 |
| 图 9-7 连续扫描模式使能通道转换时序图 (通道方向由高到低) ..... | 124 |
| 图 9-8 单次转换模式下通道转换时序图 .....             | 125 |
| 图 9-9 单周期扫描下通道转换时序图 .....              | 126 |
| 图 9-10 连续扫描模式下通道转换时序图 .....            | 127 |
| 图 9-11 连续扫描模式下动态更新配置时序图 .....          | 127 |
| 图 9-12 自动注入通道转换单周期扫描通道转换时序图 .....      | 128 |
| 图 9-13 自动注入通道转换连续转换时序图 .....           | 128 |
| 图 10-1 TIM1 结构图 .....                  | 150 |
| 图 10-2 时钟选择 .....                      | 152 |
| 图 10-3 外部时钟模式 1 下的控制电路 .....           | 153 |
| 图 10-4 自动预装载 .....                     | 153 |
| 图 10-5 递增计数模式 (UDIS=0) .....           | 154 |
| 图 10-6 递增计数模式 (UDIS=1 禁止产生更新事件) .....  | 154 |
| 图 10-7 递减计数模式 (UDIS=0) .....           | 155 |
| 图 10-8 递减计数模式 (UDIS=1 禁止产生更新事件) .....  | 155 |
| 图 10-9 中央计数模式 (UDIS=0) .....           | 155 |

|                                            |     |
|--------------------------------------------|-----|
| 图 10-10 中央计数模式 (UDIS=1 禁止产生更新事件) .....     | 156 |
| 图 10-11 中央对齐模式重复计数时序图.....                 | 156 |
| 图 10-12 边沿对齐模式递增计数时序图.....                 | 157 |
| 图 10-13 边沿对齐模式递减计数时序图.....                 | 157 |
| 图 10-14 TIM1 输入捕获结构图 .....                 | 158 |
| 图 10-15 PWM 输入模式时序 .....                   | 160 |
| 图 10-16 比较输出部分结构图 .....                    | 160 |
| 图 10-17 比较输出模式, OC1 信号在匹配时翻转 .....         | 161 |
| 图 10-18 边沿对齐递增计数时 PWM 模式 1 的波形 .....       | 163 |
| 图 10-19 边沿对齐递减计数时 PWM 模式 1 的波形 .....       | 164 |
| 图 10-20 中央对齐 PWM 模式 1 的波形.....             | 165 |
| 图 10-21 移相功能示意图 .....                      | 165 |
| 图 10-22 使用 COM 事件产生六步 PWM (OSSR = 1) ..... | 166 |
| 图 10-23 死区插入 .....                         | 167 |
| 图 10-24 响应刹车的输出 (OISx=0, OISxN=0) .....    | 170 |
| 图 10-25 响应刹车的输出 (OISx=0, OISxN=1) .....    | 170 |
| 图 10-26 响应刹车的输出 (OISx=1, OISxN=0) .....    | 170 |
| 图 10-27 响应刹车的输出 (OISx=1, OISxN=1) .....    | 170 |
| 图 10-28 单脉冲模式.....                         | 171 |
| 图 10-29 编码器模式下的计数器时序图.....                 | 173 |
| 图 10-30 IC1FP1 反相编码器接口模式时序图.....           | 173 |
| 图 10-31 复位模式的控制时序图 .....                   | 174 |
| 图 10-32 门控模式下的控制时序图 .....                  | 174 |
| 图 10-33 触发器模式下的控制时序图 .....                 | 175 |
| 图 10-34 定时器间互联 .....                       | 175 |
| 图 10-35 使用 TIM3 作为 TIM1 的预分频器.....         | 176 |
| 图 10-36 使用 TIM1 使能 TIM3 .....              | 176 |
| 图 10-37 使用 TIM1 的更新事件启动 TIM3 .....         | 177 |
| 图 10-38 TIM1 的 TI1 同步启动 TIM1 和 TIM3 .....  | 177 |
| 图 10-39 (TI1 异或输入) 输入捕获波形图 .....           | 178 |
| 图 10-40 霍尔传感器接口实例 .....                    | 179 |
| 图 11-1 TIM3 结构图 .....                      | 209 |
| 图 11-2 时钟选择.....                           | 211 |
| 图 11-3 外部时钟模式 1 下的控制电路.....                | 212 |
| 图 11-4 外部时钟模式 2 下的控制电路.....                | 212 |
| 图 11-5 自动预装载 .....                         | 213 |
| 图 11-6 递增计数模式 (UDIS=0) .....               | 213 |
| 图 11-7 递增计数模式 (UDIS=1 禁止产生更新事件) .....      | 214 |
| 图 11-8 递减计数模式 (UDIS=0) .....               | 214 |
| 图 11-9 递减计数模式 (UDIS=1 禁止产生更新事件) .....      | 214 |
| 图 11-10 中央计数模式 (UDIS=0) .....              | 215 |
| 图 11-11 中央计数模式 (UDIS=1 禁止产生更新事件) .....     | 215 |
| 图 11-12 TIM3 输入捕获结构图 .....                 | 215 |
| 图 11-13 PWM 输入模式时序 .....                   | 217 |

|                                                      |     |
|------------------------------------------------------|-----|
| 图 11-14 比较输出部分结构图 .....                              | 218 |
| 图 11-15 比较输出模式, OC1 信号在匹配时翻转 .....                   | 219 |
| 图 11-16 边沿对齐递增计数时 PWM 模式 1 的波形.....                  | 220 |
| 图 11-17 边沿对齐递减计数时 PWM 模式 1 的波形.....                  | 221 |
| 图 11-18 中央对齐 PWM 模式 1 的波形.....                       | 222 |
| 图 11-19 外部事件清除 OCxREF .....                          | 223 |
| 图 11-20 单脉冲模式 .....                                  | 223 |
| 图 11-21 编码器模式下的计数器时序图 .....                          | 225 |
| 图 11-22 IC1FP1 反相编码器接口模式时序图 .....                    | 225 |
| 图 11-23 复位模式的控制时序图 .....                             | 226 |
| 图 11-24 门控模式下的控制时序图 .....                            | 227 |
| 图 11-25 触发器模式下的控制时序图 .....                           | 227 |
| 图 11-26 外部时钟模式 2+从模式(触发模式)控制时序图 .....                | 228 |
| 图 11-27 (TI1 异或输入) 输入捕获波形图.....                      | 228 |
| 图 12-1 TIM14 结构图.....                                | 252 |
| 图 12-2 自动预装载.....                                    | 253 |
| 图 12-3 递增计数模式 (UDIS=0) .....                         | 253 |
| 图 12-4 递增计数模式 (UDIS=1 禁止产生更新事件) .....                | 254 |
| 图 12-5 TIM14 输入捕获结构图 .....                           | 254 |
| 图 12-6 比较输出部分结构图 .....                               | 255 |
| 图 12-7 比较输出模式, OC1 信号在匹配时翻转 .....                    | 257 |
| 图 12-8 边沿对齐递增计数时 PWM 模式 1 的波形 .....                  | 258 |
| 图 12-9 单脉冲模式 .....                                   | 258 |
| 图 13-1 WWDG 功能框图 .....                               | 268 |
| 图 14-1 功能框图 .....                                    | 274 |
| 图 14-2 流程框图 .....                                    | 276 |
| 图 15-1 UART 功能框图 .....                               | 282 |
| 图 15-2 UART 时序 .....                                 | 284 |
| 图 15-3 RX 引脚采样方法 .....                               | 285 |
| 图 15-4 发送时状态位变化 .....                                | 287 |
| 图 15-5 UART 奇偶校验方框图 .....                            | 292 |
| 图 15-6 UART 采样 NACK 信号方框图 .....                      | 293 |
| 图 15-7 普通模式下 IrDA 发送和接收图 .....                       | 294 |
| 图 16-1 SPI_I2S 功能框图 .....                            | 309 |
| 图 16-2 单主和单从应用 .....                                 | 310 |
| 图 16-3 数据时钟时序图 .....                                 | 311 |
| 图 16-4 飞利浦标准示意图 .....                                | 318 |
| 图 16-5 MSB 对齐标准示意图 .....                             | 318 |
| 图 16-6 LSB 对齐标准示意图 .....                             | 319 |
| 图 16-7 PCM 标准示意图 .....                               | 319 |
| 图 16-8 I2S 从模式 (SD 配置成 SDO 为发送器, 配置成 SDI 为接收器) ..... | 320 |
| 图 16-9 I2S 主模式 (SD 配置成 SDO 为发送器, 配置成 SDI 为接收器) ..... | 320 |
| 图 16-10 I2S 时钟预分频器示意图 .....                          | 321 |
| 图 17-1 I2C 功能框图 .....                                | 337 |

|                                         |     |
|-----------------------------------------|-----|
| 图 17-2 起始和停止条件 .....                    | 338 |
| 图 17-3 7 位地址格式.....                     | 339 |
| 图 17-4 10 位地址格式.....                    | 339 |
| 图 17-5 主发送协议.....                       | 340 |
| 图 17-6 主接收协议.....                       | 340 |
| 图 17-7 带 RESTART (SR) 信号的主发送和接收协议 ..... | 341 |
| 图 17-8 起始字节传输 .....                     | 341 |
| 图 17-9 I2C_DR 寄存器 .....                 | 342 |
| 图 17-10 主发送, TX FIFO 为空 .....           | 342 |
| 图 17-11 主接收, TX FIFO 为空.....            | 342 |
| 图 17-12 主发送, 发生 RESTART.....            | 343 |
| 图 17-13 主接收, 发生 RESTART.....            | 343 |
| 图 17-14 两个主器件仲裁 .....                   | 343 |
| 图 17-15 时钟同步 (示意图) .....                | 344 |
| 图 17-16 时钟同步 (时序图) .....                | 344 |
| 图 17-17 SCL 生成时序 .....                  | 345 |
| 图 17-18 流程图 (I2C 接口作为从器件) .....         | 347 |
| 图 17-19 流程图 (I2C 接口作为主器件) .....         | 349 |
| 图 17-20 I2C 中断机制.....                   | 351 |
| 图 18-1 调试功能框图 .....                     | 370 |

## 表格目录

|                                           |     |
|-------------------------------------------|-----|
| 表 1-1 存储器映像.....                          | 19  |
| 表 1-2 启动模式 .....                          | 21  |
| 表 2-1 Flash 存储空间 .....                    | 23  |
| 表 2-2 信息块.....                            | 24  |
| 表 2-3 选项字节组织结构.....                       | 24  |
| 表 2-4 USER 的位含义 .....                     | 24  |
| 表 2-5 Latency 设置关系.....                   | 26  |
| 表 2-6 编程方式 .....                          | 26  |
| 表 2-7 保护设置的状态变化 .....                     | 30  |
| 表 2-8 Flash 读保护状态.....                    | 38  |
| 表 2-9 Flash 解除读保护状态.....                  | 38  |
| 表 2-10 写保护区域.....                         | 39  |
| 表 3-1 低功耗模式列表 .....                       | 49  |
| 表 3-2 SLEEPNOW 模式 .....                   | 50  |
| 表 3-3 SLEEPONEXIT 模式 .....                | 50  |
| 表 3-4 停机模式 .....                          | 51  |
| 表 3-5 深度停机模式.....                         | 53  |
| 表 3-6 待机模式 .....                          | 53  |
| 表 3-7 电源控制寄存器概览.....                      | 55  |
| 表 4-1 SYSCFG 寄存器概览.....                   | 59  |
| 表 5-1 RCC 全局中断表.....                      | 70  |
| 表 5-2 MCO 与时钟源对应关系 .....                  | 72  |
| 表 5-3 RCC 寄存器概览.....                      | 73  |
| 表 6-1 CRC 寄存器概览.....                      | 92  |
| 表 7-1 端口位配置表（port0 为例） .....              | 96  |
| 表 7-2 SWD 复用功能重映射 .....                   | 101 |
| 表 7-3 GPIO 寄存器概览.....                     | 101 |
| 表 8-1 异常向量表.....                          | 109 |
| 表 8-2 中断向量表.....                          | 109 |
| 表 8-3 EXTI 触发源.....                       | 112 |
| 表 8-4 EXTI 寄存器总览.....                     | 113 |
| 表 9-1 中断事件一览表 .....                       | 118 |
| 表 9-2 数据分辨率与数据补偿左对齐关系 .....               | 119 |
| 表 9-3 寄存器概览.....                          | 130 |
| 表 10-1 数字滤波器宽度与 ICxF 的对应关系表 .....         | 158 |
| 表 10-2 死区时间计算 .....                       | 166 |
| 表 10-3 当 MOE=1, OSSI=0/1, OSSR=0 时: ..... | 168 |
| 表 10-4 当 MOE=1, OSSI=0/1, OSSR=1 时: ..... | 168 |
| 表 10-5 当 MOE=0, OSSI=0, OSSR=0/1 时: ..... | 168 |

|                                      |     |
|--------------------------------------|-----|
| 表 10-6 当 MOE=0, OSSI=1, OSSR=0/1 时:  | 169 |
| 表 10-7 计数方向与编码器信号的关系                 | 172 |
| 表 10-8 中断事件一览表                       | 180 |
| 表 10-9 TIM1 寄存器概览                    | 180 |
| 表 10-10 TIM1 内部触发连接                  | 185 |
| 表 10-11 ICx 极性/电平选择表                 | 199 |
| 表 11-1 数字滤波器宽度与 ICxF 的对应关系表          | 216 |
| 表 11-2 计数方向与编码器信号的关系                 | 224 |
| 表 11-3 中断事件一览表                       | 229 |
| 表 11-4 TIM3 寄存器概览                    | 229 |
| 表 11-5 TIM3 内部触发连接                   | 235 |
| 表 11-6 ICx 极性/电平选择表                  | 248 |
| 表 12-1 数字滤波器宽度与 IC1F 的对应关系表          | 254 |
| 表 12-2 中断事件一览表                       | 258 |
| 表 12-3 TIM14 寄存器概览                   | 259 |
| 表 12-4 IC1 极性/电平选择表                  | 265 |
| 表 13-1 超时时间                          | 270 |
| 表 13-2 WWDG 寄存器概览                    | 270 |
| 表 14-1 IWDG 超时时间 (40kHz 的输入时钟 (LSI)) | 276 |
| 表 14-2 IWDG 寄存器概览                    | 277 |
| 表 15-1 USART 中断请求                    | 294 |
| 表 15-2 USART 寄存器概览                   | 295 |
| 表 16-1 波特率公式                         | 315 |
| 表 16-2 SPI 状态                        | 315 |
| 表 16-3 I2S 比特率计算公式                   | 322 |
| 表 16-4 I2S 音频采样率 Fs 与 FI2SCLK 计算关系   | 322 |
| 表 16-5 I2S 音频采样率误差表                  | 322 |
| 表 16-6 I2S 中断状态                      | 323 |
| 表 16-7 SPI_I2S 寄存器概览                 | 324 |
| 表 17-1 引脚定义                          | 338 |
| 表 17-2 I2C 首字节                       | 339 |
| 表 17-3 中断位的置位和清除                     | 350 |
| 表 17-4 I2C 寄存器概览                     | 351 |
| 表 17-5 DISSLAVE 和 MASTER 配置          | 354 |
| 表 18-1 SWD 调试端口管脚                    | 371 |
| 表 18-2 ID 编码                         | 371 |
| 表 18-3 8bit 请求包                      | 372 |
| 表 18-4 3bit 应答包                      | 372 |
| 表 18-5 33bit 数据包                     | 373 |
| 表 18-6 SW-DP 寄存器                     | 374 |
| 表 18-7 DBG 寄存器概览                     | 375 |
| 表 19-1 存储器容量寄存器概览                    | 378 |
| 表 20-1 修订记录表                         | 380 |

# 1 系统和存储器架构

## 1.1 系统架构简介

MM32F0020 是基于 Arm®Cortex®-M0 处理器开发的 32 位微控制器产品，它同时具备了高性能和低功耗的特点。MM32F0020 采用矩阵总线结构，该矩阵包括一个 AHB 主机：CPU，三个从机分别是 SRAM、闪存存储、AHB 总线（含 AHB 到 APB 的总线桥）以及连接在 APB 总线的各种设备。



图 1-1 系统架构框图

### 1.1.1 系统总线

系统总线连接了 CPU 内核和总线矩阵，构造 CPU 与总线矩阵的通路，从而进行数据传输。CPU 可作为主机驱动总线，最终实现对从机如 APB 外设、SRAM、闪存等的读写操作。

### 1.1.2 总线矩阵

总线矩阵包括一个 AHB 互联矩阵，一个 AHB 总线和一个桥接的 APB 总线。AHB 总线的外设(RCC, GPIO 和 CRC) 通过 AHB 互联矩阵与系统总线连接。在 APB 和 AHB 总线之间连接通过 AHB1APB 桥进行数据交换。当 APB 寄存器进行 8 位 16 位访问，APB 会自动拓宽成 32 位，同样的，AHB1APB 桥也具备自动拓宽功能。

## 1.2 存储器介绍

系统包含了寻址范围为 4GB 的线性地址空间，其中程序和数据存储器，外设寄存器和 I/O 接口寄存器分布于 4GB 空间中的不同地址范围。地址映射的具体信息可参考存储器映像表。

### 1.2.1 存储器映像和寄存器编址

存储器映像请参考各外设对应章节的存储器映像图

表 1-1 存储器映像

| 总线    | 编址范围                      | 大小      | 外设                               |
|-------|---------------------------|---------|----------------------------------|
| Flash | 0x0000 0000 - 0x0000 7FFF | 32 KB   | 主闪存存储器、系统存储器或是 SRAM 有赖于 BOOT 的配置 |
|       | 0x0000 8000 - 0x07FF FFFF | ~127 MB | Reserved                         |
|       | 0x0800 0000 - 0x0800 7FFF | 32 KB   | 主闪存存储区                           |
|       | 0x0801 0000 - 0x1FF0 FFFF | ~383 MB | Reserved                         |
|       | 0x1FFE 0000 - 0x1FFE 01FF | 0.5 KB  | Reserved                         |
|       | 0x1FFE 0200 - 0x1FFE 0FFF | 3 KB    | Reserved                         |
|       | 0x1FFE 1000 - 0x1FFE 11FF | 0.5 KB  | Reserved                         |
|       | 0x1FFE 1200 - 0x1FFE 1BFF | 2.5 KB  | Reserved                         |
|       | 0x1FFE 1C00 - 0x1FFF F3FF | ~256 MB | Reserved                         |
|       | 0x1FFF F400 - 0x1FFF F7FF | 1 KB    | 系统存储区                            |
|       | 0x1FFF F800 - 0x1FFF F80F | 16 B    | 选项字节                             |
|       | 0x1FFF F810 - 0x1FFF FFFF | 2 KB    | Reserved                         |
| SRAM  | 0x2000 0000 - 0x2000 07FF | 2KB     | SRAM                             |
|       | 0x2000 4000 - 0x2FFF FFFF | ~255 MB | Reserved                         |
| APB1  | 0x4000 0000 - 0x4000 03FF | 1 KB    | Reserved                         |
|       | 0x4000 0400 - 0x4000 07FF | 1 KB    | TIM3                             |

| 总线  | 编址范围                      | 大小      | 外设              |
|-----|---------------------------|---------|-----------------|
| AHB | 0x4000 0800 - 0x4000 0BFF | 8 KB    | Reserved        |
|     | 0x4000 2800 - 0x4000 2BFF | 1 KB    | Reserved        |
|     | 0x4000 2C00 - 0x4000 2FFF | 1 KB    | WWDG            |
|     | 0x4000 3000 - 0x4000 33FF | 1 KB    | IWDG            |
|     | 0x4000 3400 - 0x4000 37FF | 1 KB    | Reserved        |
|     | 0x4000 3800 - 0x4000 3BFF | 1 KB    | Reserved        |
|     | 0x4000 4000 - 0x4000 43FF | 1 KB    | Reserved        |
|     | 0x4000 4400 - 0x4000 47FF | 1 KB    | UART2           |
|     | 0x4000 4800 - 0x4000 4BFF | 3 KB    | Reserved        |
|     | 0x4000 5400 - 0x4000 57FF | 1 KB    | I2C1            |
|     | 0x4000 5800 - 0x4000 5BFF | 1 KB    | Reserved        |
|     | 0x4000 5C00 - 0x4000 5FFF | 1 KB    | Reserved        |
|     | 0x4000 6000 - 0x4000 63FF | 1 KB    | Reserved        |
|     | 0x4000 6400 - 0x4000 67FF | 1 KB    | Reserved        |
|     | 0x4000 6800 - 0x4000 6BFF | 1 KB    | Reserved        |
|     | 0x4000 6C00 - 0x4000 6FFF | 1 KB    | Reserved        |
|     | 0x4000 7000 - 0x4000 73FF | 1 KB    | PWR             |
|     | 0x4000 7400 - 0x4000 FFFF | 35 KB   | Reserved        |
|     | 0x4001 0000 - 0x4001 03FF | 1 KB    | SYSCFG          |
|     | 0x4001 0400 - 0x4001 07FF | 1 KB    | EXTI            |
|     | 0x4001 0800 - 0x4001 23FF | 7 KB    | Reserved        |
|     | 0x4001 2400 - 0x4001 27FF | 1 KB    | ADC1            |
|     | 0x4001 2800 - 0x4001 2BFF | 1 KB    | Reserved        |
|     | 0x4001 2C00 - 0x4001 2FFF | 1 KB    | TIM1            |
|     | 0x4001 3000 - 0x4001 33FF | 1 KB    | SPI1            |
|     | 0x4001 3400 - 0x4001 37FF | 1 KB    | DBG             |
|     | 0x4001 3800 - 0x4001 3BFF | 1 KB    | UART1           |
|     | 0x4001 3C00 - 0x4001 3FFF | 1 KB    | Reserved        |
|     | 0x4001 4000 - 0x4001 43FF | 1 KB    | TIM14           |
|     | 0x4001 4400 - 0x4001 47FF | 1 KB    | Reserved        |
|     | 0x4001 4800 - 0x4001 4BFF | 1 KB    | Reserved        |
|     | 0x4001 4C00 - 0x4001 7FFF | 13 KB   | Reserved        |
| AHB | 0x4002 0000 - 0x4002 03FF | 1 KB    | Reserved        |
|     | 0x4002 0400 - 0x4002 0FFF | 3 KB    | Reserved        |
|     | 0x4002 1000 - 0x4002 13FF | 1 KB    | RCC             |
|     | 0x4002 1400 - 0x4002 1FFF | 3 KB    | Reserved        |
|     | 0x4002 2000 - 0x4002 23FF | 1 KB    | Flash Interface |
|     | 0x4002 2400 - 0x4002 2FFF | 3 KB    | Reserved        |
|     | 0x4002 3000 - 0x4002 33FF | 1 KB    | CRC             |
|     | 0x4002 3400 - 0x4002 FFFF | 47 KB   | Reserved        |
|     | 0x4003 0000 - 0x4003 03FF | 1 KB    | Reserved        |
|     | 0x4003 0400 - 0x47FF FFFF | ~127 MB | Reserved        |

| 总线 | 编址范围                      | 大小      | 外设       |
|----|---------------------------|---------|----------|
|    | 0x4800 0000 - 0x4800 03FF | 1 KB    | GPIOA    |
|    | 0x4800 0400 - 0x4800 07FF | 1 KB    | GPIOB    |
|    | 0x4800 0800 - 0x4800 0BFF | 1 KB    | Reserved |
|    | 0x4800 0C00 - 0x4800 0FFF | 1 KB    | Reserved |
|    | 0x4800 1000 - 0x5FFF FFFF | ~384 MB | Reserved |

### 1.2.2 内置的 SRAM

内置最大可到 2K 字节的静态 SRAM。它可以以字节（8 位）、半字（16 位）或字（32 位）进行访问。SRAM 起始地址为 0x2000 0000。

SRAM 可以被 CPU 用最快的系统时钟且不插入任何等待进行访问。

### 1.2.3 闪存存储器概述

闪存存储器分为两个存储区域：

- 由应用数据和用户数据区组成的主闪存存储块。
- 由选项字节和系统存储器组成的信息块：
- 选项字节（Option bytes）：包括硬件和存储保护用户配置选项。
- 系统存储器（System memory）：Bootloader 代码。

闪存接口基于 AHB 协议执行指令和数据存取。闪存接口的预取缓冲功能可加速 CPU 执行代码的速度。

### 1.2.4 启动配置

在芯片中，可通过 BOOT0 引脚电平状态及 nBOOT1 位的配置选择三种不同的启动模式，如下表所示：

表 1-2 启动模式

| 启动模式    | 启动模式选择   |          |
|---------|----------|----------|
|         | nBOOT1 位 | BOOT0 引脚 |
| 主闪存存储器  | x        | 0        |
| 系统存储器   | 1        | 1        |
| 内置 SRAM | 0        | 1        |

用户通过设置 nBOOT1 位和 BOOT0 引脚电平逻辑值来选择三种启动模式，在器件复位后，芯片根据 nBOOT1 位和 BOOT0 的引脚值，从而确定启动模式。其中在待机模式中需要保持启动模式引脚的设置值，因为，每一次从待机模式唤醒时，CPU 会重新采样 nBOOT1 位和 BOOT0 的值来重新确定启动模式。

器件复位后，CPU 先从 0x0000 0000 地址开始获取栈顶值，再从 0x0000 0004 地址获取引导代码的

基地址，并且从基地址开始执行程序。

启动模式主要分为三种：主闪存存储器，系统存储器和内置 SRAM。

**主闪存存储器启动 (BOOT0=0):** 主闪存存储器的起始地址是 0x0800 0000，当其被选为启动模式时，被映射到启动存储空间 (0x0000 0000)，但是闪存存储器的内容依旧可以从起始地址 (0x0800 0000) 访问，即当主闪存存储器被选为启动模式，启动地址和起始地址都可以访问闪存存储器。

**系统存储器启动 (nBOOT1=1 & BOOT0 = 1):** 系统存储器的起始地址是 0x1FFF F400，当其被选为启动模式时，被映射到启动存储空间 (0x0000 0000)，但是系统存储器的内容依旧可以从起始地址 (0x1FFF F400) 访问，即当系统存储器被选为启动模式，启动地址和起始地址都可以访问系统存储器。

**内置 SRAM 启动 (nBOOT1=0 & BOOT0 = 1):** 内置 SRAM 的起始地址是 0x2000 0000，当其被选为启动模式时，被映射到启动存储空间 (0x0000 0000)，但是内置 SRAM 的内容依旧可以从起始地址 (0x2000 0000) 访问，即当内置 SRAM 被选为启动模式，启动地址和起始地址都可以访问内置 SRAM。

## 1.2.5 引导程序

出厂后引导程序存放在系统存储器中，可以通过串口进行 ISP 编程。

## 2 Embedded FLASH 嵌入式闪存

### 2.1 简介

嵌入式闪存支持高达 32K Bytes 的片内 Main Flash，还提供了选项字节块与系统启动块（支持芯片 Boot 引导），还有保留的保密空间，提供了特殊应用的场景下的使用。闪存的控制器支持读操作、页擦除、整片擦除，可通过 16 位（半字）方式编程写入闪存，其擦写寿命可达 100000 次。闪存控制器在读取数据时，支持带预取缓冲器的数据接口，以支持 MCU 运行在更高的主频。

### 2.2 闪存构成与说明

#### 2.2.1 闪存构成

- 闪存空间由 32 位宽的存储单元组成，既可以存代码又可以存数据。
- 主闪存块按 32 页（每页 1K 字节）或 8 个写保护块（每块 4K 字节）划分。
- 主闪存块可按页（每 1K 字节）擦除（Page Erase）。
- 以 4 页（4K 字节）为单位作为 1 个写保护块来设置写保护。
- 整个片内 Flash 由两部分组成：一部分是主存储块，另一部分是信息存储块。
- 主存储块用于存储用户代码和数据，用户代码可以对主存储器进行擦除、编程和读取操作。每个 1K 字节在主存储块中称为一页，可以执行最小单位的擦除；另外以 1 个写保护区为单位（4K 字节，4 页=1 个写保护块）进行写保护分配，如表 2-1 所示。

表 2-1 Flash 存储空间

| 模块   | 区块名称   | 页名称  | 地址                        | 大小（字节） |
|------|--------|------|---------------------------|--------|
| 主存储块 | 写保护区 0 | 页 0  | 0x0800 0000 - 0x0800 03FF | 1K     |
|      |        | 页 1  | 0x0800 0400 - 0x0800 07FF | 1K     |
|      |        | 页 2  | 0x0800 0800 - 0x0800 0BFF | 1K     |
|      |        | 页 3  | 0x0800 0C00 - 0x0800 0FFF | 1K     |
|      | 写保护区 3 | ...  | ...                       | ...    |
|      |        | 页 12 | 0x0800 3000 - 0x0800 33FF | 1K     |
|      |        | 页 13 | 0x0800 3400 - 0x0800 37FF | 1K     |
|      |        | 页 14 | 0x0800 3800 - 0x0800 3BFF | 1K     |
|      | 写保护区 7 | 页 15 | 0x0800 3C00 - 0x0800 3FFF | 1K     |
|      |        | ...  | ...                       | ...    |
|      |        | 页 28 | 0x0800 7000 - 0x0800 73FF | 1K     |
|      |        | 页 29 | 0x0800 7400 - 0x0800 77FF | 1K     |
|      | 写保护区 7 | 页 30 | 0x0800 7800 - 0x0800 7BFF | 1K     |
|      |        | 页 31 | 0x0800 7C00 - 0x0800 7FFF | 1K     |

信息存储块中，除了“系统存储器 ISP”区域出厂锁定，用户不可写入外，其他区域在一定条件下用户可进行读写操作。信息存储器可分为保密空间、系统存储器 ISP 和选项字节三部分，保密空间用于存储需特别保护的数据与代码，系统存储 ISP 区用于存储出厂的 ISP Bootloader，选项字节（Option byte）部分中的前 12 个字节是主存储器的写和读保护信息，剩余字节可用于存放用户特殊的数据。对于选项字节部分，用户可以通过规定的流程对其进行擦除、编程和读取。仅 ISP 部分由于用于固化 ISP 升级的代码，不支持用户进行擦除和编程。

表 2-2 信息块

| 模块  | 名称       | 地址                        | 大小（字节） |
|-----|----------|---------------------------|--------|
| 信息块 | 保密空间     | 0x1FFE 1000 - 0x1FFE 1BFF | 3K     |
|     | 系统存储 ISP | 0x1FFF F400 - 0x1FFF F7FF | 1K     |
|     | 选项字节     | 0x1FFF F800 - 0x1FFF F9FF | 0.5K   |

## 2.2.2 选项字节说明

在选项字节页中，内容主要有写保护使能，硬件看门狗使能等。Flash 控制器可以通过选项字节中值的设置，达到使能主存储器禁止写入功能，以避免非法写入；还可以使能硬件看门狗。相关信息存储在选项字节中，修改选项字节中内容后，需要复位或重新上电后才生效，写入时需按半字高低字节反码方式写入，如 nUser, nData 等。每次系统复位后，选项字节会重新装载选项字节信息块的数据，并做相应的判断与状态改变，这些状态保存在选项字节寄存器（FLASH\_OBR 及 FLASH\_WRP0）中。在信息块中每个选择位都有对应的反码位，在加载选择位时反码位用于验证选择位是否正确，如果在加载过程中发现有差别，将产生一个选项字节错误标志（OPTERR），如果开启了对应的中断，将触发中断。

选项字节块中选项字节的组织结构如下表所示（位 15 □ 8 中的值为位 7 □ 0 中选项字节的反码）：

表 2-3 选项字节组织结构

| 地址          | [15: 8] | [7: 0] | 默认值    |
|-------------|---------|--------|--------|
| 0x1FFF F800 | nRDP    | RDP    | 0x5AA5 |
| 0x1FFF F802 | nUSER   | USER   | 0xFFFF |
| 0x1FFF F804 | nData0  | Data0  | 0xFFFF |
| 0x1FFF F806 | nData1  | Data1  | 0xFFFF |
| 0x1FFF F808 | nWRP0   | WRP0   | 0xFFFF |

表 2-4 USER 的位含义

|              | Bit   | Field     | Type | Default | Description           | FLASH_OBR          |
|--------------|-------|-----------|------|---------|-----------------------|--------------------|
| RDP          | 7: 0  | RDP       | rw   | 0xA5    | 0xA5                  |                    |
| nRDP         | 15: 8 | nRDP      | rw   | 0x5A    | 0x5A                  | FLASH_OBR.<br>Bit1 |
| User<br>Byte | 0     | WDG_SW    | rw   | 0x01    | 0: 硬件看门狗<br>1: 软件看门狗  | FLASH_OBR.<br>Bit2 |
|              | 1     | nRST_STOP | rw   | 0x01    | 0: 当进入停机（STOP）模式时产生复位 | FLASH_OBR.<br>Bit3 |

|               | Bit | Field        | Type | Default | Description                                                   | FLASH_OBR           |
|---------------|-----|--------------|------|---------|---------------------------------------------------------------|---------------------|
|               |     |              |      |         | 1: 进入停机 (STOP) 模式时不产生复位<br>0: 当进入待机模式时产生复位<br>1: 进入待机模式时不产生复位 |                     |
|               | 2   | nRST_STANDBY | rw   | 0x01    | 0: 当进入待机模式时产生复位<br>1: 进入待机模式时不产生复位                            | FLASH_OBR.<br>Bit4  |
|               | 3   | Reserved     | rw   | 0x01    | 保留为 0x01                                                      | 保留                  |
|               | 4   | nBOOT1       | rw   | 0x01    | 0: nBOOT1=0<br>1: nBOOT1=1                                    | FLASH_OBR.<br>Bit6  |
|               | 5   | OBR_nRST     | rw   | 0x01    | NRST 复用 PA10<br>1: NRST 功能<br>0: GPIO 功能                      | FLASH_OBR.<br>Bit7  |
|               | 6   | Reserved     | rw   | 0x01    | 保留为 0x01                                                      | 保留                  |
|               | 7   | Reserved     | rw   | 0x01    | 保留为 0x01                                                      | 保留                  |
|               | 0   | DATA0.Bit0   | rw   | 0x01    | 用户自定义                                                         | FLASH_OBR.<br>Bit10 |
| DATA0<br>Byte | 1   | DATA0.Bit1   | rw   | 0x01    | 用户自定义                                                         | FLASH_OBR.<br>Bit11 |
|               | 2   | DATA0.Bit2   | rw   | 0x01    | 用户自定义                                                         | FLASH_OBR.<br>Bit12 |
|               | 3   | DATA0.Bit3   | rw   | 0x01    | 用户自定义                                                         | FLASH_OBR.<br>Bit13 |
|               | 4   | DATA0.Bit4   | rw   | 0x01    | 用户自定义                                                         | FLASH_OBR.<br>Bit14 |
|               | 5   | DATA0.Bit5   | rw   | 0x01    | 用户自定义                                                         | FLASH_OBR.<br>Bit15 |
|               | 6   | DATA0.Bit6   | rw   | 0x01    | 用户自定义                                                         | FLASH_OBR.<br>Bit16 |
|               | 7   | DATA0.Bit7   | rw   | 0x01    | 用户自定义                                                         | FLASH_OBR.<br>Bit17 |
|               | 0   | DATA1.Bit0   | rw   | 0x01    | 用户自定义                                                         | FLASH_OBR.<br>Bit18 |
| DATA1<br>Byte | 1   | DATA1.Bit1   | rw   | 0x01    | 用户自定义                                                         | FLASH_OBR.<br>Bit19 |
|               | 2   | DATA1.Bit2   | rw   | 0x01    | 用户自定义                                                         | FLASH_OBR.<br>Bit20 |
|               | 3   | DATA1.Bit3   | rw   | 0x01    | 用户自定义                                                         | FLASH_OBR.<br>Bit21 |
|               | 4   | DATA1.Bit4   | rw   | 0x01    | 用户自定义                                                         | FLASH_OBR.<br>Bit22 |
|               | 5   | DATA1.Bit5   | rw   | 0x01    | 用户自定义                                                         | FLASH_OBR.<br>Bit23 |
|               | 6   | DATA1.Bit6   | rw   | 0x01    | 用户自定义                                                         | FLASH_OBR.<br>Bit24 |

|  | Bit | Field      | Type | Default | Description | FLASH_OBR           |
|--|-----|------------|------|---------|-------------|---------------------|
|  | 7   | DATA1.Bit7 | rw   | 0x01    | 用户自定义       | FLASH_OBR.<br>Bit25 |

注意：在写保护值中，一个比特位对应四页，即 4096 Bytes。

### 2.2.3 保密空间说明

在保密空间中，Flash 控制器通过指定的密钥配对操作，达到该块内容的读写保护，以避免非法访问。

## 2.3 闪存操作与流程

### 2.3.1 闪存读操作

用户代码和数据存储于主存储块中，闪存控制器可以按照 8bit/16bit/32bit 位读取数据或指令。主闪存模块与普通外设一样统一寻址访问。基于读保护与写保护的要求，任何对主存储块的内容的读写操作都须经过特定的判断过程，以防止非法读取与写入。

闪存按 Flash 访问控制寄存器（FLASH\_ACR）中的设定的方式，通过 AHB 总线执行取指令和取数据。结合 AHB 时钟，设定相应的访问时延（Latency），使能预取指缓冲区后，可提高 CPU 的取指令速度，从而提高 CPU 的运行速度。访问时延（Latency）在 SYSCLK 低于等于 24MHz，可以设定为 0，此后每增加 24MHz，需要增加一个时延。

上电复位后，闪存控制器默认设定预取指缓冲区是打开的。如需要关闭或重新打开预取指缓冲功能，必须设定 SYSCLK 低于 24MHz，并且 AHB 时钟没有经过任何分频的条件下（SYSCLK 必须等于 HCLK）才可以关闭或重新打开预取指缓冲功能。

为了保护对 Flash 的正确读取，必须在 Flash 访问控制寄存器中的 LATENCY[2: 0] 中指定预取指控制器的速度比，这个数值等于每次访问 Flash 后到下次访问之间所需插入的等待周期的个数。复位后，这个值默认为零，也就是没有插入等待周期的状态，相应的系统时钟也复位为使用内置时钟 HSI=8MHz。复位后如果需要修改系统时钟，必须先配置好安全的 LATENCY[2: 0] 值，而当 AHB 时钟的预分频器大于 1 时，预取指缓冲区也需设定相应的访问时延（Latency）。

表 2-5 Latency 设置关系

| SYSCLK                  | AHB DIV | Latency |
|-------------------------|---------|---------|
| 0MHz < SYSCLK <=24MHz   | 1       | 0       |
| 24MHz < SYSCLK <= 48MHz | 1       | 1       |

### 2.3.2 闪存编程方式与操作流程

嵌入式闪存支持如下三种编程方式。

表 2-6 编程方式

| 编程方式        | 编程说明                                                                                                                                            |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 在电路编程 (ICP) | ICP 是指通过特定烧写器，利用 SWD 接口，改变 Flash 的内容，将用户代码烧录到 MCU 中。                                                                                            |
| 在系统编程 (ISP) | ISP 是指通过 ISP Firmware，结合指定的 UART 接口，改变 Flash 的内容，将用户代码烧录到 MCU 中。                                                                                |
| 在应用编程 (IAP) | 与 ICP 和 ISP 的方法不同的是，IAP（在应用编程）能够使用 MCU 支持的任何通信接口（UART, I2C, SPI, CAN, USB 等）下载程序或者数据。IAP 允许用户在运行程序的过程中重写应用程序，前提是一部分应用程序必须预先用 ICP 或 ISP 的方法烧写进去。 |

烧写和擦除操作在整个产品工作电压范围内都可以完成，在对 Flash 空间做写操作或擦除操作时，内部振荡器 (HSI) 必须处于开启状态，还需确保 AHB 时钟大于等于 8MHz。

只要 CPU 不去访问 Flash 空间，进行中的 Flash 写操作不会妨碍 CPU 的运行（从 RAM 或 ISP 中运行）。在对 Flash 进行写操作或擦除操作时，对 Flash 的读访问都会遇到总线停顿，直到写操作或擦除操作完成后才会继续执行，因此在写操作或擦除 Flash 时，不可以对它取指和访问数据。

闪存的编程操作由一系列的动作组合而成，主要包括：

- 对 Flash 操作的解锁与保护
- 对 Flash 擦除（页擦除与整片擦除）
- 对 Flash 编程（半字编程）
- 对信息块中各空间（如选项字节）操作的解锁与保护
- 对信息块中各空间（如选项字节）擦除
- 对信息块中各空间（如选项字节）编程（半字编程）

ISP、IAP 方式编程流程



图 2-1 ISP 方式编程流程图



图 2-2 IAP 编程流程

### 2.3.3 对闪存块操作限制的解除与使能

嵌入式闪存在复位后是处于受保护状态的，可避免意外的页擦除、全片擦除和写值等破坏 Flash 存储空间的操作。复位后，FLASH\_CR 寄存器进入锁定状态，FLASH\_CR 的 LOCK 位被控制器模块置为 1。

只有通过先后向 `FLASH_KEYR` 寄存器写入 `0x45670123` 和 `0xCDEF89AB` 做解锁操作后，`FLASH_CR` 的 `LOCK` 位置为 0，才能开启对 `FLASH_CR` 的访问权限，否则 `FLASH_CR` 寄存器不允许被改写。

可以通过软件设置 `FLASH_CR` 的 `LOCK` 位置为 1 再次锁定，使 Flash 存储器处于受保护状态。

解除保护操作代码：

```
#define FLASH_KEY1      ((unsigned int)0x45670123)
#define FLASH_KEY2      ((unsigned int)0xCDEF89AB)

void FLASH_Unlock()
{
    FLASH->KEYR = ((unsigned int)0x45670123);
    FLASH->KEYR = ((unsigned int)0xCDEF89AB);
}
```

不符合上述顺序的操作与写入错误的值，将会锁死 `FLASH_CR`，并引发一个总线错误，直至下次复位。

使能保护操作代码：

```
#define FLASH_CR_LOCK_Pos      (7)
#define FLASH_CR_LOCK          (0x01U << FLASH_CR_LOCK_Pos)

void FLASH_Lock(void)
{
    FLASH->CR |= FLASH_CR_LOCK;
}
```

#### 2.3.4 对选项字节区块操作限制的解除与使能

闪存控制器在复位后，它的选项字节区块默认是处于写保护的，并且任何时候都是可读的。同样是为了避免对选项字节区做块擦除和写值等破坏性操作，复位后，`FLASH_CR` 寄存器进入锁定状态，`FLASH_CR` 的 `LOCK` 位被控制器模块置为 1，而 `OPTWRE` 位被控制器模块清除为 0；因此需先后向 `FLASH_KEYR` 寄存器写入 `0x45670123` 和 `0xCDEF89AB` 做解锁 `FLASH` 操作，`FLASH_CR` 的 `LOCK` 位置为 0 后，才做选项字节区的解锁。通过向 `FLASH_OPT_KEYR` 寄存器先后写入 `0x45670123` 和 `0xCDEF89AB`，从而使硬件将 `FLASH_CR` 寄存器的 `OPTWRE` 位置 1，才能对选项字节区执行块擦除，半字编程操作。可将 `FLASH_CR` 寄存器的 `OPTWRE` 位置 0，从而禁止对选项字节区执行块擦除，半字编程操作。

表 2-7 保护设置的状态变化

| 设置与状态            | 主闪存块 | 信息块 | 说明                            |
|------------------|------|-----|-------------------------------|
| 上电复位<br>闪存控制器状态为 | 保护   | 保护  | 使能对主闪存块的操作保护<br>使能对选项字节区的操作保护 |

| 设置与状态                                                                                                                                                       | 主闪存块 | 信息块  | 说明                                                                      |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|-------------------------------------------------------------------------|
| FLASH_CR.LOCK=1<br>FLASH_CR.OPTWRE=0                                                                                                                        |      |      |                                                                         |
| 设置<br>FLASH_KEYR=0x45670123<br>FLASH_KEYR=0xCDEF89AB<br>闪存控制器状态变为<br>FLASH_CR.LOCK=0<br>FLASH_CR.OPTWRE=0                                                   | 解除保护 | 保护   | 解除对主闪存块的操作保护，可对主闪存块执行全片擦除，页擦除，半字编程还保持使能对选项字节区的操作保护，不能对选项字节区执行块擦除，半字编程操作 |
| FLASH_KEYR=0x45670123<br>FLASH_KEYR=0xCDEF89AB<br>FLASH OTPKEYR=0x45670123<br>FLASH OTPKEYR=0xCDEF89AB<br>闪存控制器状态变为<br>FLASH_CR.LOCK=0<br>FLASH_CR.OPTWRE=1 | 解除保护 | 解除保护 | 解除对主闪存块的操作保护，可对主闪存块执行全片擦除，页擦除，半字编程解除对选项字节区的操作保护，可对选项字节区执行块擦除，半字编程操作     |
| 设置 FLASH_CR.OPTWRE=0<br>保持 FLASH_CR.LOCK=0                                                                                                                  | 解除保护 | 使能保护 | 仍处于解除对主闪存块的操作保护，使能对选项字节区的操作保护                                           |
| 设置 FLASH_CR.OPTWRE=0<br>设置 FLASH_CR.LOCK=1                                                                                                                  | 使能保护 | 使能保护 | 使能了对主闪存块的操作保护，使能对选项字节区的操作保护                                             |

解除保护操作代码:

```
#define FLASH_KEY1      ((unsigned int)0x45670123)
#define FLASH_KEY2      ((unsigned int)0xCDEF89AB)

void FLASH_Unlock(void)
{
    FLASH->KEYR = ((unsigned int)0x45670123);
    FLASH->KEYR = ((unsigned int)0xCDEF89AB);
}
```

使能保护操作代码:

```
#define FLASH_CR_LOCK_Pos      (7)
#define FLASH_CR_LOCK          (0x01U << FLASH_CR_LOCK_Pos)

void FLASH_Lock(void)
{
    FLASH->CR |= FLASH_CR_LOCK;
}
```

解除选项字节区保护操作代码:

```
#define FLASH_KEY1      ((unsigned int)0x45670123)
#define FLASH_KEY2      ((unsigned int)0xCDEF89AB)
```

```
void FLASH_OPT_Unlock (void)
{
    FLASH->OPTKEYR = FLASH_KEY1;
    FLASH->OPTKEYR = FLASH_KEY2;
}
```

对选项字节区保护使能操作代码:

```
#define FLASH_CR_OPTWRE_Pos      (9)
#define FLASH_CR_OPTWRE           (0x01U << FLASH_CR_OPTWRE_Pos)

void FLASH_OPT_Lock(void)
{
    FLASH->CR &= ~FLASH_CR_OPTWRE;
}
```

### 2.3.5 主闪存块擦除

闪存控制器支持整片擦除主闪存块和以页为单位擦除主闪存中的页。

整片擦除功能将初始化主闪存块的所有内容，使所有的值为 0xFFFF，但信息块不会受这个命令影响。

整片擦除操作的寄存器设置，具体步骤如下：

| 执行步骤                                                                                                                                                                                                                                                                                                         | 简易流程图                                                                                                                                                                                                                                                                                                         |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <p>(1) 读 FLASH_CR 的 LOCK 位，确保解除 Flash 保护<br/> (2) 否则执行 Flash Unlock<br/> (3) 设置 FLASH_CR 寄存器中的 MER 位为 1，使能对主闪存全片擦除功能<br/> (4) 设置 FLASH_CR 寄存器中的 STRT 位为 1<br/> (5) 开始对主闪存全擦除<br/> (6) 检查 FLASH_SR 中的 BSY 位<br/> (7) 等待对主闪存全擦除的操作完成<br/> (8) 清除 FLASH_CR 寄存器中的 MER 位，使该位为 0<br/> (9) 可选做 Blank 检查，以确保擦除成功</p> | <pre> graph TD     A[读取FLASH_CR 中的LOCK位] --&gt; B{FLASH_CR的LOCK=1}     B -- 是 --&gt; C[执行解锁序列]     B -- 否 --&gt; D[FLASH_CR中的MER位写1]     D --&gt; E[FLASH_CR中的STRT位写1]     E --&gt; F{FLASH_SR的BSY=1}     F -- 是 --&gt; E     F -- 否 --&gt; G[FLASH_CR中的MER位写0]     G --&gt; H[读取用户存储器中的所有地址来检查擦除操作]   </pre> |

页擦除操作的寄存器设置，具体步骤如下：

| 执行步骤                                                                                                                                                                                                                                                                                                                                                   | 简易流程图                                                                                                                                                                                                                                                                                                                                                  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <p>(1) 读 FLASH_CR 的 LOCK 位，确保解除 Flash 保护，否则执行 Flash Unlock<br/> (2) 设置 FLASH_CR 寄存器中的 PER 位为 1，使能页擦除功能<br/> (3) 把待擦除页基地址写入 FLASH_AR 寄存器<br/> (4) 设置 FLASH_CR 寄存器中的 STRT 位为 1，开始页擦除<br/> (5) 检查 FLASH_SR 中的 BSY 位<br/> (6) 等待页擦除的操作完成<br/> (7) 清除 FLASH_CR 寄存器中的 PER 位，使该位为 0<br/> (8) 可选对这一页的内容做检查，以确保页擦除成功<br/> (9) 连续多页擦除，可以重复 2~7 操作；直到完成所有页面擦除</p> | <pre> graph TD     A[读FLASH_CR的LOCK位] --&gt; B{FLASH_CR=的LOCK=1}     B -- 是 --&gt; C[执行解锁序列]     B -- 否 --&gt; D[FLASH_CR中的PER位写1]     D --&gt; E[将要擦除的页面地址写入FLASH_AR]     E --&gt; F[将FLASH_CR中的STRT位写入1]     F --&gt; G{FLASH_SR中的BSY=1}     G -- 是 --&gt; F     G -- 否 --&gt; H[FLASH_CR中的PER位写0]     H --&gt; I[读取页面中的所有地址<br/>检查页面是否被擦除]   </pre> |

### 2.3.6 主闪存块编程

主闪存只支持以 16 位半字编程，用来修改主存储闪存块内容。如果以 32 位整字或 8 位字节的长度编程，将引起硬件错误中断。当 FLASH\_CR 中的 PG 位为 1 时，直接对相应的地址写一个半字（16 位），就是一次编程操作。

主闪存控制器会预读待编程半字是否为全 1（即是否为 0xFFFF），如果不是，这次编程操作会自动取消，并且在 FLASH\_SR 寄存器的 PGERR 位上提示编程错误警告。

如果待编程地址所对应的写保护块在 FLASH\_WRPR 中的写保护位有效，同样也不会有编程动作，同样也会产生编程错误警告，编程动作结束后，FLASH\_SR 寄存器中得 EOP 位会给出提示。

注意：当 CPU 进入省电模式时，通过 SWD 接口，对闪存操作将产生错误。避免在主闪存中运行中断程序时进行擦除或编程操作。

主闪存块编程操作的寄存器设置，具体步骤如下：

| 执行步骤                                                                                                                                                                                                                                                                                                                             | 简易流程图                                                                                                                                                                                                                                                                               |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <p>(1) 读 FLASH_CR 的 LOCK 位，确保解除 Flash 保护，否则执行 Flash Unlock</p> <p>(2) 设置 FLASH_CR 寄存器中的 PG 位为 1，使能半字编程功能</p> <p>(3) 以半字为单位向目标地址写入数据，目标地址需以半字对齐</p> <p>(4) 检查 FLASH_SR 中的 BSY 位</p> <p>(5) 等待半字编程操作完成</p> <p>(6) 清除 FLASH_CR 寄存器中的 PG 位，使该位为 0</p> <p>(7) 可选读目标地址数据，以确保半字编程成功</p> <p>(8) 连续多个半字编程，可以重复 2~6 操作；直到完成所有目标地址的半字编程</p> | <pre> graph TD     A[读FLASH_CR的LOCK位] --&gt; B{FLASH_CR的LOCK=1}     B -- 是 --&gt; C[执行解锁序列]     C --&gt; D[FLASH_CR的PG位写1]     D --&gt; E[在目标地址执行半字写入]     E --&gt; F{FLASH_SR的BSY=1}     F -- 否 --&gt; G[FLASH_CR的PG位写0]     G --&gt; H[读取编程地址来检查编程值]     F -- 是 --&gt; E   </pre> |

### 2.3.7 选项字节区块擦除

选项字节区块擦除操作的寄存器设置，具体步骤如下：

| 执行步骤                                                                                                                                                                                                                                                                                                                                                                                                                                           | 简易流程图                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <p>(1) 读 FLASH_CR 的 LOCK 位，确保解除 Flash 保护，否则执行 Flash Unlock</p> <p>(2) 读 FLASH_CR 的 OPTWRE 位，确保解除选项区块保护，否则执行选项区块 Unlock</p> <p>(3) 把待擦除区块基址写入 FLASH_AR 寄存器</p> <p>(4) 设置 FLASH_CR 寄存器中的 OPTER 位为 1，使能选项字节块擦除功能</p> <p>(5) 设置 FLASH_CR 寄存器中的 STRT 位为 1</p> <p>(6) 检查 FLASH_SR 中的 BSY 位</p> <p>(7) 等待选项字节块擦除操作完成</p> <p>(8) 清除 FLASH_CR 寄存器中的 OPTER 位，设置值为 0</p> <p>(9) 可选对这一区块的内容做检查，以确保对该区块擦除成功</p> <p>(10) 连续多块擦除，可以重复 3~8 操作；直到完成所有选项区块擦除</p> | <pre> graph TD     A[读FLASH_CR<br/>的LOCK位] --&gt; B{FLASH_CR<br/>的LOCK=1}     B -- 是 --&gt; C[执行解锁序列]     B -- 否 --&gt; D{FLASH_CR<br/>的OPTWRE=0}     D -- 是 --&gt; E[执行解锁OPT序列]     D -- 否 --&gt; F[将闪存选项字节块地址<br/>写入FLASH_AR]     F --&gt; G[FLASH_CR中的OPTER位写1]     G --&gt; H[FLASH_CR的STRT位写1]     H --&gt; I{FLASH_SR<br/>的BSY=1}     I -- 是 --&gt; H     I -- 否 --&gt; J[FLASH_CR中的OPTER位写0]     J --&gt; K[通过读取闪存选项存储器中<br/>的所有地址来检查<br/>闪存选项擦除操作]   </pre> |

### 2.3.8 选项字节区块编程

选项字节区块的编程与主闪存块地址的编程不同，因其写入值复位后加载到配置选项，需要更加严格的保护。解除对闪存控制器的访问限制后，还需要对选项字节区块解除访问限制。完成该操作后，FLASH\_CR 寄存器中的 OPTWRE 位会被置 1，才能允许后续的编程操作。

选项字节有效数据为低 8 位，而高 8 位为低 8 位的反码，从而组成为 16 位数据。在编程过程中，软件将高 8 位设置为低 8 位的反码，保证选项字节的写入值总是对的，然后依次写入 16 位数据。

当选项字节被改变时，需要系统上电复位使之生效。

选项字节区块半字编程操作的寄存器设置，具体步骤如下：

| 执行步骤                                                                                                                                                                                                                                                                                                                                                                                                  | 简易流程图                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <p>(1) 读 FLASH_CR 的 LOCK 位，确保解除 Flash 保护，否则执行 Flash Unlock</p> <p>(2) 读 FLASH_CR 的 OPTWRE 位，确保解除选项区块保护，否则执行选项区块 Unlock</p> <p>(3) 设置 FLASH_CR 寄存器中的 OPTPG 位为 1，使能选项字节区块半字编程</p> <p>(4) 写数据（半字）到目标地址，目标地址需以半字对齐</p> <p>(5) 检查 FLASH_SR 中的 BSY 位</p> <p>(6) 等待半字编程操作完成</p> <p>(7) 清除 FLASH_CR 寄存器中的 OPTPG 位，使该位值为 0</p> <p>(8) 可选读目标地址数据，以确保半字编程成功</p> <p>(10) 连续多个半字编程，可以重复 3~7 操作；直到完成所有目标地址的半字编程</p> | <pre> graph TD     A[读FLASH_CR<br/>的LOCK位] --&gt; B{FLASH_CR<br/>的LOCK=1}     B -- 是 --&gt; C[执行解锁序列]     B -- 否 --&gt; D{FLASH_CR<br/>的OPTWRE=0}     D -- 是 --&gt; E[执行解锁OPT序列]     D -- 否 --&gt; F[FLASH_CR的<br/>OPTPG位写1]     F --&gt; G[在所需地址执行半字写入]     G --&gt; H{FLASH_SR<br/>的BSY=1}     H -- 是 --&gt; G     H -- 否 --&gt; I[FLASH_CR的<br/>OPTPG位写0]     I --&gt; J[通过读取目标地址数据<br/>来检查编程值]   </pre> |

## 2.3.9 闪存保护

主闪存块使能读写保护可以防范主闪存块的代码被不可信的代码读出，也可以防范在程序跑飞的时候对主闪存块的意外擦除与编程。使能读保护的范围是整个主闪存块，而使能写保护的最小单位是一个写保护块（即 4 页）。

### 2.3.9.1 主闪存块读保护

主闪存块使能或解除读保护是通过从内置 SRAM 或 ICP、ISP 方式设置 RDP 半字，然后系统重新上电复位，加载了新的 RDPs 后起作用的。设置读保护，需要执行一次上电复位，而不是系统复位，才能起作用。

#### 使能读保护

按选项字节区块半字编程的操作方式，按顺序写 RDP 半字到对应地址

- 设置 FLASH AR 地址值为 0x1FFF800，执行该选项区块擦除。
- 按选项字节区块半字编程的操作方式，按顺序写 0x807F 半字到对应地址。
- 进行上电复位以重新加载选项字节，此时读保护被使能。

当 RDP 字包含下列数值时，且被重新上电复位后主闪存块被置于保护状态。

表 2-8 Flash 读保护状态

| 使能读保护操作                                                           | 读保护状态 |
|-------------------------------------------------------------------|-------|
| 对 0xFFFF800 选项区块擦除<br>写 0x807F 半字到对应地址 0xFFFF800<br>重新上电复位，读保护被使能 | 保护    |

当读保护半字被写入相应的值以后：

1. 只允许从用户代码执行对主闪存存储器的读操作（以非调试方式从主闪存存储器启动）。
2. 读保护后，调试模式下（SRAM boot 和 debug 模式）禁止对 Flash 进行操作。
3. MCU 可以通过在主闪存存储器中执行的代码进行编程（实现 IAP 或数据存储等功能），但不允许在调试模式下或从内部 SRAM 启动后执行主闪存块写或页擦除操作（整片擦除除外）。
4. 所有通过 SWD 向内置 SRAM 装载代码并执行代码的功能依然有效，亦可以通过 SWD 从内置 SRAM 启动，这个功能可以用来解除读保护。
5. 通过从内置 SRAM 执行代码访问主闪存存储器的操作，通过 DMA、SWD（串行线调试）对闪存的访问都将被禁止。

解除读保护

从内置 SRAM 或 ICP 方式解除读保护的过程是：

1. 设置 FLASH\_AR 地址值为 0xFFFF800，执行该选项区块擦除。
2. 按选项字节区块半字编程的操作方式，按流程写 0x5AA5 半字到对应地址。
3. 设置 FLASH\_AR 地址值为 0x08000000，执行主 Flash 全片擦除。
4. 进行上电复位以重新加载选项字节，此时读保护被解除。

表 2-9 Flash 解除读保护状态

| 解除读保护操作                                                                                         | 读保护状态 |
|-------------------------------------------------------------------------------------------------|-------|
| 对 0xFFFF800 选项区块擦除<br>写 0x5AA5 半字到对应地址 0xFFFF800<br>对 0x08000000 的主 Flash 全片擦除<br>重新上电复位，读保护被解除 | 解除读保护 |

注：1.如选项字节块对应的地址值为非 0xFFFF，需先执行擦除选项字节块的动作，执行擦除选项字节块的动作不会导致自动的整片擦除操作，不会改变读保护状态。2.必需对 0x08000000 的主 Flash 全片擦除。

### 2.3.9.2 主闪存块写保护

使能写保护

写保护通过设置选项字节区块中的 WRP0 中的 WRP 位为 0，来设置写保护，系统复位后将加载新选项字节，使能写保护。如果试图写入或擦除一个受写保护的页，会引起 FLASH\_SR 中的 WRPRERR 标志位置位。

表 2-10 写保护区域

| 地址          | [15: 8] | [7: 0] | 默认值    | 注释 |
|-------------|---------|--------|--------|----|
| 0x1FFF F808 | nWRPO   | WRPO   | 0xFFFF |    |

解除写保护

解除写保护有下述 2 种情形：

1. 情形 1：解除写保护，同时解除读保护：

a. 使用闪存控制寄存器（FLASH\_CR）的 OPTER 位擦除整个选项字节区块；写 0x5AA5 半字到对应地址 0x1FFF800；

b. 对 0x08000000 的主 Flash 全片擦除；

c. 进行系统复位，重装载选项字节（包含新的 WRP 字节），写保护被解除。

使用这种方法，将解除全片主闪存模块的写保护同时擦除全片主闪存块。

2. 情形 2：解除写保护，同时保持读保护有效，这种情况常见于用户自己实现在程序中编程的启动程序中：

a. 使用闪存控制寄存器（FLASH\_CR）的 OPTER 位擦除整个选项字节区块；

b. 进行系统复位，重装载选项字节（包含新的 WRP 字节），写保护被解除。

使用这种方法，将解除整个主闪存模块的写保护，同时保持读保护有效。

## 2.4 寄存器

### 2.4.1 寄存器总览

表 111 FLASH 寄存器概览

| Offset | Acronym       | Register Name | Reset      |
|--------|---------------|---------------|------------|
| 0x00   | FLASH_ACR     | 闪存访问控制寄存器     | 0x00000038 |
| 0x04   | FLASH_KEYR    | FPEC 键寄存器     | 0x00000000 |
| 0x08   | FLASH_OPTKEYR | 闪存 OPTKEY 寄存器 | 0x00000000 |
| 0x0C   | FLASH_SR      | 闪存状态寄存器       | 0x00000000 |
| 0x10   | FLASH_CR      | 闪存控制寄存器       | 0x00000080 |
| 0x14   | FLASH_AR      | 闪存地址寄存器       | 0x00000000 |
| 0x1C   | FLASH_OBR     | 选项字节寄存器       | 0x03FFFC1C |
| 0x20   | FLASH_WRPR    | 写保护寄存器        | 0xFFFFFFFF |

注意：Flash 寄存器只支持以 32 位的方式访问

### 2.4.2 FLASH\_ACR 闪存访问控制寄存器

偏移地址：0x00

复位值：0x0000 0038

|      |    |    |    |    |    |    |    |    |    |        |        |      |         |    |    |
|------|----|----|----|----|----|----|----|----|----|--------|--------|------|---------|----|----|
| 31   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21     | 201    | 19   | 18      | 17 | 16 |
| Res. |    |    |    |    |    |    |    |    |    |        |        |      |         |    |    |
| 15   | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5      | 4      | 3    | 2       | 1  | 0  |
| Res. |    |    |    |    |    |    |    |    |    | PRFTBS | PRFTBE | Res. | LATENCY |    |    |
|      |    |    |    |    |    |    |    |    |    | r      | rw     |      | rw      |    |    |

| Bit   | Field   | Description                                                                                                                                                                  |
|-------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31: 6 | Res.    | 保留, 必须保持复位值                                                                                                                                                                  |
| 5     | PRFTBS  | 预取缓冲区状态 (Prefetchbufferstatus)<br>0: 预取缓冲区关闭<br>1: 预取缓冲区开启                                                                                                                   |
| 4     | PRFTBE  | 预取缓冲区使能 (Prefetch buffer enable)<br>0: 关闭预取缓冲区<br>1: 启用预取缓冲区<br>注释 1: 只有当 LATENCY 为 0 时, 通过此位才能控制预取缓冲区开关;<br>注释 2: 当 RCC_CFGR 中 HPRE[3]位设置为非 0 值时, 预取缓冲区硬件自动使能, PRFTBS 位置 1。 |
| 3     | Res.    | 保留, 必须保持复位值                                                                                                                                                                  |
| 2: 0  | LATENCY | 时延 (Latency)<br>这些位表示 SYSCLK (系统时钟) 周期与闪存访问时间的比例。<br>000: 零等待状态, 当 $0 < \text{SYSCLK} \leq 24\text{MHz}$<br>001: 一个等待状态, 当 $24\text{MHz} < \text{SYSCLK} \leq 48\text{MHz}$  |

### 2.4.3 FLASH\_KEYR FPEC 键寄存器

偏移地址: 0x04

复位值: 0x0000 0000

| 31    | 30    | 29                                       | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|-------|------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|
| FKEYR |       |                                          |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15    | 14    | 13                                       | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| W     |       |                                          |    |    |    |    |    |    |    |    |    |    |    |    |    |
|       |       |                                          |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | Field | Description                              |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 31: 0 | FKEYR | FPEC 键 (Flash key)<br>这些位用于输入 FPEC 的解锁键。 |    |    |    |    |    |    |    |    |    |    |    |    |    |

注: 所有这些位是只写的, 读出时返回 0。

#### 2.4.4 FLASH\_OPTKEYR 闪存 OPTKEY 寄存器

偏移地址: 0x08

复位值: 0x0000 0000

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

| Bit   | Field   | Description                                         |
|-------|---------|-----------------------------------------------------|
| 31: 0 | OPTKEYR | 选择字节键 (Option byte key)<br>这些位用于输入选项字节的键以解除 OPTWRE。 |

注: 所有这些位是只写的, 读出时返回 0。

#### 2.4.5 FLASH\_SR 闪存状态寄存器

偏移地址: 0x0C

复位值: 0x0000 0000

|      |     |    |    |    |    |    |    |    |    |     |          |      |       |      |     |
|------|-----|----|----|----|----|----|----|----|----|-----|----------|------|-------|------|-----|
| 31   | 302 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21  | 20       | 19   | 18    | 17   | 16  |
| Res. |     |    |    |    |    |    |    |    |    |     |          |      |       |      |     |
|      |     |    |    |    |    |    |    |    |    |     |          |      |       |      |     |
| 15   | 14  | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5   | 4        | 3    | 2     | 1    | 0   |
| Res. |     |    |    |    |    |    |    |    |    | EOP | WRPRTERR | Res. | PGERR | Res. | BSY |
|      |     |    |    |    |    |    |    |    |    | rw  | rw       |      | rw    |      | r   |

| Bit  | Field    | Description                                                                                                               |
|------|----------|---------------------------------------------------------------------------------------------------------------------------|
| 31:6 | Res.     | 保留, 必须保持复位值                                                                                                               |
| 5    | EOP      | 操作结束 (End of operation)<br>当闪存操作 (编程   擦除) 完成时, 硬件设置这位为“1”, 写入“1”可以清除这位状态。                                                |
| 4    | WRPRTERR | 写保护错误 (Write protection error)<br>试图对写保护的闪存地址编程时, 硬件设置这位为“1”, 写入“1”可以清除这位状态。                                              |
| 3    | Res.     | 保留, 必须保持复位值                                                                                                               |
| 2    | PGERR    | 编程错误 (Programming error)<br>试图对内容不是“0xFFFF”的地址编程时, 硬件设置这位为“1”, 写入“1”可以清除这位状态。<br>注: 进行编程操作之前, 必须先清除 FLASH_CR 寄存器的 STRT 位。 |
| 1    | Res.     | 保留, 必须保持复位值                                                                                                               |

| Bit | Field | Description                                                      |
|-----|-------|------------------------------------------------------------------|
| 0   | BSY   | 忙 (Busy)<br>该位指示闪存操作正在进行。在闪存操作开始时，该位被置为“1”；在操作结束或发生错误时该位被清除为“0”。 |

#### 2.4.6 FLASH\_CR 闪存控制寄存器

偏移地址: 0x10

复位值: 0x0000 0080

|      |    |    |    |    |    |        |      |      |      |       |       |      |     |     |    |
|------|----|----|----|----|----|--------|------|------|------|-------|-------|------|-----|-----|----|
| 31   | 30 | 29 | 28 | 28 | 27 | 26     | 25   | 24   | 23   | 22    | 21    | 20   | 19  | 18  | 17 |
| Res. |    |    |    |    |    |        |      |      |      |       |       |      |     |     |    |
| 15   | 14 | 13 | 12 | 11 | 10 | 9      | 8    | 7    | 6    | 5     | 4     | 3    | 2   | 1   | 0  |
| Res. |    |    |    |    |    | OPTWRE | Res. | LOCK | STRT | OPTER | OPTPG | Res. | MER | PER | PG |
|      |    |    |    |    |    |        | rw   |      | rw   | rw    | rw    |      | rw  | rw  | rw |

| Bit   | Field  | Description                                                                                                            |
|-------|--------|------------------------------------------------------------------------------------------------------------------------|
| 31:10 | Res.   | 保留, 必须保持复位值                                                                                                            |
| 9     | OPTWRE | 允许写选项字节 (Option byte write enable)<br>当该位为“1”时, 允许对选项字节进行编程操作。当在 FLASH_OPTKEYR 寄存器写入正确的键序列后, 该位被置为“1”。<br>软件写 0 可清除此位。 |
| 8     | Res.   | 保留, 必须保持复位值                                                                                                            |
| 7     | LOCK   | 锁 (Lock)<br>只能写“1”。当该位为“1”时表示 FPEC 和 FLASH_CR 被锁住。在检测到正确的解锁序列后, 硬件自动清除此位为“0”。<br>在一次不成功的解锁操作后, 下次系统复位前, 该位不能再被改变。      |
| 6     | STRT   | 开始 (Start)<br>当该位为“1”时将触发一次擦除操作。该位只可由软件置为“1”并在 BSY 变为“1”时自动清“0”。                                                       |
| 5     | OPTER  | 擦除选项字节 (Option byte erase)<br>擦除选项字节。                                                                                  |
| 4     | OPTPG  | 烧写选项字节 (Option byte programming)<br>对选项字节编程。                                                                           |
| 3     | Res.   | 保留, 必须保持复位值                                                                                                            |
| 2     | MER    | 全擦除 (Mass erase)<br>选择擦除所有用户页。                                                                                         |
| 1     | PER    | 页擦除 (Page erase)<br>选择擦除页。                                                                                             |
| 0     | PG     | 编程 (Programming)<br>选择编程操作。                                                                                            |

### 2.4.7 FLASH\_AR 闪存地址寄存器

偏移地址: 0x14

复位值: 0x0000 0000

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

| Bit   | Field | Description                                                                    |
|-------|-------|--------------------------------------------------------------------------------|
| 31: 0 | FAR   | 用户闪存地址 (Flash Address)<br>当进行页擦除时选择要擦除的页。注意：当 FLASH_SR 中的 BSY 位为“1”时，不能写这个寄存器。 |

由硬件修改为当前最后使用的地址。页擦除操作中，必须修改这个寄存器以指定要擦除的页。

### 2.4.8 FLASH\_OBR 选项字节寄存器

偏移地址: 0x1C

复位值: 0x03FF FC1C

|       |    |    |    |    |    |       |          |        |      |              |           |        |       |        |    |
|-------|----|----|----|----|----|-------|----------|--------|------|--------------|-----------|--------|-------|--------|----|
| 31    | 30 | 29 | 28 | 27 | 26 | 25    | 24       | 23     | 22   | 21           | 20        | 19     | 18    | 17     | 16 |
| Res.  |    |    |    |    |    | Data1 |          |        |      |              |           |        |       |        |    |
|       |    |    |    |    |    | r     |          |        |      |              |           |        |       |        |    |
| 15    | 14 | 13 | 12 | 11 | 10 | 9     | 8        | 7      | 6    | 5            | 4         | 3      | 2     | 1      | 0  |
| Data0 |    |    |    |    |    | Res.  | OBR_RSTN | nBOOT1 | Res. | nRST_STANDBY | nRST_STOP | WDG_SW | RDPRT | OPTERR |    |
| r     |    |    |    |    |    | r     | r        |        | r    | r            | r         | r      | r     | r      | r  |

| Bit    | Field    | Description                              |
|--------|----------|------------------------------------------|
| 31: 26 | Res.     | 保留，必须保持复位值                               |
| 25: 18 | Data1    | Data1                                    |
| 17: 10 | Data0    | Data0                                    |
| 9: 8   | Res.     | 保留，必须保持复位值                               |
| 7      | OBR_nRST | NRST 复用 PA10<br>1: NRST 功能<br>0: GPIO 功能 |
| 6      | nBOOT1   | nBOOT1                                   |
| 5      | Res.     | 保留，必须保持复位值                               |

| Bit | Field        | Description                                                            |
|-----|--------------|------------------------------------------------------------------------|
| 4   | nRST_STANDBY | 进入待机模式时的复位事件<br>0: 当进入待机模式时产生复位<br>1: 进入待机模式时不产生复位                     |
| 3   | nRST_STOP    | 进入停机模式时的复位事件<br>0: 当进入停机 (STOP) 模式时产生复位<br>1: 进入停机 (STOP) 模式时不产生复位     |
| 2   | WDG_SW       | 选择看门狗事件<br>0: 硬件看门狗<br>1: 软件看门狗                                        |
| 1   | RDPRT        | 读保护 (Read protection level status)<br>当设置为“1”，表示闪存存储器被读保护。<br>注：该位为只读。 |
| 0   | OPTERR       | 选项字节错误 (Option byte error)<br>当该位为“1”时表示选项字节和它的反码不匹配。<br>注意：该位为只读。     |

#### 2.4.9 FLASH\_WRPR 写保护寄存器

偏移地址: 0x20

复位值: 0x0000 FFFF

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

| Bit  | Field | Description                                                            |
|------|-------|------------------------------------------------------------------------|
| 31:8 | Res.  | 保留，必须保持复位值                                                             |
| 7:0  | WRP   | 写保护 (Write protect)<br>该寄存器包含由 OBL 加载的写保护选项字节。<br>0: 写保护生效<br>1: 写保护失效 |

### 3 PWR 电源控制

电源控制 PWR (Power Controller) 主要涉及芯片的供电系统、电源管理器和低功耗模式等功能。

#### 3.1 供电系统

芯片由以下两种电源提供供电：



图 3-1 电源控制功能框图

- 由 VDDA 和 VSSA 提供的模拟电源，为芯片模拟模块提供电压，用于 ADC 模块、内部基准电压传感器和 PLL 等。
- 由 VDD 和 VSS 提供的数字电源，用于数字部分和 I/O 引脚工作。

注：

- 在供电系统中要求在相应的电源引脚上外接 10uF 和 100nF 的电容，并尽量靠近芯片电源引脚摆放。
- 在有 VDDA 和 VSSA 的封装中，VDDA 和 VSSA 不可悬空，且 VDD 和 VDDA 电压差要小于 50mV。
- 在没有 VDDA 和 VSSA 的封装中，已经在封装内部将 VDD 和 VDDA 连接，VSSA 和 VSS 连接。

##### 3.1.1 模拟模块供电

VDDA 主要给芯片内部模拟电路提供电源，主要包括 ADC 模块、内部基准电压传感器和 PLL 等，因此电源的稳定性影响模拟模块的工作性能。

ADC 的精度有一部分取决于 ADC 模块供电的稳定性。针对有需要高精度的 ADC 的应用，为了过滤和屏蔽来自印刷电路板上的毛刺对 ADC 采样的干扰、提高 ADC 的转换精度，ADC 需要一个独立稳定的外部电源供电。

- ADC 的电源引脚为 VDDA
- ADC 独立的电源地 VSSA

### 3.1.2 数字模块供电

VDD、VSS 是芯片数字模块供电电源端口，主要为 IO 供电以及通过稳压器为内核、内置数字外设和存储器等供电。

### 3.1.3 VDD 域

VDD 域主要给 PMU、IWDG 供电，在上电后保持工作状态。

### 3.1.4 1.5V 域

1.5V 域主要给芯片的内核、内存和外设提供供电，在上电后默认是开启状态，在进入低功耗待机模式时，芯片会硬件选择关闭该 1.5V 域，在唤醒后芯片会自动开启。主要有以下几种工作状态：

运行模式：1.5V 域以正常的功耗模式运行，内存、外设都正常工作。

睡眠模式：1.5V 域以正常功耗模式工作，CPU 进入睡眠模式，内存、外设都以正常的功耗模式工作。

停机模式：1.5V 域以低功耗模式工作，只保持寄存器和 RAM 的内容。

深度停机模式：1.5V 域以更低功耗模式工作，只保持寄存器和 RAM 的内容。

待机模式：1.5V 域停止供电。此域寄存器和 SRAM 的内容全部丢失。

## 3.2 电源管理器

### 3.2.1 POR 上电复位和 PDR 掉电复位

芯片有一个完整的上电复位（POR）和掉电复位（PDR）电路。当供电电压达到芯片最低的工作电压后系统能正常工作，当供电电压低于芯片最低的工作电压时，系统处于非工作状态。在对芯片进行上电或者掉电操作时，上电操作的供电电压达到芯片最低的工作电压时，芯片产生的上电复位会被释放；芯片在掉电操作时，电压低于最低工作电压时，芯片会产生掉电复位。

当 VDD 低于指定的 POR/PDR 限位电压时，系统保持为复位状态，NRST 复位引脚处于低电平，关于复位持续时间 ( $t_{RSTTEMPO}$ ) 等上电复位和掉电复位的细节请参考数据手册的电气特性部分。



图 3-2 上电复位和掉电复位波形图

### 3.2.2 PVD 可编程电压监测器

可编程电压监测器 PVD (Programmable Voltage Detector) 可以用来监视芯片的供电电压，在供电电压下降到给定的阈值以下时，产生一个中断，软件可以做紧急处理。当供电电压又恢复到给定的阈值以上时，也会产生一个中断，软件处理供电恢复。供电下降的阈值与供电上升的阈值有一个固定的差值，这就是 PVD 迟滞电压，通过列出的 PVD 阈值数据可以看到这个差别。引入这个差值的目的是为了防止电压在阈值上下小幅抖动，而频繁地产生中断。

用户可以通过软件设置电源控制寄存器 PWR\_CR. PLS 位的阈值电压与芯片供电电压进行比较，用来监控电源。通过设置电源控制寄存器 PWR\_CR.PVDE 位来使能 PVD。电源控制/状态寄存器 PWR\_CSR. PVDO 标志用来表明 VDD 是高于还是低于 PWR\_CR.PLS 位选择的阈值电压。

PVD 中断对应到外部中断 EXTI 16，如果用户有配置外部中断 EXTI 16，该事件就会产生中断，进入相应中断服务函数。当 VDD 下降到 PVD 阈值以下或当 VDD 升到 PVD 阈值以上时，根据设置的外部中断 EXTI 16 的上升/下降边沿触发，就会产生 PVD 中断（也可以通过软件配置产生 PVD 复位）。用户可以在中断中做一些对应的操作，例如：当条件触发且掉电的速率慢于中断中处理程序的执行时间时，如果系统需要进入特别保护状态，那么可以通过执行紧急关闭任务，以保存系统一些重要数据，同时也对外设进行相应的保护等操作。



图 3-3 PVD 阈值波形图

### 3.3 功耗控制

#### 3.3.1 功耗控制概述

在系统或电源复位以后，MCU 处于运行状态。在 MCU 不需要工作时，可以利用 MCU 提供的多种低功耗模式来节省功耗；当需要 MCU 重新开始工作时，可以通过多种唤醒源唤醒 MCU，从而达到节省芯片电流消耗的目的。

芯片有四种低功耗模式，这些模式电源消耗不同、唤醒时间不同、唤醒源不同，用户可以根据应用需求，选择最佳的低功耗模式。

四种低功耗模式为：

**睡眠模式：**CPU 停止，所有芯片外设包括 CPU 的外设，如 NVIC、SysTick 等仍在运行。

**停机模式：**1.5V 域以低功耗模式工作，CPU 及所有外设时钟都停止，只保持寄存器和 RAM 的内容。

**深度停机模式：**1.5V 域以更低功耗模式工作，CPU 及所有外设时钟都停止，只保持寄存器和 RAM 的内容。

**待机模式：**1.5V 域停止供电，此域寄存器和 SRAM 的内容全部丢失。

此外，在运行模式下，可以通过以下方式中的一种降低功耗：

- 降低系统时钟频率：在满足应用需求的同时可以选择低速时钟频率或采用高速时钟和低速时钟循环切换的方式来节省功耗。
- 关闭 APB 和 AHB 总线上未被使用的外设时钟：用户只使能应用需要的时钟，其他多余的时钟都

选择关闭。

- 选择低电压供电：供电电压越高芯片的耗电越大，所以应用中在芯片安全的供电电压范围内可以选择合适的供电电压。

表 3-1 低功耗模式列表

| 模式                        | 进入方式                                       | 唤醒方式                                  | 对 1.5V 域时钟的影响            | 对 VDD 域时钟的影响         | 电压稳压器 | 对数据和寄存器的影响              | 注意事项                         |
|---------------------------|--------------------------------------------|---------------------------------------|--------------------------|----------------------|-------|-------------------------|------------------------------|
| 睡眠模式<br>(Sleep Mode)      | WFI (Wait for Interrupt)                   | 任一中断                                  | CPU 时钟关，对其他时钟和 ADC 时钟无影响 | 无                    | 开     | 寄存器和 SRAM 的内容保持         | 外设时钟继续维持，寄存器和 SRAM 的内容保持     |
|                           | WFE (Wait for Event)                       | 唤醒事件                                  |                          |                      |       |                         |                              |
| 停机模式<br>(Stop Mode)       | 清除 LPDS 位；设置 SLEEPDEEP 位；WFI 或 WFE；        | 任一外部中断（在外部中断寄存器中设置）或事件、IWDG 中断（非复位）唤醒 | 所有使用 1.5V 域的时钟都已关闭       | PLL、HSI 和 HSE 的振荡器关闭 | 开     | 寄存器和 SRAM 的内容保持         | 进入低功耗模式前不使用的 GPIO 应该设置模拟输入状态 |
| 深度停机模式<br>(DeepStop Mode) | 清除 PDDS 位；设置 LPDS 位；SLEEPDEEP 位；WFI 或 WFE； | 任一外部中断（在外部中断寄存器中设置）或事件、IWDG 中断（非复位）唤醒 |                          |                      | 开     | 寄存器和 SRAM 的内容保持         | 进入低功耗前不使用的 GPIO 应该设置模拟输入状态   |
| 待机模式<br>(Standby Mode)    | 设置 PDDS 位；SLEEPDEEP 位；WFI 或 WFE；           | WKUP 引脚                               |                          |                      | 关     | 1.5V 域寄存器和 SRAM 的内容全部丢失 | 唤醒相当于芯片复位                    |

### 3.3.2 运行模式降低系统时钟

在满足应用需求的同时可以选择低速时钟频率或采用高速时钟和低速时钟循环切换的方式来节省功耗。

芯片的系统时钟可以灵活配置，用户可以选择不同的时钟源作为系统时钟；也可以通过配置不同时钟分频器来降低系统时钟（SYSCLK、HCLK、PCLK1）的频率。

进入睡眠模式前，降低外设的时钟频率可以有效节省睡眠模式下的功耗。

### 3.3.3 外设时钟的控制

在芯片执行程序过程中，可以通过关闭外设时钟来降低功耗。

使用睡眠模式时，在执行 WFI 或 WFE 指令前可以关闭外设的时钟，有效地降低睡眠模式下外设的电流消耗。

外设主要挂在 AHB 和 APB 总线，可以通过设置 AHB 外设时钟使能寄存器（RCC\_AHBENR）、APB 外设时钟使能寄存器（RCC\_APB1ENR）。

### 3.3.4 Sleep Mode 睡眠模式

#### 3.3.4.1 睡眠模式进入

通过执行 WFI（Wait For Interrupt）或 WFE（Wait for Event）指令，可以请求 MCU 进入睡眠模式。根据 CPU 系统控制寄存器中的 SLEEPONEXIT 位的值，有两种可用于选择进入睡眠模式的机制：

**SLEEPNOW:** 如果 SLEEPONEXIT 位被清除，当 WFI 或 WFE 被执行时，MCU 立即进入睡眠模式。

**SLEEPONEXIT:** 如果 SLEEPONEXIT 位被置位，系统从最低优先级的中断处理程序中退出后 MCU 立即进入睡眠模式。

在睡眠模式下，所有的 I/O 引脚都保持在运行模式时的状态。

#### 3.3.4.2 睡眠模式退出

中断或事件发生后，睡眠模式立即被唤醒。

表 3-2 SLEEPNOW 模式

| SLEEPNOW 模式 | 说明                                                                                           |
|-------------|----------------------------------------------------------------------------------------------|
| 进入          | 在以下条件下执行 WFI（Wait for Interrupt）或 WFE（Wait for Event）指令：<br>SLEEPDEEP = 0<br>SLEEPONEXIT = 0 |
| 退出          | 如果执行 WFI 进入睡眠模式：中断（参考中断向量表）<br>如果执行 WFE 进入睡眠模式：唤醒事件（参考唤醒事件管理）                                |
| 唤醒延时        | 立即唤醒                                                                                         |

表 3-3 SLEEPONEXIT 模式

| SLEEPONEXIT 模式 | 说明                                                                      |
|----------------|-------------------------------------------------------------------------|
| 进入             | 在以下条件下执行 WFI（Wait for Interrupt）指令：<br>SLEEPDEEP = 0<br>SLEEPONEXIT = 1 |
| 退出             | 中断（参考中断向量表）                                                             |
| 唤醒延时           | 立即唤醒                                                                    |

### 3.3.5 Stop Mode 停机模式

停机模式下，CPU 进入深度睡眠模式，1.5V 域的所有时钟都被停止，PLL、HSI 和 HSE 振荡器的功能被禁止，SRAM 和寄存器内容被保留下。

#### 3.3.5.1 停机模式进入

通过对独立的控制位进行编程，停机模式根据唤醒方式的不同有两种进入方式：

- 等待外部中断线 WFI 方式进入停机模式：配置电源控制寄存器（PWR\_CR）的 PDDS = 0，LPDS = 0；CPU 系统控制寄存器（SCR）的 SLEEPDEEP=1。当 WFI 被执行时，MCU 立即进入停机模式。
- 等待外部事件 WFE 方式进入停机模式：配置电源控制寄存器（PWR\_CR）的 PDDS = 0，LPDS = 0；CPU 系统控制寄存器（SCR）的 SLEEPDEEP=1。当 WFE 被执行时，MCU 立即进入停机模式。

进入停机模式时可选择以下功能：

- 独立看门狗（IWDG）：可通过写入独立看门狗的键寄存器或硬件选择来启动独立看门狗，独立看门狗可以选择中断或者复位方式唤醒芯片，中断方式唤醒芯片后 MCU 继续执行进入低功耗前的程序，复位方式唤醒后 MCU 执行复位；用户可以选择关闭 LSI 时钟源从而关闭独立看门狗。
- 内部低速振荡器（LSI 振荡器）：通过 RCC 控制/状态寄存器（RCC\_CSR）的 LSION 位来设置。

在停机模式下，如果在进入该模式前 ADC 没有被关闭，那么 ADC 仍然消耗电流。通过设置寄存器 ADC\_ADCFG 的 ADEN 位为 0 可关闭这个外设。其它没有使用的 GPIO 需要设置模拟输入模式，否则有电流消耗。

#### 3.3.5.2 停机模式退出

当停机模式被中断或事件唤醒且退出后，系统时钟源硬件自动选择为 HSI 振荡器，如果选择其它时钟源作为系统时钟需用户重新配置。

当电压稳压器处于运行模式下，系统从停机模式退出时，将会有一段额外的启动延时。

表 3-4 停机模式

| 停机模式 | 说明                                                                                                                                                                                                                      |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 进入   | <p>在以下条件下执行 WFI（Wait for Interrupt）或 WFE（Wait for Event）指令：<br/>置位 CPU 系统控制寄存器中的 SLEEPDEEP 位；<br/>复位电源控制寄存器（PWR_CR）中的 PDDS 位和 LPDS；<br/>注：为了进入停机模式，所有的外部中断的请求位（软件中断事件挂起寄存器 EXTI_PR）标志都必须被清除，否则停机模式的进入流程将被跳过，程序继续运行。</p> |

| 停机模式 | 说明                                                                                                                                                                        |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 退出   | 在以下条件下执行 WFI (Wait for Interrupt) 指令:<br>任一外部中断线被设置为中断模式（相应的外部中断向量在 NVIC 中必须使能），参见中断向量表 Wait for Event；<br>在以下条件下执行 WFE (Wait for Event) 指令：<br>任一外部中断线被设置为事件模式，例如 看门狗中断； |
| 唤醒延时 | HSI 的唤醒时间和电压稳压器唤醒产生的额外时间                                                                                                                                                  |
| 注意事项 | 在进入停机模式时需将不使用的 GPIO 设置成模拟输入模式                                                                                                                                             |

### 3.3.6 DeepStop Mode 深度停机模式

深度停机是在 CPU 深度睡眠模式的基础上结合了外设的时钟控制和电压稳压器控制机制的一种低功耗模式。在深度停机模式下，1.5V 域的所有时钟都被停止，PLL、HSI 和 HSE 振荡器的功能被禁止，SRAM 和寄存器内容被保留下。

#### 3.3.6.1 深度停机模式进入

通过对独立的控制位进行编程，深度停机模式根据唤醒的方式不同有两种进入方式：

- 等待外部中断线 WFI 方式进入深度停机模式：配置电源控制寄存器（PWR\_CR）的 PDSS = 0，LPDS = 1；CPU 系统控制寄存器（SCR）的 SLEEPDEEP=1。当 WFI 被执行时，MCU 立即进入深度停机模式。
- 等待外部事件 WFE 方式进入深度停机模式：配置电源控制寄存器（PWR\_CR）的 PDSS = 0，LPDS = 1；CPU 系统控制寄存器（SCR）的 SLEEPDEEP=1。当 WFE 被执行时，MCU 立即进入深度停机模式。

进入停机模式时可选择以下功能：

- 独立看门狗（IWDG）：可通过写入独立看门狗的键寄存器或硬件选择来启动独立看门狗，独立看门狗可以选择中断或者复位方式唤醒芯片，中断方式唤醒芯片后 MCU 继续执行进入低功耗前的程序，复位方式唤醒后 MCU 执行复位；用户可以选择关闭 LSI 时钟源从而关闭独立看门狗。
- 内部低速振荡器（LSI 振荡器）：通过 RCC 控制/状态寄存器（RCC\_CSR）的 LSION 位来设置。

在深度停机模式下，如果在进入该模式前 ADC 没有被关闭，那么 ADC 仍然消耗电流。通过设置寄存器 ADC\_ADCFG 的 ADEN 位为 0 可关闭这个外设。其他没有使用的 GPIO 需要设置模拟输入模式，否则有电流消耗。

#### 3.3.6.2 深度停机模式退出

当深度停机模式被中断或事件唤醒且退出后，系统时钟为 HSI 振荡器，如果选择其它时钟源作为系统时钟需用户重新配置。

当电压稳压器处于运行模式下，系统从深度停机模式退出时，将会有一段额外的启动延时。

表 3-5 深度停机模式

| 深度停机模式 | 说明                                                                                                                                                                                                                        |
|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 进入     | 在以下条件下执行 WFI (Wait for Interrupt) 或 WFE (Wait for Event) 指令：<br>置位 CPU 系统控制寄存器中的 SLEEPDEEP 位；<br>复位电源控制寄存器 (PWR_CR) 中的 PDDS，且置位 LPDS 位；<br>注：为了进入深度停机模式，所有的外部中断的请求位（中断事件挂起寄存器 EXTI_PR）标志都必须被清除，否则深度停机模式的进入流程将会被跳过，程序继续运行。 |
| 退出     | 在以下条件下执行 WFI (Wait for Interrupt) 指令：<br>任一外部中断引线被设置为中断模式（相应的外部中断向量在 NVIC 中必须使能），参见中断向量表 Wait for Event；<br>在以下条件下执行 WFE (Wait for Event) 指令：<br>任一外部中断线被设置为事件模式，例如看门狗中断；                                                 |
| 唤醒延时   | HSI 的唤醒时间和电压稳压器唤醒产生的额外时间                                                                                                                                                                                                  |
| 注意事项   | 在进入深度停机模式时需将不使用的 GPIO 设置成模拟输入模式                                                                                                                                                                                           |

### 3.3.7 Standby Mode 待机模式

待机模式是在 CPU 深睡眠模式的基础上关闭电压稳压器。整个 1.5V 域被切断，PLL、HSI 和 HSE 振荡器也被关闭，1.5V 域寄存器和 SRAM 内容丢失，待机电路维持供电。待机模式是芯片的最低功耗模式，唤醒后芯片将复位。

#### 3.3.7.1 待机模式进入

通过对独立的控制位进行编程，待机模式进入方式：

- 配置电源控制寄存器(PWR\_CR)的PDDS = 1; CPU 系统控制寄存器(SCR)的SLEEPDEEP=1。  
当 WFI/WFE 被执行时，MCU 立即进入待机模式。
- 进入待机模式时可选择以下功能：
- 独立看门狗 (IWDG)：通过写入独立看门狗的键寄存器或硬件选择来启动独立看门狗，可以通过独立看门狗的复位唤醒方式来唤醒芯片，唤醒后程序重新开始执行；用户可以选择关闭 LSI 时钟源从而关闭独立看门狗。
- 内部低速振荡器 (LSI 振荡器)：通过 RCC 控制/状态寄存器 (RCC\_CSR) 的 LSION 位来设置。

#### 3.3.7.2 待机模式退出

当待机模式被唤醒事件唤醒且退出后，产生待机复位。1.5V 域寄存器和 SRAM 内容丢失，只有待机电路维持供电。系统从待机模式退出时，将会有一段启动延时。

表 3-6 待机模式

| 待机模式 | 说明                                                                                                                                                                                                           |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 进入   | 在以下条件下执行 WFI (Wait for Interrupt) 或 WFE (Wait for Event) 指令:<br>置位 CPU 系统控制寄存器中的 SLEEPDEEP 位;<br>置位电源控制寄存器 (PWR_CR) 中的 PDDS 位;<br>复位电源控制/状态寄存器 (PWR_CSR) 中的 WUF 位;<br>注意：为确保芯片可以被正常唤醒，进入 Standby 模式前需关闭中断使能。 |
| 退出   | WKUP 引脚上升沿或者下降沿                                                                                                                                                                                              |
| 唤醒延时 | 复位阶段时电压稳压器的启动                                                                                                                                                                                                |
| 注意事项 | 在进入待机模式时需配置正确的唤醒源，否则进入待机模式后可能无法二次下载                                                                                                                                                                          |

#### 待机模式下的输入/输出端口状态

在待机模式下，所有的 I/O 引脚处于高阻态，除了以下的引脚：

- 被使能的唤醒引脚，用户需要正确的配置对应的唤醒边沿信号

#### 调试模式

默认情况下，如果在进行调试微处理器时，使微处理器进入停止或待机模式，将失去调试连接，这是因为 CPU 内核失去了时钟，因此需要设置正确的唤醒源。

#### 3.3.7.3 滤波功能

配置 PWR\_CR4 和 PWR\_CR5 寄存器的 FILTSEL0、FILTSEL1 选择需要过滤的唤醒引脚；FILTCNT0、FILTCNT1 选择唤醒源过滤宽度；最后配置 FILTE0、FILTE1 使能位打开唤醒源滤波功能。滤波功能开启后可以对唤醒源进行滤波，将滤波阈值（可配置寄存器位 FILTCNT0 调整阈值）以下的干扰滤除，防止误操作唤醒。



图 3-4 Standby 模式唤醒滤波功能波形图

### 3.3.7.4 快速唤醒功能

通过配置 PWR\_CR 寄存器的 STDBY\_FS\_WK 位,可以调节从唤醒事件发生到唤醒事件有效的时间。

## 3.4 调试模式

默认情况下, 如果在进行调试微处理器时, 使微处理器进入停止或待机模式, 将失去调试连接。这是由于 CPU 内核失去了时钟, 因此需要设置正确的唤醒源。

## 3.5 电源控制寄存器

表 3-7 电源控制寄存器概览

| Offset | Acronym  | RegisterName | Reset      |
|--------|----------|--------------|------------|
| 0x00   | PWR_CR   | 电源控制寄存器      | 0x00000600 |
| 0x04   | PWR_CSR  | 电源控制/状态寄存器   | 0x00000000 |
| 0x0C   | PWR_CR1  | 电源控制寄存器 1    | 0x00000000 |
| 0x24   | PWR_CFGR | 电源配置寄存器      | 0x00000160 |

### 3.5.1 PWR\_CR 电源控制寄存器

地址偏移: 0x00

复位值: 0x00000600 (从待机模式唤醒时清除)

|             |     |     |    |    |    |     |    |    |    |      |      |      |      |      |    |
|-------------|-----|-----|----|----|----|-----|----|----|----|------|------|------|------|------|----|
| 31          | 30  | 29  | 28 | 27 | 26 | 25  | 24 | 23 | 22 | 21   | 20   | 19   | 18   | 17   | 16 |
| Res         |     |     |    |    |    |     |    |    |    |      |      |      |      |      |    |
| 15          | 14  | 13  | 12 | 11 | 10 | 9   | 8  | 7  | 6  | 5    | 4    | 3    | 2    | 1    | 0  |
| STDBY_FS_WK | Res | PLS |    |    |    | Res |    |    |    | PVDE | CSBF | CWUF | PDDS | LPDS |    |
| rw          |     | rw  |    |    |    |     |    |    |    | rw   | w    | w    | rw   | rw   |    |

| Bit   | Field       | Description                                                                                        |
|-------|-------------|----------------------------------------------------------------------------------------------------|
| 31:16 | Reserved    | 保留, 始终读为 0                                                                                         |
| 15:14 | STDBY_FS_WK | 快速唤醒 Standby 时间选择位<br>00: 9 个 LSI 周期唤醒<br>01: 7 个 LSI 周期唤醒<br>10: 5 个 LSI 周期唤醒<br>11: 2 个 LSI 周期唤醒 |
| 13    | Reserved    | 保留, 始终读为 0                                                                                         |

| Bit  | Field    | Description                                                                                                                                                                                |
|------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12:9 | PLS      | PVD 电平阈值选择<br>0001: 2.0V<br>0010: 2.3V<br>0011: 2.6V<br>0100: 2.9V<br>0101: 3.2V<br>0110: 3.5V<br>0111: 3.8V<br>1000: 4.1V<br>1001: 4.4V<br>1010: 4.7V<br>其他: 保留<br>注: 详细说明参见数据手册中的电气特性部分。 |
| 8:5  | Reserved | 保留, 始终读为 0                                                                                                                                                                                 |
| 4    | PVDE     | PVD 使能<br>1: PVD 使能<br>0: PVD 禁止                                                                                                                                                           |
| 3    | CSBF     | 清除待机标志位 (Clear Standby Flag)<br>始终读出为 0<br>1: 清除 SBF 待机位 (写)<br>0: 无功效                                                                                                                     |
| 2    | CWUF     | 清除唤醒位 (Clear wakeup flag)<br>始终读出为 0<br>1 = 清除唤醒位<br>0 = 不清除唤醒位                                                                                                                            |
| 1    | PDDS     | 掉电深睡眠 (Power Down Deepsleep)<br>1: CPU 进入深睡眠时进入待机模式<br>0: CPU 进入深睡眠时进入停机模式                                                                                                                 |
| 0    | LPDS     | 深睡眠下的低功耗 (Low Power Deepstop)<br>PDDS = 0 时, 与 PDDS 位协同操作<br>1: 进入停机模式时, 电压稳压器处于低功耗模式。<br>0: 进入停机模式时, 电压稳压器处于正常功耗模式。<br>当进入停机模式时, LPDS = 1 时的电流小于 LPDS = 0 时的电流。详见该芯片对应的数据手册。              |

### 3.5.2 PWR\_CSR 电源控制/状态寄存器

地址偏移: 0x04

复位值: 0x00000000

在 RCC\_APB1RSTR.PWR 有效后复位

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

|     |    |    |    |    |    |   |   |      |     |   |   |   |   |   |   |  |
|-----|----|----|----|----|----|---|---|------|-----|---|---|---|---|---|---|--|
| Res |    |    |    |    |    |   |   |      |     |   |   |   |   |   |   |  |
| 15  | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7    | 6   | 5 | 4 | 3 | 2 | 1 | 0 |  |
| Res |    |    |    |    |    |   |   | EWUP | Res |   |   |   |   |   |   |  |
|     |    |    |    |    |    |   |   | rw   |     |   |   |   |   |   |   |  |

| Bit  | Field    | Description                                                                                                                            |
|------|----------|----------------------------------------------------------------------------------------------------------------------------------------|
| 31:9 | Reserved | 保留, 始终读为 0                                                                                                                             |
| 8    | EWUP     | 使能唤醒引脚 0 (Enable WakeUp Pin0)<br>1: WKUP 引脚用于唤醒待机模式, WKUP 引脚需要设置为输入下拉 (WKUP 引脚上的上升沿将系统从待机模式唤醒)<br>0 : WKUP 引脚上的事件不能唤醒待机模式, 该引脚为通用 I/O。 |
| 7: 3 | Reserved | 保留, 始终读为 0                                                                                                                             |
| 2    | PVDO     | PVD 输出状态<br>1: VDD 低于由 PLS[3: 0]选定的 PVD 阈值, PVD 输出高<br>0: VDD 低于由 PLS[3: 0]选定的 PVD 阈值, PVD 输出低<br>注: PVDE 必须使能。                        |
| 1    | SBF      | 待机标志 (Standby Flag)<br>该位由硬件设置, 并只能由 POR/PDR (上电/掉电复位) 或设置电源控制寄存器 1 (PWR_CR) 的 CSBF 位清除。<br>1: 系统进入待机模式<br>0: 系统不在待机模式                 |
| 0    | WUF      | 唤醒引脚 0 的唤醒标志位 (WakeUp Source0 Flag)<br>1: 检测到唤醒引脚有唤醒事件<br>0: 未检测到唤醒引脚有唤醒事件                                                             |

### 3.5.3 PWR\_CR1 电源控制寄存器 1

地址偏移: 0x0C

复位值: 0x00000000

寄存器在退出待机模式时不进行复位, 也不会在 RCC\_APB1RSTR.PWR 有效后复位

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

| Bit  | Field    | Description |
|------|----------|-------------|
| 31:1 | Reserved | 保留, 始终读为 0  |

| Bit | Field | Description                                                                |
|-----|-------|----------------------------------------------------------------------------|
| 0   | WP    | 唤醒引脚 0 的极性检测<br>1: 低电平检测（下降沿），唤醒引脚必须先配置为高电平<br>0: 高电平检测（上升沿），唤醒引脚必须先配置为低电平 |

### 3.5.4 PWR\_CFGR电源配置寄存器

地址偏移: 0x24

复位值: 0x00000160

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

| Bit  | Field     | Description                                                                                                                                                 |
|------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6 | Reserved  | 保留, 始终读为 0                                                                                                                                                  |
| 9:5  | LSICAL    | 内部低速时钟校准位 (Internal Low-speed Clock Calibration Bits)<br>在系统启动时, 这些位被自动初始化为出厂校准值, 用户可以写入其他校准值, 但读出始终为出厂校准值。如果 LSICALSEL=0x1F, 写入的值可以重新校正 LSI 频率, 否则写入的值不起作用 |
| 4:0  | LSICALSEL | 内部低速时钟校准值选择方式 (Internal Low-speed Calibration Select)<br>初值为 0, 当写入不同值时:<br>写入 1F: 选择寄存器 LSICAL 的值, 写入 1F 后仍读出为 0。<br>写入其他: 选择出厂校准值                         |

## 4 SYSCFG 系统控制器

### 4.1 简介

该芯片具有一组系统配置寄存器。这些寄存器的主要功能如下：

- 管理连接到 GPIO 口的外部中断（引脚配置）
- 重映射存储器到代码起始区域
- 部分外设的系统级配置

### 4.2 寄存器

#### 4.2.1 寄存器总览

表 4-1 SYSCFG 寄存器概览

| Offset | Acronym        | Register Name      | Reset      |
|--------|----------------|--------------------|------------|
| 0x00   | SYSCFG_CFGR    | SYSCFG 配置寄存器       | 0x0000000X |
| 0x08   | SYSCFG_EXTICR1 | SYSCFG 外部中断配置寄存器 1 | 0x00000000 |
| 0x0C   | SYSCFG_EXTICR2 | SYSCFG 外部中断配置寄存器 2 | 0x00000000 |
| 0x10   | SYSCFG_EXTICR3 | SYSCFG 外部中断配置寄存器 3 | 0x00000000 |
| 0x14   | SYSCFG_EXTICR4 | SYSCFG 外部中断配置寄存器 4 | 0x00000000 |
| 0x18   | SYSCFG_PADHYS  | SYSCFG PAD 配置寄存器   | 0x00000000 |

#### 4.2.2 SYSCFG\_CFGR 配置寄存器

该寄存器具有两位控制位 MEM\_MODE，可以用来配置不同存储器到起始地址 0x00000000 的映射。软件配置这两个控制位可用来屏蔽 BOOT 的选择。复位后，此控制位值由实际的 BOOT PIN 配置决定。

偏移地址：0x00

复位值：0x0000 000X

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

| Bit   | Field    | Description                                                                                                                                                                                                              |
|-------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31: 2 | Reserved | 保留, 必须保持复位值                                                                                                                                                                                                              |
| 1:0   | MEM_MODE | <p>存储映射选择位 (Memory Selection Bit)<br/>控制存储器内部映射到地址 0x0000 0000。<br/>由软件设置和清除这些位。当复位后这些位值由 BOOT0 的引脚配置值和 nBOOT1 bit 值决定。</p> <p>x0: 主闪存存储器映射到 0x0000 0000<br/>01: 系统闪存映射到 0x0000 0000<br/>11: 嵌入式 RAM 映射到 0x0000 0000</p> |

#### 4.2.3 SYSCFG\_EXTICR1 外部中断配置寄存器 1

偏移地址: 0x08

复位值: 0x0000 0000

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

Res.

|       |    |    |    |       |    |   |   |       |   |   |   |       |   |   |   |
|-------|----|----|----|-------|----|---|---|-------|---|---|---|-------|---|---|---|
| 15    | 14 | 13 | 12 | 11    | 10 | 9 | 8 | 7     | 6 | 5 | 4 | 3     | 2 | 1 | 0 |
| EXTI3 |    |    |    | EXTI2 |    |   |   | EXTI1 |   |   |   | EXTI0 |   |   |   |
| rw    |    |    |    | rw    |    |   |   | rw    |   |   |   | rw    |   |   |   |

| Bit   | Field    | Description                                                                                                  |
|-------|----------|--------------------------------------------------------------------------------------------------------------|
| 31:16 | Reserved | 保留, 必须保持复位值                                                                                                  |
| 15:0  | EXTIx    | <p>EXTIx 配置 (x=0...3) (EXTIx configuration)<br/>选择 EXTIx 外部中断的输入源。<br/>0000: PA[x] 管脚<br/>0001: PB[x] 管脚</p> |

#### 4.2.4 SYSCFG\_EXTICR2 外部中断配置寄存器 2

偏移地址: 0x0C

复位值: 0x0000 0000

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

Res.

|       |    |    |    |       |    |   |   |       |   |   |   |       |   |   |   |
|-------|----|----|----|-------|----|---|---|-------|---|---|---|-------|---|---|---|
| 15    | 14 | 13 | 12 | 11    | 10 | 9 | 8 | 7     | 6 | 5 | 4 | 3     | 2 | 1 | 0 |
| EXTI7 |    |    |    | EXTI6 |    |   |   | EXTI5 |   |   |   | EXTI4 |   |   |   |
| rw    |    |    |    | rw    |    |   |   | rw    |   |   |   | rw    |   |   |   |

| Bit   | Field    | Description                                                                                                |
|-------|----------|------------------------------------------------------------------------------------------------------------|
| 31:16 | Reserved | 保留，必须保持复位值                                                                                                 |
| 15:0  | EXTIx    | EXTIx 配置 ( $x=4\ldots 7$ ) (EXTIx configuration)<br>选择 EXTIx 外部中断的输入源。<br>0000: PA[x] 管脚<br>0001: PB[x] 管脚 |

#### 4.2.5 SYSCFG\_EXTICR3 外部中断配置寄存器 3

偏移地址: 0x10

复位值: 0x0000 0000

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

Res.

|        |    |    |    |        |    |   |   |       |   |   |   |       |   |   |   |
|--------|----|----|----|--------|----|---|---|-------|---|---|---|-------|---|---|---|
| 15     | 14 | 13 | 12 | 11     | 10 | 9 | 8 | 7     | 6 | 5 | 4 | 3     | 2 | 1 | 0 |
| EXTI11 |    |    |    | EXTI10 |    |   |   | EXTI9 |   |   |   | EXTI8 |   |   |   |
| rw     |    |    |    | rw     |    |   |   | rw    |   |   |   | rw    |   |   |   |

| Bit   | Field    | Description                                                                                                 |
|-------|----------|-------------------------------------------------------------------------------------------------------------|
| 31:16 | Reserved | 保留，必须保持复位值                                                                                                  |
| 15:0  | EXTIx    | EXTIx 配置 ( $x=8\ldots 11$ ) (EXTIx configuration)<br>选择 EXTIx 外部中断的输入源。<br>0000: PA[x] 管脚<br>0001: PB[x] 管脚 |

#### 4.2.6 SYSCFG\_EXTICR4 外部中断配置寄存器 4

偏移地址: 0x014

复位值: 0x0000 0000

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

Res.

|        |    |    |    |        |    |   |   |        |   |   |   |        |   |   |   |
|--------|----|----|----|--------|----|---|---|--------|---|---|---|--------|---|---|---|
| 15     | 14 | 13 | 12 | 11     | 10 | 9 | 8 | 7      | 6 | 5 | 4 | 3      | 2 | 1 | 0 |
| EXTI15 |    |    |    | EXTI14 |    |   |   | EXTI13 |   |   |   | EXTI12 |   |   |   |
| rw     |    |    |    | rw     |    |   |   | rw     |   |   |   | rw     |   |   |   |

| Bit   | Field    | Description |
|-------|----------|-------------|
| 31:16 | Reserved | 保留，必须保持复位值  |

| Bit  | Field | Description                                                                                                 |
|------|-------|-------------------------------------------------------------------------------------------------------------|
| 15:0 | EXTIx | EXTIx 配置 ( $x=12\ldots15$ ) (EXTIx configuration)<br>选择 EXTIx 外部中断的输入源。<br>0000: PA[x] 管脚<br>0001: PB[x] 管脚 |

#### 4.2.7 SYSCFG\_PADHYS PAD 配置寄存器

偏移地址: 0x18

复位值: 0x0000 0000

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

| Bit   | Field         | Description                        |
|-------|---------------|------------------------------------|
| 31:17 | Reserved      | 保留, 必须保持复位值                        |
| 16    | I2C1_MODE_SEL | I2C1 端口模式选择位<br>0: 开漏模式<br>1: 推挽模式 |
| 15:0  | Reserved      | 保留, 必须保持复位值                        |

## 5 RCC 时钟和复位

### 5.1 复位单元

#### 5.1.1 简介

系统共有两大类复位：电源复位、系统复位。

#### 5.1.2 功能框图



图 5-1 复位功能框图

#### 5.1.3 主要特征

- 复位事件判定：通过控制状态寄存器（RCC\_CSR）中的复位标志位来进行判断。
- 电源复位：复位所有寄存器。
- 系统复位：除了 RCC\_CSR 中的复位标志、内部低速振荡器使能位、PWR\_CSR 中的待机和唤醒标志、DBG\_CR 不受系统复位影响，其余寄存器都将被系统复位。

#### 5.1.4 功能描述

##### 5.1.4.1 电源复位 (POR Reset)

电源复位有以下方式：

- 上电复位 (Power-on Reset)
- 掉电复位 (Power-down Reset)
- 待机复位 (Standby Reset)

### 5.1.4.2 系统复位 (System Reset)

系统复位有以下几种方式:

- 外部复位 (NRST Reset)
- 窗口看门狗复位 (WWDG Reset)
- 独立看门狗复位 (IWDG Reset)
- 软件复位 (Software Reset)
- CPU 死锁复位 (CPU Lockup Reset)
- PVD 复位 (PVD Reset)
- 低功耗复位 (Low Power Reset)

外部复位 (NRST Reset):

- 当通过 NRST Pin 输入低电平时, 将会发生外部复位。

窗口看门狗复位 (WWDG Reset):

- 当计数器的值大于配置寄存器 (WWDG\_CFGR) 设定的值时喂狗, 将会发生窗口看门狗复位。
- 当计数器的值小于 0x40 时, 将会发生窗口看门狗复位。
- 具体请参考窗口看门狗章节

独立看门狗复位 (IWDG Reset):

- 计数器开始从其复位值 0xFFFF 开始递减, 当递减到达 0x0000 时, 将会发生独立看门狗复位。
- 如果程序异常, 无法正常喂狗, 将会发生独立看门狗复位。
- 具体请参考独立看门狗章节

软件复位 (Software Reset):

- 可以通过将 SCB\_AIRCR[SYSRESETREQ]置 1, 将会发生软件复位

CPU 死锁复位 (CPU Lockup Reset):

- 配置控制状态寄存器 (RCC\_CSR) 的 LOCKUPEN 位为 1, CPU 死锁复位使能;
- 当 CPU 进入锁定状态将会发生 CPU 死锁复位。

PVD 复位 (PVD Reset):

- 配置控制状态寄存器 (RCC\_CSR) 的 PVDRSTEN 位为 1, PVD 复位使能;

- 配置电源控制寄存器（PWR\_CR）的 PVDE 位为 1，使能 PVD；
- 配置电源控制寄存器（PWR\_CR）的 PLS 位进行 PVD 阈值选择；
- 检测 VDD 电源，当 VDD 电源低于选择的阈值电压时将会发生 PVD 复位。

低功耗复位（Low Power Reset）：

- 为防止应用程序误进入低功耗模式，可以通过配置选项字节空间 nRST\_STDBY 位或 nRST\_STOP 位为 0，在误进入低功耗模式前进行系统复位。
  - ◆ 通过配置选项字节空间 nRST\_STDBY 位为 0，系统将被复位，而不是进入待机模式。
  - ◆ 通过配置选项字节空间 nRST\_STOP 位为 0，系统将被复位，而不是进入停机模式或者深度停机模式。
  - ◆ 具体请参考嵌入式闪存章节

## 5.2 时钟单元

### 5.2.1 简介

四个可配置的独立时钟：

- 外部高速时钟（HSE）
- 内部高速时钟（HSI）
- 锁相环（PLL）
- 内部低速时钟（LSI）

## 5.2.2 功能框图



图 5-2 时钟树

## 5.2.3 主要特征

通过时钟配置寄存器（RCC\_CFRG）的预分频控制位来分别配置 AHB 和 APB1 总线的时钟频率。AHB 和 APB1 总线时钟的最大频率是 48MHz。

## 5.2.4 功能描述

### 5.2.4.1 外部高速时钟 (HSE)

外部高速时钟的时钟源有以下两种：

- 外部高速晶振/陶瓷谐振器输入时钟  
其具有非常精确的特点。



图 5-3 高速晶振/陶瓷谐振器

上图为外部高速晶振/陶瓷谐振器输入模块示意图，具体请参考数据手册。

### ● 外部高速输入时钟

通过配置时钟控制寄存器（RCC\_CR）的 HSEBYP 和 HSEON 位来选择此时钟输入方式。



图 5-4 外部高速输入时钟

上图为外部高速输入时钟模块框图

外部高速时钟具有以下特征：

- 必须提供外部高速时钟源或晶体振荡器
- 输入频率范围 4~24MHz
- 推荐外部高速时钟信号为 50% 占空比（方波、正弦波），详情请参阅数据手册中有关电气特性部分
- 在使能 HSE 时，必须驱动 OSC\_IN 管脚，而 OSC\_OUT 引脚在未被使用时应该保持悬空

注意事项：

- 当使用外部高速输入时钟时，必须将时钟控制寄存器（RCC\_CR）的 HSEBYP 位置“1”。
- 一旦 HSE 启用，HSE 相关配置就不能更改。如需更改配置，必须先禁止 HSE。

启用 HSE 配置流程如下：

- 配置时钟控制寄存器（RCC\_CR）中的 HSEON 位为 1，使能 HSE；
- 等待时钟控制寄存器（RCC\_CR）中的 HSERDY 位被置位为 1，表示 HSE 稳定，会输出有效时

钟信号，此时才可被选择使用作为系统时钟或外设时钟源。

#### 5.2.4.2 内部高速时钟（HSI）

HSI 时钟信号由内部 8MHz 振荡器产生，HSI 时钟源在芯片上电后默认启用。

**优点：**HSI 振荡器能够在不需要任何外部器件的条件下提供系统时钟，启动时间比 HSE 晶体振荡器快。

**缺点：**即使经过校准，频率也不如外部晶体振荡器或陶瓷谐振器精确。

HSI 具有如下作用：

- 可直接用作系统时钟
- 可以作为 PLL 输入时钟源
- 如果 HSE 晶体振荡器发生故障，HSI 信号也可以用作备用时钟源，参考时钟安全系统（CSS）章节

使能 HSI 配置步骤：

- 配置时钟控制寄存器（RCC\_CR）中的 HSION 位为 1，使能 HSI；
- 等待时钟控制寄存器（RCC\_CR）中的 HSIRDY 位被置位为 1，表示 HSI 稳定，可输出有效时钟，此时才可被选择使用作为系统时钟或外设时钟源。

注意事项：

- 一旦 HSI 启用，HSI 相关配置就不能更改。如需更改配置，必须先禁止 HSI。

#### 5.2.4.3 锁相环（PLL）

PLL 的输入参考时钟有以下三种，可以通过 PLL 配置寄存器（RCC\_PLLCFGR）中的 PLLXTPRE 和 PLLSRC 位进行选择：

- HSI 振荡器输出时钟
- HSE 输出时钟
- HSE 输出时钟的两分频时钟

PLL 的输入时钟  $f_{PLL\_IN}$  和输出时钟  $f_{PLL\_OUT}$  之间关系为：

$$\frac{f_{PLL\_IN}}{(PLLDIV[2:0]+1)*(PLLIDIV[2:0]+1)} = \frac{f_{PLL\_OUT}}{PLLMUL[7:0]+1}$$

PLLMUL、PLLIDIV 和 PLLDIV 是 PLL 的倍频器和分频器的分频比设置控制位。

注意事项：

- 在使能 PLL 之前，必须进行 PLL 配置（选择 PLL 输入时钟源和选择倍频因子和分频因子）。一旦 PLL 启用，PLL 配置就不能被更改。如需更改配置，必须先禁止 PLL。
- PLL 配置寄存器（RCC\_PLLCFGR）中 PLLDIV 建议设置为奇数（1 或 3 或 5 或 7）；

使能 PLL 配置步骤：（选择 HSI 为 PLL 时钟源）

- 配置时钟控制寄存器（RCC\_CR）中的 HSION 位为 1，使能 HSI；
- 等待时钟控制寄存器（RCC\_CR）中的 HSIRDY 位被置位为 1，表示 HSI 稳定，可输出有效时钟，此时才可被选择使用作为系统时钟或外设时钟源；
- 配置 PLL 配置寄存器（RCC\_PLLCFGR）中 PLLMUL（倍频系数）、PLLPDIV（PLL\_IN 分频系数）和 PLLDIV（分频系数）控制位；
- 配置时钟控制寄存器（RCC\_CR）中的 PLLON 位为 1，使能 PLL；
- 等待时钟控制寄存器（RCC\_CR）中的 PLLRDY 位被置位为 1，表示 PLL 稳定，可输出有效时钟，此时才可被选择使用作为系统时钟或外设时钟源。

使能 PLL 配置步骤：（选择 HSE 为 PLL 时钟源）

- 配置时钟控制寄存器（RCC\_CR）中的 HSEON 位为 1，使能 HSE；
- 等待时钟控制寄存器（RCC\_CR）中的 HSERDY 位被置位为 1，表示 HSE 稳定，可输出有效时钟，此时才可被选择使用作为系统时钟或外设时钟源；
- 配置 PLL 配置寄存器（RCC\_PLLCFGR）中的 PLLSRC 位为 1，选择 HSE 时钟用作 PLL 输入时钟源；
- 配置 PLL 配置寄存器（RCC\_PLLCFGR）中的 PLLXTPRE 位，选择 HSE 或者 HSE 2 分频时钟为 PLL 输入时钟源；
- 配置 PLL 配置寄存器（RCC\_PLLCFGR）中 PLLMUL（倍频系数）、PLLPDIV（PLL\_IN 分频系数）和 PLLDIV（分频系数）控制位；
- 配置时钟控制寄存器（RCC\_CR）中的 PLLON 位为 1，使能 PLL；
- 等待时钟控制寄存器（RCC\_CR）中的 PLLRDY 位被置位为 1，表示 PLL 稳定，可输出有效时钟，此时才可被选择使用作为系统时钟或外设时钟源。

#### 5.2.4.4 内部低速时钟（LSI）

LSI 作为一个低功耗时钟源，为独立看门狗提供时钟源。时钟中心频率在 40kHz 左右。详情请参阅数据手册中有关电气特性部分。

使能 LSI 配置步骤：

- 配置控制状态寄存器（RCC\_CSR）的 LSION 位置位为 1，使能 LSI；
- 等待控制状态寄存器（RCC\_CSR）中的 LSIRDY 位被置位为 1，表示 LSI 稳定，可输出有效时钟。

注意事项：

- 一旦 LSI 启用，LSI 相关配置就不能更改。如需更改配置，必须先禁止 LSI。

#### 5.2.4.5 中断

表 5-1 RCC 全局中断表

| 中断事件       | 事件标志位   | 使能控制位    | 标志清除位   |
|------------|---------|----------|---------|
| RCC_PLLRDY | PLLRDYF | PLLRDYIE | PLLRDYC |
| RCC_HSERDY | HSERDYF | HSERDYIE | HSERDYC |
| RCC_HSIRDY | HSIRDYF | HSIRDYIE | HSIRDYC |
| RCC_LSIRDY | LSIRDYF | LSIRDYIE | LSIRDYC |

注：如上标志位/控制位/清除位都可通过时钟中断寄存器（RCC\_CIR）进行配置。

#### 5.2.4.6 系统时钟选择（SWS）

四个系统时钟源：

- 内部高速时钟（HSI 上电后默认）
- 外部高速时钟（HSE）
- 锁相环（PLL）：当 HSI（或 HSE）作为 PLL 时钟源时，HSI（或 HSE）不可禁止
- 内部低速时钟（LSI）

系统时钟配置步骤：

- 使能需要的系统时钟源（HSI, HSE, PLL, LSI），每个时钟使能方式不同，具体方式请查看（HSI, HSE, PLL, LSI 章节）；
- 等待被选择的时钟源 RDY 信号被置位为 1，表示系统时钟源稳定（当目标时钟源稳定后，系统时钟才可以切换）；
- 通过配置时钟配置寄存器（RCC\_CFGR）的 SW 位来选择系统时钟；
- 通过读取时钟配置寄存器（RCC\_CFGR）的 SWS 位，判断当前系统时钟的时钟源。

#### 5.2.4.7 系统时钟频率切换

系统时钟频率从低速到高速切换，或者从高速到低速切换，推荐先切换到中速频率过度，高速低速切换间隔至少 1us。

#### 5.2.4.8 外设复位

可以通过 APB1 外设复位寄存器（RCC\_APB1RSTR）和 AHB 外设复位寄存器（RCC\_AHBRSTR）来实现相应外设的软件复位。

#### 5.2.4.9 时钟安全系统（CSS）

时钟安全系统的具体工作方式包括软件启动和中断处理。

**软件启动：**通过时钟控制寄存器（RCC\_CR）的 CSSON 置位为 1 启动时钟安全系统。时钟检测器在 HSE 振荡器启动并稳定后延迟启用，当此 HSE 振荡器关闭时禁止此安全系统。

**触发中断：**当检测到 HSE 时钟故障时，CSS 将自行禁止 HSE 振荡器，将时钟故障事件发送到高级定时器的刹车输入端，并触发时钟安全系统中断，请求软件执行救援操作。CSS 中断连接到 CPU 的 NMI 中断。

**中断判断标志及清除方式：**当时钟中断寄存器（RCC\_CIR）中的 CSSF 位由硬件置位为 1，表示 HSE 时钟失效导致了时钟安全系统中断。通过软件将时钟中断寄存器（RCC\_CIR）中 CSSC 位写 1 来清除安全系统中断标志位 CSSF。

注意事项：

- 一旦启用 CSS，如果 HSE 时钟发生故障，CSS 中断发生，并自动生成 NMI 中断。除非 CSS 中断挂起位被清除，否则 NMI 将被不停地执行。因此，在 NMI 的处理程序中，用户必须通过设置时钟中断寄存器（RCC\_CIR）的 CSSC 位为 1 来清除 CSS 中断。
- 当故障发生时，如果直接使用 HSE 振荡器作为系统时钟，系统时钟将自动切换到内部高速振荡器 HSI，并禁止 HSE 振荡器；如果 HSE 振荡器用作 PLL 输入时钟，PLL 时钟用作系统时钟，则 PLL 也被同时禁止。
- 在启动时钟安全系统前，需使能 LSI，详情请参考内部低速时钟章节。

HSE 当系统时钟配置使用步骤：

- 配置时钟控制寄存器（RCC\_CR）中的 HSEON 置位为 1，使能 HSE；
- 等待时钟控制寄存器（RCC\_CR）中的 HSERDY 位被置位为 1，表示 HSE 稳定，可输出有效

时钟：

- 通过配置时钟配置寄存器（RCC\_CFGR）的 SW 位为 2'b01 来选择 HSE 为系统时钟；
- 通过读取时钟配置寄存器（RCC\_CFGR）的 SWS 位，判断当前系统时钟的时钟源是否为 HSE；
- 配置控制状态寄存器（RCC\_CSR）的 LSION 位为 1，使能 LSI；
- 等待控制状态寄存器（RCC\_CSR）中的 LSIRDY 位被置位为 1，表示 LSI 稳定，可输出有效时钟；
- 配置时钟控制寄存器（RCC\_CR）中的 CSSON 位为 1，时钟安全系统使能。

HSE 间接当系统时钟配置使用步骤：

- 配置时钟控制寄存器（RCC\_CR）中的 HSEON 位为 1，使能 HSE；
- 等待时钟控制寄存器（RCC\_CR）中的 HSERDY 位被置位为 1，表示 HSE 稳定，可输出有效时钟；
- 配置 PLL 配置寄存器（RCC\_PLLCFGR）中的 PLLSRC 位为 1，选择 HSE 时钟用作 PLL 输入时钟；
- 配置 PLL 配置寄存器（RCC\_PLLCFGR）中的 PLLXTPRE 位，选择 HSE 或者 HSE2 分频为 PLL 输入时钟；
- 配置 PLL 配置寄存器（RCC\_PLLCFGR）中 PLLMUL（倍频系数）、PLLPDIV（PLL\_IN 分频系数）和 PLLDIV（分频系数）控制位；
- 配置时钟控制寄存器（RCC\_CR）中的 PLLON 位为 1，使能 PLL；
- 等待时钟控制寄存器（RCC\_CR）中的 PLLRDY 位被置位为 1，表示 PLL 稳定，可输出有效时钟，此时才可被选择使用作为系统时钟或外设时钟源；
- 通过配置时钟配置寄存器（RCC\_CFGR）的 SW 位为 2'b10 来选择 PLL 为系统时钟；
- 通过读取时钟配置寄存器（RCC\_CFGR）的 SWS 位，判断当前系统时钟的时钟源是否为 PLL；
- 配置控制状态寄存器（RCC\_CSR）的 LSION 位为 1，使能 LSI；
- 等待控制状态寄存器（RCC\_CSR）中的 LSIRDY 位被置位为 1，表示 LSI 稳定，可输出有效时钟；
- 配置时钟控制寄存器（RCC\_CR）中的 CSSON 位为 1，时钟安全系统使能。

#### 5.2.4.10 微控制器时钟输出（MCO）

微控制器时钟输出（MCO）允许时钟输出到外部 MCO 引脚上。相应 GPIO 端口的配置寄存器必须被配置为复用输出功能。可以选择以下六个时钟信号中的一个作为 MCO 输出时钟：

表 5-2 MCO 与时钟源对应关系

| 时钟配置寄存器（RCC_CFGR）的 MCO 位 | 时钟源      |
|--------------------------|----------|
| 001                      | APB1_CLK |

| 时钟配置寄存器（RCC_CFGR）的 MCO 位 | 时钟源    |
|--------------------------|--------|
| 010                      | LSI    |
| 100                      | SYSCLK |
| 101                      | HSI    |
| 110                      | HSE    |
| 111                      | PLL/2  |

#### 5.2.4.11 定时器时钟

当时钟配置寄存器（RCC\_CFGR）的 PPRE1 位[10:8]为 3'b0xx（不分频）时，挂在 APB1 上的定时器的时钟频率和 APB1 总线频率一样；否则挂在 APB1 上的定时器的时钟频率是 APB1 总线频率的两倍。

当时钟配置寄存器（RCC\_CFGR）的 HPRE 位[7:4]为 4'b0xxx（不分频）时，高级定时器（TIM1）的时钟频率和挂在 APB1 上的定时器的时钟频率一样，否则高级定时器（TIM1）的时钟频率是挂在 APB1 上的定时器的时钟频率的两倍。

#### 5.2.4.12 独立看门狗时钟

硬件启动独立看门狗，LSI 振荡器将被自动开启，并且不能被关闭；

软件启动独立看门狗，则 LSI 振荡器需通过软件使能开启，在 LSI 振荡器稳定输出后，时钟供应给 IWDG，LSI 可以被软件关闭。

### 5.3 寄存器

#### 5.3.1 寄存器总览

表 5-3 RCC 寄存器概览

| Offset | Acronym      | Register Name  | Reset      |
|--------|--------------|----------------|------------|
| 0x00   | RCC_CR       | 时钟控制寄存器        | 0x00000021 |
| 0x04   | RCC_CFGR     | 时钟配置寄存器        | 0x00000000 |
| 0x08   | RCC_CIR      | 时钟中断寄存器        | 0x00000000 |
| 0x10   | RCC_APB1RSTR | APB1 外设复位寄存器   | 0x00000000 |
| 0x14   | RCC_AHBENR   | AHB 外设时钟使能寄存器  | 0x00000014 |
| 0x1C   | RCC_APB1ENR  | APB1 外设时钟使能寄存器 | 0x000000C0 |
| 0x24   | RCC_CSR      | 控制状态寄存器        | 0x08000000 |
| 0x28   | RCC_AHBRSTR  | AHB 外设复位寄存器    | 0x00000000 |
| 0x2C   | RCC_CFGR2    | 时钟配置寄存器 2      | 0x00000000 |
| 0x40   | RCC_SYSCFG   | 系统配置寄存器        | 0x00000103 |
| 0x50   | RCC_PLLCFGR  | PLL 配置寄存器      | 0x00000000 |

### 5.3.2 RCC\_CR 时钟控制寄存器

偏移地址: 0x00

复位值: 0x0000 0021

访问: 无等待状态, 字, 半字和字节访问

|      |    |    |    |    |    |                      |                        |                        |               |               |      |       |            |            |       |
|------|----|----|----|----|----|----------------------|------------------------|------------------------|---------------|---------------|------|-------|------------|------------|-------|
| 31   | 30 | 29 | 28 | 27 | 26 | 25                   | 24                     | 23                     | 22            | 21            | 20   | 19    | 18         | 17         | 16    |
| Res. |    |    |    |    |    | PLLRDY               | POLLON                 | Res.                   |               |               |      | CSSON | HSEBY<br>P | HSERD<br>Y | HSEON |
|      |    |    |    |    |    | r                    | rw                     |                        |               |               |      | rw    | rw         | r          | rw    |
| 15   | 14 | 13 | 12 | 11 | 10 | 9                    | 8                      | 7                      | 6             | 5             | 4    | 3     | 2          | 1          | 0     |
| Res. |    |    |    |    |    | HSEOU<br>TPUTS<br>EL | HSEDE<br>GLITCH<br>SEL | HSEDE<br>GLITCH<br>BYP | HSELPF<br>SEL | HSELPF<br>BYP | Res. |       | HSIRDY     | HSION      |       |
|      |    |    |    |    |    | rw                   | rw                     | rw                     | rw            | rw            |      |       | r          | rw         |       |

| Bit    | Field    | Description                                                                                                                                      |
|--------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| 31: 26 | Reserved | 保留, 必须保持复位值                                                                                                                                      |
| 25     | PLLRDY   | PLL 时钟稳定标志 (PLL Clock Ready Flag)<br>由硬件设置<br>0: PLL 未稳定<br>1: PLL 已稳定                                                                           |
| 24     | POLLON   | PLL 使能 (PLL Enable)<br>通过软件置“1”或清“0”。<br>当进入停机或待机模式时, 由硬件清除。<br>如果 PLL 时钟已经或将要作为系统时钟, 则禁止重置此位。<br>0: 禁止 PLL<br>1: 使能 PLL                         |
| 23: 20 | Reserved | 保留, 必须保持复位值                                                                                                                                      |
| 19     | CSSON    | 时钟安全系统使能 (Clock Security System Enable)<br>通过软件置“1”或清“0”。<br>0: 禁止时钟安全监测器<br>1: 如果外部高速振荡器稳定, 使能时钟安全监测器                                           |
| 18     | HSEBYP   | 外部高速时钟旁路 (External High-speed Clock Bypass)<br>由软件置“1”来旁路外部晶体振荡器。<br>只有当 HSE 振荡器被禁止时, 才能写入 HSEBYP 位。<br>0: 禁止外部高速晶体振荡器旁路模式<br>1: 使能外部高速晶体振荡器旁路模式 |
| 17     | HSERDY   | 外部高速时钟稳定标志 (External High-speed Clock Ready Flag)<br>由硬件设置。<br>0: 外部高速晶体振荡器未稳定<br>1: 外部高速晶体振荡器已稳定                                                |

| Bit   | Field          | Description                                                                                                                                                                        |
|-------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16    | HSEON          | 外部高速时钟使能 (External High-speed Clock Enable)<br>通过软件置“1”或清“0”。<br>当进入待机或停机模式时，此位由硬件清“0”。当系统时钟已经或将要使用 HSE 作为时钟源时，则禁止重置此位。<br>0: 禁止外部高速晶体振荡器<br>1: 使能外部高速晶体振荡器                        |
| 15: 9 | Reserved       | 保留，必须保持复位值                                                                                                                                                                         |
| 8     | HSEOUTPUTSEL   | 输出模式选择<br>0: 直接输出<br>1: 滤波输出                                                                                                                                                       |
| 7     | HSEDEGLITCHSEL | 去毛刺宽度控制位<br>0: 典型值 8ns<br>1: 典型值 5ns                                                                                                                                               |
| 6     | HSEDEGLITCHBYP | 去毛刺电路的 bypass 控制位<br>0: 正常采用去毛刺功能<br>1: bypass 掉去毛刺功能                                                                                                                              |
| 5     | HSELPFSEL      | LPF 滤波模式控制<br>0: LPF 滤波后信号放大输出<br>1: LPF 滤波后输出                                                                                                                                     |
| 4     | HSELPFBYP      | LPF 输入信号直连输出的使能信号<br>0: 经过 LPF 滤波输出<br>1: LPFIN 直连输出                                                                                                                               |
| 3: 2  | Reserved       | 保留，必须保持复位值                                                                                                                                                                         |
| 1     | HSIRDY         | 内部高速时钟稳定标志 (Internal High-speed Clock Ready Flag)<br>由硬件置“1”，表示内部时钟已经稳定。<br>在 HSION 位被清除后，HSIRDY 在 3 个 AHB 时钟周期后变“0”。<br>0: 内部高速时钟未稳定<br>1: 内部高速时钟已稳定                              |
| 0     | HSION          | 内部高速时钟使能 (Internal High-speed Clock Enable)<br>通过软件置“1”或清“0”。<br>当退出待机或停机模式或外部振荡器用作系统时钟并且发生故障时，此位由硬件置“1”，来迫使内部振荡器使能。当系统时钟已经或将要使用 HSI 作为时钟源时，则禁止重置此位。<br>0: 禁止内部高速时钟<br>1: 使能内部高速时钟 |

### 5.3.3 RCC\_CFGR 时钟配置寄存器

偏移地址: 0x04

复位值: 0x0000 0000

访问: 无等待状态, 字, 半字和字节访问

只有当访问发生在时钟切换时，才会插入 1 或 2 个等待周期。

|      |    |    |    |    |       |    |    |      |    |    |    |     |    |    |    |
|------|----|----|----|----|-------|----|----|------|----|----|----|-----|----|----|----|
| 31   | 30 | 29 | 28 | 27 | 26    | 25 | 24 | 23   | 22 | 21 | 20 | 19  | 18 | 17 | 16 |
| Res. |    |    |    |    | MCO   |    |    | Res. |    |    |    |     |    |    |    |
|      |    |    |    |    | rw    |    |    |      |    |    |    |     |    |    |    |
| 15   | 14 | 13 | 12 | 11 | 10    | 9  | 8  | 7    | 6  | 5  | 4  | 3   | 2  | 1  | 0  |
| Res. |    |    |    |    | PPRE1 |    |    | HPRE |    |    |    | SWS |    | SW |    |
|      |    |    |    |    | rw    |    |    | rw   |    |    |    | r   |    | rw |    |

| Bit    | Field    | Description                                                                                                                                                                                                                                                                             |
|--------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31: 27 | Reserved | 保留，必须保持复位值                                                                                                                                                                                                                                                                              |
| 26: 24 | MCO      | 微控制器时钟输出（Micro Controller Clock Output）<br>由软件置“1”或清“0”<br>000: 没有时钟输出<br>001: APB1_CLK 输出<br>010: LSI 时钟输出<br>011: 没有时钟输出<br>100: SYSCLK 系统时钟输出<br>101: HSI 时钟输出<br>110: HSE 时钟输出<br>111: PLL 时钟 2 分频后输出<br>注意：<br>该时钟输出在启动和切换 MCO 时钟源时可能会被停止。<br>系统时钟通过 MCO 管脚输出时，请保证输出时钟频率不超过 50MHz。 |
| 23: 15 | Reserved | 保留，必须保持复位值                                                                                                                                                                                                                                                                              |
| 14     | Reserved | 保留，必须保持复位值。                                                                                                                                                                                                                                                                             |
| 13: 11 | Reserved | 保留，必须保持复位值                                                                                                                                                                                                                                                                              |
| 10: 8  | PPRE1    | PPRE1: APB1 预分频系数<br>通过软件设置来控制 APB1 时钟（PCLK1）预分频系数。<br>0xx: HCLK 不分频<br>100: HCLK 2 分频<br>101: HCLK 4 分频<br>110: HCLK 8 分频<br>111: HCLK 16 分频                                                                                                                                           |

| Bit  | Field | Description                                                                                                                                                                                                                                                                                                              |
|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7: 4 | HPRE  | <p>AHB 预分频系数<br/>通过软件设置来控制 AHB 时钟的预分频系数。</p> <p>0xxx: SYSCLK 不分频<br/>1000: SYSCLK 2 分频<br/>1001: SYSCLK 4 分频<br/>1010: SYSCLK 8 分频<br/>1011: SYSCLK 16 分频<br/>1100: SYSCLK 64 分频<br/>1101: SYSCLK 128 分频<br/>1110: SYSCLK 256 分频<br/>1111: SYSCLK 512 分频</p> <p>注：<br/>当 AHB 时钟的预分频系数大于 1 时，必须开启预取缓冲器，详见闪存访问控制寄存器章节。</p> |
| 3: 2 | SWS   | <p>系统时钟选择状态 (System Clock Switch Status)</p> <p>00: 选择 HSI 输出用作系统时钟<br/>01: 选择 HSE 输出用作系统时钟<br/>10: 选择 PLL 输出用作系统时钟<br/>11: 选择 LSI 输出用作系统时钟</p>                                                                                                                                                                          |
| 1: 0 | SW    | <p>系统时钟选择 (System Clock Switch)<br/>通过软件配置来选择系统时钟源<br/>当从停止或待机模式中返回时，当直接或间接作为系统时钟的 HSE 出现故障时，硬件都会强制选择 HSI 作为系统时钟。</p> <p>00: 选择 HSI 输出用作系统时钟<br/>01: 选择 HSE 输出用作系统时钟<br/>10: 选择 PLL 输出用作系统时钟<br/>11: 选择 LSI 输出用作系统时钟</p>                                                                                                 |

### 5.3.4 RCC\_CIR 时钟中断寄存器

偏移地址: 0x08

复位值: 0x0000 0000

访问: 无等待周期, 字, 半字和字节访问

|      |    |    |        |       |        |      |        |      |      |        |        |        |        |        |        |
|------|----|----|--------|-------|--------|------|--------|------|------|--------|--------|--------|--------|--------|--------|
| 31   | 30 | 29 | 28     | 27    | 26     | 25   | 24     | 23   | 22   | 21     | 20     | 19     | 18     | 17     | 16     |
| Res. |    |    |        |       |        |      |        | CSSC | Res. |        | PLLRDY | HSERD  | HSIRDY | Res.   | LSIRDY |
|      |    |    |        |       |        |      |        | w1c  |      |        | C      | YC     | C      |        |        |
| 15   | 14 | 13 | 12     | 11    | 10     | 9    | 8      | 7    | 6    | 5      | 4      | 3      | 2      | 1      | 0      |
| Res. |    |    | PLLRDY | HSERD | HSIRDY | Res. | LSIRDY | Res. |      | PLLRDY | HSERD  | HSIRDY | Res.   | LSIRDY |        |
|      |    |    | IE     | YIE   | IE     |      | E      | CSSF |      | F      | YF     | F      |        |        |        |
|      |    |    | RW     | RW    | RW     |      | RW     |      |      | R      | R      | R      |        |        |        |

| Bit    | Field    | Description                                                                                                         |
|--------|----------|---------------------------------------------------------------------------------------------------------------------|
| 31: 24 | Reserved | 保留, 必须保持复位值                                                                                                         |
| 23     | CSSC     | 时钟安全系统中断清除 (Clock Security System Interrupt Clear)<br>通过软件置“1”来清除安全系统中断标志位 CSSF。<br>0: 无效<br>1: 清除安全系统中断标志位 CSSF    |
| 22: 21 | Reserved | 保留, 必须保持复位值                                                                                                         |
| 20     | PLLRDYC  | 清除 PLL 稳定中断 (PLL Ready Interrupt Clear)<br>通过软件置“1”来清除 PLL 稳定中断标志位 PLLRDYF。<br>0: 无效<br>1: 清除 PLL 稳定中断标志位 PLLRDYF   |
| 19     | HSERDYC  | 清除 HSE 稳定中断 (HSE Ready Interrupt Clear)<br>通过软件置“1”来清除 HSE 稳定中断标志位 HSERDYF。<br>0: 无效<br>1: 清除 HSE 稳定中断标志位 HSERDYF   |
| 18     | HSIRDYC  | 清除 HSI 稳定中断 (HSI Ready Interrupt Clear)<br>通过软件置“1”来清除 HSI 稳定中断标志位 HSIRDYF。<br>0: 无效<br>1: 清除 HSI 稳定中断标志位 HSIRDYF   |
| 17     | Reserved | 保留, 必须保持复位值                                                                                                         |
| 16     | LSIRDYC  | 清除 LSI 稳定中断 (LSI Ready Interrupt Clear)<br>通过软件置“1”来清除 LSI 稳定中断标志位 LSIRDYF。<br>0: 无效<br>1: 清除 LSI 稳定中断标志位 LSIRDYF   |
| 15: 13 | Reserved | 保留, 必须保持复位值                                                                                                         |
| 12     | PLLRDYIE | PLL 稳定中断使能 (PLL Ready Interrupt Enable)<br>通过软件置“1”来使能或清“0”来禁止 PLL 稳定中断。<br>0: 禁止 PLL 稳定中断<br>1: 使能 PLL 稳定中断        |
| 11     | HSERDYIE | HSE 稳定中断使能 (HSE Ready Interrupt Enable)<br>通过软件置“1”来使能或清“0”来禁止外部振荡器稳定中断。<br>0: 禁止 HSE 稳定中断<br>1: 使能 HSE 稳定中断        |
| 10     | HSIRDYIE | HSI 稳定中断使能 (HSI Ready Interrupt Enable)<br>通过软件置“1”来使能或清“0”来禁止内部振荡器稳定中断。<br>0: 禁止 HSI 稳定中断<br>1: 使能 HSI 稳定中断        |
| 9      | Reserved | 保留, 必须保持复位值                                                                                                         |
| 8      | LSIRDYIE | LSI 稳定中断使能 (LSI Ready Interrupt Enable)<br>通过软件置“1”来使能或清“0”来禁止内部 40KHz 振荡器稳定中断。<br>0: 禁止 LSI 稳定中断<br>1: 使能 LSI 稳定中断 |

| Bit  | Field    | Description                                                                                                                                             |
|------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7    | CSSF     | 时钟安全系统中断标志 (Clock Security System Interrupt Flag)<br>在外部振荡器时钟出现故障时, 由硬件置“1”。<br>通过软件将 CSSC 位置“1”来清除。<br>0: 无 HSE 时钟失效产生的安全系统中断<br>1: HSE 时钟失效导致时钟安全系统中断 |
| 6: 5 | Reserved | 保留, 必须保持复位值                                                                                                                                             |
| 4    | PLL RDYF | PLL 稳定中断标志 (PLL Ready Interrupt Flag)<br>在 PLL 稳定时, 由硬件置“1”。<br>通过软件将 PLLRDYC 位置“1”来清除。<br>0: 无 PLL 锁定产生的时钟稳定中断<br>1: PLL 锁定导致时钟稳定中断                    |
| 3    | HSE RDYF | HSE 稳定中断标志 (HSE Ready Interrupt Flag)<br>在外部高速时钟稳定时, 由硬件置“1”。<br>通过软件将 HSERDYC 位置“1”来清除。<br>0: 无外部振荡器产生的时钟稳定中断<br>1: 外部振荡器导致时钟稳定中断                      |
| 2    | HSI RDYF | HSI 稳定中断标志 (HSI Ready Interrupt Flag)<br>在内部高速时钟稳定时, 由硬件置“1”。<br>通过软件将 HSIRDYC 位置“1”来清除。<br>0: 无内部 HSI 振荡器产生的时钟稳定中断<br>1: 内部 HSI 振荡器导致时钟稳定中断            |
| 1    | Reserved | 保留, 必须保持复位值                                                                                                                                             |
| 0    | LSI RDYF | LSI 稳定中断标志 (LSI Ready Interrupt Flag)<br>在内部低速时钟稳定时, 由硬件置“1”。<br>通过软件将 LSIRDYC 位置“1”来清除。<br>0: 无内部 40KHz 振荡器产生的时钟稳定中断<br>1: 内部 40KHz 振荡器导致时钟稳定中断        |

### 5.3.5 RCC\_APB1RSTR APB1 外设复位寄存器

偏移地址: 0x10

复位值: 0x0000 0000

访问: 无等待周期, 字, 半字和字节访问

| 31   | 30         | 29  | 28  | 27   | 26   | 25  | 24   | 23 | 22 | 21  | 20   | 19    | 18   | 17    | 16    |
|------|------------|-----|-----|------|------|-----|------|----|----|-----|------|-------|------|-------|-------|
| Res. | SYSCF<br>G | DBG | PWR | Res. |      |     |      |    |    | I2C | Res. |       |      | UART2 | UART1 |
|      | RW         | RW  | RW  |      |      |     |      |    |    | RW  |      |       |      | RW    | RW    |
| 15   | 14         | 13  | 12  | 11   | 10   | 9   | 8    | 7  | 6  | 5   | 4    | 3     | 2    | 1     | 0     |
| Res. |            |     | SPI | WWDG | Res. | ADC | Res. |    |    |     |      | TIM14 | TIM1 | TIM3  | Res.  |
|      |            |     | RW  | RW   |      | RW  |      |    |    |     |      | RW    | RW   | RW    |       |

| Bit    | Field    | Description                                                       |
|--------|----------|-------------------------------------------------------------------|
| 31     | Reserved | 保留, 必须保持复位值                                                       |
| 30     | SYSCFG   | SYSCFG 复位 (SYSCFG Reset)<br>由软件置“1”或清“0”<br>0: 无效<br>1: 复位        |
| 29     | DBG      | DBG 复位 (DBG Reset)<br>由软件置“1”或清“0”<br>0: 无效<br>1: 复位              |
| 28     | PWR      | PWR 复位 (Power Interface Reset)<br>由软件置“1”或清“0”<br>0: 无效<br>1: 复位  |
| 27: 22 | Reserved | 保留, 必须保持复位值                                                       |
| 21     | I2C      | I2C 复位 (I2C Reset)<br>由软件置“1”或清“0”<br>0: 无效<br>1: 复位              |
| 20: 18 | Reserved | 保留, 必须保持复位值                                                       |
| 17     | UART2    | UART2 复位 (UART2 Reset)<br>由软件置“1”或清“0”<br>0: 无效<br>1: 复位          |
| 16     | UART1    | UART1 复位 (UART1 Reset)<br>由软件置“1”或清“0”<br>0: 无效<br>1: 复位          |
| 15: 13 | Reserved | 保留, 必须保持复位值                                                       |
| 12     | SPI      | SPI 复位 (SPI Reset)<br>由软件置“1”或清“0”<br>0: 无效<br>1: 复位              |
| 11     | WWDG     | WWDG 复位 (Window Watchdog Reset)<br>由软件置“1”或清“0”<br>0: 无效<br>1: 复位 |
| 10     | Reserved | 保留, 必须保持复位值                                                       |
| 9      | ADC      | ADC 复位 (ADC Reset)<br>由软件置“1”或清“0”<br>0: 无效<br>1: 复位              |
| 8: 4   | Reserved | 保留, 必须保持复位值                                                       |

| Bit | Field    | Description                                                 |
|-----|----------|-------------------------------------------------------------|
| 3   | TIM14    | TIM14 定时器复位 (TIM14 Reset)<br>由软件置“1”或清“0”<br>0: 无效<br>1: 复位 |
| 2   | TIM1     | TIM1 定时器复位 (TIM1 Reset)<br>由软件置“1”或清“0”<br>0: 无效<br>1: 复位   |
| 1   | TIM3     | TIM3 定时器复位 (TIM3 Reset)<br>由软件置“1”或清“0”<br>0: 无效<br>1: 复位   |
| 0   | Reserved | 保留, 必须保持复位值                                                 |

### 5.3.6 RCC\_AHBENR AHB 外设时钟使能寄存器

偏移地址: 0x14

复位值: 0x0000 0014

访问: 无等待周期, 字, 半字和字节访问

|      |    |    |    |    |    |    |    |    |    |    |    |       |       |      |      |
|------|----|----|----|----|----|----|----|----|----|----|----|-------|-------|------|------|
| 31   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19    | 18    | 17   | 16   |
| Res. |    |    |    |    |    |    |    |    |    |    |    | GPIOB | GPIOA | Res. |      |
| 15   | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3     | 2     | 1    | 0    |
| Res. |    |    |    |    |    |    |    |    |    |    |    | CRC   | FLASH | SRAM | Res. |
|      |    |    |    |    |    |    |    |    |    |    |    | rw    | rw    | rw   |      |

| Bit    | Field    | Description                                                           |
|--------|----------|-----------------------------------------------------------------------|
| 31: 19 | Reserved | 保留, 必须保持复位值                                                           |
| 18     | GPIOB    | GPIOB 时钟使能 (GPIOB Clock Enable)<br>由软件置“1”或清“0”<br>0: 时钟禁止<br>1: 时钟使能 |
| 17     | GPIOA    | GPIOA 时钟使能 (GPIOA Clock Enable)<br>由软件置“1”或清“0”<br>0: 时钟禁止<br>1: 时钟使能 |
| 16: 7  | Reserved | 保留, 必须保持复位值                                                           |

| Bit  | Field    | Description                                                           |
|------|----------|-----------------------------------------------------------------------|
| 6    | CRC      | CRC 时钟使能 (CRC Clock Enable)<br>由软件置“1”或清“0”<br>0: 时钟禁止<br>1: 时钟使能     |
| 5    | Reserved | 保留, 必须保持复位值                                                           |
| 4    | Flash    | FLASH 时钟使能 (FLASH Clock Enable)<br>由软件置“1”或清“0”<br>0: 时钟禁止<br>1: 时钟使能 |
| 3    | Reserved | 保留, 必须保持复位值                                                           |
| 2    | SRAM     | SRAM 时钟使能 (SRAM Clock Enable)<br>由软件置“1”或清“0”<br>0: 时钟禁止<br>1: 时钟使能   |
| 1: 0 | Reserved | 保留, 必须保持复位值                                                           |

### 5.3.7 RCC\_APB1ENR APB1 外设时钟使能寄存器

偏移地址: 0x1C

复位值: 0x0000 00C0

访问: 无等待周期, 字, 半字和字节访问

注: 当外设时钟没有启动时, 软件不能读出外设寄存器的数值

|      |        |     |      |      |     |      |      |      |      |       |      |      |      |       |       |
|------|--------|-----|------|------|-----|------|------|------|------|-------|------|------|------|-------|-------|
| 31   | 30     | 29  | 28   | 27   | 26  | 25   | 24   | 23   | 22   | 21    | 20   | 19   | 18   | 17    | 16    |
| Res. | SYSCFG | DBG | PWR  | Res. |     |      |      |      |      | I2C   | Res. |      |      | UART2 | UART1 |
|      | G      | rw  | rw   |      |     |      |      |      |      | rw    |      |      |      | rw    | rw    |
| 15   | 14     | 13  | 12   | 11   | 10  | 9    | 8    | 7    | 6    | 5     | 4    | 3    | 2    | 1     | 0     |
| Res. |        | SPI | WWDG | Res. | ADC | Res. | EXTI | IWDG | Res. | TIM14 | TIM1 | TIM3 | Res. |       |       |
|      |        | rw  | rw   |      | rw  |      | rw   | rw   |      | rw    | rw   | rw   |      |       |       |

| Bit | Field    | Description                                                             |
|-----|----------|-------------------------------------------------------------------------|
| 31  | Reserved | 保留, 必须保持复位值                                                             |
| 30  | SYSCFG   | SYSCFG 时钟使能 (SYSCFG Clock Enable)<br>由软件置“1”或清“0”<br>0: 时钟禁止<br>1: 时钟使能 |
| 29  | DBG      | DBG 时钟使能 (DBG Clock Enable)<br>由软件置“1”或清“0”<br>0: 时钟禁止<br>1: 时钟使能       |

| Bit    | Field    | Description                                                                    |
|--------|----------|--------------------------------------------------------------------------------|
| 28     | PWR      | PWR 时钟使能 (Power Interface Clock Enable)<br>由软件置“1”或清“0”<br>0: 时钟禁止<br>1: 时钟使能  |
| 27: 22 | Reserved | 保留, 必须保持复位值                                                                    |
| 21     | I2C      | I2C 时钟使能 (I2C Clock Enable)<br>由软件置“1”或清“0”<br>0: 时钟禁止<br>1: 时钟使能              |
| 20: 18 | Reserved | 保留, 必须保持复位值                                                                    |
| 17     | UART2    | UART2 时钟使能 (UART2 Clock Enable)<br>由软件置“1”或清“0”<br>0: 时钟禁止<br>1: 时钟使能          |
| 16     | UART1    | UART1 时钟使能 (UART1 Clock Enable)<br>由软件置“1”或清“0”<br>0: 时钟禁止<br>1: 时钟使能          |
| 15: 13 | Reserved | 保留, 必须保持复位值                                                                    |
| 12     | SPI      | SPI 时钟使能 (SPI1Clock Enable)<br>由软件置“1”或清“0”<br>0: 时钟禁止<br>1: 时钟使能              |
| 11     | WWDG     | WWDG 时钟使能 (Window Watchdog Clock Enable)<br>由软件置“1”或清“0”<br>0: 时钟禁止<br>1: 时钟使能 |
| 10     | Reserved | 保留, 必须保持复位值                                                                    |
| 9      | ADC      | ADC 接口时钟使能 (ADC Interface Clock Enable)<br>由软件置“1”或清“0”<br>0: 时钟禁止<br>1: 时钟使能  |
| 8      | Reserved | 保留, 必须保持复位值                                                                    |
| 7      | EXTI     | EXTI 时钟使能 (EXTI Clock Enable)<br>由软件置“1”或清“0”<br>0: 时钟禁止<br>1: 时钟使能            |
| 6      | IWDG     | IWDG 时钟使能 (IWDG Clock Enable)<br>由软件置“1”或清“0”<br>0: 时钟禁止<br>1: 时钟使能            |
| 5: 4   | Reserved | 保留, 必须保持复位值                                                                    |

| Bit | Field    | Description                                                             |
|-----|----------|-------------------------------------------------------------------------|
| 3   | TIM14    | TIM14 时钟使能 (Timer14 Clock Enable)<br>由软件置“1”或清“0”<br>0: 时钟禁止<br>1: 时钟使能 |
| 2   | TIM1     | TIM1 时钟使能 (Timer1 Clock Enable)<br>由软件置“1”或清“0”<br>0: 时钟禁止<br>1: 时钟使能   |
| 1   | TIM3     | TIM3 时钟使能 (Timer3 Clock Enable)<br>由软件置“1”或清“0”<br>0: 时钟禁止<br>1: 时钟使能   |
| 0   | Reserved | 保留, 必须保持复位值                                                             |

### 5.3.8 RCC\_CSR 控制状态寄存器

偏移地址: 0x24

复位值: 0x0800 0000

访问: 0-3 等待周期, 字, 半字和字节访问

当连续对该寄存器进行访问时, 将插入等待状态。

|          |       |       |        |       |        |      |       |       |       |    |    |    |        |       |      |
|----------|-------|-------|--------|-------|--------|------|-------|-------|-------|----|----|----|--------|-------|------|
| 31       | 30    | 29    | 28     | 27    | 26     | 25   | 24    | 23    | 22    | 21 | 20 | 19 | 18     | 17    | 16   |
| LPWRRSTF | WWWDG | IWDGR | SFTRST | PORRS | PINRST |      | RMVF  | LOCKU | PVDRS |    |    |    |        |       |      |
| r        | r     | r     | r      | r     | r      | Res. | PF    | TF    |       |    |    |    |        |       | Res. |
| 15       | 14    | 13    | 12     | 11    | 10     | 9    | 8     | 7     | 6     | 5  | 4  | 3  | 2      | 1     | 0    |
|          |       |       |        |       |        |      | LOCKU | PVDRS |       |    |    |    | LSIRDY | LSION |      |
|          |       |       |        |       |        |      | PEN   | TEN   |       |    |    |    |        |       |      |
|          |       |       |        |       |        |      | rw    | rw    |       |    |    |    | r      | rw    |      |
|          |       |       |        |       |        |      |       |       |       |    |    |    |        |       |      |

| Bit | Field    | Description                                                                                                                |
|-----|----------|----------------------------------------------------------------------------------------------------------------------------|
| 31  | LPWRRSTF | 低功耗管理复位标志 (Low Power Reset Flag)<br>在低功耗管理复位发生时由硬件置“1”, 且只能由电源复位清除或由软件通过写 RMVF 位清除。<br>0: 无低功耗管理复位<br>1: 发生低功耗管理复位         |
| 30  | WWDGRSTF | 窗口看门狗复位标志 (Window Watchdog Reset Flag)<br>在窗口看门狗复位发生时由硬件置“1”, 且只能由电源复位清除或由软件通过写 RMVF 位清除。<br>0: 无窗口看门狗复位发生<br>1: 发生窗口看门狗复位 |

| Bit   | Field    | Description                                                                                                                    |
|-------|----------|--------------------------------------------------------------------------------------------------------------------------------|
| 29    | IWDGRSTF | 独立看门狗复位标志 (Independent Watchdog Reset Flag)<br>在独立看门狗复位发生时由硬件置“1”，且只能由电源复位清除或由软件通过写 RMVF 位清除。<br>0: 无独立看门狗复位发生<br>1: 发生独立看门狗复位 |
| 28    | SFTRSTF  | 软件复位标志 (Software Reset Flag)<br>在软件复位发生时由硬件置“1”，且只能由电源复位清除或由软件通过写 RMVF 位清除。<br>0: 无软件复位发生<br>1: 发生软件复位                         |
| 27    | PORRSTF  | 上电/掉电复位标志 (POR/PDR Reset Flag)<br>在上电/掉电复位发生时由硬件置“1”，且只能由电源复位清除或由软件通过写 RMVF 位清除。<br>0: 无上电/掉电复位发生<br>1: 发生上电/掉电复位              |
| 26    | PINRSTF  | NRST 管脚复位标志 (PIN Reset Flag)<br>在 NRST 管脚复位发生时由硬件置“1”，且只能由电源复位清除或由软件通过写 RMVF 位清除。<br>0: 无 NRST 管脚复位发生<br>1: 发生 NRST 管脚复位       |
| 25    | Reserved | 保留，必须保持复位值                                                                                                                     |
| 24    | RMVF     | 清除复位标志 (Remove Reset Flag)<br>由软件置“1”来清除复位标志。<br>0: 无效<br>1: 清除复位标志                                                            |
| 23    | LOCKUPF  | CPU 死锁复位标志 (CPU Lockup Reset Flag)<br>在 CPU 发生死锁复位时由硬件置“1”，且只能由电源复位清除或由软件通过写 RMVF 位清除。<br>0: 无 CPU 死锁复位发生<br>1: 发生 CPU 死锁复位    |
| 22    | PVDRSTF  | PVD 复位标志 (PVD Reset Flag)<br>在 PVD 复位发生时由硬件置“1”，且只能由电源复位清除或由软件通过写 RMVF 位清除。<br>0: 无 PVD 复位发生<br>1: 发生 PVD 复位                   |
| 21: 8 | Reserved | 保留，必须保持复位值                                                                                                                     |
| 7     | LOCKUPEN | CPU 死锁复位使能 (CPU Lockup Reset Enable)<br>0: 禁止 CPU 死锁复位<br>1: 使能 CPU 死锁复位                                                       |
| 6     | PVDRSTEN | PVD 复位使能 (PVD Reset Enable)<br>0: 禁止 PVD 产生复位<br>1: 使能 PVD 产生复位                                                                |
| 5: 2  | Reserved | 保留，必须保持复位值                                                                                                                     |

| Bit | Field  | Description                                                                                                                                                                  |
|-----|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1   | LSIRDY | 内部低速时钟稳定 (Internal Low-speed Oscillator Ready)<br>由硬件置“1”或清“0”来指示内部 40KHz 振荡器是否稳定。<br>在 LSION 清“0”后，3 个 AHB 时钟后 LSIRDY 被清“0”。<br>0: 内部 40KHz 振荡器时钟未稳定<br>1: 内部 40KHz 振荡器时钟稳定 |
| 0   | LSION  | 内部低速振荡器使能 (Internal Low-speed Oscillator Enable)<br>通过软件置“1”或清“0”，或由电源复位清除。<br>0: 禁止内部 40KHz 振荡器<br>1: 使能内部 40KHz 振荡器                                                        |

### 5.3.9 RCC\_AHBRSTR AHB 外设复位寄存器

偏移地址: 0x28

复位值: 0x0000 0000

访问: 无等待周期, 字, 半字和字节访问

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

| Bit    | Field    | Description                                              |
|--------|----------|----------------------------------------------------------|
| 31: 19 | Reserved | 保留, 必须保持复位值                                              |
| 18     | GPIOB    | GPIOB 复位 (GPIOB Reset)<br>由软件置“1”或清“0”<br>0: 无效<br>1: 复位 |
| 17     | GPIOA    | GPIOA 复位 (GPIOA Reset)<br>由软件置“1”或清“0”<br>0: 无效<br>1: 复位 |
| 16: 7  | Reserved | 保留, 必须保持复位值                                              |
| 6      | CRC      | CRC 复位 (CRC Reset)<br>由软件置“1”或清“0”<br>0: 无效<br>1: 复位     |
| 5: 0   | Reserved | 保留, 必须保持复位值                                              |

### 5.3.10 RCC\_CFGR2 时钟配置寄存器 2

偏移地址: 0x2C

复位值: 0x0000 0000

访问: 无等待状态, 字, 半字和字节访问

只有当访问发生在时钟切换时, 才会插入 1 或 2 个等待周期。

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

| Bit    | Field    | Description                                                                                                                                                                          |
|--------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31: 24 | Reserved | 保留, 必须保持复位值                                                                                                                                                                          |
| 23: 20 | MCOPRE   | MCO 时钟预分频系数<br>0xxx: MCO 不分频<br>1000: MCO 2 分频<br>1001: MCO 4 分频<br>1010: MCO 8 分频<br>1011: MCO 16 分频<br>1100: MCO 64 分频<br>1101: MCO 128 分频<br>1110: MCO 256 分频<br>1111: MCO 512 分频 |
| 15: 0  | Reserved | 保留, 必须保持复位值                                                                                                                                                                          |

### 5.3.11 RCC\_SYSCFG 系统配置寄存器

偏移地址: 0x40

复位值: 0x0000 0103

访问: 0-3 等待周期, 字, 半字和字节访问

|      |              |      |    |    |    |             |      |    |    |    |    |    |    |    |                       |
|------|--------------|------|----|----|----|-------------|------|----|----|----|----|----|----|----|-----------------------|
| 31   | 30           | 29   | 28 | 27 | 26 | 25          | 24   | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                    |
| Res. |              |      |    |    |    |             |      |    |    |    |    |    |    |    |                       |
| 15   | 14           | 13   | 12 | 11 | 10 | 9           | 8    | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                     |
| Res. | HSELPF<br>EN | Res. |    |    |    | HSE_RFB_SEL | Res. |    |    |    |    |    |    |    | PROG_<br>CHECK<br>_EN |

|  |    |  |    |  |   |
|--|----|--|----|--|---|
|  | rw |  | rw |  | r |
|--|----|--|----|--|---|

| Bit    | Field         | Description                                                          |
|--------|---------------|----------------------------------------------------------------------|
| 31: 15 | Reserved      | 保留, 必须保持复位值                                                          |
| 14     | HSELPFEN      | 外接晶振低通滤波使能<br>0: 禁止<br>1: 使能                                         |
| 13: 10 | Reserved      | 保留, 必须保持复位值                                                          |
| 9: 8   | HSE_RFB_SEL   | 反馈电阻选择:<br>00: 2M<br>01: 1M (默认适用 8M~12M 晶振)<br>10: 500K<br>11: 200K |
| 7: 1   | Reserved      | 保留, 必须保持复位值                                                          |
| 0      | PROG_CHECK_EN | 写 Flash 时是否检查 Flash 内的数据是否是 0xFF<br>1: 检查 (硬件固定为 1)<br>0: 不检查        |

### 5.3.12 RCC\_PLLCFGR PLL 配置寄存器

偏移地址: 0x50

复位值: 0x0000 0000

访问: 无等待状态, 字, 半字和字节访问

只有当访问发生在时钟切换时, 才会插入 1 或 2 个等待周期。

|         |    |    |      |        |    |    |        |      |         |    |           |    |        |        |    |  |  |  |
|---------|----|----|------|--------|----|----|--------|------|---------|----|-----------|----|--------|--------|----|--|--|--|
| 31      | 30 | 29 | 28   | 27     | 26 | 25 | 24     | 23   | 22      | 21 | 20        | 19 | 18     | 17     | 16 |  |  |  |
| PLLPDIV |    |    | Res. |        |    |    | PLLMUL |      |         |    |           |    |        |        |    |  |  |  |
| rw      |    |    |      |        |    |    | rw     |      |         |    |           |    |        |        |    |  |  |  |
| 15      | 14 | 13 | 12   | 11     | 10 | 9  | 8      | 7    | 6       | 5  | 4         | 3  | 2      | 1      | 0  |  |  |  |
| Res.    |    |    |      | PLLDIV |    |    |        | Res. | PLL_LDS |    | PLL_ICTRL |    | PLLXTP | PLLSRC |    |  |  |  |
|         |    |    |      | rw     |    |    |        |      | rw      |    | rw        |    | RE     |        |    |  |  |  |

| Bit    | Field    | Description                                       |
|--------|----------|---------------------------------------------------|
| 31: 29 | PLLPDIV  | PLL 预分频系数 (PLL Pre-divide Factor)                 |
| 28: 24 | Reserved | 保留, 必须保持复位值                                       |
| 23: 16 | PLLMUL   | PLL 倍频系数 (PLL Multiplication Factor)              |
| 15: 11 | Reserved | 保留, 必须保持复位值                                       |
| 10: 8  | PLLDIV   | PLL 分频系数 (PLL Divide Factor)                      |
| 7: 6   | Reserved | 保留, 必须保持复位值                                       |
| 5: 4   | PLL_LDS  | PLL 锁定检测器精度选择 (PLL Lock Detector Accuracy Select) |

| Bit  | Field     | Description                                                                                                                                         |
|------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| 3: 2 | PLL_ICTRL | PLL Charge Pump 电流控制信号 (PLL CP Current Control Signals)<br>默认值为 2'b11。当 PLL 输入时钟源低于 8MHz 时，推荐设置此位为 2'b01。                                           |
| 1    | PLLXTPRE  | HSE 时钟用作 PLL 输入时的分频选择<br>通过软件置“1”或清除来分频 HSE 时钟后用作 PLL 输入时钟。<br>只有当 PLL 被禁止时，才能写入此位。<br>0: HSE 时钟不分频<br>1: HSE 时钟 2 分频                               |
| 0    | PLLSRC    | PLL 输入时钟源选择 (PLL Entry Clock Source Selection)<br>通过软件置“1”或清除来选择 PLL 输入时钟源。<br>只有当 PLL 被禁止时，才能写入此位。<br>0: HSI 时钟用作 PLL 输入时钟<br>1: HSE 时钟用作 PLL 输入时钟 |

注：配置 RCC\_PLLCFGR 寄存器请参考功能描述的 PLL 章节。

## 6 CRC 循环冗余校验计算单元

### 6.1 简介

CRC 计算单元利用固定的多项式来计算 8 位、16 位或者 32 位数据的 CRC 校验值，用于对数据传输或数据存储的完整性进行验证。

### 6.2 主要特征

- 统一计算多项式 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$$

该多项式与以太网计算多项式相同

- 支持 8、16、32 位宽的数据输入寄存器、32 位宽的数据输出寄存器
- 硬件计算时间为 3 个 HCLK 周期
- 带有可存放中间计算过程的 32 位宽的数据寄存器
- 支持 CRC-32 和 CRC-32/MPEG-2 两种算法
- 支持输入数据和输出数据的大小端选择

### 6.3 功能描述

#### 6.3.1 功能框图



图 6-1 CRC 功能框图

### 6.3.2 功能概述

- CRC 运算时，对 CRC 数据寄存器（CRC\_DR）进行写操作后，新写入的数据会与上一次的 CRC 计算结果进行 CRC 运算，得到一个新的 CRC 结果，这个 CRC 结果会存放于 CRC 数据寄存器（CRC\_DR）中。
- 进行 CRC 运算时，可以连续的将需要计算的数据依次写入到 CRC 数据寄存器（CRC\_DR）中，最后通过读取 CRC 数据寄存器（CRC\_DR）获取 CRC 的运算结果。
- 通过置位 CRC 控制寄存器（CRC\_CR）中的 RST 位，可以将 CRC 数据寄存器（CRC\_DR）和 CRC 中间数据寄存器（CRC\_MIR）的值恢复到默认值 0xFFFFFFFF。但不会影响 CRC 独立数据寄存器（CRC\_IDR）的值。
- 提供 8 位独立的数据寄存器（CRC\_IDR），作为缓存寄存器，任何时候都可以对其进行读写操作。
- 可以通过 CRC 控制寄存器（CRC\_CR）的 AS 位来选择不同的 CRC 计算算法。
- 可以通过 CRC 控制寄存器（CRC\_CR）的 ISIZE 位来选择输入数据的位宽；当输入数据为 8 位宽时，CRC 数据寄存器（CRC\_DR）的取值范围为[0x00, 0xFF]，当输入数据为 16 位宽时，CRC 数据寄存器（CRC\_DR）的取值范围为[0x0000, 0xFFFF]，当输入数据为 32 位宽时，CRC 数据寄存器（CRC\_DR）的取值范围为[0x00000000, 0xFFFFFFFF]。
- 可以通过 CRC 控制寄存器（CRC\_CR）的 IES 位来设置输入数据的大小端，OES 位来设置输出数据的大小端。
- 可以通过操作 CRC 中间数据寄存器（CRC\_MIR），实现多串数据之间的交错 CRC 计算。

### 6.3.3 使用方法

#### 6.3.3.1 CRC 计算操作步骤

- 使能 CRC 模块时钟；
- 复位 CRC 模块；
- 配置 CRC\_CR 寄存器：
  - ◆ 选择算法：CRC-32 或者 CRC-32/MPEG-2；
  - ◆ 选择输入数据位宽：8 位、16 位或者 32 位；

（举例：数值 0x00000012，输入数据 8 位位宽时，CRC\_DR 应赋值为 0x12；16 位位宽时，CRC\_DR 应赋值为 0x0012；32 位位宽时，CRC\_DR 应赋值为 0x00000012）

- ◆ 选择输入、输出的大小端。

（如 0x12345678，大端为 0x78563412，小端为 0x12345678）

- 通过配置 CRC 控制寄存器（CRC\_CR）的 RST 位，将 CRC 恢复到初始状态；
- 将数据依次写入 CRC 数据寄存器（CRC\_DR）；

- 读取 CRC 数据寄存器 (CRC\_DR)，得到 CRC 计算结果。

### 6.3.3.2 交错 CRC 计算操作步骤

当在第一串数据未计算完插入第二串数据的情况的步骤：

- 将第一串数据计算的中间结果从 CRC 中间数据寄存器 (CRC\_MIR) 中读出并进行存储；
- 通过置位 CRC 控制寄存器 (CRC\_CR) 的 RST 位来复位 CRC 数据寄存器 (CRC\_DR)；
- 依次将第二串数据写入到 CRC 数据寄存器 (CRC\_DR) 中，在完成 CRC 运算后，将第二串数据的 CRC 运算结果从 CRC 数据寄存器 (CRC\_DR) 中读出并进行存储；
- 再次通过置位 CRC 控制寄存器 (CRC\_CR) 的 RST 位来复位 CRC 数据寄存器 (CRC\_DR)，并把 CRC 计算模式设置成与第一串数据的模式相同；
- 将存储的第一串数据中间计算结果写入 CRC 中间数据寄存器 (CRC\_MIR) 中，然后将第一串数据中剩余的数据依次写入 CRC 数据寄存器 (CRC\_DR)，硬件将自动继续进行计算第一串未完成的数据，待计算完成，可以从 CRC 数据寄存器 (CRC\_DR) 中读取出第一串数据的 CRC 运算结果。

## 6.4 寄存器

### 6.4.1 寄存器总览

表 6-1 CRC 寄存器概览

| Offset | Acronym | Register Name | Reset      |
|--------|---------|---------------|------------|
| 0x00   | CRC_DR  | CRC 数据寄存器     | 0xFFFFFFFF |
| 0x04   | CRC_IDR | CRC 独立数据寄存器   | 0x00000000 |
| 0x08   | CRC_CR  | CRC 控制寄存器     | 0x00000000 |
| 0x0C   | CRC_MIR | CRC 中间数据寄存器   | 0xFFFFFFFF |

### 6.4.2 CRC\_DR CRC 数据寄存器

偏移地址：0x00

复位值：0xFFFF FFFF

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

| Bit   | Field | Description                                                                       |
|-------|-------|-----------------------------------------------------------------------------------|
| 31: 0 | DR    | 数据寄存器 (Data Register)<br>写入时, 作为输入寄存器, 将写入的数据和前一次的结果做 CRC 计算<br>读取时, 返回 CRC 计算的结果 |

#### 6.4.3 CRC\_IDR CRC 独立数据寄存器

偏移地址: 0x04

复位值: 0x0000 0000

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

| Bit   | Field    | Description                                                                                              |
|-------|----------|----------------------------------------------------------------------------------------------------------|
| 31: 8 | Reserved | 保留, 必须保持复位值                                                                                              |
| 7: 0  | IDR      | 8 位通用数据寄存器 (General-purpose 8-bit Data Register)<br>临时存放 1 个字节的数据空间。<br>不受 CRC 控制寄存器 (CRC_CR) 的 RST 位影响。 |

#### 6.4.4 CRC\_CR CRC 控制寄存器

偏移地址: 0x08

复位值: 0x0000 0000

|      |    |    |    |    |    |    |    |     |     |       |    |    |     |    |    |
|------|----|----|----|----|----|----|----|-----|-----|-------|----|----|-----|----|----|
| 31   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22  | 21    | 20 | 19 | 18  | 17 | 16 |
| Res. |    |    |    |    |    |    |    |     |     |       |    |    |     |    |    |
| 15   | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7   | 6   | 5     | 4  | 3  | 2   | 1  | 0  |
| Res. |    |    |    |    |    |    |    | OES | IES | ISIZE |    | AS | RST |    |    |
| rw   |    |    |    |    |    |    |    | rw  | rw  | rw    |    | rw | w   |    |    |

| Bit   | Field    | Description                                                                      |
|-------|----------|----------------------------------------------------------------------------------|
| 31: 6 | Reserved | 保留, 必须保持复位值                                                                      |
| 5     | OES      | 输出大小端选择 (Output Endian Selection)<br>0: 小端 (Little-endian)<br>1: 大端 (Big-endian) |

| Bit  | Field | Description                                                                                                |
|------|-------|------------------------------------------------------------------------------------------------------------|
| 4    | IES   | 输入大小端选择 (Input Endian Selection)<br>0: 小端 (Little-endian)<br>1: 大端 (Big-endian)                            |
| 3: 2 | ISIZE | 输入数据宽度 (Input Size)<br>00: 输入为 32 位<br>01: 输入为 16 位<br>10: 输入为 8 位<br>11: 保留                               |
| 1    | AS    | CRC 算法选择 (CRC Algorithm Selection)<br>0: 算法为 CRC-32/MPEG-2<br>1: 算法为 CRC-32                                |
| 0    | RST   | 复位 CRC 计算单元 (CRC Reset)<br>CRC 数据寄存器 (CRC_DR) 和 CRC 中间数据寄存器 (CRC_MIR) 复位为 0xFFFF FFFF<br>该位只能写“1”，硬件自动清“0” |

#### 6.4.5 CRC\_MIR CRC 中间数据寄存器

偏移地址: 0x0C

复位值: 0xFFFF FFFF

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

| Bit   | Field | Description                                                                                                                                                        |
|-------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31: 0 | MIR   | 中间数据寄存器 (Middle Data Register)<br>用于读取计算的中间结果，读写都是 32 位操作<br>如果将读取的值重新写入，可以继续之前的 CRC 计算。在多个数据序列做 CRC<br>计算的时候，可以将计算结果的读出保存，在其他 CRC 计算完成后，将保存<br>值写入到寄存器继续之前被中断的计算。 |

## 7 GPIO 通用端口

### 7.1 简介

每个通用 I/O 端口都可以通过两个 32 位的控制寄存器（GPIOx\_CRL/GPIOx\_CRH）和两个 32 位的复用控制寄存器（GPIOx\_AFRL/GPIOx\_AFRH）配置为 8 种模式：模拟输入、浮空输入、上拉输入、下拉输入、推挽输出、开漏输出、复用推挽输出和复用开漏输出。

可以自由编程控制每个 I/O 端口，支持字（32 位）、半字（16 位）或字节（8 位）访问所有寄存器。GPIO 寄存器组有 GPIOx\_BSRR 和 GPIOx\_BRR 位控制寄存器，通过写操作这两个寄存器可以独立的按位控制 GPIOx\_ODR 输出 0 或 1。

### 7.2 主要特征

- 每次 AHB 的写操作，可以更改 GPIOx\_ODR 对应的一位或多位
- 所有 I/O 支持编程 EXTI 配置寄存器输出外部触发中断
- 支持配置 GPIO 锁定机制
- 输入支持浮空、上拉、下拉、模拟
- 输出支持推挽与开漏上拉或开漏下拉
- 默认浮空输入，输入输出方向可配
- I/O 输出速度可配

## 7.3 功能描述

### 7.3.1 功能框图



图 7-1 标准 I/O 端口

### 7.3.2 GPIO 端口配置

表 7-1 端口位配置表 (port0 为例)

| 引脚模式         |    | 上下拉 | DCRx[1:0] |   | CNFO |    | MODE0          | ODRx   |
|--------------|----|-----|-----------|---|------|----|----------------|--------|
| 模拟输入         | x  | x   | x         | 0 | 0    | 00 | x              |        |
| 通用输入<br>复用输入 | 浮空 | x   | x         | 0 | 1    |    | x              |        |
|              | 上拉 | x   | x         | 1 | 0    |    | 1              |        |
|              | 下拉 | x   | x         | 1 | 0    |    | 0              |        |
| 通用输出         | 推挽 | x   | x         | x | 0    | 0  | 01<br>10<br>11 | 0 or 1 |
|              | 开漏 | 浮空  | x         | 0 | 0    | 1  |                | 0 or 1 |
|              |    | 上拉  | 1         | 1 | 0    | 1  |                | 0 or 1 |
|              |    | 下拉  | 0         | 1 | 0    | 1  |                | 0 or 1 |
| 复用输出         | 推挽 | x   | x         | x | 1    | 0  | x              |        |
|              | 开漏 | 浮空  | x         | 0 | 1    | 1  | x              |        |
|              |    | 上拉  | 1         | 1 | 1    | 1  | x              |        |
|              |    | 下拉  | 0         | 1 | 1    | 1  | x              |        |

注: x 表示 I/O 在对应的模式下不用关心, ODR0 代表输出数据寄存器第 0 位。

输入输出参考配置如下：

- 通用输入：

用户只需配置 `GPIOx_CRL` 中的 `CNF0` 选择输入模式

- 通用输出：

推挽输出：用户配置 `MODE0` 选择输出速度，配置 `CNF0=00`；

开漏输出：用户配置 `MODE0` 选择输出速度，配置 `CNF0=01`，如果对 pin 上下拉有要求，需要单独配置 `GPIOx_DCR` 寄存器，非开漏输出模式，上下拉失效。

- 复用功能：

配置 `AFRLx[3:0]` 与 `AFRHx[3:0]` 寄存器选择复用功能：

推挽复用输出：用户配置 `MODE0` 选择输出速度，配置 `CNF0=10`；

推挽开漏输出：用户配置 `MODE0` 选择输出速度，配置 `CNF0=11`。

如果输出模式下对 IO 上下拉有要求，需要单独配置 `GPIOx_DCR` 寄存器，非开漏输出模式，上下拉失效。

在复位期间或复位之后，GPIO 端口被配置成浮空输入模式，串行线调试端口（Serial-Wired Debug pins）默认为输入 PU/PD 模式。

配置为通用输出模式后，输出数据寄存器（`GPIOx_ODR`）的值会输出到相应的 I/O 引脚。在每个 AHB 时钟周期，输入数据寄存器（`GPIOX_IDR`）捕捉 I/O 引脚上的数据。

注：并不是所有芯片都包括 JTAG 和 SWD 调试端口，芯片具体配置可参考芯片数据手册。

- PA14: SWCLK 置于下拉模式
- PA13: SWDIO 置于上拉模式

### 7.3.3 复用功能

配置复用功能寄存器打开 IO 对应的复用功能。

- 配置 IO 为复用输入功能时，端口选择上拉、下拉或浮空输入。
- 配置 IO 为复用输出功能时，端口选择推挽或开漏输出模式。
- IO 配置为双向复用功能时，端口选择推挽或开漏输出模式，输入变为浮空输入，开漏模式下可配置 `GPIOx_DCR` 寄存器选择弱上拉或下拉电阻。

当配置端口为复用输出功能时，端口与片上外设输出信号连接。如果仅仅通过软件方式配置 GPIO 引脚为复用输出功能，外设没有被激活，此时输出不确定。

### 7.3.4 GPIO 锁定机制

GPIO 存在锁定机制，能够保持设定 IO 配置不被改变。当对某一端口执行锁定机制后，在下一次复位之前，不能改变端口对应的配置。锁定键写序列为：

- $\text{GPIOx\_LCKR}[16] = '1' + \text{LCKR}[15:0]$ 。
- $\text{GPIOx\_LCKR}[16] = '0' + \text{LCKR}[15:0]$ 。
- $\text{GPIOx\_LCKR}[16] = '1' + \text{LCKR}[15:0]$ 。

使能 GPIOA 的 PA[0] 端口锁定参考配置如下：

- $\text{GPIOA} \rightarrow \text{GPIOA\_LCKR} = 0x10001$ 。
- $\text{GPIOA} \rightarrow \text{GPIOA\_LCKR} = 0x00001$ 。
- $\text{GPIOA} \rightarrow \text{GPIOA\_LCKR} = 0x10001$ 。

当执行完上述三个步骤后，`GPIOA_LCKR` 寄存器的第 16 位置 1，在下一次软件复位之前，写 `GPIOA_LCKR` 寄存器无效，`GPIOA_LCKR` 寄存器的第 16 保持为 1，不会被更改，PA[0]会一直保持锁定之前的配置不变。

当端口被锁定后，只能在软件复位之后才能再次更改端口位的配置，`GPIOx_LCKR` 寄存器的一个锁定位锁定端口配置寄存器（`GPIOx_CRL`）与（`GPIOx_CRH`）中的 4 个位。

注意事项：

以上配置只是锁定了 PA[0]的配置，对于 PA[15:1]以及其它 GPIO 控制寄存器的配置操作依然有效。

### 7.3.5 输入配置

当 I/O 端口配置为输入时：

- 施密特触发输入使能。
- 输出缓冲被禁用。
- 可以选择浮空、上拉或下拉输入模式。
- I/O 脚上的数据在每个 AHB 时钟被采样到输入数据寄存器。
- 读访问输入数据寄存器可得到 I/O 状态。

下图给出了 I/O 端口的输入配置：



图 7-2 输入浮空/上拉/下拉配置

GPIOA 的 PA[0] 端口输入上拉参考配置如下：

- $\text{GPIOA} \rightarrow \text{GPIOA\_ODR} = 0x0001$ 。

- GPIOA->GPIOA\_CRL=0x00000008。

GPIOA 的 PA[0]端口输入下拉参考配置如下：

- GPIOA->GPIOA\_ODR=0x0000。
- GPIOA->GPIOA\_CRL=0x00000008。

注意事项：

当端口配置上拉输入时，需要首先配置对应端口的 GPIO\_ODR 寄存器对应位输出 1。

当端口配置下拉输入时，需要首先配置对应端口的 GPIO\_ODR 寄存器对应位输出 0。

### 7.3.6 输出配置

当 GPIO 配置为输出时：

- 施密特触发输入使能。
- 输出缓冲使能。
- 通用输出模式下，弱上拉和弱下拉电阻被禁用。
- 开漏模式：端口输出数据寄存器配置为 0 时，对应的引脚输出低电平，端口输出数据寄存器配置为 1 时，对应的管脚处于高阻态。
- 推挽模式：输出寄存器配置为 0 时，对应的引脚输出低电平，输出寄存器配置为 1 时，对应的管脚输出高电平。
- 对端口输出数据寄存器读操作，返回上次写入值。
- 对端口输入数据寄存器进行读操作，获得当前 I/O 的状态。

下图为 I/O 端口的输出配置：



图 7-3 输出配置

### 7.3.7 复用功能配置

当配置引脚为复用功能时：

- 施密特触发输入使能。
- 输出缓冲器可以配置为开漏或推挽。
- 在开漏输出模式下，通过配置 GPIOx\_DCR 寄存器选择弱上拉或下拉电阻。
- 当配置为输入时，可选弱上拉或弱下拉电阻。
- I/O 脚上数据在每个 AHB 时钟周期被采样到输入数据寄存器。

下图为 I/O 端口复用功能的配置，具体见 AFRL 与 AFRH 寄存器与数据手册部分。



图 7-4 复用功能配置

### 7.3.8 模拟输入配置

当 I/O 端口被配置成模拟输入配置时：

- 输出缓冲器禁用。
- 施密特触发输入禁用。
- 弱上拉与弱下拉电阻禁用。
- 端口输入数据寄存器保持为 0。

下图为 I/O 端口的模拟输入配置



图 7-5 模拟输入

### 7.3.9 外部时钟复用 GPIO 端口

外部 HSE/LSE 时钟复用 GPIO，当对应的时钟 PAD 用做 GPIO 功能时，需先关闭外部时钟，再按照正常的 GPIO 功能操作，具体映射关系参考芯片数据手册部分。

### 7.3.10 NRST 复用功能重映射

对于包含了 NRST 功能的 GPIO，其默认用做 NRST 功能，当需要将其用作 GPIO 功能时，需要首先配置闪存选项字节寄存器（FLASH\_OBR）的 OBR\_RSTN 位等于 0，然后经系统复位后，配置生效。

对于包含了 NRST 功能的 GPIO，其芯片内部默认接上拉电阻，当用作 NRST 功能时，禁止配置该引脚相关的 GPIO 控制器，避免影响复位功能。保持默认配置即可。

### 7.3.11 SWD 复用功能重映射

SWD 调试接口信号被映射到 GPIO 端口上，如下表所示：

表 7-2 SWD 复用功能重映射

| 复用功能  | GPIO 端口 |
|-------|---------|
| SWDIO | PA13    |
| SWCLK | PA14    |

## 7.4 GPIO 寄存器描述

### 7.4.1 寄存器总览

表 7-3 GPIO 寄存器概览

| Offset | Acronym   | Register Name | Reset      |
|--------|-----------|---------------|------------|
| 0x00   | GPIOx_CRL | 端口配置低寄存器      | 0x44444444 |

| Offset | Acronym    | Register Name | Reset        |
|--------|------------|---------------|--------------|
| 0x04   | GPIOx_CRH  | 端口配置高寄存器      | 0x44444444   |
| 0x08   | GPIOx_IDR  | 端口输入数据寄存器     | 0x0000XXXX   |
| 0x0C   | GPIOx_ODR  | 端口输出数据寄存器     | 0x00000000   |
| 0x10   | GPIOx_BSRR | 端口设置/清除寄存器    | 0x00000000   |
| 0x14   | GPIOx_BRR  | 端口位清除寄存器      | 0x00000000   |
| 0x18   | GPIOx_LCKR | 端口配置锁定寄存器     | 0x00000000   |
| 0x1C   | GPIOx_DCR  | 端口输出开漏控制寄存器   | 0x00000000   |
| 0x20   | GPIOx_AFRL | 端口复用功能低位寄存器   | 0xFFFFFFFF   |
| 0x24   | GPIOx_AFRH | 端口复用功能高位寄存器   | 0xF00FFFFFFF |

注：GPIOx 中“x”的可能范围是 A 到 H，但并不是所有芯片均包括所有 GPIOA 到 GPIOH 组，各芯片的具体配置可参考各芯片的数据手册。

#### 7.4.2 GPIOx\_CRL 端口配置低寄存器

偏移地址：0x00

复位值：0x4444 4444

|      |    |       |    |      |    |       |    |      |    |       |    |      |    |       |    |
|------|----|-------|----|------|----|-------|----|------|----|-------|----|------|----|-------|----|
| 31   | 30 | 29    | 28 | 27   | 26 | 25    | 24 | 23   | 22 | 21    | 20 | 19   | 18 | 17    | 16 |
| CNF7 |    | MODE7 |    | CNF6 |    | MODE6 |    | CNF5 |    | MODE5 |    | CNF4 |    | MODE4 |    |
| rw   |    | rw    |    | rw   |    | rw    |    | rw   |    | rw    |    | rw   |    | rw    |    |
| 15   | 14 | 13    | 12 | 11   | 10 | 9     | 8  | 7    | 6  | 5     | 4  | 3    | 2  | 1     | 0  |
| CNF3 |    | MODE3 |    | CNF2 |    | MODE2 |    | CNF1 |    | MODE1 |    | CNF0 |    | MODE0 |    |
| rw   |    | rw    |    | rw   |    | rw    |    | rw   |    | rw    |    | rw   |    | rw    |    |

| Bit   | Field | Description                                                                                     |
|-------|-------|-------------------------------------------------------------------------------------------------|
| 31:30 | CNF7  | 端口配置位 ( $y=7..0$ )                                                                              |
| 27:26 | CNF6  | 配置 MODEy 等于 0，端口为输入模式，此时配置 CNFy 位选择输入模式：<br>00: 模拟输入模式<br>01: 浮空输入模式<br>10: 上拉/下拉输入模式<br>11: 保留 |
| 23:22 | CNF5  |                                                                                                 |
| 19:18 | CNF4  |                                                                                                 |
| 15:14 | CNF3  |                                                                                                 |
| 11:10 | CNF2  |                                                                                                 |
| 7:6   | CNF1  | 配置 MODEy 不等于 0，端口为输出模式，此时配置 CNFy 位选择输出模式：<br>00: 通用推挽输出模式<br>01: 通用开漏输出模式                       |
| 3:2   | CNF0  | 10: 复用功能推挽输出模式<br>11: 复用功能开漏输出模式                                                                |
| 29:28 | MODE7 | 端口输入输出配置 (MODEy) ( $y = 0..7$ )                                                                 |
| 25:24 | MODE6 | 软件配置相应的 I/O 端口；参考端口位配置表                                                                         |
| 21:20 | MODE5 | 配置 MODEy 不等于 0 时，不同配置输出速度不同：                                                                    |
| 17:16 | MODE4 | 00: 输入模式；                                                                                       |
| 13:12 | MODE3 | 其它配置输出速度参考芯片数据手册部分。                                                                             |
| 9:8   | MODE2 |                                                                                                 |
| 5:4   | MODE1 |                                                                                                 |
| 1:0   | MODE0 |                                                                                                 |

### 7.4.3 GPIOx\_CRH 端口配置高寄存器

偏移地址: 0x04

复位值: 0x4444 4444

|       |    |        |    |       |    |        |    |       |    |        |    |       |    |        |    |
|-------|----|--------|----|-------|----|--------|----|-------|----|--------|----|-------|----|--------|----|
| 31    | 30 | 29     | 28 | 27    | 26 | 25     | 24 | 23    | 22 | 21     | 20 | 19    | 18 | 17     | 16 |
| CNF15 |    | MODE15 |    | CNF14 |    | MODE14 |    | CNF13 |    | MODE13 |    | CNF12 |    | MODE12 |    |
| rw    |    | rw     |    | rw    |    | rw     |    | rw    |    | rw     |    | rw    |    | rw     |    |
| 15    | 14 | 13     | 12 | 11    | 10 | 9      | 8  | 7     | 6  | 5      | 4  | 3     | 2  | 1      | 0  |
| CNF11 |    | MODE11 |    | CNF10 |    | MODE10 |    | CNF9  |    | MODE9  |    | CNF8  |    | MODE8  |    |
| rw    |    | rw     |    | rw    |    | rw     |    | rw    |    | rw     |    | rw    |    | rw     |    |

| Bit   | Field  | Description                                                                                                     |
|-------|--------|-----------------------------------------------------------------------------------------------------------------|
| 31:30 | CNF15  | 端口配置位 ( $y=15..8$ )                                                                                             |
| 27:26 | CNF14  | 配置 MODEy 等于 0, 端口为输入模式, 此时配置 CNFy 位选择输入模式:<br>00: 模拟输入模式<br>01: 浮空输入模式<br>10: 上拉/下拉输入模式<br>11: 保留               |
| 23:22 | CNF13  | 配置 MODEy 不等于 0, 端口为输出模式, 此时配置 CNFy 位选择输出模式:<br>00: 通用推挽输出模式<br>01: 通用开漏输出模式<br>10: 复用功能推挽输出模式<br>11: 复用功能开漏输出模式 |
| 19:18 | CNF12  | 端口输入输出配置 (MODEy) ( $y = 15..8$ )                                                                                |
| 15:14 | CNF11  | 软件配置相应的 I/O 端口; 参考端口位配置表                                                                                        |
| 11:10 | CNF10  | 配置 MODEy 不等于 0 时, 不同配置输出速度不同:<br>00: 输入模式;<br>其它配置输出速度参考芯片数据手册部分。                                               |
| 7:6   | CNF9   |                                                                                                                 |
| 3:2   | CNF8   |                                                                                                                 |
| 29:28 | MODE15 |                                                                                                                 |
| 25:24 | MODE14 |                                                                                                                 |
| 21:20 | MODE13 |                                                                                                                 |
| 17:16 | MODE12 |                                                                                                                 |
| 13:12 | MODE11 |                                                                                                                 |
| 9:8   | MODE10 |                                                                                                                 |
| 5:4   | MODE9  |                                                                                                                 |
| 1:0   | MODE8  |                                                                                                                 |

### 7.4.4 GPIOx\_IDR 端口输入数据寄存器

偏移地址: 0x08

复位值: 0x0000 XXXX

|                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|---------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 31                  | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Res                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15                  | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| IDRY( $y=15\sim0$ ) |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| r                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit   | Field    | Description                              |
|-------|----------|------------------------------------------|
| 31:16 | Reserved | 始终读为 0                                   |
| 15:0  | IDRY     | 端口输入数据 ( $y=15..0$ )<br>读出的值代表对应的 I/O 状态 |

#### 7.4.5 GPIOx\_ODR 端口输出数据寄存器

偏移地址: 0xC

复位值: 0x0000 0000

|                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|----------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 31                   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Res                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15                   | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| ODRY( $y=15\sim 0$ ) |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| rw                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit   | Field    | Description                                                                                                  |
|-------|----------|--------------------------------------------------------------------------------------------------------------|
| 31:16 | Reserved | 始终读为 0                                                                                                       |
| 15:0  | ODRY     | 端口输出数据 ( $y=15..0$ )<br>配置为通用输出模式时，写入值输出到对应的 IO<br>注：操作 GPIOx_BSRR ( $x=A..D$ ) 寄存器可以分别独立的对各个 ODR 位置 1 或清 0。 |

#### 7.4.6 GPIOx\_BSRR 端口设置/清除寄存器

偏移地址: 0x10

复位值: 0x0000 0000

|                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|---------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 31                  | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| BRy( $y=15\sim 0$ ) |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15                  | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| w                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| BSy( $y=15\sim 0$ ) |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| w                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit   | Field | Description                                                        |
|-------|-------|--------------------------------------------------------------------|
| 31:16 | BRy   | 端口清除位 y ( $y=15..0$ )<br>写 0 相应的 ODRY 位保持不变<br>写 1 清除对应的 ODRY 位为 0 |

| Bit  | Field | Description                                                                                             |
|------|-------|---------------------------------------------------------------------------------------------------------|
| 15:0 | BSy   | 端口置位 y (y=15..0)<br>写 0 相应的 ODRY 位保持不变<br>写 1 置位对应的 ODRY 位为 1<br>注：同时写 BSy 位与 BRy 位为 1 时，BSy 的优先级高于 BRy |

#### 7.4.7 GPIOx\_BRR 端口位清除寄存器

偏移地址: 0x14

复位值: 0x0000 0000

|             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 31          | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Res         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15          | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| BRy(y=15~0) |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit   | Field    | Description                                                    |
|-------|----------|----------------------------------------------------------------|
| 31:16 | Reserved | 始终读为 0                                                         |
| 15:0  | BRy      | 端口清除位 y (y=15..0)<br>写 0 相应的 ODRY 位保持不变<br>写 1 清除对应的 ODRY 位为 0 |

#### 7.4.8 GPIOx\_LCKR 端口配置锁定寄存器

地址偏移: 0x18

复位值: 0x0000 0000

|              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |
|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|
| 31           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16   |
| Res          |    |    |    |    |    |    |    |    |    |    |    |    |    |    | LCKK |
| 15           | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0    |
| LCKy(y=15~0) |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |
| W            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |

| Bit   | Field    | Description |
|-------|----------|-------------|
| 31:17 | Reserved | 始终读为 0      |

| Bit  | Field | Description                                                                                                                                  |
|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------|
| 16   | LCKK  | <p>锁键 (Lock key)<br/>该位可随时读出,它只可通过锁键写入序列修改。<br/>0: 端口配置锁键位未被激活<br/>1: 端口配置锁键位被激活,下次软件复位前 GPIOx_LCKR 寄存器被锁住<br/>锁键序列: 写 1-&gt;写 0-&gt;写 1</p> |
| 15:0 | LCKy  | <p>端口 x 的锁位 y (y = 15..0)<br/>这些位可读可写但只能在 LCKK 位为 0 时写入。<br/>0: 不锁定端口的配置<br/>1: 锁定端口的配置</p>                                                  |

#### 7.4.9 GPIOx\_DCR 端口输出开漏控制寄存器

偏移地址: 0x1C

复位值: 0x0000 0000

|      |      |    |      |    |      |    |      |    |      |    |     |    |     |    |    |
|------|------|----|------|----|------|----|------|----|------|----|-----|----|-----|----|----|
| 31   | 30   | 29 | 28   | 27 | 26   | 25 | 24   | 23 | 22   | 21 | 20  | 19 | 18  | 17 | 16 |
| PX15 | PX14 |    | PX13 |    | PX12 |    | PX11 |    | PX10 |    | PX9 |    | PX8 |    |    |
| rw   |      |    |      |    |      |    |      |    |      |    |     |    |     |    |    |
| 15   | 14   | 13 | 12   | 11 | 10   | 9  | 8    | 7  | 6    | 5  | 4   | 3  | 2   | 1  | 0  |
| PX7  | PX6  |    | PX5  |    | PX4  |    | PX3  |    | PX2  |    | PX1 |    | PX0 |    |    |
| rw   |      |    |      |    |      |    |      |    |      |    |     |    |     |    |    |

| Bit  | Field    | Description                                                                           |
|------|----------|---------------------------------------------------------------------------------------|
| 31:2 | PX15-PX1 | 见 PX0                                                                                 |
| 1:0  | PX0      | <p>PX0[1: 0]:<br/>11: 开漏输出模式下, 端口上拉<br/>01: 开漏输出模式下, 端口下拉<br/>x0: 开漏输出模式下, 端口无上下拉</p> |

#### 7.4.10 GPIOx\_AFRL 端口复用功能低位寄存器

偏移地址: 0x20

复位值: GPIOx\_AFRL (x = A..D): 0xFFFF FFFF

|      |    |    |    |      |    |    |    |      |    |    |    |      |    |    |    |
|------|----|----|----|------|----|----|----|------|----|----|----|------|----|----|----|
| 31   | 30 | 29 | 28 | 27   | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19   | 18 | 17 | 16 |
| AFR7 |    |    |    | AFR6 |    |    |    | AFR5 |    |    |    | AFR4 |    |    |    |
| rw   |    |    |    | rw   |    |    |    | rw   |    |    |    | rw   |    |    |    |
| 15   | 14 | 13 | 12 | 11   | 10 | 9  | 8  | 7    | 6  | 5  | 4  | 3    | 2  | 1  | 0  |
| AFR3 |    |    |    | AFR2 |    |    |    | AFR1 |    |    |    | AFR0 |    |    |    |
| rw   |    |    |    | rw   |    |    |    | rw   |    |    |    | rw   |    |    |    |

| Bit  | Field | Description                                                                                                                                                                                                                   |
|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | AFRy  | 端口 x 的位 y (y = 0..7) 的复用功能选择位, 软件写配置。<br>0000: AF0 0001: AF1 0010: AF2<br>0011: AF3 0100: AF4 0101: AF5<br>0110: AF6 0111: AF7 1000: AF8<br>1001: AF9 1010: AF10 1011: AF11<br>1100: AF12 1101: AF13 1110: AF14<br>1111: AF15 |

#### 7.4.11 GPIOx\_AFRH 端口复用功能高位寄存器

偏移地址: 0x24

复位值: GPIOx\_AFRH (x = B..D): 0xFFFF FFFF, GPIOA\_AFRH: 0xF00F FFFF

|       |    |    |    |       |    |    |    |       |    |    |    |       |    |    |    |
|-------|----|----|----|-------|----|----|----|-------|----|----|----|-------|----|----|----|
| 31    | 30 | 29 | 28 | 27    | 26 | 25 | 24 | 23    | 22 | 21 | 20 | 19    | 18 | 17 | 16 |
| AFR15 |    |    |    | AFR14 |    |    |    | AFR13 |    |    |    | AFR12 |    |    |    |
| rw    |    |    |    | rw    |    |    |    | rw    |    |    |    | rw    |    |    |    |
| 15    | 14 | 13 | 12 | 11    | 10 | 9  | 8  | 7     | 6  | 5  | 4  | 3     | 2  | 1  | 0  |
| AFR11 |    |    |    | AFR10 |    |    |    | AFR9  |    |    |    | AFR8  |    |    |    |
| rw    |    |    |    | rw    |    |    |    | rw    |    |    |    | rw    |    |    |    |

| Bit  | Field | Description                                                                                                                                                                                                                    |
|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | AFRy  | 端口 x 的位 y (y = 8..15) 的复用功能选择位, 软件写配置。<br>0000: AF0 0001: AF1 0010: AF2<br>0011: AF3 0100: AF4 0101: AF5<br>0110: AF6 0111: AF7 1000: AF8<br>1001: AF9 1010: AF10 1011: AF11<br>1100: AF12 1101: AF13 1110: AF14<br>1111: AF15 |

## 8 EXTI 中断和事件

### 8.1 简介

嵌套向量中断控制器（NVIC）连接处理器核，管理低延迟的异常和中断处理。NVIC 内部包含 4 位的中断优先级配置位，从而可提供 16 个中断优先级等级，其它更多的异常与 NVIC 编程的细节请参考《Cortex-Mx 技术参考手册》。

EXTI 模块包括边沿检测电路，能够产生中断请求或者唤醒事件，边沿检测支持上升沿、下降沿、任意边沿配置。每一个边沿检测电路支持独立的使能与屏蔽。

### 8.2 主要特征

- 独立触发与屏蔽每个中断
- 软件配置中断/事件输出
- 产生唤醒事件唤醒低功耗模式
- 挂起寄存器保存对应每条中断线的状态
- 所有 GPIO 支持配置为 EXTI 的触发源
- 支持上升沿触发，下降沿触发和任意边沿触发

## 8.3 功能描述

### 8.3.1 功能框图



图 8-1 EXTI 结构框图

### 8.3.2 中断和异常向量

在 Handler 模式下，Cortex-Mx 处理器与内嵌中断向量控制（NVIC）对所有的异常进行优先级区分处理。当异常发生时，系统会将当前处理的工作压栈，执行完中断服务程序后出栈。取向量与当前工作的压栈并行进行的，提高了中断的效率，下表分别列出了异常类型与中断向量。

表 8-1 异常向量表

| 位置 | 优先级 | 优先级类型            | 名称 | 说明                                   | 地址          |
|----|-----|------------------|----|--------------------------------------|-------------|
|    |     |                  |    | 保留                                   | 0x0000 0000 |
| -3 | 固定  | Reset            |    | 复位                                   | 0x0000 0004 |
| -2 | 固定  | NMI              |    | 不可屏蔽中断<br>RCC 时钟安全系统(CSS)连接<br>到 NMI | 0x0000 0008 |
| -1 | 固定  | 硬件失效 (HardFault) |    | 所有类型的失效                              | 0x0000 000C |

表 8-2 中断向量表

| 位置 | 优先级 | 优先级类型 | 名称     | 说明               | 地址          |
|----|-----|-------|--------|------------------|-------------|
| 3  | 3   | 可设置   | SVCALL | 通过 SWI 指令的系统服务调用 | 0x0000 002C |
|    | -   | -     |        | 保留               | 0x0000 0030 |

| 位置 | 优先级 | 优先级类型 | 名称                  | 说明                         | 地址          |
|----|-----|-------|---------------------|----------------------------|-------------|
|    |     | -     |                     | 保留                         | 0x0000_0034 |
|    | 6   | 可设置   | PendSV              | 可挂起的系统服务                   | 0x0000_0038 |
|    | 7   | 可设置   | SysTick             | 系统嘀嗒定时器                    | 0x0000_003C |
| 0  | 8   | 可设置   | WWDG_IWDG           | 窗口看门狗中断与连到 EXTI17 的独立看门狗中断 | 0x0000_0040 |
| 1  | 9   | 可设置   | PVD                 | 连到 EXTI16 的电源电压检测 (PVD) 中断 | 0x0000_0044 |
| 2  | 10  |       |                     | 保留                         | 0x0000_0048 |
| 3  | 11  | 可设置   | FLASH               | 闪存全局中断                     | 0x0000_004C |
| 4  | 12  | 可设置   | RCC                 | RCC 全局中断                   | 0x0000_0050 |
| 5  | 13  | 可设置   | EXTI0_1             | EXTI 线[1:0]中断              | 0x0000_0054 |
| 6  | 14  | 可设置   | EXTI2_3             | EXTI 线[3:2]中断              | 0x0000_0058 |
| 7  | 15  | 可设置   | EXTI4_15            | EXTI 线[15:4]中断             | 0x0000_005C |
| 8  | 16  |       |                     | 保留                         | 0x0000_0060 |
| 9  | 17  |       |                     | 保留                         | 0x0000_0064 |
| 10 | 18  |       |                     | 保留                         | 0x0000_0068 |
| 11 | 19  |       |                     | 保留                         | 0x0000_006C |
| 12 | 20  | 可设置   | ADC1                | ADC1 中断                    | 0x0000_0070 |
| 13 | 21  | 可设置   | TIM1_BRK_UP_TRG_COM | TIM1 刹车、更新、触发、COM 中断       | 0x0000_0074 |
| 14 | 22  | 可设置   | TIM1_CC             | TIM1 捕捉比较中断                | 0x0000_0078 |
| 15 | 23  |       |                     | 保留                         | 0x0000_007C |
| 16 | 24  | 可设置   | TIM3                | TIM3 全局中断                  | 0x0000_0080 |
| 17 | 25  |       |                     | 保留                         | 0x0000_0084 |
| 18 | 26  |       |                     | 保留                         | 0x0000_0088 |
| 19 | 27  | 可设置   | TIM14               | TIM14 全局中断                 | 0x0000_008C |
| 20 | 28  |       |                     | 保留                         | 0x0000_0090 |
| 21 | 29  |       |                     | 保留                         | 0x0000_0094 |
| 22 | 30  |       |                     | 保留                         | 0x0000_0098 |
| 23 | 31  | 可设置   | I2C1                | I2C1 全局中断                  | 0x0000_009C |
| 24 | 32  |       |                     | 保留                         | 0x0000_00A0 |
| 25 | 33  | 可设置   | SPI1                | SPI1 全局中断                  | 0x0000_00A4 |
| 26 | 34  |       |                     | 保留                         | 0x0000_00A8 |
| 27 | 35  | 可设置   | UART1               | UART1 全局中断                 | 0x0000_00AC |
| 28 | 36  | 可设置   | UART2               | UART2 全局中断                 | 0x0000_00B0 |
| 29 | 37  | -     |                     | 保留                         | 0x0000_00B4 |
| 30 | 38  | -     |                     | 保留                         | 0x0000_00B8 |

### 8.3.3 唤醒事件管理

EXTI 模块支持产生中断或者事件用于将系统从低功耗模式下唤醒，用户执行 WFE 指令进入相应的低功耗模式后，可以通过配置 EXTI 线产生事件输出唤醒系统，用户执行 WFI 进入低功耗模式后，可以通过配置 EXTI 线产生中断输出唤醒系统，具体详细配置参考电源控制章节。

### 8.3.4 中断功能描述

要使能中断功能，产生中断，首先配置边沿检测触发寄存器为需要的触发类型，打开相应的中断屏蔽寄存器的对应位允许中断请求。在对应的外部中断线检测到配置的触发条件时，产生一个中断请求，挂起寄存器对应位置 1，通过对挂起寄存器对应位写 1，将清除中断。

配置产生事件，首先配置边沿检测触发寄存器为需要的触发类型，打开相应的事件屏蔽寄存器的对应位允许事件请求。在对应的外部中断线检测到配置的触发条件时，产生一个事件请求。

使能软件中断/事件寄存器的对应位，也能够产生中断/事件请求。

### 8.3.5 硬件中断输出

配置硬件中断源的具体步骤如下：

- 打开对应中断线的屏蔽位（EXTI\_IMR），使能中断。
- 配置对应中断线的触发寄存器位（EXTI\_RTSR/EXTI\_FTSR）。
- 打开对应连接到 NVIC 的中断通道，使得中断请求能够传递到 CPU，被正确的响应。

当配置 EXTI<sub>x</sub> ( $x=31\sim0$ ) 线产生中断输出后，EXTI\_PR 寄存器的对应位会置 1，需要清除 EXTI\_PR 寄存器的对应挂起位才能再次检测 EXTI<sub>x</sub> ( $x=31\sim0$ ) 线的翻转并产生中断。

清除 EXTI\_PR 寄存器挂起位有以下三种方式：

- EXTI\_PR 寄存器的挂起位写 1。
- 如果配置了上升沿触发选择寄存器（EXTI\_RTSR），对应位写 0 会清除挂起位。如果配置了下降沿触发选择寄存器（EXTI\_FTSR），对应位写 0 会清除挂起位。
- 通过改变 EXTI 线的边沿检测极性清除。

### 8.3.6 硬件事件输出

配置硬件事件源的具体步骤如下：

- 打开对应事件线的屏蔽位（EXTI\_EMR）。
- 配置对应事件线的触发寄存器位（EXTI\_RTSR/EXTI\_FTSR）。

### 8.3.7 软件中断与事件输出

支持通过软件的方式配置产生中断与事件，具体步骤如下：

- 使能事件或中断使能位（EXTI\_IMR, EXTI\_EMR）。
- 配置软件中断事件寄存器对应位为 1（EXTI\_SWIER）。

### 8.3.8 外部中断映射

所有的 GPIO 均可用做 EXTI 的触发源用于产生中断或事件请求，通过配置 SYSCFG 章节的 SYSCFG\_EXTICRx 寄存器，同时支持内部模块（包括 PVD、RTC、USB、比较器、IWDG）触发。具体存在的连接关系如下表所示。

表 8-3 EXTI 触发源

| 外部中断线  | IO 映射   | 控制位                         |
|--------|---------|-----------------------------|
| EXTI0  | PA0;PB0 | SYSCFG_EXTICR1 寄存器中的 EXTI0  |
| EXTI1  | PA1;PB1 | SYSCFG_EXTICR1 寄存器中的 EXTI1  |
| EXTI2  | PA2     | SYSCFG_EXTICR1 寄存器中的 EXTI2  |
| EXTI3  | PA3     | SYSCFG_EXTICR1 寄存器中的 EXTI3  |
| EXTI4  | PA4     | SYSCFG_EXTICR2 寄存器中的 EXTI4  |
| EXTI5  | PA5     | SYSCFG_EXTICR2 寄存器中的 EXTI5  |
| EXTI6  | PA6     | SYSCFG_EXTICR2 寄存器中的 EXTI6  |
| EXTI7  | PA7     | SYSCFG_EXTICR2 寄存器中的 EXTI7  |
| EXTI8  | PA8     | SYSCFG_EXTICR3 寄存器中的 EXTI8  |
| EXTI9  | PA9     | SYSCFG_EXTICR3 寄存器中的 EXTI9  |
| EXTI10 | PA10    | SYSCFG_EXTICR3 寄存器中的 EXTI10 |
| EXTI11 | PA11    | SYSCFG_EXTICR3 寄存器中的 EXTI11 |
| EXTI12 | PA12    | SYSCFG_EXTICR4 寄存器中的 EXTI12 |
| EXTI13 | PA13    | SYSCFG_EXTICR4 寄存器中的 EXTI13 |
| EXTI14 | PA14    | SYSCFG_EXTICR4 寄存器中的 EXTI14 |
| EXTI15 | PA15    | SYSCFG_EXTICR4 寄存器中的 EXTI15 |

其他的外部中断/事件控制器的连接如下：

- EXTI 线 16 连接到 PVD 输出
- EXTI 线 17 连接到 IWDG 中断

## 8.4 寄存器描述

### 8.4.1 寄存器总览

表 8-4 EXTI 寄存器总览

| Offset | Acronym    | Register Name | Reset      |
|--------|------------|---------------|------------|
| 0x00   | EXTI_IMR   | 中断屏蔽寄存器       | 0x00000000 |
| 0x04   | EXTI_EMR   | 事件屏蔽寄存器       | 0x00000000 |
| 0x08   | EXTI_RTSR  | 上升沿触发选择寄存器    | 0x00000000 |
| 0x0C   | EXTI_FTSR  | 下降沿触发选择寄存器    | 0x00000000 |
| 0x10   | EXTI_SWIER | 软件中断事件寄存器     | 0x00000000 |
| 0x14   | EXTI_PR    | 挂起寄存器         | 0x00000000 |

### 8.4.2 EXTI\_IMR 中断屏蔽寄存器

偏移地址: 0x0

复位值: 0x0000 0000

|               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|---------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 31            | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| IMRx(x=31~16) |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| rw            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15            | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| IMRx(x=15~0)  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| rw            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit  | Field | Description                                                     |
|------|-------|-----------------------------------------------------------------|
| 31:0 | IMRx  | 线 x 中断使能位<br>1: 配置该位为 1, 使能线 x 对应的中断<br>0: 配置该位为 0, 禁止线 x 对应的中断 |

### 8.4.3 EXTI\_EMR 事件屏蔽寄存器

偏移地址: 0x04

复位值: 0x0000 0000

|               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|---------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 31            | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| EMRx(x=31~16) |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| rw            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15            | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| rw            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

EMRx(x=15~0)

rw

| Bit  | Field | Description                                                     |
|------|-------|-----------------------------------------------------------------|
| 31:0 | IMRx  | 线 x 事件使能位<br>1: 配置该位为 1, 使能线 x 对应的事件<br>0: 配置该位为 0, 禁止线 x 对应的事件 |

#### 8.4.4 EXTI\_RTSR 上升沿触发选择寄存器

偏移地址: 0x08

复位值: 0x0000 0000

|              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 31           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| PRx(x=31~16) |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| rw           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15           | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| PRx(x=15~0)  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| rw           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit  | Field | Description                                                                            |
|------|-------|----------------------------------------------------------------------------------------|
| 31:0 | TRx   | 线 x 对应中断或事件的触发极性<br>1: 配置该位为 1, 使能线 x 对应的上升沿触发中断或事件<br>0: 配置该位为 0, 禁止线 x 对应的上升沿触发中断或事件 |

#### 8.4.5 EXTI\_FTSR 下降沿触发选择寄存器

偏移地址: 0x0C

复位值: 0x0000 0000

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

| Bit  | Field | Description                                                                            |
|------|-------|----------------------------------------------------------------------------------------|
| 31:0 | TRx   | 线 x 对应中断或事件的触发极性<br>1: 配置该位为 1, 使能线 x 对应的下降沿触发中断或事件<br>0: 配置该位为 0, 禁止线 x 对应的下降沿触发中断或事件 |

#### 8.4.6 EXTI\_SWIER 软件中断事件寄存器

偏移地址: 0x10

复位值: 0x0000 0000

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

| Bit  | Field  | Description                                                                                   |
|------|--------|-----------------------------------------------------------------------------------------------|
| 31:0 | SWIERx | 线 x 上的软件配置中断或事件使能<br>写 1 将设置 EXTI_PR 寄存器中相应的挂起位, 同时配置 EXTI_IMR 或 EXTI_EMR 中对应位为 1, 能够产生中断或事件。 |
|      |        | 注: 向 EXTI PR 寄存器的对应位写 1, 可以清除该位                                                               |

#### 8.4.7 EXTI\_PR 软件中断事件挂起寄存器

偏移地址: 0x14

复位值: 0x0000 0000

|              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 31           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| PRx(x=31~16) |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| rc_w1        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15           | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| PRx(x=15~0)  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| rc_w1        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit  | Field | Description                                                                                                           |
|------|-------|-----------------------------------------------------------------------------------------------------------------------|
| 31:0 | PRx   | <p>线 x 触发挂起位</p> <p>1: 发生了选择的触发请求</p> <p>0: 没有发生触发请求</p> <p>外部中断线上出现选择的边沿事件时, 该位被置 1, 写 1 清除该位, 也可以通过改变边沿检测的极性清除。</p> |

## 9 ADC 模拟/数字转换

### 9.1 简介

ADC 是 12 位的逐次逼近型 (SAR) 模拟数字转换器，可以将模拟信号转换成数字信号。

ADC 有 9 个通道可测量内部或外部信号源，其中 ADC 有 8 路外部输入通道和 1 路内部通道。ADC 的通道可以单次、单周期和连续进行转换。根据不同的方式又可以选择普通通道转换、任意通道转换、注入通道转换。

ADC 的输入时钟不得超过 16M，他是由 APB 时钟(PCLK)分频产生。

### 9.2 功能框图



图 9-1 ADC 系统框图

注：V\_SENSOR（内部参考电压）通道在 ADC 的 AIN8 通道。

### 9.3 主要特征

- 高达 1Msps 转换速率
- 支持普通通道转换

- ◆ 单次转换模式：在指定通道完成一次转换
- ◆ 单周期扫描模式：对所有指定通道（从低序号通道到高序号通道，或从高序号通道到低序号通道）完成一个周期转换
- ◆ 连续扫描模式：连续执行单周期扫描模式直到软件停止 A/D 转换。若需要修改转换通道只能停止 A/D 转换，等待完成寄存器配置再重新开启转换
- 支持任意通道转换
  - ◆ 单次转换模式：在指定通道完成一次转换
  - ◆ 单周期扫描模式：在所有指定通道按照通道设置完成一个周期转换
  - ◆ 连续扫描模式：连续执行单周期扫描模式直到软件停止 A/D 转换。若需要转换期间修改通道，用户不必停止转换，可配置相应通道寄存器，配置的新通道将在下一个扫描周期进行转换
- 支持注入通道转换
  - ◆ 自动注入：在任意通道转换方式下，完成任意通道转换后自动开始进行注入通道工作
- 可编程通道采样时间
- 最高 12 位可编程分辨率 SAR
- A/D 转换开始条件
  - ◆ 软件启动
  - ◆ 触发启动，可配置触发延时
- 模拟看门狗功能。转换结果与指定的阈值区间进行比较，当转换值超出设定的阈值区间时，如果 ADC\_ADCR.AWDIE 置位，则产生中断

## 9.4 中断

ADC 的中断及标志位如下表所示。当配置中断使能后，中断事件发生将产生相应的中断请求。

表 9-1 中断事件一览表

| 中断           | 标志位      |
|--------------|----------|
| 模拟看门狗比较器中断   | AWDIF    |
| 通道序列转换结束中断   | EOSIF    |
| 单通道转换结束中断    | EOCIF    |
| 采样结束中断       | EOSMPIF  |
| 注入通道序列转换结束中断 | JEOSIF   |
| 注入通道转换结束中断   | JEOCIF   |
| 注入通道采样结束中断   | JEOSMPIF |

## 9.5 功能描述

### 9.5.1 时钟

ADC 的输入时钟与 PCLK 同步。在使用 ADC 之前，要先使能 RCC 控制器中的 ADC 时钟控制位。

### 9.5.2 数据补偿

非注入通道数据没有数据补偿。

注入通道转换数据减去 ADC\_JOFRn 寄存器定义的偏移量后保存到注入通道数据寄存器 ADC\_JADDATA 和 ADC\_JDRn。补偿后的结果可能为负值，因此注入通道转换的结果是有符号数据（数据对齐 SEXT 位是扩展的符号值）。

如果配置 ADC\_JOFRn.JOFFSET 不为 0，则注入通道数据寄存器 ADC\_JADDATA 和 ADC\_JDRn 数据为有符号值，否则为无符号值。

下面表格描述了数据分辨率与数据补偿左对齐关系：

表 9-2 数据分辨率与数据补偿左对齐关系

| 分辨率选择 | 模拟转换数据<br>SAR_DATA, 左移 | 补偿值                | 结果        | 说明                                      |
|-------|------------------------|--------------------|-----------|-----------------------------------------|
| 12bit | SAR_DATA[11:0]         | ADC_JOFRn.JOFFESET | 12 位有符号数据 | -                                       |
| 11bit | SAR_DATA[11:1],0       | ADC_JOFRn.JOFFESET | 11 位有符号数据 | 用户必须配置<br>ADC_JOFRn.JOFFSET[0]为“0”      |
| 10bit | SAR_DATA[11:2],00      | ADC_JOFRn.JOFFESET | 10 位有符号数据 | 用户必须配置<br>ADC_JOFRn.JOFFSET[1:0]为“00”   |
| 9bit  | SAR_DATA[11:3],000     | ADC_JOFRn.JOFFESET | 9 位有符号数据  | 用户必须配置<br>ADC_JOFRn.JOFFSET[2:0]为“000”  |
| 8bit  | SAR_DATA[11:4],0000    | ADC_JOFRn.JOFFESET | 8 位有符号数据  | 用户必须配置<br>ADC_JOFRn.JOFFSET[3:0]为“0000” |

### 9.5.3 数据对齐

通过配置 ADC\_ADCR.ALIGN 位，可以选择转换后数据储存格式为左对齐或右对齐。

如下图所示：



图 9-2 数据对齐方式

#### 9.5.4 可编程分辨率

ADC 转换有效位可通过 `ADC_ADCFG.RSLTCTL[2:0]` 位配置，有效数据位默认是 12 位数据右对齐，通过配置低分辨率可加快数据转换速率。

#### 9.5.5 可编程采样时间

ADC 转换通道的采样时间可通过 `ADC_SMPR1` 和 `ADC_SMPR2` 寄存器中的 `SAMPCTL0~SAMPCTL8` 配置。

ADC 的转换时钟 `ADC_CLK` 由 `PCLK` 分频得到，分频系数可通过设置 `ADC_ADCFG.ADCPRE` 位来确定，即  $PCLK/(ADCPRE+2)$  分频后作为 ADC 转换时钟。ADC 使用若干个 `ADC_CLK` 周期对输入电压采样，采样周期数目  $m$  可以通过配置 `ADC_SMPR1` 和 `ADC_SMPR2` 寄存器来更改。设置 ADC 分辨率为  $n$  位 ( $n=8, 9, 10, 11, 12$ )，每个通道采样周期为  $m*T$  ( $T$  为 ADC 模块的时钟周期)。

转换频率计算如下：

$$F_{\text{sample}} = F_{\text{ADC\_CLK}} / (m+n+0.5)。$$

假设分辨率  $n$  配置为 12bit，每个通道采样周期  $m$  为  $3.5T$ ，则  $F_{\text{sample}}=F_{\text{ADC\_CLK}}/16$ 。

总转换时间计算如下：

$$T_{\text{CONV}} = \text{采样时间} + 12.5 \text{ 个转换周期}。$$

例如当 `ADC_CLK=16MHz`，采样时间为  $3.5T$ ， $T_{\text{CONV}}=(3.5+12.5)*T=16*T$ ，总转换时间为  $1\mu\text{s}$ 。

### 9.5.6 数据通道寄存器

ADC 的转换完成后，非注入通道转换结果存储在寄存器 ADC\_ADDATA 中，ADC\_ADDATA.CHANNELSEL 表示当前数据对应的通道号。

注入通道转换结果存储在寄存器 ADC\_JADDATA 中，ADC\_JADDATA.JCHANNELSEL 表示当前数据对应的注入通道号。

### 9.5.7 通道选择

ADC 有 8 路外部输入通道 0~7、内部 1.2V 参考电压通道 8。

不同工作方式下可以通过不同寄存器来使能通道：普通通道转换可设置寄存器 ADC\_ADCHS；任意通道转换可设置寄存器 ADC\_ANY\_CFG、ADC\_CHANY0、ADC\_CHANY1，任意通道转换顺序从寄存器位 CHANY\_SEL0~15 优先级由高到低依次转换；注入通道转换可设置寄存器 JSQR，注入通道转换顺序从寄存器位 JSQ0~3 优先级由高到低依次转换。

## 9.6 ADC 开关

ADC\_ADCFG.ADEN 位可控制 A/D 转换模块，ADEN 位为 0 时，模拟转换模块进入掉电模式。设置 ADEN 位为 1，A/D 转换模块从掉电模式唤醒，通过清除 ADC\_ADCFG.ADEN 位可以停止转换且 ADC 进入掉电模式，掉电后 ADC 几乎不耗电。

### 9.6.1 普通通道转换

#### 9.6.1.1 单次采样

配置 ADC\_ADCR.ADMODE 为单次转换，配置的通道执行一次转换操作后进入空闲状态，具体流程如下：

- 通过外部触发输入、定时器触发、软件三种方式可以置位 ADC\_ADCR.ADST，开始 A/D 转换。
- 采样输出 SAMPL 默认被置位 2.5 个 ADC 时钟后清除。
- A/D 转换完成时，SAR 转换结果 SAR\_DATA 将存储于数据寄存器 ADC\_ADDATA 和 ADC\_ADDRn 中。
- A/D 转换结束时，状态寄存器 ADC\_ADSTA.EOSIF 位置 1，若此时控制寄存器 ADC\_ADCR.EOSIE 位置 1，将产生 AD 转换结束中断请求。
- A/D 转换期间，ADC\_ADCR.ADST 位保持为 1，A/D 通道转换结束以后，ADC\_ADCR.ADST 位自动硬件清 0，A/D 转换器进入空闲状态。

注：在单次转换模式下，如果软件使能多于一个通道，序号最小的通道被转换，其它通道被忽略。



图 9-3 单次转换模式时序图

#### 9.6.1.2 单周期扫描模式

配置 ADC\_ADCR.ADMODE 为单周期转换，在单周期扫描模式下，通过配置 ADC\_ADCR.SCANDIR 选择扫描通道方向，按 ADC\_ADCHS.CHENy(y=0~8)使能的通道顺序进行 A/D 转换，操作步骤如下：

- 触发或软件置位 ADC\_ADCR.ADST 可以开启 A/D 转换，触发事件可配置触发延时，方向设置默认从最小序号通道到最大序号通道的 A/D 转换。
- 通道输出按照转换通道配置有序输出。
- 各通道的 A/D 转换结束后，A/D 转换结果 SAR\_DATA 将有序装载到相应通道的数据寄存器 ADC\_ADDATA 和 ADC\_ADDRn 中，当前通道转换结束后 ADC\_ADSTA\_EXT.EOCIF 标志被置位，如果设置转换结束中断，则产生通道转换结束中断请求。序列转换结束后 ADC\_ADSTA.EOSIF 标志被置位，ADC\_ADSTA.EOSIF 序列转换结束标志被置位，如果设置使能了序列转换结束中断，则产生序列转换结束中断请求。
- 所有 A/D 通道转换结束后，ADC\_ADCR.ADST 位自动硬件清 0，A/D 转换器会进入空闲状态。



图 9-4 单周期扫描下使能通道转换时序图（通道方向从高到低）



图 9-5 单周期扫描下使能通道转换时序图（通道方向从低到高）

### 9.6.1.3 连续扫描模式

配置 ADC\_ADCR.ADMODE 为连续转换，在连续扫描模式下，通过配置 ADC\_ADCR.SCANDIR 选择扫描通道方向，按 ADC\_ADCHS.CHENy(y=0~8)使能的通道顺序进行 A/D 转换，操作步骤如下：

- 触发或软件置位 ADC\_ADCR.ADST 可以开启 A/D 转换，触发事件可配置触发延时，方向设置默认从最小序号通道到最大序号通道的 A/D 转换。
- 通道输出按照转换通道配置有序输出。
- 各通道的 A/D 转换结束后，A/D 转换结果 SAR\_DATA 将有序装载到相应通道的数据寄存器 ADC\_ADDATA 和 ADC\_ADDRn 中，当前通道转换结束后 ADC\_ADSTA\_EXT.EOCIF 标志被置位，如果设置转换结束中断，则产生通道转换结束中断请求。序列转换结束后 ADC\_ADSTA.EOSIF 标志被置位，ADC\_ADSTA.EOSIF 序列转换结束标志被置位，如果设置使能了序列转换结束中

断，则产生序列转换结束中断请求。

- 只要 ADC\_ADCR.ADST 位保持为 1，就可以持续进行 A/D 转换。当 ADC\_ADCR.ADST 位被清除，转换停止，进入空闲状态。当 ADC\_ADCR.ADST 位被清除，A/D 转换将结束当前转换。



图 9-6 连续扫描模式使能通道转换时序图（通道方向由低到高）



图 9-7 连续扫描模式使能通道转换时序图（通道方向由高到低）

## 9.6.2 任意通道转换

### 9.6.2.1 单次转换模式

配置 ADC\_ADCR.ADMODE 为单次转换，配置的通道执行一次转换操作后进入空闲状态。具体流程如下：

- 软件配置寄存器 ADC\_ANY\_CFG、ADC\_CHANY0、ADC\_CHANY1，将需要转换的通道配置结束后置位 ADC\_ANY\_CR.CHANY\_MDEN。
- 通过触发或软件置位 ADC\_ADCR.ADST，触发事件可配置触发延时，转换通道选择可通过寄存

器 ADC\_CHANY0 和 ADC\_CHANY1 任意配置。

- 采样输出 SAMPL 默认被置位 2.5 个 ADC 时钟后清除。
- A/D 转换结束后，A/D 转换结果 SAR\_DATA 将装载到 ADC\_ADDATA 和 ADC\_ADDR0，通道转换结束后 ADC\_ADSTA.EOSIF 标志被置位，如果设置使能了转换结束中断，则产生转换结束中断请求。
- 所有 A/D 通道转换结束后，ADST 位将被硬件自动清除，A/D 转换器会进入空闲状态。



图 9-8 单次转换模式下通道转换时序图

### 9.6.2.2 单周期扫描模式

配置 ADC\_ADCR.ADMODE 为单周期转换，在单周期扫描模式下，A/D 转换通道按照软件配置执行一遍，具体流程如下：

- 软件配置寄存器 ADC\_ANY\_CFG、ADC\_CHANY0、ADC\_CHANY1，将需要转换的通道和数量配置结束后置位 ADC\_ANY\_CR.CHANY\_MDEN。
- 通过触发或软件置位 ADC\_ADCR.ADST，触发事件可配置触发延时。A/D 转换通道数量由 ADC\_ANY\_CFG.CHANY\_NUM 配置，每次转换的输入通道可以由寄存器位 CHANY\_SEL0 到 CHANY\_SEL15 任意配置，可以完全相同或不同。
- 通道输出按照转换通道配置有序输出。
- 各通道的 A/D 转换结束后，A/D 转换结果 SAR\_DATA 将有序装载到相应通道的数据寄存器 ADC\_ADDATA 和 ADC\_ADDRn 中，当前通道转换结束后 ADC\_ADSTA\_EXT.EOCIF 标志被置位，如果设置转换结束中断，则产生通道转换结束中断请求。序列转换结束后 ADC\_ADSTA.EOSIF 标志被置位，ADC\_ADSTA.EOSIF 序列转换结束标志被置位，如果设置使能了序列转换结束中断，则产生序列转换结束中断请求。
- 所有 A/D 通道转换结束后，ADST 位硬件自动清 0，A/D 转换器进入空闲状态。
- 若在 A/D 转换过程中，软件更新 ADC\_ANY\_CFG、ADC\_CHANY0、ADC\_CHANY1 寄存器后，这些配置不会立即生效，等待所有通道转换结束后生效。软件置位 ADC\_ADCR.ADST 开启下一

次转换。



图 9-9 单周期扫描下通道转换时序图

### 9.6.2.3 连续扫描模式

配置 ADC\_ADCR.ADMODE 为连续转换，在连续扫描模式下，A/D 转换通道按照软件配置一直执行，直到软件禁止。具体流程如下：

- 软件配置寄存器 ADC\_ANY\_CFG、ADC\_CHANY0、ADC\_CHANY1，将需要转换的通道和数量配置结束后置位 ADC\_ANY\_CR.CHANY\_MDEN。
- 通过触发或软件置位 ADC\_ADCR.ADST，触发事件可配置触发延时。A/D 转换通道数量由 ADC\_ANY\_CFG.CHANY\_NUM 配置，每次转换的输入通道可以由寄存器位 CHANY\_SEL0 到 CHANY\_SEL15 任意配置，可以完全相同或不同。
- 通道输出按照转换通道配置有序输出。
- 各通道的 A/D 转换结束后，A/D 转换结果 SAR\_DATA 将有序装载到相应通道的数据寄存器 ADC\_ADDATA 和 ADC\_ADDRn 中，当前通道转换结束后 ADC\_ADSTA\_EXT.EOCIF 标志被置位，如果设置转换结束中断，则产生通道转换结束中断请求。序列转换结束后 ADC\_ADSTA.EOSIF 标志被置位，如果设置使能了序列转换结束中断，则产生序列转换结束中断请求。
- 只要 ADC\_ADCR.ADST 位保持为 1，就可以持续进行 A/D 转换。当 ADC\_ADCR.ADST 位被软件清除，当前 A/D 转换结束后停止，A/D 转换器进入空闲状态。
- 若在 A/D 转换过程中，用户更新 ADC\_ANY\_CFG、ADC\_CHANY0、ADC\_CHANY1 寄存器后，这些配置不会立即生效，等待所有通道转换结束后生效，即下一个扫描周期开始新的通道转换。



图 9-10 连续扫描模式下通道转换时序图



图 9-11 连续扫描模式下动态更新配置时序图

### 9.6.3 注入通道转换

#### 9.6.3.1 自动注入通道转换

在配置任意通道转换后，如果使能了自动注入通道转换，任意通道转换结束后，自动进入注入通道的转换。如果任意通道是连续扫描模式，需要清除 ADC\_ADCR.ADST 才能停止 A/D 转换。

- 软件配置寄存器 ADC\_ANY\_CFG、ADC\_CHANY0、ADC\_CHANY1、ADC\_JSQR，置位 ADC\_ANY\_CFG.JAUTO，将需要转换的通道和数量配置结束后置位 ADC\_ANY\_CR.JCEN、ADC\_ANY\_CR.CHANY\_MDEN。
- 通过触发或软件置位 ADC\_ADCR.ADST，触发事件可配置触发延时，A/D 转换任意通道数量由 ADC\_ANY\_CFG.CHANY\_NUM 配置，每次转换的输入通道可以由寄存器位 CHANY\_SEL0 到 CHANY\_SEL15 任意配置。任意通道转换结束后开始进行注入通道转换，转换通道数量由 JCHANY\_NUM 配置，每次转换的输入通道可以由寄存器位 JSQ0 到 JSQ3 配置。

- 通道输出按照转换通道配置有序输出。
- 各通道的 A/D 转换结束后，A/D 转换结果 SAR\_DATA 将有序装载到相应通道的数据寄存器 ADC\_ADDATA 和 ADC\_ADDRn、ADC\_JDATA 和 ADC\_JDrn 中，当前通道转换结束后 ADC\_ADSTA\_EXT.EOCIF 和 ADC\_ADSTA\_EXT.JEOCIF 转换结束标志被置位，如果设置使能了转换结束中断，则产生通道转换结束中断请求。连续转换结束后 ADC\_ADSTA.EOSIF 和 ADC\_ADSTA\_EXT.JEOSIF 标志被置位，如果设置使能了序列转换结束中断，产生序列转换结束中断请求。
- 如果是非连续扫描模式，ADC\_ADCR.ADST 在转换结束后被硬件自动清除。连续模式下只要 ADC\_ADCR.ADST 位保持为 1，就可以持续进行 A/D 转换。当 ADC\_ADCR.ADST 位被清除，当前 A/D 转换结束后停止，A/D 转换器进入空闲状态。



#### 9.6.4 ADC 触发信号

除了软件触发，ADC 转换的触发源还包括定时器和外部事件。

在触发信号产生后，延时 N（可配）个 PCLK 的时钟周期再开始采样。如果是触发扫描模式，只有第一个通道采样被延时，其余通道采样是在上一个通道转换结束后就立即开始。

通过设置 ADC\_ADCR.TRGEN 位可以使用外部事件触发非注入通道转换。

通过设置 ADC\_ADCR.TRGSEL 位可以选择非注入通道转换外部触发源。

具体的外部触发源选择情况，可以参考 A/D 控制寄存器 ADC\_ADCR.TRGSEL 位的描述。外部触发可设置延时控制，具体参考 AD 控制寄存器 ADC\_ADCR.TRGSHIFT 相关位的描述。

#### 9.6.5 模拟看门狗

看门狗比较发生在数据对齐操作前。看门狗比较器提供了上限和下限两个比较寄存器。可配置寄存器位 ADC\_ADCR.CMPCH 位选择监控通道。当 ADC\_ADCMPR.CPMHDATA 大于或等于 ADC\_ADCMPR.CPMLDATA 时，若使能 ADC\_ADCFG.AWDEN 非注入通道转换模拟看门狗使能且非注入通道结果大于或等于 ADC\_ADCMPR.CMPHDATA 值或者小于 ADC\_ADCMPR.CMPLDATA 值，状态寄存器 ADC\_ADSTA.AWDIF 位置 1，使能 ADC\_ADCFG.JAWDEN 注入通道转换模拟看门狗使能且注入通道结果大于或等于 ADC\_ADCMPR.CMPHDATA 值或者小于 ADC\_ADCMPR.CMPLDATA 值，状态寄存器 ADC\_ADSTA.AWDIF 位也会置 1。

当 ADC\_ADCMPR.CPMHDATA 小于 ADC\_ADCMPR.CPMLDATA 时，若使能 ADC\_ADCFG.AWDEN 非注入通道转换模拟看门狗使能且非注入通道结果等于 ADC\_ADCMPR.CPMHDATA 值或者处于两个指定值之间，则状态寄存器 ADC\_ADSTA.AWDIF 位会置 1。若使能 ADC\_ADCFG.JAWDEN 注入通道转换模拟看门狗使能且注入通道结果等于 ADC\_ADCMPR.CPMHDATA 值或者处于两个指定值之间，则状态寄存器 ADC\_ADSTA.AWDIF 位也会置 1。

如果控制寄存器 ADC\_ADCR.AWDIE 被置位，将产生中断请求。

#### 9.6.6 内部电压传感器

ADC 的内部信号源通道连接了一个 1.2V 内部基准参考电压 Vref，此通道把 1.2V 的参考电压输出转换为数字值，通过计算获得内部参考电压值。

例如：12bitADC 的电压 VDD 为 3.3V, V\_SENSOR 通道转换值为 ADC\_ADDR(VSensor)计算公式如下：

$$3.3/4096 = Vref / ADC\_ADDR(VSensor)$$

$$Vref = (ADC\_ADDR * 3.3) / 4096$$

内部参考电压在出厂时会被校准，得到的校准值存放在 flash 空间 0xFFFF7E0，用户可以根据该校准值反向推出当前系统模拟参考电压值，计算公式如下：

$$V_{ref\_calc} / ADC\_ADDR(VSensor) = VDDA / 4096$$

$$VDDA = ( V_{ref\_calc} * 4096 ) / ADC\_ADDR(VSensor)$$

$V_{ref\_calc}$ ：内部参考电压出厂校准值，单位 mv

内部参考电压有单独的使能位，可通过设置寄存器 ADC\_ADCFG.VSEN 位开启或关闭。

## 9.7 寄存器

### 9.7.1 寄存器总览

表 9-3 寄存器概览

| Offset    | Acronym       | Register Name     | Reset      |
|-----------|---------------|-------------------|------------|
| 0x00      | ADC_ADDATA    | A/D 数据寄存器         | 0x00000000 |
| 0x04      | ADC_ADCFG     | A/D 配置寄存器         | 0x00000000 |
| 0x08      | ADC_ADCR      | A/D 控制寄存器         | 0x00000000 |
| 0x0C      | ADC_ADCHS     | A/D 通道选择寄存器       | 0x00000000 |
| 0x10      | ADC_ADCMPR    | A/D 模拟看门狗比较寄存器    | 0x00000000 |
| 0x14      | ADC_ADSTA     | A/D 状态寄存器         | 0x00000000 |
| 0x18~0x38 | ADC_ADDR 0~8  | A/D 通道数据寄存器       | 0x00000000 |
| 0x58      | ADC_ADSTA_EXT | A/D 扩展状态寄存器       | 0x00000000 |
| 0x5C      | ADC_CHANY0    | A/D 任意通道通道选择寄存器 0 | 0x00000000 |
| 0x60      | ADC_CHANY1    | A/D 任意通道通道选择寄存器 1 | 0x00000000 |
| 0x64      | ADC_ANY_CFG   | A/D 任意通道配置寄存器     | 0x00000000 |
| 0x68      | ADC_ANY_CR    | A/D 任意通道控制寄存器     | 0x00000000 |
| 0x70      | ADC_SMPR1     | A/D 采样配置寄存器 1     | 0x00000000 |
| 0x74      | ADC_SMPR2     | A/D 采样配置寄存器 2     | 0x00000000 |
| 0x7C~0x88 | ADC_JOFR0~3   | A/D 注入通道数据补偿寄存器   | 0x00000000 |
| 0x8C      | ADC_JSQR      | A/D 注入通道序列寄存器     | 0x00000000 |
| 0x90      | ADC_JADDATA   | A/D 注入数据寄存器       | 0x00000000 |
| 0xB0~0xBC | ADC_JDR0~3    | A/D 注入通道数据寄存器     | 0x00000000 |

### 9.7.2 ADC\_ADDATA 数据寄存器

偏移地址: 0x00

复位值: 0x00000000

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

| Res. |    |    |    |    |    |   |   |   |   |   |   | VALID | OVERR<br>UN | CHANNELSEL |   |   |   |  |  |  |  |
|------|----|----|----|----|----|---|---|---|---|---|---|-------|-------------|------------|---|---|---|--|--|--|--|
|      |    |    |    |    |    |   |   |   |   |   |   |       |             | r          | r | r |   |  |  |  |  |
| 15   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3     | 2           | 1          | 0 |   |   |  |  |  |  |
| DATA |    |    |    |    |    |   |   |   |   |   |   |       |             |            |   |   | r |  |  |  |  |
|      |    |    |    |    |    |   |   |   |   |   |   |       |             |            |   |   |   |  |  |  |  |

| Bit   | Field      | Description                                                                                                                                                                                                                                                                                                                                    |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22 | Reserved   | 保留，必须保持复位值。                                                                                                                                                                                                                                                                                                                                    |
| 21    | VALID      | 数据有效标志位（只读）(Valid Flag)<br>1: DATA[11:0] 位数据有效<br>0: DATA[11:0] 位数据无效<br>通道转换完成后硬件置位，读 ADC_ADDATA 寄存器后该位自动清除。                                                                                                                                                                                                                                  |
| 20    | OVERRUN    | 数据覆盖标志位（只读）(Overrun Flag)<br>1: DATA[11:0] 上一次转换数据被覆盖<br>0: DATA[11:0] 上一次转换数据未被覆盖<br>若数据装载至 DATA[11:0] 数据寄存器位之前，若上一次 DATA[11:0] 没有被读取，则 OVERRUN 将置位，读 ADC_ADDATA 寄存器后该位自动清除。                                                                                                                                                                  |
| 19:16 | CHANNELSEL | 该 4 位显示当前数据寄存器中的数据所对应的通道 (Channel Selection)<br>0000 : 表示当前数据寄存器所属通道为通道 0<br>0001 : 表示当前数据寄存器所属通道为通道 1<br>0010 : 表示当前数据寄存器所属通道为通道 2<br>0011 : 表示当前数据寄存器所属通道为通道 3<br>0100 : 表示当前数据寄存器所属通道为通道 4<br>0101 : 表示当前数据寄存器所属通道为通道 5<br>0110 : 表示当前数据寄存器所属通道为通道 6<br>0111 : 表示当前数据寄存器所属通道为通道 7<br>1000 : 表示当前数据寄存器所属通道为通道 8 (对应数据为内部参考电压的转换数据)<br>其他: 无效 |
| 15:0  | DATA       | 12 位 A/D 当前通道转换结果 (Conversion Data)<br>软件选择对齐方式。                                                                                                                                                                                                                                                                                               |

### 9.7.3 ADC\_ADCFG 配置寄存器

偏移地址: 0x04

复位值: 0x00000000

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

|      |       |      |         |         |      |      |       |      |
|------|-------|------|---------|---------|------|------|-------|------|
| Res. | ADCPR | Res. | RSLTCTL | ADCPREH | VSEN | Res. | AWDEN | ADEN |
|      | EL    |      | rw      | rw      | rw   |      | rw    | rw   |

| Bit    | Field    | Description                                                                                                                  |
|--------|----------|------------------------------------------------------------------------------------------------------------------------------|
| 31:17  | Reserved | 保留，必须保持复位值。                                                                                                                  |
| 16     | JAWDEN   | A/D 注入通道转换结果狗使能(Analog Watchdog Enable for Injected Channels)<br>1: 注入通道 A/D 模拟看门狗使能<br>0: 注入通道 A/D 模拟看门狗禁止                  |
| 15     | Reserved | 保留，必须保持复位值                                                                                                                   |
| 14     | ADCPREL  | ADC 时钟预分频低位 (ADC Prescaler Low Bits)<br>预分频系数 ADCPRE={ADCPREH, ADCPREL}                                                      |
| 13: 10 | Reserved | 保留，必须保持复位值                                                                                                                   |
| 9: 7   | RSLTCTL  | ADC 转换数据分辨率选择 (Data Resolution Selection)<br>000: 12 位有效<br>001: 11 位有效<br>010: 10 位有效<br>011: 9 位有效<br>100: 8 位有效<br>其它: 保留 |
| 6: 4   | ADCPREH  | ADC 时钟预分频高位 (ADC Prescaler High Bits)<br>预分频系数 ADCPRE={ADCPREH, ADCPREL}<br>ADC 时钟分频: div= (ADCPRE+2)                        |
| 3      | VSEN     | 内部参考电压使能 (Voltage Sensor Enable)<br>1: 内部电压传感器使能<br>0: 内部电压传感器禁止                                                             |
| 2      | Reserved | 保留，必须保持复位值                                                                                                                   |
| 1      | AWDEN    | 非注入通道转换结果模拟看门狗使能 (Analog Watchdog Enable )<br>1: 非注入通道转换结果模拟看门狗使能<br>0: 非注入通道转换结果模拟看门狗禁止                                     |
| 0      | ADEN     | A/D 转换使能 (ADC Enable)<br>1: 使能<br>0: 禁止                                                                                      |

#### 9.7.4 ADC\_ADCR 控制寄存器

偏移地址: 0x08

复位值: 0x00000000

|      |    |    |       |        |          |    |      |          |    |    |         |    |        |    |    |
|------|----|----|-------|--------|----------|----|------|----------|----|----|---------|----|--------|----|----|
| 31   | 30 | 29 | 28    | 27     | 26       | 25 | 24   | 23       | 22 | 21 | 20      | 19 | 18     | 17 | 16 |
| Res. |    |    | EOCIE | EOSMPI | TRG_EDGE |    | Res. | TRGSHIFT |    |    | TRGSELH |    | SCANDI | R  |    |
|      |    |    | rw    | rw     | rw       |    |      | rw       |    |    | rw      |    |        |    |    |

|       |    |    |    |       |      |   |      |      |         |   |   |      |       |       |       |
|-------|----|----|----|-------|------|---|------|------|---------|---|---|------|-------|-------|-------|
| 15    | 14 | 13 | 12 | 11    | 10   | 9 | 8    | 7    | 6       | 5 | 4 | 3    | 2     | 1     | 0     |
| CMPCH |    |    |    | ALIGN | ADMD |   | ADST | Res. | TRGSELL |   |   | Res. | TRGEN | AWDIE | EOSIE |
| rw    |    |    |    | rw    | rw   |   | rw   |      | rw      |   |   |      | rw    | rw    | rw    |

| Bit     | Field    | Description                                                                                                                                                                                                                                                    |
|---------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28   | Reserved | 保留，必须保持复位值                                                                                                                                                                                                                                                     |
| 27      | EOCIE    | A/D 通道转换结束中断使能 (Interrupt Enable for End of Conversion)<br>1: 使能 A/D 单次转换结束中断<br>0: 禁止 A/D 单次转换结束中断<br>如果 EOCIF 置位，A/D 转换结束后产生中断请求。                                                                                                                            |
| 26      | EOSMPIE  | A/D 通道采样结束中断使能 (Interrupt Enable for End of Sample)<br>1: 使能 A/D 采样结束中断<br>0: 禁止 A/D 采样结束中断<br>若 EOSMPIF 置位，则在 A/D 采样结束后产生中断请求。                                                                                                                                |
| 25 : 24 | TRG_EDGE | 触发源边沿选择(Trigger Sources Edge Selection)<br>00: 双沿触发<br>01: 下沿触发<br>10: 上沿触发<br>11: 保留                                                                                                                                                                          |
| 23:22   | Reserved | 保留，必须保持复位值。                                                                                                                                                                                                                                                    |
| 21 : 19 | TRGSHIFT | 外部触发源采样延时 (External Trigger Sources Shift For Sample)<br>在触发产生后，延时 N 个 PCLK 的时钟周期再开始采样 (N=1, 2, 3...)<br>000: 不延时<br>001: 4 个周期<br>010: 16 个周期<br>011: 32 个周期<br>100: 64 个周期<br>101: 128 个周期<br>110: 256 个周期<br>111: 512 个周期<br>如果是触发扫描，则其它通道采样是在上一个转换结束后立即开始。 |
| 18 :17  | TRGSELH  | 外部触发源选择高位 (External Trigger Sources Select For High Bits)<br>TRGSEL={TRGSELH,TRGSELL}                                                                                                                                                                          |
| 16      | SCANDIR  | ADC 通道扫描方向 (ADC Scan Direction)<br>仅在普通通道转换有效<br>1: ADC 通道选择寄存器按从高到低的顺序扫描<br>0: ADC 通道选择寄存器按从低到高的顺序扫描                                                                                                                                                          |

| Bit     | Field    | Description                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15 : 12 | CMPCH    | <p>模拟看门狗通道选择 (Compare Channel Selection For Analog Watchdog)</p> <p>0000 : 选择通道 0 转换结果作为比较对象</p> <p>0001 : 选择通道 1 转换结果作为比较对象</p> <p>0010 : 选择通道 2 转换结果作为比较对象</p> <p>0011 : 选择通道 3 转换结果作为比较对象</p> <p>0100 : 选择通道 4 转换结果作为比较对象</p> <p>0101 : 选择通道 5 转换结果作为比较对象</p> <p>0110 : 选择通道 6 转换结果作为比较对象</p> <p>0111 : 选择通道 7 转换结果作为比较对象</p> <p>1000 : 选择通道 8 转换结果作为比较对象 (即选择比较内部电压传感器的转换结果为比较对象)</p> <p>1111 : 选择所有扫描通道转换结果为比较对象</p> <p>其他: 无效</p> |
| 11      | ALIGN    | <p>数据对齐格式 (Data Alignment)</p> <p>1: 左对齐</p> <p>0: 右对齐</p>                                                                                                                                                                                                                                                                                                                                                                              |
| 10 : 9  | ADMD     | <p>A/D 转换模式 (ADC Mode)</p> <p>00: 单次转换</p> <p>01: 单周期扫描</p> <p>10: 连续扫描</p> <p>11: 保留</p> <p>当改变转换模式时, 软件要先清除 ADST 位。</p>                                                                                                                                                                                                                                                                                                               |
| 8       | ADST     | <p>A/D 转换开始 (ADC Start)</p> <p>1: 转换开始</p> <p>0: 转换结束或空闲状态</p> <p>ADST 清除有下列两种方式:</p> <p>在单次模式或者单周期模式下, 转换完成后 ADST 将硬件自动清除。</p> <p>在连续扫描模式下, ADST 由软件或系统复位清除, 否则 A/D 转换将一直进行。</p>                                                                                                                                                                                                                                                       |
| 7       | Reserved | 保留, 必须保持复位值。                                                                                                                                                                                                                                                                                                                                                                                                                            |

| Bit  | Field    | Description                                                                                                                                                                                                                                                                                                                            |
|------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6: 4 | TRGSELL  | 外部触发源选择低位 (External Trigger sources Select for Low bits)<br>TRGSEL={TRGSELH,TRGSELL}<br>ADC 选择外部触发源 TRGSEL:<br>00000: TIM1_CC1<br>00001: TIM1_CC2<br>00010: TIM1_CC3<br>00100: TIM3_TRGO<br>00110: TIM3_CC1<br>00111: EXTI 11<br>01000: TIM1_TRGO<br>01100: TIM3_CC4<br>01111: EXTI 15<br>10000: TIM1_CC4<br>10001: TIM1_CC5<br>其它: 无效 |
| 3    | Reserved | 保留, 必须保持复位值。                                                                                                                                                                                                                                                                                                                           |
| 2    | TRGEN    | 外部硬件触发源使能 (External Trigger Sources Enable)<br>1: 使用外部触发信号启动 A/D 转换<br>0: 禁止外部触发信号启动 A/D 转换                                                                                                                                                                                                                                            |
| 1    | AWDIE    | A/D 模拟看门狗中断使能 (Interrupt Enable of Analog Watchdog)<br>1: 使能 A/D 模拟看门狗中断<br>0: 禁止 A/D 模拟看门狗中断                                                                                                                                                                                                                                          |
| 0    | EOSIE    | A/D 非注入通道转换的通道序列转换结束中断使能 (Interrupt Enable for End of Sequence)<br>1: 使能 A/D 中断<br>0: 禁止 A/D 中断<br>如果 EOSIF 置位, A/D 转换结束后会产生中断请求。                                                                                                                                                                                                      |

### 9.7.5 ADC\_ADCHS 通道选择寄存器

偏移地址: 0x0C

复位值: 0x00000000

|      |    |    |    |    |    |    |       |       |       |       |       |       |       |       |       |
|------|----|----|----|----|----|----|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| 31   | 30 | 29 | 28 | 27 | 26 | 25 | 24    | 23    | 22    | 21    | 20    | 19    | 18    | 17    | 16    |
| Res. |    |    |    |    |    |    |       |       |       |       |       |       |       |       |       |
| 15   | 14 | 13 | 12 | 11 | 10 | 9  | 8     | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
| Res. |    |    |    |    |    |    | CHEN8 | CHEN7 | CHEN6 | CHEN5 | CHEN4 | CHEN3 | CHEN2 | CHEN1 | CHEN0 |
|      |    |    |    |    |    |    | rw    |

| Bit  | Field    | Description |
|------|----------|-------------|
| 31:9 | Reserved | 保留, 必须保持复位值 |

| Bit | Field | Description                                                   |
|-----|-------|---------------------------------------------------------------|
| 8   | CHEN8 | ADC: 内部参考电压使能 (Voltage Sensor Enable)<br>1: 使能<br>0: 禁止       |
| 7   | CHEN7 | 模拟输入通道 7 使能 (Analog Input Channel 7 Enable)<br>1: 使能<br>0: 禁止 |
| 6   | CHEN6 | 模拟输入通道 6 使能 (Analog Input Channel 6 Enable)<br>1: 使能<br>0: 禁止 |
| 5   | CHEN5 | 模拟输入通道 5 使能 (Analog Input Channel 5 Enable)<br>1: 使能<br>0: 禁止 |
| 4   | CHEN4 | 模拟输入通道 4 使能 (Analog Input Channel 4 Enable)<br>1: 使能<br>0: 禁止 |
| 3   | CHEN3 | 模拟输入通道 3 使能 (Analog Input Channel 3 Enable)<br>1: 使能<br>0: 禁止 |
| 2   | CHEN2 | 模拟输入通道 2 使能 (Analog Input Channel 2 Enable)<br>1: 使能<br>0: 禁止 |
| 1   | CHEN1 | 模拟输入通道 1 使能 (Analog Input Channel 1 Enable)<br>1: 使能<br>0: 禁止 |
| 0   | CHENO | 模拟输入通道 0 使能 (Analog Input Channel 0 Enable)<br>1: 使能<br>0: 禁止 |

注： 1) 如果通道使能都关闭，则开启转换时根据 SCANDIR 设置， 默认转换通道为 0 或 0xF。  
 2) 在 ADC\_ADSTA.BUSY 无效时才能操作此寄存器。

### 9.7.6 ADC\_ADCMPR 模拟看门狗比较寄存器

偏移地址: 0x10

复位值: 0x00000000

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

|  |    |
|--|----|
|  | RW |
|--|----|

| Bit    | Field    | Description                                                                  |
|--------|----------|------------------------------------------------------------------------------|
| 31:28  | Reserved | 保留，必须保持复位值                                                                   |
| 27: 16 | CMPHDATA | 模拟看门狗比较数值高阈值 (Compare High Threshold Data For Analog Watchdog)<br>看门狗比较阈值的高限 |
| 15:12  | Reserved | 保留，必须保持复位值。                                                                  |
| 11 : 0 | CMPLDATA | 模拟看门狗比较数值低阈值 (Compare Low Threshold Data For Analog Watchdog)<br>看门狗比较阈值的低限  |

### 9.7.7 ADC\_ADSTA 状态寄存器

偏移地址: 0x14

复位值: 0x00000000

|       |         |    |    |    |    |    |    |         |    |    |      |       |    |    |    |
|-------|---------|----|----|----|----|----|----|---------|----|----|------|-------|----|----|----|
| 31    | 30      | 29 | 28 | 27 | 26 | 25 | 24 | 23      | 22 | 21 | 20   | 19    | 18 | 17 | 16 |
| Res.  | OVERRUN |    |    |    |    |    |    |         |    |    | Res. | VALID |    | r  |    |
|       | r       |    |    |    |    |    |    |         |    |    |      | Res.  |    |    |    |
| 15    | 14      | 13 | 12 | 11 | 10 | 9  | 8  | 7       | 6  | 5  | 4    | 3     | 2  | 1  | 0  |
| VALID |         |    |    |    |    |    |    | CHANNEL |    |    |      |       |    |    |    |
| r     |         |    |    |    |    |    |    | r       |    |    |      |       |    |    |    |
| Res.  |         |    |    |    |    |    |    | rc_w1   |    |    |      |       |    |    |    |

| Bit   | Field    | Description                                                                     |
|-------|----------|---------------------------------------------------------------------------------|
| 31:29 | Reserved | 保留，必须保持复位值                                                                      |
| 28:20 | OVERRUN  | 通道 0~8 的数据覆盖标志位 (Overrun Flag)                                                  |
| 19:17 | Reserved | 保留，必须保持复位值                                                                      |
| 16:8  | VALID    | 通道 0~8 的数据有效标志位 (Valid Flag)                                                    |
| 7:4   | CHANNEL  | 当前转换通道 (Current Convert Channel)<br>注: BUSY=1 时表示当前转换中的通道; BUSY=0 时表示即将转换的通道。   |
| 3     | Reserved | 保留，必须保持复位值                                                                      |
| 2     | BUSY     | 非注入通道转换忙/空闲 (Busy)<br>1=A/D 转换器忙碌<br>0=A/D 转换器空                                 |
| 1     | AWDIF    | 模拟看门狗标志位 (Analog Watchdog Flag)<br>该标志位写“1”清零。<br>1: 模拟看门狗事件发生<br>0: 模拟看门狗事件未发生 |

| Bit | Field | Description                                                                                                                   |
|-----|-------|-------------------------------------------------------------------------------------------------------------------------------|
| 0   | EOSIF | A/D 通道序列转换结束标志位 (End of Sequential Conversion Flag)<br>该位由硬件在通道序列转换结束时置位，由软件清除。<br>1: A/D 转换结束<br>0: A/D 转换未结束<br>该标志位写“1”清零。 |

### 9.7.8 ADC\_ADDRn 通道数据寄存器(n=0~8)

偏移地址: 0x18~0x38

复位值: 0x00000000

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

| Bit     | Field    | Description                                                                                                                                                        |
|---------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22   | Reserved | 保留，必须保持复位值。                                                                                                                                                        |
| 21      | VALID    | 有效标志位 (只读) (Valid Flag)<br>1: DATA[11:0]位数据有效<br>0: DATA[11:0]位数据无效<br>对应通道转换完成后硬件置位，读 ADC_ADDRn 寄存器自动清除。                                                          |
| 20      | OVERRUN  | 数据覆盖标志位 (只读) (Overrun Flag)<br>1: DATA[11:0]数据被覆盖<br>0: DATA[11:0]数据最近一次转换结果<br>若在装载至 DATA[11:0] 数据寄存器之前，上一次 DATA[11:0] 数据没有被读取，OVERRUN 将置位。读 ADC_ADDRn 寄存器硬件自动清除。 |
| 19 : 16 | Reserved | 保留，必须保持复位值。                                                                                                                                                        |
| 15 : 0  | DATA     | 通道 n 的 12 位 A/D 转换结果 (Covert Data)<br>软件选择对齐方式。                                                                                                                    |

### 9.7.9 ADC\_ADSTA\_EXT 扩展状态寄存器

偏移地址: 0x58

复位值: 0x00000000

|      |    |    |    |    |    |    |    |    |    |       |        |        |              |       |             |
|------|----|----|----|----|----|----|----|----|----|-------|--------|--------|--------------|-------|-------------|
| 31   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21    | 20     | 19     | 18           | 17    | 16          |
| Res. |    |    |    |    |    |    |    |    |    | JBUSY | JEOSIF | JEOCIF | JEOSM<br>PIF | EOCIF | EOSMPI<br>F |
| 15   | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | r     | rc_w1  | rc_w1  | rc_w1        | rc_w1 | rc_w1       |

Res.

| Bit   | Field    | Description                                                                                                                                         |
|-------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22 | Reserved | 保留, 必须保持复位值。                                                                                                                                        |
| 21    | JBUSY    | <p>注入通道转换忙/空闲 (Busy/Idle Flag)</p> <p>1: A/D 转换器注入通道忙碌</p> <p>0: A/D 转换器注入通道空闲</p>                                                                  |
| 20    | JEOSIF   | <p>A/D 注入通道序列转换结束标志位 (End of Injected Sequence Flag)</p> <p>该位由硬件在通道序列转换结束时置位, 由软件清除。</p> <p>1: A/D 转换结束</p> <p>0: A/D 转换未结束</p> <p>该标志位写“1”清零。</p> |
| 19    | JEOCIF   | <p>A/D 注入通道转换结束标志位 (End of Injected Conversion Flag)</p> <p>该位由硬件在通道转换结束时置位, 由软件清除。</p> <p>1: A/D 转换结束</p> <p>0: A/D 转换未结束</p> <p>该标志位写“1”清零。</p>   |
| 18    | JEOSMPIF | <p>A/D 注入通道采样结束标志位 (End of Injected Sample Flag)</p> <p>该位由硬件在通道采样结束时置位, 由软件清除。</p> <p>1: A/D 采样结束</p> <p>0: A/D 采样未结束</p> <p>该标志位写“1”清零。</p>       |
| 17    | EOCIF    | <p>A/D 转换结束标志位 (End of Conversion Flag)</p> <p>该位由硬件在通道转换结束时置位, 由软件清除。</p> <p>1: A/D 转换结束</p> <p>0: A/D 转换未结束</p> <p>该标志位写“1”清零。</p>                |
| 16    | EOSMPIF  | <p>A/D 采样结束标志位 (End of Sample Flag)</p> <p>该位由硬件在通道采样结束时置位, 由软件清除。</p> <p>1: A/D 采样转换结束</p> <p>0: A/D 采样未结束</p> <p>该标志位写“1”清零。</p>                  |
| 15:0  | Reserved | 保留, 必须保持复位值。                                                                                                                                        |

### 9.7.10 ADC\_CHANY0 任意通道的通道选择寄存器 0

偏移地址: 0x5C

复位值: 0x00000000

|            |    |    |    |            |    |    |    |            |    |    |    |            |    |    |    |
|------------|----|----|----|------------|----|----|----|------------|----|----|----|------------|----|----|----|
| 31         | 30 | 29 | 28 | 27         | 26 | 25 | 24 | 23         | 22 | 21 | 20 | 19         | 18 | 17 | 16 |
| CHANY_SEL7 |    |    |    | CHANY_SEL6 |    |    |    | CHANY_SEL5 |    |    |    | CHANY_SEL4 |    |    |    |
| rw         |    |    |    | rw         |    |    |    | rw         |    |    |    | rw         |    |    |    |
| 15         | 14 | 13 | 12 | 11         | 10 | 9  | 8  | 7          | 6  | 5  | 4  | 3          | 2  | 1  | 0  |
| CHANY_SEL3 |    |    |    | CHANY_SEL2 |    |    |    | CHANY_SEL1 |    |    |    | CHANY_SEL0 |    |    |    |
| rw         |    |    |    | rw         |    |    |    | rw         |    |    |    | rw         |    |    |    |

| Bit   | Field      | Description                                                                                                          |
|-------|------------|----------------------------------------------------------------------------------------------------------------------|
| 31:28 | CHANY_SEL7 | 任意通道转换序列第 7 次转换选择 (7th Conversion Select for Any Channel sequence )<br>0000~1000: 可配置为通道 0~通道 8 中的任意一个通道为任意通道转换的输入通道 |
| 27:24 | CHANY_SEL6 | 任意通道转换序列第 6 次转换选择 (6th Conversion Select for Any Channel sequence )<br>0000~1000: 可配置为通道 0~通道 8 中的任意一个通道为任意通道转换的输入通道 |
| 23:20 | CHANY_SEL5 | 任意通道转换序列第 5 次转换选择 (5th Conversion Select for Any Channel sequence )<br>0000~1000: 可配置为通道 0~通道 8 中的任意一个通道为任意通道转换的输入通道 |
| 19:16 | CHANY_SEL4 | 任意通道转换序列第 4 次转换选择 (4th Conversion Select for Any Channel sequence )<br>0000~1000: 可配置为通道 0~通道 8 中的任意一个通道为任意通道转换的输入通道 |
| 15:12 | CHANY_SEL3 | 任意通道转换序列第 3 次转换选择 (3th Conversion Select for Any Channel sequence )<br>0000~1000: 可配置为通道 0~通道 8 中的任意一个通道为任意通道转换的输入通道 |
| 11:8  | CHANY_SEL2 | 任意通道转换序列第 2 次转换选择 (2th Conversion Select for Any Channel sequence )<br>0000~1000: 可配置为通道 0~通道 8 中的任意一个通道为任意通道转换的输入通道 |
| 7:4   | CHANY_SEL1 | 任意通道转换序列第 1 次转换选择 (1th Conversion Select for Any Channel sequence )<br>0000~1000: 可配置为通道 0~通道 8 中的任意一个通道为任意通道转换的输入通道 |
| 3:0   | CHANY_SEL0 | 任意通道转换序列第 0 次转换选择 (0th Conversion Select for Any Channel sequence )<br>0000~1000: 可配置为通道 0~通道 8 中的任意一个通道为任意通道转换的输入通道 |

注：单周期扫描或连续扫描模式下，硬件会启动 ADC\_CHANY0 影子寄存器。在 ADC 工作期间，若更改 ADC\_CHANY0 的值，只会更新到其影子寄存器中，在 ADC 转换最后一个通道时，影子寄存器的值才会更新至 ADC\_CHANY0，实现通道动态切换。

### 9.7.11 ADC\_CHANY1 任意通道的通道选择寄存器 1

偏移地址: 0x60

复位值: 0x00000000

|             |    |    |    |             |    |    |    |             |    |    |    |             |    |    |    |
|-------------|----|----|----|-------------|----|----|----|-------------|----|----|----|-------------|----|----|----|
| 31          | 30 | 29 | 28 | 27          | 26 | 25 | 24 | 23          | 22 | 21 | 20 | 19          | 18 | 17 | 16 |
| CHANY_SEL15 |    |    |    | CHANY_SEL14 |    |    |    | CHANY_SEL13 |    |    |    | CHANY_SEL12 |    |    |    |
| rw          |    |    |    | rw          |    |    |    | rw          |    |    |    | rw          |    |    |    |
| 15          | 14 | 13 | 12 | 11          | 10 | 9  | 8  | 7           | 6  | 5  | 4  | 3           | 2  | 1  | 0  |
| CHANY_SEL11 |    |    |    | CHANY_SEL10 |    |    |    | CHANY_SEL9  |    |    |    | CHANY_SEL8  |    |    |    |
| rw          |    |    |    | rw          |    |    |    | rw          |    |    |    | rw          |    |    |    |

| Bit   | Field       | Description                                                                                                            |
|-------|-------------|------------------------------------------------------------------------------------------------------------------------|
| 31:28 | CHANY_SEL15 | 任意通道转换序列第 15 次转换选择 (15th Conversion Select for Any Channel sequence )<br>0000~1000: 可配置为通道 0~通道 8 中的任意一个通道为任意通道转换的输入通道 |
| 27:24 | CHANY_SEL14 | 任意通道转换序列第 14 次转换选择 (14th Conversion Select for Any Channel sequence )<br>0000~1000: 可配置为通道 0~通道 8 中的任意一个通道为任意通道转换的输入通道 |
| 23:20 | CHANY_SEL13 | 任意通道转换序列第 13 次转换选择 (13th Conversion Select for Any Channel sequence )<br>0000~1000: 可配置为通道 0~通道 8 中的任意一个通道为任意通道转换的输入通道 |
| 19:16 | CHANY_SEL12 | 任意通道转换序列第 12 次转换选择 (12th Conversion Select for Any Channel sequence )<br>0000~1000: 可配置为通道 0~通道 8 中的任意一个通道为任意通道转换的输入通道 |
| 15:12 | CHANY_SEL11 | 任意通道转换序列第 11 次转换选择 (11th Conversion Select for Any Channel sequence )<br>0000~1000: 可配置为通道 0~通道 8 中的任意一个通道为任意通道转换的输入通道 |
| 11:8  | CHANY_SEL10 | 任意通道转换序列第 10 次转换选择 (10th Conversion Select for Any Channel sequence )<br>0000~1000: 可配置为通道 0~通道 8 中的任意一个通道为任意通道转换的输入通道 |

| Bit | Field      | Description                                                                                                          |
|-----|------------|----------------------------------------------------------------------------------------------------------------------|
| 7:4 | CHANY_SEL9 | 任意通道转换序列第 9 次转换选择 (9th Conversion Select for Any Channel sequence )<br>0000~1000: 可配置为通道 0~通道 8 中的任意一个通道为任意通道转换的输入通道 |
| 3:0 | CHANY_SEL8 | 任意通道转换序列第 8 次转换选择 (8th Conversion Select for Any Channel sequence )<br>0000~1000: 可配置为通道 0~通道 8 中的任意一个通道为任意通道转换的输入通道 |

注：单周期扫描或连续扫描模式下，硬件会启动 ADC\_CHANY1 影子寄存器。在 ADC 工作期间，若更改 ADC\_CHANY1 的值，只会更新到其影子寄存器中，在 ADC 转换最后一个通道时，影子寄存器的值才会更新至 ADC\_CHANY1，实现通道动态切换。

### 9.7.12 ADC\_ANY\_CFG 任意通道配置寄存器

偏移地址: 0x64

复位值: 0x00000000

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

| Bit  | Field     | Description                                                                                                                                                                                                                                                                                                                                           |
|------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | Reserved  | 保留，必须保持复位值                                                                                                                                                                                                                                                                                                                                            |
| 3:0  | CHANY_NUM | 转换通道数配置(Number of Any Channel Mode):<br>0000: CHANY_SEL0 通道<br>0001: CHANY_SEL0~CHANY_SEL1 通道<br>0010: CHANY_SEL0~CHANY_SEL2 通道<br>0011: CHANY_SEL0~CHANY_SEL3 通道<br>0100: CHANY_SEL0~CHANY_SEL4 通道<br>0101: CHANY_SEL0~CHANY_SEL5 通道<br>0110: CHANY_SEL0~CHANY_SEL6 通道<br>0111: CHANY_SEL0~CHANY_SEL7 通道<br>1000: CHANY_SEL0~CHANY_SEL8 通道<br>其他: 无效 |

注：单周期扫描或连续扫描模式下，硬件会启动 ADC\_NUM 影子寄存器。在 ADC 工作期间，若更改 ADC\_NUM 的值，只会更新到其影子寄存器中，在 ADC 转换最后一个通道时，影子寄存器的值才会更新至 ADC\_NUM，实现通道动态切换。

### 9.7.13 ADC\_ANY\_CR 任意通道控制寄存器

偏移地址: 0x68

复位值: 0x00000000

|           |         |    |    |    |    |    |    |            |       |       |        |        |              |           |               |
|-----------|---------|----|----|----|----|----|----|------------|-------|-------|--------|--------|--------------|-----------|---------------|
| 31        | 30      | 29 | 28 | 27 | 26 | 25 | 24 | 23         | 22    | 21    | 20     | 19     | 18           | 17        | 16            |
| Res.      |         |    |    |    |    |    |    |            |       |       |        |        |              | JTRG_EDGE |               |
|           |         |    |    |    |    |    |    |            |       |       |        |        |              | rw        |               |
| 15        | 14      | 13 | 12 | 11 | 10 | 9  | 8  | 7          | 6     | 5     | 4      | 3      | 2            | 1         | 0             |
| JTRGSHIFT | JTRGSEL |    |    |    |    |    |    | JTRGE<br>N | JADST | JAUTO | JEOSIE | JEOCIE | JEOSM<br>PIE | JCEN      | CHANY<br>MDEN |
| rw        | rw      |    |    |    |    |    |    | rw         | rw    | rw    | rw     | rw     | rw           | rw        | rw            |

| Bit   | Field     | Description                                                                                                                                                                                                                                                        |
|-------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:18 | Reserved  | 保留, 必须保持复位值                                                                                                                                                                                                                                                        |
| 17:16 | JTRG_EDGE | 注入通道转换的外部触发源边沿选择(Trigger sources Edge Selection for Injected Channels)<br>00: 双沿触发<br>01: 下沿触发<br>10: 上沿触发<br>11: 屏蔽触发                                                                                                                                             |
| 15:13 | JTRGSHIFT | 注入通道转换的外部触发源延时采样 (External Trigger Shift Sample for Injected Channels)<br>在触发信号产生后, 延时 N 个 PCLK 的时钟周期再开始采样。<br>如果是触发扫描, 其它通道是在上一个采样结束后立即开始。<br>000: 不延时<br>001: 4 个周期<br>010: 16 个周期<br>011: 32 个周期<br>100: 64 个周期<br>101: 128 个周期<br>110: 256 个周期<br>111: 512 个周期 |

| Bit  | Field    | Description                                                                                                                                                                                                                                                                                             |
|------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12:8 | JTRGSEL  | ADC 注入通道转换的外部触发源选择 (External Trigger Sources Selection For Injected Channel)<br>00000: TIM1_CC1<br>00001: TIM1_CC2<br>00010: TIM1_CC3<br>00100: TIM3_TRGO<br>00110: TIM3_CC1<br>00111: EXTI 11<br>01000: TIM1_TRGO<br>01100: TIM3_CC4<br>01111: EXTI 15<br>10000: TIM1_CC4<br>10001: TIM1_CC5<br>其它: 无效 |
| 7    | JTRGEN   | 注入通道转换的外部硬件触发源使能 (External Trigger Enable For Injected Channels)<br>1: 使能外部触发信号启动 A/D 转换<br>0: 禁止外部触发信号启动 A/D 转换                                                                                                                                                                                        |
| 6    | JADST    | 注入通道转换的 A/D 转换开始 (ADC Start for Injected Channels): 先开启 JCEN<br>1: 注入通道转换开始<br>0: 注入通道转换结束或进入空闲状态<br>JADST 清除有下列两种方式:<br>在注入通道转换完成后, JADST 将被硬件自动清除;<br>JCEN 为 0 时 JADST 被清除; 系统复位时 JADST 被清除。                                                                                                          |
| 5    | JAUTO    | 自动注入转换 (Automatic Injected Conversion)<br>1: 开启自动注入转换<br>0: 关闭自动注入转换                                                                                                                                                                                                                                    |
| 4    | JEOSIE   | A/D 注入通道序列转换结束中断使能 (Interrupt Enable for JEoS)<br>1: 使能 A/D 序列转换结束中断<br>0: 禁止 A/D 序列转换结束中断<br>如果 JEOSIE 置位, 通道序列 A/D 转换结束后产生中断请求。                                                                                                                                                                       |
| 3    | JEOCIE   | A/D 注入通道转换结束中断使能 (Interrupt Enable for JEOC)<br>1: 使能 A/D 转换结束中断<br>0: 禁止 A/D 转换结束中断<br>如果 JEOCIF 置位, A/D 转换结束后产生中断请求。                                                                                                                                                                                  |
| 2    | JEOSMPIE | A/D 注入通道采样结束中断使能 (Interrupt Enable for JEoSAMP)<br>1: 使能 A/D 采样结束中断<br>0: 禁止 A/D 采样结束中断<br>如果 JEOSMPIF 置位, A/D 转换结束后产生中断请求。                                                                                                                                                                             |
| 1    | JCEN     | A/D 注入通道转换使能 (Conversion Enable for Injected Channels)<br>1: 使能注入转换<br>0: 禁止注入转换                                                                                                                                                                                                                        |

| Bit | Field      | Description                                                       |
|-----|------------|-------------------------------------------------------------------|
| 0   | CHANY_MDEN | 任意通道转换使能位(Any Channel Mode Enable):<br>1: 使能任意通道转换<br>0: 禁止任意通道转换 |

注：任意通道转换的单周期或连续扫描模式时，关闭 ADC 必须先等待 ADC\_ADCR.ADST 和 ADC\_ADESTA.BUSY 为 0，再清除 ADC\_ANY\_CR.CHANY\_MDEN 位。

### 9.7.14 ADC\_SMPR1 采样配置寄存器 1

偏移地址: 0x70

复位值: 0x00000000

|       |    |    |    |       |    |    |    |       |    |    |    |       |    |    |    |
|-------|----|----|----|-------|----|----|----|-------|----|----|----|-------|----|----|----|
| 31    | 30 | 29 | 28 | 27    | 26 | 25 | 24 | 23    | 22 | 21 | 20 | 19    | 18 | 17 | 16 |
| SAMP7 |    |    |    | SAMP6 |    |    |    | SAMP5 |    |    |    | SAMP4 |    |    |    |
| rw    |    |    |    | rw    |    |    |    | rw    |    |    |    | rw    |    |    |    |
| 15    | 14 | 13 | 12 | 11    | 10 | 9  | 8  | 7     | 6  | 5  | 4  | 3     | 2  | 1  | 0  |
| SAMP3 |    |    |    | SAMP2 |    |    |    | SAMP1 |    |    |    | SAMP0 |    |    |    |
| rw    |    |    |    | rw    |    |    |    | rw    |    |    |    | rw    |    |    |    |

| Bit    | Field       | Description                                                                                                                                                                                                                                                                                                                 |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 : 0 | SAMP7~SAMP0 | 选择通道 0~7 的采样时间选择 (Channel Sample Time Selection)<br>这些位用于独立地选择每个通道的采样时间。在采样周期中通道选择位必须保持不变。<br>0000: 2.5 周期<br>0100: 42.5 周期<br>0001: 8.5 周期<br>0101: 56.5 周期<br>0010: 14.5 周期<br>0110: 72.5 周期<br>0011: 29.5 周期<br>0111: 240.5 周期<br>1000: 3.5 周期<br>1001: 4.5 周期<br>1010: 5.5 周期<br>1011: 6.5 周期<br>1100: 7.5 周期<br>其它: 保留 |

### 9.7.15 ADC\_SMPR2 采样配置寄存器 2

偏移地址: 0x74

复位值: 0x00000000

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

| Bit   | Field    | Description                                                                                                                                                                                                                                                                                                               |
|-------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4  | Reserved | 保留, 必须保持复位值                                                                                                                                                                                                                                                                                                               |
| 3 : 0 | SAMP8    | 选择通道 8 的采样时间选择 (Channel Sample Time Selection)<br>这些位用于独立地选择每个通道的采样时间。在采样周期中通道选择位必须保持不变。<br>0000: 2.5 周期<br>0100: 42.5 周期<br>0001: 8.5 周期<br>0101: 56.5 周期<br>0010: 14.5 周期<br>0110: 72.5 周期<br>0011: 29.5 周期<br>0111: 240.5 周期<br>1000: 3.5 周期<br>1001: 4.5 周期<br>1010: 5.5 周期<br>1011: 6.5 周期<br>1100: 7.5 周期<br>其它: 保留 |

### 9.7.16 ADC\_JOFRn 注入通道数据补偿寄存器(n=0~3)

偏移地址: 0x7C~0x88

复位值: 0x00000000

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

| Bit   | Field    | Description |
|-------|----------|-------------|
| 31:12 | Reserved | 保留, 必须保持复位值 |

| Bit   | Field   | Description                                                                                                                                                            |
|-------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11: 0 | JOFFSET | 12 位 A/D 注入通道 n 的转换结果补偿寄存器(Data Offset Register for Injected Channel )<br>注入通道 n 的转换结果减去 JOFFSET 补偿值后，注入通道转换补偿后的结果保存在寄存器 JADDATA 和 ADC_JDRn.<br>注：该位在 JADST=0 时允许进行写操作 |

### 9.7.17 ADC\_JSQR 注入通道序列寄存器

偏移地址: 0x8C

复位值: 0x00000000

|       |      |    |    |    |      |    |    |    |      |      |      |    |    |    |    |
|-------|------|----|----|----|------|----|----|----|------|------|------|----|----|----|----|
| 31    | 30   | 29 | 28 | 27 | 26   | 25 | 24 | 23 | 22   | 21   | 20   | 19 | 18 | 17 | 16 |
| Res.  |      |    |    |    |      |    |    |    |      | JNUM | JSQ3 |    |    |    |    |
|       |      |    |    |    |      |    |    |    |      | RW   | RW   |    |    |    |    |
| 15    | 14   | 13 | 12 | 11 | 10   | 9  | 8  | 7  | 6    | 5    | 4    | 3  | 2  | 1  | 0  |
| JSQ3. | JSQ2 |    |    |    | JSQ1 |    |    |    | JSQ0 |      |      |    |    |    |    |
| RW    | RW   |    |    |    | RW   |    |    |    | RW   |      |      |    |    |    |    |

| Bit   | Field    | Description                                                                                                                    |
|-------|----------|--------------------------------------------------------------------------------------------------------------------------------|
| 23:22 | Reserved | 保留，必须保持复位值。                                                                                                                    |
| 21:20 | JNUM     | 注入通道转换的通道数配置(Channel Number for Injected Sequence )<br>00: JSQ0 通道<br>01: JSQ0~JSQ1 通道<br>10: JSQ0~JSQ2 通道<br>11: JSQ0~JSQ3 通道 |
| 19:15 | JSQ3     | 注入通道序列第 3 次转换(3th Conversion for Injected Sequence )<br>00000~01000: 可配置为通道 0~通道 8 中的任意通道为注入通道<br>其它：保留                        |
| 14:10 | JSQ2     | 注入通道序列第 2 次转换(2th Conversion for Injected Sequence )<br>00000~01000: 可配置为通道 0~通道 8 中的任意通道为注入通道<br>其它：保留                        |
| 9:5   | JSQ1     | 注入通道序列第 1 次转换(1th Conversion for Injected Sequence )<br>00000~01000: 可配置为通道 0~通道 8 中的任意通道为注入通道。<br>其它：保留                       |
| 4:0   | JSQ0     | 注入通道序列第 0 次转换(0th Conversion for Injected Sequence )<br>00000~01000: 可配置为通道 0~通道 8 中的任意通道为注入通道。<br>其它：保留                       |

注：单周期扫描或连续扫描模式下，硬件会启动 ADC\_JSQR 影子寄存器。在 ADC 工作期间，若更改 ADC\_JSQR 的值，只会更新到其影子寄存器中，在 ADC 转换最后一个通道时，影子寄存器的值才会更新至 ADC\_JSQR，实现通道动态切换。

### 9.7.18 ADC\_JADDA Data Register (n=0~3)

偏移地址: 0x90

复位值: 0x00000000

|       |    |    |    |    |    |    |    |    |    |        |              |      |             |    |    |
|-------|----|----|----|----|----|----|----|----|----|--------|--------------|------|-------------|----|----|
| 31    | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21     | 20           | 19   | 18          | 17 | 16 |
| Res.  |    |    |    |    |    |    |    |    |    | JVALID | JOVER<br>RUN | Res. | JCHANNELSEL |    |    |
| 15    | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5      | 4            | 3    | 2           | 1  | 0  |
| JDATA |    |    |    |    |    |    |    |    |    |        |              |      |             |    |    |
| r     |    |    |    |    |    |    |    |    |    |        |              |      |             |    |    |

| Bit   | Field       | Description                                                                                                                                                                                                                                                          |
|-------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:23 | Reserved    | 保留, 必须保持复位值                                                                                                                                                                                                                                                          |
| 22    | JVALID      | 注入通道有效标志位 (只读) (Valid Flag for Injected Channels)<br>1: JDATA[11:0] 位数据有效<br>0: JDATA[11:0] 位数据无效<br>对应通道转换完成后硬件置位, 读 ADC_JADDA 寄存器自动清除。                                                                                                                             |
| 21    | JOVERRUN    | 注入通道数据覆盖标志位 (只读) (Overrun Flag for Injected Channels)<br>1: JDATA[11:0] 数据被覆盖<br>0: JDATA[11:0] 数据最近一次转换结果。<br>新的转换结果装载至寄存器之前, 若 JDATA[11:0] 的数据没有被读取, JOVERRUN 将置位; 读 ADC_JADDA 寄存器硬件自动清除。                                                                          |
| 20    | Reserved    | 保留, 必须保持复位值                                                                                                                                                                                                                                                          |
| 19:16 | JCHANNELSEL | 该 4 位显示当前数据所对应的注入通道 (Injected Channel Selection)<br>0000 = 通道 0 的转换数据<br>0001 = 通道 1 的转换数据<br>0010 = 通道 2 的转换数据<br>0011 = 通道 3 的转换数据<br>0100 = 通道 4 的转换数据<br>0101 = 通道 5 的转换数据<br>0110 = 通道 6 的转换数据<br>0111 = 通道 7 的转换数据<br>1000 = 通道 8 的转换数据(内部参考电压的转换数据)<br>其它: 无效 |
| 15:0  | JDATA       | 12 位 A/D 当前注入通道转换结果 (Transfer Data for Injected Channels)<br>软件选择对齐方式。                                                                                                                                                                                               |

### 9.7.19 ADC\_JDRn 注入通道数据寄存器(n=0~3)

偏移地址: 0xB0~0xBC

复位值: 0x00000000

|       |    |    |    |    |    |    |    |    |    |        |              |      |    |    |    |
|-------|----|----|----|----|----|----|----|----|----|--------|--------------|------|----|----|----|
| 31    | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21     | 20           | 19   | 18 | 17 | 16 |
| Res.  |    |    |    |    |    |    |    |    |    | JVALID | JOVER<br>RUN | Res. |    |    |    |
| 15    | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5      | 4            | 3    | 2  | 1  | 0  |
| JDATA |    |    |    |    |    |    |    |    |    |        |              |      |    |    |    |
| r     |    |    |    |    |    |    |    |    |    |        |              |      |    |    |    |

| Bit    | Field    | Description                                                                                                                                                                     |
|--------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:23  | Reserved | 保留, 必须保持复位值                                                                                                                                                                     |
| 22     | JVALID   | 注入通道有效标志位 (Valid Flag for Injected Channels)<br>1: JDATA[11:0]位数据有效<br>0: JDATA[11:0]位数据无效<br>对应通道转换完成后硬件置位, 读 ADC_JADR 寄存器自动清除                                                 |
| 21     | JOVERRUN | 注入通道数据覆盖标志位 (Overrun Flag for Injected Channels)<br>1: JDATA [11:0]数据被覆盖<br>0: JDATA [11:0]数据最近一次转换结果<br>新的转换结果装载至寄存器之前, 若 JDATA[11:0]的数据没有被读取, JOVERRUN 将置位, 读 JDRn 寄存器硬件自动清除。 |
| 20: 16 | Reserved | 保留, 必须保持复位值。                                                                                                                                                                    |
| 15: 0  | JDATA    | A/D 注入通道 n 的转换结果 (Transfer Data for Injected Channels)<br>软件可选择对齐方式, 参考数据对齐章节。                                                                                                  |

## 10 TIM1 高级定时器

### 10.1 简介

TIM1 由一个 16 位可实时编程预分频器和一个 16 位计数方向可调的自动重装载计数器组成，可以为用户提供便捷的计数定时功能，计数器时钟由预分频器分频得到。高级定时器具有多种用途，如输入功能（测量输入信号的脉冲宽度、频率，PWM 输入等），输出功能（PWM 输出、死区时间可编程的互补输出、单脉冲模式输出等）。

### 10.2 功能框图



图 10-1 TIM1 结构图

上图为 TIM1 的结构框图，主要由输入单元、输出单元、时基单元、捕获/比较模块、刹车单元等结构组成。

## 10.3 主要特征

- 16 位可实时编程预分频器，分频系数：1–65536 可调
- 时钟源可选：内部时钟源，外部时钟输入，内部触发输入
- 16 位自动重装载计数器（计数方向：递增、递减、递增/递减）
- 8 位可编程重复计数功能，重复计数器可自动重装载(定时器到指定时间后自动更新重复寄存器)
- 外部信号控制定时器并且能够实现定时器间互连的同步电路
- 输入捕获：输入信号的脉冲宽度、周期的测量
- 触发输入可以作为外部时钟或者逐周期管理
- 支持编码器、霍尔传感器等接口
- 4 个输出通道，通道 1/2/3 有互补输出通道，通道 4 无互补输出通道
- 比较输出（控制输出波形或指示定时器已经计时结束）
- PWM 输出（死区时间可调；边沿对齐或中央对齐模式）
- 刹车输入可将计时器的输出信号置于安全状态（复位态或已知态，用户可选）
- 单脉冲输出
- 产生中断请求的事件：更新事件、触发事件、输入捕获、比较输出或者刹车输入

## 10.4 功能描述

### 10.4.1 时钟

#### 10.4.1.1 时钟选择

计数器的时钟源有以下几种：

- 内部时钟 (INT\_CK)
- 外部时钟模式 1：外部触发输入 TRGI (包含 TIx、ITRx)
- 编码器模式

上述几种时钟选择示意图如下：



图 10-2 时钟选择

#### 10.4.1.1.1 编码器模式

具体参考从模式-编码器接口章节。

#### 10.4.1.1.2 内部时钟源 (INT\_CK)

当配置 TIM1\_SMCR 寄存器的 SMS=000、关闭从模式时，计数器使能打开，预分频器的时钟直接由内部时钟驱动。此时计数器时钟为内部时钟分频后的时钟。

#### 10.4.1.1.3 外部时钟模式 1 (外部触发输入 TRGI, 包含 TIx、ITRx)

当配置 TIM1\_SMCR 寄存器的 SMS = 111 时，选择外部时钟模式 1 (TRGI)。计数器由选定的输入信号的每个上升沿或下降沿驱动。

例：计数器在 TI1 输入端的上升沿递增计数，具体配置如下：

1. 配置 TIM1\_CCMR1 寄存器的 CC1S=01，CC1 通道被配置为输入，IC1 映射在 TI1 上；配置

TIM1\_CCMR1 寄存器的 IC1F[3: 0]，设置输入滤波器带宽；配置 TIM1\_CCER 寄存器 CC1P=0，选择上升沿为有效沿。

2. 配置 TIM1\_SMCR 寄存器的 TS=101，选择 TI1 的作为触发输入源；配置 TIM1\_SMCR 寄存器的 SMS=111，选择外部时钟模式 1。

3. 配置 TIM1\_CR1 寄存器的 DIR=0，选择递增计数模式，配置 TIM1\_CR1 寄存器的 CEN=1，启动计数器。

当 TI1 出现有效边沿时，计数器递增计数一次。TI1 的有效边沿和计数器的实际时钟之间的延时取决于 TI1 输入端同步电路设计。



图 10-3 外部时钟模式 1 下的控制电路

#### 10.4.1.2 时基单元

TIM1 的时基单元主要包括：计数器寄存器（TIM1\_CNT）、预分频器寄存器（TIM1\_PSC）、自动预装载寄存器（TIM1\_ARR）和重复计数器寄存器（TIM1\_RCR）。

计数单元由一个 16 位的计数器和对应的自动预装载寄存器组成，可以实现递增计数，递减计数，递增和递减计数的功能。

计数器的时钟由预分频器提供，预分频器由预分频计数器和对应的寄存器组成，分频系数为 1-65536，可以随时写入，在下一次更新事件时生效。

自动预装载寄存器有预装载功能的 16 位影子寄存器，通过设置 TIM1\_CR1 寄存器的 ARPE 位选择写入 ARR 寄存器的值立即生效或发生更新事件时载入影子寄存器。



图 10-4 自动预装载

#### 10.4.1.3 计数模式

通过配置 TIM1\_CR1 寄存器的 DIR 位和 CMS 位可以选择计数器的计数模式，可以分为三种计数模式，递增计数模式、递减计数模式和中央对齐计数模式（递增/递减计数模式），下面对每种计数模式做详

详细介绍。

#### 10.4.1.3.1 递增计数模式

配置 TIM1\_CR1 寄存器 CMS=0, DIR=0, 选择递增计数模式。

递增计数模式下，在使能 TIM1\_CR1 寄存器的 CEN 后计数器由 0 开始递增计数，直至 TIM1\_ARR 的值，产生一个计数器上溢事件（更新事件），并从 0 开始重新递增计数。当用户启用了重复计数功能，重复计数器在每次上溢事件时递减计数，只有当重复计数器从设定值递减到 0 时，才会产生更新事件。设置 TIM1\_EGR 寄存器的 UG=1，同样可以产生一个更新事件。



图 10-5 递增计数模式 (UDIS=0)

通过配置 TIM1\_CR1 寄存器的 UDIS=1，可禁止产生更新事件，当计数器发生上溢事件时，不产生更新事件。此时若配置 UG=1，不产生更新事件，但是计数器和预分频器计数器会被初始化，从零开始递增计数。



图 10-6 递增计数模式 (UDIS=1 禁止产生更新事件)

注：发生更新事件时

- 重复计数器被载入 RCR 寄存器中的值，并重新开始递减计数。
- ARR 寄存器中的值被载入 ARR 影子寄存器中。
- 预分频器的预装载值生效。

#### 10.4.1.3.2 递减计数模式

配置 TIM1\_CR1 寄存器的 CMS=0, DIR=1, 选择递减计数模式。

递减计数模式下，计数器从自动预装载值 TIM1\_ARR 开始递减计数，计数到 0 时，产生一个下溢事件（更新事件）。当用户启用了重复计数功能后，重复计数器在每次下溢事件时递减计数，只有当重复计数器从设定值递减到 0 时，才会产生更新事件；设置 TIM1\_EGR 寄存器的 UG=1，同样可以产生一个更新事件，更新事件后计数器从自动预装载值 TIM1\_ARR 开始重新递减计数（TIM1\_CR1 寄存器 UDIS=0）。



图 10-7 递减计数模式 (UDIS=0)

通过配置 TIM1\_CR1 寄存器的 UDIS=1，可禁止产生更新事件，当计数器发生下溢事件时，不产生更新事件。此时若配置 UG=1，同样不产生更新事件，但是计数器和预分频器计数器会被初始化，从 TIM1\_ARR 开始计数。



图 10-8 递减计数模式 (UDIS=1 禁止产生更新事件)

#### 10.4.1.3.3 中央计数模式（递增/递减计数模式）

配置 TIM1\_CR1 寄存器的 CMS ≠ 0（此时写入 DIR 无效），选择中央对齐计数模式。

中央对齐计数模式，递增计数和递减计数交替进行。递增计数到 ARR-1 时，产生一个上溢事件，然后从 ARR 开始递减计数到 1，产生一个下溢事件，再从 0 开始递增计数。

当用户启用了重复计数功能后，重复计数器在每次上溢事件或下溢事件时递减重复计数值，只有当重复计数器从设定值递减到 0 时，才会产生更新事件；设置 TIM1\_EGR 寄存器的 UG=1，同样可以产生一个更新事件，更新事件后计数器从 0 开始重新递增计数（TIM1\_CR1 寄存器 UDIS=0）。



图 10-9 中央计数模式 (UDIS=0)

通过配置 TIM1\_CR1 寄存器的 UDIS=1，可禁止产生更新事件，当计数器发生上溢或下溢事件时，不产生更新事件。此时若配置 UG=1，同样不产生更新事件，但是计数器和预分频器计数器会被初始化，从零开始重新计数。



图 10-10 中央计数模式 (UDIS=1 禁止产生更新事件)

#### 10.4.2 重复计数器

重复计数器可以用来调整更新事件产生的频率。边沿对齐模式下，向上计数时，重复计数器在计数器每次上溢时递减；向下计数时，重复计数器在计数器每次下溢时递减。中央对齐模式下，重复计数器在计数器上溢和下溢时皆递减。通过配置 TIM1\_RCR 寄存器的 REP 来调整更新事件产生的频率，重复计数器在 REP+1 个计数周期后产生更新事件。在中央对齐模式下，更新事件在上溢还是在下溢时产生，由写入 REP 的值来决定。

发生更新事件，REP 的值会更新至实时重复计数器 REP\_CNT 中。允许对 REP\_CNT 实时写入以实现对更新事件发生时间点的灵活调整。



图 10-11 中央对齐模式重复计数时序图



图 10-12 边沿对齐模式递增计数时序图



图 10-13 边沿对齐模式递减计数时序图

## 10.4.3 输入捕获

### 10.4.3.1 输入捕获

输入捕获部分包括数字滤波器、多路复用、预分频器等，其结构如下图所示：



图 10-14 TIM1 输入捕获结构图

通过配置 `TIM1_CCMRx` 寄存器的 `ICxF`，可以设置数字滤波器的滤波宽度（滤波器的采样频率及数字滤波宽度如下表所示），当数字滤波器的输入信号宽度大于滤波宽度时，输入信号有效；数字滤波器对输入引脚 `TIx` 的输入信号采样后，产生一个滤波后的信号 `TIxF`，然后通过极性可选的边沿检测器，产生一个有效信号 `TIxFPx`，这个信号可以作为从模式控制器的触发输入信号，同时该信号经过预分频器产生一个信号 `ICxPS`，用于触发输入捕获事件。

表 10-1 数字滤波器宽度与 `ICxF` 的对应关系表

| <code>IC1F[3: 0]</code> | 采样频率和滤波宽度                               | <code>IC1F[3: 0]</code> | 采样频率和滤波宽度                                |
|-------------------------|-----------------------------------------|-------------------------|------------------------------------------|
| 0000                    | 无滤波器，以 $f_{DTS}$ 采样                     | 1000                    | 采样频率 $f_{sampling} = f_{DTS} / 8$ , N=6  |
| 0001                    | 采样频率 $f_{sampling} = f_{INT\_CK}$ , N=2 | 1001                    | 采样频率 $f_{sampling} = f_{DTS} / 8$ , N=8  |
| 0010                    | 采样频率 $f_{sampling} = f_{INT\_CK}$ , N=4 | 1010                    | 采样频率 $f_{sampling} = f_{DTS} / 16$ , N=5 |
| 0011                    | 采样频率 $f_{sampling} = f_{INT\_CK}$ , N=8 | 1011                    | 采样频率 $f_{sampling} = f_{DTS} / 16$ , N=6 |
| 0100                    | 采样频率 $f_{sampling} = f_{DTS} / 2$ , N=6 | 1100                    | 采样频率 $f_{sampling} = f_{DTS} / 16$ , N=8 |
| 0101                    | 采样频率 $f_{sampling} = f_{DTS} / 2$ , N=8 | 1101                    | 采样频率 $f_{sampling} = f_{DTS} / 32$ , N=5 |
| 0110                    | 采样频率 $f_{sampling} = f_{DTS} / 4$ , N=6 | 1110                    | 采样频率 $f_{sampling} = f_{DTS} / 32$ , N=6 |
| 0111                    | 采样频率 $f_{sampling} = f_{DTS} / 4$ , N=8 | 1111                    | 采样频率 $f_{sampling} = f_{DTS} / 32$ , N=8 |

输入捕获模式下，当检测到信号 `ICx` 上的有效边沿后，计数器的当前值被锁存到对应的影子寄存器上，再复制到对应的捕获比较寄存器中。当开启了中断使能，发生捕获事件时，将产生相应的中断请求。发生捕获事件时，会将状态寄存器（`TIM1_SR`）中的捕获标志位 `CCxIF` 置 1，通过配置 `CCxIF=0` 或读取 `TIM1_CCRx` 中的数据，清除 `CCxIF` 标志位。当 `CCxIF` 未被清零时，发生输入捕获事件，重复捕获标志位 `CCxOF` 将会被置 1，通过配置 `CCxOF=0`，可以清除 `CCxOF` 标志位。

例如，通过采样 TI1 输入信号的有效沿，在 TI1 的上升沿来到时捕获当前计数器的值，锁存到 TIM1\_CCR1 寄存器中，步骤如下：

1. 配置 TIM1\_CCMR1 寄存器的 CC1S=01，CC1 通道被配置为输入，IC1 映射在 TI1 上。
2. 配置 TIM1\_CCMR1 寄存器的 IC1F[3: 0]，配置数字滤波器的滤波宽度（按需配置）。
3. 配置 TIM1\_CCER 寄存器的 CC1P=0，选择捕获发生在 TI1 信号的上升沿。
4. 配置 TIM1\_CCMR1 寄存器的 IC1PSC[1:0]，选择预分频系数。
5. 配置 TIM1\_CCER 寄存器的 CC1E = 1，开启输入/捕获通道 1 的捕获使能。
6. 配置 TIM1\_DIER 寄存器的 CC1IE=1，使能通道 1 的捕获/比较通道 1 中断请求。

注：

- 当通道配置为输入模式时，TIM1\_CCRx 寄存器属性变为只读。
- 如果发生了两次以上连续捕获，但 CCxIF 标志未被清零，则重复捕获标志 CCxOF 被置 1。为了避免丢失重复捕获标志 CCxOF 置 1 之前可能产生的捕获信息，建议在读出重复捕获标志之前读取数据。
- 设置 TIM1\_EGR 寄存器中相应的 CCxG 位，可以通过软件产生输入捕获中断请求。

#### 10.4.3.2 PWM 捕获

PWM 输入模式的操作配置与一般输入捕获有以下不同点：

- 两个边沿有效且极性相反的 ICx 信号被映射至同一个 TIx 输入。
- 配置从模式为复位模式，将其中一路 TIxFP 作为触发输入信号。

例：测量 TI1 的 PWM 信号的宽度（TIM1\_CCR1 寄存器）和占空比（TIM1\_CCR2 寄存器），测量值取决于内部时钟 INT\_CK 的频率和预分频器的值。具体步骤如下：

1. 配置 TIM1\_CR1 寄存器 DIR=0，选择计数器计数模式为递增计数模式。
2. 配置 TIM1\_CCMR1 寄存器的 CC1S = 01，将 IC1 映射在 TI1 上，选择 TIM1\_CCR1 的有效输入。
3. 配置 TIM1\_CCER 寄存器的 CC1P =0，选择 TI1FP1 的有效极性（上升沿有效）（将计数器的值捕获到 TIM1\_CCR1 中并清除计数器）。
4. 配置 TIM1\_CCMR1 寄存器的 CC2S=10，将 IC2 映射在 TI1 上，选择 TIM1\_CCR2 的有效输入。
5. 配置 TIM1\_CCER 寄存器的 CC2P=1，选择 TI2FP2 的有效极性（下降沿有效）（将计数器的值捕获到 TIM1\_CCR2 中）。
6. 配置 TIM1\_SMCR 寄存器中的 TS = 101，选择 TI1FP1 为有效的触发输入信号。
7. 配置 TIM1\_SMCR 中的 SMS = 100，从模式控制器设置为复位模式。
8. 配置 TIM1\_CCER 寄存器中 CC1E=1 且 CC2E = 1。开启 CC1 通道和 CC2 通道的捕获使能。



图 10-15 PWM 输入模式时序

注：由于从模式控制器只连接了 TI1FP1 和 TI2FP2，所以 PWM 输入模式只适用于 TIM1\_CH1/TIM1\_CH2 端口输入信号。

#### 10.4.4 比较输出

捕获比较通道的比较输出部分由比较器、输出控制电路和捕获/比较寄存器组成，其结构图如下图所示：



图 10-16 比较输出部分结构图

在比较输出模式下，捕获比较寄存器的内容被载入到影子寄存器中，然后影子寄存器的内容和计数器当前值进行比较。捕获/比较模块包括一个捕获/比较寄存器（预装载寄存器）和一个影子寄存器，读写过程仅操作捕获/比较寄存器。

##### 10.4.4.1 强制输出

配置 TIM1\_CCMRx 寄存器的 CCxS = 00，将通道 CCx 设置为输出模式，通过配置 TIM1\_CCMRx 寄存器 OCxM 位，可以直接将比较输出信号直接强制为有效或无效状态，不依赖于比较结果。配置 TIM1\_CCMRx 寄存器 OCxM = 100，强置比较输出信号为无效状态。此时 OCxREF 被强置为低电平。配置 TIM1\_CCMRx 寄存器 OCxM = 101，强置比较输出信号为有效状态。此时 OCxREF 被强置为高电平（OCxREF 始终为高电平有效）。

注：强制输出模式下，在 TIM1\_CCRx 影子寄存器和计数器之间的比较输出仍在进行，比较结果的相应标志位也会被修改，如果开启了对应的中断请求，仍会产生对应的中断请求。

#### 10.4.4.2 比较输出

比较输出模式下，当计数器与捕获比较寄存器值相同时，可以根据 **TIM1\_CCMRx** 寄存器的 **OCxM** 位的配置用来输出不同的波形。

例如，当计数器与捕获/比较寄存器的内容匹配时，比较输出模式下的操作如下：

- 在比较匹配时，**OCxM** 的值不同，输出通道 **x** 信号 **OCx** 的操作不同：

- ◆ **OCxM = 000**: **OCx** 信号保持它的电平
- ◆ **OCxM = 001**: **OCx** 信号被设置成有效电平
- ◆ **OCxM = 010**: **OCx** 信号被设置成无效电平
- ◆ **OCxM = 011**: **OCx** 信号进行翻转

- 匹配时中断状态寄存器中的标志位置 1 (**TIM1\_SR** 寄存器中的 **CCxIF** 位)。

- 当配置了 **TIM1\_DIER** 寄存器中的 **CCxE = 1**，匹配时则产生一个中断。

比较输出模式也可以用来输出一个单脉冲（单脉冲输出模式）。

例如，通道 1 的比较输出模式的配置步骤如下：

- 配置计数器的时钟（选择时钟源，配置预分频系数）。

- 配置 **TIM1\_ARR** 和 **TIM1\_CCR1** 寄存器。

- 配置 **TIM1\_DIER** 寄存器的 **CC1IE = 1**，使能捕获/比较 1 中断。

- 配置输出模式：

- ◆ 配置 **TIM1\_CCMR1** 寄存器的 **OC1M = 011**，**OC1** 比较匹配时翻转。
- ◆ 配置 **TIM1\_CCMR1** 寄存器的 **OC1PE = 0**，禁止 **TIM1\_CCR1** 寄存器的预装载功能。
- ◆ 配置 **TIM1\_CCER** 寄存器的 **CC1P = 1**，**OC1** 低电平有效。
- ◆ 配置 **TIM1\_CCER** 寄存器的 **CC1E = 1**，开启输出/比较 1 输出使能，**OC1** 信号输出到对应的输出引脚。

- 配置 **TIM1\_CR1** 寄存器的 **CEN = 1**，启动计数器。

当配置 **TIM1\_CCMRx** 寄存器中 **OCxPE=0**，禁止 **TIM1\_CCRx** 寄存器的预装载功能时，可以随时写入 **TIM1\_CCRx** 寄存器，并且写入的值立即生效。当配置 **TIM1\_CCMRx** 寄存器中 **OCxPE=1**，启用 **TIM1\_CCRx** 寄存器的预装载功能时，读写仅对预装载寄存器进行操作，**TIM1\_CCRx** 预装载寄存器的值在下次更新事件到来时生效。下图给出了一个例子。



图 10-17 比较输出模式，**OC1** 信号在匹配时翻转

注：比较输出模式下，更新事件不会对输出结果产生影响。强制输出模式下，在 **TIM1\_CCRx** 影子寄

存器和计数器之间的比较输出仍在进行，比较结果的相应标志位也会被修改，如果开启了对应的中断请求，仍会产生对应的中断请求。

#### 10.4.4.3 PWM 输出

在 PWM 模式下，根据 TIM1\_ARR 寄存器和 TIM1\_CCRx 寄存器的值，产生一个频率、占空比可控的 PWM 波形。

配置与通道 x 对应的 TIM1\_CCMRx 寄存器的 OCxM=110 或 OCxM=111，选择通道 x 进入 PWM 模式 1 或 PWM 模式 2。PWM 模式下，计数器和 CCRx 会一直进行比较，根据配置和比较结果，通道 x 输出不同的信号，因此 TIM1 可以产生 4 个同频率下独立占空比的 PWM 输出信号。PWM 模式下可开启 TIM1\_CCRx 的预装载功能和 TIM1\_ARR 寄存器的预装载功能。写入 TIM1\_CCRx 预装载寄存器和 TIM1\_ARR 预装载寄存器的值在发生下个更新事件时，才会生效，载入相应的影子寄存器。PWM 模式下，使能计数器前设置 TIM1\_EGR 的 UG=1，产生更新事件用于初始化所有的寄存器。

配置 TIM1\_CCER 寄存器的 CCxP 选择 OCx 的有效极性。配置 TIM1\_CCER 寄存器的 CCxE、CCxNE 位和 TIM1\_BDTR 寄存器的 MOE、OSSI、OSSR 位控制 OCx 的输出使能。配置 TIM1\_CR1 寄存器的 CMS 位，可以选择产生边沿对齐或中央对齐的 PWM 信号。

- CMS=00，边沿对齐模式，再进一步配置 DIR，选择递增或递减计数模式。
- CMS=01，中央对齐模式 1。
- CMS=10，中央对齐模式 2。
- CMS=11，中央对齐模式 3。

##### 10.4.4.3.1 PWM 边沿对齐模式——递增计数模式

在递增计数模式配置的基础上，配置 TIM1\_CCMRx 寄存器的 CCxS=00，选择输出模式，OCxM=110，选择 PWM 模式 1，当 TIM1\_CNT < TIM1\_CCRx 时通道 x (OCxREF) 为有效电平，否则为无效电平。如果 TIM1\_CCRx 中的比较值大于自动重装载值 (TIM1\_ARR)，则 OCxREF 保持为有效电平。如果比较值为 0，则 OCxREF 保持为无效电平。下图为 CCR1=1，CCR2=4，CCR3=7，CCR4=b，ARR=a 时边沿对齐递增计数时 PWM 模式 1 的波形实例。



图 10-18 边沿对齐递增计数时 PWM 模式 1 的波形

#### 10.4.4.3.2 PWM 边沿对齐模式——递减计数模式

在递减计数模式配置的基础上，配置 TIM1\_CCMRx 寄存器的 CCxS=00，选择输出模式，OCxM=110，选择 PWM 模式 1，当 TIM1\_CNT > TIM1\_CCRx 时通道 x (OCxREF) 为无效电平，否则有效电平。下图为 CCR1=4，CCR2=6，CCR3=9，CCR4=b，ARR=a 时边沿对齐递减计数时 PWM 模式 1 的波形实例。



图 10-19 边沿对齐递减计数时 PWM 模式 1 的波形

#### 10.4.4.3.3 PWM 中央对齐模式

首先配置 TIM1 计数器为中央对齐计数模式，配置 `TIM1_CCMRx` 寄存器的 `CCxS=00`，选择输出模式，根据配置不同的 CMS，比较输出中断标志位在计数器递减计数时被设置（`CMS=01`）、在计数器递增计数时被设置（`CMS=10`）、或在计数器递增或递减计数时被设置（`CMS=11`）。下图为  $CCR1=4$ ,  $CCR2=6$ ,  $CCR3=9$ ,  $CCR4=b$ ,  $ARR=a$  时中央对齐 PWM 模式 1 的波形实例。



图 10-20 中央对齐 PWM 模式 1 的波形

#### 10.4.4.3.4 PWM 中央对齐模式下移相功能

设置 PDER 寄存器（通道 x 输出 PWM 移相使能位）和 CCRxFALL 寄存器（通道 x 在 PWM 中央对齐模式递减计数时的捕获/比较值），可以实现各通道输出 PWM 移相。根据需要移动相位，配置 CCRxFALL 以及 CCRx，即可实现 PWM 输出可编程的移相波形，可左移或是右移。



图 10-21 移相功能示意图

注：

- 进入中央对齐模式时，使用当前的递增/递减计数配置，计数方向取决于当前的 DIR 的值。
- 在中央对齐模式下，最好不要修改计数器的值，可能会产生不可预知的结果。当计数器处于递增计数时，写入计数器的值 > TIM1\_ARR，计数器会继续递增计数。直接写入 0 或 ARR，会立即更新计数方向，但不会产生更新事件。
- 建议使用中央对齐模式时，在启动计数器之前配置 TIM1\_EGR 寄存器的 UG=1，产生一个软件更新，更新所有寄存器，启动计数器后不要修改计数器的值。

#### 10.4.4.3.5 六步 PWM 输出

通过配置 OCxM 选择输出模式，CCxE=1 和 CCxNE=1 打开通道 x 和互补通道的输出使能，可以在通道 x 产生互补输出，这几个功能位为预装载位，在发生 COM 换相事件时，这些预装载位被装载到对应的影子寄存器中。这样可以在写入这些位时不会影响现在的输出，并可以同时载入所有通道配置。配置 TIM1\_EGR 寄存器的 COMG=1 或在 TRGI 上升沿都可以产生 COM 事件。

发生 COM 事件时，COM 中断标记会被硬件置 1；当配置了 TIM1\_DIER 寄存器 COMIE=1 和 COMDE = 1，发生 COM 事件会产生一个 COM 中断。

下图显示当发生 COM 事件时，不同配置下 OCx 和 OCxN 输出。



图 10-22 使用 COM 事件产生六步 PWM (OSSR = 1)

#### 10.4.4.4 互补输出和死区插入

OCx 和 OCxN 是一对互补输出通道，TIM1 的通道 1/2/3 能够输出三路可以管理瞬时关断和瞬时接通的互补信号，同时具有可调的死区时间。用户根据连接的输出器件和它们的特性（电平转换的延时、电源开关的延时等）来调整死区时间。

TIM1\_BDTR 寄存器 DTG[7: 0]位定义了插入互补输出之间的死区持续时间，具体计算方式如下表：

表 10-2 死区时间计算

| DTG[7: 5] | DT                                                                  |
|-----------|---------------------------------------------------------------------|
| 0xx       | $DT = DTG[7: 0] \times T_{dtg} (T_{dtg} = T_{DTS})$                 |
| 10x       | $DT = (64 + DTG[5: 0]) \times T_{dtg} (T_{dtg} = 2 \times T_{DTS})$ |

| DTG[7: 5] | DT                                                                 |
|-----------|--------------------------------------------------------------------|
| 110       | $DT = (32+DTG[4: 0]) \times T_{dtg} (T_{dtg} = 8 \times T_{DTS})$  |
| 111       | $DT = (32+DTG[4: 0]) \times T_{dtg} (T_{dtg} = 16 \times T_{DTS})$ |

例如, 如果  $T_{DTS}=125\text{ns}$ , 可能的死区时间为:

- 若步长时间为  $125\text{ns}$ , 死区时间为 0 至  $15875\text{ns}$ 。
- 若步长时间为  $250\text{ns}$ , 死区时间为  $16\mu\text{s}$  至  $31750\text{ns}$ 。
- 若步长时间为  $1\mu\text{s}$ , 死区时间为  $32\mu\text{s}$  至  $63\mu\text{s}$ 。
- 若步长时间为  $2\mu\text{s}$ , 死区时间为  $64\mu\text{s}$  至  $126\mu\text{s}$ 。

当不存在刹车电路时, 同时配置  $\text{CCxE}=1$  和  $\text{CCxNE}=1$ , 开启死区插入, 否则还需要配置  $\text{MOE}=1$ 。

配置  $\text{TIM1_CCER}$  寄存器的  $\text{CCxP}$  和  $\text{CCxNP}$  位, 可以为每一个输出独立地选择极性 (主输出  $\text{OCx}$  或互补输出  $\text{OCxN}$ )。

通过配置  $\text{TIM1_CCER}$  寄存器的  $\text{CCxE}$  和  $\text{CCxNE}$  位,  $\text{TIM1_BDTR}$  和  $\text{TIM1_CR2}$  寄存器中的  $\text{MOE}$ 、 $\text{OISx}$ 、 $\text{OISxN}$ 、 $\text{OSSI}$  和  $\text{OSSR}$  位的不同组合可以控制互补信号  $\text{OCx}$  和  $\text{OCxN}$  的输出。具体的组合控制配置见本章表 3、表 4、表 5 和表 6 的互补输出通道  $\text{OCx}$  和  $\text{OCxN}$  的控制位。

例:  $\text{OCx}$  和  $\text{OCxN}$  都为高有效, PWM 模式下, 发生匹配时, 输出参考信号  $\text{OCxREF}$  信号翻转, 输出信号  $\text{OCx}$  与参考信号相同, 但是  $\text{OCx}$  信号的上升沿对于参考信号的上升沿有一个延时; 互补输出信号  $\text{OCxN}$  与参考信号相反,  $\text{OCxN}$  信号的上升沿对于参考信号的下降沿同样有一个延时。

注: 死区时间不能大于或等于  $\text{OCx}$  或  $\text{OCxN}$  信号的占空比, 否则  $\text{OCx}$  或  $\text{OCxN}$  信号一直为无效值。

下列几张图显示了死区发生器的输出信号和当前参考信号  $\text{OCxREF}$  之间的关系。



图 10-23 死区插入

#### 10.4.4.5 刹车功能

$\text{TIM1}$  的刹车源有引脚输入、时钟失效事件和比较器输出三种类型。时钟失效事件由复位时钟控制器

中的时钟安全系统产生。

使用刹车功能时, OCx 和 OCxN 输出信号电平被以下功能位组合控制: TIM1\_BDTR 寄存器中的 MOE、OSSI 和 OSSR 位, TIM1\_CR2 寄存器中的 OISx 和 OISxN 位。发生刹车事件时, OCx 和 OCxN 输出不能同时有效。具体的带刹车功能的互补输出通道 OCx 和 OCxN 的输出状态如下列表所示。

表 10-3 当 MOE=1, OSSI=0/1, OSSR=0 时:

| CCxE | CCxNE | OCx                                    | OCxN                                        |
|------|-------|----------------------------------------|---------------------------------------------|
| 0    | 0     | OCx=0, OCx_EN=0                        | OCxN=0, OCxN_EN=0                           |
| 0    | 1     | OCx=0, OCx_EN=0                        | OCxN=OCxREF+Polarity,<br>OCxN_EN=1          |
| 1    | 0     | OCx=OCxREF+Polarity,<br>OCx_EN=1       | OCxN=0, OCxN_EN=0                           |
| 1    | 1     | OCx=OCxREF+Polarity+死区<br>时间, OCx_EN=1 | OCxN=OCxREF 反相+Polarity+<br>死区时间, OCxN_EN=1 |

表 10-4 当 MOE=1, OSSI=0/1, OSSR=1 时:

| CCxE | CCxNE | OCx                                    | OCxN                                        |
|------|-------|----------------------------------------|---------------------------------------------|
| 0    | 0     | OCx=0, OCx_EN=0                        | OCxN=0, OCxN_EN=0                           |
| 0    | 1     | OCx=CCxP, OCx_EN=1                     | OCxN=OCxREF+Polarity,<br>OCxN_EN=1          |
| 1    | 0     | OCx=OCxREF+Polarity,<br>OCx_EN=1       | OCxN=CCxNP, OCxN_EN=1                       |
| 1    | 1     | OCx=OCxREF+Polarity+死区<br>时间, OCx_EN=1 | OCxN=OCxREF 反相+Polarity+<br>死区时间, OCxN_EN=1 |

表 10-5 当 MOE=0, OSSI=0, OSSR=0/1 时:

| CCxE | CCxNE | OCx                                                                                                                                 | OCxN |
|------|-------|-------------------------------------------------------------------------------------------------------------------------------------|------|
| 0    | 0     | OCx_EN=0, OCxN_EN=0<br>异步的: OCx=CCxP, OCxN=CCxNP<br>若时钟存在: 经过一个死区时间后, OCx=OISx,<br>OCxN=OISxN<br>OISx 和 OISxN 都不对应 OCx 和 OCxN 的有效电平 |      |
| 0    | 1     | OCx_EN=0, OCxN_EN=0<br>异步的: OCx=CCxP, OCxN=CCxNP<br>若时钟存在: 经过一个死区时间后, OCx=OISx,<br>OCxN=OISxN<br>OISx 和 OISxN 都不对应 OCx 和 OCxN 的有效电平 |      |
| 1    | 0     | OCx_EN=0, OCxN_EN=0<br>异步的: OCx=CCxP, OCxN=CCxNP<br>若时钟存在: 经过一个死区时间后, OCx=OISx,<br>OCxN=OISxN<br>OISx 和 OISxN 都不对应 OCx 和 OCxN 的有效电平 |      |
| 1    | 1     | OCx_EN=0, OCxN_EN=0<br>异步的: OCx=CCxP, OCxN=CCxNP                                                                                    |      |

| CCxE | CCxNE | OCx                                                                           | OCxN |
|------|-------|-------------------------------------------------------------------------------|------|
|      |       | 若时钟存在：经过一个死区时间后，OCx=OISx，<br>OCxN=OISxN<br>OISx 和 OISxN 都不对应 OCx 和 OCxN 的有效电平 |      |

表 10-6 当 MOE=0, OSSI=1, OSSR=0/1 时：

| CCxE | CCxNE | OCx                                                                                                                              | OCxN |
|------|-------|----------------------------------------------------------------------------------------------------------------------------------|------|
| 0    | 0     | OCx_EN=1, OCxN_EN=1<br>异步的：OCx=CCxP, OCxN=CCxNP<br>若时钟存在：经过一个死区时间后，OCx=OISx，<br>OCxN=OISxN<br>OISx 和 OISxN 都不对应 OCx 和 OCxN 的有效电平 |      |
| 0    | 1     | OCx_EN=1, OCxN_EN=1<br>异步的：OCx=CCxP, OCxN=CCxNP<br>若时钟存在：经过一个死区时间后，OCx=OISx，<br>OCxN=OISxN<br>OISx 和 OISxN 都不对应 OCx 和 OCxN 的有效电平 |      |
| 1    | 0     | OCx_EN=1, OCxN_EN=1<br>异步的：OCx=CCxP, OCxN=CCxNP<br>若时钟存在：经过一个死区时间后，OCx=OISx，<br>OCxN=OISxN<br>OISx 和 OISxN 都不对应 OCx 和 OCxN 的有效电平 |      |
| 1    | 1     | OCx_EN=1, OCxN_EN=1<br>异步的：OCx=CCxP, OCxN=CCxNP<br>若时钟存在：经过一个死区时间后，OCx=OISx，<br>OCxN=OISxN<br>OISx 和 OISxN 都不对应 OCx 和 OCxN 的有效电平 |      |

注：当通道的输出和互补输出都关闭时，OISx, OISxN, CCxP 和 CCxNP 都必须配置为 0。

系统复位后，MOE=0，刹车功能禁止，需要配置 TIM1\_BKINF 寄存器的 BKIN\_SEL，选择刹车源，支持选择多路刹车源，任意一路刹车信号有效都会触发刹车。配置 TIM1\_BKINF 寄存器的 BKINFE，选择刹车信号滤波功能是否有效。配置 TIM1\_BKINF 寄存器的 BKINF，选择刹车数字滤波的采样频率。更改刹车数字滤波采样频率前应先关闭刹车滤波功能。配置 TIM1\_BDTR 寄存器的 BKE=1，使能刹车功能信号。配置 TIM1\_BDTR 寄存器的 BKP 位选择刹车输入信号的极性。BKP 和 BKE 可以同时写入，且会在一个时钟周期后生效。

由于 MOE 被异步清除，因此在实际信号和同步控制位间插入了一个再同步电路，用于在同步信号和异步信号间产生延迟（当 MOE 状态为 0 时写入 1，写入后读取前需要插入一个空指令用于延时，否则无法保证正确读取）。

发生刹车事件时，MOE 被异步清零，此时根据 OSSI 的配置 OCx/OCxN 的输出将置于无效状态、空闲状态或复位状态；MOE=0 时，输出由 TIM1\_CR2 寄存器的 OISx 位决定，OSSI=0 时，定时器关闭输出使能，否则打开输出使能。当使用互补输出时，输出首先置于复位状态，然后死区重新生成，在死区之后输出电平由 OISx 和 OISxN 决定。

配置 TIM1\_DIER 寄存器的 BIE=1，当发生刹车事件时，产生一个刹车中断；配置 TIM1\_BDTR 寄存器的 AOE = 1，则在下一个更新事件到来时自动置位 MOE 位。

注：刹车输入为电平有效。所以，当刹车输入有效时，不能（自动地或者通过软件）设置 MOE，并且状态标志 BIF 不能被清除。

刹车电路中实现了写保护以保证应用程序的安全，允许用户锁住死区长度，OCx/OCxN 极性和被禁止的状态，OCxM 配置，刹车使能和极性等参数。通过 TIM1\_BDTR 寄存器中的 LOCK 位，可以选择 lock 等级（总共三级 lock）。Lock 在系统复位后只能修改一次。

下图显示响应刹车的输出实例：



图 10-24 响应刹车的输出 ( $OISx=0, OISxN=0$ )



图 10-25 响应刹车的输出 ( $OISx=0, OISxN=1$ )



图 10-26 响应刹车的输出 ( $OISx=1, OISxN=0$ )



图 10-27 响应刹车的输出 ( $OISx=1, OISxN=1$ )

#### 10.4.4.6 单脉冲输出

单脉冲模式 (OPM) 下，计数器响应一个激励，产生一个脉宽可调的脉冲。配置 TIM1\_CR1 寄存器的 OPM=1，选择单脉冲模式，触发信号有效沿或配置 CEN=1 都可以启动计数器，直到下个更新事件发生或

配置 CEN=0 时，计数器停止计数。

产生脉冲的必要条件是比较值与计数器的初始值不同。所以在计数器启动之前的必要配置如下：

- 递增计数方式：计数器  $CNT < CCRx \leq ARR$ 。
- 递减计数方式：计数器  $CNT > CCRx$ 。



图 10-28 单脉冲模式

例如，在  $TI2$  检测到上升沿，延迟  $t_{DELAY}$  之后，在  $OC2$  上产生一个长度为  $t_{PULSE}$  的正脉冲。

配置  $TI2FP2$  作为触发源：

1. 配置  $TIM1\_CCMR1$  寄存器中的  $CC2S = 01$ ，将  $TI2FP2$  映射到  $TI2$ 。
2. 配置  $TIM1\_CCER$  寄存器中的  $CC2P = 0$ ，检测  $TI2FP2$  的上升沿。
3. 配置  $TIM1\_SMCR$  寄存器中的  $TS = 110$ ， $TI2FP2$  作为从模式控制器的触发（ $TRGI$ ）。
4. 配置  $TIM1\_SMCR$  寄存器中的  $SMS = 110$ ，选择触发模式， $TI2FP2$  使能计数器工作。

$OPM$  的波形由  $TIM1\_ARR$  和  $TIM1\_CCR1$  决定(要考虑时钟频率和计数器预分频器)：由  $TIM1\_CCR1$  寄存器的值和  $CNT$  初始值决定触发信号与单脉冲开始之间的延迟  $t_{DELAY}$ ， $TIM1\_ARR - TIM1\_CCR1$  的值为脉冲的宽度  $t_{PULSE}$ 。

下面是一个产生负脉冲的例子，即发生比较匹配时产生从 1 到 0 的波形，计数器达到预装载值时产生一个从 0 到 1 的波形：

1. 配置  $TIM1\_CCMR1$  寄存器  $OC1M = 111$ ，选择  $PWM$  模式 2。
2. 配置  $TIM1\_CCER$  寄存器  $CC1P = 1$ ，输出低电平有效。
3. 配置  $TIM1\_CCMR1$  中  $OC1PE = 1$  和  $TIM1\_CR1$  寄存器中  $ARPE=1$ ，使能预装载寄存器。
4. 配置  $TIM1\_CCR1$  寄存器和  $TIM1\_ARR$  寄存器。
5. 配置  $TIM1\_EGR$  寄存器  $UG=1$  产生一个更新事件。
6. 等待在  $TI2$  上的一个外部触发事件。

此例中， $TIM1\_CR1$  寄存器中的  $DIR=0$ 、 $CMS=0$ 、 $OPM=1$ ，在下一个更新事件（当计数器从自动装载值返回到 0）时停止计数。

#### 10.4.4.6.1 OCx 快速使能

$OCx$  快速使能，是单脉冲模式的一种特殊情况。在单脉冲模式下，通过设置  $TIM1\_CCMR$  寄存器的  $OCxFE=1$ ，强制  $OCxREF$  直接响应激励而不是依赖计数器和比较值之间的比较结果，输出波形和比较匹配时的波形一样。这样可以去除比较的时间，快速输出比较结果。 $OCx$  快速输出使能只在  $PWM$  模式下生

效。

## 10.4.5 从模式

### 10.4.5.1 编码器接口

编码器接口模式就是计数器在 TI1 和 TI2 正交信号相互作用下计数，在输入源改变期间，计数方向被硬件自动修改。通过配置 TIM1\_SMCR 寄存器 SMS 位可以选择输入源，根据输入源的不同，可以将编码器接口模式分为 3 种模式，SMS=001，编码器接口模式 1；SMS=010，编码器接口模式 2；SMS=011，编码器接口模式 3；三种模式具体计数操作如下表所示。两个输入 TI1 和 TI2 被用来作为正交编码器的接口。

编码器模式下，计数器开启之前必须先配置好 ARR 寄存器，因为使用编码器接口模式相当于使用了一个带有方向选择的外部时钟。计数器在 0 到 TIM1\_ARR 寄存器的自动装载值之间连续计数（递增计数和递减计数由外部时钟控制）。

注：编码器模式不支持外部时钟模式 2。

编码器接口模式下，计数器依照增量编码器的速度和方向被自动的修改，因此计数器的内容始终指示着编码器的位置。计数方向与相连的传感器旋转的方向对应。下表列出了所有可能的组合，假设 TI1 和 TI2 不同时变换。

表 10-7 计数方向与编码器信号的关系

| 计数模式                       | 相对电平 (TI1FP1 相对于 TI2, TI2FP2 相对于 TI1) | TI1FP1 信号 |      | TI2FP2 信号 |      |
|----------------------------|---------------------------------------|-----------|------|-----------|------|
|                            |                                       | 上升        | 下降   | 上升        | 下降   |
| 编码器接口模式 1 (只在 TI2 计数)      | 高电平                                   | -         | -    | 递增计数      | 递减计数 |
| 编码器接口模式 1 (只在 TI2 计数)      | 低电平                                   | -         | -    | 递减计数      | 递增计数 |
| 编码器接口模式 2 (只在 TI1 计数)      | 高电平                                   | 递减计数      | 递增计数 | -         | -    |
| 编码器接口模式 2 (只在 TI1 计数)      | 低电平                                   | 递增计数      | 递减计数 | -         | -    |
| 编码器接口模式 3 (在 TI1 和 TI2 计数) | 高电平                                   | 递减计数      | 递增计数 | 递增计数      | 递减计数 |
| 编码器接口模式 3 (在 TI1 和 TI2 计数) | 低电平                                   | 递增计数      | 递减计数 | 递减计数      | 递增计数 |

下例是计数器在编码器接口模式下的配置和时序图，从图中可以看出计数信号的产生和方向控制。具体配置如下：

1. 配置 TIM1\_CCMR 寄存器的 CC1S=01，将 IC1FP1 映射到 TI1 上。
2. 配置 TIM1\_CCMR 寄存器的 CC2S =01，将 IC2FP2 映射到 TI2 上。
3. 配置 TIM1\_CCER 寄存器的 CC1P =0，IC1 不反相，此时 IC1=TI1。
4. 配置 TIM1\_CCER 寄存器的 CC2P =0，IC2 不反相，此时 IC2=TI2。
5. 配置 TIM1\_SMCR 寄存器的 SMS =011，选择编码器模式 3，根据另一个信号的输入电平，计数器在 TI1FP1 和 TI2FP2 的边沿计数。
6. 配置 TIM1\_CR1 寄存器的 CEN =1，开启计数器。



图 10-29 编码器模式下的计数器时序图

下图为当 IC1FP1 反相时计数器的时序图（CC1P = 1，其他配置不变）



图 10-30 IC1FP1 反相编码器接口模式时序图

编码器接口模式下，计数器可以提供传感器当前位置的信息。通过使用另一个配置在捕获模式的定时器测量两个编码器事件的间隔周期来获得动态的信息（速度，加速度，减速度）。根据两个编码器事件的间隔周期，可以定期读取计数器。可以通过把计数器的值锁存到第三个输入捕获寄存器（捕获信号必须是周期性的并且可以由另一个定时器产生）来实现计数器的定期读取。

#### 10.4.5.2 复位模式

配置 TIM1\_SMCR 寄存器的 SMS=100，从模式选择复位模式。此模式下，TRGI 输入事件会使计数器清零重启。

例如，TI2 输入端的下降沿触发计数器重启：

1. 配置 TIM1\_CCMR1 寄存器的 CC2S=01，CC2 通道被配置为输入模式；IC2 映射在 TI2 上，配置 TIM1\_CCER 寄存器的 CC2P=1，检测下降沿。
2. 配置 TIM1\_SMCR 寄存器的 SMS = 100，从模式选择复位模式；配置 TIM1\_SMCR 寄存器的 TS = 110，选择滤波后的定时器输入 2 (TI2FP2) 作为同步计数器的触发输入。
3. 配置 TIM1\_CR1 寄存器的 DIR=0，选择计数方向为递增计数；配置 PSC=0，不分频；配置 CEN=1，使能计数器。

计数器的时钟源由内部时钟提供，当检测到 TI2 的下降沿，计数器被清零重启。此时触发器中断标记被硬件置 1。

下图为复位模式下 TIM1\_ARR = 0x13 的时序图。



图 10-31 复位模式的控制时序图

#### 10.4.5.3 门控模式

配置 TIM1\_SMCR 寄存器 SMS=101，从模式选择门控模式。此模式下，根据 TIM1\_CCER 寄存器 CCxP 的值来选择有效电平（0：高电平有效，1：低电平有效）。TRGI 输入为有效电平时，计数器始终开启，否则计数器停止（但不发生复位操作），计数器的开启和停止可控。

例如，计数器只在 TI1 为高时计数：

1. 配置 TIM1\_CCMR1 寄存器的 CC1S=01，CC1 通道被配置为输入模式，IC1 映射在 TI1 上；配置 TIM1\_CCER 寄存器的 CC1P=0，检测 TI1 上的高电平。
2. 配置 TIM1\_SMCR 寄存器的 SMS=101，从模式选择为门控模式；配置 TIM1\_SMCR 寄存器的 TS=101，选择滤波后的定时器输入 1 (TI1FP1) 作为同步计数器的触发输入。
3. 配置 TIM1\_CR1 寄存器的 DIR=0，选择计数方向为递增计数；配置 PSC=0，不分频；配置 CEN=1，使能计数器。

计数器的时钟源由内部时钟提供，当检测到 TI1 的高电平，计数器开始计数，当 TI1 为低电平时，计数器停止计数。计数器停止会将 TIF 置 1。

下图为门控模式下 TIM1\_ARR=0xf 的时序图。



图 10-32 门控模式下的控制时序图

#### 10.4.5.4 触发模式

配置 TIM1\_SMCR 寄存器 SMS=110，从模式选择触发模式。根据 TIM1\_CCER 寄存器 CCxP 的值来选择有效边沿（0：上升沿有效，1：下降沿有效），TRGI 输入为有效边沿时，计数器开始计数。计数器的启动可控，停止不可控。

例如，计数器在 TI1 输入的上升沿开始计数：

1. 配置 TIM1\_CCMR1 寄存器的 CC1S=01，CC1 通道被配置为输入模式，IC1 映射在 TI1 上，配置 TIM1\_CCER 寄存器的 CC1P=0，检测上升沿。
2. 配置 TIM1\_SMCR 寄存器的 SMS = 110，从模式选择为触发模式；配置 TIM1\_SMCR 寄存器的 TS=101，选择滤波后的定时器输入 1 (TI1FP1) 作为计数器的触发输入。
3. 配置 TIM1\_CR1 寄存器的 DIR=0，选择计数方向为递增计数；配置 PSC=0，不分频。

计数器的时钟源由内部时钟提供，当检测到 TI1 的上升沿，计数器开始计数。

下图为触发模式下 TIM1\_ARR=0xf 的时序图。



图 10-33 触发器模式下的控制时序图

#### 10.4.6 定时器同步

不同的 TIM1 定时器在内部连接，可以实现定时器之间的级联或同步。

定时器间的同步互联系意图如下：



图 10-34 定时器间互联

以下是几种典型的互联应用。

使用一个定时器作为另一个定时器的预分频器

例：使用 TIM3 作为 TIM1 的预分频器，时序图如下图所示：

1. TIM3 为主模式，配置 TIM3\_CR2 寄存器的 MMS=010，TIM3 的更新事件作为触发输出(TRGO)，TIM3 在每次更新事件时输出一个周期信号。
2. 配置 TIM3\_ARR 寄存器，作为 TIM3 的输出周期。
3. 配置 TIM1\_SMCR 寄存器的 TS=010，选择 TIM1 的触发源为 TIM3\_TRGO。
4. 配置 TIM1\_SMCR 寄存器的 SMS=111，从模式选择外部时钟模式 1。
5. 配置 TIM3\_CR1 寄存器的 CEN=1，启动 TIM3。
6. 配置 TIM1\_CR1 寄存器的 CEN=1，启动 TIM1。



图 10-35 使用 TIM3 作为 TIM1 的预分频器

使用一个定时器使能另一个定时器

例：使用 TIM1 使能 TIM3，时序图如下图所示：

当 TIM1 的 OC1REF 为高时，TIM3 的计数器才开始计数。两个 TIM 的计数时钟为 CK\_CNT 的三分频。具体配置如下：

1. TIM1 为主模式，配置 TIM1\_CR2 寄存器的 MMS=100，选择 TIM1 的比较输出参考信号(OC1REF)作为触发输出 (TRGO)。
2. 配置 TIM1\_CCR1 寄存器，TIM1\_ARR 寄存器，TIM1\_CCMR1 寄存器的 OC1M 位，CC1S 位等相关控制位，配置 TIM1 输出信号 TRGO 的输出波形。
3. 配置 TIM3\_SMCR 寄存器的 TS=000，选择 TIM1 的 OC1REF 作为 TIM3 的触发输入。
4. 配置 TIM3\_SMCR 寄存器的 SMS=101，选择 TIM3 为门控模式。
5. 配置 TIM3\_CR1 寄存器的 CEN=1，启动 TIM3。
6. 配置 TIM1\_CR1 寄存器的 CEN=1，启动 TIM1。



图 10-36 使用 TIM1 使能 TIM3

使用一个定时器启动另一个定时器

例：使用 TIM1 的更新事件启动 TIM3，时序图如下图所示：

当 TIM1 产生更新事件时，TIM3 接收到触发信号，TIM3 的 CEN 由硬件自动置 1，TIM3 的计数器开始计数。两个 TIM 的计数时钟为 CK\_CNT 的三分频。具体配置如下：

1. 配置 TIM1\_CR2 寄存器的 MMS=010，选择 TIM1 的更新事件为触发输出 (TRGO)；
2. 配置 TIM1\_ARR 寄存器，作为更新事件产生的周期；
3. 配置 TIM3\_SMCR 寄存器的 TS=000，选择 TIM1 的 TRGO 作为 TIM3 的触发输入；

4. 配置 TIM3\_SMCR 寄存器的 SMS=110，选择 TIM3 为触发模式；

5. 配置 TIM1\_CR1 寄存器的 CEN=1，启动 TIM1。



图 10-37 使用 TIM1 的更新事件启动 TIM3

使用一个外部触发同步启动两个定时器

例：使用 TIM1 的 TI1 上升沿，启动 TIM1 的同时启动 TIM3，时序图如下图所示：

为了确保两个定时器同时开启，TIM1 必须在主/从模式下配置。具体配置如下：

1. 配置 TIM1\_CR2 寄存器的 MMS=001，设置 TIM1 作为主模式时，将 TIM1 的使能信号 CEN 作为触发输出（TRGO）。
2. 配置 TIM1\_SMCR 寄存器的 TS=100，设置 TIM1 作为从模式时，将 TI1 作为触发输入。
3. 配置 TIM1\_SMCR 寄存器的 SMS=110，选择 TIM1 为触发模式。
4. 配置 TIM3\_SMCR 寄存器的 TS=000，选择 TIM1 的触发输出作为 TIM3 的触发输入。
5. 配置 TIM3\_SMCR 寄存器的 SMS=110，选择 TIM3 为触发模式。

当 TIM1 的 TI1 出现上升沿时，两个定时器同步启动（按照内部时钟），计数器开始计数，两个定时器的 TIF 标志也同时置 1。



图 10-38 TIM1 的 TI1 同步启动 TIM1 和 TIM3

#### 10.4.7 定时器异或

配置 TIM1\_CR2 寄存器的 TI1S =1，将 TIM1\_CH1、TIM1\_CH2 和 TIM1\_CH3 引脚经异或后连接到 TI1 的输入端，用于定时器的所有输入模式。

例：TIM1\_CH1、TIM1\_CH2 和 TIM1\_CH3 引脚经异或后连接到 TI1 的输入端，采样 TI1 输入信号的

有效沿，在 TI1 的上升沿来到时捕获当前计数器的值，锁存到 TIM1\_CCR1 寄存器中。具体配置如下：

1. 配置 TIM1\_CR2 寄存器的 TI1S=1，配置定时器的三个输入经异或后连接到 TI1 输入通道。
2. 配置 TIM1\_CCMR1 寄存器的 CC1S=01，CC1 通道被配置为输入，IC1 映射在 TI1 上。
3. 配置 TIM1\_CCMR1 寄存器的 IC1F[3: 0]，配置数字滤波器的滤波宽度（按需配置）。
4. 配置 TIM1\_CCER 寄存器的 CC1P=0，选择捕获发生在 TI1 信号的上升沿。
5. 配置 TIM1\_CCMR1 寄存器的 IC1PSC，选择预分频系数。
6. 配置 TIM1\_CCER 寄存器的 CC1E = 1，开启输入/捕获通道 1 的捕获使能。
7. 配置 TIM1\_CR1 寄存器的 CEN=1，启动计数器。



图 10-39 (TI1 异或输入) 输入捕获波形图

#### 10.4.7.1.1 霍尔接口电路

霍尔传感器接口模式是异或功能的一个应用实例，可以用来驱动电机，在使用 TIM1 产生 PWM 信号驱动电机时，可以将另一个计数器（例如 TIM3）作为“接口定时器”来连接霍尔传感器，将“接口定时器”的 3 个输入脚（CH1、CH2、CH3）经异或后连接到 TI1 输入通道，“接口定时器”接收这个信号。三个霍尔传感器与“接口定时器”的三路输入捕获引脚对应连接，每个传感器输入一路波形到输入引脚。分析输入捕获信号可以计算电机速度信息。

“接口定时器”在输出模式下可以产生一个用来控制 TIM1\_PWM 输出的脉冲，用来驱动电机。所以“接口定时器”在比较输出或 PWM 模式延时一段时间后产生一个正脉冲，然后通过 TRGO 输出到 TIM1。

例：霍尔输入连接到 TIM3 定时器，每次任一霍尔输入上信号变化都会改变 TIM1 的 PWM 配置。

1. 配置 TIM3\_CR2 寄存器的 TI1S=1，配置三个定时器输入经异或后连接到 TI1 输入通道。
2. 配置 TIM3\_ARR 为其最大值（计数器必须通过 TI1 的变化清零）。配置 PSC，设置计数周期大于传感器上两次变化的间隔时间。
4. 配置 TIM3\_CCMR1 的寄存器 CC1S=01，选择通道 1 为捕获模式（选中 TRC）。
5. 配置 TIM3\_CCMR1 寄存器的 CC2S=00，OC2M=111，配置通道 2 为 PWM2 模式，并具有要求的延时。
6. 配置 TIM3\_CR2 寄存器的 MMS=101，选择 OC2REF 作为 TRGO 上的触发输出。

TIM1 中，ITR 输入必须是 TIM3 的 TRGO，定时器被编程为可产生 PWM 信号，捕获/比较控制信号设置为可预装载的（TIM1\_CR2 寄存器中 CCPC = 1），同时触发输入用于控制 COM 事件（TIM1\_CR2 寄

存器中 **CCUS = 1**)。在一次 **COM** 事件后，写入下一步的 **PWM** 控制位 (**CCxE**、**OCxM**)，这可以在处理 **OC2REF** 上升沿的中断子程序里实现。

下图显示了这个实例：



图 10-40 霍尔传感器接口实例

#### 10.4.8 调试模式

在调试模式下，配置 **DBG\_CR** 寄存器中 **DBG\_TIM1\_STOP=1**，**TIM1** 计数器停止计数。(详见调试章节)

#### 10.4.9 中断

**TIM1** 的中断包括：捕获/比较 1 中断、捕获/比较 2 中断、捕获/比较 3 中断、捕获/比较 4 中断、比较 5 中断、更新中断、**COM** 中断、触发中断和刹车中断，当相应的中断使能位打开，发生相应的事件时，产生相应的中断。

表 10-8 中断事件一览表

| 中断事件       | 标志位   | 使能位   |
|------------|-------|-------|
| 捕获/比较 1 中断 | CC1IF | CC1IE |
| 捕获/比较 2 中断 | CC2IF | CC2IE |
| 捕获/比较 3 中断 | CC3IF | CC3IE |
| 捕获/比较 4 中断 | CC4IF | CC4IE |
| 比较 5 中断    | CC5IF | CC5IE |
| 更新中断       | UIF   | UIE   |
| COM 中断     | COMIF | COMIE |
| 触发中断       | TIF   | TIE   |
| 刹车中断       | BIF   | BIE   |

## 10.5 寄存器描述

表 10-9 TIM1 寄存器概览

| Offset      | Acronym       | Register Name      | Reset       |
|-------------|---------------|--------------------|-------------|
| 0x00        | TIM1_CR1      | 控制寄存器 1            | 0x0000      |
| 0x04        | TIM1_CR2      | 控制寄存器 2            | 0x0000      |
| 0x08        | TIM1_SMCR     | 从模式控制寄存器           | 0x0000      |
| 0x0C        | TIM1_DIER     | 中断使能寄存器            | 0x0000 0000 |
| 0x10        | TIM1_SR       | 状态寄存器              | 0x0000 0000 |
| 0x14        | TIM1_EGR      | 事件产生寄存器            | 0x0000 0000 |
| 0x18        | TIM1_CCMR1    | 捕获/比较模式寄存器 1       | 0x0000      |
| 0x1C        | TIM1_CCMR2    | 捕获/比较模式寄存器 2       | 0x0000      |
| 0x20        | TIM1_CCER     | 捕获/比较使能寄存器         | 0x0000      |
| 0x24        | TIM1_CNT      | 计数器                | 0x0000      |
| 0x28        | TIM1_PSC      | 预分频率器              | 0x0000      |
| 0x2C        | TIM1_ARR      | 自动装载寄存器            | 0x0000      |
| 0x30        | TIM1_RCR      | 重复计数寄存器            | 0x0000      |
| 0x34        | TIM1_CCR1     | 捕获/比较寄存器 1         | 0x0000      |
| 0x38        | TIM1_CCR2     | 捕获/比较寄存器 2         | 0x0000      |
| 0x3C        | TIM1_CCR3     | 捕获/比较寄存器 3         | 0x0000      |
| 0x40        | TIM1_CCR4     | 捕获/比较寄存器 4         | 0x0000      |
| 0x44        | TIM1_BDTR     | 刹车和死区寄存器           | 0x0000 0000 |
| 0x54        | TIM1_CCMR3    | 捕获/比较模式寄存器 3       | 0x0000      |
| 0x58        | TIM1_CCR5     | 捕获/比较寄存器 5         | 0x0000      |
| 0x5C        | TIM1_PDER     | PWM 移相使能寄存器        | 0x0000      |
| 0x60 ~ 0x70 | TIM1_CCRxFALL | PWM 移相递减计数捕获/比较寄存器 | 0x0000      |
| 0x74        | TIM1_BKINF    | 刹车输入滤波寄存器          | 0x0000 0000 |

### 10.5.1 TIM1\_CR1 控制寄存器 1

偏移地址: 0x00

复位值: 0x0000

|      |    |    |     |    |      |     |   |     |     |     |      |     |   |   |   |
|------|----|----|-----|----|------|-----|---|-----|-----|-----|------|-----|---|---|---|
| 15   | 14 | 13 | 12  | 11 | 10   | 9   | 8 | 7   | 6   | 5   | 4    | 3   | 2 | 1 | 0 |
| Res. |    |    | CKD |    | ARPE | CMS |   | DIR | OPM | URS | UDIS | CEN |   |   |   |
|      |    |    | rw  |    | rw   | rw  |   | rw  | rw  | rw  | rw   | rw  |   |   |   |

| Bit    | Field    | Description                                                                                                                                                                                                                                                                                                                                     |
|--------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15: 10 | Reserved | 保留, 必须保持复位值。                                                                                                                                                                                                                                                                                                                                    |
| 9: 8   | CKD      | <p>时钟分频 (clock division)<br/>           定义定时器时钟 (INT_CK) 频率与死区时间计数器、数字滤波器 (TIx) 所用的时钟之间的分频比例。</p> <p>00: <math>t_{DTS} = t_{INT\_CK}</math><br/>           01: <math>t_{DTS} = 2x t_{INT\_CK}</math><br/>           10: <math>t_{DTS} = 4x t_{INT\_CK}</math><br/>           11: 保留, 不要使用这个配置</p>                                               |
| 7      | ARPE     | <p>自动重装载预装载使能 (Auto-reload preload enable)</p> <p>0: 关闭 TIM1_ARR 寄存器的影子寄存器<br/>           1: 使能 TIM1_ARR 寄存器的影子寄存器</p>                                                                                                                                                                                                                          |
| 6: 5   | CMS      | <p>中央对齐模式选择 (Center-aligned mode selection)</p> <p>00: 边沿对齐模式。计数方向取决于 DIR 位<br/>           01: 中央对齐模式 1。计数器交替地递增和递减计数。通道为输出模式, 只在计数器递减计数时比较中断标志位被置 1<br/>           10: 中央对齐模式 2。计数器交替地递增和递减计数。通道为输出模式, 只在计数器递增计数时比较中断标志位被置 1<br/>           11: 中央对齐模式 3。计数器交替地递增和递减计数。通道为输出模式, 在计数器递增和递减计数时比较中断标志位均被置 1<br/>           注: 计数过程中, 不允许更改此位。</p> |
| 4      | DIR      | <p>计数方向 (Direction)</p> <p>0: 计数器递增计数<br/>           1: 计数器递减计数<br/>           注: 当计数器配置为中央对齐模式或编码器模式时, 该位为只读。</p>                                                                                                                                                                                                                              |
| 3      | OPM      | <p>单脉冲模式 (One pulse mode)</p> <p>0: 禁止单脉冲模式, 在发生更新事件时, 计数器继续计数<br/>           1: 使能单脉冲模式, 在发生下一次更新事件或软件清除 CEN 位时, 计数器停止计数</p>                                                                                                                                                                                                                   |

| Bit | Field | Description                                                                                                                                                                                          |
|-----|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2   | URS   | <p>更新请求源 (Update request source)<br/>软件配置该位, 选择更新事件源。</p> <p>0: 以下事件可产生一个更新中断请求:<br/>- 计数器上溢/下溢<br/>- 设置 UG 位<br/>- 从模式控制器产生的更新</p> <p>1: 只有计数器上溢/下溢才产生一个更新中断请求</p>                                  |
| 1   | UDIS  | <p>禁止更新 (Update disable)<br/>该位用来允许或禁止更新事件的产生</p> <p>0: 允许更新事件 (UEV)</p> <p>1: 禁止更新事件。不产生更新事件, 影子寄存器 (ARR、PSC、CCR<sub>x</sub>) 保持值不变。如果设置了 EGR_UG 位为 1, 计数器和预分频器被初始化; 如果从模式控制器接收到硬件复位, 计数器将被初始化。</p> |
| 0   | CEN   | <p>计数器使能 (Counter enable)</p> <p>0: 禁止计数器</p> <p>1: 使能计数器</p> <p>注: 在软件设置了 CEN 位后, 外部时钟、门控模式和编码器模式才能工作。触发模式可以自动地通过硬件设置 CEN 位。</p>                                                                    |

### 10.5.2 TIM1\_CR2 控制寄存器 2

偏移地址: 0x04

复位值: 0x0000

|      |      |       |      |       |      |       |      |      |     |   |   |      |      |      |      |
|------|------|-------|------|-------|------|-------|------|------|-----|---|---|------|------|------|------|
| 15   | 14   | 13    | 12   | 11    | 10   | 9     | 8    | 7    | 6   | 5 | 4 | 3    | 2    | 1    | 0    |
| Res. | OIS4 | OIS3N | OIS3 | OIS2N | OIS2 | OIS1N | OIS1 | TI1S | MMS |   |   | Res. | CCUS | Res. | CCPC |
|      | rw   | rw    | rw   | rw    | rw   | rw    | rw   | rw   | rw  |   |   |      | rw   |      | rw   |

| Bit | Field    | Description                                                                                                                                                                        |
|-----|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15  | Reserved | 保留, 必须保持复位值。                                                                                                                                                                       |
| 14  | OIS4     | 输出空闲状态 4 (OC4 输出)。参见 OIS1 位。                                                                                                                                                       |
| 13  | OIS3N    | 输出空闲状态 3 (OC3N 输出)。参见 OIS1N 位。                                                                                                                                                     |
| 12  | OIS3     | 输出空闲状态 3 (OC3 输出)。参见 OIS1 位。                                                                                                                                                       |
| 11  | OIS2N    | 输出空闲状态 2 (OC2N 输出)。参见 OIS1N 位。                                                                                                                                                     |
| 10  | OIS2     | 输出空闲状态 2 (OC2 输出)。参见 OIS1 位。                                                                                                                                                       |
| 9   | OIS1N    | <p>输出空闲状态 1 (OC1N 输出) (Output Idle state 1)</p> <p>0: 当 MOE = 0 时, 死区后 OC1N = 0</p> <p>1: 当 MOE = 0 时, 死区后 OC1N = 1</p> <p>注: 已经设置了 LOCK (TIM1_BKR 寄存器) 级别 1、2 或 3 后, 该位不能被修改。</p> |

| Bit  | Field    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8    | OIS1     | <p>输出空闲状态 1 (OC1 输出) (Output Idle state 1)</p> <p>0: 当 MOE=0, 若 OC1N 有效, 则在死区时间后 OC1 = 0<br/>1: 当 MOE=0, 若 OC1N 有效, 则在死区时间后 OC1 = 1</p> <p>注: 已经设置了 LOCK (TIM1_BKR 寄存器) 级别 1、2 或 3 后, 该位不能被修改。</p>                                                                                                                                                                                                                                                                                                                                |
| 7    | TI1S     | <p>TI1 选择 (TI1 selection)</p> <p>0: TIM1_CH1 管脚连到 TI1 输入<br/>1: TIM1_CH1、TIM1_CH2 和 TIM1_CH3 管脚经异或后作为 TI1 输入</p>                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 6: 4 | MMS      | <p>主模式选择 (Master mode selection)</p> <p>这些位控制 TRGO 信号的选择, 用于选择在主模式下送到从定时器的同步信息:</p> <p>000: 复位 TIM1_EGR 寄存器的 UG 位触发一次 TRGO 脉冲。<br/>001: 使能 用于控制在一定时间内使能从定时器或同时启动多个定时器。计数器使能信号 CNT_EN 被用于作为触发输出 (TRGO), 计数器使能信号是通过 CEN 控制位和门控模式下的触发输入信号的逻辑或产生。当计数器使能信号受控于触发输入时, TRGO 上会有一个延迟, 除非选择了主/从模式。<br/>010: 更新 更新事件被选为 TRGO。<br/>011: 捕获/比较脉冲 发生一次捕获或一次比较成功时, 触发输出送出一个 TRGO 信号。<br/>100: 比较 OC1REF 信号被用于作为触发输出 (TRGO)<br/>101: 比较 OC2REF 信号被用于作为触发输出 (TRGO)<br/>110: 比较 OC3REF 信号被用于作为触发输出 (TRGO)<br/>111: 比较 OC4REF 信号被用于作为触发输出 (TRGO)</p> |
| 3    | Reserved | 保留, 必须保持复位值。                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 2    | CCUS     | <p>捕获/比较控制更新源选择 (Capture/compare control update selection)</p> <p>0: CCPC=1 时, 只能配置 COMG=1 更新。<br/>1: CCPC=1 时, 可以通过配置 COMG=1 或检测到 TRGI 上的一个上升沿更新。</p> <p>注: 此位只在通道为互补输出时有效。</p>                                                                                                                                                                                                                                                                                                                                                  |
| 1    | Reserved | 保留, 必须保持复位值。                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 0    | CCPC     | <p>捕获/比较预装载控制位 (Capture/compare preloaded control)</p> <p>0: CCxE, CCxNE 和 OCxM 位预装载禁用<br/>1: CCxE, CCxNE 和 OCxM 位预装载使能</p> <p>注: 此位只在通道为互补输出时有效。</p>                                                                                                                                                                                                                                                                                                                                                                             |

### 10.5.3 TIM1\_SMCR 从模式控制寄存器

偏移地址: 0x08

复位值: 0x0000

|      |    |    |    |    |    |   |   |     |    |   |   |      |     |   |   |
|------|----|----|----|----|----|---|---|-----|----|---|---|------|-----|---|---|
| 15   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7   | 6  | 5 | 4 | 3    | 2   | 1 | 0 |
| Res. |    |    |    |    |    |   |   | MSM | TS |   |   | Res. | SMS |   |   |
|      |    |    |    |    |    |   |   | rw  | rw |   |   |      | rw  |   |   |

| Bit  | Field    | Description                                                                                                                                                                                                                                                                                                                                |
|------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:8 | Reserved | 保留，必须保持复位值。                                                                                                                                                                                                                                                                                                                                |
| 7    | MSM      | <p>主/从 模 式 (Master/slave mode)</p> <p>0: 无作用</p> <p>1: 触发输入 (TRGI) 事件被延迟，以实现当前定时器 (通过 TRGO) 与它的从定时器间的完美同步，该功能可以把几个定时器同步到一个单一的外部事件。</p>                                                                                                                                                                                                     |
| 6: 4 | TS       | <p>触发选择 (Trigger selection)</p> <p>触发输入源选择。</p> <p>000: 内部触发 0 (ITR0)<br/>     001: 内部触发 1 (ITR1)<br/>     010: 内部触发 2 (ITR2)<br/>     011: 内部触发 3 (ITR3)<br/>     100: TI1 的边沿检测器 (TI1F_ED)<br/>     101: 滤波后的定时器输入 1 (TI1FP1)<br/>     110: 滤波后的定时器输入 2 (TI2FP2)<br/>     111: 保留</p> <p>更多有关 ITRx 的细节，参见下表。</p> <p>注：从模式使能后这些位不能修改。</p> |
| 3    | Reserved | 保留，必须保持复位值。                                                                                                                                                                                                                                                                                                                                |

| Bit  | Field | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2: 0 | SMS   | <p>从模式选择 (Slave mode selection)<br/>当选择了外部信号作为触发源, 触发信号 (TRGI) 的有效边沿与选中的外部输入极性相关。</p> <p>000: 关闭从模式 - 如果 CEN = 1, 则预分频器直接由内部时钟驱动。</p> <p>001: 编码器模式 1- 根据 TI1FP1 的电平, 计数器在 TI2FP2 的边沿递增/递减计数。</p> <p>010: 编码器模式 2- 根据 TI2FP2 的电平, 计数器在 TI1FP1 的边沿递增/递减计数。</p> <p>011: 编码器模式 3- 根据另一个输入的电平, 计数器在 TI1FP1 和 TI2FP2 的边沿递增/递减计数。</p> <p>100: 复位模式 - 选中的触发输入 (TRGI) 的上升沿重新初始化计数器, 并且产生一个更新事件。</p> <p>101: 门控模式 - 当触发输入 (TRGI) 为高时, 计数器开始计数。当触发输入变为低时, 计数器停止计数 (但不复位), 并且产生一个更新事件。计数器的启动和停止都是受控的。</p> <p>110: 触发模式 - 计数器在触发输入 TRGI 的上升沿启动 (但不复位), 并且产生一个更新事件, 只有计数器的启动是受控的。</p> <p>111: 外部时钟模式 1 - 选中的触发输入 (TRGI) 的上升沿驱动计数器。</p> <p>注: 如果 TI1F_ED 被选为触发输入 (TS = 100) 时, 不要使用门控模式。这是因为, TI1F_ED 在每次 TI1F 变化时输出一个脉冲, 然而门控模式是要检查触发输入的电平。</p> |

表 10-10 TIM1 内部触发连接

| 从定时器 | ITR0      | ITR1 | ITR2      | ITR3         |
|------|-----------|------|-----------|--------------|
| TIM1 | -         | -    | TIM3_TRGO | TIM14_OC1REF |
| TIM3 | TIM1_TRGO | -    | -         | TIM14_OC1REF |

#### 10.5.4 TIM1\_DIER 中断使能寄存器

偏移地址: 0x0C

复位值: 0x0000 0000

|      |    |    |    |    |    |    |    |     |     |       |       |       |       |       |       |
|------|----|----|----|----|----|----|----|-----|-----|-------|-------|-------|-------|-------|-------|
| 31   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22  | 21    | 20    | 19    | 18    | 17    | 16    |
| Res. |    |    |    |    |    |    |    |     |     |       |       |       |       |       | CC5IE |
|      |    |    |    |    |    |    |    |     |     |       |       |       |       |       | rw    |
| 15   | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7   | 6   | 5     | 4     | 3     | 2     | 1     | 0     |
| Res. |    |    |    |    |    |    |    | BIE | TIE | COMIE | CC4IE | CC3IE | CC2IE | CC1IE | UIE   |
|      |    |    |    |    |    |    |    | rw  | rw  | rw    | rw    | rw    | rw    | rw    | rw    |

| Bit    | Field    | Description                                                                             |
|--------|----------|-----------------------------------------------------------------------------------------|
| 31: 17 | Reserved | 保留, 必须保持复位值。                                                                            |
| 16     | CC5IE    | 允许比较 5 中断 (Compare 5 interrupt enable)<br>0: 禁止比较 5 中断<br>1: 允许比较 5 中断                  |
| 15: 8  | Reserved | 保留, 必须保持复位值。                                                                            |
| 7      | BIE      | 允许刹车中断 (Break interrupt enable)<br>0: 禁止刹车中断<br>1: 允许刹车中断                               |
| 6      | TIE      | 允许触发中断 (Trigger interrupt enable)<br>0: 禁止触发中断<br>1: 允许触发中断                             |
| 5      | COMIE    | 允许 COM 中断 (COM interrupt enable)<br>0: 禁止 COM 中断<br>1: 允许 COM 中断                        |
| 4      | CC4IE    | 允许捕获/比较 4 中断 (Capture/Compare 4 interrupt enable)<br>0: 禁止捕获/比较 4 中断<br>1: 允许捕获/比较 4 中断 |
| 3      | CC3IE    | 允许捕获/比较 3 中断 (Capture/Compare 3 interrupt enable)<br>0: 禁止捕获/比较 3 中断<br>1: 允许捕获/比较 3 中断 |
| 2      | CC2IE    | 允许捕获/比较 2 中断 (Capture/Compare 2 interrupt enable)<br>0: 禁止捕获/比较 2 中断<br>1: 允许捕获/比较 2 中断 |
| 1      | CC1IE    | 允许捕获/比较 1 中断 (Capture/Compare 1 interrupt enable)<br>0: 禁止捕获/比较 1 中断<br>1: 允许捕获/比较 1 中断 |
| 0      | UIE      | 允许更新事件中断 (Update interrupt enable)<br>0: 禁止更新事件中断<br>1: 允许更新事件中断                        |

### 10.5.5 TIM1\_SR 状态寄存器

偏移地址: 0x10

复位值: 0x0000 0000

|      |    |       |       |       |       |      |       |     |       |       |       |       |       |     |    |      |       |
|------|----|-------|-------|-------|-------|------|-------|-----|-------|-------|-------|-------|-------|-----|----|------|-------|
| 31   | 30 | 29    | 28    | 27    | 26    | 25   | 24    | 23  | 22    | 21    | 20    | 19    | 18    | 17  | 16 | Res. | CC5IF |
|      |    |       |       |       |       |      |       |     |       |       |       |       |       |     |    | rw0c |       |
| 15   | 14 | 13    | 12    | 11    | 10    | 9    | 8     | 7   | 6     | 5     | 4     | 3     | 2     | 1   | 0  |      |       |
| Res. |    | CC4OF | CC3OF | CC2OF | CC1OF | Res. | BIF   | TIF | COMIF | CC4IF | CC3IF | CC2IF | CC1IF | UIF |    |      |       |
|      |    | r_w0c |       |       |       |      | r_w0c |     |       |       |       |       |       |     |    |      |       |

| Bit    | Field    | Description                                                                                                                                                  |
|--------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31: 17 | Reserved | 保留, 必须保持复位值。                                                                                                                                                 |
| 16     | CC5IF    | 比较 5 中断标记 (Compare 5 interrupt flag)<br>参考 CC1IF 描述。                                                                                                         |
| 15: 13 | Reserved | 保留, 必须保持复位值。                                                                                                                                                 |
| 12     | CC4OF    | 捕获/比较 4 重复捕获标记 (Capture/Compare 4 overcapture flag)<br>参考 CC1OF 描述。                                                                                          |
| 11     | CC3OF    | 捕获/比较 3 重复捕获标记 (Capture/Compare 3 overcapture flag)<br>参考 CC1OF 描述。                                                                                          |
| 10     | CC2OF    | 捕获/比较 2 重复捕获标记 (Capture/Compare 2 overcapture flag)<br>参考 CC1OF 描述。                                                                                          |
| 9      | CC1OF    | 捕获/比较 1 重复捕获标记 (Capture/Compare 1 overcapture flag)<br>仅当通道 1 被配置为输入捕获, CC1IF 已经为 1 后, 捕获事件再次发生时, 该标记可由硬件置 1。写 0 可清除该位。<br>0: 无重复捕获产生<br>1: 重复捕获产生           |
| 8      | Reserved | 保留, 必须保持复位值。                                                                                                                                                 |
| 7      | BIF      | 刹车中断标记 (Break interrupt flag)<br>当刹车输入有效, 由硬件对该位置 1。如果刹车输入无效, 则该位可由软件清 0<br>0: 无刹车事件产生<br>1: 刹车输入上检测到有效电平                                                    |
| 6      | TIF      | 触发器中断标记 (Trigger interrupt flag)<br>当发生触发事件 (当从模式控制器处于除门控模式和外部时钟模式外的其它模式时、在 TRGI 输入端检测到有效边沿, 或门控模式下的计数停止边沿) 时由硬件对该位置 1。它由软件清 0。<br>0: 无触发器事件产生<br>1: 触发器中断产生 |
| 5      | COMIF    | COM 中断标记 (COM interrupt flag)<br>当产生 COM 事件 (捕获/比较控制位 CCxE、CCxNE、OCxM 已被更新) 时该位由硬件置 1。它由软件清 0。<br>0: 无 COM 事件产生<br>1: COM 中断产生                               |
| 4      | CC4IF    | 捕获/比较 4 中断标记 (Capture/Compare 4 interrupt flag)<br>参考 CC1IF 描述。                                                                                              |
| 3      | CC3IF    | 捕获/比较 3 中断标记 (Capture/Compare 3 interrupt flag)<br>参考 CC1IF 描述。                                                                                              |
| 2      | CC2IF    | 捕获/比较 2 中断标记 (Capture/Compare 2 interrupt flag)<br>参考 CC1IF 描述。                                                                                              |

| Bit | Field | Description                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1   | CC1IF | <p>捕获/比较 1 中断标记 (Capture/Compare 1 interrupt flag)<br/>           通道 1 为输出模式:<br/>           当计数器值与比较值匹配时该位由硬件置 1 (在中央对齐模式下根据 TIM1_CR1.CMS[1:0]的选择来置位)。它由软件清 0。<br/>           0: 无匹配发生<br/>           1: TIM1_CNT 的值与 TIM1_CCR1 的值匹配</p> <p>通道 1 为输入模式:<br/>           当发生捕获事件时该位由硬件置 1, 由软件清 0 或读取 TIM1_CCR1 的值清 0。<br/>           0: 无输入捕获产生<br/>           1: 计数器值已被捕获至 TIM1_CCR1</p>    |
| 0   | UIF   | <p>更新中断标记 (Update interrupt flag)<br/>           当产生更新事件时该位由硬件置 1。它由软件清 0。<br/>           0: 无更新中断发生<br/>           1: 发生更新中断</p> <p>当寄存器被更新时该位由硬件置 1:</p> <ul style="list-style-type: none"> <li>- 若 TIM1_CR1 寄存器的 UDIS=0, 且 REP_CNT=0, 当计数器产生上溢/下溢事件时。</li> <li>- 若 TIM1_CR1 寄存器的 UDIS=0、URS=0, 当 TIM1_EGR 寄存器的 UG=1 时。</li> <li>- 若 TIM1_CR1 寄存器的 UDIS=0、URS=0, 从模式控制器产生更新事件时。</li> </ul> |

### 10.5.6 TIM1\_EGR 事件产生寄存器

偏移地址: 0x14

复位值: 0x0000 0000

|      |    |    |    |    |    |    |    |    |    |      |      |      |      |      |      |
|------|----|----|----|----|----|----|----|----|----|------|------|------|------|------|------|
| 31   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21   | 20   | 19   | 18   | 17   | 16   |
| Res. |    |    |    |    |    |    |    |    |    |      |      |      |      |      | CC5G |
|      |    |    |    |    |    |    |    |    |    |      |      |      |      |      | w    |
| 15   | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5    | 4    | 3    | 2    | 1    | 0    |
| Res. |    |    |    |    |    |    |    | BG | TG | COMG | CC4G | CC3G | CC2G | CC1G | UG   |
|      |    |    |    |    |    |    |    | w  | w  | w    | w    | w    | w    | w    | w    |

| Bit    | Field    | Description                                                        |
|--------|----------|--------------------------------------------------------------------|
| 31: 17 | Reserved | 保留, 必须保持复位值。                                                       |
| 16     | CC5G     | <p>产生比较 5 事件 (Compare 5 generation)<br/>           参考 CC1G 描述。</p> |
| 15: 8  | Reserved | 保留, 必须保持复位值。                                                       |

| Bit | Field | Description                                                                                                                                                                                                                                             |
|-----|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | BG    | 产生刹车事件 (Break generation)<br>0: 无动作<br>1: 产生一个刹车事件, 此时 MOE=0, BIF=1, 若开启对应的中断, 则产生相应的中断, 由硬件清除。                                                                                                                                                         |
| 6   | TG    | 产生触发事件 (Trigger generation)<br>0: 无动作<br>1: 产生触发事件, TIM1_SR 寄存器的 TIF = 1, 若开启对应的中断, 则产生相应的中断, 由硬件自动清 0。                                                                                                                                                 |
| 5   | COMG  | 捕获/比较事件, 产生控制更新 (Capture/Compare control update generation)<br>0: 无动作<br>1: 捕获/比较事件控制更新产生, 由硬件自动清 0, 当 CCPC=1, 允许更新 CCxE、CCxNE、OCxM 位。<br>注: 该位只对拥有互补输出的通道有效。                                                                                           |
| 4   | CC4G  | 产生捕获/比较 4 事件 (Capture/Compare 4 generation)<br>参考 CC1G 描述。                                                                                                                                                                                              |
| 3   | CC3G  | 产生捕获/比较 3 事件 (Capture/Compare 3 generation)<br>参考 CC1G 描述。                                                                                                                                                                                              |
| 2   | CC2G  | 产生捕获/比较 2 事件 (Capture/Compare 2 generation)<br>参考 CC1G 描述。                                                                                                                                                                                              |
| 1   | CC1G  | 产生通道 1 捕获/比较事件 (Capture/Compare 1 generation)<br>该位由软件置 1, 用于产生一个捕获/比较事件, 由硬件自动清 0。<br>0: 无动作<br>1: 通道 CC1 上产生一个捕获/比较事件:<br>若通道 CC1 配置为输出: CC1IF 置 1, 若开启对应的中断, 则产生相应的中断。<br>若通道 CC1 配置为输入: CC1IF 置 1, 若开启对应的中断, 则产生相应的中断。若 CC1IF 已经为 1, 则设置 CC1OF = 1。 |
| 0   | UG    | 产生更新事件 (Update generation)<br>0: 无动作<br>1: 初始化计数器, 并产生一个更新事件。由硬件自动清 0, 如果选择了中央对齐或递增计数模式, 计数器被清 0; 如果选择递减计数模式, 计数器将载入自动重载值。预分频计数器将同时被清除。                                                                                                                 |

### 10.5.7 TIM1\_CCMR1 捕获/比较模式寄存器 1

偏移地址: 0x18

复位值: 0x0000

|      |      |    |       |       |      |   |      |      |   |   |       |       |      |   |   |
|------|------|----|-------|-------|------|---|------|------|---|---|-------|-------|------|---|---|
| 15   | 14   | 13 | 12    | 11    | 10   | 9 | 8    | 7    | 6 | 5 | 4     | 3     | 2    | 1 | 0 |
| Res. | OC2M |    | OC2PE | OC2FE | CC2S |   | Res. | OC1M |   |   | OC1PE | OC1FE | CC1S |   |   |

| IC2F |    | IC2PSC |    | CC2S | IC1F |    | IC1PSC |    | CC1S |
|------|----|--------|----|------|------|----|--------|----|------|
| rw   | rw | rw     | rw | rw   | rw   | rw | rw     | rw | rw   |

通道可用于输入（捕获模式）或输出（比较模式），通道的方向由相应的 CCxS 定义。该寄存器 CCxS 以外其它位的作用在输入模式和输出模式下不同。OCxx 描述了通道在输出模式下的功能，ICxx 描述了通道在输入模式下的功能。

#### 比较输出模式：

| Bit    | Field    | Description                                                                                                                                                                                                                                        |
|--------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15     | Reserved | 保留，必须保持复位值。                                                                                                                                                                                                                                        |
| 14: 12 | OC2M     | 通道 2 比较输出模式 (Output compare 2 mode)<br>参考 OC1M 的描述。                                                                                                                                                                                                |
| 11     | OC2PE    | 通道 2 比较输出预装载使能 (Output compare 2 preload enable)<br>参考 OC1PE 的描述。                                                                                                                                                                                  |
| 10     | OC2FE    | 通道 2 比较输出快速使能 (Output compare 2 fast enable)<br>参考 OC1FE 的描述。                                                                                                                                                                                      |
| 9: 8   | CC2S     | 通道 2 捕获/比较选择 (Capture/Compare 2 selection)<br>该位定义通道的方向和输入信号的选择，只有在通道关闭时这些位才可写入：<br>00: 通道 2 被配置为输出<br>01: 通道 2 被配置为输入，IC2 映射在 TI2 上<br>10: 通道 2 被配置为输入，IC2 映射在 TI1 上<br>11: 通道 2 被配置为输入，IC2 映射在 TRC 上，此模式仅工作在内部触发器输入被选中时（由 TIM1_SMCR 寄存器的 TS 位选择） |
| 7      | Reserved | 保留，必须保持复位值。                                                                                                                                                                                                                                        |

| Bit  | Field | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6: 4 | OC1M  | <p>通道 1 比较输出模式 (Output compare 1 mode)<br/>     该位定义了输出参考信号 OC1REF 的动作，而 OC1REF 决定了 OC1、OC1N 的值。OC1REF 是高电平有效，而 OC1、OC1N 的有效电平取决于 CC1P、CC1NP 位。</p> <p>000: 冻结。TIM1_CCR1 与 TIM1_CNT 间的比较结果对 OC1REF 不起作用。</p> <p>001: 匹配时设置为高。当 TIM1_CNT 的值与 TIM1_CCR1 的值相同时，强制 OC1REF 为高电平。</p> <p>010: 匹配时设置为低。当 TIM1_CNT 的值与 TIM1_CCR1 的值相同时，强制 OC1REF 为低电平。</p> <p>011: 匹配时翻转。当 TIM1_CCR1=TIM1_CNT 时，翻转 OC1REF 的电平。</p> <p>100: 强制为低。强制 OC1REF 为低电平。</p> <p>101: 强制为高。强制 OC1REF 为高电平。</p> <p>110: PWM 模式 1。在递增计数时，当 TIM1_CNT&lt;TIM1_CCR1 时强制 OC1REF 为高电平，否则为低电平；在递减计数时，当 TIM1_CNT &gt; TIM1_CCR1 时强制 OC1REF 为低电平，否则为高电平。</p> <p>111: PWM 模式 2。在递增计数时，当 TIM1_CNT&lt;TIM1_CCR1 时通道 1 为强制 OC1REF 为低电平，否则为高电平；在递减计数时，当 TIM1_CNT&gt;TIM1_CCR1 时强制 OC1REF 为高电平，否则为低电平。</p> <p>注 1: 当 LOCK 级别设为 3 (TIM1_BDTR 寄存器中的 LOCK 位) 并且 CC1S = 00 (该通道配置成输出) 时，该位不能被修改。</p> <p>注 2: 在 PWM 模式 1 或 PWM 模式 2 中，只有当比较结果改变了或在比较输出模式中从冻结模式切换到 PWM 模式时，OC1REF 电平才改变。</p> |
| 3    | OC1PE | <p>通道 1 比较输出预装载使能 (Output compare 1 preload enable)<br/>     0: 禁止 TIM1_CCR1 寄存器的预装载功能，写入 TIM1_CCR1 寄存器的数值立即生效。</p> <p>1: 开启 TIM1_CCR1 寄存器的预装载功能，读写操作仅对预装载寄存器操作，TIM1_CCR1 的预装载值在更新事件到来时生效。</p> <p>注 1: 当 LOCK 级别设为 3 (TIM1_BDTR 寄存器中的 LOCK 位) 并且 CC1S = 00 (该通道配置成输出) 时，该位不能被修改。</p> <p>注 2: 若该位置 1，在单脉冲模式下 (TIM1_CR1 寄存器的 OPM=1)，是否设定预装载寄存器无影响；其它情况下，需要设定预装载寄存器，否则后续动作不确定。</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

| Bit  | Field | Description                                                                                                                                                                                                                                                                                                |
|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2    | OC1FE | <p>通道 1 比较输出快速使能 (Output compare 1 fast enable)<br/>         该位为 1 时, 若通道配置为 PWM 模式, 会加快捕获/比较输出对触发时间的响应。输出通道将触发输入信号的有效边沿的作用等同于发生了一次比较匹配, 此时 OC 被设置为比较电平, 与比较结果无关。</p> <p>0: 禁止通道 1 比较输出快速使能<br/>         1: 开启通道 1 比较输出快速使能</p>                                                                            |
| 1: 0 | CC1S  | <p>通道 1 捕获/比较选择 (Capture/Compare 1 selection)<br/>         该位定义通道的方向和输入信号的选择, 只有在通道关闭时这些位才可写入:</p> <p>00: 通道 1 被配置为输出<br/>         01: 通道 1 被配置为输入, IC1 映射在 TI1 上<br/>         10: 通道 1 被配置为输入, IC1 映射在 TI2 上<br/>         11: 通道 1 被配置为输入, IC1 映射在 TRC 上。此模式仅工作在内部触发器输入被选中时 (由 TIM1_SMCR 寄存器的 TS 位选择)</p> |

## 输入捕获模式:

| Bit    | Field  | Description                                                                                                                                                                                                                                                                                                 |
|--------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15: 12 | IC2F   | <p>输入捕获 2 滤波器 (Input capture 2 filter)<br/>         参考 IC1F 的描述</p>                                                                                                                                                                                                                                         |
| 11: 10 | IC2PSC | <p>输入/捕获 2 预分频器 (Input capture 2 prescaler)<br/>         参考 IC1PSC 的描述</p>                                                                                                                                                                                                                                  |
| 9: 8   | CC2S   | <p>通道 2 捕获/比较选择 (Capture/Compare 2 selection)<br/>         该位定义通道的方向和输入信号的选择, 只有在通道关闭时这些位才可写入:</p> <p>00: 通道 2 被配置为输出<br/>         01: 通道 2 被配置为输入, IC2 映射在 TI2 上<br/>         10: 通道 2 被配置为输入, IC2 映射在 TI1 上<br/>         11: 通道 2 被配置为输入, IC2 映射在 TRC 上, 此模式仅工作在内部触发器输入被选中时 (由 TIM1_SMCR 寄存器的 TS 位选择)</p> |

| Bit  | Field  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7: 4 | IC1F   | <p>通道 1 输入捕获滤波器 (Input capture 1 filter)<br/>           数字滤波器由一个事件计数器组成，它记录 N 个输入事件后会产生一个输出的跳变。这些位定义了 IC1 输入信号的采样频率和数字滤波器的长度。</p> <p>0000: 无滤波器，以 <math>f_{DTS}</math> 采样<br/>           0001: 采样频率 <math>f_{sampling} = f_{INT\_CK}</math>, <math>N=2</math><br/>           0010: 采样频率 <math>f_{sampling} = f_{INT\_CK}</math>, <math>N=4</math><br/>           0011: 采样频率 <math>f_{sampling} = f_{INT\_CK}</math>, <math>N=8</math><br/>           0100: 采样频率 <math>f_{sampling} = f_{DTS} / 2</math>, <math>N=6</math><br/>           0101: 采样频率 <math>f_{sampling} = f_{DTS} / 2</math>, <math>N=8</math><br/>           0110: 采样频率 <math>f_{sampling} = f_{DTS} / 4</math>, <math>N=6</math><br/>           0111: 采样频率 <math>f_{sampling} = f_{DTS} / 4</math>, <math>N=8</math><br/>           1000: 采样频率 <math>f_{sampling} = f_{DTS} / 8</math>, <math>N=6</math><br/>           1001: 采样频率 <math>f_{sampling} = f_{DTS} / 8</math>, <math>N=8</math><br/>           1010: 采样频率 <math>f_{sampling} = f_{DTS} / 16</math>, <math>N=5</math><br/>           1011: 采样频率 <math>f_{sampling} = f_{DTS} / 16</math>, <math>N=6</math><br/>           1100: 采样频率 <math>f_{sampling} = f_{DTS} / 16</math>, <math>N=8</math><br/>           1101: 采样频率 <math>f_{sampling} = f_{DTS} / 32</math>, <math>N=5</math><br/>           1110: 采样频率 <math>f_{sampling} = f_{DTS} / 32</math>, <math>N=6</math><br/>           1111: 采样频率 <math>f_{sampling} = f_{DTS} / 32</math>, <math>N=8</math></p> |
| 3: 2 | IC1PSC | <p>通道 1 输入/捕获预分频器 (Input capture 1 prescaler)<br/>           该位定义了 IC1 的预分频系数。当 CC1E=0 (TIM1_CCER 寄存器中) 时，预分频器复位。</p> <p>00: 无预分频器，捕获输入口上检测到的每一个边沿都触发一次捕获<br/>           01: 每 2 个事件触发一次捕获<br/>           10: 每 4 个事件触发一次捕获<br/>           11: 每 8 个事件触发一次捕获</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 1: 0 | CC1S   | <p>通道 1 捕获/比较选择 (Capture/Compare 1 selection)<br/>           该位定义通道的方向和输入信号的选择，只有在通道关闭时这些位才可写入：</p> <p>00: 通道 1 被配置为输出<br/>           01: 通道 1 被配置为输入，IC1 映射在 TI1 上<br/>           10: 通道 1 被配置为输入，IC1 映射在 TI2 上<br/>           11: 通道 1 被配置为输入，IC1 映射在 TRC 上。此模式仅工作在内部触发器输入被选中时 (由 TIM1_SMCR 寄存器的 TS 位选择)</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

### 10.5.8 TIM1\_CCMR2 捕获/比较模式寄存器 2

偏移地址: 0x1C

复位值: 0x0000

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

|      |      |        |       |      |      |      |        |       |      |
|------|------|--------|-------|------|------|------|--------|-------|------|
| Res. | OC4M | OC4PE  | OC4FE | CC4S | Res. | OC3M | OC3PE  | OC3FE | CC3S |
| IC4F |      | IC4PSC |       | CC4S | IC3F |      | IC3PSC |       | CC3S |
| rw   | rw   | rw     | rw    | rw   | rw   | rw   | rw     | rw    | rw   |

比较输出模式:

| Bit    | Field    | Description                                                                                                                                                                                                                                                      |
|--------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15     | Reserved | 保留, 必须保持复位值。                                                                                                                                                                                                                                                     |
| 14: 12 | OC4M     | 通道 4 比较输出模式 (Output compare 4 mode)<br>参考 OC3M 的描述                                                                                                                                                                                                               |
| 11     | OC4PE    | 通道 4 比较输出预装载使能 (Output compare 4 preload enable)<br>参考 OC3PE 的描述                                                                                                                                                                                                 |
| 10     | OC4FE    | 通道 4 比较输出快速使能 (Output compare 4 fast enable)<br>参考 OC3FE 的描述                                                                                                                                                                                                     |
| 9: 8   | CC4S     | 通道 4 捕获/比较选择 (Capture/Compare 4 selection)<br>该位定义通道的方向和输入信号的选择, 只有在通道关闭时这些位<br>才可写入:<br>00: 通道 4 被配置为输出<br>01: 通道 4 被配置为输入, IC4 映射在 TI4 上<br>10: 通道 4 被配置为输入, IC4 映射在 TI3 上<br>11: 通道 4 被配置为输入, IC4 映射在 TRC 上, 此模式仅工作在<br>内部触发器输入被选中时 (由 TIM1_SMCR 寄存器的 TS 位选择) |
| 7      | Reserved | 保留, 必须保持复位值。                                                                                                                                                                                                                                                     |

| Bit  | Field | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6: 4 | OC3M  | <p>通道 3 比较输出模式 (Output compare 3 mode)<br/>     该位定义了输出参考信号 OC3REF 的动作，而 OC3REF 决定了 OC3、OC3N 的值。OC3REF 是高电平有效，而 OC3、OC3N 的有效电平取决于 CC3P、CC3NP 位。</p> <p>000: 冻结。TIM1_CCR3 与 TIM1_CNT 间的比较结果对 OC3REF 不起作用</p> <p>001: 匹配时设置为高。当 TIM1_CNT 的值与 TIM1_CCR3 的值相同时，强制 OC3REF 为高电平</p> <p>010: 匹配时设置为低。当 TIM1_CNT 的值与 TIM1_CCR3 的值相同时，强制 OC3REF 为低电平</p> <p>011: 匹配时翻转。当 TIM1_CCR3=TIM1_CNT 时，翻转 OC3REF 的电平</p> <p>100: 强制为低。强制 OC3REF 为低电平</p> <p>101: 强制为高。强制 OC3REF 为高电平</p> <p>110: PWM 模式 1。在递增计数时，当 TIM1_CNT&lt;TIM1_CCR3 时强制 OC3REF 为高电平，否则为低电平；在递减计数时，当 TIM1_CNT &gt; TIM1_CCR3 时强制 OC3REF 为低电平，否则为高电平。</p> <p>111: PWM 模式 2。在递增计数时，当 TIM1_CNT&lt;TIM1_CCR3 时强制 OC3REF 为低电平，否则为高电平；在递减计数时，当 TIM1_CNT&gt;TIM1_CCR3 时强制 OC3REF 为高电平，否则为低电平。</p> <p>注 1: 当 LOCK 级别设为 3 (TIM1_BDTR 寄存器中的 LOCK 位) 并且 CC3S=00 (该通道配置成输出) 时，该位不能被修改。</p> <p>注 2: 在 PWM 模式 1 或 PWM 模式 2 中，只有当比较结果改变了或在比较输出模式中从冻结模式切换到 PWM 模式时，OC3REF 电平才改变。</p> |
| 3    | OC3PE | <p>通道 3 比较输出预装载使能 (Output compare 3 preload enable)</p> <p>0: 禁止 TIM1_CCR3 寄存器的预装载功能，写入 TIM1_CCR3 寄存器的数值立即生效</p> <p>1: 开启 TIM1_CCR3 寄存器的预装载功能，读写操作仅对预装载寄存器操作，TIM1_CCR3 的预装载值在更新事件到来时生效</p> <p>注 1: 当 LOCK 级别设为 3 (TIM1_BDTR 寄存器中的 LOCK 位) 并且 CC3S =00 (该通道配置成输出) 时，该位不能被修改。</p> <p>注 2: 仅在单脉冲模式下 (TIM1_CR1 寄存器的 OPM= 1)，无需设定预装载寄存器，其它情况下，需要设定预装载寄存器，否则后续动作不确定。</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

| Bit  | Field | Description                                                                                                                                                                                                                                                                                                         |
|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2    | OC3FE | <p>通道 3 比较输出快速使能 (Output compare 3 fast enable)<br/>           该位为 1 时, 若通道配置为 PWM 模式, 会加快捕获/比较输出对触发时间的响应。输出通道将触发输入信号的有效边沿的作用等同于发生了一次比较匹配, 此时 OC 被设置为比较电平, 与比较结果无关。</p> <p>0: 禁止通道 3 比较输出快速使能<br/>           1: 开启通道 3 比较输出快速使能</p>                                                                                 |
| 1: 0 | CC3S  | <p>通道 3 捕获/比较选择 (Capture/Compare 3 selection)<br/>           该位定义通道的方向和输入信号的选择, 只有在通道关闭时这些位才可写入:</p> <p>00: 通道 3 被配置为输出<br/>           01: 通道 3 被配置为输入, IC3 映射在 TI3 上<br/>           10: 通道 3 被配置为输入, IC3 映射在 TI4 上<br/>           11: 通道 3 被配置为输入, IC3 映射在 TRC 上, 此模式仅工作在内部触发器输入被选中时 (由 TIM1_SMCR 寄存器的 TS 位选择)</p> |

## 输入捕获模式:

| Bit    | Field  | Description                                                                                                                                                                                                                                                                                                         |
|--------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15: 12 | IC4F   | <p>输入捕获 4 滤波器 (Input capture 4 filter)<br/>           参考 IC3F 的描述</p>                                                                                                                                                                                                                                               |
| 11: 10 | IC4PSC | <p>输入/捕获 4 预分频器 (Input capture 4 prescaler)<br/>           参考 IC3PSC 的描述</p>                                                                                                                                                                                                                                        |
| 9: 8   | CC4S   | <p>通道 4 捕获/比较选择 (Capture/Compare 4 selection)<br/>           该位定义通道的方向和输入信号的选择, 只有在通道关闭时这些位才可写入:</p> <p>00: 通道 4 被配置为输出<br/>           01: 通道 4 被配置为输入, IC4 映射在 TI4 上<br/>           10: 通道 4 被配置为输入, IC4 映射在 TI3 上<br/>           11: 通道 4 被配置为输入, IC4 映射在 TRC 上, 此模式仅工作在内部触发器输入被选中时 (由 TIM1_SMCR 寄存器的 TS 位选择)</p> |

| Bit  | Field  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7: 4 | IC3F   | <p>通道 3 输入捕获滤波器 (Input capture 3 filter)<br/>           数字滤波器由一个事件计数器组成, 它记录 N 个输入事件后会产生一个输出的跳变。这些位定义了 IC1 输入信号的采样频率和数字滤波器的长度。</p> <p>0000: 无滤波器, 以 <math>f_{DTS}</math> 采样<br/>           0001: 采样频率 <math>f_{sampling} = f_{INT\_CK}</math>, <math>N=2</math><br/>           0010: 采样频率 <math>f_{sampling} = f_{INT\_CK}</math>, <math>N=4</math><br/>           0011: 采样频率 <math>f_{sampling} = f_{INT\_CK}</math>, <math>N=8</math><br/>           0100: 采样频率 <math>f_{sampling} = f_{DTS} / 2</math>, <math>N=6</math><br/>           0101: 采样频率 <math>f_{sampling} = f_{DTS} / 2</math>, <math>N=8</math><br/>           0110: 采样频率 <math>f_{sampling} = f_{DTS} / 4</math>, <math>N=6</math><br/>           0111: 采样频率 <math>f_{sampling} = f_{DTS} / 4</math>, <math>N=8</math><br/>           1000: 采样频率 <math>f_{sampling} = f_{DTS} / 8</math>, <math>N=6</math><br/>           1001: 采样频率 <math>f_{sampling} = f_{DTS} / 8</math>, <math>N=8</math><br/>           1010: 采样频率 <math>f_{sampling} = f_{DTS} / 16</math>, <math>N=5</math><br/>           1011: 采样频率 <math>f_{sampling} = f_{DTS} / 16</math>, <math>N=6</math><br/>           1100: 采样频率 <math>f_{sampling} = f_{DTS} / 16</math>, <math>N=8</math><br/>           1101: 采样频率 <math>f_{sampling} = f_{DTS} / 32</math>, <math>N=5</math><br/>           1110: 采样频率 <math>f_{sampling} = f_{DTS} / 32</math>, <math>N=6</math><br/>           1111: 采样频率 <math>f_{sampling} = f_{DTS} / 32</math>, <math>N=8</math></p> |
| 3: 2 | IC3PSC | <p>通道 3 输入/捕获预分频器 (Input capture 3 prescaler)<br/>           该位定义了 IC3 的预分频系数。当 CC3E=0 (TIM1_CCER 寄存器中) 时, 预分频器复位。</p> <p>00: 无预分频器, 捕获输入口上检测到的每一个边沿都触发一次捕获<br/>           01: 每 2 个事件触发一次捕获<br/>           10: 每 4 个事件触发一次捕获<br/>           11: 每 8 个事件触发一次捕获</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 1: 0 | CC3S   | <p>通道 3 捕获/比较选择 (Capture/Compare 3 selection)<br/>           该位定义通道的方向和输入信号的选择, 只有在通道关闭时这些位才可写入:</p> <p>00: 通道 3 被配置为输出<br/>           01: 通道 3 被配置为输入, IC3 映射在 TI3 上<br/>           10: 通道 3 被配置为输入, IC3 映射在 TI4 上<br/>           11: 通道 3 被配置为输入, IC3 映射在 TRC 上, 此模式仅工作在内部触发器输入被选中时 (由 TIM1_SMCR 寄存器的 TS 位选择)</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

### 10.5.9 TIM1\_CCER 捕获/比较使能寄存器

偏移地址: 0x20

复位值: 0x0000

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

| CC4NP | Res. | CC 4P | CC 4E | CC3NP | CC3NE | CC3P | CC3E | CC2NP | CC2NE | CC2P | CC2E | CC1NP | CC1NE | CC1P | CC1E |
|-------|------|-------|-------|-------|-------|------|------|-------|-------|------|------|-------|-------|------|------|
| rw    |      |       |       |       |       |      |      |       |       |      |      |       |       |      | rw   |

| Bit | Field    | Description                                                                                                                                                                                                                                                                        |
|-----|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15  | CC4NP    | 通道 4 输入 / 捕获互补输出极性 (Capture/Compare 4 complementary output polarity)<br>参考 CC1NP 的描述。                                                                                                                                                                                              |
| 14  | Reserved | 保留，必须保持复位值。                                                                                                                                                                                                                                                                        |
| 13  | CC4P     | 通道 4 输入/捕获输出极性(Capture/Compare 4 output polarity)<br>参考 CC1P 的描述。                                                                                                                                                                                                                  |
| 12  | CC4E     | 通道 4 输入/捕获输出使能(Capture/Compare 4 output enable)<br>参考 CC1E 的描述。                                                                                                                                                                                                                    |
| 11  | CC3NP    | 通道 3 输入 / 捕获互补输出极性 (Capture/Compare 3 complementary output polarity)<br>参考 CC1NP 的描述。                                                                                                                                                                                              |
| 10  | CC3NE    | 通道 3 输入 / 捕获互补输出使能 (Capture/Compare 3 complementary output enable)<br>参考 CC1NE 的描述。                                                                                                                                                                                                |
| 9   | CC3P     | 通道 3 输入捕获输出极性(Capture/Compare 3 output polarity)<br>参考 CC1P 的描述。                                                                                                                                                                                                                   |
| 8   | CC3E     | 通道 3 输入/捕获输出使能(Capture/Compare 3 output enable)<br>参考 CC1E 的描述。                                                                                                                                                                                                                    |
| 7   | CC2NP    | 通道 2 输入 / 捕获互补输出极性 (Capture/Compare 2 complementary output polarity)<br>参考 CC1NP 的描述。                                                                                                                                                                                              |
| 6   | CC2NE    | 通道 2 输入 / 捕获互补输出使能 (Capture/Compare 2 complementary output enable)<br>参考 CC1NE 的描述。                                                                                                                                                                                                |
| 5   | CC2P     | 通道 2 输入捕获输出极性(Capture/Compare 2 output polarity)<br>参考 CC1P 的描述。                                                                                                                                                                                                                   |
| 4   | CC2E     | 通道 2 输入/捕获输出使能(Capture/Compare 2 output enable)<br>参考 CC1E 的描述。                                                                                                                                                                                                                    |
| 3   | CC1NP    | 通道 1 输入 / 捕获互补输出极性 (Capture/Compare 1 complementary output polarity)<br>通道 1 配置为输出时，此位定义了输出信号极性：<br>0: OC1N 高电平有效<br>1: OC1N 低电平有效<br>通道 1 配置为输入时，CC1P/CC1NP 配合使用定义了输入信号极性和电平，详细参考 ICx 极性/电平选择表。<br>注：当 LOCK 级别 (TIM1_BDTR 寄存器中的 LCCK 位) 设为 3 或 2 且 CC1S = 00 (通道配置为输出) 时，该位不能被修改。 |

| Bit | Field | Description                                                                                                                                                                                                                                  |
|-----|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2   | CC1NE | 通道 1 输入 / 捕获互补输出使能 (Capture/Compare 1 complementary output enable)<br>0: 关闭通道 1 互补输出。OC1N 禁止输出。<br>1: 开启通道 1 互补输出。<br>OC1N 信号输出到对应的输出引脚, 其输出电平依赖于 MOE、OSSI、OSSR、OIS1、OIS1N 和 CC1E 位的值。                                                       |
| 1   | CC1P  | 通道 1 输入/捕获输出极性(Capture/Compare 1 output polarity)<br>通道 1 配置为输出时, 此位定义了输出信号极性:<br>0: OC1 高电平有效<br>1: OC1 低电平有效<br>通道 1 配置为输入时, CC1P/CC1NP 配合使用定义了输入信号极性和电平, 详细参考 ICx 极性/电平选择表。<br>注: 当 LOCK 级别 (TIM1_BDTR 寄存器中的 LCCK 位) 设为 3 或 2 时, 该位不能被修改。 |
| 0   | CC1E  | 通道 1 输入/捕获输出使能(Capture/Compare 1 output enable)<br>通道 1 配置为输出时:<br>0: 关闭。OC1 禁止输出<br>1: 开启。OC1 信号输出到对应的输出引脚<br>其输出电平依赖于 MOE、OSSI、OSSR、OIS1、OIS1N 和 CC1NE 位的值。<br>CC1 通道配置为输入:<br>该位决定了输入捕获功能是否启用。<br>0: 捕获禁止<br>1: 捕获使能                      |

输入模式下, ICx 的极性/电平选择如下表所示:

表 10-11 ICx 极性/电平选择表

| CCxP | CCxNP | ICx 极性/电平       |
|------|-------|-----------------|
| 0    | 0     | 上升沿有效/高电平有效     |
| 1    | 0     | 下降沿有效/低电平有效     |
| 1    | 1     | 上升沿或下降沿有效/高电平有效 |
| 0    | 1     | 保留              |

### 10.5.10 TIM1\_CNT 计数器

偏移地址: 0x24

复位值: 0x0000

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

| Bit   | Field | Description         |
|-------|-------|---------------------|
| 15: 0 | CNT   | 计数器的值 (Count value) |

### 10.5.11 TIM1\_PSC 预分频器

偏移地址: 0x28

复位值: 0x0000

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

| Bit   | Field | Description                                                                                                     |
|-------|-------|-----------------------------------------------------------------------------------------------------------------|
| 15: 0 | PSC   | 预分频器的值 (Prescaler value)<br>计数器的时钟频率 ( $f_{ck\_cnt} = f_{ck\_psc} / (PSC + 1)$ )<br>当发生更新事件时, PSC 的值装入当前预分频寄存器。 |

### 10.5.12 TIM1\_ARR 自动预装载寄存器

偏移地址: 0x2C

复位值: 0x0000

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

| Bit   | Field | Description                                                           |
|-------|-------|-----------------------------------------------------------------------|
| 15: 0 | ARR   | 自动预装载值 (Auto-reload value)<br>这些位定义了计数器的自动预装载值。当自动预装载的值为 0 时, 计数器不工作。 |

### 10.5.13 TIM1\_RCR 重复计数寄存器

偏移地址: 0x30

复位值: 0x0000

|         |    |    |    |    |    |   |   |     |   |   |   |   |   |   |   |
|---------|----|----|----|----|----|---|---|-----|---|---|---|---|---|---|---|
| 15      | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7   | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| REP_CNT |    |    |    |    |    |   |   | REP |   |   |   |   |   |   |   |
| rw      |    |    |    |    |    |   |   | rw  |   |   |   |   |   |   |   |

| Bit   | Field   | Description                                                                                                                                                                                                                        |
|-------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15: 8 | REP_CNT | <p>重复计数器实时写入的值 (Repetition counter value of real-time writing)</p> <p>在重复计数模式下，写入该位可以实时地将更新中断标志位 (UIF) 的检测点移位。</p> <p>注：在更新事件后写入该位，在更新事件前写入 REP_CNT 将会被 REP 的值覆盖，使移位无效。</p>                                                        |
| 7: 0  | REP     | <p>重复计数器的值 (Repetition counter value)</p> <p>重复计数器的值定义了更新事件的产生速率。重复计数器计数值递减为 0 时产生更新事件。如果允许产生更新中断，则会同时影响产生更新中断的速率。</p> <p>对 REP 值的写入在下次更新事件发生时生效，所以在 PWM 模式中，(REP+1) 对应着：</p> <p>在边沿对齐模式下，PWM 周期的数目</p> <p>在中央对齐模式下，PWM 半周期的数目</p> |

### 10.5.14 TIM1\_CCR1 捕获/比较寄存器 1

偏移地址: 0x34

复位值: 0x0000

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

| Bit   | Field | Description                                                                                                                                                                                                                                                                                                    |
|-------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15: 0 | CCR1  | <p>通道 1 捕获/比较的值 (Capture/Compare 1 value)</p> <p>通道 1 配置为输入：</p> <p>上一次捕获事件发生时捕获的计数器值存放于 CCR1(此时 CCR1 寄存器为只读)。</p> <p>通道 1 配置为输出：</p> <p>如果在 TIM1_CCMR1 寄存器 (OC1PE 位) 中未选择预装载功能，写入的数值会立即传输至对应的当前捕获/比较影子寄存器中。否则只有当更新事件发生时，此预装载值才传输至对应的当前捕获/比较影子寄存器中。当前捕获/比较影子寄存器参与同计数器 TIM1_CNT 的比较，并将比较结果反映到 OC1 端口的输出信号上。</p> |

### 10.5.15 TIM1\_CCR2 捕获/比较寄存器 2

偏移地址: 0x38

复位值: 0x0000

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

| Bit   | Field | Description                                            |
|-------|-------|--------------------------------------------------------|
| 15: 0 | CCR2  | 通道 2 捕获/比较的值 (Capture/Compare 2 value)<br>参考 CCR1 的描述。 |

### 10.5.16 TIM1\_CCR3 捕获/比较寄存器 3

偏移地址: 0x3C

复位值: 0x0000

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

| Bit   | Field | Description                                            |
|-------|-------|--------------------------------------------------------|
| 15: 0 | CCR3  | 通道 3 捕获/比较的值 (Capture/Compare 3 value)<br>参考 CCR1 的描述。 |

### 10.5.17 TIM1\_CCR4 捕获/比较寄存器 4

偏移地址: 0x40

复位值: 0x0000

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

| Bit   | Field | Description                                            |
|-------|-------|--------------------------------------------------------|
| 15: 0 | CCR4  | 通道 4 捕获/比较的值 (Capture/Compare 4 value)<br>参考 CCR1 的描述。 |

### 10.5.18 TIM1\_BDTR 刹车和死区寄存器

偏移地址: 0x44

复位值: 0x0000 0000

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

|     |     |     |     |      |      |      |     |   |   |   |   |   |   |   |   |
|-----|-----|-----|-----|------|------|------|-----|---|---|---|---|---|---|---|---|
| 15  | 14  | 13  | 12  | 11   | 10   | 9    | 8   | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| MOE | AOE | BKP | BKE | OSSR | OSSI | LOCK | DTG |   |   |   |   |   |   |   |   |
| RW  | RW  | RW  | RW  | RW   | RW   | RW   | RW  |   |   |   |   |   |   |   |   |

注：根据锁定设置，DOE、AOE、BKP、BKE、OSSI、OSSR 和 DTG 位均可被写保护，有必要在第一次写入 TIM1\_BDTR 寄存器时对它们进行配置，详见互补输出和死区插入章节。

| Bit    | Field    | Description                                                                                                                                                                                                        |
|--------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31: 17 | Reserved | 保留，必须保持复位值。                                                                                                                                                                                                        |
| 16     | DOE      | <p>直接输出（Direct output enable）<br/>当刹车有效、MOE 置零后，有效。<br/>0: 刹车输入后，等待一个死区时间后输出空闲状态（输出使能信号关闭）<br/>1: 立即输出空闲状态（输出使能信号关闭）<br/>注：当 LOCK 级别（TIM1_BDTR 寄存器中的 LOCK 位）设为 1 时，该位不能被修改。</p>                                    |
| 15     | MOE      | <p>主输出使能（Main output enable）<br/>当通道 x 配置为输出时，根据 AOE 位的设置值，该位可以由软件清 0 或被自动置 1。当刹车输入有效时，该位被硬件异步清 0。<br/>0: 禁止 OCx 和 OCxN 输出或强制为空闲状态（输出使能信号关闭）<br/>1: 如果设置了相应的使能位（TIM1_CCER 寄存器的 CCxE、CCxNE 位），则开启 OCx 和 OCxN 输出</p> |
| 14     | AOE      | <p>自动输出使能（AutoMatic output enable）<br/>0: MOE 不能被硬件置 1<br/>1: MOE 能被软件置 1 或刹车无效时在下一个更新事件被硬件自动置 1<br/>注：当 LOCK 级别（TIM1_BDTR 寄存器中的 LOCK 位）设为 1 时，该位不能被修改。</p>                                                        |
| 13     | BKP      | <p>刹车输入极性（Break Polarity）<br/>0: 刹车输入低电平有效<br/>1: 刹车输入高电平有效<br/>注：当 LOCK 级别（TIM1_BDTR 寄存器中的 LOCK 位）设为 1 时，该位不能被修改。</p>                                                                                             |
| 12     | BKE      | <p>刹车功能使能（Break enable）<br/>0: 禁止刹车输入<br/>1: 开启刹车输入<br/>注 1: 当 LOCK 级别（TIM1_BDTR 寄存器中的 LOCK 位）设为 1 时，该位不能被修改。<br/>注 2: 刹车输入包括引脚输入和 CSS 时钟失效两类事件，刹车使能前应先配置 TIM1_BKINF 寄存器中 BKIN_SEL 位，选择刹车源。</p>                    |

| Bit  | Field | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11   | OSSR  | <p>运行模式下“关闭状态”选择 (Off-state selection for Run mode)<br/>         该位仅适用于当 <math>MOE = 1</math> 且通道为互补输出。</p> <p>0: 当定时器不工作时, 禁止 OC/OCN 输出<br/>         1: 当定时器不工作时, 如果 <math>CCxE = 1</math> 或 <math>CCxNE = 1</math>, 首先开启 OC/OCN 并输出无效电平, 然后置位 OC/OCN 输出使能信号。<br/>         注: 当 LOCK 级别 (TIM1_BDTR 寄存器中的 LOCK 位) 设为 2 时, 该位不能被修改。</p>                                                                                                                                                                           |
| 10   | OSSI  | <p>空闲模式下“关闭状态”选择 (Off-state selection for Idle mode)<br/>         该位仅适用于当 <math>MOE = 0</math> 且通道设为输出时。</p> <p>0: 当定时器不工作时, 禁止 OC/OCN 输出。<br/>         1: 当定时器不工作时, 如果 <math>CCxE = 1</math> 或 <math>CCxNE = 1</math>, 首先 OC/OCN 输出无效电平, 然后置位 OC/OCN 输出使能信号。<br/>         注: 当 LOCK 级别 (TIM1_BDTR 寄存器中的 LOCK 位) 设为 2 时, 该位不能被修改。</p>                                                                                                                                                                            |
| 9: 8 | LOCK  | <p>锁定设置 (Lock configuration)<br/>         该位定义了寄存器的写保护功能。</p> <p>00: 写保护功能关闭, 寄存器无写保护<br/>         01: 锁定级别 1, 不能写入 TIM1_BDTR 寄存器的 DOE、DTG、BKE、BKP、AOE 位和 TIM1_CR2 寄存器的 OISx/OISxN 位<br/>         10: 锁定级别 2, 不能写入锁定级别 1 中的各位, 也不能写入 CC 极性位 (当相关通道通过 CCxS 位设为输出时, CC 极性位是 TIM1_CCER 寄存器的 CCxP/CCxNP 位) 以及 OSSR/OSSI 位<br/>         11: 锁定级别 3, 不能写入锁定级别 2 中的各位, 也不能写入 CC 控制位 (当相关通道通过 CCxS 位设为输出时, CC 控制位是 TIM1_CCMRx 寄存器的 OCxM/OCxPE 位)<br/>         注: 在系统复位后, LOCK 位只能写一次, 当写入 TIM1_BDTR 寄存器后, LOCK 被写保护。</p> |
| 7: 0 | DTG   | <p>死区发生器设置 (Dead-time generator setup)<br/>         这些位定义了插入互补输出之间的死区持续时间。<br/>         注: 当 LOCK 级别 (TIM1_BDTR 寄存器中的 LOCK 位) 设为 1、2 或 3 时, 不能修改这些位。</p>                                                                                                                                                                                                                                                                                                                                                         |

### 10.5.19 TIM1\_CCMR3 捕获/比较模式寄存器 3

偏移地址: 0x54

复位值: 0x0000

通道仅适用于比较输出模式

|      |    |    |    |    |    |   |   |   |   |       |      |   |   |   |   |
|------|----|----|----|----|----|---|---|---|---|-------|------|---|---|---|---|
| 15   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5     | 4    | 3 | 2 | 1 | 0 |
| Res. |    |    |    |    |    |   |   |   |   | OC5PE | Res. |   |   |   |   |

|  |    |  |
|--|----|--|
|  | rw |  |
|--|----|--|

| Bit   | Field    | Description                                                                                                                                                                                                                                              |
|-------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15: 4 | Reserved | 保留，必须保持复位值。                                                                                                                                                                                                                                              |
| 3     | OC5PE    | <p>比较输出 5 预装载使能 (Output compare 5 preload enable)</p> <p>0: 禁止 TIM1_CCR5 寄存器的预装载功能，写入 TIM1_CCR5 寄存器的数值立即生效。</p> <p>1: 开启 TIM1_CCR5 寄存器的预装载功能，读写操作仅对预装载寄存器操作，TIM1_CCR5 的预装载值在更新事件到来时生效。</p> <p>注 1: 当 LOCK 级别设为 3 (TIM1_BDTR 寄存器中的 LOCK 位) 时，该位不能被修改。</p> |
| 2: 0  | Reserved | 保留，必须保持复位值。                                                                                                                                                                                                                                              |

### 10.5.20 TIM1\_CCR5 捕获/比较寄存器 5

偏移地址: 0x58

复位值: 0x0000

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

| Bit   | Field | Description                                                                                                                                                                                                                                  |
|-------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15: 0 | CCR5  | <p>比较 5 的值 (Compare 5 value)</p> <p>CC5 通道只能配置为输出：</p> <p>如果在 TIM1_CCMR3 寄存器 (OC5PE 位) 中未选择预装载功能，写入的数值会立即传输至对应的当前捕获/比较影子寄存器中。否则只有当更新事件发生时，此预装载值才传输至对应的当前捕获/比较影子寄存器中。当前捕获/比较影子寄存器参与同计数器 TIM1_CNT 的比较，由于 CC5 通道为内部通道，无法输出至引脚，比较结果用于内部触发事件。</p> |

### 10.5.21 TIM1\_PDER PWM 移相使能寄存器

偏移地址: 0x5C

复位值: 0x0000

|      |    |    |    |    |    |   |   |                       |                       |                       |                       |                       |      |   |   |
|------|----|----|----|----|----|---|---|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|------|---|---|
| 15   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7                     | 6                     | 5                     | 4                     | 3                     | 2    | 1 | 0 |
| Res. |    |    |    |    |    |   |   |                       |                       |                       |                       |                       |      |   |   |
|      |    |    |    |    |    |   |   | CCR5_<br>SHIFT_<br>EN | CCR4_<br>SHIFT_<br>EN | CCR3_<br>SHIFT_<br>EN | CCR2_<br>SHIFT_<br>EN | CCR1_<br>SHIFT_<br>EN | Res. |   |   |

|  |           |           |           |           |           |  |
|--|-----------|-----------|-----------|-----------|-----------|--|
|  | <b>rw</b> | <b>rw</b> | <b>rw</b> | <b>rw</b> | <b>rw</b> |  |
|--|-----------|-----------|-----------|-----------|-----------|--|

| Bit   | Field         | Description                                                                                 |
|-------|---------------|---------------------------------------------------------------------------------------------|
| 15: 6 | Reserved      | 保留，必须保持复位值。                                                                                 |
| 5     | CCR5_SHIFT_EN | 允许通道 5 输出 PWM 移相使能位<br>0: 禁止通道 5 输出 PWM 移相<br>1: 允许通道 5 输出 PWM 移相<br>具体见 CCRxFALL 寄存器描述移相操作 |
| 4     | CCR4_SHIFT_EN | 允许通道 4 输出 PWM 移相使能位<br>0: 禁止通道 4 输出 PWM 移相<br>1: 允许通道 4 输出 PWM 移相<br>具体见 CCRxFALL 寄存器描述移相操作 |
| 3     | CCR3_SHIFT_EN | 允许通道 3 输出 PWM 移相使能位<br>0: 禁止通道 3 输出 PWM 移相<br>1: 允许通道 3 输出 PWM 移相<br>具体见 CCRxFALL 寄存器描述移相操作 |
| 2     | CCR2_SHIFT_EN | 允许通道 2 输出 PWM 移相使能位<br>0: 禁止通道 2 输出 PWM 移相<br>1: 允许通道 2 输出 PWM 移相<br>具体见 CCRxFALL 寄存器描述移相操作 |
| 1     | CCR1_SHIFT_EN | 允许通道 1 输出 PWM 移相使能位<br>0: 禁止通道 1 输出 PWM 移相<br>1: 允许通道 1 输出 PWM 移相<br>具体见 CCRxFALL 寄存器描述移相操作 |
| 0     | Reserved      | 保留，必须保持复位值。                                                                                 |

### 10.5.22 TIM1\_CCRxFALL PWM 移相递减计数捕获/比较寄存器

偏移地址: 0x60 ~ 0x70

复位值: 0x0000

|           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 15        | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| CCRx FALL |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>rw</b> |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit   | Field     | Description                                                                                                                    |
|-------|-----------|--------------------------------------------------------------------------------------------------------------------------------|
| 15: 0 | CCRx FALL | 通道 x 在 PWM 中央对齐模式递减计数时的捕获/比较值<br>PWM 移相功能: 开启 PDER 寄存器的 PWM 移相使能, 根据需要移动相位, 配置 CCRxFALL 以及 CCRx, 即可实现 PWM 输出可编程的移相波形, 可左移或是右移。 |

### 10.5.23 TIM1\_BKINF 刹车输入滤波寄存器

偏移地址: 0x74

复位值: 0x0000 0000

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|
| 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16     |
| Res.     |    |    |    |    |    |    |    |    |    |    |    |    |    |    | BKIN_S |
| EL       |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW     |
| 15       | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0      |
| BKIN_SEL |    |    |    |    |    |    |    |    |    |    |    |    |    |    | BKINF  |
| RW       |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW     |

| Bit    | Field    | Description                                                                                                                                                                                                                                                                                                         |
|--------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31: 17 | Reserved | 保留, 必须保持复位值。                                                                                                                                                                                                                                                                                                        |
| 16: 5  | BKIN_SEL | BKINSEL: 刹车输入选择 (break input sel)<br>xxxxxxxxxxxx1x: 若第 1bit 为 1, 则选择 PA[4]输入信号<br>xxxxxxxxxxxx1: 若第 0bit 为 1, 则选择 CSS 信号                                                                                                                                                                                           |
| 4: 1   | BKINF    | BKIN 数字滤波采样频率(break input filter)<br>0000: 2 周期<br>0001: 4 周期<br>0010: 8 周期<br>0011: 16 周期<br>0100: 32 周期<br>0101: 64 周期<br>0110: 128 周期<br>0111: 256 周期<br>1000: 384 周期<br>1001: 512 周期<br>1010: 640 周期<br>1011: 768 周期<br>1100: 896 周期<br>1101: 1024 周期<br>1110: 1152 周期<br>1111: 1280 周期<br>注: 更改档位时应先关闭刹车滤波使能位。 |

| Bit | Field  | Description                                                                                                                                                                                                               |
|-----|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | BKINFE | <p>BKIN 数字滤波使能(break input filter enable)</p> <p>1: 使能 BKIN 管脚数字滤波</p> <p>0: 禁止 BKIN 管脚数字滤波</p> <p>注: 滤波使能信号在刹车条件配置之后打开。</p> <p>滤波功能用于过滤电平。</p> <p>滤波功能仅用于 port 输入 bkin 信号。CSS 信号为内部信号，无需滤波。</p> <p>比较器配置滤波功能，无需再次滤波。</p> |

## 11 TIM3 通用定时器

### 11.1 简介

TIM3 由一个 16 位可实时编程预分频器和一个 16 位计数方向可调的自动重装载计数器组成，可以为用户提供便捷的计数定时功能，计数器时钟由预分频器分频得到。通用定时器具有多种用途，如输入功能（测量输入信号的脉冲宽度、频率，PWM 输入等），输出功能（PWM 输出、单脉冲模式输出等）。

### 11.2 功能框图



图 11-1 TIM3 结构图

上图为 TIM3 的结构框图，主要由输入单元、输出单元、时基单元、捕获/比较模块等结构组成。

### 11.3 主要特征

- 16 位可实时编程预分频器，分频系数：1–65536 可调
- 时钟源可选：内部时钟源，外部时钟输入，内部触发输入
- 16 位自动重装载计数器（计数方向：递增、递减、递增/递减）
- 输入捕获：输入信号的脉冲宽度、周期的测量

- 触发输入可以作为外部时钟或者逐周期管理
- 支持编码器、霍尔传感器等接口
- 4 个输出通道
- 比较输出（控制输出波形或指示定时器已经计时结束）
- PWM 输出（边沿对齐或中央对齐模式）
- 单脉冲输出
- 产生中断请求的事件：更新事件、触发事件、输入捕获、比较输出

## 11.4 功能描述

### 11.4.1 时钟

#### 11.4.1.1 时钟选择

计数器的时钟源有以下几种：

- 内部时钟 (INT\_CK)
- 外部时钟模式 1：外部触发输入 TRGI (包含 TIx、ITRx、ETRx)
- 外部时钟模式 2：外部触发输入 ETR (包含 ETRx)
- 编码器模式

上述几种时钟选择示意图如下：



图 11-2 时钟选择

#### 11.4.1.1.1 内部时钟源 (INT\_CK)

当配置 TIM3\_SMCR 寄存器的 SMS=000、关闭从模式时，计数器使能打开，预分频器的时钟直接由内部时钟驱动。此时计数器时钟为内部时钟分频后的时钟。

#### 11.4.1.1.2 外部时钟模式 1 (外部触发输入 TRGI, 包含 Tlx、ITRx、ETRx)

当配置 TIM3\_SMCR 寄存器的 SMS = 111 时，选择外部时钟模式 1 (TRGI)。计数器由选定的输入信号的每个上升沿或下降沿驱动。

例：计数器在 TI1 输入端的上升沿递增计数，具体配置如下：

1. 配置 TIM3\_CCMR1 寄存器的 CC1S=01，CC1 通道被配置为输入，IC1 映射在 TI1 上；配置 TIM3\_CCMR1 寄存器的 IC1F[3: 0]，设置输入滤波器带宽；配置 TIM3\_CCER 寄存器 CC1P=0，选择上升沿为有效沿。
2. 配置 TIM3\_SMCR 寄存器的 TS=101，选择 TI1 的作为触发输入源；配置 TIM3\_SMCR 寄存器的 SMS=111，选择外部时钟模式 1。

3. 配置 TIM3\_CR1 寄存器的 DIR=0，选择递增计数模式，配置 TIM3\_CR1 寄存器的 CEN=1，启动计数器。

当 TI1 出现有效边沿时，计数器递增计数一次。TI1 的有效边沿和计数器的实际时钟之间的延时取决于 TI1 输入端同步电路设计。



图 11-3 外部时钟模式 1 下的控制电路

#### 11.4.1.1.3 外部时钟模式 2（外部触发输入 ETR，包含 ETRx）

当配置 TIM3\_SMCR 寄存器的 ECE=1 时，使能外部时钟模式 2，计数器由 ETR 信号上的有效边沿驱动。

例：ETR 的每 4 个下降沿计数一次，递增计数，具体配置如下：

1. 配置 TIM3\_SMCR 寄存器的 ETF[3: 0]=0010，每 4 个 ETR 信号的有效边沿驱动计数器计数一次；配置 TIM3\_SMCR 寄存器的 ETP=1，选择下降沿有效；配置 TIM3\_SMCR 寄存器的 ECE=1，选择外部时钟模式 2。

2. 配置 TIM3\_CR1 寄存器的 DIR=0，选择递增计数模式；配置 TIM3\_CR1 寄存器的 CEN=1，启动计数器。

在 ETR 的下降沿和计数器实际时钟之间的延时取决于在 ETR 信号端的同步电路设计。



图 11-4 外部时钟模式 2 下的控制电路

#### 11.4.1.1.4 编码器模式

具体参考从模式-编码器接口章节。

#### 11.4.1.2 时基单元

TIM3 的时基单元主要包括：计数器寄存器 (TIM3\_CNT)、预分频器寄存器 (TIM3\_PSC) 和自动预装载寄存器 (TIM3\_ARR)。

计数单元由一个 16 位的计数器和对应的自动预装载寄存器组成，可以实现递增计数，递减计数，递增和递减计数的功能。

计数器的时钟由预分频器提供，预分频器由预分频计数器和对应的寄存器组成，分频系数为 1-65536，可以随时写入，在下一次更新事件时生效。

自动预装载寄存器有预装载功能的 16 位影子寄存器，通过设置 **TIM3\_CR1** 寄存器的 **ARPE** 位选择写入 **ARR** 寄存器的值立即生效或发生更新事件时载入影子寄存器。



图 11-5 自动预装载

#### 11.4.1.3 计数模式

通过配置 **TIM3\_CR1** 寄存器的 **DIR** 位和 **CMS** 位可以选择计数器的计数模式，可以分为三种计数模式，递增计数模式、递减计数模式和中央对齐计数模式（递增/递减计数模式），下面对每种计数模式做详细介绍。

##### 11.4.1.3.1 递增计数模式

配置 **TIM3\_CR1** 寄存器 **CMS=0**, **DIR=0**, 选择递增计数模式。

递增计数模式下，在使能 **TIM3\_CR1** 寄存器的 **CEN** 后计数器由 0 开始递增计数，直至 **TIM3\_ARR** 的值，产生一个计数器上溢事件（更新事件），并从 0 开始重新递增计数。设置 **TIM3\_EGR** 寄存器的 **UG=1**，同样可以产生一个更新事件。



图 11-6 递增计数模式 (UDIS=0)

通过配置 **TIM3\_CR1** 寄存器的 **UDIS=1**，可禁止产生更新事件，当计数器发生上溢事件时，不产生更新事件。此时若配置 **UG=1**，不产生更新事件，但是计数器和预分频器计数器会被初始化，从零开始递增计数。



图 11-7 递增计数模式 (UDIS=1 禁止产生更新事件)

注：发生更新事件时

- ARR 寄存器中的值被载入 ARR 影子寄存器中。
- 预分频器的预装载值生效。

#### 11.4.1.3.2 递减计数模式

配置 TIM3\_CR1 寄存器的 CMS=0, DIR=1, 选择递减计数模式。

递减计数模式下，计数器从自动预装载值 TIM3\_ARR 开始递减计数，计数到 0 时，产生一个下溢事件（更新事件）。设置 TIM3\_EGR 寄存器的 UG=1，同样可以产生一个更新事件，更新事件后计数器从自动预装载值 TIM3\_ARR 开始重新递减计数 (TIM3\_CR1 寄存器 UDIS=0)。



图 11-8 递减计数模式 (UDIS=0)

通过配置 TIM3\_CR1 寄存器的 UDIS=1，可禁止产生更新事件，当计数器发生下溢事件时，不产生更新事件。此时若配置 UG=1，同样不产生更新事件，但是计数器和预分频器计数器会被初始化，从 TIM3\_ARR 开始计数。



图 11-9 递减计数模式 (UDIS=1 禁止产生更新事件)

#### 11.4.1.3.3 中央计数模式（递增/递减计数模式）

配置 TIM3\_CR1 寄存器的 CMS ≠ 0 (此时写入 DIR 无效)，选择中央对齐计数模式。

中央对齐计数模式，递增计数和递减计数交替进行。递增计数到 ARR-1 时，产生一个上溢事件，然后从 ARR 开始递减计数到 1，产生一个下溢事件，再从 0 开始递增计数。

设置 TIM3\_EGR 寄存器的 UG=1，同样可以产生一个更新事件，更新事件后计数器从 0 开始重新递增计数（TIM3\_CR1 寄存器 UDIS=0）。



图 11-10 中央计数模式 (UDIS=0)

通过配置 TIM3\_CR1 寄存器的 UDIS=1，可禁止产生更新事件，当计数器发生上溢或下溢事件时，不产生更新事件。此时若配置 UG=1，同样不产生更新事件，但是计数器和预分频器计数器会被初始化，从零开始重新计数。



图 11-11 中央计数模式 (UDIS=1 禁止产生更新事件)

## 11.4.2 输入捕获

### 11.4.2.1 输入捕获

输入捕获部分包括数字滤波器、多路复用、预分频器等，其结构如下图所示：



图 11-12 TIM3 输入捕获结构图

通过配置 TIM3\_CCMRx 寄存器的 ICxF，可以设置数字滤波器的滤波宽度（滤波器的采样频率及数字滤波宽度如下表所示），当数字滤波器的输入信号宽度大于滤波宽度时，输入信号有效；数字滤波器对输入

引脚  $Tlx$  的输入信号采样后，产生一个滤波后的信号  $TlxPF$ ，然后通过极性可选的边沿检测器，产生一个有效信号  $TlxFPx$ ，这个信号可以作为从模式控制器的触发输入信号，同时该信号经过预分频器产生一个信号  $ICxPS$ ，用于触发输入捕获事件。

表 11-1 数字滤波器宽度与  $ICxF$  的对应关系表

| $IC1F[3: 0]$ | 采样频率和滤波宽度                            | $IC1F[3: 0]$ | 采样频率和滤波宽度                           |
|--------------|--------------------------------------|--------------|-------------------------------------|
| 0000         | 无滤波器，以 $f_{DTS}$ 采样                  | 1000         | 采样频率 $f_{sampling}=f_{DTS}/8, N=6$  |
| 0001         | 采样频率 $f_{sampling}=f_{INT\_CK}, N=2$ | 1001         | 采样频率 $f_{sampling}=f_{DTS}/8, N=8$  |
| 0010         | 采样频率 $f_{sampling}=f_{INT\_CK}, N=4$ | 1010         | 采样频率 $f_{sampling}=f_{DTS}/16, N=5$ |
| 0011         | 采样频率 $f_{sampling}=f_{INT\_CK}, N=8$ | 1011         | 采样频率 $f_{sampling}=f_{DTS}/16, N=6$ |
| 0100         | 采样频率 $f_{sampling}=f_{DTS}/2, N=6$   | 1100         | 采样频率 $f_{sampling}=f_{DTS}/16, N=8$ |
| 0101         | 采样频率 $f_{sampling}=f_{DTS}/2, N=8$   | 1101         | 采样频率 $f_{sampling}=f_{DTS}/32, N=5$ |
| 0110         | 采样频率 $f_{sampling}=f_{DTS}/4, N=6$   | 1110         | 采样频率 $f_{sampling}=f_{DTS}/32, N=6$ |
| 0111         | 采样频率 $f_{sampling}=f_{DTS}/4, N=8$   | 1111         | 采样频率 $f_{sampling}=f_{DTS}/32, N=8$ |

输入捕获模式下，当检测到信号  $ICx$  上的有效边沿后，计数器的当前值被锁存到对应的影子寄存器上，再复制到对应的捕获比较寄存器中。当开启了中断使能，发生捕获事件时，将产生相应的中断请求。发生捕获事件时，会将状态寄存器（ $TIM3\_SR$ ）中的捕获标志位  $CCxIF$  置 1，通过配置  $CCxIF=0$  或读取  $TIM3\_CCRx$  中的数据，清除  $CCxIF$  标志位。当  $CCxIF$  未被清零时，发生输入捕获事件，重复捕获标志位  $CCxOF$  将会被置 1，通过配置  $CCxOF=0$ ，可以清除  $CCxOF$  标志位。

例如，通过采样  $TI1$  输入信号的有效沿，在  $TI1$  的上升沿来到时捕获当前计数器的值，锁存到  $TIM3\_CCR1$  寄存器中，步骤如下：

1. 配置  $TIM3\_CCMR1$  寄存器的  $CC1S=01$ ， $CC1$  通道被配置为输入， $IC1$  映射在  $TI1$  上。
2. 配置  $TIM3\_CCMR1$  寄存器的  $IC1F[3: 0]$ ，配置数字滤波器的滤波宽度（按需配置）。
3. 配置  $TIM3\_CCER$  寄存器的  $CC1P=0$ ，选择捕获发生在  $TI1$  信号的上升沿。
4. 配置  $TIM3\_CCMR1$  寄存器的  $IC1PSC[1:0]$ ，选择预分频系数。
5. 配置  $TIM3\_CCER$  寄存器的  $CC1E = 1$ ，开启输入/捕获通道 1 的捕获使能。
6. 配置  $TIM3\_DIER$  寄存器的  $CC1IE=1$ ，使能通道 1 的捕获/比较通道 1 中断请求。

注：

- 当通道配置为输入模式时， $TIM3\_CCRx$  寄存器属性变为只读。
- 如果发生了两次以上连续捕获，但  $CCxIF$  标志未被清零，则重复捕获标志  $CCxOF$  被置 1。为了避免丢失重复捕获标志  $CCxOF$  置 1 之前可能产生的捕获信息，建议在读出重复捕获标志之前读取数据。
- 设置  $TIM3\_EGR$  寄存器中相应的  $CCxG$  位，可以通过软件产生输入捕获中断请求。

#### 11.4.2.2 PWM 捕获

PWM 输入模式的操作配置与一般输入捕获有以下不同点：

- 两个边沿有效且极性相反的  $ICx$  信号被映射至同一个  $TIx$  输入。

- 配置从模式为复位模式，将其中一路 TIxFP 作为触发输入信号。

例：测量 TI1 的 PWM 信号的宽度（TIM3\_CCR1 寄存器）和占空比（TIM3\_CCR2 寄存器），测量值取决于内部时钟 INT\_CK 的频率和预分频器的值。具体步骤如下：

1. 配置 TIM3\_CR1 寄存器 DIR=0，选择计数器计数模式为递增计数模式。
2. 配置 TIM3\_CCMR1 寄存器的 CC1S = 01，将 IC1 映射在 TI1 上，选择 TIM3\_CCR1 的有效输入。
3. 配置 TIM3\_CCER 寄存器的 CC1P =0，选择 TI1FP1 的有效极性（上升沿有效）（将计数器的值捕获到 TIM3\_CCR1 中并清除计数器）。
4. 配置 TIM3\_CCMR1 寄存器的 CC2S =10，将 IC2 映射在 TI1 上，选择 TIM3\_CCR2 的有效输入。
5. 配置 TIM3\_CCER 寄存器的 CC2P =1，选择 TI2FP2 的有效极性（下降沿有效）（将计数器的值捕获到 TIM3\_CCR2 中）。
6. 配置 TIM3\_SMCR 寄存器中的 TS = 101，选择 TI1FP1 为有效的触发输入信号。
7. 配置 TIM3\_SMCR 中的 SMS = 100，从模式控制器设置为复位模式。
8. 配置 TIM3\_CCER 寄存器中 CC1E=1 且 CC2E = 1。开启 CC1 通道和 CC2 通道的捕获使能。



图 11-13 PWM 输入模式时序

注：由于从模式控制器只连接了 TI1FP1 和 TI2FP2，所以 PWM 输入模式只适用于 TIM3\_CH1/TIM3\_CH2 端口输入信号。

### 11.4.3 比较输出

捕获比较通道的比较输出部分由比较器、输出控制电路和捕获/比较寄存器组成，其结构图如下图所示：



图 11-14 比较输出部分结构图

在比较输出模式下，捕获比较寄存器的内容被载入到影子寄存器中，然后影子寄存器的内容和计数器当前值进行比较。捕获/比较模块包括一个捕获/比较寄存器（预装载寄存器）和一个影子寄存器，读写过程仅操作捕获/比较寄存器。

#### 11.4.3.1 强制输出

配置 `TIM3_CCMRx` 寄存器的 `CCxS = 00`，将通道 `CCx` 设置为输出模式，通过配置 `TIM3_CCMRx` 寄存器 `OCxM` 位，可以直接将比较输出信号直接强制为有效或无效状态，不依赖于比较结果。配置 `TIM3_CCMRx` 寄存器 `OCxM = 100`，强置比较输出信号为无效状态。此时 `OCxREF` 被强置为低电平。配置 `TIM3_CCMRx` 寄存器 `OCxM = 101`，强置比较输出信号为有效状态。此时 `OCxREF` 被强置为高电平（`OCxREF` 始终为高电平有效）。

注：强制输出模式下，在 `TIM3_CCRx` 影子寄存器和计数器之间的比较输出仍在进行，比较结果的相应标志位也会被修改，如果开启了对应的中断请求，仍会产生对应的中断请求。

#### 11.4.3.2 比较输出

比较输出模式下，当计数器与捕获比较寄存器值相同时，可以根据 `TIM3_CCMRx` 寄存器的 `OCxM` 位的配置用来输出不同的波形。

例如，当计数器与捕获/比较寄存器的内容匹配时，比较输出模式下的操作如下：

1. 在比较匹配时，`OCxM` 的值不同，输出通道 `x` 信号 `OCx` 的操作不同：

- ◆ `OCxM = 000`: `OCx` 信号保持它的电平
- ◆ `OCxM = 001`: `OCx` 信号被设置成有效电平
- ◆ `OCxM = 010`: `OCx` 信号被设置成无效电平
- ◆ `OCxM = 011`: `OCx` 信号进行翻转

2. 匹配时中断状态寄存器中的标志位置 1 (`TIM3_SR` 寄存器中的 `CCxIF` 位)。

3. 当配置了 **TIM3\_DIER** 寄存器中的 **CCxIE =1**, 匹配时则产生一个中断。

比较输出模式也可以用来输出一个单脉冲（单脉冲输出模式）。

例如, 通道 1 的比较输出模式的配置步骤如下:

1. 配置计数器的时钟（选择时钟源，配置预分频系数）。
2. 配置 **TIM3\_ARR** 和 **TIM3\_CCR1** 寄存器。
3. 配置 **TIM3\_DIER** 寄存器的 **CC1IE =1**, 使能捕获/比较 1 中断。
4. 配置输出模式:
  - ◆ 配置 **TIM3\_CCMR1** 寄存器的 **OC1M = 011**, OC1 比较匹配时翻转。
  - ◆ 配置 **TIM3\_CCMR1** 寄存器的 **OC1PE = 0** , 禁止 **TIM3\_CCR1** 寄存器的预装载功能。
  - ◆ 配置 **TIM3\_CCER** 寄存器的 **CC1P = 1**, OC1 低电平有效。
  - ◆ 配置 **TIM3\_CCER** 寄存器的 **CC1E = 1**, 开启输出/比较 1 输出使能, OC1 信号输出到对应的输出引脚。
5. 配置 **TIM3\_CR1** 寄存器的 **CEN =1**, 启动计数器。

当配置 **TIM3\_CCMRx** 寄存器中 **OCxPE=0**, 禁止 **TIM3\_CCRx** 寄存器的预装载功能时, 可以随时写入 **TIM3\_CCRx** 寄存器, 并且写入的值立即生效。当配置 **TIM3\_CCMRx** 寄存器中 **OCxPE=1**, 启用 **TIM3\_CCRx** 寄存器的预装载功能时, 读写仅对预装载寄存器进行操作, **TIM3\_CCRx** 预装载寄存器的值在下次更新事件到来时生效。下图给出了一个例子。



图 11-15 比较输出模式, OC1 信号在匹配时翻转

注: 比较输出模式下, 更新事件不会对输出结果产生影响。强制输出模式下, 在 **TIM3\_CCRx** 影子寄存器和计数器之间的比较输出仍在进行, 比较结果的相应标志位也会被修改, 如果开启了对应的中断请求, 仍会产生对应的中断请求。

#### 11.4.3.3 PWM 输出

在 PWM 模式下, 根据 **TIM3\_ARR** 寄存器和 **TIM3\_CCRx** 寄存器的值, 产生一个频率、占空比可控的 PWM 波形。

配置与通道 x 对应的 **TIM3\_CCMRx** 寄存器的 **OCxM=110** 或 **OCxM=111**, 选择通道 x 进入 PWM 模式 1 或 PWM 模式 2。PWM 模式下, 计数器和 **CCRx** 会一直进行比较, 根据配置和比较结果, 通道 x 输出不同的信号, 因此 TIM3 可以产生 4 个同频率下独立占空比的 PWM 输出信号。PWM 模式下可开启 **TIM3\_CCRx** 的预装载功能和 **TIM3\_ARR** 寄存器的预装载功能。写入 **TIM3\_CCRx** 预装载寄存器和 **TIM3\_ARR** 预装载寄存器的值在发生下个更新事件时, 才会生效, 载入相应的影子寄存器。PWM 模式下, 使能计数器前设置 **TIM3\_EGR** 的 **UG=1**, 产生更新事件用于初始化所有的寄存器。

配置 TIM3\_CCER 寄存器的 CCxP 位选择 OCx 的有效极性。配置 TIM3\_CCER 寄存器的 CCxE 位控制 OCx 的输出使能。配置 TIM3\_CR1 寄存器的 CMS 位，可以选择产生边沿对齐或中央对齐的 PWM 信号。

- CMS=00，边沿对齐模式，再进一步配置 DIR，选择递增或递减计数模式。
- CMS=01，中央对齐模式 1。
- CMS=10，中央对齐模式 2。
- CMS=11，中央对齐模式 3。

#### 11.4.3.3.1 PWM 边沿对齐模式——递增计数模式

在递增计数模式配置的基础上，配置 TIM3\_CCMRx 寄存器的 CCxS=00，选择输出模式，OCxM=110，选择 PWM 模式 1，当  $\text{TIM3_CNT} < \text{TIM3_CCRx}$  时通道 x (OCxREF) 为有效电平，否则为无效电平。如果 TIM3\_CCRx 中的比较值大于自动重装载值 (TIM3\_ARR)，则 OCxREF 保持为有效电平。如果比较值为 0，则 OCxREF 保持为无效电平。下图为 CCR1=1，CCR2=4，CCR3=7，CCR4=b，ARR=a 时边沿对齐递增计数时 PWM 模式 1 的波形实例。



图 11-16 边沿对齐递增计数时 PWM 模式 1 的波形

#### 11.4.3.3.2 PWM 边沿对齐模式——递减计数模式

在递减计数模式配置的基础上，配置 TIM3\_CCMRx 寄存器的 CCxS=00，选择输出模式，OCxM=110，选择 PWM 模式 1，当  $\text{TIM3_CNT} > \text{TIM3_CCRx}$  时通道 x (OCxREF) 为无效电平，否则有效电平。下图为 CCR1=4，CCR2=6，CCR3=9，CCR4=b，ARR=a 时边沿对齐递减计数时 PWM 模式 1 的波形实例。



图 11-17 边沿对齐递减计数时 PWM 模式 1 的波形

#### 11.4.3.3.3 PWM 中央对齐模式

首先配置 TIM3 计数器为中央对齐计数模式，配置 TIM3\_CCMRx 寄存器的 CCxS=00，选择输出模式，根据配置不同的 CMS，比较输出中断标志位在计数器递减计数时被设置（CMS=01）、在计数器递增计数时被设置（CMS=10）、或在计数器递增或递减计数时被设置（CMS=11）。下图为 CCR1=4, CCR2=6, CCR3=9, CCR4=b, ARR=a 时中央对齐 PWM 模式 1 的波形实例。



图 11-18 中央对齐 PWM 模式 1 的波形

注：

- 进入中央对齐模式时，使用当前的递增/递减计数配置，计数方向取决于当前的 DIR 的值。
- 在中央对齐模式下，最好不要修改计数器的值，可能会产生不可预知的结果。当计数器处于递增计数时，写入计数器的值 > TIM3\_ARR，计数器会继续递增计数。直接写入 0 或 ARR，会立即更新计数方向，但不会产生更新事件。
- 建议使用中央对齐模式时，在启动计数器之前配置 TIM3\_EGR 寄存器的 UG=1，产生一个软件更新，更新所有寄存器，启动计数器后不要修改计数器的值。

#### 11.4.3.4 外部事件清除 OCxREF

在配置 TIM3\_CCMR 寄存器的 OCxCE=1 时，OCxREF 可以被 ETR 输入端的有效电平拉低直到发生下一次更新事件（UEV）。此功能只能用于比较输出模式和 PWM 模式，不能用于强制输出模式。

例，OCxREF 信号连到一个外部输入时，ETR 配置如下：

1. 配置 TIM3\_SMCR 寄存器的 ETPS[1: 0]=00，关闭外部触发预分频。
2. 配置 TIM3\_SMCR 寄存器 ECE=0，禁用外部时钟模式 2。
3. 配置 TIM3\_SMCR 寄存器 ETF[3: 0]和 ETP，配置 ETR 信号的触发极性和滤波宽度。

下图显示了当 ETR 输入变化触发 ETRF 为高时，对应不同 OCxCE 的值，OCxREF 信号的动作（PWM 模式）。



图 11-19 外部事件清除 OCxREF

#### 11.4.3.5 单脉冲输出

单脉冲模式 (OPM) 下，计数器响应一个激励，产生一个脉宽可调的脉冲。配置 TIM3\_CR1 寄存器的 OPM=1，选择单脉冲模式，触发信号有效沿或配置 CEN=1 都可以启动计数器，直到下一个更新事件发生或配置 CEN=0 时，计数器停止计数。

产生脉冲的必要条件是比较值与计数器的初始值不同。所以在计数器启动之前的必要配置如下：

- 递增计数方式：计数器  $CNT < CCRx \leq ARR$ 。
- 递减计数方式：计数器  $CNT > CCRx$ 。



图 11-20 单脉冲模式

例如，在 TI2 检测到上升沿，延迟  $t_{DELAY}$  之后，在 OC2 上产生一个长度为  $t_{PULSE}$  的正脉冲。

配置 TI2FP2 作为触发源：

1. 配置 TIM3\_CCMR1 寄存器中的 CC2S = 01，将 TI2FP2 映射到 TI2。
2. 配置 TIM3\_CCER 寄存器中的 CC2P = 0，检测 TI2FP2 的上升沿。
3. 配置 TIM3\_SMCR 寄存器中的 TS = 110，TI2FP2 作为从模式控制器的触发 (TRGI)。
4. 配置 TIM3\_SMCR 寄存器中的 SMS = 110，选择触发模式，TI2FP2 使能计数器工作。

OPM 的波形由 TIM3\_ARR 和 TIM3\_CCR1 决定(要考虑时钟频率和计数器预分频器)：由 TIM3\_CCR1 寄存器的值和 CNT 初始值决定触发信号与单脉冲开始之间的延迟  $t_{DELAY}$ ， $TIM3\_ARR - TIM3\_CCR1$  的值为脉冲的宽度  $t_{PULSE}$ 。

下面是一个产生负脉冲的例子，即发生比较匹配时产生从 1 到 0 的波形，计数器达到预装载值时产生一个从 0 到 1 的波形：

1. 配置 TIM3\_CCMR1 寄存器 OC1M = 111，选择 PWM 模式 2。
2. 配置 TIM3\_CCER 寄存器 CC1P = 1，输出低电平有效。
3. 配置 TIM3\_CCMR1 中 OC1PE = 1 和 TIM3\_CR1 寄存器中 ARPE=1，使能预装载寄存器。

4. 配置 TIM3\_CCR1 寄存器和 TIM3\_ARR 寄存器。
5. 配置 TIM3\_EGR 寄存器 UG=1 产生一个更新事件。
6. 等待在 TI2 上的一个外部触发事件。

此例中, TIM3\_CR1 寄存器中的 DIR=0、CMS=0、OPM=1, 在下一个更新事件(当计数器从自动装载值返回到 0)时停止计数。

#### 11.4.3.5.1 OCx 快速使能

OCx 快速使能, 是单脉冲模式的一种特殊情况。在单脉冲模式下, 通过设置 TIM3\_CCMR 寄存器的 OCxFE=1, 强制 OCxREF 直接响应激励而不是依赖计数器和比较值之间的比较结果, 输出波形和比较匹配时的波形一样。这样可以去除比较的时间, 快速输出比较结果。OCx 快速输出使能只在 PWM 模式下生效。

### 11.4.4 从模式

#### 11.4.4.1 编码器接口

编码器接口模式就是计数器在 TI1 和 TI2 正交信号相互作用下计数, 在输入源改变期间, 计数方向被硬件自动修改。通过配置 TIM3\_SMCR 寄存器 SMS 位可以选择输入源, 根据输入源的不同, 可以将编码器接口模式分为 3 种模式, SMS=001, 编码器接口模式 1; SMS=010, 编码器接口模式 2; SMS=011, 编码器接口模式 3; 三种模式具体计数操作如下表所示。两个输入 TI1 和 TI2 被用来作为正交编码器的接口。

编码器模式下, 计数器开启之前必须先配置好 ARR 寄存器, 因为使用编码器接口模式相当于使用了一个带有方向选择的外部时钟。计数器在 0 到 TIM3\_ARR 寄存器的自动装载值之间连续计数(递增计数和递减计数由外部时钟控制)。

注: 编码器模式不支持外部时钟模式 2。

编码器接口模式下, 计数器依照增量编码器的速度和方向被自动的修改, 因此计数器的内容始终指示着编码器的位置。计数方向与相连的传感器旋转的方向对应。下表列出了所有可能的组合, 假设 TI1 和 TI2 不同时变换。

表 11-2 计数方向与编码器信号的关系

| 计数模式                  | 相对电平 (TI1FP1 相对于 TI2, TI2FP2 相对于 TI1) | TI1FP1 信号 |    | TI2FP2 信号 |      |
|-----------------------|---------------------------------------|-----------|----|-----------|------|
|                       |                                       | 上升        | 下降 | 上升        | 下降   |
| 编码器接口模式 1 (只在 TI2 计数) | 高电平                                   | -         | -  | 递增计数      | 递减计数 |

| 计数模式                       | 相对电平 (TI1FP1 相对于 TI2, TI2FP2 相对于 TI1) | TI1FP1 信号 |      | TI2FP2 信号 |      |
|----------------------------|---------------------------------------|-----------|------|-----------|------|
|                            |                                       | 上升        | 下降   | 上升        | 下降   |
| 编码器接口模式 1 (只在 TI2 计数)      | 低电平                                   | -         | -    | 递减计数      | 递增计数 |
| 编码器接口模式 2 (只在 TI1 计数)      | 高电平                                   | 递减计数      | 递增计数 | -         | -    |
| 编码器接口模式 2 (只在 TI1 计数)      | 低电平                                   | 递增计数      | 递减计数 | -         | -    |
| 编码器接口模式 3 (在 TI1 和 TI2 计数) | 高电平                                   | 递减计数      | 递增计数 | 递增计数      | 递减计数 |
| 编码器接口模式 3 (在 TI1 和 TI2 计数) | 低电平                                   | 递增计数      | 递减计数 | 递减计数      | 递增计数 |

下例是计数器在编码器模式下的配置和时序图，从图中可以看出计数信号的产生和方向控制。具体配置如下：

1. 配置 TIM3\_CCMR 寄存器的 CC1S=01, 将 IC1FP1 映射到 TI1 上。
2. 配置 TIM3\_CCMR 寄存器的 CC2S =01, 将 IC2FP2 映射到 TI2 上。
3. 配置 TIM3\_CCER 寄存器的 CC1P =0, IC1 不反相, 此时 IC1=TI1。
4. 配置 TIM3\_CCER 寄存器的 CC2P =0, IC2 不反相, 此时 IC1=TI2。
5. 配置 TIM3\_SMCR 寄存器的 SMS =011, 选择编码器模式 3, 根据另一个信号的输入电平, 计数器在 TI1FP1 和 TI2FP2 的边沿计数。
6. 配置 TIM3\_CR1 寄存器的 CEN =1, 开启计数器。



图 11-21 编码器模式下的计数器时序图

下图为当 IC1FP1 反相时计数器的时序图 (CC1P = 1, 其他配置不变)



图 11-22 IC1FP1 反相编码器接口模式时序图

编码器接口模式下, 计数器可以提供传感器当前位置的信息。通过使用另一个配置在捕获模式的定时器测量两个编码器事件的间隔周期来获得动态的信息 (速度, 加速度, 减速度)。根据两个编码器事件的间隔周期, 可以定期读取计数器。可以通过把计数器的值锁存到第三个输入捕获寄存器 (捕获信号必须是周期性的并且可以由另一个定时器产生) 来实现计数器的定期读取。

#### 11.4.4.2 复位模式

配置 TIM3\_SMCR 寄存器的 SMS=100，从模式选择复位模式。此模式下，TRGI 输入事件会使计数器清零重启。

例如，TI2 输入端的下降沿触发计数器重启：

1. 配置 TIM3\_CCMR1 寄存器的 CC2S=01，CC2 通道被配置为输入模式；IC2 映射在 TI2 上，配置 TIM3\_CCER 寄存器的 CC2P=1，检测下降沿。
2. 配置 TIM3\_SMCR 寄存器的 SMS = 100，从模式选择复位模式；配置 TIM3\_SMCR 寄存器的 TS = 110，选择滤波后的定时器输入 2 (TI2FP2) 作为同步计数器的触发输入。
3. 配置 TIM3\_CR1 寄存器的 DIR=0，选择计数方向为递增计数；配置 PSC=0，不分频；配置 CEN=1，使能计数器。

计数器的时钟源由内部时钟提供，当检测到 TI2 的下降沿，计数器被清零重启。此时触发器中断标记被硬件置 1。

下图为复位模式下 TIM3\_ARR = 0x13 的时序图。



图 11-23 复位模式的控制时序图

#### 11.4.4.3 门控模式

配置 TIM3\_SMCR 寄存器 SMS=101，从模式选择门控模式。此模式下，根据 TIM3\_CCER 寄存器 CCxP 的值来选择有效电平（0：高电平有效，1：低电平有效）。TRGI 输入为有效电平时，计数器始终开启，否则计数器停止（但不发生复位操作），计数器的开启和停止可控。

例如，计数器只在 TI1 为高时计数：

1. 配置 TIM3\_CCMR1 寄存器的 CC1S=01，CC1 通道被配置为输入模式，IC1 映射在 TI1 上；配置 TIM3\_CCER 寄存器的 CC1P=0，检测 TI1 上的高电平。
2. 配置 TIM3\_SMCR 寄存器的 SMS=101，从模式选择为门控模式；配置 TIM3\_SMCR 寄存器的 TS=101，选择滤波后的定时器输入 1 (TI1FP1) 作为同步计数器的触发输入。
3. 配置 TIM3\_CR1 寄存器的 DIR=0，选择计数方向为递增计数；配置 PSC=0，不分频；配置 CEN=1，使能计数器。

计数器的时钟源由内部时钟提供，当检测到 TI1 的高电平，计数器开始计数，当 TI1 为低电平时，计数器停止计数。计数器停止会将 TIF 置 1。

下图为门控模式下 TIM3\_ARR=0xf 的时序图。



图 11-24 门控模式下的控制时序图

#### 11.4.4.4 触发模式

配置 TIM3\_SMCR 寄存器 SMS=110，从模式选择触发模式。根据 TIM3\_CCER 寄存器 CCxP 的值来选择有效边沿（0：上升沿有效，1：下降沿有效），TRGI 输入为有效边沿时，计数器开始计数。计数器的启动可控，停止不可控。

例如，计数器在 TI1 输入的上升沿开始计数：

1. 配置 TIM3\_CCMR1 寄存器的 CC1S=01，CC1 通道被配置为输入模式，IC1 映射在 TI1 上，配置 TIM3\_CCER 寄存器的 CC1P=0，检测上升沿。
2. 配置 TIM3\_SMCR 寄存器的 SMS = 110，从模式选择为触发模式；配置 TIM3\_SMCR 寄存器的 TS=101，选择滤波后的定时器输入 1 (TI1FP1) 作为计数器的触发输入。
3. 配置 TIM3\_CR1 寄存器的 DIR=0，选择计数方向为递增计数；配置 PSC=0，不分频。

计数器的时钟源由内部时钟提供，当检测到 TI1 的上升沿，计数器开始计数。

下图为触发模式下 TIM3\_ARR=0xf 的时序图。



图 11-25 触发器模式下的控制时序图

#### 11.4.4.5 外部时钟模式 2+从模式

当时钟源选择外部时钟模式 2、ETR 信号被用作外部时钟的输入时，可以与从模式一起使用。这种使用方式时，从模式仅支持复位模式、门控模式、触发模式，不支持外部时钟模式 1 和编码器模式。

例如，从模式选择触发模式，计数器在 ETR 的每一个上升沿计数一次：

1. 配置 TIM3\_SMCR 寄存器的 ETF = 0000，不使用数字滤波器；配置 TIM3\_SMCR 寄存器的 ETPS = 00，关闭预分频；配置 TIM3\_SMCR 寄存器的 ETP = 0，检测 ETR 的上升沿；配置 TIM3\_SMCR 寄存器的 ECE = 1，使能外部时钟模式 2。
2. 配置 TIM3\_CCMR1 寄存器的 CC1S=01，CC1 通道被配置为输入，IC1 映射在 TI1 上作为输入捕获源；配置 TIM3\_CCER 寄存器的 CC1P=0，选择上升沿有效。
3. 配置 TIM3\_SMCR 寄存器的 SMS = 110，从模式选择为触发模式。配置 TIM3\_SMCR 寄存器的 TS = 101，选择 TI1 作为输入源。
4. 配置 TIM3\_CR1 寄存器的 DIR=0，选择计数方向为递增计数；配置 PSC=0，不分频。

计数器在 TI1 的上升沿开始计数，并将 TIF 置 1。ETR 信号的上升沿和计数器实际计数时钟间的延时取决于 ETR 输入端的同步电路设计。

下图为外部时钟模式 2+从模式（触发模式）下 TIM3\_ARR=13 时的时序图。



图 11-26 外部时钟模式 2+从模式（触发模式）控制时序图

#### 11.4.5 定时器同步

不同的定时器在内部连接，可以实现定时器之间的级联或同步。

详细描述请参考 TIM1 相关章节。

#### 11.4.6 定时器异或

配置 TIM3\_CR2 寄存器的 TI1S =1，将 TIM3\_CH1、TIM3\_CH2 和 TIM3\_CH3 引脚经异或后连接到 TI1 的输入端，用于定时器的所有输入模式。

例：TIM3\_CH1、TIM3\_CH2 和 TIM3\_CH3 引脚经异或后连接到 TI1 的输入端，采样 TI1 输入信号的有效沿，在 TI1 的上升沿来到时捕获当前计数器的值，锁存到 TIM3\_CCR1 寄存器中。具体配置如下：

1. 配置 TIM3\_CR2 寄存器的 TI1S=1，配置定时器的三个输入经异或后连接到 TI1 输入通道。
2. 配置 TIM3\_CCMR1 寄存器的 CC1S=01，CC1 通道被配置为输入，IC1 映射在 TI1 上。
3. 配置 TIM3\_CCMR1 寄存器的 IC1F[3: 0]，配置数字滤波器的滤波宽度（按需配置）。
4. 配置 TIM3\_CCER 寄存器的 CC1P=0，选择捕获发生在 TI1 信号的上升沿。
5. 配置 TIM3\_CCMR1 寄存器的 IC1PSC，选择预分频系数。
6. 配置 TIM3\_CCER 寄存器的 CC1E = 1，开启输入/捕获通道 1 的捕获使能。
7. 配置 TIM3\_CR1 寄存器的 CEN=1，启动计数器。



图 11-27 (TI1 异或输入) 输入捕获波形图

霍尔接口电路

详细描述请参考 TIM1 相关章节。

### 11.4.7 调试模式

在调试模式下，配置 DBG\_CR 寄存器中 DBG\_TIM3\_STOP=1，TIM3 计数器停止计数。(详见调试章节)

### 11.4.8 中断

TIM3 的中断包括：捕获/比较 1 中断、捕获/比较 2 中断、捕获/比较 3 中断、捕获/比较 4 中断、更新中断、触发中断，当相应的中断使能位打开，发生相应的事件时，产生相应的中断。

表 11-3 中断事件一览表

| 中断事件       | 标志位   | 使能位   |
|------------|-------|-------|
| 捕获/比较 1 中断 | CC1IF | CC1IE |
| 捕获/比较 2 中断 | CC2IF | CC2IE |
| 捕获/比较 3 中断 | CC3IF | CC3IE |
| 捕获/比较 4 中断 | CC4IF | CC4IE |
| 更新中断       | UIF   | UIE   |
| 触发中断       | TIF   | TIE   |

## 11.5 寄存器描述

表 11-4 TIM3 寄存器概览

| Offset | Acronym    | Register Name | Reset  |
|--------|------------|---------------|--------|
| 0x00   | TIM3_CR1   | 控制寄存器 1       | 0x0000 |
| 0x04   | TIM3_CR2   | 控制寄存器 2       | 0x0000 |
| 0x08   | TIM3_SMCR  | 从模式控制寄存器      | 0x0000 |
| 0x0C   | TIM3_DIER  | 中断使能寄存器       | 0x0000 |
| 0x10   | TIM3_SR    | 状态寄存器         | 0x0000 |
| 0x14   | TIM3_EGR   | 事件产生寄存器       | 0x0000 |
| 0x18   | TIM3_CCMR1 | 捕获/比较模式寄存器 1  | 0x0000 |
| 0x1C   | TIM3_CCMR2 | 捕获/比较模式寄存器 2  | 0x0000 |
| 0x20   | TIM3_CCER  | 捕获/比较使能寄存器    | 0x0000 |
| 0x24   | TIM3_CNT   | 计数器           | 0x0000 |
| 0x28   | TIM3_PSC   | 预分频率器         | 0x0000 |
| 0x2C   | TIM3_ARR   | 自动装载寄存器       | 0x0000 |
| 0x34   | TIM3_CCR1  | 捕获/比较寄存器 1    | 0x0000 |
| 0x38   | TIM3_CCR2  | 捕获/比较寄存器 2    | 0x0000 |
| 0x3C   | TIM3_CCR3  | 捕获/比较寄存器 3    | 0x0000 |
| 0x40   | TIM3_CCR4  | 捕获/比较寄存器 4    | 0x0000 |
| 0x50   | TIM3_OR    | 输入选项寄存器       | 0x0000 |

### 11.5.1 TIM3\_CR1 控制寄存器 1

偏移地址: 0x0

复位值: 0x0000

|      |    |    |    |    |     |    |      |     |    |     |     |     |      |     |    |
|------|----|----|----|----|-----|----|------|-----|----|-----|-----|-----|------|-----|----|
| 15   | 14 | 13 | 12 | 11 | 10  | 9  | 8    | 7   | 6  | 5   | 4   | 3   | 2    | 1   | 0  |
| Res. |    |    |    |    | CKD |    | ARPE | CMS |    | DIR | OPM | URS | UDIS | CEN |    |
|      |    |    |    |    |     | rw | rw   |     | rw |     | rw  | rw  | rw   | rw  | rw |

| Bit    | Field    | Description                                                                                                                                                                                                                                                                                                                                     |
|--------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15: 10 | Reserved | 保留, 必须保持复位值。                                                                                                                                                                                                                                                                                                                                    |
| 9: 8   | CKD      | <p>时钟分频 (clock division)<br/>           定义定时器时钟 (INT_CK) 频率与死区时间计数器、数字滤波器 (ETR, TIx) 所用的时钟之间的分频比例。</p> <p>00: <math>t_{DTs} = t_{INT\_CK}</math><br/>           01: <math>t_{DTs} = 2 \times t_{INT\_CK}</math><br/>           10: <math>t_{DTs} = 4 \times t_{INT\_CK}</math><br/>           11: 保留, 不要使用这个配置</p>                              |
| 7      | ARPE     | <p>自动重装载预装载使能 (Auto-reload preload enable)</p> <p>0: 关闭 TIM3_ARR 寄存器的影子寄存器<br/>           1: 使能 TIM3_ARR 寄存器的影子寄存器</p>                                                                                                                                                                                                                          |
| 6: 5   | CMS      | <p>中央对齐模式选择 (Center-aligned mode selection)</p> <p>00: 边沿对齐模式。计数方向取决于 DIR 位<br/>           01: 中央对齐模式 1。计数器交替地递增和递减计数。通道为输出模式, 只在计数器递减计数时比较中断标志位被置 1<br/>           10: 中央对齐模式 2。计数器交替地递增和递减计数。通道为输出模式, 只在计数器递增计数时比较中断标志位被置 1<br/>           11: 中央对齐模式 3。计数器交替地递增和递减计数。通道为输出模式, 在计数器递增和递减计数时比较中断标志位均被置 1<br/>           注: 计数过程中, 不允许更改此位。</p> |
| 4      | DIR      | <p>计数方向 (Direction)</p> <p>0: 计数器递增计数<br/>           1: 计数器递减计数<br/>           注: 当计数器配置为中央对齐模式或编码器模式时, 该位为只读。</p>                                                                                                                                                                                                                              |
| 3      | OPM      | <p>单脉冲模式 (One pulse mode)</p> <p>0: 禁止单脉冲模式, 在发生更新事件时, 计数器继续计数<br/>           1: 使能单脉冲模式, 在发生下一次更新事件或软件清除 CEN 位时, 计数器停止计数</p>                                                                                                                                                                                                                   |

| Bit | Field | Description                                                                                                                                                                                                                 |
|-----|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2   | URS   | <p>更新请求源 (Update request source)<br/>软件配置该位, 选择更新事件源。</p> <p>0: 以下事件可产生一个更新中断请求:</p> <ul style="list-style-type: none"> <li>- 计数器上溢/下溢</li> <li>- 设置 UG 位</li> <li>- 从模式控制器产生的更新</li> </ul> <p>1: 只有计数器上溢/下溢才产生一个更新中断请求</p> |
| 1   | UDIS  | <p>禁止更新 (Update disable)<br/>该位用来允许或禁止更新事件的产生</p> <p>0: 允许更新事件 (UEV)</p> <p>1: 禁止更新事件。不产生更新事件, 影子寄存器 (ARR、PSC、CCRx) 保持值不变。如果设置了 EGR_UG 位为 1, 计数器和预分频器被初始化; 如果从模式控制器接收到硬件复位, 计数器将被初始化。</p>                                   |
| 0   | CEN   | <p>计数器使能 (Counter enable)</p> <p>0: 禁止计数器</p> <p>1: 使能计数器</p> <p>注: 在软件设置了 CEN 位后, 外部时钟、门控模式和编码器模式才能工作。触发模式可以自动地通过硬件设置 CEN 位。</p>                                                                                           |

### 11.5.2 TIM3\_CR2 控制寄存器 2

偏移地址: 0x04

复位值: 0x0000

|      |    |    |    |    |    |   |   |      |     |   |   |      |   |   |   |
|------|----|----|----|----|----|---|---|------|-----|---|---|------|---|---|---|
| 15   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7    | 6   | 5 | 4 | 3    | 2 | 1 | 0 |
| Res. |    |    |    |    |    |   |   | TI1S | MMS |   |   | Res. |   |   |   |
|      |    |    |    |    |    |   |   | rw   | rw  |   |   |      |   |   |   |

| Bit   | Field    | Description                                                                                                         |
|-------|----------|---------------------------------------------------------------------------------------------------------------------|
| 15: 8 | Reserved | 保留, 必须保持复位值。                                                                                                        |
| 7     | TI1S     | <p>TI1 选择 (TI1 selection)</p> <p>0: TIM3_CH1 管脚连到 TI1 输入</p> <p>1: TIM3_CH1、TIM3_CH2 和 TIM3_CH3 管脚经异或后作为 TI1 输入</p> |

| Bit  | Field    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6: 4 | MMS      | <p>主模式选择 (Master mode selection)<br/>     这些位控制 TRGO 信号的选择, 用于选择在主模式下送到从定时器的同步信息:</p> <p>000: 复位 TIM3_EGR 寄存器的 UG 位触发一次 TRGO 脉冲。<br/>     001: 使能 用于控制在一定时间内使能从定时器或同时启动多个定时器。计数器使能信号 CNT_EN 被用于作为触发输出 (TRGO), 计数器使能信号是通过 CEN 控制位和门控模式下的触发输入信号的逻辑或产生。当计数器使能信号受控于触发输入时, TRGO 上会有一个延迟, 除非选择了主/从模式。<br/>     010: 更新 更新事件被选为 TRGO。<br/>     011: 捕获/比较脉冲 发生一次捕获或一次比较成功时, 触发输出送出一个 TRGO 信号。<br/>     100: 比较 OC1REF 信号被用于作为触发输出 (TRGO)<br/>     101: 比较 OC2REF 信号被用于作为触发输出 (TRGO)<br/>     110: 比较 OC3REF 信号被用于作为触发输出 (TRGO)<br/>     111: 比较 OC4REF 信号被用于作为触发输出 (TRGO)</p> |
| 3: 0 | Reserved | 保留, 必须保持复位值。                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

### 11.5.3 TIM3\_SMCR 从模式控制寄存器

偏移地址: 0x08

复位值: 0x0000

|     |     |      |    |     |    |   |     |    |   |   |      |     |   |   |   |
|-----|-----|------|----|-----|----|---|-----|----|---|---|------|-----|---|---|---|
| 15  | 14  | 13   | 12 | 11  | 10 | 9 | 8   | 7  | 6 | 5 | 4    | 3   | 2 | 1 | 0 |
| ETP | ECE | ETPS |    | ETF |    |   | MSM | TS |   |   | OCCS | SMS |   |   |   |
| rw  | rw  | rw   |    | rw  |    |   | rw  | rw |   |   | rw   | rw  |   |   |   |

| Bit | Field | Description                                                                                                                            |
|-----|-------|----------------------------------------------------------------------------------------------------------------------------------------|
| 15  | ETP   | <p>外部触发极性 (External trigger polarity)<br/>     该位选择 ETR 信号的极性。</p> <p>0: 高电平或上升沿有效<br/>     1: 低电平或下降沿有效<br/>     注: 仅适用于支持外部触发的产品</p> |

| Bit    | Field | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14     | ECE   | <p>外部时钟使能位 (External clock enable)<br/>该位启用外部时钟模式 2。<br/>0: 禁止外部时钟模式 2<br/>1: 使能外部时钟模式 2, ETRF 信号上的任意有效沿驱动计数器计数</p> <p>注 1: 仅适用于支持外部触发的产品。<br/>注 2: 配置 ECE=1 与配置 SMS = 111 和 TS = 111 效果一样。<br/>注 3: TS ≠ 111 时, 复位模式, 门控模式和触发模式可以与外部时钟模式 2 同时使用。<br/>注 4: 同时使能外部时钟模式 1 和外部时钟模式 2 时, 外部时钟的输入是 ETR。</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 13: 12 | ETPS  | <p>外部触发预分频 (External trigger prescaler)<br/>外部触发信号 ETRP 的频率必须低于 TIM3 主时钟 PCLK 频率的 1/4。当输入较快的外部时钟时, 可以使用预分频降低 ETRP 的频率。</p> <p>00: 关闭预分频<br/>01: ETRP 频率除以 2<br/>10: ETRP 频率除以 4<br/>11: ETRP 频率除以 8</p> <p>注: 仅适用于支持外部触发的产品。</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 11: 8  | ETF   | <p>外部触发滤波 (External trigger filter)<br/>这些位定义了对 ETRP 信号采样的频率和对 ETRP 数字滤波的带宽。实际上, 数字滤波器是一个事件计数器, 它记录到 N 个事件后会产生一个输出的跳变。</p> <p>0000: 无滤波器, 以 <math>f_{DTS}</math> 采样<br/>0001: 采样频率 <math>f_{sampling} = f_{INT\_CK}</math>, <math>N=2</math><br/>0010: 采样频率 <math>f_{sampling} = f_{INT\_CK}</math>, <math>N=4</math><br/>0011: 采样频率 <math>f_{sampling} = f_{INT\_CK}</math>, <math>N=8</math><br/>0100: 采样频率 <math>f_{sampling} = f_{DTS}/2</math>, <math>N=6</math><br/>0101: 采样频率 <math>f_{sampling} = f_{DTS}/2</math>, <math>N=8</math><br/>0110: 采样频率 <math>f_{sampling} = f_{DTS}/4</math>, <math>N=6</math><br/>0111: 采样频率 <math>f_{sampling} = f_{DTS}/4</math>, <math>N=8</math><br/>1000: 采样频率 <math>f_{sampling} = f_{DTS}/8</math>, <math>N=6</math><br/>1001: 采样频率 <math>f_{sampling} = f_{DTS}/8</math>, <math>N=8</math><br/>1010: 采样频率 <math>f_{sampling} = f_{DTS}/16</math>, <math>N=5</math><br/>1011: 采样频率 <math>f_{sampling} = f_{DTS}/16</math>, <math>N=6</math><br/>1100: 采样频率 <math>f_{sampling} = f_{DTS}/16</math>, <math>N=8</math><br/>1101: 采样频率 <math>f_{sampling} = f_{DTS}/32</math>, <math>N=5</math><br/>1110: 采样频率 <math>f_{sampling} = f_{DTS}/32</math>, <math>N=6</math><br/>1111: 采样频率 <math>f_{sampling} = f_{DTS}/32</math>, <math>N=8</math></p> <p>注: 仅适用于支持外部触发的产品。</p> |

| Bit  | Field | Description                                                                                                                                                                                                                                                                                                                                            |
|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7    | MSM   | <p>主/从 模 式 (Master/slave mode)</p> <p>0: 无作用</p> <p>1: 触发输入 (TRGI) 事件被延迟, 以实现当前定时器 (通过 TRGO) 与它的从定时器间的完美同步, 该功能可以把几个定时器同步到一个单一的外部事件。</p>                                                                                                                                                                                                               |
| 6: 4 | TS    | <p>触发选择 (Trigger selection)</p> <p>触发输入源选择。</p> <p>000: 内部触发 0 (ITR0)<br/>     001: 内部触发 1 (ITR1)<br/>     010: 内部触发 2 (ITR2)<br/>     011: 内部触发 3 (ITR3)<br/>     100: TI1 的边沿检测器 (TI1F_ED)<br/>     101: 滤波后的定时器输入 1 (TI1FP1)<br/>     110: 滤波后的定时器输入 2 (TI2FP2)<br/>     111: 外部触发输入 (ETR)</p> <p>更多有关 ITRx 的细节, 参见下表。</p> <p>注: 从模式使能后这些位不能修改。</p> |
| 3    | OCCS  | <p>比较输出信号 (OCxREF) 清除选择 (Output compare clear selection)</p> <p>在 PWM 模式下, 清除比较输出 (OCxREF)。</p> <p>0: 外部触发信号作为清除信号<br/>     1: 比较器 (COMP) 输出作为清除信号</p> <p>注: 仅适用于支持外部触发或有内置比较器 (COMP) 的产品。</p>                                                                                                                                                         |

| Bit  | Field | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2: 0 | SMS   | <p>从模式选择 (Slave mode selection)<br/>当选择了外部信号作为触发源, 触发信号 (TRGI) 的有效边沿与选中的外部输入极性相关。</p> <p>000: 关闭从模式 - 如果 CEN = 1, 则预分频器直接由内部时钟驱动。</p> <p>001: 编码器模式 1- 根据 TI1FP1 的电平, 计数器在 TI2FP2 的边沿递增/递减计数。</p> <p>010: 编码器模式 2- 根据 TI2FP2 的电平, 计数器在 TI1FP1 的边沿递增/递减计数。</p> <p>011: 编码器模式 3- 根据另一个输入的电平, 计数器在 TI1FP1 和 TI2FP2 的边沿递增/递减计数。</p> <p>100: 复位模式 - 选中的触发输入 (TRGI) 的上升沿重新初始化计数器, 并且产生一个更新事件。</p> <p>101: 门控模式 - 当触发输入 (TRGI) 为高时, 计数器开始计数。当触发输入变为低时, 计数器停止计数 (但不复位), 并且产生一个更新事件。计数器的启动和停止都是受控的。</p> <p>110: 触发模式 - 计数器在触发输入 TRGI 的上升沿启动 (但不复位), 并且产生一个更新事件, 只有计数器的启动是受控的。</p> <p>111: 外部时钟模式 1- 选中的触发输入 (TRGI) 的上升沿驱动计数器。<br/>注: 如果 TI1F_ED 被选为触发输入 (TS = 100) 时, 不要使用门控模式。这是因为, TI1F_ED 在每次 TI1F 变化时输出一个脉冲, 然而门控模式是要检查触发输入的电平。</p> |

表 11-5 TIM3 内部触发连接

| 从定时器 | ITR0      | ITR1 | ITR2      | ITR3         |
|------|-----------|------|-----------|--------------|
| TIM1 | -         | -    | TIM3_TRGO | TIM14_OC1REF |
| TIM3 | TIM1_TRGO | -    | -         | TIM14_OC1REF |

#### 11.5.4 TIM3\_DIER 中断使能寄存器

偏移地址: 0x0C

复位值: 0x0000

|      |    |    |    |    |    |   |   |     |      |       |       |       |       |     |    |
|------|----|----|----|----|----|---|---|-----|------|-------|-------|-------|-------|-----|----|
| 15   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7   | 6    | 5     | 4     | 3     | 2     | 1   | 0  |
| Res. |    |    |    |    |    |   |   | TIE | Res. | CC4IE | CC3IE | CC2IE | CC1IE | UIE |    |
|      |    |    |    |    |    |   |   | rw  |      | rw    | rw    | rw    | rw    | rw  | rw |

| Bit   | Field    | Description  |
|-------|----------|--------------|
| 15: 7 | Reserved | 保留, 必须保持复位值。 |

| Bit | Field    | Description                                                                             |
|-----|----------|-----------------------------------------------------------------------------------------|
| 6   | TIE      | 允许触发中断 (Trigger interrupt enable)<br>0: 禁止触发中断<br>1: 允许触发中断                             |
| 5   | Reserved | 保留, 必须保持复位值。                                                                            |
| 4   | CC4IE    | 允许捕获/比较 4 中断 (Capture/Compare 4 interrupt enable)<br>0: 禁止捕获/比较 4 中断<br>1: 允许捕获/比较 4 中断 |
| 3   | CC3IE    | 允许捕获/比较 3 中断 (Capture/Compare 3 interrupt enable)<br>0: 禁止捕获/比较 3 中断<br>1: 允许捕获/比较 3 中断 |
| 2   | CC2IE    | 允许捕获/比较 2 中断 (Capture/Compare 2 interrupt enable)<br>0: 禁止捕获/比较 2 中断<br>1: 允许捕获/比较 2 中断 |
| 1   | CC1IE    | 允许捕获/比较 1 中断 (Capture/Compare 1 interrupt enable)<br>0: 禁止捕获/比较 1 中断<br>1: 允许捕获/比较 1 中断 |
| 0   | UIE      | 允许更新事件中断 (Update interrupt enable)<br>0: 禁止更新事件中断<br>1: 允许更新事件中断                        |

### 11.5.5 TIM3\_SR 状态寄存器

偏移地址: 0x10

复位值: 0x0000

|      |    |    |       |       |       |       |      |   |       |      |       |       |       |       |     |
|------|----|----|-------|-------|-------|-------|------|---|-------|------|-------|-------|-------|-------|-----|
| 15   | 14 | 13 | 12    | 11    | 10    | 9     | 8    | 7 | 6     | 5    | 4     | 3     | 2     | 1     | 0   |
| Res. |    |    | CC4OF | CC3OF | CC2OF | CC1OF | Res. |   | TIF   | Res. | CC4IF | CC3IF | CC2IF | CC1IF | UIF |
|      |    |    | r_w0c |       |       |       |      |   | r_w0c |      | r_w0c |       |       |       |     |

| Bit    | Field    | Description                                                         |
|--------|----------|---------------------------------------------------------------------|
| 15: 13 | Reserved | 保留, 必须保持复位值。                                                        |
| 12     | CC4OF    | 捕获/比较 4 重复捕获标记 (Capture/Compare 4 overcapture flag)<br>参考 CC1OF 描述。 |
| 11     | CC3OF    | 捕获/比较 3 重复捕获标记 (Capture/Compare 3 overcapture flag)<br>参考 CC1OF 描述。 |
| 10     | CC2OF    | 捕获/比较 2 重复捕获标记 (Capture/Compare 2 overcapture flag)<br>参考 CC1OF 描述。 |

| Bit  | Field    | Description                                                                                                                                                                                                                                                                                                                                                       |
|------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9    | CC1OF    | <p>捕获/比较 1 重复捕获标记 (Capture/Compare 1 overcapture flag)</p> <p>仅当通道 1 被配置为输入捕获, CC1IF 已经为 1 后, 捕获事件再次发生时, 该标记可由硬件置 1。写 0 可清除该位。</p> <p>0: 无重复捕获产生<br/>1: 重复捕获产生</p>                                                                                                                                                                                                |
| 8: 7 | Reserved | 保留, 必须保持复位值。                                                                                                                                                                                                                                                                                                                                                      |
| 6    | TIF      | <p>触发器中断标记 (Trigger interrupt flag)</p> <p>当发生触发事件(当从模式控制器处于除门控模式和外部时钟模式外的其它模式时、在 TRGI 输入端检测到有效边沿, 或门控模式下的计数停止边沿) 时由硬件对该位置 1。它由软件清 0。</p> <p>0: 无触发器事件产生<br/>1: 触发器中断产生</p>                                                                                                                                                                                       |
| 5    | Reserved | 保留, 必须保持复位值。                                                                                                                                                                                                                                                                                                                                                      |
| 4    | CC4IF    | <p>捕获/比较 4 中断标记 (Capture/Compare 4 interrupt flag)</p> <p>参考 CC1IF 描述。</p>                                                                                                                                                                                                                                                                                        |
| 3    | CC3IF    | <p>捕获/比较 3 中断标记 (Capture/Compare 3 interrupt flag)</p> <p>参考 CC1IF 描述。</p>                                                                                                                                                                                                                                                                                        |
| 2    | CC2IF    | <p>捕获/比较 2 中断标记 (Capture/Compare 2 interrupt flag)</p> <p>参考 CC1IF 描述。</p>                                                                                                                                                                                                                                                                                        |
| 1    | CC1IF    | <p>捕获/比较 1 中断标记 (Capture/Compare 1 interrupt flag)</p> <p>通道 1 为输出模式:</p> <p>当计数器值与比较值匹配时该位由硬件置 1 (在中央对齐模式下根据 TIM3_CR1.CMS[1:0]的选择来置位)。它由软件清 0。</p> <p>0: 无匹配发生<br/>1: TIM3_CNT 的值与 TIM3_CCR1 的值匹配</p> <p>通道 1 为输入模式:</p> <p>当发生捕获事件时该位由硬件置 1, 由软件清 0 或读取 TIM3_CCR1 的值清 0。</p> <p>0: 无输入捕获产生<br/>1: 计数器值已被捕获至 TIM3_CCR1</p>                                       |
| 0    | UIF      | <p>更新中断标记 (Update interrupt flag)</p> <p>当产生更新事件时该位由硬件置 1。它由软件清 0。</p> <p>0: 无更新中断发生<br/>1: 发生更新中断</p> <p>当寄存器被更新时该位由硬件置 1:</p> <ul style="list-style-type: none"> <li>- 若 TIM3_CR1 寄存器的 UDIS=0, 且 REP_CNT=0, 当计数器产生上溢/下溢事件时。</li> <li>- 若 TIM3_CR1 寄存器的 UDIS=0、URS=0, 当 TIM3_EGR 寄存器的 UG=1 时。</li> <li>- 若 TIM3_CR1 寄存器的 UDIS=0、URS=0, 从模式控制器产生更新事件时。</li> </ul> |

### 11.5.6 TIM3\_EGR 事件产生寄存器

偏移地址: 0x14

复位值: 0x0000

|      |    |    |    |    |    |   |   |    |      |      |      |      |      |    |   |
|------|----|----|----|----|----|---|---|----|------|------|------|------|------|----|---|
| 15   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7  | 6    | 5    | 4    | 3    | 2    | 1  | 0 |
| Res. |    |    |    |    |    |   |   | TG | Res. | CC4G | CC3G | CC2G | CC1G | UG |   |
|      |    |    |    |    |    |   |   | w  |      | w    | w    | w    | w    | w  | w |

| Bit   | Field    | Description                                                                                                                                                                                                                                             |
|-------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15: 7 | Reserved | 保留, 必须保持复位值。                                                                                                                                                                                                                                            |
| 6     | TG       | 产生触发事件 (Trigger generation)<br>0: 无动作<br>1: 产生触发事件, TIM3_SR 寄存器的 TIF = 1, 若开启对应的中断, 则产生相应的中断, 由硬件自动清 0。                                                                                                                                                 |
| 5     | Reserved | 保留, 必须保持复位值。                                                                                                                                                                                                                                            |
| 4     | CC4G     | 产生捕获/比较 4 事件 (Capture/Compare 4 generation)<br>参考 CC1G 描述。                                                                                                                                                                                              |
| 3     | CC3G     | 产生捕获/比较 3 事件 (Capture/Compare 3 generation)<br>参考 CC1G 描述。                                                                                                                                                                                              |
| 2     | CC2G     | 产生捕获/比较 2 事件 (Capture/Compare 2 generation)<br>参考 CC1G 描述。                                                                                                                                                                                              |
| 1     | CC1G     | 产生通道 1 捕获/比较事件 (Capture/Compare 1 generation)<br>该位由软件置 1, 用于产生一个捕获/比较事件, 由硬件自动清 0。<br>0: 无动作<br>1: 通道 CC1 上产生一个捕获/比较事件:<br>若通道 CC1 配置为输出: CC1IF 置 1, 若开启对应的中断, 则产生相应的中断。<br>若通道 CC1 配置为输入: CC1IF 置 1, 若开启对应的中断, 则产生相应的中断。若 CC1IF 已经为 1, 则设置 CC1OF = 1。 |
| 0     | UG       | 产生更新事件 (Update generation)<br>0: 无动作<br>1: 初始化计数器, 并产生一个更新事件。由硬件自动清 0, 如果选择了中央对齐或递增计数模式, 计数器被清 0; 如果选择递减计数模式, 计数器将载入自动重载值。预分频计数器将同时被清除。                                                                                                                 |

### 11.5.7 TIM3\_CCMR1 捕获/比较模式寄存器 1

偏移地址: 0x18

复位值: 0x0000

|       |      |    |       |       |      |   |       |      |   |   |       |       |      |   |   |
|-------|------|----|-------|-------|------|---|-------|------|---|---|-------|-------|------|---|---|
| 15    | 14   | 13 | 12    | 11    | 10   | 9 | 8     | 7    | 6 | 5 | 4     | 3     | 2    | 1 | 0 |
| OC2CE | OC2M |    | OC2PE | OC2FE | CC2S |   | OC1CE | OC1M |   |   | OC1PE | OC1FE | CC1S |   |   |

| IC2F |    | IC2PSC |    | CC2S | IC1F |    | IC1PSC |    | CC1S |
|------|----|--------|----|------|------|----|--------|----|------|
| rw   | rw | rw     | rw | rw   | rw   | rw | rw     | rw | rw   |

通道可用于输入（捕获模式）或输出（比较模式），通道的方向由相应的 CCxS 定义。该寄存器 CCxS 以外其它位的作用在输入模式和输出模式下不同。OCxx 描述了通道在输出模式下的功能，ICxx 描述了通道在输入模式下的功能。

#### 比较输出模式：

| Bit    | Field | Description                                                                                                                                                                                                                                         |
|--------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15     | OC2CE | 通道 2 比较输出清零使能 (Output compare 2 clear enable)<br>参考 OC1CE 的描述。                                                                                                                                                                                      |
| 14: 12 | OC2M  | 通道 2 比较输出模式 (Output compare 2 mode)<br>参考 OC1M 的描述。                                                                                                                                                                                                 |
| 11     | OC2PE | 通道 2 比较输出预装载使能 (Output compare 2 preload enable)<br>参考 OC1PE 的描述。                                                                                                                                                                                   |
| 10     | OC2FE | 通道 2 比较输出快速使能 (Output compare 2 fast enable)<br>参考 OC1FE 的描述。                                                                                                                                                                                       |
| 9: 8   | CC2S  | 通道 2 捕获/比较选择 (Capture/Compare 2 selection)<br>该位定义通道的方向和输入信号的选择，只有在通道关闭时这些位才可写入：<br>00: 通道 2 被配置为输出<br>01: 通道 2 被配置为输入，IC2 映射在 TI2 上<br>10: 通道 2 被配置为输入，IC2 映射在 TI1 上<br>11: 通道 2 被配置为输入，IC2 映射在 TRC 上，此模式仅工作在内部触发器输入被选中时 (由 TIM3_SMCR 寄存器的 TS 位选择) |
| 7      | OC1CE | 通道 1 比较输出清 0 使能 (Output compare 1 clear enable)<br>0: OC1REF 不受 ETR 输入的影响<br>1: 当检测到 ETR 输入有效电平时，OC1REF 清零                                                                                                                                          |

| Bit  | Field | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6: 4 | OC1M  | <p>通道 1 比较输出模式 (Output compare 1 mode)<br/>     该位定义了输出参考信号 OC1REF 的动作，而 OC1REF 决定了 OC1 的值。OC1REF 是高电平有效，而 OC1 的有效电平取决于 CC1P 位。</p> <p>000: 冻结。TIM3_CCR1 与 TIM3_CNT 间的比较结果对 OC1REF 不起作用。</p> <p>001: 匹配时设置为高。当 TIM3_CNT 的值与 TIM3_CCR1 的值相同时，强制 OC1REF 为高电平。</p> <p>010: 匹配时设置为低。当 TIM3_CNT 的值与 TIM3_CCR1 的值相同时，强制 OC1REF 为低电平。</p> <p>011: 匹配时翻转。当 TIM3_CCR1=TIM3_CNT 时，翻转 OC1REF 的电平。</p> <p>100: 强制为低。强制 OC1REF 为低电平。</p> <p>101: 强制为高。强制 OC1REF 为高电平。</p> <p>110: PWM 模式 1。在递增计数时，当 TIM3_CNT&lt;TIM3_CCR1 时强制 OC1REF 为高电平，否则为低电平；在递减计数时，当 TIM3_CNT &gt; TIM3_CCR1 时强制 OC1REF 为低电平，否则为高电平。</p> <p>111: PWM 模式 2。在递增计数时，当 TIM3_CNT&lt;TIM3_CCR1 时通道 1 为强制 OC1REF 为低电平，否则为高电平；在递减计数时，当 TIM3_CNT &gt; TIM3_CCR1 时强制 OC1REF 为高电平，否则为低电平。</p> <p>注：在 PWM 模式 1 或 PWM 模式 2 中，只有当比较结果改变了或在比较输出模式中从冻结模式切换到 PWM 模式时，OC1REF 电平才改变。</p> |
| 3    | OC1PE | <p>通道 1 比较输出预装载使能 (Output compare 1 preload enable)</p> <p>0: 禁止 TIM3_CCR1 寄存器的预装载功能，写入 TIM3_CCR1 寄存器的数值立即生效。</p> <p>1: 开启 TIM3_CCR1 寄存器的预装载功能，读写操作仅对预装载寄存器操作，TIM3_CCR1 的预装载值在更新事件到来时生效。</p> <p>注：若该位置 1，在单脉冲模式下 (TIM3_CR1 寄存器的 OPM=1)，是否设定预装载寄存器无影响；其它情况下，需要设定预装载寄存器，否则后续动作不确定。</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 2    | OC1FE | <p>通道 1 比较输出快速使能 (Output compare 1 fast enable)</p> <p>该位为 1 时，若通道配置为 PWM 模式，会加快捕获/比较输出对触发时间的响应。输出通道将触发输入信号的有效边沿的作用等同于发生了一次比较匹配，此时 OC 被设置为比较电平，与比较结果无关。</p> <p>0: 禁止通道 1 比较输出快速使能</p> <p>1: 开启通道 1 比较输出快速使能</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

| Bit  | Field | Description                                                                                                                                                                                                                                                                                                                           |
|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1: 0 | CC1S  | <p>通道 1 捕获/比较选择 (Capture/Compare 1 selection)<br/>         该位定义通道的方向和输入信号的选择，只有在通道关闭时这些位才可写入：</p> <ul style="list-style-type: none"> <li>00: 通道 1 被配置为输出</li> <li>01: 通道 1 被配置为输入，IC1 映射在 TI1 上</li> <li>10: 通道 1 被配置为输入，IC1 映射在 TI2 上</li> <li>11: 通道 1 被配置为输入，IC1 映射在 TRC 上。此模式仅工作在内部触发器输入被选中时 (由 TIM3_SMCR 寄存器的 TS 位选择)</li> </ul> |

## 输入捕获模式：

| Bit    | Field  | Description                                                                                                                                                                                                                                                                                                                           |
|--------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15: 12 | IC2F   | <p>输入捕获 2 滤波器 (Input capture 2 filter)<br/>         参考 IC1F 的描述</p>                                                                                                                                                                                                                                                                   |
| 11: 10 | IC2PSC | <p>输入/捕获 2 预分频器 (Input capture 2 prescaler)<br/>         参考 IC1PSC 的描述</p>                                                                                                                                                                                                                                                            |
| 9: 8   | CC2S   | <p>通道 2 捕获/比较选择 (Capture/Compare 2 selection)<br/>         该位定义通道的方向和输入信号的选择，只有在通道关闭时这些位才可写入：</p> <ul style="list-style-type: none"> <li>00: 通道 2 被配置为输出</li> <li>01: 通道 2 被配置为输入，IC2 映射在 TI2 上</li> <li>10: 通道 2 被配置为输入，IC2 映射在 TI1 上</li> <li>11: 通道 2 被配置为输入，IC2 映射在 TRC 上，此模式仅工作在内部触发器输入被选中时 (由 TIM3_SMCR 寄存器的 TS 位选择)</li> </ul> |

| Bit  | Field  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7: 4 | IC1F   | <p>通道 1 输入捕获滤波器 (Input capture 1 filter)<br/>           数字滤波器由一个事件计数器组成，它记录 N 个输入事件后会产生一个输出的跳变。这些位定义了 IC1 输入信号的采样频率和数字滤波器的长度。</p> <p>0000: 无滤波器，以 <math>f_{DTS}</math> 采样<br/>           0001: 采样频率 <math>f_{sampling} = f_{INT\_CK}</math>, N=2<br/>           0010: 采样频率 <math>f_{sampling} = f_{INT\_CK}</math>, N=4<br/>           0011: 采样频率 <math>f_{sampling} = f_{INT\_CK}</math>, N=8<br/>           0100: 采样频率 <math>f_{sampling} = f_{DTS}/2</math>, N=6<br/>           0101: 采样频率 <math>f_{sampling} = f_{DTS}/2</math>, N=8<br/>           0110: 采样频率 <math>f_{sampling} = f_{DTS}/4</math>, N=6<br/>           0111: 采样频率 <math>f_{sampling} = f_{DTS}/4</math>, N=8<br/>           1000: 采样频率 <math>f_{sampling} = f_{DTS}/8</math>, N=6<br/>           1001: 采样频率 <math>f_{sampling} = f_{DTS}/8</math>, N=8<br/>           1010: 采样频率 <math>f_{sampling} = f_{DTS}/16</math>, N=5<br/>           1011: 采样频率 <math>f_{sampling} = f_{DTS}/16</math>, N=6<br/>           1100: 采样频率 <math>f_{sampling} = f_{DTS}/16</math>, N=8<br/>           1101: 采样频率 <math>f_{sampling} = f_{DTS}/32</math>, N=5<br/>           1110: 采样频率 <math>f_{sampling} = f_{DTS}/32</math>, N=6<br/>           1111: 采样频率 <math>f_{sampling} = f_{DTS}/32</math>, N=8</p> |
| 3: 2 | IC1PSC | <p>通道 1 输入/捕获预分频器 (Input capture 1 prescaler)<br/>           该位定义了 IC1 的预分频系数。当 CC1E=0 (TIM3_CCER 寄存器中) 时，预分频器复位。</p> <p>00: 无预分频器，捕获输入口上检测到的每一个边沿都触发一次捕获<br/>           01: 每 2 个事件触发一次捕获<br/>           10: 每 4 个事件触发一次捕获<br/>           11: 每 8 个事件触发一次捕获</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 1: 0 | CC1S   | <p>通道 1 捕获/比较选择 (Capture/Compare 1 selection)<br/>           该位定义通道的方向和输入信号的选择，只有在通道关闭时这些位才可写入：</p> <p>00: 通道 1 被配置为输出<br/>           01: 通道 1 被配置为输入，IC1 映射在 TI1 上<br/>           10: 通道 1 被配置为输入，IC1 映射在 TI2 上<br/>           11: 通道 1 被配置为输入，IC1 映射在 TRC 上。此模式仅工作在内部触发器输入被选中时 (由 TIM3_SMCR 寄存器的 TS 位选择)</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

### 11.5.8 TIM3\_CCMR2 捕获/比较模式寄存器 2

偏移地址: 0x1C

复位值: 0x0000

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

|       |      |        |       |      |       |      |       |        |      |
|-------|------|--------|-------|------|-------|------|-------|--------|------|
| OC4CE | OC4M | OC4PE  | OC4FE | CC4S | OC3CE | OC3M | OC3PE | OC3FE  | CC3S |
| IC4F  |      | IC4PSC |       | CC4S |       | IC3F |       | IC3PSC |      |
| rw    | rw   | rw     | rw    | rw   | rw    | rw   | rw    | rw     | rw   |

比较输出模式:

| Bit    | Field | Description                                                                                                                                                                                                                  |
|--------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15     | OC4CE | 通道 4 比较输出清零使能 (Output compare 4 clear enable)<br>参考 OC3CE 的描述                                                                                                                                                                |
| 14: 12 | OC4M  | 通道 4 比较输出模式 (Output compare 4 mode)<br>参考 OC3M 的描述                                                                                                                                                                           |
| 11     | OC4PE | 通道 4 比较输出预装载使能 (Output compare 4 preload enable)<br>参考 OC3PE 的描述                                                                                                                                                             |
| 10     | OC4FE | 通道 4 比较输出快速使能 (Output compare 4 fast enable)<br>参考 OC3FE 的描述                                                                                                                                                                 |
| 9: 8   | CC4S  | 通道 4 捕获/比较选择 (Capture/Compare 4 selection)<br>该位定义通道的方向和输入信号的选择，只有在通道关闭时这些位才可写入：<br>00: 通道 4 被配置为输出<br>01: 保留<br>10: 通道 4 被配置为输入，IC4 映射在 TI3 上<br>11: 通道 4 被配置为输入，IC4 映射在 TRC 上，此模式仅工作在内部触发器输入被选中时 (由 TIM3_SMCR 寄存器的 TS 位选择) |
| 7      | OC3CE | 通道 3 比较输出清 0 使能 (Output compare 3 clear enable)<br>0: OC3REF 不受 ETR 输入的影响<br>1: 当检测到 ETR 输入有效电平时，OC3REF 清零                                                                                                                   |

| Bit  | Field | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6: 4 | OC3M  | <p>通道 3 比较输出模式 (Output compare 3 mode)<br/>     该位定义了输出参考信号 OC3REF 的动作，而 OC3REF 决定了 OC3 的值。OC3REF 是高电平有效，而 OC3 的有效电平取决于 CC3P 位。</p> <p>000: 冻结。TIM3_CCR3 与 TIM3_CNT 间的比较结果对 OC3REF 不起作用</p> <p>001: 匹配时设置为高。当 TIM3_CNT 的值与 TIM3_CCR3 的值相同时，强制 OC3REF 为高电平</p> <p>010: 匹配时设置为低。当 TIM3_CNT 的值与 TIM3_CCR3 的值相同时，强制 OC3REF 为低电平</p> <p>011: 匹配时翻转。当 TIM3_CCR3=TIM3_CNT 时，翻转 OC3REF 的电平</p> <p>100: 强制为低。强制 OC3REF 为低电平</p> <p>101: 强制为高。强制 OC3REF 为高电平</p> <p>110: PWM 模式 1。在递增计数时，当 TIM3_CNT&lt;TIM3_CCR3 时强制 OC3REF 为高电平，否则为低电平；在递减计数时，当 TIM3_CNT &gt; TIM3_CCR3 时强制 OC3REF 为低电平，否则为高电平。</p> <p>111: PWM 模式 2。在递增计数时，当 TIM3_CNT&lt;TIM3_CCR3 时强制 OC3REF 为低电平，否则为高电平；在递减计数时，当 TIM3_CNT&gt;TIM3_CCR3 时强制 OC3REF 为高电平，否则为低电平。</p> <p>注：在 PWM 模式 1 或 PWM 模式 2 中，只有当比较结果改变了或在比较输出模式中从冻结模式切换到 PWM 模式时，OC3REF 电平才改变。</p> |
| 3    | OC3PE | <p>通道 3 比较输出预装载使能 (Output compare 3 preload enable)</p> <p>0: 禁止 TIM3_CCR3 寄存器的预装载功能，写入 TIM3_CCR3 寄存器的数值立即生效</p> <p>1: 开启 TIM3_CCR3 寄存器的预装载功能，读写操作仅对预装载寄存器操作，TIM3_CCR3 的预装载值在更新事件到来时生效</p> <p>注：仅在单脉冲模式下 (TIM3_CR1 寄存器的 OPM= 1)，无需设定预装载寄存器，其它情况下，需要设定预装载寄存器，否则后续动作不确定。</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 2    | OC3FE | <p>通道 3 比较输出快速使能 (Output compare 3 fast enable)</p> <p>该位为 1 时，若通道配置为 PWM 模式，会加快捕获/比较输出对触发时间的响应。输出通道将触发输入信号的有效边沿的作用等同于发生了一次比较匹配，此时 OC 被设置为比较电平，与比较结果无关。</p> <p>0: 禁止通道 3 比较输出快速使能</p> <p>1: 开启通道 3 比较输出快速使能</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

| Bit  | Field | Description                                                                                                                                                                                                                                                                                                    |
|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1: 0 | CC3S  | <p>通道 3 捕获/比较选择 (Capture/Compare 3 selection)<br/>         该位定义通道的方向和输入信号的选择，只有在通道关闭时这些位才可写入：</p> <ul style="list-style-type: none"> <li>00: 通道 3 被配置为输出</li> <li>01: 通道 3 被配置为输入，IC3 映射在 TI3 上</li> <li>10: 保留</li> <li>11: 通道 3 被配置为输入，IC3 映射在 TRC 上，此模式仅工作在内部触发器输入被选中时 (由 TIM3_SMCR 寄存器的 TS 位选择)</li> </ul> |

输入捕获模式：

| Bit    | Field  | Description                                                                                                                                                                                                                                                                                                    |
|--------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15: 12 | IC4F   | <p>输入捕获 4 滤波器 (Input capture 4 filter)<br/>         参考 IC3F 的描述</p>                                                                                                                                                                                                                                            |
| 11: 10 | IC4PSC | <p>输入/捕获 4 预分频器 (Input capture 4 prescaler)<br/>         参考 IC3PSC 的描述</p>                                                                                                                                                                                                                                     |
| 9: 8   | CC4S   | <p>通道 4 捕获/比较选择 (Capture/Compare 4 selection)<br/>         该位定义通道的方向和输入信号的选择，只有在通道关闭时这些位才可写入：</p> <ul style="list-style-type: none"> <li>00: 通道 4 被配置为输出</li> <li>01: 保留</li> <li>10: 通道 4 被配置为输入，IC4 映射在 TI3 上</li> <li>11: 通道 4 被配置为输入，IC4 映射在 TRC 上，此模式仅工作在内部触发器输入被选中时 (由 TIM3_SMCR 寄存器的 TS 位选择)</li> </ul> |

| Bit  | Field  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7: 4 | IC3F   | <p>通道 3 输入捕获滤波器 (Input capture 3 filter)<br/>           数字滤波器由一个事件计数器组成，它记录 N 个输入事件后会产生一个输出的跳变。这些位定义了 IC1 输入信号的采样频率和数字滤波器的长度。</p> <p>0000: 无滤波器，以 <math>f_{DTS}</math> 采样<br/>           0001: 采样频率 <math>f_{sampling} = f_{INT\_CK}</math>, <math>N=2</math><br/>           0010: 采样频率 <math>f_{sampling} = f_{INT\_CK}</math>, <math>N=4</math><br/>           0011: 采样频率 <math>f_{sampling} = f_{INT\_CK}</math>, <math>N=8</math><br/>           0100: 采样频率 <math>f_{sampling} = f_{DTS}/2</math>, <math>N=6</math><br/>           0101: 采样频率 <math>f_{sampling} = f_{DTS}/2</math>, <math>N=8</math><br/>           0110: 采样频率 <math>f_{sampling} = f_{DTS}/4</math>, <math>N=6</math><br/>           0111: 采样频率 <math>f_{sampling} = f_{DTS}/4</math>, <math>N=8</math><br/>           1000: 采样频率 <math>f_{sampling} = f_{DTS}/8</math>, <math>N=6</math><br/>           1001: 采样频率 <math>f_{sampling} = f_{DTS}/8</math>, <math>N=8</math><br/>           1010: 采样频率 <math>f_{sampling} = f_{DTS}/16</math>, <math>N=5</math><br/>           1011: 采样频率 <math>f_{sampling} = f_{DTS}/16</math>, <math>N=6</math><br/>           1100: 采样频率 <math>f_{sampling} = f_{DTS}/16</math>, <math>N=8</math><br/>           1101: 采样频率 <math>f_{sampling} = f_{DTS}/32</math>, <math>N=5</math><br/>           1110: 采样频率 <math>f_{sampling} = f_{DTS}/32</math>, <math>N=6</math><br/>           1111: 采样频率 <math>f_{sampling} = f_{DTS}/32</math>, <math>N=8</math></p> |
| 3: 2 | IC3PSC | <p>通道 3 输入/捕获预分频器 (Input capture 3 prescaler)<br/>           该位定义了 IC3 的预分频系数。当 CC3E=0 (TIM3_CCER 寄存器中) 时，预分频器复位。</p> <p>00: 无预分频器，捕获输入口上检测到的每一个边沿都触发一次捕获<br/>           01: 每 2 个事件触发一次捕获<br/>           10: 每 4 个事件触发一次捕获<br/>           11: 每 8 个事件触发一次捕获</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 1: 0 | CC3S   | <p>通道 3 捕获/比较选择 (Capture/Compare 3 selection)<br/>           该位定义通道的方向和输入信号的选择，只有在通道关闭时这些位才可写入：</p> <p>00: 通道 3 被配置为输出<br/>           01: 通道 3 被配置为输入，IC3 映射在 TI3 上<br/>           10: 保留<br/>           11: 通道 3 被配置为输入，IC3 映射在 TRC 上，此模式仅工作在内部触发器输入被选中时 (由 TIM3_SMCR 寄存器的 TS 位选择)</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

### 11.5.9 TIM3\_CCER 捕获/比较使能寄存器

偏移地址: 0x20

复位值: 0x0000

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

| CC4NP | Res. | CC4P | CC4E | CC3NP | Res. | CC3P | CC3E | CC2NP | Res. | CC2P | CC2E | CC1NP | Res. | CC1P | CC1E |
|-------|------|------|------|-------|------|------|------|-------|------|------|------|-------|------|------|------|
| rw    |      | rw   | rw   |

| Bit | Field    | Description                                                                                                                                                                 |
|-----|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15  | CC4NP    | 通道 4 输入捕获极性 (Capture 4 polarity)<br>参考 CC1NP 的描述。                                                                                                                           |
| 14  | Reserved | 保留，必须保持复位值。                                                                                                                                                                 |
| 13  | CC4P     | 通道 4 输入/捕获输出极性(Capture/Compare 4 output polarity)<br>参考 CC1P 的描述。                                                                                                           |
| 12  | CC4E     | 通道 4 输入/捕获输出使能(Capture/Compare 4 output enable)<br>参考 CC1E 的描述。                                                                                                             |
| 11  | CC3NP    | 通道 3 输入捕获极性 (Capture 3 polarity)<br>参考 CC1NP 的描述。                                                                                                                           |
| 10  | Reserved | 保留，必须保持复位值。                                                                                                                                                                 |
| 9   | CC3P     | 通道 3 输入/捕获输出极性(Capture/Compare 3 output polarity)<br>参考 CC1P 的描述。                                                                                                           |
| 8   | CC3E     | 通道 3 输入/捕获输出使能(Capture/Compare 3 output enable)<br>参考 CC1E 的描述。                                                                                                             |
| 7   | CC2NP    | 通道 2 输入捕获极性 (Capture 2 polarity)<br>参考 CC1NP 的描述。                                                                                                                           |
| 6   | Reserved | 保留，必须保持复位值。                                                                                                                                                                 |
| 5   | CC2P     | 通道 2 输入捕获输出极性 (Capture/Compare 2 output polarity)<br>参考 CC1P 的描述。                                                                                                           |
| 4   | CC2E     | 通道 2 输入/捕获输出使能(Capture/Compare 2 output enable)<br>参考 CC1E 的描述。                                                                                                             |
| 3   | CC1NP    | 通道 1 输入捕获极性 (Capture 1 polarity)<br>通道 1 配置为输出时，此位无效。<br>通道 1 配置为输入时，CC1P/CC1NP 配合使用定义了输入信号极性和电平，详细参考 ICx 极性/电平选择表。                                                         |
| 2   | Reserved | 保留，必须保持复位值。                                                                                                                                                                 |
| 1   | CC1P     | 通道 1 输入/捕获输出极性(Capture/Compare 1 output polarity)<br>通道 1 配置为输出时，此位定义了输出信号极性：<br>0: OC1 高电平有效<br>1: OC1 低电平有效<br>通道 1 配置为输入时，CC1P/CC1NP 配合使用定义了输入信号极性和电平，详细参考 ICx 极性/电平选择表。 |

| Bit | Field | Description                                                                                                                                                                                               |
|-----|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | CC1E  | <p>通道 1 输入/捕获输出使能 (Capture/Compare 1 output enable)</p> <p>通道 1 配置为输出时：</p> <p>0: 关闭。OC1 禁止输出</p> <p>1: 开启。OC1 信号输出到对应的输出引脚</p> <p>CC1 通道配置为输入：</p> <p>该位决定了输入捕获功能是否启用。</p> <p>0: 捕获禁止</p> <p>1: 捕获使能</p> |

输入模式下，ICx 的极性/电平选择如下表所示：

表 11-6 ICx 极性/电平选择表

| CCxP | CCxNP | ICx 极性/电平       |
|------|-------|-----------------|
| 0    | 0     | 上升沿有效/高电平有效     |
| 1    | 0     | 下降沿有效/低电平有效     |
| 1    | 1     | 上升沿或下降沿有效/高电平有效 |
| 0    | 1     | 保留              |

### 11.5.10 TIM3\_CNT 计数器

偏移地址：0x24

复位值：0x0000

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

| Bit   | Field | Description         |
|-------|-------|---------------------|
| 15: 0 | CNT   | 计数器的值 (Count value) |

### 11.5.11 TIM3\_PSC 预分频器

偏移地址：0x28

复位值：0x0000

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

| Bit   | Field | Description                                                                                                 |
|-------|-------|-------------------------------------------------------------------------------------------------------------|
| 15: 0 | PSC   | 预分频器的值 (Prescaler value)<br>计数器的时钟频率 ( $ck\_cnt$ ) = $f_{CK\_PSC}$ / (PSC+1)<br>当发生更新事件时, PSC 的值装入当前预分频寄存器。 |

### 11.5.12 TIM3\_ARR 自动预装载寄存器

偏移地址: 0x2C

复位值: 0x0000

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

| Bit   | Field | Description                                                          |
|-------|-------|----------------------------------------------------------------------|
| 15: 0 | ARR   | 自动预装载值 (Auto-reload value)<br>这些位定义了计数器的自动预装载值。当自动预装载的值为 0 时，计数器不工作。 |

### 11.5.13 TIM3\_CCR1 捕获/比较寄存器 1

偏移地址: 0x34

复位值: 0x0000

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

| Bit   | Field | Description                                                                                                                                                                                                                                                                              |
|-------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15: 0 | CCR1  | 通道 1 捕获/比较的值 (Capture/Compare 1 value)<br>通道 1 配置为输入：<br>上一次捕获事件发生时捕获的计数器值存放于 CCR1 (此时 CCR1 寄存器为只读)。<br>通道 1 配置为输出：<br>如果在 TIM3_CCMR1 寄存器 (OC1PE 位) 中未选择预装载功能，写入的数值会立即传输至对应的当前捕获/比较影子寄存器中。否则只有当更新事件发生时，此预装载值才传输至对应的当前捕获/比较影子寄存器中。当前捕获/比较影子寄存器参与同计数器 TIM3_CNT 的比较，并将比较结果反映到 OC1 端口的输出信号上。 |

### 11.5.14 TIM3\_CCR2 捕获/比较寄存器 2

偏移地址: 0x38

复位值: 0x0000

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

| Bit   | Field | Description                                            |
|-------|-------|--------------------------------------------------------|
| 15: 0 | CCR2  | 通道 2 捕获/比较的值 (Capture/Compare 2 value)<br>参考 CCR1 的描述。 |

### 11.5.15 TIM3\_CCR3 捕获/比较寄存器 3

偏移地址: 0x3C

复位值: 0x0000

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

| Bit   | Field | Description                                            |
|-------|-------|--------------------------------------------------------|
| 15: 0 | CCR3  | 通道 3 捕获/比较的值 (Capture/Compare 3 value)<br>参考 CCR1 的描述。 |

### 11.5.16 TIM3\_CCR4 捕获/比较寄存器 4

偏移地址: 0x40

复位值: 0x0000

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

| Bit   | Field | Description                                            |
|-------|-------|--------------------------------------------------------|
| 15: 0 | CCR4  | 通道 4 捕获/比较的值 (Capture/Compare 4 value)<br>参考 CCR1 的描述。 |

### 11.5.17 TIM3\_OR 输入选项寄存器

偏移地址: 0x50

复位值: 0x0000

|      |    |    |    |    |    |   |   |   |   |   |   |   |   |         |   |
|------|----|----|----|----|----|---|---|---|---|---|---|---|---|---------|---|
| 15   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1       | 0 |
| Res. |    |    |    |    |    |   |   |   |   |   |   |   |   | ETR_RMP |   |
|      |    |    |    |    |    |   |   |   |   |   |   |   |   | rw rw   |   |

| Bit  | Field    | Description                                                            |
|------|----------|------------------------------------------------------------------------|
| 15:2 | Reserved | 保留, 必须保持复位值。                                                           |
| 1:0  | ETR_RMP  | ETR 复用<br>00: 保留<br>01: LSI 时钟输入<br>10: 保留<br>11: HSE_CLK_DIV_128 时钟输入 |

## 12 TIM14 基本定时器

### 12.1 简介

TIM14 由一个 16 位可实时编程预分频器和一个 16 位自动重装载计数器组成，可以为用户提供便捷的计数定时功能，计数器时钟由预分频器分频得到。基本定时器具有多种用途，如输入功能（测量输入信号的脉冲宽度、频率等），输出功能（PWM 输出、比较输出等）。

### 12.2 功能框图



图 12-1 TIM14 结构图

上图为 TIM14 的结构框图，主要由输入单元、输出单元、时基单元、捕获/比较模块等结构组成。

### 12.3 主要特征

- 16 位可实时编程预分频器，分频系数：1–65536 可调
- 16 位自动重装载计数器（计数方向：递增）
- 输入捕获：输入信号的脉冲宽度、周期的测量
- 比较输出（控制输出波形或指示定时器已经计时结束）
- 单脉冲模式
- PWM 输出（边沿对齐模式）
- 产生中断请求的事件：更新事件、输入捕获、比较输出

## 12.4 功能描述

### 12.4.1 时钟

#### 12.4.1.1 时钟选择

计数器的时钟由内部时钟 (INT\_CK) 提供。

#### 12.4.1.2 时基单元

TIM14 的时基单元主要包括：计数器寄存器 (TIM14\_CNT)、预分频器寄存器 (TIM14\_PSC) 和自动预装载寄存器 (TIM14\_ARR)。

计数单元由一个 16 位的计数器和对应的自动预装载寄存器组成，可以实现递增计数功能。

计数器的时钟由预分频器提供，预分频器由预分频计数器和对应的寄存器组成，分频系数为 1-65536，可以随时写入，在下一次更新事件时生效。

自动预装载寄存器有预装载功能的 16 位影子寄存器，通过设置 TIM14\_CR1 寄存器的 ARPE 位选择写入 ARR 寄存器的值立即生效或发生更新事件时载入影子寄存器。



图 12-2 自动预装载

#### 12.4.1.3 计数模式

TIM14 仅支持递增计数模式。在使能 TIM14\_CR1 寄存器的 CEN 后计数器由 0 开始递增计数，直至 TIM14\_ARR 的值，产生一个计数器上溢事件（更新事件），并从 0 开始重新递增计数。设置 TIM14\_EGR 寄存器的 UG=1，同样可以产生一个更新事件。



图 12-3 递增计数模式 (UDIS=0)

通过配置 TIM14\_CR1 寄存器的 UDIS=1，可禁止产生更新事件，当计数器发生上溢事件时，不产生更新事件。此时若配置 UG=1，不产生更新事件，但是计数器和预分频器计数器会被初始化，从零开始递

增计数。



图 12-4 递增计数模式 (UDIS=1 禁止产生更新事件)

注：发生更新事件时

- ARR 寄存器中的值被载入 ARR 影子寄存器中。
- 预分频器的预装载值生效。

## 12.4.2 输入捕获

### 12.4.2.1 输入捕获

输入捕获部分包括数字滤波器、边沿检测器、预分频器和捕获比较寄存器等，其结构如下图所示：



图 12-5 TIM14 输入捕获结构图

通过配置 TIM14\_CCMR1 寄存器的 IC1F，可以设置数字滤波器的滤波宽度（滤波器的采样频率及数字滤波宽度如下表所示），当数字滤波器的输入信号宽度大于滤波宽度时，输入信号有效；数字滤波器对输入引脚 TI1 的输入信号采样后，产生一个滤波后的信号 TI1F，然后通过极性可选的边沿检测器，产生一个有效信号 IC1，该信号经过预分频器产生一个信号 IC1PS，用于触发输入捕获事件。

表 12-1 数字滤波器宽度与 IC1F 的对应关系表

| IC1F[3: 0] | 采样频率和滤波宽度                              | IC1F[3: 0] | 采样频率和滤波宽度                               |
|------------|----------------------------------------|------------|-----------------------------------------|
| 0000       | 无滤波器，以 fDTS 采样                         | 1000       | 采样频率 $f_{sampling} = f_{DTS} / 8, N=6$  |
| 0001       | 采样频率 $f_{sampling} = f_{INT\_CK}, N=2$ | 1001       | 采样频率 $f_{sampling} = f_{DTS} / 8, N=8$  |
| 0010       | 采样频率 $f_{sampling} = f_{INT\_CK}, N=4$ | 1010       | 采样频率 $f_{sampling} = f_{DTS} / 16, N=5$ |
| 0011       | 采样频率 $f_{sampling} = f_{INT\_CK}, N=8$ | 1011       | 采样频率 $f_{sampling} = f_{DTS} / 16, N=6$ |
| 0100       | 采样频率 $f_{sampling} = f_{DTS} / 2, N=6$ | 1100       | 采样频率 $f_{sampling} = f_{DTS} / 16, N=8$ |

| IC1F[3: 0] | 采样频率和滤波宽度                          | IC1F[3: 0] | 采样频率和滤波宽度                           |
|------------|------------------------------------|------------|-------------------------------------|
| 0101       | 采样频率 $f_{sampling}=f_{DTS}/2, N=8$ | 1101       | 采样频率 $f_{sampling}=f_{DTS}/32, N=5$ |
| 0110       | 采样频率 $f_{sampling}=f_{DTS}/4, N=6$ | 1110       | 采样频率 $f_{sampling}=f_{DTS}/32, N=6$ |
| 0111       | 采样频率 $f_{sampling}=f_{DTS}/4, N=8$ | 1111       | 采样频率 $f_{sampling}=f_{DTS}/32, N=8$ |

输入捕获模式下,当检测到信号 IC1 上的有效边沿后,计数器的当前值被锁存到对应的影子寄存器上,再复制到对应的捕获比较寄存器中。当开启了中断使能,发生捕获事件时,将产生相应的中断请求。发生捕获事件时,会将状态寄存器 (TIM14\_SR) 中的捕获标志位 CC1IF 置 1,通过配置 CC1IF=0 或读取 TIM14\_CCR1 中的数据,清除 CC1IF 标志位。当 CC1IF 未被清零时,发生输入捕获事件,重复捕获标志位 CC1OF 将会被置 1,通过配置 CC1OF=0,可以清除 CC1OF 标志位。

例如,通过采样 TI1 输入信号的有效沿,在 TI1 的上升沿来到时捕获当前计数器的值,锁存到 TIM14\_CCR1 寄存器中,步骤如下:

1. 配置 TIM14\_CCMR1 寄存器的 CC1S=01, CC1 通道被配置为输入, IC1 映射在 TI1 上。
2. 配置 TIM14\_CCMR1 寄存器的 IC1F[3: 0], 配置数字滤波器的滤波宽度 (按需配置)。
3. 配置 TIM14\_CCER 寄存器的 CC1P=0, 选择捕获发生在 TI1 信号的上升沿。
4. 配置 TIM14\_CCMR1 寄存器的 IC1PSC[1:0] , 选择预分频系数。
5. 配置 TIM14\_CCER 寄存器的 CC1E = 1, 开启输入/捕获通道 1 的捕获使能。
6. 配置 TIM14\_DIER 寄存器的 CC1IE=1, 使能通道 1 的捕获/比较通道 1 中断请求。

注:

- 当通道配置为输入模式时, TIM14\_CCR1 寄存器属性变为只读。
- 如果发生了两次以上连续捕获,但 CC1IF 标志未被清零,则重复捕获标志 CC1OF 被置 1。为了避免丢失重复捕获标志 CC1OF 置 1 之前可能产生的捕获信息,建议在读出重复捕获标志之前读取数据。
- 设置 TIM14\_EGR 寄存器中相应的 CC1G 位,可以通过软件产生输入捕获中断请求。

### 12.4.3 比较输出

捕获比较通道的比较输出部分由比较器、输出控制电路和捕获/比较寄存器组成,其结构图如下图所示:



图 12-6 比较输出部分结构图

在比较输出模式下,捕获比较寄存器的内容被载入到影子寄存器中,然后影子寄存器的内容和计数器当前值进行比较。捕获/比较模块包括一个捕获/比较寄存器(预装载寄存器)和一个影子寄存器,读写过程仅操作捕获/比较寄存器。

### 12.4.3.1 强制输出

配置 `TIM14_CCMR1` 寄存器的 `CC1S = 00`, 将通道 CC1 设置为输出模式, 通过配置 `TIM14_CCMR1` 寄存器 `OC1M` 位, 可以直接将比较输出信号直接强制为有效或无效状态, 不依赖于比较结果。配置 `TIM14_CCMR1` 寄存器 `OC1M = 100`, 强置比较输出信号为无效状态。此时 `OC1REF` 被强置为低电平。配置 `TIM14_CCMR1` 寄存器 `OC1M = 101`, 强置比较输出信号为有效状态。此时 `OC1REF` 被强置为高电平 (`OC1REF` 始终为高电平有效)。

注: 强制输出模式下, 在 `TIM14_CCR1` 影子寄存器和计数器之间的比较输出仍在进行, 比较结果的相应标志位也会被修改, 如果开启了对应的中断请求, 仍会产生对应的中断请求。

### 12.4.3.2 比较输出

比较输出模式下, 当计数器与捕获比较寄存器值相同时, 可以根据 `TIM14_CCMR1` 寄存器的 `OC1M` 位的配置用来输出不同的波形。

例如, 当计数器与捕获/比较寄存器的内容匹配时, 比较输出模式下的操作如下:

1. 在比较匹配时, `OC1M` 的值不同, 输出通道 1 信号 `OC1` 的操作不同:
  - ◆ `OC1M = 000`: `OC1` 信号保持它的电平
  - ◆ `OC1M = 001`: `OC1` 信号被设置成有效电平
  - ◆ `OC1M = 010`: `OC1` 信号被设置成无效电平
  - ◆ `OC1M = 011`: `OC1` 信号进行翻转
2. 匹配时中断状态寄存器中的标志位置 1 (`TIM14_SR` 寄存器中的 `CC1IF` 位)。
3. 当配置了 `TIM14_DIER` 寄存器中的 `CC1IE = 1`, 匹配时则产生一个中断。

比较输出模式也可以用来输出一个单脉冲 (单脉冲输出模式)。

例如, 通道 1 的比较输出模式的配置步骤如下:

1. 配置计数器的时钟 (选择时钟源, 配置预分频系数)。
2. 配置 `TIM14_ARR` 和 `TIM14_CCR1` 寄存器。
3. 配置 `TIM14_DIER` 寄存器的 `CC1IE = 1`, 使能捕获/比较 1 中断。
4. 配置输出模式:
  - ◆ 配置 `TIM14_CCMR1` 寄存器的 `OC1M = 011`, `OC1` 比较匹配时翻转。
  - ◆ 配置 `TIM14_CCMR1` 寄存器的 `OC1PE = 0`, 禁止 `TIM14_CCR1` 寄存器的预装载功能。
  - ◆ 配置 `TIM14_CCER` 寄存器的 `CC1P = 1`, `OC1` 低电平有效。
  - ◆ 配置 `TIM14_CCER` 寄存器的 `CC1E = 1`, 开启输出/比较 1 输出使能, `OC1` 信号输出到对应的输出引脚。
5. 配置 `TIM14_CR1` 寄存器的 `CEN = 1`, 启动计数器。

当配置 `TIM14_CCMR1` 寄存器中 `OC1PE=0`, 禁止 `TIM14_CCR1` 寄存器的预装载功能时, 可以随时

写入 TIM14\_CCR1 寄存器，并且写入的值立即生效。当配置 TIM14\_CCMR1 寄存器中 OC1PE=1，启用 TIM14\_CCR1 寄存器的预装载功能时，读写仅对预装载寄存器进行操作，TIM14\_CCR1 预装载寄存器的值在下次更新事件到来时生效。下图给出了一个例子。



图 12-7 比较输出模式，OC1 信号在匹配时翻转

注：比较输出模式下，更新事件不会对输出结果产生影响。强制输出模式下，在 TIM14\_CCR1 影子寄存器和计数器之间的比较输出仍在进行，比较结果的相应标志位也会被修改，如果开启了对应的中断请求，仍会产生对应的中断请求。

#### 12.4.3.3 PWM 输出

在 PWM 模式下，根据 TIM14\_ARR 寄存器和 TIM14\_CCR1 寄存器的值，产生一个频率、占空比可控的 PWM 波形。

配置与通道 1 对应的 TIM14\_CCMR1 寄存器的 OC1M=110 或 OC1M=111，选择通道 1 进入 PWM 模式 1 或 PWM 模式 2。PWM 模式下，计数器和 CCR1 会一直进行比较，根据配置和比较结果，通道 1 输出不同的信号，TIM14 可以产生 1 个独立占空比的 PWM 输出信号。PWM 模式下可开启 TIM14\_CCR1 的预装载功能和 TIM14\_ARR 寄存器的预装载功能。写入 TIM14\_CCR1 预装载寄存器和 TIM14\_ARR 预装载寄存器的值在发生下个更新事件时，才会生效，载入相应的影子寄存器。PWM 模式下，使能计数器前设置 TIM14\_EGR 的 UG=1，产生更新事件用于初始化所有的寄存器。

配置 TIM14\_CCER 寄存器的 CC1P 位选择 OC1 的有效极性。配置 TIM14\_CCER 寄存器的 CC1E 位控制 OC1 的输出使能。

##### 12.4.3.3.1 PWM 边沿对齐模式——递增计数模式

配置 TIM14\_CCMR1 寄存器的 CC1S=00，选择输出模式，OC1M=110，选择 PWM 模式 1，当 TIM14\_CNT < TIM14\_CCR1 时通道 1 (OC1REF) 为有效电平，否则为无效电平。如果 TIM14\_CCR1 中的比较值大于自动重装载值 (TIM14\_ARR)，则 OC1REF 保持为有效电平。如果比较值为 0，则 OC1REF 保持为无效电平。下图为 CCR1=4，ARR=a 时边沿对齐递增计数时 PWM 模式 1 的波形实例。



图 12-8 边沿对齐递增计数时 PWM 模式 1 的波形

#### 12.4.3.4 单脉冲输出

单脉冲模式 (OPM) 下，计数器响应一个激励，产生一个脉宽可调的脉冲。配置 `TIM14_CR1` 寄存器的 `OPM=1`，选择单脉冲模式，配置 `CEN=1` 启动计数器，直到下个更新事件发生或配置 `CEN=0` 时，计数器停止计数。

产生脉冲的必要条件是比较值与计数器的初始值不同。所以在计数器启动之前的必要配置如下：

- 递增计数方式：计数器  $CNT < CCR1 \leq ARR$ 。

下图是单脉冲输出示例。



图 12-9 单脉冲模式

#### 12.4.4 调试模式

在调试模式下，配置 `DBG_CR` 寄存器中 `DBG_TIM14_STOP=1`，TIM14 计数器停止计数。（详见调试章节）

#### 12.4.5 中断

TIM14 的中断包括：捕获/比较 1 中断和更新中断，当相应的中断使能位打开，发生相应的事件时，产生相应的中断。

表 12-2 中断事件一览表

| 中断事件       | 标志位   | 使能位   |
|------------|-------|-------|
| 捕获/比较 1 中断 | CC1IF | CC1IE |
| 更新中断       | UIF   | UIE   |

## 12.5 寄存器描述

表 12-3 TIM14 寄存器概览

| Offset | Acronym     | Register Name | Reset  |
|--------|-------------|---------------|--------|
| 0x00   | TIM14_CR1   | 控制寄存器 1       | 0x0000 |
| 0x0C   | TIM14_DIER  | 中断使能寄存器       | 0x0000 |
| 0x10   | TIM14_SR    | 状态寄存器         | 0x0000 |
| 0x14   | TIM14_EGR   | 事件产生寄存器       | 0x0000 |
| 0x18   | TIM14_CCMR1 | 捕获/比较模式寄存器 1  | 0x0000 |
| 0x20   | TIM14_CCER  | 捕获/比较使能寄存器    | 0x0000 |
| 0x24   | TIM14_CNT   | 计数器           | 0x0000 |
| 0x28   | TIM14_PSC   | 预分频器          | 0x0000 |
| 0x2C   | TIM14_ARR   | 自动装载寄存器       | 0x0000 |
| 0x34   | TIM14_CCR1  | 捕获/比较寄存器 1    | 0x0000 |
| 0x44   | TIM14_BDTR  | 输出控制寄存器       | 0x0000 |

### 12.5.1 TIM14\_CR1 控制寄存器 1

偏移地址: 0x00

复位值: 0x0000

|      |    |    |    |     |    |      |      |   |   |   |     |     |      |     |   |
|------|----|----|----|-----|----|------|------|---|---|---|-----|-----|------|-----|---|
| 15   | 14 | 13 | 12 | 11  | 10 | 9    | 8    | 7 | 6 | 5 | 4   | 3   | 2    | 1   | 0 |
| Res. |    |    |    | CKD |    | ARPE | Res. |   |   |   | OPM | URS | UDIS | CEN |   |
|      |    |    |    | rw  |    | rw   |      |   |   |   | rw  | rw  | rw   | rw  |   |

| Bit    | Field    | Description                                                                                                                                                                                                                                |
|--------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15: 10 | Reserved | 保留, 必须保持复位值。                                                                                                                                                                                                                               |
| 9: 8   | CKD      | 时钟分频 (clock division)<br>定义定时器时钟 (INT_CK) 频率与数字滤波器 (TI1) 所用的时钟之间的分频比例。<br>00: t <sub>DTS</sub> = t <sub>INT_CK</sub><br>01: t <sub>DTS</sub> = 2x t <sub>INT_CK</sub><br>10: t <sub>DTS</sub> = 4x t <sub>INT_CK</sub><br>11: 保留, 不要使用这个配置 |
| 7      | ARPE     | 自动重装载预装载使能 (Auto-reload preload enable)<br>0: 关闭 TIM14_ARR 寄存器的影子寄存器<br>1: 使能 TIM14_ARR 寄存器的影子寄存器                                                                                                                                          |
| 6: 4   | Reserved | 保留, 必须保持复位值。                                                                                                                                                                                                                               |

| Bit | Field | Description                                                                                                                                    |
|-----|-------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 3   | OPM   | 单脉冲模式 (One pulse mode)<br>0: 禁止单脉冲模式, 在发生更新事件时, 计数器继续计数<br>1: 使能单脉冲模式, 在发生下一次更新事件或软件清除 CEN 位时, 计数器停止计数                                         |
| 2   | URS   | 更新请求源 (Update request source)<br>软件配置该位, 选择更新事件源。<br>0: 以下事件可产生一个更新中断请求:<br>- 计数器上溢<br>- 设置 UG 位<br>1: 只有计数器上溢才产生一个更新中断请求                      |
| 1   | UDIS  | 禁止更新 (Update disable)<br>该位用来允许或禁止更新事件的产生<br>0: 允许更新事件 (UEV)<br>1: 禁止更新事件。不产生更新事件, 影子寄存器 (ARR、PSC、CCR1) 保持值不变。如果设置了 EGR_UG 位为 1, 计数器和预分频器被初始化。 |
| 0   | CEN   | 计数器使能 (Counter enable)<br>0: 禁止计数器<br>1: 使能计数器                                                                                                 |

### 12.5.2 TIM14\_DIER 中断使能寄存器

偏移地址: 0x0C

复位值: 0x0000

|      |    |    |    |    |    |   |   |   |   |   |   |   |   |       |     |
|------|----|----|----|----|----|---|---|---|---|---|---|---|---|-------|-----|
| 15   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1     | 0   |
| Res. |    |    |    |    |    |   |   |   |   |   |   |   |   | CC1IE | UIE |
|      |    |    |    |    |    |   |   |   |   |   |   |   |   | rw    | rw  |

| Bit   | Field    | Description                                                                             |
|-------|----------|-----------------------------------------------------------------------------------------|
| 15: 2 | Reserved | 保留, 必须保持复位值。                                                                            |
| 1     | CC1IE    | 允许捕获/比较 1 中断 (Capture/Compare 1 interrupt enable)<br>0: 禁止捕获/比较 1 中断<br>1: 允许捕获/比较 1 中断 |
| 0     | UIE      | 允许更新事件中断 (Update interrupt enable)<br>0: 禁止更新事件中断<br>1: 允许更新事件中断                        |

### 12.5.3 TIM14\_SR 状态寄存器

偏移地址: 0x10

复位值: 0x0000

|      |    |    |    |    |    |       |      |   |   |   |   |   |   |   |       |       |
|------|----|----|----|----|----|-------|------|---|---|---|---|---|---|---|-------|-------|
| 15   | 14 | 13 | 12 | 11 | 10 | 9     | 8    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0     |       |
| Res. |    |    |    |    |    | CC1OF | Res. |   |   |   |   |   |   |   | CC1IF | UIF   |
|      |    |    |    |    |    | r_w0c |      |   |   |   |   |   |   |   | r_w0c | r_w0c |

| Bit    | Field    | Description                                                                                                                                                                                                                                                                                 |
|--------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15: 10 | Reserved | 保留, 必须保持复位值。                                                                                                                                                                                                                                                                                |
| 9      | CC1OF    | <p>捕获/比较 1 重复捕获标记 (Capture/Compare 1 overcapture flag)</p> <p>仅当通道 1 被配置为输入捕获, CC1IF 已经为 1 后, 捕获事件再次发生时, 该标记可由硬件置 1。写 0 可清除该位。</p> <p>0: 无重复捕获产生<br/>1: 重复捕获产生</p>                                                                                                                          |
| 8: 2   | Reserved | 保留, 必须保持复位值。                                                                                                                                                                                                                                                                                |
| 1      | CC1IF    | <p>捕获/比较 1 中断标记 (Capture/Compare 1 interrupt flag)</p> <p>通道 1 为输出模式:</p> <p>当计数器值与比较值匹配时该位由硬件置 1, 它由软件清 0。</p> <p>0: 无匹配发生<br/>1: TIM14_CNT 的值与 TIM14_CCR1 的值匹配</p> <p>通道 1 为输入模式:</p> <p>当发生捕获事件时该位由硬件置 1, 由软件清 0 或读取 TIM14_CCR1 的值清 0。</p> <p>0: 无输入捕获产生<br/>1: 计数器值已被捕获至 TIM14_CCR1</p> |
| 0      | UIF      | <p>更新中断标记 (Update interrupt flag)</p> <p>当产生更新事件时该位由硬件置 1。它由软件清 0。</p> <p>0: 无更新中断发生<br/>1: 发生更新中断</p> <p>更新事件包含计数器上溢、设置 UG=1。</p>                                                                                                                                                          |

#### 12.5.4 TIM14\_EGR 事件产生寄存器

偏移地址: 0x14

复位值: 0x0000

|      |    |    |    |    |    |   |   |   |   |   |   |      |    |   |   |
|------|----|----|----|----|----|---|---|---|---|---|---|------|----|---|---|
| 15   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3    | 2  | 1 | 0 |
| Res. |    |    |    |    |    |   |   |   |   |   |   | CC1G | UG |   |   |
|      |    |    |    |    |    |   |   |   |   |   |   | w    | w  |   |   |

| Bit   | Field    | Description  |
|-------|----------|--------------|
| 15: 2 | Reserved | 保留, 必须保持复位值。 |

| Bit | Field | Description                                                                                                                                                                                                                                             |
|-----|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1   | CC1G  | 产生通道 1 捕获/比较事件 (Capture/Compare 1 generation)<br>该位由软件置 1, 用于产生一个捕获/比较事件, 由硬件自动清 0。<br>0: 无动作<br>1: 通道 CC1 上产生一个捕获/比较事件:<br>若通道 CC1 配置为输出: CC1IF 置 1, 若开启对应的中断, 则产生相应的中断。<br>若通道 CC1 配置为输入: CC1IF 置 1, 若开启对应的中断, 则产生相应的中断。若 CC1IF 已经为 1, 则设置 CC1OF = 1。 |
| 0   | UG    | 产生更新事件 (Update generation)<br>0: 无动作<br>1: 初始化计数器, 并产生一个更新事件。由硬件自动清 0                                                                                                                                                                                   |

### 12.5.5 TIM14\_CCMR1 捕获/比较模式寄存器 1

偏移地址: 0x18

复位值: 0x0000

|      |    |    |    |        |      |   |   |      |       |      |      |   |   |   |   |
|------|----|----|----|--------|------|---|---|------|-------|------|------|---|---|---|---|
| 15   | 14 | 13 | 12 | 11     | 10   | 9 | 8 | 7    | 6     | 5    | 4    | 3 | 2 | 1 | 0 |
| Res. |    |    |    | Res.   | OC1M |   |   |      | OC1PE | Res. | CC1S |   |   |   |   |
| IC1F |    |    |    | IC1PSC |      |   |   | CC1S |       |      |      |   |   |   |   |
|      |    |    |    | rw     | rw   |   |   |      | rw    | rw   | rw   |   |   |   |   |

通道可用于输入 (捕获模式) 或输出 (比较模式), 通道的方向由相应的 CC1S 定义。该寄存器 CC1S 以外其它位的作用在输入模式和输出模式下不同。OC1x 描述了通道在输出模式下的功能, IC1x 描述了通道在输入模式下的功能。

比较输出模式:

| Bit   | Field    | Description  |
|-------|----------|--------------|
| 15: 7 | Reserved | 保留, 必须保持复位值。 |

| Bit  | Field    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6: 4 | OC1M     | <p>通道 1 比较输出模式 (Output compare 1 mode)</p> <p>该位定义了输出参考信号 OC1REF 的动作，而 OC1REF 决定了 OC1 的值。OC1REF 是高电平有效，而 OC1 的有效电平取决于 CC1P 位。</p> <p>000: 冻结。TIM14_CCR1 与 TIM14_CNT 间的比较结果对 OC1REF 不起作用。</p> <p>001: 匹配时设置为高。当 TIM14_CNT 的值与 TIM14_CCR1 的值相同时，强制 OC1REF 为高电平。</p> <p>010: 匹配时设置为低。当 TIM14_CNT 的值与 TIM14_CCR1 的值相同时，强制 OC1REF 为低电平。</p> <p>011: 匹配时翻转，当 TIM14_CCR1=TIM14_CNT 时，翻转 OC1REF 的电平。</p> <p>100: 强制为低。强制 OC1REF 为低电平。</p> <p>101: 强制为高。强制 OC1REF 为高电平。</p> <p>110: PWM 模式 1。在递增计数时，当 TIM14_CNT&lt;TIM14_CCR1 时强制 OC1REF 为高电平，否则为低电平。</p> <p>111: PWM 模式 2。在递增计数时，当 TIM14_CNT&lt;TIM14_CCR1 时通道 1 为强制 OC1REF 为低电平，否则为高电平。</p> <p>注：在 PWM 模式 1 或 PWM 模式 2 中，只有当比较结果改变了或在比较输出模式中从冻结模式切换到 PWM 模式时，OC1REF 电平才改变。</p> |
| 3    | OC1PE    | <p>通道 1 比较输出预装载使能 (Output compare 1 preload enable)</p> <p>0: 禁止 TIM14_CCR1 寄存器的预装载功能，写入 TIM14_CCR1 寄存器的数值立即生效。</p> <p>1: 开启 TIM14_CCR1 寄存器的预装载功能，读写操作仅对预装载寄存器操作，TIM14_CCR1 的预装载值在更新事件到来时生效。</p> <p>注：若该位置 1，在单脉冲模式下 (TIM14_CR1 寄存器的 OPM=1)，是否设定预装载寄存器无影响；其它情况下，需要设定预装载寄存器，否则后续动作不确定。</p>                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 2    | Reserved | 保留，必须保持复位值。                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 1: 0 | CC1S     | <p>通道 1 捕获/比较选择 (Capture/Compare 1 selection)</p> <p>该位定义通道的方向和输入信号的选择，只有在通道关闭时这些位才可写入：</p> <p>00: 通道 1 被配置为输出</p> <p>01: 通道 1 被配置为输入</p> <p>10: 保留</p> <p>11: 保留</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

## 输入捕获模式：

| Bit   | Field    | Description |
|-------|----------|-------------|
| 15: 8 | Reserved | 保留，必须保持复位值。 |

| Bit  | Field  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7: 4 | IC1F   | <p>通道 1 输入捕获滤波器 (Input capture 1 filter)<br/>           数字滤波器由一个事件计数器组成，它记录 N 个输入事件后会产生一个输出的跳变。这些位定义了 IC1 输入信号的采样频率和数字滤波器的长度。</p> <p>0000: 无滤波器，以 <math>f_{DTS}</math> 采样<br/>           0001: 采样频率 <math>f_{sampling} = f_{INT\_CK}</math>, <math>N=2</math><br/>           0010: 采样频率 <math>f_{sampling} = f_{INT\_CK}</math>, <math>N=4</math><br/>           0011: 采样频率 <math>f_{sampling} = f_{INT\_CK}</math>, <math>N=8</math><br/>           0100: 采样频率 <math>f_{sampling} = f_{DTS} / 2</math>, <math>N=6</math><br/>           0101: 采样频率 <math>f_{sampling} = f_{DTS} / 2</math>, <math>N=8</math><br/>           0110: 采样频率 <math>f_{sampling} = f_{DTS} / 4</math>, <math>N=6</math><br/>           0111: 采样频率 <math>f_{sampling} = f_{DTS} / 4</math>, <math>N=8</math><br/>           1000: 采样频率 <math>f_{sampling} = f_{DTS} / 8</math>, <math>N=6</math><br/>           1001: 采样频率 <math>f_{sampling} = f_{DTS} / 8</math>, <math>N=8</math><br/>           1010: 采样频率 <math>f_{sampling} = f_{DTS} / 16</math>, <math>N=5</math><br/>           1011: 采样频率 <math>f_{sampling} = f_{DTS} / 16</math>, <math>N=6</math><br/>           1100: 采样频率 <math>f_{sampling} = f_{DTS} / 16</math>, <math>N=8</math><br/>           1101: 采样频率 <math>f_{sampling} = f_{DTS} / 32</math>, <math>N=5</math><br/>           1110: 采样频率 <math>f_{sampling} = f_{DTS} / 32</math>, <math>N=6</math><br/>           1111: 采样频率 <math>f_{sampling} = f_{DTS} / 32</math>, <math>N=8</math></p> |
| 3: 2 | IC1PSC | <p>通道 1 输入/捕获预分频器 (Input capture 1 prescaler)<br/>           该位定义了 IC1 的预分频系数。当 CC1E=0 (TIM14_CCER 寄存器中) 时，预分频器复位。</p> <p>00: 无预分频器，捕获输入口上检测到的每一个边沿都触发一次捕获<br/>           01: 每 2 个事件触发一次捕获<br/>           10: 每 4 个事件触发一次捕获<br/>           11: 每 8 个事件触发一次捕获</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 1: 0 | CC1S   | <p>通道 1 捕获/比较选择 (Capture/Compare 1 selection)<br/>           该位定义通道的方向和输入信号的选择，只有在通道关闭时这些位才可写入：</p> <p>00: 通道 1 被配置为输出<br/>           01: 通道 1 被配置为输入<br/>           10: 保留<br/>           11: 保留</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

### 12.5.6 TIM14\_CCER 捕获/比较使能寄存器

偏移地址: 0x20

复位值: 0x0000

|      |    |    |    |    |    |   |   |   |   |   |   |       |      |      |      |
|------|----|----|----|----|----|---|---|---|---|---|---|-------|------|------|------|
| 15   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3     | 2    | 1    | 0    |
| Res. |    |    |    |    |    |   |   |   |   |   |   | CC1NP | Res. | CC1P | CC1E |

|  |  |           |  |           |           |
|--|--|-----------|--|-----------|-----------|
|  |  | <b>rw</b> |  | <b>rw</b> | <b>rw</b> |
|--|--|-----------|--|-----------|-----------|

| Bit   | Field    | Description                                                                                                                                                                  |
|-------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15: 4 | Reserved | 保留，必须保持复位值。                                                                                                                                                                  |
| 3     | CC1NP    | 通道 1 输入捕获极性 (Capture 1 polarity)<br>通道 1 配置为输出时，此位无效。<br>通道 1 配置为输入时，CC1P/CC1NP 配合使用定义了输入信号极性和电平，详细参考 IC1 极性/电平选择表。                                                          |
| 2     | Reserved | 保留，必须保持复位值。                                                                                                                                                                  |
| 1     | CC1P     | 通道 1 输入/捕获输出极性 (Capture/Compare 1 output polarity)<br>通道 1 配置为输出时，此位定义了输出信号极性：<br>0: OC1 高电平有效<br>1: OC1 低电平有效<br>通道 1 配置为输入时，CC1P/CC1NP 配合使用定义了输入信号极性和电平，详细参考 IC1 极性/电平选择表。 |
| 0     | CC1E     | 通道 1 输入/捕获输出使能 (Capture/Compare 1 output enable)<br>通道 1 配置为输出时：<br>0: 关闭。OC1 禁止输出<br>1: 开启。OC1 信号输出到对应的输出引脚<br>CC1 通道配置为输入：<br>该位决定了输入捕获功能是否启用。<br>0: 捕获禁止<br>1: 捕获使能       |

输入模式下，IC1 的极性/电平选择如下表所示：

表 12-4 IC1 极性/电平选择表

| CC1P | CC1NP | IC1 极性/电平       |
|------|-------|-----------------|
| 0    | 0     | 上升沿有效/高电平有效     |
| 1    | 0     | 下降沿有效/低电平有效     |
| 1    | 1     | 上升沿或下降沿有效/高电平有效 |
| 0    | 1     | 保留              |

## 12.5.7 TIM14\_CNT 计数器

偏移地址：0x24

复位值：0x0000

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

| Bit   | Field | Description         |
|-------|-------|---------------------|
| 15: 0 | CNT   | 计数器的值 (Count value) |

### 12.5.8 TIM14\_PSC 预分频器

偏移地址: 0x28

复位值: 0x0000

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

| Bit   | Field | Description                                                                                                     |
|-------|-------|-----------------------------------------------------------------------------------------------------------------|
| 15: 0 | PSC   | 预分频器的值 (Prescaler value)<br>计数器的时钟频率 ( $f_{ck\_cnt} = f_{ck\_PSC} / (PSC + 1)$ )<br>当发生更新事件时, PSC 的值装入当前预分频寄存器。 |

### 12.5.9 TIM14\_ARR 自动预装载寄存器

偏移地址: 0x2C

复位值: 0x0000

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

| Bit   | Field | Description                                                          |
|-------|-------|----------------------------------------------------------------------|
| 15: 0 | ARR   | 自动预装载值 (Auto-reload value)<br>这些位定义了计数器的自动预装载值。当自动预装载的值为 0 时，计数器不工作。 |

### 12.5.10 TIM14\_CCR1 捕获/比较寄存器 1

偏移地址: 0x34

复位值: 0x0000

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

| Bit   | Field | Description                                                                                                                                                                                                                                                                                                    |
|-------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15: 0 | CCR1  | <p>通道 1 捕获/比较的值 (Capture/Compare 1 value)</p> <p>通道 1 配置为输入:<br/>上一次捕获事件发生时捕获的计数器值存放于 CCR1 (此时 CCR1 寄存器为只读)。</p> <p>通道 1 配置为输出:<br/>如果在 TIM14_CCMR1 寄存器 (OC1PE 位) 中未选择预装载功能, 写入的数值会立即传输至对应的当前捕获/比较影子寄存器中。否则只有当更新事件发生时, 此预装载值才传输至对应的当前捕获/比较影子寄存器中。当前捕获/比较影子寄存器参与同计数器 TIM14_CNT 的比较, 并将比较结果反映到 OC1 端口的输出信号上。</p> |

### 12.5.11 TIM14\_BDTR 输出控制寄存器

偏移地址: 0x44

复位值: 0x0000

|     |      |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-----|------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 15  | 14   | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| MOE | Res. |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| rw  |      |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit   | Field    | Description                                                                                                            |
|-------|----------|------------------------------------------------------------------------------------------------------------------------|
| 15    | MOE      | <p>主输出使能 (Main output enable)</p> <p>0: 禁止 OC1 输出或强制为空闲状态</p> <p>1: 如果设置了相应的使能位 (TIM14_CCER 寄存器的 CC1E), 则开启 OC1 输出</p> |
| 14: 0 | Reserved | 保留, 必须保持复位值。                                                                                                           |

## 13 WWDG 窗口看门狗

### 13.1 简介

窗口看门狗是喂狗时间有上下限范围的看门狗，主要用于检测由外部干扰和不可预测的条件导致程序跑飞而引起的软件问题。

根据程序正常执行的时间来设置刷新看门狗的一个时间窗口，保证不会提前刷新看门狗也不会滞后刷新看门狗，这样就可以检测出程序有没有按照正常的路径运行或者出现非正常地跳过某些程序段的情况。

### 13.2 功能框图



图 13-1 WWDG 功能框图

### 13.3 主要特征

- 可编程的自由运行的 7 位递减计数器（0xFF 和 0xC0）
- 窗口外喂狗产生复位

上限：当计数器的值大于配置寄存器（WWDG\_CFGR）设定的值时喂狗，将会产生复位

下限：当计数器的值小于 0x40 时，产生复位

- 中断：

如果启动了窗口看门狗并且允许中断，当递减计数器递减到 0x40 时，将产生提前唤醒中断(EWI)，可以在中断处理函数中，向 WWDG\_CR 重新装载计数器的值来达到喂狗的目的，从而防止复位。

## 13.4 功能描述

- 当控制寄存器 WWDG\_CR 中的第 7bit 位 WDGA 被置“1”时，启动窗口看门狗，若计数器的值从下限固定值 0x40 递减到 0x3F (WWDG\_CR 中的第 6bit 位清零)，将会产生一个复位。或者计数器的值大于配置寄存器 WWDG\_CFGR 设定的值时喂狗，也会产生复位。
- 窗口看门狗和独立看门狗一样，都是在应用程序正常运行中做定时喂狗操作，来防止 MCU 发生复位。区别在于：窗口看门狗喂狗必须在计数器值小于窗口寄存器值的时候操作，也只有在这种情况下，喂狗才不会产生复位。其中，写入控制寄存器 WWDG\_CR 的值必须在 0xFF 和 0xC0 之间。
- 窗口看门狗在系统复位后不会自动运行，需要设置控制寄存器 WWDG\_CR 中的 WDGA 位开启窗口看门狗。因为 WDGA 位只能由硬件复位清零，所以一旦软件置位后，窗口看门狗会一直开启。当窗口看门狗被打开后，需要配置控制寄存器 WWDG\_CR 的第 6bit 位置“1”，以防止立即产生窗口看门狗复位。WWDG\_CR[6:0]代表看门狗复位前的计数值，由于预分频值软件可配，且复位前的延时与预分频值的配置有关，因此复位前的延时会在一个最小值和最大值之间变化。
- 利用提前唤醒中断 (EWI) 可以重载计数器来避免复位。设置配置寄存器 WWDG\_CFGR 中的 EWI 位来使能中断，当计数器数值到达 0x40 且产生中断后，在中断处理函数中向控制寄存器 WWDG\_CR 重写计数器的值来达到喂狗目的从而防止复位。在状态寄存器 WWDG\_SR 中软件写“0”来清除中断。

## 13.5 窗口看门狗超时时间



图 12 WWDG 超时时间坐标图

表 13-1 超时时间

| 时基 (WDGTB) | 最短时间    | 最长时间    |
|------------|---------|---------|
| 0          | 56.5us  | 3.64ms  |
| 1          | 113.5us | 7.28ms  |
| 2          | 227.5us | 14.56ms |
| 3          | 455us   | 29.12ms |

超时计算公式：

$$T = T_{\text{pclk1}} * 4096 * 2^{\text{WDGTB}} * (T[5:0] + 1)$$

WDGTB：分频器的时基

T<sub>pclk1</sub>：APB1 的时钟间隔

## 13.6 寄存器描述

表 13-2 WWDG 寄存器概览

| Offset | Acronym   | Register Name | Reset      |
|--------|-----------|---------------|------------|
| 0x00   | WWDG_CR   | 控制寄存器         | 0x0000007F |
| 0x04   | WWDG_CFGR | 配置寄存器         | 0x0000007F |

| Offset | Acronym | Register Name | Reset      |
|--------|---------|---------------|------------|
| 0x08   | WWDG_SR | 状态寄存器         | 0x00000000 |

### 13.6.1 控制寄存器 (WWDG\_CR)

偏移地址: 0x00

复位值: 0x0000 007F

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

|      |    |    |    |    |    |   |   |      |        |   |   |   |   |   |   |
|------|----|----|----|----|----|---|---|------|--------|---|---|---|---|---|---|
| 15   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7    | 6      | 5 | 4 | 3 | 2 | 1 | 0 |
| Res. |    |    |    |    |    |   |   | WDGA | T[6:0] |   |   |   |   |   |   |
| Res. |    |    |    |    |    |   |   | rw   | rw     |   |   |   |   |   |   |

| Bit  | Field    | Description                                                                                                                                                           |
|------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | Reserved | 保留, 必须保持复位值                                                                                                                                                           |
| 7    | WDGA     | <p>激活位 (Activation Bit)<br/>此位由软件置 1, 但仅能由硬件在复位后清 0。当 WDGA 为 1 时, 看门狗被启动。<br/>0: 关闭看门狗<br/>1: 启动看门狗</p>                                                               |
| 6:0  | T[6:0]   | <p>7 位递减计数器 (MSB 至 LSB) (7 - Bit Counter)<br/>用来存储看门狗的计数器值。每 <math>(4096 \times 2^{\text{WDGTB}})</math> 个 PCLK1 周期减 1, 当计数器值从 40h 递减为 3Fh 时 (T[6]变成 0), 产生看门狗复位。</p> |

### 13.6.2 配置寄存器 (WWDG\_CFR)

偏移地址: 0x04

复位值: 0x0000 007F

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

|      |    |    |    |    |    |   |   |     |       |   |   |   |   |   |   |
|------|----|----|----|----|----|---|---|-----|-------|---|---|---|---|---|---|
| 15   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7   | 6     | 5 | 4 | 3 | 2 | 1 | 0 |
| Res. |    |    |    |    |    |   |   | EWI | WDGTB |   |   |   |   |   |   |
| Res. |    |    |    |    |    |   |   | rw  | rw    |   |   |   |   |   |   |

| Bit   | Field    | Description  |
|-------|----------|--------------|
| 31:10 | Reserved | 保留, 必须保持复位值。 |

| Bit  | Field  | Description                                                                                                                                                                |
|------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9    | EWI    | 提前唤醒中断使能 (Early Wakeup Interrupt)<br>1: 当计数器值达到 40h, 产生中断。<br>0: 看门狗中断禁止<br>该位只能由硬件在复位后清除。                                                                                 |
| 8: 7 | WDGTB  | 时基 (Timer Base)<br>预分频器的时基可根据如下修改:<br>00: 计时器时钟 (PCLK1 除以 4096) 除以 1<br>01: 计时器时钟 (PCLK1 除以 4096) 除以 2<br>10: 计时器时钟 (PCLK1 除以 4096) 除以 4<br>11: 计时器时钟 (PCLK1 除以 4096) 除以 8 |
| 6: 0 | W[6:0] | 7 位窗口值 (7-Bit Window Value)<br>窗口看门狗的上限窗口值。                                                                                                                                |

### 13.6.3 状态寄存器 (WWDG\_SR)

偏移地址: 0x08

复位值: 0x0000 0000

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

| Bit   | Field    | Description                                                                                 |
|-------|----------|---------------------------------------------------------------------------------------------|
| 31: 1 | Reserved | 保留, 必须保持复位值。                                                                                |
| 0     | EWIF     | EWIF: 提前唤醒中断标志 (Early Wakeup Interrupt Flag)<br>当计数器值达到 40h, 此位由硬件置 1; 通过软件写 0 来清除, 写 1 无效。 |

## 14 IWDG 独立看门狗

### 14.1 简介

独立看门狗的设计初衷是为了检测和解决由软件错误所引起的故障，它的原理可简述为：当独立看门狗（IWDG）计数器不断递减到达给定数值时，产生一个系统复位信号使系统复位，从而提高系统整体安全性能。

独立看门狗适合应用于那些需要看门狗作为一个处于主程序之外，能够完全独立工作，并且对时间精度要求低的场合。

独立看门狗是由内部低速的时钟（LSI）驱动的，保证当主时钟发生故障的时候，独立看门狗依旧可以继续工作。

## 14.2 功能框图



图 14-1 功能框图

## 14.3 主要特征

- 芯片默认为软件看门狗模式。
- 通过闪存烧写复位选项字节寄存器中的 WDG\_SW 位可以启动硬件看门狗。硬件看门狗启动后在系统复位上电后自动启动，内部计数器开始递减。
- LSI 可在停机模式和待机模式下继续进行工作；

- 看门狗内部是自由运行的 12 位递减计数器，当计数到达 0x0000 产生一个系统复位或者中断信号。

## 14.4 功能描述

- 在键值寄存器（IWDG\_KR）中写入 0XCCCC，开启独立看门狗。与此同时，计数器开始从其复位值 0Xfff 开始递减，当递减到达 0x0000 时会产生一个系统复位信号，或者递减到 IWDG\_IGEN 的值后产生中断，两种结果取决于 IRQ\_SEL 的配置。
- 任何时候写入 0XAAAA 到 IWDG\_KR，就会把重载寄存器（IWDG\_RLR）中的值重新加载到计数器中（通常说的喂狗），从而避免复位信号或中断信号的产生。
- 比较/输出如果程序异常，无法正常喂狗，就会产生复位信号或中断信号，系统复位或系统中断。
- IWDG\_PR, IWDG\_RLR, IWDG\_IGEN 寄存器具有访问保护功能。只有在键值寄存器（IWDG\_KR）写入 0x5555，才可以修改以上被保护的寄存器的值。当以其他的值写入键值寄存器，会打乱操作顺序，寄存器依旧处于保护状态。当进行重载操作时，也会处于保护状态。
- 独立看门狗的时钟由 LSI 提供，因此可以工作在停止和待机模式下。
- 独立看门狗可以在低功耗模式下正常计数，它的复位能够使系统退出 Standby 模式。
- 在低功耗模式下，可以通过配置 RCC 寄存器，选择在进入 Stop 模式后是否关闭 LSI 时钟，从而关闭软件看门狗。

#### 14.4.1 流程框图



图 14-2 流程框图

#### 14.4.2 独立看门狗超时时间

表 14-1 IWDG 超时时间 (40kHz 的输入时钟 (LSI))

| 预分频系数 | PR[2:0] 位 | 最短时间 (ms)<br>RL[11:0]=0x000 | 最长时间 (ms) |
|-------|-----------|-----------------------------|-----------|
| /4    | 0         | 0.1                         | 409.6     |
| /8    | 1         | 0.2                         | 819.2     |
| /16   | 2         | 0.4                         | 1638.4    |
| /32   | 3         | 0.8                         | 3276.8    |
| /64   | 4         | 1.6                         | 6553.6    |
| /128  | 5         | 3.2                         | 13107.2   |
| /256  | (6 或 7)   | 6.4                         | 26214.4   |

超出 (溢出) 时间计算:

$$T_{out} = ((4 \times 2^{\text{PR}}) \times RLR) / 40$$

其中:  $T_{out}$  的单位为毫秒。

时钟频率  $LSI = 40K$ , 一个看门狗时钟周期就是最短超时时间。

最长超时时间 = (IWDG\_RLR 寄存器最大值)  $\times$  看门狗时钟周期。

#### 14.4.3 中断

- IWDG 在 CR.IRQ\_SEL 配置为 1 条件下, 当计数器溢出后产生中断。

### 14.5 寄存器描述

#### 14.5.1 寄存器总览

表 14-2 IWDG 寄存器概览

| Offset | Acronym   | Register Name | Reset      |
|--------|-----------|---------------|------------|
| 0x00   | IWDG_KR   | 键寄存器          | 0x00000000 |
| 0x04   | IWDG_PR   | 预分频寄存器        | 0x00000000 |
| 0x08   | IWDG_RLR  | 重装载寄存器        | 0x00000FFF |
| 0x0C   | IWDG_SR   | 状态寄存器         | 0x00000000 |
| 0x10   | IWDG_CR   | 控制寄存器         | 0x00000000 |
| 0x14   | IWDG_IGEN | 中断生成寄存器       | 0x00000FFF |
| 0x18   | IWDG_CNT  | 计数寄存器         | 0x00000001 |

#### 14.5.2 IWDG\_KR 键寄存器

偏移地址: 0x00

复位值: 0x0000 0000

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

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

| Bit    | Field    | Description                                                                                                                                                                                                           |
|--------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31: 16 | Reserved | 保留，必须保持复位值                                                                                                                                                                                                            |
| 15: 0  | KEY      | <p>键值（只写寄存器）(Key value)<br/>           软件每隔一段时间，写进 0XAAAA 进行喂狗操作，否则当计数器递减到 0x0000 时，会产生一个复位信号，使系统复位。</p> <p>软件写入 0x5555 表示解除保护，可以访问其他配置寄存器 (IWDG_PR、IWDG_RLR、IWDG_CR (bit0), IWDG_IGEN)</p> <p>软件写入 0xCCCC，开启看门狗。</p> |

### 14.5.3 IWDG\_PR 预分频寄存器

偏移地址: 0x04

复位值: 0x0000 0000 (在待机模式复位)

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

Res.

|      |    |    |    |    |    |   |   |   |   |   |   |   |    |   |   |
|------|----|----|----|----|----|---|---|---|---|---|---|---|----|---|---|
| 15   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2  | 1 | 0 |
| Res. |    |    |    |    |    |   |   |   |   |   |   |   | PR |   |   |
| Res. |    |    |    |    |    |   |   |   |   |   |   |   | rw |   |   |

| Bit             | Field            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                |                 |                |                  |                 |                  |                 |                  |
|-----------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|-----------------|----------------|------------------|-----------------|------------------|-----------------|------------------|
| 31:3            | Reserved         | 始终读为 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                |                 |                |                  |                 |                  |                 |                  |
| 2: 0            | PR               | <p>预分频因子 (Prescaler divider)<br/>           通过设置这些位来选择 LSI 时钟的预分频因子<br/>           要改变预分频因子，需要先解除保护（向 IWDG_KE 中写入 0x5555）才能写入，当预分频因子被更新完成后，PUV 寄存器位会变为 0，此时读出数据才是有效的。</p> <table style="width: 100%; border-collapse: collapse;"> <tr> <td style="width: 50%;">000: 预分频因子 = 4</td> <td style="width: 50%;">100: 预分频因子 = 64</td> </tr> <tr> <td>001: 预分频因子 = 8</td> <td>101: 预分频因子 = 128</td> </tr> <tr> <td>010: 预分频因子 = 16</td> <td>110: 预分频因子 = 256</td> </tr> <tr> <td>011: 预分频因子 = 32</td> <td>111: 预分频因子 = 256</td> </tr> </table> | 000: 预分频因子 = 4 | 100: 预分频因子 = 64 | 001: 预分频因子 = 8 | 101: 预分频因子 = 128 | 010: 预分频因子 = 16 | 110: 预分频因子 = 256 | 011: 预分频因子 = 32 | 111: 预分频因子 = 256 |
| 000: 预分频因子 = 4  | 100: 预分频因子 = 64  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                |                 |                |                  |                 |                  |                 |                  |
| 001: 预分频因子 = 8  | 101: 预分频因子 = 128 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                |                 |                |                  |                 |                  |                 |                  |
| 010: 预分频因子 = 16 | 110: 预分频因子 = 256 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                |                 |                |                  |                 |                  |                 |                  |
| 011: 预分频因子 = 32 | 111: 预分频因子 = 256 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                |                 |                |                  |                 |                  |                 |                  |

#### 14.5.4 IWDG\_RLR 重装载寄存器

偏移地址: 0x08

复位值: 0x0000 0FFF (在待机模式复位)

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

Res.

|      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 15   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Res. |    |    |    | RL |    |   |   |   |   |   |   |   |   |   |   |
| Res. |    |    |    | rw |    |   |   |   |   |   |   |   |   |   |   |

| Bit   | Field    | Description                                                                                                                                                                                                              |
|-------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12 | Reserved | 保留, 必须保持复位值                                                                                                                                                                                                              |
| 11: 0 | RL       | 重装载值 (Watchdog counter reload value)<br>配置看门狗计数器的重载值, 每当喂狗 (向 IWDG_KR 寄存器中写入 0xAAAA) 时, 会把此位数值更新到计时器中, 然后从此值开始递减。更改重载值需要解除保护 (向 IWDG_KR 寄存器中写入 0x5555), 当重载值更新完毕后, RUV 寄存器位会清 0, 也就在此时读出值才是有效的。看门狗的超时周期可以通过重装载值和预分频值来计算。 |

#### 14.5.5 IWDG\_SR 状态寄存器

偏移地址: 0x0C

复位值: 0x0000 0000 (待机模式不复位)

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

Res.

|      |    |    |    |    |    |   |   |   |   |   |   |       |     |     |     |
|------|----|----|----|----|----|---|---|---|---|---|---|-------|-----|-----|-----|
| 15   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3     | 2   | 1   | 0   |
| Res. |    |    |    |    |    |   |   |   |   |   |   | UPDAT | IVU | RVU | PVU |
| E    |    |    |    |    |    |   |   |   |   |   |   | r     | r   | r   | r   |

| Bit  | Field    | Description |
|------|----------|-------------|
| 31:4 | Reserved | 保留, 必须保持复位值 |

| Bit | Field  | Description                                                                                                                                                               |
|-----|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3   | UPDATE | 看门狗重装载值更新标志<br>当 IWDG_KR 寄存器中写入 0XAAAA 时, update 置位, 当看门狗计数器被更新, 重装载值写入到计数器中, update 自动清零。                                                                                |
| 2   | IVU    | 看门狗中断生成值更新 (Watchdog Interrupt Generate value update)<br>此位由硬件置'1'用来指示中断生成值的更新正在进行中。<br>当在 VDD 域中的中断生成值更新结束后, 此位由硬件清'0' (最多需要 5 个 40KHz 的振荡器周期) 中断生成值只有在 IVU 位被清'0'后才可更新。 |
| 1   | RVU    | 看门狗计数器重装载值更新 (Watchdog counter reload value update)<br>重装载值的更新正在进行中, 此位置 1。<br>当重装载更新结束后, 此位清'0' (最多需要 5 个 40KHz 的振荡器周期)<br>重装载值只有在 RVU 位被清'0'后才可更新。                      |
| 0   | PVU    | 看门狗预分频更新 (Watchdog prescaler value update)<br>预分频值的更新正在进行中时, 此位置 1。<br>当预分频值更新结束后, 此位由清'0' (最多需要 5 个 40KHz 的振荡器周期)<br>预分频值只有在 PVU 位被清'0'后才可更新。                            |

注: 如果在应用程序中使用多个重装载值、预分频值或中断生成值, 先解除寄存器保护(向 IWDG\_KR 中写入 0x5555), 然后配置 IWDG\_PR IWDG\_RLR, IWDG\_IGEN 寄存器, 等待对应的状态寄存器位 (PVU, RVU, IVU) 清零, 表示已经配置好重装载值, 预分频值, 和中断生成值, 接下来就可以执行喂狗操作, 或者等待计数器自动递减产生复位或者中断信号。

#### 14.5.6 IWDG\_CR 控制寄存器

偏移地址: 0x10

复位值: 0x0000 0000

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

| Bit  | Field    | Description                                                                     |
|------|----------|---------------------------------------------------------------------------------|
| 31:2 | Reserved | 保留, 必须保持复位值                                                                     |
| 1    | IRQ_CLR  | IWDG 中断清除<br>1: 写 1 清除中断<br>0: 无效操作, 中断标志位依旧挂起<br>注意: 这个 bit 的写操作不需要设置 KEY 解除保护 |

| Bit | Field   | Description                             |
|-----|---------|-----------------------------------------|
| 0   | IRQ_SEL | IWDG 溢出操作选择<br>1: 溢出后产生中断<br>0: 溢出后产生复位 |

#### 14.5.7 IWDG\_IGEN 中断生成寄存器

偏移地址: 0x14

复位值: 0x0000 0FFF

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

| Bit   | Field    | Description                                                                                                                                                       |
|-------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12 | Reserved | 保留, 必须保持复位值                                                                                                                                                       |
| 11: 0 | IGEN     | IWDG 中断生成值 (Watchdog Interrupt Generate value)<br>用于定义看门狗中断生成值, 每当计数器值递减等于该值时, 会产生中断。<br>要改变该位数值, 需要先解除保护。<br>当改变数值被更新完成后 IWDG_SR 寄存器中的 IVU 位为 清 0 此时, 读出数据才是有效的。 |

#### 14.5.8 IWDG\_CNT 计数寄存器

偏移地址: 0x18

复位值: 0x0000 0001

|          |    |    |    |    |    |    |    |         |    |    |    |          |    |    |    |  |  |  |  |
|----------|----|----|----|----|----|----|----|---------|----|----|----|----------|----|----|----|--|--|--|--|
| 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23      | 22 | 21 | 20 | 19       | 18 | 17 | 16 |  |  |  |  |
| Res.     |    |    |    |    |    |    |    |         |    |    |    | IWDG_CNT |    |    |    |  |  |  |  |
| r        |    |    |    |    |    |    |    |         |    |    |    | r        |    |    |    |  |  |  |  |
| IWDG_CNT |    |    |    |    |    |    |    | IWDG_PS |    |    |    |          |    |    |    |  |  |  |  |
| r        |    |    |    |    |    |    |    | r       |    |    |    |          |    |    |    |  |  |  |  |

| Bit    | Field    | Description         |
|--------|----------|---------------------|
| 31: 19 | Reserved | 保留, 必须保持复位值         |
| 18: 8  | IWDG_CNT | IWDG 计数器 counter 的值 |
| 7: 0   | IWDG_PS  | IWDG 时钟分频计数器的值      |

## 15 UART 通用异步收发器

### 15.1 简介

通用异步收发器(UART)可以灵活地与外部设备进行全双工数据交换。通过分数波特率发生器，UART可以选择宽范围的波特率。异步单向通信和半双工单线通信，IrDA红外功能也能够被支持。另外，UART也支持多处理器之间的通信。

### 15.2 功能框图



图 15-1 UART 功能框图

### 15.3 主要特征

- 支持异步方式下 RS-232S 协议，符合异步串口通信 16550 芯片标准
- 全双工异步操作
- 分数波特率发生器
- 可配置波特率，供发送器和接收器使用，最小分频系数为 1

- 独立的发送和接收缓冲寄存器
- 内置 1 字节发送和 1 字节接收缓冲
- 发送和接收数据低位在前，一个起始位开始，后面接数据位，数据长度可为 5~8 位，最后为停止位；另外可选择是否有奇偶校验位（奇偶校验位在数据位之后，停止位之前）
- 第 9 位可做同步帧配置
- 支持硬件奇/偶校验的产生和检测
- 断开符号的产生和检测
- 空闲符号的产生和检测
- 支持 LIN 协议下收发断开符号
- 支持信号收发互换，接收和发送取反
- 支持波特率自适应功能
- 支持 IrDA SIR ENDEC 规范的红外功能

## 15.4 功能概述

在全双工通信的情况下，至少需要分配两个脚给 UART：接收数据输入（RX）和发送数据输出（TX）。

**RX：**外部串行数据通过该引脚，传送给 UART 接收器。对于传输过程中产生的噪音，可以使用过采样的技术将其与数据区分并剔除，得到原本的数据。

**TX：**UART 发送器内部产生的串行数据通过该引脚发送输出。当发送器被使能，并且无数据发送时，TX 引脚输出高电平。当发送器被除能时，TX 引脚恢复到它的 I/O 端口配置状态。

空闲状态为总线在开始发送或者开始接收前的初始状态。

起始位为一位，用‘0’表示。

一个数据（5, 6, 7 或 8 位），发送和接收顺序为从最低位（LSB）到最高位。

停止位用‘1’表示一帧的结束，位数可配置为 0.5、1、1.5、2 位。

分数波特率发生器：可配置 16 位的整数以及 4 位的小数，从而提高波特率的精度。

通过使能 UART\_GCR 寄存器的 SWAP 位，可以交换接收和发送端的信号。

通过使能 UART\_GCR 寄存器的 RXTOG/ TXTOG 位，可以将接收/发送端的信号取反（包含起始位、停止位也都被取反后再输入/输出）。

### 15.4.1 UART 特性描述

通过配置 UART\_CCR.CHAR 位，可调整字符位长度为 5~8 位。发送器会在发送起始位时拉低 TX 引脚，在发送停止位时拉高 TX 引脚。

包括停止位在内，一个完全由‘1’组成的完整数据帧，定义为一个空闲符号。下一个数据帧的起始位跟在空闲符号之后。

包括停止位在内，一个完全由‘0’组成的完整数据帧，定义为一个断开符号。在断开符号结束后，发送端会再发送一个‘1’的停止位，使得下一帧的起始位能够被识别到（产生下降沿被接收端检测到）。

波特率发生器产生的时钟经过发送器和接收器的使能位置位控制之后，供给发送器或接收器使用。



图 15-2 UART 时序

### 15.4.2 分数波特率发生器

设置 BRR 和 FRA 寄存器，可设置相应波特率，参考如下公式：

$$f_{baudrate} = \frac{f_{PCLK}}{16 \times UARTDIV}$$

$$UARTDIV = BRR + \frac{FRA}{16}$$

$$f_{baudrate} = \frac{f_{PCLK}}{16 \times BRR + FRA}$$

其中 BRR 寄存器最小值为 1，FRA 的值可配置在 0~15 范围。

### 15.4.3 采样

UART 内置检测电路检测一帧数据的开始，并对 RX 引脚进行采样，UART 采用 16 倍数据波特率的时钟采样 RX 引脚的数据，取中间第 7, 8, 9 个时钟下降沿的采样值。



图 15-3 RX 引脚采样方法

#### 15.4.4 容忍度

时钟偏差等因素会导致收发双方波特率的偏差，为了提高接收端对波特率变化的容忍度，在 STOP 状态时，当三次数据采样完成后，接收端就开始准备下一帧数据的接收。当收发双方波特率偏差处于 $\pm 3\%$ 以内时，仍然能保证数据正常传输。

#### 15.4.5 校验控制

奇偶控制（发送时生成一个奇偶位，接收时进行奇偶校验）可以通过配置 `UART_CCR.PEN` 位为‘1’来激活。如果奇偶校验出错，无效数据仍然会从移位寄存器传输到 `UART_RDR` 寄存器。配置 `UART_ICR.RXPERR` 位为‘1’来清除 `UART_ISR.RXPERR_INTF` 标志。

智能卡自动应答有效 (`UART_SCR.SCAEN=1`) 时，在 STOP 状态检测到奇偶校验错误，会产生 1 位的低电平信号 (`RXNACK`)，指示帧错误。

偶校验：校验位加上数据中 1 的个数为偶数。

奇校验：校验位加上数据中 1 的个数为奇数。

奇偶校验位的输出或接收判断，由硬件自动完成，无需软件配置。

例如，数据为 8'b1000\_0110，有 3 个‘1’。

偶校验 (`UART_CCR.PSEL =1`)：校验位将是‘1’。

奇校验 (`UART_CCR.PSEL =0`)：校验位将是‘0’。

奇偶校验使能时，奇偶校验位的发送跟在数据 MSB 位之后；接收时奇偶校验错误，硬件自动置位 `UART_ISR.RXPERR_INTF` 标志。若想产生中断，需要提前配置中断使能寄存器。

注意：如果使能 9bit 功能，则奇偶检验无效。

#### 15.4.6 发送器

`UART_CCR.CHAR` 位的配置决定发送数据的位数 (5~8 位)。配置 `UART_CCR.TXEN` 位为‘1’，使能

发送器，数据会串行输出到 TX 引脚上。

#### 15.4.6.1 字符发送

在 UART 发送期间，数据从 **UART\_TDR** 寄存器写入，经过一字节的缓冲器缓冲，通过发送移位寄存器以最低字节到最高字节的顺序，串行在 TX 引脚上输出。

发送数据顺序：1 位起始位，字符，1 位奇偶校验位（有或无），停止位。

通过配置 **UART\_CCR.CHAR[1:0]** 位来配置字符长度；通过配置 **UART\_CCR.SPB[1:0]** 位来配置停止位的位数。

当前数据输出未完成前不能清零 **UART\_GCR.TXEN** 位，否则波特率发生器会停止产生时钟，导致该数据后部分丢失。

#### 15.4.6.2 配置步骤

1. 配置 **UART\_GCR.UARTEN** 位为‘1’，使能 UART。
2. 配置 **UART\_CCR.CHAR[1:0]** 位，设置字符长度。
3. 配置 **UART\_CCR.SPB[1:0]** 位，设置停止位的位数。
4. 配置 **UART\_BRR** 和 **UART\_FRA**，产生需要的波特率时钟。
5. 配置 **UART\_GCR.TXEN** 位为‘1’，使能发送器。
6. 将待发送数据写入 **UART\_TDR** 寄存器（此时硬件自动清‘0’**UART\_ISR.TX\_INTF** 位）。由于缓冲器为一字节，每次只能写入一个数据，且需要等待缓冲器为空时才能写 **UART\_TDR** 寄存器。

#### 15.4.6.3 通信过程

**UART\_ISR.TX\_INTF** 只能由硬件写‘1’和清‘0’。当该位被硬件置‘1’时，表明：

1. 数据发送已经开始，数据已经从 **UART\_TDR** 寄存器传输到移位寄存器
2. 可向 **UART\_TDR** 寄存器写入下一个传输数据（不会影响当前数据的输出）

UART 发送器处于空闲状态时，软件写 **UART\_TDR** 寄存器，数据被立即搬运至移位寄存器进行串行输出，且置位 **UART\_ISR.TX\_INTF** 标志和 **UART\_CSR.TXEPT** 标志；如果 **UART\_IER.TX\_IEN** 位已配置为‘1’，会产生中断。

可以通过 **TX\_INTF** 中断向 **UART\_TDR** 寄存器写入下一个传输数据，实现连续发送。

当停止位发送完成，且没有写入新的发送数据，会置位 **UART\_ISR.TXC\_INTF** 标志和 **UART\_CSR.TXC** 标志，表明发送已完成；如果 **UART\_IER.TXC\_IEN** 位已配置为‘1’，也会产生中断。



图 15-4 发送时状态位变化

#### 15.4.6.4 断开符号

断开符号的发送只能在 **UART\_CSR.TXC** 为 1 时发起。配置 **UART\_CCR.BRK** 位为‘1’即可发送断开符号。断开符号发送完成后，硬件自动清‘0’**BRK** 位，并发送一位的高电平用于接收端下一帧数据起始位的检测。

断开符号的总长度由‘起始位 + 数据位 + (校验位) + 停止位’构成，长度不固定，会随着数据位、校验位、停止位的设置改变。断开符号发送完成时，会置位 **UART\_ISR.TXBRK\_INTF** 标志。

#### 15.4.6.5 空闲符号

空闲符号的长度由 **UART\_IDLR** 寄存器的值决定。当 **UART\_IDLR** 不为 0 时，在使能 **TXEN** 后，会立即发送一帧空闲符号，再进行有效数据的输出。

### 15.4.7 接收器

#### 15.4.7.1 字符接收

对于 UART 的接收器，RX 串行输入数据，接收顺序从数据最低位到最高位。内置一个接收移位寄存器和一个接收数据寄存器形成双缓冲结构，从而可以实现数据的连续接收。

配置步骤：

1. 配置 **UART\_GCR.UARTEN** 位为 1，使能 UART。
2. 配置 **UART\_CCR.CHAR** 位来设置字符长度。
3. 配置 **UART\_CCR.SPB** 位来设置停止位的位数。
4. 配置 **UART\_BRR** 和 **UART\_FRA**，产生需要的波特率时钟。
5. 配置 **UART\_GCR.RXEN** 位为 1，使能接收器，等待检测起始位。
6. 当接收到一个完整帧时，接收移位寄存器的数据被传输到 **RDR** 寄存器，硬件置位

**UART\_ISR.RX\_INTF** 标志和 **UART\_CSR.RXAVL** 标志，表明数据已经被接收并且可以被读出。如果硬件检测到数据接收错误时，会置位相应的错误标志。

7. 通过配置 **UART\_IER.RX\_IEN** 位为‘1’，使能接收中断。
8. 在接收期间如果检测到帧错误、溢出错误或奇偶校验错误，硬件置位相应的错误标志。
9. 软件读 **UART\_RDR** 寄存器，或配置 **UART\_ICR.RX\_ICLR** 位为‘0’，实现清‘0’**UART\_ISR.RX\_INTF** 位。为了防止溢出错误，在下一字符接收结束前 **RX\_INTF** 位必须被清零。

在接收数据时，软件不应该清零 **RXEN** 位，否则还在 **RX** 引脚上的数据将不再被接收。

#### 15.4.7.2 断开符号

UART 接收器识别到一个断开符号时，会置位 **RXBRK\_INTF** 标志，且数据不会被写入接收缓冲器。断开符号由‘起始位 + 数据位 +（校验位）+ 停止位’构成，长度不固定，会随着数据位、校验位、停止位设置而变化。

#### 15.4.7.3 空闲符号

空闲符号长度由 **UART\_IDLR** 寄存器决定（默认值为 0x0C）。当 **UART\_IDLR** 不为 0 时，接收到一个空闲符号，硬件会置位 **UART\_ISR.RXIDLE\_INTF** 标志，数据不会被写入接收缓冲器。

#### 15.4.7.4 溢出错误

如果 **UART\_RDR** 没有被读出，又接收到一个字符则发生溢出错误。当产生溢出错误时，表明：

1. 硬件将置位 **UART\_ISR.RXOERR\_INTF** 标志。
2. 未读出的 **UART\_RDR** 内容不会丢失，读 **UART\_RDR** 寄存器仍然得到此数据。
3. 后接收到的字符将被丢失。

如果 **UART\_IER.RXOERR\_IEN** 位已配置为‘1’，会产生中断。

#### 15.4.7.5 帧错误

当停止位没有在预期的时间上被识别出，接收器会产生帧错误。当帧错误被检测到时，表明：

1. 硬件将置位 **UART\_ISR.RXFERR\_INTF** 标志。
2. **UART\_RDR** 寄存器不会被更新。

如果 **UART\_IER.RXFERR\_IEN** 位已配置为‘1’，会产生中断。

#### 15.4.8 自动波特率检测

UART 能够根据接收到的信号，自动检测并重置 **UART\_BRR** 寄存器。自动波特率配置如下：

1. 配置 **UART\_ABRCR** 寄存器的 **Former\_edge** 和 **Latter\_edge**, 选择自动波特率开始及结束的边沿方式(上升或下降)。
2. 配置 **UART\_ABRCR.Abr\_bitcnt**, 选择自动波特率的数据位长度。
3. 配置 **UART\_ABRCR.Abre** 位为‘1’, 打开自动波特率功能。
4. 配置 **UART\_IER.ABREND\_IEN** 位为‘1’, 自动波特率结束后会产生中断。
5. 配置 **UART\_IER.ABRERR\_IEN** 位为‘1’, 自动波特率检测发生错误, 会产生错误中断。

**示例 1:** 设置 **Former\_edge=1** (上升沿), **Latter\_edge=0** (下降沿), **Abr\_bitcnt=2** (4 位长度)。

当接收到数据 0x0F 时, 将对 RX 线上数据 (起始位->MSB 位: 0\_1111\_0000) 的低四位 0xF 进行波特率检测, 然后重置 **UART\_BRR** 寄存器, 并置位 **UART\_ISR.ABREND\_INTF** 标志。

**示例 2:** 设置 **Former\_edge=0** (下降沿), **Latter\_edge=1** (上升沿), **Abr\_bitcnt=2** (4 位长度)。

当接收到数据 0x08 时, 将对 RX 线上数据 (起始位->MSB 位: 0\_0001\_0000) 的‘起始位+最低三位数据’进行波特率检测, 然后重置 **UART\_BRR** 寄存器, 并置位 **UART\_ISR.ABREND\_INTF** 标志。

注意: 检测边沿和数据长度的配置, 应该与接收数据相匹配。例如, 当 **Former\_edge=1**, 而接收数据的最低位不为‘1’, 硬件会置位 **UART\_ISR.ABRERR\_INTF** 标志。

另外, 当自动波特率检测开始前, 通过软件初始配置的波特率与发送侧波特率相差过大, 可能会导致自动波特率功能失效。

#### 15.4.9 九位数据通信

通过配置 **UART\_CCR** 寄存器的相关配置, 来实现 9 位数据通信。具体如下:

**B8EN** 为‘1’, 将使能 9 位数据的发送和接收。

在 **B8EN** 使能后, 奇偶校验使能位 **PEN** 无效。

数据发送时, 需要先设置 **B8TXD**; **B8TXD** 作为发送数据的 MSB 和 **UART\_TDR** 的值一起发送。**B8TXD** 与 **B8POL** 相同时, 表示该数据作为地址帧或者同步帧。**B8TOG** 为‘1’, 当前帧发送结束后 **B8TXD** 会自动翻转, 下一个数据帧无需再配置 **B8TXD**。

数据接收时, 接收数据的第 9 位可以从 **B8RXD** 读到; **B8RXD** 与 **B8POL** 相同时, 硬件置位 **UART\_ISR.RXB8\_INTF** 标志。

#### 15.4.10 多处理器通信

多个处理器通信可以通过将多个 **UART** 连在一个网络里实现。作为主设备的 **UART**, 它的 **TX** 输出连接其余从设备的 **RX** 输入; 而其余从设备的 **TX** 输出逻辑相与之后, 连接到主设备的 **RX** 输入。

主机通过寻址方式找到目的从机, 而其他非目的从机应该保持在一个较低功耗的模式, 以避免资源浪费。

当从设备不是目的从机时, 配置此从机进入静默模式来降低功耗。在静默模式里:

1. 硬件不会置位所有的接收相关状态标志位。

## 2. 不会产生所有接收相关的中断。

软硬件均可改写 **UART\_CCR.RWU** 位。配置 **UART\_CCR.RWU** 位为‘1’，使接收器进入静默模式。在设置地址标记唤醒时，如果接收缓冲器非空（接收地址未匹配从机），则软件不能配置 **RWU** 位为‘0’来退出静默模式。

通过配置 **UART\_CCR.WAKE** 位，选择退出静默模式的检测方式：

1. **WAKE=0**: 空闲总线检测。
2. **WAKE=1**: 地址标记检测。

### 15.4.10.1 空闲总线检测

静默模式下，**UART\_CCR.WAKE=0**，从设备进行空闲符号检测。如果在 **RX** 线上检测空闲符号，硬件在自动清‘0’**UART\_CCR.RWU** 位，并退出静默模式。由于没有正常帧输入，硬件不会置位 **UART\_ISR.RX\_INTF** 标志。

### 15.4.10.2 地址标记（Address Mark）检测

静默模式下，**UART\_CCR.WAKE=1**，从设备进行地址标记检测。

接收字节有效位的最高位作为地址帧或数据帧的识别标记，因此，最高位等于 **B8POL** 则代表该字节为地址帧；反之，则为数据帧。

从机接收器将 **UART\_RXADDR** 寄存器的配置值作为该从机地址，与接收到的地址帧比较。应注意，**UART\_RXMASK** 寄存器具备地址掩码功能，只有当它某一位为 1 时，相应的地址位才会参与比较；为 0 则直接认为该位匹配成功。

若从机接收的地址帧经过地址掩码后匹配失败，硬件置位 **UART\_CCR.RWU** 位并进入静默模式。由于本从机处于静默模式，接收到的地址帧将不会导致相关的硬件响应（比如触发标志位、中断请求等）。

若从机接收的地址帧经过地址掩码后匹配成功，硬件自动清‘0’**UART\_CCR.RWU** 位并退出静默模式。由于本从机已经退出静默模式，此地址帧会触发 **UART\_ISR.RX\_INTF** 标志，之后接收器正常工作。

### 15.4.10.3 配置步骤

多处理器通信的实现，建立在九位数据通信使能的基础上，需以下步骤。

主机发送时，可参考（发送器）进行，另注意如下：

1. 在使能 **TXEN** 前，配置 **B8EN** 位为‘1’，并配置 **B8TxD** 与 **B8POL** 位。如果配置 **B8TxD=B8POL=1**，从设备检测到最高位的高电平认为是地址帧；如果配置 **B8TxD=B8POL=0**，从设备检测到最高位的低电平认为是地址帧。此时如果配置 **B8TOG** 位为‘1’，无需步骤 3 中的 **B8TxD** 配置。
2. 使能 **TXEN** 后，再写 **TDR** 数据作为地址值，与 **B8TxD** 一起作为地址帧发送到 **TX** 线上。
3. 之后再配置 **B8TxD** 为 **B8POL** 的相反值，并写 **TDR**，将紧接着发送数据帧。

4. 根据发送的数据类型（地址帧或数据帧），按照步骤 3 所示操作，改写 B8TXD 和 TDR，实现主机的连续发送（地址帧+数据帧+... ...）。

从机接收时，可参考（接收器）进行，另注意如下：

1. 在使能 RXEN 前，配置 B8EN 位为‘1’，同时配置 B8POL 位（作为判断当前字符为地址帧或数据帧的标志，与 B8RXD 位进行比较，相同则认为是地址帧，否则为数据帧）。

2. 在使能 RXEN 前，还需配置 WAKE 位来选择从机退出静默模式的检测方式。如果配置 WAKE=1，还需配置本机的从机地址（配置 RXADDR 和 RXMASK 寄存器）。

3. 使能 RXEN 后，如果 WAKE=0，通过写 RWU=1 使从机进入静默模式，之后从机接收器将在检测到空闲帧时自动退出静默模式（硬件会清‘0’RWU 位）。

4. 使能 RXEN 后，如果 WAKE=1，可通过软件配置 RWU 位为‘1’使从机进入静默模式，之后从机接收器将进行地址标记检测。另外硬件将会在地址匹配失败时置位 RWU 并进入静默模式。

#### 15.4.11 单线半双工通信

配置 UART\_SCR.HDSEL 位为‘1’，选择单线半双工模式，芯片内部逻辑会将 TX 与 RX 互连。需注意 UART\_SCR.SCEN 位应配置为‘0’。

单线半双工时：

1. RX 引脚悬空，不参与传输。UART 的 TX 直接连接另一个 UART 的 TX。
2. 在传输数据时，TX 一直被占用，直到停止位发送完成。
3. 在没有传输数据时，TX 处于被释放状态。因此，它在空闲状态的或接收状态时表现为一个标准 I/O 口；TX 对应 I/O 在不被 UART 驱动时，必须配置成悬空输入（或开漏的输出高）。

除了单线引脚的配置外，其余配置和正常传输一致。

在没有通信前，两个 UART 的 UART\_GCR.RXEN 都开启，处于等待接收状态。当需要通信时，两个 UART 需要约定好谁来发送；发送方 RXEN 关闭，TXEN 使能。如果两边 UART 都试图发送数据，将产生发送冲突（硬件不会阻碍 UART 的发送：当发送使能位 TXEN 开启，只要写 UART\_TDR，TX 就会发送数据）。

#### 15.4.12 智能卡

配置 UART\_SCR.SCEN 位为‘1’进入智能卡模式，硬件将自动为半双工模式（不用设置 UART\_SCR.HDSEL 位）。

该模式下的 UART 符合 ISO7816-3 标准，在 TXEN 或 RXEN 使能前还需以下步骤：

1. 8 位数据位+校验位：UART\_CCR 寄存器配置 CHAR=11、PEN=1。
2. 发送和接收均推荐为 1.5 个停止位：UART\_CCR 寄存器配置 SPB1=1、SPB0=1。
3. 如需使能 NACK 信号：UART\_SCR 寄存器配置 SCAEN=1。
4. 智能卡保护时间配置：UART\_SCR 寄存器配置 SCFCNT。

下图举例说明，有校验错误和无校验错误的两种情况下，TX 线上信号区别。



图 15-5 UART 奇偶校验方框图

UART 作为主机，为了能够识别从机方向反馈的校验错误信号（1位低电平：NACK信号），UART 发送数据时需使能 TXEN，而在停止位发送完毕后应该除能 TXEN，同时 TX 被拉到高电平（TX 应被配置成开漏模式）。

UART 作为主机，需要用 TX 单线驱动智能卡端的双向线，TX 与 RX 实质上使用的同一个 IO 口。

#### 智能卡通信协议：

1. 从机数据被传输至移位寄存器，再到 TX 引脚上串行输出，相比正常模式下的发送时间会多至少  $1/2$  波特时钟周期。正常模式下，TX 引脚出现数据的时间是在发送移位寄存器满时的下一个波特时钟沿；而智能卡模式 TX 引脚出现数据的时间会比正常模式慢  $1/2$  波特时钟。
2. 从机接收器在数据帧的停止位（推荐为 1.5 位）接收期间，检测到了奇偶校验错误，会拉低数据线一个波特时钟周期（NACK 信号）。由于数据线被拉低，相当于主机发送了一个帧错误（停止位被拉低成‘0’）。主机收到反馈后，软件利用这个反馈信号可根据协议处理重发数据。注意，需要输出该 NACK 信号，应配置 UART\_SCR.SCAEN 位为‘1’。
3. 智能卡模式下存在保护时间，即通过配置 UART\_SCR.SCFCNT[7:0]，来延长 UART\_CSR.TXC 标志的置位时间；奇偶校验结束后，对应的保护时间计数器就会启动累加，当计数器的值累加到等于配置的保护时间寄存器的值时，TxC 标志才会被置位。而在正常传输模式（非智能卡）下，硬件置位 TxC 的条件是发送缓冲器为空且没有后续数据写入 TDR。
4. 智能卡模式不会影响硬件写 TDR 时，自动清‘0’TxC 标志的时序。
5. 如果主机收到从机的 NACK 信号，主机的接收器不会把 NACK 当作起始位检测。
6. 从机接收器检测到校验错误后，其反馈给主机的 NACK 信号也不会被认为是起始位。

注意：

a. 智能卡模式中没有断开符号的定义；一个包括停止位在内的全‘0’数据帧将被识别为帧错误。

b. 智能卡模式中没有空闲符号的定义；当来回切换 TXEN 位时，不会认为接收到空闲符号。

下图说明了 UART 对于 NACK 信号的采样逻辑，使能 UART 的接收器，用于检查数据的完整性和 NACK 信号（停止位为 1.5 位，其中 1 个 NACK 位处于停止位的后段）。



图 15-6 UART 采样 NACK 信号方框图

#### 15.4.13 红外 IrDA 功能

UART 模块支持 IrDA (infrared data association) SIR ENDEC 规范；IrDA SIR 物理层规定使用反相归零调制方案 (RZI)。

该方案用一个红外光脉冲代表逻辑“0”。正常模式下，“0”的脉宽为 3/16 的波特率；低功耗模式下，频率范围应配置在 ( $1.42 \text{ MHz} < \text{sirlp\_clk} < 2.12 \text{ MHz}$ )，脉冲的宽度是的  $\text{sirlp\_clk} * 3$ ， $\text{sirlp\_clk}$  可通过配置 `UART_IRDA.PSC_REG[7: 0]` 来将系统时钟 `pclk` 分频以达到这个值。

SIR 发送编码器和 SIR 接收解码器实现 UART 数据流与红外脉冲流的转换。

IrDA 是一个半双工通信协议，编解码不可同时进行；在 IrDA 模式里，`UART_CCRL` 寄存器上的停止位必须配置成 1 个。

在 TXEN 或 RXEN 使能前还需以下步骤：

1. 使能红外功能：`UART_IRDA` 寄存器配置 `Siren=1`。
2. 低功耗模式时：提前配置 `UART_IRDA` 寄存器 `PSC_REG` 和 `Sirlp=1`。

下图示意了数据格式转换的样式：



图 15-7 普通模式下 IrDA 发送和接收图

## 15.5 中断

支持下面中断源：

- 发送缓冲空
- 接收数据有效
- 接收溢出错误
- 帧错误
- 奇偶校验错误
- 接收断开帧
- 发送移位寄存器完成
- 发送断开帧完成
- 接收同步帧
- 检测到空闲帧
- 自动波特率结束
- 自动波特率错误

表 15-1 UART 中断请求

| 中断事件      | 中断状态        | 使能位      |
|-----------|-------------|----------|
| 发送缓冲空     | TX_INTF     | TXIEN    |
| 接收到有效数据   | RX_INTF     | RXIEN    |
| 发送移位寄存器完成 | TXC_INTF    | TXC_EN   |
| 接收溢出错误    | RXOERR_INTF | RXOERREN |
| 奇偶校验错误    | RXPERR_INTF | RXPERREN |
| 帧错误       | RXFERR_INTF | RXFERREN |

| 中断事件    | 中断状态        | 使能位       |
|---------|-------------|-----------|
| 接收断开帧   | RXBRK_INTF  | RXBRKEN   |
| 发送断开帧   | TXBRK_INTF  | TXBRK_EN  |
| 接收同步帧   | RXB8_INTF   | RXB8_EN   |
| 接收空闲帧   | RXIDLE_INTF | RXIDLEN   |
| 自动波特率结束 | ABREND_INTF | ABRENDIEN |
| 自动波特率错误 | ABRERR_INTF | ABRERRIEN |

如果设置了对应的中断使能控制位，这些设置就可以产生各自对应的中断。

## 15.6 寄存器

### 15.6.1 寄存器总览

表 15-2 UART 寄存器概览

| Offset | Acronym     | Register Name         | Reset      |
|--------|-------------|-----------------------|------------|
| 0x00   | UART_TDR    | UART 发送数据寄存器          | 0x00000000 |
| 0x04   | UART_RDR    | UART 接收数据寄存器          | 0x00000000 |
| 0x08   | UART_CSR    | UART 当前状态寄存器          | 0x00000009 |
| 0x0C   | UART_ISR    | UART 中断状态寄存器          | 0x00000000 |
| 0x10   | UART_IER    | UART 中断使能寄存器          | 0x00000000 |
| 0x14   | UART_ICR    | UART 中断清除寄存器          | 0x00000000 |
| 0x18   | UART_GCR    | UART 全局控制寄存器          | 0x00000000 |
| 0x1C   | UART_CCR    | UART 通用控制寄存器          | 0x00000000 |
| 0x20   | UART_BRR    | UART 波特率寄存器           | 0x00000001 |
| 0x24   | UART_FRA    | UART 分数波特率寄存器         | 0x00000000 |
| 0x28   | UART_RXADDR | UART 接收地址寄存器          | 0x00000000 |
| 0x2C   | UART_RXMASK | UART 接收掩码寄存器          | 0x000000FF |
| 0x30   | UART_SCR    | UART SCR 寄存器          | 0x00000000 |
| 0x34   | UART_IDLR   | UART IDLE 数据长度寄存器     | 0x0000000C |
| 0x38   | UART_ABRCR  | UART ABRCR 自动波特率控制寄存器 | 0x00000000 |
| 0x3C   | UART_IRDA   | UART IRDA 红外功能控制寄存器   | 0x00000100 |

### 15.6.2 UART\_TDR 发送数据寄存器

偏移地址: 0x00

复位值: 0x0000 0000

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

|      |       |
|------|-------|
| Res. | TXREG |
|      | rw    |

| Bit   | Field    | Description                      |
|-------|----------|----------------------------------|
| 31: 9 | Reserved | 保留, 始终读为 0                       |
| 8: 0  | TXREG    | 发送数据寄存器 (Transmit data register) |

### 15.6.3 UART\_RDR 接收数据寄存器

偏移地址: 0x04

复位值: 0x0000 0000

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

| Bit   | Field    | Description                               |
|-------|----------|-------------------------------------------|
| 31: 9 | Reserved | 保留, 始终读为 0                                |
| 8: 0  | RXREG    | 接收数据寄存器 (Receive data register)<br>该寄存器只读 |

### 15.6.4 UART\_CSR 当前状态寄存器

偏移地址: 0x08

复位值: 0x0000 0009

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |       |        |       |     |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|--------|-------|-----|
| 31   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17    | 16     |       |     |
| Res. |    |    |    |    |    |    |    |    |    |    |    |    |    |       |        |       |     |
| 15   | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1     | 0      |       |     |
| Res. |    |    |    |    |    |    |    |    |    |    |    |    |    |       |        |       |     |
|      |    |    |    |    |    |    |    |    |    |    |    |    |    | TXEPT | TXFULL | RXAVL | TXC |
|      |    |    |    |    |    |    |    |    |    |    |    |    |    | r     | r      | r     | r   |

| Bit   | Field    | Description                                                          |
|-------|----------|----------------------------------------------------------------------|
| 31: 4 | Reserved | 保留, 始终读为 0                                                           |
| 3     | TXEPT    | 发送缓冲空标识位 (Transmit buffer empty flag bit)<br>0: 发送缓冲不为空<br>1: 发送缓冲为空 |

| Bit | Field  | Description                                                                                                                     |
|-----|--------|---------------------------------------------------------------------------------------------------------------------------------|
| 2   | TXFULL | 发送缓冲满标识位 (Transmit buffer full flag bit)<br>0: 发送缓冲不满<br>1: 发送缓冲满                                                               |
| 1   | RXAVL  | 接收有效字节数据标识位 (Receive valid data flag bit)<br>当接收缓冲接收了一个完整字节的数据时置位该位。<br>0: 接收缓冲为空<br>1: 接收缓冲接收了一个完整有效的字节数据                      |
| 0   | TXC    | 发送结束标识位 (Transmit complete flag bit)<br>0: 发送不为空<br>1: 发送缓冲和发送移位寄存器都为空<br>注: 此标识位在智能卡 (ISO7816) 时与保护时间 (UART_SCR.SCFCNT 配置) 相关。 |

### 15.6.5 UART\_ISR 中断状态寄存器

偏移地址: 0x0C

复位值: 0x0000 0000

|        |    |    |    |        |       |        |        |        |        |        |        |        |        |        |        |
|--------|----|----|----|--------|-------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|
| 31     | 30 | 29 | 28 | 27     | 26    | 25     | 24     | 23     | 22     | 21     | 20     | 19     | 18     | 17     | 16     |
| Res.   |    |    |    |        |       |        |        |        |        |        |        |        |        |        |        |
| 15     | 14 | 13 | 12 | 11     | 10    | 9      | 8      | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
| Res.   |    |    |    | ABRER  | ABREN | RXIDLE | RXB8_I | TXBRK_ | RXBRK  | RXFER  | RXPER  | RXOER  | TXC_IN | RX_INT | TX_INT |
| R_INTF |    |    |    | D_INTF | _INTF | NTF    | INTF   | _INTF  | R_INTF | R_INTF | R_INTF | R_INTF | TF     | F      | F      |
| r      |    |    |    | r      | r     | r      | r      | r      | r      | r      | r      | r      | r      | r      | r      |

| Bit    | Field       | Description                                                                                                                       |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31: 12 | Reserved    | 保留, 始终读为 0                                                                                                                        |
| 11     | ABRERR_INTF | UART 自动波特率错误中断标志位 (Auto baud rate error interrupt flag bit)<br>0: 无自动波特率错误<br>1: 自动波特率错误                                          |
| 10     | ABREND_INTF | UART 自动波特率结束中断标志位 (Auto baud rate end interrupt flag bit)<br>0: 自动波特率未结束<br>1: 自动波特率结束                                            |
| 9      | RXIDLE_INTF | UART 接收空闲帧中断标志位 (Receive frame idle interrupt flag bit)<br>在停止位后 RX 引脚在一段时间内接收到若干 (UART_IDLR 数量) 高电平。<br>0: 没有检测到空闲帧<br>1: 检测到空闲帧 |
| 8      | RXB8_INTF   | UART 同步帧中断标志位<br>在 9 位通讯模式下, 当接收到到数据的第九位与寄存器 CCR.B8POL 相同时, RXB8_INT 位置。该位可以作为中断请求信号<br>0: 没有接收到同步帧<br>1: 接收到同步帧                  |

| Bit | Field       | Description                                                                                                                      |
|-----|-------------|----------------------------------------------------------------------------------------------------------------------------------|
| 7   | TXBRK_INTF  | UART 断开帧发送完成中断标志位<br>1: 移位寄存器断开帧数据发送完成<br>0: 移位寄存器空或正在移位发送备注: 不能连续发送断开帧。                                                         |
| 6   | RXBRK_INTF  | UART 接收断开帧中断标志位 (Receive frame break interrupt flag bit)<br>在异常停止位后 RX 引脚在一段时间内接收到 10 个或大于 10 位的低电平。<br>0: 没有检测到断开帧<br>1: 检测到断开帧 |
| 5   | RXFERR_INTF | 帧错误中断标志位 (Frame error interrupt flag bit)<br>帧错误发生在当检测到异常停止位。<br>0: 没有检测到帧错误<br>1: 检测到帧错误                                        |
| 4   | RXPERR_INTF | 奇偶校验错误中断标志位 (Parity error interrupt flag bit)<br>0: 没有检测到奇偶校验错误<br>1: 检测到奇偶校验错误                                                  |
| 3   | RXOERR_INTF | 接收溢出错误中断标志位 (Receive overflow error interrupt flag bit)<br>0: 没有溢出错误<br>1: 接收溢出错误                                                |
| 2   | TXC_INTF    | UART 发送移位寄存器完成中断标志位。<br>0: 移位寄存器空或正在移位发送<br>1: 移位寄存器数据发送完成<br>注: 此标志位在智能卡 (ISO7816) 时与保护时间 (UART_SCR.SCFCNT 配置) 相关。              |
| 1   | RX_INTF     | 接收有效数据中断标志位 (Receive valid data interrupt flag bit)<br>当接收缓冲接收了一个完整字节的数据时置位该位。<br>0: 接收缓冲为空<br>1: 接收缓冲有效字节数据                     |
| 0   | TX_INTF     | 发送缓冲空中断标志位 (Transmit buffer empty interrupt flag bit)<br>0: 发送缓冲不为空<br>1: 发送缓冲空                                                  |

### 15.6.6 UART\_IER 中断使能寄存器

偏移地址: 0x10

复位值: 0x0000 0000

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

|      |    |    |    |       |       |        |          |           |           |             |             |             |          |        |        |
|------|----|----|----|-------|-------|--------|----------|-----------|-----------|-------------|-------------|-------------|----------|--------|--------|
| 15   | 14 | 13 | 12 | 11    | 10    | 9      | 8        | 7         | 6         | 5           | 4           | 3           | 2        | 1      | 0      |
| Res. |    |    |    | ABRER | ABREN | RXIDLE | RXB8_IEN | TXBRK_IEN | RXBRK_IEN | RXFER_R_IEN | RXPER_R_IEN | RXOER_R_IEN | TXC_IE_N | RX_IEN | TX_IEN |
| rw   |    |    |    | rw    | rw    | rw     | rw       | rw        | rw        | rw          | rw          | rw          | rw       | rw     | rw     |

| Bit    | Field      | Description                                                                      |
|--------|------------|----------------------------------------------------------------------------------|
| 31: 12 | Reserved   | 保留, 始终读为 0                                                                       |
| 11     | ABRERR_IEN | 自动波特率错误中断使能 (Auto baud rate error enable bit)。<br>0: 中断禁止<br>1: 中断使能             |
| 10     | ABREND_IEN | 自动波特率结束中断使能 (Auto baud rate end enable bit)。<br>0: 中断禁止<br>1: 中断使能               |
| 9      | RXIDLE_IEN | 接收空闲帧中断使能位 (Receive frame idle interrupt enable bit)<br>0: 中断禁止<br>1: 中断使能       |
| 8      | RXB8_IEN   | UART 同步帧中断使能控制位。<br>0: 禁止接收同步帧中断<br>1: 使能接收同步帧中断                                 |
| 7      | TXBRK_IEN  | UART 断开帧发送完成中断使能控制位。<br>0: 禁止发送断开帧完成中断<br>1: 使能发送断开帧完成中断                         |
| 6      | RXBRK_IEN  | UART 接收断开帧中断使能位 (Receive frame break interrupt enable bit)<br>0: 中断禁止<br>1: 中断使能 |
| 5      | RXFERR_IEN | 帧错误中断使能位 (Frame error interrupt enable bit)<br>0: 中断禁止<br>1: 中断使能                |
| 4      | RXPERR_IEN | 奇偶校验错误中断使能位 (Parity error interrupt enable bit)<br>0: 中断禁止<br>1: 中断使能            |
| 3      | RXOERR_IEN | 接收溢出错误中断使能位 (Receive overflow error interrupt enable bit)<br>0: 中断禁止<br>1: 中断使能  |
| 2      | TXC_IEN    | UART 发送移位寄存器完成中断使能控制位。<br>0: 中断禁止<br>1: 中断使能                                     |
| 1      | RX_IEN     | 接收缓冲中断使能位 (Receive buffer interrupt enable bit)<br>0: 中断禁止<br>1: 中断使能            |
| 0      | TX_IEN     | 发送缓冲空中断使能位 (Transmit buffer empty interrupt enable bit)<br>0: 中断禁止<br>1: 中断使能    |

### 15.6.7 UART\_ICR 中断清除寄存器

偏移地址: 0x14

复位值: 0x0000 0000

|      |    |    |    |                 |                 |                 |               |                 |                 |                 |                 |                 |              |             |             |
|------|----|----|----|-----------------|-----------------|-----------------|---------------|-----------------|-----------------|-----------------|-----------------|-----------------|--------------|-------------|-------------|
| 31   | 30 | 29 | 28 | 27              | 26              | 25              | 24            | 23              | 22              | 21              | 20              | 19              | 18           | 17          | 16          |
| Res. |    |    |    |                 |                 |                 |               |                 |                 |                 |                 |                 |              |             |             |
| 15   | 14 | 13 | 12 | 11              | 10              | 9               | 8             | 7               | 6               | 5               | 4               | 3               | 2            | 1           | 0           |
| Res. |    |    |    | ABRER<br>R_ICLR | ABREN<br>D_ICLR | RXIDLE<br>_ICLR | RXB8_I<br>CLR | TXBRK_<br>_ICLR | RXBRK<br>R_ICLR | RXFER<br>R_ICLR | RXPER<br>R_ICLR | RXOER<br>R_ICLR | TXC_IC<br>LR | RX_ICL<br>R | TX_ICL<br>R |
|      |    |    |    | w               | w               | w               | w             | w               | w               | w               | w               | w               | w            | w           | w           |

| Bit    | Field       | Description                                                                            |
|--------|-------------|----------------------------------------------------------------------------------------|
| 31: 12 | Reserved    | 保留, 始终读为 0                                                                             |
| 11     | ABRERR_ICLR | UART 自动波特率错误中断清除位 (Auto baud rate error clear bit)<br>0: 写 0 无意义<br>1: 写 1 清除中断        |
| 10     | ABREND_ICLR | UART 自动波特率结束中断清除位 (Auto baud rate end clear bit)<br>0: 写 0 无意义<br>1: 写 1 清除中断          |
| 9      | RXIDLE_ICLR | UART 接收空闲帧中断清除位 (Receive frame idle interrupt clear bit)<br>0: 写 0 无意义<br>1: 写 1 清除中断  |
| 8      | RXB8_ICLR   | UART 同步帧中断标志清除控制位。<br>0: 写 0 无意义<br>1: 清除接收同步帧中断标志                                     |
| 7      | TXBRK_ICLR  | UART 断开帧发送完成中断标志清除控制位。<br>0: 写 0 无意义<br>1: 清除断开帧发送完成中断标志                               |
| 6      | RXBRK_ICLR  | UART 接收断开帧中断清除位 (Receive frame break interrupt clear bit)<br>0: 写 0 无意义<br>1: 写 1 清除中断 |
| 5      | RXFERR_ICLR | 帧错误中断使能位 (Frame error interrupt enable bit)<br>0: 写 0 无意义<br>1: 写 1 清除中断               |
| 4      | RXPERR_ICLR | 奇偶校验错误中断清除位 (Parity error interrupt clear bit)<br>0: 写 0 无意义<br>1: 写 1 清除中断            |
| 3      | RXOERR_ICLR | 接收溢出错误中断清除位 (Receive overflow error interrupt clear bit)<br>0: 写 0 无意义<br>1: 写 1 清除中断  |

| Bit | Field    | Description                                                                         |
|-----|----------|-------------------------------------------------------------------------------------|
| 2   | TXC_ICLR | 发送完成中断清除位 (Transmit complete interrupt clear bit)<br>0: 写 0 无意义<br>1: 写 1 清除中断      |
| 1   | RX_ICLR  | 接收中断清除位 (Receive interrupt clear bit)<br>0: 写 0 无意义<br>1: 写 1 清除中断                  |
| 0   | TX_ICLR  | 发送缓冲空中断清除位 (Transmit buffer empty interrupt clear bit)<br>0: 写 0 无意义<br>1: 写 1 清除中断 |

### 15.6.8 UART\_GCR 全局控制寄存器

偏移地址: 0x18

复位值: 0x0000 0000

|      |    |    |    |    |       |       |      |       |      |    |      |      |      |    |        |
|------|----|----|----|----|-------|-------|------|-------|------|----|------|------|------|----|--------|
| 31   | 30 | 29 | 28 | 27 | 26    | 25    | 24   | 23    | 22   | 21 | 20   | 19   | 18   | 17 | 16     |
| Res. |    |    |    |    |       |       |      |       |      |    |      |      |      |    |        |
| 15   | 14 | 13 | 12 | 11 | 10    | 9     | 8    | 7     | 6    | 5  | 4    | 3    | 2    | 1  | 0      |
| Res. |    |    |    |    | TXTOG | RXTOG | SWAP | SELB8 | Res. |    | TXEN | RXEN | Res. |    | UARTEN |
|      |    |    |    |    | rw    | rw    | rw   | rw    |      |    | rw   | rw   |      |    | rw     |

| Bit    | Field    | Description                                                                                            |
|--------|----------|--------------------------------------------------------------------------------------------------------|
| 31: 11 | Reserved | 保留, 始终读为 0                                                                                             |
| 10     | TXTOG    | 发送取反位<br>0: 无效<br>1: 发送取反                                                                              |
| 9      | RXTOG    | 接收取反<br>0: 无效<br>1: 接收取反                                                                               |
| 8      | SWAP     | 输入与输出交换<br>0: 无效<br>1: 输入输出交换<br>注: SWAP 置位后, GPIOx_CRL 寄存器的 MODE 需要更改, 如: 原输入模式变为输出模式。                |
| 7      | SELB8    | 选择 B8 数据接收或发送是否有效<br>0: 无效<br>1: B8 数据收发<br>UART_CCR 位 B8EN 有效时, 发送时发送 9 位数据; 接收时接收寄存器位 CHAR +1 的数据长度。 |
| 6: 5   | Reserved | 保留, 始终读为 0                                                                                             |

| Bit  | Field    | Description                                                          |
|------|----------|----------------------------------------------------------------------|
| 4    | TXEN     | 发送使能位 (Enable transmit)<br>0: 发送禁止。可以清除 TX BUFFER<br>1: 发送使能         |
| 3    | RXEN     | 接收使能位 (Enable receive)<br>0: 接收禁止。可以清除 RX BUFFER.<br>1: 接收使能         |
| 2: 1 | Reserved | 预留, 必须保持复位值。                                                         |
| 0    | UARTEN   | UART 模块选择位 (UART mode selection bit)<br>0: UART 模块禁止<br>1: UART 模块使能 |

### 15.6.9 UART\_CCR 通用空制寄存器

偏移地址: 0x1C

复位值: 0x0000 0000

|      |     |      |     |      |       |       |       |       |      |      |    |     |      |      |     |
|------|-----|------|-----|------|-------|-------|-------|-------|------|------|----|-----|------|------|-----|
| 31   | 30  | 29   | 28  | 27   | 26    | 25    | 24    | 23    | 22   | 21   | 20 | 19  | 18   | 17   | 16  |
| Res. |     |      |     |      |       |       |       |       |      |      |    |     |      |      |     |
| 15   | 14  | 13   | 12  | 11   | 10    | 9     | 8     | 7     | 6    | 5    | 4  | 3   | 2    | 1    | 0   |
| Res. | LIN | WAKE | RWU | B8EN | B8TOG | B8POL | B8TXD | B8RXD | SPB1 | CHAR |    | BRK | SPB0 | PSEL | PEN |
|      | rw  | rw   | rw  | rw   | rw    | rw    | rw    | r     | rw   | rw   |    | rw  | rw   | rw   | rw  |

| Bit    | Field    | Description                                                                                                                               |
|--------|----------|-------------------------------------------------------------------------------------------------------------------------------------------|
| 31: 15 | Reserved | 保留, 始终读为 0                                                                                                                                |
| 14     | LIN      | UART LIN 协议收发断开帧 (UART LIN enable bit)<br>0: LIN 协议无效<br>1: LIN 协议有效                                                                      |
| 13     | WAKE     | 唤醒方法。<br>该位决定把 UART 唤醒的方法。<br>0: 空闲总线唤醒<br>1: 地址标记唤醒                                                                                      |
| 12     | RWU      | 接收静默。<br>该位用来决定是否把 UART 置于静默模式。该位可以由软件设置或清除。当唤醒序列到来时, 硬件也会自动将其清零。<br>0: 接收器处于正常工作模式<br>1: 接收器处于静默模式<br>在设置地址标记唤醒时, 如果接收 buffer 非空则不能软件修改。 |
| 11     | B8EN     | UART 同步帧第九位使能控制位。<br>该位使能后校验使能位 PEN 不起作用。<br>0: 禁止同步帧第九位发送<br>1: 使能同步帧第九位发送                                                               |

| Bit  | Field | Description                                                                                                                                     |
|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 10   | B8TOG | UART 同步帧发送第九位自动翻转控制位。<br>0: 禁止第九位自动翻转<br>1: 使能第九位自动翻转<br>注: 在 B8TXD 和 B8POL 的值相同时, 在配置完寄存器后传输的第二个数据开始翻转, 第一个数据默认为地址位。                           |
| 9    | B8POL | UART 同步帧第九位极性控制位。<br>0: 同步帧第九位低电平有效<br>1: 同步帧第九位高电平有效                                                                                           |
| 8    | B8TXD | UART 同步帧发送数据第九位。<br>0: 发送同步帧第九位为低电平<br>1: 发送同步帧第九位为高电平                                                                                          |
| 7    | B8RXD | UART 同步帧接收数据第九位。<br>只读。<br>0: 接收同步帧第九位为低电平<br>1: 接收同步帧第九位为高电平                                                                                   |
| 6    | SPB1  | 停止位选择位, 与 SPB0 结合设置停止位数。                                                                                                                        |
| 5: 4 | CHAR  | UART 数据宽度位 (UART width bit)<br>00: 5 位; 01: 6 位<br>10: 7 位; 11: 8 位                                                                             |
| 3    | BRK   | UART 发送断开帧 (UART transmit frame break)<br>0: 不输出断开帧<br>1: 串行强制输出逻辑'0' (断开帧)                                                                     |
| 2    | SPB0  | 停止位选择 (Stop bit selection)<br>设置发送停止位数。<br>SPB1, SPB0 00: 1 个停止位<br>SPB1, SPB0 01: 2 个停止位<br>SPB1, SPB0 10: 0.5 个停止位<br>SPB1, SPB0 11: 1.5 个停止位 |
| 1    | PSEL  | 校验选择位 (Parity selection bit)<br>当校验使能后, 该位用于选择是采用偶校验还是奇校验。<br>0: 奇校验<br>1: 偶校验                                                                  |
| 0    | PEN   | 校验使能位 (Parity enable bit)<br>0: 禁止奇偶校验<br>1: 发送接收使能奇偶校验                                                                                         |

### 15.6.10 UART\_BRR 波特率寄存器

偏移地址: 0x20

复位值: 0x0000 0001

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

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

DIV\_Mantissa

rw

| Bit    | Field        | Description                                                                     |
|--------|--------------|---------------------------------------------------------------------------------|
| 31: 16 | Reserved     | 保留, 始终读为 0                                                                      |
| 15: 0  | DIV_Mantissa | UARTDIV 的整数部分<br>这 16 位定义了 UART 分频器除法因子 (UARTDIV) 的整数部分。<br>DIV_Mantissa 最小值为 1 |

### 15.6.11 UART\_FRA 分数波特率寄存器

偏移地址: 0x24

复位值: 0x0000 0000

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

| Bit   | Field        | Description                                             |
|-------|--------------|---------------------------------------------------------|
| 31: 4 | Reserved     | 保留, 始终读为 0                                              |
| 3: 0  | DIV_Fraction | UARTDIV 的小数部分<br>这 4 位定义了 UART 分频器除法因子 (UARTDIV) 的小数部分。 |

### 15.6.12 UART\_RXADDR 接收地址寄存器

偏移地址: 0x28

复位值: 0x0000 0000

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

| Bit   | Field    | Description                                                                                        |
|-------|----------|----------------------------------------------------------------------------------------------------|
| 31: 8 | Reserved | 保留, 始终读为 0                                                                                         |
| 7: 0  | RXADDR   | UART 同步帧数据本机匹配地址。<br>如果 RXMASK =0xFF 时, 接收到的同步帧数据与本机匹配地址相同时, 产生 RXB8_INTF。<br>地址 0 是广播地址, 收到后都会响应。 |

### 15.6.13 UART\_RXMASK 接收掩码寄存器

偏移地址: 0x2C

复位值: 0x0000 00FF

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

| Bit   | Field    | Description                                                                  |
|-------|----------|------------------------------------------------------------------------------|
| 31: 8 | Reserved | 保留, 始终读为 0                                                                   |
| 7: 0  | RXMASK   | 数据位全为“0”时, 接收到任何数据都产生同步帧中断请求。<br>如果数据位为“1”, RDR 和 RXADDR 的相应位匹配时, 产生同步帧中断请求。 |

### 15.6.14 UART\_SCR SCR 寄存器

偏移地址: 0x30

复位值: 0x0000 0000

|      |    |       |        |    |    |    |    |    |    |    |      |    |      |       |      |
|------|----|-------|--------|----|----|----|----|----|----|----|------|----|------|-------|------|
| 31   | 30 | 29    | 28     | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20   | 19 | 18   | 17    | 16   |
| Res. |    |       |        |    |    |    |    |    |    |    |      |    |      |       |      |
| 15   | 14 | 13    | 12     | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4    | 3  | 2    | 1     | 0    |
| Res. |    | HDSEL | SCFCNT |    |    |    |    |    |    |    | Res. |    | NACK | SCAEN | SCEN |
|      |    | rw    | rw     |    |    |    |    |    |    |    | r    |    | rw   | rw    |      |

| Bit    | Field    | Description                            |
|--------|----------|----------------------------------------|
| 31: 13 | Reserved | 保留, 始终读为 0                             |
| 12     | HDSEL    | 单线半双工模式选择。<br>0: 禁止半双工模式<br>1: 使能半双工模式 |

| Bit   | Field    | Description                                                                                                                                                                          |
|-------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11: 4 | SCFCNT   | ISO7816 保护计数器。<br>发送数据时，通过该寄存器配置当前数据发送完成时延迟 TXC 标志置位的时间。在未达到此计数周期时，发送器将禁止发送下一个数据的起始位。<br>1: 禁止此设定<br>2~255: 保护时间为 2~255 个波特率时间（单位为波特率时间）<br>注：当设置计数器为 0x0 或 0xFF 时，均为 255 个波特率的计数时间。 |
| 3     | Reserved | 保留，始终读为 0                                                                                                                                                                            |
| 2     | NACK     | 主接收帧应答位。<br>保护期间收到低电平置位                                                                                                                                                              |
| 1     | SCAEN    | ISO7816 校验自动应答位。<br>0: 禁止自动应答<br>1: 使能自动应答                                                                                                                                           |
| 0     | SCEN     | ISO7816 使能控制位。<br>0: 禁止 ISO7816 功能<br>1: 使能 ISO7816 功能                                                                                                                               |

### 15.6.15 UART\_IDLR IDLE 数据长度寄存器

偏移地址: 0x34

复位值: 0x0000 000C

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

| Bit    | Field    | Description                                                   |
|--------|----------|---------------------------------------------------------------|
| 31: 16 | Reserved | 保留，始终读为 0                                                     |
| 15: 0  | IDLR     | UART idle 数据长度寄存器 (Idle data length register)<br>数据长度不可配置为 0。 |

### 15.6.16 UART\_ABRCR 自动波特率寄存器

偏移地址: 0x38

复位值: 0x0000 0000

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

|      |             |             |            |       |
|------|-------------|-------------|------------|-------|
| Res. | Latter_edge | Former_edge | Abr_bitcnt | Abren |
|      | rw          | rw          | rw         | rw    |

| Bit   | Field       | Description                                                                                                                                 |
|-------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| 31: 5 | Reserved    | 保留, 始终读为 0                                                                                                                                  |
| 4     | Latter_edge | 自动波特率后一个边沿选择。<br>0: 下降沿<br>1: 上升沿                                                                                                           |
| 3     | Former_edge | 自动波特率前一个边沿选择。<br>0: 下降沿<br>1: 上升沿                                                                                                           |
| 2: 1  | Abr_bitcnt  | 自动波特率检测长度。<br>检测前一个边沿和后一个边沿之间的位长。<br>00: 1 位<br>01: 2 位<br>10: 4 位<br>11: 8 位                                                               |
| 0     | Abren       | 自动波特率使能。<br>只能在 <b>UART</b> 空闲时使能自动波特率, 使能后检测接收信号的边沿, 完成自动波特率检测后, 硬件自动设置 <b>UART_BRR</b> 和 <b>UART_FRA</b> 寄存器。<br>0: 自动波特率禁止<br>1: 自动波特率使能 |

### 15.6.17 **UART\_IRDA** 红外功能控制寄存器

偏移地址: 0x3C

复位值: 0x0000 0100

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

| Bit    | Field    | Description |
|--------|----------|-------------|
| 31: 16 | Reserved | 保留, 始终读为 0  |

| Bit   | Field    | Description                                                                                                                                                                                                                                                                                                                                |
|-------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15: 8 | PSC_REG  | <p>预分频寄存器（Prescaler value）</p> <p>在红外低功耗模式下，对 UART 源时钟（pclk）分频获得低功耗模式下频率 sirlp_clk：</p> <ul style="list-style-type: none"> <li>0000 0000 : 保留，不能写入该值</li> <li>0000 0001 : 对源时钟 1 分频</li> <li>0000 0010 : 对源时钟 2 分频</li> <li>0000 0011 : 对源时钟 3 分频</li> <li>.....</li> </ul> <p>注：保证分频后的时钟频率在（1.42 MHz &lt; sirlp_clk &lt; 2.12 MHz）之间。</p> |
| 7: 2  | Reserved | 保留，始终读为 0                                                                                                                                                                                                                                                                                                                                  |
| 1     | Sirlp    | <p>红外低功耗模式（IrDA low_power）</p> <ul style="list-style-type: none"> <li>0 : 普通模式</li> <li>1 : 低功耗模式</li> </ul>                                                                                                                                                                                                                               |
| 0     | Siren    | <p>IrDA 红外模式使能（IrDA mode enable）</p> <ul style="list-style-type: none"> <li>0 : 不使能红外模式</li> <li>1 : 使能红外模式</li> </ul>                                                                                                                                                                                                                     |

## 16 SPI\_I2S 串行外设接口

### 16.1 SPI\_I2S 功能框图



图 16-1 SPI\_I2S 功能框图

### 16.2 SPI\_I2S 简述

SPI (Serial Peripheral Interface) 接口广泛用于不同设备之间的板级通讯，如扩展串行 Flash, ADC 等。许多 IC 制造商生产的器件都支持 SPI 接口。

SPI 允许 MCU 与外部设备以全双工、同步、串行方式通信。应用软件可以通过查询状态或 SPI 中断来通信。

I2S (Inter—IC Sound) 总线，也称为集成电路内置音频总线，是飞利浦公司针对数字音频设备之间的音频数据传输而制定的一种总线标准。它使用独立的导线分别传输时钟与数据信号，因而避免了因时差诱发的失真，所以广泛应用于多媒体系统上各音频设备之间的数据传输。

## 16.3 SPI 功能描述

### 16.3.1 概述

SPI 支持同时接收和发送 1~32 位数据，可以被配置为从模式或在一个主机环境下的主模式。软件通过配置通用控制寄存器(CCTL)中的 CPOL 位和 CPHA 位，选择时钟与数据之间有四种不同的传输时序；并可配置 LSBFE 位选择使用 MSB 在前或者 LSB 在前来传输数据。

SPI 在时钟 SCK 的上升沿或下降沿发送数据，在相反的时钟有效沿接收数据。

使用 SPI 交换数据，要求必须在接收数据完成时进行数据读取操作，即使该数据不是有效数据；并且要求主机和与其通信的从机之间具有相同的时钟相位和极性。

SPI 通过 4 个引脚与外部器件相连：

- MISO：主设备输入、从设备输出引脚。传输方向为从设备发送到主设备。
- MOSI：主设备输出、从设备输入引脚。传输方向为主设备发送到从设备。
- SCK：串口时钟，由主设备产生并提供给从设备。
- NSS：从设备选择。该引脚为 SPI 协议下的可选功能，用于主设备选择与之通信的从设备（多从设备时），实现主从设备间的一对一单独通信，并能避免数据线上设备之间的冲突。当软件配置激活 NSS 引脚功能后，配置 SPI\_I2S\_GCTL.MODE 为‘1’使 SPI 工作于主模式，再配置 SPI\_I2S\_NSSR.NSS 为‘0’使 NSS 引脚输出低电平，从而允许与主设备连接的从设备（配置 SPI\_I2S\_GCTL.MODE 为‘0’）和它进行数据通信。

下图示意主、从设备之间一对一通信时的连接情况：



图 16-2 单主和单从应用

SPI 主、从设备的同名引脚互连，图中示意数据方向为从最高位到最低位的方式串行通信。

主设备负责发起通信请求，从设备负责响应，从设备通过 SCK 引脚得到主设备提供的时钟信号，从而使得主、从设备均使用同一个时钟进行同步的全双工通信。

对于从设备而言，MOSI 引脚输入来自主设备的发送数据，MISO 引脚输出响应数据传给主设备。

### 16.3.1.1 时钟信号的极性和相位

SPI\_I2S\_CCTL 寄存器的 CPOL 和 CPHA 位分别控制时钟的极性和相位，通过软件配置可分别得到 4 种不同的时钟/数据时序关系。

时钟极性指的是 SCK 时钟空闲状态下电平保持何种状态：如果配置 CPOL 位为‘0’，在空闲状态下 SCK 时钟保持为低电平；反之，则在空闲状态下 SCK 时钟保持为高电平。主、从设备都会受到 CPOL 控制位的影响。

时钟相位决定输入数据采样的时序：如果配置 CPHA 位为‘0’，第一个数据位会在 SCK 的第二个时钟边沿被采样；反之，则第一个数据位会在 SCK 的第一个时钟边沿被采样。

另外 CPHASEL 位在系统上电复位后为‘0’，当软件调整此位配置为‘1’后将会切换数据采样时序，也就是使得 CPHA 位的功能发生切换。例如，CPHASEL=1，CPHA=0 时：第一个数据位会在 SCK 的第一个时钟边沿被采样（CPOL 位为‘0’为上升沿；为‘1’则是下降沿）。

因此，需要根据 CPOL、CPHA 及 CPHASEL 位的组合配置来期望使用的时钟/数据时序关系。

时序配置需要注意以下几点：

- SPI 工作时不能修改 CPOL/CPHA（如需修改，首先关闭 SPI 的使能位 SPIEN）。
- 主、从设备同步通信，因此双方时序配置应保持一致。
- 空闲状态时 SCK 的电平情况必须和 CPOL 为配置的极性一致。

下图示意在 SPI 传输下的不同 CPHA 与 CPOL 位组合的 4 种情况（配置 CPHASEL 位为‘1’时），以及主/从设备的 SCK/MISO/MOSI/NSS 引脚的时序关系。



图 16-3 数据时钟时序图

需注意，配置 SPI\_I2S\_GCTL.NSS=1，即 NSS 引脚功能由硬件自动控制时，在数据通信完成后硬件将自动拉高此引脚（上图例中所示）；当配置 SPI\_I2S\_GCTL.NSS=0，NSS 输出状态则由从机片选寄存器 SPI\_I2S\_NSSR 的 NSS 位进行控制（需软件切换 NSS 引脚的输出状态）。

### 16.3.1.2 高速传输

针对高速传输时板级延时敏感的情况，可配置 SPI\_I2S\_CCTL 寄存器中 TXEDGE/RXEDGE 位对数据发送/接收采样的时间点进行调整。高速传输，针对主设备的波特率发生器配置在 SPBRG<4 且输出 SCK 时钟较快 ( $>=10MHz$ )；低速传输，针对主设备波特率发生器配置在 SPBRG>4 且输出 SCK 时钟较慢 ( $<10MHz$ )。

- 在从模式下，TXEDGE 位为‘1’时，软件一旦配置 TXREG 写入数据，不等待 SCK 时钟输入的边

沿而是立即发送到 MISO 引脚线上；TXEDGE 位为‘0’时，从设备总是等到一个有效时钟边沿才发送数据到 MISO 引脚线上。

- 在主模式下，RXEDGE 位为‘1’时，将后移采样数据的时间点，在传输数据位的尾时钟沿采样数据；RXEDGE 位为‘0’时，在传输数据位的中间点上采样数据。

### 16.3.1.3 数据帧格式

配置 SPI\_I2S\_CCTL 寄存器中的 LSBFE 位，决定数据输出的优先顺序。LSBFE 位为‘1’会从最低位到最高位的顺序收发数据，为‘0’（缺省）会从最高位到最低位的顺序收发数据。

配置 SPI\_I2S\_CCTL 寄存器的 SPILEN 位，决定数据帧的数据长度。SPILEN 位为‘1’（缺省）则数据帧长是 8 位，为‘0’则数据帧长是 7 位。SPI 的发送和接收都受到数据帧格式配置的控制。

另外，可通过配置 SPI\_I2S\_GCT.DW8\_32=1，和寄存器 SPI\_I2S\_EXTCTL 来实现任意帧长的数据格式（帧长范围在 1~32 位之间）；任意帧长配置时也支持 LSBFE 位的功能（LSB 或 MSB 优先）。

### 16.3.2 SPI 主要特征

- 完全兼容 Motorola 的 SPI 规格
- 在 3 根线上支持全双工同步传输
- 16 位的可配置波特率生成器
- 支持主机模式和从机模式
- 支持一个主机与多个从机通信
- SPI 在主、从机模式下，时钟最快分别可达 PCLK/2、PCLK/4（PCLK 为 APB 时钟）
- 可配置的时钟极性和相位
- 可配置的数据帧长度（固定 8 位或 7 位帧长，1~32 位任意帧长）
- 可配置的数据顺序，MSB 在前或者 LSB 在前（1~32 位任意帧长、固定帧长的数据收发都支持）
- 8 个字节的接收/发送缓冲，同时具备下列中断事件或状态供软件配置使用：
  - ◆ 发送缓冲为空
  - ◆ 发送缓冲和发送移位寄存器同时为空
  - ◆ 发送端下溢
  - ◆ 接收到有效字节
  - ◆ 接收缓冲上溢
  - ◆ 接收缓冲满
  - ◆ 主模式下接收到指定的字节个数

### 16.3.3 SPI 从模式

SPI 作为从设备时，SCK 引脚输入来自主设备的串行时钟，因此从设备工作时不使用波特率发生器，不需配置寄存器 SPI\_I2S\_SPBRG（从设备下无效）。

#### 16.3.3.1 配置步骤

1. 配置 SPI\_I2S\_GCTL.SPILEN，定义数据帧格式为 7 位或者 8 位。
2. 配置寄存器 SPI\_I2S\_CCTL 中的 CPOL、CPHA/CPHASEL 位，以确定时序模式。
3. 配置 SPI\_I2S\_CCTL.LSBFE，确定数据帧的收发顺序（LSB 或 MSB 位优先）。
4. 配置寄存器 SPI\_I2S\_GCTL 中的 MODE 位为‘0’（从模式），SPIEN 位为‘1’（SPI 功能使能），并配置 SPI 工作所需的 GPIO 功能引脚。
5. 配置寄存器 SPI\_I2S\_GCTL 中 TXEN、RXEN 位为‘1’，打开发送、接收的许可（发送时需提前写入数据到寄存器 SPI\_I2S\_TXREG），SPI 将在从模式下接收 MOSI 引脚数据，并从 MISO 引脚输出数据。

注意：必须配置主、从设备的时序模式和数据帧收发顺序为一致，以保证数据能正常传输。

#### 16.3.3.2 数据发送过程

写数据到发送数据寄存器 SPI\_I2S\_TXREG 后，整个数据会一起传输到发送缓冲。

当从设备接收到 SCK 引脚上的时钟信号，也同时接收到 MOSI 引脚传来的第一个数据位；从设备利用 SCK 的变化边沿，把发送数据逐位发送到 MISO 引脚上。发送数据的过程符合数据/时钟的相关时序（由 CPOL、CPHA/CPHASEL 位来决定）。

但在高速传输时（配置 SPI\_I2S\_CCTL.TXEDGE=1），数据将不再按照输入的 SCK 时钟边沿而变化，而会提前以内部 PCLK 的时钟边沿把数据送到 MISO 引脚上（此提前量不会早于前一位数据接收采样的 SCK 时钟边沿）。

当数据第一位被发送时，硬件会置位 SPI\_I2S\_INTSTAT.TX\_INTF 标志，软件可利用此标志来写 TXREG 以实现数据的连续发送（配置 SPI\_I2S\_INTEN.TX\_IEN 位为‘1’来产生 CPU 中断）。

注意：从机时钟信号由主机提供，因此，连续传输的前提必须是主机能提供连续不断的时钟。

#### 16.3.3.3 数据接收过程

从设备接收到 MOSI 引脚输入的一个完整数据时：

- 此数据通过移位寄存器，会在最后一个采样时钟边沿被传输到接收缓冲中；硬件也同时会置位 SPI\_I2S\_INTSTAT.RX\_INTF 标志。之后软件通过读 SPI\_I2S\_RXREG，就能从接收缓冲中获取该数据。
- 软件配置 SPI\_I2S\_INTEN.RX\_IEN 位为‘1’来打开中断使能，利用 CPU 中断获取接收数据。

### 16.3.4 SPI 主模式

SPI 作为主设备时，输出串行时钟到 SCK 引脚上，供从设备使用。

#### 16.3.4.1 配置步骤

1. 配置 SPI\_I2S\_SPBREG 寄存器，定义串行时钟波特率。
2. 配置 SPI\_I2S\_CCTL 寄存器中 CPOL、CPHA/CPHASEL 位，确定时序模式。
3. 配置 SPI\_I2S\_CCTL.SPILEN 来定义 8 或 7 位数据帧格式；配置 SPI\_I2S\_GCTL.DW8\_32 为‘1’，可配置 SPI\_I2S\_EXTCTL 寄存器来定义成任意帧格式（SPILEN 需固定为‘1’）。
4. 配置 SPI\_I2S\_CCTL.LSBFE 来确定数据收发的顺序（LSB 或 MSB 位优先）。
5. 如果只接收而不发送数据，可配置 SPI\_I2S\_RXDNR 寄存器来定义需要接收的字节数（当接收到指定个字节数后，SCK 时钟输出会结束并保持在 CPOL 位配置的状态上）。
6. 配置寄存器 SPI\_I2S\_GCTL 中的 MODE 位为‘1’（主模式）、SPIEN 位为‘1’（SPI 功能使能），并配置 SPI 工作所需的 GPIO 功能引脚。
7. 配置寄存器 SPI\_I2S\_GCTL 中 TXEN、RXEN 位为‘1’，打开发送、接收的许可（发送时打开 TXEN 后写入数据到寄存器 SPI\_I2S\_TXREG），SPI 将在主模式下输出时钟 SCK 和同步数据 MOSI 到引脚上，并从 MISO 引脚上采样输入数据；NSS 是主设备可选的输出功能。

注意：必须配置主、从设备的时序模式和数据帧收发顺序为一致，以保证数据能正常传输。

#### 16.3.4.2 数据发送过程

配置 TXEN 位为‘1’后，写数据到发送数据寄存器 TXREG，此数据将传输到发送缓冲，主设备开始发送。主设备按照预先配置好的波特率串行输出 SCK 时钟和 MOSI 数据到引脚上，此过程符合数据/时钟的相关时序（由 CPOL、CPHA/CPHASEL 位决定）；而且 LSBFE 位决定了数据串行传输顺序。

当数据第一位被发送时，硬件会置位 SPI\_I2S\_INTSTAT.TX\_INTF 标志，软件利用此标志来写 TXREG 以实现数据的连续发送（配置 SPI\_I2S\_INTEN.TX\_IEN 位为‘1’来产生 CPU 中断）。

#### 16.3.4.3 数据接收过程

主设备接收到 MISO 引脚输入的一个完整数据时：

- 此数据通过移位寄存器，会在最后一个采样时钟边沿被传输到接收缓冲中；硬件也同时会置位 SPI\_I2S\_INTSTAT.RX\_INTF 标志。之后软件通过读 SPI\_I2S\_RXREG，就能从接收缓冲中获取该数据。
- 软件配置 SPI\_I2S\_INTEN.RX\_IEN 位为‘1’可打开中断使能，利用 CPU 中断获取接收数据。
- 只接收时，接收完 RXDNR 定义的字节个数后，硬件将置位 SPI\_I2S\_INTEN.RXMATCH\_INTF

标志，同时主设备不再发送时钟信号，**SCK** 输出将保持在 **CPOL** 位配置的状态上（固定高或低电平）。

### 16.3.5 波特率设置

**SCK** 引脚输出的时钟频率符合波特率配置，它由内部时钟 **PCLK** 按照 **SPI\_I2S\_SPBRG** 寄存器的配置值分频得到。寄存器 **SPBREG** 控制一个 16 位计数器的计数周期。

按照期望的波特率和 **Fpclk** (APB 模块 **PCLK** 时钟频率)，使用下表公式可计算出给寄存器 **SPBRG** 的配置值（下表中的 **X**），**X** 在 2~65535 范围之内。

表 16-1 波特率公式

| 模式     | 公式                 |
|--------|--------------------|
| SPI 模式 | 波特率 = $F_{pclk}/X$ |

### 16.3.6 中断

#### 16.3.6.1 状态标志

为了软件操作的方便，应用程序可以通过 4 个当前状态标志和 7 个中断状态标志来监控 SPI 总线的状态。

当前状态标志是只读，由硬件自动置位和清除。

中断状态标志会在事件发生时置位，可在中断使能时产生 CPU 中断请求，并由软件清除。

SPI 内部分别有一个 8 字节的发送缓冲和接收缓冲，CPU 可根据 **SPI\_I2S\_GCTL** 寄存器中 **DW8\_32** 位的配置，每次读写 1 个或 4 个字节。根据 **DW8\_32** 的配置，发送和接收缓冲分别有 1 个字节或者 1 个有效数据的状态标志。

注意：配置 **SPI\_I2S\_GCTL.DW8\_32=1**，收发缓冲至多有两个有效数据；此时，当帧长配置为 8bit 及以下时一个有效数据为 1 个字节；帧长配置在 9~16bit 范围时一个有效数据为 2 个字节；帧长配置在 17~24bit 范围时一个有效数据为 3 个字节；帧长配置在 25~32bit 范围时一个有效数据为 4 个字节。

表 16-2 SPI 状态

| 分类   | 状态标志          | 缓冲和信号状态                                                         |
|------|---------------|-----------------------------------------------------------------|
| 中断状态 | TX_INTF       | 发送缓冲为空，根据 <b>DW8_32</b> 配置能完成一次发送数据寄存器 <b>TXREG</b> 的写操作        |
|      | RX_INTF       | 根据 <b>DW8_32</b> 设置，至少有一个有效数据的数据，能完成一次接收数据寄存器 <b>RXREG</b> 的读操作 |
|      | UNDERRUN_INTF | 发送缓冲空且重复发送                                                      |
|      | RXOERR_INTF   | 接收缓冲非空且被覆盖                                                      |
|      | RXMATCH_INTF  | 非空，指定个数的最后 1 个数据传到接收缓冲中（主模式下有效）                                 |
|      | RXFULL_INTF   | 接收缓冲满，不能再接收新的数据                                                 |
|      | TXEPT_INTF    | 发送缓冲和 <b>TX</b> 移位寄存器都为空                                        |

| 分类   | 状态标志        | 缓冲和信号状态           |
|------|-------------|-------------------|
| 当前状态 | RXAVL_4BYTE | 接收缓冲有超过 4 字节有效数据  |
|      | TXFULL      | 发送缓冲满             |
|      | TXEPT       | 发送缓冲和 TX 移位寄存器都为空 |
|      | RXAVL       | 接收缓冲非空            |

## 16.4 I2S 功能描述

### 16.4.1 I2S 主要特征

- 半双工通信（仅发送器或接收器）
- 主操作或从操作
- 9 位可配置线性预分频器，以达到精确的音频采样频率（8KHz~192KHz）
- 数据帧格式可配置为 16 位、24 位或 32 位
- 数据包帧固定为 16 位（16 位有效数据）或 32 位（16 位、24 位、32 位有效数据）
- 可配置时钟极性（稳定状态）
- 发送模式下具有下溢标志（仅从机），接收模式下具有上溢标志（主/从机）和发送/接收模式下的帧错误标志（仅从机）
- 用于传输和接收的 32 位寄存器为两个声道分时复用
- 数据方向始终是 MSB 优先
- 支持 I2S 协议：
  - ◆ 飞利浦标准
  - ◆ MSB 对齐标准（MSB 位向左对齐）
  - ◆ LSB 对齐标准（LSB 位向右对齐）
  - ◆ PCM 标准（具有短帧同步模式、长帧同步模式的两种方式）
- 可配置 MCLK 时钟输出来驱动外部音频组件，其比率固定在  $256 \times F_s$ （其中  $F_s$  为音频采样频率）

### 16.4.2 I2S 总线接口

I2S 与 SPI 共用以下引脚：

- SD：串行数据（映射在 MOSI 引脚上），用于发送或接收两次多路数据通道（仅在半双工模式下）。
- WS：声道选择（映射在 NSS 引脚上），是主模式控制数据的输出信号，或从模式的输入。
- CK：串行时钟（映射在 SCK 引脚上），是主模式串行时钟的输出，或从模式串行时钟的输入。
- MCK：可选的驱动时钟（映射在 MISO 引脚上），用于驱动外部音频组件（仅当外部音频设备需要时钟输入时使用，由主模式提供）。

### 16.4.3 数据格式

三线总线处理音频数据，必须经过分时复用两个声道：右声道和左声道。因为只有一个 32 位寄存器用于传输或接收，所以软件应依次配置寄存器 TXREG 为各声道的数据，或依次读取寄存器 RXREG 为各声道的数据。按照 I2S 协议，总是先发送左声道，然后发送右声道。

注意：在 PCM 协议下 SPI\_I2S\_CSTAT.CHSIDE 状态标志无效。

数据采用以下格式发送：

- 16 位数据打包在 16 位数据包帧
- 16 位有效数据打包在 32 位数据包帧（软件配置无效位为‘0’）
- 24 位有效数据打包在 32 位数据包帧（软件配置无效位为‘0’）
- 32 位数据打包在 32 位数据包帧

当使用 32 位数据包帧上发送 16 位有效数据或 24 位有效数据时，软件应注意配置无效数据位为‘0’（例如，针对数据 0x12345678，只发送 16 位有效数据则写 TXREG 为 0x00005678，发送 24 位有效数据则写 0x00345678）。

### 16.4.4 通信标准

I2S 接口支持四种音频标准，通过配置寄存器 SPI\_I2S\_I2SCFGR 中的 I2SSTD[1:0]、PCMSYNC 位进行切换；数据格式则通过配置 DATLEN[1:0]、CHLEN 来进行选择。

对于所有通信标准及数据格式，总是先发送最高位（MSB 优先）。

#### 16.4.4.1 飞利浦标准

对于飞利浦标准，WS 信号用于指示正在传输的声道，它在 CK 的下降沿被锁定。发射器在 CK 的下降沿锁存数据，接收器在 CK 的上升沿读取数据。对于本标准格式的信号，无论有多少位有效数据，每个数据包帧的最高有效位总是出现在 WS 变化后的第 2 个 CK 脉冲周期处。



图 16-4 飞利浦标准示意图

#### 16.4.4.2 MSB 对齐标准

对于 MSB 对齐标准，每个数据包帧的最高有效位（MSB 位）总是出现在 WS 变化后的第 1 个 CK 脉冲周期处。



图 16-5 MSB 对齐标准示意图

#### 16.4.4.3 LSB 对齐标准

对于 LSB 对齐标准，每个数据包帧的最低有效位总（LSB 位）是出现在 WS 变化前的 1 个 CK 脉冲周期处。



图 16-6 LSB 对齐标准示意图

#### 16.4.4.4 PCM 标准

对于 PCM 标准，WS 引脚不作为声道信息使用（CHSIDE 标志位无效）。

PCM 标准有两个模式，分别为短帧模式和长帧模式；通过配置 SPI\_I2S\_I2SCFGR.PCM\_SYNC 位进行切换。在 PCM 模式下，输出信号（WS, SD）在 CK 时钟的上升沿锁存，输入信号（WS, SD）在 CK 时钟的下降沿采样。在主模式下应配置 CK 时钟和 WS 引脚为输出。



图 16-7 PCM 标准示意图

### 16.4.5 从模式



图 16-8 I2S 从模式 (SD 配置成 SDO 为发送器, 配置成 SDI 为接收器)

从模式支持发送或接收，由于 I2S 只能支持半双工，SD 引脚只能配置成 SDO 输出或 SDI 输入。收发状态、实现方法类同 SPI 从模式，配置流程如下：

1. 配置 SPI\_I2S\_GCTL.SPIEN 位为‘1’，开启模块使能；
2. 配置 SPI\_I2S\_GCTL.MODE 位为‘0’，使模块功能为从模式；
3. 配置 SPI\_I2S\_CCTL.CPOL 位，选择时钟空闲状态时的输入电平；
4. 配置寄存器 SPI\_I2S\_I2SCFGR 中的 I2SDIV[8:0]、DATLEN 和 CHLEN 位，以符合希望得到的音频采样频率及数据包帧格式，计算方法请参考 16.4.7 时钟预分频器；
5. 配置 SPI\_I2S\_I2SCFGR.SPI\_I2S 位为‘1’，使能 I2S 传输功能；
6. 配置寄存器 SPI\_I2S\_I2SCFGR 中的 I2SSTD[1:0]、PCMSYNC 位，选择 I2S 传输时使用的通信标准；
7. 开启半双工传输许可，即配置寄存器 SPI\_I2S\_GCTL 中的 TXEN 或 RXEN 位为‘1’(TXEN、RXEN 不可同时配置为‘1’)。

注意，从模式下发送时，在检测到 WS 的边沿之前，需要对寄存器 SPI\_I2S\_TXREG 进行 1 次数据写入操作；而且，从模式下接收时，在配置 RXEN 位为‘1’之前，需要一直维持 WS 输入信号在高电平。

### 16.4.6 主模式



图 16-9 I2S 主模式 (SD 配置成 SDO 为发送器, 配置成 SDI 为接收器)

主模式也支持发送或接收，且半双工机制下 SD 引脚只能配置成 SDO 输出或 SDI 输入。收发状态、实现方法类同 SPI 从模式，配置流程如下：

1. 配置 SPI\_I2S\_GCTL.SPIEN 位为‘1’，开启模块使能；
2. 配置 SPI\_I2S\_GCTL.MODE 位为‘1’，使模块功能为主模式；
3. 配置 SPI\_I2S\_CCTL.CPOL 位，选择时钟空闲状态时的输出电平；
4. 配置 SPI\_I2S\_I2SCFGR.MCKOE 位，选择是否向外部器件提供 MCK 驱动时钟；
5. 配置寄存器 SPI\_I2S\_I2SCFGR 中的 I2SDIV[8:0]、DATLEN 和 CHLEN 位，以符合希望得到的音频采样频率及数据包帧格式，计算方法请参考 16.4.7 时钟预分频器；
6. 配置 SPI\_I2S\_I2SCFGR.SPI\_I2S 位为‘1’，使能 I2S 传输功能；
7. 配置寄存器 SPI\_I2S\_I2SCFGR 中的 I2SSTD[1:0]、PCMSYNC 位，选择 I2S 传输时使用的通信标准；
8. 开启半双工传输许可，即配置寄存器 SPI\_I2S\_GCTL 中的 TXEN 或 RXEN 位为‘1’(TXEN、RXEN 不可同时配置为‘1’)。

注意：主模式接收时，当接收到的字节个数达到寄存器 SPI\_I2S\_RXDNR 配置值时，将立即停止传输（CK 时钟输出结束，并固定在 CPOL 位配置的电平状态）。

#### 16.4.7 时钟预分频器

I2SCLK 时钟由系统 APB 时钟提供，下图示意了 I2S 模块的预分频器电路结构：



图 16-10 I2S 时钟预分频器示意图

由上图看出，当 MCKOE 位为‘0’时芯片不需要输出 MCK 时钟，预分频器直接将 I2SCLK 分频到 CK；当 MCKOE 位为‘1’时芯片会输出 MCK 时钟，预分频器将 I2SCLK 分频后得到 MCK，然后再经过分频处理

才得到 CK (分频倍数由 CHLEN 选择为 4 或 8)。

音频采样率一般常用 192KHz, 96 KHz, 48 KHz, 44.1 KHz, 32 KHz, 22.05 KHz, 16 KHz, 11.025 KHz, 8 KHz。因此可根据 I2S 时钟分频器的电路功能式样，配置寄存器 I2SCFGR 中的 I2SDIV[8:0]、MCKOE 和 CHLEN 位来得到期望的音频采样率。

I2S 传输数据时，比特率计算公式如下表所示 (CK 输出一个时钟周期对应传输 1 比特数据，因此比特率 = CK 频率  $F_{CK}$ )。

表 16-3 I2S 比特率计算公式

| MCKOE | CHLEN | 比特率计算公式                                                 |
|-------|-------|---------------------------------------------------------|
| 0     | 0     | $F_{CK} = F_{I2SCLK} / I2SDIV[8:0]$                     |
| 0     | 1     | $F_{CK} = F_{I2SCLK} / I2SDIV[8:0]$                     |
| 1     | 0     | $F_{CK} = F_{I2SCLK} / (I2SDIV[8:0] \times 4 \times 2)$ |
| 1     | 1     | $F_{CK} = F_{I2SCLK} / (I2SDIV[8:0] \times 4)$          |

音频采样率 ( $F_s$ ) 和 I2S 比特率的关系由如下的公式定义：

$$F_s = I2S \text{ 比特率} / (\text{通道长度} \times \text{通道数}) = F_{CK} / (\text{通道长度} \times \text{通道数})$$

注：通道长度，即数据包帧长度，可配置为 16 位或 32 位；通道数为左右声道，值固定为 2。

综上所述，根据 I2SDIV[8:0]、MCKOE 和 CHLEN 位的配置情况，得到音频采样率与  $F_{I2SCLK}$  (APB 时钟频率) 的关系如下：

表 16-4 I2S 音频采样率  $F_s$  与  $F_{I2SCLK}$  计算关系

| MCKOE | CHLEN | 音频采样率 $F_s$ 与 $F_{I2SCLK}$ 计算关系                  | 注意事项                         |
|-------|-------|--------------------------------------------------|------------------------------|
| 0     | 0     | $F_{I2SCLK} = I2SDIV[8:0] \times 32 \times F_s$  | $I2SDIV[8:0]$ 应配置在 2~511 范围内 |
| 0     | 1     | $F_{I2SCLK} = I2SDIV[8:0] \times 64 \times F_s$  | $I2SDIV[8:0]$ 应配置在 2~511 范围内 |
| 1     | 0     | $F_{I2SCLK} = I2SDIV[8:0] \times 256 \times F_s$ | $I2SDIV[8:0]$ 应配置在 1~511 范围内 |
| 1     | 1     | $F_{I2SCLK} = I2SDIV[8:0] \times 256 \times F_s$ | $I2SDIV[8:0]$ 应配置在 1~511 范围内 |

当 MCKOE 位为 ‘1’，芯片会输出 MCK 驱动时钟，且满足  $F_{MCLK} = 256 \times F_s$ ；此时假设  $F_s = 192KHz$ ,  $I2SDIV[8:0] = 1$ ，则要求 APB 时钟 ( $F_{I2SCLK}$ ) =  $1 \times 256 \times 192KHz = 49.152MHz$ 。

针对常用的音频采样率，当按照  $F_{I2SCLK}=48MHz$  计算时，误差如下：

表 16-5 I2S 音频采样率误差表

| $F_s$  | 声道位宽 | MCKOE=1    |            |          |          | MCKOE=0    |            |          |          |
|--------|------|------------|------------|----------|----------|------------|------------|----------|----------|
|        |      | I2SDIV 理想值 | I2SDIV 配置值 | 真实 $F_s$ | 误差 (%)   | I2SDIV 理想值 | I2SDIV 配置值 | 真实 $F_s$ | 误差 (%)   |
| 192000 | 32   | 0.976563   | 1          | 187500   | -2.34375 | 3.90625    | 4          | 187500   | -2.34375 |
| 192000 | 16   | 0.976563   | 1          | 187500   | -2.34375 | 7.8125     | 8          | 187500   | -2.34375 |
| 96000  | 32   | 1.953125   | 2          | 93750    | -2.34375 | 7.8125     | 8          | 93750    | -2.34375 |
| 96000  | 16   | 1.953125   | 2          | 93750    | -2.34375 | 15.625     | 16         | 93750    | -2.34375 |
| 48000  | 32   | 3.90625    | 4          | 46875    | -2.34375 | 15.625     | 16         | 46875    | -2.34375 |
| 48000  | 16   | 3.90625    | 4          | 46875    | -2.34375 | 31.25      | 31         | 48387.1  | 0.806452 |
| 44100  | 32   | 4.251701   | 4          | 46875    | 6.292517 | 17.0068    | 17         | 44117.65 | 0.040016 |

|       |    | MCKOE=1  |    |             |          |          | MCKOE=0 |          |          |  |
|-------|----|----------|----|-------------|----------|----------|---------|----------|----------|--|
| 44100 | 16 | 4.251701 | 4  | 46875       | 6.292517 | 34.01361 | 34      | 44117.65 | 0.040016 |  |
| 32000 | 32 | 5.859375 | 6  | 31250       | -2.34375 | 23.4375  | 23      | 32608.7  | 1.902174 |  |
| 32000 | 16 | 5.859375 | 6  | 31250       | -2.34375 | 46.875   | 47      | 31914.89 | -0.26596 |  |
| 22050 | 32 | 8.503401 | 9  | 20833.33333 | -5.51776 | 34.01361 | 34      | 22058.82 | 0.040016 |  |
| 22050 | 16 | 8.503401 | 9  | 20833.33333 | -5.51776 | 68.02721 | 68      | 22058.82 | 0.040016 |  |
| 16000 | 32 | 11.71875 | 12 | 15625       | -2.34375 | 46.875   | 47      | 15957.45 | -0.26596 |  |
| 16000 | 16 | 11.71875 | 12 | 15625       | -2.34375 | 93.75    | 94      | 15957.45 | -0.26596 |  |
| 11025 | 32 | 17.0068  | 17 | 11029.41176 | 0.040016 | 68.02721 | 68      | 11029.41 | 0.040016 |  |
| 11025 | 16 | 17.0068  | 17 | 11029.41176 | 0.040016 | 136.0544 | 136     | 11029.41 | 0.040016 |  |
| 8000  | 32 | 23.4375  | 23 | 8152.173913 | 1.902174 | 93.75    | 94      | 7978.723 | -0.26596 |  |
| 8000  | 16 | 23.4375  | 23 | 8152.173913 | 1.902174 | 187.5    | 188     | 7978.723 | -0.26596 |  |

## 16.4.8 中断

### 16.4.8.1 状态标志

与 SPI 共用同一个中断向量

表 16-6 I2S 中断状态

| 中断事件           | 中断寄存器标志       |
|----------------|---------------|
| TX BUFFER 空    | TX_INTF       |
| RX BUFFER 非空   | RX_INTF       |
| TX BUFFER 向下溢出 | UNDERRUN_INTF |
| RX BUFFER 向上溢出 | RXOERR_INTF   |
| 帧传输错误          | FRE_INTF      |

TX BUFFER 空 (TX\_INTF): 表示当前发送缓冲中的数据已经被读走。

RX BUFFER 非空 (RX\_INTF): 表示当前接收缓冲中的数据有效, APB 总线可读。

TX BUFFER 向下溢出 (UNDERRUN\_INTF): 表示从模式下发送缓冲中的数据在 I2S 总线上被传输了两次。

RX BUFFER 向上溢出 (RXOERR\_INTF): 表示上一个接收数据未被读走, 且已经被覆盖。

帧传输错误 (FRE\_INTF): 表示 I2S 传输协议不匹配 (仅从模式下有效)。

此外, I2S 模式下有以下 2 个专用的状态标志:

忙标志 (BSY): 表示 I2S 正在传输中。

声道标志 (CHSIDE): 表示正在传输的声道为左声道还是右声道。

## 16.5 寄存器

### 16.5.1 寄存器总览

表 16-7 SPI\_I2S 寄存器概览

| Offset | Acronym         | Register Name | Reset      |
|--------|-----------------|---------------|------------|
| 0x00   | SPI_I2S_TXREG   | 发送数据寄存器       | 0x00000000 |
| 0x04   | SPI_I2S_RXREG   | 接收数据寄存器       | 0x00000000 |
| 0x08   | SPI_I2S_CSTAT   | 当前状态寄存器       | 0x00002001 |
| 0x0C   | SPI_I2S_INTSTAT | 中断状态寄存器       | 0x00000000 |
| 0x10   | SPI_I2S_INTEN   | 中断使能寄存器       | 0x00000000 |
| 0x14   | SPI_I2S_INTCLR  | 中断清除寄存器       | 0x00000000 |
| 0x18   | SPI_I2S_GCTL    | 全局控制寄存器       | 0x00000004 |
| 0x1C   | SPI_I2S_CCTL    | 通用控制寄存器       | 0x00000008 |
| 0x20   | SPI_I2S_SPBRG   | 波特率发生器        | 0x00000002 |
| 0x24   | SPI_I2S_RXDNR   | 接收数据个数寄存器     | 0x00000001 |
| 0x28   | SPI_I2S_NSSR    | 从机片选寄存器       | 0x000000FF |
| 0x2C   | SPI_I2S_EXTCTL  | 数据控制寄存器       | 0x00000008 |
| 0x30   | SPI_I2S_I2SCFGR | I2S 配置寄存器     | 0x00010000 |

### 16.5.2 SPI\_I2S\_TXREG 发送数据寄存器

偏移地址: 0x00

复位值: 0x0000 0000

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

| Bit   | Field | Description                                                                                                   |
|-------|-------|---------------------------------------------------------------------------------------------------------------|
| 31: 0 | TXREG | 发送数据寄存器 (Transmit data register)<br>有效数据位由 DW8_32 控制:<br>DW8_32=0 时, 只有低 8 位有效<br>DW8_32=1 时, TXREG[31: 0]都有效 |

### 16.5.3 SPI\_I2S\_RXREG 接收数据寄存器

偏移地址: 0x04

复位值: 0x0000 0000

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

| Bit   | Field | Type | Reset       | Description                                                                                                                   |
|-------|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------|
| 31: 0 | RXREG | r    | 0x0000 0000 | 接收数据寄存器 (Receive data register)<br>有效数据位由 DW8_32 控制:<br>DW8_32=0 时, 只有低 8 位有效<br>DW8_32=1 时, RXREG[31: 0]都有效<br>注: 该寄存器可读不可写。 |

#### 16.5.4 SPI\_I2S\_CSTAT 当前状态寄存器

偏移地址: 0x08

复位值: 0x0000 2001

|                                                                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|---------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 31                                                                        | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Res.                                                                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15                                                                        | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Res. CHSIDE BUSY RXFADDR TXFADDR RXAVL_4BYTE TXFULL RXAVL TXEPT r r r r r |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit    | Field    | Description                                                                           |
|--------|----------|---------------------------------------------------------------------------------------|
| 31: 14 | Reserved | 始终读为 0                                                                                |
| 13     | CHSIDE   | 声道标志位<br>0: 表示正在传输的声道为左声道<br>1: 表示正在传输的声道为右声道<br>注: SPI 模式下不可用; 且 I2S 的 PCM 标准模式下无意义。 |
| 12     | BUSY     | 忙标志位<br>表示 I2S 或 SPI 正在传输中                                                            |
| 11: 8  | RXFADDR  | 当前接收缓冲中有效字节个数                                                                         |
| 7: 4   | TXFADDR  | 当前发送缓冲中有效字节个数                                                                         |

| Bit | Field       | Description                                                                                                                                                                        |
|-----|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3   | RXAVL_4BYTE | <p>接收缓冲中有效数据达到4个字节标志位(Receive available 4 byte data message)</p> <p>0: 接收缓冲中数据小于4个字节<br/>1: 接收缓冲中有超过4个字节</p> <p>注: 工作在 I2S 模式下时, 该位在接收到一个声道数据后置位(如 CHLEN=0, 在接收到 16bit 数据后置位)。</p> |
| 2   | TXFULL      | <p>发送缓冲满标志位 (Transmitter FIFO full status bit)</p> <p>0: 发送缓冲未满<br/>1: 发送缓冲满</p>                                                                                                   |
| 1   | RXAVL       | <p>接收有效数据标志位 (Receive available byte data message)</p> <p>当接收缓冲中接收到一个字节数据时置位该位。</p> <p>0: 接收缓冲空<br/>1: 接收缓冲非空</p> <p>注: 该位只读, 由硬件自动置位和清除。</p>                                      |
| 0   | TXEPT       | <p>发送端空标志位 (Transmitter empty bit)</p> <p>0: 发送缓冲或发送移位寄存器不为空<br/>1: 发送缓冲和发送移位寄存器都为空</p> <p>注: 该位只读, 由硬件自动置位和清除。</p>                                                                |

### 16.5.5 SPI\_I2S\_INTSTAT 中断状态寄存器

偏移地址: 0x0C

复位值: 0x0000 0000

|      |    |    |    |    |    |    |    |              |                |                  |                      |                 |                       |             |             |
|------|----|----|----|----|----|----|----|--------------|----------------|------------------|----------------------|-----------------|-----------------------|-------------|-------------|
| 31   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23           | 22             | 21               | 20                   | 19              | 18                    | 17          | 16          |
| Res. |    |    |    |    |    |    |    |              |                |                  |                      |                 |                       |             |             |
| 15   | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7            | 6              | 5                | 4                    | 3               | 2                     | 1           | 0           |
| Res. |    |    |    |    |    |    |    | FRE_IN<br>TF | TXEPT_<br>INTF | RXFULL_<br>_INTF | RXMAT<br>CH_INT<br>F | RXOER<br>R_INTF | UNDER<br>RUN_IN<br>TF | RX_INT<br>F | TX_INT<br>F |
|      |    |    |    |    |    |    |    | r            | r              | r                | r                    | r               | r                     | r           | r           |

| Bit   | Field      | Description                                                                                                                                                                     |
|-------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31: 8 | Reserved   | 保留, 始终读为 0                                                                                                                                                                      |
| 7     | FRE_INTF   | <p>帧传输错误中断标志位:</p> <p>表示 I2S 传输协议不匹配(仅从模式有效)</p>                                                                                                                                |
| 6     | TXEPT_INTF | <p>发送端空中断标志位 (Transmitter empty interrupt flag bit) 硬件自动置位, 写 INTCLR.TXEPT_ICLR 位为'1'清除。</p> <p>0: 发送缓冲或发送移位寄存器不为空<br/>1: 发送缓冲和发送移位寄存器都为空</p> <p>注: 该位是中断状态信号, TXEPT 是状态信号。</p> |

| Bit | Field         | Description                                                                                                                                                                                                         |
|-----|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5   | RXFULL_INTF   | 接收缓冲满中断标志位 (RX FIFO full interrupt flag bit)<br>硬件自动置位, 写 INTCLR.RXFULL_ICLR 位为'1'清除。<br>0: RX 缓冲未满<br>1: RX 缓冲满                                                                                                    |
| 4   | RXMATCH_INTF  | 接收到指定字节数中断标志位 (Receive data match the RXDNR number, the receive process will be completed and generate the interrupt)<br>硬件自动置位, 写 INTCLR.RXMATCH_ICLR 位为'1'清除。<br>0: 未完成 RXDNR 寄存器指定的字节数<br>1: 接收了 RXDNR 寄存器指定的字节数 |
| 3   | RXOERR_INTF   | 接收端溢出错误中断标志位 (Receive overrun error interrupt flag bit)<br>硬件自动置位, 写 INTCLR.RXOERR_ICLR 位为'1'清除。<br>0: 没有溢出错误<br>1: 溢出错误                                                                                            |
| 2   | UNDERRUN_INTF | SPI 从机模式下溢标志位 (SPI underrun interrupt flag bit)<br>硬件自动置位, 写 INTCLR.UNDERRUN_ICLR 位为'1'清除。<br>0: 没有下溢错误<br>1: 下溢错误                                                                                                  |
| 1   | RX_INTF       | 接收缓冲数据有效中断标志位 (Receive data available interrupt flag bit)<br>硬件自动置位, 写 INTCLR.RX_ICLR 位为'1'清除。当接收缓冲接收了一个完整有效数据时置位。<br>0: 接收缓冲空<br>1: 接收缓冲接收到一个完整有效数据<br>注: 有效数据包含的字节数, 请参考 16.3.6.1 状态标志。                           |
| 0   | TX_INTF       | 发送缓冲空中断标志位 (缓冲为空, 可写 TXREG) (Transmit FIFO available interrupt flag bit)<br>硬件自动置位, 发送缓冲不为空时自动清零。<br>0: 发送缓冲不为空<br>1: 发送缓冲为空                                                                                        |

### 16.5.6 SPI\_I2S\_INTEN 中断使能寄存器

偏移地址: 0x10

复位值: 0x0000 0000

|      |    |    |    |    |    |    |    |             |               |                 |                  |                 |                      |        |        |
|------|----|----|----|----|----|----|----|-------------|---------------|-----------------|------------------|-----------------|----------------------|--------|--------|
| 31   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23          | 22            | 21              | 20               | 19              | 18                   | 17     | 16     |
| Res. |    |    |    |    |    |    |    |             |               |                 |                  |                 |                      |        |        |
| 15   | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7           | 6             | 5               | 4                | 3               | 2                    | 1      | 0      |
| Res. |    |    |    |    |    |    |    | FRE_IE<br>N | TXEPT_<br>IEN | RXFULL_<br>_IEN | RXMAT_<br>CH_IEN | RXOER_<br>R_IEN | UNDER<br>RUN_IE<br>N | RX_IEN | TX_IEN |
|      |    |    |    |    |    |    |    | rw          | rw            | rw              | rw               | rw              | rw                   | rw     | rw     |

| Bit   | Field        | Description                                                                                                       |
|-------|--------------|-------------------------------------------------------------------------------------------------------------------|
| 31: 8 | Reserved     | 保留, 始终读为 0                                                                                                        |
| 7     | FRE_IEN      | 帧传输错误中断使能 (FRE_IEN):<br>0: 禁止中断<br>1: 中断使能                                                                        |
| 6     | TXEPT_IEN    | 发送端空中断使能位 (Transmit empty interrupt enable bit)<br>0: 禁止中断<br>1: 中断使能                                             |
| 5     | RXFULL_IEN   | 接收缓冲满中断使能位 (Receive FIFO full interrupt enable bit)<br>0: 禁止中断<br>1: 中断使能                                         |
| 4     | RXMATCH_IEN  | 接收指定字节数中断使能位 (Receive data complete interrupt enable bit)<br>0: 禁止中断<br>1: 中断使能                                   |
| 3     | RXOERR_IEN   | 接收端溢出错误中断使能位 (Overrun error interrupt enable bit)<br>0: 禁止中断<br>1: 中断使能                                           |
| 2     | UNDERRUN_IEN | SPI 从机模式下溢中断使能位 (SPI 从机模式) (Transmitterunderrun interrupt enable bit (SPI slave mode only))<br>0: 禁止中断<br>1: 中断使能 |
| 1     | RX_IEN       | 接收端数据中断使能位 (Receive FIFO interrupt enable bit)<br>0: 禁止中断<br>1: 中断使能                                              |
| 0     | TX_IEN       | 发送缓冲空中断使能位 (Transmit FIFO empty interrupt enable bit)<br>0: 禁止中断<br>1: 中断使能                                       |

### 16.5.7 SPI\_I2S\_INTCLR 中断清除寄存器

偏移地址: 0x14

复位值: 0x0000 0000

|      |    |    |    |    |    |    |    |              |                |                 |                      |                 |                       |             |             |
|------|----|----|----|----|----|----|----|--------------|----------------|-----------------|----------------------|-----------------|-----------------------|-------------|-------------|
| 31   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23           | 22             | 21              | 20                   | 19              | 18                    | 17          | 16          |
| Res. |    |    |    |    |    |    |    |              |                |                 |                      |                 |                       |             |             |
| 15   | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7            | 6              | 5               | 4                    | 3               | 2                     | 1           | 0           |
| Res. |    |    |    |    |    |    |    | FRE_IC<br>LR | TXEPT_<br>ICLR | RXFULL_<br>ICLR | RXMAT<br>CH_ICL<br>R | RXOER<br>R_ICLR | UNDER<br>RUN_IC<br>LR | RX_ICL<br>R | TX_ICL<br>R |
|      |    |    |    |    |    |    |    | w            | w              | w               | w                    | w               | w                     | w           | w           |

| Bit   | Field         | Description                                                                                                            |
|-------|---------------|------------------------------------------------------------------------------------------------------------------------|
| 31: 8 | Reserved      | 保留, 始终读为 0                                                                                                             |
| 7     | FRE_ICLR      | 帧传输错误中断清除<br>0: 写 0 无意义<br>1: 写 1 清除中断                                                                                 |
| 6     | TXEPT_ICLR    | 发送端空中断清除位 (Transmitter empty interrupt clear bit)<br>0: 写 0 无意义<br>1: 写 1 清除中断                                         |
| 5     | RXFULL_ICLR   | 接收缓冲满中断清除位 (Receiver buffer full interrupt clear bit)<br>0: 写 0 无意义<br>1: 写 1 清除中断                                     |
| 4     | RXMATCH_ICLR  | 接收指定字节数中断清除位 (Receive completed interrupt clear bit)<br>0: 写 0 无意义<br>1: 写 1 清除中断                                      |
| 3     | RXOERR_ICLR   | 接收端溢出错误中断清除位 (Overrun error interrupt clear bit)<br>0: 写 0 无意义<br>1: 写 1 清除中断                                          |
| 2     | UNDERRUN_ICLR | SPI 从机模式下溢中断清除位(SPI 从机模式)(Transmitter underrun interrupt clear bit (SPI slave mode only))<br>0: 写 0 无意义<br>1: 写 1 清除中断 |
| 1     | RX_ICLR       | 接收端数据中断清除位 (Receive interrupt clear bit)<br>0: 写 0 无意义<br>1: 写 1 清除中断                                                  |
| 0     | TX_ICLR       | 发送缓冲空中断清除位 (Transmitter FIFO empty interrupt clear bit)<br>0: 写 0 无意义<br>1: 写 1 清除中断                                   |

### 16.5.8 SPI\_I2S\_GCTL 全局控制寄存器

偏移地址: 0x18

复位值: 0x0000 0004

|         |    |      |        |     |      |    |    |    |      |      |      |       |       |         |    |
|---------|----|------|--------|-----|------|----|----|----|------|------|------|-------|-------|---------|----|
| 31      | 30 | 29   | 28     | 27  | 26   | 25 | 24 | 23 | 22   | 21   | 20   | 19    | 18    | 17      | 16 |
| Res.    |    |      |        |     |      |    |    |    |      |      |      |       |       | PAD_SEL |    |
|         |    |      |        |     |      |    |    |    |      |      |      |       |       | rw      |    |
| 15      | 14 | 13   | 12     | 11  | 10   | 9  | 8  | 7  | 6    | 5    | 4    | 3     | 2     | 1       | 0  |
| PAD_SEL |    | Res. | DW8_32 | NSS | Res. |    |    |    | RXEN | TXEN | MODE | INTEN | SPIEN |         |    |
| rw      |    |      | rw     | rw  |      |    |    |    | rw   | rw   | rw   | rw    | rw    | rw      |    |

| Bit    | Field    | Description |
|--------|----------|-------------|
| 31: 18 | Reserved | 保留, 始终读为 0  |

| Bit         | Field    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |         |      |      |     |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |
|-------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|------|------|-----|------|---|------|------|------|------|---|------|------|------|------|---|------|------|------|------|---|------|------|------|------|---|------|------|------|------|---|------|------|------|------|---|------|------|------|------|---|------|------|------|------|---|------|------|------|------|---|------|------|------|------|----|------|------|------|------|----|------|------|------|------|----|------|------|------|------|----|------|------|------|------|----|------|------|------|------|----|------|------|------|------|----|------|------|------|------|----|------|------|------|------|----|------|------|------|------|----|------|------|------|------|----|------|------|------|------|----|------|------|------|------|----|------|------|------|------|----|------|------|------|------|
| 17: 13      | PAD_SEL  | <p>PAD0, PAD1, PAD2, PAD3 分别对应引脚分布中的 SCK、MOSI、NSS、MISO 引脚。<br/>           信号 SCL、MOSI、NSS、MISO 和 PAD 的映射变换如下：</p> <table> <thead> <tr> <th>PAD_SEL</th> <th>SCL</th> <th>MOSI</th> <th>NSS</th> <th>MISO</th> </tr> </thead> <tbody> <tr><td>0</td><td>PAD0</td><td>PAD1</td><td>PAD2</td><td>PAD3</td></tr> <tr><td>1</td><td>PAD0</td><td>PAD1</td><td>PAD3</td><td>PAD2</td></tr> <tr><td>2</td><td>PAD0</td><td>PAD2</td><td>PAD1</td><td>PAD3</td></tr> <tr><td>3</td><td>PAD0</td><td>PAD2</td><td>PAD3</td><td>PAD1</td></tr> <tr><td>4</td><td>PAD0</td><td>PAD3</td><td>PAD1</td><td>PAD2</td></tr> <tr><td>5</td><td>PAD0</td><td>PAD3</td><td>PAD2</td><td>PAD1</td></tr> <tr><td>6</td><td>PAD1</td><td>PAD0</td><td>PAD2</td><td>PAD3</td></tr> <tr><td>7</td><td>PAD1</td><td>PAD0</td><td>PAD3</td><td>PAD2</td></tr> <tr><td>8</td><td>PAD1</td><td>PAD2</td><td>PAD0</td><td>PAD3</td></tr> <tr><td>9</td><td>PAD1</td><td>PAD2</td><td>PAD3</td><td>PAD0</td></tr> <tr><td>10</td><td>PAD1</td><td>PAD3</td><td>PAD0</td><td>PAD2</td></tr> <tr><td>11</td><td>PAD1</td><td>PAD3</td><td>PAD2</td><td>PAD0</td></tr> <tr><td>12</td><td>PAD2</td><td>PAD0</td><td>PAD1</td><td>PAD3</td></tr> <tr><td>13</td><td>PAD2</td><td>PAD0</td><td>PAD3</td><td>PAD1</td></tr> <tr><td>14</td><td>PAD2</td><td>PAD1</td><td>PAD0</td><td>PAD3</td></tr> <tr><td>15</td><td>PAD2</td><td>PAD1</td><td>PAD3</td><td>PAD0</td></tr> <tr><td>16</td><td>PAD2</td><td>PAD3</td><td>PAD0</td><td>PAD1</td></tr> <tr><td>17</td><td>PAD2</td><td>PAD3</td><td>PAD1</td><td>PAD0</td></tr> <tr><td>18</td><td>PAD3</td><td>PAD0</td><td>PAD1</td><td>PAD2</td></tr> <tr><td>19</td><td>PAD3</td><td>PAD0</td><td>PAD2</td><td>PAD1</td></tr> <tr><td>20</td><td>PAD3</td><td>PAD1</td><td>PAD0</td><td>PAD2</td></tr> <tr><td>21</td><td>PAD3</td><td>PAD1</td><td>PAD2</td><td>PAD0</td></tr> <tr><td>22</td><td>PAD3</td><td>PAD2</td><td>PAD0</td><td>PAD1</td></tr> <tr><td>23</td><td>PAD3</td><td>PAD2</td><td>PAD1</td><td>PAD0</td></tr> </tbody> </table> | PAD_SEL | SCL  | MOSI | NSS | MISO | 0 | PAD0 | PAD1 | PAD2 | PAD3 | 1 | PAD0 | PAD1 | PAD3 | PAD2 | 2 | PAD0 | PAD2 | PAD1 | PAD3 | 3 | PAD0 | PAD2 | PAD3 | PAD1 | 4 | PAD0 | PAD3 | PAD1 | PAD2 | 5 | PAD0 | PAD3 | PAD2 | PAD1 | 6 | PAD1 | PAD0 | PAD2 | PAD3 | 7 | PAD1 | PAD0 | PAD3 | PAD2 | 8 | PAD1 | PAD2 | PAD0 | PAD3 | 9 | PAD1 | PAD2 | PAD3 | PAD0 | 10 | PAD1 | PAD3 | PAD0 | PAD2 | 11 | PAD1 | PAD3 | PAD2 | PAD0 | 12 | PAD2 | PAD0 | PAD1 | PAD3 | 13 | PAD2 | PAD0 | PAD3 | PAD1 | 14 | PAD2 | PAD1 | PAD0 | PAD3 | 15 | PAD2 | PAD1 | PAD3 | PAD0 | 16 | PAD2 | PAD3 | PAD0 | PAD1 | 17 | PAD2 | PAD3 | PAD1 | PAD0 | 18 | PAD3 | PAD0 | PAD1 | PAD2 | 19 | PAD3 | PAD0 | PAD2 | PAD1 | 20 | PAD3 | PAD1 | PAD0 | PAD2 | 21 | PAD3 | PAD1 | PAD2 | PAD0 | 22 | PAD3 | PAD2 | PAD0 | PAD1 | 23 | PAD3 | PAD2 | PAD1 | PAD0 |
| PAD_SEL     | SCL      | MOSI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | NSS     | MISO |      |     |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |
| 0           | PAD0     | PAD1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | PAD2    | PAD3 |      |     |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |
| 1           | PAD0     | PAD1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | PAD3    | PAD2 |      |     |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |
| 2           | PAD0     | PAD2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | PAD1    | PAD3 |      |     |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |
| 3           | PAD0     | PAD2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | PAD3    | PAD1 |      |     |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |
| 4           | PAD0     | PAD3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | PAD1    | PAD2 |      |     |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |
| 5           | PAD0     | PAD3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | PAD2    | PAD1 |      |     |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |
| 6           | PAD1     | PAD0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | PAD2    | PAD3 |      |     |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |
| 7           | PAD1     | PAD0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | PAD3    | PAD2 |      |     |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |
| 8           | PAD1     | PAD2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | PAD0    | PAD3 |      |     |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |
| 9           | PAD1     | PAD2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | PAD3    | PAD0 |      |     |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |
| 10          | PAD1     | PAD3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | PAD0    | PAD2 |      |     |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |
| 11          | PAD1     | PAD3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | PAD2    | PAD0 |      |     |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |
| 12          | PAD2     | PAD0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | PAD1    | PAD3 |      |     |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |
| 13          | PAD2     | PAD0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | PAD3    | PAD1 |      |     |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |
| 14          | PAD2     | PAD1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | PAD0    | PAD3 |      |     |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |
| 15          | PAD2     | PAD1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | PAD3    | PAD0 |      |     |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |
| 16          | PAD2     | PAD3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | PAD0    | PAD1 |      |     |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |
| 17          | PAD2     | PAD3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | PAD1    | PAD0 |      |     |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |
| 18          | PAD3     | PAD0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | PAD1    | PAD2 |      |     |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |
| 19          | PAD3     | PAD0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | PAD2    | PAD1 |      |     |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |
| 20          | PAD3     | PAD1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | PAD0    | PAD2 |      |     |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |
| 21          | PAD3     | PAD1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | PAD2    | PAD0 |      |     |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |
| 22          | PAD3     | PAD2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | PAD0    | PAD1 |      |     |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |
| 23          | PAD3     | PAD2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | PAD1    | PAD0 |      |     |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |
| 预留，必须保持复位值。 |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |         |      |      |     |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |
| 12          | Reserved | 发送和接收数据寄存器有效数据选择 (Valid byte or double-word data select signal)<br>0: 只有低 8 位有效<br>1: 32 位数据都有效<br>注: I2S 模式下固定为 1。                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |         |      |      |     |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |
|             |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |         |      |      |     |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |
| 11          | DW8_32   | 硬件或软件控制主模式下的 NSS 输出 (NSS select signal that from software or hardware)<br>0: 由 NSSR 寄存器值控制<br>1: 进行数据传输时硬件自动控制<br>注: I2S 模式下固定为 0。                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |         |      |      |     |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |
|             |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |         |      |      |     |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |
| 10          | NSS      | 预留，必须保持复位值。                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |         |      |      |     |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |
|             |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |         |      |      |     |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |
| 9: 5        | Reserved | 接收使能位 (Receive enable bit)<br>0: 接收禁止。同时可以清空 RX 缓冲<br>1: 接收使能<br>注: 当 SPI 只工作在主机接收模式时, TXEN 必须设置为 0。                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |         |      |      |     |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |
|             |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |         |      |      |     |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |
| 4           | RXEN     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |         |      |      |     |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |
|             |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |         |      |      |     |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |   |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |    |      |      |      |      |

| Bit | Field | Description                                                                                                                       |
|-----|-------|-----------------------------------------------------------------------------------------------------------------------------------|
| 3   | TXEN  | <p>发送使能位 (Transmit enable bit)<br/>           0: 发送禁止。同时可以清空 TX 缓冲<br/>           1: 发送使能<br/>           注: 当在主机模式下发送和接收同时发生。</p> |
| 2   | MODE  | <p>主机模式位 (Master mode bit)<br/>           0: 从机模式 (串行时钟来自外部主机)<br/>           1: 主机模式 (由内部 BRG 产生串行时钟)</p>                        |
| 1   | INTEN | <p>SPI/I2S 中断使能位 (SPI/I2S interrupt enable bit)<br/>           0: 禁止 SPI/I2S 中断<br/>           1: 使能 SPI/I2S 中断</p>               |
| 0   | SPIEN | <p>SPI/I2S 选择位 (SPI/I2S select bit)<br/>           0: SPI/I2S 禁止 (复位状态)<br/>           1: SPI/I2S 使能</p>                          |

### 16.5.9 SPI\_I2S\_CCTL 通用控制寄存器

偏移地址: 0x1C

复位值: 0x0000 0008

|      |    |    |    |    |    |    |    |             |            |            |        |       |      |      |    |
|------|----|----|----|----|----|----|----|-------------|------------|------------|--------|-------|------|------|----|
| 31   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23          | 22         | 21         | 20     | 19    | 18   | 17   | 16 |
| Res. |    |    |    |    |    |    |    |             |            |            |        |       |      |      |    |
| 15   | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7           | 6          | 5          | 4      | 3     | 2    | 1    | 0  |
| Res. |    |    |    |    |    |    |    | CPHAS<br>EL | TXEDG<br>E | RXEDG<br>E | SPILEN | LSBFE | CPOL | CPHA |    |
|      |    |    |    |    |    |    |    | rw          | rw         | rw         | rw     | rw    | rw   | rw   | rw |

| Bit   | Field    | Description                                                                                                                                                                                                                                                                           |
|-------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31: 7 | Reserved | 保留, 始终读为 0                                                                                                                                                                                                                                                                            |
| 6     | CPHASEL  | <p>CPHA 极性取反选择 (CPHA polarity invert select)<br/>           0: CPHA 设置保持不变<br/>           1: 将 CPHA 设置值取反<br/>           CPHA 为 1 时, 第一个数据位采样从第二个时钟边沿开始<br/>           CPHA 为 0 时, 第一个数据位采样从第一个时钟边沿开始<br/>           注: I2S 模式下固定为 1。</p>                                             |
| 5     | TXEDGE   | <p>发送数据相位调整位 (从模式) (Transmit data edge select)<br/>           0: 发送数据在一个有效时钟边沿后发送到数据总线<br/>           可用于低速模式时 (从模式输入时钟较慢)。<br/>           1: 发送数据立即发送到数据总线<br/>           可用于高速传输时 (从模式输入时钟较快, 超过 10MHz)<br/>           注: 建议该位配置为 1, 以免通信速率较快时不满足 AC 特性, 导致从模式下发送数据不符合主机采样时序要求。</p> |

| Bit | Field  | Description                                                                                                                                                                              |
|-----|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4   | RXEDGE | <p>接收数据采样时钟沿选择位（主模式）(Receive data edge select)</p> <p>0: 在传输数据位的中间采样数据<br/>1: 在传输数据位的尾时钟沿采样数据（用于高速传输，后移采样时间点以应对板级布线及从模式发送数据的延迟）</p> <p>注：建议该位配置为 1，以免通信速率较快时不满足 AC 特性，导致主模式下接收数据不正确。</p> |
| 3   | SPILEN | <p>SPI 数据宽度位 (SPI character length bit)</p> <p>该位在 DW8_32=0 时有效；DW8_32=1 时，该位需保持为 1。</p> <p>0: 7 位数据<br/>1: 8 位数据（缺省）</p> <p>注：I2S 模式下固定为 1。</p>                                         |
| 2   | LSBFE  | <p>LSBFE: LSB 在前使能位 (LSI first enable bit)</p> <p>0: 数据传输或接收时最高位在前<br/>1: 数据传输或接收时最低位在前</p> <p>注：I2S 模式下固定为 0。</p>                                                                       |
| 1   | CPOL   | <p>时钟极性标志位 (Clock polarity select bit)</p> <p>0: 时钟在空闲状态为低电平（两次传输之间）<br/>1: 时钟在空闲状态为高电平（两次传输之间）</p>                                                                                      |
| 0   | CPHA   | <p>时钟相位选择位 (Clock phase select bit)</p> <p>0: 第一个数据位采样从第二个时钟边沿开始<br/>1: 第一个数据位采样从第一个时钟边沿开始</p> <p>注：I2S 模式下固定为 0。</p>                                                                    |

### 16.5.10 SPI\_I2S\_SPBRG 波特率发生器

偏移地址: 0x20

复位值: 0x0000 0002

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

| Bit    | Field    | Description                                                                                                                                                    |
|--------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31: 16 | Reserved | 保留，始终读为 0                                                                                                                                                      |
| 15: 0  | SPBRG    | <p>SPI 波特率控制寄存器用于产生波特率 (SPI baud rate control register for baud rate)</p> <p>波特率公式：</p> <p>波特率 = Fpclk / SPBRG (Fpclk 是 APB 时钟频率)</p> <p>注：不能对该寄存器写值为 0、1。</p> |

### 16.5.11 SPI\_I2S\_RXDNR 接收数据个数寄存器

偏移地址: 0x24

复位值: 0x0000 0001

| 31     | 30       | 29 | 28                                                                                                                                                                                    | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------|----------|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|
| Res.   |          |    |                                                                                                                                                                                       |    |    |    |    |    |    |    |    |    |    |    |    |
| 15     | 14       | 13 | 12                                                                                                                                                                                    | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| RXDNR  |          |    |                                                                                                                                                                                       |    |    |    |    |    |    |    |    |    |    |    |    |
| rw     |          |    |                                                                                                                                                                                       |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit    | Field    |    | Description                                                                                                                                                                           |    |    |    |    |    |    |    |    |    |    |    |    |
| 31: 16 | Reserved |    | 保留, 始终读为 0                                                                                                                                                                            |    |    |    |    |    |    |    |    |    |    |    |    |
| 15: 0  | RXDNR    |    | 该寄存器用于存储下次接收过程需要接收字节的个数 (The register is used to hold a count of to be received bytes in next receive process)<br>注: 该寄存器的值仅在 SPI 为主机接收模式下有效; 缺省值是 1。<br>该寄存器值通过软件来改变, 且不能对该寄存器写值为 0。 |    |    |    |    |    |    |    |    |    |    |    |    |

### 16.5.12 SPI\_I2S\_NSSR 从机片选寄存器

偏移地址: 0x28

复位值: 0x0000 00FF

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

| Bit   | Field    |  | Description                                                                                                    |  |  |  |  |  |  |  |  |  |  |  |  |
|-------|----------|--|----------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|
| 31: 1 | Reserved |  | 保留, 必须保持复位值。                                                                                                   |  |  |  |  |  |  |  |  |  |  |  |  |
| 0     | NSS      |  | 主模式下片选输出信号。低有效, 从模式下该位无效 (Chip select output signal in Master mode)。<br>0: 从器件被选中 (允许从器件与主模式建立通信)<br>1: 从器件未选中 |  |  |  |  |  |  |  |  |  |  |  |  |

### 16.5.13 SPI\_I2S\_EXTCTL 数据控制寄存器

偏移地址: 0x2C

复位值: 0x0000 0008

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

|      |    |    |    |    |    |   |   |   |   |   |   |        |   |   |   |
|------|----|----|----|----|----|---|---|---|---|---|---|--------|---|---|---|
| 15   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3      | 2 | 1 | 0 |
| Res. |    |    |    |    |    |   |   |   |   |   |   | EXTLEN |   |   |   |
|      |    |    |    |    |    |   |   |   |   |   |   | rw     |   |   |   |

| Bit   | Field    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31: 5 | Reserved | 保留, 始终读为 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 4: 0  | EXTLEN   | <p>控制 SPI 数据帧长度的选择<br/>           0 0000: 32 bit<br/>           0 0001: 1 bit<br/>           0 0010: 2 bit<br/>           0 0011: 3 bit<br/>           .....<br/>           1 1100: 28 bit<br/>           1 1101: 29 bit<br/>           1 1110: 30 bit<br/>           1 1111: 31 bit<br/>           注: 仅当 SPI_I2S_GCTL.DW8_32=1 时有效; 当 DW8_32=0 时, 必须保持初始值 5'h8)。I2S 模式下此配置为无效:<br/>           I2S 模式下, 当 CHLEN=1, EXTLEN 值固定为 5'b00000 (32 位);<br/>           I2S 模式下, 当 CHLEN=0, EXTLEN 值固定为 5'b10000 (16 位)。</p> |

### 16.5.14 SPI\_I2S\_I2SCFGR I2S 配置寄存器

偏移地址: 0x30

复位值: 0x00010000

|      |    |    |    |       |         |      |    |        |        |        |    |      |        |    |       |
|------|----|----|----|-------|---------|------|----|--------|--------|--------|----|------|--------|----|-------|
| 31   | 30 | 29 | 28 | 27    | 26      | 25   | 24 | 23     | 22     | 21     | 20 | 19   | 18     | 17 | 16    |
| Res. |    |    |    |       |         |      |    | I2SDIV |        |        |    |      |        |    |       |
|      |    |    |    |       |         |      |    | rw     |        |        |    |      |        |    |       |
| 15   | 14 | 13 | 12 | 11    | 10      | 9    | 8  | 7      | 6      | 5      | 4  | 3    | 2      | 1  | 0     |
| Res. |    |    |    | MCKOE | SPI_I2S | Res. |    |        | PCMSYN | I2SSTD |    | Res. | DATLEN |    | CHLEN |
|      |    |    |    | rw    | rw      |      |    |        | rw     |        |    |      |        |    | rw    |

| Bit    | Field    | Description                                                                                                         |
|--------|----------|---------------------------------------------------------------------------------------------------------------------|
| 31: 25 | Reserved | 保留, 始终读为 0                                                                                                          |
| 24: 16 | I2SDIV   | <p>I2S 预分频器的分频系数<br/>           注: 主模式下才有效, 且不可配置该位值为 0; 当主模式下不输出 MCK 驱动时钟, 即 MCKOE=0 时, 不可配置该位值为 1 (不支持 1 分频)。</p> |

| Bit    | Field    | Description                                                                                                                                                                                |
|--------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15: 12 | Reserved | 保留, 始终读为 0                                                                                                                                                                                 |
| 11     | MCKOE    | 主时钟输出使能<br>0: 主模式驱动时钟 MCK 输出禁止<br>1: 主模式驱动 MCK 输出使能                                                                                                                                        |
| 10     | SPI_I2S  | 模块功能选择<br>0: 启用 SPI 功能<br>1: 启用 I2S 功能<br>注: 当配置该位为 1, 即 I2S 模式下, 以下寄存器功能位会被硬件固定, 无需软件配置。<br>GCTL 寄存器中的 DW8_32、NSS 位;<br>CCTL 寄存器中的 CPHASEL、SPILEN、LSBFE、CPHA 位;<br>EXTCTL 寄存器中的 EXTLEN 位。 |
| 9: 7   | Reserved | 保留, 始终读为 0                                                                                                                                                                                 |
| 6      | PCMSYNC  | PCM 标准帧同步模式<br>0: 短帧同步模式<br>1: 长帧同步模式                                                                                                                                                      |
| 5: 4   | I2SSTD   | I2S 标准<br>00: PHILIPS 标准<br>01: MSB 对齐标准<br>10: LSB 对齐标准<br>11: PCM 标准                                                                                                                     |
| 3      | Reserved | 保留, 始终读为 0                                                                                                                                                                                 |
| 2: 1   | DATLEN   | 数据长度<br>00: 16 位宽<br>01: 24 位宽<br>10: 32 位宽<br>11: 禁止设置该值<br>注: 当 CHLEN = 0 时, DATLEN 值由硬件固定为 2'b00。                                                                                       |
| 0      | CHLEN    | 声道长度 (每个声道包含的数据位数)<br>0: 16 位宽<br>1: 32 位宽                                                                                                                                                 |

# 17 I2C 内部集成电路接口

## 17.1 简介

微控制器通过 I2C 总线接口实现芯片间的串行互联。所有 I2C 总线特定的序列、协议仲裁和时序，都可以通过 I2C 提供的多主功能来控制。

I2C 总线是一种两线串行接口，串行数据线（SDA）和串行时钟（SCL）在连接到总线的器件间传递信息。每个器件都通过一个唯一的地址进行识别，且都可以作为发送或接收器。此外，器件在执行数据传输时也可以被看作是主器件或从器件。主器件是在总线上发起数据传输，并产生允许该传输的时钟信号的器件。此时，任何被寻址的器件都被认为是从器件。

I2C 有两种速率模式可供选择：标准模式（数据传输速率最大为 100Kbps）、快速模式（数据传输速率最大为 400Kbps）。

## 17.2 主要特征

- I2C 总线协议转换器/并行总线
- 半双工同步操作
- 支持主从模式
- 支持 7 位和 10 位地址格式
- 支持起始（START）、停止（STOP）、重新起始（RESTART）以及应答（ACK）信号的生成和检测
- 支持标准模式（最大 100Kbps）、快速模式（最大 400Kbps）
- 分别有 2 字节的发送和接收缓冲
- 支持过滤毛刺功能
- 支持中断和查询操作
- 支持多个从地址（详细见 I2C\_SLVMASK 寄存器描述）

## 17.3 功能描述

### 17.3.1 功能框图



图 17-1 I2C 功能框图

### 17.3.2 信号描述

表 17-1 引脚定义

| 引脚名     | 属性  | 描述     |
|---------|-----|--------|
| I2C_SCL | I/O | I2C 时钟 |
| I2C_SDA | I/O | I2C 数据 |

注：使用时引脚均需配置为开漏模式，配置方法请参考 GPIO 章节。

### 17.3.3 I2C 协议

#### 17.3.3.1 起始和停止条件

总线处于空闲状态时，SCL 和 SDA 同时被外部上拉电阻拉为高电平。主器件启动数据传输时，必须先产生起始条件。在 SCL 线为高电平时，SDA 线从高电平向低电平切换表示起始条件。主器件结束传输时要发送停止条件。在 SCL 线为高电平时，SDA 线由低电平向高电平切换表示停止条件。下图显示了起始和停止条件的时序。数据传输过程中，当 SCL 为 1 时，SDA 必须保持稳定。



图 17-2 起始和停止条件

#### 17.3.3.2 寻址协议

I2C 有两种地址格式：7 位地址格式和 10 位地址格式。

- 7 位地址格式

下图中，起始条件 (S) 后发送的第一个字节的前七位 (b7: 1) 为从地址，最低位 (b0) 为数据方向位。b0 为 0 表示主器件写数据到从器件，b0 为 1 表示主器件从从器件读数据。



图 17-3 7 位地址格式

- 10 位地址格式

在 10 位地址格式中，需要发送 2 个字节来传输 10 位地址。第一个字节的描述如下：前五位 (b7: 3) 用于通知从器件传输为 10 位地址格式；后两位 (b2: 1) 为从地址的 b9: 8；最低位 (b0) 为数据方向位 (R/W)。第二个字节为 10 位地址的低八位。

具体如下图所示：



图 17-4 10 位地址格式

下表定义了 I2C 首字节的特殊用途和保留地址。

表 17-2 I2C 首字节

| 从地址      | R/W 位 | 描述                             |
|----------|-------|--------------------------------|
| 0000 000 | 0     | 广播呼叫地址。I2C 将数据放入接收缓冲，并产生广播呼叫中断 |
| 0000 000 | 1     | 起始字节                           |
| 0000 001 | x     | CBUS 地址。I2C 接口忽略该访问            |
| 0000 010 | x     | 保留                             |
| 0000 011 | x     | 保留                             |
| 0000 1xx | x     | 保留                             |
| 1111 1xx | x     | 保留                             |
| 1111 0xx | x     | 10 位从器件寻址                      |

### 17.3.3.3 发送和接收协议

主器件可以发起数据传输，作为主发送器或主接收器，向总线发送数据或从总线接收数据。从器件响应主器件的请求，充当从发送器或从接收器。

- 主发送和从接收

所有数据都以字节格式传输，对每次传输的字节数没有限制。主器件发送完地址和 R/W 位或者一个字节的数据到从器件后，从接收器必须产生一个响应信号（ACK）。从接收器不能产生响应信号（ACK）时，主器件将会产生一个停止条件中止传输。从器件不能响应时，必须释放 SDA 为高电平，以便主器件产生停止条件。

当主发送器如下图所示传输数据时，从接收器在接收到的每个字节后产生一个 ACK 来响应主发送器。



图 17-5 主发送协议

### ● 主接收和从发送

当主器件如下图所示接收数据时，主器件在每次接收到一个字节数据后响应从发送器，最后一个字节除外。通过这种方式，主接收器能够通知从发送器是否为最后一个字节。从发送器在检测到 NACK 时必须释放 SDA，以便主器件产生停止条件。



图 17-6 主接收协议

主器件不想因产生停止条件而释放总线时，可以产生一个重复起始条件。重复起始条件与起始条件相同，但重复起始条件在 ACK 后产生。在主模式下，I2C 接口可以使用不同的传输方向与相同的从器件通

信。



图 17-7 带 RESTART (SR) 信号的主发送和接收协议

### ● 起始字节传输协议

起始字节传输协议用于无专用 I2C 硬件模块的系统。当 I2C 接口模块作为主器件时，在每次传输开始，可以为需要的从器件产生起始字节输出。

如下图所示，该协议由 7 个 0 以及 1 个 1 组成。处理器可以在地址阶段用低速采样来查询总线。一旦检测到 0，处理器可以从低速采样切换到主器件的正常速率。



图 17-8 起始字节传输

起始字节程序流程如下：

- 1) 主器件产生起始条件
- 2) 主器件发送起始字节 (0000 0001)
- 3) 主器件发送应答相关的时钟脉冲 (为了符合总线上的字节处理格式)
- 4) 没有从器件响应 ACK 信号
- 5) 主器件产生重复起始条件 (RESTART)

I2C 硬件接收器无需响应起始字节，因为这是一个保留地址，且地址会在 RESTART 后复位。

### 17.3.3.4 发送缓冲管理以及起始、停止和重复起始条件产生

发送为空时 I2C 不产生停止条件，而是拉低 SCL 使总线停止，直到有新数据为止。只有写 1 到 I2C\_CR.STOP (位 9) 或 I2C\_ENR.ABORT (位 1) 时才会产生停止条件。

下图显示了 I2C\_DR 寄存器的位。



图 17-9 I2C\_DR 寄存器

下图描述了 I2C 模块工作在主发送模式下，TX FIFO 变为空时的时序。



图 17-10 主发送，TX FIFO 为空

下图描述了 I2C 模块工作在主接收模式下，TX FIFO 变为空时的时序。



图 17-11 主接收，TX FIFO 为空

下图描述了 I2C 模块工作在主发送模式下，发生 RESTART (I2C\_CR.REPEN 为 1) 时的时序。I2C\_CR.REPEN 为 0 时，则先生成 STOP 再生成 START，以此代替 RESTART。



图 17-12 主发送，发生 RESTART

下图描述了 I2C 模块工作在主接收模式下，发生 RESTART 时的时序。



图 17-13 主接收，发生 RESTART

### 17.3.3.5 仲裁

如果总线上有多个主器件试图通过同时生成 START 条件来控制总线，那么就会有一个仲裁过程（多个主器件同时尝试控制总线，但只允许其中一个控制总线并使报文不被破坏的过程）。一旦其中一个主器件已经控制了总线，那么直到该主器件发送停止条件并将总线释放为空闲状态后，其他主器件才能控制总线。

当 SCL 线为高电平时，仲裁在 SDA 线发生。如果两个或多个主器件尝试发送信息到总线，在其他主器件都产生 0 的情况下，首先产生 1 的主器件将丢失仲裁。丢失仲裁的主器件可以继续产生时钟脉冲直到字节传输结束。如果每个主器件都尝试寻址相同的器件，仲裁会继续在数据阶段进行。

检测到丢失仲裁后，I2C 接口会停止产生 SCL 信号。

下图显示了两个主器件仲裁的总线时序。



图 17-14 两个主器件仲裁

### 17.3.3.6 时钟同步

当两个或多个主器件试图同时在总线上传输信息时，必须仲裁和同步 SCL 时钟。所有主器件都各自产生时钟来传输消息。数据只在时钟的高电平有效。时钟同步通过 SCL 信号的线“与”连接进行。当主器件把 SCL 时钟转换为 0 时，主器件会计算 SCL 低电平的时间，在下一个时钟周期开始时把 SCL 转换为 1。但如果另一个主器件把 SCL 保持为 0，那么这个主器件会进入等待状态直到 SCL 变为 1。

之后，所有主器件计算各自的高电平时间，最短高电平时间的主器件把 SCL 转换为 0。接着，所有主器件计算各自的低电平时间，最长低电平时间的主器件强制其他主器件进入等待状态。由此产生一个同步后的 SCL 时钟，如下图所示。



图 17-15 时钟同步（示意图）



图 17-16 时钟同步（时序图）

### 17.3.3.7 SCL 配置

I2C 的 SCL 可参考如下配置：



图 17-17 SCL 生成时序

- 标准模式:

$$SCLH = (\text{SSHR} + 12) \times \text{I2C CLK} + t_{\text{SYNC1}}$$

$$SCLL = (\text{SSLR} + 1) \times \text{I2C CLK} + t_{\text{SYNC2}}$$

注:  $t_{\text{SYNC1}}$  为 0~1 个 I2C CLK,  $t_{\text{SYNC2}}$  为 0~1 个 I2C CLK

- 快速模式:

$$SCLH = (\text{FSHR} + 12) \times \text{I2C CLK} + t_{\text{SYNC1}}$$

$$SCLL = (\text{FSLR} + 1) \times \text{I2C CLK} + t_{\text{SYNC2}}$$

注:  $t_{\text{SYNC1}}$  为 2~3 个 I2C CLK,  $t_{\text{SYNC2}}$  为 2~3 个 I2C CLK

#### 17.3.4 工作模式

I2C 接口可以以下述 4 种方式之一运行:

- 从发送模式
- 从接收模式
- 主发送模式
- 主接收模式

注：I2C 接口模块只能工作在主模式或从模式，不能同时工作在两种模式下。因此需要确保寄存器 I2C\_CR.DISSLAVE（位 6）和 I2C\_CR.MASTER（位 0）不能分别设置为 0 和 1（或者分别设置为 1 和 0）。

#### 17.3.4.1 从模式

- 初始化配置

- 1) 写 0 到 I2C\_ENR.ENABLE（位 0）以禁止 I2C
- 2) 通过配置 I2C\_SAR 寄存器指定从地址（该地址为 I2C 接口所响应的地址）
- 3) 通过配置 I2C\_CR.SLAVE10（位 3）指定地址格式（7 位或 10 位地址）；写 0 到 I2C\_CR.DISSLAVE（位 6）和 I2C\_CR.MASTER（位 0）
- 4) 置位 I2C\_ENR.ENABLE（位 0），使能 I2C 接口模块

- 从发送的单字节操作

I2C 接口被其他 I2C 主器件寻址并请求数据时，I2C 接口工作在从发送模式，工作流程如下：

- 1) 其他 I2C 主器件发起 I2C 传输，发送地址与 I2C\_SAR 寄存器的从地址匹配
- 2) I2C 接口响应发送的地址，识别传输方向以表明其工作在从发送模式
- 3) I2C 接口产生 RD\_REQ 中断 (I2C\_RAWISR 位 5)，并将 SCL 线拉低；总线一直处于等待状态直到软件响应。若 RD\_REQ 中断被屏蔽 (I2C\_IMR 位 5 为 0)，建议 CPU 定期查询 I2C\_RAWISR 寄存器：

- a. 读到 I2C\_RAWISR.RD\_REQ（位 5）为 1 等效于产生了 RD\_REQ 中断
- b. 软件必须采取行动以满足 I2C 传输的要求
- c. 时间间隔通常在 10 个 SCL 时钟周期左右（例如，400kbps 的时间间隔是 25us）

- 4) 如果在接收到读请求前 TX FIFO 中仍有数据，I2C 接口会产生 TX\_ABRT 中断 (I2C\_RAWISR 位 6)，以清空 TX FIFO 中的数据 (I2C\_CR.SLV\_TX\_ABRT\_DIS 为 0 时)

因此，在试图写入 TX FIFO 前，软件有必要通过读取 I2C\_TX\_ABRT 寄存器来清除 TX\_ABRT 中断。若 TX\_ABRT 中断被屏蔽 (I2C\_IMR 位 6 为 0)，建议 CPU 定期查询 I2C\_RAWISR 寄存器。读到 I2C\_RAWISR.TX\_ABRT（位 6）为 1 等效于产生了 TX\_ABRT 中断。

- 5) 软件写数据到 I2C\_DR 寄存器（其中位 8 设置为 0）
- 6) 软件必须先清除 I2C\_RAWISR.RD\_REQ（位 5）和 I2C\_RAWISR.TX\_ABRT（位 6）中断
- 7) I2C 接口释放 SCL，并发送数据字节
- 8) 主器件发送重复起始条件控制总线，或发送停止条件释放总线

- 从接收的单字节操作

其他主器件寻址 I2C 接口并发送数据时，I2C 接口工作在从接收模式，工作流程如下：

- 1) 其他 I2C 主器件发起 I2C 传输，发送地址与 I2C\_SAR 寄存器的从地址匹配
- 2) I2C 接口响应发送的地址，识别传输方向以表明其工作在从接收模式

- 3) I2C 接口接收主器件发送的数据并将其存储在接收缓冲中
  - 4) I2C 接口产生 RX\_FULL 中断 (I2C\_RAWISR 位 2)
- 若 RX\_FULL 中断被屏蔽 (I2C\_IMR 位 2 为 0)，建议 CPU 定期查询 I2C\_SR 寄存器。读到 I2C\_SR.RFNE (位 3) 为 1 等效于产生了 RX\_FULL 中断
- 5) 软件通过读 I2C\_DR 寄存器 (位 7:0) 来获得接收到的数据
  - 6) 主器件发送重复起始条件控制总线，或发送停止条件释放总线

- 程序流程图

下图为 I2C 接口作为从器件时的程序示例：



图 17-18 流程图 (I2C 接口作为从器件)

- 从器件的块传输操作

标准 I2C 协议中，所有的数据处理都是单字节的处理，程序通过写一个字节到从器件的 TX FIFO 来响应主器件的读请求。当从器件（从发送）接收到主器件（主接收）的读请求 (RD\_REQ) 时，至少应在从发送的 TX FIFO 中放置一个数据。I2C 接口模块可以处理 TX FIFO 中的多个数据，因此，后续的读

请求无需再产生中断来获取数据。这极大地减少了因每次数据中断而导致的等待时间。

此模式仅适用于 I2C 接口作为从发送器的情况。如果接收到主器件发送的 ACK，从器件的 TX FIFO 中没有数据，I2C 接口将拉低总线的 SCL 线直到读请求中断（RD\_REQ）产生并且 TX FIFO 的数据准备好后才释放 SCL 线。

如果 RX\_REQ 中断被屏蔽（I2C\_ISR 位 5 为 0），软件可以定期查询 I2C\_RAWISR 寄存器。读到 I2C\_RAWISR.RX\_REQ（位 5）为 1 等效于产生了 RX\_REQ 中断。

RD\_REQ 中断由读请求产生，和中断一样必须在退出中断服务程序（ISR）时清除。在中断服务程序中（ISR）可以写一个或多个字节的数据到 TX FIFO。在将这些字节传输给主器件的过程中，如果主器件响应了最后一个字节，则说明主器件正在要求更多的数据，那么从器件必须再次产生 RD\_REQ 中断请求。

如果主器件要从 I2C 接口接收 n 个字节，但程序写到 TX FIFO 中的数据个数大于 n，那么从器件在发送完要求的 n 个字节数据后，将会清空 TX FIFO 并忽略额外的字节。

#### 17.3.4.2 主模式

- 初始化配置

- 1) 写 0 到 I2C\_ENR.ENALE（位 0）以禁止 I2C
- 2) 通过配置 I2C\_CR.SPEED（位 2:1）指定 I2C 工作的速率模式（标准模式、快速模式）；同时确保 I2C\_CR.DISSLAVE（位 6）和 I2C\_CR.MASTER（位 0）都为 1
- 3) 将要寻址的 I2C 器件地址写入 I2C\_TAR（该寄存器还可以配置为广播呼叫地址或起始字节命令）
- 4) 置位 I2C\_ENR.ENALE（位 0），使能 I2C 接口模块
- 5) 将传输方向和数据写入 I2C\_DR，I2C 接口由此产生起始条件并发送地址字节

如果在使能 I2C 接口前配置了 I2C\_DR 寄存器，数据和命令都会丢失，因为在 I2C 接口禁止的情况下缓冲是清空的。

- 主发送和主接收

I2C 接口支持读写的动态切换。发送数据时，写数据到 I2C\_DR 的低字节中，配置 I2C\_DR.CMD（位 8）为 0 产生写操作。随后的读命令无需配置 I2C\_DR 的低字节，只需要配置 I2C\_DR.CMD（位 8）为 1 即可。若 TX FIFO 为空，I2C 模块拉低 SCL 直到下个命令写入到 TX FIFO 中。

- 程序流程图

下图为 I2C 接口作为主器件时的程序示例：



图 17-19 流程图 (I2C 接口作为主器件)

### 17.3.4.3 中止传输

I2C\_ENR.ABORT(位 1)允许软件在完成 TX FIFO 中的传输命令之前放弃 I2C 总线。作为 ABORT 请求的响应, I2C 模块发出停止条件到 I2C 总线, 同时清空 TX FIFO。中止传输只允许在主模式下执行。

- 程序流程

- 1) 停止向 TX FIFO (I2C\_DR) 中写入新命令
- 2) 置 I2C\_ENR.ABORT (位 1) 为 1
- 3) 等待 TX\_ABRT 中断

### 17.3.5 中断

下表列出了 I2C 的中断位及其设置和清除方式。部分位由硬件置位并由软件清除; 另一部分位由硬件置位和清除。

表 17-3 中断位的置位和清除

| 中断位       | 硬件置位/软件清除 | 硬件置位和清除 |
|-----------|-----------|---------|
| GEN_CALL  | √         | ✗       |
| START_DET | √         | ✗       |
| STOP_DET  | √         | ✗       |
| ACTIVITY  | √         | ✗       |
| RX_DONE   | √         | ✗       |
| TX_ABRT   | √         | ✗       |
| RD_REQ    | √         | ✗       |
| TX_EMPTY  | ✗         | √       |
| TX_OVER   | √         | ✗       |
| RX_FULL   | ✗         | √       |
| RX_OVER   | √         | ✗       |
| RX_UNDER  | √         | ✗       |

下图描述了中断寄存器中, 中断位被硬件置位和软件清除的操作。



图 17-20 I2C 中断机制

## 17.4 寄存器

### 17.4.1 寄存器总览

表 17-4 I2C 寄存器概览

| Offset | Acronym      | Register Name     | Reset      |
|--------|--------------|-------------------|------------|
| 0x00   | I2C_CR       | 控制寄存器             | 0x0000007F |
| 0x04   | I2C_TAR      | 目标地址寄存器           | 0x00000055 |
| 0x08   | I2C_SAR      | 从地址寄存器            | 0x00000055 |
| 0x10   | I2C_DR       | 数据命令寄存器           | 0x00000000 |
| 0x14   | I2C_SSHR     | 标准模式时钟高电平计数寄存器    | 0x00000190 |
| 0x18   | I2C_SSLR     | 标准模式时钟低电平计数寄存器    | 0x000001D6 |
| 0x1C   | I2C_FSHR     | 快速模式时钟高电平计数寄存器    | 0x0000003C |
| 0x20   | I2C_FSLR     | 快速模式时钟低电平计数寄存器    | 0x00000082 |
| 0x2C   | I2C_ISR      | 中断状态寄存器           | 0x00000000 |
| 0x30   | I2C_IMR      | 中断屏蔽寄存器           | 0x000008FF |
| 0x34   | I2C_RAWISR   | RAW 中断寄存器         | 0x00000000 |
| 0x38   | I2C_RXTLR    | 接收阈值              | 0x00000000 |
| 0x3C   | I2C_TXTLR    | 发送阈值              | 0x00000000 |
| 0x40   | I2C_ICR      | 组合和独立中断清除寄存器      | 0x00000000 |
| 0x44   | I2C_RX_UNDER | 清除 RX_UNDER 中断寄存器 | 0x00000000 |
| 0x48   | I2C_RX_OVER  | 清除 RX_OVER 中断寄存器  | 0x00000000 |
| 0x4C   | I2C_TX_OVER  | 清除 TX_OVER 中断寄存器  | 0x00000000 |
| 0x50   | I2C_RD_REQ   | 清除 RD_REQ 中断寄存器   | 0x00000000 |
| 0x54   | I2C_TX_ABRT  | 清除 TX_ABRT 中断寄存器  | 0x00000000 |

| Offset | Acronym        | Register Name      | Reset      |
|--------|----------------|--------------------|------------|
| 0x58   | I2C_RX_DONE    | 清除 RX_DONE 中断寄存器   | 0x00000000 |
| 0x5C   | I2C_ACTIV      | 清除 ACTIVITY 中断寄存器  | 0x00000000 |
| 0x60   | I2C_STOP       | 清除 STOP_DET 中断寄存器  | 0x00000000 |
| 0x64   | I2C_START      | 清除 START_DET 中断寄存器 | 0x00000000 |
| 0x68   | I2C_GC         | 清除 GEN_CALL 中断寄存器  | 0x00000000 |
| 0x6C   | I2C_ENR        | 使能寄存器              | 0x00000000 |
| 0x70   | I2C_SR         | 状态寄存器              | 0x00000006 |
| 0x74   | I2C_TXFLR      | 发送缓冲级别寄存器          | 0x00000000 |
| 0x78   | I2C_RXFLR      | 接收缓冲级别寄存器          | 0x00000000 |
| 0x7C   | I2C_HOLD       | SDA 保持时间寄存器        | 0x00000001 |
| 0x94   | I2C_SETUP      | SDA 建立时间寄存器        | 0x00000064 |
| 0x98   | I2C_GCR        | 广播呼叫 ACK 寄存器       | 0x00000001 |
| 0xB0   | I2C_SLVMASK    | 从地址掩码寄存器           | 0x000003FF |
| 0xB4   | I2C_SLVRCVADDR | 从器件接收地址寄存器         | 0x00000000 |

### 17.4.2 I2C\_CR 控制寄存器

偏移地址: 0x00

复位值: 0x0000 007F

|      |    |          |                 |          |      |        |          |           |        |           |          |       |         |    |    |
|------|----|----------|-----------------|----------|------|--------|----------|-----------|--------|-----------|----------|-------|---------|----|----|
| 31   | 30 | 29       | 28              | 27       | 26   | 25     | 24       | 23        | 22     | 21        | 20       | 19    | 18      | 17 | 16 |
| Res. |    |          |                 |          |      |        |          |           |        |           |          |       |         |    |    |
| 15   | 14 | 13       | 12              | 11       | 10   | 9      | 8        | 7         | 6      | 5         | 4        | 3     | 2       | 1  | 0  |
| Res. |    | PAD_SE_L | SLV_TX_ABRT_DIS | RESTA_RT | STOP | EMPINT | STOPIN_T | DISSLA_VE | REOPEN | MASTE_R10 | SLAVE1_0 | SPEED | MASTE_R |    |    |
|      |    | rw       | rw              | rw       | rw   | rw     | rw       | rw        | rw     | rw        | rw       | rw    | rw      | rw | rw |

| Bit    | Field           | Description                                                                            |
|--------|-----------------|----------------------------------------------------------------------------------------|
| 31: 13 | Reserved        | 保留, 必须保持复位值                                                                            |
| 12     | PAD_SEL         | PAD MUX<br>交换 SCL、SDA 对应 PAD<br>0: PAD0 ⇄ SCL; PAD1 ⇄ SDA<br>1: PAD0 ⇄ SDA; PAD1 ⇄ SCL |
| 11     | SLV_TX_ABRT_DIS | I2C 作为从发送器时<br>0: 接收到 RD_REQ 信号后清除 TX FIFO<br>1: 接收到 RD_REQ 信号后禁止清除 TX FIFO            |

| Bit | Field    | Description                                                                                                                                                                                                                                                                                                                                                     |
|-----|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10  | RESTART  | <p>发送或接收字节前，是否产生 RESTART</p> <p>0: 如果 REPEN 为 1，则仅在前一个命令改变传输方向时才产生 RESTART；如果 REPEN 为 0，则先产生 STOP 再产生 START</p> <p>1: 如果 REPEN 为 1，则在数据接收或发送（根据 CMD 的值）前产生 RESTART，无论前一个命令是否改变数据的传输方向；如果 REPEN 为 0，则先产生 STOP 再产生 START</p>                                                                                                                                      |
| 9   | STOP     | <p>发送或接收字节后，是否产生 STOP</p> <p>0: 当前字节之后不产生 STOP，无论 TX FIFO 是否为空。主器件继续当前传输（根据 CMD 的值发送或接收数据）。如果 TX FIFO 为空，主器件将拉低 SCL 线，挂起总线直至 TX FIFO 收到新命令</p> <p>1:</p> <p>发送模式：如果 TX FIFO 为空，则在当前字节后产生 STOP。如果 TX FIFO 不为空，则在完成剩余传输后产生 STOP</p> <p>接收模式：在当前字节后产生 STOP。如果 TX FIFO 不为空，则主器件立即发起一个新的传输并进行总线仲裁</p> <p>注：若需在接收字节后产生 STOP，请使用 I2C_ENR.ABORT 位实现，参考 I2C_ENR 寄存器。</p> |
| 8   | EMPINT   | 该位控制 TX_EMPTY 中断的产生，细节请参考 I2C_RAWISR 寄存器                                                                                                                                                                                                                                                                                                                        |
| 7   | STOPINT  | <p>从模式下，是否产生 STOP 中断</p> <p>0: 无论地址是否匹配，都产生 STOP 中断</p> <p>1: 仅在地址匹配时产生 STOP 中断</p> <p>注：广播地址寻址时，如果该位置位，从器件不产生 STOP 中断。STOP 中断仅在发送地址与从地址（I2C_SAR）匹配时产生。</p>                                                                                                                                                                                                     |
| 6   | DISSLAVE | <p>该位控制是否禁用 I2C 从器件</p> <p>0: 从器件使能</p> <p>1: 从器件禁止</p>                                                                                                                                                                                                                                                                                                         |
| 5   | REPEN    | <p>I2C 作为主器件时是否发送 RESTART 条件</p> <p>0: 禁止</p> <p>1: 使能</p> <p>RESTART 条件可以替换为先发送停止条件再发送起始条件。</p> <p>当 RESTART 被禁止时，I2C 接口作为主器件不能执行以下功能：</p> <p>发送起始字节</p> <p>组合格式模式下改变传输方向</p> <p>10 位地址格式的读操作</p> <p>执行上述操作会置位 I2C_RAWISR.TX_ABRT (位 6)。</p>                                                                                                                   |
| 4   | MASTER10 | <p>I2C 作为主器件时的地址格式</p> <p>0: 7 位地址格式</p> <p>1: 10 位地址格式</p>                                                                                                                                                                                                                                                                                                     |
| 3   | SLAVE10  | <p>I2C 作为从器件时，该位控制是否响应 7 位或 10 位地址</p> <p>0: 7 位寻址。I2C 接口忽略 10 位寻址；对于 7 位寻址，仅比较 I2C_SAR 寄存器的低 7 位</p> <p>1: 10 位寻址。I2C 仅响应 10 位寻址，接收地址与 I2C_SAR 的 10 位比较</p>                                                                                                                                                                                                    |

| Bit  | Field  | Description                                                          |
|------|--------|----------------------------------------------------------------------|
| 2: 1 | SPEED  | 该两位控制 I2C 接口工作在主模式时的速率<br>1: 标准模式（最大 100Kbps）<br>2: 快速模式（最大 400Kbps） |
| 0    | MASTER | 该位控制是否使能主器件<br>0: 主器件禁止<br>1: 主器件使能                                  |

I2C\_CR.DISSLAVE (位 6) 和 I2C\_CR.MASTER (位 0) 的配置组合如下表所示：

表 17-5 DISSLAVE 和 MASTER 配置

| DISSLAVE (I2C_CR[6]) | MASTER (I2C_CR[0]) | 状态   |
|----------------------|--------------------|------|
| 0                    | 0                  | 从器件  |
| 0                    | 1                  | 禁止配置 |
| 1                    | 0                  | 禁止配置 |
| 1                    | 1                  | 主器件  |

### 17.4.3 I2C\_TAR 目标地址寄存器

偏移地址：0x04

复位值：0x0000 0055

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

| Bit    | Field    | Description                                                                                                           |
|--------|----------|-----------------------------------------------------------------------------------------------------------------------|
| 31: 12 | Reserved | 保留，必须保持复位值                                                                                                            |
| 11     | SPECIAL  | 该位指示软件执行的是否为特殊命令（广播呼叫或起始字节命令）<br>0: 忽略 GC (位 10)，正常使用 ADDR (位 9:0)<br>1: 执行特殊 I2C 命令，细节请参考 GC 位的描述                    |
| 10     | GC       | 位 11 置位时，该位显示 I2C 执行的是广播呼叫还是起始字节命令<br>0: 广播呼叫<br>发起广播呼叫后只能执行写操作。I2C 接口一直工作在广播呼叫模式下，直到 SPECIAL (位 11) 被清零<br>1: 起始字节命令 |
| 9: 0   | ADDR     | 主模式时的目标地址<br>发起广播呼叫时，该字段被忽略。<br>要产生开始字节命令，CPU 只需要对该字段写一次。                                                             |

#### 17.4.4 I2C\_SAR 从地址寄存器

偏移地址: 0x08

复位值: 0x0000 0055

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

| Bit    | Field    | Description                             |
|--------|----------|-----------------------------------------|
| 31: 10 | Reserved | 保留, 必须保持复位值                             |
| 9: 0   | ADDR     | I2C 接口的从地址。对于 7 位地址格式, ADDR 只有[6: 0]有效。 |

#### 17.4.5 I2C\_DR 数据命令寄存器

偏移地址: 0x10

复位值: 0x0000 0000

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

| Bit   | Field    | Description                                                                                                         |
|-------|----------|---------------------------------------------------------------------------------------------------------------------|
| 31: 9 | Reserved | 保留, 必须保持复位值                                                                                                         |
| 8     | CMD      | 控制在主模式下执行读或写操作<br>0: 写<br>1: 读<br>向 TX FIFO 中输入命令时, 该位用于区分读和写命令。从接收模式下, 对该位的写操作被忽略; 从发送模式下, 写 0 表示发送 I2C_DR 寄存器的数据。 |
| 7: 0  | DAT      | I2C 总线待发送或接收到的数据                                                                                                    |

#### 17.4.6 I2C\_SSHR 标准模式时钟高电平计数寄存器

偏移地址: 0x14

复位值: 0x0000 0190

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

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

| Bit    | Field    | Description                                                                                              |
|--------|----------|----------------------------------------------------------------------------------------------------------|
| 31: 16 | Reserved | 保留，必须保持复位值                                                                                               |
| 15: 0  | CNT      | 标准模式下 SCL 时钟高电平周期<br>注：该寄存器只可配置在 6 至 65525 之间，这是由于 I2C 接口使用了一个 16 位的计数器，该计数器值等于 CNT+10 时标志 I2C 总线处于空闲状态。 |

#### 17.4.7 I2C\_SSLR 标准模式时钟低电平计数寄存器

偏移地址: 0x18

复位值: 0x0000 01D6

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

| Bit    | Field    | Description               |
|--------|----------|---------------------------|
| 31: 16 | Reserved | 保留，必须保持复位值                |
| 15: 0  | CNT      | 标准模式下 SCL 时钟低电平周期，最小值为 8。 |

#### 17.4.8 I2C\_FSHR 快速模式时钟高电平计数寄存器

偏移地址: 0x1C

复位值: 0x0000 003C

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

| Bit    | Field    | Description               |
|--------|----------|---------------------------|
| 31: 16 | Reserved | 保留，必须保持复位值                |
| 15: 0  | CNT      | 快速模式下 SCL 时钟高电平周期，最小值为 6。 |

#### 17.4.9 I2C\_FSLR 快速模式时钟低电平计数寄存器

偏移地址: 0x20

复位值: 0x0000 0082

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

| Bit    | Field    | Description               |
|--------|----------|---------------------------|
| 31: 16 | Reserved | 保留，必须保持复位值                |
| 15: 0  | CNT      | 快速模式下 SCL 时钟低电平周期，最小值为 8。 |

#### 17.4.10 I2C\_ISR 中断状态寄存器

偏移地址: 0x2C

复位值: 0x0000 0000

|      |    |    |    |    |       |      |       |             |             |            |              |             |             |             |              |
|------|----|----|----|----|-------|------|-------|-------------|-------------|------------|--------------|-------------|-------------|-------------|--------------|
| 31   | 30 | 29 | 28 | 27 | 26    | 25   | 24    | 23          | 22          | 21         | 20           | 19          | 18          | 17          | 16           |
| Res. |    |    |    |    |       |      |       |             |             |            |              |             |             |             |              |
| 15   | 14 | 13 | 12 | 11 | 10    | 9    | 8     | 7           | 6           | 5          | 4            | 3           | 2           | 1           | 0            |
| Res. |    |    |    |    |       |      |       |             |             |            |              |             |             |             |              |
|      |    |    |    | GC | START | STOP | ACTIV | RX_DO<br>NE | TX_ABR<br>T | RD_RE<br>Q | TX_EM<br>PTY | TX_OV<br>ER | RX_FUL<br>L | RX_OV<br>ER | RX_UN<br>DER |
|      |    |    |    | r  | r     | r    | r     | r           | r           | r          | r            | r           | r           | r           | r            |

| Bit    | Field    | Description                |
|--------|----------|----------------------------|
| 31: 12 | Reserved | 保留，必须保持复位值                 |
| 11: 0  | ISR      | 每位的具体描述可以参考 I2C_RAWISR 寄存器 |

#### 17.4.11 I2C\_IMR 中断屏蔽寄存器

偏移地址: 0x30

复位值: 0x0000 08FF

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

|      |    |    |    |    |       |      |       |             |             |            |              |             |             |             |              |
|------|----|----|----|----|-------|------|-------|-------------|-------------|------------|--------------|-------------|-------------|-------------|--------------|
| 15   | 14 | 13 | 12 | 11 | 10    | 9    | 8     | 7           | 6           | 5          | 4            | 3           | 2           | 1           | 0            |
| Res. |    |    |    | GC | START | STOP | ACTIV | RX_DO<br>NE | TX_ABR<br>T | RD_RE<br>Q | TX_EM<br>PTY | TX_OV<br>ER | RX_FUL<br>L | RX_OV<br>ER | RX_UN<br>DER |
|      |    |    |    | rw | rw    | rw   | rw    | rw          | rw          | rw         | rw           | rw          | rw          | rw          | rw           |

| Bit    | Field    | Description                |
|--------|----------|----------------------------|
| 31: 12 | Reserved | 保留, 必须保持复位值                |
| 11: 0  | IMR      | 每一位屏蔽与 I2C_ISR 寄存器对应的中断状态位 |

#### 17.4.12 I2C\_RAWISR RAW 中断寄存器

偏移地址: 0x34

复位值: 0x0000 0000

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

|      |    |    |    |    |       |      |       |             |             |            |              |             |             |             |              |
|------|----|----|----|----|-------|------|-------|-------------|-------------|------------|--------------|-------------|-------------|-------------|--------------|
| 15   | 14 | 13 | 12 | 11 | 10    | 9    | 8     | 7           | 6           | 5          | 4            | 3           | 2           | 1           | 0            |
| Res. |    |    |    | GC | START | STOP | ACTIV | RX_DO<br>NE | TX_ABR<br>T | RD_RE<br>Q | TX_EM<br>PTY | TX_OV<br>ER | RX_FUL<br>L | RX_OV<br>ER | RX_UN<br>DER |
|      |    |    |    | r  | r     | r    | r     | r           | r           | r          | r            | r           | r           | r           | r            |

| Bit    | Field    | Description                                                                                                                                                                                                                                                      |
|--------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31: 12 | Reserved | 保留, 必须保持复位值                                                                                                                                                                                                                                                      |
| 11     | GC       | 广播呼叫 (General call)<br>接收到广播呼叫地址并响应时置位。<br>禁止 I2C 接口或当 CPU 读 I2C_GC.GC (位 0) 时清零。<br>I2C 将接收到的数据存储在接收缓冲中。                                                                                                                                                        |
| 10     | START    | 起始条件检测<br>无论 I2C 接口工作在主模式或从模式, 一旦检测到 I2C 接口上发生了起始或重复起始条件即置位该位。                                                                                                                                                                                                   |
| 9      | STOP     | 停止条件检测<br>该位状态取决于 I2C_CR.STOPINT (位 7) 的状态:<br><b>STOPINT = 0:</b><br>无论 I2C 接口工作在主模式或从模式, 一旦检测到 I2C 接口上发生了停止条件时即置位该位。从模式下, 无论从器件是否被寻址都会产生 STOP 中断。<br><b>STOPINT = 1:</b><br>主模式下 (MASTER = 1), 该位指示 I2C 接口是否发生停止条件;<br>从模式下 (MASTER = 0), 仅当从器件被寻址时产生 STOP 中断。 |

| Bit | Field    | Description                                                                                                                                                                                    |
|-----|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8   | ACTIV    | 该位用于捕捉 I2C 模块的活动状态。置位后只能由以下四种方式清零： <ul style="list-style-type: none"><li>▪ 禁止 I2C 接口</li><li>▪ 读 I2C_ACTIV 寄存器</li><li>▪ 读 I2C_ICR 寄存器</li><li>▪ 系统复位</li></ul> 即使 I2C 处于空闲状态，该位也仍然保持为高直到被清零。  |
| 7   | RX_DONE  | 从发送结束 (Transmit done)<br>当 I2C 作为从发送器时，如果主器件没有响应发送的字节，则该位置位。<br>该情况发生在传输的最后一个字节则表示传输结束。                                                                                                        |
| 6   | TX_ABRT  | 发送中止 (Transmit abort)<br>当 I2C 接口作为发送器，不能发送完缓冲中的数据时置位。<br>注意：发送中止会将 I2C 接口的接收和发送缓冲清空。发送缓冲会处于刷新状态直到读 I2C_TX_ABRT 寄存器。一旦该读操作执行后，发送缓冲就可以接收 APB 接口上的新数据。                                           |
| 5   | RD_REQ   | 读请求 (Read request)<br>当 I2C 作为从器件，其他主器件试图从 I2C 接口读取数据时置位。<br>I2C 接口会使总线保持在等待状态 ( $SCL = 0$ ) 直到中断被处理。这表明 I2C 接口被其他主器件寻址成功且被要求发送数据。处理器必须响应该中断然后写数据到 I2C_DR 寄存器中。该位在处理器读 I2C_RD_REQ 寄存器后清零。      |
| 4   | TX_EMPTY | 发送缓冲空 (Transmit buffer empty)<br>该位状态取决于 I2C_CR.EMPINT (位 8) 的状态：<br>$EMPINT = 0$ , 发送缓冲区数据个数小于等于阈值时置位；<br>$EMPINT = 1$ , 发送缓冲区数据个数小于等于阈值且前一个发送地址/数据的内部移位寄存器发送结束时置位。<br>发送缓冲区数据个数大于阈值时由硬件自动清零。 |
| 3   | TX_OVER  | 发送缓冲过载 (Transmit buffer over)<br>发送缓冲满时处理器写入新数据导致溢出时置位。                                                                                                                                        |
| 2   | RX_FULL  | 接收缓冲满 (Receive buffer full)<br>接收缓冲区数据大于阈值时置位。<br>接收缓冲区数据小于等于阈值时由硬件清零。                                                                                                                         |
| 1   | RX_OVER  | 接收缓冲过载 (Receive buffer over)<br>接收缓冲满时收到新数据时置位。此时 I2C 接口会响应，但新的数据会丢失。                                                                                                                          |
| 0   | RX_UNDER | 接收缓冲欠载 (Receive buffer under)<br>RX FIFO 为空时处理器读 I2C_DR 寄存器则该位置位。                                                                                                                              |

#### 17.4.13 I2C\_RXTLR 接收阈值

偏移地址: 0x38

复位值: 0x0000 0000

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

|      |    |    |    |    |    |   |   |    |   |   |   |   |   |   |   |
|------|----|----|----|----|----|---|---|----|---|---|---|---|---|---|---|
| 15   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7  | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Res. |    |    |    |    |    |   |   | TL |   |   |   |   |   |   |   |
|      |    |    |    |    |    |   |   | rw |   |   |   |   |   |   |   |

| Bit   | Field    | Description                                                   |
|-------|----------|---------------------------------------------------------------|
| 31: 8 | Reserved | 保留，必须保持复位值                                                    |
| 7: 0  | TL       | 接收 FIFO 阈值 (Receive FIFO threshold level)<br>控制 RX_FULL 中断触发。 |

#### 17.4.14 I2C\_TXTLR 发送阈值

偏移地址: 0x3C

复位值: 0x0000 0000

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

| Bit   | Field    | Description                                                     |
|-------|----------|-----------------------------------------------------------------|
| 31: 8 | Reserved | 保留，必须保持复位值                                                      |
| 7: 0  | TL       | 发送 FIFO 阈值 (Transmit FIFO threshold level)<br>控制 TX_EMPTY 中断触发。 |

#### 17.4.15 I2C\_ICR 组合和独立中断清除寄存器

偏移地址: 0x40

复位值: 0x0000 0000

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

| Bit   | Field    | Description                                          |
|-------|----------|------------------------------------------------------|
| 31: 1 | Reserved | 保留，必须保持复位值                                           |
| 0     | ICR      | 读该寄存器将会清除所有组合中断、独立中断。<br>该位不清除硬件可自动清除的中断，仅清除软件可清除中断。 |

#### 17.4.16 I2C\_RX\_UNDER 清除 RX\_UNDER 中断寄存器

偏移地址: 0x44

复位值: 0x0000 0000

|                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-----------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 31                    | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Res.                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15                    | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Res.                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| RX_UN<br>DER<br><br>r |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit   | Field    | Description                         |
|-------|----------|-------------------------------------|
| 31: 1 | Reserved | 保留, 必须保持复位值                         |
| 0     | RX_UNDER | 读该寄存器清零 RX_UNDER 中断 (I2C_RAWISR[0]) |

#### 17.4.17 I2C\_RX\_OVER 清除 RX\_OVER 中断寄存器

偏移地址: 0x48

复位值: 0x0000 0000

|                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|----------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 31                   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Res.                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15                   | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Res.                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| RX_OV<br>ER<br><br>r |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit   | Field    | Description                        |
|-------|----------|------------------------------------|
| 31: 1 | Reserved | 保留, 必须保持复位值                        |
| 0     | RX_OVER  | 读该寄存器清零 RX_OVER 中断 (I2C_RAWISR[1]) |

#### 17.4.18 I2C\_TX\_OVER 清除 TX\_OVER 中断寄存器

偏移地址: 0x4C

复位值: 0x0000 0000

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

|      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |       |
|------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-------|
| 15   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0     |
| Res. |    |    |    |    |    |   |   |   |   |   |   |   |   |   | TX_OV |
| ER   |    |    |    |    |    |   |   |   |   |   |   |   |   |   | r     |
|      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |       |

| Bit   | Field    | Description                        |
|-------|----------|------------------------------------|
| 31: 1 | Reserved | 保留, 必须保持复位值                        |
| 0     | TX_OVER  | 读该寄存器清零 TX_OVER 中断 (I2C_RAWISR[3]) |

#### 17.4.19 I2C\_RD\_REQ 清除 RD\_REQ 中断寄存器

偏移地址: 0x50

复位值: 0x0000 0000

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

| Bit   | Field    | Description                       |
|-------|----------|-----------------------------------|
| 31: 1 | Reserved | 保留, 必须保持复位值                       |
| 0     | RD_REQ   | 读该寄存器清零 RD_REQ 中断 (I2C_RAWISR[5]) |

#### 17.4.20 I2C\_TX\_ABRT 清除 TX\_ABRT 中断寄存器

偏移地址: 0x54

复位值: 0x0000 0000

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

| Bit   | Field    | Description |
|-------|----------|-------------|
| 31: 1 | Reserved | 保留, 必须保持复位值 |

| Bit | Field   | Description                                                              |
|-----|---------|--------------------------------------------------------------------------|
| 0   | TX_ABRT | 读该寄存器清零 TX_ABRT 中断 (I2C_RAWISR[6])<br>同时将 TX FIFO 从刷新/复位状态中释放，以便接收写入的数据。 |

#### 17.4.21 I2C\_RX\_DONE 清除 RX\_DONE 中断寄存器

偏移地址: 0x58

复位值: 0x0000 0000

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

| Bit   | Field    | Description                        |
|-------|----------|------------------------------------|
| 31: 1 | Reserved | 保留，必须保持复位值                         |
| 0     | RX_DONE  | 读该寄存器清零 RX_DONE 中断 (I2C_RAWISR[7]) |

#### 17.4.22 I2C\_ACTIV 清除 ACTIVITY 中断寄存器

偏移地址: 0x5C

复位值: 0x0000 0000

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

| Bit   | Field    | Description                                                                                                                                      |
|-------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| 31: 1 | Reserved | 保留，必须保持复位值                                                                                                                                       |
| 0     | ACTIV    | I2C 不活动时，读该寄存器清零 ACTIV 中断 (I2C_RAWISR[8])<br>如果 I2C 仍然活动，那么 ACTIV 中断将继续置位。当 I2C 模块禁止或 I2C 总线不再活动时该位由硬件清零。可以通过读该寄存器得到 I2C_RAWISR.ACTIV (位 8) 的状态。 |

### 17.4.23 I2C\_STOP 清除 STOP\_DET 中断寄存器

偏移地址: 0x60

复位值: 0x0000 0000

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

| Bit   | Field    | Description                     |
|-------|----------|---------------------------------|
| 31: 1 | Reserved | 保留, 必须保持复位值                     |
| 0     | STOP     | 读该寄存器清零 STOP 中断 (I2C_RAWISR[9]) |

### 17.4.24 I2C\_START 清除 START\_DET 中断寄存器

偏移地址: 0x64

复位值: 0x0000 0000

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

| Bit   | Field    | Description                       |
|-------|----------|-----------------------------------|
| 31: 1 | Reserved | 保留, 必须保持复位值                       |
| 0     | START    | 读该寄存器清零 START 中断 (I2C_RAWISR[10]) |

### 17.4.25 I2C\_GC 清除 GEN\_CALL 中断寄存器

偏移地址: 0x68

复位值: 0x0000 0000

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

r

| Bit   | Field    | Description                    |
|-------|----------|--------------------------------|
| 31: 1 | Reserved | 保留, 必须保持复位值                    |
| 0     | GC       | 读该寄存器清零 GC 中断 (I2C_RAWISR[11]) |

#### 17.4.26 I2C\_ENR 使能寄存器

偏移地址: 0x6C

复位值: 0x0000 0000

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

| Bit   | Field    | Description                                                                                                                                                                                                  |
|-------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31: 2 | Reserved | 保留, 必须保持复位值                                                                                                                                                                                                  |
| 1     | ABORT    | I2C 传输中止 (I2C transfer abort)<br>0: 中止没有发生或者已经结束<br>1: 中止操作正在进行<br><br>I2C 模块作为主器件时, 软件可以置位该位以中止 I2C 传输。一旦置位不能立即清除。置位后 I2C 模块控制逻辑会在完成当前传输后产生 STOP 条件并清空发送缓冲, 中止操作之后产生 TX_ABRT 中断。<br>该 ABORT 位会在中止操作结束后自动清零。 |
| 0     | ENABLE   | I2C 模块使能<br>0: 禁止 I2C 模块 (发送和接收缓冲保持擦除状态)<br>1: 使能 I2C 模块                                                                                                                                                     |

#### 17.4.27 I2C\_SR 状态寄存器

偏移地址: 0x70

复位值: 0x0000 0006

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

| Res. | SLV_AC<br>TIV | MST_A<br>CTIV | RFF | RFNE | TFE | TFNF | ACTIV |
|------|---------------|---------------|-----|------|-----|------|-------|
|      | r             | r             | r   | r    | r   | r    | r     |

| Bit   | Field     | Description                                                                                |
|-------|-----------|--------------------------------------------------------------------------------------------|
| 31: 7 | Reserved  | 保留，必须保持复位值                                                                                 |
| 6     | SLV_ACTIV | 从状态机（Slave FSM）活动状态<br>0: 从状态机处于 IDLE 状态, I2C 从器件部分不活动<br>1: 从状态机不处于 IDLE 状态, I2C 从器件部分活动  |
| 5     | MST_ACTIV | 主状态机（Master FSM）活动状态<br>0: 主状态机处于 IDLE 状态, I2C 主器件部分不活动<br>1: 主状态机不处于 IDLE 状态, I2C 主器件部分活动 |
| 4     | RFF       | 接收缓冲满<br>0: 接收缓冲未满<br>1: 接收缓冲满                                                             |
| 3     | RFNE      | 接收缓冲非空<br>0: 接收缓冲空<br>1: 接收缓冲非空                                                            |
| 2     | TFE       | 发送缓冲空<br>0: 发送缓冲非空<br>1: 发送缓冲空                                                             |
| 1     | TFNF      | 发送缓冲未满<br>0: 发送缓冲满<br>1: 发送缓冲未满                                                            |
| 0     | ACTIV     | I2C 活动状态<br>MST_ACTIV 位与 SLV_ACTIV 位相或的结果。                                                 |

#### 17.4.28 I2C\_TXFLR 发送缓冲级别寄存器

偏移地址: 0x74

复位值: 0x0000 0000

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

| Bit   | Field    | Description       |
|-------|----------|-------------------|
| 31: 2 | Reserved | 保留，必须保持复位值        |
| 1: 0  | CNT      | 发送缓冲中有效数据的个数（0~2） |

### 17.4.29 I2C\_RXFLR 接收缓冲级别寄存器

偏移地址: 0x78

复位值: 0x0000 0000

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

| Bit   | Field    | Description        |
|-------|----------|--------------------|
| 31: 2 | Reserved | 保留, 必须保持复位值        |
| 1: 0  | CNT      | 接收缓冲中有效数据的个数 (0~2) |

### 17.4.30 I2C\_HOLD SDA 保持时间寄存器

偏移地址: 0x7C

复位值: 0x0000 0001

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

| Bit    | Field    | Description                                              |
|--------|----------|----------------------------------------------------------|
| 31: 24 | Reserved | 保留, 必须保持复位值                                              |
| 23: 16 | RX_HOLD  | I2C 作为接收器时, 配置 SDA 内部保持时间 (SCL 为高电平时有效), 单位为 APB 时钟周期。   |
| 15: 0  | TX_HOLD  | I2C 作为发送器时, 配置 SDA 保持时间 (SCL 从高电平转换为低电平后), 单位为 APB 时钟周期。 |

### 17.4.31 I2C\_SETUP SDA 建立时间寄存器

偏移地址: 0x94

复位值: 0x0000 0064

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

|      |    |    |    |    |    |   |   |     |   |   |   |   |   |   |   |
|------|----|----|----|----|----|---|---|-----|---|---|---|---|---|---|---|
| 15   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7   | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Res. |    |    |    |    |    |   |   | CNT |   |   |   |   |   |   |   |
|      |    |    |    |    |    |   |   | rw  |   |   |   |   |   |   |   |

| Bit   | Field    | Description                                                            |
|-------|----------|------------------------------------------------------------------------|
| 31: 8 | Reserved | 保留，必须保持复位值                                                             |
| 7: 0  | CNT      | SDA 建立时间，最小值为 2。<br>如果所需延迟时间为 1000ns，当 APB 时钟频率为 10MHz 时，建议将该寄存器设为 11。 |

#### 17.4.32 I2C\_GCR 广播呼叫 ACK 寄存器

偏移地址: 0x98

复位值: 0x0000 0001

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

| Bit   | Field    | Description                                                     |
|-------|----------|-----------------------------------------------------------------|
| 31: 1 | Reserved | 保留，必须保持复位值                                                      |
| 0     | GC       | 广播呼叫 ACK<br>0: 接收到广播呼叫后不响应 (NACK)，也不产生中断<br>1: 接收到广播呼叫后响应 (ACK) |

#### 17.4.33 I2C\_SLVMASK 从地址掩码寄存器

偏移地址: 0xB0

复位值: 0x0000 03FF

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

| Bit    | Field    | Description                                                       |
|--------|----------|-------------------------------------------------------------------|
| 31: 10 | Reserved | 保留, 必须保持复位值                                                       |
| 9: 0   | MASK     | 从地址掩码<br>0: I2C_SAR 寄存器的相应位被掩码忽略, 不需要比较<br>1: I2C_SAR 寄存器的相应位需要比较 |

#### 17.4.34 I2C\_SLVRCVADDR 从器件接收地址寄存器

偏移地址: 0xB4

复位值: 0x0000 0000

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

| Bit    | Field    | Description |
|--------|----------|-------------|
| 31: 10 | Reserved | 保留, 必须保持复位值 |
| 9: 0   | ADDR     | 从器件实际接收到的地址 |

## 18 DBG 调试支持

### 18.1 简介

芯片内核包含硬件调试模块，主要用于功能的调试。当内核在取指（指令断点）或访问数据（数据断点）时，硬件调试模块可以控制内核停止，此时用户可以查询内核的内部状态和系统的外部状态。查询完成后，内核可以继续执行当前程序。

当芯片与调试器连接开始调试时，调试器自动调用内核的调试模块进行调试操作。

### 18.2 功能描述

#### 18.2.1 功能框图



图 18-1 调试功能框图

Cortex-M0 内核含有调试单元，该单元由以下部分组成：

SWDP: SW 调试端口

BPU: 断点调试单元

DWT: 数据观察点和跟踪

### 18.2.2 SWD 内部上拉与下拉

SWD 引脚输入直接控制调试模式，不能悬空。为了保证 I/O 电平可控，SWD 引脚上内嵌了上拉和下拉电阻。

- SWDIO: 内部上拉
- SWCLK: 内部下拉

软件可以把这些 I/O 口作为普通的 I/O 口使用，此时默认的上下拉功能关闭，参考通用端口 GPIO 章节。

### 18.2.3 SWJ 调试端口

该芯片的 2 个普通 I/O 口可用作 SWD-DP 接口引脚，不同封装都支持 SWD 调试端口。

表 18-1 SWD 调试端口管脚

| SWD-DP 端口引脚名称 | SW 调试接口 |           | 引脚分配 |
|---------------|---------|-----------|------|
|               | 类型      | 调试功能      |      |
| SWDIO         | 输入/输出   | 串行数据输入/输出 | PA13 |
| SWCLK         | 输入      | 串行时钟      | PA14 |

### 18.3 ID 代码和锁定机制

在芯片内部有多个 ID 编码，如下表：

表 18-2 ID 编码

| ID 名          | 芯片         |
|---------------|------------|
| DEV_ID        | 0x4C50F800 |
| CPU TAP SW ID | 0x0BB11477 |

#### 18.3.1 微控制器设备 ID 编码

微控制器内部包含设备 ID 编码，此 ID 定义了微控制器的硅片版本，并且映射到外部 APB 总线上。通过用户代码与调试接口均能够获取此 ID 编码。

#### 18.3.2 Cortex JEDEC-106 ID 编码

微控制器有一个 JEDEC-106ID 编码。它位于映射到内部 PPB 总线地址为 0xE00FF000\_0xE00FFFFF 的 4KB ROM 表中。

## 18.4 SW 调试端口

### 18.4.1 SW 协议介绍

此同步串行协议使用 2 个引脚：主机到目标的时钟信号（SWCLK）与双向数据信号（SWDIO）。

SWDIO 作为双向数据线，需连接上拉电阻（ARM 建议值 100K）。SWDIO 引脚内嵌了上拉电阻，无需额外的外接电阻。

数据从低位开始传输，允许读写寄存器组 DPACC 与 APACC。

根据协议，当 SWDIO 改变方向时，同时需要插入一个转换时间（默认一个 Bit 时间，具体可以通过 SWCLK 调整），这段区间内，任何设备不能驱动此信号线。

### 18.4.2 SW 协议序列

一次序列包含三个阶段：

- 主机发送 8 位请求包；
- 目标发送 3 位确认应答；
- 根据配置方向，主机或目标发送 33 位（包含一位校验位）数据；

表 18-3 8bit 请求包

| 比特位  | 名称       | 描述                     |
|------|----------|------------------------|
| 0    | 起始       | 必须为 1                  |
| 1    | APnDP    | 0: 访问 DP<br>1: 访问 AP   |
| 2    | RnW      | 0: 写请求<br>1: 读请求       |
| 4: 3 | A[3 : 2] | DP 或 AP 寄存器的地址         |
| 5    | Parity   | 前面比特位的校验位              |
| 6    | Stop     | 0                      |
| 7    | Park     | 不能由主机驱动，由于有上拉，目标永远读为 1 |

注：每一个请求包紧跟一个 Bit 转换时间。更多关于 DAPCC 与 APACC 寄存器的信息，查看 ARM 相关的 CPU 技术参考手册。

表 18-4 3bit 应答包

| 比特位    | 名称  | 描述                            |
|--------|-----|-------------------------------|
| 0 .. 2 | ACK | 001: 失败<br>010: 等待<br>100: 成功 |

注：当应答信号（ACK）处于上表的情况之一时，应答位后有一个转换时间。

表 18-5 33bit 数据包

| 比特位     | 名称          | 描述           |
|---------|-------------|--------------|
| 0 .. 31 | WDATA/RDATA | 写或读的数据       |
| 32      | Parity      | 32 位数据的奇偶校验位 |

注：读数据位结束后等待一个转换时间。

#### 18.4.3 SW-DP 状态机 (Reset, Idle states, ID code)

SW-DP 状态机通过内部的 ID 码识别 SW\_DP, 遵守 JEP-106 标准, 具体信息请参考 ARM 相关手册。

直到调试器读取 ID 之前, SW-DP 的状态机不会工作。

- 当出现了上电复位, 或 DP 从 JTAG 切换到 SWD 后, 或超过 50 个周期的高电平时, SW-DP 状态机将处于复位状态;
- 如果 RESET 状态之后出现了至少 2 个周期的低电平, 状态机会切换到 IDLE 状态;
- 状态机开始处于复位态, 工作时必须先切换到 IDLE 态, 先执行读 DP-SW ID 寄存器的操作。否则, 调试器无法进行其它正常的传输, 会出现 ACK Fault;

#### 18.4.4 DP 和 AP 读 / 写访问

- 对 DP 的读操作没有延时: 调试器将直接获得数据 (如果 ACK 返回成功状态), 或者处于等待状态 (如果 ACK 返回等待状态);
- 对 AP 的读操作具有延时。这意味着前一次读操作的结果只能在下一次操作时获得。如果下一次的操作不是对 AP 的访问, 则必须读 DP-RDBUFF 寄存器来获得上一次读操作的结果;
- DP-CTRL/STAT 寄存器的 READOK 标志位会在每次 AP 读操作和 RDBUFF 读操作后更新, 以通知调试器 AP 的读操作是否成功;
- SW-DP 具有写缓冲区 (DP 和 AP 都有写缓冲), 这使得其它传输进行时, 仍然可以接受写操作。如果写缓冲区满, 调试器将获得一个等待的 ACK 响应。读 IDCODE 寄存器, 读 CTRL/STAT 寄存器和写 ABORT 寄存器操作在写缓冲区满时仍被接受;
- 由于 SWCLK 和 HCLK 的异步性, 需要在写操作后 (在奇偶校验位后) 插入 2 个额外的 SWCLK 周期, 以确保内部写操作正确完成。这两个额外的时钟周期需要在 IDLE 状态下插入。这个操作步骤在写 CTRL/STAT 寄存器以提出一个上电请求时尤其重要, 否则下一个操作 (在内核上电后才有效的操作) 会立即执行, 这将会导致操作失败;

#### 18.4.5 SW-DP 寄存器

当 APnDP=0 时, 可以访问以下这些寄存器。

表 18-6 SW-DP 寄存器

| A[3:2] | 读 / 写 | SELECT 寄存器的 CTRLSEL 位 | 寄存器           | 描述                                                                  |
|--------|-------|-----------------------|---------------|---------------------------------------------------------------------|
| 00     | 读     |                       | IDCODE        | 固定为 0x0BB1 1477 (用于识别 SW-DP)。                                       |
| 00     | 写     |                       | ABORT         |                                                                     |
| 01     | 读/写   | 0                     | DP-CTRL /STAT | 请求一个系统或调试的上电操作; 配置 AP 访问的操作式;<br>控制比较, 校验操作;<br>读取一些状态位 (溢出, 上电响应)。 |
| 01     | 读/写   | 1                     | WIRE CONTROL  | 配置串行通信物理层协议 (如转换时间长度等)。                                             |
| 10     | 读     |                       | READ RESEND   | 允许从一个错误的调试传输中恢复数据而不用重复最初的 AP 传输。                                    |
| 10     | 写     |                       | SELECT        | 选择当前的访问端口和有效的 4 字长寄存器窗口。                                            |
| 11     | 读/写   |                       | READ BUFFER   | 这个寄存器会从 AP 捕获上一次读操作的数据结果, 因此可以获得数据而不必再启动一个新的 AP 传输。                 |

#### 18.4.6 SW-AP 寄存器

当 APnDP=1 时, 可以访问 AP 寄存器的访问地址由以下两部分组成:

- A[3: 2]的值
- DP SELECT 寄存器的当前值

### 18.5 MCU 调试模块 (DBGMCU)

MCU 调试模块提供以下调试器协助功能:

- 支持低功耗模式
- 断点时定时器与看门狗的时钟控制

#### 18.5.1 低功耗模式的调试支持

MCU 具有多种低功耗模式, 能够关闭 CPU 时钟, 降低 CPU 的功耗, 通过执行 WFE 或 WFI 指令进入低功耗模式。CPU Free-Run 时钟 FCLK 与 AHB 总线时钟 HCLK 对于调试操作时必须的, 不能关闭, 同时 MCU 可以通过配置一些寄存器来改变低功耗模式特性, 从而支持在低功耗模式下调试代码, 具体的配置如下。

- 当进入睡眠模式时, 为了能够提供 HCLK 同 FCLK 相同的时钟, 调试器必须先置位 DBG\_CR 寄存器的 DBG\_SLEEP 位。
- 当进入停机模式时, 必须先配置 DBG\_STOP 位, 该操作会激活内部振荡器 HSI, 从而为 FCLK 与 HCLK 提供时钟。
- 当进入待机模式时, 须配置 DBG\_STANDBY 位, 该配置下数字电路将不会断电, 并且将会激活

HSI 为 FCLK 和 HCLK 提供时钟。

### 18.5.2 支持定时器、看门狗

当产生断点时，根据定时器和看门狗的应用不同来选择计数器的工作模式：

- 计数器可以选择继续计数，通常应用在输出 PWM 波控制电机
- 计数器可以选择停止计数，通常应用在看门狗计数

## 18.6 寄存器

### 18.6.1 寄存器总览

表 18-7 DBG 寄存器概览

| Offset | Acronym    | Register Name | Reset      |
|--------|------------|---------------|------------|
| 0x00   | DBG_IDCODE | DBG ID 编码寄存器  | 0x4C50F800 |
| 0x04   | DBG_CR     | DBG 控制寄存器     | 0x00000000 |

### 18.6.2 DBG\_IDCODE ID 编码寄存器

偏移地址：0x40013400（只支持 32 位访问，只读）

复位值：0x4C50F800

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

| Bit  | Field  | Description                                 |
|------|--------|---------------------------------------------|
| 31:0 | DEV_ID | 设备识别编码 (Device Identifier)<br>只读寄存器，始终读为复位值 |

### 18.6.3 DBG\_CR 控制寄存器

偏移地址：0x40013404（只支持 32 位访问，只读）

复位值：0x0000 0000（POR 复位，不被系统复位所复位）

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

|                       |    |    |      |    |    |                       |              |              |      |   |   |                              |                     |              |               |
|-----------------------|----|----|------|----|----|-----------------------|--------------|--------------|------|---|---|------------------------------|---------------------|--------------|---------------|
| 15                    | 14 | 13 | 12   | 11 | 10 | 9                     | 8            | 7            | 6    | 5 | 4 | 3                            | 2                   | 1            | 0             |
| Res.                  |    |    |      |    |    |                       |              |              |      |   |   | DBG_TI<br>M14_ST<br>OP       | Res.                |              |               |
| Res.                  |    |    |      |    |    |                       |              |              |      |   |   | rw                           | Res.                |              |               |
| DBG_TI<br>M3_ST<br>OP |    |    | Res. |    |    | DBG_TI<br>M1_ST<br>OP | DBG_W<br>TOP | DBG_I<br>TOP | Res. |   |   | DBG_S<br>TOP_F<br>OR_LD<br>O | DBG_S<br>TANDB<br>Y | DBG_S<br>TOP | DBG_S<br>LEEP |
| rw                    |    |    | rw   |    |    | rw                    |              |              | rw   |   |   | rw                           |                     |              |               |

| Bit   | Field            | Description                                                                                                                                    |
|-------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:19 | Reserved         | 保留, 必须保持复位值                                                                                                                                    |
| 18    | DBG_TIM14_STOP   | 当内核进入调试状态时计数器 14 停止工作 (TIM14 Counter Stopped When Core is Halted)<br>0: 选中定时器的计数器仍然正常工作<br>1: 选中定时器的计数器停止工作                                    |
| 17:13 | Reserved         | 保留, 必须保持复位值                                                                                                                                    |
| 12    | DBG_TIM3_STOP    | 当内核进入调试状态时计数器 3 停止工作 (TIM3 Counter Stopped When Core is Halted)<br>0: 选中定时器的计数器仍然正常工作<br>1: 选中定时器的计数器停止工作                                      |
| 11    | Reserved         | 保留, 必须保持复位值                                                                                                                                    |
| 10    | DBG_TIM1_STOP    | 当内核进入调试状态时计数器 1 停止工作 (TIM1 Counter Stopped When Core is Halted)<br>0: 选中定时器的计数器仍然正常工作<br>1: 选中定时器的计数器停止工作                                      |
| 9     | DBG_WWDG_STOP    | 当内核进入调试状态时调试窗口看门狗停止工作 (Debug Window Watchdog Stopped When Core is Halted)<br>0: 窗口看门狗计数器仍然正常工作<br>1: 窗口看门狗计数器停止工作                              |
| 8     | DBG_IWWDG_STOP   | 独立看门狗停止工作 (Debug Independent Watchdog Stopped)<br>此位与内核是否进入调试状态无关<br>0: 看门狗计数器仍然正常工作<br>1: 看门狗计数器停止工作                                          |
| 7:4   | Reserved         | 保留, 必须保持复位值                                                                                                                                    |
| 3     | DBG_STOP_FOR_LDO | 调试停机模式 LDO 状态 (Debug Stop Mode For LDO)<br>0: LDO 进入低功耗状态, 正常进入 STOP 模式<br>1: LDO 不进入低功耗状态, PLL 保持供电, 不能进入真正 STOP 模式。CPU 进入 DEEPSLEEP, HCLK 关闭 |

| Bit | Field       | Description                                                                                                                                                                                                                         |
|-----|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2   | DBG_STANDBY | <p>调试待机模式（Debug Standby Mode）</p> <p>0: 数字电路部分完全断电，HCLK 与 FCLK 关闭。除指示退出待机模式的标志位，STANDBY 模式的退出与复位行为相同</p> <p>1: 数字电路不断电，时钟 FCLK 与 HCLK 开启，由 HSI 提供时钟。STANDBY 模式的退出与复位行为相同。</p>                                                       |
| 1   | DBG_STOP    | <p>调试停机模式（Debug Stop Mode）</p> <p>0: 在停机模式时，时钟控制器禁止一切时钟（包括 HCLK 和 FCLK）。当从 STOP 模式退出时，时钟配置与复位之后的配置一致。如果需要重新使能 PLL, HSE 等时钟，必须通过软件重新配置</p> <p>1: 在停机模式时，FCLK 与 HCLK 开启，由 HSI 提供时钟。当从 STOP 模式退出时，如果需要重新使能 PLL, HSE 等时钟，必须通过软件重新配置</p> |
| 0   | DBG_SLEEP   | <p>调试睡眠模式（Debug Sleep Mode）</p> <p>0: 在睡眠模式时，时钟 FCLK 开启，FCLK 保持默认配置的系统时钟，HCLK 则关闭。睡眠模式不会复位配置好的时钟系统，因此退出睡眠模式时，软件不需重新配置系统时钟</p> <p>1: 在睡眠模式时，FCLK 和 HCLK 时钟开启，都保持原先配置好的时钟。</p>                                                        |

## 19 Device Electronic Signature 器件电子签名

### 19.1 简介

器件电子签名是存放在闪存存储器系统存储区域内用来唯一识别一颗微控制器的身份标识码(96 bits)。在任何情况下，用户都不可以修改器件电子签名。

可以通过软件读取器件电子签名，用来实现以下功能：

- 作为密码使用，在编程闪存时，通过器件电子签名与软件加密算法结合使用，提高代码在闪存中的安全性
- 作为序列号，用作终端应用中的序列号
- 激活安全引导流程

### 19.2 寄存器描述

基址：0x1FFF F7E8

表 19-1 存储器容量寄存器概览

| Offset | Acronym | Register Name | Reset      |
|--------|---------|---------------|------------|
| 0x00   | UID1    | 唯一标识码 1       | 0xFFFFFFFF |
| 0x04   | UID2    | 唯一标识码 2       | 0xFFFFFFFF |
| 0x08   | UID3    | 唯一标识码 3       | 0xFFFFFFFF |

#### 19.2.1 UID1 唯一标识码

偏移地址：0x00

复位值：其值在出厂时编写

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

U\_ID (31: 16)

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

U\_ID (15: 0)

|     |       |             |
|-----|-------|-------------|
| Bit | Field | Description |
|-----|-------|-------------|

|       |              |                                             |
|-------|--------------|---------------------------------------------|
| 31: 0 | U_ID (31: 0) | U_ID: 唯一身份标志 31: 0 位 (31: 0 unique ID bits) |
|-------|--------------|---------------------------------------------|

### 19.2.2 UID2 唯一标识码

偏移地址: 0x04

复位值: 其值在出厂时编写

| 31            | 30            | 29                                            | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|---------------|---------------|-----------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|
| U_ID (63: 48) |               |                                               |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15            | 14            | 13                                            | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| U_ID (47: 32) |               |                                               |    |    |    |    |    |    |    |    |    |    |    |    |    |
| r             |               |                                               |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit           | Field         | Description                                   |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 31: 0         | U_ID (63: 32) | U_ID: 唯一身份标志 63: 32 位 (63: 32 unique ID bits) |    |    |    |    |    |    |    |    |    |    |    |    |    |

### 19.2.3 UID3 唯一标识码

偏移地址: 0x08

复位值: 其值在出厂时编写

| 31            | 30            | 29                                             | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|---------------|---------------|------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|
| U_ID (95: 80) |               |                                                |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15            | 14            | 13                                             | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| U_ID (79: 64) |               |                                                |    |    |    |    |    |    |    |    |    |    |    |    |    |
| r             |               |                                                |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit           | Field         | Description                                    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 31: 0         | U_ID (95: 64) | U_ID: 唯一身份标志 95 : 64 位 (95: 64 unique ID bits) |    |    |    |    |    |    |    |    |    |    |    |    |    |

## 20 修订记录

表 20-1 修订记录表

| 修订时间       | 修订版本  | 修订内容       |
|------------|-------|------------|
| 2022/10/27 | V1.01 | 定时器章节内容修改  |
| 2022/08/11 | V1.0  | 定时器等章节内容修改 |
| 2022/03/15 | V0.51 | 内容和版式优化    |
| 2022/01/27 | V0.5  | 初版发布       |