

# HK32F103x8xB 用户手册

版本: 1.1

发布日期: 2022-09-22



## 前言

### 编写目的

本文档介绍了 HK32F103x8xB 芯片的功能框图、存储器映射、Flash、中断和事件等功能以及各功能 模块的寄存器描述,旨在帮助用户快速开发 HK32F103x8xB 的应用及产品。

### 读者对象

本文适用于以下读者:

- 开发工程师
- 芯片测试工程师

### 版本说明

本文档对应的产品系列为 HK32F103x8xB。

### 修订记录

| 版本  | 日期         | 修订内容                                  |
|-----|------------|---------------------------------------|
| 1.0 | 2022/03/23 | 首次发布                                  |
| 1.1 | 2022/09/22 | 1. 更新了定时器"捕获/比较通道"章节的图,以及"定时器同步"章节。   |
|     |            | 2. 更新了"18.6.7 位时间特性"中的图 1-1 各种 CAN 帧。 |
|     |            | 3. 更正了其它的细小错误。                        |



## 目录

| 1 简介                                | 1  |
|-------------------------------------|----|
| 2 存储器和总线构架                          | 2  |
| 2.1 系统构架                            | 2  |
| 2.2 存储器组织                           | 3  |
| 2.2.1 存储器映射                         | 3  |
| 2.2.2 嵌入式 SRAM                      | 5  |
| 2.2.3 位段                            | 6  |
| 2.3 启动配置                            | 6  |
| 2.3.1 内嵌的自举程序                       | 7  |
| 3 嵌入式 Flash                         | 8  |
| 3.1 Flash 主要特性                      | 8  |
| 3.2 Flash 功能描述                      | 8  |
| 3.2.1 Flash 结构                      | 8  |
| 3.2.2 读操作                           | 9  |
| 3.2.3 Flash 写和擦除操作                  | 9  |
| 3.2.4 读写保护                          | 14 |
| 3.2.5 选项字节的写保护                      | 15 |
| 3.3 选项字节说明                          | 15 |
| 3.4 Flash 中断                        | 18 |
| 3.5 Flash 寄存器                       | 18 |
| 3.5.1 Flash 访问控制寄存器(FLASH_ACR)      | 18 |
| 3.5.2 Flash 关键字寄存器(FLASH_KEYR)      | 19 |
| 3.5.3 Flash 选项关键字寄存器(FLASH_OPTKEYR) | 19 |
| 3.5.4 Flash 状态寄存器(FLASH_SR)         | 20 |
| 3.5.5 Flash 控制寄存器(FLASH_CR)         | 20 |
| 3.5.6 Flash 地址寄存器(FLASH_AR)         | 22 |
| 3.5.7 Flash 选项字节寄存器(FLASH_OBR)      | 22 |
| 3.5.8 Flash 写保护寄存器(FLASH_WRPR)      | 23 |
| 3.5.9 Flash 控制寄存器 2(FLASH_ECR)      | 23 |



| 4 CRC 计算单元(CRC)                | 25 |
|--------------------------------|----|
| 4.1 CRC 主要特性                   | 25 |
| 4.2 CRC 功能描述                   | 25 |
| 4.3 CRC 寄存器                    | 25 |
| 4.3.1 数据寄存器(CRC_DR)            | 26 |
| 4.3.2 独立数据寄存器(CRC_IDR)         | 26 |
| 4.3.3 控制寄存器(CRC_CR)            | 26 |
| 5 电源控制(PWR)                    | 28 |
| 5.1 电源                         | 28 |
| 5.1.1 独立的 ADC 供电和参考电压          | 28 |
| 5.1.2 电池备份域                    | 28 |
| 5.1.3 Core 电压调节器               | 29 |
| 5.2 电源监控器                      | 29 |
| 5.2.1 上电复位(POR)和掉电复位(PDR)      | 29 |
| 5.2.2 可编程电压监测器(PVD)            | 30 |
| 5.3 低功耗模式                      | 30 |
| 5.3.1 降低系统时钟频率                 | 31 |
| 5.3.2 外部时钟的控制                  | 31 |
| 5.3.3 睡眠(Sleep)模式              | 31 |
| 5.3.4 停机(Stop)模式               | 32 |
| 5.3.5 待机(Standby)模式            | 33 |
| 5.3.6 丰富的唤醒源                   | 34 |
| 5.3.7 调试模式                     | 34 |
| 5.3.8 低功耗模式下的自动唤醒(AWU)         | 34 |
| 5.4 PWR 寄存器                    | 34 |
| 5.4.1 电源控制寄存器(PWR_CR)          | 34 |
| 5.4.2 电源控制/状态寄存器(PWR_CSR)      | 36 |
| 5.4.3 唤醒引脚极性寄存器(PWR_POL)       | 37 |
| 5.4.4 电源控制/状态寄存器(PWR_LDO_STOP) | 37 |
| 6 备份寄存器(BKP)                   | 39 |
| 6.1 BKP 特性                     | 39 |



| 6.2 BKP 功能描述                     | 39 |
|----------------------------------|----|
| 6.2.1 侵入检测                       | 39 |
| 6.2.2 RTC 校准                     | 39 |
| 6.3 BKP 寄存器                      | 40 |
| 6.3.1 备份域数据寄存器 x(BKP_DRx)(x=110) | 40 |
| 6.3.2 RTC 时钟校准寄存器(BKP_RTCCR)     | 40 |
| 6.3.3 备份控制寄存器(BKP_CR)            | 41 |
| 6.3.4 备份控制/状态寄存器(BKP_CSR)        | 41 |
| 6.3.5 控制寄存器(BKP_LSE_CTL)         | 42 |
| 7 复位和时钟控制(RCC)                   | 44 |
| 7.1 复位                           | 44 |
| 7.1.1 系统复位                       | 44 |
| 7.1.2 电源复位                       | 45 |
| 7.1.3 备份域复位                      | 45 |
| 7.2 时钟                           | 45 |
| 7.2.1 HSI 时钟                     | 46 |
| 7.2.2 HSE 时钟                     | 47 |
| 7.2.3 PLL                        | 48 |
| 7.2.4 LSE 时钟                     | 48 |
| 7.2.5 LSI 时钟                     | 48 |
| 7.2.6 系统时钟(SYSCLK)选择             | 49 |
| 7.2.7 时钟安全系统(CSS)                | 49 |
| 7.2.8 RTC 时钟                     | 49 |
| 7.2.9 看门狗时钟                      | 49 |
| 7.2.10 时钟输出                      | 49 |
| 7.3 RCC 寄存器                      | 50 |
| 7.3.1 时钟控制寄存器(RCC_CR)            | 50 |
| 7.3.2 时钟配置寄存器(RCC_CFGR)          | 52 |
| 7.3.3 时钟中断寄存器(RCC_CIR)           | 54 |
| 7.3.4 APB2 外设复位寄存器(RCC_APB2RSTR) | 57 |
| 7.3.5 APB1 外设复位寄存器(RCC_APB1RSTR) | 59 |



| 7.3.6 AHB 外设时钟使能寄存器(RCC_AHBENR)   | 61 |
|-----------------------------------|----|
| 7.3.7 APB2 外设时钟使能寄存器(RCC_APB2ENR) | 62 |
| 7.3.8 APB1 外设时钟使能寄存器(RCC_APB1ENR) | 64 |
| 7.3.9 备份域控制寄存器(RCC_BDCR)          | 66 |
| 7.3.10 时钟控制/状态寄存器(RCC_CSR)        | 67 |
| 7.3.11 HSE 控制寄存器(RCC_HSECTL)      | 69 |
| 7.3.12 PLL 控制寄存器(RCC_LPCLK_CTL)   | 70 |
| 8 中断和事件(EXTI 和 NVIC)              | 71 |
| 8.1 嵌套向量中断控制器(NVIC)               | 71 |
| 8.1.1 系统嘀嗒(SysTick)校准值寄存器         | 71 |
| 8.1.2 中断和异常向量                     | 71 |
| 8.2 外部中断/事件控制器(EXTI)              | 74 |
| 8.2.1 主要特性                        | 74 |
| 8.2.2 框图                          | 74 |
| 8.2.3 EXTI 与周边模块关系                | 75 |
| 8.2.4 唤醒事件管理                      | 75 |
| 8.2.5 功能说明                        | 76 |
| 8.2.6 外部中断/事件线映射                  | 76 |
| 8.3 EXTI 寄存器                      | 77 |
| 8.3.1 中断屏蔽寄存器(EXTI_IMR)           | 77 |
| 8.3.2 事件屏蔽寄存器(EXTI_EMR)           | 77 |
| 8.3.3 上升沿触发选择寄存器(EXTI_RTSR)       | 78 |
| 8.3.4 下降沿触发选择寄存器(EXTI_FTSR)       | 78 |
| 8.3.5 软件中断事件寄存器(EXTI_SWIER)       | 79 |
| 8.3.6 挂起寄存器(EXTI_PR)              | 79 |
| 9 通用和复用功能 I/O(GPIO 和 AFIO)        | 80 |
| 9.1 GPIO 功能描述                     | 80 |
| 9.1.1 通用 I/O(GPIO)                | 82 |
| 9.1.2 单独的位设置或位清除                  | 82 |
| 9.1.3 外部中断/唤醒线                    | 82 |
| 9.1.4 复用功能(AF)                    | 82 |



| 9.1.5 软件重新映射 I/O 复用功能                           | 82  |
|-------------------------------------------------|-----|
| 9.1.6 GPIO 锁定机制                                 | 82  |
| 9.1.7 输入配置                                      | 83  |
| 9.1.8 输出配置                                      | 83  |
| 9.1.9 复用功能配置                                    | 84  |
| 9.1.10 模拟输入配置                                   | 85  |
| 9.1.11 外设的 GPIO 配置                              | 85  |
| 9.2 GPIO 寄存器                                    | 87  |
| 9.2.1 端口 x 配置低寄存器(GPIOx_CRL)(x=AD)              | 87  |
| 9.2.2 端口 x 配置高寄存器(GPIOx_CRH)(x=AD)              | 88  |
| 9.2.3 端口 x 输入数据寄存器(GPIOx_IDR)(x= AD)            | 89  |
| 9.2.4 端口 x 输出数据寄存器(GPIOx_ODR)(x= AD)            | 89  |
| 9.2.5 端口 x 位设置/清除寄存器(GPIOx_BSRR)(x=AD)          | 89  |
| 9.2.6 端口 x 位清除寄存器(GPIOx_BRR)(x=AD)              | 90  |
| 9.2.7 端口 x 配置锁定寄存器(GPIOx_LCKR)(x=AD)            | 90  |
| 9.3 复用功能 I/O 和调试配置(AFIO)                        | 91  |
| 9.3.1 把 OSC32_IN/OSC32_OUT 作为 GPIO 端口 PC14/PC15 | 91  |
| 9.3.2 把 OSC_IN/OSC_OUT 引脚作为 GPIO 端口 PD0/PD1     | 91  |
| 9.3.3 CAN 复用功能重映射                               | 92  |
| 9.3.4 JTAG/SWD 复用功能重映射                          | 92  |
| 9.3.5 定时器复用功能重映射                                | 92  |
| 9.3.6 USART 复用功能重映射                             | 93  |
| 9.3.7 I2C1 复用功能重映射                              | 94  |
| 9.3.8 SPI1 复用功能重映射                              | 94  |
| 9.4 AFIO 寄存器                                    | 95  |
| 9.4.1 事件控制寄存器(AFIO_EVCR)                        | 95  |
| 9.4.2 复用重映射和调试 I/O 配置寄存器(AFIO_MAPR)             | 96  |
| 9.4.3 外部中断配置寄存器 1(AFIO_EXTICR1)                 | 98  |
| 9.4.4 外部中断配置寄存器 2(AFIO_EXTICR2)                 | 99  |
| 9.4.5 外部中断配置寄存器 3(AFIO_EXTICR3)                 | 99  |
| 9.4.6 外部中断配置寄存器 4(AFIO_EXTICR4)                 | 100 |



| 10 DMA 控制器                          | 101 |
|-------------------------------------|-----|
| 10.1 DMA 主要特性                       | 101 |
| 10.2 功能描述                           | 102 |
| 10.2.1 DMA 处理                       | 102 |
| 10.2.2 仲裁器                          | 102 |
| 10.2.3 DMA 通道                       | 102 |
| 10.2.4 可编程的数据传输宽度、对齐方式和数据大小端        | 103 |
| 10.2.5 错误管理                         | 105 |
| 10.2.6 中断                           | 105 |
| 10.2.7 DMA 请求映射                     | 105 |
| 10.3 DMA 寄存器                        | 107 |
| 10.3.1 DMA 中断状态寄存器(DMA_ISR)         | 107 |
| 10.3.2 DMA 中断标志清除寄存器(DMA_IFCR)      | 108 |
| 10.3.3 DMA 通道 x 配置寄存器(DMA_CCRx)     | 108 |
| 10.3.4 DMA 通道 x 传输数量寄存器(DMA_CNDTRx) | 110 |
| 10.3.5 DMA 通道 x 外设地址寄存器(DMA_CPARx)  | 111 |
| 10.3.6 DMA 通道 x 存储器地址寄存器(DMA_CMARx) | 111 |
| 11 模拟/数字转换(ADC)                     | 112 |
| 11.1 ADC 主要特征                       | 112 |
| 11.2 ADC 功能描述                       | 112 |
| 11.2.1 ADC 开关控制                     | 114 |
| 11.2.2 ADC 时钟                       | 114 |
| 11.2.3 通道选择                         | 114 |
| 11.2.4 单次转换模式                       | 114 |
| 11.2.5 连续转换模式                       | 115 |
| 11.2.6 时序图                          | 115 |
| 11.2.7 模拟看门狗                        | 115 |
| 11.2.8 扫描模式                         | 116 |
| 11.2.9 注入通道管理                       | 116 |
| 11.2.10 间断模式                        | 117 |
| 11.3 校准                             | 118 |



| 11.4 数据对齐                                   | 119 |
|---------------------------------------------|-----|
| 11.5 可编程的通道采样时间                             | 119 |
| 11.6 外部触发转换                                 | 119 |
| 11.7 DMA 请求                                 | 120 |
| 11.8 双 ADC 模式                               | 120 |
| 11.8.1 同步注入模式                               | 122 |
| 11.8.2 同步规则模式                               | 122 |
| 11.8.3 快速交替模式                               | 122 |
| 11.8.4 慢速交替模式                               | 123 |
| 11.8.5 交替触发模式                               | 124 |
| 11.8.6 独立模式                                 | 124 |
| 11.8.7 混合的规则/注入同步模式                         | 124 |
| 11.8.8 混合的同步规则+交替触发模式                       | 125 |
| 11.8.9 混合同步注入+交替模式                          | 125 |
| 11.9 温度传感器                                  | 126 |
| 11.10 ADC 中断                                | 127 |
| 11.11 ADC 寄存器                               | 127 |
| 11.11.1 ADC 状态寄存器(ADC_SR)                   | 127 |
| 11.11.2 ADC 控制寄存器 1(ADC_CR1)                | 128 |
| 11.11.3 ADC 控制寄存器 2(ADC_CR2)                | 131 |
| 11.11.4 ADC 采样时间寄存器 1(ADC_SMPR1)            | 133 |
| 11.11.5 ADC 采样时间寄存器 2(ADC_SMPR2)            | 134 |
| 11.11.6 ADC 注入通道 x 数据偏移寄存器(ADC_JOFRx)(x=14) | 134 |
| 11.11.7 ADC 看门狗高阈值寄存器(ADC_HTR)              | 135 |
| 11.11.8 ADC 看门狗低阈值寄存器(ADC_LTR)              | 135 |
| 11.11.9 ADC 规则序列寄存器(ADC_SQR1)               | 135 |
| 11.11.10 ADC 规则序列寄存器 2(ADC_SQR2)            | 136 |
| 11.11.11 ADC 规则序列寄存器 3(ADC_SQR3)            | 137 |
| 11.11.12 ADC 注入序列寄存器(ADC_JSQR)              | 137 |
| 11.11.13 ADC 注入数据寄存器 x(ADC_JDRx)(x=14)      | 138 |
| 11.11.14 ADC 规则数据寄存器(ADC_DR)                | 138 |



| 2 高级控制定时器(TIM1)                    | 140 |
|------------------------------------|-----|
| 12.1 TIM1 主要特性                     | 140 |
| 12.2 TIM1 功能描述                     | 141 |
| 12.2.1 时基单元                        | 141 |
| 12.2.2 计数器模式                       | 143 |
| 12.2.3 重复计数器                       | 151 |
| 12.2.4 时钟选择                        | 151 |
| 12.2.5 捕获/比较通道                     | 154 |
| 12.2.6 输入捕获模式                      | 156 |
| 12.2.7 PWM 输入模式                    | 156 |
| 12.2.8 强置输出模式                      | 157 |
| 12.2.9 输出比较模式                      | 157 |
| 12.2.10 PWM 模式                     | 158 |
| 12.2.11 互补输出和死区插入                  | 160 |
| 12.2.12 使用刹车功能                     | 162 |
| 12.2.13 在外部事件时清除 OCxREF 信号         | 163 |
| 12.2.14 产生六步 PWM 输出                | 164 |
| 12.2.15 单脉冲模式                      | 165 |
| 12.2.16 编码器接口模式                    | 166 |
| 12.2.17 定时器输入异或功能                  | 167 |
| 12.2.18 与霍尔传感器的接口                  | 168 |
| 12.2.19 TIMx 定时器和外部触发的同步           | 169 |
| 12.2.20 定时器同步                      | 171 |
| 12.2.21 调试模式                       | 172 |
| 12.3 TIM1 寄存器                      | 172 |
| 12.3.1 TIM1 控制寄存器 1(TIMx_CR1)      | 172 |
| 12.3.2 TIM1 控制寄存器 2(TIMx_CR2)      | 173 |
| 12.3.3 TIM1 从模式控制寄存器(TIMx_SMCR)    | 175 |
| 12.3.4 TIM1 DMA/中断使能寄存器(TIMx_DIER) | 178 |
| 12.3.5 TIM1 状态寄存器(TIMx_SR)         | 179 |
| 12.3.6 TIM1 事件产生寄存器(TIMx_EGR)      | 181 |



| 12.3.7 TIM1 捕获/比较模式寄存器 1(TIMx_CCMR1)    | 182 |
|-----------------------------------------|-----|
| 12.3.8 TIM1 捕获/比较模式寄存器 2(TIMx_CCMR2)    | 185 |
| 12.3.9 TIM1 捕获/比较使能寄存器(TIMx_CCER)       | 187 |
| 12.3.10 TIM1 计数器寄存器(TIMx_CNT)           | 190 |
| 12.3.11 TIM1 预分频器寄存器(TIMx_PSC)          | 190 |
| 12.3.12 TIM1 自动重装载寄存器(TIMx_ARR)         | 191 |
| 12.3.13 TIM1 重复计数寄存器(TIMx_RCR)          | 191 |
| 12.3.14 TIM1 捕获/比较寄存器 1(TIMx_CCR1)      | 191 |
| 12.3.15 TIM1 捕获/比较寄存器 2(TIMx_CCR2)      | 192 |
| 12.3.16 TIM1 捕获/比较寄存器 3(TIMx_CCR3)      | 192 |
| 12.3.17 TIM1 捕获/比较寄存器 4(TIMx_CCR4)      | 193 |
| 12.3.18 TIM1 刹车和死区寄存器(TIMx_BDTR)        | 193 |
| 12.3.19 TIM1 DMA 控制寄存器(TIMx_DCR)        | 195 |
| 12.3.20 TIM1 连续模式的 DMA 地址寄存器(TIMx_DMAR) | 196 |
| 13 通用定时器(TIMx)                          | 197 |
| 13.1 TIMx 主要功能                          | 197 |
| 13.2 TIMx 功能                            | 198 |
| 13.2.1 时基单元                             | 198 |
| 13.2.2 计数器模式                            | 199 |
| 13.2.3 时钟选择                             | 207 |
| 13.2.4 捕获/比较通道                          | 209 |
| 13.2.5 输入捕获模式                           | 210 |
| 13.2.6 PWM 输入模式                         | 211 |
| 13.2.7 强置输出模式                           | 212 |
| 13.2.8 输出比较模式                           | 212 |
| 13.2.9 PWM 模式                           | 213 |
| 13.2.10 单脉冲模式                           | 215 |
| 13.2.11 在外部事件时清除 OCxREF 信号              | 217 |
| 13.2.12 编码器接口模式                         | 217 |
| 13.2.13 定时器输入异或功能                       | 219 |
| 13.2.14 定时器和外部触发的同步                     | 219 |



| 13.2.15 定时器同步                      | 222 |
|------------------------------------|-----|
| 13.2.16 调试模式                       | 226 |
| 13.3 TIMx 寄存器(x=2, 3, 4)           | 226 |
| 13.3.1 控制寄存器 1(TIMx_CR1)           | 226 |
| 13.3.2 控制寄存器 2(TIMx_CR2)           | 228 |
| 13.3.3 从模式控制寄存器(TIMx_SMCR)         | 229 |
| 13.3.4 DMA/中断使能寄存器(TIMx_DIER)      | 231 |
| 13.3.5 状态寄存器(TIMx_SR)              | 233 |
| 13.3.6 事件产生寄存器(TIMx_EGR)           | 234 |
| 13.3.7 捕获/比较模式寄存器 1(TIMx_CCMR1)    | 235 |
| 13.3.8 捕获/比较模式寄存器 2(TIMx_CCMR2)    | 239 |
| 13.3.9 捕获/比较使能寄存器(TIMx_CCER)       | 240 |
| 13.3.10 计数器寄存器(TIMx_CNT)           | 242 |
| 13.3.11 预分频器寄存器(TIMx_PSC)          | 242 |
| 13.3.12 自动重装载寄存器(TIMx_ARR)         | 243 |
| 13.3.13 捕获/比较寄存器 1(TIMx_CCR1)      | 243 |
| 13.3.14 捕获/比较寄存器 2(TIMx_CCR2)      | 243 |
| 13.3.15 捕获/比较寄存器 3(TIMx_CCR3)      | 244 |
| 13.3.16 捕获/比较寄存器 4(TIMx_CCR4)      | 244 |
| 13.3.17 DMA 控制寄存器(TIMx_DCR)        | 245 |
| 13.3.18 连续模式的 DMA 地址寄存器(TIMx_DMAR) | 245 |
| 14 实时时钟(RTC)                       | 247 |
| 14.1 主要特性                          | 247 |
| 14.2 功能描述                          | 247 |
| 14.2.1 概述                          | 247 |
| 14.2.2 复位过程                        | 248 |
| 14.2.3 读 RTC 寄存器                   | 248 |
| 14.2.4 配置 RTC 寄存器                  | 248 |
| 14.2.5 RTC 标志的设置                   | 249 |
| 14.3 RTC 寄存器                       | 249 |
| 14.3.1 RTC 控制寄存器高位(RTC_CRH)        | 250 |



|      | 14.3.2 RTC 控制寄存器低位(RTC_CRL)             | 250 |
|------|-----------------------------------------|-----|
|      | 14.3.3 RTC 预分频装载寄存器(RTC_PRLH/RTC_PRLL)  | 252 |
|      | 14.3.4 RTC 预分频器余数寄存器(RTC_DIVH/RTC_DIVL) | 252 |
|      | 14.3.5 RTC 计数器寄存器(RTC_CNTH/RTC_CNTL)    | 253 |
|      | 14.3.6 RTC 闹钟寄存器(RTC_ALRH/RTC_ALRL)     | 254 |
| 15 独 | 虫立看门狗(IWDG)                             | 255 |
|      | 15.1 IWDG 主要性能                          | 255 |
|      | 15.2 IWDG 功能描述                          | 255 |
|      | 15.2.1 窗口选项                             | 256 |
|      | 15.2.2 硬件看门狗                            | 257 |
|      | 15.2.3 寄存器访问保护                          | 257 |
|      | 15.2.4 调试模式                             | 257 |
|      | 15.3 IWDG 寄存器                           | 257 |
|      | 15.3.1 键寄存器(IWDG_KR)                    | 257 |
|      | 15.3.2 预分频寄存器(IWDG_PR)                  | 258 |
|      | 15.3.3 重装载寄存器(IWDG_RLR)                 | 258 |
|      | 15.3.4 状态寄存器(IWDG_SR)                   | 259 |
|      | 15.3.5 窗口寄存器(IWDG_WINR)                 | 259 |
| 16 🏻 | 窗口看门狗(WWDG)                             | 261 |
|      | 16.1 WWDG 主要特性                          | 261 |
|      | 16.2 WWDG 功能描述                          | 261 |
|      | 16.3 如何编写看门狗超时程序                        | 262 |
|      | 16.4 调试模式                               | 263 |
|      | 16.5 WWDG 寄存器                           | 263 |
|      | 16.5.1 控制寄存器(WWDG_CR)                   | 263 |
|      | 16.5.2 配置寄存器(WWDG_CFR)                  | 263 |
|      | 16.5.3 状态寄存器(WWDG_SR)                   | 264 |
| 17 U | JSB 全速设备接口(USB)                         | 265 |
|      | 17.1 USB 主要特征                           | 265 |
|      | 17.2 USB 功能描述                           | 265 |
|      | 17.2.1 USB 功能模块描述                       | 266 |



| 17.3 编程中需要考虑的问题      | 267 |
|----------------------|-----|
| 17.3.1 通用 USB 设备编程   | 267 |
| 17.3.2 系统复位和上电复位     | 267 |
| 17.3.3 双缓冲端点         | 271 |
| 17.3.4 同步传输          | 273 |
| 17.3.5 挂起/唤醒事件       | 273 |
| 17.4 USB 寄存器         | 274 |
| 17.4.1 通用寄存器         | 275 |
| 17.4.2 端点寄存器         | 280 |
| 17.4.3 缓冲区描述表        | 283 |
| 18 控制器局域网(bxCAN)     | 287 |
| 18.1 bxCAN 主要特点      | 287 |
| 18.2 bxCAN 总体描述      | 287 |
| 18.2.1 CAN 2.0B 主动内核 | 288 |
| 18.2.2 控制、状态和配置寄存器   | 288 |
| 18.2.3 发送邮箱          | 288 |
| 18.2.4 接收过滤器         | 288 |
| 18.3 bxCAN 工作模式      | 289 |
| 18.3.1 初始化模式         | 289 |
| 18.3.2 正常模式          | 290 |
| 18.3.3 睡眠模式(低功耗)     | 290 |
| 18.4 测试模式            | 291 |
| 18.4.1 静默模式          | 291 |
| 18.4.2 环回模式          | 291 |
| 18.4.3 环回静默模式        | 292 |
| 18.5 处于调试模式时         | 292 |
| 18.6 bxCAN 功能描述      | 292 |
| 18.6.1 发送处理          | 292 |
| 18.6.2 时间触发通信模式      | 293 |
| 18.6.3 接收管理          | 294 |
| 18.6.4 标识符过滤         | 295 |



| 18.6.5 报文存储                             | 298 |
|-----------------------------------------|-----|
| 18.6.6 出错管理                             | 299 |
| 18.6.7 位时间特性                            | 300 |
| 18.7 bxCAN 中断                           | 301 |
| 18.8 CAN 寄存器                            | 303 |
| 18.8.1 寄存器访问保护                          | 303 |
| 18.8.2 CAN 控制和状态寄存器                     | 303 |
| 18.8.3 CAN 邮箱寄存器                        | 314 |
| 18.8.4 CAN 过滤器寄存器                       | 319 |
| 19 串行外设接口(SPI)                          | 323 |
| 19.1 SPI 简介                             | 323 |
| 19.2 SPI 主要特征                           | 323 |
| 19.2.1 SPI 特征                           | 323 |
| 19.3 SPI 功能描述                           | 323 |
| 19.3.1 概述                               | 323 |
| 19.3.2 配置 SPI 为从模式                      | 326 |
| 19.3.3 配置 SPI 为主模式                      | 327 |
| 19.3.4 配置 SPI 为单工通信                     | 328 |
| 19.3.5 数据发送与接收过程                        | 328 |
| 19.3.6 CRC 计算                           | 333 |
| 19.3.7 状态标志                             | 335 |
| 19.3.8 关闭 SPI                           | 335 |
| 19.3.9 利用 DMA 的 SPI 通信                  | 336 |
| 19.3.10 错误标志                            | 337 |
| 19.3.11 SPI 中断                          | 338 |
| 19.4 SPI 寄存器                            | 338 |
| 19.4.1 SPI 控制寄存器 1(SPIx_CR1)(x=12)      | 339 |
| 19.4.2 SPI 控制寄存器 2(SPIx_CR2)(x=12)      | 341 |
| 19.4.3 SPI 状态寄存器(SPIx_SR)(x=12)         | 342 |
| 19.4.4 SPI 数据寄存器(SPIx_DR)(x=12)         | 343 |
| 19.4.5 SPI CRC 多项式寄存器(SPIx_CRCPR)(x=12) | 343 |



|             | 19.4.6 SPI Rx CRC 寄存器(SPIx_RXCRCR)(x=12) | 343 |
|-------------|------------------------------------------|-----|
|             | 19.4.7 SPI Tx CRC 寄存器(SPIx_TXCRCR)(x=12) | 344 |
|             | 19.4.8 SPI 控制寄存器 SPIx_CR3(x=12)          | 344 |
| 20 12       | 2C接口                                     | 346 |
|             | 20.1 I2C 主要特点                            | 346 |
|             | 20.2 I2C 功能描述                            | 347 |
|             | 20.2.1 模式选择                              | 347 |
|             | 20.2.2 I2C 从模式                           | 348 |
|             | 20.2.3 I2C 主模式                           | 350 |
|             | 20.2.4 错误条件                              | 353 |
|             | 20.2.5 SDA/SCL 线控制                       | 354 |
|             | 20.2.6 SMBus                             | 355 |
|             | 20.2.7 DMA 请求                            | 357 |
|             | 20.2.8 包错误校验(PEC)                        | 358 |
|             | 20.3 I2C 中断请求                            | 358 |
|             | 20.4 I2C 调试模式                            | 359 |
|             | 20.5 I2C 寄存器                             | 360 |
|             | 20.5.1 控制寄存器 1(I2Cx_CR1)(x=12)           | 360 |
|             | 20.5.2 控制寄存器 2(I2Cx_CR2)(x=12)           | 362 |
|             | 20.5.3 自身地址寄存器 1(I2Cx_OAR1)(x=12)        | 363 |
|             | 20.5.4 自身地址寄存器 2(I2Cx_OAR2)(x=12)        | 364 |
|             | 20.5.5 数据寄存器(I2Cx_DR)(x=12)              | 364 |
|             | 20.5.6 状态寄存器 1(I2Cx_SR1)(x=12)           | 365 |
|             | 20.5.7 状态寄存器 2(I2Cx_SR2)(x=12)           | 368 |
|             | 20.5.8 时钟控制寄存器(I2Cx_CCR)(x=12)           | 369 |
|             | 20.5.9 TRISE 寄存器(I2Cx_TRISE)(x=12)       | 370 |
| <b>21</b> 湞 | 通用同步异步收发器(USART)                         | 372 |
|             | 21.1 USART 介绍                            | 372 |
|             | 21.2 USART 主要特性                          | 372 |
|             | 21.3 USART 功能概述                          | 373 |
|             | 21.3.1 USART 特性描述                        | 374 |



|      | 21.3.2 发送器                            | 375 |
|------|---------------------------------------|-----|
|      | 21.3.3 接收器                            | 377 |
|      | 21.3.4 分数波特率的产生                       | 381 |
|      | 21.3.5 USART 接收器容忍时钟的变化               | 382 |
|      | 21.3.6 多处理器通信                         | 383 |
|      | 21.3.7 校验控制                           | 384 |
|      | 21.3.8 LIN(局域互联网)模式                   | 385 |
|      | 21.3.9 USART 同步模式                     | 386 |
|      | 21.3.10 单线半双工通信                       | 389 |
|      | 21.3.11 智能卡                           | 389 |
|      | 21.3.12 IrDA SIR ENDEC 功能模块           | 391 |
|      | 21.3.13 利用 DMA 连续通信                   | 392 |
|      | 21.3.14 硬件流控制                         | 394 |
| 2    | 21.4 USART 中断请求                       | 395 |
| 2    | 21.5 USART 模式配置                       | 396 |
| 2    | 21.6 USART 寄存器                        | 397 |
|      | 21.6.1 状态寄存器(USARTx_SR)(x=15)         | 397 |
|      | 21.6.2 数据寄存器(USARTx_DR)(x=15)         | 399 |
|      | 21.6.3 波特比率寄存器(USARTx_BRR)(x=15)      | 399 |
|      | 21.6.4 控制寄存器 1(USARTx_CR1)(x=15)      | 400 |
|      | 21.6.5 控制寄存器 2(USARTx_CR2)(x=15)      | 402 |
|      | 21.6.6 控制寄存器 3(USARTx_CR3)(x=15)      | 404 |
|      | 21.6.7 保护时间和预分频寄存器(USARTx_GTPR)(x=15) | 405 |
| 22 除 | 法开方运算单元(DVSQ)                         | 407 |
| 2    | 22.1 DVSQ 主要特性                        | 407 |
| 2    | 22.2 除法操作流程                           | 407 |
| 2    | 22.3 除法运行时间                           | 408 |
| 2    | 22.4 开方操作描述                           | 409 |
| 2    | 22.5 开方运行时间                           | 409 |
| 2    | 22.6 中断                               | 411 |
| 2    | 22.7 注意事项                             | 411 |



| 22.8 DVSQ 寄存器                             | 412 |
|-------------------------------------------|-----|
| 22.8.1 被除数寄存器(DVSQ_DIVIDEND)              | 412 |
| 22.8.2 除数寄存器(DVSQ_DIVISOR)                | 412 |
| 22.8.3 控制和状态寄存器(DVSQ_CSR)                 | 413 |
| 22.8.4 被开方数寄存器(DVSQ_RADICAND)             | 415 |
| 22.8.5 结果寄存器(DVSQ_RES)                    | 415 |
| 22.8.6 余数寄存器(DVSQ_REMAINDER)              | 416 |
| 23 器件电子签名(UID)                            | 417 |
| 23.1 存储器容量寄存器                             | 417 |
| 23.1.1 闪存容量寄存器                            | 417 |
| 23.1.2 UID 寄存器(96 位)                      | 417 |
| 24 调试支持(DBG)                              | 419 |
| 24.1 概况                                   | 419 |
| 24.2 ARM®参考文献                             | 420 |
| 24.3 SWJ 调试端口                             | 420 |
| 24.3.1 JTAG-DP 和 SW-DP 切换的机制              | 420 |
| 24.3.2 SWJ 调试端口脚                          | 421 |
| 24.3.3 灵活的 SWJ-DP 脚分配                     | 421 |
| 24.3.4 JTAG 脚上的内部上拉和下拉                    | 422 |
| 24.3.5 利用串行接口并释放不用的调试脚作为普通 I/O 口          | 423 |
| 24.4 JTAG TAP 连接                          | 423 |
| 24.5 ID 代码和锁定机制                           | 424 |
| 24.5.1 微控制器设备 ID 编码                       | 424 |
| 24.5.2 边界扫描 TAP                           | 424 |
| 24.5.3 Cortex-M3 TAP                      | 424 |
| 24.5.4 Cortex-M3 JEDEC-106 ID 代码          | 425 |
| 24.6 JTAG 调试端口                            | 425 |
| 24.7 SW 调试端口                              | 426 |
| 24.7.1 SW 协议介绍                            | 426 |
| 24.7.2 SW 协议序列                            | 426 |
| 24.7.3 SW-DP 状态机(Reset,idlestates,IDcode) | 427 |



|   | 24.7.4 DP 和 AP 读/写访问                         | 428 |
|---|----------------------------------------------|-----|
|   | 24.7.5 SW-DP 寄存器                             | 428 |
|   | 24.7.6 SW-AP 寄存器                             | 428 |
|   | 24.8 对于 JTAG-DP 或 SWDP 都有效的 AHB-AP(AHB 访问端口) | 429 |
|   | 24.9 内核调试                                    | 429 |
|   | 24.10 调试器主机在系统复位下的连接能力                       | 430 |
|   | 24.11 FPB                                    | 430 |
|   | 24.12 数据观察点触发(DWT)                           | 430 |
|   | 24.13 指令跟踪微单元(ITM)                           | 431 |
|   | 24.13.1 概述                                   | 431 |
|   | 24.13.2 时间戳包,同步和溢出包                          | 431 |
|   | 24.14 MCU 调试模块(MCUDBG)                       | 432 |
|   | 24.14.1 低功耗模式的调试支持                           | 432 |
|   | 24.14.2 支持定时器、看门狗、bxCAN 和 I2C 的调试            | 433 |
|   | 24.14.3 MCU 调试配置寄存器                          | 433 |
|   | 24.14.4 调试 MCU 配置寄存器(DBGMCU_CR)              | 433 |
|   | 24.15 跟踪端口接口单元(TPIU)                         | 435 |
|   | 24.15.1 导言                                   | 435 |
|   | 24.15.2 跟踪引脚分配                               | 436 |
|   | 24.15.3 TPUI 格式器                             | 437 |
|   | 24.15.4 TPUI 帧异步包                            | 437 |
|   | 24.15.5 同步帧包的发送                              | 437 |
|   | 24.15.6 同步模式                                 | 437 |
|   | 24.15.7 异步模式                                 | 438 |
|   | 24.15.8 TRACECLKIN 在芯片内部的连接                  | 438 |
|   | 24.15.9 TPIU 寄存器                             | 438 |
|   | 24.15.10 配置的例子                               | 439 |
| 4 | 宿略语与术语                                       | 440 |
|   | 25.1 寄存器描述中的缩略语                              | 440 |
|   | 25.2 缩略语                                     | 440 |
|   | 25.3 术语                                      | 440 |

25





## 1 简介

本文档为 HK32F103x8xB 芯片的用户手册。HK32F103x8xB 系列芯片是由深圳市航顺芯片技术研发有限公司研发的高性能 MCU 芯片,包括以下型号:

- HK32F103RBT6
- HK32F103R8T6
- HK32F103CBT6
- HK32F103C8T6

在阅读本手册前,你可能需要参考以下文档:

表 1-1 参考文档

| 名称                | 说明                                                      |  |
|-------------------|---------------------------------------------------------|--|
| HK32F103x8xB 数据手册 | 航顺 HK32F103x8xB 数据手册,描述了该 MCU 的外设接口、电器特性、引脚封装等。         |  |
| Cortex®-M3 技术参考手册 | ARM 公司的 Cortex®-M3 产品的技术手册。<br>下载地址: <u>www.arm.com</u> |  |

说明: 本手册中缩略语的释义请参考章节: "25 缩略语与术语"。



## 2 存储器和总线构架

## 2.1 系统构架

主系统由以下部分构成:

- 驱动单元:
  - 。 Cortex®-M3 内核 DCode 总线(D-bus)和系统总线(S-bus)
  - 。 通用 DMA
- 被动单元:
  - 。 内部 Flash 存储器
  - 。 内部 SRAM
  - 。 AHB 到 APB 的桥(APB1 和 APB2),用于连接所有的 APB 外设

这些都是通过一个多级的 AHB 总线构架相互连接的,如下图所示。现以 HK32F103RBT6 为例,说明 HK32F103x8xB MCU 的系统框图。



图 2-1 HK32F103RBT6 系统框图

#### 2.1.1.1 ICode 总线(ICode-bus)

ICode 总线将 Cortex®-M3 内核的指令总线与 Flash 存储器的指令接口相连接。预取指令在此总线上



完成。这个总线的操作对象是内部 Flash 和 SRAM。

#### 2.1.1.2 DCode 总线(DCode-bus)

DCode 总线将 Cortex®-M3 内核的 DCode 总线(常量加载和调试访问)与 Flash 存储器的数据接口相连接。这个总线的操作对象是内部 Flash 和 SRAM。

### 2.1.1.3 系统总线(Sys-bus)

该总线将 Cortex®-M3 内核的系统总线(外设总线)连接到总线矩阵。总线矩阵管理着内核和 DMA 间的访问仲裁。

#### 2.1.1.4 DMA 总线

该总线将 DMA 的 AHB 主控接口连接到总线矩阵。总线矩阵用于管理 CPU DCode 总线和 DMA 到 SRAM、Flash 和外设的访问。

#### 2.1.1.5 总线矩阵

总线矩阵管理内核系统总线和 DMA 主控总线之间的访问仲裁,仲裁利用轮换算法。总线矩阵包含驱动单元(CPU 的 DCode 总线、系统总线、DMA 总线)和被动部件(内部 Flash 存储器、SRAM、AHB-APB 桥)。

AHB 外设通过总线矩阵与系统总线相连,以允许 DMA 访问。

#### 2.1.1.6 AHB/APB 桥(APB)

两个 AHB/APB 桥在 AHB 和 2 个 APB 总线间提供同步连接。APB1 工作频率限速最高 48 MHz, APB2 工作于全速(最高为 96MHz)。

若需了解连接到各个桥的外设地址映射,请参见表 2-1。

在每次器件复位以后,除了 SRAM 和 FLITF(Flash 存储器接口)以外的所有外设都被关闭。在使用某个外设之前,必须设置 RCC\_AHBENRx、RCC\_APB1ENRx 和 RCC\_APB2ENRx 寄存器以使能该外设的时钟。

## 2.2 存储器组织

程序存储器、数据存储器、寄存器和输入输出端口被组织在同一个 4 Gbyte 的线性地址空间内。数据字节以小端格式存放在存储器中。一个字里的最低地址字节被认为是该字的最低有效字节,而最高地址字节是最高有效字节。

外设寄存器的映射请参考相关章节。可访问的存储器空间被分成 8 个主要块,每个块为 512 Mbyte。

其他所有没有分配给片上存储器和外设的存储器空间都是保留的地址空间,请参考器件的数据手册中的存储器映射图。

### 2.2.1 存储器映射

请参考器件的数据手册中的存储器映射图。

下表列出了所用 HK32F103x8xB 中内置外设的起始地址。

表 2-1 寄存器组起始地址

| 起始地址- 结束地址              | 外设 | 总线  |
|-------------------------|----|-----|
| 0x4003 0400-0x5FFF FFFF | 保留 | АНВ |



| 起始地址- 结束地址              | 外设           | 总线   |
|-------------------------|--------------|------|
| 0x4003 0000-0x4003 03FF | DVSQ         |      |
| 0x4002 3400-0x4002 FFFF | 保留           |      |
| 0x4002 3000-0x4002 33FF | CRC          |      |
| 0x4002 2400-0x4002 2FFF | 保留           |      |
| 0x4002 2000-0x4002 23FF | Flash 存储器接口  |      |
| 0x4002 1400-0x4002 1FFF | 保留           |      |
| 0x4002 1000-0x4002 13FF | 复位和时钟控制(RCC) |      |
| 0x4002 0800-0x4002 0FFF | 保留           |      |
| 0x4002 0400-0x4002 07FF | 保留           |      |
| 0x4002 0000-0x4002 03FF | DMA1         |      |
| 0x4001 8400-0x4001 FFFF | 保留           |      |
| 0x4001 8000-0x4001 83FF | 保留           |      |
| 0x4001 4000-0x4001 7FFF | 保留           | APB2 |
| 0x4001 3C00-0x4001 3FFF | 保留           |      |
| 0x4001 3800-0x4001 3BFF | USART1       |      |
| 0x4001 3400-0x4001 37FF | 保留           |      |
| 0x4001 3000-0x4001 33FF | SPI1         |      |
| 0x4001 2C00-0x4001 2FFF | TIM1 定时器     |      |
| 0x4001 2800-0x4001 2BFF | ADC2         |      |
| 0x4001 2400-0x4001 27FF | ADC1         |      |
| 0x4001 1C00-0x4001 23FF | 保留           |      |
| 0x4001 1800-0x4001 1BFF | 保留           |      |
| 0x4001 1400-0x4001 17FF | GPIO 端口 D    |      |
| 0x4001 1000-0x4001 13FF | GPIO 端口 C    |      |
| 0X4001 0C00-0x4001 0FFF | GPIO 端口 B    |      |
| 0x4001 0800-0x4001 0BFF | GPIO 端口 A    |      |
| 0x4001 0400-0x4001 07FF | EXTI         |      |
| 0x4001 0000-0x4001 03FF | AFIO         |      |
| 0x4000 7800-0x4000 FFFF | 保留           | APB1 |
| 0x4000 7400-0x4000 77FF | 保留           |      |



| 起始地址- 结束地址              | 外设                      | 总线 |
|-------------------------|-------------------------|----|
| 0x4000 7000-0x4000 73FF | 电源控制(PWR)               |    |
| 0x4000 6C00-0x4000 6FFF | 备份寄存器(BKP)              |    |
| 0x4000 6800-0x4000 6BFF | 保留                      |    |
| 0x4000 6400-0x4000 67FF | CAN                     |    |
| 0x4000 6000-0x4000 63FF | USB/CAN 共享的 512 字节 SRAM |    |
| 0x4000 5C00-0x4000 5FFF | USB 全速设备                |    |
| 0x4000 5800-0x4000 5BFF | 12C2                    |    |
| 0x4000 5400-0x4000 57FF | 12C1                    |    |
| 0x4000 5000-0x4000 53FF | 保留                      |    |
| 0x4000 4C00-0x4000 4FFF | 保留                      |    |
| 0x4000 4800-0x4000 4BFF | USART3                  |    |
| 0x4000 4400-0x4000 47FF | USART2                  |    |
| 0x4000 4000-0x4000 43FF | 保留                      |    |
| 0x4000 3C00-0x4000 3FFF | 保留                      |    |
| 0x4000 3800-0x4000 3BFF | SPI2                    |    |
| 0x4000 3400-0x4000 37FF | 保留                      |    |
| 0x4000 3000-0x4000 33FF | 独立看门狗(IWDG)             |    |
| 0x4000 2C00-0x4000 2FFF | 窗口看门狗(WWDG)             |    |
| 0x4000 2800-0x4000 2BFF | RTC                     |    |
| 0x4000 1800-0x4000 27FF | 保留                      |    |
| 0x4000 1400-0x4000 17FF | 保留                      |    |
| 0x4000 1000-0x4000 13FF | 保留                      |    |
| 0x4000 0C00-0x4000 0FFF | 保留                      |    |
| 0x4000 0800-0x4000 0BFF | TIM4 定时器                |    |
| 0x4000 0400-0x4000 07FF | TIM3 定时器                |    |
| 0x4000 0000-0x4000 03FF | TIM2 定时器                |    |

## 2.2.2 嵌入式 SRAM

HK32F103x8xB 内置 20 Kbyte 的静态 SRAM。它可以以字节、半字(16 位)或全字(32 位)访问。 SRAM 的起始地址是 0x2000 0000。



### 2.2.3 位段

Cortex®-M3 存储器映射包括两个位段(Bit-band)区。这两个位段区将存储器别名区中的每个字映射到位段存储器区的一个位,在别名存储区写入一个字具有对位段区的目标位执行读-改-写操作的相同效果。

在 HK32F103x8xB 里,外设寄存器和 SRAM 都被映射到一个位段区里,这允许执行单一的位段的写和读操作。

下面的映射公式给出了别名区中的每个字是如何对应位段区的相应位的:

bit\_word\_addr=bit\_band\_base+ (byte\_offset\*32) + (bit\_number\*4)

#### 其中:

- bit\_word\_addr 是存储器别名区中字的地址,它映射到某个目标位。
- bit band base 是别名区的起始地址。
- byte\_offset 是包含目标位的字节在位段里的序号。
- bit number 是目标位所在位置(0~31)。

#### 例子

下面以如何将 SRAM 地址为 0x2000 0300 的字节中的位 2 映射到别名区为例进行说明:

$$0x22006008=0x22000000+(0x300*0x20)+(0x2*0x4)$$

对 0x2200 6008 地址的写操作与对 SRAM 中地址 0x2000 0300 字节的位 2 执行读-改-写操作有着相同的效果。

读 0x2200 6008 地址返回 SRAM 中地址 0x2000 0300 字节的位 2 的值 (0x01 或 0x00)。请参考《Cortex®-M3 技术参考手册》以了解更多有关位段的信息。

## 2.3 启动配置

在 HK32F103x8xB 里,可以通过 BOOT[1:0]引脚选择三种不同的启动模式。

启动模式选择引脚 启动模式 说明 BOOT1 воото Χ 0 主 Flash 存储器 主 Flash 存储器被选为启动区域 0 1 系统存储器 系统存储器被选为启动区域 1 1 内置 SRAM 内置 SRAM 被选为启动区域

表 2-2 启动模式

在系统复位后,BOOT 引脚的值将被锁存。用户可以通过设置 BOOT1 和 BOOT0 引脚的状态,以选择复位后的启动模式。

在从待机模式退出时,BOOT 引脚的值将被重新锁存。因此,在待机模式下 BOOT 引脚应保持为需要的启动配置。在启动延迟之后,CPU 从地址 0x0000 0000 获取堆栈顶的地址,并从启动存储器的 0x0000 0004 指示的地址开始执行代码。

因为存储器映射是固定的,代码区始终从地址 0x0000 0000 开始(通过 ICode 和 DCode 总线访问),而数据区(SRAM)始终从地址 0x2000 0000 开始(通过系统总线访问)。Cortex®-M3 的 CPU 始终从 ICode 总线获取复位向量,即启动仅适合于从代码区开始(典型地从 Flash 启动)。HK32F103x8xB 实现了一个特殊的机制,系统可以不仅从 Flash 存储器或系统存储器启动,还可以从内置 SRAM 启动。



根据选定的启动模式, 主 Flash 存储器、系统存储器或 SRAM 可以按照以下方式访问:

- 从主 Flash 存储器启动: 主 Flash 存储器被映射到启动空间(0x0000 0000),但仍然能够在它原有的地址(0x0800 0000)访问它。即 Flash 存储器的内容可以在两个地址区域访问,0x0000 0000 或 0x0800 0000。
- ▶ 从系统存储器启动:系统存储器被映射到启动空间(0x0000 0000),但仍然能够在它原有的地址(0x1FFF F000)访问它。
- 从内置 SRAM 启动: SRAM 被映射到启动空间(0x0000 0000),也能在 0x2000 0000 开始的地址 区访问 SRAM。

## 2.3.1 内嵌的自举程序

内嵌的自举程序存放在系统存储区,在生产线上写入,用于通过串行接口对 Flash 存储器进行重新编程:可以通过 USART1 接口启用自举程序。



## 3 嵌入式 Flash

## 3.1 Flash 主要特性

- 高达 128 Kbyte Flash 存储器
- 存储器结构
  - 。 主 Flash 模块: 128 Kbyte(32Kbit×32 位)
  - 。 选项字节有 512 字节

#### Flash 的接口特征:

- 带预取缓冲器的读接口
- 选项字节加载器
- Flash 编程/擦除操作
- 访问/写保护
- 低功耗模式

## 3.2 Flash 功能描述

## 3.2.1 Flash 结构

Flash 空间由 32 位宽的存储单元组成,既可以存代码又可以存数据。主 Flash 块有 128 页(每页 1 Kbyte)。模块如下表所示:

表 3-1 Flash 模块的组织

| 模块          | 名称            | 地址                      | 大小 (字节) |
|-------------|---------------|-------------------------|---------|
| 主存储块        | 页 0           | 0x0800 0000-0x0800 03FF | 1K      |
|             | 页 1           | 0x0800 0400-0x0800 07FF | 1K      |
|             | 页 2           | 0x0800 0800-0x0800 0BFF | 1K      |
|             | 页 3           | 0x0800 0C00-0x0800 0FFF | 1K      |
|             | 页 4           | 0x0800 1000-0x0800 13FF | 1K      |
|             |               |                         |         |
|             | 页 127         | 0x0801 FC00-0x0801 FFFF | 1K      |
| 信息块         | 系统存储器         | 0x1FFF F000-0x1FFF F7FF | 2K      |
|             | 选项字节          | 0x1FFF F800-0x1FFF F9FF | 512     |
| Flash 存储器接口 | FLASH_ACR     | 0x4002 2000-0x4002 2003 | 4       |
| 寄存器         | FALSH_KEYR    | 0x4002 2004-0x4002 2007 | 4       |
|             | FLASH_OPTKEYR | 0x4002 2008-0x4002 200B | 4       |
|             | FLASH_SR      | 0x4002 200C-0x4002 200F | 4       |
|             | FLASH_CR      | 0x4002 2010-0x4002 2013 | 4       |



| 模块 | 名称         | 地址                      | 大小 (字节) |
|----|------------|-------------------------|---------|
|    | FLASH_AR   | 0x4002 2014-0x4002 2017 | 4       |
|    | 保留         | 0x4002 2018-0x4002 201B | 4       |
|    | FLASH_OBR  | 0x4002 201C-0x4002 201F | 4       |
|    | FLASH_WRPR | 0x4002 2020-0x4002 2023 | 4       |
|    | FLASH_ECR  | 0x4002 2024-0x4002 2027 | 4       |

### 3.2.2 读操作

嵌入式 Flash 模块可以像普遍存储空间一样直接寻址访问。

取指令和取数据都是通过 AHB 总线读取访问。它主要的工作就是产生控制信号,然后从 Flash 里读取信息和预取 CPU 所需要的信息。预取模块仅用于在 I-Code 总线上实现指令预取。D-Code 总线具有更高的预取优先级。

#### 取指

Cortex®-M3 通过 I-Code 总线取指和通过 D-Code 总线取数(常量/数据)。预取模块旨在增加总线的效率。

#### 预取缓冲区

预取缓冲区的内容与 Flash 相同,能够完全替代一次同样大小的读取访问。预取缓冲区的工作使得更快速的 CPU 执行成为可能,因为 CPU 取一个字的同时下一个字的内容已经在预取缓冲区中。

#### 预取控制器

预取控制器会根据预取缓冲区的可用空间来控制访问 Flash 的时机。当预取缓冲区中存在至少一块可用空间时,预取控制器会发起一次读取请求。复位后,预取指缓冲区的默认状态是打开的。

#### 访问等待周期

为了保持读取 Flash 的控制信号,必须在 Flash 访问控制寄存器(LATENCY[4:0])中设置预取控制器时钟周期与 Flash 访问时间的比值。这个数值等于每次访问 Flash 后到下次访问之间所需插入的等待周期的个数。复位后,这个值默认为零,也就是没有插入等待周期的状态。

#### 3.2.2.1 D-Code 接口

D-Code 接口在 CPU 端包含一个简单的 AHB 接口和产生 Flash 访问控制的仲裁申请发生器。D-Code 具有高于预取指的优先级。这个接口运用在预取缓存的访问时钟调谐器。

#### 3.2.2.2 Flash 访问控制器

该模块主要作为一个简单的仲裁器,用于仲裁预取(I-Code)和 D-Code 之间的读取请求。D-Code 接口请求的优先级高于 I-Code。

## 3.2.3 Flash 写和擦除操作

Flash 擦写模块处理 Flash 的编程和擦除,它包含 8 个 32 位的寄存器。

在产品的整个工作电压范围内支持执行 Flash 编程和擦除操作。该操作由下列 12 个寄存器完成:

- Flash 关键字寄存器(FLASH KEYR)
- Flash 选项关键字寄存器(FLASH\_OPTKEYR)



- Flash 控制寄存器(FLASH CR)
- Flash 状态寄存器(FLASH\_SR)
- Flash 地址寄存器(FLASH AR)
- Flash 选项字节寄存器(FLASH OBR)
- Flash 写保护寄存器(FLASH WRPR)
- Flash 控制寄存器 2(FLASH ECR)

只要 CPU 不访问 Flash 空间,正在执行的 Flash 写操作不会影响 CPU 的运行。即,在执行写/擦除 Flash 的同时,不能对 Flash 取指和访问其数据。因为在对 Flash 进行写/擦除操作的同时,任何对 Flash 的访问都会令总线停顿,直到写/擦除操作完成后才会继续执行。

#### 3.2.3.1 键值

键值用于对 FLASH\_KEYR 寄存器进行解锁:

- RDPRT=0x00A5
- KEY1=0x4567 0123
- KEY2=0xCDEF 89AB

#### 3.2.3.2 对 Flash 空间的解锁

复位后,Flash 存储器默认处于受保护状态,以避免意外擦除。FLASH\_CR 寄存器的值通常不允许改写。只有对 FLASH\_KEYR 寄存器进行解锁操作后,才具有对 FLASH\_CR 寄存器的访问权限。解锁操作包括以下步骤:

- 1. 向 FLASH KEYR 寄存器写入关键字 KEY1=0x4567 0123。
- 2. 向 FLASH KEYR 寄存器写入关键字 KEY2=0xCDEF 89AB。

任何错误的解锁顺序将会锁死 FLASH\_CR 直至下次复位。当发生关键字错误时,会由总线错误引发一次硬件错误中断。

- 如果 KEY1 出错,就会立即触发中断。
- 如果 KEY1 正确且 KEY2 错误时,就会在 KEY2 错的时刻触发中断。

#### 3.2.3.3 主 Flash 编程

主 Flash 一次可以编程 16 位或 32 位。编程长度由 FLASH\_CR 和 FLASH\_ECR 决定。

- 当 FLASH CR 中的 PG 位为 1 时,直接对相应的地址写一个半字(16 位),是一次编程操作。
- 当 FLASH ECR 中的 WPG 位为 1 时,直接对相应的地址写一个字(32 位),是一次编程操作。

注意:如果 FLASH\_CR 中的 PG 为 1 并试图写别的长度而不是半字,将引起总线错误中断。

如果在编程的过程中读/写(BSY 位会被置'1'), CPU 会被挂起,直到 Flash 编程完成。

半字编写流程如下图:





图 3-1 对 Flash 的半字编程

字编程的流程与半字编程流程相似,区别在于将 FLASH\_ECR 中的 WPG 位置'1'。

#### 标准编程

在这种模式下, CPU 编程执行标准的半字写操作。FLASH CR 中的 PG 位必须被置 1。

Flash 存储器接口会预读待编程地址的内容,然后判断其是否已经被擦除。如果不是,那么编程操作会自动取消,并且在 FLASH\_SR 寄存器的 PGERR 位上提示编程错误告警。如果被编程的内容为全零,则会例外,这时会正确编程并且不告警。

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

主 Flash 存储器标准模式下的编程过程如下:

- 1. 检查 FLASH\_SR 中的 BSY 位,以确认上次操作已经结束。
- 2. 置位 FLASH\_CR 寄存器中的 PG 位。
- 3. 根据配置,以半字为单位向目标地址写入数据。
- 4. 等待 FLASH SR 寄存器中的 BSY 归零。
- 5. 读取编程的值然后进行验证。

注意: 当FLASH\_SR 中的BSY 被置'1'时,写模式下的寄存器不能被读。



#### 3.2.3.4 Flash 存储器擦除

Flash 存储器可以按页或半页为单位擦除,也可以整片擦除。

#### 页擦除

擦除页的步骤如下:

- 1. 检查 FLASH\_SR 寄存器中的 BSY 位,以确认上次操作已经结束。
- 2. 将 FLASH CR 寄存器中的 PER 位置为 1,以选择按页擦除。
- 3. 写 FLASH\_AR 寄存器的 FAR 位,写入待擦除页的地址。
- 4. 将 FLASH\_CR 寄存器中的 STRT 位置为 1,以启动擦除操作。
- 5. 等待 FLASH\_SR 中的 BSY 变为 0,表明擦除操作完成。
- 6. 检查 LASH\_SR 寄存器的 EOP 标志(若 Flash 擦除成功会置位 EOP),然后软件清除该标志位。擦除页流程如下图:



图 3-2 对 Flash 擦除页的流程



#### 半页擦除

Flash 的半页为 512 Kbyte, 半页擦除流程和页擦除流程类似,区别在于把 FLASH\_ECR 中的 HPER 位置'1'。

擦除半页的步骤如下:

- 检查 FLASH SR 寄存器中的 BSY 位,以确认上次操作已经结束。
- 2. 将 FLASH CR 寄存器中的 HPER 位置为 1,以选择按半页擦除。
- 3. 写 FLASH AR 寄存器的 FAR 位,写入待擦除半页的地址。
- 4. 将 FLASH CR 寄存器中的 STRT 位置为 1,以启动擦除操作。
- 5. 等待 FLASH SR 中的 BSY 变为 0,表明擦除操作完成。
- 6. 检查 LASH SR 寄存器的 EOP 标志(若 Flash 擦除成功会置位 EOP),然后软件清除该标志位。

#### 整片擦除

可以用整片擦除命令一次擦除整个 Flash 区,但该命令不会影响信息块,具体步骤如下:

- 1. 检查 FLASH SR 寄存器的 BSY 位,以确认上次操作已经结束。
- 2. 将 FLASH CR 寄存器中的 MER 位置为 1,以选择整片擦除。
- 3. 将 FLASH CR 寄存器中的 STRT 位置为 1,以启动擦除操作。
- 4. 等待 FLASH SR 中的 BSY 位置 0,表明整片擦除操作结束。
- 5. 检查 FLASH\_SR 寄存器的 EOP 标志位(如果 Flash 擦除成功会置位 EOP),然后软件清除该标志 位。

#### 3.2.3.5 选项字节编程

选项字节的编程与常规用户地址不同,总共是 512 byte,包括:

- 4 个写保护
- 1 个读保护
- 2 个用户数据
- 1 个硬件配置
- 496 个用户数据储存

编程操作开始前,需要对 FLASH\_KEYR(解除 Flash 访问限制)和 FLASH\_OPTKEYR 写入关键字 KEY 以解锁 Flash,然后进行选项字节擦除或编程操作。在编程地址 0x1FFF F800~0x1FFF F80F(选项字节段)操作开始前,LSB 值会自动转化为 MSB,以适应选项字节的位定义。系统会自动检查选项字节是否已被擦除。如果未被擦除,则编程操作会被取消并在 FLASH SR 中的 PGERR 位提示错误。

选项字节编程的步骤如下:

- 1. 检查 FLASH SR 寄存器中的 BSY 位,以确保上次操作结束。
- 2. 将 FLASH\_CR 寄存器中的 OPTWRE 位置'1',以使能选项字节编程。
- 3. 将 FLASH CR 寄存器中的 OPTPG 位置为 1,以选择半字方式写入。
- 4. 写数据(半字)到目标地址。
- 5. 等待 FLASH SR 中的 BSY 位为 0,表示编程操作结束。



6. 将 FLASH\_CR 寄存器中的 OPTPG 位置为 0,以恢复默认值。

当读保护选项字节由保护状态变成非保护状态时,会执行一次整片擦除,然后才允许改写读保护位数据。若用户仅想改写选项字节区以外的数据,则不会引起整片擦除,该机制用于保护 Flash 的内容。

#### 擦除过程

选项字节是按页擦除的,步骤如下:

- 1. 检查 FLASH\_SR 寄存器中的 BSY 位,以确保上次操作结束。
- 2. 将 FLASH\_CR 寄存器中的 OPTWRE 位置'1',以使能选项字节编程。
- 3. 置 FLASH CR 寄存器中的 OPTER 位为 1,以擦除整个选项字节区域。
- 4. 将待擦除的地址写入 FLASH\_AR 寄存器(待擦除地址必须属于 OPT 选项字节表里已有的地址, 否则会出现不可预计的错误)。
- 5. 将 FLASH\_CR 寄存器中的 STRT 位置为 1,以启动擦除操作。
- 6. 等待 FLASH\_SR 中的 BSY 位变成 0,表明擦除操作结束。
- 7. 将 FLASH CR 寄存器中的 OPTER 位置为 0,以恢复默认值。

## 3.2.4 读写保护

支持保护 Flash 存储器的用户区,以防止被不可信的程序读取,也可防止在程序跑飞时意外擦除 Flash。写保护的最小单位是 4 页。

#### 3.2.4.1 读保护

通过置位选项字节中的 RDP 位,然后重新复位系统,读保护功能就被激活了。

注意:如果调试器处于连接状态时(通过JTAG/SWD 连接)设置了读保护,应使用 POR 复位(上电复位),而不是系统复位(无调试器连接)。

- 一旦保护字节被编程:
- 主 Flash 区的内容只能被用户程序读取(如果连接了调试器,用户程序也不能读取主 Flash 区的内容)。
- 页 0~3 是自动写保护的,剩下的 Flash 空间可以被用户程序编程(写入 IAP,常量储存等)。这个保护只针对在调试模式和从 SRAM 启动时的擦除和编程,不保护整片擦除。
- 可以下载代码到 SRAM 和从 SRAM 中执行程序,它也可以被用来关闭读保护。当读保护选项字 节被改变,会引发整片擦除。
- 当从 SRAM 启动的时候,使用 DMA 的 Flash 访问也会被禁止。
- 使用 JTAG、串行线查看器 SWV(Serial wire viewer)、串行线调试 SWD(Serial wire debug)和 边界扫描时,Flash 的访问被禁止。

Flash 存储器的读保护级别和RDP 选项字节及其反码内容的对应关系,如下表:

 RDP 字节值
 RDP 反码值(按位取反)
 读保护级别

 0x00FF
 0x00FF
 保护

 0x00A5
 RDP 反码
 没有保护

 其他值
 非 RDP 反码值
 保护

表 3-2 读保护级别和RDP 字节的对应关系



注意:擦除选项字节不会触发整页擦除,因为擦除值0xFF和保护值对应。

#### 读保护解除

从 SRAM 中解除读保护的方法:

- 1. 擦除整个选项区间,擦除后读保护代码(RDP)会被置为0x00FF,此时读保护仍然是使能。
- 2. 写入正确的 RDP 值 0x00A5 以解除读保护,这个操作会引发一次主 Flash 的整片擦除。
- 3. POR 复位会重加载选项字节 RDP, 从而关闭读保护。

注意: bootloader 可以关闭读保护(在这种情况下只有系统复位能重加载选项字节),同样, bootloader 关闭读保护时,也会触发主 Flash 的整片擦除。

#### 3.2.4.2 写保护

写保护以4页为单位进行控制。通过配置选项字节中的WRP位,然后复位时自动重新加载新的WRP选项字节即可使能写保护。如果试图写入或擦除一个受保护的扇区,会引起 FLASH\_SR 中的 WRPRTERR标志位被置位。

#### 写保护的解除

以下提供2个解除写保护的示例:

- 例 1: 在解除写保护后禁止读保护
  - 。 使用 FLASH CR 寄存器中的 OPTER 位,擦除整个选项字节区域。
  - 。 向 RDP 写入 0xA5 从而解除保护,这会引起整片擦除。
  - 。 复位引起选项字节重新加载,写保护解除。
- 例 2:在解除写保护后,读保护仍然有效,这种方式对使用用户 bootloader 进行在应用编程时很有用。
  - 。 使用 FLASH CR 寄存器中的 OPTER 位,擦除整个选项字节区域。
  - 。 复位引起选项字节重新加载,写保护解除。

## 3.2.5 选项字节的写保护

选项字节默认被写保护且随时可读。必须先向 FLASH\_OPTKEYR 寄存器顺序写入关键字,才能对选项字节进行写/擦除操作。填入正确的关键字会引起 FLASH\_CR 中的 OPTWRE 置位,表明解锁成功;通过对 OPTWRE 位清零,能够禁止对选项字节的写操作。

## 3.3 选项字节说明

选项字节由用户根据应用的需要进行配置。例如:可以选择使用硬件模式的看门狗或软件模式的看门狗。在选项字节中每个32位的字被划分为下述格式:

| 位[31:24]       | 位[23:16] | 位[15:8]    | 位[7:0] |
|----------------|----------|------------|--------|
| 选项字节1的反码 选项字节1 |          | 选项字节 0 的反码 | 选项字节 0 |

表 3-3 选项字的格式

#### 注意:

- 编程时,反码由硬件自动实现,软件写无效。
- 新写入的选项字节(用户的或读/写保护的),在系统复位后才生效。

选项字节块中选项字节的组织结构如表 3-4 所示。选项字节可以从下表列出的存储器地址读出,或



从选项字节寄存器(FLASH\_OBR)读出。

#### 表 3-4 选项字节结构

| 地址                      | [31:24]        | [23:16] | [15:8] | [7:0] |
|-------------------------|----------------|---------|--------|-------|
| 0X1FFF F800             | nUSER          | USER    | nRDP   | RDP   |
| 0X1FFF F804             | nDATA1         | DATA1   | nDATA0 | DATA0 |
| 0X1FFF F808             | nWRP1          | WRP1    | nWRP0  | WRP0  |
| 0X1FFF F80C             | nWRP3          | WRP3    | nWRP2  | WRP2  |
| 0X1FFF F810~0X1FFF F9FF | 保留,用于存储用户自定义数据 |         |        |       |

#### 表 3-5 0x1FFF F800~0x1FFF F80F 地址的选项字节说明

| 地址          | 位域      | 选项字节描述                                                                                                                                                                                                                                                  |  |
|-------------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 0x1FFF F800 | 位 31:24 | nUSER: USER 按位取反                                                                                                                                                                                                                                        |  |
|             | 位 23:16 | USER: 用户选项字节 USER 内容存储于 FLASH_OBR[9:2],用于配置如下特性:  ● 选择硬件或软件看门狗事件。  ● 当进入停机(Stop)模式时,复位事件。  ○ 位[18]: nRST_STDBY  - 0: 当进入待机模式时产生复位  - 1: 进入待机模式时不产生复位  ○ 位[17]: nRST_STOP  - 0: 当进入停机模式时产生复位  - 1: 当进入停机模式不产生复位  ○ 位[16]: WDG_SW  - 0: 硬件看门狗  - 1: 软件看门狗 |  |
|             | 位 15:8  | nRDP: RDP 按位取反                                                                                                                                                                                                                                          |  |
|             | 位 7:0   | RDP: Flash 读保护选项字节 该字节的值定义了 Flash 读保护级别,可帮助用户保护存储在 Flash 内部的程序。通过设置 RDP 选项字节来使能读保护。当 RDP 选择字配置值非 0xA5 时,使能读保护。读保护状态存储在 FLASH_OBR[1]。                                                                                                                    |  |
| 0x1FFF F804 | 位 31:0  | DATAx: 用户数据<br>可以使用选项字节的编程方式编程。<br>● 位[31:24]: nDATA1<br>● 位[23:16]: DATA1(存于FLASH_OBR[25:18])<br>● 位[15:8]: nDATA0<br>● 位[7:0]: DATA0(存于FLASH_OBR[17:10])                                                                                              |  |
| 0x1FFF F808 | 位 31:0  | WRPx: Flash 写保护选项字节  ● 位[31:24]: nWRP1  ● 位[23:16]: WRP1(存于 FLASH_WRPR[15:8])  ● 位[15:8]: nWRP0  ● 位[7:0]: WRP0(存于 FLASH_WRPR[7:0])  ο 0: 写保护使能                                                                                                         |  |



| 地址                          | 位域     | 选项字节描述                                                                                                                                                                                                                                                                              |
|-----------------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                             |        | o 1: 写保护禁能                                                                                                                                                                                                                                                                          |
| 0x1FFF F80C                 | 位 31:0 | WRPx: Flash 写保护选项字节  ● 位[31:24]: nWRP3  ● 位[23:16]: WRP3(存于 FLASH_WRPR[31:24])  ● 位[15:8]: nWRP2  ● 位[7:0]: WRP2(存于 FLASH_WRPR[23:16])  ○ 0: 写保护使能  ○ 1: 写保护禁能  Flash 的写保护范围是按照每一位(Bit)控制对应的 Flash 页(Page)。  WRP0: 写保护页 0~31  WRP1: 写保护页 32~63  WRP2: 写保护页 64~95  WRP3: 写保护页 96~127 |
| 0x1FFF F810-<br>0x1FFF F81F | 位 31:0 | 存储用户自定义数据                                                                                                                                                                                                                                                                           |

表 3-6 0x1FFF F820~0x1FFF F83F 地址的选项字说明

| 地址                          | 位域     | 选项字节描述                                                                                                                                                                                                            |
|-----------------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x1FFF F820                 | 位 31:0 | ENCRY_CFG[31:0]: 如果存储的值为 0x1357 ECA8,则使能片内 Flash 数据加密。<br>在使能加密后,再对 Flash 编程时,Flash 上存储的是加密后的密文。                                                                                                                  |
| 0x1FFF F824                 | 位 31:0 | DECRY_CFG[31:0]: 如果存储的值为 0x2468 DB97,则使能片内 Flash 数据解密。<br>在使能解密后,从 Flash 读出的数据自动解密后再返给 CPU。                                                                                                                       |
| 0x1FFF F828-<br>0x1FFF F82C | 位 31:0 | UKEY[63:0]:存储 Flash 加解密的密钥,由用户自己配置。<br>当地址 0x1FFF F828 和 0x1FFF F82C 的值不为全 FF 时,如果软件读这两个地址,返回的值为 0xAAAA AAAA。                                                                                                     |
| 0x1FFF F830                 | 位 31:0 | 位[31:12]: 保留   IWDG_RL_IV[11:0]: 存储   IWDG_RLR 寄存器的初始值。                                                                                                                                                           |
| 0x1FFF F834                 | 位 31:0 | IWDG_INI_KEY[31:0]: 决定 IWDG_RL_IV 是否生效。<br>当 IWDG_INI_KEY[31:0]为 0xA5A5 5B1E 时,IWDG_RL_IV 配置有效,否则无效。                                                                                                              |
| 0x1FFF F838                 | 位 31:0 | LSI_LP_CTL[31:0]: 决定系统在使能IWDG后再进入停机或待机模式时,是否需要被IWDG周期唤醒。  • 该位域配置为 0x369C F0F0 时: MCU 进入停机(Stop)或待机(Standby)模式后,可根据 LSION的设置关闭 LSI。 MCU 被唤醒后,LSI 恢复为进入低功耗模式之前的状态。  • 若未配置该位域: 在使能IWDG 后再进入停机或待机模式,系统会被 IWDG 周期唤醒。 |
| 0x1FFF_F83C                 | 位 31:0 | DBG_CLK_CTL[31:0]: 当存储的值为 0x1234 BCDE 时,关闭 CPU 内部调试(Debug)时钟,否则保持调试时钟打开。                                                                                                                                          |

每次系统复位后,选项字节装载器(OBL)读取信息块 0x1FFF F800~0x1FFF F80F 的数据,并保存在选项字节寄存器(FLASH\_OBR)中。所有的选项字节(不包括它们的反码)用于配置该 MCU,CPU 可以



读 FLASH OBR 寄存器。

每个选项字节都有其值的反码数据存放在信息块中,其目的用于校验选项字节的正确性。当选项字节装载后,CPU 会检查选项字节的正确性。若选项字节与其反码比较不一致时,会产生选项字节校验错(OPTERR)信息。当产生 OPTERR 后,CPU 会强制将相应的选项字节值变为 0xFF。当选项字节与其反码都为 0xFF(擦除后的状态)时,CPU 不会比较其与反码的差异。

### 3.4 Flash 中断

表 3-7 Flash 中断事件和事件标志

| 中断事件  | 事件标志     | 使能控制位 |
|-------|----------|-------|
| 操作结束  | EOP      | EOPIE |
| 写保护错误 | WRPRTERR | ERRIE |
| 编程错误  | PGERR    | ERRIE |

### 3.5 Flash 寄存器

基地址: 0x4002 2000 空间大小: 0x400

Flash 寄存器可以字(32位)为单位进行访问。

## 3.5.1 Flash 访问控制寄存器(FLASH\_ACR)

偏移地址: 0x00

复位值: 0x00000030

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

| 15  | 14 | 13 | 12 | 11 | 10 | 9 | 8      | 7      | 6      | 5  | 4       | 3    | 2 | 1  | 0 |
|-----|----|----|----|----|----|---|--------|--------|--------|----|---------|------|---|----|---|
| Res |    |    |    |    |    |   | PRFTBS | PRFTBE | HLFCYA | LA | TENCY[2 | 2:0] |   |    |   |
|     |    |    |    |    |    |   |        |        |        | r  | rw      | rw   |   | rw |   |

| 31:6 | Res: 保留<br>必须保持复位值。                                                               |
|------|-----------------------------------------------------------------------------------|
| 位 5  | PRFTBS: 预取指缓冲区的状态(Prefetch buffer status)  • 0: 预取缓冲区被禁止  • 1: 预取缓冲区被使能           |
| 位 4  | PRFTBE: 预取指缓冲区使能(Prefetch buffer enable)  • 0: 禁止预取指  • 1: 使能预取指                  |
| 位 3  | HLFCYA: Flash 半周期访问使能(Flash half cycle access enable)  • 0: 禁止半周期访问  • 1: 使能半周期访问 |



位 2:0

LATENCY[2:0]: 预设 HCLK 周期和 Flash 访问时间的比率关系(Latency)

- 000: 0 个等待周期,适用于 0 MHz<HCLK<=24 MHz。
- 001: 1 个等待周期,适用于 24 MHz<HCLK<=48 MHz
- 010: 2 个等待周期,适用于 48 MHz<HCLK<=72 MHz
- 011: 3 个等待周期,适用于 72 MHz<HCLK<=96 MHz
- 100: 7 个等待周期
- 101: 9 个等待周期
- 110: 19 个等待周期
- 111: 39 个等待周期

LATENCY 配置为 011~111 适用于 CPU 以极低频率运行的应用程序。通过配置大的等待周期 可以降低整个芯片的功耗。

通过设置更大的等待周期值,在无需高速处理能力的应用场景下 MCU 的功耗可以得到进 一步的降低。

### 3.5.2 Flash 关键字寄存器(FLASH\_KEYR)

偏移地址: 0x04

复位值: 0xXXXX XXXX

所有寄存器位全部只能写,如果读会返回0。

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

位 31:0

FKEYR[31:0]:解锁 Flash 的关键字(Flash key)

该位域用于输入关键字以解锁 Flash。

以下键值用于对该寄存器进行解锁,参见"3.2.3.1键值":

- KEY1=0x4567 0123
- KEY2=0xCDEF 89AB

## 3.5.3 Flash 选项关键字寄存器(FLASH OPTKEYR)

偏移地址: 0x08

复位值: 0xXXXX XXXX

所有寄存器位全部只能写,如果读会返回0。

| 31                                            | 30 | 29 | 28 | 27 | 26 | 25 | 24     | 23       | 22 | 21 | 20  | 19  | 18 | 17 | 16 |
|-----------------------------------------------|----|----|----|----|----|----|--------|----------|----|----|-----|-----|----|----|----|
|                                               |    |    |    |    |    |    | OPTKEY | '[31:16] |    |    |     |     |    |    | •  |
|                                               |    |    |    |    |    |    | V      | V        |    |    |     |     |    |    |    |
| 15                                            | 14 | 13 | 3  | 12 | 11 | 10 | 9      | 8        | 7  | 6  | 5 4 | . 3 | 2  | 1  | 0  |
|                                               |    |    |    |    |    |    | OPTKE' | Y[15:0]  |    |    |     |     |    |    |    |
| W                                             |    |    |    |    |    |    |        |          |    |    |     |     |    |    |    |
| 位 31:0 OPTKEY[31:0]: 选项字节关键字(Option byte key) |    |    |    |    |    |    |        |          |    |    |     |     |    |    |    |



该位域用于输入关键字以解锁 OPTWRE。 以下键值用于对该寄存器进行解锁:

- KEY1=0x4567 0123
- KEY2=0xCDEF 89AB

## 3.5.4 Flash 状态寄存器(FLASH\_SR)

偏移地址: 0x0C

复位值: 0x0000 0000

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

| 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   |

|            | 100 100 100 1                                                                                                      |  |  |  |  |  |  |  |
|------------|--------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| 位 31:6     | Res: 保留<br>必须保持复位值。                                                                                                |  |  |  |  |  |  |  |
| 位 5        | EOP:操作结束(End of operation)<br>当 Flash 操作(写/擦除)完成时,该位由硬件置位。<br>该位由软件写 1 后可清零。<br>注意:只有成功的写或擦除操作才会由硬件置位 EOP。         |  |  |  |  |  |  |  |
| 位 4        | WRPRTERR:写保护错误标志(Write protection error)当出现对写保护区域的写操作时,该位由硬件置位。该位由软件写 1 后可清零。                                      |  |  |  |  |  |  |  |
| 位 3        | Res: 保留<br>必须保持复位值。                                                                                                |  |  |  |  |  |  |  |
| 位 2        | PGERR:写入错误标志(Programming error)半字编程时,如果被编程区域的值不为'0xFFFF'或者字编程时,如果被编程区域的值不为'0xFFFFFFF',则执行写入操作时被硬件置位。该位由软件写 1 后可清零。 |  |  |  |  |  |  |  |
| 位 1        | Res: 保留<br>必须保持复位值。                                                                                                |  |  |  |  |  |  |  |
| 位 <b>0</b> | BSY: 忙标志(Busy)<br>该位标明 Flash 操作正在进行。<br>当开始 Flash 操作的时候被硬件置位,当操作结束时或发生错误时被硬件清零。                                    |  |  |  |  |  |  |  |

# 3.5.5 Flash 控制寄存器(FLASH\_CR)

偏移地址: 0x10

复位值: 0x0000 0080



| 15 | 14  | 13 | 12    | 11  | 10    | 9      | 8   | 7    | 6    | 5     | 4     | 3   | 2   | 1   | 0  |
|----|-----|----|-------|-----|-------|--------|-----|------|------|-------|-------|-----|-----|-----|----|
|    | Res |    | EOPIE | Res | ERRIE | OPTWRE | Res | LOCK | STRT | OPTER | OPTPG | Res | MER | PER | PG |
|    |     |    | rw    |     | rw    | rw     |     | rw   | rw   | rw    | rw    |     | rw  | rw  | rw |

| 位 31:13 | Res: 保留<br>必须保持复位值。                                                                                                   |
|---------|-----------------------------------------------------------------------------------------------------------------------|
| 位 12    | EOPIE:操作结束中断使能(End of operation interrupt enable) 该位使能操作结束中断,在使能 FLASH_SR 中的 EOP 位变成 1 时产生中断请求。  • 0: 中断禁止  • 1: 中断使能 |
| 位 11    | Res: 保留<br>必须保持复位值。                                                                                                   |
| 位 10    | ERRIE: 错误中断使能(Error interrupt enable) 该位使能操作错误中断,在使能 FLASH_SR 中的 PGERR/WRPRTERR 位变成 1 时产生中断请求。  • 0: 中断禁止 • 1: 中断使能   |
| 位 9     | OPTWRE: 选项字节写使能(Option byte write enable) 该位为 1 时,选项字节即允许改写。对 FLASH_OPTKEYR 寄存器写入正确的关键字序列就可以将它置'1'。 该位由软件清零。          |
| 位 8     | Res: 保留<br>必须保持复位值。                                                                                                   |
| 位 7     | LOCK: 锁定 Flash 标志(Lock) 该位只能写 1。当该位为 1 时,表明 Flash 为锁定状态。 该位可以由解锁时序来清零。当解锁不成功时,该位就一直为 1 了,除非下次复位重新操作。                  |
| 位 6     | STRT: 启动(Start)<br>该位会触发一个擦除操作,仅由软件置'1',仅会在 BSY 被清零时清零。                                                               |
| 位 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:写入(Half-word programming) Flash 写入(以半字为单位)时选择。 |

### 3.5.6 Flash 地址寄存器(FLASH\_AR)

偏移地址: 0x14

复位值: 0x0000 0000

本寄存器由硬件根据当前和上次操作的地址更新。对于页擦除操作,该寄存器该由软件配置以指明要擦除的页或半页。

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

位 31:0 FAR[31:0]: Flash 地址(Flash Address)

当 HPER/PER 位被选中时,选择待擦除的半页/页的地址。

注意: 当FLASH\_SR 寄存器中的BSY 为1 时,写操作被锁定。

## 3.5.7 Flash 选项字节寄存器(FLASH\_OBR)

偏移地址: 0x1C

复位值: 0x03FF FFFC

本寄存器的复位值取决于选项字节的写入值,OPTERR 位的复位值取决于复位时选项字节加载环节中比较选项字节及其补码的结果。

| 31 | 30  | 29 | 28 | 27 | 26 | 25 | 24 | 23         | 22 | 21 | 20 | 19 | 18 | 17 | 16 |  |
|----|-----|----|----|----|----|----|----|------------|----|----|----|----|----|----|----|--|
|    | Res |    |    |    |    |    |    | Data1[7:0] |    |    |    |    |    |    |    |  |
|    |     |    |    |    |    |    |    |            |    | r  |    |    |    | 1  | ٢  |  |

| 15 | 14         | 13 | 12 | 11 | 10 | 9   | 8 7 6 5 |  | 4 | 3 | 2          | 1         | 0      |       |        |
|----|------------|----|----|----|----|-----|---------|--|---|---|------------|-----------|--------|-------|--------|
|    | Data0[5:0] |    |    |    |    | Res |         |  |   |   | nRST_STDBY | nRST_Stop | WDG_SW | RDPRT | OPTERR |
|    |            |    | r  |    |    |     |         |  |   |   | r          | r         | r      | r     | r      |

| 位 31:26 | Res: 保留<br>必须保持复位值。         |
|---------|-----------------------------|
| 位 25:18 | Data1[7:0]: 用户数据(User Data) |
| 位 17:10 | Data0[7:0]: 用户数据(User Data) |



| 位 9:5 | Res: 保留<br>必须保持复位值。                                                                                               |
|-------|-------------------------------------------------------------------------------------------------------------------|
| 位 4   | nRST_STDBY: 进入待机模式时的复位事件(Generate reset when entering Standby mode)  • 0: 当进入待机模式时产生复位  • 1: 进入待机模式时不产生复位         |
| 位 3   | nRST_Stop: 进入停机模式时的复位事件(Generate reset when entering Stop mode)  • 0: 当进入停机(Stop)模式时产生复位  • 1: 进入停机(Stop)模式时不产生复位 |
| 位 2   | WDG_SW: 选择软件或硬件看门狗(Hardware or software watchdog selection) • 0: 硬件看门狗 • 1: 软件看门狗                                 |
| 位 1   | RDPRT: 读保护(Read protection)<br>该位为 1 表示已设置为读保护(只读)。                                                               |
| 位 0   | OPTERR: 选项字节错误(Option byte error)<br>当置位时,表明加载选项字节时反码校验错误(只读)。                                                    |

## 3.5.8 Flash 写保护寄存器(FLASH\_WRPR)

偏移地址: 0x20

复位值: OxFFFF FFFF

本寄存器的复位值取决于选项字节的写入值。

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

位 31:0 WRP[31:0]: 写保护(Write protection)

该位保持由 OBL 载入的写保护选项字(只读)。

- 0: 写保护激活
- 1: 写保护禁止

# 3.5.9 Flash 控制寄存器 2(FLASH\_ECR)

偏移地址: 0x70

复位值: 0x0000 0000

说明: FLASH\_ECR 的寄存器的位均是配置'1'有效,同一时刻只能配置其中1 位为有效。

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



| Res            | WPG | Res | HPER |
|----------------|-----|-----|------|
|                | rw  |     | rw   |
| Donat - Its de |     |     |      |

| 位 31:4 | Res: 保留<br>必须保持复位值。                                         |
|--------|-------------------------------------------------------------|
| 位 3    | WPG: 主 Flash 区按字编程(Word programming in main Flash memory)   |
| 位 2:1  | Res: 保留<br>必须保持复位值。                                         |
| 位 0    | HPER: 主 Flash 区半页擦除(Half-page erasing in main Flash memory) |



### 4 CRC 计算单元 (CRC)

循环冗余校验(Cyclic redundancy check,CRC)计算单元是根据一个固定的生成多项式和一个 **32** 位 的数据得到任一 **32** 位字的 CRC 计算结果。

在其他的应用中,CRC 技术主要应用于验证数据传输或数据存储的正确性和完整性。在EN/IEC60335-1标准中提供了一种验证 Flash 存储器完整性的方法,即 CRC 计算单元在程序运行期间辅助计算软件的签名,并在软件连接期间将该签名与存储在指定存储位置的参考签名进行比较。

### 4.1 CRC 主要特性

- 使用 CRC-32(以太网)多项式: 0x4C11DB7
   X<sup>32</sup>+X<sup>26</sup>+X<sup>23</sup>+X<sup>22</sup>+X<sup>16</sup>+X<sup>12</sup>+X<sup>11</sup>+X<sup>10</sup>+X<sup>8</sup>+X<sup>7</sup>+X<sup>5</sup>+X<sup>4</sup>+X<sup>2</sup>+X+1
- 单个 32 位输入/输出数据寄存器
- CRC 计算在 4 个 AHB 时钟周期(HCLK)内完成
- 通用 8 位寄存器 (可用于存放临时数据)



图 4-1 CRC 计算单元框图

## 4.2 CRC 功能描述

CRC 计算单元有 1 个 32 位数据寄存器:

- 向该寄存器写入数据时,它作为输入寄存器为 CRC 计算提供新数据。
- 当从该寄存器读数据时,它存储的是上一次 CRC 计算的结果。

每一次写入数据寄存器,其计算结果是前一次 CRC 计算结果和新计算结果的组合(对整个 32 位字进行 CRC 计算,而不是逐字节地计算)。

在 CRC 计算期间会暂停 CPU 的写操作,因此可以对寄存器 CRC\_DR 进行背靠背写入或者连续地写和读操作。

可以通过设置寄存器 CRC\_CR 的 RESET 位来重置寄存器 CRC\_DR 为 0xFFFF FFFF。该操作不影响寄存器 CRC\_IDR 内的数据。

## 4.3 CRC 寄存器

基地址: 0x4002 3000 空间大小: 0x400

CRC 计算单元包括 2 个数据寄存器和 1 个控制寄存器。

CRC 寄存器必须以字为单位进行访问。



# 4.3.1 数据寄存器(CRC\_DR)

偏移地址: 0x00

复位值: OxFFFF FFFF

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

位 31:0 DR[31:0]: 数据寄存器(Data register)

该寄存器用于存放待计算的新数据,直接将其写入即可。读取该寄存器得到的是上次 CRC 计算的结果。

## 4.3.2 独立数据寄存器(CRC\_IDR)

偏移地址: 0x04

复位值: 0x0000 0000

此寄存器不参与 CRC 计算,可以存放任何数据。

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

| 位 31:8 | Res: 保留<br>必须保持复位值。                                                                                                |
|--------|--------------------------------------------------------------------------------------------------------------------|
| 位 7:0  | IDR[7:0]: 通用 8 位数据寄存器(General purpose 8-bit data register) 该寄存器可用作 1 个字节的临时存储。CRC_CR 寄存器中的 RESET 位引起的复位操作不会影响该寄存器。 |

## 4.3.3 控制寄存器(CRC\_CR)

偏移地址: 0x08

复位值: 0x0000 0000

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

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

| 位 31:1 | Res: 保留<br>必须保持复位值。        |
|--------|----------------------------|
| 位 0    | RESET: 复位控制(Reset control) |



该位用于复位 CRC 计算单元,设置数据寄存器为 0xFFFFFFFF。只能对该位写'1', 它由硬件自动清零。



### 5 电源控制(PWR)

### 5.1 电源

HK32F103x8xB 的工作电压(VDD)为 2.0~5.5V。通过内置的电压调节器提供所需的内部 1.8V 数字电源。当主电源 VDD 掉电后,通过备用电源 VBAT 为实时时钟(RTC)和备份寄存器供电。

HK32F103x8xB 片内数字逻辑的电源由片内 LDO 提供。

片内 LDO 的输出电压可通过寄存器设置,以方便软件根据应用场景最大程度地优化芯片的电流功耗。芯片运行(Run)模式和停机(Stop)模式的 LDO 输出电压可以分别独立设置。



图 5-1 电源框图

说明: V<sub>DDA</sub> 和 V<sub>SSA</sub> 必须分别连接到 V<sub>DD</sub> 和 V<sub>SS</sub>。

## 5.1.1 独立的 ADC 供电和参考电压

为了提高转换精度, ADC 带一个独立的电源。该电源能过滤和屏蔽来自印刷电路板的噪声。

- ADC 的电源引脚为 VDDA
- · 独立的电源地连接至 Vssa 引脚

#### 5.1.2 电池备份域

当  $V_{DD}$  断电时,为了保持备份寄存器的内容和 RTC 的供电, $V_{BAT}$  脚可连接至可选的待机电压。该待机电压由电池或其它电源提供。



V<sub>BAT</sub> 脚为 RTC、LSE 振荡器和 PC13 至 PC15 端口供电,可以确保当主电源被切断时 RTC 能继续工作。 切换到 V<sub>BAT</sub> 供电的开关,由复位模块中的掉电复位(Power Down Reset,PDR)功能控制。

#### 警告:

- 在复位期间(t<sub>RSTTEMPO</sub>,即 V<sub>DD</sub> 的上升时间)或检测到复位掉电信号(PDR)之后,V<sub>BAT</sub> 和 V<sub>DD</sub> 之 间的电源开关仍会保持连接在 V<sub>BAT</sub>。
- 在 V<sub>DD</sub> 上升阶段,如果 V<sub>DD</sub> 在小于 t<sub>RSTTEMPO</sub> 的时间内达到稳定状态(关于 t<sub>RSTTEMPO</sub> 数值可参考数据手册中的相关部分),且 V<sub>DD</sub>>V<sub>BAT</sub>+0.6V 时,电流可能通过 V<sub>DD</sub> 和 V<sub>BAT</sub> 之间的内部二极管注入 到 V<sub>BAT</sub>。如果与 V<sub>BAT</sub> 连接的电源或者电池不能承受这样的注入电流,强烈建议在外部 V<sub>BAT</sub> 和电源之间连接一个低压降二极管。

若在实际应用中没有外部电池,推荐  $V_{\text{bat}}$ 在外部连接至  $V_{\text{to}}$ 并连接一个 100 nF 的陶瓷滤波电容。当该备份域由  $V_{\text{DD}}$ (内部模拟开关连到  $V_{\text{DD}}$ )供电时,下述功能可用:

- PC14 和 PC15 可以用作 GPIO 或 LSE 引脚
- PC13 可以作为通用 I/O 口、TAMPER 引脚、RTC 校准时钟、RTC 闹钟或秒输出(可参考"6备份寄存器(BKP)")

说明:因为模拟开关只能通过少量的电流(3 mA),在输出模式下使用 PC13 至 PC15 口的功能是有限制的:速度必须限制在 2 MHz 以下,最大负载为 30pF,而且这些 I/O 口绝对不能用作电流源(如驱动 LED)。

当备份域由 VBAT 供电时 (VDD 不存在,则模拟开关连接到 VBAT),下述功能可用:

- PC14 和 PC15 只能用于 LSE 引脚
- PC13 可以作为 TAMPER 引脚、RTC 闹钟或秒输出(可参考"6.3.2 RTC 时钟校准寄存器 (BKP RTCCR)")

#### 5.1.3 Core 电压调节器

复位后 Core 电压调节器总是使能的。根据应用方式,它可以工作在以下几种模式。

- 运行(Run)模式:调节器以正常功耗模式提供1.8V电源(内核,内存和内置数字外设)。
- 停机(Stop)模式:调节器以低功耗模式提供 1.8V 电源,以保存寄存器和 SRAM 的内容。
- 待机(Standby)模式:调节器停止供电。除了备份电路和备份域外,寄存器和 SRAM 的内容 全部丢失。

#### 5.2 电源监控器

#### 5.2.1 上电复位 (POR) 和掉电复位 (PDR)

HK32F103x8xB 内部集成了上电复位(POR)和掉电复位(PDR)电路。当供电电压达到 POR/PDR 阈值,系统即能正常工作。

当 V<sub>DD</sub>/V<sub>DDA</sub> 低于指定的电压阈值 V<sub>POR</sub>/V<sub>PDR</sub> 时,系统保持复位状态,而无需外部复位电路。关于上电复位和掉电复位阈值,请参考数据手册的电气特性部分。





图 5-2 上电复位和掉电复位的波形图

#### 5.2.2 可编程电压监测器(PVD)

可以使用可编程电压监测器(Programmable Voltage Detector,PVD)监测 V<sub>DD</sub>/V<sub>DDA</sub>的供电。通过比较监测值与电源控制寄存器(PWR\_CR)的 PLS[2:0]位所设置的阈值,即可监测。

通过设置(PWR\_CR)的 PVDE 位以使能 PVD。

电源控制/状态寄存器(PWR\_CSR)中的 PVDO 标志用于表示  $V_{DD}/V_{DDA}$ 高于或低于 PVD 阈值。该事件在内部连接到外部中断的第 16 线(EXTI 线 16),如果在外部中断寄存器使能了该中断,则会产生中断。当  $V_{DD}/V_{DDA}$ 下降到 PVD 阈值以下或当  $V_{DD}$ 上升到 PVD 阈值以上时,根据 EXTI 线 16 上升沿/下降沿触发配置,则会产生 PVD 输出中断。例如,这一特性可用于服务程序执行紧急关闭任务。



图 5-3 PVD 阈值

## 5.3 低功耗模式

在系统或电源复位以后,MCU 默认处于运行状态。当 CPU 不需继续运行时(例如在等待某个外部事件时),可使用几种低功耗模式以节省功耗。用户需要根据最低电源消耗、最短启动时间和可用的唤醒源等条件,选定一个最佳的低功耗模式。

该芯片有以下几种低功耗模式:

- 睡眠(Sleep)模式: Cortex®-M3 内核停止,所有外设包括 Cortex-M3 核心的外设,如 NVIC、系统时钟(SysTick)等仍在运行。
- 停机(Stop)模式: 所有的时钟都已停止。



- 特机(Standby)模式: Core 电源域关闭。 此外,在运行(Run)模式下,可以通过以下任一方式降低功耗:
- 降低系统时钟频率
- 关闭 APB 和 AHB 总线上未被使用的外设时钟。

表 5-1 低功耗模式一览

| 工作模式              | 进入条件                                                                                                                                                                  | 唤醒条件                                                               | 内部核电<br>源时钟状<br>态                         | V <sub>DD</sub> 主区<br>域时钟状<br>态 | 电压调节<br>器状态                             |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|-------------------------------------------|---------------------------------|-----------------------------------------|
| 睡眠模式<br>(Sleep)   | <ol> <li>设置 PWR_CR:LPDS=0 和 PWR_CR:PDDS=0。</li> <li>软件执行 WFI/WFE 指令进入。</li> </ol>                                                                                     | 由任何一个普通 IRQ 中断事件唤醒,包括<br>System Tick。                              | CPU 时钟<br>关闭,对<br>其他时钟<br>和 ADC 时<br>钟无影响 | 开启                              | 开启                                      |
| 停机模式<br>(Stop)    | <ol> <li>设置 PWR_CR:PDDS=0。</li> <li>设置 Cortex-M3 系统控制寄存器的 SLEEPDEEP 位。</li> <li>软件执行 WFI/WFE 指令进入。</li> </ol>                                                         | 由任何一个 EXTI 外部中<br>断线唤醒。                                            | 所有时钟<br>停止                                | HSI 和 HSE<br>关闭                 | 开启或者<br>处于模 式<br>(在 PWR<br>_CR 中设<br>置) |
| 待机模式<br>(Standby) | <ol> <li>设置 PWR_CR:LPDS=0 和 PWR_CR:PDDS=1。</li> <li>设置 Cortex-M3 系统控制寄存器的 SLEEPDEEP 位。</li> <li>软件执行 WFI/WFE 指令进入。</li> <li>清除电源控制/状态寄存器(PWR_CSR)中的 WUF 位。</li> </ol> | 支持 3 个可配置极性的外 部 唤 醒 引 脚(WUKPx)、RTC 闹钟唤醒,NRST 引脚上的外部复位以及 IWDG 复位唤醒。 | 所有时钟<br>停止                                | HSI 和 HSE<br>关闭                 | 关闭                                      |

#### 5.3.1 降低系统时钟频率

在运行模式下,通过编程预分频寄存器可以降低任意一个系统时钟(SYSCLK、HCLK、PCLK1、PCLK2)的频率。在进入睡眠模式之前,也可以利用预分频器来降低外设的时钟频率。更多信息,可参考章节:"7.3.2 时钟配置寄存器(RCC\_CFGR)"。

### 5.3.2 外部时钟的控制

在运行模式下,任何时候都可以通过停止为外设和内存提供时钟(HCLK 和 PCLKx)来减少功耗。为了在睡眠模式下进一步减少功耗,可在执行 WFI 或 WFE 指令前关闭所有外设的时钟。

通过设置 AHB 外设时钟使能寄存器(RCC\_AHBENR)、APB2 外设时钟使能寄存器(RCC\_APB2ENR)和 APB1 外设时钟使能寄存器(RCC\_APB1ENR)来开关各个外设的时钟。

## 5.3.3 睡眠(Sleep)模式

#### 5.3.3.1 进入睡眠模式

通过执行 WFI 或 WFE 指令进入睡眠状态。根据 Cortex®-M3 系统控制寄存器中的 SLEEPONEXIT 位的值,提供两种选项选择睡眠模式的进入机制:

- SLEEP-NOW:如果 SLEEPONEXIT 位被清除,当执行 WFI 或 WFE 指令时,MCU 立即进入睡眠模式。
- SLEEP-ON-EXIT: 如果 SLEEPONEXIT 位被置位,系统从最低优先级的中断服务程序(ISR)中退出时,MCU 立即进入睡眠模式。



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

若想了解如何进入睡眠模式,可参考表 5-2 和表 5-3。

#### 5.3.3.2 退出睡眠模式

如果执行 WFI 指令进入睡眠模式,任意一个被嵌套向量中断控制器(Nested Vectored Interrupt Controller, NVIC)响应的外设中断都能将系统从睡眠模式唤醒。

如果执行 WFE 指令进入睡眠模式,则一旦发生唤醒事件时,MCU 将从睡眠模式退出。唤醒事件可以通过下述方式产生:

- 在外设控制寄存器中使能一个中断,而不是在 NVIC 中使能,并且在 Cortex®-M3 系统控制寄存器中使能 SEVONPEND 位。当 MCU 从 WFE 中唤醒后,外设的中断挂起位和外设的 NVIC 中断通道挂起位(在 NVIC 中断清除挂起寄存器中)必须被清除。
- 配置一个外部或内部的 EXTI 线为事件模式。当 MCU 从 WFE 中唤醒后,因为与事件线对应的 挂起位未被设置,不必清除外设的中断挂起位或 NVIC 中断请求(IRQ)通道挂起位。

该模式唤醒所需的时间最短,因为没有时间损失在中断的进入或退出上。若需了解如何退出睡眠模式,可参考表 5-2 和表 5-3。

|              | 及 3-2 SLEEP-NOW 侯以                                                                                                              |
|--------------|---------------------------------------------------------------------------------------------------------------------------------|
| SLEEP-NOW 模式 | 说明                                                                                                                              |
| 进入条件         | 在以下条件下执行 WFI(等待中断)或 WFE(等待事件)指令: SLEEPDEEP=0 和 SLEEPONEXIT=0 参考 Cortex®-M3 系统控制寄存器。                                             |
| 退出条件         | <ul> <li>如果执行 WFI 进入睡眠模式:</li> <li>中断: 参考"8.1.2 中断和异常向量"。</li> <li>如果执行 WFE 进入睡眠模式:</li> <li>唤醒事件: 参考"8.2.4 唤醒事件管理"。</li> </ul> |
| 唤醒延时         | -                                                                                                                               |

表 5-2 SLEEP-NOW 模式

#### 表 5-3 SLEEP-ON-EXIT 模式

| SLEEP-ON-EXIT 模式 | 说明                                                                  |
|------------------|---------------------------------------------------------------------|
| 进入条件             | 在以下条件下执行 WFI 指令: SLEEPDEEP=0 和 SLEEPONEXIT=1 参考 Cortex®-M3 系统控制寄存器。 |
| 退出条件             | 中断:参考"8.1.2 中断和异常向量"。                                               |
| 唤醒延时             | -                                                                   |

## 5.3.4 停机(Stop)模式

停机模式是基于结合了外设时钟门控的 Cortex®-M3 的深睡眠模式。在停机模式下,电压调节器可配置为正常或低功耗模式。在该模式下,Core 供电域的所有时钟都被停止,PLL、HSI 和 HSE RC 振荡器被禁用,SRAM 和寄存器内容被保留下来。

在停机模式下,所有的 I/O 引脚都保持运行模式下的状态。



#### 5.3.4.1 进入停机模式

若需了解如何进入停机模式,可参考表 5-1。

为了进一步降低停机模式下的功耗,可将内部电压调节器设置为低功耗模式。通过配置电源控制寄存器(PWR\_CR)中的 LPDS 位来实现。

如果正在进行 Flash 编程,直到对 Flash 访问完成,系统才进入停机模式。如果正在进行对 APB 访问,直到对 APB 访问完成,系统才进入停机模式。

在停机模式下,通过对独立的控制位进行编程,可选择以下功能:

- 独立看门狗(IWDG): 可通过写入看门狗的键寄存器或硬件选择来启动 IWDG。一旦启动了 IWDG,除了系统复位,它不能被停止。详见章节: "15.2 IWDG 功能描述"。
- 实时时钟(RTC): 通过备份域控制寄存器(RCC BDCR)的 RTCEN 位来设置。
- 内部 RC 振荡器(LSI RC): 通过控制/状态寄存器(RCC CSR)的 LSION 位来设置。
- 外部 32.768 kHz 振荡器(LSE OSC): 通过备份域控制寄存器(RCC BDCR)的 LSEON 位设置。

在停机模式下,如果在进入该模式前未关闭 ADC,则这些外设仍然耗电。通过设置寄存器 ADC\_CR2 的 ADON 位为 0 可关闭这个外设。

#### 5.3.4.2 退出停机模式

关于如何退出停机模式,可参考表 5-1。当一个中断或唤醒事件导致退出停机模式时, HSI RC 振荡器被选为系统时钟。

当电压调节器处于低功耗模式下,当系统从停机模式退出时,将会有一段额外的启动延时。如果在停机模式期间保持内部调节器开启,则退出启动时间会缩短,但相应的功耗会增加。

### 5.3.5 待机 (Standby) 模式

待机模式可实现系统的最低功耗。该模式在 Cortex®-M3 深睡眠模式时关闭电压调节器,整个 Core 供电域被断电,PLL、HSI 和 HSE 振荡器也被断电,SRAM 和寄存器内容丢失,仅备份域的寄存器和 待机电路维持供电(见图 5-1)。

#### 5.3.5.1 讲入待机模式

关于如何进入待机模式,可参考表 5-1。可以通过设置独立的控制位,选择以下待机模式的功能:

- 独立看门狗(IWDG):可通过写入看门狗的键寄存器或硬件选择来启动 IWDG。一旦启动了独立看门狗,除了系统复位外,它不能被停止。详见章节:"15.2 IWDG 功能描述"。
- 实时时钟(RTC): 通过备份域的控制寄存器(RCC BDCR)的 RTCEN 位来设置。
- 内部 RC 振荡器(LSI RC): 通过控制/状态寄存器(RCC CSR)的 LSION 位来设置。
- 外部 32.768 kHz 振荡器(LSE): 通过备份域的控制寄存器(RCC\_BDCR)的 LSEON 位设置。

#### 5.3.5.2 退出待机模式

当一个外部复位(NRST 引脚)、IWDG 复位、WKUP 引脚上的上升沿或 RTC 闹钟事件的上升沿发生时(见图 14-1),MCU 从待机模式退出。从待机模式唤醒后,除了电源控制/状态寄存器(PWR\_CSR),所有寄存器被复位。

从待机模式唤醒后,代码执行与重启后以相同的方式重新启动(采样启动模式引脚、读取复位向量等)。电源控制/状态寄存器(PWR CSR)将会指示内核由待机状态退出。

关于如何退出待机模式,详见表 5-1。



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

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

- 复位引脚(始终有效)
- 被设置为防侵入或校准输出时的 TAMPER 引脚
- 被使能的唤醒引脚

#### 5.3.6 丰富的唤醒源

- 睡眠(Sleep)模式下,可以由任何一个普通 IRQ 中断事件唤醒。
- 停机(Stop)模式下,可以由任何一个 EXTI 外部中断线唤醒。
- 待机(Standby)模式下,支持 3 个可配置极性的外部唤醒引脚以及 RTC ALARM 唤醒。

### 5.3.7 调试模式

默认情况下,如果调试 MCU 时,使 MCU 进入停机或待机模式将失去调试连接。这是因为 Cortex®-M3 的内核失去了时钟。

然而,通过设置 DBGMCU\_CR 寄存器中的某些配置位,可以在使用低功耗模式下调试软件。更多的细节请参考章节: "24.14.1 低功耗模式的调试支持"。

### 5.3.8 低功耗模式下的自动唤醒(AWU)

RTC 可以在不需要依赖外部中断的情况下唤醒低功耗模式下的 MCU (自动唤醒模式)。RTC 提供一个可编程的时间基数,用于周期性从停机或待机模式下唤醒。通过编程备份域控制寄存器(RCC\_BDCR)的 RTCSEL[1:0]位,以下两个时钟源可用作低功耗模式下的 RTC 时钟。

- 低功耗 32.768 kHz 外部晶振(LSE): 该时钟源提供了一个低功耗且精确的时间基准。(在典型情形下消耗小于 1 μA)
- 低功耗内部 RC 振荡器(LSI RC)

使用该时钟源,节省了一个 32.768 kHz 晶振的成本。但是 RC 振荡器将少许增加电源消耗。为了用 RTC 闹钟事件将系统从停机模式下唤醒,必须进行如下操作:

- 。 配置外部中断线 17 为上升沿触发。
- 。 配置 RTC 使其可产生 RTC 闹钟事件。

如果要从待机模式中唤醒,则不必配置外部中断线 17。

## 5.4 PWR 寄存器

基地址: 0x4000 7000

空间大小: 0x400

可以按半字(16位)或字(32位)的方式操作 PWR 寄存器。

## 5.4.1 电源控制寄存器 (PWR\_CR)

偏移地址: 0x00

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

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



| Res | DBP | PLS[2:0] | PVDE | CSBF | CWUF | PDDS | LPDS |
|-----|-----|----------|------|------|------|------|------|
|     | rw  | rw       | rw.  | rw   | r\w/ | rw   | rw/  |

| 位 31:9          | Res: 保留                                             |
|-----------------|-----------------------------------------------------|
| ղ <u>√</u> 31:9 | 必须保持复位值。                                            |
|                 | 2次体的交性性。                                            |
| 位 8             | DBP: 取消备份域的写保护(Disable RTC domain write protection) |
|                 | 在复位后,RTC 和备份寄存器处于被保护状态以防意外写入。设置该位以允许写入这些寄存器。        |
|                 | • 0: 禁止写入 RTC 和备份寄存器                                |
|                 | <ul> <li>1: 允许写入 RTC 和备份寄存器</li> </ul>              |
|                 | 说明: 如果RTC 的时钟是HSE/128,该位必须保持为1'。                    |
| <br>位 7:5       | PLS[2:0]: PVD 电平选择(PVD level selection)             |
| <u> </u>        | 该位域由软件写入,以选择电源电压监测器所监测的电压阈值。                        |
|                 | • 000: 2.2 V                                        |
|                 | • 001: 2.3 V                                        |
|                 | • 010: 2.4 V                                        |
|                 | • 011: 2.5 V                                        |
|                 | • 100: 2.6 V                                        |
|                 | • 101: 2.7 V                                        |
|                 | • 110: 2.8 V                                        |
|                 | • 111: 2.9 V                                        |
|                 | 说明: 详细说明参见数据手册中的电气特性部分。                             |
| 位 4             | PVDE: PVD 使能(Power voltage detector enable)         |
|                 | • 0: 禁止 PVD                                         |
|                 | • 1: 开启 PVD                                         |
| 位 3             | CSBF: 清除待机位(Clear standby flag)                     |
|                 | 读该位始终为0。                                            |
|                 | • 0: 无功效                                            |
|                 | • 1: 清除 SBF 待机位 (写)                                 |
| 位 2             | CWUF: 清除唤醒位(Clear wakeup flag)                      |
|                 | 读该位始终为0。                                            |
|                 | • 0: 不生效                                            |
|                 | • 1: 2 个系统时钟周期后清除 WUF 唤醒位(写)                        |
| 位 1             | PDDS: 掉电深睡眠 (Power down deep sleep)                 |
|                 | 该位与 LPDS 位协同操作。该位由软件设置和清零。                          |
|                 | • 0: 当 CPU 进入深睡眠时,进入停机模式。电压调压器的状态由 LPDS 位控制。        |
|                 | • 1: 当 CPU 进入深睡眠时,进入待机模式。                           |
| 位 0             | LPDS: 低功耗深睡眠(Low-power deep sleep)                  |
| <u> </u> U      | L. DO. INCOMENIA (LOW POWER ACCE)                   |



PDDS=0 时,该位与 PDDS 位协同操作。

- 0: 在停机模式下, 电压调压器开启。
- 1: 在停机模式下,电压调压器处于低功耗模式。

## 5.4.2 电源控制/状态寄存器(PWR\_CSR)

偏移地址: 0x04

复位值: 0x0000 0000 (从待机模式唤醒时不复位)

与标准的 APB 读相比,读此寄存器需要额外的 APB 周期。

| 31 30  | ) 29              | 28                                     | 27                      | 26                    | 25                      | 24                     | 23           | 22         | 2            | 21  | 20                                            | 19             | 18  | 17  |     | 16  |
|--------|-------------------|----------------------------------------|-------------------------|-----------------------|-------------------------|------------------------|--------------|------------|--------------|-----|-----------------------------------------------|----------------|-----|-----|-----|-----|
|        |                   |                                        |                         |                       |                         | Re                     |              |            |              |     |                                               |                |     |     |     |     |
|        |                   |                                        |                         |                       |                         |                        |              |            |              |     |                                               |                |     |     |     |     |
| 15 14  | 13                | 12                                     | 11                      | 10                    | 9                       | 8                      | 7            | 6          | 5            | 4   | 3                                             | 2              | 1   | l l |     | 0   |
|        |                   | Res                                    |                         | ı                     |                         | EWUP                   |              |            | Res          |     |                                               | PVDO           | SE  | 3F  | W   | VUF |
|        |                   |                                        |                         |                       |                         | rw                     |              |            |              |     |                                               | r              | ı   | ſ   |     | r   |
| 位 31:9 | Res:<br>必须仍       | 保留<br>R持复位                             | 立值。                     |                       |                         |                        |              |            |              |     |                                               |                |     |     |     |     |
| 位 8    | • 0:<br>• 1:      | WKUP1<br>WKUP1                         | . 引脚为<br>. 引脚戶          | 为通用<br>用于将            | I/O。\<br>CPU            |                        | 别脚上<br>Stand | 的事<br>lby) | 模式           | 唤醒  | , wĸ                                          | 从待机构<br>UP1 引用 |     |     | 输   | 入下  |
| 位 7:3  | Res:<br>必须你       | 保留<br>R持复位                             | 立值。                     |                       |                         |                        |              |            |              |     |                                               |                |     |     |     |     |
| 位 2    | PVDE • 0: • 1:    | V <sub>DD</sub> /V <sub>DI</sub>       | PVD 使<br>pa 高于<br>pa 低于 | 能)后<br>由 PLS<br>由 PLS | 后,该<br>[2:0]选<br>[2:0]选 | 立有效。<br>定的 PV<br>定的 PV | D 阈值         | 直。         | 莫式店          | 言或复 | 更位直                                           | ·到 PVDE        | 置位。 | 之前  | , i | 亥位  |
| 位 1    | 该位<br>(PW<br>• 0: | 待机标<br>由 硬 件<br>R_CR )<br>系 统<br>系 统 处 | · 设置,<br>的 CSB<br>处于待   | 并 5<br>F 位清<br>机模 z   | 只能由<br>除。               | POR/P                  | DR (.        | 上电         | <b>/</b> 掉 申 | 电复值 | <u>, , , , , , , , , , , , , , , , , , , </u> | 或 设 置 !        | 电源挡 | 空制  | 寄不  | 存器  |
| 位 0    | 该位<br>(PW<br>• 0: | R_CR)<br>未发生                           | · 设置,<br>的 CWI<br>唤醒事   | 并                     | 只能由<br>青除。              | POR/P<br>事件或出          |              |            |              |     | <u>जे</u> ) <u>इ</u>                          | 或设置!           | 电源控 | 空制  | 寄石  | 存器  |

说明: 当WKUP 引脚已经是高电平时,在(通过设置 EWUP 位)使能 WKUP 引脚时,会



检测到一个额外的事件。

## 5.4.3 唤醒引脚极性寄存器(PWR\_POL)

偏移地址: 0x10

复位值: 0x0000 2538 (复位时恢复默认值)

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

位 31:4 Res: 保留 必须保持复位值。 LDO\_VOUT:设置在 MCU 的 Run 模式下,片内 LDO 的输出电压。 位 3:0 • 0000:1.20V • 0001:1.24V • 0010:1.28V • 0011:1.32V • 0100:1.36 V • 0101:1.40 V • 0110:1.44 V • 0111:1.52 V • 1000:1.56 V • 1001:1.60 V • 1010 : 1.64 V • 1011:1.68V • 其他: 禁止设置

# 5.4.4 电源控制/状态寄存器(PWR\_LDO\_STOP)

地址偏移: 0x14

复位值: 0x0000 20b8 (复位时恢复默认值)

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

| 位 31:4 | Res: 保留<br>必须保持复位值。                                      |
|--------|----------------------------------------------------------|
| 位 3:0  | LDO_VOUTS: 设置在 MCU 的 Stop 模式下,片内 LDO 的输出电压。 • 0000:1.20V |

rw



- 0001:1.24V
- 0010:1.28V
- 0011:1.32V
- 0100:1.36 V
- 0101:1.40 V
- 0110:1.44 V
- 0111:1.52 V
- 1000:1.56 V
- 1001:1.60 V
- 1010:1.64 V
- 1011 : 1.68V
- 其他: 禁止设置



### 6备份寄存器(BKP)

备份寄存器由 10 个 16 位的寄存器组成,用于存储用户应用数据(共 20 个字节)。这些寄存器工作在备份域。当 V<sub>DD</sub> 电源被切断,备份域通过 V<sub>BAT</sub> 保持供电。当器件从待机模式或者通过系统复位/电源复位唤醒时,备份寄存器不会被复位。

此外, BKP 控制寄存器用来管理侵入检测和 RTC 校准功能。

复位后,禁止访问备份寄存器和 RTC,并且备份域被保护以防止发生可能的意外写操作。使能备份寄存器和 RTC 的访问,其步骤如下:

- 1. 设置寄存器 RCC\_APB1ENR 的 PWREN 和 BKPEN 位以打开电源和备份接口时钟。
- 2. 设置电源控制寄存器(PWR CR)的 DBP 位,以使能对备份寄存器和 RTC 的访问。

### 6.1 BKP 特性

- 用于管理防侵入检测并具有中断功能的控制/状态寄存器
- 用于存储 RTC 校验值的校准寄存器
- 在 PC13 引脚(当该引脚不用于侵入检测时)上输出 RTC 校准时钟、RTC 闹钟脉冲或者秒脉冲
- 提供 10 个备份域数据寄存器(BKP\_DR0~BKP\_DR10), 共计 20 个字节

### 6.2 BKP 功能描述

### 6.2.1 侵入检测

当 TAMPER 引脚上的信号从'0'变成'1',或者从'1'变成'0'(取决于备份控制寄存器 BKP\_CR 的 TPAL 位),会产生一个侵入检测事件。侵入检测事件会复位所有的备份寄存器。

然而为了避免丢失侵入事件,通过将用于边沿检测的信号和侵入使能信号进行逻辑与运算来检测一个侵入事件。这使得在 TAMPER 引脚被使能之前,产生的侵入事件也能被检测到。

- **当 TPAL=0 时:** 在 TAMPER 引脚的侵入检测功能被使能(通过设置 TPE 位)前,若该引脚已为高电平,一旦使能 TAMPER 引脚则可检测额外的侵入事件(尽管在 TPE 位置'1'后并没有出现上升沿)。
- 当 TPAL=1 时:在 TAMPER 引脚的侵入检测功能被使能(通过设置 TPE 位)前,若该引脚已为低电平,一旦使能 TAMPER 引脚则可检测额外的侵入事件(尽管在 TPE 位置'1'后并没有出现下降沿)。

通过设置 BKP CSR 寄存器的 TPIE 位为'1', 当检测到侵入事件时就会产生一个中断。

在检测到并清除一个侵入事件后,TAMPER 引脚应该被禁用。然后,在再次写备份域数据寄存器(BKP\_DRx)之前,通过配置 TPE 位重新使能 TAMPER 引脚。这样,可以阻止软件在侵入检测引脚上仍然有侵入事件时对备份数据寄存器进行写操作。这相当于对侵入引脚 TAMPER 进行电平检测。

说明:当 V<sub>DD</sub> 电源断开时,侵入检测功能仍然有效。为了避免不必要地复位数据备份寄存器,TAMPER 引脚应该在片外连接到正确的电平。

### 6.2.2 RTC 校准

为方便测量,RTC 时钟可以经 64 分频输出到 TAMPER 引脚上。通过设置 RTC 时钟校准寄存器 (BKP\_RTCCR)的 CCO 位使能该功能。

通过配置 CAL[6:0]位,此时钟可以最多减慢 121 ppm。



### 6.3 BKP 寄存器

基地址: 0x4000 6C00

空间大小: 0x400

BKP 寄存器可以半字(16位)或字(32位)为单位进行访问。

### 6.3.1 备份域数据寄存器 x (BKP\_DRx) (x=1..10)

偏移地址: 0x04 到 0x28 复位值: 0x0000 0000

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

位 15:0 D[15:0]: 备份数据(Backup data)

可写入用户数据至该位域。

注意: BKP\_DRx 寄存器不会被系统复位、电源复位或从待机模式唤醒所复位。它们可以由备份域复位或 TAMPER 引脚事件(如果 TAMPER 引脚的侵入检测功能被开启)复位。

### 6.3.2 RTC 时钟校准寄存器(BKP\_RTCCR)

偏移地址: 0x2C

复位值: 0x0000 0000

| 15 | 14 | 13 | 12 | 11 | 10 | 9    | 8    | 7   | 6 | 5 | 4 | 3      | 2  | 1 | 0 |
|----|----|----|----|----|----|------|------|-----|---|---|---|--------|----|---|---|
|    |    | R  | es |    |    | ASOS | ASOE | CCO |   |   | C | AL[6:0 | )] |   |   |
|    |    |    |    |    |    | rw   | rw   | rw  |   |   |   | rw     |    |   |   |

|       |                                                                                                  | I VV            | I W         | I VV | I W                  |
|-------|--------------------------------------------------------------------------------------------------|-----------------|-------------|------|----------------------|
| 15:10 | Res: 保留<br>必须保持复位值。                                                                              |                 |             |      |                      |
| 位 9   | ASOS:闹钟或秒输出选择(Alar 当 ASOE 被置位,ASOS 位可用于信号。  • 0:输出 RTC 闹钟脉冲  • 1:输出秒脉冲  说明:该位只能通过备份域复位           | 选择在 T           | -           |      |                      |
| 位 8   | ASOE:闹钟或秒输出使能(Alar根据 ASOS 位的设置,配置该位持续时间为一个 RTC 时钟的周期说明:该位只能被备份域的复位                               | 可输出 RT<br>]。设置了 | ·<br>rc 闹钟或 | 秒脉冲到 | 到 TAMPER 引脚上。输出脉冲的   |
| 位 7   | CCO: 校准时钟输出(Calibrated • 0: 无影响 • 1: 此位置'1'可以在侵入检测5 关闭侵入检测功能以避免检测 说明: 当 V <sub>DD</sub> 供电断开时,该位 | 引脚输出约<br>到无用的   | 圣 64 分频     |      | C 时钟。当 CCO 位置'1'时,必须 |



位 6:0

CAL[6:0]: 校准值(Calibration value)

校准值表示在每 2<sup>20</sup> 个时钟脉冲内被忽略的脉冲个数。这可以用来对 RTC 进行校准, 2<sup>20</sup> 个时钟脉冲内被忽略的脉冲个数。

RTC 时钟可以被减慢 0~121ppm。

# 6.3.3 备份控制寄存器(BKP\_CR)

偏移地址: 0x30

复位值: 0x0000 0000

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

| 位 15:2 | Res: 保留<br>必须保持复位值。                                                                                                                                    |
|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 1    | TPAL: TAMPER 引脚有效电平(Effective level on the TAMPER pin)  • 0: TAMPER 引脚上的高电平会复位所有数据备份寄存器(如果 TPE 位置为 1)。  • 1: TAMPER 引脚上的低电平会复位所有数据备份寄存器(如果 TPE 位置为 1)。 |
| 位 0    | TPE: 启动 TAMPER 引脚(Enable the Tamper function on the TAMPER pin)  • 0: TAMPER 引脚用作通用 IO 口  • 1: 开启 TAMPER 引脚的侵入检测复用功能                                   |

说明:同时设置 TPAL 和 TPE 位总是安全的。然而,同时清除两者会产生一个假的侵入事件。因此,推荐仅在 TPE 为 0 时改变 TPAL 位的值。

## 6.3.4 备份控制/状态寄存器(BKP\_CSR)

偏移地址: 0x34

复位值: 0x0000 0000

| 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8   | 7 | 6 | 5   | 4 | 3 | 2    | 1   | 0   |
|----|----|----|----|----|----|-----|-----|---|---|-----|---|---|------|-----|-----|
|    |    | R  | es |    |    | TIF | TEF |   |   | Res |   |   | TPIE | CTI | CTE |
|    |    |    |    |    |    | r   | r   |   |   |     |   |   | rw   | W   | w   |

| 位 15:10 | Res: 保留<br>必须保持复位值。                                                                                                                                                     |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 9     | TIF: 侵入中断标志(Tamper interrupt flag) 当检测到侵入事件且 TPIE 位为 1 时,此位由硬件置'1'。通过向 CTI 位写 1 来清除此位(同时也清除了中断)。如果 TPIE 位被复位,则此位也会被清除。  • 0: 无侵入中断  • 1: 产生侵入中断  注意: 该位仅由系统复位或待机模式唤醒复位。 |
| 位 8     | TEF: 侵入事件标志(Tamper event flag)<br>当检测到侵入事件时,此位由硬件置'1'。通过向 CTE 位写 1 可清除此位。                                                                                               |



| רל יבוי אוינועלים | 2.00 (1.00)                                                                                                                                                                   |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                   | <ul> <li>0: 无侵入事件</li> <li>1: 检测到侵入事件</li> <li>说明: 侵入事件会复位所有的 BKP_DRx 寄存器。只要 TEF 为1,所有的 BKP_DRx 寄存器就一直保持复位状态。当此位被置'1'时,若对 BKP_DRx 进行写操作,写入的值不会被保存。</li> </ul>                 |
| 位 7:3             | Res: 保留<br>必须保持复位值。                                                                                                                                                           |
| 位 2               | TPIE: 使能侵入 TAMPER 引脚中断(TAMPER interrupt detection enable)  • 0: 禁止侵入检测中断  • 1: 使能侵入检测中断(BKP_CR 寄存器的 TPE 位也必须被置'1') <i>说明:</i> • 侵入中断无法将系统内核从低功耗模式唤醒。  • 仅当系统复位或由待机模式唤醒后才复位该位。 |
| 位 1               | <ul> <li>CTI: 清除侵入检测中断(TAMPER interrupt detection flag clear)</li> <li>此位只能写入,读该位值为 0。</li> <li>0: 无效</li> <li>1: 清除侵入检测中断和 TIF 侵入检测中断标志。</li> </ul>                          |
| 位 0               | <ul> <li>CTE: 清除侵入检测事件(TAMPER event detection flag clear)</li> <li>此位只能写入,读该位值为 0。</li> <li>0: 无效</li> <li>1: 清除 TEF 侵入检测事件标志(并且复位侵入检测器)。</li> </ul>                          |

# 6.3.5 控制寄存器(BKP\_LSE\_CTL)

偏移地址: 0x3C

复位值: 0x0000 82C2

| 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    | 4 3 |     | 1  | 0  |
|--------|----|----|-----|----|----|------|-----|----------|-------|-----|------|-----|-----|----|----|
| AGC_EN |    |    | Res |    |    | SEL_ | AGC | AUTO_IOP | NFBYP | Res | IOP_ | MON | Res | IC | )P |
| rw     |    |    |     |    |    | r    | w   | rw       | rw    |     |      | r   |     | r۱ | W  |

| 位 31:16 | Res: 保留<br>必须保持复位值。                                                                                                 |
|---------|---------------------------------------------------------------------------------------------------------------------|
| 位 15    | AGC_EN: 开关 LSE AGC 自动增益电路(LSE AGC automatic gain circuit enable)  • 0: 关闭 LSE AGC 自动增益电路  • 1: 开启并使用 LSE AGC 自动增益电路 |
| 位 14:10 | Res: 保留<br>必须保持复位值。                                                                                                 |



| 位 9:8 | SEL_AGC: 选择 AGC 电路的增益能力(The gain capacity of AGC automatic gain circuit) • 00: 最低档位增益 • • 11: 最高档位增益                                              |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 7   | AUTO_IOP: LSE 驱动档位设置(LSE driven capacity setting)  • 0: IOP[1:0]的 LSE 驱动档位设置值立即生效  • 1: LSE 驱动档位将由 2'b11 逐渐降为 IOP[1:0]的设置值                        |
| 位 6   | NFBYP: 选择 LSE 时钟信号是否经过片内滤噪器(LSE signal handled by the on-chip noise filter)  • 0: LSE 时钟信号经过片内滤噪器后被使用  • 1: LSE 时钟信号不经过片内滤噪器                      |
| 位 5   | Res: 保留<br>必须保持复位值。                                                                                                                               |
| 位 4:3 | IOP_MON: IOP 监测器(IOP detector) 当 AUTO_IOP 位设置为'1'时,IOP[1:0]的设置值不会立即生效;LSE 的驱动档位会由 2'b11 逐渐降为 IOP[1:0]的设置值。在此期间,可通过读取 IOP_MON[1:0]获得当前 LSE 的驱动档位值。 |
| 位 2   | Res: 保留<br>必须保持复位值。                                                                                                                               |
| 位 1:0 | IOP: 用于设置 LSE 晶振电路驱动能力(LSE driven capacity selection)                                                                                             |



## 7 复位和时钟控制(RCC)

### 7.1 复位

HK32F103x8xB 支持三种复位方式:系统复位、电源复位和备份域复位。



图 7-1 复位电路

### 7.1.1 系统复位

除了时钟控制/状态寄存器 RCC\_CSR 中的复位标志位和备份域中的寄存器以外,系统复位将复位所有寄存器至它们的复位值(参见图 5-1)。可通过查看 RCC\_CSR 控制/状态寄存器中的复位状态标志位识别复位事件来源。

当发生以下任一事件时,产生一个系统复位:

- NRST 引脚上的低电平(外部复位)
- 窗口看门狗计数终止(WWDG 复位)
- 独立看门狗计数终止(IWDG 复位)
- 软件复位(SW 复位)
- 低功耗管理复位

系统复位信号会输出至 NRST 引脚。脉冲发生器保证每个复位源(外部和内部)的复位脉冲持续时间至少为 40 us。若发生外部复位,在 NRST 引脚被拉低时会产生复位脉冲。

#### 7.1.1.1 软件复位

通过将 Cortex®-M3 中断应用和复位控制寄存器中的 SYSRESETREQ 位置'1',可产生软件复位将系统强制复位。请参考《Cortex®-M3 技术参考手册》获得进一步信息。

#### 7.1.1.2 低功耗管理复位

在以下两种情况下可产生低功耗管理复位:

- 在进入待机模式时产生低功耗管理复位
   通过将用户选项字节中的 nRST\_STDBY 位置为'0',将使能该复位。此时,即使执行了进入待机模式的操作,系统将被复位而不是进入待机模式。
- 在进入停机模式时产生低功耗管理复位
   通过将用户选项字节中的 nRST\_STOP 位置为'0',将使能该复位。此时,即使执行了进入停机模式的操作,系统将被复位而不是进入停机模式。



### 7.1.2 电源复位

当以下事件中之一发生时,产生电源复位:

- 上电/掉电复位(POR/PDR)
- 从待机模式中返回

电源复位将复位除了备份域外的所有寄存器(参见图 5-1)。

电源复位源将作用于 NRST 引脚并在复位过程中保持低电平。复位服务程序入口矢量在存储器映射的地址被固定在 0x0000 0004,详情可参考表 8-1。

### 7.1.3 备份域复位

备份域拥有两个专用的复位,它们仅作用于备份域(见图 5-1)。

以下任一事件发生, 会产生备份域复位。

- 软件复位:通过设置备份域控制寄存器(RCC\_BDCR)中的 BDRST 位产生。
- 若 V<sub>DD</sub> 和 V<sub>BAT</sub> 都已掉电, V<sub>DD</sub> 或 V<sub>BAT</sub> 再上电将产生备份域复位。

#### 7.2 时钟

以下时钟源均可用于驱动系统时钟(SYSCLK):

- HSI 振荡器时钟
- HSE 振荡器时钟
- PLL 时钟
- 40 kHz 低速内部时钟(LSI) 可用于驱动独立看门狗和 RTC。可选择是否由该时钟驱动 RTC。RTC 用在停机/待机模式下自动唤醒系统。
- 32.768 kHz 低速外部时钟(LSE)
   可用于驱动 RTC(RTCCLK)。可选择是否由它驱动 RTC。

在未被使用时,以上任一时钟源可被独立地打开或关闭,以优化系统功耗。





图 7-2 时钟树

#### 上图说明:

- 该 MCU 支持 32.768 kHz (LSE)或 40k Hz (LSI)作为系统时钟。
- 该 MCU 支持 HSI 时钟作为 PLL 的输入参考时钟,使得最高工作频率达到 96MHz。
- 若需了解内部和外部时钟源特性,请参见《HK32F103x8xB 数据手册》的"电气特性"章节。

通过多个预分频器配置 AHB、高速 APB(APB2)和低速 APB(APB1)域的频率。AHB 和 APB2 域的最大频率是 96MHz。APB1 域的最大允许频率是 48MHz。

RCC 将 AHB 时钟(HCLK)8 分频后作为 Cortex 系统定时器(SysTick)的外部时钟。通过配置 SysTick 控制与状态寄存器,可选择 HCLK/8 时钟或 Cortex(HCLK)时钟作为 SysTick 时钟。

ADC 时钟由高速 APB2 时钟经 2、4、6 或 8 分频后获得。

定时器时钟频率由硬件自动确定,包括2种情况:

- 若 APB 预分频系数为 1,则定时器频率设置为定时器所连接的 APB 域的频率。
- 否则,定时器频率被设置为定时器所连接的APB域频率的2倍。

FCLK 是 Cortex®-M3 的自由运行时钟。详情见 ARM 的《Cortex®-M3 技术参考手册》。

### 7.2.1 HSI 时钟

HSI 时钟信号由内部 8MHz 的 RC 振荡器产生

HSI 时钟默认作为 SYSCLK 的时钟源。

HSI RC 振荡器的优点在于无需使用外部元器件,也能提供时钟源。与 HSE 晶体振荡器相比,它的启



动时间更短。然而,即使在校准之后它的时钟频率精度仍较晶体振荡器/陶瓷谐振器更差。

#### 校准

制造工艺决定了不同芯片的 RC 振荡器频率会不同,这就是为什么每个芯片的 HSI 时钟频率在出厂前已经被校准到 1%(25°C)的原因。系统复位时,工厂校准值被加载到时钟控制寄存器 RCC\_CR 中的 HSICAL[7:0]位。

如果用户的应用基于不同的电压或环境温度,这将会影响 RC 振荡器的精度。可以通过寄存器 RCC\_CR 中的 HSITRIM[4:0]位来调整用户应用的 HSI 频率。寄存器 RCC\_CR 中的 HSIRDY 位用来指示 HSI RC 振荡器是否稳定。在启动过程中,HSI RC 输出时钟直到 HSIRDY 位被硬件置'1'才被释放。通过配置寄存器 RCC CR 中的 HSION 位可打开或关闭 HSI RC。

HSE 晶体振荡器失效, HSI 时钟会被作为备用时钟源。参考章节: "7.2.7 时钟安全系统(CSS)"。

#### 7.2.2 HSE 时钟

高速外部时钟信号(HSE)由以下两种时钟源产生:

- HSE 外部晶体/陶瓷谐振器
- HSE 用户外部时钟

晶体/陶瓷谐振器和负载电容器必须尽可能地靠近振荡器引脚,以使时钟输出的失真和启动稳定时间减到最小。负载电容值必须根据所选择的振荡器来调整。

| 时钟源      | 硬件配置                                                |
|----------|-----------------------------------------------------|
| 外部时钟     | OSC_OUT  (HiZ)  外部 时钟源                              |
| 晶体/陶瓷谐振器 | OSC_IN OSC_OUT  OSC_IN OSC_OUT  CL1 CL2 7/1/1  负载电容 |

表 7-1 HSE/LSE 时钟源

HK32F103x8xB 的 HSE 具有以下特性:

- HSE 时钟信号可经过片内滤噪器后供片内电路使用,以减少环境噪声对 HSE 时钟的影响。
- HSE 晶振振荡稳定的等待时间可配置。
- HSE 晶振引脚驱动能力可配置。

#### 7.2.2.1 外部晶体/陶瓷谐振器(HSE 晶体)

支持 4~16Mz HSE 外部振荡器,可为系统提供更为精确的主时钟。相关的硬件配置见表 7-1。详情可参考《HK32F103x8xB 数据手册》的"电气参数"章节。

时钟控制寄存器(RCC\_CR)中的 HSERDY 位可指示高速外部振荡器是否稳定。在启动时,直到这一位被硬件置'1',该时钟才被释放。如果在时钟中断寄存器 RCC CIR 中使能中断,将会产生相应中断。

通过设置时钟控制寄存器(RCC CR)中的 HSEON 位可打开和关闭 HSE 晶振。



#### 7.2.2.2 外部时钟源(HSE 旁路)

在这个模式里,必须提供外部时钟。它支持频率最高可达 25 MHz。用户可通过设置时钟控制寄存器(RCC\_CR)中的 HSEBYP 和 HSEON 位来选择这一模式。外部时钟信号(50%占空比的方波、正弦波或三角波)必须连到 OSC IN 引脚,同时保证 OSC OUT 引脚为高阻态,见表 7-1。

#### 7.2.3 PLL

内部 PLL 可以用来倍频 HSI RC 的输出时钟或 HSE 晶体输出时钟。参考图 7-2 和章节:"时钟控制寄存器(RCC CR)"。

在使能 PLL 之前必须先完成 PLL 配置(选择 HSI/2、HSI 或 HSE 作为 PLL 输入时钟,以及 PLL 倍频系数),见图 7-2。PLL 的设置(选择输入时钟源和倍频因子)必须在其被激活前完成。

#### 注意:一旦PLL被激活,这些参数就不能被改动。

如果 PLL 中断在时钟中断寄存器(RCC\_CIR)中被使能,当 PLL 准备就绪时,可产生中断。如果需要在应用中使用 USB 接口,PLL 必须被设置为输出 48 或 72 MHZ 时钟,用于分频后提供 48 MHz 的 USBCLK 时钟。PLL 支持的输入/输出频率范围参考芯片数据手册。

#### 7.2.4 LSE 时钟

LSE 晶体是一个 32.768 kHz 的低速外部晶体或陶瓷谐振器。它为 RTC 或者其他定时功能提供一个低功耗、高精度的时钟源。

HK32F103x8xB 的 LSE 具有以下的特性:

- 可以选择经过片内滤噪器后再提供给片内电路使用,以减少环境噪声对 LSE 时钟的干扰。
- LSE 晶振引脚驱动能力可配置。
- LSE 晶振电路带有 AGC 自动增益功能;通过使能 AGC 电路可显著降低 LSE 晶振电流功耗。
- 通过配置备份域控制寄存器(RCC BDCR)中的 LSEON 位,可启动或关闭 LSE 晶体。
- 通过配置寄存器 BKP\_LSE\_CTL 可设置 LSE 的驱动能力和 AGC 功能。
- 备份域控制寄存器(RCC\_BDCR)中的 LSERDY 位指示 LSE 晶体振荡是否已稳定。在启动阶段,直到 LSERDY 位被硬件置'1', LSE 晶体才被释放。如果在时钟中断寄存器(RCC\_CIR)中使能,则可产生中断。

#### 外部时钟源(LSE 旁路)

在该模式下,必须提供外部时钟源,其最高频率为 1MHz。通过配置备份域控制寄存器(RCC\_BDCR)中的 LSEON 位和 LSEBYP 位选择该模式。具有 50%占空比的外部时钟信号(方波、正弦波或三角波)必须连到 OSC32\_IN 引脚,同时保证 OSC32\_OUT 引脚高阻态,见表 7-1 HSE/LSE 时钟源。

### 7.2.5 LSI 时钟

LSI RC 40kHz 可作为低功耗时钟源在停机和待机模式下保持运行,为 IWDG 和自动唤醒单元(AWU)提供时钟。LSI 时钟频率大约 40 kHz(在 30 kHz 和 60 kHz 之间)。详情请参考数据手册中有关电气特性部分。

通过配置控制/状态寄存器(RCC\_CSR)里的 LSION 位来启动或关闭 LSI RC。

控制/状态寄存器(RCC\_CSR)里的 LSIRDY 位指示 LSI RC 是否已稳定。在启动阶段,直到 LSIRDY 位被硬件设置为'1', LSI 时钟才被释放。如果在时钟中断寄存器(RCC\_CIR)里使能中断,将产生 LSI 中断请求。



### 7.2.6 系统时钟(SYSCLK)选择

系统复位后,HSI 时钟(8 MHz)被选为系统时钟。当某个时钟源被直接或通过 PLL 间接作为系统时钟时,它将不能被停止。

只有当目标时钟源准备就绪了(经过启动稳定阶段的延迟或 PLL 稳定),系统时钟才从原来的时钟源切换到该目标时钟。在目标时钟源未准备就绪时,不会切换系统时钟。

在时钟控制寄存器(RCC\_CR)里的状态位指示哪个时钟已经准备就绪,当前哪个时钟用作系统时钟。

### 7.2.7 时钟安全系统(CSS)

通过软件激活时钟安全系统。当 CSS 启用后,在 HSE 振荡器启动稳定后会使能时钟检测器;当 HSE 时钟关闭后会禁用该时钟检测器。

如果 HSE 时钟发生故障,HSE 振荡器被自动关闭,时钟故障事件将被送到高级定时器(TIM1)的刹车输入端,并产生时钟安全中断 CSSF,允许软件完成营救操作。此 CSSF 中断连接到 Cortex®-M3 的非屏蔽中断(NMI)。

CSS 判断 HSE 故障的频率阈值可调,可以通过寄存器 RCC\_HSECTL.CSS\_THRESHOLD 配置。

注意:一旦使能 CSS 且 HSE 时钟出现故障,则发生 CSS 中断,并且自动产生 NMI。NMI 将被不断执行, 直到 CSS 中断挂起位被清除。因此,在 NMI 的处理程序中必须通过设置时钟中断寄存器(RCC\_CIR)里的 CSSC 位来清除 CSS 中断。

如果 HSE 振荡器被直接或间接地作为系统时钟(间接指的是:它作为 PLL 的输入时钟,PLL 的输出时钟作为系统时钟)。若检测到 HSE 时钟故障将导致系统时钟自动切换到 HSI 振荡器,同时外部 HSE 振荡器被禁用。在 HSE 时钟故障时,如果 HSE 时钟(分频或未分频)间接地作为系统时钟,PLL 也将被禁用。

### 7.2.8 RTC 时钟

通过设置备份域控制寄存器(RCC\_BDCR)里的 RTCSEL[1:0]位,从 HSE/128、LSE 或 LSI 时钟中选择 RTCCLK 时钟源。除非备份域复位,否则不能被改变此选择。LSE 时钟在备份域里,但 HSE 和 LSI 时钟不在此域。因此:

- 如果选择 LSE 为 RTC 时钟: 只要 V<sub>BAT</sub>维持供电,尽管 V<sub>DD</sub> 供电被切断,RTC 仍继续工作。
- 如果选择 LSI 为自动唤醒单元(AWU)时钟: 如果 V<sub>DD</sub> 供电被切断,不能保证 AWU 状态。
- 如果 HSE 时钟 128 分频后作为 RTC 时钟:
  - · 如果 V<sub>DD</sub> 供电被切断或内部电压调节器被关闭(core 电压域供电被切断),则无法保证 RTC 状态。
  - 。 必须设置电源控制寄存器(PWR\_CR)的 DPB 位(取消备份域的写保护)为'1'。

### 7.2.9 看门狗时钟

如果独立看门狗已经由硬件选项或软件启动,LSI振荡器将被强制在打开状态,并且不能被禁用。在LSI振荡器稳定后,该时钟供给IWDG。

### 7.2.10 时钟输出

MCU 允许输出时钟信号到外部 MCO 引脚。相应的 GPIO 端口寄存器必须被配置为相应功能。以下



几个时钟信号可被选作 MCO 时钟:

- SYSCLK
- HSE
- HSI/2
- HSI

MCO 时钟的选择由时钟配置寄存器(RCC\_CFGR)中的 MCO[2:0]位控制。

### 7.3 RCC 寄存器

基地址: 0x4002 1000 空间大小: 0x400

# 7.3.1 时钟控制寄存器(RCC\_CR)

偏移地址: 0x00

复位值: 0x0000 XX83

说明: X 代表不定值; 该寄存器支持无等待状态访问, 支持字、半字和字节访问。

|   | 31 | 30 | 29 | 28 | 27  | 26 | 25     | :  | 24  | 23  | 22 | 21 | 20 | 19   | )   | 18     | 17     | 16    |
|---|----|----|----|----|-----|----|--------|----|-----|-----|----|----|----|------|-----|--------|--------|-------|
|   | ,  | ,  | Re | :S |     |    | PLLRDY | PL | LON |     | R  | es |    | CSSC | N F | HSEBYP | HSERDY | HSEON |
|   |    |    |    |    |     |    | r      | 1  | ſW  |     |    | rw | ,  | rw   | r   | rw     |        |       |
| _ | 15 | 14 | 13 |    | 4.2 | 11 | 10     | ٥  |     | T = |    |    | _  | - 1  |     |        | 1 -    | _     |

| 15 | 14          | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6  | 5       | 4   | 3      | 2     | 1 | 0  |
|----|-------------|----|----|----|----|---|---|---|----|---------|-----|--------|-------|---|----|
|    | HSICAL[7:0] |    |    |    |    |   |   |   | HS | ITRIM[4 | Res | HSIRDY | HSION |   |    |
|    | r           |    |    |    |    |   |   |   | rw |         |     |        |       | r | rw |

| 位 30:26 | Res: 保留<br>必须保持复位值。                                                                                                                  |
|---------|--------------------------------------------------------------------------------------------------------------------------------------|
| 位 25    | PLLRDY: PLL 时钟就绪标志(PLL clock ready flag) PLL 锁定后由硬件置'1'。  • 0: PLL 未锁定  • 1: PLL 锁定                                                  |
| 位 24    | PLLON: PLL 使能位(PLL enable)<br>此位由软件置位和清零,以使能 PLL。<br>当进入停机或待机模式时,该位由硬件清零。如果 PLL 时钟用作系统时钟或被选择将要作为系统时钟,该位不能复位。 • 0: PLL 关闭 • 1: PLL 开启 |
| 位 23:20 | Res: 保留<br>必须保持复位值。                                                                                                                  |
| 位 19    | CSSON: 时钟安全系统使能(Clock security system enable)由软件置'1'或清零。<br>设置该位来使能时钟监测器。<br>• 0: 时钟监测器关闭                                            |



| JUNDY CO. 7 |                                                                                                                                                                                                                   |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | • 1: 如果外部 HSE(4-32MHz)振荡器就绪,时钟监测器开启。                                                                                                                                                                              |
| 位 18        | HSEBYP:外部高速时钟旁路(HSE crystal oscillator bypass)在调试模式下由软件置'1'或置'0'。设置该位来旁路外部晶体振荡器。只有在 HSE 振荡器关闭的情况下,才能写入该位。  • 0: HSE 振荡器未被旁路  • 1: HSE 晶体振荡器被旁路                                                                    |
| 位 17        | HSERDY:外部高速时钟就绪标志(HSE clock ready flag)由硬件置'1'来指示 HSE 振荡器已经稳定。在 HSEON 位清零后,该位需要 6 个外部 HSE 振荡器周期清零。  • 0: HSE 振荡器就绪  • 1: HSE 振荡器就绪                                                                                |
| 位 16        | HSEON: 外部高速时钟使能(HSE clock enable)<br>由软件置'1'或清零。<br>当进入待机和停止模式时,该位由硬件清零,关闭 HSE 振荡器。当外部 HSE 振荡器被用作<br>或被选择将要作为系统时钟时,该位不能被清零。<br>• 0: HSE 振荡器关闭<br>• 1: HSE 振荡器开启                                                   |
| 位 15:8      | HSICAL[7:0]: 内部高速时钟校准(HSI clock calibration)<br>在系统启动时,这些位被自动初始化。                                                                                                                                                 |
| 位 7:3       | HSITRIM[4:0]: 内部高速时钟调整(HSI clock trimming)<br>软件可以写入不同值来调整内部高速时钟频率,它们被叠加在 HSICAL[7:0]数值上。这些位在 HSICAL[7:0]的基础上,让用户可以输入一个调整数值,根据电压和温度的变化调整内部 HSI RC 振荡器的频率。<br>默认数值为 16,可以把 HSI 调整到 8MHz±1%;每步 HSICAL 的变化调整约 40kHz。 |
| 位 2         | Res: 保留<br>必须保持复位值。                                                                                                                                                                                               |
| 位 1         | HSIRDY: 内部高速时钟就绪标志(HSI clock ready flag)<br>由硬件置'1'来指示内部 8MHz 振荡器已经稳定。在 HSION 位清零后,该位需要 6 个内部<br>8MHz 振荡器周期清零。<br>• 0: 内部 8MHz 振荡器未就绪<br>• 1: 内部 8MHz 振荡器就绪                                                       |
| 位 <b>0</b>  | HSION: 内部高速时钟使能(HSI clock enable)由软件置'1'或清零。<br>当从待机和停止模式返回或用作系统时钟的 HSE 振荡器发生故障时,该位由硬件置'1'来启动内部 RC 振荡器并分频产生 8MHz 时钟。当内部 8MHz 振荡器被直接或间接地用作或被选择将要用作系统时钟时,该位不能被清零。<br>• 0: 内部 8MHz 时钟关闭                              |



31

• 1: 内部 8MHz 时钟开启

27

26 25

# 7.3.2 时钟配置寄存器(RCC\_CFGR)

偏移地址: 0x04

复位值: 0x0000 0000

30

29

访问: 0 到 2 个等待周期,该寄存器支持字、半字和字节访问;只有当访问发生在时钟切换时,才会插入 1 或 2 个等待周期。

23

21

20 19

18

17

16

24

| PLLHS      | Res                                                                                                                                       | MCO[2:0]                             | Re      | USBPR      | PLLMULL        | [3:0]           |        | PLLXTPR<br>E |         |  |  |  |  |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|---------|------------|----------------|-----------------|--------|--------------|---------|--|--|--|--|
| IPRE<br>rw |                                                                                                                                           | rw                                   | S       | E<br>rw    | rw             |                 | rw     |              | C<br>rw |  |  |  |  |
| 15 14      | 1 13 12 11                                                                                                                                | 10 9 8                               | 7       | 6          | 5 4            | 3               | 2      | 1            | 0       |  |  |  |  |
| ADCPRE     | PPRE2[2:0]                                                                                                                                | PPRE1[2:0]                           | ,       | HPRE       | _              | SWS[1           |        |              | /[1:0]  |  |  |  |  |
| rw         | rw                                                                                                                                        | rw                                   |         | rv         |                | r               |        |              | rw      |  |  |  |  |
| 位 31       | PLLHSIPRE: PLL 的输入 • 0: 选择 HSI 的 2 分 • 1: 选择 HSI 时钟作                                                                                      | 频时钟作为 PLL 的                          |         |            | †∘             |                 |        |              |         |  |  |  |  |
| 位 30:27    | Res: 保留<br>必须保持复位值。                                                                                                                       |                                      |         |            |                |                 |        |              |         |  |  |  |  |
| 位 26:24    | MCO[2:0]: MCU 时钟给由软件置'1'或清零。  Oxx: 没有时钟输出  100: 系统时钟(SY  101: HSI 时钟(8 M  110: HSE 时钟输出  111: PLL/2 时钟输出 <i>注意: 在启动和切换 MC 在系统时钟输出至率)。</i> | SCLK)输出<br>IHz)输出<br>出               | 9寸钟4    | 渝出可能:      | 会被截断。          | <u>ਹ</u> 50 MH. | z (1/0 | 口载           | 長高频     |  |  |  |  |
| 位 23       | Res: 保留<br>必须保持复位值。                                                                                                                       |                                      |         |            |                |                 |        |              |         |  |  |  |  |
| 位 22       | USBPRE: USB 预分频<br>在 RCC_APB1ENR 寄存<br>使能,该位不能被清零<br>• 0: PLL 时钟 1.5 倍分<br>• 1: PLL 时钟直接作为                                                | ·<br>器中使能 USB 时<br>≹。<br>↑频作为 USB 时钟 | ı (PL   | L 输出为      | <b>72</b> MHz) | 经有效。            | 如果 U   | ISB F        | 付钟被     |  |  |  |  |
| 位 21:18    | PLLMULL[3:0]: PLL 倍频                                                                                                                      | 顼系数(PLL mult                         | iplicat | ion factor | r)             |                 |        |              |         |  |  |  |  |



只有在 PLL 关闭的情况下才可被写入。 注意: PLL 的输出频率不能超过 96MHz。 • 0000: PLL 2 倍频输出 • 0001: PLL 3 倍频输出 • 0010: PLL 4 倍频输出 • 0011: PLL 5 倍频输出 • 0100: PLL 6 倍频输出 • 0101: PLL 7 倍频输出 • 0110: PLL 8 倍频输出 • 0111: PLL 9 倍频输出 • 1000: PLL 10 倍频输出 • 1001: PLL 11 倍频输出 • 1010: PLL 12 倍频输出 • 1011: PLL 13 倍频输出 • 1100: PLL 14 倍频输出 • 1101: PLL 15 倍频输出 • 1110 和 1111: PLL 16 倍频输出 位 17 PLLXTPRE: HSE 分频器作为 PLL 输入(HSE divider for PLL input clock) 由软件置'1'或清'0'来分频 HSE 后作为 PLL 输入时钟。只能在关闭 PLL 时才能写入此位。 • 0: HSE 不分频 • 1: HSE 2 分频 位 16 PLLSRC: PLL 输入时钟源(PLL entry clock source) 由软件置'1'或清零来选择 PLL 输入时钟源。仅能在 PLL 关闭时,才能写入此位。 • 0: HSI 时钟作为 PLL 输入时钟 • 1: HSE 时钟作为 PLL 输入时钟 位 15:14 ADCPRE[1:0]: ADC 预分频(ADC prescaler) 该位由软件置'1'或清零来配置 ADC 时钟频率。 • 00: PCLK2 2 分频后作为 ADC 时钟 • 01: PCLK2 4 分频后作为 ADC 时钟 • 10: PCLK2 6 分频后作为 ADC 时钟 • 11: PCLK2 8 分频后作为 ADC 时钟 位 13:11 PPRE2[2:0]: 高速 APB 预分频(APB2)(APB2 prescaler) 该位由软件置'1'或清零,以控制高速 APB2 时钟(PCLK2)的预分频系数。 • 0xx: HCLK 不分频 • 100: HCLK 2 分频 • 101: HCLK 4 分频 • 110: HCLK 8 分频 • 111: HCLK 16 分频



#### 位 10:8

PPRE1[2:0]: 低速 APB 预分频 (APB1) (APB1 prescaler)

该位由软件置'1'或清零,以控制低速 APB1 时钟(PCLK1)的预分频系数。

警告: 软件必须保证 APB1 时钟频率不超过 HCLK(max)/2,即 48MHz。HCLK(max) 表示 HCLK 的最高频率,即 96MHz。

- 0xx: HCLK 不分频
- 100: HCLK 2 分频
- 101: HCLK 4 分频
- 110: HCLK 8 分频
- 111: HCLK 16 分频

#### 位 7:4

HPRE[3:0]: AHB 预分频(HCLK prescaler factor)

该位由软件置'1'或清零,以控制 AHB 时钟的预分频系数。

- 0xxx: SYSCLK 不分频
- 1000: SYSCLK 2 分频
- 1001: SYSCLK 4 分频
- 1010: SYSCLK 8 分频
- 1011: SYSCLK 16 分频
- 1100: SYSCLK 64 分频
- 1101: SYSCLK 128 分频
- 1110: SYSCLK 256 分频
- 1111: SYSCLK 512 分频

注意: 当 AHB 时钟的预分频系数大于 1 时,必须开启预取缓冲器。

#### 位 3:2

SWS[1:0]: 系统时钟切换状态(System clock switch status)

该位由硬件置'1'或清零,用于指示哪个时钟源被作为系统时钟。

- 00: HSI 为系统时钟
- 01: HSE 为系统时钟
- 10: PLL 输出为系统时钟
- 11: 选择 LSI 或 LSE 作为系统时钟(通过 RCC\_LPCLK\_CTL.LCLK\_SEL 来选择)

#### 位 1:0

SW[1:0]: 系统时钟切换(System clock switch)

该位由软件置'1'或清零,以选择系统时钟源。

当在从停机或待机模式中返回或直接/间接作为系统时钟的 HSE 出现故障时,由硬件强制选择 HSI 作为系统时钟(如果 CSS 已经启动)。

- 00: HSI 作为系统时钟
- 01: HSE 作为系统时钟
- 10: PLL 输出作为系统时钟
- 11: 选择 LSI 或 LSE 作为系统时钟(通过 RCC\_LPCLK\_CTL.LCLK\_SEL 来选择)

## 7.3.3 时钟中断寄存器(RCC\_CIR)

偏移地址: 0x08

复位值: 0x0000 0000



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

| 31 | 30  | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20      | 19      | 18      | 17      | 16      |
|----|-----|----|----|----|----|----|----|------|----|----|---------|---------|---------|---------|---------|
|    | Res |    |    |    |    |    |    | CSSC | Re | es | PLLRDYC | HSERDYC | HSIRDYC | LSERDYC | LSIRDYC |
|    |     |    |    |    |    |    |    | w    |    |    | W       | W       | W       | W       | W       |

| 1 | 1   | 1 | 12    | 11    | 10    | 9     | 8      | 7   | 6  | 5  | 4     | 3     | 2     | 1     | 0     |
|---|-----|---|-------|-------|-------|-------|--------|-----|----|----|-------|-------|-------|-------|-------|
| 5 | 4   | 3 |       |       |       |       |        |     |    |    |       |       |       |       |       |
|   | Res |   | PLLRD | HSERD | HSIRD | LSERD | LSIRDY | CSS | Re | es | PLLRD | HSERD | HSIRD | LSERD | LSIRD |
|   |     |   | YIE   | YIE   | YIE   | YIE   | ΙE     | F   |    |    | YF    | YF    | YF    | YF    | YF    |
|   |     |   | rw    | rw    | rw    | rw    | rw     | r   |    |    | r     | r     | r     | r     | r     |

|         | rw            | rw                                            | rw      | rw          | rw    | r     |   | r         | r          | r    | r | r |  |  |  |  |
|---------|---------------|-----------------------------------------------|---------|-------------|-------|-------|---|-----------|------------|------|---|---|--|--|--|--|
| 位 31:24 |               | Res: 保留<br>必须保持复位值。                           |         |             |       |       |   |           |            |      |   |   |  |  |  |  |
| 位 23    | 由软件<br>• 0: Э | 清除时钟<br>置 <b>'1'</b> 来清<br>无作用<br>青除 CSSF     | 除 CSSF  | 安全系统        | 充中断标  | -     | - | n interru | pt flag cl | ear) |   |   |  |  |  |  |
| 位 22:21 |               | Res: 保留<br>必须保持复位值。                           |         |             |       |       |   |           |            |      |   |   |  |  |  |  |
| 位 20    | 由软件<br>• 0: Э | C: 清除  <br>置'1'来清<br>元作用<br>青除 PLL 涼          | 除 PLL â | 忧绪中断        | 标志位」  |       | - | ar)       |            |      |   |   |  |  |  |  |
| 位 19    | 由软件<br>• 0: Э | /C:清除<br>置'1'来清<br><sup>无作用</sup><br>青除 HSE ! | 除 HSE ፤ | 就绪中断        | 标志位   | HSERI | - | lear)     |            |      |   |   |  |  |  |  |
| 位 18    | 由软件<br>• 0: Э | C:清除  <br>置'1'来清<br>元作用<br>青除 HSI 涼           | 除 HSI 京 | 忧绪中断        | 标志位 I |       | - | terrupt   | clear )    |      |   |   |  |  |  |  |
| 位 17    | 由软件<br>• 0: Э | C: 清除<br>置'1'来清<br>无作用<br>青除 LSE <sup>京</sup> | 除 LSE â | 忧绪中断        | 标志位」  |       |   | ear)      |            |      |   |   |  |  |  |  |
| 位 16    | 由软件<br>• 0: Э | C: 清除 L<br>置'1'来清<br>E作用<br>青除 LSI 勍          | 除 LSI 勍 | <b>计绪中断</b> | 示志位 L |       |   | r)        |            |      |   |   |  |  |  |  |
| 位 15:13 | Res: 仍        | <b>R</b> 留                                    |         |             |       |       |   |           |            |      |   |   |  |  |  |  |



| ן לייםי אטיינו עני |                                                                                                                                                             |  |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                    | 必须保持复位值。                                                                                                                                                    |  |
| 位 12               | PLLRDYIE: PLL 就绪中断使能(PLL ready interrupt enable)<br>由软件置'1'或清零来使能或关闭 PLL 就绪中断。<br>• 0: PLL 就绪中断关闭<br>• 1: PLL 就绪中断使能                                        |  |
| 位 11               | HSERDYIE: HSE 就绪中断使能(HSE ready interrupt enable)由软件置'1'或清零来使能或关闭外部 HSE 振荡器就绪中断。  • 0: HSE 就绪中断关闭  • 1: HSE 就绪中断使能                                           |  |
| 位 10               | HSIRDYIE: HSI(8 MHz)就绪中断使能(HSI ready interrupt enable)由软件置'1'或清零来使能或关闭内部 8 MHz RC 振荡器就绪中断。  • 0: HSI 就绪中断关闭  • 1: HSI 就绪中断使能                                |  |
| 位 9                | LSERDYIE: LSE 就绪中断使能(LSE ready interrupt enable)<br>由软件置'1'或清零来使能或关闭外部 32 kHz RC 振荡器就绪中断。<br>• 0: LSE 就绪中断关闭<br>• 1: LSE 就绪中断使能                             |  |
| 位 8                | LSIRDYIE: LSI 就绪中断使能(LSI ready interrupt enable)<br>由软件置'1'或清零来使能或关闭内部 40 kHz RC 振荡器就绪中断。<br>• 0: LSI 就绪中断关闭<br>• 1: LSI 就绪中断使能                             |  |
| 位 7                | CSSF: 时钟安全系统中断标志(Clock security system interrupt flag)在外部 4-16M 振荡器时钟出现故障时,由硬件置'1'。由软件通过将 CSSC 位置'1'来清除。  • 0: 无 HSE 时钟失效产生的安全系统中断  • 1: HSE 时钟失效触发时钟安全系统中断 |  |
| 位 6:5              | Res: 保留<br>必须保持复位值。                                                                                                                                         |  |
| 位 4                | PLLRDYF: PLL 就绪中断标志(PLL ready interrupt flag)在 PLL 就绪且 PLLRDYIE 位被置'1'时,由硬件置'1'。由软件通过将 PLLRDYC 位置'1'来清除。  • 0: 没有由 PLL 锁定引起的时钟就绪中断  • 1: 由 PLL 锁定引起的时钟就绪中断  |  |
| 位 3                | HSERDYF: HSE 就绪中断标志(HSE ready interrupt flag)在 HSE 高速时钟就绪且 HSERDYIE 位被置'1'时,由硬件置'1'。由软件通过将 HSERDYC 位置'1'来清除。                                                |  |



|     | • 0: 无外部 HSE 振荡器产生的时钟就绪中断 • 1: 外部 HSE 振荡器时钟就绪中断                                                                                                                               |
|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 2 | HSIRDYF: HSI(8 MHz)就绪中断标志(HSI ready interrupt flag)在 HSI 时钟就绪且 HSIRDYIE 位被置'1'时,由硬件置'1'。由软件通过将 HSIRDYC 位置'1'来清除。  • 0: 无内部 8 MHz RC 振荡器产生的时钟就绪中断  • 1: 内部 8 MHz RC 振荡器时钟就绪中断。 |
| 位 1 | LSERDYF: LSE 就绪中断标志(LSE ready interrupt flag)在 LSE 时钟就绪且 LSERDYIE 位被置'1'时,由硬件置'1'。由软件通过将 LSERDYC 位置'1'来清除。  • 0: 无外部 32 kHz 振荡器产生的时钟就绪中断  • 1: 外部 32 kHz 振荡器时钟就绪中断            |
| 位 0 | LSIRDYF: LSI 就绪中断标志(LSI ready interrupt flag)在 LSI 时钟就绪且 LSIRDYIE 位被置'1'时,由硬件置'1'。由软件通过将 LSIRDYC 位置'1'来清除。  • 0: 无内部 40 kHz RC 振荡器产生的时钟就绪中断  • 1: 内部 40 kHz RC 振荡器时钟就绪中断      |

# 7.3.4 APB2 外设复位寄存器(RCC\_APB2RSTR)

偏移地址: 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     |
|---|----|--------|----|-------|-------|------|------|-------|-----|-------|-------|-------|-------|----|-------|
|   | Re | USART1 | Re | SPI1R | TIM1R | ADC2 | ADC1 | IOPGR | Res | IOPDR | IOPCR | IOPBR | IOPAR | Re | AFIOR |
|   | S  | RST    | S  | ST    | ST    | RST  | RST  | ST    |     | ST    | ST    | ST    | ST    | S  | ST    |
| ĺ |    | rw     |    | rw    | rw    | rw   | rw   | rw    |     | rw    | rw    | rw    | rw    |    | rw    |

| 位 31:15 | Res: 保留<br>必须保持复位值。                                                             |
|---------|---------------------------------------------------------------------------------|
| 位 14    | USART1RST: USART1 复位(Reset USART1)<br>由软件置'1'或清零。<br>• 0: 无作用<br>• 1: 复位 USART1 |
| 位 13    | Res: 保留<br>必须保持复位值。                                                             |
| 位 12    | SPI1RST: SPI1 复位(Reset SPI1)                                                    |



| ו לייםי אטילים ער |                                                                                        |
|-------------------|----------------------------------------------------------------------------------------|
|                   | 由软件置'1'或清零。 • 0: 无作用 • 1: 复位 SPI1                                                      |
| 位 11              | TIM1RST: TIM1 复位(Reset TIM1)<br>由软件置'1'或清零。<br>• 0: 无作用<br>• 1: 复位 TIM1 定时器            |
| 位 10              | ADC2RST: ADC2 接口复位(Reset ADC2 interface)<br>由软件置'1'或清零。<br>• 0: 无作用<br>• 1: 复位 ADC2 接口 |
| 位 9               | ADC1RST: ADC1 接口复位(Reset ADC1 interface)<br>由软件置'1'或清零。<br>• 0: 无作用<br>• 1: 复位 ADC1 接口 |
| 位 8               | IOPGRST: IO 端口 G 复位(Reset IO G)<br>由软件置'1'或清零。<br>• 0: 无作用<br>• 1: 复位 IO 端口 G          |
| 位 7:6             | Res: 保留<br>必须保持复位值。                                                                    |
| 位 5               | IOPDRST: IO 端口 D 复位(Reset IO D)<br>由软件置'1'或清零。<br>• 0: 无作用<br>• 1: 复位 IO 端口 D          |
| 位 4               | IOPCRST: IO 端口 C 复位(Reset IO C)<br>由软件置'1'或清零。<br>• 0: 无作用<br>• 1: 复位 IO 端口 C          |
| 位 3               | IOPBRST: IO 端口 B 复位(Reset IO B)<br>由软件置'1'或清零。<br>• 0: 无作用<br>• 1: 复位 IO 端口 B          |
| 位 2               | IOPARST: IO 端口 A 复位(Reset IO A)<br>由软件置'1'或清零。<br>• 0: 无作用                             |



|     | • 1: 复位 IO 端口 A                                                            |
|-----|----------------------------------------------------------------------------|
| 位 1 | Res: 保留<br>必须保持复位值。                                                        |
| 位 0 | AFIORST: 复用功能 I/O 复位(Reset AFIO)<br>由软件置'1'或清零。<br>• 0: 无作用<br>• 1: 复位复用功能 |

# 7.3.5 APB1 外设复位寄存器(RCC\_APB1RSTR)

偏移地址: 0x10

复位值: 0x0000 0000

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

|     |    |        |     |    |       |     |     |    |    |       |   |        |        |        |     | 1     |     |      |     |    |
|-----|----|--------|-----|----|-------|-----|-----|----|----|-------|---|--------|--------|--------|-----|-------|-----|------|-----|----|
| 3   | 3  | 29     | 28  |    | 27    | 26  | 25  | 5  | 24 | 23    |   | 22     | 21     | 2      | 1   | 18    |     | 17   | 7   | 16 |
| 1   | 0  |        |     |    |       |     |     |    |    |       |   |        |        | 0      | 9   |       |     |      |     |    |
|     | Re | :S     | PWF | RR | BKPRS | Re  | CAN | RS | Re | USBRS | 3 | I2C2RS | I2C1RS | R      | es  | USART | 3R  | USAR | T2R | Re |
|     |    |        | ST  |    | T     | S   | Т   |    | S  | T     |   | T      | T      |        |     | ST    |     | ST   | -   | S  |
|     |    |        | rw  | '  | rw    |     | rv  | ٧  |    | rw    |   | rw     | rw     |        |     | rw    |     | rw   | 1   |    |
|     |    |        |     | _  | 1     |     |     | _  | 0  |       | _ | _      |        |        |     | 2     |     | _    |     | _  |
| 15  | 1  | 14     | 1   | 1  | 11    | L   | 1   | 9  | 8  | /     | 6 | 5      | 4      | 3      |     | 2     |     | 1    |     | 0  |
|     |    |        | 3   | 2  |       |     | 0   |    |    |       |   |        |        |        |     |       |     |      |     |    |
| Res | 6  | SPI2RS | R   | es | WWD   | GRS | Res |    |    |       |   |        | 1      | TIM4RS | TIN | M3RS  | TIM | I2RS |     |    |

| r       | W                | rw                   |                             | rw | rw | rw |
|---------|------------------|----------------------|-----------------------------|----|----|----|
| 位 31:29 | Res: 保留<br>必须保持  |                      |                             |    |    |    |
| 位 28    |                  | <b>1</b> '或清零。<br>=用 | [位 (Power interface reset ) |    |    |    |
| 位 27    |                  | 1′或清零。<br>=用         | 位(Backup interface reset )  |    |    |    |
| 位 26    | Res: 保留<br>必须保持分 |                      |                             |    |    |    |
| 位 25    |                  |                      | CAN reset)                  |    |    |    |
| 位 24    | Res: 保留          |                      |                             |    |    |    |



|         | 必须保持复位值。                                                                           |
|---------|------------------------------------------------------------------------------------|
| 位 23    | USBRST: USB 复位(USB reset)<br>由软件置'1'或清零。<br>• 0: 无作用<br>• 1: 复位 USB                |
| 位 22    | I2C2RST: I2C2 复位(I2C2 reset)<br>由软件置'1'或清零。<br>• 0: 无作用<br>• 1: 复位 I2C2            |
| 位 21    | I2C1RST: I2C1 复位(I2C1 reset)<br>由软件置'1'或清零。<br>• 0: 无作用<br>• 1: 复位 I2C1            |
| 位 20:19 | Res: 保留<br>必须保持复位值。                                                                |
| 位 18    | USART3RST: USART3 复位(USART3 reset)<br>由软件置'1'或清零。<br>• 0: 无作用<br>• 1: 复位 USART3    |
| 位 17    | USART2RST: USART2 复位(USART2 reset)<br>由软件置'1'或清零。<br>• 0: 无作用<br>• 1: 复位 USART2    |
| 位 16:15 | Res: 保留<br>必须保持复位值。                                                                |
| 位 14    | SPI2RST: SPI2 复位(SPI2 reset)<br>由软件置'1'或清零。<br>• 0: 无作用<br>• 1: 复位 SPI2            |
| 位 13:12 | Res: 保留<br>必须保持复位值。                                                                |
| 位 11    | WWDGRST: WWDG 复位(Window watchdog reset)<br>由软件置'1'或清零。<br>• 0: 无作用<br>• 1: 复位 WWDG |



| 位 10:3 | Res: 保留<br>必须保持复位值。                                                            |
|--------|--------------------------------------------------------------------------------|
| 位 2    | TIM4RST: 定时器 4 复位(Timer4 reset)<br>由软件置'1'或清零。<br>• 0: 无作用<br>• 1: 复位 TIM4 定时器 |
| 位 1    | TIM3RST: 定时器 3 复位(Timer3 reset)<br>由软件置'1'或清零。<br>• 0: 无作用<br>• 1: 复位 TIM3 定时器 |
| 位 0    | TIM2RST: 定时器 2 复位(Timer2 reset)<br>由软件置'1'或清零。<br>• 0: 无作用<br>• 1: 复位 TIM2 定时器 |

# 7.3.6 AHB 外设时钟使能寄存器(RCC\_AHBENR)

偏移地址: 0x14

复位值: 0x00000014

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

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

| 15 | 5   1/1   13   12   11   10   9   9   7 |  |  |  | 6 | 5 | 4 | 3 | 2     | 1   | 0       |     |        |     |        |
|----|-----------------------------------------|--|--|--|---|---|---|---|-------|-----|---------|-----|--------|-----|--------|
|    | Res                                     |  |  |  |   |   |   |   | CRCEN | Res | FLITFEN | Res | SRAMEN | Res | DMA1EN |
|    |                                         |  |  |  |   |   |   |   | rw    |     | rw      |     | rw     |     | rw     |

| 位 31:17 | Res: 保留<br>必须保持复位值。                                                                |
|---------|------------------------------------------------------------------------------------|
| 位       |                                                                                    |
| 位 6     | CRCEN: CRC 时钟使能(CRC clock enable)<br>由软件置'1'或清零。<br>• 0: CRC 时钟关闭<br>• 1: CRC 时钟开启 |
| 位 5     | Res: 保留<br>必须保持复位值。                                                                |
| 位 4     | FLITFEN: Flash 接口电路时钟使能(FLITF clock enable)<br>由软件置'1'或清零来开启或关闭睡眠模式下 Flash 接口电路时钟。 |



|     | <ul><li>0: 睡眠模式下, Flash 接口电路时钟关闭</li><li>1: 睡眠模式下, Flash 接口电路时钟开启</li></ul>                                                      |
|-----|----------------------------------------------------------------------------------------------------------------------------------|
| 位 3 | Res: 保留<br>必须保持复位值。                                                                                                              |
| 位 2 | SRAMEN: SRAM 时钟使能(SRAM interface clock enable)<br>由软件置'1'或清零来开启或关闭睡眠模式下 SRAM 时钟。<br>• 0: 睡眠模式时,SRAM 时钟关闭<br>• 1: 睡眠模式时,SRAM 时钟开启 |
| 位 1 | Res: 保留<br>必须保持复位值。                                                                                                              |
| 位 0 | DMA1EN: DMA1 时钟使能(DMA1 clock enable)<br>由软件置'1'或清零。<br>• 0: DMA1 时钟关闭<br>• 1: DMA1 时钟开启                                          |

# 7.3.7 APB2 外设时钟使能寄存器(RCC\_APB2ENR)

偏移地址: 0x18

复位值: 0x0000 0000

访问: 支持字, 半字和字节访问

通常访问无等待周期。但当 APB2 总线上的外设被访问时,将插入等待状态直到 APB2 的外设访问结束。

说明: 当外设时钟没有启用时,软件不能读出外设寄存器的数值,返回的数值始终是 0x0。

| 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     | 1 |
|----|---------|----|-------|--------|-------|-------|---|-----|---|-------|-------|-------|-------|----|-------|---|
| Re | USART1E | Re | SPI1E | TIM1EN | ADC2E | ADC1E |   | Res |   | IOPDE | IOPCE | IOPBE | IOPAE | Re | AFIOE | 1 |
| S  | N       | S  | N     | N      | N     | N     | N |     |   | N     | N     | N     | N     | S  | N     |   |
|    | rw      |    | rw    | rw     | rw    | rw    |   |     |   | rw    | rw    | rw    | rw    |    | rw    | 1 |

| 位 31:15 | Res: 保留<br>必须保持复位值。                                                                               |
|---------|---------------------------------------------------------------------------------------------------|
| 位 14    | USART1EN: USART1 时钟使能(USART1 clock enable)<br>由软件置'1'或清零。<br>• 0: USART1 时钟关闭<br>• 1: USART1 时钟开启 |
| 位 13    | Res: 保留<br>必须保持复位值。                                                                               |



| 位 12  | SPI1EN: SPI1 时钟使能(SPI1 clock enable)<br>由软件置'1'或清零。<br>• 0: SPI1 时钟关闭<br>• 1: SPI1 时钟开启                 |
|-------|---------------------------------------------------------------------------------------------------------|
| 位 11  | TIM1EN: TIM1 定时器时钟使能(TIM1 Timer clock enable)由软件置'1'或清零。  • 0: TIM1 定时器时钟关闭  • 1: TIM1 定时器时钟开启          |
| 位 10  | ADC2EN: ADC2 接口时钟使能(ADC2 interface clock enable)<br>由软件置'1'或清零。<br>• 0: ADC2 接口时钟关闭<br>• 1: ADC2 接口时钟开启 |
| 位 9   | ADC1EN: ADC1 接口时钟使能(ADC1 interface clock enable)<br>由软件置'1'或清零。<br>• 0: ADC1 接口时钟关闭<br>• 1: ADC1 接口时钟开启 |
| 位 8:6 | Res: 保留<br>必须保持复位值。                                                                                     |
| 位 5   | IOPDEN: GPIOD 组端口的时钟使能(I/O port D clock enable)由软件置'1'或清零。  • 0: GPIOD 组端口的时钟关闭  • 1: GPIOD 组端口的时钟开启    |
| 位 4   | IOPCEN: GPIOC 组端口的时钟使能(I/O port C clock enable)由软件置'1'或清零。  • 0: GPIOC 组端口的时钟关闭  • 1: GPIOC 组端口的时钟开启    |
| 位 3   | IOPBEN: GPIOB 组端口的时钟使能(I/O port B clock enable)由软件置'1'或清零。  • 0: GPIOB 组端口的时钟关闭  • 1: GPIOB 组端口的时钟开启    |
| 位 2   | IOPAEN: GPIOA 组端口的时钟使能(I/O port A clock enable)由软件置'1'或清零。  • 0: GPIOA 组端口的时钟关闭  • 1: GPIOA 组端口的时钟开启    |
| 位 1   | Res: 保留                                                                                                 |



|     | 必须保持复位值。                                                   |
|-----|------------------------------------------------------------|
| 位 0 | AFIOEN: 复用功能 I/O 时钟使能(Alternate function I/O clock enable) |
|     | 由软件置'1'或清零。  • 0: 复用功能 I/O 时钟关闭                            |
|     | • 1: 复用功能 I/O 时钟开启                                         |

# 7.3.8 APB1 外设时钟使能寄存器(RCC\_APB1ENR)

偏移地址: 0x1C

复位值: 0x0000 0000

访问: 支持字、半字和字节访问

通常无访问等待周期。但在 APB1 总线上的外设被访问时,将插入等待状态直到 APB1 外设访问结束。

说明: 当外设时钟没有启用时, 软件不能读出外设寄存器的数值, 返回的数值始终是 0x0。

| 3 | 3   | 29 | 28   | 27   | 26 | 25   | 24 | 23   | 22    | 21    | 20 | 19 | 18      | 17      | 16 |
|---|-----|----|------|------|----|------|----|------|-------|-------|----|----|---------|---------|----|
| 1 | 1 0 |    |      |      |    |      |    |      |       |       |    |    |         |         |    |
|   | Res |    | PWRE | BKPE | Re | CANE | Re | USBE | I2C2E | I2C1E | Re | es | USART3E | USART2E | Re |
|   |     |    | N    | N    | S  | N    | S  | N    | N     | N     |    |    | N       | N       | S  |
|   |     |    | rw   | rw   |    | rw   |    | rw   | rw    | rw    |    |    | rw      | rw      |    |

| 15  | 14     | 13 | 12 | 11     | 10 | 9 | 8 | 7 | 6 | 5   | 4 | 3 | 2      | 1      | 0      |
|-----|--------|----|----|--------|----|---|---|---|---|-----|---|---|--------|--------|--------|
| Res | SPI2EN | Re | es | WWDGEN |    |   |   |   |   | Res |   |   | TIM4EN | TIM3EN | TIM2EN |
|     | rw     |    |    | rw     |    |   |   |   |   |     |   |   | rw     | rw     | rw     |

| 位 31:29 | Res: 保留<br>必须保持复位值。                                                                                           |
|---------|---------------------------------------------------------------------------------------------------------------|
| 位 28    | PWREN: 电源接口时钟使能(Power interface clock enable)         由软件置'1'或清零。         • 0: 电源接口时钟关闭         • 1: 电源接口时钟开启 |
| 位 27    | BKPEN: 备份接口时钟使能(Backup interface clock enable)<br>由软件置'1'或清零。<br>• 0: 备份接口时钟关闭<br>• 1: 备份接口时钟开启               |
| 位 26    | Res: 保留<br>必须保持复位值。                                                                                           |
| 位 25    | CAN1EN: CAN 时钟使能(CAN clock enable)<br>由软件置'1'或清零。<br>• 0: CAN 时钟关闭<br>• 1: CAN 时钟开启                           |
| 位 24    | Res: 保留<br>必须保持复位值。                                                                                           |



| 位 23    | USBEN: USB 时钟使能(USB clock enable)<br>由软件置'1'或清零。<br>• 0: USB 时钟关闭<br>• 1: USB 时钟开启                                                   |
|---------|--------------------------------------------------------------------------------------------------------------------------------------|
| 位 22    | I2C2EN: I2C2 时钟使能(I2C2 clock enable)<br>由软件置'1'或清零。<br>• 0: I2C2 时钟关闭<br>• 1: I2C2 时钟开启                                              |
| 位 21    | I2C1EN: I2C1 时钟使能(I2C1 clock enable)<br>由软件置'1'或清零。<br>• 0: I2C1 时钟关闭<br>• 1: I2C1 时钟开启                                              |
| 位 20:19 | Res: 保留<br>必须保持复位值。                                                                                                                  |
| 位 18    | USART3EN: USART3 时钟使能(USART3 clock enable)<br>由软件置'1'或清零。<br>• 0: USART3 时钟关闭<br>1: USART3 时钟开启                                      |
| 位 17    | USART2EN: USART2 时钟使能(USART2 clock enable)<br>由软件置'1'或清零。<br>• 0: USART2 时钟关闭<br>• 1: USART2 时钟开启                                    |
| 位 16:15 | Res: 保留<br>必须保持复位值。                                                                                                                  |
| 位 14    | SPI2EN: SPI2 时钟使能(SPI2 clock enable)<br>由软件置'1'或清零。<br>• 0: SPI2 时钟关闭<br>• 1: SPI2 时钟开启                                              |
| 位 13:12 | Res: 保留<br>必须保持复位值。                                                                                                                  |
| 位 11    | <ul> <li>WWDGEN: 窗口看门狗时钟使能(Window watchdog clock enable)</li> <li>由软件置'1'或清零。</li> <li>0: 窗口看门狗时钟关闭</li> <li>1: 窗口看门狗时钟开启</li> </ul> |
| 位 10:3  | Res: 保留                                                                                                                              |



|     | 必须保持复位值。                                                                                     |
|-----|----------------------------------------------------------------------------------------------|
| 位 2 | TIM4EN: 定时器 4 时钟使能(Timer4 clock enable)<br>由软件置'1'或清零。<br>• 0: 定时器 4 时钟关闭<br>• 1: 定时器 4 时钟开启 |
| 位 1 | TIM3EN: 定时器 3 时钟使能(Timer3 clock enable)<br>由软件置'1'或清零。<br>• 0: 定时器 3 时钟关闭<br>• 1: 定时器 3 时钟开启 |
| 位 0 | TIM2EN: 定时器 2 时钟使能(Timer2 clock enable)<br>由软件置'1'或清零。<br>• 0: 定时器 2 时钟关闭<br>• 1: 定时器 2 时钟开启 |

## 7.3.9 备份域控制寄存器(RCC\_BDCR)

份域复位")。任何内部或外部复位都不会影响这些位。

偏移地址: 0x20

复位值: 0x0000 0000

访问: 0 到 3 等待周期,支持字、半字和字节访问; 当连续对该寄存器进行访问时,将插入等待状态。 注意: 寄存器 RCC\_BDCR 中的 LSEON、LSEBYP、RTCSEL 和 RTCEN 位处于备份域。因此,这些位在复位后 处于写保护状态,只有在电源控制寄存器(PWR\_CR)中的 DBP 位置'1'后,才能对这些位进行修改。详 情请参考章节: "5.4.1 电源控制寄存器(PWR\_CR)"。这些位只能由备份域复位清除(见章节: "7.1.3 备

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

| 15    | 14  | 13 | 12 | 11 | 10    | 9      | 8   | 7 | 6 | 5 | 4 | 3      | 2      | 1     | 0 |
|-------|-----|----|----|----|-------|--------|-----|---|---|---|---|--------|--------|-------|---|
| RTCEN | Res |    |    |    | RTCSE | L[1:0] | Res |   |   |   |   | LSEBYP | LSERDY | LSEON |   |
| rw    |     |    |    |    | r۱    | N      |     |   |   |   |   | rw     | r      | rw    |   |

| 位 31:17 | Res: 保留<br>必须保持复位值。                                                                       |
|---------|-------------------------------------------------------------------------------------------|
| 位 16    | BDRST: 备份域软件复位(Backup domain software reset)<br>由软件置'1'或清零。<br>• 0: 复位未激活<br>• 1: 复位整个备份域 |
| 位 15    | RTCEN: RTC 时钟使能(RTC clock enable)<br>由软件置'1'或清零。<br>• 0: RTC 时钟关闭<br>• 1: RTC 时钟开启        |



| 位 14:10 | Res: 保留<br>必须保持复位值。                                                                                                                                                                             |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 9:8   | RTCSEL[1:0]: RTC 时钟源选择(RTC clock source selection)<br>由软件设置来选择 RTC 时钟源。一旦 RTC 时钟源被选定,直到下次备份域被复位之前,它<br>不能被改变。可通过设置 BDRST 位来清除。<br>• 00: 无时钟<br>• 01: LSE 振荡器作为 RTC 时钟<br>• 10: LSI 振荡器作为 RTC 时钟 |
| 位 7:3   | Res: 保留<br>必须保持复位值。                                                                                                                                                                             |
| 位 2     | LSEBYP: 外部低速时钟振荡器旁路(External low-speed oscillator bypass)在调试模式下,由软件置'1'或清零来旁路 LSE。<br>只有在外部 32 kHz 振荡器关闭时,才能写入该位。<br>• 0: LSE 时钟未被旁路<br>• 1: LSE 时钟被旁路                                          |
| 位 1     | LSERDY: 外部低速振荡器就绪(External low-speed oscillator ready)由硬件置'1'或清零来指示外部 32 kHz 振荡器是否就绪。在 LSEON 被清零后,该位需要 6 个外部低速振荡器的周期才被清零。  • 0: 外部 32 kHz 振荡器未就绪  • 1: 外部 32 kHz 振荡器就绪                          |
| 位 0     | LSEON: 外部低速振荡器使能(External low-speed oscillator enable)由软件置'1'或清零。  • 0: 外部 32 kHz 振荡器关闭  • 1: 外部 32 kHz 振荡器开启                                                                                   |

# 7.3.10 时钟控制/状态寄存器(RCC\_CSR)

偏移地址: 0x24

复位值: 0x0C000000

说明:除复位标志外由系统复位清除,复位标志只能由电源复位清除。支持 0 到 3 等待周期访问,字、半字和字节访问。

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

| 31      | 30      | 29      | 28     | 27     | 26     | 25 | 24  | 2 | 2 | 2 | 2  | 1  | 1 | 1 | 1 |
|---------|---------|---------|--------|--------|--------|----|-----|---|---|---|----|----|---|---|---|
|         |         |         |        |        |        |    |     | 3 | 2 | 1 | 0  | 9  | 8 | 7 | 6 |
| LPWRRST | WWDGRST | IWDGRST | SFTRST | PORRST | PINRST | Re | RMV |   |   |   | Re | es |   |   |   |
| F       | F       | F       | F      | F      | F      | S  | F   |   |   |   |    |    |   |   |   |
| rw      | rw      | rw      | rw     | rw     | rw     |    | rw  |   |   |   |    |    |   |   |   |

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



| 位 31   | LPWRRSTF: 低功耗复位标志(Low-power reset flag)<br>在低功耗管理复位发生时,由硬件置'1'。由软件通过写 RMVF 位清除。<br>• 0: 无低功耗管理复位发生<br>• 1: 发生低功耗管理复位<br>关于低功耗管理复位的详细信息,请参考: "7.1.1.2 低功耗管理复位"。 |
|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 30   | WWDGRSTF: 窗口看门狗复位标志(Window watchdog reset flag)在窗口看门狗复位发生时,由硬件置'1'。由软件通过写 RMVF 位清除。  • 0: 无窗口看门狗复位发生  • 1: 发生窗口看门狗复位                                           |
| 位 29   | IWDGRSTF: 独立看门狗复位标志(Independent watchdog reset flag)在独立看门狗复位发生在 V <sub>DD</sub> 区域时,由硬件置'1'。由软件通过写 RMVF 位清除。  • 0: 无独立看门狗复位发生  • 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   | Res: 保留<br>必须保持复位值。                                                                                                                                            |
| 位 24   | RMVF: 清除复位标志(Remove reset flag)<br>由软件置'1'来清除复位标志。<br>• 0: 无作用<br>• 1: 清除复位标志                                                                                  |
| 位 23:2 | Res: 保留<br>必须保持复位值。                                                                                                                                            |
| 位 1    | LSIRDY: 内部低速振荡器就绪(Internal low-speed oscillator ready)<br>由硬件置'1'或清零来指示内部 40 kHz RC 振荡器是否就绪。                                                                   |



|     | 在 LSION 清零后,在 3 个内部 40 kHz RC 振荡器的周期后 LSIRDY 被清零。  • 0: 内部 40 kHz RC 振荡器时钟未就绪  • 1: 内部 40 kHz RC 振荡器时钟就绪            |
|-----|---------------------------------------------------------------------------------------------------------------------|
| 位 0 | LSION: 内部低速振荡器使能(Internal low-speed oscillator enable)由软件置'1'或清零。  • 0: 内部 40 kHz RC 振荡器关闭  • 1: 内部 40 kHz RC 振荡器开启 |

# 7.3.11 HSE 控制寄存器(RCC\_HSECTL)

偏移地址: 0x28

复位值: 0x0104 0004

| 31             | 30   | 29      | 28         | 27         | 26              | 25    | 24              | ļ           | 23           | 22           | 21          | 20   | 19       | 18            | 17     | 16   |
|----------------|------|---------|------------|------------|-----------------|-------|-----------------|-------------|--------------|--------------|-------------|------|----------|---------------|--------|------|
|                |      |         | Res        |            |                 |       | HSENF           |             |              |              | Res         |      |          | XTA           | L32M[7 | ':0] |
|                |      |         |            |            |                 |       | rw              | /           |              |              |             |      |          |               | rw     |      |
| 15             | 14   | 13      |            | 12         | 11              | 10    | 9               | 8           | 7            | 6            | 5           | 4    | 3        | 2             | 1      | 0    |
| Re             | es   |         |            |            |                 |       |                 | HS          | EWT[11<br>rw | :0]          |             |      |          |               |        |      |
|                |      |         |            |            |                 |       |                 |             |              |              |             |      |          |               |        |      |
| 位 31           | :25  | Res:    | 保留         |            |                 |       |                 |             |              |              |             |      |          |               |        |      |
|                |      | 必须供     | 录持复        | 位值。        |                 |       |                 |             |              |              |             |      |          |               |        |      |
|                |      |         |            |            |                 |       |                 |             |              |              |             |      |          |               |        |      |
| 位 24           |      | HSENF   | BYP:       | 开或         | 关 HSE           | 去噪声   | <sup>吉</sup> 功能 | (HSE        | noise        | filter b     | ypass       | )    |          |               |        |      |
|                |      | • 1:    | 关闭 :       | HSE 去「     | 噪声功             | 能     |                 |             |              |              |             |      |          |               |        |      |
|                |      | • 0:    | 打开!        | HSE 去「     | 噪声功             | 能     |                 |             |              |              |             |      |          |               |        |      |
|                |      |         |            |            | )(i) ) <b>4</b> | 170   |                 |             |              |              |             |      |          |               |        |      |
| 位 23           | :19  | Res:    | 保留         |            |                 |       |                 |             |              |              |             |      |          |               |        |      |
|                |      | 必须供     | 录持复        | 位值。        |                 |       |                 |             |              |              |             |      |          |               |        |      |
|                |      |         |            |            |                 |       |                 |             |              |              |             |      |          |               |        |      |
| 位 18           | 3:16 | XCH_I   | OP[2:0     | )]:        |                 |       |                 |             |              |              |             |      |          |               |        |      |
|                |      | • 000   | : 驱z       | <b>动电流</b> | 大约为             | 20μΑ  | ,推荐             | 使用(         | 0.5 ~ 3      | MHz 🖁        | 猖振。         |      |          |               |        |      |
|                |      | • 001   | : 驱z       | <b></b>    | 大约为             | 30uA  | ,推荐             | 使用(         | 0.5 ~ 4      | MHz 🗄        | <b>書振。</b>  |      |          |               |        |      |
|                |      |         |            | 动电流        |                 | -     |                 |             |              |              |             |      |          |               |        |      |
|                |      |         |            | 功电流        |                 | -     |                 |             |              |              |             |      |          |               |        |      |
|                |      |         |            |            |                 | -     |                 |             |              |              |             |      |          |               |        |      |
|                |      |         |            | 功电流        |                 | -     |                 |             |              |              |             |      |          |               |        |      |
|                |      | • 101   | : 驱z       | 功电流        | 大约为             | 80μΑ  | ,推荐             | 使用 2        | 2 ~ 151      | ∕IHz         | <b>撮振</b> 。 |      |          |               |        |      |
|                |      | • 110   | : 驱z       | カ电流 たんしん   | 大约为             | 100μΑ | 4,推荐            | <b>梦使用</b>  | 3 ~ 20       | )MHz i       | 晶振。         |      |          |               |        |      |
|                |      | • 111   | : 驱z       | 动电流        | 大约为             | 200μΑ | 4,推荐            | 使用          | 5 ~ 30       | )MHz ;       | 晶振。         |      |          |               |        |      |
|                |      |         |            |            |                 |       |                 |             |              |              |             |      |          |               |        |      |
| 位 15           | 5:14 | Res:    | 保留         |            |                 |       |                 |             |              |              |             |      |          |               |        |      |
|                |      | 必须供     | 录持复        | 位值。        |                 |       |                 |             |              |              |             |      |          |               |        |      |
| <i>1</i> → 4 ⊃ | 0    | LICEY ( | T[4 0]     | UCE        | 44 <u>六</u> n.4 | 治され   | 型 / 1167        | <b>-</b> •• | 11 C         |              | :1:= - + *  |      | >        |               |        |      |
| 位 13           | 3:0  |         |            | : HSE      |                 |       |                 |             |              |              |             |      | _        |               |        |      |
|                |      |         |            | :闭到打       |                 |       |                 |             |              |              |             |      |          | <i>ī</i> . 1. |        |      |
|                |      | HSE 晶   | <b>指振振</b> | 荡等待        | 时间设             | 置,    | 等待时             | 间=HS        | SEWTX        | $8 \times H$ | SE 时年       | 中周期。 | <b>o</b> |               |        |      |
|                |      |         |            |            |                 |       |                 |             |              |              |             |      |          |               |        |      |



当使用 8MHz 振荡器时, 初始等待时间值为: 0x100×8×125ns = 256μs。

# 7.3.12 PLL 控制寄存器(RCC\_LPCLK\_CTL)

偏移地址: 0x30 复位值: 0x0100

说明: X 表示不定值。

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

| 15 | 14  | 13 | 12 | 11 | 10 | 9 | 9 8       |  | 6 | 5 | 4   | 3 | 2 | 1 | 0        |
|----|-----|----|----|----|----|---|-----------|--|---|---|-----|---|---|---|----------|
|    | Res |    |    |    |    |   | USBCLK_EN |  |   |   | Res |   |   |   | LCLK_SEL |
|    |     |    |    |    |    |   |           |  |   |   |     |   |   |   |          |

| 位 31:9 | Res: 保留<br>必须保持复位值。                                                                                    |
|--------|--------------------------------------------------------------------------------------------------------|
| 位 8    | USBCLK_EN: USB 时钟使能<br>该位用于在工作模式或者 Sleep 模式下关闭 USB 48MHz 时钟。关闭 USB 48MHz 时钟后,<br>MCU 芯片电流功耗可降低约 400μA。 |
| 位 7:1  | Res: 保留<br>必须保持复位值。                                                                                    |
| 位 0    | LCLK_SEL[1:0]: 选择系统时钟的时钟源  • 0:选择 LSI 作为系统时钟  • 1:选择 LSE 作为系统时钟                                        |



# 8 中断和事件(EXTI和 NVIC)

# 8.1 嵌套向量中断控制器(NVIC)

- 44 个可屏蔽中断通道(不包含 16 个 Cortex®-M3 的中断线)
- 16 个可编程的优先等级(使用了 4 位中断优先级)
- 低延迟的异常和中断处理
- 电源管理控制
- 系统控制寄存器的实现

嵌套向量中断控制器(NVIC)和处理器核的接口紧密相连,可以实现低延迟的中断处理和高效地处理晚到的中断。

NVIC 管理着内核异常等中断。更多关于异常和 NVIC 编程的说明,请参考 Cortex®-M3 相关手册。

## 8.1.1 系统嘀嗒(SysTick)校准值寄存器

系统嘀嗒校准值固定为 9000,当系统嘀嗒时钟设定为 9 MHz(HCLK/8 且 HCLK=72 MHz),产生 1 ms 时间基准。

### 8.1.2 中断和异常向量

表 8-1 NVIC表

| 位置 | 优先 |     | 名称           | 描述                                                                 | 地址                          |
|----|----|-----|--------------|--------------------------------------------------------------------|-----------------------------|
| -  | -  | -   | -            | 保留                                                                 | 0x0000 0000                 |
| -  | -3 | 固定  | Reset        | 复位(Reset)                                                          | 0x0000 0004                 |
| -  | -2 | 固定  | NMI          | 非屏蔽中断<br>RCC 时钟安全系统(CSS)联接到 NMI 向量<br>(Non-maskable interrupt)     | 0x0000 0008                 |
| -  | -1 | 固定  | HardFault    | 所有类型错误(All class of fault)                                         | 0x0000 000C                 |
| -  | 0  | 可配置 | MemManage    | 存储器管理<br>(Memory management)                                       | 0x0000 0010                 |
| -  | 1  | 可配置 | BusFault     | 预取指错误,存储器访问错误<br>(Pre-fetch instruction fault/Memory access fault) | 0x0000 0014                 |
|    | 2  | 可配置 | UsageFault   | 未定义的指令或非法状态<br>(Undefined instruction and illegal state)           | 0x0000 0018                 |
| -  | -  | -   | -            | 保留                                                                 | 0x0000 001C-<br>0x0000 002B |
| -  | 3  | 可配置 | SVCall       | 通过 SWI 指令的系统服务调用<br>(System service call via SWI instruction)      | 0x0000 002C                 |
| -  | 4  | 可配置 | DebugMonitor | 调试监控器                                                              | 0x0000 0030                 |
| -  | -  | -   | -            | 保留                                                                 | 0x0000 0034                 |
| -  | 5  | 可配置 | PendSV       | 可挂起的系统服务请求                                                         | 0x0000 0038                 |



| 位置 | 优先 | 级   | 名称            | 描述                                                                        | 地址          |
|----|----|-----|---------------|---------------------------------------------------------------------------|-------------|
|    |    |     |               | ( Pendable request for system service )                                   |             |
| -  | 6  | 可配置 | SysTick       | 系统嘀嗒定时器<br>(System tick timer)                                            | 0x0000 003C |
| 0  | 7  | 可配置 | WWDG          | 窗口看门狗中断<br>(Window Watchdog interrupt)                                    | 0x0000 0040 |
| 1  | 8  | 可配置 | PVD           | 连到 EXTI16 的电源电压检测(PVD)中断<br>(PVD through EXTI Line16 detection interrupt) | 0x0000 0044 |
| 2  | 9  | 可配置 | TAMPER        | 侵入检测中断(Tamper interrupt)                                                  | 0x0000 0048 |
| 3  | 10 | 可配置 | RTC           | RTC 全局中断<br>(RTC global interrupt)                                        | 0x0000 004C |
| 4  | 11 | 可配置 | FLASH         | Flash 全局中断<br>(Flash global interrupt)                                    | 0x0000 0050 |
| 5  | 12 | 可配置 | RCC           | 复位和时钟控制(RCC)全局中断(RCC global interrupt)                                    | 0x0000 0054 |
| 6  | 13 | 可配置 | EXTIO         | EXTI 线 0 的中断(EXTI Line0 interrupt)                                        | 0x0000 0058 |
| 7  | 14 | 可配置 | EXTI1         | EXTI 线 1 的中断(EXTI Line1 interrupt)                                        | 0x0000 005C |
| 8  | 15 | 可配置 | EXTI2         | EXTI 线 2 的中断(EXTI Line2 interrupt)                                        | 0x0000 0060 |
| 9  | 16 | 可配置 | EXTI3         | EXTI 线 3 的中断(EXTI Line3 interrupt)                                        | 0x0000 0064 |
| 10 | 17 | 可配置 | EXTI4         | EXTI 线 4 的中断(EXTI Line4 interrupt)                                        | 0x0000 0068 |
| 11 | 18 | 可配置 | DMA1_Channel1 | DMA1 通道 1 全局中断<br>(DMA Channel1 global interrupt)                         | 0x0000 006C |
| 12 | 19 | 可配置 | DMA1_Channel2 | DMA1 通道 2 全局中断<br>(DMA Channel2 global interrupt)                         | 0x0000 0070 |
| 13 | 20 | 可配置 | DMA1_Channel3 | DMA1 通道 3 全局中断<br>(DMA Channel3 global interrupt)                         | 0x0000 0074 |
| 14 | 21 | 可配置 | DMA1_Channel4 | DMA1 通道 4 全局中断<br>(DMA Channel4 global interrupt)                         | 0x0000 0078 |
| 15 | 22 | 可配置 | DMA1_Channel5 | DMA1 通道 5 全局中断<br>(DMA Channel5 global interrupt)                         | 0x0000 007C |
| 16 | 23 | 可配置 | DMA1_Channel6 | DMA1 通道 6 全局中断<br>(DMA Channel6 global interrupt)                         | 0x0000 0080 |
| 17 | 24 | 可配置 | DMA1_Channel7 | DMA1 通道 7 全局中断<br>(DMA Channel7 global interrupt)                         | 0x0000 0084 |
| 18 | 25 | 可配置 | ADC1_2        | ADC1 和 ADC2 全局中断(结合 EXTI24, EXTI25)<br>(ADC1/ADC2 interrupt)              | 0x0000 0088 |



| 位置 | 优先 | 级   | 名称             | 描述                                                            | 地址          |
|----|----|-----|----------------|---------------------------------------------------------------|-------------|
|    |    |     |                | (Combined with EXTI24, EXTI25)                                |             |
| 19 | 26 | 可配置 | USB_HP_CAN_TX  | USB 高优先级或 CAN 发送中断<br>(USB high priority/CAN Tx interrupt)    | 0x0000 008C |
| 20 | 27 | 可配置 | USB_LP_CAN_RX0 | USB 低优先级或 CAN 接收 0 中断<br>(USB low priority/CAN Rx0 interrupt) | 0x0000 0090 |
| 21 | 28 | 可配置 | CAN_RX1        | CAN 接收 1 中断<br>(CAN Rx1 interrupt)                            | 0x0000 0094 |
| 22 | 29 | 可配置 | CAN_SCE        | CAN SCE 中断<br>(CAN SCE interrupt)                             | 0x0000 0098 |
| 23 | 30 | 可配置 | EXTI9_5        | EXTI 线[9:5]中断<br>(EXTI Line[9:5] interrupt)                   | 0x0000 009C |
| 24 | 31 | 可配置 | TIM1_BRK       | TIM1 刹车中断<br>(TIM1 break interrupt)                           | 0x0000 00A0 |
| 25 | 32 | 可配置 | TIM1_UP        | TIM1 更新中断<br>(TIM1 update interrupt)                          | 0x0000 00A4 |
| 26 | 33 | 可配置 | TIM1_TRG_COM   | TIM1 触发和通信中断<br>(TIM1 trigger and Com interrupt)              | 0x0000 00A8 |
| 27 | 34 | 可配置 | TIM1_CC        | TIM1 捕获/比较中断<br>(TIM1 Capture/Compare interrupt)              | 0x0000 00AC |
| 28 | 35 | 可配置 | TIM2           | TIM2 全局中断<br>(TIM2 global interrupt)                          | 0x0000 00B0 |
| 29 | 36 | 可配置 | TIM3           | TIM3 全局中断<br>(TIM3 global interrupt)                          | 0x0000 00B4 |
| 30 | 37 | 可配置 | TIM4           | TIM4 全局中断<br>(TIM4 global interrupt)                          | 0x0000 00B8 |
| 31 | 38 | 可配置 | I2C1_EV        | I2C1 事件中断<br>(I2C1 event interrupt)                           | 0x0000 00BC |
| 32 | 39 | 可配置 | I2C1_ER        | I2C1 错误中断<br>(I2C1 fault interrupt)                           | 0x0000 00C0 |
| 33 | 40 | 可配置 | I2C2_EV        | I2C2 事件中断<br>(I2C2 event interrupt)                           | 0x0000 00C4 |
| 34 | 41 | 可配置 | I2C2_ER        | I2C2 错误中断<br>(I2C2 fault interrupt)                           | 0x0000 00C8 |
| 35 | 42 | 可配置 | SPI1           | SPI1 全局中断<br>(SPI1 global interrupt)                          | 0x0000 00CC |
| 36 | 43 | 可配置 | SPI2           | SPI2 全局中断                                                     | 0x0000 00D0 |



| 位置 | 优先 | <del>.</del> 级 | 名称        | 描述                                                                                 | 地址          |
|----|----|----------------|-----------|------------------------------------------------------------------------------------|-------------|
|    |    |                |           | (SPI2 global interrupt)                                                            |             |
| 37 | 44 | 可配置            | USART1    | USART1 全局中断<br>(USART1 global interrupt)                                           | 0x0000 00D4 |
| 38 | 45 | 可配置            | USART2    | USART2 全局中断<br>(USART2 global interrupt)                                           | 0x0000 00D8 |
| 39 | 46 | 可配置            | USART3    | USART3 全局中断<br>(USART3 global interrupt)                                           | 0x0000 00DC |
| 40 | 47 | 可配置            | EXTI15_10 | EXTI 线[15:10]中断<br>(EXTI Line[15:10] interrupt)                                    | 0x0000 00E0 |
| 41 | 48 | 可配置            | RTCAlarm  | 连接到 EXTI17 的 RTC 闹钟中断<br>(RTC alarm through EXTI Line 17 interrupt)                | 0x0000 00E4 |
| 42 | 49 | 可配置            | USBWakeUp | 连接到 EXTI18 的 USB 待机唤醒中断<br>(USB standby wake-up through EXTI Line 18<br>interrupt) | 0x0000 00E8 |
| 43 | 50 | 保留             | -         | 保留                                                                                 | 0x0000 00EC |
| 44 | 51 | 保留             | -         | 保留                                                                                 | 0x0000 00F0 |
| 45 | 52 | 保留             | -         | 保留                                                                                 | 0x0000 00F4 |
| 46 | 53 | 保留             | -         | 保留                                                                                 | 0x0000 00F8 |
| 47 | 54 | 可设置            | DVSQ      | 连接到 DVSQ 事件中断                                                                      | 0x0000 00FC |

## 8.2 外部中断/事件控制器(EXTI)

外部中断/事件控制器由 19 个能产生事件/中断请求的边沿检测器组成。每根输入线可以独立地配置类型(事件或中断)和对应的触发事件(上升沿、下降沿或双边沿触发)。每根输入线都可以单独被屏蔽。挂起寄存器保持着中断请求的状态线。

## 8.2.1 主要特性

EXTI 控制器的主要特性如下:

- 每根中断/事件线都可单独被触发和屏蔽
- 每根中断线都有专用的状态位
- 支持多达 19 个软件的中断/事件请求

## 8.2.2 框图

EXTI 结构框图如下所示:





图 8-1 EXTI 框图

说明: 以上中断为19个。

### 8.2.3 EXTI 与周边模块关系



图 8-2 EXTI 与周边模块关系框图

如图 8-2 所示,EXTI 的中断输出与芯片内其他中断源一起汇总于 NVIC; EXTI 输出的事件,输入到 RXEV 模块,用于管理内核唤醒相关操作; EXTI 输出的唤醒信号,输出给 PMU 单元。

### 8.2.4 唤醒事件管理

HK32F103x8xB 可以处理外部或内部事件来唤醒内核(WFE)。唤醒事件可以通过下述配置产生:

在外设的控制寄存器而非 NVIC 中使能一个中断,同时在 Cortex®-M3 的系统控制寄存器中使能



SEVONPEND 位。当 CPU 从 WFE 恢复后,需要清除相应外设的中断挂起位和外设 NVIC 中断通道挂起位(在 NVIC 中断清除挂起寄存器中)。

• 配置一个外部或内部 EXTI 线为事件模式,当 CPU 从 WFE 恢复后,因为对应事件线的挂起位没有被置位,不必清除相应外设的中断挂起位或 NVIC 中断通道挂起位。

使用外部 I/O 端口作为唤醒事件,请参考"8.2.5 功能说明"。

### 8.2.5 功能说明

要产生中断,必须先配置并使能中断线。根据所需的边沿检测条件来配置 2 个触发寄存器,并且通过向中断屏蔽寄存器的相应位写'1'来使能中断请求。当外部中断线上发生了所设置的边沿时,将产生一个中断请求。该中断线对应的挂起位也随之被置'1',向挂起寄存器的对应位写'1',将清除该中断请求。

如果需要产生事件,必须先配置并使能事件线。根据所需的边沿检测条件来配置 2 个触发寄存器,并且通过向事件屏蔽寄存器的相应位写'1'来使能事件请求。当事件线上发生了需要的边沿时,将产生一个事件请求脉冲,对应的挂起位不被置'1'。

通过软件向软件中断/事件寄存器写'1',可以产生中断/事件请求。

#### 8.2.5.1 选择硬件中断

配置 EXTI 线作为中断源的步骤如下:

- 1. 配置其中断屏蔽位(EXTI IMR)。
- 2. 配置其触发选择位(EXTI RTSR 和 EXTI FTSR)。
- 3. 配置对应到外部中断控制器(EXTI)的 NVIC 中断通道的使能和屏蔽位,以使得 EXTI 线上来的中断能正确地被响应。

#### 8.2.5.2 选择硬件事件

配置 EXTI 线作为事件源的步骤如下:

- 1. 配置其事件屏蔽位(EXTI EMR)。
- 2. 配置其触发选择位(EXTI RTSR 和 EXTI FTSR)。

#### 8.2.5.3 选择软件中断/事件

EXTI 线可以被配置成软件中断/事件线。下面是产生软件中断的步骤:

- 1. 配置其中断/事件线的屏蔽位(EXTI\_IMR / EXTI\_EMR)。
- 2. 设置其软件中断寄存器的请求位(EXTI\_SWIER)。

#### 8.2.6 外部中断/事件线映射

51 个 GPIO 口以下图的方式连接到 16 个外部中断/事件线上:





图 8-3 外部中断 GPIO 映射

如图 8-3 所示,通过 AFIO\_EXTICRx 配置 GPIO 线上的外部中断/事件,必须先使能 AFIO 时钟。参见: "7.3.7 APB2 外设时钟使能寄存器(RCC\_APB2ENR)"。

另外 5 根 EXTI 线的连接方式如下:

- EXTI16 连接 PVD 输出
- EXTI17 连接 RTC 的闹钟事件
- EXTI18 连接 USB 的唤醒事件

## 8.3 EXTI 寄存器

基地址: 0x4001 0400 空间大小: 0x400

EXTI 寄存器必须以字(32位)的方式进行访问。

## 8.3.1 中断屏蔽寄存器(EXTI\_IMR)

偏移地址: 0x00

复位值: 0x0000 0000

| 31 | 30  | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18   | 17   | 16   |
|----|-----|----|----|----|----|----|----|----|----|----|----|----|------|------|------|
|    | Res |    |    |    |    |    |    |    |    |    |    |    | MR18 | MR17 | MR16 |
|    |     |    |    |    |    |    |    |    |    |    |    |    | rw   | rw   | rw   |

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

| 位 31:19        | Res: 保留<br>必须保持复位值。                                                                                      |
|----------------|----------------------------------------------------------------------------------------------------------|
| 位 x<br>(x=180) | MRx: 线 x 上的中断屏蔽(x=180)(Interrupt Mask on line x)         • 0: 屏蔽来自线 x 上的中断请求         • 1: 允许来自线 x 上的中断请求 |

## 8.3.2 事件屏蔽寄存器(EXTI\_EMR)

偏移地址: 0x04

复位值: 0x0000 0000

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 8  | 17   | 16   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|
|    |    |    |    |    |    | R  | es |    |    |    |    |    | MR | 18 | MR17 | MR16 |
|    |    |    |    |    |    |    |    |    |    |    |    |    |    | V  | rw   | rw   |
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |      |
| 15 | 1  | L4 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1    | 0    |



|   | MR1 | MR1 | MR1 | MR1 | MR1 | MR1 | MR |
|---|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|
|   | 5   | 4   | 3   | 2   | 1   | 0   | 9  | 8  | 7  | 6  | 4  | 4  | 3  | 2  | 1  | 0  |
| ĺ | rw  | rw  | rw  | rw  | rw  | rw  | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw |

# 8.3.3 上升沿触发选择寄存器(EXTI\_RTSR)

偏移地址: 0x08

复位值: 0x0000 0000

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23 | 22 | 21 | 20 | 19 | 18   | 17   | 16   |
|----|----|----|----|----|----|----|-----|----|----|----|----|----|------|------|------|
|    |    |    |    |    |    | F  | Res |    |    |    |    |    | TR18 | TR17 | TR16 |
|    |    |    |    |    |    |    |     |    |    |    |    |    | rw   | rw   | rw   |

| 15   | 14   | 13   | 12   | 11   | 10   | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|------|------|------|------|------|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| TR15 | TR14 | TR13 | TR12 | TR11 | TR10 | TR9 | TR8 | TR7 | TR6 | TR5 | TR4 | TR3 | TR2 | TR1 | TR0 |
| rw   | rw   | rw   | rw   | rw   | rw   | rw  | rw  | rw  | rw  | rw  | rw  | rw  | rw  | rw  | rw  |

| 位 31:19        | Res: 保留<br>必须保持复位值。                                                                                                                                                                                                                                           |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 x<br>(x=180) | TRx: 线 x 上的上升沿触发事件配置位(Rising trigger event configuration bit of line x)  • 0: 禁止输入线 x 上的上升沿触发(中断和事件)  • 1: 允许输入线 x 上的上升沿触发(中断和事件) <i>注意:</i> • 外部唤醒线是边沿触发的,这些线上不能出现毛刺信号。  • 在写 EXTI_RTSR 寄存器时,不能检测外部中断线上的上升沿信号,挂起位也不会被置位。 可以在同一中断线上同时设置上升沿和下降沿触发,即任一边沿均可触发中断。 |

# 8.3.4 下降沿触发选择寄存器(EXTI\_FTSR)

偏移地址: 0x0C

复位值: 0x0000 0000

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23 | 22 | 21 | 20 | 19 | 18   | 17   | 16   |
|----|----|----|----|----|----|----|-----|----|----|----|----|----|------|------|------|
|    |    |    |    |    |    | F  | Res |    |    |    |    |    | TR18 | TR17 | TR16 |
|    |    |    |    |    |    |    |     |    |    |    |    |    | rw   | rw   | rw   |

| 15   | 14   | 13   | 12   | 11   | 10   | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|------|------|------|------|------|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| TR15 | TR14 | TR13 | TR12 | TR11 | TR10 | TR9 | TR8 | TR7 | TR6 | TR5 | TR4 | TR3 | TR2 | TR1 | TR0 |
| rw   | rw   | rw   | rw   | rw   | rw   | rw  | rw  | rw  | rw  | rw  | rw  | rw  | rw  | rw  | rw  |

| 位 31:19 | Res: 保留<br>必须保持复位值。                                                                                   |
|---------|-------------------------------------------------------------------------------------------------------|
| 位 x     | TRx: 线 x 上的下降沿触发事件配置位(Falling trigger event configuration bit of line x)  • 0: 禁止输入线 x 上的下降沿触发(中断和事件) |



(x=18..0)

- 1: 允许输入线 x 上的下降沿触发(中断和事件) 注意:
- 外部唤醒线是边沿触发的,这些线上不能出现毛刺信号。
- 在写 EXTI\_FTSR 寄存器时,不能检测外部中断线上的下降沿信号,挂起位也不会被置位。可以在同一中断线上同时设置上升沿和下降沿触发,即任一边沿均可触发中断。

22

21

20

18

SWIER18

17

SWIER17

16

SWIER16

# 8.3.5 软件中断事件寄存器(EXTI\_SWIER)

26

25

Res

24

23

偏移地址: 0x10

复位值: 0x0000 0000

31 30 29 28 27

| 15            | 4.4  |                                                                                                                               |                                        |      |      |     |     |     |     |     |     |     |     |     | rw  |
|---------------|------|-------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|------|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| CVA/IE        | 14   | 13                                                                                                                            | 12                                     | 11   | 10   | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
| SWIE          | SWIE | SWIE                                                                                                                          | SWIE                                   | SWIE | SWIE | SWI |
| R15           | R14  | R13                                                                                                                           | R12                                    | R11  | R10  | ER9 | ER8 | ER7 | ER6 | ER5 | ER4 | ER3 | ER2 | ER1 | ER0 |
| rw            | rw   | rw                                                                                                                            | rw |      |      |     |     |     |     |     |     |     |     |     |     |
| 位 31:1        | 19   |                                                                                                                               | Res: 保留<br>必须保持复位值。                    |      |      |     |     |     |     |     |     |     |     |     |     |
| 位 x<br>(x=180 | .0)  | SWIERx: 线 x 上的软件中断(Software interrupt on line x)<br>当该位为'0'时,对该位写'1'将设置 EXTI_PR 中相应的挂起位。如果在 EXTI_IMR 中允许产<br>生该中断,则此时将产生一个中断。 |                                        |      |      |     |     |     |     |     |     |     |     |     |     |

说明:通过清除 EXTI\_PR 的对应位 (写入'1'),可清除该位为'0'。

## 8.3.6 挂起寄存器(EXTI\_PR)

26

25

偏移地址: 0x14

复位值: 0xXXXX XXXX 说明: X 表示不定值。

31 30 29 28 27

|      | Res Pl |      |      |      |      |     |     |     |     | PR18 | PR17 | PR16 |     |     |     |
|------|--------|------|------|------|------|-----|-----|-----|-----|------|------|------|-----|-----|-----|
|      |        |      |      |      |      |     |     |     |     |      |      |      | rw  | rw  | rw  |
|      |        |      |      |      |      |     |     |     |     |      |      |      |     |     |     |
| 15   | 14     | 13   | 12   | 11   | 10   | 9   | 8   | 7   | 6   | 5    | 4    | 3    | 2   | 1   | 0   |
| PR15 | PR14   | PR13 | PR12 | PR11 | PR10 | PR9 | PR8 | PR7 | PR6 | PR5  | PR4  | PR3  | PR2 | PR1 | PRO |
| rw   | rw     | rw   | rw   | rw   | rw   | rw  | rw  | rw  | rw  | rw   | rw   | rw   | rw  | rw  | rw  |

| 位 31:19        | Res: 保留<br>必须保持复位值。                                                                                                                             |
|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 x<br>(x=180) | PRx: 线 x 的挂起位(Pending interrupt flag on line x)  • 0: 没有发生触发请求  • 1: 发生了所选择的触发请求  当在外部中断线上发生了所选择的边沿事件,则该位被置'1'。在该位中写入'1'可以清除它,也可以通过改变边沿检测的极性清除。 |

16



## 9 通用和复用功能 I/O (GPIO 和 AFIO)

### 9.1 GPIO 功能描述

每个 GPIO 端口有两个 32 位配置寄存器 (GPIOx\_CRL, GPIOx\_CRH)、两个 32 位数据寄存器 (GPIOx\_IDR 和 GPIOx\_ODR)、一个 32 位置位/复位寄存器 (GPIOx\_BSRR)、一个 16 位复位寄存器 (GPIOx\_BRR)、一个 32 位锁定寄存器 (GPIOx\_LCKR)。

根据数据手册中列出的每个 I/O 端口的特定硬件特征, GPIO 端口的每个位可以由软件分别配置成多种模式,包括:

- 输入浮空
- 输入上拉
- 输入下拉
- 模拟输入
- 开漏输出
- 推挽式输出
- 推挽式复用功能
- 开漏复用功能

I/O 端口的每个位均可自由编程,但必须按照 32 位,即以字为单位访问(不允许半字或字节访问)I/O 端口寄存器。GPIOx\_BSRR 和 GPIOx\_BRR 寄存器用于对任一个 GPIO 寄存器进行原子操作(按位读/写)。这样,在读和修改访问时产生的 IRQ 就不会有冲突。

每个 GPIO 引脚都可以由软件配置成输出(推挽或开漏)、输入(浮空输入、上拉输入或下拉输入)或其它的外设功能端口。多数 GPIO 引脚都与数字或模拟的外设共用。I/O 引脚的外设功能可以按需锁定,以避免意外的写入 I/O 寄存器。所有的 GPIO 引脚都有大电流通过能力。

图 9-1 给出了一个 I/O 端口位的基本结构。



图 9-1 I/O 端口位的基本结构





图 9-2 5V 兼容 I/O 端口位的基本结构

(1) V<sub>DD\_FT</sub>: 5V 耐受的 I/O 端口,它与 V<sub>DD</sub>不同。

表 9-1 端口位配置表

| 配置模式   |                | CNFx[1] | CNFx[0] | MODEx[1] | MODEx[0] | PxODR 寄存器 |
|--------|----------------|---------|---------|----------|----------|-----------|
| 通用输出   | 推挽(Push-Pull)  | 0       | 0       | 01       |          | 0 或 1     |
|        | 开漏(Open-Drain) |         | 1       | 10<br>11 |          | 0 或 1     |
| 复用功能输出 | 推挽(Push-Pull)  | 1       | 0       | 见表 9-2   |          | 不使用       |
|        | 开漏(Open-Drain) |         | 1       |          |          | 不使用       |
| 输入     | 模拟输入           | 0       | 0       | 00       |          | 不使用       |
|        | 浮空输入           |         | 1       |          |          | 不使用       |
|        | 下拉输入           | 1       | 0       |          |          | 0         |
|        | 上拉输入           |         |         |          |          | 1         |

表 9-2 输出模式位

| MODEx[1:0] | 含义             |
|------------|----------------|
| 00         | 保留             |
| 01         | 最大输出速度为 10 MHz |
| 10         | 最大输出速度为 2 MHz  |
| 11         | 最大输出速度为 50 MHz |



#### 9.1.1 通用 I/O(GPIO)

复位期间和刚复位后,复用功能尚未开启,I/O 端口被配置成浮空输入模式(CNFx[1:0]=01b, MODEx[1:0]=00b)。

复位后, JTAG 引脚被置于输入上拉或下拉模式:

- PA15: JTDI 置于上拉模式
- PA14: JTCK 置于下拉模式
- PA13: JTMS 置于上拉模式
- PB4: NJTRST 置于上拉模式

当配置为输出时,写到输出数据寄存器(GPIOx\_ODR)上的值输出至相应的 I/O 引脚。可以在推挽模式或开漏模式下(当输出 0 时,只有 N-MOS 被打开)使用输出驱动器。

输入数据寄存器(GPIOx IDR)在每个 APB2 时钟周期捕捉 I/O 引脚上的数据。

所有 GPIO 引脚有一个内部弱上拉和弱下拉功能,当配置为输入时,该功能可被打开或关闭。

### 9.1.2 单独的位设置或位清除

当对寄存器 GPIOx\_ODR 以位进行编程时,软件不需要禁止中断:在单次 APB2 的原子写操作里,可以只更改一个或多个位。这是通过对"位设置/复位寄存器 GPIOx\_BSRR"中对应位写'1'来实现的。未被选择的位将不被更改。

### 9.1.3 外部中断/唤醒线

所有端口都有外部中断能力。为了使用外部中断线,端口必须配置成输入模式。更多的关于外部中断的信息,可参考"8.2 外部中断/事件控制器(EXTI)"和"8.2.4 唤醒事件管理"。

#### 9.1.4 复用功能(AF)

使用默认复用功能前, 必须对端口位配置寄存器编程。

对于复用的输入功能,端口必须配置成输入模式(浮空、上拉或下拉)且输入引脚必须由外部驱动。

注意:也可通过软件编程 GPIO 控制器来模拟复用功能输入引脚。此时,端口应当被设置为复用功能输出模式。显然,这时相应的引脚不再由外部驱动,而是通过 GPIO 控制器由软件来驱动。

- 对于复用输出功能,端口必须配置成复用功能输出模式(推挽或开漏)。
- 对于双向复用功能,端口位必须配置成复用功能输出模式(推挽或开漏)。这时,输入驱动器被配置成浮空输入模式。

如果把一个端口配置成复用输出功能,则该引脚和输出寄存器断开,并连接至片上外设的输出信号。如果软件把一个 GPIO 脚配置成复用输出功能,但是外设没有启用,则它的输出将不确定。

### 9.1.5 软件重新映射 I/O 复用功能

为了使不同器件封装的外设 I/O 功能的数量达到最优,可以把一些复用功能重新映射到其他一些引脚上。这可通过软件配置相应的寄存器来完成(参考 AFIO 寄存器)。这时,复用功能就不再映射到它们的原始引脚上了。

### 9.1.6 GPIO 锁定机制

锁定机制允许冻结 IO 配置。当在一个端口位上执行了锁定(LOCK)程序,在下一次复位之前,将



不能更改端口位的配置。

### 9.1.7 输入配置

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

- 输出缓冲器被禁止
- 根据输入配置(上拉、下拉或浮空),启用或不启用弱上拉和弱下拉电阻
- 出现在 I/O 脚上的数据在每个 APB2 时钟被采样到输入数据寄存器
- 对输入数据寄存器的读访问可得到 I/O 状态

图 9-3 给出了 I/O 端口位的输入配置。



图 9-3 输入浮空/上拉/下拉配置

(1) V<sub>DD FT</sub>: 5V 耐受的 I/O 端口, 它与 V₀ 不同。

#### 9.1.8 输出配置

当 I/O 端口被配置为输出时:

- 输出缓冲器被使能
  - 。 开漏模式:输出寄存器上的'0'激活 N-MOS,而输出寄存器上的'1'将端口置于高阻状态(P-MOS 一直未被激活)。
  - 。 推挽模式:输出寄存器上的'0'激活 N-MOS,而输出寄存器上的'1'将激活 P-MOS。
- 弱上拉和下拉电阻被禁用。
- 出现在 I/O 脚上的数据在每个 APB2 时钟被采样到输入数据寄存器。
- 在开漏模式时,对输入数据寄存器的读访问可得到 I/O 状态。
- 在推挽式模式时,对输出数据寄存器的读访问得到最后一次写的值。





图 9-4 输出配置

(1) V<sub>DD FT</sub>: 5V 耐受的 I/O 端口,它与 V₀ 不同。

#### 9.1.9 复用功能配置

当 I/O 端口被配置为复用功能时:

- 在开漏或推挽式配置中,输出缓冲器被打开。
- 由来自片内外设的信号驱动输出缓冲器(复用功能输出)。
- 弱上拉和弱下拉电阻被禁用。
- 在每个 APB2 时钟周期, 出现在 I/O 脚上的数据被采样到输入数据寄存器。
- 开漏模式时,读输入数据寄存器时可得到 I/O 口状态。
- 在推挽模式时,读输出数据寄存器时可得到最后一次写的值。

图 9-5 示出了 I/O 端口位的复用功能配置。详见"9.4 AFIO 寄存器"。

一组复用功能 I/O 寄存器允许用户把一些复用功能重新映射到不同的引脚。



图 9-5 复用功能配置

(1) V<sub>DD\_FT</sub>: 5V 耐受的 I/O 端口, 它与 V₀ 不同。



## 9.1.10 模拟输入配置

当 I/O 端口被配置为模拟输入配置时:

- 输出缓冲器被禁用。
- 禁止施密特触发输入,实现了每个模拟 I/O 引脚上的零消耗。施密特触发输出值被强置为'0'。
- 弱上拉和弱下拉电阻被禁用。
- 读取输入数据寄存器的数值为'0'。

图 9-6 示出了 I/O 端口位的高阻抗模拟输入配置:



图 9-6 高阻抗的模拟输入配置

(1) V<sub>DD\_FT</sub>: 5V 耐受的 I/O 端口,它与 V₀ 不同。

## 9.1.11 外设的 GPIO 配置

表 9-3 至表 9-11 列出了各个外设的 GPIO 配置。

|           | T.       |         |  |  |  |  |
|-----------|----------|---------|--|--|--|--|
| TIM1 引脚   | 配置       | GPIO 配置 |  |  |  |  |
| TIM1_CHx  | 输入捕获通道 x | 浮空输入    |  |  |  |  |
|           | 输出比较通道 x | 推挽复用输出  |  |  |  |  |
| TIM1_CHxN | 互补输出通道 x | 推挽复用输出  |  |  |  |  |
| TIM1_BKIN | 刹车输入     | 浮空输入    |  |  |  |  |
| TIM1_ETR  | 外部触发时钟输入 | 浮空输入    |  |  |  |  |

表 9-3 高级定时器 TIM1

表 9-4 通用定时器 TIM2/3/4

| TIM2/3/4 引脚  | 配置       | GPIO 配置 |
|--------------|----------|---------|
| TIM2/3/4_CHx | 输入捕获通道 x | 浮空输入    |



| TIM2/3/4 引脚  | 配置       | GPIO 配置 |
|--------------|----------|---------|
|              | 输出比较通道 x | 推挽复用输出  |
| TIM2/3/4_ETR | 外部触发时钟输入 | 浮空输入    |

#### 表 9-5 USART

| USART 引脚      | 配置      | GPIO 配置      |  |  |  |  |
|---------------|---------|--------------|--|--|--|--|
| USARTx_TX (1) | 全双工模式   | 推挽复用输出       |  |  |  |  |
|               | 半双工同步模式 | 推挽复用输出       |  |  |  |  |
| USARTx_RX     | 全双工模式   | 浮空输入或带上拉输入   |  |  |  |  |
|               | 半双工同步模式 | 未用,可作为通用 I/O |  |  |  |  |
| USARTx_CK     | 同步模式    | 推挽复用输出       |  |  |  |  |
| USARTx_RTS    | 硬件流量控制  | 推挽复用输出       |  |  |  |  |
| USARTx_CTS    | 硬件流量控制  | 浮空输入或带上拉输入   |  |  |  |  |

## (1). USART\_TX 也可以配置为复用开漏模式。

#### 表 9-6 SPI

| SPI 引脚    | 配置             | GPIO 配置          |  |  |  |  |  |
|-----------|----------------|------------------|--|--|--|--|--|
| SPIx_SCK  | 主模式            | 推挽复用输出           |  |  |  |  |  |
|           | 从模式            | 浮空输入             |  |  |  |  |  |
| SPIx_MOSI | 全双工模式/主模式      | 推挽复用输出           |  |  |  |  |  |
|           | 全双工模式/从模式      | 浮空输入或带上拉输入       |  |  |  |  |  |
|           | 单线半双工数据线/主模式   | 推挽复用输出           |  |  |  |  |  |
|           | 单线半双工数据线/从模式   | 未用,可作为通用 I/O     |  |  |  |  |  |
| SPIx_MISO | 全双工模式/主模式      | 浮空输入或带上拉输入       |  |  |  |  |  |
|           | 全双工模式/从模式      | 推挽复用输出           |  |  |  |  |  |
|           | 单线半双工数据线/主模式   | 未用,可作为通用 I/O     |  |  |  |  |  |
|           | 单线半双工数据线/从模式   | 推挽复用输出           |  |  |  |  |  |
| SPIx_NSS  | 硬件主/从模式        | 浮空输入、带上拉输入或带下拉输入 |  |  |  |  |  |
|           | 硬件主模式/NSS 输出使能 | 推挽复用输出           |  |  |  |  |  |
|           | 软件模式           | 未用,可作为通用 I/O     |  |  |  |  |  |



#### 表 9-7 I2C 接口

| I2C 引脚   | 配置     | GPIO 配置 |  |  |  |  |
|----------|--------|---------|--|--|--|--|
| I2Cx_SCL | I2C 时钟 | 开漏复用    |  |  |  |  |
| I2Cx_SDA | I2C 数据 | 开漏复用    |  |  |  |  |

#### 表 9-8 bxCAN

| BxCAN 引脚 | GPIO 配置   |
|----------|-----------|
| CAN_TX   | 推挽复用输出    |
| CAN_RX   | 浮空输入或上拉输入 |

#### 表 9-9 USB

| USB 引脚        | GPIO 配置                           |
|---------------|-----------------------------------|
| USB_DM/USB_DP | 一旦使能了 USB 模块,这些引脚会自动连接到内部 USB 收发器 |

#### 表 9-10 ADC

| ADC 引脚  | GPIO 配置 |
|---------|---------|
| ADC (1) | 模拟输入    |

#### (1). ADC 输入引脚必须配置为模拟输入。

#### 表 9-11 其它 I/O 功能

| 引脚         | 复用功能   | GPIO 配置                      |  |  |  |  |
|------------|--------|------------------------------|--|--|--|--|
| TAMPER-RTC | RTC 输出 | 当配置 BKP_CR 和 BKP_RTCCR 寄存器时, |  |  |  |  |
|            | 侵入事件输入 | 由硬件强制设置                      |  |  |  |  |
| МСО        | 时钟输出   | 推挽复用输出                       |  |  |  |  |
| EXTI 输入线   | 外部中断输入 | 浮空输入、上拉输入或下拉输入               |  |  |  |  |

## 9.2 GPIO 寄存器

基地址:(GPIOA; GPIOB, GPIOC, GPIOD)=(0x4001 0800; 0x4001 0C00, 0x4001 1000, 0x4001 1400)

空间大小:(GPIOA; GPIOB, GPIOC, GPIOD)=(0x400; 0x400, 0x400, 0x400)

GPIO 寄存器必须以字(32位)的方式进行访问。

## 9.2.1 端口 x 配置低寄存器(GPIOx\_CRL)(x=A..D)

偏移地址: 0x00

复位值: 0x4444 4444

| 31   | 30        | 29   | 28         | 27 | 26        | 25 | 24         | 23  | 22         | 21 | 20                 | 19 | 18         | 17 | 16         |    |       |               |  |       |       |            |  |    |  |
|------|-----------|------|------------|----|-----------|----|------------|-----|------------|----|--------------------|----|------------|----|------------|----|-------|---------------|--|-------|-------|------------|--|----|--|
| CNF7 | CNF7[1:0] |      | MODE7[1:0] |    | CNF6[1:0] |    | [6[1:0]    | CNF | CNF5[1:0]  |    | DE5[1:0] CNF4[1:0] |    | MODE4[1:0] |    |            |    |       |               |  |       |       |            |  |    |  |
| r    | W         | r    | w          | r  | w rw      |    | rw rw      |     | rw rw      |    | rw                 |    | rw         |    |            |    |       |               |  |       |       |            |  |    |  |
| 1.5  | 1.4       | 12   | 12         | 11 | 10        | 0  |            | 7   |            | Е  | 4                  | 2  | 2          | 1  |            |    |       |               |  |       |       |            |  |    |  |
| 15   | 14        | 13   | 12         | 11 | 10        | 9  | 8          | /   | 6          | 5  | 4                  | 3  | 2          | T  | 0          |    |       |               |  |       |       |            |  |    |  |
| CNF3 | [1:0]     | MODE | MODE3[1:0] |    | CNF2[1:0] |    | MODE2[1:0] |     | MODE2[1:0] |    | MODE2[1:0]         |    | MODE2[1:0] |    | MODE2[1:0] |    | [1:0] | MODE1[1:0] CI |  | CNF0  | [1:0] | MODE0[1:0] |  |    |  |
| rv   | V         | rv   | v          | r١ | N         | r۱ | N          | rw  |            | rw |                    | rw |            | rw |            | rw |       | rw            |  | rw rw |       | rw         |  | rw |  |



位 (4y+3):(4y+2) (y=7..0) CNFy[1:0]: 端口 x 配置位 y (Port x configuration bits)

软件通过这些位配置相应的 I/O 端口,请参考表 9-1。

- 在输入模式 (MODEy[1:0]=00):
  - 。00: 模拟输入模式
  - o 01: 浮空输入模式(复位后的状态)
  - o 10: 上拉/下拉输入模式
  - o 11: 保留
- 在输出模式 (MODEy[1:0]>00):
  - o 00: 通用推挽输出模式
  - o 01: 通用开漏输出模式
  - o 10: 复用功能推挽输出模式
  - o 11: 复用功能开漏输出模式

位 (4y+1):(4y+0) (y=7..0) MODEy[1:0]: 端口 x 的 y 引脚工作模式配置位(Port x pin y mode configuration bits)软件通过这些位配置相应的 I/O 端口,请参考表 9-1。

- 00: 输入模式(复位后的状态)
- 01: 输出模式,最大速度 10 MHz
- 10: 输出模式, 最大速度 2 MHz
- 11: 输出模式,最大速度 50 MHz

### 9.2.2 端口 x 配置高寄存器(GPIOx\_CRH)(x=A..D)

偏移地址: 0x04

复位值: 0x4444 4444

| 31   | 30                     | 29 | 28                       | 27 | 26      | 25          | 24 | 23          | 22 | 21         | 20 | 19        | 18          | 17     | 16         |  |         |
|------|------------------------|----|--------------------------|----|---------|-------------|----|-------------|----|------------|----|-----------|-------------|--------|------------|--|---------|
| CNF1 | 15[1:0] MODE           |    | CNF15[1:0]               |    | 15[1:0] | CNF14[1:0]  |    | MODE14[1:0] |    | CNF13[1:0] |    | MODE      | MODE13[1:0] |        | CNF12[1:0] |  | 12[1:0] |
| rv   | w                      | rw |                          | r۱ | N       | rw          |    | rw          |    | rw         |    | rw        |             | rw     |            |  |         |
|      |                        |    |                          |    |         |             |    |             |    |            | 1  | 1         |             |        |            |  |         |
| 15   | 14                     | 13 | 12                       | 11 | 10      | 9           | 8  | 7           | 6  | 5          | 4  | 3         | 2           | 1      | 0          |  |         |
| CNF1 | CNF11[1:0] MODE11[1:0] |    | MODE11[1:0] CNF10[1:0] N |    | MOD     | MODE10[1:0] |    | CNF9[1:0]   |    | MODE9[1:0] |    | CNF8[1:0] |             | 8[1:0] |            |  |         |
| rı   | rw rw                  |    | 14/                      |    | rw      | rw          |    | rw          |    | rw         |    | rw        |             | rw     |            |  |         |

位 4(y-8)+3:4(y-8)+2 (y=15..8) CNFy[1:0]: 端口 x 配置位 y (Port x configuration bits)

软件通过这些位配置相应的 I/O 端口,请参考表 9-1。

- 在输入模式 (MODEy[1:0]=00):
  - o 00: 模拟输入模式
  - o 01: 浮空输入模式(复位后的状态)
  - o 10: 上拉/下拉输入模式
  - o 11: 保留
- 在输出模式 (MODEy[1:0]>00):
  - o 00: 通用推挽输出模式
  - o 01: 通用开漏输出模式
  - o 10: 复用功能推挽输出模式
  - o 11: 复用功能开漏输出模式

位 4(y-8)+1:4(y-8)

(y=15..8)

MODEy[1:0]: 端口 x 的 y 引脚工作模式配置位(Port x pin y mode configuration bits)

版权所有©2022 深圳市航顺芯片技术研发有限公司



软件通过这些位配置相应的 I/O 端口,请参考表 9-1。

• 00: 输入模式(复位后的状态)

• 01: 输出模式,最大速度 10 MHz

• 10: 输出模式,最大速度 2 MHz

• 11: 输出模式,最大速度 50 MHz

# 9.2.3 端口 x 输入数据寄存器(GPIOx\_IDR)(x= A..D)

偏移地址: 0x08

复位值: 0x0000 XXXX

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

| 15   | 14   | 13   | 12   | 11   | 10   | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|------|------|------|------|------|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| IDR1 | IDR1 | IDR1 | IDR1 | IDR1 | IDR1 | IDR |
| 5    | 4    | 3    | 2    | 1    | 0    | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
| r    | r    | r    | r    | r    | r    | r   | r   | r   | r   | r   | r   | r   | r   | r   | r   |

 位 31:16
 Res: 保留

 必须保持复位值。

 位 y
 IDRy[15:0]: 端口输入数据(Port input data)

 (y=15..0)
 这些位为只读并只能以字的方式读出。读出的值为对应 I/O 口的状态。

 (y=15..0)

 (y=15..0)

 (y=15..0)
 (y=15..0)
 (y=15..0)
 (y=15..0)
 (y=15..0)
 (y=15..0)
 (y=15..0)
 (y=15..0)
 (y=15..0)
 (y=15..0)
 (y=15..0)
 (y=15..0)
 (y=15..0)
 (y=15..0)
 (y=15..0)
 (y=15..0)
 (y=15..0)
 (y=15..0)
 (y=15..0)
 (y=15..0)
 (y=15..0)
 (y=15..0)
 (y=15..0)
 (y=15..0)
 (y=15..0)
 (y=15..0)
 (y=15..0)
 (y=15..0)
 (y=15..0)
 (y=15..0)
 (y=15..0)
 (y=15..0)
 (y=15..0)
 (y=15..0)
 (y=15..0)
 (y=15..0)

# 9.2.4 端口 x 输出数据寄存器(GPIOx\_ODR)(x= A..D)

偏移地址: 0x0C

复位值: 0x0000 0000

| Res | 30   29   28   27   26   25   24   23   22   21   20   19   18   3 | 16 |
|-----|--------------------------------------------------------------------|----|
| nes | Res                                                                |    |

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

| 位 31:16    | Res: 保留<br>必须保持复位值。                             |
|------------|-------------------------------------------------|
| 位 <b>y</b> | ODRy[15:0]: 端口输出数据(Port output data)            |
| (y=150)    | 这些位可读可写并只能以字的方式操作。                              |
|            | 说明:通过GPIOx_BSRR (x=AD),可以分别地对各个ODR 位进行独立的设置/清除。 |

# 9.2.5 端口 x 位设置/清除寄存器(GPIOx\_BSRR)(x=A..D)

偏移地址: 0x10

复位值: 0x0000 0000

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



| BR1        | BR1        | BR1        | BR1        | BR1        | BR1        | BR9      | BR8      | BR7      | BR6      | BR5      | BR4      | BR3      | BR2      | BR1      | BR0      |
|------------|------------|------------|------------|------------|------------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|
| 5          | 4          | 3          | 2          | 1          | 0          |          |          |          |          |          |          |          |          |          |          |
| W          | w          | w          | w          | w          | w          | W        | w        | w        | w        | w        | w        | w        | w        | w        | w        |
|            |            |            |            |            |            |          |          |          |          |          |          |          |          |          |          |
|            |            |            |            |            |            |          |          |          |          |          |          |          |          |          |          |
| 15         | 14         | 13         | 12         | 11         | 10         | 9        | 8        | 7        | 6        | 5        | 4        | 3        | 2        | 1        | 0        |
| 15<br>BS15 | 14<br>BS14 | 13<br>BS13 | 12<br>BS12 | 11<br>BS11 | 10<br>BS10 | 9<br>BS9 | 8<br>BS8 | 7<br>BS7 | 6<br>BS6 | 5<br>BS5 | 4<br>BS4 | 3<br>BS3 | 2<br>BS2 | 1<br>BS1 | 0<br>BS0 |

## 9.2.6 端口 x 位清除寄存器 (GPIOx\_BRR) (x=A..D)

偏移地址: 0x14

复位值: 0x0000 0000

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

| 15   | 14   | 13   | 12   | 11   | 10   | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|------|------|------|------|------|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| BR15 | BR14 | BR13 | BR12 | BR11 | BR10 | BR9 | BR8 | BR7 | BR6 | BR5 | BR4 | BR3 | BR2 | BR1 | BRO |
| W    | W    | W    | W    | W    | W    | w   | w   | w   | W   | w   | W   | W   | w   | w   | w   |

位 31:16 Res: 保留

必须保持复位值。

位 y

BRy: 清除端口 x 的位 y (Port x Reset bit y)

(y=15..0)

这些位只能写入并只能以字(16位)的方式操作。

• 0: 不影响对应的 ODRy 位

• 1: 清除对应的 ODRy 位为 0

# 9.2.7 端口 x 配置锁定寄存器(GPIOx\_LCKR)(x=A..D)

偏移地址: 0x18

复位值: 0x0000 0000

当执行正确的写序列设置了位 16(LCKK)时,该寄存器用来锁定端口位的配置。位[15:0]用于锁定 GPIO 端口的配置。在规定的写入操作期间,不能改变 LCKR[15:0]。当对相应的端口位执行了 LOCK 序列 后,在下次系统复位之前不能再更改端口位的配置。

每个锁定位锁定控制寄存器(CRL, CRH)中相应的 4 个位。

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



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

| 位 31:17        | Res: 保留<br>必须保持复位值。                                                                                                                                                                                                                                            |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 16           | LCKK: 锁键(Lock key)<br>该位可随时读出,它只可通过锁键写入序列修改。<br>• 0: 端口配置锁键位激活<br>• 1: 端口配置锁键位被激活,下次系统复位前 GPIOx_LCKR 寄存器被锁住。<br>锁键的写序列:<br>1. 写 1<br>2. 写 0<br>3. 写 1<br>4. 读 0<br>5. 读 1(该步可省略,但该步可用于确认锁键已被激活)<br>说明: 在操作锁键的写入序列时,不能改变 LCK[15:0]的值。<br>操作锁键写入序列中的任何错误将不能激活锁键。 |
| 位 y<br>(y=150) | LCKy: 端口 x 的锁位 y (Port x Lock bit y) 这些位可读可写,但只能在 LCKK 位为 0 时写入。  • 0: 不锁定端口的配置  • 1: 锁定端口的配置                                                                                                                                                                  |

# 9.3 复用功能 I/O 和调试配置(AFIO)

为了优化 64 脚封装的外设数目,可以把一些复用功能重新映射到其他引脚上。设置复用重映射和调试 I/O 配置寄存器(AFIO\_MAPR)实现引脚的重新映射。重映射后,复用功能不再映射到它们原来所指定的引脚。

# 9.3.1 把 OSC32\_IN/OSC32\_OUT 作为 GPIO 端口 PC14/PC15

当LSE 振荡器关闭时,LSE 振荡器引脚 OSC32\_IN/OSC32\_OUT 可以分别用做 GPIO 的 PC14/PC15,LSE 功能始终优先于通用 I/O 口的功能。

说明: 当关闭 Core 电压域(进入待机模式)或备份域使用 V<sub>BAT</sub> 供电(不再有 V<sub>DD</sub> 供电)时,不能使用 PC14/PC15 的 GPIO 口功能。参考"5.1.2 电池备份域"。

# 9.3.2 把 OSC\_IN/OSC\_OUT 引脚作为 GPIO 端口 PD0/PD1

外部振荡器引脚 OSC\_IN/OSC\_OUT 可以用做 GPIO 的 PD0/PD1,通过设置复用重映射和调试 I/O 配置寄存器(AFIO MAPR)实现。

说明:外部中断/事件功能没有被重映射。在 48 和 64 脚的封装上,PD0 和 PD1 不能用来产生外部中断/事件。



## 9.3.3 CAN 复用功能重映射

CAN 信号可以被映射到端口 A 或端口 B 上,如表 9-12 所示。

#### 表 9-12 CAN 复用功能重映射

| 复用功能   | CAN_REMAP[1:0]="00" | CAN_REMAP[1:0]="10" |
|--------|---------------------|---------------------|
| CAN_RX | PA11                | PB8                 |
| CAN_TX | PA12                | PB9                 |

## 9.3.4 JTAG/SWD 复用功能重映射

调试接口信号被映射到 GPIO 端口上,如表 9-13 所示。

表 9-13 调试接口信号

| 复用功能          | GPIO 端口 |
|---------------|---------|
| JTMS/SWDIO    | PA13    |
| JTCK/SWCLK    | PA14    |
| JTDI          | PA15    |
| JTDO/TRACESWO | PB3     |
| NJTRST        | PB4     |

为了在调试期间可以使用更多 GPIOs,通过设置复用重映射和调试 I/O 配置寄存器(AFIO\_MAPR)的 SWJ\_CFG[2:0]位,可以改变上述重映射配置。参见表 9-14。

表 9-14 调试端口映射

| SWJ_CFG[2:0] 可用的调试端口 |                                     | SWJ I/O 引脚分配        |                     |           |                       |                |
|----------------------|-------------------------------------|---------------------|---------------------|-----------|-----------------------|----------------|
|                      |                                     | PA13/JTMS<br>/SWDIO | PA14/JTCK/<br>SWCLK | PA15/JTDI | PB3/JTDO/<br>TRACESWO | PB4/<br>NJTRST |
| 000                  | 完全 SWJ(JTAG-DP+SW-DP)<br>(复位状态)     | I/O 不可用             | I/O 不可用             | I/O 不可用   | I/O 不可用               | I/O 不可用        |
| 001                  | 完全 SWJ(JTAG-DP+SW-DP)<br>但没有 NJTRST | I/O 不可用             | I/O 不可用             | I/O 不可用   | I/O 不可用               | I/O 可用         |
| 010                  | 关闭 JTAG-DP,启用 SW-DP                 | I/O 不可用             | I/O 不可用             | I/O 可用    | I/O 可 用<br>(1)        | I/O 可用         |
| 100                  | 关闭 JTAG-DP,关闭 SW-DP                 | I/O 可用              | I/O 可用              | I/O 可用    | I/O 可用                | I/O 可用         |
| 其它                   | 禁用                                  | -                   | -                   | -         | -                     | -              |

(1). I/O 口仅可在不使用异步跟踪时使用。

## 9.3.5 定时器复用功能重映射

定时器的重映射表见表 9-15 至表 9-17。



### 表 9-15 TIM3 复用功能重映射

| 复用功能     | TIM3_REMAP[1:0]=00<br>(没有重映射) | TIM3_REMAP[1:0]=10<br>(部分重映射) | TIM3_REMAP[1:0] = 11<br>(完全重映射) <sup>(1)</sup> |
|----------|-------------------------------|-------------------------------|------------------------------------------------|
| TIM3_CH1 | PA6                           | PB4                           | PC6                                            |
| TIM3_CH2 | PA7                           | PB5                           | PC7                                            |
| TIM3_CH3 | PB0                           |                               | PC8                                            |
| TIM3_CH4 | PB1                           |                               | PC9                                            |

#### (1). 重映射只适用于 64 脚的封装

#### 表 9-16 TIM2 复用功能重映射

| 复用功能             | TIM2_REMAP[1:0]=00<br>(没有重映射) | TIM2_REMAP[1:0]=01<br>(部分重映射) | TIM2_REMAP[1:0]=10<br>(部分重映射) <sup>(1)</sup> | TIM2_REMAP[1:0]=11<br>(完全重映射) |
|------------------|-------------------------------|-------------------------------|----------------------------------------------|-------------------------------|
| TIM2_CH1_ETR (1) | PA0                           | PA15                          | PA0                                          | PA15                          |
| TIM2_CH2         | PA1                           | PB3                           | PA1                                          | PB3                           |
| TIM2_CH3         | PA2                           |                               | PB10                                         |                               |
| TIM2_CH4         | PA3                           |                               | PB11                                         |                               |

### (1). TIM2\_CH1 和 TIM2\_ETR 共用一个引脚,但不能同时使用(因此使用约定的标记: TIM2\_CH1\_ETR)

#### 表 9-17 TIM1 复用功能重映射

| 复用功能映射    | TIM1_REMAP[1:0]=00<br>(没有重映射) | TIM1_REMAP[1:0]=01<br>(部分重映射) |
|-----------|-------------------------------|-------------------------------|
| TIM1_ETR  | PA12                          |                               |
| TIM1_CH1  | PA8                           |                               |
| TIM1_CH2  | PA9                           |                               |
| TIM1_CH3  | PA10                          |                               |
| TIM1_CH4  | PA11                          |                               |
| TIM1_BKIN | PB12 PA6                      |                               |
| TIM1_CH1N | PB13                          | PA7                           |
| TIM1_CH2N | PB14                          | РВО                           |
| TIM1_CH3N | PB15                          | PB1                           |

## 9.3.6 USART 复用功能重映射

参见复用重映射和调试 I/O 配置寄存器(AFIO\_MAPR)。



### 表 9-18 USART3 重映射

| 复用功能       | USART3_REMAP[1:0] = 00<br>(没有重映射) | USART3_REMAP[1:0] = 01<br>(部分重映射) <sup>(1)</sup> | USART3_REMAP[1:0] = 11<br>(完全重映射) <sup>(2)</sup> |
|------------|-----------------------------------|--------------------------------------------------|--------------------------------------------------|
| USART3_TX  | PB10                              | PC10                                             | 保留                                               |
| USART3_RX  | PB11                              | PC11                                             | 保留                                               |
| USART3_CK  | PB12                              | PC12                                             | 保留                                               |
| USART3_CTS | PB13                              |                                                  | 保留                                               |
| USART3_RTS | PB14                              |                                                  | 保留                                               |

### (1). 重映射只适用于 64 脚的封装。

### 表 9-19 USART2 重映射

| 复用功能       | USART2_REMAP=0 | USART2_REMAP=1 |
|------------|----------------|----------------|
| USART2_CTS | PAO PAO        | PD3            |
| USART2_RTS | PA1            | PD4            |
| USART2_TX  | PA2            | PD5            |
| USART2_RX  | PA3            | PD6            |
| USART2_CK  | PA4            | PD7            |

### 表 9-20 USART1 重映射

| 复用功能      | USART1_REMAP=0 | USART1_REMAP=1 |
|-----------|----------------|----------------|
| USART1_TX | PA9            | PB6            |
| USART1_RX | PA10           | PB7            |

# 9.3.7 I2C1 复用功能重映射

参见复用重映射和调试 I/O 配置寄存器(AFIO\_MAPR)。

### 表 9-21 I2C1 重映射

| 复用功能     | I2C1_REMAP=0 | I2C1_REMAP=1 |
|----------|--------------|--------------|
| I2C1_SCL | PB6          | PB8          |
| I2C1_SDA | PB7          | PB9          |

# 9.3.8 SPI1 复用功能重映射

参见复用重映射和调试 I/O 配置寄存器(AFIO\_MAPR)。

### 表 9-22 SPI1 重映射

| 复用功能     | SPI1_REMAP=0 | SPI1_REMAP=1 |
|----------|--------------|--------------|
| SPI1_NSS | PA4          | PA15         |



| 复用功能      | SPI1_REMAP=0 | SPI1_REMAP=1 |
|-----------|--------------|--------------|
| SPI1_SCK  | PA5          | PB3          |
| SPI1_MISO | PA6          | PB4          |
| SPI1_MOSI | PA7          | PB5          |

## 9.4 AFIO 寄存器

基地址: 0x40010000

空间大小: 0x400

AFIO 寄存器必须以字(32位)的方式进行访问。

注意: 对寄存器 AFIO\_EVCR、AFIO\_MAPR 和 AFIO\_EXTICRX 进行读写操作前,应当首先打开 AFIO 的时钟。参 考APB2 外设时钟使能寄存器(RCC\_APB2ENR)。

# 9.4.1 事件控制寄存器(AFIO\_EVCR)

偏移地址: 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 |    |    |    |    |    |   |   | EVOE | PORT[2:0] PIN[3:0 |    |   | [3:0] |   |   |   |
|     |    |    |    |    |    |   |   | rw   |                   | rw |   |       | r | w |   |

| 位 31:8 | Res: 保留<br>必须保持复位值。                                                                                                                                |
|--------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 7    | EVOE:允许事件输出(Event output enable)该位可由软件设置和清零。<br>当设置该位后,Cortex 的 EVENTOUT 将连接到由 PORT[2:0]和 PIN[3:0]所选择的 I/O 口。                                      |
| 位 6:4  | PORT[2:0]: 端口选择(Port selection)<br>选择用于输出 Cortex 的 EVENTOUT 信号的端口:<br>• 000: 选择 PA<br>• 001: 选择 PB<br>• 010: 选择 PC<br>• 011: 选择 PD<br>该位可由软件设置和清零。 |
| 位 3:0  | PIN[3:0]: 引脚选择(x=AE)(Pin selection)<br>选择用于输出 Cortex 的 EVENTOUT 信号的引脚:<br>• 0000: 选择 Px0<br>• 0001: 选择 Px1<br>• 0010: 选择 Px2<br>• 0011: 选择 Px3     |



• 0100: 选择 Px4

• 0101: 选择 Px5

• 0110: 选择 Px6

• 0111: 选择 Px7

• 1000: 选择 Px8

• 1001: 选择 Px9

• 1010: 选择 Px10

• 1011: 选择 Px11

• 1100: 选择 Px12

• 1101: 选择 Px13

• 1110: 选择 Px14

• 1111:选择 Px15

# 9.4.2 复用重映射和调试 I/O 配置寄存器(AFIO\_MAPR)

偏移地址: 0x04

复位值: 0x0000 0000

| 31 | 30 | 29  | 28 | 27 | 26  | 25    | 24   | 23     | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|-----|----|----|-----|-------|------|--------|----|----|----|----|----|----|----|
|    |    | Res |    |    | SWJ | _CFG[ | 2:0] | 0] Res |    |    |    |    |    |    |    |
| w  |    |     |    |    |     | W     |      |        |    |    |    |    |    |    |    |

| 15      | 14    | 13     | 1 | 11     | 10   | 9      | 8    | 7     | 6    | 5 | 4   | 3 | 2        | 1       | 0       |
|---------|-------|--------|---|--------|------|--------|------|-------|------|---|-----|---|----------|---------|---------|
|         |       |        | 2 |        |      |        |      |       |      |   |     |   |          |         |         |
| PD01_RE | CAN1_ | REMA   | R | TIM3_  | REMA | TIM2_  | REMA | TIM1_ | REMA |   | Res |   | USART1_R | I2C1_RE | SPI1_RE |
| MAP     | P[1   | P[1:0] |   | P[1:0] |      | P[1:0] |      | P[1   | L:0] |   |     |   | EMAP     | MAP     | MAP     |
| rw      | r     | w      |   | r      | W    | r      | w    | r     | w    |   |     |   | rw       | rw      | rw      |

| rw      | rw                                                                        | rw                                                                                                                                   | rw                                                                | rw                                    |                              | rw           | rw         | rw        |  |  |  |
|---------|---------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------|---------------------------------------|------------------------------|--------------|------------|-----------|--|--|--|
| 位 31:27 | Res: 保留<br>必须保持复                                                          | [位值。                                                                                                                                 |                                                                   |                                       |                              |              |            |           |  |  |  |
| 位 26:24 | 这些位只可的 I/O 口。<br>默认状态是<br>选择 JTAG §<br>• 000: 完:<br>• 001: 完:<br>• 010: 关 | EO]: 串行线 JTAG<br>J由软件写(读述<br>SWJ(串行线 JT<br>是启用 SWJ 但不<br>或 SW(串行线)<br>全 SWJ(JTAG-DI<br>全 SWJ(JTAG-DI<br>闭 JTAG-DP,启)<br>闭 JTAG-DP,关问 | 这些位,将返<br>FAG)支持 JT.<br>带跟踪功能。<br>)模式。<br>P+SW-DP),<br>P+SW-DP),{ | 回未定义的。<br>AG 或 SWD i<br>这种状态下<br>复位状态 | 数值),用<br>疠问 Cortex<br>可以通过 J | 的调试端口        | 口。系统复      | 夏位后的      |  |  |  |
| 位 23:16 | 5 Res: 保留<br>必须保持复位值。                                                     |                                                                                                                                      |                                                                   |                                       |                              |              |            |           |  |  |  |
| 位 15    | OSC_IN/OSC_                                                               | AP: 端口 DO/໑<br>_OUT)<br>次件置'1'或置'0'。                                                                                                 |                                                                   | 射到 OSC_II                             | N/OSC_OU <sup>-</sup>        | Γ ( Port DO/ | Port D1 ma | apping on |  |  |  |



它控制 PDO 和 PD1 的 GPIO 功能映射。当不使用主振荡器 HSE 时(应用程序工作在内部的 8 MHz RC 振荡器下), PDO 和 PD1 可以映射到 OSC IN 和 OSC OUT 引脚。 • 0: 不进行 PDO 和 PD1 的重映射。 • 1: PDO 映射到 OSC IN, PD1 映射到 OSC OUT。 位 14:13 CAN REMAP[1:0]: CAN 复用功能重映射(CAN alternate function remapping) 这些位可由软件置'1'或置'0'。 该位域控制复用功能 CAN RX 和 CAN TX 的重映射。 • 00: CAN RX 映射到 PA11, CAN TX 映射到 PA12。 • 01: 未用组合 • 10: CAN RX 映射到 PB8, CAN TX 映射到 PB9。 • 11: CAN RX 映射到 PDO, CAN TX 映射到 PD1。 位 12 Res: 保留 必须保持复位值。 位 11:10 TIM3 REMAP[1:0]: 定时器 3 的重映射(TIM3 remapping) 这些位可由软件置'1'或置'0',控制定时器 3 的通道 1 至 4 在 GPIO 端口的映射。 • 00: 没有重映射(CH1/PA6, CH2/PA7, CH3/PB0, CH4/PB1) • 01: 未用组合 • 10: 部分映射(CH1/PB4, CH2/PB5, CH3/PB0, CH4/PB1) • 11: 完全映射(CH1/PC6, CH2/PC7, CH3/PC8, CH4/PC9) 说明: 重映射不影响在PD2 上的TIM3\_ETR。 位 9:8 TIM2 REMAP[1:0]: 定时器 2 的重映射(TIM2 remapping) 这些位可由软件置'1'或置'0',控制定时器2的通道1至4和外部触发(ETR)在GPIO端口 的映射。 • 00: 没有重映射(CH1/ETR/PA0, CH2/PA1, CH3/PA2, CH4/PA3) • 01: 部分映射(CH1/ETR/PA15,CH2/PB3,CH3/PA2,CH4/PA3) • 10: 部分映射(CH1/ETR/PA0, CH2/PA1, CH3/PB10, CH4/PB11) • 11: 完全映射(CH1/ETR/PA15, CH2/PB3, CH3/PB10, CH4/PB11) 位 7:6 TIM1 REMAP[1:0]: 定时器 1 的重映射(TIM1 remapping) 这些位可由软件置'1'或置'0',控制定时器1的通道1至4、1N至3N、外部触发(ETR)和 刹车输入(BKIN)在 GPIO 端口的映射。 • 00: 没有重映射(ETR/PA12, CH1/PA8, CH2/PA9, CH3/PA10, CH4/PA11, BKIN/PB12, CH1N/PB13, CH2N/PB14, CH3N/PB15) • 01: 部分映射(ETR/PA12, CH1/PA8, CH2/PA9, CH3/PA10, CH4/PA11, BKIN/PA6, CH1N/PA7, CH2N/PB0, CH3N/PB1) • 10: 未使用 • 11: 未使用 位 5:4 TIM1 REMAP[1:0]: 定时器 1 的重映像 (TIM1 remapping) 这些位可由软件置'1'或置'0',控制定时器1的通道1至4、1N至3N、外部触发(ETR)



和刹车输入 (BKIN)在 GPIO 端口的映像。 • 00: 没有重映像(ETR/PA12, CH1/PA8, CH2/PA9, CH3/PA10, CH4/PA11, BKIN/PB12, CH1N/PB13, CH2N/PB14, CH3N/PB15); • 01: 部分映像(ETR/PA12, CH1/PA8, CH2/PA9, CH3/PA10, CH4/PA11, BKIN/PA6, CH1N/PA7, CH2N/PB0, CH3N/PB1); • 10: 未用组合; • 11: 保留 位 3 USART2 REMAP: USART2 的重映像 (USART2 remapping) 这些位可由软件置'1'或置'0',控制 USART2 的 CTS、RTS、CK、TX 和 RX 复用功能在 GPIO 端 口的映像。 • 0: 没有重映像(CTS/PAO, RTS/PA1, TX/PA2, RX/PA3, CK/PA4) • 1: 重映像(CTS/PD3, RTS/PD4, TX/PD5, RX/PD6, CK/PD7) 位. 2 USART1\_REMAP: USART1 的重映射(USART1 remapping) 该位可由软件置'1'或置'0',控制 USART1 的 TX 和 RX 复用功能在 GPIO 端口的映射。 • 0: 没有重映射(TX/PA9, RX/PA10) • 1: 重映射 (TX/PB6, RX/PB7) 位 1 I2C1\_REMAP: I2C1 的重映射(I2C1 remapping) 该位可由软件置'1'或置'0',控制 I2C1 的 SCL 和 SDA 复用功能在 GPIO 端口的映射。 • 0: 没有重映射(SCL/PB6, SDA/PB7) • 1: 重映射(SCL/PB8, SDA/PB9) 位 0 SPI1 REMAP: SPI1 的重映射 (SPI1 remapping) 该位可由软件置'1'或置'0',控制 SPI1 的 NSS、SCK、MISO 和 MOSI 复用功能在 GPIO 端口 的映射。 • 0: 没有重映射(NSS/PA4,SCK/PA5,MISO/PA6,MOSI/PA7) • 1: 重映射(NSS/PA15, SCK/PB3, MISO/PB4, MOSI/PB5)

# 9.4.3 外部中断配置寄存器 1 (AFIO\_EXTICR1)

偏移地址: 0x08 复位值: 0x0000

30

| 15 | 14   | 13     | 12 | 11 | 10      | 9 | 8     | 7     | 6 | 5          | 4 | 3  | 2 | 1 | 0 |
|----|------|--------|----|----|---------|---|-------|-------|---|------------|---|----|---|---|---|
|    | EXTI | 3[3:0] |    |    | EXTI2[3 |   | EXTI: | [3:0] |   | EXTI0[3:0] |   |    |   |   |   |
|    | r    | w      |    |    | rw      |   |       |       | r | w          |   | rw |   |   |   |

Res

| 位 31:16   | Res: 保留                                                |
|-----------|--------------------------------------------------------|
|           | 必须保持复位值。                                               |
| 位 4x+3:4x | EXTIx[3:0]: EXTIx 配置(x=30)(EXTI x configuration(x=30)) |
|           | 这些位可由软件读写,用于选择 EXTIx 外部中断的输入源。参看"8.2.6 外部中断/事件         |

18



(x=3..0)

线映射"。

0000: PA[x]引脚
0001: PB[x]引脚
0010: PC[x]引脚
0011: PD[x]引脚
其他值: 保留

# 9.4.4 外部中断配置寄存器 2(AFIO\_EXTICR2)

偏移地址: 0x0C 复位值: 0x0000

| 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[3:0] EXTI6[3:0] |    |    |    |    |   |   |   | EXTI5 | [3:0] |   | EXTI4[3:0] |   |   |   |
|    | rw                    |    |    |    |    |   |   |   | r     | w     |   |            | r | w |   |

| 位 31:16                     | Res: 保留<br>必须保持复位值。                                                                                                                                 |
|-----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 4(x-4)+3:4(x-4)<br>(x=74) | EXTIx[3:0]: EXTIx 配置(x=74)(EXTI x configuration(x=74)) 这些位可由软件读写,用于选择 EXTIx 外部中断的输入源。  • 0000: PA[x]引脚  • 0001: PB[x]引脚  • 0010: PC[x]引脚  • 其他值: 保留 |

# 9.4.5 外部中断配置寄存器 3(AFIO\_EXTICR3)

偏移地址: 0x10 复位值: 0x0000

| 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 |  |
|----|-------|--------|----|-----------|-------|-------|--|------------|---|---|---|----|---|---|---|--|
|    | EXTI1 | 1[3:0] |    |           | EXTIS | [3:0] |  | EXTI8[3:0] |   |   |   |    |   |   |   |  |
|    | rw    |        |    |           | rw    |       |  |            |   | W |   | rw |   |   |   |  |

| 位 31:16                      | Res: 保留<br>必须保持复位值。                                                                                      |
|------------------------------|----------------------------------------------------------------------------------------------------------|
| 位 4(x-8)+3:4(x-8)<br>(x=118) | EXTIx[3:0]: EXTIx 配置(x=118)(EXTI x configuration(x=118)) 这些位可由软件读写,用于选择 EXTIx 外部中断的输入源。  • 0000: PA[x]引脚 |



• 0001: PB[x]引脚

• 0010: PC[x]引脚

• 0011: PD[x]引脚

• 其他值: 保留

# 9.4.6 外部中断配置寄存器 4(AFIO\_EXTICR4)

偏移地址: 0x14 复位值: 0x0000

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

| 15 | 16   17   19   19 |        |  |    | 10    | 9 | 8 | 7           | 7 6 5 4 |    |  |  | 2 | 1 | 0 |
|----|-------------------|--------|--|----|-------|---|---|-------------|---------|----|--|--|---|---|---|
|    | EXTI1             | 5[3:0] |  |    | EXTI1 |   |   | EXTI12[3:0] |         |    |  |  |   |   |   |
|    | r                 | W      |  | rw |       |   |   | r۱          | w       | rw |  |  |   |   |   |

| 位 31:16                         | Res: 保留<br>必须保持复位值。                                                                                                                           |
|---------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 位 4(x-12)+3:4(x-12)<br>(x=1512) | EXTIx[3:0]: EXTIx 配置(x=1512)(EXTI x configuration (x=1512)) 这些位可由软件读写,用于选择 EXTIx 外部中断的输入源。  • 0000: PA[x]引脚  • 0001: PB[x]引脚  • 0011: PD[x]引脚 |
|                                 | <ul><li>其他值: 保留</li></ul>                                                                                                                     |



## 10 DMA 控制器

直接存储器存取(DMA)用来提供外设和存储器之间或者存储器和存储器之间的高速数据传输。 无须 CPU 干预,数据可以通过 DMA 快速地移动,这就节省了 CPU 的资源来做其他操作。

DMA 控制器共有 7 个通道(有 7 个通道),每个通道专门用来管理来自于一个或多个外设对存储器的访问请求。还有一个仲裁器来协调各个 DMA 请求的优先权。

## 10.1 DMA 主要特性

- 7个独立的可配置的通道(请求): DMA 有 7 个通道。
- 每个通道都直接连接专用的硬件 DMA 请求,每个通道都同样支持软件触发。通过软件来配置 该功能。
- 在同一个 DMA 模块上,多个请求间的优先权可以通过软件编程设置(共有四级:最高、高、中等和低),优先权设置相等时由硬件决定(请求 0 优先于请求 1,依此类推)。
- 独立数据源和目标数据区的传输宽度(字节、半字、字),模拟打包和拆包的过程。源和目标 地址必须按数据传输宽度对齐。
- 支持循环的缓冲器管理。
- 每个通道都有 3 个事件标志(DMA 半传输、DMA 传输完成和 DMA 传输出错),这 3 个事件标志逻辑或成为一个单独的中断请求。
- Flash、SRAM、外设的 SRAM、APB1、APB2 和 AHB 外设均可作为访问的源和目标。
- 存储器到存储器的传输、外设和存储器、存储器和外设之间的传输
- 可编程的数据传输数目:最大为65536
- 支持外设的 DMA

下面为功能框图:



图 10-1 DMA 框图



## 10.2 功能描述

DMA 控制器通过与 Cortex®-M3 内核共享的系统总线来执行直接存储器数据传输。当 CPU 和 DMA 同时访问相同的目标(存储器或外设)时,DMA 请求会暂停 CPU 在若干个周期内访问系统总线。总线仲裁器执行循环调度,这可以保证 CPU 至少可以得到一半的系统总线(存储器或外设)带宽。

### 10.2.1 DMA 处理

在发生一个事件后,外设向 DMA 控制器发送一个请求信号。DMA 控制器根据通道的优先权处理请求。当 DMA 控制器开始访问发出请求的外设时,DMA 控制器立即向它发送一个应答信号。当从 DMA 控制器得到应答信号时,外设立即释放它的请求。一旦外设释放了这个请求,DMA 控制器撤销应答信号。如果有更多的请求时,外设可以启动下一个周期。

总之,每次 DMA 传输由 3 个操作组成:

- 从外设数据寄存器或者从当前外设/存储器地址寄存器指示的存储器地址取数据,第一次传输时的开始地址是 DMA\_CPARx 或 DMA\_CMARx 寄存器指定的外设基地址或存储器地址。
- 向外设数据寄存器或者当前外设/存储器地址寄存器指示的存储器地址存数据,第一次传输时的开始地址是 DMA\_CPARx 或 DMA\_CMARx 寄存器指定的外设基地址或存储器地址。
- 执行一次 DMA CNDTRx 寄存器的递减操作,该寄存器包含未完成的操作次数。

## 10.2.2 仲裁器

仲裁器根据通道请求的优先级来启动外设/存储器的访问。

优先权管理分2个阶段:

- 软件:每个通道的优先权可以在 DMA\_CCRx 寄存器中设置,有 4 个等级:
  - 。 最高优先级
  - 。高优先级
  - 。 中等优先级
  - 。 低优先级
- 硬件:如果 2 个请求有相同的软件优先级,则较低编号的通道比较高编号的通道有更高的优先级。举个例子,通道 2 优先于通道 4。

### 10.2.3 DMA 通道

每个通道都可以在有固定地址的外设寄存器和存储器地址之间执行 DMA 传输。在每次传输后,包含了待传输数据量的寄存器会递减。

### 10.2.3.1 可编程的数据量

外设和存储器的传输数据宽度可以通过 DMA CCRx 寄存器中的 PSIZE 和 MSIZE 位编程。

### 10.2.3.2 指针增量

通过设置 DMA\_CCRx 寄存器中的 PINC 和 MINC 标志位,外设和存储器的指针在每次传输后可以选成自动增加模式。当设置为增量模式时,下一个要传输的地址将是前一个地址加上增量值,增量值取决由所选的数据宽度决定,可以为 1、2 或 4。第一个传输的地址是存放在 DMA\_CPARx/DMA\_CMARx寄存器中。在传输过程中,这些寄存器保持它们初始的数值,软件不能改变和读出当前正在传输的地址(它在当前的内部外设/存储器地址寄存器中)。

当通道配置为非循环模式时,传输结束后(即待传输次数变为 0)将不再处理 DMA 请求。为了载入新的传输数目到 DMA CNDTRx 寄存器中,必须禁用 DMA 通道。



注意:若禁用了DMA 通道,则DMA 寄存器不会被复位。DMA 寄存器(DMA\_CCRx, DMA\_CPARx 和DMA CMARx)在通道配置期间仍保持初始值。

在循环模式下,最后一次传输结束时,DMA\_CNDTRx 寄存器会自动地再次加载为编程的初始值。当前的内部地址寄存器将再次载入 DMA\_CPARx/DMA\_CMARx 寄存器中的基地址。

### 10.2.3.3 通道配置过程

下面是配置 DMA 通道 x 的步骤 (x 代表通道号):

- 1. 在 DMA\_CPARx 寄存器中设置外设寄存器的地址。发生外设数据传输请求时,这个地址将是数据传输的源或目标。
- 2. 在 DMA\_CMARx 寄存器中设置数据存储器的地址。发生外设数据传输请求时,传输的数据将从 这个地址读出或写入这个地址。
- 3. 在 DMA CNDTRx 寄存器中设置要传输的数据量。在每个数据传输后,这个数值递减。
- 4. 在 DMA\_CCRx 寄存器的 PL[1:0]位中设置通道的优先级。
- 5. 在 DMA\_CCRx 寄存器中设置数据传输的方向、循环模式、外设和存储器的增量模式、外设和存储器的数据宽度、传输一半产生中断或传输完成产生中断。
- 6. 设置 DMA CCRx 寄存器的 ENABLE 位, 启动该通道。
- 一旦启动了 DMA 通道,它就能处理连到该通道上的外设的 DMA 请求。

当传输一半的数据后,半传输标志(HTIF)被置'1',当设置了半传输中断使能位(HTIE)时,将产生一个中断请求。在数据传输结束后,传输完成标志(TCIF)被置'1',当设置了传输完成中断使能位(TCIE)时,将产生一个中断请求。

### 10.2.3.4 循环模式

循环模式用于处理循环缓冲区和连续的数据传输(如 ADC 的扫描模式)。在 DMA\_CCRx 寄存器中的 CIRC 位用于开启这一功能。当启动了循环模式,数据传输的数目变为 0 时,将会自动地被恢复成配置通道时设置的初值,DMA 操作将会继续进行。

### 10.2.3.5 存储器到存储器模式

DMA 通道的操作可以在没有外设请求的情况下进行,这种操作就是存储器到存储器模式。

当设置了 DMA\_CCRx 寄存器中的 MEM2MEM 位之后,在软件设置了 DMA\_CCRx 寄存器中的 EN 位启动 DMA 通道时,DMA 传输将马上开始。当 DMA\_CNDTRx 寄存器变为 0 时,DMA 传输结束。存储器到存储器模式不能与循环模式同时使用。

# 10.2.4 可编程的数据传输宽度、对齐方式和数据大小端

当 PSIZE 和 MSIZE 不相同时,DMA 模块按照下表进行数据对齐。

表 10-1 可编程的数据传输宽度和大小端操作(当 PINC=MINC=1)

| 源端<br>口宽<br>度 | 目标<br>端口<br>宽度 | 传输<br>数目<br>(NDT) | 源内容:<br>地址/数据              | 传输操作                                                                                                           | 目标内容:<br>地址/数据             |
|---------------|----------------|-------------------|----------------------------|----------------------------------------------------------------------------------------------------------------|----------------------------|
| 8             | 8              | 4                 | 0x0/B0<br>0x1/B1<br>0x2/B2 | 1: 在 0x0 读 B0[7:0],在 0x0 写 B0[7:0]<br>2: 在 0x1 读 B1[7:0],在 0x1 写 B1[7:0]<br>3: 在 0x2 读 B2[7:0],在 0x2 写 B2[7:0] | 0x0/B0<br>0x1/B1<br>0x2/B2 |



| 源端<br>口宽<br>度 | 目标<br>端口<br>宽度 | 传输<br>数目<br>(NDT) | 源内容:<br>地址/数据                                                | 传输操作                                                                                                                                                                                                         | 目标内容:<br>地址/数据                                               |
|---------------|----------------|-------------------|--------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|
|               |                |                   | 0x3/B3                                                       | 4: 在 0x3 读 B3[7:0],在 0x3 写 B3[7:0]                                                                                                                                                                           | 0x3/B3                                                       |
| 8             | 16             | 4                 | 0x0/B0<br>0x1/B1<br>0x2/B2<br>0x3/B3                         | 1: 在 0x0 读 B0[7:0], 在 0x0 写 00B0[15:0]<br>2: 在 0x1 读 B1[7:0], 在 0x2 写 00B1[15:0]<br>3: 在 0x2 读 B2[7:0], 在 0x4 写 00B2[15:0]<br>4: 在 0x3 读 B3[7:0], 在 0x6 写 00B3[15:0]                                         | 0x0/00B0<br>0x2/00B1<br>0x4/00B2<br>0x6/00B3                 |
| 8             | 32             | 4                 | 0x0/B0<br>0x1/B1<br>0x2/B2<br>0x3/B3                         | 1: 在 0x0 读 B0[7:0],在 0x0 写 000000B0[31:0]<br>2: 在 0x1 读 B1[7:0],在 0x4 写 000000B1[31:0]<br>3: 在 0x2 读 B2[7:0],在 0x8 写 000000B2[31:0]<br>4: 在 0x3 读 B3[7:0],在 0xC 写 000000B3[31:0]                             | 0x0/000000B0<br>0x4/000000B1<br>0x8/000000B2<br>0xC/000000B3 |
| 16            | 8              | 4                 | 0x0/B1B0<br>0x2/B3B2<br>0x4/B5B4<br>0x6/B7B6                 | 1: 在 0x0 读 B1B0[15:0],在 0x0 写 B0[7:0]<br>2: 在 0x2 读 B3B2[15:0],在 0x1 写 B2[7:0]<br>3: 在 0x4 读 B5B4[15:0],在 0x2 写 B4[7:0]<br>4: 在 0x6 读 B7B6[15:0],在 0x3 写 B6[7:0]                                             | 0x0/B0<br>0x1/B2<br>0x2/B4<br>0x3/B6                         |
| 16            | 16             | 4                 | 0x0/B1B0<br>0x2/B3B2<br>0x4/B5B4<br>0x6/B7B6                 | 1: 在 0x0 读 B1B0[15:0],在 0x0 写 B1B0[15:0]<br>2: 在 0x2 读 B3B2[15:0],在 0x2 写 B3B2[15:0]<br>3: 在 0x4 读 B5B4[15:0],在 0x4 写 B5B4[15:0]<br>4: 在 0x6 读 B7B6[15:0],在 0x6 写 B7B6[15:0]                                 | 0x0/B1B0<br>0x2/B3B2<br>0x4/B5B4<br>0x6/B7B6                 |
| 16            | 32             | 4                 | 0x0/B1B0<br>0x2/B3B2<br>0x4/B5B4<br>0x6/B7B6                 | 1: 在 0x0 读 B1B0[15:0],在 0x0 写 0000B1B0[31:0]<br>2: 在 0x2 读 B3B2[15:0],在 0x4 写 0000B3B2[31:0]<br>3: 在 0x4 读 B5B4[15:0],在 0x8 写 0000B5B4[31:0]<br>4: 在 0x6 读 B7B6[15:0],在 0xC 写 0000B7B6[31:0]                 | 0x0/0000B1B0<br>0x4/0000B3B2<br>0x8/0000B5B4<br>0xC/0000B7B6 |
| 32            | 8              | 4                 | 0x0/B3B2B1B0<br>0x4/B7B6B5B4<br>0x8/BBBAB9B8<br>0xC/BFBEBDBC | 1: 在 0x0 读 B3B2B1B0[31:0],在 0x0 写 B0[7:0]<br>2: 在 0x4 读 B7B6B5B4[31:0],在 0x1 写 B4[7:0]<br>3: 在 0x8 读 BBBAB9B8[31:0],在 0x2 写 B8[7:0]<br>4: 在 0xC 读 BFBEBDBC[31:0],在 0x3 写 BC[7:0]                             | 0x0/B0<br>0x1/B4<br>0x2/B8<br>0x3/BC                         |
| 32            | 16             | 4                 | 0x0/B3B2B1B0<br>0x4/B7B6B5B4<br>0x8/BBBAB9B8<br>0xC/BFBEBDBC | 1: 在 0x0 读 B3B2B1B0[31:0],在 0x0 写 B1B0[15:0]<br>2: 在 0x4 读 B7B6B5B4[31:0],在 0x2 写 B5B4[15:0]<br>3: 在 0x8 读 BBBAB9B8[31:0],在 0x4 写 B9B8[15:0]<br>4: 在 0xC 读 BFBEBDBC[31:0],在 0x6 写 BDBC[15:0]                 | 0x0/B1B0<br>0x2/B5B4<br>0x4/B9B8<br>0x6/BDBC                 |
| 32            | 32             | 4                 | 0x0/B3B2B1B0<br>0x4/B7B6B5B4<br>0x8/BBBAB9B8<br>0xC/BFBEBDBC | 1: 在 0x0 读 B3B2B1B0[31:0],在 0x0 写 B3B2B1B0[31:0]<br>2: 在 0x4 读 B7B6B5B4[31:0],在 0x4 写 B7B6B5B4[31:0]<br>3: 在 0x8 读 BBBAB9B8[31:0],在 0x8 写 BBBAB9B8[31:0]<br>4: 在 0xC 读 BFBEBDBC[31:0],在 0xC 写 BFBEBDBC[31:0] | 0x0/B3B2B1B0<br>0x4/B7B6B5B4<br>0x8/BBBAB9B8<br>0xC/BFBEBDBC |

### 10.2.4.1 寻址一个不支持字节或半字写的 AHB 设备

当 DMA 模块开始一个 AHB 的字节或半字写操作时,数据将在 HWDATA[31:0]总线中未使用的部分重复。因此,如果 DMA 以字节或半字写入不支持字节或半字写操作的 AHB 设备时(即 HSIZE 不适于该模块),不会发生错误,DMA 将按照下面两个例子写入 32 位 HWDATA 数据:

当 HSIZE=半字时,写入半字'0xABCD', DMA 将设置 HWDATA 总线为'0xABCDABCD'。

当 HSIZE=字节时,写入字节'0xAB',DMA 将设置 HWDATA 总线为'0xABABABAB'。



假定 AHB/APB 桥是一个 AHB 的 32 位从设备,它不处理 HSIZE 参数,它将按照下述方式把任何 AHB 上的字节或半字按 32 位传送到 APB 上:

- 一次向地址 0x0(或 0x1、0x2 或 0x3)写一个字节数据'0xB0'(即 AHB 字节写操作),将被转换成对地址 0x0 写入一个字数据'0xB0B0B0B0'。
- 一次向地址 0x0 (或 0x2) 写半个字数据' 0xB1B0' (即 AHB 半字写操作),将被转换成对地址 0x0 写入一个字数据'0xB1B0B1B0'。

例如,如果要写入 APB 备份寄存器(与 32 位地址对齐的 16 位寄存器),需要配置存储器数据源宽度(MSIZE)为'16 位',外设目标数据宽度(PSIZE)为'32 位'。

### 10.2.5 错误管理

读/写一个保留的地址区域,将会产生 DMA 传输错误。当在 DMA 读写操作时发生了 DMA 传输错误,硬件会清除发生错误的通道所对应的通道配置寄存器(DMA\_CCRx)的 EN 位,该通道操作自动被停止。此时,在 DMA\_ISR 寄存器中对应该通道的传输错误中断标志位(TEIF)将被置位,如果在 DMA CCRx 寄存器中设置了传输错误中断使能位,则将产生中断。

## 10.2.6 中断

每个 DMA 通道都可以在 DMA 传输过半、传输完成和传输错误时产生中断。为应用的灵活性考虑,通过设置寄存器的不同位来打开这些中断。

| 中断事件 | 事件标志位 | 使能控制位 |
|------|-------|-------|
| 传输过半 | HTIF  | HTIE  |
| 传输完成 | TCIF  | TCIE  |
| 传输错误 | TEIF  | TEIE  |

表 10-2 DMA 中断请求

注意: DMA 通道都有自己的中断向量, 详细的请参考中断向量表。

## 10.2.7 DMA 请求映射

### 10.2.7.1 DMA1 控制器

从外设(TIMx[x=1、2、3、4]、ADC1、SPI1、SPI2、I2Cx[x=1、2]和 USARTx[x=1、2、3])产生的 7 个请求,通过逻辑或输入到 DMA1 控制器,这意味着同时只能有一个请求有效。参见下图的 DMA 请求映射。

外设的 DMA 请求,可以通过设置相应外设寄存器中的控制位,被独立地开启或关闭。





图 10-2 DMA 请求映射

表 10-3 各个通道的 DMA1 请求一览

|       |          |           |           | 22H) 2 (2 ///-)             |           |           |           |
|-------|----------|-----------|-----------|-----------------------------|-----------|-----------|-----------|
| 外设    | 通道 1     | 通道 2      | 通道 3      | 通道 4                        | 通道 5      | 通道 6      | 通道 7      |
| ADC1  | ADC1     | -         | -         | -                           | -         | -         | -         |
| SPI   | -        | SPI1_RX   | SPI1_TX   | SPI2_RX                     | SPI2_TX   | -         | -         |
| USART | -        | USART3_TX | USART3_RX | USART1_TX                   | USART1_RX | USART2_RX | USART2_TX |
| I2C   | -        | -         | -         | I2C2_TX                     | I2C2_RX   | I2C1_TX   | I2C1_RX   |
| TIM1  | -        | TIM1_CH1  | TIM1_CH2  | TIM1_CH4 TIM1_TRIG TIM1_COM | TIM1_UP   | TIM1_CH3  | -         |
| TIM2  | TIM2_CH3 | TIM2_UP   | -         | -                           | TIM2_CH1  | -         | TIM2_CH2  |



| 外设   | 通道 1     | 通道 2     | 通道 3                | 通道 4     | 通道 5     | 通道 6                  | 通道 7     |
|------|----------|----------|---------------------|----------|----------|-----------------------|----------|
|      |          |          |                     |          |          |                       | TIM2_CH4 |
| TIM3 | -        | TIM3_CH3 | TIM3_CH4<br>TIM3_UP | -        | -        | TIM3_CH1<br>TIM3_TRIG | -        |
| TIM4 | TIM4_CH1 | -        | -                   | TIM4_CH2 | TIM4_CH3 |                       | TIM4_UP  |

# 10.3 DMA 寄存器

基地址: 0x4002 0000 空间大小: 0x400

# 10.3.1 DMA 中断状态寄存器(DMA\_ISR)

27

TEIF7

26

HTIF7

25

TCIF7

24

GIF7

23

TEIF6

22

HTIF6

21

TCIF6

20

GIF6

19

TEIF5

18

HTIF5

17

TCIF5

16

GIF5 r

偏移地址: 0x00

复位值: 0x0000 0000

30 29

Res

28

| 15             | 14        | 13                                                                                                                                                                                                                 | 12                 | 11                     | 10           | 9                       | 8                     | 7         | 6      | 5        | 4        | 3      | 2      | 1      | 0      |
|----------------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|------------------------|--------------|-------------------------|-----------------------|-----------|--------|----------|----------|--------|--------|--------|--------|
| TEIF           | HTIF<br>4 | TCIF                                                                                                                                                                                                               | GIF                | TEIF                   | HTIF         | TCIF                    | GIF                   | TEIF      | HTIF   | TCIF     | GIF      | TEIF   | HTIF   | TCIF   | GIF    |
| 4<br>r         | 4<br>r    | 4<br>r                                                                                                                                                                                                             | 4<br>r             | 3<br>r                 | 3<br>r       | 3<br>r                  | 3<br>r                | 2<br>r    | 2<br>r | 2<br>r   | 2<br>r   | 1<br>r | 1<br>r | 1<br>r | 1<br>r |
| 位 31           |           | Res:                                                                                                                                                                                                               | 保留                 | 夏位值。                   |              | <u> </u>                |                       | -         | -      | <u> </u> | <u> </u> |        |        | ·      | · ·    |
| 位 4x-<br>(x=7: |           | <ul> <li>TEIFx: 通道 x 的传输错误标志 (x=71) (Channel x transfer error flag (x=71))</li> <li>硬件设置这些位。</li> <li>在 DMA_IFCR 寄存器的相应位写入'1'可以清除这里对应的标志位。</li> <li>0: 在通道 x 没有传输错误 (TE)</li> <li>1: 在通道 x 发生了传输错误 (TE)</li> </ul> |                    |                        |              |                         |                       |           |        |          |          |        |        |        |        |
| 位 4x-<br>(x=7: |           | 硬件<br>在 D<br>• 0:                                                                                                                                                                                                  | 设置定<br>MA_IF<br>在通 | 这些位。<br>CR 寄花<br>道 x 没 | 半传输字器的标注 有半传 | 目应位 <sup>5</sup><br>输事件 | <b>員入′1</b> ′<br>≕(HT | '可以清<br>) |        |          |          |        | .))    |        |        |
| 位 4x-<br>(x=7) | _         | TCIFx: 通道 x 的传输完成标志(x=71)(Channel x transfer complete flag(x=71)) 硬件设置这些位。 在 DMA_IFCR 寄存器的相应位写入'1'可以清除这里对应的标志位。                                                                                                    |                    |                        |              |                         |                       |           |        |          |          |        |        |        |        |
| 位 4x-          | -4        | GIFx: 通道 x 的全局中断标志(x=71)(Channel x global interrupt flag(x=71))<br>硬件设置这些位。                                                                                                                                        |                    |                        |              |                         |                       |           |        |          |          |        |        |        |        |

16

**CGIF** 

**CTCIF** 

**CHTIF** 



(x=7..1)

在 DMA\_IFCR 寄存器的相应位写入'1'可以清除这里对应的标志位。

23

CTEIF

CHTIF

**CTCIF** 

**CGIF** 

**CTEIF** 

- 0: 在通道 x 没有 TE、HT 或 TC 事件
- 1: 在通道 x 产生了 TE、HT 或 TC 事件

**CTCIF** 

CGIF

# 10.3.2 DMA 中断标志清除寄存器(DMA\_IFCR)

CHTIF

偏移地址: 0x04

复位值: 0x0000 0000

30 29

Res

28

27

**CTEIF** 

|            | INCS       | CTEM CHAIN CHEM COM CTEM CHAIN CHEM CHEM CHEM CHEM |                                                                   |             |            |                                        |                   |            |                 |          |           |           |           |            |           |           |  |
|------------|------------|----------------------------------------------------|-------------------------------------------------------------------|-------------|------------|----------------------------------------|-------------------|------------|-----------------|----------|-----------|-----------|-----------|------------|-----------|-----------|--|
|            |            |                                                    | 7                                                                 | 7           | 7          | 7                                      | 6                 |            | 6               | 6        | 6         |           | 5         | 5          | 5         | 5         |  |
|            |            |                                                    | w                                                                 | W           | w          | W                                      | W                 | '          | N               | W        | W         |           | w         | W          | W         | w         |  |
| 1.5        | 1.4        | 12                                                 | 12                                                                | 11          | 10         | 0                                      | 0                 | 7          | c               |          | -         | 1         | 2         | 2          | 1         | 0         |  |
| 15<br>CTEI | 14         | 13<br>CTCI                                         | 12<br>CGI                                                         | 11<br>CTEI  | 10<br>CHTI | 9<br>CTCI                              | 8<br>CGI          | 7          | CH <sup>-</sup> |          | 5         | 4<br>GI   | 3<br>CTEI | 2          | 1<br>CTCI | 0         |  |
| F4         | CHTI<br>F4 | F4                                                 | F4                                                                | F3          | F3         | F3                                     | F3                | CTEI<br>F2 | F2              |          |           | .Gi<br>F2 | F1        | CHTI<br>F1 | F1        | CGI<br>F1 |  |
| W          | W W        | W                                                  | W W                                                               | W           | W          | W                                      | W                 | W          | W               |          |           | W         | W         | W          | W         | W         |  |
| •••        |            |                                                    |                                                                   |             |            |                                        |                   |            |                 |          |           |           |           |            |           |           |  |
| 位 31       | :28        |                                                    | 保留<br>〔保持复                                                        | 夏位值。        |            |                                        |                   |            |                 |          |           |           |           |            |           |           |  |
| 位 4x-      | -1         | CTEI                                               | TEIFx: 清除通道 x 的传输错误标志(x=71)(Channel x transfer error clear(x=71)) |             |            |                                        |                   |            |                 |          |           |           |           |            |           |           |  |
| (x=7       | 1)         | 这些                                                 | 区些位由软件设置和清除。                                                      |             |            |                                        |                   |            |                 |          |           |           |           |            |           |           |  |
|            |            | • 0-                                               | 0: 不起作用                                                           |             |            |                                        |                   |            |                 |          |           |           |           |            |           |           |  |
|            |            |                                                    |                                                                   |             |            |                                        |                   |            |                 |          |           |           |           |            |           |           |  |
|            |            | • 1:                                               | 1:清除 DMA_ISR 寄存器中的对应 TEIF 标志                                      |             |            |                                        |                   |            |                 |          |           |           |           |            |           |           |  |
| <i>D</i>   |            |                                                    | _ \+                                                              | * bV /35 /7 | - 44 VI    | , ,,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, | <del>- 4.</del> / |            |                 |          |           |           |           |            |           |           |  |
| 位 4x       | -2         | CHT                                                | lFx: 清                                                            | 除理理         | Lx 的羊      | 传输机                                    | 「志(               | x=71       | (Cł             | nannel x | half tr   | ansf      | er clear  | (x=7       | 1))       |           |  |
| (x=7       | 1)         | 这些                                                 | 位由转                                                               | 次件设置        | 显和清冽       | 余。                                     |                   |            |                 |          |           |           |           |            |           |           |  |
|            |            | • 0.                                               | 不起                                                                | 作田          |            |                                        |                   |            |                 |          |           |           |           |            |           |           |  |
|            |            |                                                    |                                                                   |             |            |                                        |                   |            |                 |          |           |           |           |            |           |           |  |
|            |            | • 1:                                               | 清除                                                                | DMA_I       | SR 寄存      | 字器中的                                   | 勺对应               | HTIF ₹     | 示志              |          |           |           |           |            |           |           |  |
|            |            |                                                    |                                                                   |             |            |                                        |                   |            |                 |          |           |           |           |            |           |           |  |
| 位 4x       | -3         | CTCI                                               | Fx: 清                                                             | 除通道         | x 的传       | 输完成                                    | 法标志               | (x=7       | 1) (            | Chann    | el x trar | sfer      | comple    | ete clear  | (x=7      | 1))       |  |
| (x=7       | 1)         | 这些                                                 | 位由转                                                               | 次件设置        | 冒和清陽       | 余。                                     |                   |            |                 |          |           |           |           |            |           |           |  |
| •          | ,          |                                                    |                                                                   |             | T 1. (14)  | 4                                      |                   |            |                 |          |           |           |           |            |           |           |  |
|            |            | • 0:                                               | 不起                                                                | 作用          |            |                                        |                   |            |                 |          |           |           |           |            |           |           |  |
|            |            | • 1:                                               | 清除                                                                | DMA_I       | SR 寄存      | 字器中的                                   | 勺对应               | TCIF 杉     | 示志              |          |           |           |           |            |           |           |  |
|            |            |                                                    |                                                                   |             |            |                                        |                   |            |                 |          |           |           |           |            |           |           |  |
| 位 4x       | -4         | CGIF                                               | x: 清[                                                             | 除通道         | x 的全       | 局中断                                    | 标志                | (x=71      | ) (             | Channe   | x glob    | al int    | terrupt   | clear (x   | (=71)     | )         |  |
| (x=7       | 1)         | <b></b>                                            | 这些位由软件设置和清除。                                                      |             |            |                                        |                   |            |                 |          |           |           |           |            |           |           |  |
| ۱۸ /       | -,         |                                                    |                                                                   |             | 3.4日1日15   | a, o                                   |                   |            |                 |          |           |           |           |            |           |           |  |
|            |            | • 0: 不起作用                                          |                                                                   |             |            |                                        |                   |            |                 |          |           |           |           |            |           |           |  |
|            |            | • 1: 清除 DMA_ISR 寄存器中的对应的 GIF、TEIF、HTIF 和 TCIF 标志   |                                                                   |             |            |                                        |                   |            |                 |          |           |           |           |            |           |           |  |
|            |            |                                                    |                                                                   | _           |            |                                        |                   |            |                 |          |           |           |           |            |           |           |  |

# 10.3.3 DMA 通道 x 配置寄存器(DMA\_CCRx)

偏移地址: 0x08+0d20\* (x-1)

复位值: 0x0000 0000

说明: x 表示通道号, DMA 的x 取值为1~7

| 31 | 30   | 29 | 28 | 27 | 26 | 25 | 24  | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|------|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|
| J1 | - 50 | 23 |    | 2, |    | 23 | - ' | 23 | 22 | 21 |    | 13 | 0  | -, | -0 |
|    |      |    |    |    |    |    | R   | es |    |    |    |    |    |    |    |



| l   |                 |      |      |        |        |       |        |         |      |      |     |      |      |      |     |
|-----|-----------------|------|------|--------|--------|-------|--------|---------|------|------|-----|------|------|------|-----|
|     |                 |      | _    |        |        | _     |        |         | _    |      |     | _    | _    |      |     |
| 15  | 14              | 13   | 12   | 11     | 10     | 9     | 8      | 7       | 6    | 5    | 4   | 3    | 2    | 1    | 0   |
| Res | MEM2MEM         | DI f | 1.01 | NACIZ  | E[1:0] | PSIZE | [1.0]  | MINC    | PINC | CIRC | DIR | TEIE | HTIE | TCIE | EN  |
| ues | IVILIVIZIVILIVI | FL[. | 1.0] | IVISIZ | L[I.U] | FJIZL | -[1.0] | IVIIIVC | FINC | CINC | חות | ILIL | HIHL | ICIL | LIN |
|     | rw              | r    | Μ/   | r      | W      | r     | W/     | rw      | rw   | rw   | rw  | rw/  | rw   | rw   | rw  |

| 位 31:15 | Res: 保留<br>必须保持复位值。                                                                                      |
|---------|----------------------------------------------------------------------------------------------------------|
| 位 14    | MEM2MEM:存储器到存储器模式(Memory to memory mode) 该位由软件设置和清除。  • 0: 非存储器到存储器模式  • 1: 启动存储器到存储器模式                  |
| 位 13:12 | PL[1:0]: 通道优先级(Channel priority level)<br>这些位由软件设置和清除。  • 00: 低  • 01: 中  • 10: 高  • 11: 最高              |
| 位 11:10 | MSIZE[1:0]: 存储器数据宽度(Memory size) 这些位由软件设置和清除。 • 00: 8 位 • 01: 16 位 • 10: 32 位 • 11: 保留                   |
| 位 9:8   | PSIZE[1:0]: 外设数据宽度(Peripheral size)<br>这些位由软件设置和清除。<br>• 00: 8 位<br>• 01: 16 位<br>• 10: 32 位<br>• 11: 保留 |
| 位 7     | MINC: 存储器地址增量模式(Memory increment mode) 该位由软件设置和清除。  • 0: 不执行存储器地址增量操作  • 1: 执行存储器地址增量操作                  |
| 位 6     | PINC: 外设地址增量模式(Peripheral increment mode) 该位由软件设置和清除。  • 0: 不执行外设地址增量操作  • 1: 执行外设地址增量操作                 |
| 位 5     | CIRC: 循环模式(Circular mode)                                                                                |



| ו ליבוי אייי אייי זעני | <del>1</del> —111                                                                               |
|------------------------|-------------------------------------------------------------------------------------------------|
|                        | 该位由软件设置和清除。 • 0: 不执行循环操作 • 1: 执行循环操作                                                            |
| 位 4                    | DIR: 数据传输方向(Data transfer direction)         该位由软件设置和清除。         • 0: 从外设读         • 1: 从存储器读   |
| 位 3                    | TEIE: 允许传输错误中断(Transfer error interrupt enable) 该位由软件设置和清除。  • 0: 禁止 TE 中断  • 1: 允许 TE 中断       |
| 位 2                    | HTIE: 允许半传输中断(Half transfer interrupt enable) 该位由软件设置和清除。  • 0: 禁止 HT 中断  • 1: 允许 HT 中断         |
| 位 1                    | TCIE: 允许传输完成中断(Transfer complete interrupt enable) 该位由软件设置和清除。  • 0: 禁止 TC 中断  • 1: 允许 TC 中断    |
| 位 0                    | <ul><li>EN: 通道开启(Channel enable)</li><li>该位由软件设置和清除。</li><li>0: 通道不工作</li><li>1: 通道开启</li></ul> |

# 10.3.4 DMA 通道 x 传输数量寄存器(DMA\_CNDTRx)

偏移地址: 0x0C+20\* (x-1)

复位值: 0x0000 0000

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

| 位 31:16 | Res: 保留<br>必须保持复位值。                                                                                                                             |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 15:0  | NDT[15:0]:数据传输数量(Number of data to transfer)数据传输数量为 0 至 2 <sup>16</sup> -1。这个寄存器只能在通道不工作(DMA_CCRx 的 EN=0)时写入。当寄存器的内容为 0 时,无论通道是否开启,都不会发生任何数据传输。 |



通道开启后,该寄存器变为只读,用于指示剩余的待传输字节数目。寄存器内容在每次 DMA 传输后递减。

数据传输结束后,寄存器的内容变为 0 或者当该通道配置为自动重加载模式时,寄存器的内容将自动重新加载为之前配置的数值。

## 10.3.5 DMA 通道 x 外设地址寄存器(DMA\_CPARx)

偏移地址: 0x10+0d20\* (x-1)

复位值: 0x0000 0000

说明: x 表示通道号, DMA 的x 取值为1~7。当开启通道(DMA CCRx 的 EN=1)时不能写该寄存器。

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

位 31:3

PA[31:0]: 外设地址(Peripheral address)

外设数据寄存器的基地址, 作为数据传输的源或目标。

- 当 PSIZE='01'(16位),不使用 PA[0]位。操作自动地与半字地址对齐。
- 当 PSIZE='10'(32位),不使用 PA[1:0]位。操作自动地与字地址对齐。

## 10.3.6 DMA 通道 x 存储器地址寄存器(DMA CMARx)

偏移地址: 0x14+0d20\* (x-1)

复位值: 0x0000 0000

说明: x 表示通道号, DMA 的x 取值为1~7。当开启通道(DMA CCRx 的 EN=1)时不能写该寄存器。

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

位 31:0

MA[31:0]: 存储器地址(Memory address)

存储器地址作为数据传输的源或目标

- 当 MSIZE='01'(16位),不使用 MA[0]位。操作自动地与半字地址对齐。
- 当 MSIZE='10'(32位),不使用 MA[1:0]位。操作自动地与字地址对齐。



# 11 模拟/数字转换(ADC)

12 位 ADC 是一种逐次逼近型模拟数字转换器。它有多达 18 个通道,可测量 16 个外部和 2 个内部信号源。各通道的 A/D 转换可以单次、连续、扫描或间断模式执行。ADC 的结果可以左对齐或右对齐方式存储在 16 位数据寄存器中。

模拟看门狗特性允许应用程序检测输入电压是否超出用户定义的高/低阈值。

ADC 的输入时钟不得超过 14 MHz, 它是由 PCLK2 经分频产生, 见图 7-2。

## 11.1 ADC 主要特征

- 12 位分辨率
- 转换结束、注入转换结束和发生模拟看门狗事件时产生中断
- 单次和连续转换模式
- 从通道 0 到通道 n 的自动扫描模式
- 自校准
- 数据对齐功能
- 采样时间可以按通道独立编程
- 规则转换和注入转换均有外部触发选项
- 间断模式
- 双重模式
- ADC 转换时间: 1 μs@56 MHz (0.875 μs@96 MHz)
- ADC 供电要求: 2V~5.5V
- ADC 输入范围: V<sub>SSA</sub>≤V<sub>IN</sub>≤V<sub>DDA</sub>
- 规则通道转换期间有 DMA 请求产生。

# 11.2 ADC 功能描述

下图为一个 ADC 模块的框图,下表为 ADC 引脚的说明。





图 11-1 单个 ADC 框图



### 表 11-1 ADC 引脚

| 名称                   | 信号类型     | 说明                                                                       |
|----------------------|----------|--------------------------------------------------------------------------|
| V <sub>DDA</sub> (1) | 输入,模拟电源  | 等效于 V <sub>DD</sub> 的模拟电源且: 2V≤V <sub>DDA</sub> ≤V <sub>DD</sub> (5.5 V) |
| V <sub>SSA</sub> (1) | 输入,模拟电源地 | 等效于 Vss 的模拟电源地                                                           |
| ADCx_IN[15:0]        | 模拟输入信号   | 16 个模拟输入通道                                                               |

(1). VDDA 和 VSSA 应该分别连接到 VDD 和 VSS。

## 11.2.1 ADC 开关控制

通过设置 ADC\_CR2 寄存器的 ADON 位可给 ADC 上电。当第一次设置 ADON 位时,它将 ADC 从断电状态下唤醒。

ADC 上电延迟一段时间后(t<sub>STAB</sub>),再次设置 ADON 位时开始进行转换。通过清除 ADON 位可以停止转换,并将 ADC 置于断电模式。在这个模式中,ADC 几乎不耗电(仅几个 μA)。

### 11.2.2 ADC 时钟

由时钟控制器提供的 ADCCLK 时钟和 PCLK2(APB2 时钟)同步。RCC 控制器为 ADC 时钟提供一个专用的可编程预分频器,详见章节:"7 复位和时钟控制(RCC)"。

### 11.2.3 通道选择

有 16 路外部复用通道。可以把转换分类成两组:规则组和注入组。在任意多个通道上以任意顺序进行的一转换构成组转换。例如,可以如下顺序完成转换:通道3、通道8、通道2、通道2、通道0、通道2、通道15。

#### • 规则组

由多达 16 个转换组成。规则通道和它们的转换顺序在 ADC\_SQRx 寄存器中选择。规则组中转换的总数应写入 ADC\_SQR1 寄存器的 L[3:0]位中。

### • 注入组

由多达 4 个转换组成。注入通道和它们的转换顺序在 ADC\_JSQR 寄存器中选择。注入组中转换的总数应写入 ADC\_JSQR 寄存器的 L[1:0]位中。

如果在转换期间修改 ADC\_SQRx 或 ADC\_JSQR 寄存器,当前的转换则被清除,一个新的启动脉冲将发送到 ADC 以转换新选择的组。

### 温度传感器/VREFINT 内部通道

温度传感器和通道 ADC1\_IN16 相连接,内部参考电压 V<sub>REFINT</sub> 和 ADC1\_IN17 相连接。这两个内部通道可被选择作为注入或规则通道进行转换。

注意: 温度传感器和 VREFINT 只能出现在主 ADC1 中。

### 11.2.4 单次转换模式

单次转换模式下,ADC 只执行一次转换。通过设置 ADC\_CR2 寄存器的 ADON 位(只适用于规则通道)或外部触发启动(适用于规则通道或注入通道)该模式,此时 CONT 位为 0。

- 一旦所选通道的转换完成:
- 如果转换一个规则通道:
  - 。 转换数据被储存在 16 位 ADC DR 寄存器中。



- 。 EOC (转换结束)标志被置位。
- 。 如果设置了 EOCIE,则产生中断。
- 如果转换一个注入通道:
  - 。 转换数据被储存在 16 位的 ADC JDR1 寄存器中。
  - · JEOC(注入转换结束)标志被置位。
  - 。 如果设置了 JEOCIE 位,则产生中断。

随后 ADC 停止。

## 11.2.5 连续转换模式

在连续转换模式中,ADC 完成一次转换后立即开始下一次转换。此模式可通过外部触发或设置 ADC CR2 寄存器上的 ADON 位启动,此时 CONT 位为 1。

每次转换后:

- 如果转换一个规则通道:
  - 。 转换数据被储存在 16 位的 ADC DR 寄存器中。
  - 。 EOC (转换结束)标志被置位。
  - 。 如果设置了 EOCIE,则产生中断。
- 如果转换一个注入通道:
  - 。 转换数据被储存在 16 位的 ADC JDR1 寄存器中。
  - 。 JEOC (注入转换结束)标志被置位。
  - 。 如果设置了 JEOCIE 位,则产生中断。

## 11.2.6 时序图

如下图所示,ADC在开始精确转换前需要一个稳定时间 t<sub>STAB</sub>。在开始 ADC 转换和 14 个时钟周期后,EOC 标志被置位,16 位 ADC 数据寄存器包含转换的结果。



图 11-2 时序图

# 11.2.7 模拟看门狗

如果被 ADC 转换的模拟电压小于低阈值或大于高阈值,AWD 模拟看门狗的状态位则被置位。阈值位于 16 位的 ADC\_HTR 和 ADC\_LTR 寄存器的最低 12 个有效位中。通过设置 ADC\_CR1 寄存器的 AWDIE 位以允许产生相应中断或唤醒系统(详细的操作请结合 BKP、RTC 和 PWR 相关的寄存器)。



阈值独立于由 ADC\_CR2 寄存器上的 ALIGN 位选择的数据对齐模式。比较是在对齐之前完成的(见"11.4 数据对齐")。通过配置 ADC CR1 寄存器,模拟看门狗可以作用于 1 个或多个通道,如表 11-2 所示。



图 11-3 模拟看门狗警戒区

表 11-2 模拟看门狗通道选择

| 模拟看门狗监视的通道             | ADC_CR1 寄存器控制位 |         |          |
|------------------------|----------------|---------|----------|
|                        | AWDSGL 位       | AWDEN 位 | JAWDEN 位 |
| 无                      | 任意值            | 0       | 0        |
| 所有注入通道                 | 0              | 0       | 1        |
| 所有规则通道                 | 0              | 1       | 0        |
| 所有注入和规则通道              | 0              | 1       | 1        |
| 单个 (1) 注入通道            | 1              | 0       | 1        |
| 单个 <sup>(1)</sup> 规则通道 | 1              | 1       | 0        |
| 单个的 (1) 注入或规则通道        | 1              | 1       | 1        |

#### (1). 由 AWDCH[4:0]位选择。

## 11.2.8 扫描模式

此模式用于扫描一组模拟通道。

通过设置 ADC\_CR1 寄存器的 SCAN 位来选择扫描模式。一旦设置该位,ADC 将扫描被 ADC\_SQRx 寄存器(对规则通道)或 ADC\_JSQR 寄存器(对注入通道)选中的所有通道。在每个组的每个通道上执行单次转换。在每个转换结束时,同一组的下一个通道被自动转换。如果设置了 CONT 位,转换不会在选择组的最后一个通道上停止,而是再次从所选择组的第一个通道继续转换。

在扫描模式下,必须设置 ADC\_CR2 的 DMA 位。每次规则组的通道转换结束,即 ADC\_DR 寄存器被更新时,DMA 控制器会把转换结果从 ADC DR 寄存器搬到 SRAM 中。

而注入通道转换的数据总是存储在 ADC\_JDRx 寄存器中。

## 11.2.9 注入通道管理

### 触发注入

清除 ADC CR1 寄存器的 JAUTO 位且设置 SCAN 位,即可使用触发注入功能。



- 1. 利用外部触发或通过设置 ADC\_CR2 寄存器的 ADON 位,启动一组规则通道的转换。
- 2. 如果在规则组通道转换期间产生一次外部注入触发,当前转换被复位,注入通道序列以单次扫描方式进行转换。
- 3. 上次发生中断的规则组通道转换被恢复。如果在注入转换期间产生一次规则事件,注入转换不会被中断,但是规则序列将在注入序列结束后被执行。图 11-4 示出了时序图。

说明: 当使用触发的注入转换时,必须保证触发事件的间隔长于注入序列。例如: 序列长度为 28 个 ADC 时钟周期(两次转换需间隔 1.5 个时钟周期采样时间),触发之间最小的间隔必须是 29 个 ADC 时钟周期。

#### 自动注入

如果设置了 JAUTO 位,注入组通道在规则组通道之后被自动转换。这可以用来转换在 ADC\_SQRx 和 ADC\_JSQR 寄存器中设置的最多 20 个转换序列。在此模式里,必须禁止注入通道的外部触发。如果除 JAUTO 位外还设置了 CONT 位,规则通道至注入通道的转换序列被连续执行。

对于 ADC 时钟预分频系数为 4 至 8 时,当从规则转换切换到注入序列(或从注入转换切换到规则序列)时,会自动插入 1 个 ADC 时钟间隔;当 ADC 时钟预分频系数为 2 时,则自助插入 2 个 ADC 时钟间隔。

注意:不能同时使用自动注入和间断模式。



图 11-4 注入转换延时

图 11-4 中的最大延迟数值,可参考 HK32F103x8xB 数据手册中有关电气特性部分。

## 11.2.10 间断模式

### 规则组

通过设置 ADC\_CR1 寄存器上的 DISCEN 位使能此模式。它可以用来执行一个短序列的 n 次转换 (n≤8), 此转换是 ADC\_SQRx 寄存器所选择的转换序列的一部分。数值 n 由 ADC\_CR1 寄存器的 DISCNUM[2:0]位给出。

一个外部触发信号可以启动 ADC\_SQRx 寄存器中描述的下一轮 n 次转换,直到此序列所有的转换完成为止。总的序列长度由 ADC\_SQR1 寄存器的 L[3:0]定义。

举例: 若 n=3,被转换的通道=0、1、2、3、6、7、9、10,则:

- 1. 第一次触发:转换的序列为 0、1、2
- 2. 第二次触发:转换的序列为 3、6、7
- 3. 第三次触发:转换的序列为 9、10,并产生 EOC 事件



4. 第四次触发: 转换的序列 0、1、2

注意: 当以间断模式转换一个规则组时,转换序列结束后不自动从头开始。当所有子组被转换完成,下一次触发启动第一个子组的转换。在上面的例子中,第四次触发重新转换第一子组的通道 0 、1 和 2 。

#### 注入组

通过设置 ADC\_CR1 寄存器的 JDISCEN 位使能此模式。在一个外部触发事件后,该模式按通道顺序逐个转换 ADC JSQR 寄存器中选择的序列。

一个外部触发信号可以启动 ADC\_JSQR 寄存器选择的下一个通道序列的转换,直到序列中所有的转换完成为止。总的序列长度由 ADC JSQR 寄存器的 JL[1:0]位定义。

例子: 若 n=1, 被转换的通道=1、2、3, 则:

- 1. 第一次触发:通道1被转换
- 2. 第二次触发:通道2被转换
- 3. 第三次触发:通道 3 被转换,并且产生 EOC 和 JEOC 事件
- 4. 第四次触发:通道1被转换

#### 注意:

- 当完成所有注入通道转换,下个触发启动第 1 个注入通道的转换。在上述例子中,第四个触发重新 转换第1 个注入通道1。
- 不能同时使用自动注入和间断模式。
- 必须避免同时为规则和注入组设置间断模式。间断模式只能作用于一组转换。

# 11.3 校准

ADC 有一个内置自校准模式。校准可显著减小因内部电容器组的变化而造成的精度误差。在校准期间,在每个电容器上都会计算出一个误差修正码(数字值),这个码用于消除在随后的转换中每个电容器上产生的误差。

通过设置 ADC\_CR2 寄存器的 CAL 位启动校准。一旦校准结束,CAL 位被硬件复位,可以开始正常转换。建议在上电时执行一次 ADC 校准。校准阶段结束后,校准码储存在 ADC DR 中。

### 注意:

- 建议在每次上电后执行一次校准。
- 启动校准前。ADC 必须处于开电状态(ADON='1') 超过至少两个ADC 时钟周期。



图 11-5 校准时序图



# 11.4 数据对齐

ADC\_CR2 寄存器中的 ALIGN 位选择转换后数据储存的对齐方式。数据可以左对齐或右对齐,如图 11-6 和图 11-7 所示。

注入组通道转换的数据值已经减去了在 ADC\_JOFRx 寄存器中定义的偏移量,因此结果可以是一个负值。SEXT 位是扩展的符号值。

对于规则组通道,不需减去偏移值,因此只有12个位有效。

| 注入组  |      |      |      |     |     |    |    |    |    |    |    |    |    |    |    |
|------|------|------|------|-----|-----|----|----|----|----|----|----|----|----|----|----|
| SEXT | SEXT | SEXT | SEXT | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| 规则组  |      |      |      |     |     |    |    |    |    |    |    |    |    |    |    |
| 0    | 0    | 0    | 0    | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |

图 11-6 数据右对齐

| 注入组  |     |     |    |    |    |    |    |    |    |    |    |    |   |   |   |
|------|-----|-----|----|----|----|----|----|----|----|----|----|----|---|---|---|
| SEXT | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | 0 | 0 | 0 |
| 规则组  |     |     |    |    |    |    |    |    |    |    |    |    |   |   |   |
| D11  | D10 | D9  | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | 0  | 0 | 0 | 0 |

图 11-7 数据左对齐

## 11.5 可编程的通道采样时间

ADC 使用若干个 ADC\_CLK 周期对输入电压采样,采样周期数目可以通过 ADC\_SMPR1 和 ADC\_SMPR2 寄存器中的 SMPx[2:0]位更改。每个通道可以分别用不同的时间采样。

总转换时间如下计算:

T<sub>CONV</sub>=采样时间+12.5 个周期

例如:

当 ADCCLK=14 MHz, 采样时间为 1.5 周期时: T<sub>CONV</sub>=1.5+12.5=14 个周期=1 μs

# 11.6 外部触发转换

转换可以由外部事件触发(例如定时器捕获,EXTI 线)。如果设置了 EXTTRIG 控制位,则外部事件就能够触发转换。EXTSEL[2:0]和 JEXTSEL[2:0]控制位允许应用程序选择 8 个可能的事件中的某一个,以触发规则和注入组的采样。

注意: 当外部触发信号被选为 ADC 规则或注入转换时, 只有它的上升沿可以启动转换。

| 触发源         | 类型 | EXTSEL[2:0] |
|-------------|----|-------------|
| TIM1_CC1 事件 | -  | 000         |
| TIM1_CC2 事件 |    | 001         |
| TIM1_CC3 事件 |    | 010         |
| TIM2_CC2 事件 |    | 011         |

表 11-3 ADC1 和 ADC2 用于规则通道的外部触发



| 触发源          | 类型    | EXTSEL[2:0] |
|--------------|-------|-------------|
| TIM3_TRGO 事件 |       | 100         |
| TIM4_CC4 事件  |       | 101         |
| EXTI 线 11    | 外部引脚  | 110         |
| SWSTART      | 软件控制位 | 111         |

表 11-4 ADC1 和 ADC2 用于注入通道的外部触发

| 触发源          | 连接类型         | JEXTSEL[2:0] |
|--------------|--------------|--------------|
| TIM1_TRGO 事件 | 来自片上定时器的内部信号 | 000          |
| TIM1_CC4 事件  |              | 001          |
| TIM2_TRGO 事件 |              | 010          |
| TIM2_CC1 事件  |              | 011          |
| TIM3_CC4 事件  |              | 100          |
| TIM4_TRGO 事件 |              | 101          |
| EXTI 线 15    | 外部引脚         | 110          |
| JSWSTART     | 软件控制位        | 111          |

软件触发事件可以通过对寄存器 ADC\_CR2 的 SWSTART 或 JSWSTART 位置'1'产生。注入触发可中断规则组的转换。

# 11.7 DMA 请求

因为规则通道已转换的值储存在一个仅有的数据寄存器中,所以当转换多个规则通道时需要使用 DMA。这可以避免已存储在 ADC\_DR 寄存器中的数据丢失。

只有在规则通道的转换结束时才产生 DMA 请求,并将转换的数据从 ADC\_DR 寄存器传输到用户指定的目的地址。

说明: 只有ADC1 拥有DMA 功能。由ADC2 转化的数据可以通过双ADC 模式,利用ADC1 的DMA 功能传输。

# 11.8 双 ADC 模式

HK32F103x8xB 具有 2 个的 ADC 模块,支持双 ADC 模式(见图 11-8)。在双 ADC 模式里,根据 ADC1\_CR1 寄存器中 DUALMOD[3:0]位所选的模式,转换的启动可由 ADC1 主到 ADC2 从交替触发或同步触发。

注意:在双 ADC 模式里,当转换配置成由外部事件触发时,用户必须将其设置成仅触发主 ADC,从 ADC 设置成软件触发,这样可以防止意外触发从转换。但是,主和从 ADC 的外部触发必须同时使能。

共有6种可能的模式:

- 同步注入模式
- 同步规则模式
- 快速交替模式



- 慢速交替模式
- 交替触发模式
- 独立模式

还有可以用下列方式组合使用上面的模式:

- 同步注入模式+同步规则模式
- 同步规则模式+交替触发模式
- 同步注入模式+交替模式



图 11-8 双 ADC 框图

#### 说明:

- 外部触发信号作用于ADC2,但在上图中没有显示。
- 在某些双 ADC 模式中,在完整的 ADC 数据寄存器(ADC\_DR)中包含了 ADC1 和 ADC2 的规则转 换数据。



## 11.8.1 同步注入模式

此模式转换一个注入通道组。外部触发来自 ADC1 的注入组多路开关(由 ADC1\_CR2 寄存器的 JEXTSEL[2:0]选择),它同时给 ADC2 提供同步触发。

注意: 不要在2 个ADC 上转换相同的通道(2 个ADC 在同一个通道上的采样时间不能重叠)。

在 ADC1 或 ADC2 的转换结束时:

- 转换的数据存储在每个 ADC 接口的 ADC JDRx 寄存器中。
- 当所有 ADC1/ADC2 注入通道都被转换完时,产生 JEOC 中断(若任一 ADC 接口使能了中断)。

说明:在同步注入模式中,在 ADC1 和 ADC2 上同时采样的两个通道必须设置同样的采样时间,来保证两个 ADC 的同步。



图 11-9 在 4 个通道上的同步注入模式

## 11.8.2 同步规则模式

此模式在规则通道组上执行。外部触发来自 ADC1 的规则组多路开关(由 ADC1\_CR2 寄存器的 EXTSEL[2:0]选择)。它同时给 ADC2 提供同步触发。

注意:不要在2个ADC上转换相同的通道(两个ADC在同一个通道上的采样时间不能重叠)。

在 ADC1 或 ADC2 的转换结束时:

- 产生一个 32 位 DMA 传输请求(如果设置了 DMA 位), 32 位的 ADC\_DR 寄存器内容传输到 SRAM 中, 它高半个字包含 ADC2 的转换数据, 低半个字包含 ADC1 的转换数据。
- 当所有 ADC1/ADC2 规则通道都被转换完时,产生 EOC 中断(若任一 ADC 接口使能了中断)。

说明:在同步规则模式中,在 ADC1 和 ADC2 上同时采样的两个通道必须设置同样的采样时间,来保证两个 ADC 的同步。



图 11-10 16 个通道上的同步规则模式

# 11.8.3 快速交替模式

此模式只适用于规则通道组(通常为一个通道)。外部触发来自 ADC1 的规则通道多路开关。外部触发产生后:

• ADC2 立即启动;



ADC1 在延迟 7 个 ADC 时钟周期后启动。

如果同时设置了 ADC1 和 ADC2 的 CONT 位,ADC1 和 ADC2 的所选择的规则通道将被连续地转换。 ADC1 产生一个 EOC 中断后(若 EOCIE 位使能),产生一个 32 位的 DMA 传输请求(如果设置了 DMA 位), ADC\_DR 寄存器的 32 位数据被传输到 SRAM。ADC\_DR 的高半个字包含 ADC2 的转换数据,低半个字包含 ADC1 的转换数据。

注意:最大允许采样时间<7 个 ADCCLK 周期,避免 ADC1 和 ADC2 转换相同通道时发生两个采样周期的重叠。



图 11-11 在 1 个通道上连续转换模式下的快速交替模式

## 11.8.4 慢速交替模式

此模式只适用于规则通道组(只能为一个通道)。外部触发来自 ADC1 的规则通道多路开关。外部触发产生后:

- ADC2 立即启动:
- ADC1 在延迟 14 个 ADC 时钟周期后启动;
- 在延迟第二次 14 个 ADC 周期后 ADC2 再次启动,按此循环。

注意:最大允许采样时间<14 个ADCCLK 周期,以避免和下个转换重叠。

ADC1 产生一个 EOC 中断后(若 EOCIE 位使能),产生一个 32 位的 DMA 传输请求(如果设置了 DMA 位),ADC\_DR 寄存器的 32 位数据被传输到 SRAM,ADC\_DR 的高半个字包含 ADC2 的转换数据,低 半个字包含 ADC1 的转换数据。

在 28 个 ADC 时钟周期后自动启动第二次 ADC2 转换。在这个模式下不能设置 CONT 位,因为它将连续转换所选择的规则通道。

注意: 应用程序必须确保当使用交替模式时, 不能有注入通道的外部触发产生。



图 11-12 在 1 个通道上的慢速交替模式



## 11.8.5 交替触发模式

此模式只适用于注入通道组。外部触发源来自 ADC1 的注入通道多路开关。

- 当第一个触发产生时, ADC1 上的所有注入组通道被转换;
- 当第二个触发到达时, ADC2 上的所有注入组通道被转换;
- 依此循环...

如果使能 JEOC 中断,在所有 ADC1 注入组通道转换后产生一个 JEOC 中断。如果使能 JEOC 中断,在 所有 ADC2 注入组通道转换后产生一个 JEOC 中断。当所有注入组通道都转换完后,如果又有另一个外部 触发,交替触发从转换 ADC1 注入组通道重新开始。



图 11-13 交替触发:每个 ADC1 的注入通道组

如果 ADC1 和 ADC2 上同时使用了注入间断模式:

- 当第一个触发产生时, ADC1 上的第一个注入通道被转换;
- 当第二个触发到达时, ADC2 上的第一个注入通道被转换;
- 依此循环...

如果允许产生 JEOC 中断,在所有 ADC1 注入组通道转换后产生一个 JEOC 中断。如果允许产生 JEOC 中断,在所有 ADC2 注入组通道转换后产生一个 JEOC 中断。当所有注入组通道都转换完后,如果又有另一个外部触发,则重新开始交替触发过程。



图 11-14 交替触发: 在间断模式下每个 ADC 上的 4 个注入通道

## 11.8.6 独立模式

此模式里,双 ADC 的同步被旁路,每个 ADC 接口独立工作。

# 11.8.7 混合的规则/注入同步模式

规则组同步转换可以被中断,以启动注入组的同步转换。

说明:在混合的规则/注入同步模式中,在 ADC1 和 ADC2 上同时采样的两个通道必须设置同样的采样时间,来保证两个ADC 的同步。



### 11.8.8 混合的同步规则+交替触发模式

规则组同步转换可以被中断,以启动注入组交替触发转换。图 **11-15** 显示了一个规则同步转换被交替触发所中断。

注入交替转换在注入事件到达后立即启动。如果规则转换正在进行,为了在注入转换后确保同步, 所有的 ADC(主和从)的规则转换被停止,并在注入转换结束时同步恢复。

说明:在混合的同步规则+交替触发模式中,在ADC1和ADC2上同时采样的两个通道必须设置同样的采样时间,来保证两个ADC的同步。



图 11-15 交替+规则同步

如果触发事件发生在一个中断了规则转换的注入转换期间,这个触发事件将被忽略。图 **11-16** 示出了这种情况的操作(第 **2** 个触发被忽略)。



图 11-16 触发事件发生在注入转换期间

### 11.8.9 混合同步注入+交替模式

一个注入事件可以中断一个交替转换。这种情况下,交替转换被中断,注入转换被启动,在注入序列转换结束时,交替转换被恢复。图 **11-17** 是这种情况的一个例子。

说明: 当 ADC 时钟预分频系数设置为 4 时,交替模式恢复后不会均匀地分配采样时间,采样间隔是 8 个 ADC 时钟周期与 6 个 ADC 时钟周期轮替,而不是均匀的 7 个 ADC 时钟周期。





图 11-17 交替的单通道转换被注入序列 CH11 和 CH12 中断

### 11.9 温度传感器

温度传感器可以用来测量器件周围的温度 (T<sub>A</sub>)。温度传感器在内部和 ADC1\_IN16 输入通道相连接, 此通道把传感器输出的电压转换成数字值。温度传感器的推荐采样时间是 17.1μs。

图 11-18 是温度传感器的方框图。当没有被使用时,传感器可以置于关电模式。

#### 注意:

- 必须设置 TSVREFE 位激活内部通道: ADC1 IN16 (温度传感器)和 ADC1 IN17 (VREFINT)的转换。
- 温度传感器输出电压随温度线性变化,由于生产过程的变化,温度变化曲线的偏移在不同芯片上会有不同(最多相差 45℃)。内部温度传感器更适合于检测温度的变化,而不是测量绝对的温度。如果需要测量精确的温度,应该使用一个外置的温度传感器。



图 11-18 温度传感器和 VREFINT 通道框图

#### 读温度

使用温度传感器的步骤:

- 1. 选择 ADC1 IN16 输入通道。
- 2. 选择采样时间为 17.1 μs。
- 3. 设置 ADC 控制寄存器 2(ADC CR2)的 TSVREFE 位,以唤醒关电模式下的温度传感器。
- 4. 通过设置 ADON 位启动 ADC 转换(或用外部触发)。
- 5. 读 ADC 数据寄存器上的 VSENSE 数据结果。
- 6. 利用下列公式得出温度:

温度 (°C) ={ (V<sub>25</sub>-V<sub>SENSE</sub>) /Avg Slope}+25



其中, $V_{25}$  为  $V_{SENSE}$  在 25°C 时的数值。Avg\_Slope 为温度与  $V_{SENSE}$  曲线的平均斜率(单位为  $mV/^{\circ}$ C 或  $\mu V/^{\circ}$ C)。可参考数据手册的电气特性章节中  $V_{25}$  和  $V_{25}$ 

注意: 传感器从关电模式唤醒后到可以输出正确电平的 V<sub>SENSE</sub> 前,有一个建立时间。ADC 在上电后也有一个建立时间,因此为了缩短延时,应该同时设置 ADON 和 TSVREFE 位。

## 11.10 ADC 中断

当模拟看门狗状态位被置位,或者规则和注入组转换结束时,能产生中断。它们都有独立的中断使 能位。

说明: ADC1 和 ADC2 的中断映射在同一个中断向量上。

ADC SR 寄存器中有 2 个其他标志,但是它们没有相关联的中断:

- JSTRT (注入组通道转换的启动)
- STRT (规则组通道转换的启动)

表 11-5 ADC 中断

| 中断事件        | 事件标志 | 使能控制位  |
|-------------|------|--------|
| 规则组转换结束     | EOC  | EOCIE  |
| 注入组转换结束     | JEOC | JEOCIE |
| 设置了模拟看门狗状态位 | AWD  | AWDIE  |

## 11.11 ADC 寄存器

基地址: (ADC1, ADC2) = (0x4001 2400, 0x4001 2800)

空间大小: (ADC1, ADC2) = (0x400, 0x400)

ADC 寄存器必须以字(32位)的方式进行访问。

## 11.11.1 ADC 状态寄存器(ADC\_SR)

偏移地址: 0x00

| 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 | 7 6 5 |       | 4     | 3     | 2     | 1     | 0 |
|-----|----|----|----|----|----|---|---|---|-------|-------|-------|-------|-------|-------|---|
| Res |    |    |    |    |    |   |   |   | STRT  | JSTRT | JEOC  | EOC   | AWD   |       |   |
|     |    |    |    |    |    |   |   |   |       | rc w0 |   |

| 位 31: 5 | Res: 保留<br>必须保持复位值。                                                                                 |
|---------|-----------------------------------------------------------------------------------------------------|
| 位 4     | STRT: 规则通道开始位(Regular channel Start flag)<br>该位由硬件在规则通道转换开始时设置,由软件清除。 • 0: 规则通道转换未开始 • 1: 规则通道转换已开始 |
| 位 3     | JSTRT: 注入通道开始位(Injected channel Start flag)                                                         |



|     | 该位由硬件在注入通道组转换开始时设置,由软件清除。 • 0: 注入通道组转换未开始 • 1: 注入通道组转换已开始                                                                 |
|-----|---------------------------------------------------------------------------------------------------------------------------|
| 位 2 | JEOC: 注入通道转换结束位(Injected channel end of conversion) 该位由硬件在所有注入通道组转换结束时设置,由软件清除。  • 0: 转换未完成  • 1: 转换完成                    |
| 位 1 | EOC:转换结束位(End of conversion)<br>该位由硬件在(规则或注入)通道组转换结束时设置。<br>该位由软件或由读取 ADC_DR 时清除。<br>• 0:转换未完成<br>• 1:转换完成                |
| 位 0 | AWD:模拟看门狗标志位(Analog watchdog flag) 该位由硬件在转换的电压值超出了 ADC_LTR 和 ADC_HTR 寄存器定义的范围时设置,由软件清除。  • 0: 没有发生模拟看门狗事件  • 1: 发生模拟看门狗事件 |

# 11.11.2 ADC 控制寄存器 1(ADC\_CR1)

偏移地址: 0x04

| 31   |                                         | 30 | 29    | 28 | 27     | 26  | 25  | 24    | 23   |             | 22   | 21 | 20 | 19 | 18           | 17    | , | 16 |  |
|------|-----------------------------------------|----|-------|----|--------|-----|-----|-------|------|-------------|------|----|----|----|--------------|-------|---|----|--|
| Res  |                                         |    |       |    |        |     |     |       | AWDE | WDEN JAWDEN |      |    | es |    | DUALMOD[3:0] |       |   |    |  |
|      |                                         |    |       |    |        |     | rw  | rw rw |      |             |      |    | rw |    |              |       |   |    |  |
|      |                                         |    |       |    |        |     | _   |       | _    |             |      |    |    | 1  |              |       |   |    |  |
| 15   | 14                                      | 13 | 1     | 12 | 11     | 1   | 10  | 9     |      | 3           | 7    | 6  |    | 5  | 4            | 3   2 | 1 | 0  |  |
| DISC | DISCNUM[2:0] JDISCEN DISCEN JAUTO AWDSC |    | GL SC | ΑN | JEOCIE | AWE | DIE | EOCIE | P    | WDCH        | [4:0 | ]  |    |    |              |       |   |    |  |
|      | rw rw rw rw                             |    | r     | W  | rw     | rw  | 1   | rw    |      | rw          |      |    |    |    |              |       |   |    |  |

| 位 31:24 | Res: 保留<br>必须保持复位值。                                                                                                 |
|---------|---------------------------------------------------------------------------------------------------------------------|
| 位 23    | AWDEN: 在规则通道上开启模拟看门狗(Analog watchdog enable on regular channels)该位由软件设置和清除。  • 0: 在规则通道上禁用模拟看门狗  • 1: 在规则通道上使能模拟看门狗 |
| 位 22    | JAWDEN:在注入通道上开启模拟看门狗(Analog watchdog enable on injected channels)该位由软件设置和清除。  • 0:在注入通道上禁用模拟看门狗  • 1:在注入通道上使能模拟看门狗  |
| 位 21:20 | Res: 保留                                                                                                             |



|         | (大)》/ 数 1 代 (ADC)                                                                                                                                                                                                                                                                                                                                                                       |
|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         | 必须保持复位值。                                                                                                                                                                                                                                                                                                                                                                                |
| 位 19:16 | DUALMOD[3:0]: 双模式选择(Dual mode selection)<br>软件使用这些位选择操作模式。<br>• 0000: 独立模式<br>• 0001: 混合的同步规则+注入同步模式<br>• 0010: 混合的同步规则+交替触发模式<br>• 0011: 混合同步注入+快速交替模式<br>• 0100: 混合同步注入+慢速交替模式<br>• 0101: 注入同步模式<br>• 0110: 规则同步模式<br>• 0111: 快速交替模式<br>• 1000: 慢速交替模式<br>• 1000: 慢速交替模式<br>• 1001: 交替触发模式<br><i>说明: 在ADC2 中这些位为保留位。</i><br>在双模式中,改变通道的配置会产生一个重新开始的条件,这将导致同步丢失。建议在<br>进行任何配置改变前关闭双模式。 |
| 位 15:13 | DISCNUM[2:0]: 间断模式通道计数 (Discontinuous mode channel count ) 软件通过这些位定义在间断模式下,收到外部触发后转换规则通道的数目。                                                                                                                                                                                                                                                                                            |
| 位 12    | JDISCEN:在注入通道上的间断模式(Discontinuous mode on injected channels)该位由软件设置和清除,用于开启或关闭注入通道组上的间断模式。  • 0:注入通道组上禁用间断模式  • 1:注入通道组上使能间断模式                                                                                                                                                                                                                                                          |
| 位 11    | DISCEN: 在规则通道上的间断模式(Discontinuous mode on regular channels)该位由软件设置和清除,用于开启或关闭规则通道组上的间断模式。  • 0: 规则通道组上禁用间断模式  • 1: 规则通道组上使能间断模式                                                                                                                                                                                                                                                         |
| 位 10    | JAUTO: 自动的注入通道组转换(Automatic Injected Group conversion) 该位由软件设置和清除,用于开启或关闭规则通道组转换结束后注入通道组的自动转换。  • 0: 关闭自动的注入通道组转换  • 1: 开启自动的注入通道组转换                                                                                                                                                                                                                                                    |
| 位 9     | AWDSGL: 扫描模式中在一个单一的通道上使用看门狗(Enable the watchdog on a single channel in scan mode)<br>该位由软件设置和清除,用于开启或关闭由 AWDCH[4:0]位指定的通道上的模拟看门狗功                                                                                                                                                                                                                                                       |



|       | 能。         • 0: 在所有的通道上使用模拟看门狗         • 1: 在单一通道上使能模拟看门狗                                                                                                                                                                                                                                                               |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 8   | SCAN: 扫描模式(Scan mode)<br>该位由软件设置和清除,用于开启或关闭扫描模式。在扫描模式中,转换由 ADC_SQRx<br>或 ADC_JSQRx 寄存器选中的通道。<br>• 0: 关闭扫描模式<br>• 1: 使用扫描模式<br>说明: 如果分别设置了 EOCIE 或 JEOCIE 位,只在最后一个通道转换完毕后才会产生 EOC<br>或 JEOC 中断。                                                                                                                          |
| 位 7   | JEOCIE: 允许产生注入通道转换结束中断(Interrupt enable for injected channels)该位由软件设置和清除,用于禁止或允许所有注入通道转换结束后产生中断。 • 0: 禁止 JEOC 中断 • 1: 允许 JEOC 中断。当硬件设置 JEOC 位时产生中断。                                                                                                                                                                     |
| 位 6   | AWDIE: 允许产生模拟看门狗中断(Analog watchdog interrupt enable)该位由软件设置和清除,用于禁止或允许模拟看门狗产生中断。 • 0: 禁止模拟看门狗中断 • 1: 允许模拟看门狗中断                                                                                                                                                                                                          |
| 位 5   | EOCIE: 允许产生 EOC 中断(Interrupt enable for EOC)该位由软件设置和清除,用于禁止或允许转换结束后产生中断。 • 0: 禁止 EOC 中断 • 1: 允许 EOC 中断。当硬件设置 EOC 位时产生中断                                                                                                                                                                                                 |
| 位 4:0 | AWDCH[4:0]: 模拟看门狗通道选择位(Analog watchdog channel select bits)这些位由软件设置和清除,用于选择模拟看门狗保护的输入通道。  • 00000: ADC 模拟输入通道 0  • 00001: ADC 模拟输入通道 1  •  • 01111: ADC 模拟输入通道 15  • 10000: ADC 模拟输入通道 16  • 10001: ADC 模拟输入通道 17  • 其他值: 保留 说明: ADC1 的模拟输入通道 16 和通道 17 在芯片内部分别连到了温度传感器和 VREFINT。  ADC2 的模拟输入通道 16 和通道 17 在芯片内部连到了 VSS。 |

#### 注意:

- RTC 输出的触发信号只能触发规则组转换,不需要设置规则组的触发使能控制 EXTTRIG。
- ADC 的配置都在这种模式下生效,所以必须使能 AWDEN,不能使能循环和间断模式,在转换 的过程中除ADC\_SR.AWD 以外的状态寄存器不会被置位。

16

Res



- 和其他触发信号一样的效果触发ADC单个通道或整个规则组的转换,如果在整个规则组转换完 成后ADC SR.AWD 状态位没有置起则重新回到停机(Stop)模式。
- AWD 的唤醒信号根据 AWDSGL 和 AWDCH 设置可以单个通道的结果比较也可以所有通道的结果 比较,直接把 ADC\_SR.AWD 发到 EXTI,不需要使能 AWDIE。

22

SWSTART

20

EXTTRIG

21

JSWSTART

19

18

EXTSEL[2:0]

## 11.11.3 ADC 控制寄存器 2(ADC\_CR2)

27

Res

26

25

24

23

TSVREFE

偏移地址: 0x08

30

31

复位值: 0x0000 0000

29

28

|          |                                                                                                                                                     |                                                                                                                                                                                                                                                | rw                       |                       |      | rw | rw rw |     |         | rw         |           | rw       |      |  |
|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|-----------------------|------|----|-------|-----|---------|------------|-----------|----------|------|--|
| 15       | 14 13 12                                                                                                                                            | 11                                                                                                                                                                                                                                             | 10                       | 9                     | 8    | 7  | 6     | 5   | 4       | 3          | 2 1       |          | 0    |  |
| JEXTTRIG | JEXTSEL[2:0]                                                                                                                                        | ALIGN                                                                                                                                                                                                                                          | Res                      |                       | DMA  |    |       | Res |         | RSTCAL     | CAL       | CONT     | ADON |  |
| rw       | rw                                                                                                                                                  | rw                                                                                                                                                                                                                                             |                          |                       | rw   |    |       |     |         | rw         | rw        | rw       | rw   |  |
| 位 31:24  | Res: 保留<br>必须保持复位值。                                                                                                                                 |                                                                                                                                                                                                                                                |                          |                       |      |    |       |     |         |            |           |          |      |  |
| 位 23     | 该位由软件设置件中,该位仅是 • 0:禁止温度                                                                                                                             | TSVREFE: 温度传感器和 V <sub>REFINT</sub> 使能(Temperature sensor and V <sub>REFINT</sub> enable) 该位由软件设置和清除,用于开启或禁止温度传感器和 V <sub>REFINT</sub> 通道。在多于 1 个 ADC 的器件中,该位仅出现在 ADC1 中。  • 0: 禁止温度传感器和 V <sub>REFINT</sub> • 1: 启用温度传感器和 V <sub>REFINT</sub> |                          |                       |      |    |       |     |         |            |           |          |      |  |
| 位 22     | 由软件设置该位了 SWSTART 为 • 0: 复位状态                                                                                                                        | SWSTART: 开始转换规则通道(Start conversion of regular channels)由软件设置该位以启动转换,转换开始后硬件马上清除此位。如果在 EXTSEL[2:0]位中选择了 SWSTART 为触发事件,该位用于启动一组规则通道的转换。  • 0: 复位状态  • 1: 开始转换规则通道                                                                                |                          |                       |      |    |       |     |         |            |           |          |      |  |
| 位 21     | JSWSTART: 开<br>由软件设置该<br>通过 JEXTSEL[2<br>• 0: 复位状态<br>• 1: 开始转换                                                                                     | 位以启<br>:0]位选:                                                                                                                                                                                                                                  | 动转换。<br>择了 JS\           | ,软                    | (件可清 | 除此 | 位或    | 在转换 | 开始      | 后硬件        |           |          |      |  |
| 位 20     | EXTTRIG: 规则通道的外部触发转换模式(External trigger conversion mode for regular channels)该位由软件设置和清除,可开启或禁止用于启动规则通道组转换的外部触发事件。  • 0: 禁用外部事件启动转换  • 1: 使用外部事件启动转换 |                                                                                                                                                                                                                                                |                          |                       |      |    |       |     |         |            |           | els )    |      |  |
| 位 19:17  | EXTSEL[2:0]:                                                                                                                                        | 于启动 射                                                                                                                                                                                                                                          | 见则通道<br>配置如 <sup>-</sup> | ∮组 <sup>∮</sup><br>下: |      |    |       |     | nal eve | ent select | for regul | ar group | )    |  |



|         | <ul> <li>001: 定时器 1 的 CC2 事件</li> <li>010: 定时器 1 的 CC3 事件</li> <li>011: 定时器 2 的 CC2 事件</li> <li>100: 定时器 3 的 TRGO 事件</li> <li>101: 定时器 4 的 CC4 事件</li> <li>110: EXTI 线 11</li> <li>111: SWSTART</li> </ul>                 |
|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 16    | Res: 保留<br>必须保持复位值。                                                                                                                                                                                                        |
| 位 15    | JEXTTRIG: 注入通道的外部触发转换模式(External trigger conversion mode for injected channels)该位由软件设置和清除,可开启或禁止用于启动注入通道组转换的外部触发事件。  • 0: 禁用外部事件启动转换  • 1: 使用外部事件启动转换                                                                      |
| 位 14:12 | JEXTSEL[2:0]: 选择启动注入通道组转换的外部事件(External event select for injected group)这些位选择用于启动注入通道组转换的外部事件。 ADC1 和 ADC2 的触发配置如下: 000: 定时器 1 的 TRGO 事件 001: 定时器 2 的 TRGO 事件 010: 定时器 2 的 CC1 事件 100: 定时器 3 的 CC4 事件 110: 定时器 4 的 TRGO 事件 |
| 位 11    | ALIGN: 数据对齐 (Data alignment) 该位由软件设置和清除。见图 11-6 和图 11-7。 • 0: 右对齐 • 1: 左对齐                                                                                                                                                 |
| 位 10:9  | Res: 保留<br>必须保持复位值。                                                                                                                                                                                                        |
| 位 8     | DMA: 直接存储器访问模式 (Direct memory access mode)         该位由软件设置和清除。详见 DMA 控制器。         • 0: 禁用 DMA 模式         • 1: 使用 DMA 模式         说明: 只有 ADC1 能产生 DMA 请求。                                                                    |
| 位 7:4   | Res: 保留<br>必须保持复位值。                                                                                                                                                                                                        |



位 3 RSTCAL: 复位校准(Reset calibration) 该位由软件设置并由硬件清除。在校准寄存器被初始化后,该位将被清除。 • 0: 校准寄存器已初始化 • 1: 初始化校准寄存器 说明:如果正在进行转换时设置RSTCAL,清除校准寄存器需要额外的周期。 位 2 CAL: A/D 校准(A/D Calibration) 该位由软件设置以开始校准,并在校准结束时由硬件清除。 • 0: 校准完成 • 1: 开始校准 CONT: 连续转换(Continuous conversion) 位 1 该位由软件设置和清除。如果设置了此位,则转换将连续进行直到该位被清除。 • 0: 单次转换模式 • 1: 连续转换模式 位 0 ADON: 开或关 A/D 转换器 (A/D converter ON / OFF) 该位由软件设置和清除。 当该位为'0'时,写入'1'将把 ADC 从断电模式下唤醒。当该位为'1'时,写入'1'将启动转 换。应用程序需注意,在转换器上电至转换开始有一个延迟 t<sub>STAB</sub>,参见图 11-2。 • 0: 禁用 ADC 转换/校准,并进入断电模式。 • 1: 使能 ADC 并启动转换。 说明:如果在这个寄存器中与ADON 一起还有其他位被改变,则转换不被触发。这是为 了防止触发错误的转换。

## 11.11.4 ADC 采样时间寄存器 1 (ADC\_SMPR1)

偏移地址: 0x0C

| 31       | 30   | 29  | 28      | 3  | 27 | 26    | 25   | 24 | 23    | 22                    | 21   | 20 | 19     | 18         | 1/     | 16  |  |
|----------|------|-----|---------|----|----|-------|------|----|-------|-----------------------|------|----|--------|------------|--------|-----|--|
| Res      |      |     |         |    |    |       |      |    | S     | MP17[2                | 2:0] | 9  | MP16[2 | SMP15[2:1] |        |     |  |
|          |      |     |         |    |    |       |      |    |       | rw rw                 |      |    |        |            | rw     |     |  |
|          |      |     |         |    |    |       |      |    | _     | _                     |      |    | 1      |            |        |     |  |
| 15       |      | 14  | 13      | 12 | 11 | 10    | 9    | 8  | 7     | 6                     | 5    | 4  | 3      | 2          | 1      | 0   |  |
| SMP15    | 5[0] | SMF | 214[2:0 | 0] | S  | MP13[ | 2:0] |    | SMP12 | SMP12[2:0] SMP11[2:0] |      |    |        |            | MP10[2 | :0] |  |
| rw rw rw |      |     |         |    |    |       | rw   | ,  |       | rw                    |      |    | rw     |            |        |     |  |
|          |      |     |         |    |    |       |      |    |       |                       |      |    |        | •          |        |     |  |

| 位 31:24                         | Res: 保留<br>必须保持复位值。                                                                                     |
|---------------------------------|---------------------------------------------------------------------------------------------------------|
| 位 3(x-10)+2:3(x-10)<br>(x=1710) | SMPx[2:0]: 选择通道 x 的采样时间(x=1710)(Channel x Sample time selection)这些位用于独立地选择每个通道的采样时间。在采样周期中,通道选择位必须保持不变。 |



• 011: 28.5 周期

• 100: 41.5 周期

• 101: 55.5 周期

• 110: 71.5 周期

• 111: 239.5 周期

说明: ADC1 的模拟输入通道16 和通道17 在芯片内部分别连到了温度传感器

和VREFINT。

ADC2 的模拟输入通道16 和通道17 在芯片内部连到了Vss。

## 11.11.5 ADC 采样时间寄存器 2(ADC\_SMPR2)

偏移地址: 0x10

复位值: 0x0000 0000

| 31            | 30             | 29 | 28 | 27 | 26        | 25      | 24 | 23      | 22      | 21        | 20 | 19      | 18        | 17        | 16 |  |
|---------------|----------------|----|----|----|-----------|---------|----|---------|---------|-----------|----|---------|-----------|-----------|----|--|
| Res SMP9[2:0] |                |    |    | ]  | SN        | ИР8[2:0 | ]  | S       | MP7[2:0 | )]        | S  | MP6[2:0 | )]        | SMP5[2:1] |    |  |
|               |                |    | rw |    |           | rw      |    |         | rw      |           |    | rw      |           | r         | w  |  |
|               | 1              |    |    | 1  | 1         | 1       | 1  | 1       |         | 1         | 1  |         |           |           | 1  |  |
| 15            | 14             | 13 | 12 | 11 | 10        | 9       | 8  | 7       | 6       | 5         | 4  | 3       | 2         | 1         | 0  |  |
| SMP50         | MP50 SMP4[2:0] |    |    |    | SMP3[2:0] |         |    | SMP2[2: | :0]     | SMP1[2:0] |    |         | SMP0[2:0] |           |    |  |
| rw rw         |                |    |    | rw |           |         | rw |         |         | rw        |    |         | rw        |           |    |  |

| 位 31:30             | Res: 保留<br>必须保持复位值。                                                                                   |
|---------------------|-------------------------------------------------------------------------------------------------------|
| 位 3x+2:3x<br>(x=90) | SMPx[2:0]: 选择通道 x 的采样时间(x=90)(Channel x Sample time selection) 这些位用于独立地选择每个通道的采样时间。在采样周期中通道选择位必须保持不变。 |

## 11.11.6 ADC 注入通道 x 数据偏移寄存器(ADC\_JOFRx)(x=1..4)

偏移地址: 0x14+0x04\*(x-1)

复位值: 0x0000 0000

| 31 | 30 | 29  | 28 | 27 | 26 | 25 | 24 | 23 | 22  | 21       | 20  | 19 | 18 | 17 | 16 |
|----|----|-----|----|----|----|----|----|----|-----|----------|-----|----|----|----|----|
|    |    |     |    |    |    |    | R  | es |     |          |     |    |    |    |    |
|    |    |     |    |    |    |    |    |    |     |          |     |    |    |    |    |
|    | _  |     |    |    |    |    |    |    |     |          |     |    |    |    |    |
| 15 | 14 | 13  | 3  | 12 | 11 | 10 | 9  | 8  | 7   | 6        | 5 4 | 3  | 2  | 1  | 0  |
|    |    | Poc |    |    |    |    |    |    | IOE | ECETV[11 | ·01 |    |    |    |    |

Res JOFFSETx[11:0] rw

位 31: 12

Res: 保留



|        | 必须保持复位值。                                                                                                                        |
|--------|---------------------------------------------------------------------------------------------------------------------------------|
| 位 11:0 | JOFFSETx[11:0]: 注入通道 x 的数据偏移(x=14)(Data offset for injected channel x) 当转换注入通道时,这些位定义了用于从原始转换数据中减去的数值。转换的结果可以在 ADC_JDRx 寄存器中读出。 |

## 11.11.7 ADC 看门狗高阈值寄存器(ADC\_HTR)

偏移地址: 0x24

复位值: 0x0000 0000

| 31     | 30                                                                                          | 29          | 28 27      | 26 | 25 | 24 | 23 | 22 | 21 | 20  | 19  | 18 | 17 | 16 |
|--------|---------------------------------------------------------------------------------------------|-------------|------------|----|----|----|----|----|----|-----|-----|----|----|----|
|        |                                                                                             |             |            |    |    | R  | es |    |    |     |     |    |    |    |
|        |                                                                                             |             |            |    |    |    |    |    |    |     |     |    |    |    |
| 15     | 14                                                                                          | 13          | 12         | 11 | 10 | 9  | 8  | 7  | 6  | 5 4 | 1 3 | 2  | 1  | 0  |
|        | Res HT[11:0]                                                                                |             |            |    |    |    |    |    |    |     | •   |    |    |    |
|        |                                                                                             |             |            |    |    |    |    |    | rw |     |     |    |    |    |
| 位 31:3 | 3                                                                                           | Res:<br>必须( | 保留<br>保持复位 | 值。 |    |    |    |    |    |     |     |    |    |    |
| 位 11:0 | 位 <b>11:0</b> HT[ <b>11:0</b> ]:模拟看门狗阈值上限(Analog watchdog high threshold) 这些位定义了模拟看门狗的阈值上限。 |             |            |    |    |    |    |    |    |     |     |    |    |    |

说明: 软件可以在 ADC 转换进行的时候写该寄存器。写入的值在下一次转换结束的时候生效。写入该寄存器存在一定的延迟,导致其生效的准确时间存在一定的不确定性。

## 11.11.8 ADC 看门狗低阈值寄存器(ADC\_LTR)

偏移地址: 0x28

复位值: 0x0000 0000

| 31     | 30                                                                        | 29 2     | 8 27       | 26  | 25 | 24 | 23  | 22 | 21      | 2  | 20 | 19 | 18 | 17 | 16 |
|--------|---------------------------------------------------------------------------|----------|------------|-----|----|----|-----|----|---------|----|----|----|----|----|----|
|        |                                                                           |          |            |     |    | F  | les | •  |         | •  |    | ·  |    |    |    |
|        |                                                                           |          |            |     |    |    |     |    |         |    |    |    |    |    |    |
| 15     | 14                                                                        | 13       | 12         | 11  | 10 | 9  | 8   | 7  | 6       | 5  | 4  | 3  | 2  | 1  | 0  |
|        | F                                                                         | Res      |            |     |    | 1  |     | 1  | LT[11:0 | 0] |    |    |    |    |    |
|        |                                                                           |          |            |     |    |    |     |    | rw      |    |    |    |    |    |    |
| 位 31:3 | 3                                                                         | Res: 必须仍 | 保留<br>R持复位 | .值。 |    |    |     |    |         |    |    |    |    |    |    |
| 位 11:0 | 11:0 LT[11:0]:模拟看门狗的阈值下限(Analog watchdog low threshold) 这些位定义了模拟看门狗的阈值下限。 |          |            |     |    |    |     |    |         |    |    |    |    |    |    |

说明: 软件可以在 ADC 转换进行的时候写该寄存器。写入的值在下一次转换结束的时候生效。写入该寄存器存在一定的延迟,导致其生效的准确时间存在一定的不确定性。

## 11.11.9 ADC 规则序列寄存器(ADC\_SQR1)

偏移地址: 0x2C



复位值: 0x0000 0000

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22  | 21   | 20 | 19        | 18 | 17 | 16 |  |
|----|----|----|----|----|----|----|----|----|-----|------|----|-----------|----|----|----|--|
|    |    |    | Re | es |    |    |    |    | L[3 | 3:0] |    | SQ16[4:1] |    |    |    |  |
|    |    |    |    |    |    |    |    |    | r۱  | N    |    |           | r  | w  |    |  |

| 15      | 14 | 13 | 12      | 11 | 10 | 9 | 8 | 7       | 6 | 5 | 4 3 2 1 0 |  |    |  |  |  |
|---------|----|----|---------|----|----|---|---|---------|---|---|-----------|--|----|--|--|--|
| SQ16[0] |    | S  | Q15[4:0 | )] |    |   | S | Q14[4:0 | ] |   | SQ13[4:0] |  |    |  |  |  |
| rw      |    |    | rw      |    |    |   |   | rw      |   |   |           |  | rw |  |  |  |

| 位 31:24 | Res: 保留<br>必须保持复位值。                                                                                  |
|---------|------------------------------------------------------------------------------------------------------|
| 位 23:20 | L[3:0]: 规则通道序列长度(Regular channel sequence length) 这些位由软件定义在规则通道转换序列中的通道数目。                           |
| 位 19:15 | SQ16[4:0]: 规则序列中的第 16 个转换(16th conversion in regular sequence)<br>这些位由软件定义转换序列中的第 16 个转换通道的编号(0~17)。 |
| 位 14:10 | SQ15[4:0]: 规则序列中的第 15 个转换(15th conversion in regular sequence)                                       |
| 位 9:5   | SQ14[4:0]: 规则序列中的第 14 个转换(14th conversion in regular sequence)                                       |
| 位 4:0   | SQ13[4:0]: 规则序列中的第 13 个转换(13th conversion in regular sequence)                                       |

# 11.11.10 ADC 规则序列寄存器 2(ADC\_SQR2)

偏移地址: 0x30

| 31     | 30    | 29 | 28    | 27      | 26 | 25 | 24    | 23     | 22      | 21 | 20       | 19        | 18 | 17 | 16 |  |  |
|--------|-------|----|-------|---------|----|----|-------|--------|---------|----|----------|-----------|----|----|----|--|--|
| Re     | es    |    | S     | Q12[4:0 | ]  |    |       | S      | Q11[4:0 | ]  |          | SQ10[4:1] |    |    |    |  |  |
|        |       |    |       | rw      |    |    |       |        | rw      |    |          | rw        |    |    |    |  |  |
|        |       |    |       | _       |    | _  | _     | _      |         |    |          |           |    |    |    |  |  |
| 15     | 14    | 13 | 12    | 11      | 10 | 9  | 8     | 7      | 6       | 5  | 4        | 3         | 2  | 1  | 0  |  |  |
| SQ10[0 | 0]    |    | SQ9[4 | :0]     |    |    |       | SQ8[4: | 0]      |    | SQ7[4:0] |           |    |    |    |  |  |
| r\A/   | rw rw |    |       |         |    |    | rw rw |        |         |    |          |           |    |    |    |  |  |

| 位 31:30 | Res: 保留<br>必须保持复位值。                                                                                                         |
|---------|-----------------------------------------------------------------------------------------------------------------------------|
| 位 29:25 | SQ12[4:0]: 规则序列中的第 <b>12</b> 个转换(12th conversion in regular sequence)<br>这些位由软件定义转换序列中的第 <b>12</b> 个转换通道的编号( <b>0~17</b> )。 |
| 位 24:20 | SQ11[4:0]: 规则序列中的第 11 个转换(11th conversion in regular sequence)                                                              |
| 位 19:15 | SQ10[4:0]: 规则序列中的第 10 个转换(10th conversion in regular sequence)                                                              |
| 位 14:10 | SQ9[4:0]: 规则序列中的第 9 个转换(9th conversion in regular sequence)                                                                 |



| 位 9:5 | SQ8[4:0]: 规则序列中的第 8 个转换(7th conversion in regular sequence) |
|-------|-------------------------------------------------------------|
| 位 4:0 | SQ7[4:0]: 规则序列中的第 7 个转换(7th conversion in regular sequence) |

# 11.11.11 ADC 规则序列寄存器 3(ADC\_SQR3)

偏移地址: 0x34

复位值: 0x0000 0000

| 31 | 30  | 29 | 28 | 27       | 26 | 25 | 24 | 23 | 22       | 21 | 20 | 19       | 18 | 17 | 16 |  |
|----|-----|----|----|----------|----|----|----|----|----------|----|----|----------|----|----|----|--|
| R  | les |    |    | SQ6[4:0] |    |    |    |    | SQ5[4:0] |    |    | SQ4[4:1] |    |    |    |  |
|    |     | rw |    |          |    |    |    |    | rw       |    |    | rw       |    |    |    |  |

| 15     | 14 | 13 | 12       | 11 | 10 | 9 | 8 | 7       | 6 | 5 | 4        | 3 | 2  | 1 | 0 |  |
|--------|----|----|----------|----|----|---|---|---------|---|---|----------|---|----|---|---|--|
| SQ4[0] |    |    | SQ3[4:0] | ]  |    |   | : | SQ2[4:0 |   |   | SQ1[4:0] |   |    |   |   |  |
| rw     |    |    | rw       |    |    |   |   | rw      |   |   |          |   | rw |   |   |  |

| 位 31:30 | Res: 保留<br>必须保持复位值。                                                                              |
|---------|--------------------------------------------------------------------------------------------------|
| 位 29:25 | SQ6[4:0]: 规则序列中的第 6 个转换(6th conversion in regular sequence)<br>这些位由软件定义转换序列中的第 6 个转换通道的编号(0~17)。 |
| 位 24:20 | SQ5[4:0]: 规则序列中的第 5 个转换(5th conversion in regular sequence)                                      |
| 位 19:15 | SQ4[4:0]: 规则序列中的第 4 个转换(4th conversion in regular sequence)                                      |
| 位 14:10 | SQ3[4:0]: 规则序列中的第 3 个转换(3rd conversion in regular sequence)                                      |
| 位 9:5   | SQ2[4:0]: 规则序列中的第 2 个转换(2nd conversion in regular sequence)                                      |
| 位 4:0   | SQ1[4:0]: 规则序列中的第 1 个转换(1st conversion in regular sequence)                                      |

## 11.11.12 ADC 注入序列寄存器(ADC\_JSQR)

偏移地址: 0x38

| 31 | 30  | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20   | 19        | 18 | 17 | 16 |
|----|-----|----|----|----|----|----|----|----|----|----|------|-----------|----|----|----|
|    | Res |    |    |    |    |    |    |    |    |    | L:0] | JSQ4[4:1] |    |    |    |
|    |     |    |    |    |    |    |    |    |    |    | N    |           | r  | w  |    |

| 15      | 14 | 13 | 12       | 11 | 10 | 9 | 8       | 7  | 6 | 5         | 4  | 3 | 2 | 1 | 0 |  |
|---------|----|----|----------|----|----|---|---------|----|---|-----------|----|---|---|---|---|--|
| JSQ4[0] |    | J  | ISQ3[4:0 | ]  |    | J | SQ2[4:0 | ]  |   | JSQ1[4:0] |    |   |   |   |   |  |
| rw      |    |    | rw       |    |    |   |         | rw |   |           | rw |   |   |   |   |  |

| 位 31:22 | Res: 保留<br>必须保持复位值。                                                  |
|---------|----------------------------------------------------------------------|
| 位 21:20 | JL[1:0]: 注入通道序列长度(Injected sequence length) 这些位由软件定义在注入通道转换序列中的通道数目。 |



|         | <ul><li>10: 3 个转换</li><li>11: 4 个转换</li></ul>                                                                                                                                                                                                                                 |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 19:15 | JSQ4[4:0]: 注入序列中的第 4 个转换(4th conversion in injected sequence (when JL[1:0] = 3) <sup>(1)</sup> ) 这些位由软件定义转换序列中的第 4 个转换的通道号(0~17)。 <i>说明:不同于规则转换序列,如果 JL</i> [1:0]的长度小于4,则转换的序列顺序是从(4-JL) 开始。例如: ADC_JSQR[21:0]=10 00011 00011 00111 00010,意味着扫描转换将按下列通道顺序转换: 7、3、3,而不是 2、7、3。 |
| 位 14:10 | JSQ3[4:0]: 注入序列中的第 3 个转换(3rd conversion in injected sequence (when JL[1:0] = 3))                                                                                                                                                                                              |
| 位 9:5   | JSQ2[4:0]: 注入序列中的第 2 个转换(2nd conversion in injected sequence (when JL[1:0] = 3))                                                                                                                                                                                              |
| 位 4:0   | JSQ1[4:0]: 注入序列中的第 1 个转换(1st conversion in injected sequence (when JL[1:0] = 3))                                                                                                                                                                                              |

## 11.11.13 ADC 注入数据寄存器 x(ADC\_JDRx)(x=1..4)

偏移地址: 0x3C+0x04\*(x-1)

复位值: 0x0000 0000

| 31          | 30  | 29 | 28        | 27 | 26           | 25 | 24 | 23  | 22  | 21 | 20  | 19  | 18   | 17    | 16    |
|-------------|-----|----|-----------|----|--------------|----|----|-----|-----|----|-----|-----|------|-------|-------|
|             |     |    |           |    |              |    | F  | Res |     |    |     |     |      |       |       |
|             |     |    |           |    |              |    |    |     |     |    |     |     |      |       |       |
| 15          | 14  | 13 | : :       | 12 | 11           | 10 | 9  | 8   | 7   | 6  | 5   | 4   | 3 2  | 1     | 0     |
| JDATA[15:0] |     |    |           |    |              |    |    |     |     |    |     |     |      |       |       |
|             |     |    |           |    |              |    |    | r   |     |    |     |     |      |       |       |
| 位 31:       | :16 |    | : 保<br>保持 |    | 直。           |    |    |     |     |    |     |     |      |       |       |
| 位 15:       | :0  | 这  | _         | _  | 三入转扬<br>包含 、 |    |    | 的转换 | 结果。 | 右对 | 齐或左 | 对齐的 | 的数据, | 见图 1: | 1-6 和 |

## 11.11.14 ADC 规则数据寄存器(ADC\_DR)

偏移地址: 0x4C

| 31     | 30                                               | 29 2    | 28 27            | 7 26   | 25   | 24   | 23     | 22  | 21 |  | 20 | 19 | 18 | 17 | 16 |
|--------|--------------------------------------------------|---------|------------------|--------|------|------|--------|-----|----|--|----|----|----|----|----|
| 31     | ADC2DATA[15:0]                                   |         |                  |        |      |      |        |     |    |  |    |    |    | 10 |    |
|        | rw                                               |         |                  |        |      |      |        |     |    |  |    |    |    |    |    |
| 15     | 15                                               |         |                  |        |      |      |        |     |    |  |    |    |    |    | 0  |
|        | DATA[15:0]                                       |         |                  |        |      |      |        |     |    |  |    |    |    |    |    |
|        |                                                  |         |                  |        |      | r    | W      |     |    |  |    |    |    |    |    |
| 位 31:: | 16 A                                             | DC2DATA | ۸[15:0] <b>:</b> | ADC2 车 | 专换的数 | 女据(A | DC2 da | ta) |    |  |    |    |    |    |    |
|        | • 在 ADC1 中:双模式下,这些位包含了 ADC2 转换的规则通道数据。见双 ADC 模式。 |         |                  |        |      |      |        |     |    |  |    |    |    |    |    |
|        | • 在 ADC2 中: 不使用这些位。                              |         |                  |        |      |      |        |     |    |  |    |    |    |    |    |



位 15:0

DATA[15:0]: 规则转换的数据(Regular data)

这些位为只读,包含了注入通道的转换结果。右对齐或左对齐的数据,见图 11-6 和图 11-7。



## 12 高级控制定时器(TIM1)

高级控制定时器(TIM1)由一个 16 位的自动装载计数器组成,它由一个可编程的预分频器驱动。

高级控制定时器适合多种用途,包含测量输入信号的脉冲宽度(输入捕获),或者产生输出波形(输出比较、PWM、带死区插入的互补 PWM 等)。

使用定时器预分频器和 RCC 时钟控制预分频器,可以实现脉冲宽度和波形周期从几个微秒到几个毫秒的调节。

高级控制定时器(TIM1)和通用定时器(TIMx)是完全独立的,它们不共享任何资源。这两种定时器可以同步操作,详情可参考"12.2.20 定时器同步"。

## 12.1 TIM1 主要特性

TIM1 定时器的功能包括:

- 四路输入通道均支持上升沿、下降沿和双边沿触发功能
- 16 位向上、向下、向上/下自动装载计数器
- 16 位可编程(支持实时修改)预分频器,计数器时钟频率的分频系数为 1~65536 之间的任意数值
- 多达 4 个独立通道:
  - 。 输入捕获
  - 。 输出比较
  - 。 PWM 生成(边沿或中央对齐模式)
  - 。 单脉冲模式输出
- 带死区时间可编程的互补输出
- 使用外部信号控制定时器和定时器互联的同步电路
- 允许在指定数目的计数器周期之后更新定时器寄存器的重复计数器
- 刹车输入信号可以将定时器输出信号置于复位状态或者一个已知状态
- 如下事件发生时产生中断/DMA:
  - 。 更新: 计数器向上溢出/向下溢出, 计数器初始化(通过软件或者内部/外部触发)
  - 。 触发事件(计数器启动、停止、初始化或者由内部/外部触发计数)
  - 。 输入捕获
  - 。 输出比较
  - 。 刹车信号输入
- 支持针对定位的增量(正交)编码器和霍尔传感器电路
- 触发输入作为外部时钟或者按周期的电流管理





图 12-1 高级控制定时器框图

## 12.2 TIM1 功能描述

## 12.2.1 时基单元

可编程高级控制定时器的主要部分是一个 16 位计数器和与其相关的自动装载寄存器。这个计数器可以向上计数、向下计数或者向上向下双向计数。此计数器时钟由预分频器分频得到。

计数器、自动装载寄存器和预分频器寄存器可以由软件读写。即使计数器还在运行,读写仍然有效。时基单元包含:

• 计数器寄存器(TIMx\_CNT)



- 预分频器寄存器(TIMx PSC)
- 自动重装载寄存器(TIMx\_ARR)
- 重复次数寄存器(TIMx RCR)

自动重装载寄存器是预先装载的,写或读自动重装载寄存器将访问预装载寄存器。根据在TIMx\_CR1 寄存器中的自动装载预装载使能位(ARPE)的设置,预装载寄存器的内容被立即或在每次的更新事件 UEV 时传送到影子寄存器。当计数器达到溢出条件(如向下计数时的下溢条件)并当TIMx\_CR1 寄存器中的 UDIS 位等于 0 时,产生更新事件。更新事件也可以由软件产生。随后会详细描述每一种配置下更新事件的产生。

计数器由预分频器的时钟输出 CK\_CNT 驱动,仅当设置了计数器 TIMx\_CR1 寄存器中的计数器使能位 (CEN)时,CK CNT 才有效。(更多有关使能计数器的细节,请参见控制器的从模式描述)。

注意:在设置了TIMx\_CR 寄存器的CEN 位的一个时钟周期后,计数器开始计数。

TIMx\_PCS、TIMx\_ARR、TIMx\_RCR 等寄存器具有预装载功能,分别由各自的预装载寄存器和影子寄存器组成。影子寄存器是实际起作用的寄存器。

#### 12.2.1.1 预分频器描述

预分频器可以将计数器的时钟频率按 1 到 65536 之间的任意值分频。它是基于一个(在 TIMx\_PSC 寄存器中的)16 位寄存器控制的 16 位计数器。因为这个控制寄存器带有缓冲功能,它能够在运行时被改变。新的预分频器的参数在下一次更新事件到来时被采用。

下面两个图给出了在预分频器运行时,更改计数器参数的例子。



图 12-2 当预分频器的参数从 1 变到 2 时, 计数器的时序图





图 12-3 当预分频器的参数从 1 变到 4 时, 计数器的时序图

#### 12.2.2 计数器模式

#### 12.2.2.1 向上计数模式

在向上计数模式中,计数器从 0 计数到自动加载值(TIMx\_ARR 寄存器的值),然后重新从 0 开始计数并且产生一个计数器溢出事件。

如果使用了重复计数器功能,在向上计数达到设置的重复计数次数加 1 (TIMx\_RCR+1) 时,产生更新事件(UEV);否则每次计数器溢出时才产生更新事件。

在 TIMx\_EGR 寄存器中(通过软件方式或者使用从模式控制器)设置 UG 位也可产生一个更新事件。

设置 TIMx\_CR1 寄存器中的 UDIS 位,可以禁止更新事件;这样可以避免在向预装载寄存器中写入新值时更新影子寄存器。在 UDIS 位被清零之前,将不产生更新事件。但是计数器仍会被清零,同时预分频器的计数也会被清 0 (但预分频器的数值不变)。此外,如果设置了 TIMx\_CR1 寄存器中的 URS 位 (选择更新请求),设置 UG 位将产生一个更新事件 UEV,但硬件不设置 UIF 标志(即不产生中断或 DMA 请求)。这是为了避免在捕获模式下清除计数器时,同时产生更新和捕获中断。

当发生一个更新事件时,所有的寄存器都被更新,且硬件同时(依据 URS 位)设置更新标志位(TIMx SR 寄存器中的 UIF 位):

- 重复计数器被重新加载为 TIMx RCR 寄存器的内容。
- 自动装载影子寄存器被重新置入预装载寄存器的值(TIMx ARR)。
- 预分频器的缓冲区被置入预装载寄存器的值(TIMx PSC 寄存器的内容)。

下面给出一些例子,当 TIMx ARR=0x36 时计数器在不同时钟频率下的动作。





图 12-4 计数器时序图,内部时钟分频因子为 1



图 12-5 计数器时序图,内部时钟分频因子为 2



图 12-6 计数器时序图,内部时钟分频因子为 4





图 12-7 计数器时序图,内部时钟分频因子为 N



图 12-8 计数器时序图, 当 ARPE=0 时的更新事件(TIMx\_ARR 没有预装入)



图 12-9 计数器时序图, 当 ARPE=1 时的更新事件(预装入了 TIMx\_ARR)



#### 12.2.2.2 向下计数模式

在向下模式中,计数器从自动装载的值(TIMx\_ARR 计数器的值)开始向下计数到 0,然后从自动装载的值重新开始并且产生一个计数器向下溢出事件。

如果使用了重复计数器,当向下计数达到了重复计数寄存器(TIMx\_RCR)中设定的次数后,将产生更新事件(UEV),否则每次计数器下溢时才产生更新事件。

在 TIMx\_EGR 寄存器中(通过软件方式或者使用从模式控制器)设置 UG 位,也同样可以产生一个更新事件。

设置 TIMx\_CR1 寄存器的 UDIS 位可以禁止 UEV 事件。这样可以避免向预装载寄存器中写入新值时更新影子寄存器。因此 UDIS 位被清为 0 之前不会产生更新事件。然而,计数器仍会从当前自动加载值重新开始计数,并且预分频器的计数器重新从 0 开始(但预分频系数不变)。

此外,如果设置了 TIMx\_CR1 寄存器中的 URS 位(选择更新请求),设置 UG 位将产生一个更新事件(UEV)但不设置 UIF 标志(因此不产生中断和 DMA 请求)。这是为了避免在发生捕获事件并清除计数器时,同时产生更新和捕获中断。

当发生更新事件时,所有的寄存器都被更新,并且(根据 URS 位的设置)更新标志位(TIMx\_SR 寄存器中的 UIF 位)也被设置:

- 重复计数器被重置为 TIMx RCR 寄存器中的值。
- 预分频器的缓冲器被加载为预装载的值(TIMx PSC 寄存器的值)。
- 当前的自动重装载寄存器被更新为预装载值(TIMX ARR 寄存器中的内容)。

注意: 自动装载在计数器重装载之前被更新, 因此下一个周期将是预期的值。

以下是一些当 TIMx\_ARR=0x36 时,计数器在不同时钟频率下的操作例子。



图 12-10 计数器时序图,内部时钟分频因子为 1





图 12-11 计数器时序图,内部时钟分频因子为 2



图 12-12 计数器时序图,内部时钟分频因子为 4



图 12-13 计数器时序图,内部时钟分频因子为 N





图 12-14 计数器时序图, 当没有使用重复计数器时的更新事件

#### 12.2.2.3 中央对齐模式(向上/向下计数)

在中央对齐模式, 计数器从 0 开始计数到自动装载的值减 1 (TIMx\_ARR 寄存器的值-1), 产生一个计数器溢出事件, 然后向下计数到 1 并且产生一个计数器下溢事件, 然后再从 0 开始重新计数。

在此模式下,不能写入 TIMx\_CR1 中的 DIR 方向位。它由硬件更新并指示当前的计数方向。

可以在每次计数上溢和每次计数下溢时产生更新事件;也可以通过(软件或者使用从模式控制器)设置 TIMx\_EGR 寄存器中的 UG 位产生更新事件。然后,计数器重新从 0 开始计数,预分频器也重新从 0 开始计数。

设置 TIMx\_CR1 寄存器中的 UDIS 位可以禁止 UEV 事件。这样可以避免在向预装载寄存器中写入新值时更新影子寄存器。因此 UDIS 位被清为 0 之前不会产生更新事件。然而,计数器仍会根据当前自动重加载的值,继续向上或向下计数。

此外,如果设置了 TIMx\_CR1 寄存器中的 URS 位(选择更新请求),设置 UG 位将产生一个更新事件(UEV)但不设置 UIF 标志(因此不产生中断和 DMA 请求),这是为了避免在发生捕获事件并清除计数器时,同时产生更新和捕获中断。

当发生更新事件时,所有的寄存器都被更新,并且(根据 URS 位的设置)更新标志位(TIMx\_SR 寄存器中的 UIF 位)也被设置:

- 重复计数器被重置为 TIMx\_RCR 寄存器中的值。
- 预分频器的缓存器被加载为预装载(TIMx PSC 寄存器)的值。
- 当前的自动加载寄存器被更新为预装载值(TIMx ARR 寄存器中的内容)。

注意:如果因为计数器溢出而产生更新,自动重装载将在计数器重载入之前被更新,因此下一个周期将是预期的值(计数器被装载为新的值)。

以下是一些计数器在不同时钟频率下的操作的例子:





图 12-15 计数器时序图,内部时钟分频因子为 1,TIMx\_ARR=0x6

图 12-15 中使用了中心对齐模式 1, 详见"TIM1 控制寄存器 1 (TIMx CR1)"。



图 12-16 计数器时序图,内部时钟分频因子为 2



图 12-17 计数器时序图,内部时钟分频因子为 4,TIMx ARR=0x36





图 12-18 计数器时序图,内部时钟分频因子为 N



图 12-19 计数器时序图, ARPE=1 时的更新事件(计数器下溢)



图 12-20 计数器时序图, ARPE=1 时的更新事件(计数器上溢)



#### 12.2.3 重复计数器

"12.2.1 时基单元"解释了计数器上溢/下溢时更新事件(UEV)是如何产生的,然而事实上它只能在重复计数达到 0 的时候产生。这个特性对产生 PWM 信号非常有用。

这意味着在每 N+1 次计数上溢或下溢时,数据从预装载寄存器传输到影子寄存器(TIMx\_ARR 自动重 装 载 寄 存 器 , TIMx\_PSC 预 装 载 寄 存 器 , 还 有 在 比 较 模 式 下 的 捕 获 /比 较 寄 存 器 TIMx\_CCRx ), N 是 TIMx\_RCR 重复计数寄存器中的值。

重复计数器在下述任一条件成立时递减:

- 向上计数模式下每次计数器上溢时
- 向下计数模式下每次计数器下溢时
- 中央对齐模式下每次上溢和每次下溢时。虽然这样限制了 PWM 的最大循环周期为 128,但它能够在每个 PWM 周期 2 次更新占空比。在中央对齐模式下,因为波形是对称的,如果每个 PWM 周期中仅刷新一次比较寄存器,则最大的分辨率为 2xT<sub>ck</sub>。

重复计数器是自动加载的,重复速率是由 TIMx\_RCR 寄存器的值定义。当更新事件由软件产生(通过设置 TIMx\_EGR 中的 UG 位)或者通过硬件的从模式控制器产生,则无论重复计数器的值是多少,立即发生更新事件,并且 TIMx RCR 寄存器中的内容被重载入到重复计数器。



图 12-21 不同模式下更新速率的例子,及 TIMx RCR 的寄存器设置

#### 12.2.4 时钟选择

计数器时钟可由下列时钟源提供:

- 内部时钟(CK INT)
- 外部时钟模式 1: 外部输入引脚
- 外部时钟模式 2: 外部触发输入 ETR
- 内部触发输入(ITRx): 使用一个定时器作为另一个定时器的预分频器。如可以配置一个定时器 Timer1 而作为另一个定时器 Timer2 的预分频器。详见下一章。



#### 12.2.4.1 内部时钟源(CK INT)

如果禁止了从模式控制器(SMS=000),则 CEN、DIR(TIMx\_CR1 寄存器)和 UG 位(TIMx\_EGR 寄存器)是事实上的控制位,并且只能被软件修改(UG 位仍被自动清除)。只要 CEN 位被写成'1',预分频器的时钟就由内部时钟 CK\_INT 提供。

下图显示控制电路和向上计数器在一般模式下,不带预分频器时的操作。



图 12-22 一般模式下的控制电路,内部时钟分频因子为 1

#### 12.2.4.2 外部时钟源模式 1

当 TIMx\_SMCR 寄存器的 SMS=111 时,此模式被选中。计数器可以在选定输入端的每个上升沿或下降沿计数。



图 12-23 TI2 外部时钟连接例子

例如,配置向上计数器在 T12 输入端的上升沿计数,步骤如下:

- 1. 配置 TIMx CCMR1 寄存器 CC2S=01,以设置通道 2 检测 TI2 输入的上升沿。
- 2. 配置 TIMx\_CCMR1 寄存器的 IC2F[3:0],以选择输入滤波器带宽(如果不需要滤波器,保持 IC2F=0000)。
- 3. 配置 TIMx\_CCER 寄存器的 CC2P=0,以选择上升沿极性。
- 4. 配置 TIMx\_SMCR 寄存器的 SMS=111,以选择定时器工作在外部时钟模式 1。
- 5. 配置 TIMx SMCR 寄存器中的 TS=110,以选择 TI2 作为触发输入源。
- 6. 配置 TIMx CR1 寄存器的 CEN=1,以使能计数器。

注意:捕获预分频器不用作触发,所以不需要对它进行配置。

当上升沿出现在 TI2, 计数器计数一次, 且 TIF 标志被设置。



在 TI2 的上升沿和计数器实际时钟之间的延时,取决于在 TI2 输入端的重新同步电路。



图 12-24 外部时钟模式 1 下的控制电路

#### 12.2.4.3 外部时钟源模式 2

当 TIMx\_SMCR 寄存器的 ECE=1 时,此模式被选中。计数器能够在外部触发 ETR 的每一个上升沿或下降沿计数。

下图是外部触发输入的框图。



图 12-25 外部触发输入框图

例如,配置在 ETR 下每 2 个上升沿计数一次的向上计数器,步骤如下:

- 1. 本例中不需要滤波器,置 TIMx SMCR 寄存器中的 ETF[3:0]=0000。
- 2. 设置预分频器,置 TIMx SMCR 寄存器中的 ETPS[1:0]=01。
- 3. 选择 ETR 的上升沿检测,置 TIMx\_SMCR 寄存器中的 ETP=0。
- 4. 开启外部时钟模式 2,写 TIMx SMCR 寄存器中的 ECE=1。
- 5. 启动计数器,写 TIMx\_CR1 寄存器中的 CEN=1。
- 6. 计数器在每 2 个 ETR 上升沿计数一次。

在 ETR 的上升沿和计数器实际时钟之间的延时取决于在 ETRP 信号端的重新同步电路。





图 12-26 外部时钟模式 2 下的控制电路

### 12.2.5 捕获/比较通道

每一个捕获/比较通道都是围绕着一个捕获/比较寄存器(包含影子寄存器),包括捕获的输入部分(数字滤波、多路复用和预分频器),和输出部分(比较器和输出控制)。

图 12-27 和图 12-28 是一个捕获/比较通道概览。

输入部分对相应的 Tlx 输入信号采样,并产生一个滤波后的信号 TlxF。然后,一个带极性选择的边 沿检测器产生一个信号(TlxFPx),它可以作为从模式控制器的输入触发或者作为捕获控制。该信号通过 预分频进入捕获寄存器(ICxPS)。



图 12-27 捕获/比较通道(如:通道1输入部分)





图 12-28 捕获/比较通道 1 的主电路

输出部分产生一个中间波形 OCxRef(高有效)作为基准,链的末端决定最终输出信号的极性。



图 12-29 捕获/比较通道的输出部分(通道1至3)



图 12-30 捕获/比较通道的输出部分(通道 4)

捕获/比较模块由一个预装载寄存器和一个影子寄存器组成。读写过程仅操作预装载寄存器。

在捕获模式下,捕获发生在影子寄存器上,然后再复制到预装载寄存器中。

在比较模式下,预装载寄存器的内容被复制到影子寄存器中,然后影子寄存器的内容和计数器进行



比较。

## 12.2.6 输入捕获模式

在输入捕获模式下,当检测到 ICx 信号上相应的边沿后,计数器的当前值被锁存到捕获/比较寄存器(TIMx\_CCRx)中。当发生捕获事件时,相应的 CCxIF 标志(TIMx\_SR 寄存器)被置'1',如果开放了中断或者 DMA 操作,则将产生中断或者 DMA 请求。如果发生捕获事件时 CCxIF 标志已经为高,那么重复捕获标志 CCxOF(TIMx\_SR 寄存器)被置'1'。写 CCxIF=0 可清除 CCxIF,或读取存储在 TIMx\_CCRx 寄存器中的捕获数据也可清除 CCxIF。写 CCxOF=0 可清除 CCxOF。

以下例子说明如何在 TI1 输入的上升沿时捕获计数器的值到 TIMx CCR1 寄存器中,步骤如下:

- 1. 选择有效输入端: TIMx\_CCR1 必须连接到 TI1 输入,所以写入 TIMx\_CCR1 寄存器中的 CC1S=01。只要 CC1S 不为'00',通道被配置为输入,并且 TIMx\_CCR1 寄存器变为只读。
- 2. 根据输入信号的特点,配置输入滤波器为所需的带宽(即输入为 Tix 时,输入滤波器控制位是 TiMx\_CCMRx 寄存器中的 ICxF 位)。假设输入信号在最多 5 个内部时钟周期的时间内抖动,必 须配置滤波器的带宽大于 5 个时钟周期,因此可以(以 fors 频率)连续采样 8 次,以确认在 Ti1 上一次真实的边沿变换,即在 TiMx\_CCMR1 寄存器中写入 IC1F=0011。
- 3. 选择 TI1 通道的有效转换边沿,在 TIMx CCER 寄存器中写入 CC1P=0(上升沿)。
- 4. 配置输入预分频器。在本例中,希望捕获发生在每一个有效的电平转换时刻,因此预分频器被禁止(写 TIMx\_CCMR1 寄存器的 IC1PS=00 )。
- 5. 设置 TIMx CCER 寄存器的 CC1E=1,允许捕获计数器的值到捕获寄存器中。
- 6. 如果需要,通过设置 TIMx\_DIER 寄存器中的 CC1IE 位允许相关中断请求,通过设置 TIMx\_DIER 寄存器中的 CC1DE 位允许 DMA 请求。

当发生一个输入捕获时:

- 产生有效的电平转换时, 计数器的值被传送到 TIMx CCR1 寄存器。
- CC1IF 标志被设置(中断标志)。当发生至少 2 个连续的捕获时,而 CC1IF 未曾被清除,则 CC1OF 也被置'1'。
- 如设置了 CC1IE 位,则会产生一个中断。
- 如设置了 CC1DE 位,则还会产生一个 DMA 请求。

为了处理捕获溢出,建议在读出捕获溢出标志之前读取数据,这是为了避免丢失在读出捕获溢出标志之后和读取数据之前可能产生的捕获溢出信息。

注意:设置 TIMx EGR 寄存器中相应的 CCxG 位,可以通过软件产生输入捕获中断和/或 DMA 请求。

## 12.2.7 PWM 输入模式

该模式是输入捕获模式的一个特例,除下列区别外,操作与输入捕获模式相同:

- 两个 ICx 信号被映射至同一个 TIX 输入。
- 这 2 个 ICx 信号为边沿有效, 但是极性相反。
- 其中一个 TIXFP 信号被作为触发输入信号,而从模式控制器被配置成复位模式。

例如,你需要测量输入到 TI1 上的 PWM 信号的周期(TIMx\_CCR1 寄存器)和占空比(TIMx\_CCR2 寄存器),具体步骤如下(取决于 CK\_INT 的频率和预分频器的值):

- 1. 选择 TIMx CCR1 的有效输入:置 TIMx CCMR1 寄存器的 CC1S=01 (选中 TI1)。
- 2. 选择 TI1FP1 的有效极性 (用来捕获数据到 TIMx CCR1 和清除计数器);置 CC1P=0 (上升沿有



效)。

- 3. 选择 TIMx CCR2 的有效输入:置 TIMx CCMR1 寄存器的 CC2S=10 (选中 TI1)。
- 4. 选择 TI1FP2 的有效极性(捕获数据到 TIMx CCR2):置 CC2P=1(下降沿有效)。
- 5. 选择有效的触发输入信号:置 TIMx SMCR 寄存器中的 TS=101(选择 TI1FP1)。
- 6. 配置从模式控制器为复位模式:置 TIMx\_SMCR 中的 SMS=100。
- 7. 使能捕获:置 TIMx CCER 寄存器中 CC1E=1 且 CC2E=1。



图 12-31 PWM 输入模式时序

因为只有TI1FP1和TI2FP2连到了从模式控制器,所以PWM输入模式只能使用TIMx\_CH1/TIMx\_CH2信号。

#### 12.2.8 强置输出模式

在输出模式(TIMx\_CCMRx 寄存器中 CCxS=00)下,输出比较信号(OCxREF 和相应的 OCx/OCxN)能够直接由软件强置为有效或无效状态,而不依赖于输出比较寄存器和计数器间的比较结果。

置 TIMx\_CCMRx 寄存器中相应的 OCxM=101,即可强置输出比较信号(OCxREF/OCx)为有效状态。这样 OCxREF 被强置为高电平(OCxREF 始终为高电平有效),同时 OCx 得到 CCxP 极性相反的信号。

例如: CCxP=0(OCx 高电平有效),则 OCx 被强置为高电平。置 TIMx\_CCMRx 寄存器中的 OCxM=100,可强置 OCxREF 信号为低。

该模式下,在 TIMx\_CCRx 影子寄存器和计数器之间的比较仍然在进行,相应的标志也会被修改。因此仍然会产生相应的中断和 DMA 请求。这将会在下面的输出比较模式一节中介绍。

## 12.2.9 输出比较模式

该功能用于控制输出波形,或者指示一段给定的时间已经到时。当计数器与捕获/比较寄存器的内容相同时,输出比较功能做如下操作:

- 将输出比较模式(TIMx\_CCMRx 寄存器中的 OCxM 位)和输出极性(TIMx\_CCER 寄存器中的 CCxP 位)定义的值输出到对应的引脚上。在比较匹配时,输出引脚可以保持它的电平 (OCxM=000)、被设置成有效电平(OCxM=001)、被设置成无效电平(OCxM=010)或进行翻转(OCxM=011)。
- 设置中断状态寄存器中的标志位(TIMx SR 寄存器中的 CCxIF 位)。
- 若设置了相应的中断屏蔽(TIMx DIER 寄存器中的 CCxIE 位),则产生一个中断。
- 若设置了相应的使能位(TIMx\_DIER 寄存器中的 CCxDE 位,TIMx\_CR2 寄存器中的 CCDS 位选择



DMA 请求功能),则产生一个 DMA 请求。

TIMx\_CCMRx 中的 OCxPE 位选择 TIMx\_CCRx 寄存器是否需要使用预装载寄存器。在输出比较模式下,更新事件 UEV 对 OCxREF 和 OCx 输出没有影响。

同步的精度可以达到计数器的一个计数周期。输出比较模式(在单脉冲模式下)也能用来输出一个单脉冲。

配置输出比较模式的步骤:

- 1. 选择计数器时钟(内部、外部或预分频器)。
- 2. 将相应的数据写入 TIMx ARR 和 TIMx CCRx 寄存器中。
- 3. 如果要产生一个中断请求,设置 CCxIE 位。
- 4. 选择输出模式,例如:
  - 。 要求计数器与 CCRx 匹配时翻转 OCx 的输出引脚,设置 OCxM=011。
  - 。 设置 OCxPE=0, 以禁用预装载寄存器。
  - 。 设置 CCxP=0, 以选择极性为高电平有效。
  - 。 设置 CCxE=1,以使能输出。
- 5. 设置 TIMx CR1 寄存器的 CEN 位启动计数器。

TIMx\_CCRx 寄存器能够在任何时候通过软件进行更新以控制输出波形,条件是未使用预装载寄存器(OCxPE='0', 否则 TIMx\_CCRx 的影子寄存器只能在发生下一次更新事件时被更新)。下图给出了一个例子。



图 12-32 输出比较模式, 翻转 OC1

## 12.2.10 PWM 模式

脉冲宽度调制模式可以产生一个由 TIMx\_ARR 寄存器确定频率、由 TIMx\_CCRx 寄存器确定占空比的信号。

在 TIMx\_CCMRx 寄存器中的 OCxM 位写入'110'(PWM 模式 1)或'111'(PWM 模式 2),能够独立地设置每个 OCx 输出通道产生一路 PWM。必须通过设置 TIMx\_CCMRx 寄存器的 OCxPE 位使能相应的预装载寄存器,最后还要设置 TIMx\_CR1 寄存器的 ARPE 位,(在向上计数或中心对称模式中)使能自动重装载的预装载寄存器。

仅当发生一个更新事件的时候,预装载寄存器才能被传送到影子寄存器,因此在计数器开始计数 之前,必须通过设置 TIMx\_EGR 寄存器中的 UG 位来初始化所有的寄存器。OCx 的极性可以通过软件在



TIMx\_CCER 寄存器中的 CCxP 位设置,它可以设置为高电平有效或低电平有效。OCx 的输出使能通过(TIMx\_CCER 和 TIMx\_BDTR 寄存器中)CCxE、CCxNE、MOE、OSSI 和 OSSR 位的组合控制。详见 TIMx CCER 寄存器的描述。

在 PWM 模式(模式 1 或模式 2)下,TIMx\_CNT 和 TIMx\_CCRx 始终在进行比较,(依据计数器的计数方向)以确定是否符合 TIMx CCRx≤TIMx CNT 或者 TIMx CNT≤TIMx CCRx。

根据 TIMx\_CR1 寄存器中 CMS 位的状态,定时器能够产生边沿对齐或中央对齐的 PWM 信号。

#### 12.2.10.1 PWM 边沿对齐模式

#### • 向上计数配置

当 TIMx\_CR1 寄存器中的 DIR 位为低的时候执行向上计数。可参考"12.2.2.1 向上计数模式"。

下面是一个 PWM 模式 1 的例子。当 TIMx\_CNT<TIMx\_CCRx 时,PWM 参考信号 OCxREF 为高,否则为低。如果 TIMx\_CCRx 中的比较值大于自动重装载值(TIMx\_ARR),则 OCxREF 保持为'1'。如果该比较值为 0,则 OCxREF 保持为'0'。下图为 TIMx ARR=8 时边沿对齐的 PWM 波形实例。



图 12-33 边沿对齐的 PWM 波形 (ARR=8)

#### • 向下计数的配置

当 TIMx CR1 寄存器的 DIR 位为高时执行向下计数。可参考"12.2.2.2 向下计数模式"。

在 PWM 模式 1,当 TIMx\_CNT>TIMx\_CCRx 时参考信号 OCxREF 为低,否则为高。如果 TIMx\_CCRx 中的比较值大于 TIMx\_ARR 中的自动重装载值,则 OCxREF 保持为'1'。该模式下不能产生 0%的 PWM 波形。

#### 12.2.10.2 PWM 中央对齐模式

当 TIMx\_CR1 寄存器中的 CMS 位不为'00'时为中央对齐模式(所有其他的配置对 OCxREF/OCx 信号都有相同的作用)。根据不同的 CMS 位设置,比较标志可以在计数器向上计数时被置'1'、在计数器向下计数时被置'1'、或在计数器向上和向下计数时被置'1'。TIMx\_CR1 寄存器中的计数方向位(DIR)由硬件更新,不能用软件修改它。可参考"12.2.2.3 中央对齐模式(向上/向下计数)"。

图 12-34 示出了中央对齐的 PWM 波形的一个例子:

- TIMx ARR=8
- PWM 模式 1
- TIMx CR1 寄存器的 CMS=01,在中央对齐模式1下,当计数器向下计数时设置比较标志。





图 12-34 中央对齐的 PWM 波形(APR=8)

#### 12.2.10.3 使用中央对齐模式的提示

- 进入中央对齐模式时,使用当前的向上/向下计数配置;这意味着计数器向上还是向下计数取决于 TIMx\_CR1 寄存器中 DIR 位的当前值。此外,软件不能同时修改 DIR 和 CMS 位。
- 不推荐当运行在中央对齐模式时改写计数器,因为这会产生不可预知的结果。特别地:
  - 如果写入计数器的值大于自动重加载的值(TIMx\_CNT>TIMx\_ARR),则方向不会被更新。 例如,如果计数器正在向上计数,它就会继续向上计数。
  - 。 如果将 0 或者 TIMx\_ARR 的值写入计数器,方向被更新,但不产生更新事件 UEV。
- 使用中央对齐模式最保险的方法,就是在启动计数器之前产生一个软件更新(设置 TIMx\_EGR 寄存器中的 UG 位),并且不要在计数进行过程中修改计数器的值。

### 12.2.11 互补输出和死区插入

高级控制定时器(TIM1)能够输出两路互补信号,并且能够管理输出的瞬时关断和接通。

这段时间通常被称为死区,用户应该根据连接的输出器件和它们的特性(电平转换的延时、电源开关的延时等)来调整死区时间。

配置 TIMx\_CCER 寄存器中的 CCxP 和 CCxNP 位,可以为每一个输出独立地选择极性(主输出 OCx 或互补输出 OCxN)。

互补信号 OCx 和 OCxN 通过下列控制位的组合进行控制: TIMx\_CCER 寄存器的 CCxE 和 CCxNE 位,TIMx\_BDTR 和 TIMx\_CR2 寄存器中的 MOE、OISx、OISxN、OSSI 和 OSSR 位,详见表 12-3 带刹车功能的互补输出通道 OCx 和 OCxN 的控制位。特别的是,在转换到 IDLE 状态时(MOE 下降到 0)死区被激活。

同时设置 CCxE 和 CCxNE 位将插入死区,如果存在刹车电路,则还要设置 MOE 位。每一个通道都有



一个 10 位的死区发生器。参考信号 OCxREF 可以产生 2 路输出 OCx 和 OCxN。

如果 OCx 和 OCxN 为高有效:

- OCx 输出信号与参考信号相同,只是它的上升沿相对于参考信号的上升沿有一个延迟。
- OCxN 输出信号与参考信号相反,只是它的上升沿相对于参考信号的下降沿有一个延迟。如果 延迟大于当前有效的输出宽度(OCx 或者 OCxN),则不会产生相应的脉冲。

下列几张图显示了死区发生器的输出信号和当前参考信号 OCxREF 之间的关系。(假设 CCxP=0、CCxNP=0、MOE=1、CCxE=1 并且 CCxNE=1)



图 12-35 带死区插入的互补输出



图 12-36 死区波形延迟大于负脉冲



图 12-37 死区波形延迟大于正脉冲

每一个通道的死区延时都是相同的,是由 TIMx\_BDTR 寄存器中的 DTG 位编程配置。详见 TIM1 刹车和死区寄存器(TIMx\_BDTR)中的延时计算。

#### 12.2.11.1 重定向 OCxREF 到 OCx 或 OCxN

在输出模式下(强置、输出比较或 PWM ),通过配置 TIMx\_CCER 寄存器的 CCxE 和 CCxNE 位,OCxREF 可以被重定向到 OCx 或者 OCxN 的输出。

这个功能可以在互补输出处于无效电平时,在某个输出上送出一个特殊的波形(例如 PWM 或者静态有效电平)。另一个作用是,让两个输出同时处于无效电平,或处于有效电平和带死区的互补输出。

说明: 当只使能 OCxN(CCxE=0, CCxNE=1)时,它不会反相,当 OCxREF 有效时立即变高。例如,如果 CCxNP=0,则 OCxN=OCxREF。另一方面,当 OCx 和 OCxN 都被使能时(CCxE=CCxNE=1),当 OCxREF 为高时 OCx 有效;而 OCxN 相反,当 OCxREF 低时 OCxN 变为有效。



## 12.2.12 使用刹车功能

当使用刹车功能时,依据相应的控制位(TIMx\_BDTR 寄存器中的 MOE、OSSI 和 OSSR 位,TIMx\_CR2 寄存器中的 OISx 和 OISxN 位),输出使能信号和无效电平都会被修改。但无论何时,OCx 和 OCxN 输出不能在同一时间同时处于有效电平上。详见表 12-3。

刹车源既可以是刹车输入引脚又可以是一个时钟故障事件。时钟故障事件由复位时钟控制器中的时钟安全系统产生,详见"7.2.7 时钟安全系统(CSS)"。系统复位后,刹车电路被禁止,MOE 位为低。设置 TIMx\_BDTR 寄存器中的 BKE 位可以使能刹车功能,刹车输入信号的极性可以通过配置同一个寄存器中的 BKP 位选择。BKE 和 BKP 可以同时被修改。当写入 BKE 和 BKP 位时,在真正写入之前会有 1 个 APB 时钟周期的延迟,因此需要等待一个 APB 时钟周期之后,才能正确地读回写入的位。

因为 MOE 下降沿可以是异步的,在实际信号(作用在输出端)和同步控制位(在 TIMx\_BDTR 寄存器中)之间设置了一个再同步电路。这个再同步电路会在异步信号和同步信号之间产生延迟。特别的,如果当它为低时写 MOE=1,则读出它之前必须先插入一个延时(空指令)才能读到正确的值。这是因为写入的是异步信号而读的是同步信号。

当发生刹车时(在刹车输入端出现选定的电平),有下述动作:

- MOE 位被异步地清除,将输出置于无效状态、空闲状态或者复位状态(由 OSSI 位选择)。这个特性在 MCU 的振荡器关闭时依然有效。
- 一旦 MOE=0,每一个输出通道输出由 TIMx\_CR2 寄存器中的 OISx 位设定的电平。如果 OSSI=0,则定时器释放使能输出,否则使能输出始终为高。
- 当使用互补输出时:
  - 输出首先被置于复位状态即无效的状态(取决于极性)。这是异步操作,即使定时器没有时钟时,此功能也有效。
  - 。 如果定时器的时钟依然存在,死区生成器将会重新生效,在死区之后根据 OISx 和 OISxN 位指示的电平驱动输出端口。即使在这种情况下,OCx 和 OCxN 也不能被同时驱动到有效的电平。注,因为重新同步 MOE,死区时间比通常情况下长一些(大约 2 个 ck\_tim 的时钟周期)。
  - 。 如果 OSSI=0, 定时器释放使能输出, 否则保持使能输出, 或一旦 CCxE 与 CCxNE 之一变高时, 使能输出变为高。
- 设置了刹车状态标志(TIMx\_SR 寄存器中的 BIF 位)。当 TIMx\_DIER 寄存器中的 BIE 位置为'1'时,则产生一个中断。
- 如果设置了 TIMx\_BDTR 寄存器中的 AOE 位,在下一个更新事件 UEV 时 MOE 位被自动置位;例如,这可以用来进行整形。否则,MOE 始终保持低直到被再次置'1';这种情况下,该特性可以被用在安全方面,你可以把刹车输入连到电源驱动的报警输出、热敏传感器或者其他安全器件上。

#### 说明:

刹车输入为电平有效。所以,当刹车输入有效时,不能同时(自动地或者通过软件)设置 MOE。 同时,状态标志 BIF 不能被清除。

刹车由 BRK 输入产生,它的有效极性是可编程的,且由 TIMx\_BDTR 寄存器中的 BKE 位开启。除了刹车输入和输出管理,刹车电路中还实现了写保护以保证应用程序的安全。它允许用户冻结几个配置参数(死区长度、OCx/OCxN 极性和被禁止的状态、OCxM 配置、刹车使能和极性)。

用户可以通过 TIMx\_BDTR 寄存器中的 LOCK 位,从三级保护中选择一种,可参考 TIM1 刹车和死区 寄存器(TIMx BDTR)。在 MCU 复位后 LOCK 位只能被修改一次。下图显示响应刹车的输出实例。





图 12-38 响应刹车的输出

# 12.2.13 在外部事件时清除 OCxREF 信号

对于一个给定的通道,设置 TIMx\_CCMRx 寄存器中对应的 OCxCE 位为'1', 能够用 ETRF 输入端的高电平把 OCxREF 信号拉低,OCxREF 信号将保持为低直到发生下一次的更新事件 UEV。

该功能只能用于输出比较和 PWM 模式,而不能用于强置模式。例如,OCxREF 信号可以连到一个比较器的输出,用于控制电流。这时,ETR 必须配置如下:

- 外部触发预分频器必须处于关闭: TIMx SMCR 寄存器中的 ETPS[1:0]=00。
- 必须禁止外部时钟模式 2: TIMx SMCR 寄存器中的 ECE=0。
- 外部触发极性(ETP)和外部触发滤波器(ETF)可以根据需要配置。

下图显示了当 ETRF 输入变为高时,对应不同 OCxCE 的值,OCxREF 信号的动作。在这个例子中,定时器 TIMx 被置于 PWM 模式。





图 12-39 清除 TIMx 的 OCxREF

## 12.2.14 产生六步 PWM 输出

当在一个通道上需要互补输出时,预装载位有 OCxM、CCxE 和 CCxNE。在发生 COM 换相事件时,这些预装载位被传送到影子寄存器位。这样你就可以预先设置好下一步配置,并在同一个时刻同时更改所有通道的配置。COM 可以通过设置 TIMx\_EGR 寄存器的 COMG 位由软件产生,或在 TRGI 上升沿由硬件产生。

当发生 COM 事件时会设置一个标志位(TIMx\_SR 寄存器中的 COMIF 位),这时如果已设置了TIMx\_DIER 寄存器的 COMIE 位,则产生一个中断;如果已设置了 TIMx\_DIER 寄存器的 COMDE 位,则产生一个 DMA 请求。

下图显示当发生 COM 事件时,三种不同配置下 OCx 和 OCxN 输出。



图 12-40 产生六步 PWM, 使用 COM 的例子(OSSR=1)



## 12.2.15 单脉冲模式

单脉冲模式(OPM)是前述众多模式的一个特例。这种模式允许计数器响应一个激励,并在一个程序可控的延时之后产生一个脉宽可程序控制的脉冲。

可以通过从模式控制器启动计数器,在输出比较模式或者 PWM 模式下产生波形。设置 TIMx\_CR1 寄存器中的 OPM 位将选择单脉冲模式,这样可以让计数器自动地在产生下一个更新事件 UEV 时停止。

仅当比较值与计数器的初始值不同时,才能产生一个脉冲。启动之前(当定时器正在等待触发), 必须按如下配置:

- 向上计数方式: 计数器 CNT<CCRx≤ARR(特别地,0<CCRx)</li>
- 向下计数方式: 计数器 CNT>CCRx



图 12-41 单脉冲模式的例子

例如,你需要在从 TI2 输入脚上检测到一个上升沿开始,延迟  $t_{DELAY}$  之后,在 OC1 上产生一个长度为  $t_{PULSE}$  的正脉冲。

假定 TI2FP2 作为触发 1:

- 置 TIMx\_CCMR1 寄存器中的 CC2S=01,把 TI2FP2 映射到 TI2。
- 置 TIMx CCER 寄存器中的 CC2P=0, 使 TI2FP2 能够检测上升沿。
- 置 TIMx SMCR 寄存器中的 TS=110, TI2FP2 作为从模式控制器的触发(TRGI)。
- 置 TIMx\_SMCR 寄存器中的 SMS=110 (触发模式), TI2FP2 被用来启动计数器。

OPM 的波形由写入比较寄存器的数值决定(要考虑时钟频率和计数器预分频器)。

- t<sub>DELAY</sub> 由 TIMx\_CCR1 寄存器中的值定义。
- t<sub>PULSE</sub> 由自动装载值和比较值之间的差值定义(TIMx\_ARR-TIMx\_CCR1)。
- 假定当发生比较匹配时要产生从 0 到 1 的波形,当计数器达到预装载值时要产生一个从 1 到 0 的波形;首先要置 TIMx\_CCMR1 寄存器的 OC1M=111,进入 PWM 模式 2;根据需要有选择地使能预装载寄存器:置 TIMx\_CCMR1 中的 OC1PE=1 和 TIMx\_CR1 寄存器中的 ARPE;然后在TIMx\_CCR1 寄存器中填写比较值,在 TIMx\_ARR 寄存器中填写自动装载值,设置 UG 位来产生一个更新事件,然后等待在 TI2 上的一个外部触发事件。本例中,CC1P=0。

在这个例子中,TIMx\_CR1 寄存器中的 DIR 和 CMS 位应该置低。

因为只需要一个脉冲,所以必须设置 TIMx\_CR1 寄存器中的 OPM=1,在下一个更新事件(当计数器 从自动装载值翻转到 0) 时停止计数。



#### 12.2.15.1 特殊情况: OCx 快速使能:

在单脉冲模式下,在 Tix 输入脚的边沿检测逻辑设置 CEN 位以启动计数器。然后计数器和比较值间的比较操作产生了输出的转换。但是这些操作需要一定的时钟周期,因此它限制了可得到的最小延时toelay。如果要以最小延时输出波形,可以设置 TIMx\_CCMRx 寄存器中的 OCxFE 位;此时 OCxREF (和OCx)直接响应激励而不再依赖比较的结果,输出的波形与比较匹配时的波形一样。OCxFE 只在通道配置为 PWM1 和 PWM2 模式时起作用。

## 12.2.16 编码器接口模式

选择编码器接口模式的方法是:如果计数器只在 TI2 的边沿计数,则置 TIMx\_SMCR 寄存器中的 SMS=001;如果只在 TI1 边沿计数,则置 SMS=010;如果计数器同时在 TI1 和 TI2 边沿计数,则置 SMS=011。

通过设置 TIMx\_CCER 寄存器中的 CC1P 和 CC2P 位,可以选择 TI1 和 TI2 极性;如果需要,还可以对输入滤波器编程。

两个输入 TI1 和 TI2 被用来作为增量编码器的接口。参看表 12-1,假定计数器已经启动(TIMx\_CR1 寄存器中的 CEN=1),则计数器由每次在 TI1FP1 或 TI2FP2 上的有效跳变驱动。TI1FP1 和 TI2FP2 是 TI1 和 TI2 在通过输入滤波器和极性控制后的信号;如果没有滤波和变相,则 TI1FP1=TI1,TI2FP2=TI2。根据两个输入信号的跳变顺序,产生了计数脉冲和方向信号。依据两个输入信号的跳变顺序,计数器向上或向下计数,同时硬件对 TIMx\_CR1 寄存器的 DIR 位进行相应的设置。不管计数器是依靠 TI1 计数、依靠 TI2 计数或者同时依靠 TI1 和 TI2 计数,在任一输入端(TI1 或者 TI2)的跳变都会重新计算 DIR 位。

编码器接口模式基本上相当于使用了一个带有方向选择的外部时钟。这意味着计数器只在 0 到 TIMx\_ARR 寄存器的自动装载值之间连续计数(根据方向,或是 0 到 ARR 计数,或是 ARR 到 0 计数)。所以在开始计数之前必须配置 TIMx\_ARR; 同样,捕获器、比较器、预分频器、重复计数器、触发输出特性等仍工作如常。编码器模式和外部时钟模式 2 不兼容,因此不能同时操作。

在这个模式下,计数器依照增量编码器的速度和方向被自动的修改,因此计数器的内容始终指示着编码器的位置。计数方向与相连的传感器旋转的方向对应。下表列出了所有可能的组合,假设 TI1 和 TI2 不同时变换。

| 有效边沿            | 相对信号的电平                           | TI1FP1 信号 |      | TI2FP2 信号 |      |  |  |
|-----------------|-----------------------------------|-----------|------|-----------|------|--|--|
|                 | (TI1FP1 对应 TI2, TI2FP2<br>对应 TI1) | 上升        | 下降   | 上升        | 下降   |  |  |
| 仅在 TI1 计数       | 高                                 | 向下计数      | 向上计数 | 不计数       | 不计数  |  |  |
|                 | 低                                 | 向上计数      | 向下计数 | 不计数       | 不计数  |  |  |
| 仅在 TI2 计数       | 高                                 | 不计数       | 不计数  | 向上计数      | 向下计数 |  |  |
|                 | 低                                 | 不计数       | 不计数  | 向下计数      | 向上计数 |  |  |
| 在 TI1 和 TI2 上计数 | 高                                 | 向下计数      | 向上计数 | 向上计数      | 向下计数 |  |  |
|                 | 低                                 | 向上计数      | 向下计数 | 向下计数      | 向上计数 |  |  |

表 12-1 计数方向与编码器信号的关系

一个外部的增量编码器可以直接与 MCU 连接而不需要外部接口逻辑。但是,一般会使用比较器将编码器的差动输出转换到数字信号,这大大增加了抗噪声干扰能力。编码器输出的第三个信号表示机械零点,可以把它连接到一个外部中断输入并触发一个计数器复位。

下图是一个计数器操作的实例,显示了计数信号的产生和方向控制。它还显示了当选择了双边沿时,



输入抖动是如何被抑制的;抖动可能会在传感器的位置靠近一个转换点时产生。在这个例子中,我们假定配置如下:

- CC1S='01'(TIMx CCMR1 寄存器,IC1FP1 映射到 TI1)
- CC2S='01'(TIMx CCMR2 寄存器, IC2FP2 映射到 TI2)
- CC1P='0' (TIMx\_CCER 寄存器, IC1FP1 不反相, IC1FP1=TI1)
- CC2P='0'(TIMx CCER 寄存器, IC2FP2 不反相, IC2FP2=TI2)
- SMS='011'(TIMx SMCR 寄存器,所有的输入均在上升沿和下降沿有效)
- CEN='1'(TIMx\_CR1 寄存器, 计数器使能)



图 12-42 编码器模式下的计数器操作实例

下图为当 IC1FP1 极性反相时计数器的操作实例(CC1P='1',其他配置与上例相同)。



图 12-43 IC1FP1 反相的编码器接口模式实例

当定时器配置成编码器接口模式时,提供传感器当前位置的信息。使用第二个配置在捕获模式的定时器,可以测量两个编码器事件的间隔,获得动态的信息(速度,加速度,减速度)。指示机械零点的编码器输出可被用做此目的。根据两个事件间的间隔,可以按照固定的时间读出计数器。如果可能的话,你可以把计数器的值锁存到第三个输入捕获寄存器(捕获信号必须是周期的并且可以由另一个定时器产生);也可以通过一个由实时时钟产生的 DMA 请求来读取它的值。

# 12.2.17 定时器输入异或功能

TIMx\_CR2 寄存器中的 TI1S 位,允许通道 1 的输入滤波器连接到一个异或门的输出端,异或门的 3 个输入端为 TIMx\_CH1、TIMx\_CH2 和 TIMx\_CH3。

异或输出能够被用于所有定时器的输入功能,如触发或输入捕获。与霍尔传感器的接口给出了此特性用于连接霍尔传感器的例子。



## 12.2.18 与霍尔传感器的接口

使用高级控制定时器(TIM1)产生 PWM 信号驱动马达时,可以用另一个通用 TIMx(TIM2、TIM3 和 TIM4)定时器作为"接口定时器"来连接霍尔传感器,见下图,3 个定时器输入脚(CC1、CC2、CC3)通过一个异或门连接到 TI1 输入通道(通过设置 TIMx\_CR2 寄存器中的 TI1S 位来选择),"接口定时器"捕获这个信号。

从模式控制器被配置于复位模式,从输入是 TI1F\_ED。每当 3 个输入之一变化时,计数器重新从'0' 开始计数。这样产生一个由霍尔输入端的任何变化而触发的时间基准。

"接口定时器"上的捕获/比较通道 1 配置为捕获模式,捕获信号为 TRC(见图 12-27)。捕获值反映了两个输入变化间的时间延迟,给出了马达速度的信息。

"接口定时器"可以在输出模式产生一个脉冲,这个脉冲可以(通过触发一个 COM 事件)用于改变高级定时器 TIM1 各个通道的属性,而高级控制定时器产生 PWM 信号驱动马达。因此"接口定时器"通道必须编程为在一个指定的延时(输出比较或 PWM 模式)之后产生一个正脉冲,这个脉冲通过 TRGO 输出被送到高级控制定时器 TIM1。

举例:霍尔输入连接到 TIMx 定时器,要求每次任一霍尔输入上发生变化之后的一个指定的时刻,改变高级控制定时器 TIMx 的 PWM 配置。

- 置 TIMx CR2 寄存器的 TI1S 位为'1', 配置三个定时器输入逻辑或到 TI1 输入,
- 时基编程:置 TIMx\_ARR 为其最大值(计数器必须通过 TI1 的变化清零)。设置预分频器得到一个最大的计数器周期,它长于传感器上的两次变化的时间间隔。
- 设置通道 1 为捕获模式(选中 TRC):置 TIMx\_CCMR1 寄存器中 CC1S=01,如果需要,还可以设置数字滤波器。
- 设置通道 2 为 PWM2 模式, 并具有要求的延时: 置 TIMx\_CCMR1 寄存器中的 OC2M=111 和 CC2S=00。
- 选择 OC2REF 作为 TRGO 上的触发输出: 置 TIMx CR2 寄存器中的 MMS=101。

在高级控制寄存器 TIM1 中,正确的 ITR 输入必须是触发器输入,定时器被编程为产生 PWM 信号,捕获/比较控制信号为预装载的(TIMx\_CR2 寄存器中 CCPC=1),同时触发输入控制 COM 事件(TIMx\_CR2 寄存器中 CCUS=1)。在一次 COM 事件后,写入下一步的 PWM 控制位(CCxE、OCxM),这可以在处理 OC2REF 上升沿的中断子程序里实现。

下图显示了这个实例。





图 12-44 霍尔传感器接口的实例

## 12.2.19 TIMx 定时器和外部触发的同步

TIMx 定时器能够在多种模式下和一个外部的触发同步: 复位模式、门控模式和触发模式。

#### 12.2.19.1 从模式: 复位模式

在发生一个触发输入事件时,计数器和它的预分频器能够重新被初始化;同时,如果 TIMx\_CR1 寄存器的 URS 位为低,还产生一个更新事件 UEV;然后所有的预装载寄存器(TIMx\_ARR,TIMx\_CCRx)都被更新了。

在以下的例子中, TI1 输入端的上升沿导致向上计数器被清零:

- 配置通道 1 以检测 TI1 的上升沿。配置输入滤波器的带宽(在本例中,不需要任何滤波器,因此保持 IC1F=0000)。触发操作中不使用捕获预分频器,所以不需要配置。CC1S 位只选择输入捕获源,即 TIMx\_CCMR1 寄存器中 CC1S=01。置 TIMx\_CCER 寄存器中 CC1P=0 以确定极性(只检测上升沿)。
- 置 TIMx\_SMCR 寄存器中 SMS=100,配置定时器为复位模式;置 TIMx\_SMCR 寄存器中TS=101,选择 TI1 作为输入源。
- 置 TIMx CR1 寄存器中 CEN=1, 启动计数器。

计数器开始依据内部时钟计数,然后正常运转直到 TI1 出现一个上升沿;此时,计数器被清零然后从 0 重新开始计数。同时,触发标志(TIMx\_SR 寄存器中的 TIF 位)被设置,根据 TIMx\_DIER 寄存器中 TIE(中断使能)位和 TDE(DMA 使能)位的设置,产生一个中断请求或一个 DMA 请求。

下图显示当自动重装载寄存器 TIMx\_ARR=0x36 时的动作。在 TI1 上升沿和计数器的实际复位之间的延时取决于 TI1 输入端的重同步电路。





图 12-45 复位模式下的控制电路

#### 12.2.19.2 从模式: 门控模式

按照选中的输入端电平使能计数器。

在如下的例子中, 计数器只在 TI1 为低时向上计数:

- 配置通道 1 以检测 TI1 上的低电平。配置输入滤波器带宽(本例中,不需要滤波,所以保持 IC1F=0000)。触发操作中不使用捕获预分频器,所以不需要配置。CC1S 位用于选择输入捕获 源,置 TIMx\_CCMR1 寄存器中 CC1S=01。置 TIMx\_CCER 寄存器中 CC1P=1 以确定极性(只检测低电平)。
- 置 TIMx\_SMCR 寄存器中 SMS=101,配置定时器为门控模式;置 TIMx\_SMCR 寄存器中TS=101,选择 TI1 作为输入源。
- 置 TIMx\_CR1 寄存器中 CEN=1, 启动计数器。在门控模式下,如果 CEN=0,则计数器不能启动,不论触发输入电平如何。

只要 TI1 为低,计数器开始依据内部时钟计数,一旦 TI1 变高则停止计数。当计数器开始或停止时都设置 TIMx\_SR 中的 TIF 标志。

TI1 上升沿和计数器实际停止之间的延时取决于 TI1 输入端的重同步电路。



图 12-46 门控模式下的控制电路

#### 12.2.19.3 从模式: 触发模式

输入端上选中的事件使能计数器。

在下面的例子中, 计数器在 TI2 输入的上升沿开始向上计数:

- 配置通道 2 检测 TI2 的上升沿。配置输入滤波器带宽(本例中,不需要任何滤波器,保持 IC2F=0000)。触发操作中不使用捕获预分频器,不需要配置。CC2S 位只用于选择输入捕获源,置 TIMx\_CCMR1 寄存器中 CC2S=01。置 TIMx\_CCER 寄存器中 CC2P=1 以确定极性(只检测低电平)。
- 置 TIMx\_SMCR 寄存器中 SMS=110, 配置定时器为触发模式;置 TIMx\_SMCR 寄存器中TS=110,选择 TI2 作为输入源。

当 TI2 出现一个上升沿时,计数器开始在内部时钟驱动下计数,同时设置 TIF 标志。



TI2 上升沿和计数器启动计数之间的延时,取决于 TI2 输入端的重同步电路。



图 12-47 触发器模式下的控制电路

#### 12.2.19.4 从模式:外部时钟模式 2+触发模式

外部时钟模式 2 可以与另一种从模式(外部时钟模式 1 和编码器模式除外)一起使用。这时,ETR 信号被用作外部时钟的输入,在复位模式、门控模式或触发模式可以选择另一个输入作为触发输入。不建议使用 TIMx SMCR 寄存器的 TS 位选择 ETR 作为 TRGI。

在下面的例子中,一旦在 TI1 上出现一个上升沿,计数器即在 ETR 的每一个上升沿向上计数一次:

- 1. 通过 TIMx\_SMCR 寄存器配置外部触发输入电路:
  - 。 ETF=0000: 没有滤波
  - 。 ETPS=00: 不用预分频器
  - 。 ETP=0: 检测 ETR 的上升沿,置 ECE=1 使能外部时钟模式 2。
- 2. 按如下配置通道 1, 检测 TI 的上升沿:
  - 。 IC1F=0000: 没有滤波。
  - 。 触发操作中不使用捕获预分频器,不需要配置。
  - 。 置 TIMx CCMR1 寄存器中 CC1S=01,选择输入捕获源。
  - 。 置 TIMx\_CCER 寄存器中 CC1P=0 以确定极性(只检测上升沿)。
- 3. 置 TIMx\_SMCR 寄存器中 SMS=110,配置定时器为触发模式。置 TIMx\_SMCR 寄存器中 TS=101, 选择 TI1 作为输入源。

当 TI1 上出现一个上升沿时, TIF 标志被设置, 计数器开始在 ETR 的上升沿计数。

ETR 信号的上升沿和计数器实际复位之间的延时,取决于 ETRP 输入端的重同步电路。



图 12-48 外部时钟模式 2+触发模式下的控制电路

# 12.2.20 定时器同步

所有 TIM 定时器在内部相连,用于定时器同步或链接。



# 12.2.21 调试模式

当 MCU 进入调试模式时(Cortex®-M3 内核停止),根据 DBG 模块中 DBG\_TIMx\_STOP 的设置,TIMx 计数器可以或者继续正常操作,或者停止。详细信息,请参考章节:"24.14.2 支持定时器、看门狗、bxCAN 和 I2C 的调试"。

# 12.3 TIM1 寄存器

基地址: 0x4001 2C00

空间大小: 0x400

TIM1 寄存器必须半字(16 位)或字(32 位)的方式进行访问。

# 12.3.1 TIM1 控制寄存器 1 (TIMx\_CR1)

偏移地址: 0x00 复位值: 0x0000

| 15  | 14 | 13 | 12 | 11 | 10  | 9     | 8    | 7   | 6     | 5   | 4   | 3   | 2    | 1   | 0  |
|-----|----|----|----|----|-----|-------|------|-----|-------|-----|-----|-----|------|-----|----|
| Res |    |    |    |    | CKD | [1:0] | ARPE | CMS | [1:0] | DIR | OPM | URS | UDIS | CEN |    |
|     |    |    |    |    |     | r     | w    | rw  | r     | w   | rw  | rw  | rw   | rw  | rw |

|            |                                                                                                                                                                                                              | rw                                                        | rw                            | rw                                | rw                    | rw     | rw      | rw      | rw    |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------|-------------------------------|-----------------------------------|-----------------------|--------|---------|---------|-------|
| 位 15:10    | Res: 保留<br>必须保持复位值。                                                                                                                                                                                          |                                                           |                               |                                   |                       |        |         |         |       |
| 位 9:8      | CKD[1:0]: 时钟分频图 该位域定义了定时器 的采样时钟(t <sub>DTS</sub> )之 • 00: t <sub>DTS</sub> =t <sub>CK_INT</sub> • 01: t <sub>DTS</sub> =2 x t <sub>CK_INT</sub> • 10: t <sub>DTS</sub> =4 x t <sub>CK_INT</sub> • 11: 保留,不使用 | 时钟频率(                                                     | CK_INT)                       |                                   | 器和数学                  | 字滤波器   | ÷ (ETR, | Tix)所   | 使用    |
| 位 <b>7</b> | ARPE: 自动重装载预 • 0: TIMx_ARR 寄存 • 1: TIMx_ARR 寄存                                                                                                                                                               | 器没有缓冲                                                     |                               | eload preload                     | enable                | 2)     |         |         |       |
| 位 6:5      | CMS[1:0]:选择中央对 • 00:边沿对齐模式 计数器依据方向位 • 01:中央对齐模式 计数器交替地向上的输出比较中断标 • 10:中央对齐模式 计数器交替地向上的输出比较中断标 • 11:中央对齐模式                                                                                                    | (DIR)向上<br>1<br>和向下计数。<br>志位,只在i<br>2<br>和向下计数。<br>志位,只在i | 或向下; 或向下; 。配置为 计数器向 。配置为 。配置为 | 十数。<br>如输出的通道<br>下计数时被证<br>切输出的通道 | (TIMx<br>殳置。<br>(TIMx | _CCMRx |         |         |       |
|            | 计数器交替地向上的输出比较中断标                                                                                                                                                                                             | 和向下计数。                                                    |                               |                                   |                       | _      | 寄存器     | 导中 CCxs | S=00) |



| 航顺芯片 |                                                                                                                                                                                               |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | 注意: 在计数器开启时(CEN=1),不允许从边沿对齐模式转换到中央对齐模式。                                                                                                                                                       |
| 位 4  | DIR: 计数方向(Direction)  • 0: 计数器向上计数  • 1: 计数器向下计数 <i>说明: 当计数器配置为中央对齐模式或编码器模式时,该位为只读。</i>                                                                                                       |
| 位 3  | OPM: 单脉冲模式 (One pulse mode)  • 0: 在发生更新事件时,计数器不停止。  • 1: 在发生下一次更新事件 (清除 CEN 位)时,计数器停止。                                                                                                        |
| 位 2  | URS: 更新请求源(Update request source) 软件通过该位选择 UEV 事件的源。  • 0: 如果使能了更新中断或 DMA 请求,则下述任一事件产生更新中断或 DMA 请求:  。 计数器溢出/下溢  。 设置 UG 位  。 从模式控制器产生的更新  • 1: 如果使能了更新中断或 DMA 请求,则只有计数器溢出/下溢才产生更新中断或 DMA 请求。 |
| 位 1  | UDIS:禁止更新(Update disable)<br>软件通过该位允许/禁止 UEV 事件的产生。                                                                                                                                           |
| 位 0  | CEN: 使能计数器 (Counter enable)  • 0: 禁止计数器  • 1: 使能计数器 <i>说明: 在软件设置了 CEN 位后, 外部时钟、门控模式和编码器模式才能工作。触发模式</i>                                                                                        |

# 12.3.2 TIM1 控制寄存器 2(TIMx\_CR2)

可以自动地通过硬件设置 CEN 位。

偏移地址: 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 | MI | MS[2 | :0] | CCDS | CCUS | Res | CCPC |
|     | rw   | rw    | rw   | rw    | rw   | rw    | rw   | rw   |    | rw   |     | rw   | rw   |     | rw   |



| 位 15  | Res: 保留<br>必须保持复位值。                                                                                                                                                                            |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 14  | OIS4:输出空闲状态 4(OC4 输出)(Output Idle state 4)(OC4 output)<br>参见 OIS1 位。                                                                                                                           |
| 位 13  | OIS3N:输出空闲状态 3(OC3N 输出)(Output Idle state 3)(OC3N output)<br>参见 OIS1N 位。                                                                                                                       |
| 位 12  | OIS3:输出空闲状态 3(OC3 输出)(Output Idle state 3)(OC3 output)<br>参见 OIS1 位。                                                                                                                           |
| 位 11  | OIS2N:输出空闲状态 2(OC2N 输出)(Output Idle state 2)(OC2N output)参见 OIS1N 位。                                                                                                                           |
| 位 10  | OIS2:输出空闲状态 2(OC2输出)(Output Idle state 2)(OC2 output)参见 OIS1 位。                                                                                                                                |
| 位 9   | OIS1N:输出空闲状态 1(OC1N 输出)(Output Idle state 1)(OC1 output)  • 0: 当 MOE=0 时,死区后 OC1N=0。  • 1: 当 MOE=0 时,死区后 OC1N=1。 <i>说明:已经设置了 LOCK(TIMx_BKR 寄存器)级别 1、2 或 3 后,该位不能被修改。</i>                       |
| 位 8   | OIS1: 输出空闲状态 1(OC1 输出)(Output Idle state 1)(OC1 output)  • 0: 当 MOE=0 时,如果实现了 OC1N,则死区后 OC1=0。  • 1: 当 MOE=0 时,如果实现了 OC1N,则死区后 OC1=1。 <i>说明: 已经设置了 LOCK(TIMx_BKR 寄存器)级别 1、2 或 3 后,该位不能被修改。</i> |
| 位 7   | TI1S: TI1 选择(TI1 selection)  • 0: TIMx_CH1 引脚连到 TI1 输入。  • 1: TIMx_CH1、TIMx_CH2 和 TIMx_CH3 引脚经异或后连到 TI1 输入。                                                                                    |
| 位 6:4 | MMS[2:0]: 主模式选择(Master mode selection) 这 3 位用于选择在主模式下送到从定时器的同步信息(TRGO)。可能的组合如下:                                                                                                                |



• 011: 比较脉冲

在发生一次捕获或一次比较成功时,当要设置 CC1IF 标志时(即使它已经为高),触发输出送出一个正脉冲(TRGO)。

• 100: 比较

OC1REF 信号被用于作为触发输出(TRGO)。

• 101: 比较

OC2REF 信号被用于作为触发输出(TRGO)。

110: 比较

OC3REF 信号被用于作为触发输出(TRGO)。

• 111: 比较

OC4REF 信号被用于作为触发输出(TRGO)。

位 3 CCDS: 捕获/比较的 DMA 选择(Capture/Compare DMA selection)

- 0: 当发生 CCx 事件时,送出 CCx 的 DMA 请求。
- 1: 当发生更新事件时,送出 CCx 的 DMA 请求。
- 位 2 CCUS: 捕获/比较控制更新选择(Capture/Compare control update selection)
  - 0: 如果捕获/比较控制位是预装载的(CCPC=1),只能通过设置 COM 位更新它们。
  - 1: 如果捕获/比较控制位是预装载的(CCPC=1),可以通过设置 COM 位或 TRGI 上的一个上升沿更新它们。

说明: 该位只对具有互补输出的通道起作用。

位 1 Res: 保留

必须保持复位值。

位 0 CCPC: 捕获/比较预装载控制位(Capture/Compare preloaded control)

- 0: CCxE, CCxNE 和 OCxM 位不是预装载的。
- 1: CCxE, CCxNE 和 OCxM 位是预装载的;设置该位后,它们只在设置了 COM 位后被更新。

说明:该位只对具有互补输出的通道起作用。

# 12.3.3 TIM1 从模式控制寄存器(TIMx\_SMCR)

偏移地址: 0x08 复位值: 0x0000

| 15  | 14  | 13   | 12    | 11 | 10       | 9 | 8     | 7 | 6       | 5 | 4  | 3   | 2  | 1      | 0  |  |
|-----|-----|------|-------|----|----------|---|-------|---|---------|---|----|-----|----|--------|----|--|
| ETP | ECE | ETPS | [1:0] |    | ETF[3:0] |   |       |   | TS[2:0] |   |    | Res | S  | MS[2:0 | )] |  |
| rw  | rw  | r    | w     | rw |          |   | rw rw |   | rw      |   | rw |     | rw |        | rw |  |

位 15 ETP: 外部触发极性(External trigger polarity)

该位选择是用 ETR 还是 ETR 的反相作为触发操作。

- 0: ETR 不反相, 高电平或上升沿有效
- 1: ETR 被反相, 低电平或下降沿有效

位 14 ECE:外部时钟使能位(External clock enable)



该位启用外部时钟模式 2。

- 0: 禁止外部时钟模式 2。
- 1: 使能外部时钟模式 2。计数器由 ETRF 信号上的任意有效边沿驱动。

#### 说明:

- 设置 ECE 位与选择外部时钟模式 1 并将 TRGI 连到 ETRF(SMS=111 和 TS=111)具有相同功效。
- 下述从模式可以与外部时钟模式 2 同时使用:复位模式,门控模式和触发模式;但是,这时 TRGI 不能连到 ETRF(TS 位不能是'111')。
- 外部时钟模式 1 和外部时钟模式 2 同时被使能时, 外部时钟的输入是 ETRF。

#### 位 13:12 | ETPS[1:0]: 外部触发预分频 (External trigger prescaler)

外部触发信号 ETRP 的频率必须满足最多为 TIMxCLK 频率的 1/4。当输入较快的外部时钟时,可以使用预分频降低 ETRP 的频率。

- 00: 关闭预分频
- 01: ETRP 频率除以 2
- 10: ETRP 频率除以 4
- 11: ETRP 频率除以 8

#### 位 11:8 ETF[3:0]: 外部触发滤波(External trigger filter)

该位域定义了对 ETRP 信号采样的频率和对 ETRP 数字滤波的带宽。实际上,数字滤波器是一个事件计数器,它记录到 N 个事件后会产生一个输出的跳变。

- 0000: 无滤波器,以 f<sub>DTS</sub> 采样
- 0001: 采样频率 f<sub>SAMPLING</sub>=f<sub>CK INT</sub>, N=2
- 0010: 采样频率 f<sub>SAMPLING</sub>=f<sub>CK\_INT</sub>, N=4
- 0011: 采样频率 f<sub>SAMPLING</sub>=f<sub>CK INT</sub>, N=8
- 0100: 采样频率 f<sub>SAMPLING</sub>=f<sub>DTS</sub>/2, N=6
- 0101: 采样频率 f<sub>SAMPLING</sub>=f<sub>DTS</sub>/2, N=8
- 0110: 采样频率 f<sub>SAMPLING</sub>=f<sub>DTS</sub>/4, N=6
- 0111: 采样频率 f<sub>SAMPLING</sub>=f<sub>DTS</sub>/4, N=8
- 1000: 采样频率 fsampling=fdts/8, N=6
- 1001: 采样频率 f<sub>SAMPLING</sub>=f<sub>DTS</sub>/8, N=8
- 1010: 采样频率 f<sub>SAMPLING</sub>=f<sub>DTS</sub>/16, N=5
- 1011: 采样频率 f<sub>SAMPLING</sub>=f<sub>DTS</sub>/16, N=6
- 1100: 采样频率 f<sub>SAMPLING</sub>=f<sub>DTS</sub>/16, N=8
- 1101: 采样频率 f<sub>SAMPLING</sub>=f<sub>DTS</sub>/32, N=5
- 1110: 采样频率 f<sub>SAMPLING</sub>=f<sub>DTS</sub>/32, N=6
- 1111: 采样频率 f<sub>SAMPLING</sub>=f<sub>DTS</sub>/32, N=8

#### 位 7 MSM: 主/从模式 (Master/slave mode)

- 0: 无作用
- 1: 触发输入(TRGI)上的事件被延迟了,以允许在当前定时器(通过 TRGO)与它的从定时器间的完美同步。这对要求把几个定时器同步到一个单一的外部事件时是非常有用的。



#### 位 6:4 TS[2:0]: 触发选择(Trigger selection)

这3位选择用于同步计数器的触发输入。

- 000: 内部触发 0 (ITRO)
- 001: 内部触发 1 (ITR1)
- 010: 内部触发 2 (ITR2)
- 011: 内部触发 3 (ITR3)
- 100: TI1 的边沿检测器(TI1F ED)
- 101: 滤波后的定时器输入 1 (TI1FP1)
- 110: 滤波后的定时器输入 2(TI2FP2)
- 111: 外部触发输入(ETRF)

更多有关 ITRx 的细节,参见表 12-2。

说明:该位域只能在未用到(如SMS=000)时被改变,以避免在改变时产生错误的边沿检测。

#### 位 3 Res: 保留

必须保持复位值。

#### 位 2:0 SMS[2:0]: 从模式选择(Slave mode selection)

当选择了外部信号,触发信号(TRGI)的有效边沿与选中的外部输入极性相关(见输入控制寄存器和控制寄存器的说明)

• 000: 关闭从模式

如果 CEN=1,则预分频器直接由内部时钟驱动。

• 001: 编码器模式 1

根据 TI1FP1 的电平, 计数器在 TI2FP2 的边沿向上/下计数。

• 010: 编码器模式 2

根据 TI2FP2 的电平, 计数器在 TI1FP1 的边沿向上/下计数。

• 011: 编码器模式 3

根据另一个信号的输入电平,计数器在 TI1FP1 和 TI2FP2 的边沿向上/下计数。

• 100: 复位模式

选中的触发输入(TRGI)的上升沿重新初始化计数器,并且产生一个更新寄存器的信号。

• 101: 门控模式

当触发输入(TRGI)为高时,计数器的时钟开启。一旦触发输入变为低,则计数器停止 (但不复位)。计数器的启动和停止都是受控的。

• 110: 触发模式

计数器在触发输入 TRGI 的上升沿启动 (但不复位), 只有计数器的启动是受控的。

• 111: 外部时钟模式 1

选中的触发输入(TRGI)的上升沿驱动计数器。

说明:如果TI1F\_EN 被选为触发输入(TS=100)时,不要使用门控模式。这是因为,TI1F\_ED 在每次TI1F 变化时输出一个脉冲,然而门控模式是要检查触发输入的电平。



#### 表 12-2 主从定时器内部触发连接

| 从定时器 | ITR1 (TS=001) | ITR2 (TS=010) | ITR3 (TS=011) |
|------|---------------|---------------|---------------|
| TIM1 | TIM2          | TIM3          | TIM4          |

# 12.3.4 TIM1 DMA/中断使能寄存器(TIMx\_DIER)

偏移地址: 0x0C 复位值: 0x0000

| 15 | 14 | 13   | 12   | 11   | 10   | 9    | 8  | 7  | 6  | 5    | 4    | 3    | 2    | 1    | 0  |
|----|----|------|------|------|------|------|----|----|----|------|------|------|------|------|----|
| Re | TD | COMD | CC4D | CC3D | CC2D | CC1D | UD | BI | TI | COMI | CC4I | CC3I | CC2I | CC1I | UI |
| S  | E  | E    | E    | E    | E    | E    | E  | Е  | Ε  | E    | E    | E    | E    | E    | Ε  |
|    | rw | rw   | rw   | rw   | rw   | rw   | rw | rw | rw | rw   | rw   | rw   | rw   | rw   | rw |

| I W  | TW                                                                               |
|------|-------------------------------------------------------------------------------------------------------------------|
| 位 15 | Res: 保留<br>必须保持复位值。                                                                                               |
| 位 14 | TDE: 允许触发 DMA 请求(Trigger DMA request enable)  • 0: 禁止触发 DMA 请求  • 1: 允许触发 DMA 请求                                  |
| 位 13 | COMDE: 允许 COM 的 DMA 请求(COM DMA request enable)  • 0: 禁止 COM 的 DMA 请求  • 1: 允许 COM 的 DMA 请求                        |
| 位 12 | CC4DE:允许捕获/比较 4 的 DMA 请求(Capture/Compare 4 DMA request enable)  • 0:禁止捕获/比较 4 的 DMA 请求  • 1:允许捕获/比较 4 的 DMA 请求    |
| 位 11 | CC3DE: 允许捕获/比较 3 的 DMA 请求(Capture/Compare 3 DMA request enable)  • 0: 禁止捕获/比较 3 的 DMA 请求  • 1: 允许捕获/比较 3 的 DMA 请求 |
| 位 10 | CC2DE: 允许捕获/比较 2 的 DMA 请求(Capture/Compare 2 DMA request enable)  • 0: 禁止捕获/比较 2 的 DMA 请求  • 1: 允许捕获/比较 2 的 DMA 请求 |
| 位 9  | CC1DE:允许捕获/比较 1 的 DMA 请求(Capture/Compare 1 DMA request enable)  • 0:禁止捕获/比较 1 的 DMA 请求  • 1:允许捕获/比较 1 的 DMA 请求    |
| 位 8  | UDE: 允许更新的 DMA 请求(Update DMA request enable)  • 0: 禁止更新的 DMA 请求  • 1: 允许更新的 DMA 请求                                |
| 位 7  | BIE: 允许刹车中断(Break interrupt enable)  • 0: 禁止刹车中断                                                                  |



|     | • 1: 允许刹车中断                                                                                   |
|-----|-----------------------------------------------------------------------------------------------|
| 位 6 | TIE: 触发中断使能(Trigger interrupt enable)  • 0: 禁止触发中断  • 1: 使能触发中断                               |
| 位 5 | COMIE: 允许 COM 中断(COM interrupt enable)  • 0: 禁止 COM 中断  • 1: 允许 COM 中断                        |
| 位 4 | CC4IE: 允许捕获/比较 4 中断(Capture/Compare 4 interrupt enable)  • 0: 禁止捕获/比较 4 中断  • 1: 允许捕获/比较 4 中断 |
| 位 3 | CC3IE: 允许捕获/比较 3 中断(Capture/Compare 3 interrupt enable)  • 0: 禁止捕获/比较 3 中断  • 1: 允许捕获/比较 3 中断 |
| 位 2 | CC2IE: 允许捕获/比较 2 中断(Capture/Compare 2 interrupt enable)  • 0: 禁止捕获/比较 2 中断  • 1: 允许捕获/比较 2 中断 |
| 位 1 | CC1IE: 允许捕获/比较 1 中断(Capture/Compare 1 interrupt enable)  • 0: 禁止捕获/比较 1 中断  • 1: 允许捕获/比较 1 中断 |
| 位 0 | UIE: 允许更新中断(Update interrupt enable)  • 0: 禁止更新中断  • 1: 允许更新中断                                |

# 12.3.5 TIM1 状态寄存器(TIMx\_SR)

偏移地址: 0x10 复位值: 0x0000

| 1 | 1   | 1 | 12    | 11    | 10    | 9     | 8  | 7    | 6    | 5     | 4    | 3    | 2    | 1    | 0    |
|---|-----|---|-------|-------|-------|-------|----|------|------|-------|------|------|------|------|------|
| 5 | 4   | 3 |       |       |       |       |    |      |      |       |      |      |      |      |      |
|   | Res |   | CC40  | CC30  | CC2O  | CC1O  | Re | BIF  | TIF  | COMI  | CC4I | CC3I | CC2I | CC1I | UIF  |
|   |     |   | F     | F     | F     | F     | S  |      |      | F     | F    | F    | F    | F    |      |
|   |     |   | rc_w0 | rc_w0 | rc_w0 | rc_w0 |    | rc_w | rc_w | rc_w0 | rc_w | rc_w | rc_w | rc_w | rc_w |
|   |     |   |       |       |       |       |    | 0    | 0    |       | 0    | 0    | 0    | 0    | 0    |

| 位 15:13 | Res: 保留<br>必须保持复位值。                                                       |
|---------|---------------------------------------------------------------------------|
| 位 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  | CC10F: 捕获/比较 1 重复捕获标志(Capture/Compare 1 overcapture flag)仅当相应的通道被配置为输入捕获时,该标志可由硬件置'1'。写 0 可清除该位。 • 0: 无重复捕获产生 • 1: 计数器的值被捕获到 TIMx_CCR1 寄存器时,CC1IF 的状态已经为'1'。                                      |
| 位 8  | Res: 保留<br>必须保持复位值。                                                                                                                                                                               |
| 位 7  | BIF: 刹车中断标志(Break interrupt flag) 一旦刹车输入有效,由硬件对该位置'1'。如果刹车输入无效,则该位可由软件清零。 • 0: 无刹车事件产生 • 1: 刹车输入上检测到有效电平                                                                                          |
| 位 6  | TIF: 触发器中断标志(Trigger interrupt flag)<br>当发生触发事件(当从模式控制器处于除门控模式外的其它模式时,在 TRGI 输入端检测<br>到有效边沿,或门控模式下的任一边沿)时,由硬件对该位置'1'。它由软件清零。<br>• 0: 无触发器事件产生<br>• 1: 触发中断等待响应                                    |
| 位 5  | COMIF: COM 中断标志(COM interrupt flag) 一旦产生 COM 事件(当捕获/比较控制位: CCxE、CCxNE、OCxM 已被更新),该位由硬件置'1'。它由软件清零。  • 0: 无 COM 事件产生  • 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 描述。                                                                                                                             |
| 位 1  | CC1IF: 捕获/比较 1 中断标志(Capture/Compare 1 interrupt flag)  • 如果通道 CC1 配置为输出模式:   当计数器值与比较值匹配时该位由硬件置'1', 但在中心对称模式下除外(参考 TIMx_CR1 寄存器的 CMS 位)。它由软件清零。   。 0: 无匹配发生。   。 1: TIMx_CNT 的值与 TIMx_CCR1 的值匹配。 |



当 TIMx\_CCR1 的内容大于 TIMx\_APR 的内容时,在向上或向上/下计数模式时计数器溢出,或向下计数模式时的计数器下溢条件下,CC1IF 位变高。

• 如果通道 CC1 配置为输入模式:

当捕获事件发生时该位由硬件置'1',它由软件清零或通过读 TIMx\_CCR1 清零。

- o 0: 无输入捕获产生。
- o 1: 计数器值已被捕获(拷贝)至 TIMx\_CCR1(在 IC1 上检测到与所选极性相同的边沿)。
- 位 0 UIF: 更新中断标志(Update interrupt flag)

当产生更新事件时该位由硬件置'1'。它由软件清零。

- 0: 无更新事件产生
- 1: 更新中断等待响应。当寄存器被更新时该位由硬件置'1':
  - o 若 TIMx\_CR1 寄存器的 UDIS=0,当重复计数器数值上溢或下溢时(重复计数器=0 时产生更新事件)。
  - o 若 TIMx\_CR1 寄存器的 URS=0、UDIS=0,当设置 TIMx\_EGR 寄存器的 UG=1 时产生更新事件,通过软件对计数器 CNT 重新初始化时。
  - o 若 TIMx\_CR1 寄存器的 URS=0、UDIS=0,当计数器 CNT 被触发事件重新初始化时。参 考 TIM1 从模式控制寄存器(TIMx\_SMCR)。

# 12.3.6 TIM1 事件产生寄存器(TIMx\_EGR)

偏移地址: 0x14 复位值: 0x0000

| 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  |

|        |                                                                            | VV             | VV   | VV      | VV | VV        | VV        | VV        | VV  |
|--------|----------------------------------------------------------------------------|----------------|------|---------|----|-----------|-----------|-----------|-----|
| 位 15:8 | Res: 保留<br>必须保持复位值。                                                        |                |      |         |    |           |           |           |     |
| 位 7    | BG:产生刹车事件(Break ge 该位由软件置'1',用于产生一 0:无动作。 • 1:产生一个刹车事件。此的中断和 DMA。          | 一个刹车           | 三事件  |         |    |           | 和 DMA     | ,则产生      | 三相应 |
| 位 6    | TG: 产生触发事件 (Trigger g 该位由软件置'1', 用于产生- • 0: 无动作 • 1: TIMx_SR 寄存器的 TIF=:    | 一个触发           | 文事件  |         |    |           | 相应的中      | 断和 DM     | IA。 |
| 位 5    | COMG: 捕获/比较事件,产生该位由软件置'1',由硬件自动 0: 无动作。 • 1: 当 CCPC=1,允许更新 (说明:该位只对拥有互补输品) | 动清零。<br>CCxE、C | CXNE | 、OCxM 1 | ·  | control u | pdate ger | neration) |     |



| •   |                                                                                                                                                                                                                                                                                                                                                        |
|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 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)该位由软件置'1',用于产生一个捕获/比较事件,由硬件自动清零。  • 0:无动作。  • 1:在通道 CC1 上产生一个捕获/比较事件:  。 若通道 CC1 配置为输出:  设置 CC1IF=1,若开启对应的中断和 DMA,则产生相应的中断和 DMA。  • 若通道 CC1 配置为输入:  当前的计数器值被捕获至 TIMx_CCR1 寄存器;设置 CC1IF=1,若开启对应的中断和 DMA,则产生相应的中断和 DMA,则产生相应的中断和 DMA,则产生相应的中断和 DMA,则产生相应的中断和 DMA,则产生相应的中断和 DMA。若 CC1IF 已经为 1,则设置 CC1OF=1。 |
| 位 0 | UG:产生更新事件(Update generation) 该位由软件置'1',由硬件自动清零。         • 0:无动作。         • 1:重新初始化计数器,并产生一个更新事件。注意预分频器的计数器也被清零(但是预分频系数不变)。若在中心对称模式下或 DIR=0(向上计数)则计数器被清零;若 DIR=1(向下计数)则计数器取 TIMx_ARR 的值。                                                                                                                                                                |

# 12.3.7 TIM1 捕获/比较模式寄存器 1(TIMx\_CCMR1)

偏移地址: 0x18 复位值: 0x0000

通道可用于输入(捕获模式)或输出(比较模式),通道的方向由相应的 CCxS 位定义。该寄存器其它位的作用在输入和输出模式下不同。OCxx 描述了通道在输出模式下的功能,ICxx 描述了通道在输入模式下的功能。因此必须注意,同一个位在输出模式和输入模式下的功能是不同的。

| 15    | 14              | 13 | 12    | 11    | 10        | 9  | 8     | 7         | 6  | 5  | 4     | 3     | 2    | 1     | 0 |
|-------|-----------------|----|-------|-------|-----------|----|-------|-----------|----|----|-------|-------|------|-------|---|
| OC2CE | OC2CE OC2M[2:0] |    | OC2PE | OC2FE | CC2S[1:0] |    | OC1CE | OC1M[2:0] |    |    | OC1PE | OC1FE | CC1S | [1:0] |   |
| 1     | IC2F[3:0]       |    |       | IC2PS | C[1:0]    |    |       | IC1F[3:0] |    |    | IC1PS |       |      |       |   |
| rw    | rw              | rw | rw    | rw    | rw        | rv | w     | rw        | rw | rw | rw    | rw    | rw   | r     | W |

#### 输出比较模式:

| 位 15    | OC2CE: 输出比较 2 清零使能(Output Compare 2 clear enable)    |
|---------|------------------------------------------------------|
| 位 14:12 | OC2M[2:0]: 输出比较 2 模式(Output Compare 2 mode)          |
| 位 11    | OC2PE: 输出比较 2 预装载使能(Output Compare 2 preload enable) |
| 位 10    | OC2FE: 输出比较 2 快速使能(Output Compare 2 fast enable)     |



#### 位 9:8 CC2S[1:0]: 捕获/比较 2 选择(Capture/Compare 2 selection)

该位定义通道的方向(输入/输出),及输入脚的选择:

- 00: CC2 通道被配置为输出。
- 01: CC2 通道被配置为输入, IC2 映射在 TI2 上。
- 10: CC2 通道被配置为输入, IC2 映射在 TI1 上。
- 11: CC2 通道被配置为输入,IC2 映射在 TRC 上。此模式仅工作在内部触发器输入被选中时(由 TIMx SMCR 寄存器的 TS 位选择)。

说明: CC2S 仅在通道关闭时(TIMx\_CCER 寄存器的CC2E=0)才是可写的。

#### 位 7 OC1CE: 输出比较 1 清零使能(Output Compare 1 clear enable)

- 0: OC1REF 不受 ETRF 输入的影响。
- 1: 一旦检测到 ETRF 输入高电平,清除 OC1REF=0。

#### 位 6:4 OC1M[2:0]: 输出比较 1 模式(Output Compare 1 mode)

该 3 位定义了输出参考信号 OC1REF 的动作,而 OC1REF 决定了 OC1、OC1N 的值。OC1REF 是高电平有效,而 OC1、OC1N 的有效电平取决于 CC1P、CC1NP 位。

• 000: 冻结

输出比较寄存器 TIMx\_CCR1 与计数器 TIMx\_CNT 间的比较对 OC1REF 不起作用。

• 001: 匹配时设置通道 1 为有效电平

当计数器 TIMx\_CNT 的值与捕获/比较寄存器 1(TIMx\_CCR1)相同时,强制 OC1REF 为高。

• 010: 匹配时设置通道 1 为无效电平

当计数器 TIMx\_CNT 的值与捕获/比较寄存器 1(TIMx\_CCR1)相同时,强制 OC1REF 为低。

• 011: 翻转

当 TIMx CCR1=TIMx CNT 时,翻转 OC1REF 的电平。

• 100: 强制为无效电平

强制 OC1REF 为低。

• 101: 强制为有效电平

强制 OC1REF 为高。

- 110: PWM 模式 1
  - o 在向上计数时,一旦 TIMx CNT<TIMx CCR1 时通道 1 为有效电平,否则为无效电平。
  - o 在向下计数时,一旦 TIMx\_CNT>TIMx\_CCR1 时通道 1 为无效电平(OC1REF=0),否则 为有效电平(OC1REF=1)。
- 111: PWM 模式 2
  - o 在向上计数时,一旦 TIMx CNT<TIMx CCR1 时通道 1 为无效电平,否则为有效电平。
  - o 在向下计数时,一旦 TIMx\_CNT>TIMx\_CCR1 时通道 1 为有效电平,否则为无效电平。

#### 说明:

- 一旦 LOCK 级别设为 3(TIMx\_BDTR 寄存器中的 LOCK 位)并且 CC1S=00(该通道配置成输出)则该位不能被修改。
- 在 PWM 模式 1 或 PWM 模式 2 中,只有当比较结果改变了或在输出比较模式中从冻结模式切换到 PWM 模式时,OC1REF 电平才改变。



#### 位 3

OC1PE: 输出比较 1 预装载使能(Output Compare 1 preload enable)

- 0: 禁止 TIMx\_CCR1 寄存器的预装载功能,可随时写入 TIMx\_CCR1 寄存器,并且新写入的数值立即起作用。
- 1: 开启 TIMx\_CCR1 寄存器的预装载功能,读写操作仅对预装载寄存器操作, TIMx CCR1 的预装载值在更新事件到来时被加载至当前寄存器中。

说明:

- 一旦 LOCK 级别设为 3(TIMx\_BDTR 寄存器中的 LOCK 位)并且 CC1S=00(该通道配置成输出)则该位不能被修改。
- 仅在单脉冲模式下(TIMx\_CR1 寄存器的 OPM=1),可以在未确认预装载寄存器情况下 使用 PWM 模式,否则其动作不确定。

#### 位 2

OC1FE: 输出比较 1 快速使能(Output Compare 1 fast enable)

该位用于加快 CC 输出对触发输入事件的响应。

- 0: 根据计数器与 CCR1 的值, CC1 正常操作,即使触发器是打开的。当触发器的输入 有一个有效沿时,激活 CC1 输出的最小延时为 5 个时钟周期。
- 1: 输入到触发器的有效沿的作用就像发生了一次比较匹配。因此,OC 被设置为比较电平而与比较结果无关。采样触发器的有效沿和 CC1 输出间的延时被缩短为 3 个时钟周期。

OCFE 只在通道被配置成 PWM1 或 PWM2 模式时起作用。

#### 位 1:0

CC1S[1:0]: 捕获/比较 1 选择。(Capture/Compare 1 selection)

这 2 位定义通道的方向(输入/输出),及输入脚的选择:

- 00: CC1 通道被配置为输出。
- 01: CC1 通道被配置为输入, IC1 映射在 TI1 上。
- 10: CC1 通道被配置为输入, IC1 映射在 TI2 上。
- 11: CC1 通道被配置为输入,IC1 映射在 TRC 上。此模式仅工作在内部触发器输入被选中时(由 TIMx\_SMCR 寄存器的 TS 位选择)。

说明: CC1S 仅在通道关闭时(TIMx\_CCER 寄存器的CC1E=0)才是可写的。

#### 输入捕获模式:

# 位 15:12 IC2F[3:0]: 输入/捕获 2 滤波器(Input capture 2 filter) 可参考 IC1F 的描述。 位 11:10 IC2PSC[1:0]: 输入/捕获 2 预分频器(Input capture 2 prescaler) 可参考 IC1PSC 的描述。 位 9:8 CC2S[1:0]: 捕获/比较 2 选择(Capture/Compare 2 selection) 这 2 位定义通道的方向(输入/输出),及输入脚的选择:

- 00: CC2 通道被配置为输出。
- 01: CC2 通道被配置为输入, IC2 映射在 TI2 上。
- 10: CC2 通道被配置为输入, IC2 映射在 TI1 上。
- 11: CC2 通道被配置为输入,IC2 映射在 TRC 上。此模式仅工作在内部触发器输入被选中时(由 TIMx\_SMCR 寄存器的 TS 位选择)。

说明: CC2S 仅在通道关闭时(TIMx\_CCER 寄存器的 CC2E=0)才是可写的。



#### 位 7:4 IC1F[3:0]: 输入捕获 1 滤波器(Input capture 1 filter)

这几位定义了 TI1 输入的采样频率及数字滤波器长度。数字滤波器由一个事件计数器组成,它记录到 N 个事件后会产生一个输出的跳变:

- 0000: 无滤波器,以 f<sub>DTS</sub> 采样
- 0001: 采样频率 f<sub>SAMPLING</sub>=f<sub>CK INT</sub>, N=2
- 0010: 采样频率 f<sub>SAMPLING</sub>=f<sub>CK\_INT</sub>, N=4
- 0011: 采样频率 f<sub>SAMPLING</sub>=f<sub>CK INT</sub>, N=8
- 0100: 采样频率 f<sub>SAMPLING</sub>=f<sub>DTS</sub>/2, N=6
- 0101: 采样频率 f<sub>SAMPLING</sub>=f<sub>DTS</sub>/2, N=8
- 0110: 采样频率 fsampling=fpts/4, N=6
- 0111: 采样频率 f<sub>SAMPLING</sub>=f<sub>DTS</sub>/4, N=8
- 1000: 采样频率 f<sub>SAMPLING</sub>=f<sub>DTS</sub>/8, N=6
- 1001: 采样频率 fsampling=fpts/8, N=8
- 1010: 采样频率 f<sub>SAMPLING</sub>=f<sub>DTS</sub>/16, N=5
- 1011: 采样频率 fsampling=fpts/16, N=6
- 1100: 采样频率 f<sub>SAMPLING</sub>=f<sub>DTS</sub>/16, N=8
- 1101: 采样频率 f<sub>SAMPLING</sub>=f<sub>DTS</sub>/32, N=5
- 1110: 采样频率 fsampling=fpts/32, N=6
- 1111: 采样频率 f<sub>SAMPLING</sub>=f<sub>DTS</sub>/32, N=8

#### 位 3:2 IC1PSC[1:0]: 输入/捕获 1 预分频器(Input capture 1 prescaler)

这 2 位定义了 CC1 输入 (IC1) 的预分频系数。

- 一旦 CC1E=0 (TIMx CCER 寄存器中),则预分频器复位。
- 00: 无预分频器, 捕获输入口上检测到的每一个边沿都触发一次捕获。
- 01:每2个事件触发一次捕获。
- 10: 每 4 个事件触发一次捕获。
- 11: 每8个事件触发一次捕获。

#### 位 1:0 CC1S[1:0]: 捕获/比较 1 选择(Capture/Compare 1 Selection)

这2位定义通道的方向(输入/输出),及输入脚的选择:

- 00: CC1 通道被配置为输出。
- 01: CC1 通道被配置为输入, IC1 映射在 TI1 上。
- 10: CC1 通道被配置为输入, IC1 映射在 TI2 上。
- 11: CC1 通道被配置为输入,IC1 映射在 TRC 上。此模式仅工作在内部触发器输入被选中时(由 TIMx SMCR 寄存器的 TS 位选择)。

说明: CC1S 仅在通道关闭时(TIMx CCER 寄存器的CC1E=0)才是可写的。

# 12.3.8 TIM1 捕获/比较模式寄存器 2(TIMx\_CCMR2)

偏移地址: 0x1C 复位值: 0x0000

参考以上 CCMR1 寄存器的描述。



| 15    | 14              | 13 | 12    | 11    | 10        | 9 | 8     | 7         | 6      | 5  | 4     | 3     | 2      | 1     | 0 |
|-------|-----------------|----|-------|-------|-----------|---|-------|-----------|--------|----|-------|-------|--------|-------|---|
| OC4CE | OC4CE OC4M[2:0] |    | OC4PE | OC4FE | CC4S[1:0] |   | OC3CE | OC3M[2:0] |        |    | OC3PE | OC3FE | CC3S   | [1:0] |   |
| 1     | IC4F[3:0]       |    |       | IC4PS | C[1:0]    |   |       | 10        | C3F[3: | 0] |       | IC3PS | C[1:0] |       |   |
| rw    | rw              | rw | rw    | rw    | rw        | r | W     | rw        | rw     | rw | rw    | rw    | rw     | r     | w |

#### 输出比较模式:

| 位 15    | OC4CE:输出比较 4 清零使能(Output compare 4 clear enable)                                                                                                                                                                                                                                                               |
|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 14:12 | OC4M[2:0]: 输出比较 4 模式(Output compare 4 mode)                                                                                                                                                                                                                                                                    |
| 位 11    | OC4PE: 输出比较 4 预装载使能(Output compare 4 preload enable)                                                                                                                                                                                                                                                           |
| 位 10    | OC4FE: 输出比较 4 快速使能(Output compare 4 fast enable)                                                                                                                                                                                                                                                               |
| 位 9:8   | CC4S[1:0]: 捕获/比较 4 选择(Capture/Compare 4 selection)该 2 位定义通道的方向(输入/输出),及输入脚的选择:  • 00: CC4 通道被配置为输出。  • 01: CC4 通道被配置为输入,IC4 映射在 TI4 上。  • 10: CC4 通道被配置为输入,IC4 映射在 TI3 上。  • 11: CC4 通道被配置为输入,IC4 映射在 TRC 上。此模式仅工作在内部触发器输入被选中时(由 TIMx_SMCR 寄存器的 TS 位选择)。 <i>说明: CC4S 仅在通道关闭时(TIMx_CCER 寄存器的 CC4E=0)才是可写的。</i>  |
| 位 7     | OC3CE: 输出比较 3 清零使能(Output compare 3 clear enable)                                                                                                                                                                                                                                                              |
| 位 6:4   | OC3M[2:0]: 输出比较 3 模式(Output compare 3 mode)                                                                                                                                                                                                                                                                    |
| 位 3     | OC3PE: 输出比较 3 预装载使能(Output compare 3 preload enable)                                                                                                                                                                                                                                                           |
| 位 2     | OC3FE: 输出比较 3 快速使能(Output compare 3 fast enable)                                                                                                                                                                                                                                                               |
| 位 1:0   | CC3S[1:0]: 捕获/比较 3 选择(Capture/Compare 3 selection) 这 2 位定义通道的方向(输入/输出),及输入脚的选择:  • 00: CC3 通道被配置为输出。  • 01: CC3 通道被配置为输入,IC3 映射在 TI3 上。  • 10: CC3 通道被配置为输入,IC3 映射在 TI4 上。  • 11: CC3 通道被配置为输入,IC3 映射在 TRC 上。此模式仅工作在内部触发器输入被选中时(由 TIMx_SMCR 寄存器的 TS 位选择)。 <i>说明: CC3S 仅在通道关闭时(TIMx_CCER 寄存器的 CC3E=0)才是可写的。</i> |

# 输入捕获模式:

| 位 15:12 | IC4F[3:0]: 输入捕获 4 滤波器(Input capture 4 filter)                                                                       |
|---------|---------------------------------------------------------------------------------------------------------------------|
| 位 11:10 | IC4PSC[1:0]: 输入/捕获 4 预分频器(Input capture 4 prescaler)                                                                |
| 位 9:8   | CC4S[1:0]: 捕获/比较 4 选择(Capture/Compare 4 selection)         这 2 位定义通道的方向(输入/输出),及输入脚的选择:         • 00: CC4 通道被配置为输出。 |



|       | <ul> <li>01: CC4 通道被配置为输入,IC4 映射在 TI4 上。</li> <li>10: CC4 通道被配置为输入,IC4 映射在 TI3 上。</li> <li>11: CC4 通道被配置为输入,IC4 映射在 TRC 上。此模式仅工作在内部触发器输入被选中时(由 TIMx_SMCR 寄存器的 TS 位选择)。</li> <li>说明: CC4S 仅在通道关闭时(TIMx_CCER 寄存器的 CC4E=0)才是可写的。</li> </ul>                                                                      |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 7:4 | IC3F[3:0]: 输入捕获 3 滤波器(Input capture 3 filter)                                                                                                                                                                                                                                                                 |
| 位 3:2 | IC3PSC[1:0]: 输入/捕获 3 预分频器(Input capture 3 prescaler)                                                                                                                                                                                                                                                          |
| 位 1:0 | CC3S[1:0]: 捕获/比较 3 选择(Capture/Compare 3 selection)这 2 位定义通道的方向(输入/输出),及输入脚的选择:  • 00: CC3 通道被配置为输出。  • 01: CC3 通道被配置为输入,IC3 映射在 TI3 上。  • 10: CC3 通道被配置为输入,IC3 映射在 TI4 上。  • 11: CC3 通道被配置为输入,IC3 映射在 TRC 上。此模式仅工作在内部触发器输入被选中时(由 TIMx_SMCR 寄存器的 TS 位选择)。 <i>说明: CC3S 仅在通道关闭时(TIMx_CCER 寄存器的 CC3E=0)才是可写的。</i> |

# 12.3.9 TIM1 捕获/比较使能寄存器(TIMx\_CCER)

偏移地址: 0x20 复位值: 0x0000

| 1  | 1  | 13  | 12  | 11   | 10   | 9   | 8   | 7    | 6    | 5   | 4   | 3    | 2    | 1   | 0   |
|----|----|-----|-----|------|------|-----|-----|------|------|-----|-----|------|------|-----|-----|
| 5  | 4  |     |     |      |      |     |     |      |      |     |     |      |      |     |     |
| Re | es | CC4 | CC4 | CC3N | CC3N | CC3 | CC3 | CC2N | CC2N | CC2 | CC2 | CC1N | CC1N | CC1 | CC1 |
|    |    | Р   | Ε   | Р    | Ε    | Р   | E   | Р    | Е    | Р   | E   | Р    | Е    | Р   | Ε   |
|    |    | rw  | rw  | rw   | rw   | rw  | rw  | rw   | rw   | rw  | rw  | rw   | rw   | rw  | rw  |

| 位 15:14 | Res: 保留<br>必须保持复位值。                                                                 |
|---------|-------------------------------------------------------------------------------------|
| 位 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)参考 CC1NP 的描述。 |
| 位 10    | CC3NE: 捕获/比较 3 互补输出使能(Capture/Compare 3 complementary output enable)参考 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)  • CC1 通道配置为输出:  • 0: OC1N 高电平有效  • 1: OC1N 低电平有效  • CC1 通道配置为输入:  这一位和 CC1P 联合使用来定义 TI1FP1 和 TI2FP1。详细的参考 CC1P 的描述。 说明:  • 在具有互补输出的通道上,此位是预加载的。如果 CCPC 位是在 TIMx_CR2 寄存器中设置,CC1NP 仅在通讯事件产生时加载新的值。  • 一旦 LOCK 级别(TIMx_BDTR 寄存器中的 LOCK 位)设为3 或2 且 CC1S=00(通道配置为输出)则该位不能被修改。 |
| 位 2 | CC1NE: 捕获/比较 1 互补输出使能(Capture/Compare 1 complementary output enable)  • 0: 关闭 OC1N 禁止输出,因此 OC1N 的电平依赖于 MOE、OSSI、OSSR、OIS1、OIS1N 和 CC1E 位的值。  • 1: 开启 OC1N信号输出到对应的输出引脚,其输出电平依赖于 MOE、OSSI、OSSR、OIS1、OIS1N和 CC1E 位的值。  说明: 在具有互补输出的通道上,此位是预加载的。如果 CCPC 位是在 TIMx_CR2 寄存器中设置,CC1NE 仅在通讯事件产生时加载新的值。                                                    |
| 位 1 | CC1P: 捕获/比较 1 输出极性(Capture/Compare 1 output polarity)  • CC1 通道配置为输出:  • 0: OC1 高电平有效  • 1: OC1 低电平有效  • CC1 通道配置为输入:  CC1NP/CC1P 联合组成两位控制来选择 TI1FP1 和 TI2FP1 的激活极性:  • 00: 没有翻转/上升沿                                                                                                                                                             |



电路对 TIxFP1 的上升沿敏感(捕获或触发操作复位,外部时钟或触发模式),TIxFP1 没有翻转(触发操作在门控或编码模式)。

o 01: 翻转/下降沿

电路对 TIXFP1 的下降沿敏感(捕获或触发操作复位,外部时钟或触发模式),TIXFP1 翻转(触发操作在门控或编码模式)。

- o 10: 保留
- o 11: 没有翻转/双沿

电路对 TixFP1 的上升沿和下降沿敏感(捕获或触发操作复位,外部时钟或触发模式), TixFP1 没有翻转(触发操作在门控模式)。这个配置不能用在编码模式。

#### 说明:

- 在具有互补输出的通道上,此位是预加载的。如果 CCPC 位是在 TIMx\_CR2 寄存器中设置,CC1P 仅在通讯事件产生时加载新的值。
- 一旦 LOCK 级别(TIMx\_BDTR 寄存器中的 LOCK 位)设为 3 或 2 ,则该位不能被修改。

#### 位 0 CC1E: 捕获/比较 1 输出使能(Capture/Compare 1 output enable)

- CC1 通道配置为输出:
  - o 0: 关闭

OC1 禁止输出,因此 OC1 的输出电平依赖于 MOE、OSSI、OSSR、OIS1、OIS1N 和 CC1NE 位的值。

o 1: 开启

OC1 信号输出到对应的输出引脚,其输出电平依赖于 MOE、OSSI、OSSR、OIS1、OIS1N 和 CC1NE 位的值。

• CC1 通道配置为输入:

该位决定了计数器的值是否能捕获入 TIMx\_CCR1 寄存器。

- o 0: 捕获禁止
- o 1: 捕获使能

说明: 在具有互补输出的通道上,此位是预加载的。如果 CCPC 位是在 TIMx\_CR2 寄存器中设置,CC1E 仅在通讯事件产生时加载新的值。

表 12-3 带刹车功能的互补输出通道 OCx 和 OCxN 的控制位

| 控制位      |           |           |           |            | 输出状态 (1)                                   |                                                   |
|----------|-----------|-----------|-----------|------------|--------------------------------------------|---------------------------------------------------|
| MOE<br>位 | OSSI<br>位 | OSSR<br>位 | CCxE<br>位 | CCxNE<br>位 | OCx 输出状态                                   | OCxN 输出状态                                         |
| 1        | Х         | 0         | 0         | 0          | 输出禁止 (与定时器断开)<br>OCx=0, OCx_EN=0           | 输出禁止(与定时器断开)<br>OCxN=0,OCxN_EN=0                  |
|          |           | 0         | 0         | 1          | 输出禁止(与定时器断开)<br>OCx=0,OCx_EN=0             | OCxREF+极性,<br>OCxN=OCxREF xor CCxNP,<br>OCxN_EN=1 |
|          |           | 0         | 1         | 0          | OCxREF+极性,<br>OCx=OCxREF xor CCxP,OCx_EN=1 | 输出禁止(与定时器断开)<br>OCxN=0,OCxN_EN=0                  |
|          |           | 0         | 1         | 1          | OCxREF+极性+死区,<br>OCx_EN=1                  | OCxREF 反相+极性+死区,<br>OCxN_EN=1                     |



| 控制位 |   |   |   |   | 输出状态 (1)                                       |                                                   |  |  |  |  |
|-----|---|---|---|---|------------------------------------------------|---------------------------------------------------|--|--|--|--|
|     |   | 1 | 0 | 0 | 输出禁止(与定时器断开)<br>OCx=CCxP,OCx_EN=0              | 输出禁止(与定时器断开)<br>OCxN=CCxNP,OCxN_EN=0              |  |  |  |  |
|     |   | 1 | 0 | 1 | 关闭状态(输出使能且为无效电平)OCx=CCxP,OCx_EN=1              | OCxREF+极性,<br>OCxN=OCxREF xor CCxNP,<br>OCxN_EN=1 |  |  |  |  |
|     |   | 1 | 1 | 0 | OCxREF+极性,<br>OCx=OCxREF xor CCxP,<br>OCx_EN=1 | 关闭状态(输出使能且为无效<br>电 平 ) OCxN=CCxNP,<br>OCxN_EN=1   |  |  |  |  |
|     |   | 1 | 1 | 1 | OCxREF+极性+死区,<br>OCx_EN=1                      | OCxREF 反相+极性+死区,<br>OCxN_EN=1                     |  |  |  |  |
| 0   | 0 | Х | 0 | 0 | 输出禁止(与定时器断开)                                   |                                                   |  |  |  |  |
|     | 0 |   | 0 | 1 | 异步地: OCx=CCxP, OCx_EN=0,<br>若 时 钟 存 在 : 经 过 一  | <del>-</del>                                      |  |  |  |  |
|     | 0 |   | 1 | 0 | OCxN=OISxN,假设 OISx 与 OISxN<br>平。               |                                                   |  |  |  |  |
|     | 0 | - | 1 | 1 |                                                |                                                   |  |  |  |  |
|     | 1 |   | 0 | 0 | 关闭状态(输出使能且为无效电平                                | )                                                 |  |  |  |  |
|     | 1 | - | 0 | 1 | 异步地: OCx=CCxP, OCx_EN=1,<br>若 时 钟 存 在 : 经 过 一  | _                                                 |  |  |  |  |
|     | 1 | - | 1 | 0 |                                                | 可OISxN 并不都对应 OCx 和 OCxN 的有效电                      |  |  |  |  |
|     | 1 |   | 1 | 1 |                                                |                                                   |  |  |  |  |

(1). 如果一个通道的 2 个输出都没有使用(CCxE=CCxNE=0),那么 OISx,OISxN,CCxP 和 CCxNP 都必须清零。 说明:引脚连接到互补的 OCx 和 OCxN 通道的外部 I/O 引脚的状态,取决于 OCx 和 OCxN 通道状态和 GPIO 以及 AFIO 寄存器。

# 12.3.10 TIM1 计数器寄存器(TIMx\_CNT)

偏移地址: 0x24 复位值: 0x0000

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

位 15:0 CNT[15:0]: 计数器的值(Counter value)

# 12.3.11 TIM1 预分频器寄存器(TIMx\_PSC)

偏移地址: 0x28 复位值: 0x0000

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



位 15:0

PSC[15:0]: 预分频器的值(Prescaler value)

计数器的时钟频率(CK CNT)等于 f<sub>CK PSC</sub>/(PSC[15:0]+1)。

每次更新事件产生时,PSC 的值被加载到当前分频器的寄存器中; 更新事件包括计数器被 TIM\_EGR 的 UG 位清零或计数器被配置为复位模式时通过触发控制器清零。

# 12.3.12 TIM1 自动重装载寄存器(TIMx\_ARR)

偏移地址: 0x2C 复位值: 0xFFFF

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

位 15:0

ARR[15:0]: 自动重装载的值(Auto-reload value)

ARR 包含了将要装载入实际的自动重装载寄存器的值。有关 ARR 的更新和动作,可参考"12.2.1 时基单元"。

当自动重装载的值为空时, 计数器不工作。

## 12.3.13 TIM1 重复计数寄存器(TIMx RCR)

偏移地址: 0x30 复位值: 0x0000

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

位 **15:8** Res: 保留

必须保持复位值。

位 7:0 REP[7:0]: 重复计数器的值(Repetition counter value)

开启了预装载功能后,该位域允许用户设置比较寄存器的更新速率(即周期性地从预装载寄存器传输到当前寄存器);如果允许产生更新中断,则会同时影响产生更新中断的速率。

每次向下计数器(REP\_CNT)达到 0,会产生一个更新事件并且 REP\_CNT 重新从 REP 值开始计数。由于 REP\_CNT 只有在周期更新事件 U\_RC 发生时才重载 REP 值,因此对 TIMx\_RCR 寄存器写入的新值只在下次周期更新事件发生时才起作用。

这意味着在 PWM 模式中,(REP+1)对应着:

- 在边沿对齐模式下, PWM 周期的数目。
- 在中心对称模式下, PWM 半周期的数目。

# 12.3.14 TIM1 捕获/比较寄存器 1(TIMx\_CCR1)

偏移地址: 0x34 复位值: 0x0000

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



rw/ro

#### 位 15:0

CCR1[15:0]: 捕获/比较通道 1 的值(Capture/Compare 1 value)

• 若 CC1 通道配置为输出:

CCR1 包含了装入当前捕获/比较 1 寄存器的值(预装载值)。

如果在 TIMx\_CCMR1 寄存器(OC1PE 位)中未选择预装载功能,写入的数值会立即 传输至当前寄存器中。否则只有当更新事件发生时,此预装载值才传输至当前捕获 /比较 1 寄存器中。

当前捕获/比较寄存器参与同计数器 TIMx\_CNT 的比较,并在 OC1 端口上产生输出信号。

• 若 CC1 通道配置为输入:

CCR1 包含了由上一次输入捕获 1 事件(IC1)传输的计数器值。TIMx\_CCR1 只能读不能被编程。

# 12.3.15 TIM1 捕获/比较寄存器 2(TIMx\_CCR2)

偏移地址: 0x38 复位值: 0x0000

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

#### 位 15:0

CCR2[15:0]: 捕获/比较通道 2 的值(Capture/Compare 2 value)

• 若 CC2 通道配置为输出:

CCR2 包含了装入当前捕获/比较 2 寄存器的值(预装载值)。

如果在 TIMx\_CCMR2 寄存器(OC2PE 位)中未选择预装载特性,写入的数值会立即传输至当前寄存器中。否则只有当更新事件发生时,此预装载值才传输至当前捕获/比较 2 寄存器中。

当前捕获/比较寄存器参与同计数器 TIMx\_CNT 的比较,并在 OC2 端口上产生输出信号。

• 若 CC2 通道配置为输入:

CCR2 包含了由上一次输入捕获 2 事件(IC2)传输的计数器值。TIMx\_CCR2 只能读不能被编程。

# 12.3.16 TIM1 捕获/比较寄存器 3(TIMx\_CCR3)

偏移地址: 0x3C 复位值: 0x0000

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

#### 位 15:0

CCR3[15:0]: 捕获/比较通道 3 的值(Capture/Compare 3 value)

• 若 CC3 通道配置为输出:

CCR3 包含了装入当前捕获/比较 3 寄存器的值(预装载值)。



如果在 TIMx\_CCMR3 寄存器(OC3PE 位)中未选择预装载特性,写入的数值会立即传输至当前寄存器中。否则只有当更新事件发生时,此预装载值才传输至当前捕获/比较 3 寄存器中。

当前捕获/比较寄存器参与同计数器 TIMx\_CNT 的比较,并在 OC3 端口上产生输出信号。

• 若 CC3 通道配置为输入:

CCR3 包含了由上一次输入捕获 3 事件(IC3)传输的计数器值。TIMx\_CCR3 只能读不能被编程。

## 12.3.17 TIM1 捕获/比较寄存器 4(TIMx CCR4)

偏移地址: 0x40 复位值: 0x0000

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

#### 位 15:0

CCR4[15:0]: 捕获/比较通道 4 的值(Capture/Compare 4 value)

• 若 CC4 通道配置为输出:

CCR4 包含了装入当前捕获/比较 4 寄存器的值(预装载值)。

如果在 TIMx\_CCMR4 寄存器(OC4PE 位)中未选择预装载特性,写入的数值会立即传输至当前寄存器中。否则只有当更新事件发生时,此预装载值才传输至当前捕获/比较 4 寄存器中。

当前捕获/比较寄存器参与同计数器 TIMx\_CNT 的比较,并在 OC4 端口上产生输出信号。

• 若 CC4 通道配置为输入:

CCR4 包含了由上一次输入捕获 4 事件(IC4)传输的计数器值。TIMx\_CCR4 只能读不能被编程。

# 12.3.18 TIM1 刹车和死区寄存器(TIMx\_BDTR)

偏移地址: 0x44 复位值: 0x0000

说明:根据锁定设置,该寄存器的 AOE、BKP、BKE、OSSI、OSSR 和 DTG[7:0] 位均可被写保护,有必要在第一次写入 TIMX\_BDTR 寄存器时对它们进行配置。

| 15  | 14  | 13  | 12  | 11   | 10   | 9   | 8        | 7  | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|-----|-----|-----|------|------|-----|----------|----|---|---|---|---|---|---|---|
| MOE | AOE | BKP | BKE | OSSR | OSSI | LOC | DTG[7:0] |    |   |   |   |   |   |   |   |
| rw  | rw  | rw  | rw  | rw   | rw   | r   | w        | rw |   |   |   |   |   |   |   |

#### 位 15 MOE: 主输出使能(Main output enable)

一旦刹车输入有效,该位被硬件异步清零。根据 AOE 位的设置值,该位可以由软件清零或被自动置'1'。它仅对配置为输出的通道有效。

- 0: 禁止 OC 和 OCN 输出或强制为空闲状态。
- 1: 如果设置了相应的使能位(TIMx\_CCER 寄存器的 CCxE、CCxNE 位),则开启 OC 和 OCN 输出。



| ו ל יבוי אטילנוע |                                                                                                                                                                                                                                                                                                                                 |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | 有关 OC/OCN 使能的细节,参见 TIM1 捕获/比较使能寄存器(TIMx_CCER)。                                                                                                                                                                                                                                                                                  |
| 位 14             | AOE: 自动输出使能(Automatic output enable)         • 0: MOE 只能被软件置'1'。         • 1: MOE 能被软件置'1'或在下一个更新事件被自动置'1'(如果刹车输入无效)。         说明: 一旦 LOCK 级别(TIMx_BDTR 寄存器中的 LOCK 位)设为'1',则该位不能被修改。                                                                                                                                             |
| 位 13             | BKP: 刹车输入极性(Break polarity)  O: 刹车输入低电平有效。  1: 刹车输入高电平有效。 <i>说明:</i> 一旦 LOCK 级别(TIMx_BDTR 寄存器中的 LOCK 位)设为'1',则该位不能被修改。  任何对该位的写操作都需要一个 APB 时钟的延迟以后才能起作用。                                                                                                                                                                        |
| 位 12             | BKE: 刹车功能使能(Break enable)  • 0: 禁止刹车输入(BRK 及 CCS 时钟失效事件)。  • 1: 开启刹车输入(BRK 及 CCS 时钟失效事件)。 <i>说明:</i> • 当设置了 LOCK 级别 1 时(TIMx_BDTR 寄存器中的 LOCK 位),该位不能被修改。  • 任何对该位的写操作都需要一个 APB 时钟的延迟以后才能起作用。                                                                                                                                    |
| 位 11             | OSSR: 运行模式下"关闭状态"选择(Off-state selection for Run mode)该位用于当 MOE=1 且通道为互补输出时。没有互补输出的定时器中不存在 OSSR 位。OC/OCN 使能的详细说明,可参考 TIM1 捕获/比较使能寄存器(TIMx_CCER)。  • 0: 当定时器不工作时,禁止 OC/OCN 输出(OC/OCN 使能输出信号=0)。  • 1: 当定时器不工作时,一旦 CCxE=1 或 CCxNE=1,首先开启 OC/OCN 并输出无效电平,然后置 OC/OCN 使能输出信号=1。  说明: 一旦 LOCK 级别(TIMx_BDTR 寄存器中的 LOCK 位)设为 2,则该位不能被修改。 |
| 位 10             | OSSI: 空闲模式下"关闭状态"选择(Off-state selection for Idle mode)该位用于当 MOE=0 且通道设为输出时。 OC/OCN 使能的详细说明,可参考 TIM1 捕获/比较使能寄存器(TIMx_CCER)。 • 0: 当定时器不工作时,禁止 OC/OCN 输出(OC/OCN 使能输出信号=0)。 • 1: 当定时器不工作时,一旦 CCxE=1 或 CCxNE=1,OC/OCN 首先输出其空闲电平,然后 OC/OCN 使能输出信号=1。 说明: 一旦 LOCK 级别(TIMx_BDTR 寄存器中的 LOCK 位)设为 2,则该位不能被修改。                             |
| 位 9:8            | LOCK[1:0]: 锁定设置(Lock configuration)。该位为防止软件错误而提供写保护。  • 00: 锁定关闭,寄存器无写保护。  • 01: 锁定级别 1,不能写入 TIMx_BDTR 寄存器的 DTG、BKE、BKP、AOE 位和 TIMx_CR2 寄存器的 OISx/OISxN 位。  • 10: 锁定级别 2,不能写入锁定级别 1 中的各位,也不能写入 CC 极性位(一旦相关通道通过 CCxS 位设为输出,CC 极性位是 TIMx_CCER 寄存器的 CCxP/CCNxP 位)以及                                                                |



OSSR/OSSI 位。

• 11: 锁定级别 3,不能写入锁定级别 2 中的各位,也不能写入 CC 控制位(一旦相关通道通过 CCxS 位设为输出,CC 控制位是 TIMx\_CCMRx 寄存器的 OCxM/OCxPE 位)。 说明: 在系统复位后,只能写一次 LOCK 位,一旦写入 TIMx\_BDTR 寄存器,则其内容冻结

直至复位。

位 7:0 DTG[7:0]: 死区发生器设置(Dead-time generator setup)

该位域定义了插入互补输出之间的死区持续时间。假设 DT 表示其持续时间:

- DTG[7:5]=0xx=>DT=DTG[7:0]×Tdtg, 其中 Tdtg=TDTS;
- DTG[7:5]=10x=>DT=(64+DTG[5:0]) ×Tdtg, 其中 Tdtg=2×T<sub>DTS</sub>;
- DTG[7:5]=110=>DT=(32+DTG[4:0])×Tdtg, 其中 Tdtg=8×T<sub>DTS</sub>;

例: 若 T<sub>DTS</sub>=125 ns (8 MHz), 可能的死区时间为:

- 0 到 15875 ns, 步长时间为 125 ns;
- 16 µs 到 31750 ns, 步长时间为 250 ns;
- 32 μs 到 63 μs, 步长时间为 1 μs;
- 64 μs 到 126 μs, 步长时间为 2 μs;

说明:一旦 LOCK 级别(TIMx\_BDTR 寄存器中的 LOCK 位)设为1、2 或3,则不能修改这些位。

# 12.3.19 TIM1 DMA 控制寄存器(TIMx DCR)

偏移地址: 0x48 复位值: 0x0000

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

位 15:13 Res: 保留

必须保持复位值。

位 12:8 DBL[4:0]: DMA 连续传送长度(DMA burst length)

该位域定义了 DMA 在连续模式下的传送长度(当对 TIMx\_DMAR 寄存器进行读或写时,定时器则进行一次连续传送),即:定义传输的次数,传输可以是半字(双字节)或字节:

- 00000: 1 次传输
- 00001: 2 次传输
- 00010: 3 次传输
- ..
- 10001: 18 次传输

例:考虑这样的传输: DBL=7, DBA=TIM2\_CR1

• 如果 DBL=7,DBA=TIM2\_CR1 表示待传输数据的地址,那么传输的地址由下式给出: (TIMx\_CR1 的地址)+DBA+(DMA 索引),其中: DMA 索引=DBL=7; DBA: 参考 DBA 描述。



(TIMx\_CR1 的地址)+DBA+7,给出了将要写入或者读出数据的地址,这样数据的传输将发生在从地址(TIMx CR1 的地址)+DBA 开始的 7 个寄存器。

根据 DMA 数据长度的设置,可能发生以下情况:

- 如果设置数据为半字(16位),那么数据就会传输给全部7个寄存器。
- 如果设置数据为字节,数据仍然会传输给全部 7 个寄存器:第一个寄存器包含第一个MSB字节,第二个寄存器包含第一个LSB字节,以此类推。因此对于定时器,用户必须指定由 DMA 传输的数据宽度。

#### 位 7:5 Res: 保留

必须保持复位值。

#### 位 4:0 DBA[4:0]: DMA 基地址(DMA base address)

该位域定义了 DMA 在连续模式下的基地址(当对 TIMx\_DMAR 寄存器进行读或写时), DBA 定义为从 TIMx\_CR1 寄存器所在地址开始的偏移量:

• 00000: TIMx\_CR1

• 00001: TIMx\_CR2

• 00010: TIMx SMCR

...

# 12.3.20 TIM1 连续模式的 DMA 地址寄存器(TIMx\_DMAR)

偏移地址: 0x4C 复位值: 0x0000

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

#### 位 15:0 DMAB[15:0]: DMA 连续传送寄存器(DMA register for burst accesses)

对 TIMx DMAR 寄存器的读或写会导致对以下地址所在寄存器的存取操作:

(TIMx CR1 地址) + (DBA + DMA 索引) \*4,

其中: "TIMx CR1 地址"是控制寄存器 1(TIMx CR1)所在的地址;

"DBA"是 TIMx DCR 寄存器中定义的基地址;

"DMA 索引"是由 DMA 自动控制的偏移量,它取决于 TIMx\_DCR 寄存器中定义的 DBL 位。



# 13 通用定时器(TIMx)

通用定时器由一个通过可编程预分频器驱动的 16 位自动装载计数器构成。它适用于多种场合,包括测量输入信号的脉冲长度(输入捕获)或者产生输出波形(输出比较和 PWM)。

使用定时器预分频器和 RCC 时钟控制器预分频器,脉冲长度和波形周期可以在几个微秒到几个毫秒间调整。

每个定时器都是完全独立的,没有互相共享任何资源。它们可以一起同步操作,参见:"定时器同步"。

TIM2/TIM3/TIM4 的功能完全一样,只是寄存器基地址不同;寄存器基地址请参见"2.2.1 存储器映射"。

# 13.1 TIMx 主要功能

通用 TIMx(TIM2、TIM3、TIM4) 定时器功能包括:

- 16 位向上、向下、向上/向下自动装载计数器
- 16 位可编程(可以实时修改)预分频器,计数器时钟频率的分频系数为1~65536 之间的任意数值
- 4 个独立通道:
  - 。 输入捕获
  - 。 输出比较
  - 。 PWM 生成(边沿或中央对齐模式)
  - 。 单脉冲模式输出
- 使用外部信号控制定时器和定时器互联的同步电路
- 如下事件发生时产生中断/DMA:
  - 。 更新: 计数器向上溢出/向下溢出,计数器初始化(通过软件或者内部/外部触发)
  - 。 触发事件(计数器启动、停止、初始化或者由内部/外部触发计数)
  - 。 输入捕获
  - 。 输出比较
- 支持针对定位的增量(正交)编码器和霍尔传感器电路
- 触发输入作为外部时钟或者按周期的电流管理





图 13-1 通用定时器框图

# 13.2 TIMx 功能

## 13.2.1 时基单元

可编程通用定时器的主要部分是一个 16 位计数器和与其相关的自动装载寄存器。这个计数器可以向上计数、向下计数或者向上向下双向计数。此计数器时钟由预分频器分频得到。

计数器寄存器、自动装载寄存器和预分频器寄存器可以由软件读写,在计数器运行时仍可以读写。 时基单元包含:

- 计数器寄存器(TIMx CNT)
- 预分频器寄存器(TIMx PSC)
- 自动重装载寄存器(TIMx\_ARR)

自动重装载寄存器是预先装载的,写或读自动重装载寄存器将访问预装载寄存器。根据在TIMx\_CR1 寄存器中的自动装载预装载使能位(ARPE)的设置,预装载寄存器的内容被立即或在每次的更新事件 UEV 时传送到影子寄存器。当计数器达到溢出条件(向下计数时的下溢条件)并当TIMx\_CR1 寄存器中的 UDIS 位等于'0'时,产生更新事件。更新事件也可以由软件产生。随后会详细描述每一种配置下更新事件的产生。



计数器由预分频器的时钟输出 CK\_CNT 驱动,只有当设置了计数器 TIMx\_CR1 寄存器中的计数器使能位(CEN)时,CK CNT 才有效。(有关计数器使能的细节,请参见控制器的从模式描述)。

注意: 真正的计数器使能信号 CNT EN 是在 CEN 的一个时钟周期后被设置。

## 13.2.1.1 预分频器描述

预分频器可以将计数器的时钟频率按 1 到 65536 之间的任意值分频。它是基于一个(在 TIMx\_PSC 寄存器中的)16 位寄存器控制的 16 位计数器。这个控制寄存器带有缓冲器,它能够在工作时被改变。新的预分频器参数在下一次更新事件到来时被采用。

下面两个图给出了在预分频器运行时,更改计数器参数的例子。



图 13-2 当预分频器的参数从 1 变到 2 时, 计数器的时序图



图 13-3 当预分频器的参数从 1 变到 4 时, 计数器的时序图

## 13.2.2 计数器模式

#### 13.2.2.1 向上计数模式

在向上计数模式中,计数器从 0 计数到自动加载值(TIMx\_ARR 计数器的值),然后重新从 0 开始计数并且产生一个计数器溢出事件。



每次计数器溢出时可以产生更新事件,在 TIMx\_EGR 寄存器中(通过软件方式或者使用从模式控制器)设置 UG 位也同样可以产生一个更新事件。设置 TIMx\_CR1 寄存器中的 UDIS 位,可以禁止更新事件;这样可以避免在向预装载寄存器中写入新值时更新影子寄存器。在 UDIS 位被清零之前,将不产生更新事件。但是在应该产生更新事件时,计数器仍会被清零,同时预分频器的计数也被清零(但预分频系数不变)。此外,如果设置了 TIMx\_CR1 寄存器中的 URS 位(选择更新请求),设置 UG 位将产生一个更新事件 UEV,但硬件不设置 UIF 标志(即不产生中断或 DMA 请求);这是为了避免在捕获模式下清除计数器时,同时产生更新和捕获中断。

当发生一个更新事件时,所有的寄存器都被更新,且硬件同时(依据 URS 位)设置更新标志位 (TIMx SR 寄存器中的 UIF 位)。

- 预分频器的缓冲区被置入预装载寄存器的值(TIMx\_PSC 寄存器的内容)。
- 自动装载影子寄存器被重新置入预装载寄存器的值(TIMx ARR)。

下图给出一些例子, 当 TIMx ARR=0x36 时计数器在不同时钟频率下的动作。



图 13-4 计数器时序图,内部时钟分频因子为 1



图 13-5 计数器时序图,内部时钟分频因子为 2





图 13-6 计数器时序图,内部时钟分频因子为 4



图 13-7 计数器时序图,内部时钟分频因子为 N



图 13-8 计数器时序图, 当 ARPE=0 时的更新事件(TIMx\_ARR 没有预装入)





图 13-9 计数器时序图, 当 ARPE=1 时的更新事件(预装入了 TIMx ARR)

## 13.2.2.2 向下计数模式

在向下模式中,计数器从自动装入的值(TIMx\_ARR 计数器的值)开始向下计数到 0,然后从自动装入的值重新开始并且产生一个计数器向下溢出事件。

每次计数器溢出时可以产生更新事件,在 TIMx\_EGR 寄存器中(通过软件方式或者使用从模式控制器)设置 UG 位,也同样可以产生一个更新事件。

设置 TIMx\_CR1 寄存器的 UDIS 位可以禁止 UEV 事件。这样可以避免向预装载寄存器中写入新值时更新影子寄存器。因此 UDIS 位被清零之前不会产生更新事件。然而,计数器仍会从当前自动加载值重新开始计数,同时预分频器的计数器重新从 0 开始 (但预分频系数不变)。

此外,如果设置了 TIMx\_CR1 寄存器中的 URS 位(选择更新请求),设置 UG 位将产生一个更新事件 UEV 但不设置 UIF 标志(因此不产生中断和 DMA 请求)。这是为了避免在发生捕获事件并清除计数器时,同时产生更新和捕获中断。

当发生更新事件时,所有的寄存器都被更新,并且(根据 URS 位的设置)更新标志位(TIMx\_SR 寄存器中的 UIF 位)也被设置。

- 预分频器的缓冲器被置入预装载寄存器的值(TIMx\_PSC 寄存器的值)。
- 当前的自动加载寄存器被更新为预装载值(TIMX ARR 寄存器中的内容)。

注意: 自动装载在计数器重载入之前被更新, 因此下一个周期将是预期的值。

以下是一些当 TIMx ARR=0x36 时,计数器在不同时钟频率下的操作例子。





图 13-10 计数器时序图,内部时钟分频因子为 1



图 13-11 计数器时序图,内部时钟分频因子为 2



图 13-12 计数器时序图,内部时钟分频因子为 4





图 13-13 计数器时序图,内部时钟分频因子为 N



图 13-14 计数器时序图, 当没有使用重复计数器时的更新事件

#### 13.2.2.3 中央对齐模式(向上/向下计数)

在中央对齐模式, 计数器从 0 开始计数到自动加载的值减 1 (TIMx\_ARR 寄存器-1), 产生一个计数器溢出事件, 然后向下计数到 1 并且产生一个计数器下溢事件, 然后再从 0 开始重新计数。

在这个模式,不能写入 TIMx CR1 中的 DIR 方向位。它由硬件更新并指示当前的计数方向。

可以在每次计数上溢和每次计数下溢时产生更新事件,也可以通过(软件或者使用从模式控制器)设置 TIMx\_EGR 寄存器中的 UG 位产生更新事件。然后,计数器重新从 0 开始计数,预分频器也重新从 0 开始计数。

设置 TIMx\_CR1 寄存器中的 UDIS 位可以禁止 UEV 事件。这样可以避免在向预装载寄存器中写入新值时更新影子寄存器。因此 UDIS 位被清为'0'之前不会产生更新事件。然而,计数器仍会根据当前自动重加载的值,继续向上或向下计数。

此外,如果设置了 TIMx\_CR1 寄存器中的 URS 位(选择更新请求),设置 UG 位将产生一个更新事件 UEV 但不设置 UIF 标志(因此不产生中断和 DMA 请求),这是为了避免在发生捕获事件并清除计数器时,同时产生更新和捕获中断。

当发生更新事件时,所有的寄存器都被更新,并且(根据 URS 位的设置)更新标志位(TIMx\_SR 寄存器中的 UIF 位)也被设置。

- 预分频器的缓存器被加载为预装载(TIMx\_PSC 寄存器)的值。
- 当前的自动加载寄存器被更新为预装载值(TIMx ARR 寄存器中的内容)。



注意:如果因为计数器溢出而产生更新,自动重装载将在计数器重载入之前被更新,因此下一个周期将是预期的值(计数器被装载为新的值)。

以下是一些计数器在不同时钟频率下的操作的例子:

图 13-15 使用了中心对齐模式 1 (详见 TIMx CR1 章节)。



图 13-15 计数器时序图,内部时钟分频因子为 1,TIMx ARR=0x6



图 13-16 计数器时序图,内部时钟分频因子为 2



图 13-17 计数器时序图,内部时钟分频因子为 4,TIMx ARR=0x36





图 13-18 计数器时序图,内部时钟分频因子为 N



图 13-19 计数器时序图, ARPE=1 时的更新事件(计数器下溢)



图 13-20 计数器时序图, ARPE=1 时的更新事件(计数器溢出)



# 13.2.3 时钟选择

计数器时钟可由下列时钟源提供:

- 内部时钟(CK INT)
- 外部时钟模式 1: 外部输入脚(Tlx)
- 外部时钟模式 2: 外部触发输入(ETR)
- 内部触发输入(ITRx): 使用一个定时器作为另一个定时器的预分频器,如可以配置一个定时器 Timer1 而作为另一个定时器 Timer2 的预分频器。参见: "定时器同步"。

## 13.2.3.1 内部时钟源(CK\_INT)

如果禁止了从模式控制器(TIMx\_SMCR 寄存器的 SMS=000),则 CEN、DIR(TIMx\_CR1 寄存器)和 UG 位(TIMx\_EGR 寄存器)是实际控制位,并且只能被软件修改(UG 位仍被自动清除)。只要 CEN 位被 写成'1',预分频器的时钟就由内部时钟 CK INT 提供。

下图显示了控制电路和向上计数器在一般模式下,不带预分频器时的操作。



图 13-21 一般模式下的控制电路,内部时钟分频因子为 1

#### 13.2.3.2 外部时钟源模式 1

当 TIMx\_SMCR 寄存器的 SMS=111 时,此模式被选中。计数器可以在选定输入端的每个上升沿或下降沿计数。



图 13-22 TI2 外部时钟连接例子

例如,要配置向上计数器在 T12 输入端的上升沿计数,使用下列步骤:

- 1. 配置 TIMx CCMR1 寄存器 CC2S='01', 配置通道 2 检测 TI2 输入的上升沿。
- 2. 配置 TIMx CCMR1 寄存器的 IC2F[3:0],选择输入滤波器带宽(如果不需要滤波器,保持



IC2F=0000)。

注意: 捕获预分频器不用作触发, 所以不需要对它进行配置。

- 3. 配置 TIMx\_CCER 寄存器的 CC2P='0', 选定上升沿极性。
- 4. 配置 TIMx SMCR 寄存器的 SMS='111',选择定时器外部时钟模式 1。
- 5. 配置 TIMx SMCR 寄存器中的 TS='110',选定 TI2 作为触发输入源。
- 6. 设置 TIMx CR1 寄存器的 CEN='1', 启动计数器。

当上升沿出现在 TI2, 计数器计数一次,且 TIF 标志被设置。在 TI2 的上升沿和计数器实际时钟之间的延时,取决于在 TI2 输入端的重新同步电路。



图 13-23 外部时钟模式 1 下的控制电路

### 13.2.3.3 外部时钟源模式 2

选定此模式的方法为:设置 TIMx SMCR 寄存器中的 ECE=1。

计数器能够在外部触发 ETR 的每一个上升沿或下降沿计数。

下图是外部触发输入的框图。



图 13-24 外部触发输入框图

例如,要配置在 ETR 下每 2 个上升沿计数一次的向上计数器,使用下列步骤:

- 1. 本例中不需要滤波器,置 TIMx\_SMCR 寄存器中的 ETF[3:0]=0000。
- 2. 设置预分频器,置 TIMx SMCR 寄存器中的 ETPS[1:0]=01。
- 3. 设置在 ETR 的上升沿检测,置 TIMx\_SMCR 寄存器中的 ETP=0。
- 4. 开启外部时钟模式 2, 置 TIMx SMCR 寄存器中的 ECE=1。



5. 启动计数器,置 TIMx\_CR1 寄存器中的 CEN=1。计数器在每 2 个 ETR 上升沿计数一次。在 ETR 的上升沿和计数器实际时钟之间的延时取决于在 ETRP 信号端的重新同步电路。



图 13-25 外部时钟模式 2 下的控制电路

# 13.2.4 捕获/比较通道

每一个捕获/比较通道都是围绕着一个捕获/比较寄存器(包含影子寄存器),包括捕获的输入部分(数字滤波、多路复用和预分频器),和输出部分(比较器和输出控制)。

下面几张图是一个捕获/比较通道概览。

输入部分对相应的 Tlx 输入信号采样,并产生一个滤波后的信号 TlxF。然后,一个带极性选择的边沿检测器产生一个信号(TlxFPx),它可以作为从模式控制器的输入触发或者作为捕获控制。该信号通过预分频进入捕获寄存器(ICxPS)。



图 13-26 捕获/比较通道(如:通道1输入部分)

输出部分产生一个中间波形 OCxRef(高有效)作为基准,链的末端决定最终输出信号的极性。





图 13-27 捕获/比较通道 1 的主电路



图 13-28 捕获/比较通道的输出部分(通道 1)

捕获/比较模块由一个预装载寄存器和一个影子寄存器组成。读写过程仅操作预装载寄存器。

在捕获模式下,捕获发生在影子寄存器上,然后再复制到预装载寄存器中。

在比较模式下,预装载寄存器的内容被复制到影子寄存器中,然后影子寄存器的内容和计数器进行比较。

# 13.2.5 输入捕获模式

在输入捕获模式下,当检测到 ICx 信号上相应的边沿后,计数器的当前值被锁存到捕获/比较寄存器(TIMx\_CCRx)中。当捕获事件发生时,相应的 CCxIF 标志(TIMx\_SR 寄存器)被置'1',如果使能了中断或者 DMA 操作,则将产生中断或者 DMA 操作。如果捕获事件发生时 CCxIF 标志已经为高,那么重复捕获标志 CCxOF(TIMx\_SR 寄存器)被置'1'。写 CCxIF=0 可清除 CCxIF,或读取存储在 TIMx\_CCRx 寄存器中的捕获数据也可清除 CCxIF。写 CCxOF=0 可清除 CCxOF。

以下例子说明如何在 TI1 输入的上升沿时捕获计数器的值到 TIMx CCR1 寄存器中,步骤如下:

- 1. 选择有效输入端: TIMx\_CCR1 必须连接到 TI1 输入,所以写入 TIMx\_CCR1 寄存器中的 CC1S=01,只要 CC1S 不为'00',通道被配置为输入,并且 TM1 CCR1 寄存器变为只读。
- 2. 根据输入信号的特点,配置输入滤波器为所需的带宽(即输入为 TIx 时,输入滤波器控制位是 TIMx\_CCMRx 寄存器中的 ICxF 位)。假设输入信号在最多 5 个内部时钟周期的时间内抖动,我们须配置滤波器的带宽长于 5 个时钟周期。因此可以(以 f<sub>DTS</sub> 频率)连续采样 8 次,以确认在 TI1 上一次真实的边沿变换,即在 TIMx\_CCMR1 寄存器中写入 IC1F=0011。



- 选择 TI1 通道的有效转换边沿,在 TIMx CCER 寄存器中写入 CC1P=0(上升沿)。
- 4. 配置输入预分频器。在本例中,希望捕获发生在每一个有效的电平转换时刻,因此预分频器被禁止(写 TIMx\_CCMR1 寄存器的 IC1PS=00 )。
- 5. 设置 TIMx\_CCER 寄存器的 CC1E=1,允许捕获计数器的值到捕获寄存器中。
- 6. 如果需要,通过设置 TIMx\_DIER 寄存器中的 CC1IE 位允许相关中断请求,通过设置 TIMx\_DIER 寄存器中的 CC1DE 位允许 DMA 请求。

当发生一个输入捕获时:

- 产生有效的电平转换时,计数器的值被传送到 TIMx\_CCR1 寄存器。
- CC1IF 标志被设置(中断标志)。当发生至少 2 个连续的捕获时,而 CC1IF 未曾被清除,CC1OF 也被置'1'。
- 如设置了 CC1IE 位,则会产生一个中断。
- 如设置了 CC1DE 位,则还会产生一个 DMA 请求。

为了处理捕获溢出,建议在读出捕获溢出标志之前读取数据,这是为了避免丢失在读出捕获溢出标志之后和读取数据之前可能产生的捕获溢出信息。

注意:设置 TIMx EGR 寄存器中相应的 CCxG 位,可以通过软件产生输入捕获中断和/或 DMA 请求。

# 13.2.6 PWM 输入模式

该模式是输入捕获模式的一个特例,除下列区别外,操作与输入捕获模式相同:

- 两个 ICx 信号被映射至同一个 TIx 输入。
- 这 2 个 ICx 信号为边沿有效, 但是极性相反。
- 其中一个 TIXFP 信号被作为触发输入信号,而从模式控制器被配置成复位模式。

例如,你需要测量输入到 TI1 上的 PWM 信号的长度(TIMx\_CCR1 寄存器)和占空比(TIMx\_CCR2寄存器),具体步骤如下(取决于 CK INT 的频率和预分频器的值)

- 1. 选择 TIMx CCR1 的有效输入:置 TIMx CCMR1 寄存器的 CC1S=01 (选择 TI1)。
- 2. 选择 TI1FP1 的有效极性(用来捕获数据到 TIMx\_CCR1 中和清除计数器)。置 CC1P=0(上升沿有效)。
- 3. 选择 TIMx\_CCR2 的有效输入:置 TIMx\_CCMR1 寄存器的 CC2S=10 (选择 TI1)。
- 4. 选择 TI1FP2 的有效极性(捕获数据到 TIMx CCR2); 置 CC2P=1 (下降沿有效)。
- 5. 选择有效的触发输入信号: 置 TIMx\_SMCR 寄存器中的 TS=101 (选择 TI1FP1)。
- 6. 配置从模式控制器为复位模式:置 TIMx\_SMCR 中的 SMS=100。
- 7. 使能捕获:置 TIMx\_CCER 寄存器中 CC1E=1 且 CC2E=1。





图 13-29 PWM 输入模式时序

由于只有TI1FP1和TI2FP2连到了从模式控制器,所以PWM输入模式只能使用TIMx\_CH1/TIMx\_CH2信号。

## 13.2.7 强置输出模式

在输出模式(TIMx\_CCMRx 寄存器中 CCxS=00)下,输出比较信号(OCxREF 和相应的 OCx)能够直接由软件强置为有效或无效状态,而不依赖于输出比较寄存器和计数器间的比较结果。

置 TIMx\_CCMRx 寄存器中相应的 OCxM=101,即可强置输出比较信号(OCxREF/OCx)为有效状态。这样 OCxREF 被强置为高电平(OCxREF 始终为高电平有效),同时 OCx 得到 CCxP 极性相反的值。

例如: CCxP=0(OCx 高电平有效),则 OCx 被强置为高电平。

置 TIMx CCMRx 寄存器中的 OCxM=100,可强置 OCxREF 信号为低。

该模式下,在 TIMx\_CCRx 影子寄存器和计数器之间的比较仍然在进行,相应的标志也会被修改。因此仍然会产生相应的中断和 DMA 请求。这将会在下面的输出比较模式一节中介绍。

## 13.2.8 输出比较模式

此项功能是用来控制一个输出波形,或者指示一段给定的的时间已经到时。当计数器与捕获/比较寄存器的内容相同时,输出比较功能做如下操作:

- 将输出比较模式(TIMx\_CCMRx 寄存器中的 OCxM 位)和输出极性(TIMx\_CCER 寄存器中的 CCxP 位)定义的值输出到对应的引脚上。在比较匹配时,输出引脚可以保持它的电平 (OCxM=000)、被设置成有效电平(OCxM=001)、被设置成无效电平(OCxM=010)或进行翻转(OCxM=011)。
- 设置中断状态寄存器中的标志位(TIMx SR 寄存器中的 CCxIF 位)。
- 若设置了相应的中断屏蔽(TIMx\_DIER 寄存器中的 CCXIE 位),则产生一个中断。
- 若设置了相应的使能位(TIMx\_DIER 寄存器中的 CCxDE 位,TIMx\_CR2 寄存器中的 CCDS 位选择 DMA 请求功能),则产生一个 DMA 请求。

TIMx CCMRx 中的 OCxPE 位选择 TIMx CCRx 寄存器是否需要使用预装载寄存器。

在输出比较模式下,更新事件 UEV 对 OCxREF 和 OCx 输出没有影响。

同步的精度可以达到计数器的一个计数周期。输出比较模式(在单脉冲模式下)也能用来输出一个单脉冲。

输出比较模式的配置步骤:



- 1. 选择计数器时钟(内部、外部、预分频器)。
- 2. 将相应的数据写入 TIMx ARR 和 TIMx CCRx 寄存器中。
- 3. 如果要产生一个中断请求和/或一个 DMA 请求,设置 CCxIE 位和/或 CCxDE 位。
- 4. 选择输出模式,例如当计数器 CNT 与 CCRx 匹配时翻转 OCx 的输出引脚,CCRx 预装载未用, 开启 OCx 输出且高电平有效,则必须设置 OCxM='011'、OCxPE='0'、CCxP='0'和 CCxE='1'。
- 5. 设置 TIMx\_CR1 寄存器的 CEN 位启动计数器。

TIMx\_CCRx 寄存器能够在任何时候通过软件进行更新以控制输出波形,条件是未使用预装载寄存器(OCxPE='0', 否则 TIMx\_CCRx 的影子寄存器只能在发生下一次更新事件时被更新)。下图给出了一个例子。



图 13-30 输出比较模式, 翻转 OC1

# 13.2.9 PWM 模式

脉冲宽度调制(PWM)模式可以产生一个由 TIMx\_ARR 寄存器确定频率、由 TIMx\_CCRx 寄存器确定占空比的信号。

在 TIMx\_CCMRx 寄存器中的 OCxM 位写入'110'(PWM 模式 1)或'111'(PWM 模式 2),能够独立地设置每个 OCx 输出通道产生一路 PWM。必须设置 TIMx\_CCMRx 寄存器 OCxPE 位以使能相应的预装载寄存器,最后还要设置 TIMx\_CR1 寄存器的 ARPE 位,(在向上计数或中心对称模式中)使能自动重装载的预装载寄存器。

仅当发生一个更新事件的时候,预装载寄存器才能被传送到影子寄存器,因此在计数器开始计数之前,必须通过设置 TIMx\_EGR 寄存器中的 UG 位来初始化所有的寄存器。OCx 的极性可以通过软件在 TIMx\_CCER 寄存器中的 CCxP 位设置,它可以设置为高电平有效或低电平有效。TIMx\_CCER 寄存器中的 CCxE 位控制 OCx 输出使能。详见 TIMx\_CCERx 寄存器的描述。

在 PWM 模式(模式 1 或模式 2)下,TIMx\_CNT 和 TIMx\_CCRx 始终在进行比较,(依据计数器的计数方向)以确定是否符合TIMx\_CCRx≤TIMx\_CNT 或者TIMx\_CNT≤TIMx\_CCRx。然而为了与 OCREF\_CLR 的功能(在下一个 PWM 周期之前,ETR 信号上的一个外部事件能够清除 OCxREF)一致,OCxREF 信号只能在下述条件下产生:

- 当比较的结果改变。
- 当输出比较模式(TIMx\_CCMRx 寄存器中的 OCxM 位)从"冻结"(无比较,OCxM='000')切换 到某个 PWM 模式(OCxM='110'或'111')。



这样在运行中可以通过软件强置 PWM 输出。根据 TIMx\_CR1 寄存器中 CMS 位的状态,定时器能够产生边沿对齐的 PWM 信号或中央对齐的 PWM 信号。

## 13.2.9.1 PWM 边沿对齐模式

#### 13.2.9.2 向上计数配置

当 TIMx CR1 寄存器中的 DIR 位为低的时候执行向上计数。参看章节:"计数器模式"。

下面是一个 PWM 模式 1 的例子。当 TIMx\_CNT<TIMx\_CCRx 时 PWM 参考信号 OCxREF 为高,否则为低。如果 TIMx\_CCRx 中的比较值大于自动重装载值(TIMx\_ARR),则 OCxREF 保持为'1'。如果比较值为 0,则 OCxREF 保持为'0'。下图为 TIMx ARR=8 时边沿对齐的 PWM 波形实例。



图 13-31 边沿对齐的 PWM 波形(ARR=8)

#### 13.2.9.3 向下计数的配置

当 TIMx\_CR1 寄存器的 DIR 位为高时执行向下计数。参看章节: "13.2.2.2 向下计数模式"。

在 PWM 模式 1,当 TIMx\_CNT>TIMx\_CCRx 时参考信号 OCxREF 为低,否则为高。如果 TIMx\_CCRx 中的比较值大于 TIMx ARR 中的自动重装载值,则 OCxREF 保持为'1'。该模式下不能产生 0%的 PWM 波形。

#### 13.2.9.4 PWM 中央对齐模式

当 TIMx\_CR1 寄存器中的 CMS 位不为'00'时,为中央对齐模式(所有其他的配置对 OCxREF/OCx 信号都有相同的作用)。根据不同的 CMS 位设置,比较标志可以在计数器向上计数时被置'1'、在计数器向下计数时被置'1'、或在计数器向上和向下计数时被置'1'。TIMx\_CR1 寄存器中的计数方向位(DIR)由硬件更新,不要用软件修改它。参看章节计数器模式的中央对齐模式。

下图给出了一些中央对齐的 PWM 波形的例子, 当:

- TIMx ARR=8
- PWM 模式 1
- TIMx CR1 寄存器中的 CMS=01,在中央对齐模式 1 时,当计数器向下计数时设置比较标志。





图 13-32 中央对齐的 PWM 波形 (APR=8)

#### 13.2.9.5 使用中央对齐模式的提示:

- 进入中央对齐模式时,使用当前的向上/向下计数配置;这就意味着计数器向上还是向下计数 取决于 TIMx CR1 寄存器中 DIR 位的当前值。此外,软件不能同时修改 DIR 和 CMS 位。
- 不推荐当运行在中央对齐模式时改写计数器,因为这会产生不可预知的结果。尤其是:
  - 。 如果写入计数器的值大于自动重加载的值(TIMx\_CNT>TIMx\_ARR),则方向不会被更新。 例如,如果计数器正在向上计数,它就会继续向上计数。
  - 。 如果将 0 或者 TIMx ARR 的值写入计数器,方向被更新,但不产生更新事件 UEV。
- 使用中央对齐模式最保险的方法,就是在启动计数器之前产生一个软件更新(设置 TIMx\_EGR 寄存器中的 UG 位),不要在计数进行过程中修改计数器的值。

# 13.2.10 单脉冲模式

单脉冲模式(OPM)是前述众多模式的一个特例。这种模式允许计数器响应一个激励,并在一个程序可控的延时之后,产生一个脉宽程序可控的脉冲。

可以通过从模式控制器启动计数器,在输出比较模式或者 PWM 模式下产生波形。设置TIMx\_CR1 寄存器中的 OPM 位将选择单脉冲模式,这样可以让计数器自动地在产生下一个更新事件 UEV 时停止。

仅当比较值与计数器的初始值不同时,才能产生一个脉冲。启动之前(当定时器正在等待触发), 必须如下配置:

- 向上计数方式: 计数器 CNT < CCRx ≤ ARR (特别地, 0 < CCRx),
- 向下计数方式: 计数器 CNT > CCRx。





图 13-33 单脉冲模式的例子

例如,你需要在从 TI2 输入脚上检测到一个上升沿开始,延迟 t<sub>DELAY</sub> 之后,在 OC1 上产生一个长度为 t<sub>PULSE</sub> 的正脉冲。

假定 TI2FP2 作为触发 1:

- 置 TIMx\_CCMR1 寄存器中的 CC2S='01', 把 TI2FP2 映射到 TI2。
- 置 TIMx CCER 寄存器中的 CC2P='0', 使 TI2FP2 能够检测上升沿。
- 置 TIMx SMCR 寄存器中的 TS='110', TI2FP2 作为从模式控制器的触发(TRGI)。
- 置 TIMx\_SMCR 寄存器中的 SMS='110'(触发模式), TI2FP2 被用来启动计数器。

OPM 波形由写入比较寄存器的数值决定(要考虑时钟频率和计数器预分频器)。

- t<sub>DELAY</sub> 由 TIMx CCR1 寄存器中的值定义。
- t<sub>PULSE</sub> 由自动装载值和比较值之间的差值定义(TIMx\_ARR-TIMx\_CCR1)。

假定当发生比较匹配时要产生从'0'到'1'的波形,当计数器到达预装载值时要产生一个从'1'到'0'的波形:

- 1. 首先要置 TIMx\_CCMR1 寄存器的 OC1M='111', 进入 PWM 模式 2;
- 2. 根据需要有选择地使能预装载寄存器:置 TIMx\_CCMR1 中的 OC1PE='1'和 TIMx\_CR1 寄存器中的 ARPE:
- 3. 然后在 TIMx\_CCR1 寄存器中填写比较值,在 TIMx\_ARR 寄存器中填写自动装载值,修改 UG 位来产生一个更新事件,然后等待在 TI2 上的一个外部触发事件。本例中,CC1P='0'。

在这个例子中, TIMx CR1 寄存器中的 DIR 和 CMS 位应该置低。

因为只需要一个脉冲,所以必须设置 TIMx\_CR1 寄存器中的 OPM='1', 在下一个更新事件(当计数器从自动装载值翻转到 0) 时停止计数。

#### 13.2.10.1 特殊情况: OCx 快速使能:

在单脉冲模式下,在 Tix 输入脚的边沿检测逻辑设置 CEN 位以启动计数器。然后计数器和比较值间的比较操作产生了输出的转换。但是这些操作需要一定的时钟周期,因此它限制了可得到的最小延时 $t_{DELAY}$ 。

如果要以最小延时输出波形,可以设置 TIMx\_CCMRx 寄存器中的 OCxFE 位,此时 OCxREF(和OCx)被强制响应激励而不再依赖比较的结果,输出的波形与比较匹配时的波形一样。OCxFE 只在通道配置为 PWM1 和 PWM2 模式时起作用。



## 13.2.11 在外部事件时清除 OCxREF 信号

对于一个给定的通道,设置 TIMx\_CCMRx 寄存器中对应的 OCxCE 位为'1', 能够用 ETRF 输入端的高电平把 OCxREF 信号拉低,OCxREF 信号将保持为低,直到发生下一次的更新事件 UEV。

该功能只能用于输出比较和 PWM 模式,而不能用于强置模式。

例如,OCxREF 信号可以连到一个比较器的输出,用于控制电流。这时,ETR 必须配置如下:

- 1. 外部触发预分频器必须处于关闭: TIMx SMCR 寄存器中的 ETPS[1:0]='00'。
- 2. 必须禁止外部时钟模式 2: TIMx SMCR 寄存器中的 ECE='0'。
- 3. 外部触发极性(ETP)和外部触发滤波器(ETF)可以根据需要配置。下图显示了当 ETRF 输入 变为高时,对应不同 OCxCE 的值,OCxREF 信号的变化。在这个例子中,定时器 TIMx 被置于 PWM 模式。



图 13-34 清除 TIMx 的 OCxREF

# 13.2.12 编码器接口模式

选择编码器接口模式的方法是:如果计数器只在 TI2 的边沿计数,则置 TIMx\_SMCR 寄存器中的 SMS=001;如果只在 TI1 边沿计数,则置 SMS=010;如果计数器同时在 TI1 和 TI2 边沿计数,则置 SMS=011。

通过设置 TIMx\_CCER 寄存器中的 CC1P 和 CC2P 位,可以选择 TI1 和 TI2 极性;如果需要,还可以对输入滤波器编程。

两个输入 TI1 和 TI2 被用来作为增量编码器的接口。参看表 13-1,假定计数器已经启动(TIMx\_CR1 寄存器中的 CEN='1'),则计数器由每次在 TI1FP1 或 TI2FP2 上的有效跳变驱动。TI1FP1 和 TI2FP2是 TI1 和 TI2 在通过输入滤波器和极性控制后的信号;如果没有滤波和变相,则 TI1FP1=TI1,TI2FP2=TI2。根据两个输入信号的跳变顺序,产生了计数脉冲和方向信号。依据两个输入信号的跳变顺序,计数器向上或向下计数,同时硬件对 TIMx\_CR1 寄存器的 DIR 位进行相应的设置。不管计数器是依靠 TI1 计数、依靠 TI2 计数或者同时依靠 TI1 和 TI2 计数。在任一输入端(TI1 或者TI2)的跳变都会重新计算 DIR 位。

编码器接口模式基本上相当于使用了一个带有方向选择的外部时钟。这意味着计数器只在 0 到 TIMx\_ARR 寄存器的自动装载值之间连续计数(根据方向,或是 0 到 ARR 计数,或是 ARR 到 0 计数)。所以在开始计数之前必须配置 TIMx\_ARR; 同样,捕获器、比较器、预分频器、触发输出特性等仍工作如常。

在这个模式下,计数器依照增量编码器的速度和方向被自动的修改,因此计数器的内容始终指示着编码器的位置。计数方向与相连的传感器旋转的方向对应。下表列出了所有可能的组合,假设 TI1 和 TI2 不同时变换。

向下计数

向上计数



在 TI1 和 TI2 上计数

| 有效边沿      | 相对信号的电平<br>(TI1FP1 对应 TI2, | TI1FP1 信号 |      | TI2FP2 信号 |      |  |
|-----------|----------------------------|-----------|------|-----------|------|--|
|           | TI2FP2 对应 TI1)             | 上升        | 下降   | 上升        | 下降   |  |
| 仅在 TI1 计数 | 高                          | 向下计数      | 向上计数 | 不计数       | 不计数  |  |
|           | 低                          | 向上计数      | 向下计数 | 不计数       | 不计数  |  |
| 仅在 TI2 计数 | 高                          | 不计数       | 不计数  | 向上计数      | 向下计数 |  |
|           | 低                          | 不计数       | 不计数  | 向下计数      | 向上计数 |  |

表 13-1 计数方向与编码器信号的关系

一个外部的增量编码器可以直接与 MCU 连接而不需要外部接口逻辑。但是,一般会使用比较器将编码器的差动输出转换到数字信号,这大大增加了抗噪声干扰能力。编码器输出的第三个信号表示机械零点,可以把它连接到一个外部中断输入并触发一个计数器复位。

向下计数

向上计数

向上计数

向下计数

向上计数

向下计数

下图是一个计数器操作的实例,显示了计数信号的产生和方向控制。它还显示了当选择了双边沿时,输入抖动是如何被抑制的;抖动可能会在传感器的位置靠近一个转换点时产生。在这个例子中,我们假定配置如下:

- CC1S='01'(TIMx\_CCMR1 寄存器,IC1FP1 映射到 TI1)
- CC2S='01'(TIMx\_CCMR2 寄存器,IC2FP2 映射到 TI2)
- CC1P='0' (TIMx CCER 寄存器, IC1FP1 不反相, IC1FP1=TI1)
- CC2P='0' (TIMx CCER 寄存器, IC2FP2 不反相, IC2FP2=TI2)
- SMS='011'(TIMx SMCR 寄存器,所有的输入均在上升沿和下降沿有效)
- CEN='1'(TIMx CR1 寄存器, 计数器使能)

高

低



图 13-35 编码器模式下的计数器操作实例

下图为当 IC1FP1 极性反相时计数器的操作实例(CC1P='1', 其他配置与上例相同):





图 13-36 IC1FP1 反相的编码器接口模式实例

当定时器配置成编码器接口模式时,提供传感器当前位置的信息。使用第二个配置在捕获模式的定时器,可以测量两个编码器事件的间隔,获得动态的信息(速度,加速度,减速度)。指示机械零点的编码器输出可被用做此目的。根据两个事件间的间隔,可以按照固定的时间读出计数器。如果可能的话,你可以把计数器的值锁存到第三个输入捕获寄存器(捕获信号必须是周期的并且可以由另一个定时器产生);也可以通过一个由实时时钟产生的 DMA 请求来读取它的值。

## 13.2.13 定时器输入异或功能

TIMx\_CR2 寄存器中的 Ti1S 位,允许通道 1 的输入滤波器连接到一个异或门的输出端,异或门的3 个输入端为 TIMx CH1、TIMx CH2 和 TIMx CH3。

异或输入功能能够被用于所有定时器的输入功能,如触发或输入捕获。章节"12.2.18 与霍尔传感器的接口"给出了此特性用于连接霍尔传感器的例子。

# 13.2.14 定时器和外部触发的同步

TIMx 定时器能够在多种模式下和一个外部的触发同步: 复位模式、门控模式和触发模式。

## 13.2.14.1 从模式: 复位模式

在发生一个触发输入事件时,计数器和它的预分频器能够重新被初始化;同时,如果 TIMx\_CR1寄存器的 URS 位为低,还会产生一个更新事件 UEV;然后所有的预装载寄存器(TIMx\_ARR,TIMx\_CCRx)都会被更新。

在下面的例子中, TI1 输入端的上升沿导致向上计数器被清零:

- 配置通道 1 以检测 TI1 的上升沿。配置输入滤波器的带宽(在本例中,不需要任何滤波器,因此保持 IC1F=0000)。触发操作中不使用捕获预分频器,所以不需要配置它。CC1S 位只选择输入捕获源,即 TIMx\_CCMR1 寄存器中 CC1S=01。置 TIMx\_CCER 寄存器中 CC1P=0 以确定极性(只检测上升沿)。
- 置 TIMx\_SMCR 寄存器中 SMS=100, 配置定时器为复位模式;置 TIMx\_SMCR 寄存器中TS=101,选择 TI1 作为输入源。
- 置 TIMx CR1 寄存器中 CEN=1, 启动计数器。

计数器开始依据内部时钟计数,然后正常运转直到 TI1 出现一个上升沿;此时,计数器被清零然后从 0 重新开始计数。同时,触发标志(TIMx\_SR 寄存器中的 TIF 位)被设置,根据 TIMx\_DIER 寄存器中 TIE(中断使能)位和 TDE(DMA 使能)位的设置,产生一个中断请求或一个 DMA 请求。

下图显示当自动重装载寄存器 TIMx\_ARR=0x36 时的动作。在 TI1 上升沿和计数器的实际复位之间的延时,取决于 TI1 输入端的重同步电路。





图 13-37 复位模式下的控制电路

## 13.2.14.2 从模式:门控模式

按照选中的输入端电平使能计数器。

在如下的例子中, 计数器只在 TI1 为低时向上计数:

- 配置通道 1 以检测 TI1 上的低电平。配置输入滤波器带宽(本例中,不需要滤波,所以保持 IC1F=0000)。触发操作中不使用捕获预分频器,所以不需要配置。CC1S 位用于选择输入捕获源,置 TIMx\_CCMR1 寄存器中 CC1S=01。置 TIMx\_CCER 寄存器中 CC1P=1 以确定极性(只检测低电平)。
- 置 TIMx\_SMCR 寄存器中 SMS=101,配置定时器为门控模式;置 TIMx\_SMCR 寄存器中TS=101,选择 TI1 作为输入源。
- 置 TIMx\_CR1 寄存器中 CEN=1, 启动计数器。在门控模式下,如果 CEN=0,则计数器不能启动,不论触发输入电平如何。

只要 TI1 为低,计数器开始依据内部时钟计数,在 TI1 变高时停止计数。当计数器开始或停止时都 设置 TIMx SR 中的标志。

TI1 上升沿和计数器实际停止之间的延时,取决于 TI1 输入端的重同步电路。



图 13-38 门控模式下的控制电路

#### 13.2.14.3 从模式: 触发模式

输入端上选中的事件使能计数器。

在下面的例子中, 计数器在 TI2 输入的上升沿开始向上计数:

- 配置通道 2 检测 TI2 的上升沿。配置输入滤波器带宽(本例中,不需要任何滤波器,保持 IC2F=0000)。触发操作中不使用捕获预分频器,不需要配置。CC2S 位只用于选择输入捕获源,置 TIMx\_CCMR1 寄存器中 CC2S=01。置 TIMx\_CCER 寄存器中 CC2P=1 以确定极性(只检测低电平)。
- 置 TIMx\_SMCR 寄存器中 SMS=110,配置定时器为触发模式;置 TIMx\_SMCR 寄存器中 TS=110,选择 TI2 作为输入源。当 TI2 出现一个上升沿时,计数器开始在内部时钟驱动下计



数,同时设置 TIF 标志。

TI2 上升沿和计数器启动计数之间的延时,取决于 TI2 输入端的重同步电路。



图 13-39 触发器模式下的控制电路

## 13.2.14.4 从模式:外部时钟模式 2 和触发模式

外部时钟模式 2 可以与另一种从模式(外部时钟模式 1 和编码器模式除外)一起使用。这时,ETR 信号被用作外部时钟的输入,在复位模式、门控模式或触发模式时可以选择另一个输入作为触发输入。不建议使用 TIMx SMCR 寄存器的 TS 位选择 ETR 作为 TRGI。

下面的例子中,TI1 上出现一个上升沿之后,计数器即在 ETR 的每一个上升沿向上计数一次:

- 1. 通过 TIMx\_SMCR 寄存器配置外部触发输入电路:
  - 。 ETF=0000: 没有滤波
  - 。 ETPS=00: 不用预分频器
  - 。 ETP=0: 检测 ETR 的上升沿,置 ECE=1 使能外部时钟模式
- 2. 按如下配置通道 1, 检测 TI 的上升沿:
  - 。 IC1F=0000: 没有滤波
  - 。 触发操作中不使用捕获预分频器,不需要配置
  - 。 置 TIMx CCMR1 寄存器中 CC1S=01,选择输入捕获源
  - 。 置 TIMx CCER 寄存器中 CC1P=0 以确定极性(只检测上升沿)
- 3. 置 TIMx\_SMCR 寄存器中 SMS=110, 配置定时器为触发模式。置 TIMx\_SMCR 寄存器中 TS=101, 选择 TI1 作为输入源。

当 TI1 上出现一个上升沿时,TIF 标志被设置,计数器开始在 ETR 的上升沿计数。ETR 信号的上升沿和计数器实际复位间的延时,取决于 ETRP 输入端的重同步电路。



图 13-40 外部时钟模式 2+触发模式下的控制电路



## 13.2.15 定时器同步

所有 TIMx 定时器在内部相连,用于定时器同步或链接。当一个定时器处于主模式时,它可以对另一个处于从模式的定时器的计数器进行复位、启动、停止或提供时钟等操作。

下图显示了触发选择和主模式选择模块的概况。

### 13.2.15.1 使用一个定时器作为另一个定时器的预分频器



图 13-41 主/从定时器的例子

如:可以配置定时器1作为定时器2的预分频器。参考上图,进行下述操作:

- 1. 配置定时器 1 为主模式,它可以在每一个更新事件 UEV 时输出一个周期性的触发信号。在 TIM1\_CR2 寄存器的 MMS='010'时,每当产生一个更新事件时在 TRGO1 上输出一个上升沿信 号。
- 2. 连接定时器 1 的 TRGO1 输出至定时器 2,设置 TIM2\_SMCR 寄存器的 TS='000',配置定时器 2 为使用 ITR1 作为内部触发的从模式。
- 3. 然后把从模式控制器置于外部时钟模式 1 (TIM2\_SMCR 寄存器的 SMS=111); 这样定时器 2 即可由定时器 1 周期性的上升沿(即定时器 1 的计数器溢出)信号驱动。
- 4. 最后,必须设置相应(TIMx\_CR1 寄存器)的 CEN 位分别启动两个定时器。

注意:如果OCx已被选中为定时器1的触发输出(MMS=1xx),它的上升沿用于驱动定时器2的计数器。

## 13.2.15.2 使用一个定时器使能另一个定时器

在这个例子中,定时器 2 的使能由定时器 1 的输出比较控制。参考图 13-41 的连接。只当定时器 1 的 OC1REF 为高时,定时器 2 才对分频后的内部时钟计数。两个定时器的时钟频率都是由预分频器对 CK INT 除以 3( $f_{CK\ CNT}=f_{CK\ INT}/3$ )得到。

- 1. 配置定时器 1 为主模式,送出它的输出比较参考信号(OC1REF)为触发输出(TIM1\_CR2 寄存器的 MMS=100)。
- 2. 配置定时器 1 的 OC1REF 波形 (TIM1\_CCMR1 寄存器)。
- 3. 配置定时器 2 从定时器 1 获得输入触发(TIM2 SMCR 寄存器的 TS=000)。
- 4. 配置定时器 2 为门控模式(TIM2\_SMCR 寄存器的 SMS=101)。
- 5. 置 TIM2 CR1 寄存器的 CEN=1 以使能定时器 2。
- 6. 置 TIM1 CR1 寄存器的 CEN=1 以启动定时器 1。

注意: 定时器 2 的时钟不与定时器 1 的时钟同步, 这个模式只影响定时器 2 计数器的使能信号。





图 13-42 定时器 1 的 OC1REF 控制定时器 2

在上图的例子中,在定时器 2 启动之前,它们的计数器和预分频器未被初始化,因此它们从当前的数值开始计数。可以在启动定时器 1 之前复位 2 个定时器,使它们从给定的数值开始,即在定时器计数器中写入需要的任意数值。写 TIMx\_EGR 寄存器的 UG 位即可复位定时器。

在下一个例子中,需要同步定时器 1 和定时器 2。定时器 1 是主模式并从 0 开始,定时器 2 是从模式并从 0xE7 开始; 2 个定时器的预分频器系数相同。写'0'到 TIM1\_CR1 的 CEN 位将禁止定时器 1,定时器 2 随即停止:

- 1. 配置定时器 1 为主模式,送出输出比较 1 参考信号(OC1REF)做为触发输出(TIM1\_CR2 寄存器的 MMS=100)。
- 2. 配置定时器 1 的 OC1REF 波形 (TIM1\_CCMR1 寄存器)。
- 3. 配置定时器 2 从定时器 1 获得输入触发(TIM2 SMCR 寄存器的 TS=000)。
- 4. 配置定时器 2 为门控模式 (TIM2 SMCR 寄存器的 SMS=101)。
- 5. 置 TIM1\_EGR 寄存器的 UG='1', 复位定时器 1。
- 6. 置 TIM2\_EGR 寄存器的 UG='1', 复位定时器 2。
- 7. 写'0xE7'至定时器 2 的计数器 (TIM2 CNTL), 初始化它为 0xE7。
- 8. 置 TIM2\_CR1 寄存器的 CEN='1'以使能定时器 2。
- 9. 置 TIM1 CR1 寄存器的 CEN='1'以启动定时器 1。
- 10. 置 TIM1 CR1 寄存器的 CEN='0'以停止定时器 1。





图 13-43 通过使能定时器 1 可以控制定时器 2

## 13.2.15.3 使用一个定时器去启动另一个定时器

在这个例子中,使用定时器 1 的更新事件使能定时器 2。参考图 13-41 的连接。一旦定时器 1 产生更新事件,定时器 2 即从它当前的数值(可以是非 0)按照分频的内部时钟开始计数。在收到触发信号时,定时器 2 的 CEN 位被自动地置'1',同时计数器开始计数直到写'0'到 TIM2\_CR1 寄存器的 CEN 位。两个定时器的时钟频率都是由预分频器对 CK\_INT 除以 3( $f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{CK_CNT}=f_{$ 

- 1. 配置定时器 1 为主模式,送出它的更新事件(UEV)做为触发输出(TIM1\_CR2 寄存器的 MMS=010)。
- 2. 配置定时器 1 的周期(TIM1 ARR 寄存器)。
- 3. 配置定时器 2 从定时器 1 获得输入触发(TIM2 SMCR 寄存器的 TS=000)。
- 4. 配置定时器 2 为触发模式(TIM2 SMCR 寄存器的 SMS=110)。
- 5. 置 TIM1\_CR1 寄存器的 CEN=1 以启动定时器 1。



图 13-44 使用定时器 1 的更新触发定时器 2

在上一个例子中,可以在启动计数之前初始化两个计数器。下图显示在与 0 相同配置情况下,使用触发模式而不是门控模式(TIM2\_SMCR 寄存器的 SMS=110)的动作。





图 13-45 利用定时器 1 的使能触发定时器 2

### 13.2.15.4 使用一个外部触发同步地启动 2 个定时器

这个例子中当定时器 1 的 TI1 输入上升时使能定时器 1,使能定时器 1 的同时使能定时器 2,参见图 13-41。为保证计数器的对齐,定时器 1 必须配置为主/从模式(对应 TI1 为从,对应定时器 2 为主):

- 1. 配置定时器 1 为主模式,送出它的使能做为触发输出(TIM1\_CR2 寄存器的 MMS='001')。
- 2. 配置定时器 1 为从模式,从 TI1 获得输入触发(TIM1 SMCR 寄存器的 TS='100')。
- 3. 配置定时器 1 为触发模式(TIM1\_SMCR 寄存器的 SMS='110')。
- 4. 配置定时器 1 为主/从模式, TIM1\_SMCR 寄存器的 MSM='1'。
- 5. 配置定时器 2 从定时器 1 获得输入触发(TIM2 SMCR 寄存器的 TS=000)。
- 6. 配置定时器 2 为触发模式(TIM2 SMCR 寄存器的 SMS='110')。

当定时器 1 的 TI1 上出现一个上升沿时,两个定时器同步地按照内部时钟开始计数,两个 TIF 标志也同时被设置。

注意:在这个例子中,在启动之前两个定时器都被初始化(设置相应的 UG 位),两个计数器都从 0 开始,但可以通过写入任意一个计数器寄存器(TIMx\_CNT)在定时器间插入一个偏移。下图中能看到 主/ 从模式下在定时器 1 的 CNT EN 和 CK PSC 之间有个延迟。





图 13-46 使用定时器 1 的 TI1 输入触发定时器 1 和定时器 2

# 13.2.16 调试模式

当微控制器进入调试模式(Cortex-M3 核心停止),根据 DBG 模块中 DBG\_TIMx\_STOP 的设置,TIMx 计数器或者继续正常操作,或者停止。详见随后章节:支持定时器、看门狗、bxCAN 和 I2C 的调试。

# 13.3 TIMx 寄存器(x=2, 3, 4)

基地址: (TIM2, TIM3, TIM4) = (0x4000 0000, 0x4000 0400, 0x4000 0800)

空间大小: (TIM2, TIM3, TIM4) = (0x400, 0x400, 0x400)

可以用半字(16位)或字(32位)的方式操作这些外设寄存器。

# 13.3.1 控制寄存器 1 (TIMx\_CR1)

地址偏移: 0x00 复位值: 0x0000

| 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8     | 7                 | 6  | 5   | 4   | 3   | 2    | 1   | 0 |
|----|----|----|----|----|----|-----|-------|-------------------|----|-----|-----|-----|------|-----|---|
|    |    | R  | es |    |    | CKD | [1:0] | :0] ARPE CMS[1:0] |    | DIR | OPM | URS | UDIS | CEN |   |
|    |    |    | r  | w  | rw | r   | w     | rw                | rw | rw  | rw  | rw  |      |     |   |

| 位 15:10 | Res: 保留<br>必须保持复位值。                           |
|---------|-----------------------------------------------|
| 位 9:8   | CKD[1:0]: 时钟分频因子(Clock division)              |
| 位 7     | ARPE: 自动重装载预装载允许位(Auto-reload preload enable) |



- 0: TIMx ARR 寄存器没有缓冲
- 1: TIMx ARR 寄存器被装入缓冲器

## 位 6:5 CMS[1:0]: 选择中央对齐模式(Center-aligned mode selection)

• 00: 边沿对齐模式

计数器依据方向位(DIR)向上或向下计数。

• 01: 中央对齐模式 1

计数器交替地向上和向下计数。配置为输出的通道(TIMx\_CCMRx 寄存器中 CCxS=00)的输出比较中断标志位,只在计数器向下计数时被设置。

• 10: 中央对齐模式 2

计数器交替地向上和向下计数。配置为输出的通道(TIMx\_CCMRx 寄存器中 CCxS=00)的输出比较中断标志位,只在计数器向上计数时被设置。

• 11: 中央对齐模式 3

计数器交替地向上和向下计数。配置为输出的通道(TIMx\_CCMRx 寄存器中 CCxS=00)的输出比较中断标志位,在计数器向上和向下计数时均被设置。

注意: 在计数器开启时(CEN=1),不允许从边沿对齐模式转换到中央对齐模式。

#### 位 4 DIR: 方向 (Direction)

- 0: 计数器向上计数
- 1: 计数器向下计数

注意: 当计数器配置为中央对齐模式或编码器模式时,该位为只读。

#### 位 3 OPM: 单脉冲模式 (One pulse mode)

- 0: 在发生更新事件时, 计数器不停止
- 1: 在发生下一次更新事件(清除 CEN 位)时,计数器停止。

#### 位 2 URS: 更新请求源(Update request source)

软件通过该位选择 UEV 事件的源。

- 0: 如果使能了更新中断或 DMA 请求,则下述任一事件产生更新中断或 DMA 请求:
  - o 计数器溢出/下溢
  - o 设置 UG 位
  - o 从模式控制器产生的更新
- 1: 如果使能了更新中断或 DMA 请求,则只有计数器溢出/下溢才产生更新中断或 DMA 请求。

#### 位 1 UDIS: 禁止更新 (Update disable)

软件通过该位允许/禁止 UEV 事件的产生。

• 0: 允许 UEV

更新(UEV)事件由下述任一事件产生:

- o 计数器溢出/下溢
- o 设置 UG 位
- o 从模式控制器产生的更新

具有缓存的寄存器被装入它们的预装载值。



|     | • 1: 禁止 UEV 不产生更新事件,影子寄存器(ARR、PSC、CCRx)保持它们的值。如果设置了 UG 位或 从模式控制器发出了一个硬件复位,则计数器和预分频器被重新初始化。                                                |
|-----|-------------------------------------------------------------------------------------------------------------------------------------------|
| 位 0 | CEN: 使能计数器(Counter enable)  • 0: 禁止计数器  • 1: 使能计数器  注意: 在软件设置了CEN 位后,外部时钟、门控模式和编码器模式才能工作。触发模式可以自动地通过硬件设置CEN 位。在单脉冲模式下,当发生更新事件时,CEN 被自动清除。 |

# 13.3.2 控制寄存器 2(TIMx\_CR2)

地址偏移: 0x04 复位值: 0x0000

| 15  | 14 | 13 | 12 | 11 | 10 | 9    | 8             | 7 | 6  | 5 | 4   | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|------|---------------|---|----|---|-----|---|---|---|---|
| Res |    |    |    |    |    | TI1S | MMS[2:0] CCDS |   |    |   | Res |   |   |   |   |
|     |    |    |    |    |    |      | rw            |   | rw |   | rw  |   |   |   |   |

|        |                                                                                                                                                                                                                                                                                                                                                                   | rw                                                                                                            | rw                                                                 | rw           |                                                                           |
|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|--------------|---------------------------------------------------------------------------|
| 位 15:8 | Res: 保留<br>必须保持复位值。                                                                                                                                                                                                                                                                                                                                               |                                                                                                               |                                                                    |              |                                                                           |
| 位 7    | TI1S: TI1 选择(TI1 selection)  • 0: TIMx_CH1 引脚连到 TI1 输入。  • 1: TIMx_CH1、TIMx_CH2 和 TIMx_CH2 见上一章与霍尔传感器的接口一节。                                                                                                                                                                                                                                                       | I3 引財                                                                                                         | 经异或后连到 TI1 \$                                                      | 俞入。          |                                                                           |
| 位 6:4  | <ul> <li>MMS[2:0]: 主模式选择(Master mode</li> <li>这3位用于选择在主模式下送到从定</li> <li>可能的组合如下:</li> <li>000: 复位 TIMX_EGR 寄存器的 UG 位被用于作 (从模式控制器处于复位模式),则</li> <li>001: 使能 计数器使能信号 CNT_EN 被用于作为 定时器或控制在一段时间内使能从定式下的触发输入信号的"或"逻辑产生上会有一个延迟,除非选择了主/从描述)。</li> <li>010: 更新 更新事件被选为触发输入(TRGO)。 器的预分频器。</li> <li>011: 比较脉冲 在发生一次捕获或一次比较成功时,输出送出一个正脉冲(TRGO)。</li> <li>100: 比较</li> </ul> | 时<br>为<br>TRGO<br>会<br>大<br>大<br>大<br>大<br>大<br>大<br>大<br>大<br>大<br>大<br>大<br>大<br>大<br>大<br>大<br>大<br>大<br>大 | 可用步信息(TRGO)。如<br>计的信号相对实际的<br>计数器使能信号是<br>计数器使能信号受<br>(见下章"TIMx_SM | 果是位 需通控 CR 钟 | 高有一个延迟。<br>同一时间启动多个<br>EN 控制位和门控模<br>发输入时,TRGO<br>字器"中 MSM 位的<br>被用作一个从定时 |



|       | OC1REF 信号被用于作为触发输出(TRGO)。  • 101: 比较                                                  |
|-------|---------------------------------------------------------------------------------------|
|       | OC2REF 信号被用于作为触发输出(TRGO)。  • 110: 比较                                                  |
|       | OC3REF 信号被用于作为触发输出(TRGO)。                                                             |
|       | • 111: 比较 OC4REF 信号被用于作为触发输出(TRGO)。                                                   |
| 位 3   | CCDS: 捕获/比较的 DMA 选择(Capture/Compare DMA selection)  • 0: 当发生 CCx 事件时,送出 CCx 的 DMA 请求; |
|       | • 1: 当发生更新事件时,送出 CCx 的 DMA 请求。                                                        |
| 位 2:0 | Res: 保留<br>必须保持复位值。                                                                   |

# 13.3.3 从模式控制寄存器(TIMx\_SMCR)

10 9

地址偏移: 0x08 复位值: 0x0000

14

13

12

|      | '                                                                                                                          |                                                                                                                        |          |         | , |         |     |          |  |  |  |
|------|----------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|----------|---------|---|---------|-----|----------|--|--|--|
| ETP  | ECE                                                                                                                        | ETPS[1:0]                                                                                                              | ETF[3:0] | MSM     |   | TS[2:0] | Res | SMS[2:0] |  |  |  |
| rw   | rw                                                                                                                         | rw                                                                                                                     | rw       | rw rw   |   |         |     |          |  |  |  |
| 位 15 |                                                                                                                            | ETP: 外部触发极性(External trigger polarity) 该位选择是用 ETR 还是 ETR 的反相来作为触发操作。  • 0: ETR 不反相,高电平或上升沿有效。  • 1: ETR 被反相,低电平或下降沿有效。 |          |         |   |         |     |          |  |  |  |
| 位 14 |                                                                                                                            | 该位启用外部 • 0: 禁止外部 • 1: 使能外部 注意: • 设置 ECE 位                                                                              |          | ETRF 信· |   |         |     |          |  |  |  |
|      | 功效。 • 下述从模式可以与外部时钟模式 2 同时使用: 复位模式、门控模式和触发模式是, 这时 TRGI 不能连到 ETRF (TS 位不能是'111')。 • 外部时钟模式 1 和外部时钟模式 2 同时被使能时,外部时钟的输入是 ETRF。 |                                                                                                                        |          |         |   |         |     |          |  |  |  |
| 位 13 | :12                                                                                                                        | ETPS[1:0]: 外部触发预分频(External trigger prescaler) 外部触发信号 ETRP 的频率必须最多是 CK_INT 频率的 1/4。当输入较快的外部时钟时,可                       |          |         |   |         |     |          |  |  |  |

• 00: 关闭预分频

• 01: ETRP 频率除以 2

以使用预分频降低 ETRP 的频率。



| ן ליבוי אטייל שלער |                                                                                                                                                                                                                                                                                                                                                                 |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | <ul> <li>10: ETRP 频率除以 4</li> <li>11: ETRP 频率除以 8</li> </ul>                                                                                                                                                                                                                                                                                                    |
|                    |                                                                                                                                                                                                                                                                                                                                                                 |
| 位 11:8             | ETF[3:0]: 外部触发滤波(External trigger filter) 该位域定义了对 ETRP 信号采样的频率和对 ETRP 数字滤波的带宽。实际上,数字滤波器是一个事件计数器,它记录到 N 个事件后会产生一个输出的跳变。                                                                                                                                                                                                                                          |
|                    | <ul> <li>0111: 采样频率 fsampling=fdts/4, N=8</li> <li>1000: 采样频率 fsampling=fdts/8, N=6</li> <li>1001: 采样频率 fsampling=fdts/8, N=8</li> <li>1010: 采样频率 fsampling=fdts/16, N=5</li> <li>1011: 采样频率 fsampling=fdts/16, N=6</li> <li>1100: 采样频率 fsampling=fdts/16, N=8</li> <li>1110: 采样频率 fsampling=fdts/32, N=6</li> <li>1111: 采样频率 fsampling=fdts/32, N=8</li> </ul> |
| 位 7                | MSM: 主/从模式(Master/Slave mode)  • 0: 无作用  • 1: 触发输入(TRGI)上的事件被延迟了,以允许在当前定时器(通过 TRGO)与它的从定时器间的美同步。这对要求把几个定时器同步到一个单一的外部事件时是非常有用的。                                                                                                                                                                                                                                  |
| 位 6:4              | TS[2:0]: 触发选择(Trigger selection) 这 3 位选择用于同步计数器的触发输入。                                                                                                                                                                                                                                                                                                           |
| 位 3                | Res: 保留<br>必须保持复位值。                                                                                                                                                                                                                                                                                                                                             |



#### 位 2:0 SMS[2:0]: 从模式选择(Slave mode selection)

当选择了外部信号,触发信号(TRGI)的有效边沿与选中的外部输入极性相关(见输入控制寄存器和控制寄存器的说明)。

• 000: 关闭从模式

如果 CEN=1,则预分频器直接由内部时钟驱动。

• 001: 编码器模式 1

根据 TI1FP1 的电平, 计数器在 TI2FP2 的边沿向上/下计数。

• 010: 编码器模式 2

根据 TI2FP2 的电平, 计数器在 TI1FP1 的边沿向上/下计数。

• 011: 编码器模式 3

根据另一个信号的输入电平,计数器在 TI1FP1 和 TI2FP2 的边沿向上/下计数。

• 100: 复位模式

选中的触发输入(TRGI)的上升沿重新初始化计数器,并且产生一个更新寄存器的信号。

• 101: 门控模式

当触发输入(TRGI)为高时,计数器的时钟开启。一旦触发输入变为低,则计数器停止 (但不复位)。计数器的启动和停止都是受控的。

• 110: 触发模式

计数器在触发输入 TRGI 的上升沿启动(但不复位),只有计数器的启动是受控的。

• 111: 外部时钟模式 1

选中的触发输入(TRGI)的上升沿驱动计数器。

注意:如果TI1F\_EN 被选为触发输入(TS=100)时,不要使用门控模式。这是因为,TI1F\_ED 在每次TI1F 变化时输出一个脉冲,然而门控模式是要检查触发输入的电平。

#### 表 13-2 TIMx 内部触发连接

| 从定时器 | ITRO (TS=000) | ITR1 (TS=001) | ITR2 (TS=010) | ITR3 (TS=011) |
|------|---------------|---------------|---------------|---------------|
| TIM2 | TIM1          | _             | TIM3          | TIM4          |
| TIM3 | TIM1          | TIM2          | _             | TIM4          |
| TIM4 | TIM1          | TIM2          | TIM3          | _             |

# 13.3.4 DMA/中断使能寄存器(TIMx DIER)

地址偏移: 0x0C 复位值: 0x0000

| 15  | 14  | 13  | 12    | 11    | 10    | 9     | 8   | 7   | 6   | 5   | 4     | 3     | 2     | 1     | 0   |
|-----|-----|-----|-------|-------|-------|-------|-----|-----|-----|-----|-------|-------|-------|-------|-----|
| Res | TDE | Res | CC4DE | CC3DE | CC2DE | CC1DE | UDE | Res | TIE | Res | CC4IE | CC3IE | CC2IE | CC1IE | UIE |
|     | rw  |     | rw    | rw    | rw    | rw    | rw  |     | rw  |     | rw    | rw    | rw    | rw    | rw  |

| 位 15 | Res: 保留<br>必须保持复位值。                          |
|------|----------------------------------------------|
| 位 14 | TDE: 允许触发 DMA 请求(Trigger DMA request enable) |



|      | <ul><li>0: 禁止触发 DMA 请求</li><li>1: 允许触发 DMA 请求</li></ul>                                                           |
|------|-------------------------------------------------------------------------------------------------------------------|
| 位 13 | Res: 保留<br>必须保持复位值。                                                                                               |
| 位 12 | CC4DE:允许捕获/比较 4 的 DMA 请求(Capture/Compare 4 DMA request enable)  • 0:禁止捕获/比较 4 的 DMA 请求  • 1:允许捕获/比较 4 的 DMA 请求    |
| 位 11 | CC3DE:允许捕获/比较 3 的 DMA 请求(Capture/Compare 3 DMA request enable)  • 0:禁止捕获/比较 3 的 DMA 请求  • 1:允许捕获/比较 3 的 DMA 请求    |
| 位 10 | CC2DE: 允许捕获/比较 2 的 DMA 请求(Capture/Compare 2 DMA request enable)  • 0: 禁止捕获/比较 2 的 DMA 请求  • 1: 允许捕获/比较 2 的 DMA 请求 |
| 位 9  | CC1DE:允许捕获/比较 1 的 DMA 请求(Capture/Compare 1 DMA request enable)  • 0:禁止捕获/比较 1 的 DMA 请求  • 1:允许捕获/比较 1 的 DMA 请求    |
| 位 8  | UDE: 允许更新的 DMA 请求(Update DMA request enable)  • 0: 禁止更新的 DMA 请求  • 1: 允许更新的 DMA 请求                                |
| 位 7  | Res: 保留<br>必须保持复位值。                                                                                               |
| 位 6  | TIE: 触发中断使能(Trigger interrupt enable)  • 0: 禁止触发中断  • 1: 使能触发中断                                                   |
| 位 5  | Res: 保留<br>必须保持复位值。                                                                                               |
| 位 4  | CC4IE: 允许捕获/比较 4 中断(Capture/Compare 4 interrupt enable)  • 0: 禁止捕获/比较 4 中断  • 1: 允许捕获/比较 4 中断                     |
| 位 3  | CC3IE:允许捕获/比较 3 中断(Capture/Compare 3 interrupt enable)  • 0:禁止捕获/比较 3 中断  • 1:允许捕获/比较 3 中断                        |
| 位 2  | CC2IE: 允许捕获/比较 2 中断(Capture/Compare 2 interrupt enable)  • 0: 禁止捕获/比较 2 中断                                        |



|     | • 1: 允许捕获/比较 2 中断                                                                             |
|-----|-----------------------------------------------------------------------------------------------|
| 位 1 | CC1IE: 允许捕获/比较 1 中断(Capture/Compare 1 interrupt enable)  • 0: 禁止捕获/比较 1 中断  • 1: 允许捕获/比较 1 中断 |
| 位 0 | UIE: 允许更新中断(Update interrupt enable)  • 0: 禁止更新中断  • 1: 允许更新中断                                |

# 13.3.5 状态寄存器(TIMx\_SR)

地址偏移: 0x10 复位值: 0x0000

| 15 | 14  | 13 | 12    | 11    | 10    | 9     | 8  | 7  | 6     | 5   | 4     | 3     | 2     | 1     | 0     |
|----|-----|----|-------|-------|-------|-------|----|----|-------|-----|-------|-------|-------|-------|-------|
|    | Res |    | CC4OF | CC3OF | CC2OF | CC1OF | Re | :S | TIF   | Res | CC4IF | CC3IF | CC2IF | CC1IF | UIF   |
|    |     |    | rc_w0 | rc_w0 | rc_w0 | rc_w0 |    |    | rc_w0 |     | rc_w0 | rc_w0 | rc_w0 | rc_w0 | rc_w0 |

| 位 15:13 | Res: 保留<br>必须保持复位值。                                                                                                                                            |
|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 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)仅当相应的通道被配置为输入捕获时,该标志可由硬件置'1'。写'0'可清除该位。 • 0: 无重复捕获产生。 • 1: 当计数器的值被捕获到 TIMx_CCR1 寄存器时,CC1IF 的状态已经为'1'。 |
| 位 8:7   | Res: 保留<br>必须保持复位值。                                                                                                                                            |
| 位 6     | TIF: 触发器中断标志(Trigger interrupt flag)<br>当发生触发事件(当从模式控制器处于除门控模式外的其它模式时,在 TRGI 输入端检测<br>到有效边沿,或门控模式下的任一边沿)时由硬件对该位置'1'。它由软件清零。<br>• 0: 无触发器事件产生<br>• 1: 触发器中断等待响应 |
| 位 5     | Res: 保留<br>必须保持复位值。                                                                                                                                            |



| 位 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 描述。                                                                                                                                                                                                                                                       |
| 位 1 | CC1IF: 捕获/比较 1 中断标志(Capture/Compare 1 interrupt flag)  • 如果通道 CC1 配置为输出模式: 当计数器值与比较值匹配时该位由硬件置'1',但在中心对称模式下除外(参考TIMx_CR1 寄存器的 CMS 位)。它由软件清零。  • 0: 无匹配发生  • 1: TIMx_CNT 的值与 TIMx_CCR1 的值匹配  • 如果通道 CC1 配置为输入模式: 当捕获事件发生时该位由硬件置'1',它由软件清零或通过读 TIMx_CCR1 清零。  • 0: 无输入捕获产生  • 1: 计数器值已被捕获(拷贝)至 TIMx_CCR1(在 IC1 上检测到与所选极性相同的边沿) |
| 位 0 | UIF: 更新中断标志(Update interrupt flag)  • 当产生更新事件时该位由硬件置'1'。它由软件清零。  • 0: 无更新事件产生  • 1: 更新中断等待响应  • 当寄存器被更新时该位由硬件置'1':  • 若 TIMx_CR1 寄存器的 UDIS=0、URS=0,当 TIMx_EGR 寄存器的 UG=1 时产生更新事件(软件对计数器 CNT 重新初始化)。  • 若 TIMx_CR1 寄存器的 UDIS=0、URS=0,当计数器 CNT 被触发事件重初始化时产生更新事件(参考同步控制寄存器的说明)。                                                 |

# 13.3.6 事件产生寄存器(TIMx\_EGR)

地址偏移: 0x14 复位值: 0x0000

| Ī | 15 | 14 | 13 | 12 | 11   | 10 | 9 | 8 | 7 | 6  | 5     | 4   | 3    | 2   | 1   | 0  |
|---|----|----|----|----|------|----|---|---|---|----|-------|-----|------|-----|-----|----|
| ŀ |    |    |    |    | Res  |    |   |   |   | TG | Res   | CC4 | CC3G | CC2 | CC1 | UG |
|   |    |    |    |    | 1103 |    |   |   |   |    | 11.03 | G   | 0000 | G   | G   |    |
| - |    |    |    |    |      |    |   |   |   | w  |       | w   | w    | w   | w   | w  |

| 位 15:7 | Res: 保留<br>必须保持复位值。                                            |
|--------|----------------------------------------------------------------|
| 位 6    | TG:产生触发事件(Trigger generation)<br>该位由软件置'1',用于产生一个触发事件,由硬件自动清零。 |



| ו לים אטינשער |                                                                                                                                                                                                                                                                                                                                                                       |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | • 0:无动作 • 1: TIMx_SR 寄存器的 TIF=1,若开启对应的中断和 DMA,则产生相应的中断和 DMA。                                                                                                                                                                                                                                                                                                          |
| 位 5           | Res: 保留<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)该位由软件置'1',用于产生一个捕获/比较事件,由硬件自动清零。  • 0: 无动作  • 1: 在通道 CC1 上产生一个捕获/比较事件:  。 若通道 CC1 配置为输出:  设置 CC1IF=1,若开启对应的中断和 DMA,则产生相应的中断和 DMA。  • 若通道 CC1 配置为输入:  当前的计数器值捕获至 TIMx_CCR1 寄存器;设置 CC1IF=1,若开启对应的中断和 DMA,则产生相应的中断和 DMA,则产生相应的中断和 DMA,则产生相应的中断和 DMA,则产生相应的中断和 DMA,则产生相应的中断和 DMA,则产生相应的中断和 DMA。若 CC1IF 已经为 1,则设置 CC1OF=1。 |
| 位 0           | UG: 产生更新事件(Update generation) 该位由软件置'1',由硬件自动清零。  • 0: 无动作  • 1: 重新初始化计数器,并产生一个更新事件。 注意预分频器的计数器也被清零(但是预分频系数不变)。  • 若在中心对称模式下或 DIR=0(向上计数)则计数器被清零。  • 若 DIR=1(向下计数)则计数器取 TIMx_ARR 的值。                                                                                                                                                                                  |

# 13.3.7 捕获/比较模式寄存器 1(TIMx\_CCMR1)

地址偏移: 0x18 复位值: 0x0000

通道可用于输入(捕获模式)或输出(比较模式),通道的方向由相应的 CCxS 定义。该寄存器其它位的作用在输入和输出模式下不同。OCxx 描述了通道在输出模式下的功能,ICxx 描述了通道在输入模式下的功能。因此必须注意,同一个位在输出模式和输入模式下的功能是不同的。

| 15        | 14 | 13   | 12    | 11     | 10    | 9    | 8     | 7      | 6         | 5  | 4     | 3      | 2     | 1    | 0     |
|-----------|----|------|-------|--------|-------|------|-------|--------|-----------|----|-------|--------|-------|------|-------|
| OC2CE     | 00 | 2M[2 | :0]   | OC2PE  | OC2FE | CC2S | [1:0] | OC1CE  | OC1M[2:0] |    |       | OC1PE  | OC1FE | CC1S | [1:0] |
| IC2F[3:0] |    |      | IC2PS | C[1:0] |       |      | 10    | C1F[3: | 0]        |    | IC1PS | C[1:0] |       |      |       |
| rw        | rw | rw   | rw    | rw     | rw    | r    | W     | rw     | rw        | rw | rw    | rw     | rw    | r    | w     |

输出比较模式:



| 位 15    | OC2CE:输出比较 2 清零使能(Output compare 2 clear enable)<br>参见 OC1CE 的描述。                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 14:12 | OC2M[2:0]: 输出比较 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[1:0]: 捕获/比较 2 选择(Capture/Compare 2 selection)该位定义通道的方向(输入/输出),及输入脚的选择:  • 00: CC2 通道被配置为输出。  • 01: CC2 通道被配置为输入,IC2 映射在 TI2 上。  • 10: CC2 通道被配置为输入,IC2 映射在 TI1 上。  • 11: CC2 通道被配置为输入,IC2 映射在 TRC 上。  此模式仅工作在内部触发器输入被选中时(由 TIMx_SMCR 寄存器的 TS 位选择)。  注意: CC2S 仅在通道关闭时(TIMx_CCER 寄存器的 CC2E='0')才是可写的。                                                                                                                                                                            |
| 位 7     | OC1CE:输出比较 1 清零使能(Output compare 1 clear enable)  • 0: OC1REF 不受 ETRF 输入的影响。  • 1: 一旦检测到 ETRF 输入高电平,清除 OC1REF=0。                                                                                                                                                                                                                                                                                                                                                                    |
| 位 6:4   | OC1M[2:0]: 输出比较 1 模式(Output compare 1 mode) 该 3 位定义了输出参考信号 OC1REF 的动作,而 OC1REF 决定了 OC1 的值。OC1REF 是高电平有效,而 OC1 的有效电平取决于 CC1P 位。 • 000: 冻结 输出比较寄存器 TIMx_CCR1 与计数器 TIMx_CNT 间的比较对 OC1REF 不起作用。 • 001: 匹配时设置通道 1 为有效电平 当计数器 TIMx_CNT 的值与捕获/比较寄存器 1(TIMx_CCR1)相同时,强制 OC1REF 为高。 • 010: 匹配时设置通道 1 为无效电平 当计数器 TIMx_CNT 的值与捕获/比较寄存器 1(TIMx_CCR1)相同时,强制 OC1REF 为低。 • 011: 翻转 当 TIMx_CCR1 时间的电平。 • 100: 强制为无效电平。强制 OC1REF 为低。 • 101: 强制为有效电平。强制 OC1REF 为高。 • 110: PWM 模式 1 在向上计数时,一旦 TIMx_CNT |



• 111: PWM 模式 2

在向上计数时,一旦  $TIMx\_CNT < TIMx\_CCR1$  时通道 1 为无效电平,否则为有效电平;在向下计数时,一旦  $TIMx\_CNT > TIMx\_CCR1$  时通道 1 为有效电平,否则为无效电平。

注意: 在PWM 模式1、2 时,仅在比较结果发生改变或输出比较模式从 Frozen 切换到 PWM 模式时 OCREF 才改变。

- 位 3 OC1PE: 输出比较 1 预装载使能(Output compare 1 preload enable)
  - 0: 禁止 TIMx\_CCR1 寄存器的预装载功能,可随时写入 TIMx\_CCR1 寄存器,并且新写入的数值立即起作用。
  - 1: 开启 TIMx\_CCR1 寄存器的预装载功能,读写操作仅对预装载寄存器操作, TIMx CCR1 的预装载值在更新事件到来时被传送至当前寄存器中。

注:

- 一旦 LOCK 级别设为3(TIMx\_BDTR 寄存器中的 LOCK 位)并且 CC1S='00'(该通道配置成输出)则该位不能被修改。
- 仅在单脉冲模式下(TIMx\_CR1 寄存器的 OPM='1'),可以在未确认预装载寄存器情况 下使用 PWM 模式,否则其动作不确定。
- 位 2 OC1FE: 输出比较 1 快速使能(Output compare 1 fast enable)

该位用于加快 CC 输出对触发器输入事件的响应。

- 0: 根据计数器与 CCR1 的值, CC1 正常操作,即使触发器是打开的。当触发器的输入 出现一个有效沿时,激活 CC1 输出的最小延时为 5 个时钟周期。
- 1: 输入到触发器的有效沿的作用就像发生了一次比较匹配。因此,OC 被设置为比较电平而与比较结果无关。采样触发器的有效沿和 CC1 输出间的延时被缩短为 3 个时钟周期。

该位只在通道被配置成 PWM1 或 PWM2 模式时起作用。

位 1:0 CC1S[1:0]: 捕获/比较 1 选择(Capture/Compare 1 selection)

这 2 位定义通道的方向(输入/输出),及输入脚的选择:

- 00: CC1 通道被配置为输出。
- 01: CC1 通道被配置为输入, IC1 映射在 TI1 上。
- 10: CC1 通道被配置为输入, IC1 映射在 TI2 上。
- 11: CC1 通道被配置为输入,IC1 映射在 TRC 上。

此模式仅工作在内部触发器输入被选中时(由 TIMx SMCR 寄存器的 TS 位选择)。

注意: CC1S 仅在通道关闭时(TIMx CCER 寄存器的CC1E='0')才是可写的。

#### 输入捕获模式:

| 位 15:12 | IC2F[3:0]: 输入捕获 2 滤波器(Input capture 2 filter)                                   |
|---------|---------------------------------------------------------------------------------|
| 位 11:10 | IC2PSC[1:0]: 输入/捕获 2 预分频器(Input capture 2 prescaler)                            |
| 位 9:8   | CC2S[1:0]: 捕获/比较 2 选择(Capture/Compare 2 selection) 这 2 位定义通道的方向(输入/输出),及输入脚的选择: |



- 10: CC2 通道被配置为输入, IC2 映射在 TI1 上。
- 11: CC2 通道被配置为输入, IC2 映射在 TRC 上。

此模式仅工作在内部触发器输入被选中时(由TIMx SMCR 寄存器的 TS 位选择)。

注意: CC2S 仅在通道关闭时(TIMx CCER 寄存器的CC2E='0')才是可写的。

#### 位 7:4 IC1F[3:0]: 输入捕获 1 滤波器(Input capture 1 filter)

这几位定义了 TI1 输入的采样频率及数字滤波器长度。数字滤波器由一个事件计数器组成,它记录到 N 个事件后会产生一个输出的跳变:

- 0000: 无滤波器,以 fprs 采样
- 0001: 采样频率 fsampling=fck int, N=2
- 0010: 采样频率 fsampling=fck int, N=4
- 0011: 采样频率 fsampling=fck int, N=8
- 0100: 采样频率 fsampung=fpts/2, N=6
- 0101: 采样频率 fsampling=fdts/2, N=8
- 0110: 采样频率 fsampling=fpts/4, N=6
- 0111: 采样频率 fsampung=fpts/4, N=8
- 1000: 采样频率 fsampling=fpts/8, N=6
- 1001: 采样频率 fsampling=fpts/8, N=8
- 1010: 采样频率 fsampling=fpts/16, N=5
- 1011: 采样频率 fsampling=fpts/16, N=6
- 1100: 采样频率 fsampling=fdts/16, N=8
- 1101: 采样频率 fsampling=fdts/32, N=5
- 1110: 采样频率 fsampling=fdts/32, N=6
- 1111: 采样频率 fsampling=fdts/32, N=8

注意: 在现在的芯片版本中, 当 ICxF[3:0]=1、2 或 3 时, 公式中的 fors 由 CK\_INT 替代。

#### 位 3:2 IC1PSC[1:0]: 输入/捕获 1 预分频器(Input capture 1 prescaler)

这 2 位定义了 CC1 输入(IC1)的预分频系数。一旦 CC1E='0'(TIMx\_CCER 寄存器中),则预分频器复位。

- 00: 无预分频器, 捕获输入口上检测到的每一个边沿都触发一次捕获
- 01: 每 2 个事件触发一次捕获
- 10: 每 4 个事件触发一次捕获
- 11: 每8个事件触发一次捕获

#### 位 1:0 CC1S[1:0]: 捕获/比较 1 选择(Capture/Compare 1 selection)

这 2 位定义通道的方向(输入/输出),及输入脚的选择:

- 00: CC1 通道被配置为输出。
- 01: CC1 通道被配置为输入, IC1 映射在 TI1 上。
- 10: CC1 通道被配置为输入, IC1 映射在 TI2 上。
- 11: CC1 通道被配置为输入, IC1 映射在 TRC 上。

此模式仅工作在内部触发器输入被选中时(由TIMx\_SMCR 寄存器的 TS 位选择)。

注意: CC1S 仅在通道关闭时(TIMx CCER 寄存器的CC1E='0')才是可写的。



# 13.3.8 捕获/比较模式寄存器 2(TIMx\_CCMR2)

地址偏移: 0x1C 复位值: 0x0000

参看以上 CCMR1 寄存器的描述

| 15        | 14 | 13   | 12    | 11     | 10    | 9    | 8     | 7      | 6         | 5  | 4     | 3      | 2     | 1    | 0     |
|-----------|----|------|-------|--------|-------|------|-------|--------|-----------|----|-------|--------|-------|------|-------|
| OC4CE     | 00 | 4M[2 | :0]   | OC4PE  | OC4FE | CC4S | [1:0] | OC3CE  | OC3M[2:0] |    |       | OC3PE  | OC3FE | CC3S | [1:0] |
| IC4F[3:0] |    |      | IC4PS | C[1:0] |       |      | I     | C3F[3: | 0]        |    | IC3PS | C[1:0] |       |      |       |
| rw        | rw | rw   | rw    | rw     | rw    | r    | W     | rw     | rw        | rw | rw    | rw     | rw    | r۱   | W     |

#### 输出比较模式:

| 位 15    | OC4CE: 输出比较 4 清零使能(Output compare 4 clear enable)<br>参见 OC1CE 的描述。                                                                                                                                                                                                                                        |
|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 14:12 | OC4M[2:0]:输出比较 4 模式(Output compare 4 mode)<br>参见 OC1M 的描述。                                                                                                                                                                                                                                                |
| 位 11    | OC4PE:输出比较 4 预装载使能(Output compare 4 preload enable)<br>参见 OC1PE 的描述。                                                                                                                                                                                                                                      |
| 位 10    | OC4FE:输出比较 4 快速使能(Output compare 4 fast enable)<br>参见 OC1FE 的描述。                                                                                                                                                                                                                                          |
| 位 9:8   | CC4S[1:0]: 捕获/比较 4 选择(Capture/Compare 4 selection)这 2 位定义通道的方向(输入/输出),及输入脚的选择:  • 00: CC4 通道被配置为输出。  • 01: CC4 通道被配置为输入,IC4 映射在 TI4 上。  • 10: CC4 通道被配置为输入,IC4 映射在 TI3 上。  • 11: CC4 通道被配置为输入,IC4 映射在 TRC 上。 此模式仅工作在内部触发器输入被选中时(由 TIMx_SMCR 寄存器的 TS 位选择)。 注意: CC4S 仅在通道关闭时(TIMx_CCER 寄存器的 CC4E='0')才是可写的。 |
| 位 7     | OC3CE: 输出比较 3 清零使能(Output compare 3 clear enable)<br>参见 OC1CE 的描述。                                                                                                                                                                                                                                        |
| 位 6:4   | OC3M[2:0]:输出比较 3 模式(Output compare 3 mode)<br>参见 OC1M 的描述。                                                                                                                                                                                                                                                |
| 位 3     | OC3PE:输出比较 3 预装载使能(Output compare 3 preload enable)<br>参见 OC1PE 的描述。                                                                                                                                                                                                                                      |
| 位 2     | OC3FE: 输出比较 3 快速使能(Output compare 3 fast enable)<br>参见 OC1FE 的描述。                                                                                                                                                                                                                                         |
| 位 1:0   | CC3S[1:0]: 捕获/比较 3 选择(Capture/Compare 3 selection)         这 2 位定义通道的方向(输入/输出),及输入脚的选择:                                                                                                                                                                                                                   |



- 00: CC3 通道被配置为输出。
- 01: CC3 通道被配置为输入, IC3 映射在 TI3 上。
- 10: CC3 通道被配置为输入, IC3 映射在 TI4 上。
- 11: CC3 通道被配置为输入,IC3 映射在 TRGI 上。

此模式仅工作在内部触发器输入被选中时(由 TIMx SMCR 寄存器的 TS 位选择)。

注意: CC3S 仅在通道关闭时(TIMx\_CCER 寄存器的 CC3E='0')才是可写的。

#### 输入捕获模式:

| 位 15:12 | IC4F[3:0]: 输入捕获 4 滤波器(Input capture 4 filter)                                                                                                                                                                                                                                                             |
|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 11:10 | IC4PSC[1:0]: 输入/捕获 4 预分频器(Input capture 4 prescaler)                                                                                                                                                                                                                                                      |
| 位 9:8   | CC4S[1:0]: 捕获/比较 4 选择(Capture/Compare 4 selection)这 2 位定义通道的方向(输入/输出),及输入脚的选择:  • 00: CC4 通道被配置为输出。  • 01: CC4 通道被配置为输入,IC4 映射在 TI4 上。  • 10: CC4 通道被配置为输入,IC4 映射在 TI3 上。  • 11: CC4 通道被配置为输入,IC4 映射在 TRC 上。此模式仅工作在内部触发器输入被选中时(由 TIMx_SMCR 寄存器的 TS 位选择)。  注意: CC4S 仅在通道关闭时(TIMx_CCER 寄存器的 CC4E='0')才是可写的。 |
| 位 7:4   | IC3F[3:0]: 输入捕获 3 滤波器(Input capture 3 filter)                                                                                                                                                                                                                                                             |
| 位 3:2   | IC3PSC[1:0]: 输入/捕获 3 预分频器(Input capture 3 prescaler)                                                                                                                                                                                                                                                      |
| 位 1:0   | CC3S[1:0]: 捕获/比较 3 选择(Capture/Compare 3 selection) 这 2 位定义通道的方向(输入/输出),及输入脚的选择:                                                                                                                                                                                                                           |

# 13.3.9 捕获/比较使能寄存器(TIMx\_CCER)

地址偏移: 0x20 复位值: 0x0000

| 15 | 14  | 13   | 12   | 11    | 10  | 9    | 8    | 7     | 6   | 5    | 4    | 3     | 2   | 1    | 0    |
|----|-----|------|------|-------|-----|------|------|-------|-----|------|------|-------|-----|------|------|
| F  | les | CC4P | CC4E | CC3NP | Res | CC3P | CC3E | CC2NP | Res | CC2P | CC2E | CC1NP | Res | CC1P | CC1E |
|    |     | rw   | rw   | rw    |     | rw   | rw   | rw    |     | rw   | rw   | rw    |     | rw   | rw   |

位 15:14

Res: 保留

必须保持复位值。



| 位 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>用于输入双沿触发,详细的参考 CC1P 的描述。                                                                                                                                                                                                                                                                                                       |
| 位 10 | Res: 保留<br>必须保持复位值。                                                                                                                                                                                                                                                                                                                                                     |
| 位 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>用于输入双沿触发,详细的参考 CC1P 的描述。                                                                                                                                                                                                                                                                                                          |
| 位 6  | Res: 保留<br>必须保持复位值。                                                                                                                                                                                                                                                                                                                                                     |
| 位 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>用于输入双沿触发,详细的参考 CC1P 的描述。                                                                                                                                                                                                                                                                                                          |
| 位 2  | Res: 保留<br>必须保持复位值。                                                                                                                                                                                                                                                                                                                                                     |
| 位 1  | <ul> <li>CC1P: 捕捉/比较 1 输出极性(Capture/Compare 1 output polarity)</li> <li>CC1 通道配置为输出: <ul> <li>0: OC1 高电平有效;</li> <li>1: OC1 低电平有效。</li> </ul> </li> <li>CC1 通道配置为输入: <ul> <li>CC1P 和 CC1NP 组成两位控制来选择 TI1FP1 和 TI2FP1 的激活极性:</li> <li>00: 没有翻转/上升沿</li> <li>电路对 TIxFP1 的上升沿敏感(捕获或触发操作复位,外部时钟或触发模式),TIxFP1 没有翻转(触发操作在门控或编码模式)。</li> <li>01: 翻转/下降沿</li> </ul> </li> </ul> |



电路对 TIxFP1 的下降沿敏感(捕获或触发操作复位,外部时钟或触发模式),TIxFP1 翻转(触发操作在门控或编码模式)。

- o 10: 保留
- o 11: 没有翻转/双沿

电路对 TIxFP1 的上升沿和下降沿敏感(捕获或触发操作复位,外部时钟或触发模式), TIxFP1 没有翻转(触发操作在门控模式)。这个配置不能用在编码模式。

#### 注意:

- 在具有互补输出的通道上,此位是预加载的。如果 CCPC 位是在 TIMx\_CR2 寄存器中设置,CC1P 仅在通讯事件产生时加载新的值。
- 一旦 LOCK 级别(TIMx\_BDTR 寄存器中的 LOCK 位)设为 3 或 2 ,则该位不能被修 改。

位 0 CC1E: 捕获/比较 1 输出使能(Capture/Compare 3 output enable)

- CC1 通道配置为输出:
  - o 0: 关闭

OC1 禁止输出。

- o 1: 开启
  - OC1 信号输出到对应的输出引脚。
- CC1 通道配置为输入:

该位决定了计数器的值是否能捕获入 TIMx\_CCR1 寄存器。

- o 0: 捕获禁止;
- o 1: 捕获使能。

注意:在具有互补输出的通道上,此位是预加载的。如果 CCPC 位是在 TIMx\_CR2 寄存器中设置, CC1E 仅在通讯事件产生时加载新的值。

表 13-3 标准 OCx 通道的输出控制位

| CCxE 位 | OCx 输出状态                |
|--------|-------------------------|
| 0      | 禁止输出(OCx=0,OCx_EN=0)    |
| 1      | OCx=OCxREF +极性,OCx_EN=1 |

注意: 连接到标准OCx 通道的外部I/O 引脚状态, 取决于OCx 通道状态和GPIO 以及AFIO 寄存器。

## 13.3.10 计数器寄存器(TIMx\_CNT)

地址偏移: 0x24 复位值: 0x0000

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

位 15:0 CNT[15:0]: 计数器的值(Counter value high bits of TIMx)

# 13.3.11 预分频器寄存器(TIMx\_PSC)

地址偏移: 0x28



复位值: 0x0000

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

位 15:0

PSC[15:0]: 预分频器的值(Prescaler value)

计数器的时钟频率  $CK_CNT$  等于  $f_{CK_PSC}/(PSC[15:0]+1)$ 。 PSC 包含了当更新事件产生时 装入当前预分频器寄存器的值。

## 13.3.12 自动重装载寄存器(TIMx\_ARR)

地址偏移: 0x2C 复位值: 0xFFFF

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

位 15:0

ARR[15:0]: 自动重装载的值(Auto-reload value)

ARR 包含了将要传送至实际的自动重装载寄存器的数值。详细参考章节有关 ARR 的更新和动作。当自动重装载的值为空时,计数器不工作。

## 13.3.13 捕获/比较寄存器 1(TIMx\_CCR1)

地址偏移: 0x34 复位值: 0x0000

| 15 | 14         | 13 | 12 | 11 | 10 | 9  | 8    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|------------|----|----|----|----|----|------|---|---|---|---|---|---|---|---|
|    | CCR1[15:0] |    |    |    |    |    |      |   |   |   |   |   |   |   |   |
|    |            |    |    |    |    | rv | v/ro |   |   |   |   |   |   |   |   |

位 15:0

CCR1[15:0]: 捕获/比较 1 的值(Capture/Compare 1 value)

• 若 CC1 通道配置为输出:

CCR1 包含了装入当前捕获/比较 1 寄存器的值(预装载值)。

如果在 TIMx\_CCMR1 寄存器(OC1PE 位)中未选择预装载特性,写入的数值会被立即传输至当前寄存器中。否则只有当更新事件发生时,此预装载值才传输至当前捕获/比较 1 寄存器中。当前捕获/比较寄存器参与同计数器 TIMx\_CNT 的比较,并在OC1 端口上产生输出信号。

• 若 CC1 通道配置为输入:

CCR1 包含了由上一次输入捕获 1 事件(IC1)传输的计数器值。CCR1 是只读寄存器。

# 13.3.14 捕获/比较寄存器 2(TIMx\_CCR2)

地址偏移: 0x38 复位值: 0x0000

| 15 | 14         | 13 | 12 | 11 | 10 | 9  | 8    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|------------|----|----|----|----|----|------|---|---|---|---|---|---|---|---|
|    | CCR2[15:0] |    |    |    |    |    |      |   |   |   |   |   |   |   |   |
|    |            |    |    |    |    | rw | v/ro |   |   |   |   |   |   |   |   |



#### 位 15:0

CCR2[15:0]: 捕获/比较 2 的值(Capture/Compare 2 value)

• 若 CC2 通道配置为输出:

CCR2 包含了装入当前捕获/比较 2 寄存器的值(预装载值)。

如果在 TIMx\_CCMR2 寄存器(OC2PE 位)中未选择预装载特性,写入的数值会被立即传输至当前寄存器中。否则只有当更新事件发生时,此预装载值才传输至当前捕获/比较 2 寄存器中。当前捕获/比较寄存器参与同计数器 TIMx\_CNT 的比较,并在OC2 端口上产生输出信号。

• 若 CC2 通道配置为输入:

CCR2 包含了由上一次输入捕获 2 事件(IC2)传输的计数器值。CCR2 是只读寄存器。

# 13.3.15 捕获/比较寄存器 3(TIMx\_CCR3)

地址偏移: 0x3C 复位值: 0x0000

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

#### 位 15:0

CCR3[15:0]: 捕获/比较 3 的值(Capture/Compare 3 value)

• 若 CC3 通道配置为输出:

CCR3 包含了装入当前捕获/比较 3 寄存器的值(预装载值)。

如果在 TIMx\_CCMR3 寄存器(OC3PE 位)中未选择预装载特性,写入的数值会被立即传输至当前寄存器中。否则只有当更新事件发生时,此预装载值才传输至当前捕获/比较 3 寄存器中。当前捕获/比较寄存器参与同计数器 TIMx\_CNT 的比较,并在 OC3 端口上产生输出信号。

• 若 CC3 通道配置为输入:

CCR3 包含了由上一次输入捕获 3 事件(IC3)传输的计数器值。CCR3 是只读寄存器。

# 13.3.16 捕获/比较寄存器 4(TIMx\_CCR4)

地址偏移: 0x40 复位值: 0x0000

| 15 14 13 12 11 10 9 8 |            |  |  |  |  |    |      |  | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----------------------|------------|--|--|--|--|----|------|--|---|---|---|---|---|---|---|
|                       | CCR4[15:0] |  |  |  |  |    |      |  |   |   |   |   |   |   |   |
|                       |            |  |  |  |  | rv | v/ro |  |   |   |   |   |   |   |   |

#### 位 15:0

CCR4[15:0]: 捕获/比较 4 的值(Capture/Compare 4 value)

• 若 CC4 通道配置为输出:

CCR4 包含了装入当前捕获/比较 4 寄存器的值(预装载值)。

如果在 TIMx\_CCMR4 寄存器(OC4PE 位)中未选择预装载特性,写入的数值会被立即传输至当前寄存器中。否则只有当更新事件发生时,此预装载值才传输至当前捕获/比较 4 寄存器中。当前捕获/比较寄存器参与同计数器 TIMx\_CNT 的比较,并在 OC4 端口上产生输出信号。



• 若 CC4 通道配置为输入: CCR4 包含了由上一次输入捕获 4 事件(IC4)传输的计数器值。CCR4 是只读寄存器。

# 13.3.17 DMA 控制寄存器(TIMx\_DCR)

地址偏移: 0x48 复位值: 0x0000

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

|         | rw                                                                                                                                                               | rw            |
|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 位 15:13 | Res: 保留<br>必须保持复位值。                                                                                                                                              |               |
| 位 12:8  | DBL[4:0]: DMA 连续传送长度(DMA burst length) 该位域定义了 DMA 在连续模式下的传送长度(当对 TIMx_DMA 时器则进行一次连续传送),即: 定义传输的字节数目:                                                             | R 寄存器进行读或写时,定 |
| 位 7:5   | Res: 保留<br>必须保持复位值。                                                                                                                                              |               |
| 位 4:0   | DBA[4:0]: DMA 基地址(DMA base address) 该位域定义了 DMA 在连续模式下的基地址(当对 TIMx_DMA DBA 定义为从 TIMx_CR1 寄存器所在地址开始的偏移量:  • 00000: TIMx_CR1  • 00001: TIMx_CR2  • 00010: TIMx_SMCR | R 寄存器进行读或写时), |

# 13.3.18 连续模式的 DMA 地址寄存器(TIMx\_DMAR)

地址偏移: 0x4C 复位值: 0x0000

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

位 15:0 DMAB[15:0]: DMA 连续传送寄存器(DMA register for burst accesses)
对 TIMx\_DMAR 寄存器的读或写会导致对以下地址所在寄存器的存取操作:
(TIMx\_CR1 地址)+(DBA +DMA 索引)X4,其中:



- TIMx\_CR1 地址是控制寄存器 1(TIMx\_CR1)所在的地址。
- DBA 是 TIMx\_DCR 寄存器中定义的基地址。
- DMA 索引是由 DMA 自动控制的偏移量,它取决于 TIMx\_DCR 寄存器中定义的 DBL。



## 14 实时时钟(RTC)

实时时钟是一个独立的定时器。RTC 模块拥有一组连续计数的计数器,在相应软件配置下,可提供时钟日历的功能。修改计数器的值可以重新设置系统当前的时间和日期。

RTC 模块和时钟配置系统(RCC\_BDCR 寄存器)处于备份区域,即在系统复位或从待机模式唤醒后,RTC 的设置和时间维持不变。

系统复位后,对备份寄存器和 RTC 的访问被禁止,这是为了防止对备份区域(BKP)的意外写操作。 执行以下操作将使能对备份寄存器和 RTC 的访问:

- 设置寄存器 RCC APB1ENR 的 PWREN 和 BKPEN 位,使能电源和备份接口时钟。
- 设置寄存器 PWR CR 的 DBP 位,使能对备份寄存器和 RTC 的访问。

## 14.1 主要特性

- 可编程的预分频系数:分频系数最高为 2<sup>20</sup>。
- 32 位的可编程计数器,可用于较长时间段的测量。
- 2 个独立的时钟: 用于 APB1 接口的 PCLK1 和 RTC 时钟(RTC 时钟的频率必须小于 PCLK1 时钟 频率的四分之一以上)。
- 可以选择以下三种 RTC 的时钟源:
  - 。 HSE 时钟除以 128
  - 。 LSE 振荡器时钟
  - 。 LSI 振荡器时钟(详见章节: "7.2.8 RTC 时钟"。)
- 2个独立的复位类型:
  - APB1 接口由系统复位
  - RTC 核心(预分频器、闹钟、计数器和分频器)只能由备份域复位(详见章节: "7.1.3 备份域复位")
- 3个专门的可屏蔽中断:
  - 。 闹钟中断,用来产生一个软件可编程的闹钟中断。
  - 。 秒中断,用来产生一个可编程的周期性中断信号(最长可达1秒)。
  - 。 溢出中断,指示内部可编程计数器溢出并回转为0的状态。

## 14.2 功能描述

### 14.2.1 概述

RTC 由两个主要部分组成(参见下图)。

- 第一部分为 APB1 接口,用来和 APB1 总线相连。此单元还包含一组 16 位寄存器,可通过 APB1 总线对其进行读写操作(参见章节:"14.3 RTC 寄存器")。APB1 接口由 APB1 总线时钟驱动,用来与 APB1 总线接口。
- 另一部分为 RTC 核心,由一组可编程计数器组成,分成两个主要模块:
  - 。 第一个模块是 RTC 的预分频模块,它可编程产生周期最长为 1 秒的 RTC 时间基准 TR\_CLK。 RTC 的预分频模块包含了一个 20 位的可编程分频器(RTC 预分频器)。如果在 RTC\_CR 寄存器中设置了相应的允许位,则在每个TR CLK 周期中,RTC 产生一个中断(秒中断)。
  - 。 第二个模块是一个 32 位的可编程计数器,可被初始化为当前的系统时间。系统时间按 TR\_CLK 周期累加并与存储在 RTC\_ALR 寄存器中的可编程时间相比较,如果 RTC\_CR 控制寄存器中设置了相应允许位,比较匹配时将产生一个闹钟中断。





图 14-1 简化的 RTC 框图

### 14.2.2 复位过程

除了 RTC\_PRL、RTC\_ALR、RTC\_CNT 和 RTC\_DIV 寄存器外,所有的系统寄存器都由系统复位或电源复位进行异步复位。

RTC\_PRL、RTC\_ALR、RTC\_CNT 和 RTC\_DIV 寄存器仅能通过备份域复位信号复位,详见章节: "7.1.3 备份域复位"。

## 14.2.3 读 RTC 寄存器

RTC 核完全独立于 RTC APB1 接口。软件通过 APB1 接口访问 RTC 的预分频值、计数器值和闹钟值。但是,相关的可读寄存器只在与 RTC APB1 时钟进行重新同步的 RTC 时钟的上升沿被更新。RTC 标志也是如此的。

这意味着,如果 APB1 接口曾经被关闭,而读操作又是在刚刚重新开启 APB1 接口之后,在第一次的内部寄存器更新之前,那么从 APB1 上读出的 RTC 寄存器数值可能被破坏了(通常读到 0)。下述几种情况下能够发生这种情形:

- 发生系统复位或电源复位
- 系统刚从待机模式唤醒(参见:"低功耗模式")。
- 系统刚从停机模式唤醒(参见:"低功耗模式")。

所有以上情况中,当 APB1 接口被禁止时(复位、无时钟或断电),RTC 核仍保持运行状态。

因此,在读取 RTC 寄存器时,如果 RTC 的 APB1 接口曾被禁止,那么软件首先必须等待 RTC\_CRL 寄存器中的 RSF 位(寄存器同步标志)被硬件置'1'。

注意: RTC 的 APB1 接口不受 WFI 和 WFE 等低功耗模式的影响。

#### 14.2.4 配置 RTC 寄存器

必须先设置RTC\_CRL 寄存器中的CNF 位,使RTC 进入配置模式后,才能写入RTC\_PRL、RTC\_CNT、



RTC ALR 寄存器。

另外,对RTC任何寄存器的写操作,都必须在前一次写操作结束后再进行。可以通过查询RTC\_CR 寄存器中的 RTOFF 状态位,判断 RTC 寄存器是否处于更新中。只有当 RTOFF 状态位是'1'时,才可以写入 RTC 寄存器。

#### 配置过程:

- 1. 查询 RTOFF 位, 直到 RTOFF 的值变为'1'。
- 2. 置 CNF 值为 1, 进入配置模式。
- 3. 对一个或多个 RTC 寄存器进行写操作。
- 4. 清除 CNF 标志位,退出配置模式。
- 5. 查询 RTOFF, 直至 RTOFF 位变为'1'以确认写操作已经完成。

只有当 CNF 标志位被清除时,写操作才能进行,这个过程至少需要 3 个 RTCCLK 周期。

## 14.2.5 RTC 标志的设置

在每一个 RTC 核的时钟周期中,在更改 RTC 计数器之前,RTC 秒标志(SECF)被设置。在计数器到达 0x0000 之前的最后一个 RTC 时钟周期中,设置 RTC 溢出标志(OWF)。

在计数器的值到达闹钟寄存器的值加 1(RTC\_ALR+1)之前的最后一个 RTC 时钟周期中,设置 RTC\_Alarm 和 RTC 闹钟标志(ALRF)。对 RTC 闹钟的写操作必须使用下述过程之一与 RTC 秒标志(SECF)同步:

- 使用 RTC 闹钟中断,并在中断处理程序中修改 RTC 闹钟和/或 RTC 计数器。
- 等待 RTC 控制寄存器中的 SECF 位被设置,再更改 RTC 闹钟和/或 RTC 计数器。



图 14-2 RTC 秒和闹钟波形图示例, PR=0003, ALARM=00004



图 14-3 RTC 溢出波形图示例, PR=0003

# 14.3 RTC 寄存器

基地址: 0x4000 2800



空间大小: 0x400

可以用半字(16位)或字(32位)的方式操作这些外设寄存器。

## 14.3.1 RTC 控制寄存器高位(RTC\_CRH)

偏移地址: 0x00 复位值: 0x0000

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

| 位 15:3 | Res: 保留<br>必须保持复位值。                                                     |
|--------|-------------------------------------------------------------------------|
| 位 2    | OWIE: 允许溢出中断位(Overflow interrupt enable)  • 0: 屏蔽(不允许)溢出中断  • 1: 允许溢出中断 |
| 位 1    | ALRIE: 允许闹钟中断(Alarm interrupt enable)  • 0: 屏蔽(不允许)闹钟中断  • 1: 允许闹钟中断    |
| 位 0    | SECIE: 允许秒中断(Second interrupt enable)  • 0: 屏蔽(不允许)秒中断  • 1: 允许秒中断      |

这些位用来屏蔽中断请求。

注意:系统复位后所有的中断被屏蔽,因此可通过写RTC 寄存器来确保在初始化后没有挂起的中断请求。当外设正在完成前一次写操作时(标志位RTOFF=0),不能对RTC\_CRH 寄存器进行写操作。RTC 功能由这个控制寄存器控制。一些位的写操作必须经过一个特殊的配置过程来完成(详见"14.2.4 配置 RTC 寄存器")。

# 14.3.2 RTC 控制寄存器低位(RTC\_CRL)

偏移地址: 0x04 复位值: 0x0020

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5     | 4   | 3     | 2     | 1     | 0     |
|----|----|----|----|----|----|---|---|---|---|-------|-----|-------|-------|-------|-------|
|    |    |    |    | Re | es |   |   |   |   | RTOFF | CNF | RSF   | OWF   | ALRF  | SECF  |
|    |    |    |    |    |    |   |   |   |   | r     | rw  | rc w0 | rc w0 | rc w0 | rc w0 |

| 位 15:6 | Res: 保留<br>必须保持复位值。                                                                                                                         |
|--------|---------------------------------------------------------------------------------------------------------------------------------------------|
| 位 5    | RTOFF: RTC 操作关闭(RTC operation OFF) RTC 模块利用这位来指示对其寄存器进行的最后一次操作的状态,指示操作是否完成。若此位为'0',则表示无法对任何的 RTC 寄存器进行写操作。此位为只读位。 • 0: 上一次对 RTC 寄存器的写操作仍在进行 |



|     | • 1: 上一次对 RTC 寄存器的写操作已经完成                                                                                                                                                                                                                 |
|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 4 | CNF: 配置标志(Configuration flag)<br>此位必须由软件置'1'以进入配置模式,从而允许向 RTC_CNT、RTC_ALR 或 RTC_PRL 寄存器<br>写入数据。只有当此位在被置'1'并重新由软件清零后,才会执行写操作。<br>• 0: 退出配置模式(开始更新 RTC 寄存器)<br>• 1: 进入配置模式                                                                 |
| 位 3 | RSF: 寄存器同步标志(Registers synchronized flag)<br>每当 RTC_CNT 寄存器和 RTC_DIV 寄存器由软件更新或清零时,此位由硬件置'1'。在 APB1<br>复位后,或 APB1 时钟停止后,此位必须由软件清零。要进行任何的读操作之前,用户程<br>序必须等待这位被硬件置'1',以确保 RTC_CNT、RTC_ALR 或 RTC_PRL 已经被同步。<br>• 0: 寄存器尚未被同步<br>• 1: 寄存器已经被同步 |
| 位 2 | OWF: 溢出标志(Overflow flag)<br>当 32 位可编程计数器溢出时,此位由硬件置'1'。如果 RTC_CRH 寄存器中 OWIE=1,则产生中断。此位只能由软件清零。对此位写'1'是无效的。<br>• 0: 无溢出<br>• 1: 32 位可编程计数器溢出                                                                                                |
| 位 1 | ALRF: 闹钟标志(Alarm flag)<br>当 32 位可编程计数器达到 RTC_ALR 寄存器所设置的预定值,此位由硬件置'1'。如果<br>RTC_CRH 寄存器中 ALRIE=1,则产生中断。此位只能由软件清零。对此位写'1'是无效的。<br>• 0: 无闹钟<br>• 1: 有闹钟                                                                                     |
| 位 0 | SECF: 秒标志(Second flag)<br>当 32 位可编程预分频器溢出时,此位由硬件置'1'同时 RTC 计数器加 1。因此,此标志为<br>分辨率可编程的 RTC 计数器提供一个周期性的信号(通常为 1 秒)。如果 RTC_CRH 寄存器<br>中 SECIE=1,则产生中断。此位只能由软件清除。对此位写'1'是无效的。<br>• 0: 秒标志条件不成立<br>• 1: 秒标志条件成立                                 |

RTC 的功能由这个控制寄存器控制。当前一个写操作还未完成时(RTOFF=0 时,详见: "14.2.4 配置 RTC 寄存器"),不能写 RTC\_CR 寄存器。

#### 注意:

- 任何标志位都将保持挂起状态,直到适当的 RTC\_CR 请求位被软件复位,表示所请求的中断已 经被接受。
- 在复位时禁止所有中断,无挂起的中断请求,可以对RTC 寄存器进行写操作。
- 当APB1 时钟不运行时,OWF、ALRF、SECF 和 RSF 位不被更新。
- OWF、ALRF、SECF 和 RSF 位只能由硬件置位,由软件来清零。
- 若 ALRF=1 且 ALRIE=1,则允许产生 RTC 全局中断。如果在 EXTI 控制器中允许产生 EXTI 线 17 中断,则允许产生 RTC 全局中断和 RTC 闹钟中断。



• 若ALRF=1,如果在EXTI 控制器中设置了EXTI 线17 的中断模式,则允许产生RTC 闹钟中断;如果在EXTI 控制器中设置了EXTI 线17 的事件模式,则这条线上会产生一个脉冲(不会产生RTC 闹钟中断)。

# 14.3.3 RTC 预分频装载寄存器(RTC\_PRLH/RTC\_PRLL)

预分频装载寄存器用来保存RTC预分频器的周期计数值。它们受RTC\_CR寄存器的RTOFF位写保护,仅当RTOFF值为'1'时允许进行写操作。

#### 14.3.3.1 RTC 预分频装载寄存器高位(RTC PRLH)

偏移地址: 0x08 复位值: 0x0000

只写(参见"14.2.4 配置 RTC 寄存器")

| 15    | 14 | 13                      | 12                | 11            | 10              | 9           | 8      | 7      | 6                          |     |     |     |       |        |  |  |  |  |  |  |  |
|-------|----|-------------------------|-------------------|---------------|-----------------|-------------|--------|--------|----------------------------|-----|-----|-----|-------|--------|--|--|--|--|--|--|--|
|       |    |                         |                   |               | Re              | es          |        |        |                            |     |     |     | PRL[1 | L9:16] |  |  |  |  |  |  |  |
|       |    |                         |                   |               |                 |             |        |        |                            |     |     |     | ١     | N      |  |  |  |  |  |  |  |
| 位 15  | :4 |                         | s:保旨              | -             | Ĺo              |             |        |        |                            |     |     |     |       |        |  |  |  |  |  |  |  |
| 位 3:0 | 0  | 根:<br>f <sub>TR</sub> _ | 据以下<br>clk=frtcci | 公式,<br>k/(PRL | 该位均<br>[19:0]+1 | <b>戊</b> 结合 | RTC_PF | RLL 用多 | orescaler<br>来定义记<br>可产生 R | 十数器 | 的时钟 | 频率: |       |        |  |  |  |  |  |  |  |

#### 14.3.3.2 RTC 预分频装载寄存器低位(RTC\_PRLL)

偏移地址: 0x0C 复位值: 0x8000

只写(参见:"14.2.4 配置 RTC 寄存器")

| 15   | 14 | 13 | 12 | 11  | 10 | 9 | 8    | 7     | 6                     | 5 | 4 | 3 | 2   | 1             | 0       |
|------|----|----|----|-----|----|---|------|-------|-----------------------|---|---|---|-----|---------------|---------|
|      |    |    |    |     |    |   | PRL[ | 15:0] |                       |   |   |   |     |               |         |
|      |    |    |    |     |    |   | ١    | v     |                       |   |   |   |     |               |         |
| 位 15 | :0 | 根  |    | 公式, | 该位 |   |      |       | escaler r<br>PRL[19:1 |   |   |   | 时钟频 | 〔率 <b>:</b> f | TR_CLK= |

注意:如果输入时钟频率是 32.768kHz(f<sub>RTCCLK</sub>),这个寄存器中写入 7FFFh 可获得周期为 1 秒钟的信号。

# 14.3.4 RTC 预分频器余数寄存器(RTC\_DIVH/RTC\_DIVL)

在 TR\_CLK 的每个周期里,RTC 预分频器中计数器的值都会被重新设置为 RTC\_PRL 寄存器的值。用户可通过读取 RTC\_DIV 寄存器,获得预分频计数器的当前值,而不停止分频计数器的工作,从而获得精确的时间测量。此寄存器是只读寄存器,其值在 RTC\_PRL 或 RTC\_CNT 寄存器中的值发生改变后,由硬件重新装载。



#### 14.3.4.1 RTC 预分频器余数寄存器高位(RTC\_DIVH)

偏移地址: 0x10 复位值: 0x0000

| 15 | 14  | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1        | 0 |
|----|-----|----|----|----|----|---|---|---|---|---|---|---|---|----------|---|
|    | Res |    |    |    |    |   |   |   |   |   |   |   |   | /[19:16] |   |
|    |     |    |    |    |    |   |   |   |   |   |   |   |   | r        |   |

| 位 15:4 | Res: 保留<br>必须保持复位值。                                   |
|--------|-------------------------------------------------------|
| 位 3:0  | RTC_DIV[19:16]: RTC 时钟分频器余数高位(RTC clock divider high) |

#### 14.3.4.2 RTC 预分频器余数寄存器低位(RTC DIVL)

偏移地址: 0x14 复位值: 0x8000

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

位 15:0

RTC DIV[15:0]: RTC 时钟器余数低位(RTC clock divider low)

## 14.3.5 RTC 计数器寄存器(RTC\_CNTH/RTC\_CNTL)

RTC 核有一个 32 位可编程的计数器,可通过两个 16 位的寄存器访问。计数器以预分频器产生的TR\_CLK时间基准为参考进行计数。RTC\_CNT寄存器用来存放计数器的计数值。它们受RTC\_CR 的位RTOFF写保护,仅当RTOFF 值为'1'时,允许写操作。在高或低寄存器(RTC\_CNTH 或RTC\_CNTL)上的写操作,能够直接装载到相应的可编程计数器,并且重新装载RTC 预分频器。当进行读操作时,直接返回计数器内的计数值(系统时间)。

#### 14.3.5.1 RTC 计数器寄存器高位(RTC\_CNTH)

偏移地址: 0x18 复位值: 0x0000

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8       | 7        | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---------|----------|---|---|---|---|---|---|---|
|    |    |    |    |    |    |   |         |          | - |   |   | - | _ | _ | - |
|    |    |    |    |    |    |   |         | T[31·16] |   |   |   |   |   |   |   |
|    |    |    |    |    |    |   | KIC_CIV | 1[31.10] |   |   |   |   |   |   |   |
|    |    |    |    |    |    |   |         |          |   |   |   |   |   |   |   |
|    |    |    |    |    |    |   | r۱      | W        |   |   |   |   |   |   |   |

位 15:0

RTC\_CNT[31:16]: RTC 计数器高位(RTC counter high)

可通过读 RTC\_CNTH 寄存器来获得 RTC 计数器当前值的高位部分。要对此寄存器进行写操作前,必须先进入配置模式(参见"14.2.4 配置 RTC 寄存器")。

#### 14.3.5.2 RTC 计数器寄存器低位(RTC\_CNTL)

偏移地址: 0x1C 复位值: 0x0000

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



|        | rw                                                                                                                          |
|--------|-----------------------------------------------------------------------------------------------------------------------------|
| 位 15:0 | RTC_CNT[15:0]: RTC 计数器低位(RTC counter low)可通过读 RTC_CNTL 寄存器来获得 RTC 计数器当前值的低位部分。要对此寄存器进行写操作,必须先进入配置模式(参见"14.2.4 配置 RTC 寄存器")。 |

# 14.3.6 RTC 闹钟寄存器(RTC\_ALRH/RTC\_ALRL)

当可编程计数器的值与 RTC\_ALR 中的 32 位值相等时,即触发一个闹钟事件,并且产生 RTC 闹钟中断。此寄存器受 RTC\_CR 寄存器里的 RTOFF 位写保护,仅当 RTOFF 值为'1'时,允许写操作。

### 14.3.6.1 RTC 闹钟寄存器高位(RTC\_ALRH)

偏移地址: 0x20 复位值: 0xFFFF

只写(参见"14.2.4 配置 RTC 寄存器")

| 15   | 14 | 13 | 12       | 11  | 10  | 9    | 8                     | 7        | 6   | 5   | 4   | 3   | 2   | 1    | 0    |
|------|----|----|----------|-----|-----|------|-----------------------|----------|-----|-----|-----|-----|-----|------|------|
|      |    |    |          |     |     |      | RTC_AL                | R[31:16] |     |     |     |     |     |      |      |
|      |    |    |          |     |     |      | ١                     | V        |     |     |     |     |     |      |      |
| 位 15 | :0 | 此  | -<br>寄存器 | 用来保 | 存由转 | 次件写. | 高位(<br>入的闹<br>I.2.4 配 | 钟时间      | 的高位 | 部分。 | 要对」 | 比寄存 | 器进行 | ·写操作 | :, 必 |

# 14.3.6.2 RTC 闹钟寄存器低位(RTC\_ALRL)

偏移地址: 0x24 复位值: 0xFFFF

只写(参见"14.2.4 配置 RTC 寄存器")

| 15   | 14 | 13 | 12  | 11  | 10  | 9   | 8                      | 7       | 6   | 5 | 4   | 3   | 2   | 1    | 0    |
|------|----|----|-----|-----|-----|-----|------------------------|---------|-----|---|-----|-----|-----|------|------|
|      |    |    |     |     |     |     | RTC_AL                 | R[15:0] |     |   |     |     |     |      |      |
|      |    |    |     |     |     |     | ,                      | W       |     |   |     |     |     |      |      |
| 位 15 | :0 | 此  | 寄存器 | 用来倪 | 存由车 | 次件写 | 氐位(F<br>入的闹<br>4.2.4 酢 | 钟时间     | 的低位 |   | 要对」 | 此寄存 | 器进行 | ·写操作 | E, 必 |



## 15 独立看门狗(IWDG)

器件内置两个看门狗(独立看门狗 IWDG 和窗口看门狗 WWDG),提供了更高的安全性、精确性和灵活性。两个看门狗设备可用来检测和解决由软件错误引起的故障;当计数器达到给定的超时值时,触发一个中断(仅适用于 WWDG)或产生系统复位。

IWDG 由专用的低速时钟(LSI)驱动,即使主时钟发生故障它也仍然有效。WWDG 由从 APB1 时钟分频后得到的时钟驱动,通过可配置的时间窗口来检测应用程序非正常的过迟或过早的操作。

IWDG 最适合应用于那些需要看门狗作为一个在主程序之外,能够完全独立工作,并且对时间精度要求较低的场合。WWDG 最适合那些要求看门狗在精确计时窗口起作用的应用程序。

关于窗口看门狗的详情,请参看章节: "16 窗口看门狗(WWDG)"。

## 15.1 IWDG 主要性能

- 自由运行的递减计数器
- 时钟由独立的 RC 振荡器提供(可在停机和待机模式下工作)
- 看门狗被激活后,则在计数器计数至 0x000 时产生复位

## 15.2 IWDG 功能描述

图 15-1 为独立看门狗模块的功能框图。

在键寄存器(IWDG\_KR)中写入 0xCCCC,开始启用 IWDG;此时计数器开始从其复位值 0xFFF 递减计数。当计数器计数到末尾 0x000 时,会产生一个复位信号(IWDG\_RESET)。

无论何时,只要在键寄存器 IWDG\_KR 中写入 0xAAAA,IWDG\_RLR 中的值就会被重新加载到计数器,从而避免产生看门狗复位。

支持看门狗窗口(window)模式,详细的描述请参考章节: "15.2.1 窗口选项"。



图 15-1 IWDG 框图

注意:看门狗功能处于VDD 供电区,即在停机和待机模式时仍能正常工作。

计算超时的公式为:

 $T_{IWDG} = ((1/f_{LSI}) /PR[2:0]) * (RL[11:0]+1)$ 

其中:

- T<sub>IWDG</sub> 为 IWDG 超时时间;
- f<sub>LSI</sub>: LSI 的频率。



| 表 15-1 IWDG 超时时间表(40KHz 的输入 | 时钟 | (LSI) | ) |
|-----------------------------|----|-------|---|
|-----------------------------|----|-------|---|

| 预分频系数 | PR[2:0] <b>(</b> 立 | 最短时间(ms)RL[11:0]=0x000 | 最长时间(ms)RL[11:0]=0xFFF |
|-------|--------------------|------------------------|------------------------|
| /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                |

#### 注意:

- 这些时间是按照 40 kHz 时钟给出。实际上,MCU 内部的 RC 频率会在 30 kHz 到 60 kHz 之间变化。此外,即使 RC 振荡器的频率是精确的,确切的时序仍然依赖于 APB 接口时钟与 RC 振荡器时钟之间的相位差,因此总会有一个完整的 RC 周期是不确定的。
- 通过对 LSI 进行校准可获得相对精确的看门狗超时时间。

### 15.2.1 窗口选项

通过在 IWDG\_WINR 寄存器中设置合适的窗口,IWDG 也可以用作窗口看门狗。当计数器值大于窗口寄存器(IWDG\_WINR)中存储的值时,如果执行重载操作,则会产生复位。IWDG\_WINR 的默认值为0x0000 0FFF,因此如果不更新此默认值,窗口选项将一直处于禁用状态。窗口值一经更改,便会执行重载操作,以便将递减计数器的值复位为 IWDG RLR 值,方便计算周期数以生成下一次重载。



图 15-2 IWDG 使能窗口选项时的工作说明

使能窗口选项时配置 IWDG 的流程:

- 1. 向 IWDG KR 写入 0x0000 CCCC 来使能 IWDG。
- 2. 向 IWDG\_KR 写入 0x0000 5555 来使能寄存器访问。
- 3. 修改 IWDG PR 的值为 0~7 中的值,配置 IWDG 的预分频器。
- 4. 写重载寄存器 IWDG\_RLR。



- 5. 等待 IWDG RLR 寄存器值更新完成(IWDG SR = 0x0000 0000)。
- 6. 写窗口寄存器 IWDG WINR,这个操作会导致 IWDG 计数器自动更新为 IWDG RLR 中的值。

注意: 当IWDG\_SR 为0x0000 0000 时, 才能写IWDT\_WINR, 否则IWDG 计数器可能不会正确的重载为IWDG RLR 中的值。

禁能窗口选项时配置 IWDG 的流程:

- 1. 向 IWDG\_KR 写入 0x0000 CCCC 来使能 IWDG。
- 2. 向 IWDG KR 写入 0x0000 5555 来使能寄存器访问。
- 3. 修改 IWDG\_PR 的值为 0~7 中的值,配置 IWDG 的预分频器。
- 4. 写重载寄存器 IWDG RLR。
- 5. 等待 IWDG\_RLR 寄存器值更新完成(IWDG\_SR = 0x0000 0000)。
- 6. 刷新计数器值为 IWDG\_RLR 值(IWDG\_KR = 0x0000 AAAA)。

## 15.2.2 硬件看门狗

如果用户在选择字节中启用了硬件看门狗功能,在系统上电复位后,看门狗会自动开始运行;如果 在计数器计数结束前,若软件没有向键寄存器写入相应的值,则系统会产生复位。

## 15.2.3 寄存器访问保护

IWDG\_PR 和 IWDG\_RLR 寄存器具有写保护功能。要修改这两个寄存器的值,必须先向IWDG\_KR 寄存器写入 0x5555。以不同的值写入这个寄存器将会打乱操作顺序,寄存器将重新被保护。重装载操作(即写入 0xAAAA)也会启动写保护功能。

状态寄存器指示预分频值和递减计数器是否正在被更新。

## 15.2.4 调试模式

当微控制器进入调试模式时(Cortex-M3 核心停止),根据调试模块中的 DBG\_IWDG\_STOP 配置位的状态,IWDG 的计数器能够继续工作或停止。详细信息,请参见: "24.14.2 支持定时器、看门狗、bxCAN和 I2C 的调试"。

## 15.3 IWDG 寄存器

基地址: 0x4000 3000

空间大小: 0x400

可以用半字(16位)或字(32位)的方式操作这些外设寄存器。

# 15.3.1 键寄存器(IWDG\_KR)

偏移地址: 0x00

复位值: 0x0000 0000

该寄存器在待机模式复位。

|    |    |    | -  |       |    | 1  | 1  | _      | -  |    |    |    | 1  |    | _ |    |    |
|----|----|----|----|-------|----|----|----|--------|----|----|----|----|----|----|---|----|----|
| 31 | 30 | 29 | 28 | 27    | 26 | 25 | 24 | 2      | 23 | 22 | 21 | 20 | 19 | 18 | 1 | L7 | 16 |
|    |    |    |    |       |    |    |    | Res    |    |    |    |    |    |    |   |    |    |
|    |    |    |    |       |    |    |    |        |    |    |    |    |    |    |   |    |    |
|    | 1  |    |    |       |    |    |    |        | 1  |    |    |    |    |    |   |    |    |
| 15 | 14 | 13 | 12 | 2   1 | L1 | 10 | 9  | 8      | 7  | 6  | 5  | 4  | 3  | 2  | 1 |    | 0  |
|    |    |    |    |       |    |    | KE | Y[15:0 | 0] |    |    |    |    |    |   |    |    |
|    |    |    |    |       |    |    |    | w      |    |    |    |    |    |    |   |    |    |



| 位 31:16 | Res: 保留<br>必须保持复位值。                                                                                                                                                                                     |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 15:0  | KEY[15:0]:键值(只写寄存器,读出值为 0x0000)(Key value (write only, read 0000h))软件必须以一定的间隔写入 0xAAAA,否则,当计数器为 0 时,看门狗会产生复位。写入 0x5555 表示允许访问 IWDG_PR 和 IWDG_RLR 寄存器。(见 LSI 时钟章节)写入 0xCCCC,启动看门狗工作(若选择了硬件看门狗则不受此命令字限制)。 |

# 15.3.2 预分频寄存器(IWDG\_PR)

Res

偏移地址: 0x04

复位值: 0x0000 0000

| 位 31:3<br>位 2:0 | Res: 保留<br>必须保持复位<br>PR[2:0]: 预分<br>该位域具有写<br>器时钟的预分 | 频因子(Pres<br>保护设置,参 | caler di<br>≽见"15 | .2.3  | 寄存器   |             |      | 。通讨  | \.\.\.\.\.\.\.\.\.\.\.\.\.\.\.\.\.\.\ |            | PR[2 | V               |
|-----------------|------------------------------------------------------|--------------------|-------------------|-------|-------|-------------|------|------|---------------------------------------|------------|------|-----------------|
|                 | 必须保持复位<br>PR[2:0]: 预分<br>该位域具有写<br>器时钟的预分            | 频因子(Pres<br>保护设置,参 | ≽见 <b>"15</b>     | .2.3  | 寄存器   |             |      | 。通讨  | - <b>:</b> 八 四 )                      |            | rv   |                 |
|                 | 必须保持复位<br>PR[2:0]: 预分<br>该位域具有写<br>器时钟的预分            | 频因子(Pres<br>保护设置,参 | ≽见 <b>"15</b>     | .2.3  | 寄存器   |             |      | 。通讨  | -2/L EZ )                             |            |      | . LV 11 W       |
|                 | 必须保持复位<br>PR[2:0]: 预分<br>该位域具有写<br>器时钟的预分            | 频因子(Pres<br>保护设置,参 | ≽见 <b>"15</b>     | .2.3  | 寄存器   |             |      | 。诵讨  | -2.T. EE )                            | 12a () . I |      | . LV 11 W       |
| 位 2:0           | PR[2:0]: 预分<br>该位域具有写<br>器时钟的预分                      | 频因子(Pres<br>保护设置,参 | ≽见 <b>"15</b>     | .2.3  | 寄存器   |             |      | 。通过  | - 1 TL PE 1                           | · / / / /  |      | • 14 11 M       |
| 位 2:0           | 该位域具有写器时钟的预分                                         | 保护设置,参             | ≽见 <b>"15</b>     | .2.3  | 寄存器   |             |      | 。通讨  | - 1.T. EE 1                           | <u>, .</u> |      | • 144 / 1 / 1/4 |
|                 | 器时钟的预分                                               |                    | -                 |       |       |             |      | 。通过  | - 2几 모 :                              | N. I       |      | * TA > L \M.    |
|                 | 器时钟的预分                                               |                    | -                 |       |       |             |      |      | . 仅自.1                                | 夕位‡        | 或来说  | └斧け数            |
|                 | 1\ .l                                                |                    |                   |       | • /   | NDG_:       | SR 寄 | 存器的  | PVU                                   | 位必須        | 须为(  | )。              |
|                 | • 000: 预分频                                           | 项因子=4              |                   |       |       |             |      |      |                                       |            |      |                 |
|                 | • 001: 预分频                                           | 页因子=8              |                   |       |       |             |      |      |                                       |            |      |                 |
|                 | • 010: 预分频                                           | 页因子=16             |                   |       |       |             |      |      |                                       |            |      |                 |
|                 | • 011: 预分频                                           | 页因子=32             |                   |       |       |             |      |      |                                       |            |      |                 |
|                 | • 100: 预分频                                           | 页因子=64             |                   |       |       |             |      |      |                                       |            |      |                 |
|                 | • 101: 预分频                                           | 页因子=128            |                   |       |       |             |      |      |                                       |            |      |                 |
|                 | • 110: 预分频                                           | 页因子=256            |                   |       |       |             |      |      |                                       |            |      |                 |
|                 | • 111: 预分步                                           | 页因子=256            |                   |       |       |             |      |      |                                       |            |      |                 |
|                 | 注意: 对此寄                                              | 存器进行读热             | 操作,将              | 寄从 Vi | oo 电后 | 医域返         | 回预约  | 分频值  | 。如果                                   | 思写媒        | 蜂作正  | 在进              |
|                 | 行,则读回的                                               | 值可能是无效             | (或是)              | 过期的   | 。因如   | <b>光,</b> 只 | 有当   | IWDG | SR 寄                                  | 存器         | 的 PV | U 位为            |
|                 | 0时,读出的                                               |                    |                   |       |       |             |      | _    |                                       |            |      |                 |

# 15.3.3 重装载寄存器(IWDG\_RLR)

偏移地址: 0x08

复位值: 0x0000 0FFF (待机模式时复位)

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 2 | 0 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|----|----|----|----|---|---|----|----|----|----|
|    |    |    |    |    |    |    | R  | es |    |    |   |   |    |    |    |    |
|    |    |    |    |    |    |    |    |    |    |    |   |   |    |    |    |    |
|    | 1  | _  |    |    |    |    |    |    |    |    |   |   |    | _  | _  | ,  |
| 15 | 14 | 13 | 1  | L2 | 11 | 10 | 9  | 8  | 7  | 6  | 5 | 4 | 3  | 2  | 1  | 0  |



| Ro      | es                                                             | RL[11:0]                                                                                                                                                                                                                                                                             |
|---------|----------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |                                                                | rw                                                                                                                                                                                                                                                                                   |
| 位 31:12 | Res: 保留<br>必须保持复位                                              | 值。                                                                                                                                                                                                                                                                                   |
| 位 11:0  | 该位域具有写<br>装载值,每当<br>后计数器从这<br>来计算,参见<br>进行修改。<br><i>注意:对此奇</i> | 门狗计数器重装载值(Watchdog counter reload value)<br>保护功能,参看"15.2.3 寄存器访问保护"。用于定义看门狗计数器的重向 IWDG_KR 寄存器写入 0xAAAA 时,重装载值会被传送到计数器中。随个值开始递减计数。看门狗超时周期可通过此重装载值和时钟预分频值表 15-1。只有当 IWDG_SR 寄存器中的 RVU 位为 0 时,才能对此寄存器。<br>存器进行读操作,将从 VDD 电压域返回预分频值。如果写操作正在进口值可能是无效或是过期的。因此,只有当 IWDG_SR 寄存器的 RVU 位为值才有效。 |

# 15.3.4 状态寄存器(IWDG\_SR)

偏移地址: 0x0C

复位值: 0x0000 0000 (待机模式时不复位)

| 31  | 30 | 29 | 28  | 27  | 26 | 25 | 24 | 23 | 22       | 21 | 20 | 19 | 18 | 17  | 16  |
|-----|----|----|-----|-----|----|----|----|----|----------|----|----|----|----|-----|-----|
|     |    |    |     |     |    |    | R  | es |          |    |    |    |    |     |     |
|     |    |    |     |     |    |    |    |    |          |    |    |    |    |     |     |
| 4.5 |    | 42 | 4.2 | 4.4 | 40 | -  | 0  | _  | -        |    |    |    | _  |     | •   |
| 15  | 14 | 13 | 12  | 11  | 10 | 9  | 8  | /  | 6        | 5  | 4  | 3  | 2  | 1   | U   |
|     |    |    |     |     |    |    |    |    |          |    |    |    |    |     |     |
|     |    |    |     | ı   | I  | Re | es |    | <u> </u> |    |    |    |    | RVU | PVU |

| 位 31:2 | Res: 保留<br>必须保持复位值。                                                                                                                                                               |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 1    | RVU: 看门狗计数器重装载值更新(Watchdog counter reload value update)<br>此位由硬件置'1'用来指示重装载值的更新正在进行中。当在 V <sub>DD</sub> 域中的重装载更新结束<br>后,此位由硬件清零(最多需 5 个 40kHz 的 RC 周期)。<br>重装载值只有在 RVU 位被清零后才可更新。 |
| 位 0    | PVU: 看门狗预分频值更新(Watchdog prescaler value update)<br>此位由硬件置'1'用来指示预分频值的更新正在进行中。当在 V <sub>DD</sub> 域中的预分频值更新结束<br>后,此位由硬件清零(最多需 5 个 40kHz 的 RC 周期)。<br>预分频值只有在 PVU 位被清零后才可更新。        |

注意:如果在应用程序中使用了多个重装载值或预分频值,则必须在RVU 位被清零后才能重新改变预装载值,在 PVU 位被清零后才能重新改变预分频值。然而,在更新预分频和/或重装载值后,不必等待RVU 或 PVU 位清零,可继续执行下面的代码。(即使是在低功耗模式下,此写操作仍会被继续执行完成。)

# 15.3.5 窗口寄存器(IWDG\_WINR)

偏移地址: 0x10

复位值: 0x0000 0FFF (待机模式时复位)



| 31    | 30                                                         | 29  | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21      | 2   | 0 | 19 | 18 | 17 | 16 |
|-------|------------------------------------------------------------|-----|----|----|----|----|----|----|----|---------|-----|---|----|----|----|----|
|       |                                                            |     |    |    |    |    | R  | es |    |         |     |   |    |    |    |    |
|       |                                                            |     |    |    |    |    |    |    |    |         |     |   |    |    |    |    |
| 15    | 14                                                         | 13  |    | 12 | 11 | 10 | 9  | 8  | 7  | 6       | 5   | 4 | 3  | 2  | 1  | 0  |
|       |                                                            | Res | '  |    |    |    |    |    | ,  | WIN[11: | :0] |   |    |    |    |    |
|       | rw                                                         |     |    |    |    |    |    |    |    |         |     |   |    |    |    |    |
| 位 31: |                                                            |     |    |    |    |    |    |    |    |         |     |   |    |    |    |    |
| 位 11: | 位 11:0 WIN[11:0]: 看门狗计数器窗口值(Watchdog counter window value) |     |    |    |    |    |    |    |    |         |     |   |    |    |    |    |



## 16 窗口看门狗(WWDG)

窗口看门狗通常被用来监测由外部干扰或不可预见的逻辑条件所造成的应用程序背离正常的运行顺序而产生的软件故障。除非递减计数器的值在 T6 位变成 0 前被刷新,否则看门狗电路在达到预置的时间周期时,会产生一个 MCU 复位。在递减计数器达到窗口寄存器数值之前,如果 7 位的递减计数器的数值(在控制寄存器中)被刷新,那么也将产生一个 MCU 复位。这表明递减计数器必须在一个有限的时间窗口中被刷新。

## 16.1 WWDG 主要特性

- 可编程的自由运行递减计数器。
- 复位条件:
  - 。 当递减计数器的值小于 0x40, (若看门狗被启动)则产生复位。
  - 。 当递减计数器在窗口外被重新装载,(若看门狗被启动)则产生复位。具体信息请参见: 图 16-2。
- 早期唤醒中断(EWI): 如果启动了看门狗并且允许中断,当递减计数器等于 0x40 时产生早期 唤醒中断,它可以被用于重装载计数器以避免 WWDG 复位。

## 16.2 WWDG 功能描述

如果看门狗被启动(WWDG\_CR 寄存器中的 WDGA 位被置'1'),且当 7 位(T[6:0])递减计数器从 0x40 翻转到 0x3F(T6 位清零)时,则产生一个复位。如果软件在计数器值大于配置寄存器中的数值时,重新装载计数器,将产生一个复位。



图 16-1 看门狗框图

应用程序在正常运行过程中必须定期地写入 WWDG\_CR 寄存器以防止 MCU 发生复位。只有当计数器值小于配置寄存器的值时,才能进行该操作。

储存在 WWDG\_CR 寄存器中的数值必须在0xFF 和 0xC0 之间:

启动看门狗:

在系统复位后,看门狗总是处于关闭状态,设置 WWDG\_CR 寄存器的 WDGA 位能够开启看门狗,随后它不能再被关闭,除非发生复位。

• 控制递减计数器:

递减计数器处于自由运行状态,即使看门狗被禁止,递减计数器仍继续递减计数。当看门狗被



启用时,T6 位必须被设置,以防止立即产生一个复位。

T[5:0]位包含了看门狗产生复位之前的计时数目;复位前的延时时间在一个最小值和一个最大值之间变化,这是因为写入 WWDG\_CR 寄存器时,预分频值是未知的。配置寄存器(WWDG\_CFR)中包含窗口的上限值:要避免产生复位,递减计数器必须在其值小于窗口寄存器的数值并且大于 0x3F 时被重新装载,图 16-2 描述了窗口寄存器的工作过程。另一个重装载计数器的方法是利用早期唤醒中断(EWI)。设置 WWDG\_CFR 寄存器中的 EWI 位开启该中断。当递减计数器到达 0x40 时,则产生此中断,相应的中断服务程序(ISR)可以用来加载计数器以防止 WWDG 复位。在 WWDG SR 寄存器中写'0'可以清除该中断。

注意: 可以用 T6 位产生一个软件复位(设置 WDGA 位为1', T6 位为'0')。

## 16.3 如何编写看门狗超时程序

可以使用图 16-2 提供的公式计算窗口看门狗的超时时间。

警告: 当写入 WWDG\_CR 寄存器时,确保 T6 位始终为'1'以避免立即产生一个复位。



图 16-2 WWDG 时序图

计算超时的公式如下:

 $T_{WWDG} = T_{PCLK1} * 4096 * 2^{WDGTB} * (T[5:0] +1)$ 

- Twwpg: WWDG 超时时间
- Т<sub>РСІКІ</sub>: APB1 以 ms 为单位的时钟间隔,在 PCLK1=36MHz 时的最小/最大超时值(具体值如下表)。

|       | V 10 1 11 10 10 10 10 10 11 11 |         |
|-------|--------------------------------|---------|
| WDGTB | 最小超时值                          | 最大超时值   |
| 0     | 113μs                          | 7.28ms  |
| 1     | 227μs                          | 14.56ms |
| 2     | 455μs                          | 29.12ms |
| 3     | 910μs                          | 58.25ms |

表 16-1 WDGTB 超时值



# 16.4 调试模式

当微控制器进入调试模式时(Cortex®-M3 核心停止),根据调试模块中的 DBG\_WWDG\_STOP 配置位的状态,WWDG 的计数器能够继续工作或停止。详见章节:"24.14.2 支持定时器、看门狗、bxCAN 和 I2C 的调试"。

## 16.5 WWDG 寄存器

基地址: 0x4000 2C00

空间大小: 0x400

可以用半字(16位)或字(32位)的方式操作这些外设寄存器。

## 16.5.1 控制寄存器(WWDG\_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 |    |    |   |   | WDGA  | T[6:0] |   |   |   |   |   |   |
|    |    |    |     |    |    |   |   | rw rw |        |   |   |   |   |   |   |

| 位 31:8 | Res: 保留<br>必须保持复位值。                                                                                                    |
|--------|------------------------------------------------------------------------------------------------------------------------|
| 位 7    | WDGA: 激活位(Activation bit)<br>此位由软件置'1',但仅能由硬件在复位后清零。当 WDGA=1 时,看门狗可以产生复位。<br>• 0:禁止看门狗<br>• 1:启用看门狗                    |
| 位 6:0  | T[6:0]: 7位计数器(MSB 至 LSB)(7-bit counter (MSB to LSB))<br>该位域用来存储看门狗的计数器值。每(4096x2 <sup>WDGTB</sup> )个 PCLK1 周期减 1。当计数器值 |

从 0x40 翻转为 0x3F 时(T6 变成 0),产生看门狗复位。

## 16.5.2 配置寄存器(WWDG\_CFR)

地址偏移: 0x04 复位值: 0x7F

| 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 |
|----|----|----|----|----|----|-----|------|--------|----|---|--------|---|---|---|---|
|    |    | Re | es |    |    | EWI | WDGT | B[1:0] |    |   | W[6:0] |   |   |   |   |
|    |    |    |    |    |    | rw  | r    | w      | rw |   |        |   |   |   |   |

位 31:10

Res: 保留

必须保持复位值。



| 位 9   | EWI: 提前唤醒中断(Early wakeup interrupt)<br>此位若置'1',则当计数器值达到 0x40,即产生中断。此中断只能由硬件在复位后清除。                                                                                                   |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 8:7 | WDGTB[1:0]: 时基(Timer base)<br>预分频器的时基可以设置如下: • 00: CK 计时器时钟(PCLK1 除以 4096)除以 1 • 01: CK 计时器时钟(PCLK1 除以 4096)除以 2 • 10: CK 计时器时钟(PCLK1 除以 4096)除以 4 • 11: CK 计时器时钟(PCLK1 除以 4096)除以 8 |
| 位 6:0 | W[6:0]: 7 位窗口值(7-bit window value)<br>该位域包含了用来与递减计数器进行比较用的窗口值。                                                                                                                       |

# 16.5.3 状态寄存器(WWDG\_SR)

地址偏移: 0x08

复位值: 0x0000 0000

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

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

| 位 31:1 | Res: 保留<br>必须保持复位值。                                                                                                 |
|--------|---------------------------------------------------------------------------------------------------------------------|
| 位 0    | EWIF: 提前唤醒中断标志(Early wakeup interrupt flag)<br>当计数器值达到 0x40 时,此位由硬件置'1'。它必须通过软件写'0'来清除。对此位写'1'无效。若中断未被使能,此位也会被置'1'。 |



## 17 USB 全速设备接口(USB)

USB 外设实现了 USB2.0 全速总线和 APB1 总线间的接口。USB 外设支持 USB 挂起/唤醒操作,可以停止设备时钟实现低功耗。

## 17.1 USB 主要特征

- 符合 USB2.0 全速设备的技术规范
- 可配置 1 到 8 个 USB 端点
- 循环冗余校验(CRC)生成/校验,反向不归零(NRZI)编码/解码和位填充
- 支持同步传输
- 支持批量/同步端点的双缓冲区机制
- 支持 USB 挂起/唤醒操作
- 帧锁定时钟脉冲生成

注意: USB 和 CAN 共用一个专用的 512 字节的 SRAM 存储器用于数据的发送和接收,因此不能同时使用 USB 和 CAN (共享的 SRAM 被 USB 和 CAN 模块互斥地访问)。USB 和 CAN 可以同时用于一个应用中但不能在同一个时间使用。

下图是 USB 外设的方框图。



图 17-1 USB 设备框图

# 17.2 USB 功能描述

USB 模块为 PC 主机和微控制器所实现的功能之间提供了符合 USB 规范的通信连接。PC 主机和微控制器之间的数据传输是通过共享同一专用的数据缓冲区来完成的,该数据缓冲区能被 USB 外设直接访问。这块专用数据缓冲区的大小由所使用的端点数目和每个端点最大的数据分组大小所决定,每个端点



最大可使用 512 字节缓冲区,最多可用于 16 个单向或 8 个双向端点。USB 模块同 PC 主机通信,根据 USB 规范实现令牌分组的检测,数据发送/接收的处理,和握手分组的处理。整个传输格式化由硬件完成,其中包括 CRC 的生成和校验。

每个端点都有一个缓冲区描述块,描述该端点使用的缓冲区地址、大小和需要传输的字节数。

当 USB 模块识别出一个有效的功能/端点的令牌分组时,(如果需要传输数据并且端点已配置) 随之发生相关的数据传输。USB 模块通过一个内部的 16 位寄存器实现端口与专用缓冲区的数据交换。在所有的数据传输完成后,如果需要,则根据传输的方向,发送或接收适当的握手分组。

在数据传输结束时, USB 模块将触发与端点相关的中断,通过读状态寄存器和/或者利用不同的中断处理程序,微控制器可以确定:

- 哪个端点需要得到服务
- 当发生位填充、格式、CRC、协议、缺失 ACK、缓冲区溢出/缓冲区未满等错误时,正在进行的是哪种类型的传输。

USB 模块对同步传输和高吞吐量的批量传输提供了特殊的双缓冲区机制,在微控制器使用一个缓冲区的时候,该机制保证了 USB 外设总是可以使用另一个缓冲区。

在任何不需要使用 USB 模块的时候,通过写控制寄存器可以使 USB 模块置于低功耗模式(SUSPEND模式)。在这种模式下,不产生任何静态电流消耗,同时 USB 时钟也会减慢或停止。通过对 USB 线上数据传输的检测,可以在低功耗模式下唤醒 USB 模块。也可以将一特定的中断输入源直接连接到唤醒引脚上,以使系统能立即恢复正常的时钟系统,并支持直接启动或停止时钟系统。

### 17.2.1 USB 功能模块描述

USB 模块实现了标准 USB 接口的所有特性,它由以下部分组成:

串行接口控制器(SIE):

该模块包括的功能有:帧头同步域的识别,位填充,CRC的产生和校验,PID的验证/产生,和握手分组处理等。它与 USB 收发器交互,利用分组缓冲接口提供的虚拟缓冲区存储局部数据。它也可以根据 USB 事件(比如帧起始位(SOF),USB 复位,数据错误和传输结束)或一个包正确接收等与端点相关事件生成信号,这些信号用来产生中断。

• 定时器:

本模块的功能是产生一个与帧起始位报文同步的时钟脉冲,将 3ms 内没有数据传输的状态,检测为(主机的)全局挂起条件。

• 分组缓冲器接口:

此模块管理那些用于发送和接收的临时本地内存单元。它根据 SIE 的要求分配合适的缓冲区,并将其定位到端点寄存器所指向的存储区地址。它在每个字节传输后,自动递增地址,直到数据分组传输结束。它记录传输的字节数以防止缓冲区溢出。

• 端点相关寄存器:

每个端点都有一个与之相关的寄存器,用于描述端点类型和当前状态。对于单向和单缓冲器端点,一个寄存器就可以用于实现两个不同的端点。一共8个寄存器,可以用于实现最多16个单向/单缓冲的端点或者7个双缓冲的端点或者这些端点的组合。例如,可以同时实现4个双缓冲端点和8个单缓冲/单向端点。

• 控制寄存器:

这些寄存器包含整个 USB 模块的状态信息,用来触发诸如恢复、低功耗等 USB 事件。

• 中断寄存器:

这些寄存器包含中断屏蔽信息和中断事件的记录信息。配置和访问这些寄存器可以获取中断源,中断状态等信息,并能清除待处理中断的状态标志。

注意:端点0总是作为单缓冲模式下的控制端点。



USB 模块通过 APB1 接口部件与 APB1 总线相连, APB1 接口部件包括以下部分:

• 分组缓冲区:

数据分组缓存在分组缓冲区中,它由分组缓冲接口控制并创建数据结构。应用软件可以直接访问该缓冲区。它的大小为512字节,由256个16位的字构成。

仲裁器:

该部件负责处理来自 APB1 总线和 USB 接口的存储器请求。它通过向 APB1 提供较高的访问优先权来解决总线的冲突,并且总是保留一半的存储器带宽供 USB 完成传输。它采用时分复用的策略实现了虚拟的双端口 SRAM,即在 USB 传输的同时,允许应用程序访问存储器。此策略也允许任意长度的多字 APB1 传输。

• 寄存器映射单元:

此部件将 USB 模块的各种字节宽度和位宽度的寄存器映射成能被 APB1 寻址的 16 位宽度的内存集合。

APB1 封装:

此部件为缓冲区和寄存器提供了到 APB1 的接口,并将整个 USB 模块映射到 APB1 地址空间。

• 中断映射单元:

将可能产生中断的 USB 事件映射到三个不同的 NVIC 请求线上:

- USB 低优先级中断(通道 19): 可由所有 USB 事件触发(正确传输, USB 复位等)。固件在处理中断前应当首先确定中断源。
- 。 USB 高优先级中断 (通道 20): 仅能由同步和双缓冲批量传输的正确传输事件触发,目的是保证最大的传输速率。
- 。 USB 唤醒中断 (通道 42): 由 USB 挂起模式的唤醒事件触发。

## 17.3 编程中需要考虑的问题

在下面的章节中,将介绍 USB 模块和应用程序之间的交互过程,有利于简化应用程序的开发。

## 17.3.1 通用 USB 设备编程

这一部分描述了实现 USB 设备功能的应用程序需要完成的任务。除了介绍一般的 USB 事件中应该采取的操作外,还着重介绍了双缓冲端点和同步传输的操作。这些相关的操作都是由 USB 模块初始化,并由以下几节所描述的 USB 事件所驱动。

## 17.3.2 系统复位和上电复位

发生系统复位或者上电复位时,应用程序首先需要做的是提供 USB 模块所需要的时钟信号,然后清除复位信号,使程序可以访问 USB 模块的寄存器。复位之后的初始化流程如下所述:

首先,由应用程序激活寄存器单元的时钟,再配置设备时钟管理逻辑单元的相关控制位,清除复位信号。

然后,应用程序需要通过配置设备时钟管理逻辑的相应控制位来为 USB 模块提供标准所定义的 48MHz 时钟。

当系统复位时,应用程序应该初始化所有需要的寄存器和分组缓冲区描述表,使 USB 模块能够产生 正常的中断和完成数据传输。所有与端点无关的寄存器需要根据应用的需求进行初始化(比如中断使能的选择,分组缓冲区地址的选择等)。接下来按照 USB 复位处理(参见下段)。

#### 17.3.2.1 USB 复位(RESET 中断)

发生 USB 复位时, USB 模块进入前面章节中描述过的系统复位状态: 所有端点的通信都被禁止 (USB 模块不会响应任何分组)。在 USB 复位后, USB 模块被使能,同时地址为 0 的默认控制端点 (端



点 0)也需要被使能。这可以通过配置 USB\_DADDR 寄存器的 EF 位,USB\_EPOR 寄存器和相关的分组缓冲 区来实现。在 USB 设备的枚举阶段,主机将分配给设备一个唯一的地址,这个地址必须写入 USB DADDR 寄存器的 ADD[6:0]位中,同时配置其他所需的端点。

当复位中断产生时,应用程序必须在中断产生后的 10 ms 之内使能端点 0 的传输。

#### 17.3.2.2 分组缓冲区的结构和用途

每个双向端点都可以接收或发送数据。接收到的数据存储在该端点指定的专用缓冲区内,而另一个缓冲区则用于存放待发送的数据。对这些缓冲区的访问由分组缓冲区接口模块实现,它提出缓冲区访问请求,并等待确认信息后返回。为防止产生微控制器与 USB 模块对缓冲区的访问冲突,缓冲区接口模块使用仲裁机制,使 APB1 总线的一半周期用于微控制器的访问,另一半保证 USB 模块的访问。这样,微控制器和 USB 模块对分组缓冲区的访问如同对一个双端口 SRAM 的访问,即使微控制器连续访问缓冲区,也不会产生访问冲突。

USB 模块使用固定的时钟,按照 USB 标准,此时钟频率被固定为 48MHz。APB1 总线的时钟可以大于或者小于这个频率。

注意:为满足USB 数据传输率和分组缓冲区接口的系统需求,APB1 总线时钟的频率必须大于8MHz, 以避免数据缓冲区溢出或不满。

每个端点对应于两个分组缓冲区(一般一个用于发送,另一个用于接收)。这些缓冲区可以位于整个分组存储区的任意位置,因为它们的地址和长度都定义在缓冲区描述表中,而缓冲区描述表也同样位于分组缓冲区中,其地址由 USB BTABLE 寄存器确定。

缓冲区描述表的每个表项都关联到一个端点寄存器,它由 4 个 16 位的字组成,因此缓冲区描述表的起始地址按 8 字节对齐(寄存器的最低 3 位总是'000')。章节"17.4.3 缓冲区"详细介绍缓冲区描述表表项。如果是非同步非双缓冲的单向端点,只需要一个分组缓冲区(即发送方向上的分组缓冲区)。其他未用到的端点或某个未使用的方向上的缓冲区描述表项可以用于其他用途。同步和双缓冲批量端点有特殊的分组缓冲区处理方法(请分别参考章节:"17.3.3 双缓冲端点"和"17.3.4 同步传输"。下图描述了缓冲区描述表项和分组缓冲区区域的关系。





图 17-2 分组缓冲区对应的缓冲区描述表项定位

不管是接收还是发送,分组缓冲区都是从底部开始使用的。USB 模块不会改变超出当前分配到的缓冲区区域以外的其他缓冲区的内容。如果缓冲区收到一个比自己大的数据分组,它只会接收最大为自身大小的数据,其他的丢掉,即发生了所谓的缓冲区溢出异常。

#### 17.3.2.3 端点初始化

初始化端点的第一步是把适当的值写到 USB\_ADDRx\_TX 或 USB\_ADDRx\_RX 寄存器中,以便 USB 模块能找到要传输的数据或准备好接收数据的缓冲区。配置 USB\_EPxR 寄存器的 EP\_TYPE 位确定端点的基本类型,EP\_KIND 位确定端点的特殊特性。作为发送方,需要设置 USB\_EPxR 寄存器的 STAT\_TX 位来使能端点,USB\_COUNTx\_TX 位寄存器必须要被初始化。作为接收方,需要设置 USB\_EPxR 寄存器的 STAT\_RX 位来使能端点,还需要设置 USB\_COUNTx\_RX 寄存器的 BL\_SIZE 和 NUM\_BLOCK 位,确定接收缓冲区的大小,以检测缓冲区溢出的异常。对于非同步非双缓冲批量传输的单向端点,只需要初始化与支持的传输方向相关的寄存器和位。一旦端点被使能,应用程序就不能再修改 USB\_EPxR 寄存器的值和以及 USB\_ADDRx\_TX/USB\_ADDRx\_RX,COUNTx\_TX/USB\_COUNTx\_RX 所在的位置,因为这些值会被硬件实时修改。当数据传输完成时,CTR 中断会产生,此时上述寄存器可以被访问,并重新使能新的传输。

#### 17.3.2.4 IN 分组(用于数据发送)

当接收到一个 IN 令牌分组时,如果接收到的地址和一个配置好的端点地址相符合的话,USB 模块将会访问缓冲区描述表的表项找到与该端点相关的 USB\_ADDRx\_TX 和 USB\_COUNTx\_TX 寄存器,并将这些寄存器中的数值存储到内部的 16 位寄存器 ADDR 和 COUNT(应用程序无法访问)中。此时,USB 模块开始根据 USB\_EPxR 寄存器的 DTOG\_TX 位发送 DATAO 或 DATA1 分组,并访问缓冲区(参见:"17.3.2.2 分组缓冲区的结构和用途")。在 IN 分组传输完毕之后,从缓冲区读到的第一个字节将被装载到输出移位寄存器中,并开始发送。最后一个数据字节发送完成之后,计算好的 CRC 将被发送。如果收到的分组所对应的端点是无效的,将根据 USB\_EPxR 寄存器上的 STAT\_TX 位发送 NAK 或 STALL 握手分组而不发送数据。



内部的 ADDR 寄存器被用作当前缓冲区的指针,COUNT 寄存器用于记录剩下未传输的字节数。USB 总线使用低字节在先的方式传输从缓冲区中读出的每一个字。数据从 ADDRx\_TX 指向的数据分组缓冲区 开始读取,长度为 COUNTx\_TX/2 个字。如果发送的数据分组为奇数个字节,则只使用最后一个字的低 8 位。

在接收到主机响应的 ACK 后,USB\_EPXR 寄存器的值有以下更新: DTOG\_TX 位被翻转,STAT\_TX 位为'10',使端点无效,CTR\_TX 位被置位。应用程序需要通过 USB\_ISTR 寄存器的 EP\_ID 和 DIR 位识别产生中断的 USB 端点。CTR\_TX 事件的中断服务程序需要首先清除中断标志位,然后准备好需要发送的数据缓冲区,更新 COUNTx\_TX 为下次需要传输的字节数,最后再设置 STAT\_TX 位为'11'(端点有效),再次使能数据传输。当 STAT\_TX 位为'10'时(端点为 NAK 状态),任何发送到该端点的 IN 请求都会被 NAK,USB主机会重发 IN 请求直到该端点确认请求有效。上述操作过程是必须遵守的,以避免丢失紧随上一次 CTR中断请求的下一个 IN 传输请求。

### 17.3.2.5 OUT 分组和 SETUP 分组 (用于数据接收)

USB 模块对这两种分组的处理方式基本相同;对 SETUP 分组的特殊处理将在下面关于控制传输部分详细说明。当接收到一个 OUT 或 SETUP 分组时,如果地址和某个有效端点的地址相匹配,USB 模块将访问缓冲区描述表,找到与该端点相关的 USB\_ADDRx\_RX 和 USB\_COUNTx\_RX 寄存器,并将 ADDRx\_RX 寄存器的值保存在内部 ADDR 寄存器中。同时,COUNT 会被复位,从 USB\_COUNTx\_RX 中读出的 BL\_SIZE 和 NUM\_BLOCK 的值用于初始化内部 16 位寄存器 BUF\_COUNT,该寄存器用于检测缓冲区溢出(所有的内部寄存器都不能被应用程序访问)。USB 模块将随后收到的数据按字方式组织(先收到的为低字节),并存储到 ADDR 指向的分组缓冲区中。同时,随着每个字节的传输,BUF\_COUNT 值自动递减,COUNT 值自动递增。当检测到数据分组的结束信号时,USB 模块校验收到 CRC 的正确性。如果传输中没有任何错误发生,则发送 ACK 握手分组到主机。即使发生 CRC 错误或者其他类型的错误(位填充错误,帧错误等),数据还是会被保存到分组缓冲区中,至少会保存到发生错误的数据点,只是不会发送 ACK 分组,并且 USB\_ISTR 寄存器的 ERR 位将会置位。在这种情况下,应用程序通常不需要干涉处理,USB 模块将从传输错误中自动恢复,并为下一次传输做好准备。如果收到的分组所对应的端点没有准备好,USB 模块将根据 USB\_EPxR 寄存器的 STAT\_RX 位发送 NAK 或 STALL 分组,数据将不会被写入接收缓冲区。

ADDRx\_RX 的值决定接收缓冲区的起始地址,长度由包含 CRC 的数据分组的长度(即有效数据长度+2)决定,但不能超过 BL\_SIZE 和 NUM\_BLOCK 所定义的缓冲区的长度。如果接收到的数据分组的长度超出了缓冲区的范围,超过范围的数据不会被写入缓冲区,USB 模块将报告缓冲区发生溢出,并向主机发送 STALL 握手分组,通知此次传输失败,也不产生中断。

如果传输正确完成,USB 模块将发送 ACK 握手分组,内部的 COUNT 寄存器的值会被复制到相应的 COUNTx\_RX 寄存器中,BL\_SIZE 和 NUM\_BLOCK 的值保持不变,也不需要重写。USB\_EPxR 寄存器按下列 方式更新: DTOG\_RX 位翻转,STAT\_RX=10(NAK)使端点无效,CTR\_RX 位置位(如果 CTR 中断已使能(CTRM 位被置位),将触发中断)。如果传输过程中发生了错误或者缓冲区溢出,前面所列出的动作都不会发生。CRT 中断发生时,应用程序需要首先根据 USB\_ISTR 寄存器的 EP\_ID 和 DIR 位识别是哪个端点的中断请求。在处理 CTR\_RX 中断事件时,应用程序首先要确定传输的类型(根据 USB\_EPxR 寄存器的 SETUP 位),同时清除中断标志位,然后读相关的缓冲区描述表表项指向的 COUNTx\_RX 寄存器,获得此次传输的总字节数。处理完接收到的数据后,应用程序需要将 USB\_EPxR 中的 STAT\_RX 位置成'11',使能下一次的传输。当 STAT\_RX 位为'10'时(NAK),任何一个发送到端点上的 OUT 请求都会被 NAK,PC 主机将不断重发被 NAK 的分组,直到收到端点的 ACK 握手分组。以上描述的操作次序是必须遵守的,以避免丢失紧随上一个 CTR 中断的另一个 OUT 分组请求。

#### 17.3.2.6 控制传输

控制传输由 3 个阶段组成,首先是主机发送 SETUP 分组的 SETUP 阶段,然后是主机发送零个或多个数据的数据阶段,最后是状态阶段,由与数据阶段方向相反的数据分组构成。SETUP 传输只发生在控制端点,它非常类似于 OUT 分组的传输过程。使能 SETUP 传输除了需要分别初始化 DTOG\_TX 位为'1',



DTOG\_RX 位为'0'外,还需要设置 STAT\_TX 位和 STAT\_RX 位为 10 (NAK),由应用程序根据 SETUP 分组的相应字段决定后面的传输是 IN 还是 OUT。控制端点在每次发生 CTR\_RX 中断时,都必须检查 USB\_EPxR 寄存器的 SETUP 位,以识别是普通的 OUT 分组还是 SETUP 分组。USB 设备应该能够通过 SETUP 分组中的相应数据决定数据阶段传输的字节数和方向,并且能在发生错误的情况下发送 STALL 分组,拒绝数据的传输。因此在数据阶段,未被使用到的方向都应该被设置成 STALL,并且在开始传输数据阶段的最后一个数据分组时,其反方向的传输仍设成 NAK 状态,这样,即使主机立刻改变了传输方向(进入状态阶段),仍然可以保持为等待控制传输结束的状态。在控制传输成功结束后,应用程序可以把 NAK 变为 VALID,如果控制传输出错,就改为 STALL。此时,如果状态分组是由主机发送给设备的,那么 STATUS\_OUT 位(USB\_EPxR 寄存器中的 EP\_KIND)应该被置位,只有这样,在状态传输过程中收到了非零长度的数据分组,才会产生传输错误。在完成状态传输阶段后,应用程序应该清除 STATUS\_OUT 位,并且将 STAT\_RX 设为 VALID 表示已准备好接收一个新的命令请求,STAT\_TX 则设为 NAK,表示在下一个 SETUP 分组传输完成前,不接受数据传输的请求。

USB 规范定义 SETUP 分组不能以非 ACK 握手分组来响应,如果 SETUP 分组传输失败,则会引发下一个 SETUP 分组。因此,以 NAK 或 STALL 分组响应主机的 SETUP 分组是被禁止的。

当 STAT\_RX 位被设置为'01'(STALL)或'10'(NAK)时,如果收到 SETUP 分组,USB 模块会接收分组,开始分组所要求的数据传输,并回送 ACK 握手分组。如果应用程序在处理前一个 CTR\_RX 事件时 USB 模块又收到了 SETUP 分组(即 CTR\_RX 仍然保持置位),USB 模块会丢掉收到的 SETUP 分组,并且不回答任何握手分组,以此来模拟一个接收错误,迫使主机再次发送 SETUP 分组。这样做是为了避免丢失紧随一次 CTR\_RX 中断之后的又一个 SETUP 分组传输。

### 17.3.3 双缓冲端点

USB 标准不仅为不同的传输模式定义了不同的端点类型,而且对这些数据传输所需要的系统要求做了描述。其中,批量端点适用于在主机 PC 和 USB 设备之间传输大批量的数据,因为主机可以在一帧内利用尽可能多的带宽批量传输数据,使传输效率得到提高。然而,当 USB 设备处理前一次的数据传输时,又收到新的数据分组,它将回应 NAK 分组,使 PC 主机不断重发同样的数据分组,直到设备在可以处理数据时回应 ACK 分组。这样的重传占用了很多带宽,影响了批量传输的速率,因此引入了批量端点的双缓冲机制,提高数据传输率。

使用双缓冲机制时,单向端点的数据传输将使用到该端点的接收和发送两块数据缓冲区。数据翻转位用来选择当前使用到两块缓冲区中的哪一块,使应用程序可以在 USB 模块访问其中一块缓冲区的同时,对另一块缓冲区进行操作。例如,对一个双缓冲批量端点进行 OUT 分组传输时,USB 模块将来自PC 主机的数据保存到一个缓冲区,同时应用程序可以对另一个缓冲区中的数据进行处理(对于 IN 分组来说,情况是一样的)。

因为切换缓冲区的管理机制需要用到所有 4 个缓冲区描述表的表项,分别用来表示每个方向上的两个缓冲区的地址指针和缓冲区大小,因此用来实现双缓冲批量端点的 USB\_EPxR 寄存器必须配置为单向。所以只需要设定 STAT\_RX 位(作为双缓冲批量接收端点)或者 STAT\_TX 位(作为双缓冲批量发送端点)。如果需要一个双向的双缓冲批量端点,则须使用两个 USB\_EPxR 寄存器。

为尽可能利用双缓冲的优势,达到较高的传输速率,双缓冲批量端点的流量控制流程与其他端点的稍有不同。它只在缓冲区发生访问冲突时才会设置端点为 NAK 状态,而不是在每次传输成功后都将端点设为 NAK 状态。

DTOG 位用来标识 USB 模块当前所使用的储存缓冲区。双缓冲批量端点接收方向的缓冲区由 DTOG\_RX(USB\_EPxR 寄存器的第 14 位)标识,而双缓冲批量端点发送方向的缓冲区由 DTOG\_TX(USB\_EPxR 寄存器的第 6 位)标识。同时,USB 模块也需要知道当前哪个缓冲区正在被应用程序使用,以避免发生冲突。由于 USB\_EPxR 寄存器中有 2 个 DTOG 位,而 USB 模块只使用其中的一位来标识硬件所使用的缓冲区,因此,应用程序可使用另一位来标识当前正在使用哪个缓冲区,这个新的标识被称为 SW BUF 位。下表列出了双缓冲批量端点在实现发送和接收操作时,USB EPxR 寄存器的 DTOG 位和



SW BUF 位之间的关系。

表 17-1 双缓冲批量端点缓冲区标识定义

| 缓冲区标识位 | 作为发送端点                      | 作为接收端点                       |
|--------|-----------------------------|------------------------------|
| DTOG   | DTOG_TX(USB_EPxR 寄存器的第 6 位) | DTOG_RX(USB_EPxR 寄存器的第 14 位) |
| SW_BUF | USB_EPxR 寄存器的第 14 位         | USB_EPxR 寄存器的第 6 位           |

USB 模块当前使用的缓冲区由 DTOG 位标识,而应用程序所使用的缓冲区由 SW BUF 位标识,这两 个位的标识方式相同,下表描述了这种标识方式。

端点类型 DTOG 位 SW BUF 位 USB 模块使用的缓冲区 应用程序使用的缓冲区 IN 端点 ADDRx\_TX\_0/COUNTx\_TX\_0 ADDRx\_TX\_1/COUNTx\_TX\_1 1 0 ADDRx\_TX\_1/COUNTx\_TX\_1 ADDRx\_TX\_0/COUNTx\_TX\_0 0 0 无(1) ADDRx\_TX\_0/COUNTx\_TX\_0 1 无(1) 1 ADDRx\_TX\_0/COUNTx\_TX\_0 OUT 端点 1 ADDRx\_RX\_0/COUNTx\_RX\_0 ADDRx\_RX\_1/COUNTx\_RX\_1 0 ADDRx\_RX\_1/COUNTx\_RX\_1 1 ADDRx\_RX\_0/COUNTx\_RX\_0 ADDRx\_RX\_0/COUNTx\_RX\_0 n 0 无(1) 1 无(1) ADDRx\_RX\_0/COUNTx\_RX\_0 1

表 17-2 双缓冲批量端点的缓冲区使用标识

#### (1) 端点处于 NAK 状态。

可以通过以下方式设置一个双缓冲批量端点:

- 将 USB EPxR 寄存器的 EP TYPE 位设为'00', 定义端点为批量端点。
- 将 USB\_EPxR 寄存器的 EP\_KIND 位设为'1', 定义端点为双缓冲端点。

应用程序根据传输开始时用到的缓冲区来初始化 DTOG 和 SW BUF 位:这需要考虑到这两位的数据 翻转特性。设置好 DBL\_BUF 位之后,每完成一次传输后,USB 模块将根据双缓冲批量端点的流量控制操 作,并且持续到 DBL BUF 变为无效为止。每次传输结束,根据端点的传输方向,CTR\_RX 位或 CTR\_TX 位 将会置为'1'。与此同时,硬件将设置相应的 DTOG 位,完全独立于软件来实现缓冲区交换机制。 DBL BUF 位设置后,每次传输结束时,双缓冲批量端点的 STAT 位的取值不会像其他类型端点一样受到 传输过程的影响,而是一直保持为'11'(有效)。但是,如果在收到新的数据分组的传输请求时,USB模 块和应用程序发生了缓冲区访问冲突(即 DTOG 和 SW BUF 为相同的值,见表 17-2,状态位将会被置 为'10'(NAK)。应用程序响应 CTR 中断时,首先要清除中断标志,然后再处理传输完成的数据。应用程 序访问缓冲区之后,需要翻转 SW BUF 位,以通知 USB 模块该块缓冲区已变为可用状态。由此,双缓冲 批量传输的 NAK 分组的数目只由应用程序处理一次数据传输的快慢所决定: 如果数据处理的时间小于 USB 总线上完成一次数据传输的时间,则不会发生重传,此时,数据的传输率仅受限于 USB 主机。

应用程序也可以不考虑双缓冲批量端点的特殊控制流程,直接在相应 USB EPxR 寄存器的 STAT 位写 入不同于'11'(有效)的任何状态,在这种情况下,USB模块将按照写入的状态执行流程而忽略缓冲器 实际的使用情况。



### 17.3.4 同步传输

USB 标准定义了一种全速的需要保持固定和精确的数据传输率的传输方式: 同步传输。同步传输一般用于传输音频流、压缩的视频流等对数据传输率有严格要求的数据。一个端点如果在枚举时被定义为"同步端点",USB 主机则会为每个帧分配固定的带宽,并且保证每个帧正好传送一个 IN 分组或者 OUT 分组(由端点传输方向确定分组类型)。为了满足带宽要求,同步传输中没有出错重传; 这也就意味着,同步传输在发送或接收数据分组之后,无握手协议,即不会发送 ACK 分组。同样,同步传输只传送 PID (分组 ID)为 DATAO 的数据包,而不会用到数据翻转机制。

通过设置 USB\_EPxR 寄存器 EP\_TYPE 为'10',可以使其成为同步端点。同步端点没有握手机制,根据 USB 标准中的说明,USB\_EPxR 寄存器的 STAT\_RX 位和 STAT\_TX 位分别只能设成'00'(禁止)和'11'(有效)。同步传输通过实现双缓冲机制来简化软件应用程序开发,它同样使用两个缓冲区,以确保在 USB 模块使用其中一块缓冲区时,应用程序可以访问另外一块缓冲区。

USB 模块使用的缓冲区根据不同的传输方向,由不同的 DTOG 位来标识。(同一寄存器中的 DTOG\_RX 位用来标识接收同步端点,DTOG\_TX 位用来标识发送同步端点),见下表。

| 端点类型   | DTOG 位值 | USB 模块使用的缓冲区           | 应用程序使用的缓冲区             |
|--------|---------|------------------------|------------------------|
| IN 端点  | 0       | ADDRx_TX_0/COUNTx_TX_0 | ADDRx_TX_1/COUNTx_TX_1 |
|        | 1       | ADDRx_TX_1/COUNTx_TX_1 | ADDRx_TX_0/COUNTx_TX_0 |
| OUT 端点 | 0       | ADDRx_RX_0/COUNTx_RX_0 | ADDRx_RX_1/COUNTx_RX_1 |
|        | 1       | ADDRx_RX_1/COUNTx_RX_1 | ADDRx_RX_0/COUNTx_RX_0 |

表 17-3 同步端点的缓冲区使用标识

与双缓冲批量端点一样,一个 USB\_EPxR 寄存器只能处理同步端点单方向的数据传输,如果要求同步端点在两个传输方向上都有效,则需要使用两个 USB EPxR 寄存器。

应用程序需要根据首次传输的数据分组来初始化 DTOG 位;它的取值还需要考虑到 DTOG\_RX 或 DTOG\_TX 两位的数据翻转特性。每次传输完成时,USB\_EPxR 寄存器的 CTR\_RX 位或 CTR\_TX 位置位。与此同时,相关的 DTOG 位由硬件翻转,从而使得交换缓冲区的操作完全独立于应用程序。传输结束时,STAT\_RX 或 STAT\_TX 位不会发生变化,因为同步传输没有握手机制,所以不需要任何流量控制,而一直设为'11'(有效)。同步传输中,即使 OUT 分组发生 CRC 错误或者缓冲区溢出,本次传输仍被看作是正确的,并且可以触发 CTR\_RX 中断事件;但是,发生 CRC 错误时硬件会设置 USB\_ISTR 寄存器的 ERR 位,提醒应用程序数据可能损坏。

## 17.3.5 挂起/唤醒事件

USB 标准中定义了一种特殊的设备状态,即挂起状态,在这种状态下 USB 总线上的平均电流消耗不超过 2.5mA。这种电流限制对于由总线供电的 USB 设备至关重要,而自供电的设备则不需要严格遵守这样的电流消耗限制。USB 主机以 3 毫秒内不发送任何信号标志进入挂起状态。通常情况下 USB 主机每毫秒会发送一个 SOF,当 USB 模块检测到 3 个连续的 SOF 分组丢失事件即可判定主机发出了挂起请求,接着它会置位 SB\_ISTR 寄存器的 SUSP 位,以触发挂起中断。USB 设备进入挂起状态之后,将由"唤醒"序列唤醒。所谓的"唤醒"序列,可以由 USB 主机发起,也可以由 USB 设备本身触发;但是,只有 USB 主机可以结束"唤醒"序列。被挂起的 USB 模块必须至少还具备检测 RESET 信号的功能,它会将其当作一次正常的复位操作来执行。

实际的挂起操作过程对于不同的 USB 设备来说是不同的,因为需要不同的操作来降低电源消耗。下面描述了一起典型的挂起操作,重点介绍应用程序如何响应 USB 模块的 SUSP 信号:

1. 将 USB CNTR 寄存器的 FSUSP 置为'1',这将使 USB 模块进入挂起状态。USB 模块一旦进入挂起



状态,对 SOF 的检测立刻停止,以避免在 USB 挂起时又发生新的 SUSP 事件。

- 2. 消除或减少 USB 模块以外的其他模块的静态电流消耗。
- 3. 可以选择关闭外部振荡器和设备的 PLL,以停止设备内部的任何活动。

当设备处于挂起状态时发生 USB 事件,该设备会被唤醒,并需要调用"唤醒"程序来恢复正常时钟和 USB 数据传输。如果唤醒设备的是 USB 复位操作,则应该保证唤醒的过程不要超 10 毫秒(参见 USB 协议规范)。即使唤醒事件可以立刻触发一个使能了的 WKUP 中断事件,但由于恢复系统时钟需要比较长的延迟时间,处理 WKUP 中断的中断服务程序必须非常小心;为了减短系统唤醒的时间,建议将唤醒代码直接写在挂起代码后面,这样就可以在系统时钟重启后迅速进入唤醒代码中执行。为防止或减少 ESD 等干扰意外地唤醒系统(从挂起模式退出是一个异步事件),在挂起过程中数据线被过滤,滤波宽度大约为 70ns。

下面是唤醒操作的过程:

- 1. 启动外部振荡器和设备的 PLL (此项可选)。
- 2. 清零 USB CNTR 寄存器的 FSUSP 位。
- 3. USB\_FNR 寄存器的 RXDP 和 RXDM 位可以用来判断是什么触发了唤醒事件,如表 17-4 所示,它还同时列出了各种情况软件应该采取的操作。如果需要的话,可以通过检测这两位变成'10'(代表空闲总线状态)的时间来知道唤醒或复位事件的结束。此外,在复位事件结束时,USB\_ISTR 寄存器的 RESET 位被置为'1',如果 RESET 中断被使能,就会产生中断。此中断应该按正常的复位操作处理。

| [RXDP, RXDM]的状态 | 唤醒事件        | 应用程序应执行的操作 |
|-----------------|-------------|------------|
| 00              | 复位          | 无          |
| 10              | 无 (总线干扰)    | 恢复到挂起状态    |
| 01              | 恢复挂起        | 无          |
| 11              | 未定义的值(总线干扰) | 恢复到挂起状态    |

表 17-4 唤醒事件检测

设备可能不是被与 USB 模块相关的事件唤醒的(例如一个鼠标的移动可唤醒整个系统)。在这种情况下,先将 USB\_CNTR 寄存器的 RESUME 位置为'1',然后在 1ms 到 15ms 之间再把它清为 0 可以启动唤醒序列(这个间隔可以用 ESOF 中断来实现,该中断在内核正常运行时每 1ms 发生一次)。RESUME 位被清零后,唤醒过程将由主机 PC 完成,可以利用 USB\_FNR 寄存器的 RXDP 和 RXDM 位来判断唤醒是否完成。

注意: 只有在 USB 模块被设置为挂起状态时(设置 USB\_CNTR 寄存器的 FSUSP 位为'1'),才可以设置 RESUME 位。

## 17.4 USB 寄存器

基地址: 0x4000 5C00

空间大小: 0x400

USB 模块的寄存器有以下三类:

- 通用类寄存器:中断寄存器和控制寄存器。
- 端点类寄存器:端点配置寄存器和状态寄存器。
- 缓冲区描述表类寄存器: 用来确定数据分组存放地址的寄存器缓冲区描述表类寄存器的基地址



由 USB\_BTABLE 寄存器指定,所有其他寄存器的基地址则为 USB 模块的基地址 0x4000 5C00。由于 APB1 总线按 32 位寻址,因此所有的 16 位寄存器的地址都是按 32 位字对齐的。同样的地址对齐方式也用于从 0x4000 6000 开始的分组缓冲存储区。

可以用半字(16位)或字(32位)的方式操作这些外设寄存器。

### 17.4.1 通用寄存器

这组寄存器用于定义 USB 模块的工作模式,中断的处理,设备的地址和读取当前帧的编号。

### 17.4.1.1 USB 控制寄存器(USB\_CNTR)

偏移地址: 0x40 复位值: 0x0003

| 15  | 14     | 13  | 12   | 11   | 10    | 9   | 8    | 7   | 6 | 5         | 4  | 3    | 2 1 | 0   |
|-----|--------|-----|------|------|-------|-----|------|-----|---|-----------|----|------|-----|-----|
| CTR | PMAOVR | ERR | WKUP | SUSP | RESET | SOF | ESOF | Res |   | Res RESUM |    | FSUS | Res | FRE |
| M   | M      | M   | М    | М    | M     | M   | M    |     |   |           | E  | Р    |     | S   |
| rw  | rw     | rw  | rw   | rw   | rw    | rw  | rw   |     |   |           | rw | rw   |     | rw  |

| I VV             | TW TW TW TW TW TW TW                                                                                  |  |  |  |  |  |  |  |  |  |  |  |  |
|------------------|-------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|
| 位 15             | CTRM: 正确传输中断屏蔽位(Correct transfer interrupt mask)  • 0: 正确传输中断禁止。  • 1: 正确传输中断使能,在中断寄存器的相应位被置 1 时产生中断。 |  |  |  |  |  |  |  |  |  |  |  |  |
|                  | · 1: 正确控制作例反形,但作例可行相的相应应恢复 1 时) 工作例。                                                                  |  |  |  |  |  |  |  |  |  |  |  |  |
| 位 14             | PMAOVRM: 分组缓冲区溢出中断屏蔽位(Packet memory area over/underrun interrupt                                      |  |  |  |  |  |  |  |  |  |  |  |  |
|                  | mask)                                                                                                 |  |  |  |  |  |  |  |  |  |  |  |  |
|                  | • 0: 分组缓冲区溢出中断禁止。                                                                                     |  |  |  |  |  |  |  |  |  |  |  |  |
|                  | • 1: 分组缓冲区溢出中断使能,在中断寄存器的相应位被置1时产生中断。                                                                  |  |  |  |  |  |  |  |  |  |  |  |  |
| 位 13             | ERRM: 出错中断屏蔽位(Error interrupt mask)                                                                   |  |  |  |  |  |  |  |  |  |  |  |  |
|                  | <ul><li>● 0: 出错中断禁止。</li></ul>                                                                        |  |  |  |  |  |  |  |  |  |  |  |  |
|                  | • 1: 出错中断使能,在中断寄存器的相应位被置1时产生中断。                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |
|                  |                                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |
| 位 12             | WKUPM: 唤醒中断屏蔽位(Wakeup interrupt mask)                                                                 |  |  |  |  |  |  |  |  |  |  |  |  |
|                  | • 0: 唤醒中断禁止。                                                                                          |  |  |  |  |  |  |  |  |  |  |  |  |
|                  | • 1: 唤醒中断使能,在中断寄存器的相应位被置 1 时产生中断。                                                                     |  |  |  |  |  |  |  |  |  |  |  |  |
| 位 11             | SUSPM: 挂起中断屏蔽位(Suspend mode interrupt mask)                                                           |  |  |  |  |  |  |  |  |  |  |  |  |
|                  | • 0: 挂起中断禁止                                                                                           |  |  |  |  |  |  |  |  |  |  |  |  |
|                  | • 1: 挂起中断使能,在中断寄存器的相应位被置1时产生中断。                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |
| 位 10             | RESETM: USB 复位中断屏蔽位(USB reset interrupt mask)                                                         |  |  |  |  |  |  |  |  |  |  |  |  |
| ,                | • 0: USB 复位中断禁止。                                                                                      |  |  |  |  |  |  |  |  |  |  |  |  |
|                  | • 1: USB 复位中断使能,在中断寄存器的相应位被置 1 时产生中断。                                                                 |  |  |  |  |  |  |  |  |  |  |  |  |
| / <del>-</del> - |                                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |
| 位 9              | SOFM: 帧起始位中断屏蔽位(Start of frame interrupt mask)                                                        |  |  |  |  |  |  |  |  |  |  |  |  |
|                  | • 0: 帧起始位中断禁止。                                                                                        |  |  |  |  |  |  |  |  |  |  |  |  |
|                  | • 1: 帧起始位中断使能,在中断寄存器的相应位被置1时产生中断。                                                                     |  |  |  |  |  |  |  |  |  |  |  |  |
| 位 8              | ESOFM: 期望帧起始位中断屏蔽位(Expected start of frame interrupt mask)                                            |  |  |  |  |  |  |  |  |  |  |  |  |



|       | • 0: 期望帧起始位中断禁止<br>• 1: 期望帧起始位中断使能,在中断寄存器的相应位被置1时产生中断。                                                                                        |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 位 7:5 | Res: 保留<br>必须保持复位值。                                                                                                                           |
| 位 4   | RESUME: 唤醒请求(Resume request)<br>设置此位将向 PC 主机发送唤醒请求。根据 USB 协议,如果此位在 1 ms 到 15 ms 内保持有效,主机将对 USB 模块实行唤醒操作。                                      |
| 位 3   | FSUSP: 强制挂起(Force suspend)<br>当 USB 总线上保持 3ms 没有数据通信时,SUSP 中断会被触发,此时软件必须设置此位。<br>• 0: 无效<br>• 1: 进入挂起模式                                       |
| 位 2:1 | Res: 保留<br>必须保持复位值。                                                                                                                           |
| 位 0   | FRES: 强制 USB 复位(Force USB reset)  • 0: 清除 USB 复位信号。  • 1: 对 USB 模块强制复位,类似于 USB 总线上的复位信号。  USB 模块将一直保持在复位状态下直到软件清除此位。如果 USB 复位中断被使能,将产生一个复位中断。 |

# 17.4.1.2 USB 中断状态寄存器(USB\_ISTR)

偏移地址: 0x44 复位值: 0x0000

| 15  | 14     | 13    | 12    | 11    | 10    | 9     | 8     | 7 | 7 6 5 |   | 4   | 3 | 2     | 1      | 0 |
|-----|--------|-------|-------|-------|-------|-------|-------|---|-------|---|-----|---|-------|--------|---|
| CTR | PMAOVR | ERR   | WKUP  | SUSP  | RESET | SOF   | ESOF  |   | Res   |   | DIR |   | EP_IC | 0[3:0] |   |
| r   | rc w0  | rc w0 | rc w0 | rc w0 | rc w0 | rc w0 | rc w0 |   |       | r |     |   | r     |        |   |

| 位 15 | CTR: 正确的传输(Correct transfer)<br>此位在端点正确完成一次数据传输后由硬件置位。应用程序可以通过 DIR 和 EP_ID 位来识别是哪个端点完成了正确的数据传输。<br>此位应用程序只读。                                                                                                                                                                                                                                  |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 14 | PMAOVR: 分组缓冲区溢出(Packet memory area over/underrun)<br>此位在微控制器长时间没有响应一个访问 USB 分组缓冲区请求时由硬件置位。USB 模块通<br>常在以下情况时置位该位: 在接收过程中一个 ACK 握手分组没有被发送,或者在发送过<br>程中发生了比特填充错误,在以上两种情况下主机都会要求数据重传。在正常的数据传<br>输中不会产生 PMAOVR 中断。由于失败的传输都将由主机发起重传,应用程序就可以在<br>这个中断的服务程序中加速设备的其他操作,并准备重传。但这个中断不会在同步传输<br>中产生(同步传输不支持重传)因此数据可能会丢失。<br>此位应用程序可读可写,但只有写 0 有效,写 1 无效。 |
| 位 13 | ERR: 出错(Error)                                                                                                                                                                                                                                                                                                                                |



在下列错误发生时硬件会置位此位: • NANS: 无应答 主机的应答超时。 • CRC: 循环冗余校验码错误 数据或令牌分组中的 CRC 校验出错。 • BST: 位填充错误 PID,数据或 CRC 中检测出位填充错误。 • **FVIO**: 帧格式错误 收到非标准帧(如 EOP 出现在错误的时刻,错误的令牌等)。 USB 应用程序通常可以忽略这些错误,因为 USB 模块和主机在发生错误时都会启动重传机 制。此位产生的中断可以用于应用程序的开发阶段,可以用来监测USB总线的传输质量, 标识用户可能发生的错误(连接线松,环境干扰严重, USB线损坏等)。 此位应用程序可读可写,但只有写0有效,写1无效。 位 12 WKUP: 唤醒请求(Wakeup) 当 USB 模块处于挂起状态时,如果检测到唤醒信号,此位将由硬件置位。此时 USB WAKEUP 被激活,通知设备的其他部分(如唤醒单元)将开始唤醒过程。 此位应用程序可读可写,但只有写0有效,写1无效。 位 11 SUSP: 挂起模块请求(Suspend mode request) 此位在 USB 线上超过 3ms 没有信号传输时由硬件置位,用以指示一个来自 USB 总线的挂 起请求。USB 复位后硬件立即使能对挂起信号的检测,但在挂起模式下(FSUSP=1)硬件 不会再检测挂起信号直到唤醒过程结束。 此位应用程序可读可写,但只有写 0 有效,写 1 无效。 位 10 RESET: USB 复位请求(USB reset request) 此位在 USB 模块检测到 USB 复位信号输入时由硬件置位。此时 USB 模块将复位内部协议 状态机,并在中断使能的情况下触发复位中断来响应复位信号。USB 模块的发送和接收部 分将被禁止,直到此位被清除。所有的配置寄存器不会被复位,除非应用程序对他们清 零。这用来保证在复位后 USB 传输还可以立即正确执行。但设备的地址和端点寄存器会 被 USB 复位所复位。 此位应用程序可读可写,但只有写 0 有效,写 1 无效。 位 9 SOF: 帧起始位标志(Start of frame) 此位在 USB 模块检测到总线上的 SOF 分组时由硬件置位,标志一个新的 USB 帧的开始。 中断服务程序可以通过检测 SOF 事件来完成与主机的 1ms 同步,并正确读出寄存器在收 到 SOF 分组时的更新内容(此功能在同步传输时非常有意义)。 此位应用程序可读可写,但只有写0有效,写1无效。 位 8 ESOF: 期望帧起始位标识位(Expected start of frame) 此位在 USB 模块未收到期望的 SOF 分组时由硬件置位。主机应该每毫秒都发送 SOF 分组, 但如果 USB 模块没有收到,挂起定时器将触发此中断。如果连续发生 3 次 ESOF 中断,也 就是连续 3 次未收到 SOF 分组,将产生 SUSP 中断。即使在挂起定时器未被锁定时发生 SOF 分组丢失,此位也会被置位。 此位应用程序可读可写,但只有写0有效,写1无效。



| 位 7:5 | Res: 保留<br>必须保持复位值。                                                                                                                                                                                                                                                                              |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 4   | DIR: 传输方向(Direction of transaction)<br>此位在完成数据传输产生中断后由硬件根据传输方向写入。  • 0: 相应端点的 CTR_TX 位被置位<br>标志一个 IN 分组(数据从 USB 模块传输到 PC 主机)的传输完成  • 1: 相应端点的 CTR_RX 位被置位<br>标志一个 OUT 分组(数据从 PC 主机传输到 USB 模块)的传输完成。如果 CTR_TX 位同时也被置位,就标志同时存在挂起的 OUT 分组和 IN 分组。应用程序可以利用该信息访问 USB_EPxR 位对应的操作,它表示挂起中断传输方向的信息该位为只读。 |
| 位 3:0 | EP_ID[3:0]: 端点 ID(Endpoint identifier)<br>此位在 USB 模块完成数据传输产生中断后由硬件根据请求中断的端点号写入。如果同时<br>有多个端点的请求中断,硬件写入优先级最高的端点号。<br>端点的优先级按以下方法定义: 同步端点和双缓冲批量端点具有高优先级,其他的端点<br>为低优先级。如果多个同优先级的端点请求中断,则根据端点号来确定优先级,即端点 0<br>具有最高优先级,端点号越小,优先级越高。应用程序可以通过上述的优先级策略顺序<br>处理端点的中断请求。<br>该位为只读。                        |

此寄存器包含所有中断源的状态信息,以供应用程序确认产生中断请求的事件。

寄存器的高 8 位各表示一个中断源。当相关事件发生时,这些位被硬件置位,如果 USB\_CNTR 寄存器上的相应位也被置位,则会产生相应的中断。中断服务程序需要检查每个位,在执行必要的操作后必须清除相应的状态位,不然中断信号线一直保持为高,同样的中断会再次被触发。如果同时多个中断标志被设置,也只会产生一个中断。

应用程序可以使用不同的方式处理传输完成中断,以减少中断响应的延迟时间。端点在成功完成一次传输后,CTR 位会被硬件置起,如果 USB\_CNTR 上的相应位也被设置的话,就会产生中断。与端点相关的中断标志和 USB\_CNTR 寄存器的 CTRM 位无关。这两个中断标志位将一直保持有效,直到应用程序清除了 USB EPxR 寄存器中的相关中断挂起位(CTR 位是个只读位)。

USB 模块有两路中断请求源:

- 高优先级的 USB IRQ: 用于高优先级的端点(同步和双缓冲批量端点)的中断请求,并且该中断不能被屏蔽。
- 低优先级 USB IRQ: 用于其他中断事件,可以是低优先级的不可屏蔽中断,也可以是由 USB\_ISTR 寄存器的高 8 位标识的可屏蔽中断。

对于端点产生的中断,应用程序可以通过 DIR 寄存器和 EP\_ID 只读位来识别中断请求由哪个端点产生,并调用相应的中断服务程序。

用户在处理同时发生的多个中断事件时,可以在中断服务程序里检查 USB\_ISTR 寄存器各个位的顺序来确定这些事件的优先级。在处理完相应位的中断后需要清零该中断标志。完成一次中断服务后,另一中断请求将会产生,用以请求处理剩下的中断事件。

为了避免意外清零某些位,建议使用加载指令,对所有不需改变的位写'1',对需要清除的位写'0'。对于该寄存器,不建议使用读出一修改一写入的流程,因为在读写操作之间,硬件可能需要设置某些位,而这些位会在写入时被清零。



# 17.4.1.3 USB 帧编号寄存器(USB\_FNR)

偏移地址: 0x48 复位值: 0x0XXX

说明: X 代表未定义数值。

| 15  | 14  | 13  | 12   | 11    | 10       | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
|-----|-----|-----|------|-------|----------|---|---|---|---|---|---|---|---|---|---|--|
| RXD | RXD | LCK | LSOF | [1:0] | FN[10:0] |   |   |   |   |   |   |   |   |   |   |  |
| Р   | M   |     |      |       |          |   |   |   |   |   |   |   |   |   |   |  |
| r   | r   | r   |      | r     |          | r |   |   |   |   |   |   |   |   |   |  |

| 位 15    | RXDP: D+状态位(Receive data + line status)<br>此位用于观察 USB D+数据线的状态,可在挂起状态下检测唤醒条件的出现。                                     |
|---------|----------------------------------------------------------------------------------------------------------------------|
| 位 14    | RXDM: D-状态位(Receive data - line status)<br>此位用于观察 USB D-数据线的状态,可在挂起状态下检测唤醒条件的出现。                                     |
| 位 13    | LCK:锁定位(Locked) USB 模块在复位或唤醒序列结束后会检测 SOF 分组,如果连续检测到至少 2 个 SOF 分组,则硬件会置位此位。此位一旦锁定,帧计数器将停止计数,一直等到 USB 模块复位或总线挂起时再恢复计数。 |
| 位 12:11 | LSOF[1:0]: 帧起始位丢失标志位(Lost SOF)<br>当 ESOF 事件发生时,硬件会将丢失的 SOF 分组的数目写入此位。如果再次收到 SOF 分组,引脚会清除此位。                          |
| 位 10:0  | FN[10:0]: 帧编号(Frame number)<br>此部分记录了最新收到的 SOF 分组中的 11 位帧编号。主机每发送一个帧,帧编号都会自加,这对于同步传输非常有意义。此部分发生 SOF 中断时更新。           |

### 17.4.1.4 USB 设备地址寄存器(USB\_DADDR)

偏移地址: 0x4C 复位值: 0x0000

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

| 位 15:8 | Res: 保留<br>必须保持复位值。                                                                                                           |
|--------|-------------------------------------------------------------------------------------------------------------------------------|
| 位 7    | EF: USB 模块使能位(Enable function)<br>此位在需要使能 USB 模块时由应用程序置位。ADD[6:0]包含了设备地址。如果此位为 0,<br>USB 模块将停止工作,忽略所有寄存器的设置,不响应任何 USB 通信。     |
| 位 6:0  | ADD[6:0]: 设备地址(Device address)<br>该位域记录了 USB 主机在枚举过程中为 USB 设备分配的地址值。该地址值和端点地址<br>(EA)必须和USB 令牌分组中的地址信息匹配,才能在指定的端点进行正确的USB 传输。 |



## 17.4.1.5 USB 分组缓冲区描述表地址寄存器(USB\_BTABLE)

偏移地址: 0x50 复位值: 0x0000

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

| 位 15:3 | BTABLE[15:3]:缓冲表(Buffer table) 该位域记录分组缓冲区描述表的起始地址。分组缓冲区描述表用来指示每个端点的分组缓冲区地址和大小,按8字节对齐(即最低3位为000)。每次传输开始时,USB模块读取相应端点所对应的分组缓冲区描述表获得缓冲区地址和大小信息。 |
|--------|----------------------------------------------------------------------------------------------------------------------------------------------|
| 位 2:0  | Res: 保留<br>必须保持复位值。                                                                                                                          |

## 17.4.2 端点寄存器

端点寄存器的数量由 USB 模块所支持的端点数目决定。USB 模块最多支持 8 个双向端点。每个USB 设备必须支持一个控制端点,控制端点的地址(EA 位)必须为 0。不同的端点必须使用不同的端点号,否则端点的状态不定。每个端点都有与之对应的 USB\_EPxR 寄存器,用于存储该端点的各种状态信息。

### 17.4.2.1 USB 端点 x 寄存器(USB\_EPxR)(x=0..7)

偏移地址: x\*4 复位值: 0x0000

| 15     | 14      |          | 12    | 11    | 10            | 9 | 8            | 7     | 6       | 5   | 4    | 3            | 2 | 1            | 0 |  |     |      |  |
|--------|---------|----------|-------|-------|---------------|---|--------------|-------|---------|-----|------|--------------|---|--------------|---|--|-----|------|--|
| CTR_RX | DTOG_RX | STAT_RX[ | [1:0] | SETUP | SETUP EP_TYPE |   | EP_TYPE[1:0] |       | EP_KIND | CTR | DTOG | STAT_TX[1:0] |   | STAT_TX[1:0] |   |  | EA[ | 3:0] |  |
|        |         |          |       |       |               |   |              | _TX   | _TX     |     |      |              |   |              |   |  |     |      |  |
| rc w0  | t       | t        |       | r     | rv            | v | rw           | rc w0 | t       | t   |      | rw           |   |              |   |  |     |      |  |

| 位 15 | CTR_RX: 正确接收标志位(Correct transfer for reception) 此位在正确接收到 OUT 或 SETUP 分组时由硬件置位,应用程序只能对此位清零。如果 CTRM 位已置位,相应的中断会产生。收到的是 OUT 分组还是 SETUP 分组可以通过下面描述的 SETUP 位确定。以 NAK 或 STALL 结束的分组和出错的传输不会导致此位置位,因为没有真正传输数据。 此位应用程序可读可写,但只有写 0 有效,写 1 无效。                                                                                                      |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 14 | DTOG_RX: 用于数据接收的数据翻转位(Data Toggle, for reception transfers)对于非同步端点,此位由硬件设置,用于标记希望接收的下一个数据分组的 Toggle 位(0=DATAO,1=DATA1)。在接收到PID(分组ID)正确的数据分组之后,USB模块发送ACK握手分组,并翻转此位。对于控制端点,硬件在收到 SETUP 分组后清除此位。对于双缓冲端点,此位还用于支持双缓冲区的交换(请参考章节:"17.3.3 双缓冲端点")。对于同步端点,由于仅发送 DATAO,因此位仅用于支持双缓冲区的交换(请参考章节:"17.3.4 同步传输")而不需进行翻转。同步传输不需要握手分组,因此硬件在收到数据分组后立即设置此位。 |



| 应用程序可以对此位进行初始化(对于非控制端点,初始化是必需的),或者翻转此位用于特殊用途。                                                                                                                                        |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 此位应用程序可读可写,但写0无效,写1可以翻转此位。                                                                                                                                                           |
| STAT_RX[1:0]: 用于数据接收的状态位(Status bits, for reception transfers)                                                                                                                       |
| 该位域用于指示端点当前的状态,表 17-5 列出了端点的所有状态。当一次正确的 OUT 或 SETUP 数据传输完成后(CTR_RX=1),硬件会自动设置此位为 NAK 状态,使应用程序有足够的时间在处理完当前传输的数据后,响应下一个数据分组。                                                           |
| 对于双缓冲批量端点,由于使用特殊的传输流量控制策略,因此根据使用的缓冲区状态控制传输状态(参见:"17.3.3 双缓冲端点")。                                                                                                                     |
| 对于同步端点,由于端点状态只能是有效或禁用,因此硬件不会在正确的传输之后设置此位。如果应用程序将此位设为 STALL 或者 NAK, USB 模块响应的操作是未定义的。此位应用程序可读可写,但写 0 无效,写 1 翻转此位。                                                                     |
| SETUP: SETUP 分组传输完成标志位(Setup transaction completed)                                                                                                                                  |
| 此位在 USB 模块收到一个正确的 SETUP 分组后由硬件置位,只有控制端点才使用此位。在接收完成后(CTR_RX=1),应用程序需要检测此位以判断完成的传输是否是 SETUP 分组。为了防止中断服务程序在处理 SETUP 分组时下一个令牌分组修改了此位,只有 CTR_RX 为 0 时,此位才可以被修改,CTR_RX 为 1 时不能修改。此位应用程序只读。 |
| EP_TPYE[1:0]: 端点类型位(Endpoint type)                                                                                                                                                   |
| 该位域用于指示端点当前的类型,所有的端点类型都在表 17-6 中列出。<br>所有的 USB 设备都必须包含一个地址为 0 的控制端点,如果需要可以有其他地址的控制端<br>点。只有控制端点才会有 SETUP 传输,其他类型的端点无视此类传输。                                                           |
| SETUP 传输不能以 NAK 或 STALL 分组响应,如果控制端点在收到 SETUP 分组时处于 NAK 状态,USB 模块将不响应分组,就会出现接收错误。如果控制端点处于 STALL 状态,SETUP 分组会被正确接收,数据会被正确传输,并产生一个正确传输完成的中断。控制端点的 OUT 分组安装普通端点的方式处理。                    |
| 批量端点和中断端点的处理方式非常类似,仅在对 EP_KIND 位的处理上有差别。同步端点的用法请参考章节:"17.3.4同步传输"。                                                                                                                   |
| EP_KIND:端点特殊类型位(Endpoint kind)                                                                                                                                                       |
| 此位需要和 EP_TYPE 位配合使用,具体的定义参见:表 17-7。                                                                                                                                                  |
| DBL_BUF: 应用程序设置此位能使能批量端点的双缓冲功能。详见章节: "17.3.3 双缓冲端点"。                                                                                                                                 |
| STATUS_OUT:应用程序设置此位表示 USB 设备期望主机发送一个状态数据分组,此时,设备对于任何长度不为 0 的数据分组都响应 STALL 分组。此功能仅用于控制端点,有利于提供应用程序对于协议层错误的检测。如果 STATUS_OUT 位被清除,OUT 分组可以包含任意长度的数据。                                    |
| CTR_TX: 正确发送标志位(Correct transfer for transmission)                                                                                                                                   |
| 此位由硬件在一个正确的 IN 分组传输完成后置位。如果 CTRM 位已被置位,会产生相应的中断。应用程序需要在处理完该事件后清除此位。在 IN 分组结束时,如果主机响应 NAK 或 STALL 则此位不会被置位,因为数据传输没有成功。此位应用程序可读可写,但写 0 有效,写 1 无效。                                      |
|                                                                                                                                                                                      |



## 位 6 DTOG TX: 发送数据翻转位 (Data Toggle, for transmission transfers) 对于非同步端点,此位用于指示下一个要传输的数据分组的 Toggle 位(0=DATAO, 1=DATA1)。在一个成功传输的数据分组后,如果 USB 模块接收到主机发送的 ACK 分组, 就会翻转此位。 对于控制端点, USB 模块会在收到正确的 SETUP PID 后置位此位。 对于双缓冲端点,此位还可用于支持分组缓冲区交换(参见:"17.3.3 双缓冲端点")。 对于同步端点,由于只传送 DATAO,因此该位只用于支持分组缓冲区交换(参见:"17.3.4 同步传输")。由于同步传输不需要握手分组,因此硬件在接收到数据分组后即设置该 应用程序可以初始化该位(对于非控制端点,初始化此位是必需的),也可以设置该位用 于特殊用途。 此位应用程序可读可写,但写 0 无效,写 1 翻转此位。 位 5:4 STAT TX[1:0]: 用于发送数据的状态位(Status bits, for transmission transfers) 该位域用于标识端点的当前状态,表 17-8 列出了所有的状态。应用程序可以翻转这些位 来初始化状态信息。在正确完成一次 IN 或者 SETUP 分组的传输后(CTR TX=1), 硬件会自 动设置此位为 NAK 状态,保证应用程序有足够的时间准备好数据响应后续的数据传输。 对于双缓冲批量端点,由于使用特殊的传输流量控制策略,是根据缓冲区的状态控制传 输的状态的(参见:"17.3.3 双缓冲端点")。 对于同步端点,由于端点的状态只能是有效或禁用,因此硬件不会在数据传输结束时改 变端点的状态。如果应用程序将此位设为 STALL 或者 NAK,则 USB 模块后续的操作是未定 义的。 此位应用程序可读可写,但写0无效,写1翻转此位。 位 3:0 EA[3:0]: 端点地址(Endpoint address) 应用程序必须设置此4位,在使能一个端点前为它定义一个地址。

当 USB 模块收到 USB 总线复位信号,或 CTLR 寄存器的 FRES 位置位时,USB 模块将会复位。该寄存器除了 CTR\_RX 和 CTR\_TX 位保持不变以处理紧随的 USB 传输外,其他位都被复位。每个端点对应一个 USB EPxR 寄存器,其中 n 为端点地址,即端点 ID 号。

对于此类寄存器应避免执行读出一修改一写入操作,因为在读和写操作之间,硬件可能会设置某些位,而这些位又会在写入时被修改,导致应用程序错过相应的操作。因此,这些位都有一个写入无效的值,建议用 Load 指令修改这些寄存器,以免应用程序修改了不需要修改的位。

表 17-5 接收状态编码

| STAT_RX[1:0] | 描述                            |
|--------------|-------------------------------|
| 00           | DISABLED:端点忽略所有的接收请求。         |
| 01           | STALL: 端点以 STALL 分组响应所有的接收请求。 |
| 10           | NAK: 端点以 NAK 分组响应所有的接收请求。     |
| 11           | VALID:端点可用于接收。                |

表 17-6 端点类型编码



| EP_TYPE[1:0] | 描述              |
|--------------|-----------------|
| 00           | BULK: 批量端点      |
| 01           | CONTROL: 控制端点   |
| 10           | ISO: 同步端点       |
| 11           | INTERRUPT: 中断端点 |

#### 表 17-7 端点特殊类型定义

| EP_TYPE[1:0] |           | EP_KIND 意义     |
|--------------|-----------|----------------|
| 00 BULK      |           | DBL_BUF: 双缓冲端点 |
| 01           | CONTROL   | STATUS_OUT     |
| 10           | ISO       | 未使用            |
| 11           | INTERRUPT | 未使用            |

#### 表 17-8 发送状态编码

| STAT_TX[1:0] | 描述                            |
|--------------|-------------------------------|
| 00           | DISABLED:端点忽略所有的发送请求。         |
| 01           | STALL: 端点以 STALL 分组响应所有的发送请求。 |
| 10           | NAK: 端点以 NAK 分组响应所有的发送请求。     |
| 11           | VALID: 端点可用于发送。               |

### 17.4.3 缓冲区描述表

基地址: 0x4000 6000

空间大小: 0x400

说明:此缓冲区和 CAN 共用, USB 和 CAN 可以同时用于一个应用中但不能在同一个时间使用。

虽然缓冲区描述表位于分组缓冲区内,但仍可将它看作是特殊的寄存器,用以配置 USB 模块和微控制器内核共享的分组缓冲区的地址和大小。由于 APB1 总线按 32 位寻址,所以所有的分组缓冲区地址都使用 32 位对齐的地址,而不是 USB\_BTABLE 寄存器和缓冲区描述表所使用的地址。

以下介绍两种地址表示方式:一种是应用程序访问分组缓冲区时使用的,另一种是相对于 USB模块的本地地址。供应用程序使用的分组缓冲区地址需要乘以 2 才能得到缓冲区在微控制器中的真正地址。分组缓冲区的首地址为 0x4000 6000。下面将描述与 USB\_EPxR 寄存器相关的缓冲区描述表。完整的分组缓冲区的说明和缓冲区描述表的用法参见:"17.3.2.2 分组缓冲区的结构和用途"。

#### 17.4.3.1 发送缓冲区地址寄存器 x(USB\_ADDRx\_TX)(x=0..7)

偏移地址: [USB\_BTABLE] +x\*16 USB 本地地址: [USB\_BTABLE] +x\*8

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



| 位 | 15:1 | ADDRx_TX[15:1]: 发送缓冲区地址(Transmission buffer address)<br>此位记录了收到下一个 IN 分组时,需要发送的数据所在的缓冲区起始地址。 |
|---|------|----------------------------------------------------------------------------------------------|
| 位 | 0    | 因为分组缓冲区的地址必须按字对齐,所以此位必须写为'0'。                                                                |

## 17.4.3.2 发送数据字节数寄存器 x(USB\_COUNTx\_TX)(x=0..7)

15 14 13 12 11 10 9 8 7 6

偏移地址: [USB\_BTABLE] +x\*16 +4

USB 本地地址: [USB\_BTABLE] + x\*8 +2

|         | Res                         | COUNTx_TX[9:0]                                    |
|---------|-----------------------------|---------------------------------------------------|
|         | -                           | rw                                                |
| 位 15:10 | Res:保留位,必须保持复由于 USB 模块支持的最大 | 位值。<br>数据分组为 1023 个字节,所以 USB 模块忽略该位域。             |
| 位 9:0   |                             | 居字节数(Transmission byte count)<br>IN 分组时要传输的数据字节数。 |

双缓冲区和同步 IN 端点有两个 USB\_COUNTx\_TX 寄存器:分别为 USB\_COUNTx\_TX\_1 和 USB\_COUNTx\_TX\_0,内容如下:

| 31    | 30  | 29                                                                                                        | 28                       | 27  | 26  | 25   | 24 | 23 | 22  | 21     | 20       | 19               | 18  | 17  | 16  |  |
|-------|-----|-----------------------------------------------------------------------------------------------------------|--------------------------|-----|-----|------|----|----|-----|--------|----------|------------------|-----|-----|-----|--|
|       |     |                                                                                                           | Res                      |     |     |      |    |    | (   |        | _TX_1[9: | 0]               |     |     |     |  |
|       |     |                                                                                                           | -                        |     |     | rw   |    |    |     |        |          |                  |     |     |     |  |
| 15    | 14  |                                                                                                           |                          |     |     |      |    |    |     |        |          |                  | 1   | 0   |     |  |
|       |     | R                                                                                                         | es                       |     |     |      |    |    | CC  | DUNTx_ | TX_0[9:0 | ]                |     |     |     |  |
|       |     | - rw                                                                                                      |                          |     |     |      |    |    |     |        |          |                  |     |     |     |  |
| 位 31  | :26 | 26 Res: 保留位,必须保持复位值。<br>由于 USB 模块支持的最大数据分组为 1023 个字节,所以 USB 模块忽略该位域,相当于非双缓冲和非同步端点的发送数据字节寄存器。              |                          |     |     |      |    |    |     |        |          |                  |     |     |     |  |
| 位 25  | :16 | COUNTx_TX_1[9:0]: 发送数据字节数 1(Transmission byte count) 该位域记录了收到下一个 IN 分组时要传输的数据字节数,相当于非双缓冲和非同步端点的发送数据字节寄存器。 |                          |     |     |      |    |    |     |        |          |                  |     |     |     |  |
| 位 15  | :10 | 曲チし                                                                                                       | 保留位,<br>JSB 模块<br>P和非同   | 支持的 | 最大数 | 按据分: |    |    | 字节, | 所以し    | ISB 模均   | 央忽略 <sup>-</sup> | 该位域 | ,相当 | 当于非 |  |
| 位 9:0 | 0   | 该位域                                                                                                       | [x_TX_0[<br>就记录了<br>[数据字 | 收到下 | 一个1 |      |    |    |     |        |          | F非双:             | 缓冲和 | 非同步 | 5端点 |  |

### 17.4.3.3 接收缓冲区地址寄存器 x(USB\_ADDRx\_RX)(x=0..7)

偏移地址: [USB\_BTABLE] +x\*16 +8

USB 本地地址: [USB\_BTABLE] + x\*8 +4

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



| ADDRx_RX[15:1] rw |                                                                                                 |  |  |  |  |  |  |  |
|-------------------|-------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| 位 15:1            | ADDRx_RX[15:1]:接收缓冲区地址(Reception buffer address)<br>此位记录了收到下一个 OUT 或者 SETUP 分组时,用于保存数据的缓冲区起始地址。 |  |  |  |  |  |  |  |
| 位 0               | 因为分组缓冲区的地址按字对齐,所以此位必须写为'0'。                                                                     |  |  |  |  |  |  |  |

### 17.4.3.4 接收数据字节数寄存器 x(USB\_COUNTx\_RX)(x=0..7)

偏移地址: [USB\_BTABLE] +x\*16 +12

USB 本地地址: [USB\_BTABLE] + x\*8 +6

| 15      | 14 | 13  | 12     | 11     | 10 | 9              | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---------|----|-----|--------|--------|----|----------------|---|---|---|---|---|---|---|---|---|
| BL_SIZE |    | NUM | _BLOCK | ([4:0] |    | COUNTx_RX[9:0] |   |   |   |   |   | ] |   |   |   |
| rw      |    |     | rw     |        |    | r              |   |   |   |   |   |   |   |   |   |
|         |    |     |        |        |    |                |   |   |   |   |   |   |   |   |   |

| 1 44    |                                                                                                               |
|---------|---------------------------------------------------------------------------------------------------------------|
| 位 15    | BL_SIZE:存储区块的大小(Block size)<br>此位用于定义决定缓冲区大小的存储区块的大小。                                                         |
|         | • 如果 BL_SIZE=0,存储区块的大小为 2 字节,因此能分配的分组缓冲区的大小范围为 2~62 个字节。                                                      |
|         | • 如果 BL_SIZE=1,存储区块的大小为 32 字节,因此能分配的分组缓冲区的大小范围为 32~1024字节,符合 USB 协议定义的最大分组长度限制。                               |
| 位 14:10 | NUM_BLOCK[4:0]:存储区块的数目(Number of blocks)<br>此位用以记录分配的存储区块的数目,从而决定最终使用的分组缓冲区的大小。具体请<br>参考表 17-9。               |
| 位 9:0   | COUNTx_RX[9:0]:接收到的字节数(Reception byte count)<br>此位由 USB 模块写入,用以记录端点收到的和 USB_EPxR 相关的最新的 OUT 或 SETUP 分组的实际字节数。 |

该寄存器用于存放接收分组时需要使用到的两个参数。最高的标志位定义了接收分组缓冲区的大小,以便 USB 模块检测缓冲区的溢出。低标志位则用于 USB 模块记录实际接收到的字节数。由于有效位数的限制,缓冲区的大小由分配到的存储区块数表示,而存储区块的大小则由所需的缓冲区大小决定。缓冲区的大小在设备枚举过程中定义,由端点描述符的参数 maxPacketSize 表述。(具体信息请参考 USB 2.0 协议规范)

双缓冲区和同步 IN 端点有两个 USB\_COUNTx\_RX 寄存器:分别为 USB\_COUNTx\_RX\_1 和 USB\_COUNTx\_RX\_0,内容如下(与发送数据字节数寄存器相同,高 16 位为接收数据字节数寄存器,低 16 位为发送数据字节数寄存器):

| 31        | 30 | 29      | 28                                | 27      | 26 | 25         24         23         22         21         20         19         18 |                     |  |  |         |          |                |  | 17 | 16 |
|-----------|----|---------|-----------------------------------|---------|----|---------------------------------------------------------------------------------|---------------------|--|--|---------|----------|----------------|--|----|----|
| BLSIZE_1  |    | NUM_    | BLOCK_                            | _1[4:0] |    | COUNTx_RX_1[9:0]                                                                |                     |  |  |         |          |                |  |    |    |
| rw        |    |         | rw                                |         |    |                                                                                 |                     |  |  | 1       | r        |                |  |    |    |
|           |    |         |                                   |         |    |                                                                                 |                     |  |  |         |          |                |  |    |    |
| 15        | 14 | 13      | 12                                | 11      | 10 | 9                                                                               | 9 8 7 6 5 4 3 2 1 0 |  |  |         |          |                |  |    |    |
| DI CIZE O |    | VILIN   | NUM_BLOCK_0[4:0] COUNTX_RX_0[9:0] |         |    |                                                                                 |                     |  |  |         |          |                |  |    |    |
| BLSIZE_0  |    | INOIVI_ | _BLOCK_                           | _0[4.0] |    |                                                                                 |                     |  |  | OUIVIA_ | 11X_0[J. | o <sub>j</sub> |  |    |    |

#### 表 17-9 分组缓冲区大小的定义

| NUM_BLOCK_x[4:0]的值 | BL_SIZE=0 时的分组缓冲区大小 | 当 BL_SIZE=1 时的分组缓冲区大小 |
|--------------------|---------------------|-----------------------|
| 00000              | 不允许使用               | 32 字节                 |



| NUM_BLOCK_x[4:0]的值 | BL_SIZE=0 时的分组缓冲区大小 | 当 BL_SIZE=1 时的分组缓冲区大小 |
|--------------------|---------------------|-----------------------|
| 00001              | 2 字节                | 64 字节                 |
| 00010              | 4 字节                | 96 字节                 |
| 00011              | 6 字节                | 128 字节                |
|                    |                     |                       |
| 01111              | 30 字节               | 512 字节                |
| 0000               | 32 字节               | 保留                    |
| 10001              | 34 字节               | 保留                    |
| 10010              | 36 字节               | 保留                    |
|                    |                     |                       |
| 11110              | 60 字节               | 保留                    |
| 11111              | 62 字节               | 保留                    |



### 18 控制器局域网(bxCAN)

bxCAN 是基本扩展 CAN (Basic Extended CAN) 的缩写,它支持 CAN 协议 2.0A 和 2.0B。它的设计目标是,以最小的 CPU 负荷来高效处理大量收到的报文。它也支持报文发送的优先级要求(优先级特性可软件配置)。

对于安全紧要的应用, bxCAN 提供所有支持时间触发通信模式所需的硬件功能。

## 18.1 bxCAN 主要特点

- 支持 CAN 协议 2.0A 和 2.0B 主动模式
- 波特率最高可达 1 Mbit/s
- 支持时间触发通信功能
- 发送:
  - 。 3个发送邮箱
  - 。 发送报文的优先级特性可软件配置
  - 。 记录发送 SOF 时刻的时间戳
- 接收:
  - 。 2个3级深度的接收 FIFO
  - 。 14 个可变的过滤器组
  - 。 标识符列表
  - 。 FIFO 溢出处理方式可配置
  - 。 记录接收 SOF 时刻的时间戳
- 时间触发通信模式:
  - 。 禁止自动重传模式
  - 。 16 位自由运行定时器
  - 。 可在最后 2 个数据字节发送时间戳
- 管理:
  - 。可屏蔽中断
  - 邮箱占用单独1块地址空间,便于提高软件效率。

注意: USB 和 CAN 共用一个专用的 512 字节的 SRAM 存储器用于数据的发送和接收,因此不能同时使用 USB 和 CAN (共享的 SRAM 被 USB 和 CAN 模块互斥地访问)。 USB 和 CAN 可以同时用于一个应用中但不能在同一个时间使用。

## 18.2 bxCAN 总体描述

在当今的 CAN 应用中,CAN 网络的节点在不断增加,并且多个 CAN 常常通过网关连接起来,因此整个 CAN 网中的报文数量(每个节点都需要处理)急剧增加。除了应用层报文外,网络管理和诊断报文也被引入。

- 需要一个增强的过滤机制来处理各种类型的报文。此外,应用层任务需要更多 CPU 时间,因此报文接收所需的实时响应程度需要减轻。
- 接收 FIFO 的方案允许 CPU 花很长时间处理应用层任务而不会丢失报文。 构筑在底层 CAN 驱动程序上的高层协议软件,要求跟 CAN 控制器之间有高效的接口。





图 18-1 CAN 网拓扑结构

### 18.2.1 CAN 2.0B 主动内核

bxCAN 模块可以完全自动地接收和发送 CAN 报文;且完全支持标准标识符(11 位)和扩展标识符(29 位)。

### 18.2.2 控制、状态和配置寄存器

应用程序通过这些寄存器,可以:

- 配置 CAN 参数,如波特率
- 请求发送报文
- 处理报文接收
- 管理中断
- 获取诊断信息

## 18.2.3 发送邮箱

共有3个发送邮箱供软件来发送报文。发送调度器根据优先级决定哪个邮箱的报文先被发送。

## 18.2.4 接收过滤器

bxCAN 提供 14 个位宽可变/可配置的标识符过滤器组,软件通过对它们编程,从收到的报文中选择它需要的报文,而把其它报文丢弃掉。

#### 18.2.4.1 接收 FIFO

共有 2 个接收 FIFO,每个 FIFO 都可以存放 3 个完整的报文。它们完全由硬件来管理。





图 18-2 CAN 框图

## 18.3 bxCAN 工作模式

bxCAN 有 3 个主要的工作模式: 初始化、正常和睡眠模式。

在硬件复位后,bxCAN 工作在睡眠模式以节省电能,同时 CANTX 引脚的内部上拉电阻被激活。软件通过对 CAN\_MCR 寄存器的INRQ 或 SLEEP 位置'1',可以请求 bxCAN 进入初始化或睡眠模式。一旦进入了初始化或睡眠模式,bxCAN 就对 CAN\_MSR 寄存器的 INAK 或 SLAK 位置'1'来进行确认,同时内部上拉电阻被禁用。当 INAK 和 SLAK 位都为'0'时,bxCAN 就处于正常模式。在进入正常模式前,bxCAN 必须跟 CAN 总线取得同步;为取得同步,bxCAN 要等待 CAN 总线达到空闲状态,即在 CANRX 引脚上监测到 11 个连续的隐性位。

## 18.3.1 初始化模式

软件初始化应该在硬件处于初始化模式时进行。设置 CAN\_MCR 寄存器的 INRQ 位为'1', 请求 bxCAN 进入初始化模式, 然后等待硬件对 CAN MSR 寄存器的 INAK 位置'1'来进行确认。

清除 CAN\_MCR 寄存器的 INRQ 位为'0', 请求 bxCAN 退出初始化模式,当硬件对 CAN\_MSR 寄存器的 INAK 位清零就确认了初始化模式的退出。

当 bxCAN 处于初始化模式时,禁止报文的接收和发送,并且 CANTX 引脚输出隐性位(高电平)。初始化模式的进入,不会改变配置寄存器。

软件对 bxCAN 的初始化,至少包括位时间特性(CAN\_BTR)和控制(CAN\_MCR)这 2 个寄存器。在对 bxCAN 的过滤器组(模式、位宽、FIFO 关联、激活和过滤器值)进行初始化前,软件要对 CAN FMR 寄存器的 FINIT 位设置'1'。对过滤器的初始化可以在非初始化模式下进行。



注意: 当 FINIT=1 时,报文的接收被禁止。可以先对过滤器激活位清零(在 CAN\_FA1R 中),然后修改相应过滤器的值。如果过滤器组没有使用,那么就应该让它处于非激活状态(保持其 FACT 位为清零状态)。

### 18.3.2 正常模式

在初始化完成后,软件应该让硬件进入正常模式,以便正常接收和发送报文。软件可以通过对CAN\_MCR 寄存器的 INRQ 位清零,来请求从初始化模式进入正常模式,然后要等待硬件对 CAN\_MSR 寄存器的 INAK 位置'1'的确认。在跟 CAN 总线取得同步,即在 CANRX 引脚上监测到 11 个连续的隐性位(等效于总线空闲)后,bxCAN 才能正常接收和发送报文。

不需要在初始化模式下进行过滤器初值的设置,但必须在它处在非激活状态下完成(相应的 FACT 位为 0)。而过滤器的位宽和模式的设置,则必须在初始化模式中进入正常模式前完成。

### 18.3.3 睡眠模式(低功耗)

bxCAN 可工作在低功耗的睡眠模式。软件通过对 CAN\_MCR 寄存器的 SLEEP 位置'1',来请求进入这一模式。在该模式下,bxCAN 的时钟停止了,但软件仍然可以访问邮箱寄存器。

当 bxCAN 处于睡眠模式,软件必须对 CAN\_MCR 寄存器的 INRQ 位置'1'并且同时对 SLEEP 位清零,才能进入初始化模式。

有 2 种方式可以唤醒(退出睡眠模式)bxCAN:通过软件对 SLEEP 位清零,或硬件检测到 CAN 总线的活动。

如果 CAN\_MCR 寄存器的 AWUM 位为'1',一旦检测到 CAN 总线的活动,硬件就自动对 SLEEP 位清零来唤醒 bxCAN。如果 CAN\_MCR 寄存器的 AWUM 位为'0',软件必须在唤醒中断里对 SLEEP 位清零才能退出睡眠状态。

注意:如果唤醒中断被允许(CAN\_IER 寄存器的 WKUIE 位为'1'),那么一旦检测到 CAN 总线活动就会产生唤醒中断,而不管硬件是否会自动唤醒 bxCAN。

在对 SLEEP 位清零后,睡眠模式的退出必须与 CAN 总线同步,请参考下图。当硬件对 SLAK 位清零时,就确认了睡眠模式的退出。



图 18-3 bxCAN 工作模式

#### 注意:

• ACK =硬件响应睡眠或初始化请求,而对 CAN MSR 寄存器的 INAK 或 SLAK 位置 1 的状态。



• SYNC=bxCAN 等待 CAN 总线变为空闲的状态,即在 CANRX 引脚上检测到连续的 11 个隐性位。

### 18.4 测试模式

通过对 CAN\_BTR 寄存器的 SILM 和/或 LBKM 位置'1',来选择一种测试模式。只能在初始化模式下,修改这 2 位。在选择了一种测试模式后,软件需要对 CAN\_MCR 寄存器的 INRQ 位清零,来真正进入测试模式。

### 18.4.1 静默模式

通过对 CAN BTR 寄存器的 SILM 位置'1',来选择静默模式。

在静默模式下,bxCAN 可以正常地接收数据帧和远程帧,但只能发出隐性位,而不能真正发送报文。如果 bxCAN 需要发出显性位 (确认位、过载标志、主动错误标志),那么这样的显性位在内部被接回来从而可以被 CAN 内核检测到,同时 CAN 总线不会受到影响而仍然维持在隐性位状态。因此,静默模式通常用于分析 CAN 总线的活动,而不会对总线造成影响一显性位(确认位、错误帧)不会真正发送到总线上。



图 18-4 bxCAN 工作在静默模式

### 18.4.2 环回模式

通过对 CAN\_BTR 寄存器的 LBKM 位置'1',来选择环回模式。在环回模式下,bxCAN 把发送的报文当作接收的报文并保存(如果可以通过接收过滤)在接收邮箱里。



图 18-5 bxCAN 工作在环回模式

环回模式可用于自测试。为了避免外部的影响,在环回模式下 CAN 内核忽略确认错误(在数据/远程帧的确认位时刻,不检测是否有显性位)。在环回模式下,bxCAN 在内部把 Tx 输出回馈到 Rx 输入上,而完全忽略 CANRX 引脚的实际状态。发送的报文可以在 CANTX 引脚上检测到。



### 18.4.3 环回静默模式



图 18-6 bxCAN 工作在环回静默模式

通过对 CAN\_BTR 寄存器的 LBKM 和 SILM 位同时置'1',可以选择环回静默模式。该模式可用于"热自测试",即可以像环回模式那样测试 bxCAN,但却不会影响 CANTX 和 CANRX 所连接的整个 CAN 系统。在环回静默模式下,CANRX 引脚与 CAN 总线断开,同时 CANTX 引脚被驱动到隐性位状态。

### 18.5 处于调试模式时

当微控制器处于调试模式时,Cortex-M3 核心处于暂停状态,依据下述配置位的状态,bxCAN 可以继续正常工作或停止工作:

- 调试(DBG)模块中 CAN1 的 DBG\_CAN\_STOP 位。详见章节: "24.14.2 支持定时器、看门狗、bxCAN 和 I2C 的调试"。
- CAN\_MCR 中的 DBF 位。详见章节: "18.8.2 CAN 控制和状态寄存器"。

## 18.6 bxCAN 功能描述

### 18.6.1 发送处理

发送报文的流程为:

- 1. 应用程序选择 1 个空置的发送邮箱;
- 2. 设置标识符,数据长度和待发送数据;
- 3. 对 CAN\_TIXR 寄存器的 TXRQ 位置'1',来请求发送。TXRQ 位置'1'后,邮箱就不再是空邮箱; 而一旦邮箱不再为空置,软件对邮箱寄存器就不再有写的权限。TXRQ 位置 1 后,邮箱马上进入挂号状态,并等待成为最高优先级的邮箱,参见:"18.6.1.1 发送优先级"。
- 4. 一旦邮箱成为最高优先级的邮箱,其状态就变为预定发送状态。一旦 CAN 总线进入空闲状态, 预定发送邮箱中的报文就马上被发送(进入发送状态)。
- 5. 一旦邮箱中的报文被成功发送后,它马上变为空置邮箱;硬件相应地对 CAN\_TSR 寄存器的 RQCP 和 TXOK 位置 1,来表明一次成功发送。如果发送失败,由于仲裁引起的就对 CAN\_TSR 寄存器的 ALST 位置'1',由于发送错误引起的就对 TERR 位置'1'。

#### 18.6.1.1 发送优先级

• 由标识符决定:

当有超过1个发送邮箱在挂号时,发送顺序由邮箱中报文的标识符决定。根据 CAN 协议,标识符数值最低的报文具有最高的优先级。如果标识符的值相等,那么邮箱号小的报文先被发送。

• 由发送请求次序决定:



通过对 CAN\_MCR 寄存器的 TXFP 位置'1',可以把发送邮箱配置为发送 FIFO。在该模式下,发送的优先级由发送请求次序决定。该模式对分段发送很有用。

#### 18.6.1.2 中止

通过对 CAN\_TSR 寄存器的 ABRQ 位置'1',可以中止发送请求。

- 邮箱如果处于挂号或预定状态,发送请求马上就被中止了。
- 如果邮箱处于发送状态,那么中止请求可能导致两种结果:
  - 如果邮箱中的报文被成功发送,那么邮箱变为空置邮箱,并且 CAN\_TSR 寄存器的 TXOK 位被硬件置'1'。
  - 。 如果邮箱中的报文发送失败了,那么邮箱变为预定状态,然后发送请求被中止,邮箱变为 空置邮箱且 TXOK 位被硬件清零。

因此如果邮箱处于发送状态,那么在发送操作结束后,邮箱都会变为空置邮箱。

#### 18.6.1.3 禁止自动重传模式

该模式主要用于满足 CAN 标准中,时间触发通信选项的需求。通过对 CAN\_MCR 寄存器的 NART 位置'1',来让硬件工作在该模式。

在该模式下,发送操作只会执行一次。如果发送操作失败了,不管是由于仲裁丢失或出错,硬件都 不会再自动发送该报文。

在一次发送操作结束后,硬件认为发送请求已经完成,从而对 CAN\_TSR 寄存器的 RQCP 位置'1',同时发送的结果反映在 TXOK、ALST 和 TERR 位上。



图 18-7 发送邮箱状态

### 18.6.2 时间触发通信模式

在该模式下, CAN 硬件的内部定时器被激活,并且被用于产生(发送与接收邮箱的)时间戳,分别存储在 CAN\_RDTxR/CAN\_TDTxR 寄存器中。内部定时器在每个 CAN 位时间累加(见章节:"18.6.7 位时间特性")。内部定时器在接收和发送的帧起始位的采样点位置被采样,并生成时间戳。



### 18.6.3 接收管理

接收到的报文,被存储在 3 级邮箱深度的 FIFO 中。FIFO 完全由硬件来管理,从而节省了 CPU 的处理负荷,简化了软件并保证了数据的一致性。应用程序只能通过读取 FIFO 输出邮箱,来读取FIFO 中最先收到的报文。

#### 18.6.3.1 有效报文

根据 CAN 协议,当报文被正确接收(直到 EOF 域的最后一位都没有错误),且通过了标识符过滤,那么该报文被认为是有效报文。请参考章节:"18.6.4 标识符过滤"。



图 18-8 接收 FIFO 状态

#### 18.6.3.2 FIFO 管理

FIFO 从空状态开始,在接收到第一个有效的报文后,FIFO 状态变为"挂号\_1"(pending\_1),硬件相应地把 CAN\_RFR 寄存器的 FMP[1:0]设置为'01'(二进制 01b)。软件可以读取 FIFO 输出邮箱来读出邮箱中的报文,然后通过对 CAN\_RFR 寄存器的 RFOM 位设置'1'来释放邮箱,这样 FIFO 又变为空状态了。如果在释放邮箱的同时,又收到了一个有效的报文,那么 FIFO 仍然保留在"挂号\_1"状态,软件可以读取 FIFO 输出邮箱来读出新收到的报文。

如果应用程序不释放邮箱,在接收到下一个有效的报文后,FIFO 状态变为"挂号\_2"(pending\_2),硬件相应地把 FMP[1:0]设置为'10'(二进制 10b)。重复上面的过程,第三个有效的报文把 FIFO 变为"挂号\_3"状态(FMP[1:0]=11b)。此时,软件必须对 RFOM 位设置 1 来释放邮箱,以便 FIFO 可以有空间来存放下一个有效的报文;否则,下一个有效的报文到来时就会导致一个报文的丢失。参见:"18.6.5报文存储"。



#### 18.6.3.3 溢出

当 FIFO 处于"挂号\_3"状态(即 FIFO 的 3 个邮箱都是满的),下一个有效的报文就会导致溢出,并且一个报文会丢失。此时,硬件对 CAN\_RFR 寄存器的 FOVR 位进行置'1'来表明溢出情况。至于哪个报文会被丢弃,取决于对 FIFO 的设置:

- 如果禁用了 FIFO 锁定功能(CAN\_MCR 寄存器的 RFLM 位被清零),那么 FIFO 中最后收到的报 文就被新报文所覆盖。这样,最新收到的报文不会被丢弃掉。
- 如果启用了 FIFO 锁定功能(CAN\_MCR 寄存器的 RFLM 位被置'1'),那么新收到的报文就被丢弃,软件可以读到 FIFO 中最早收到的 3 个报文。

#### 18.6.3.4 接收相关的中断

一旦往 FIFO 存入一个报文,硬件就会更新 FMP[1:0]位,并且如果 CAN\_IER 寄存器的 FMPIE 位为'1',那么就会产生一个中断请求。

当 FIFO 变满时(即第 3 个报文被存入), CAN\_RFR 寄存器的 FULL 位就被置'1', 并且如果 CAN\_IER 寄存器的 FFIE 位为'1', 那么就会产生一个满中断请求。

在溢出的情况下,FOVR 位被置'1',并且如果 CAN\_IER 寄存器的 FOVIE 位为'1',那么就会产生一个溢出中断请求。

### 18.6.4 标识符过滤

在 CAN 协议里,报文的标识符不代表节点的地址,而是跟报文的内容相关的。因此,发送者以广播的形式把报文发送给所有的接收者。节点在接收报文时一根据标识符的值一决定软件是否需要该报文;如果需要,就拷贝到 SRAM 里;如果不需要,报文就被丢弃且无需软件的干预。

为满足这一需求,bxCAN 控制器为应用程序提供了 14 个位宽可变的、可配置的过滤器组(13~0),以便只接收那些软件需要的报文。硬件过滤的做法节省了 CPU 开销,否则就必须由软件过滤从而占用一定的 CPU 开销。每个过滤器组 x 由 2 个 32 位寄存器,CAN\_FiR1 和 CAN\_FiR2 组成。

#### 18.6.4.1 可变的位宽

每个过滤器组的位宽都可以独立配置,以满足应用程序的不同需求。根据位宽的不同,每个过滤器组可提供:

- 1个32位过滤器,包括:STID[10:0]、EXID[17:0]、IDE和RTR位
- 2 个 16 位过滤器,包括: STID[10:0]、IDE、RTR 和 EXID[17:15]位

更多信息,可参见图 18-9。此外过滤器可配置为,屏蔽位模式和标识符列表模式。

#### 18.6.4.2 屏蔽位模式

在屏蔽位模式下,标识符寄存器和屏蔽寄存器一起,指定报文标识符的任何一位,应该按照"必须 匹配"或"不用关心"处理。

#### 18.6.4.3 标识符列表模式

在标识符列表模式下,屏蔽寄存器也被当作标识符寄存器用。因此,不是采用一个标识符加一个 屏蔽位的方式,而是使用 2 个标识符寄存器。接收报文标识符的每一位都必须跟过滤器标识符相同。

#### 18.6.4.4 过滤器组位宽和模式的设置

过滤器组可以通过相应的 CAN\_FM1R 寄存器配置。在配置一个过滤器组前,必须通过清除 CAN FA1R 寄存器的 FACTx 位,把它设置为禁用状态。通过设置 CAN FS1R 的相应 FSCx 位,可以配置一



个过滤器组的位宽,请参见下图。通过 CAN\_FM1R 的 FBMx 位,可以配置对应的屏蔽/标识符寄存器的标识符列表模式或屏蔽位模式。

为了过滤出一组标识符,应该设置过滤器组工作在屏蔽位模式。

为了过滤出一个标识符,应该设置过滤器组工作在标识符列表模式。

应用程序不用的过滤器组,应该保持在禁用状态。

过滤器组中的每个过滤器,都被编号(过滤器号)。编号从 0 到某个最大数值(最大值取决于过滤器组的模式和位宽的设置)。

关于过滤器配置,参见下图。



图 18-9 过滤器组位宽设置一寄存器组织

#### 18.6.4.5 过滤器匹配序号

一旦收到的报文被存入 FIFO,就可被应用程序访问。通常情况下,报文中的数据被拷贝到SRAM 中;为了把数据拷贝到合适的位置,应用程序需要根据报文的标识符来辨别不同的数据。bxCAN 提供了过滤器匹配序号,以简化这一辨别过程。

根据过滤器优先级规则,过滤器匹配序号和报文一起,被存入邮箱中。因此每个收到的报文,都有与它相关联的过滤器匹配序号。

过滤器匹配序号可以通过下面两种方式来使用:

- 把过滤器匹配序号跟一系列所期望的值进行比较。
- 把过滤器匹配序号当作一个索引来访问目标地址。



对于标识符列表模式下的过滤器(非屏蔽方式的过滤器),软件不需要直接跟标识符进行比较。

对于屏蔽位模式下的过滤器,软件只须对需要的那些屏蔽位(必须匹配的位)进行比较即可。在给过滤器编号时,并不考虑过滤器组是否为激活状态。另外,每个FIFO各自对其关联的过滤器进行编号。请参考下图的例子。



图 18-10 过滤器编号的例子

#### 18.6.4.6 过滤器优先级规则

根据过滤器的不同配置,有可能一个报文标识符能通过多个过滤器的过滤;在这种情况下,存放在接收邮箱中的过滤器匹配序号,根据下列优先级规则来确定:

- 位宽为 32 位的过滤器,优先级高于位宽为 16 位的过滤器。
- 对于位宽相同的过滤器,标识符列表模式的优先级高于屏蔽位模式。
- 位宽和模式都相同的过滤器,优先级由过滤器号决定,过滤器号小的优先级高。





图 18-11 过滤器机制的例子

上面的例子说明了 bxCAN 的过滤器规则:在接收一个报文时,其标识符首先与配置在标识符列表模式下的过滤器相比较;如果匹配上,报文就被存放到相关联的 FIFO 中,并且所匹配的过滤器的序号被存入过滤器匹配序号中。如同例子中所显示,报文标识符跟#4 标识符匹配,因此报文内容和 FMI4 被存入 FIFO。

如果没有匹配,报文标识符接着与配置在屏蔽位模式下的过滤器进行比较。

如果报文标识符没有跟过滤器中的任何标识符相匹配,那么硬件就丢弃该报文,且不会对软件有任何打扰。

### 18.6.5 报文存储

邮箱是软件和硬件之间传递报文的接口。邮箱包含了所有跟报文有关的信息:标识符、数据、控制、 状态和时间戳信息。

#### 18.6.5.1 发送邮箱

软件需要在一个空的发送邮箱中,把待发送报文的各种信息设置好(然后再发出发送的请求)。发送的状态可通过查询 CAN\_TSR 寄存器获知。

| 相对发送邮箱基地址的偏移量 | 寄存器名      |
|---------------|-----------|
| 0             | CAN_TIXR  |
| 4             | CAN_TDTxR |
| 8             | CAN_TDLxR |
| 12            | CAN_TDHxR |

表 18-1 发送邮箱寄存器列表



#### 18.6.5.2 接收邮箱(FIFO)

在接收到一个报文后,软件就可以访问接收 FIFO 的输出邮箱来读取它。一旦软件处理了报文(如把它读出来),软件就应该对 CAN\_RFxR 寄存器的 RFOM 位进行置'1',来释放该报文,以便为后面收到的报文留出存储空间。过滤器匹配序号存放在 CAN\_RDTxR 寄存器的 FMI 域中。16 位的时间戳存放在 CAN\_RDTxR 寄存器的 TIME[15:0]域中。

| 相对接收邮箱基地址的偏移量 | 寄存器名      |
|---------------|-----------|
| 0             | CAN_RIXR  |
| 4             | CAN_RDTxR |
| 8             | CAN_RDLxR |
| 12            | CAN_RDHxR |

表 18-2 接收邮箱寄存器列表

### 18.6.6 出错管理



图 18-12 CAN 错误状态图

CAN 协议描述的出错管理,完全由硬件通过发送错误计数器(CAN\_ESR 寄存器里的 TEC 域),和接收错误计数器(CAN\_ESR 寄存器里的 REC 域)来实现,其值根据错误的情况而增加或减少。关于 TEC 和 REC 管理的详细信息,请参考 CAN 标准。

软件可以读出它们的值来判断 CAN 网络的稳定性。

此外,CAN\_ESR 寄存器提供了当前错误状态的详细信息。通过设置 CAN\_IER 寄存器(比如 ERRIE 位),当检测到出错时软件可以灵活地控制中断的产生。

#### 18.6.6.1 离线恢复

当 TEC 大于 255 时,bxCAN 就进入离线状态,同时 CAN\_ESR 寄存器的 BOFF 位被置'1'。在离线状态下,bxCAN 无法接收和发送报文。

根据 CAN\_MCR 寄存器中 ABOM 位的设置, bxCAN 可以自动或在软件的请求下,从离线状态恢复(变为错误主动状态)。在这两种情况下,bxCAN 都必须等待一个 CAN 标准所描述的恢复过程(CAN RX 引脚上检测到 128 次 11 个连续的隐性位)。

• 如果 ABOM 位为'1', bxCAN 进入离线状态后,就自动开启恢复过程。



• 如果 ABOM 位为'0', 软件必须先请求 bxCAN 进入然后再退出初始化模式, 随后恢复过程才被开启。

注意:在初始化模式下,bxCAN 不会监视 CAN RX 引脚的状态,这样就不能完成恢复过程。为了完成恢复过程,bxCAN 必须工作在正常模式。

#### 18.6.7 位时间特性

位时间特性逻辑通过采样来监视串行的 CAN 总线,并且通过与帧起始位的边沿进行同步,及通过与 后面的边沿进行重新同步,来调整其采样点。

它的操作可以简单解释为,如下所述把名义上的每位时间分为3段:

- 同步段(SYNC\_SEG): 通常期望位的变化发生在该时间段内。其值固定为 1 个时间单元(1x  $t_{CAN}$ )。
- 时间段 1 (BS1): 定义采样点的位置。它包含 CAN 标准里的 PROP\_SEG 和 PHASE\_SEG1。其值可以编程为 1 到 16 个时间单元,但也可以被自动延长,以补偿因为网络中不同节点的频率差异所造成的相位的正向漂移。
- 时间段 2 (BS2): 定义发送点的位置。它代表 CAN 标准里的 PHASE\_SEG2。其值可以编程为 1 到 8 个时间单元,但也可以被自动缩短以补偿相位的负向漂移。

重新同步跳跃宽度(SJW)定义了在每位中可以延长或缩短多少个时间单元的上限。其值可以编程为1到4个时间单元。

有效跳变被定义为当 bxCAN 自己没有发送隐性位时,从显性位到隐性位的第1次转变。

如果在时间段 1(BS1)而不是在同步段(SYNC\_SEG)检测到有效跳变,那么 BS1 的时间就被延长最多 SJW 那么长,从而采样点被延迟了。

相反如果在时间段 2(BS2)而不是在 SYNC\_SEG 检测到有效跳变,那么 BS2 的时间就被缩短最多 SJW 那么长,从而采样点被提前了。

为了避免软件的编程错误,对位时间特性寄存器(CAN\_BTR)的设置,只能在 bxCAN 处于初始化状态下进行。

注意:关于CAN 位时间特性和重同步机制的详细信息,请参考ISO11898 标准。



图 18-13 位时序





图 18-14 各种 CAN 帧

## 18.7 bxCAN 中断

bxCAN 占用 4 个专用的中断向量。通过设置 CAN 中断允许寄存器(CAN\_IER),每个中断源都可以单独允许和禁用。





图 18-15 事件标志和中断产生

- 发送中断可由下列事件产生:
  - 。 发送邮箱 0 变为空,CAN\_TSR 寄存器的 RQCP0 位被置'1'。
  - 。 发送邮箱 1 变为空, CAN\_TSR 寄存器的 RQCP1 位被置'1'。
  - 。 发送邮箱 2 变为空,CAN\_TSR 寄存器的 RQCP2 位被置'1'。
- FIFOO 中断可由下列事件产生:
  - 。 FIFOO 接收到一个新报文, CAN RFOR 寄存器的 FMPO 位不再是'00'。
  - 。 FIFOO 变为满的情况,CAN RFOR 寄存器的 FULLO 位被置'1'。
  - 。 FIFOO 发生溢出的情况,CAN\_RFOR 寄存器的 FOVRO 位被置'1'。
- FIFO1 中断可由下列事件产生:
  - 。 FIFO1 接收到一个新报文, CAN\_RF1R 寄存器的 FMP1 位不再是'00'。
  - 。 FIFO1 变为满的情况,CAN\_RF1R 寄存器的 FULL1 位被置'1'。
  - 。 FIFO1 发生溢出的情况,CAN\_RF1R 寄存器的 FOVR1 位被置'1'。
- 错误和状态变化中断可由下列事件产生:
  - 出错情况,关于出错情况的详细信息请参考 CAN 错误状态寄存器(CAN ESR)。



- · 唤醒情况,在 CAN 接收引脚上监视到帧起始位 (SOF)。
- 。 CAN 进入睡眠模式。

### 18.8 CAN 寄存器

基地址: 0x4000 6400

空间大小: 0x400

必须以字(32位)的方式操作这些外设寄存器。

### 18.8.1 寄存器访问保护

对某些寄存器的错误访问会导致一个 CAN 节点对整个 CAN 网络的暂时性干扰。因此,软件只能在 CAN 处于初始化模式时修改 CAN\_BTR 寄存器。

虽然错误数据的发送对 CAN 网的网络层不会带来问题,但却会对应用程序造成严重影响。因此,软件只能在发送邮箱为空的状态改变它,参见图 18-7。

过滤器的数值只能在关闭对应过滤器组的状态下,或设置 FINIT 位为'1'后才能修改。此外,只有在设置整个过滤器为初始化模式下(即 FINIT=1),才能修改过滤器的设置,即修改 CAN\_FM1R,CAN\_FS1R和 CAN\_FFA1R 寄存器。

### 18.8.2 CAN 控制和状态寄存器

### 18.8.2.1 CAN 主控制寄存器(CAN\_MCR)

偏移地址: 0x00

复位值: 0x0001 0002

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

| 15    | 14 | 13 | 12 | 11  | 10 | 9 | 8 | 7    | 6    | 5    | 4    | 3    | 2    | 1     | 0    |
|-------|----|----|----|-----|----|---|---|------|------|------|------|------|------|-------|------|
| RESET |    |    |    | Res |    |   |   | TTCM | ABOM | AWUM | NART | RFLM | TXFP | SLEEP | INRQ |
| rs    |    |    |    |     |    |   |   | rw    | rw   |

| 位 31:17 | Res: 保留<br>必须保持复位值。                                                                                                                       |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------|
| 位 16    | DBF: 调试冻结(Debug freeze)  • 0: 在调试时,CAN 照常工作。  • 1: 在调试时,冻结 CAN 的接收/发送。仍然可以正常地读写和控制接收 FIFO。                                                |
| 位 15    | RESET: bxCAN 软件复位(bxCAN software master)  • 0: 本外设正常工作。  • 1: 对 bxCAN 进行强行复位。 复位后 bxCAN 进入睡眠模式(FMP 位和 CAN_MCR 寄存器被初始化为其复位值)。 此后硬件自动对该位清零。 |
| 位 14:8  | Res: 保留<br>必须保持复位值。                                                                                                                       |



| 位 7 | TTCM: 时间触发通信模式(Time triggered communication mode)  • 0: 禁止时间触发通信模式。  • 1: 允许时间触发通信模式。  注意: 要想了解关于时间触发通信模式的更多信息,请参考章节: "18.6.2 时间触发通信模式"。                                                                                               |
|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 6 | ABOM: 自动离线管理(Automatic bus-off management) 该位决定 CAN 硬件在什么条件下可以退出离线状态。  • 0: 软件对 CAN_MCR 寄存器的 INRQ 位进行置'1'随后清零后,一旦硬件检测到 128 次 11 位连续的隐性位,则退出离线状态。  • 1: 硬件检测到 128 次 11 位连续的隐性位,则自动退出离线状态。 <i>注意: 关于离线状态的更多信息,请参考章节:"图 7-7 发送邮箱状态</i> "。 |
| 位 5 | AWUM: 自动唤醒模式(Automatic wakeup mode) 该位决定 CAN 处在睡眠模式时由硬件还是软件唤醒。  • 0: 软件通过清除 CAN_MCR 寄存器的 SLEEP 位,将 CAN 从睡眠模式中唤醒。  • 1: 硬件通过检测 CAN 报文,将 CAN 从睡眠模式中自动唤醒。 唤醒的同时,硬件自动对 CAN_MCR 的 SLEEP 位和 CAN_MSR 寄存器的 SLEEP 和 SLAK 位清零。                   |
| 位 4 | NART: 禁止报文自动重发(No automatic retransmission)  • 0: 按照 CAN 标准,CAN 硬件在发送报文失败时会一直自动重传直到发送成功。  • 1: CAN 报文只被发送 1 次,不管发送的结果如何(成功、出错或仲裁丢失)。                                                                                                   |
| 位 3 | RFLM:接收 FIFO 锁定模式(Receive FIFO locked mode)  • 0:在接收溢出时 FIFO 未被锁定,当接收 FIFO 的报文未被读出,下一个收到的报文会覆盖原有的报文。  • 1:在接收溢出时 FIFO 被锁定,当接收 FIFO 的报文未被读出,下一个收到的报文会被丢弃。                                                                               |
| 位 2 | TXFP: 发送 FIFO 优先级(Transmit FIFO priority)<br>当有多个报文同时在等待发送时,该位决定这些报文的发送顺序。<br>• 0: 优先级由报文的标识符来决定。<br>• 1: 优先级由发送请求的顺序来决定。                                                                                                              |
| 位 1 | SLEEP: 睡眠模式请求(Sleep mode request) 软件对该位置'1'可以请求 CAN 进入睡眠模式,一旦当前的 CAN 活动(发送或接收报文)结束,CAN 就进入睡眠。 软件对该位清零使 CAN 退出睡眠模式。 当设置了 AWUM 位且在 CAN Rx 信号中检测出 SOF 位时,硬件对该位清零。 在复位后该位被置'1',即 CAN 在复位后处于睡眠模式。                                           |
| 位 0 | INRQ: 初始化请求(Initialization request)<br>软件对该位清零可使 CAN 从初始化模式进入正常工作模式:                                                                                                                                                                   |



当 CAN 在接收引脚检测到连续的 11 个隐性位后,CAN 就达到同步,并为接收和发送数据作好准备了。为此,硬件相应地对 CAN\_MSR 寄存器的 INAK 位清零。

软件对该位置 1 可使 CAN 从正常工作模式进入初始化模式:

一旦当前的 CAN 活动(发送或接收)结束,CAN 就进入初始化模式。相应地,硬件对 CAN\_MSR 寄存器的 INAK 位置'1'。

## 18.8.2.2 CAN 主状态寄存器(CAN\_MSR)

偏移地址: 0x04

复位值: 0x0000 0C02

| 31      | 30                    | 29                                                                                                                               | 28                              | 27               | 26               | 25                     | 24            | 23                | 22                  | 2                             | 1 20                                          | 19        | 18        | 17        | 16        |
|---------|-----------------------|----------------------------------------------------------------------------------------------------------------------------------|---------------------------------|------------------|------------------|------------------------|---------------|-------------------|---------------------|-------------------------------|-----------------------------------------------|-----------|-----------|-----------|-----------|
|         |                       |                                                                                                                                  |                                 |                  |                  |                        |               | Res               |                     |                               |                                               |           |           |           |           |
|         |                       |                                                                                                                                  |                                 |                  |                  |                        |               |                   |                     |                               |                                               | -         |           |           |           |
| 15 1    | L4<br>Re              | 13                                                                                                                               | 12                              | 11<br>RX         | 10<br>SAMP       | 9<br>RXM               | 8<br>TXM      | 7                 | 6<br>Res            | 5                             | 4<br>SLAKI                                    | 3<br>WKUI | 2<br>ERRI | 1<br>SLAK | 0<br>INAK |
|         |                       | .5                                                                                                                               |                                 | r                | r                | r                      | r             |                   | 1103                |                               | rc_w1                                         | rc_w1     | rc_w1     | r         | r         |
| 位 31:12 | 2 Res: 保留<br>必须保持复位值。 |                                                                                                                                  |                                 |                  |                  |                        |               |                   |                     |                               |                                               |           |           |           |           |
| 位 11    |                       | RX: CAN 接收电平(CAN Rx signal)<br>该位反映 CAN 接收引脚(CAN_RX)的实际电平。                                                                       |                                 |                  |                  |                        |               |                   |                     |                               |                                               |           |           |           |           |
| 位 10    |                       | SAMP: 上次采样值(Last sample point) CAN 接收引脚的上次采样值(对应于当前接收位的值)。                                                                       |                                 |                  |                  |                        |               |                   |                     |                               |                                               |           |           |           |           |
| 位 9     |                       |                                                                                                                                  |                                 | -                | Receive<br>I 当前为 |                        |               |                   |                     |                               |                                               |           |           |           |           |
| 位 8     |                       |                                                                                                                                  |                                 |                  | Transm<br>I 当前为  |                        |               |                   |                     |                               |                                               |           |           |           |           |
| 位 7:5   |                       | Res:<br>必须仍                                                                                                                      |                                 | 位值。              |                  |                        |               |                   |                     |                               |                                               |           |           |           |           |
| 位 4     |                       | 当 SLE<br>置该位<br>软件 <sup>口</sup>                                                                                                  | (IE=1,<br>立为 <b>'1'</b><br>丁对该· | 一旦<br>时,如<br>位清零 | 果设置<br>,当 SI     | 上入睡眼<br>了 CAN<br>LAK 位 | R模式(<br>J_IER | 更件就<br>寄存器<br>时硬件 | 对该位<br>中的 S<br>·也对记 | 2置 <b>'1</b><br>LKIE 化<br>该位清 | ,紧接 <sup>注</sup><br>立,将产<br>青零。<br><i>位来获</i> | 生一个       | 状态改       |           |           |
| 位 3     |                       | WKUI: 唤醒中断(Wakeup interrupt)<br>当 CAN 处于睡眠状态,一旦检测到帧起始位(SOF),硬件就置该位为'1';并且如果<br>CAN_IER 寄存器的 WKUIE 位为'1',则产生一个状态改变中断。<br>该位由软件清零。 |                                 |                  |                  |                        |               |                   |                     |                               |                                               |           |           |           | 如果        |
| 位 2     |                       | ERRI:                                                                                                                            | 出错。                             | 中断 (             | Error in         | terrupt                | )             |                   |                     |                               |                                               |           |           |           |           |



|     | 当检测到错误时,CAN_ESR 寄存器的某位被置'1',如果 CAN_IER 寄存器的相应中断使能位也被置'1'时,则硬件对该位置'1';如果 CAN_IER 寄存器的 ERRIE 位为'1',则产生状态改变中断。<br>该位由软件清零。                                                                                                                                                                         |
|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 1 | SLAK: 睡眠模式确认(Sleep mode acknowledge) 该位由硬件置'1',指示软件 CAN 模块正处于睡眠模式。该位是对软件请求进入睡眠模式的确认(对 CAN_MCR 寄存器的 SLEEP 位置'1')。 当 CAN 退出睡眠模式时硬件对该位清零(需要跟 CAN 总线同步)。这里跟 CAN 总线同步是指,硬件需要在 CAN 的 RX 引脚上检测到连续的 11 位隐性位。 注意: 通过软件或硬件对 CAN_MCR 的 SLEEP 位清零,将启动退出睡眠模式的过程。有关清除 SLEEP 位的详细信息,参见 CAN_MCR 寄存器的 AWUM 位的描述。 |
| 位 0 | INAK: 初始化确认(Initiation acknowledge) 该位由硬件置'1',指示软件 CAN 模块正处于初始化模式。该位是对软件请求进入初始化模式的确认(对 CAN_MCR 寄存器的 INRQ 位置'1')。 当 CAN 退出初始化模式时硬件对该位清零(需要跟 CAN 总线同步)。这里跟 CAN 总线同步是指,硬件需要在 CAN 的 RX 引脚上检测到连续的 11 位隐性位。                                                                                           |

## 18.8.2.3 CAN 发送状态寄存器(CAN\_TSR)

偏移地址: 0x08

复位值: 0x1C00 0000

| 31    | 30  | 30 29 |    | 28    | 27   | 26         | 25  | 24     | 23    | 2 | 2   | 2 | 19    | 18    | 17    | 16    |
|-------|-----|-------|----|-------|------|------------|-----|--------|-------|---|-----|---|-------|-------|-------|-------|
|       |     |       |    |       |      |            |     |        |       | 2 | 1   | 0 |       |       |       |       |
| LOW   | LOW | LO    | W  | TME   | TME  | TME        | COI | DE[1:0 | ABRQ  |   | Res |   | TERR  | ALST2 | TXOK  | RQCP  |
| 2     | 1   | C     | )  | 2     | 1    | 0          |     | ]      | 2     |   |     |   | 2     |       | 2     | 2     |
| r     | r   | r     |    | r     | r    | r          |     | r      | rs    |   |     |   | rc_w1 | rc_w  | rc_w1 | rc_w1 |
|       |     |       |    |       |      |            |     |        |       |   |     |   |       | 1     |       |       |
|       |     |       |    |       |      |            |     |        |       |   |     |   |       |       |       |       |
| 15    | 14  | 13    | 12 | 11    | 10   | 9          |     | 8      | 7     | 6 | 5   | 4 | 3     | 2     | 1     | 0     |
| ABRQ1 |     | Res   |    | TERR1 | ALST | ALST1 TXOK |     | RQCP1  | ABRQ0 |   | Res |   | TERR0 | ALST0 | TXOK0 | RQCP0 |
| rs    |     |       |    | rc_w1 | rc_w | 1 rc_w     | /1  | rc_w1  | rs    |   |     |   | rc_w1 | rc_w1 | rc_w1 | rc_w1 |
| 位 31  |     |       |    |       |      |            |     |        |       |   |     |   |       |       |       |       |

| 位 31 | LOW2:邮箱 2 最低优先级标志(Lowest priority flag for mailbox 2)<br>当多个邮箱在等待发送报文,且邮箱 2 的优先级最低时,硬件对该位置'1'。                                     |
|------|------------------------------------------------------------------------------------------------------------------------------------|
| 位 30 | LOW1: 邮箱 1 最低优先级标志(Lowest priority flag for mailbox 1)<br>当多个邮箱在等待发送报文,且邮箱 1 的优先级最低时,硬件对该位置'1'。                                    |
| 位 29 | LOW0:邮箱 0 最低优先级标志(Lowest priority flag for mailbox 0)<br>当多个邮箱在等待发送报文,且邮箱 0 的优先级最低时,硬件对该位置'1'。<br>注意:如果只有 1 个邮箱在等待,则 LOW[2:0] 被清零。 |
| 位 28 | TME2: 发送邮箱 2 空(Transmit mailbox 2 empty)<br>当邮箱 2 中没有等待发送的报文时,硬件对该位置'1'。                                                           |
| 位 27 | TME1: 发送邮箱 1 空(Transmit mailbox1 empty)<br>当邮箱 1 中没有等待发送的报文时,硬件对该位置'1'。                                                            |



| 位 26    | TME0: 发送邮箱 0 空(Transmit mailbox 0 empty)<br>当邮箱 0 中没有等待发送的报文时,硬件对该位置 <b>'1'</b> 。                                                                                                                    |
|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 25:24 | CODE[1:0]: 邮箱号(Mailbox code)  • 当有至少 1 个发送邮箱为空时,这 2 位表示下一个空的发送邮箱号。  • 当所有的发送邮箱都为空时,这 2 位表示优先级最低的那个发送邮箱号。                                                                                             |
| 位 23    | ABRQ2:邮箱 2 中止发送(Abort request for mailbox 2)<br>软件对该位置'1',可以中止邮箱 2 的发送请求,当邮箱 2 的发送报文被清除时硬件对该位<br>清零。如果邮箱 2 中没有等待发送的报文,则对该位置'1'没有任何效果。                                                                |
| 位 22:20 | Res: 保留<br>必须保持复位值。                                                                                                                                                                                  |
| 位 19    | TERR2:邮箱 2 发送失败(Transmission error of mailbox 2)<br>当邮箱 2 因为出错而导致发送失败时,对该位置'1'。                                                                                                                      |
| 位 18    | ALST2: 邮箱 2 仲裁丢失(Arbitration lost for mailbox 2)<br>当邮箱 2 因为仲裁丢失而导致发送失败时,对该位置'1'。                                                                                                                    |
| 位 17    | TXOK2:邮箱 2 发送成功(Transmission OK of mailbox 2)每次在邮箱 2 进行发送尝试后,硬件对该位进行更新:                                                                                                                              |
| 位 16    | RQCP2:邮箱 2 请求完成(Request completed mailbox 2)<br>当上次对邮箱 2 的请求(发送或中止)完成后,硬件对该位置'1'。<br>软件对该位写'1'可以对其清零;当硬件接收到发送请求时也对该位清零(CAN_TI2R 寄存器的 TXRQ 位被置'1')。<br>该位被清零时,邮箱 2 的其它发送状态位(TXOK2,ALST2 和 TERR2)也被清零。 |
| 位 15    | ABRQ1:邮箱 1 中止发送(Abort request for mailbox 1)<br>软件对该位置'1',可以中止邮箱 1 的发送请求,当邮箱 1 的发送报文被清除时硬件对该位<br>清零。如果邮箱 1 中没有等待发送的报文,则对该位置'1'没有任何效果。                                                                |
| 位 14:12 | Res: 保留<br>必须保持复位值。                                                                                                                                                                                  |
| 位 11    | TERR1:邮箱 1 发送失败(Transmission error of mailbox 1)<br>当邮箱 1 因为出错而导致发送失败时,对该位置 <b>'1'</b> 。                                                                                                             |
| 位 10    | ALST1:邮箱 1 仲裁丢失(Arbitration lost for mailbox 1)<br>当邮箱 1 因为仲裁丢失而导致发送失败时,对该位置'1'。                                                                                                                     |
| 位 9     | TXOK1: 邮箱 1 发送成功(Transmission OK of mailbox 1)                                                                                                                                                       |



|       | 每次在邮箱 1 进行发送尝试后,硬件对该位进行更新:  • 0: 上次发送尝试失败。  • 1: 上次发送尝试成功。 当邮箱 1 的发送请求被成功完成后,硬件对该位置'1'。请参见图发送邮箱状态。                                                                                                   |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 8   | RQCP1:邮箱 1 请求完成(Request completed mailbox 1)当上次对邮箱 1 的请求(发送或中止)完成后,硬件对该位置'1'。软件对该位写'1'可以对其清零;当硬件接收到发送请求时也对该位清零(CAN_TI1R 寄存器的 TXRQ 位被置'1')。该位被清零时,邮箱 1 的其它发送状态位(TXOK1,ALST1 和 TERR1)也被清零。             |
| 位 7   | ABRQ0:邮箱 0 中止发送(Abort request for mailbox 0) 软件对该位置'1'可以中止邮箱 0 的发送请求,当邮箱 0 的发送报文被清除时硬件对该位清零。如果邮箱 0 中没有等待发送的报文,则对该位置 1 没有任何效果。                                                                        |
| 位 6:4 | Res: 保留<br>必须保持复位值。                                                                                                                                                                                  |
| 位 3   | TERRO: 邮箱 0 发送失败(Transmission error of mailbox 0)<br>当邮箱 0 因为出错而导致发送失败时,对该位置 <b>'1'</b> 。                                                                                                            |
| 位 2   | ALSTO:邮箱 0 仲裁丢失(Arbitration lost for mailbox 0)<br>当邮箱 0 因为仲裁丢失而导致发送失败时,对该位置'1'。                                                                                                                     |
| 位 1   | TXOK0: 邮箱 0 发送成功(Transmission OK of mailbox 0)每次在邮箱 0 进行发送尝试后,硬件对该位进行更新:                                                                                                                             |
| 位 0   | RQCPO:邮箱 0 请求完成(Request completed mailbox 0)<br>当上次对邮箱 0 的请求(发送或中止)完成后,硬件对该位置'1'。<br>软件对该位写'1'可以对其清零;当硬件接收到发送请求时也对该位清零(CAN_TIOR 寄存器的 TXRQ 位被置'1')。<br>该位被清零时,邮箱 0 的其它发送状态位(TXOKO,ALSTO 和 TERRO)也被清零。 |

# 18.8.2.4 CAN 接收 FIFO 0 寄存器(CAN\_RFOR)

偏移地址: 0x0C

复位值: 0x0000 0000

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

RFOM0

FOVR0

rc\_w1

FULL0

rc\_w1

Res

FMP0[1:0]



| 位 31:6 | Res: 保留<br>必须保持复位值。                                                                                                                                                                                                  |
|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 5    | RFOMO: 释放接收 FIFO 0 输出邮箱(Release FIFO 0 output mailbox) 软件通过对该位置'1'来释放接收 FIFO 的输出邮箱。如果接收 FIFO 为空,那么对该位置'1'没有任何效果,即只有当 FIFO 中有报文时对该位置'1'才有意义。如果 FIFO 中有 2 个以上的报文,由于 FIFO 的特点,软件需要释放输出邮箱才能访问第 2 个报文。 当输出邮箱被释放时,硬件对该位清零。 |
| 位 4    | FOVR0: FIFO 0 溢出(FIFO 0 overrun)<br>当 FIFO 0 已满,又收到新的报文且报文符合过滤条件,硬件对该位置'1'。该位由软件清<br>零。                                                                                                                              |
| 位 3    | FULLO: FIFO 0 满 (FIFO 0 full)         当 FIFO 0 中有 3 个报文时,硬件对该位置'1'。         该位由软件清零。                                                                                                                                 |
| 位 2    | Res: 保留<br>必须保持复位值。                                                                                                                                                                                                  |
| 位 1:0  | FMP0[1:0]: FIFO 0 报文数目(FIFO 0 message pending) FIFO 0 报文数目这 2 位反映了当前接收 FIFO 0 中存放的报文数目。 每当 1 个新的报文被存入接收 FIFO 0,硬件就对 FMP0 加 1。 每当软件对 RFOM0 位写'1'来释放输出邮箱,FMP0 就被减 1,直到其为 0。                                            |

# 18.8.2.5 CAN 接收 FIFO 1 寄存器(CAN\_RF1R)

偏移地址: 0x10

复位值: 0x0000 0000

| 31  | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21    | 20    | 19    | 18  | 17   | 16     |
|-----|----|----|----|----|----|----|----|----|----|-------|-------|-------|-----|------|--------|
|     |    |    |    |    |    |    |    |    |    |       |       |       |     |      |        |
|     |    |    |    |    |    |    |    |    |    |       |       |       |     |      |        |
|     |    | 1  |    |    |    |    |    |    |    |       |       | 1     |     |      |        |
| 15  | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5     | 4     | 3     | 2   | 1    | 0      |
| Res |    |    |    |    |    |    |    |    |    | RFOM1 | FOVR1 | FULL1 | Res | FMP: | 1[1:0] |
|     |    |    |    |    |    |    |    |    |    | rs    | rc w1 | rc w1 |     |      | r      |

| 位 31:6 | Res: 保留<br>必须保持复位值。                                                                                                                                                                                              |
|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 5    | RFOM1:释放接收 FIFO 1 输出邮箱(Release FIFO1 output mailbox)软件通过对该位置'1'来释放接收 FIFO 的输出邮箱。如果接收 FIFO 为空,那么对该位置'1'没有任何效果,即只有当 FIFO 中有报文时对该位置'1'才有意义。如果 FIFO 中有 2 个以上的报文,由于 FIFO 的特点,软件需要释放输出邮箱才能访问第 2 个报文。当输出邮箱被释放时,硬件对该位清零。 |
| 位 4    | FOVR1: FIFO1 溢出(FIFO1 overrun)<br>当 FIFO 1 已满,又收到新的报文且报文符合过滤条件,硬件对该位置'1'。该位由软件清                                                                                                                                  |



|       | 零。                                                                                                                                                                      |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 3   | FULL1: FIFO1 满(FIFO1 full)<br>当 FIFO 1 中有 3 个报文时,硬件对该位置'1'。<br>该位由软件清零。                                                                                                 |
| 位 2   | Res: 保留<br>必须保持复位值。                                                                                                                                                     |
| 位 1:0 | FMP1[1:0]: FIFO 1 报文数目(FIFO1message pending) FIFO 1 报文数目这 2 位反映了当前接收 FIFO 1 中存放的报文数目。 每当 1 个新的报文被存入接收 FIFO 1,硬件就对 FMP1 加 1。 每当软件对 RFOM1 位写 1 来释放输出邮箱,FMP1 就被减 1,直到其为 0。 |

## 18.8.2.6 CAN 中断使能寄存器 (CAN\_IER)

Res

SLKIE

WKUIE

rw

偏移地址: 0x14

复位值: 0x0000 0000

| 15                          | 1 4 | 1                                                                                              | 1 2                 | 11        | 10        | 9               | 8                                     | 7           | 6                      | 5         | 4          | 3          | 2         | 1          | 0         |
|-----------------------------|-----|------------------------------------------------------------------------------------------------|---------------------|-----------|-----------|-----------------|---------------------------------------|-------------|------------------------|-----------|------------|------------|-----------|------------|-----------|
| ERRI<br>E                   |     | Res                                                                                            |                     | LECI<br>E | BOFI<br>E | EPVI<br>E       | EWGI<br>E                             | Re<br>s     | FOVIE<br>1             | FFIE<br>1 | FMPIE<br>1 | FOVIE<br>0 | FFIE<br>0 | FMPIE<br>0 | TMEI<br>E |
| rw                          |     |                                                                                                |                     | rw        | rw        | rw              | rw                                    |             | rw                     | rw        | rw         | rw         | rw        | rw         | rw        |
| 位 31:18 Res: 保留<br>必须保持复位值。 |     |                                                                                                |                     |           |           |                 |                                       |             |                        |           |            |            |           |            |           |
| 位 17                        |     | SLKIE: 睡眠中断使能(Sleep interrupt enable)  • 0: 当 SLAKI 位被置'1'时,不产生中断。  • 1: 当 SLAKI 位被置'1'时,产生中断。 |                     |           |           |                 |                                       |             |                        |           |            |            |           |            |           |
| 位 16                        |     | •                                                                                              | 0: <u> </u>         | ≝ WKL     | 』 位被旨     | 置 <b>′1′</b> 时, | /akeup ii<br>,不产生<br>,产生 <sup>归</sup> | <b>上中</b> 勝 | ipt enabl              | e)        |            |            |           |            |           |
| 位 15                        |     | •                                                                                              | 0: <u>È</u>         | ≝ CAN     | _ESR 寄    | 存器有             |                                       | 号时,         | nable)<br>,不产生<br>,产生中 |           |            |            |           |            |           |
| 位 14                        | :12 |                                                                                                | Res: 保留<br>必须保持复位值。 |           |           |                 |                                       |             |                        |           |            |            |           |            |           |
| 位 11                        |     | LECIE: 上次错误号中断使能(Last error code interrupt enable)  • 0: 当检测到错误,硬件设置 LEC[2:0]时,不设置 ERRI 位。     |                     |           |           |                 |                                       |             |                        |           |            |            |           |            |           |



|      | • 1: 当检测到错误,硬件设置 LEC[2:0]时,设置 ERRI 位为'1'。                                                                                                     |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 位 10 | BOFIE: 离线中断使能(Bus-off interrupt enable)  • 0: 当 BOFF 位被置'1'时,不设置 ERRI 位。  • 1: 当 BOFF 位被置'1'时,设置 ERRI 位为'1'。                                  |
| 位 9  | EPVIE: 错误被动中断使能(Error Passive Interrupt Enable)  • 0: 当 EPVF 位被置'1'时,不设置 ERRI 位。  • 1: 当 EPVF 位被置'1'时,设置 ERRI 位为'1'。                          |
| 位 8  | EWGIE: 错误警告中断使能(Error warning interrupt enable)  • 0: 当 EWGF 位被置'1'时,不设置 ERRI 位。  • 1: 当 EWGF 位被置'1'时,设置 ERRI 位为'1'。                          |
| 位 7  | Res: 保留<br>必须保持复位值。                                                                                                                           |
| 位 6  | FOVIE1: FIFO 1 溢出中断使能(FIFO overrun interrupt enable)  • 0: 当 FIFO 1 的 FOVR 位被置'1'时,不产生中断。  • 1: 当 FIFO 1 的 FOVR 位被置'1'时,产生中断。                 |
| 位 5  | FFIE1: FIFO 1 满中断使能(FIFO full interrupt enable)  • 0: 当 FIFO 1 的 FULL 位被置'1'时,不产生中断。  • 1: 当 FIFO 1 的 FULL 位被置'1'时,产生中断。                      |
| 位 4  | FMPIE1: FIFO 1 消息保持中断使能(FIFO message pending interrupt enable)  • 0: 当 FIFO 1 的 FMP[1:0]位为非 0 时,不产生中断。  • 1: 当 FIFO 1 的 FMP[1:0]位为非 0 时,产生中断。 |
| 位 3  | FOVIEO: FIFO 0 溢出中断使能(FIFO overrun interrupt enable)  • 0: 当 FIFO 0 的 FOVR 位被置'1'时,不产生中断。  • 1: 当 FIFO 0 的 FOVR 位被置'1'时,产生中断。                 |
| 位 2  | FFIE0: FIFO 0 满中断使能(FIFO full interrupt enable)  • 0: 当 FIFO 0 的 FULL 位被置'1'时,不产生中断。  • 1: 当 FIFO 0 的 FULL 位被置'1'时,产生中断。                      |
| 位 1  | FMPIE0: FIFO 0 消息挂号中断使能(FIFO message pending interrupt enable)  • 0: 当 FIFO 0 的 FMP[1:0]位为非 0 时,不产生中断。  • 1: 当 FIFO 0 的 FMP[1:0]位为非 0 时,产生中断。 |
| 位 0  | TMEIE:发送邮箱空中断使能(Transmit mailbox empty interrupt enable)  • 0: 当 RQCPx 位被置'1'时,不产生中断。  • 1: 当 RQCPx 位被置'1'时,产生中断。  注意:请参考章节:"bxCAN 中断"。       |



# 18.8.2.7 CAN 错误状态寄存器(CAN\_ESR)

偏移地址: 0x18

复位值: 0x0000 0000

| 31 | 30       | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21       | 20 | 19 | 18 | 17 | 16 |  |  |  |
|----|----------|----|----|----|----|----|----|----|----|----------|----|----|----|----|----|--|--|--|
|    | REC[7:0] |    |    |    |    |    |    |    |    | TEC[7:0] |    |    |    |    |    |  |  |  |
|    | r        |    |    |    |    |    |    |    | r  |          |    |    |    |    |    |  |  |  |

| 15  | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5        | 4 | 3 | 2   | 1    | 0   |
|-----|----|----|----|----|----|---|---|---|---|----------|---|---|-----|------|-----|
| Res |    |    |    |    |    |   |   |   |   | LEC[2:0] |   |   | BOF | EPVF | EWG |
|     |    |    |    |    |    |   |   |   |   |          |   |   | F   |      | F   |
|     |    |    |    |    |    |   |   |   |   | rw       |   |   | r   | r    | r   |

|         | rw r r                                                                                                                                                                                  |
|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 31:24 | REC[7:0]:接收错误计数器(Receive error counter) 这个计数器按照 CAN 协议的故障界定机制的接收部分实现。按照 CAN 的标准,当接收出错时,根据出错的条件,该计数器加 1 或加 8;而在每次接收成功后,该计数器减 1,或当该计数器的值大于 128 时,设置它的值为 120。当该计数器的值超过 127 时,CAN 进入错误被动状态。 |
| 位 23:16 | TEC[7:0]: 9 位发送错误计数器的低 8 位(Least significant byte of the 9-bit transmit error counter) 与上面相似,这个计数器按照 CAN 协议的故障界定机制的发送部分实现。                                                              |
| 位 15:7  | Res: 保留<br>必须保持复位值。                                                                                                                                                                     |
| 位 6:4   | LEC[2:0]: 上次错误代码(Last error code) 在检测到 CAN 总线上发生错误时,硬件根据出错情况设置。当报文被正确发送或接收后,硬件清除其值为'0'。 硬件没有使用错误代码 7,软件可以设置该值,从而可以检测代码的更新。                                                              |
| 位 3     | Res: 保留<br>必须保持复位值。                                                                                                                                                                     |
| 位 2     | BOFF: 离线标志(Bus-off flag)<br>当进入离线状态时,硬件对该位置'1'。当发送错误计数器 TEC 溢出,即大于 255 时,CAN<br>进入 离线状态。请参考章节:"位时间特性"。                                                                                  |
| 位 1     | EPVF: 错误被动标志(Error passive flag)<br>当出错次数达到错误被动的阈值时,硬件对该位置'1'。(接收错误计数器或发送错误计数                                                                                                           |



|     | 器的值>127)。                        |
|-----|----------------------------------|
| 位 0 | EWGF: 错误警告标志(Error warning flag) |
|     | 当出错次数达到警告的阈值时,硬件对该位置'1'。         |
|     | (接收错误计数器或发送错误计数器的值≥96)。          |

# 18.8.2.8 CAN 位时序寄存器(CAN\_BTR)

偏移地址: 0x1C

复位值: 0x0123 0000

注意: 当 CAN 处于初始化模式时,该寄存器只能由软件访问。

| 31   | 30  | 29 | 28 | 27 | 26 | 25  | 24       | 23  | 22 | 21       | 20 | 19       | 18 | 17 | 16 |  |  |
|------|-----|----|----|----|----|-----|----------|-----|----|----------|----|----------|----|----|----|--|--|
| SILM | LBK |    | R  | es |    | SJW | [1:0]    | Res |    | TS2[2:0] |    | TS1[3:0] |    |    |    |  |  |
|      | M   |    |    |    |    |     |          |     |    |          |    |          |    |    |    |  |  |
| rw   | rw  |    |    |    |    | r   | w        |     |    | rw       |    | rw       |    |    |    |  |  |
|      |     |    |    |    |    |     |          |     |    |          |    |          |    |    |    |  |  |
| 15   | 14  | 13 | 12 | 11 | 10 | 9   | 8        | 7   | 6  | 5        | 4  | 3        | 2  | 1  | 0  |  |  |
|      | Res |    |    |    |    |     | BRP[9:0] |     |    |          |    |          |    |    |    |  |  |
|      |     |    |    |    |    | rw  |          |     |    |          |    |          |    |    |    |  |  |

|         | rw                                                                                                                                           |
|---------|----------------------------------------------------------------------------------------------------------------------------------------------|
| 位 31    | SILM: 静默模式 (用于调试) (Silent mode (debug))  • 0: 正常状态  • 1: 静默模式                                                                                |
| 位 30    | LBKM: 环回模式 (用于调试) (Loop back mode (debug))  • 0: 禁止环回模式  • 1: 允许环回模式                                                                         |
| 位 29:26 | Res: 保留<br>必须保持复位值。                                                                                                                          |
| 位 25:24 | SJW[1:0]: 重新同步跳跃宽度(Resynchronization jump width) 为了重新同步,该位域定义了 CAN 硬件在每位中可以延长或缩短多少个时间单元的上限。 $t_{\text{RJW}=t_q}*(\text{SJW}[1:0]+1)$         |
| 位 23    | Res: 保留<br>必须保持复位值。                                                                                                                          |
| 位 22:20 | TS2[2:0]: 时间段 2(Time segment 2)<br>该位域定义了时间段 2 占用了多少个时间单元<br>t <sub>BS2=</sub> t <sub>q</sub> *(TS2[2:0]+1)                                  |
| 位 19:16 | TS1[3:0]: 时间段 1 (Time segment 1) 该位域定义了时间段 1 占用了多少个时间单元。 t <sub>BS1</sub> =t <sub>q</sub> * (TS1[3:0] +1) 关于位时间特性的详细信息,请参考章节: "位时间特性节位时间特性"。 |



| 位 15:10 | Res: 保留<br>必须保持复位值。                                                                            |
|---------|------------------------------------------------------------------------------------------------|
| 位 9:0   | BRP[9:0]: 波特率分频器(Baud rate prescaler) 该位域定义了时间单元( $t_q$ )的时间长度。 $t_{q=} (BRP[9:0]+1)*t_{PCLK}$ |

## 18.8.3 CAN 邮箱寄存器

本节描述发送和接收邮箱寄存器。关于寄存器映像的详细信息,请参考章节:"报文存储"。除了下述例外,发送和接收邮箱几乎一样:

- CAN\_RDTxR 寄存器的 FMI 域;
- 接收邮箱是只读的。

发送邮箱只有在它为空时才是可写的,CAN\_TSR 寄存器的相应 TME 位为'1',表示发送邮箱为空。

共有 3 个发送邮箱和 2 个接收邮箱。每个接收邮箱为 3 级深度的 FIFO,并且只能访问 FIFO 中最先收到的报文。

每个邮箱包含 4 个寄存器。



图 18-16 CAN 邮箱寄存器

## 18.8.3.1 发送邮箱标识符寄存器(CAN\_TIxR)(x=0..2)

偏移地址:(CAN\_TIOR, CAN\_TI1R, CAN\_TI2R)=(0x180, 0x190, 0x1A0)

复位值: 0xXXXX XXXX

X 代表不定值(除了第0位,复位时 TXRQ=0)。

## 注意:

当其所属的邮箱处在等待发送的状态时,该寄存器是写保护的。

该寄存器实现了发送请求控制功能(第0位)一复位值为0。

| 31  | 30                              | 29 | 28 | 27      | 26        | 25      | 24 | 23 | 22 | 21 | 20          | 19 | 18 | 17 | 16  |  |  |
|-----|---------------------------------|----|----|---------|-----------|---------|----|----|----|----|-------------|----|----|----|-----|--|--|
|     |                                 |    |    | STID[10 | ):0]/EXIC | [28:18] |    |    |    |    | EXID[17:13] |    |    |    |     |  |  |
|     | rw                              |    |    |         |           |         |    |    |    |    |             |    |    |    |     |  |  |
| 4.5 | 15 14 12 12 11 10 0 9 7 6 5 4 2 |    |    |         |           |         |    |    |    |    |             |    |    |    | 0   |  |  |
| 15  | 14                              | 13 | 12 | 11      | 10        | 9       | 8  | /  | 6  | 5  | 4           | 3  | 2  | 1  | 0   |  |  |
|     | EXID[12:0]                      |    |    |         |           |         |    |    |    |    |             |    |    |    | TXR |  |  |
|     |                                 |    |    |         |           |         |    |    |    |    |             |    |    |    | Q   |  |  |
|     | rw                              |    |    |         |           |         |    |    |    |    |             |    |    | rw | rw  |  |  |

位 31:21 STID[10:0]/EXID[28:18]: 标准标识符或扩展标识符(Standard identifier or extended



|        | identifier)<br>依据 IDE 位的内容,该位域或是标准标识符,或是扩展身份标识的高字节。                                      |
|--------|------------------------------------------------------------------------------------------|
| 位 20:3 | EXID[17:0]:扩展标识符(Extended identifier)<br>扩展身份标识的低字节。                                     |
| 位 2    | IDE:标识符选择(Identifier extension)<br>该位决定发送邮箱中报文使用的标识符类型  • 0:使用标准标识符  • 1:使用扩展标识符         |
| 位 1    | RTR: 远程发送请求(Remote transmission request)  • 0: 数据帧  • 1: 远程帧                             |
| 位 0    | TXRQ: 发送邮箱请求(Transmit mailbox request)<br>由软件对其置'1',来请求发送邮箱的数据。当数据发送完成,邮箱为空时,硬件对其清<br>零。 |

## 18.8.3.2 发送邮箱数据长度和时间戳寄存器(CAN\_TDTxR)(x=0..2)

偏移地址:(CAN\_TIOR, CAN\_TI1R, CAN\_TI2R)=(0x184, 0x194, 0x1A4)

复位值: 0xXXXX XXXX

X 代表不定值。

当邮箱不在空置状态时,该寄存器的所有位为写保护。

| 31  | 30         | 29 | 28 | 27 | 26  | 25 | 24 | 23 | 22 | 21 | 20 | 1 | 9 | 18 | 17  | 16 |
|-----|------------|----|----|----|-----|----|----|----|----|----|----|---|---|----|-----|----|
|     | TIME[15:0] |    |    |    |     |    |    |    |    |    |    |   |   |    |     |    |
|     | rw         |    |    |    |     |    |    |    |    |    |    |   |   |    |     |    |
|     |            |    |    |    |     |    |    |    |    |    |    |   |   |    |     |    |
| 4.5 | 1.1        | 12 | 1  | 2  | 1.1 | 10 | 0  | 0  | 7  | _  | _  | 4 | 2 | 1  | - 1 | 0  |

| 15 | 14  | 13 | 12 | 11 | 10 | 9        | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|-----|----|----|----|----|----------|---|---|---|---|---|---|---|---|---|
|    | TGT |    | R  | es |    | DLC[3:0] |   |   |   |   |   |   |   |   |   |
|    | rw  |    |    |    |    |          | r | W |   |   |   |   |   |   |   |

| 位 31:16 | TIME[15:0]:报文时间戳(Message time stamp) 该域包含了,在发送该报文 SOF 的时刻,16 位定时器的值。                                                                                                                                                                                                                                             |
|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 15:9  | Res: 保留<br>必须保持复位值。                                                                                                                                                                                                                                                                                              |
| 位 8     | TGT: 发送时间戳 (Transmit global time)<br>只有在 CAN 处于时间触发通信模式,即 CAN_MCR 寄存器的 TTCM 位为'1'时,该位才有效。<br>• 0: 不发送时间戳 TIME[15:0]<br>• 1: 发送时间戳 TIME[15:0]<br>在长度为 8 的报文中,时间戳 TIME[15:0]是最后 2 个发送的字节: TIME[7:0]作为第 7 个字节,TIME[15:8]为第 8 个字节,它们替换了写入 CAN_TDHxR[31:16]的数据(DATA6[7:0]和 DATA7[7:0])。为了把时间戳的 2 个字节发送出去,DLC 必须编程为 8。 |



| 位 7:4 | Res: 保留<br>必须保持复位值。                                                                           |
|-------|-----------------------------------------------------------------------------------------------|
| 位 3:0 | DLC[3:0]: 发送数据长度(Data length code) 该域指定了数据报文的数据长度或者远程帧请求的数据长度。1 个报文包含 0 到 8 个字节数据,而这由 DLC 决定。 |

## 18.8.3.3 发送邮箱低字节数据寄存器(CAN\_TDLxR)(x=0..2)

偏移地址: (CAN\_TIOR, CAN\_TI1R, CAN\_TI2R) = (0x188, 0x198, 0x1A8)

复位值: 0xXXXX XXXX

x 代表不定值。

当邮箱不在空置状态时,该寄存器的所有位为写保护。

| 31    | 30  | 29            | 28    | 27     | 26  | 25     | 24     | 23              | 22 | 21 | 20    | 19     | 18 | 17 | 16 |  |  |
|-------|-----|---------------|-------|--------|-----|--------|--------|-----------------|----|----|-------|--------|----|----|----|--|--|
|       |     |               | DATA  | 3[7:0] |     |        |        |                 |    |    | DATA: | 2[7:0] |    |    |    |  |  |
|       |     |               | r     | w      |     |        |        | rw              |    |    |       |        |    |    |    |  |  |
|       |     |               |       |        |     | _      | _      |                 |    | _  | _     | _      | _  | _  |    |  |  |
| 15    | 14  | 13            | 12    | 11     | 10  | 9      | 8      | 7 6 5 4 3 2 1 0 |    |    |       |        |    |    |    |  |  |
|       |     |               | DATA  | 1[7:0] |     |        |        |                 |    |    | DATA  | 0[7:0] |    |    |    |  |  |
|       |     |               | r     | W      |     |        |        |                 |    |    | r     | w      |    |    |    |  |  |
| 位 31  | :24 | DATA3 <br>报文的 | _     |        | 节3( | Data b | yte 3) |                 |    |    |       |        |    |    |    |  |  |
| 位 23  | :16 | DATA2[<br>报文的 | _     |        | 节2( | Data b | yte 2) |                 |    |    |       |        |    |    |    |  |  |
| 位. 15 | :8  | DATA1         | 7:01: | 数据字    | 节1( | Data b | vte 1) |                 |    |    |       |        |    |    |    |  |  |

# 报文包含 0 到 8 个字节数据,且从字节 0 开始。 18.8.3.4 发送邮箱高字节数据寄存器(CAN\_TDHxR)(x=0..2)

DATA0[7:0]: 数据字节 0 (Data byte 0)

偏移地址: (CAN\_TIOR, CAN\_TI1R, CAN\_TI2R) = (0x18C, 0x19C, 0x1AC)

复位值: 0xXXXX XXXX

X代表不定值。

位 7:0

当邮箱不在空置状态时,该寄存器的所有位为写保护。

报文的数据字节1。

报文的数据字节 0。

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

位 31:24 DATA7[7:0]: 数据字节 7(Data byte 7)



|         | 报文的数据字节 7 注意:如果 CAN_MCR 寄存器的 TTCM 位为'1',且该邮箱的 TGT 位也为'1',那么 DATA7 和 DATA6 将被 TIME 时间戳代替。 |
|---------|------------------------------------------------------------------------------------------|
| 位 23:16 | DATA6[7:0]: 数据字节 6 (Data byte 6)<br>报文的数据字节 6。                                           |
| 位 15:8  | DATA5[7:0]: 数据字节 5(Data byte 5)<br>报文的数据字节 5。                                            |
| 位 7:0   | DATA4[7:0]: 数据字节 4(Data byte 4)<br>报文的数据字节 4。                                            |

## 18.8.3.5 接收 FIFO 邮箱标识符寄存器(CAN\_RIxR)(x=0..1)

偏移地址:(CAN\_TIOR, CAN\_TI1R)=(0x1B0, 0x1C0)

复位值: 0xXXXX XXXX

x 代表不定值。

所有接收邮箱寄存器都是只读的。

| 31 | 30         | 29 | 28 | 27      | 26       | 25      | 24 | 23 | 22 | 21 | 20 | 19 | 18       | 17  | 16  |
|----|------------|----|----|---------|----------|---------|----|----|----|----|----|----|----------|-----|-----|
|    |            |    |    | STID[10 | :0]/EXIE | [28:18] |    |    |    |    |    | EX | XID[17:1 | 3]  |     |
|    | r          |    |    |         |          |         |    |    |    |    |    |    | r        |     |     |
|    |            |    |    |         |          |         |    |    |    |    |    |    |          |     |     |
| 15 | 14         | 13 | 12 | 11      | 10       | 9       | 8  | 7  | 6  | 5  | 4  | 3  | 2        | 1   | 0   |
|    | EXID[12:0] |    |    |         |          |         |    |    |    |    |    |    | IDE      | RTR | Res |
|    | r          |    |    |         |          |         |    |    |    |    |    |    | r        | r   |     |

| 位 31:21 | STID[10:0]/EXID[28:18]:标准标识符或扩展标识符(Standard identifier or extended identifier)依据 IDE 位的内容,该位域或是标准标识符,或是扩展身份标识的高字节。 |
|---------|--------------------------------------------------------------------------------------------------------------------|
| 位 20:3  | EXID[17:0]:扩展标识符(Extended identifier)<br>扩展标识符的低字节。                                                                |
| 位 2     | IDE:标识符选择(Identifier extension)<br>该位决定接收邮箱中报文使用的标识符类型:  • 0:使用标准标识符  • 1:使用扩展标识符                                  |
| 位 1     | RTR: 远程发送请求(Remote transmission request)  • 0: 数据帧  • 1: 远程帧                                                       |
| 位 0     | Res: 保留<br>必须保持复位值。                                                                                                |

## 18.8.3.6 接收 FIFO 邮箱数据长度和时间戳寄存器(CAN\_RDTxR)(x=0..1)

偏移地址: (CAN\_TIOR, CAN\_TI1R) = (0x1B4, 0x1C4)



复位值: OxXXXX XXXX

X代表不定值。

所有接收邮箱寄存器都是只读的。

| 31 | 30  | 29 | 28  | 27                   | 26 | 25 | 24   | 23     | 22 | 21  | 20       | 19  | 18 | 17      | 16 |
|----|-----|----|-----|----------------------|----|----|------|--------|----|-----|----------|-----|----|---------|----|
|    |     |    | ,   |                      | u. | 1  | TIME | [15:0] |    |     |          |     |    | ı       |    |
|    |     |    |     |                      |    |    |      | r      |    |     |          |     |    |         |    |
| 15 | 14  | 13 | 3 1 | 2                    | 11 | 10 | q    | 8      | 7  | 6   | 5        | 1 3 | 2  | 1       | 0  |
| 13 | 1-7 | 15 |     | <u>۔</u><br>اا[15:0] |    | 10 | J    | 0      | ,  | Res | <u> </u> | , , | DL | .C[3:0] |    |
|    |     |    |     | r                    |    |    |      |        |    |     |          |     |    | r       |    |

| 位 31:16 | TIME[15:0]:报文时间戳(Message time stamp) 该域包含了,在接收该报文 SOF 的时刻,16 位定时器的值。                         |
|---------|----------------------------------------------------------------------------------------------|
| 位 15:8  | FMI[15:0]:过滤器匹配序号(Filter match index)这里是存在邮箱中的信息传送的过滤器序号。关于标识符过滤的细节,请参考章节:"标识符过滤"中有关过滤器匹配序号。 |
| 位 7:4   | Res: 保留<br>必须保持复位值。                                                                          |
| 位 3:0   | DLC[3:0]:接收数据长度(Data length code)<br>该域表明接收数据帧的数据长度(0~8)。对于远程帧请求,数据长度 DLC 恒为 0。              |

## 18.8.3.7 接收 FIFO 邮箱低字节数据寄存器(CAN\_RDLxR)(x=0..1)

偏移地址:(CAN\_TIOR, CAN\_TI1R)=(0x1B8, 0x1C8)

复位值: 0xXXXX XXXX

X代表不定值。

所有接收邮箱寄存器都是只读的。

| 31 3    | 0 29          | 28    | 27     | 26  | 25     | 24     | 23  | 22  | 21   | 20   | 19     | 18 | 17 | 16 |
|---------|---------------|-------|--------|-----|--------|--------|-----|-----|------|------|--------|----|----|----|
|         |               | DATA: | 3[7:0] |     |        |        |     |     |      | DATA | 2[7:0] |    |    |    |
|         |               | I     | r      |     |        |        |     |     |      |      | r      |    |    |    |
| 15 1    | 4 13          | 12    | 11     | 10  | 9      | 8      | 7   | 6   | 5    | 4    | 3      | 2  | 1  | 0  |
|         |               | DATA  | 1[7:0] |     |        |        |     |     |      | DATA | 0[7:0] | 1  |    | 1  |
|         |               | 1     | r      |     |        |        |     |     |      |      | r      |    |    |    |
| 位 31:24 | DATA3 <br>报文的 |       |        | 节3( | Data b | yte 3) |     |     |      |      |        |    |    |    |
| 位 23:16 | DATA2 <br>报文的 |       |        | 节2( | Data b | yte 2) |     |     |      |      |        |    |    |    |
| 位 15:8  | DATA1 <br>报文的 |       |        | 节1( | Data b | yte 1) |     |     |      |      |        |    |    |    |
| 位 7:0   | DATA0 <br>报文的 |       |        |     |        | •      | 字节数 | 据,且 | L从字节 | 贲0开タ | 冶。     |    |    |    |



## 18.8.3.8 接收 FIFO 邮箱高字节数据寄存器(CAN\_RDHxR)(x=0..1)

偏移地址: (CAN\_TIOR, CAN\_TI1R) = (0x1BC, 0x1CC)

复位值: 0xXXXX XXXX

x 代表不定值。

所有接收邮箱寄存器都是只读的。

| 31               | 30   | 29        | 28                | 27                 | 26     | 25         | 24      | 23 | 22 | 21 | 20   | 19     | 18 | 17 | 16 |
|------------------|------|-----------|-------------------|--------------------|--------|------------|---------|----|----|----|------|--------|----|----|----|
|                  |      |           | DATA              | 7[7:0]             |        |            |         |    |    |    | DATA | 6[7:0] |    |    |    |
|                  |      |           |                   | r                  |        |            |         |    |    |    |      | r      |    |    |    |
|                  |      |           |                   |                    |        |            |         |    |    |    |      |        |    |    |    |
| 15               | 14   | 13        | 12                | 11                 | 10     | 9          | 8       | 7  | 6  | 5  | 4    | 3      | 2  | 1  | 0  |
|                  |      |           | DATA              | 5[7:0]             |        |            |         |    |    |    | DATA | 4[7:0] |    |    |    |
|                  |      |           |                   | r                  |        |            |         |    |    |    |      | r      |    |    |    |
|                  |      |           |                   |                    |        |            |         |    |    |    |      |        |    |    |    |
| 位 31             | 1.24 | DΔΤΔ 7    | 7[7·0]•           | 数据与                | ≥ 井 7  | (Data b    | wte 7)  |    |    |    |      |        |    |    |    |
| 12. 31           |      | ראואו     | [7.0].            | 3X 1/H 1           | 14 1   | Data       | yte /   |    |    |    |      |        |    |    |    |
|                  |      | 报文的       | 勺数据5              | 字节 7               |        |            |         |    |    |    |      |        |    |    |    |
|                  |      |           |                   |                    |        |            |         |    |    |    |      |        |    |    |    |
| 位 23             | 0.16 | DATAG     | :[7:0].           | 粉捉兮                | オキィ    | (Data b    | v40 6 ) |    |    |    |      |        |    |    |    |
| <u> 14.</u> 25   | 5.10 | DAIAC     | 1[0.7]:           | 奴1/6寸              | - 11 O | Data L     | yte o   |    |    |    |      |        |    |    |    |
|                  |      | 报文的       | 勺数据5              | 字节 6。              |        |            |         |    |    |    |      |        |    |    |    |
|                  |      | •, •      |                   |                    |        |            |         |    |    |    |      |        |    |    |    |
| 台 15             | 0    | DATAE     | .[2.0]            | 粉提合                | 7 # F  | (Data b    |         |    |    |    |      |        |    |    |    |
| 位 15             | 5:8  | DATAS     | [/:0]:            | 剱/店寸               | - 11 2 | (Data b    | yte 5)  |    |    |    |      |        |    |    |    |
|                  |      | 报文的       | 勺数据5              | 字节 5。              |        |            |         |    |    |    |      |        |    |    |    |
|                  |      | 4N/VH     | <b>→</b> /// •/ ⊢ | , , J <sub>0</sub> |        |            |         |    |    |    |      |        |    |    |    |
| / <del>-</del> - |      | D.4.T.4.4 | .[- 0]            | *** +12 -2         | - H- a | / <b>D</b> |         |    |    |    |      |        |    |    |    |
| 位 7:0            | U    | DATA4     | [[/:0] <b>:</b>   | <b></b>            | - 7 4  | (Data b    | yte 4)  |    |    |    |      |        |    |    |    |
|                  |      | 报文的       | <b>有数据</b> 5      | 字节 4。              |        |            |         |    |    |    |      |        |    |    |    |
|                  |      | 1V V I    | 1 7/7 1/1         | 1 14 -10           |        |            |         |    |    |    |      |        |    |    |    |

## 18.8.4 CAN 过滤器寄存器

## 18.8.4.1 CAN 过滤器主控寄存器(CAN\_FMR)

28

27

26

偏移地址: 0x200

复位值: 0x2A1C 0E01

30

31

该寄存器的非保留位完全由软件控制。

29

| Res    |    |                                      |             |             |             |                   |   |      |   |   |   |   |   |   |       |
|--------|----|--------------------------------------|-------------|-------------|-------------|-------------------|---|------|---|---|---|---|---|---|-------|
|        |    |                                      |             |             |             |                   |   |      |   |   |   |   |   |   |       |
| 15     | 14 | 13                                   | 12          | 11          | 10          | 9                 | 8 | 7    | 6 | 5 | 4 | 3 | 2 | 1 | 0     |
|        |    |                                      |             |             |             | Res               |   |      |   |   |   |   |   |   | FINIT |
|        |    |                                      |             |             |             |                   |   |      |   |   |   |   |   |   | rw    |
| 位 31:: |    | Res: 保留<br>必须保持复位值。                  |             |             |             |                   |   |      |   |   |   |   |   |   |       |
| 位 0    | 2  | FINIT: 立<br>针对所存<br>• 0: 过<br>• 1: 过 | 与过滤器<br>滤器组 | 署组的初<br>工作在 | D始化模<br>正常模 | 莫式设 <u>。</u><br>式 |   | mode | ) |   |   |   |   |   |       |

22

20

19

18

16



## 18.8.4.2 CAN 过滤器模式寄存器(CAN\_FM1R)

偏移地址: 0x204

复位值: 0x0000 0000

只有在设置 CAN\_FMR (FINIT=1), 使过滤器处于初始化模式下, 才能对该寄存器写入。

| 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   |
|---|----|----|------|------|------|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
|   | Re | es | FBM1 | FBM1 | FBM1 | FBM1 | FBM |
|   |    |    | 3    | 2    | 1    | 0    | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
| Ī |    |    | rw   | rw   | rw   | rw   | rw  | rw  | rw  | rw  | rw  | rw  | rw  | rw  | rw  | rw  |

注意: 请参考图: 过滤器组位宽设置一寄存器组织。

## 18.8.4.3 CAN 过滤器位宽寄存器(CAN\_FS1R)

偏移地址: 0x20C

复位值: 0x0000 0000

只有在设置 CAN FMR (FINIT=1), 使过滤器处于初始化模式下,才能对该寄存器写入。

| 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   |
|----|----|------|------|------|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| R  | es | FSC1 | FSC1 | FSC1 | FSC1 | FSC |
|    |    | 3    | 2    | 1    | 0    | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|    |    | rw/  | rw/  | rw/  | rw/  | rw/ | rw/ | rw/ | rw/ | rw/ | rw/ | rw. | rw/ | rw  | rw. |

| 位 31:14 | Res: 保留<br>必须保持复位值。                                   |
|---------|-------------------------------------------------------|
| 位 x     | FSCx: 过滤器位宽设置(Filter scale configuration)             |
| (x=130) | 过滤器组 x 的位宽:  • 0: 过滤器位宽为 2 个 16 位  • 1: 过滤器位宽为单个 32 位 |

注意:请参考图:过滤器组位宽设置一寄存器组织。

## 18.8.4.4 CAN 过滤器 FIFO 关联寄存器(CAN\_FFA1R)

偏移地址: 0x214

复位值: 0x0000 0000



只有在设置 CAN FMR (FINIT=1),使过滤器处于初始化模式下,才能对该寄存器写入。

| 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   |
|----|----|------|------|------|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| R  | es | FFA1 | FFA1 | FFA1 | FFA1 | FFA |
|    |    | 3    | 2    | 1    | 0    | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|    |    | rw   | rw   | rw   | rw   | rw  | rw  | rw  | rw  | rw  | rw  | rw  | rw  | rw  | rw  |

## 18.8.4.5 CAN 过滤器激活寄存器(CAN\_FA1R)

偏移地址: 0x21C 复位值: 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    |
|----|----|-------|-------|------|------|------|------|------|------|------|------|------|------|------|------|
| Re | es | FACT1 | FACT1 | FACT |
|    |    | 3     | 2     | 11   | 10   | 9    | 8    | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|    |    | rw    | rw    | rw   | rw   | rw   | rw   | rw   | rw   | rw   | rw   | rw   | rw   | rw   | rw   |

| 位 31:14        | Res: 保留<br>必须保持复位值。                                                                                                                                  |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 x<br>(x=130) | FACTx: 过滤器激活(Filter activation) 软件对某位设置'1'来激活相应的过滤器。只有对 FACTx 位清零,或对 CAN_FMR 寄存器的 FINIT 位设置'1'后,才能修改相应的过滤器寄存器 x(CAN_FiRx):  • 0: 过滤器被禁用  • 1: 过滤器被激活 |

## 18.8.4.6 CAN 过滤器组 i 的寄存器 x(CAN\_FiRx)(i=0..13, x=1..2)

偏移地址: 0x240+i\*8+(x-1)\*4

复位值: 0xXXXX XXXX

X 表示未定义值。

注意: 共有 14 组过滤器: i=0..13。每组过滤器由 2 个 32 位的寄存器, CAN\_FIR[2:1]组成。只有在 CAN\_FAXR 寄存器相应的 FACTx 位清零,或 CAN\_FMR 寄存器的 FINIT 位为'1'时,才能修改相应的过滤器 寄存器。

| 31   | 30   | 29   | 28   | 27   | 26   | 25   | 24   | 23   | 22   | 21   | 20   | 19   | 18   | 17   | 16   |
|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|
| FB31 | FB30 | FB29 | FB28 | FB27 | FB26 | FB25 | FB24 | FB23 | FB22 | FB21 | FB20 | FB19 | FB18 | FB17 | FB16 |
| rw   |



| 15   | 14   | 13   | 12   | 11   | 10   | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|------|------|------|------|------|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| FB15 | FB14 | FB13 | FB12 | FB11 | FB10 | FB9 | FB8 | FB7 | FB6 | FB5 | FB4 | FB3 | FB2 | FB1 | FB0 |
| rw   | rw   | rw   | rw   | rw   | rw   | rw  | rw  | rw  | rw  | rw  | rw  | rw  | rw  | rw  | rw  |

位 **y** 

FBy: 过滤器位(Filter bits)

(y=31..0)

• 标识符模式

寄存器的每位对应于所期望的标识符的相应位的电平。

- o 0: 期望相应位为显性位
- o 1: 期望相应位为隐性位
- 屏蔽位模式

寄存器的每位指示是否对应的标识符寄存器位一定要与期望的标识符的相应位一致。

- o 0: 不关心,该位不用于比较。
- o 1: 必须匹配,到来的标识符位必须与滤波器对应的标识符寄存器位相一致。

#### 注意:

- 根据过滤器位宽和模式的不同设置,过滤器组中的两个寄存器的功能也不尽相同。关于过滤器的映射,功能描述和屏蔽寄存器的关联,请参见:"标识符过滤"。
- 屏蔽位模式下的屏蔽/标识符寄存器,跟标识符列表模式下的寄存器位定义相同。



## 19 串行外设接口(SPI)

## 19.1 SPI 简介

SPI 接口支持半双工、全双工、单工通信,器件可以作为 SPI 主机,也可作为 SPI 从机。

## 19.2 SPI 主要特征

## 19.2.1 SPI 特征

- 主模式或从模式操作
- 3线全双工同步传输
- 多主模式功能
- 带或不带第三根双向数据线的双线单工同步传输
- 8 或 16 位传输帧格式选择
- 8 个波特率预分频系数(最大为 fpclk/2)
- 主模式和从模式的快速通信
- 主模式和从模式下均可以由软件或硬件进行 NSS 管理: 主/从操作模式的动态改变
- 时钟极性和相位可配置
- 数据顺序可配置, MSB 在前或 LSB 在前
- 可触发中断的专用发送和接收标志
- SPI 总线忙状态标志
- 支持可靠通信的硬件 CRC:
  - 。 在发送模式下可将 CRC 值作为最后一个字节发送
  - 。 在全双工模式中,根据收到的最后一个字节自动进行 CRC 错误校验
- 可触发中断的主模式故障、过载以及 CRC 错误标志
- 支持 DMA 功能的 1 字节发送和接收缓冲器:产生发送和接受请求
- SPI 接口支持 2~32 比特数据包长度可配(此功能无法与 SPI 的 CRC 校验功能同时使用)

## 19.3 SPI 功能描述

## 19.3.1 概述

SPI 的方框图见下图:





图 19-1 SPI 框图

通常 SPI 通过 4 个引脚与外部器件相连:

- MISO: 主设备输入/从设备输出引脚。该引脚在从模式下发送数据,在主模式下接收数据。
- MOSI: 主设备输出/从设备输入引脚。该引脚在主模式下发送数据,在从模式下接收数据。
- SCK: 串口时钟,作为主设备的输出,从设备的输入。
- NSS: 从设备选择。这是一个可选的引脚,用来选择主/从设备。它的功能是用来作为"片选引脚",让主设备可以单独地与特定的从设备通讯,避免数据线上的冲突。从设备的 NSS 引脚可以由主设备的一个标准 I/O 引脚来驱动。一旦被使能(SSOE 位),NSS 引脚也可以作为输出引脚,并在 SPI 处于主模式时拉低;此时,所有的 SPI 设备,如果它们的 NSS 引脚连接到主设备的 NSS 引脚,则会检测到低电平,如果它们被设置为 NSS 硬件模式,就会自动进入从设备状态。当配置为主设备、NSS 配置为输入引脚(MSTR=1,SSOE=0)时,如果 NSS 被拉低,则这个 SPI 设备进入主模式失败状态:即 MSTR 位被自动清除,此设备进入从模式。

下图是一个单主和单从设备互连的例子:





图 19-2 单主和单从应用

#### 说明: 1. 这里 NSS 引脚设置为输入。

MOSI 脚相互连接,MISO 脚相互连接。这样,数据在主和从之间串行地传输(MSB 位在前)。

通信总是由主设备发起。主设备通过 MOSI 脚把数据发送给从设备,从设备通过 MISO 引脚回传数据。这意味全双工通信的数据输出和数据输入是用同一个时钟信号同步的; 时钟信号由主设备通过 SCK 脚提供。

#### 19.3.1.1 从设备选择(NSS) 脚管理

可以通过 SPIx CR1 的 SSM 位设置硬件或者软件管理从设备选择:

- 软件 NSS 模式(SSM=1): NSS 信号电平通过写内部 SPIx\_CR1 的 SSI 位来控制,在这种模式下 SPI 不需要占用外部 NSS 引脚,它可以用作其他功能。
- 硬件 NSS 模式,基于 NSS 的输出配置(SPIx CR2 的 SSOE 位)有两种情况:
  - 。 NSS 输出使能(SSM=0, SSOE=1): 这种配置只能用于 SPI 主设备,并且在主设备开始传输 后 NSS 被驱动为低,并且一直保持到 SPI 关闭。
  - 。 NSS 输出关闭(SSM=0,SSOE=0): 这种配置可以用于主机模式下实现多主机系统。在从机模式下,这种配置就是经典的 NSS 引脚作为从机输入信号,当 NSS 为低时从机被选中,当 NSS 为高时从机未被选中。

#### 19.3.1.2 时钟信号的相位和极性

SPIx\_CR 寄存器的 CPOL(时钟极性)和 CPHA 位,能够组合成四种可能的时序关系。CPOL 位控制在没有数据传输时时钟的空闲状态电平,此位对主模式和从模式下的设备都有效。如果 CPOL 被清零,SCK 引脚在空闲状态保持低电平;如果 CPOL 被置'1',SCK 引脚在空闲状态保持高电平。如果 CPHA(时钟相位)位被置'1',SCK 时钟的第二个边沿(CPOL 位为 0 时就是下降沿,CPOL 位为'1'时就是上升沿)进行数据位的采样,数据在第二个时钟边沿被锁存。如果 CPHA 位被清零,SCK 时钟的第一边沿(CPOL 位为'0'时就是上升沿,CPOL 位为'1'时就是下降沿)进行数据位采样,数据在第一个时钟边沿被锁存。

CPOL 时钟极性和 CPHA 时钟相位的组合选择数据捕捉的时钟边沿。下图显示了 SPI 传输的 4 种 CPHA 和 CPOL 位组合。此图可以解释为主设备和从设备的 SCK 脚、MISO 脚、MOSI 脚直接连接的主或从时序图。

#### 注意:

- 在改变 CPOL/CPHA 位之前, 必须清除 SPE 位将 SPI 禁止。
- 主和从必须配置成相同的时序模式。



- SCK 的空闲状态必须和 SPIx\_CR1 寄存器指定的极性一致(CPOL 为1'时,空闲时应上拉 SCK 为高电平; CPOL 为0'时,空闲时应下拉 SCK 为低电平)。
- 数据帧格式(8位或16位)由SPIx\_CR1寄存器的DFF位选择,并且决定发送/接收的数据长度。



图 19-3 数据时钟时序图

## 19.3.1.3 数据帧格式

根据 SPIx\_CR1 寄存器中的 LSBFIRST 位,输出数据位时可以 MSB 在先也可以 LSB 在先。根据 SPIx\_CR1 寄存器的 DFF 位,每个数据帧可以是 8 位或是 16 位。所选择的数据帧格式对发送和/或接收都有效。

## 19.3.2 配置 SPI 为从模式

在从模式下,SCK 引脚用于接收从主设备来的串行时钟。SPIx\_CR1 寄存器中 BR[2:0]的设置不会影响数据传输速率。

注意:建议在主设备发送时钟之前使能 SPI 从设备,否则可能会发生意外的数据传输。在通信时钟的第一个边沿到来之前或正在进行的通信结束之前,从设备的数据寄存器必须就绪。在使能从设备和主设备之前,通信时钟的极性必须处于稳定的数值。



#### 配置步骤:

- 1. 设置 DFF 位以定义数据帧格式为 8 位或 16 位。
- 2. 选择 CPOL 和 CPHA 位来定义数据传输和串行时钟之间的相位关系(见图 19-3)。为保证正确的数据传输,从设备和主设备的 CPOL 和 CPHA 位必须配置成相同的方式。
- 3. 帧格式(SPIx\_CR1 寄存器中的 LSBFIRST 位定义的"MSB 在前"还是"LSB 在前")必须与主设备相同。
- 4. 硬件模式下(参考从选择(NSS)脚管理部分),在完整的数据帧(8位或16位)传输过程中,NSS引脚必须为低电平。在NSS软件模式下,设置SPIx\_CR1寄存器中的SSM位并清除SSI位。
- 5. 清除 MSTR 位、设置 SPE 位(SPIx\_CR1 寄存器),使相应引脚工作于 SPI 模式下。在这个配置中,MOSI 引脚是数据输入,MISO 引脚是数据输出。

#### 数据发送过程:

在写操作中,数据字被并行地写入发送缓冲器。

当从设备收到时钟信号,并且在 MOSI 引脚上出现第一个数据位时,发送过程开始。余下的位(对于 8 位数据帧格式,还有 7 位;对于 16 位数据帧格式,还有 15 位)被装进移位寄存器。当发送缓冲器中的数据传输到移位寄存器时,SPIx\_SP 寄存器的 TXE 标志被设置,如果设置了 SPIx\_CR2 寄存器的 TXEIE 位,将会产生中断。

#### 数据接收过程:

对于接收器, 当数据接收完成时:

- 移位寄存器中的数据传送到接收缓冲器,SPIx SR 寄存器中的 RXNE 标志被设置。
- 如果设置了 SPIx CR2 寄存器中的 RXNEIE 位,则产生中断。

在最后一个采样时钟边沿后,RXNE 位被置'1',移位寄存器中接收到的数据字节被传送到接收缓冲器。当读 SPIx\_DR 寄存器时,SPI 设备返回这个接收缓冲器的数值。读 SPIx\_DR 寄存器时,RXNE 位被清除。

## 19.3.3 配置 SPI 为主模式

在主配置时,在 SCK 脚产生串行时钟。

#### 配置步骤:

- 1. 通过 SPIx CR1 寄存器的 BR[2:0]位定义串行时钟波特率。
- 2. 选择 CPOL 和 CPHA 位,定义数据传输和串行时钟间的相位关系(见图 19-3)。
- 3. 设置 DFF 位来定义 8 位或 16 位数据帧格式。
- 4. 配置 SPIx CR1 寄存器的 LSBFIRST 位定义帧格式。
- 5. 如果需要 NSS 引脚工作在输入模式,硬件模式下,在整个数据帧传输期间应把 NSS 脚连接到高电平;在软件模式下,需设置 SPIx\_CR1 寄存器的 SSM 位和 SSI 位。如果 NSS 引脚工作 在输出模式,则只需设置 SSOE 位。
- 6. 必须设置 MSTR 位和 SPE 位(只当 NSS 脚被连到高电平,这些位才能保持置位)。在这个配置中,MOSI 引脚是数据输出,而 MISO 引脚是数据输入。

#### 数据发送过程:

当写入数据至发送缓冲器时,发送过程开始。在发送第一个数据位时,通过内部总线,数据字被



并行地传入移位寄存器,而后串行地移出到 MOSI 脚上; MSB 在先还是 LSB 在先,取决于 SPIx\_CR1 寄存器中的 LSBFIRST 位的设置。数据从发送缓冲器传输到移位寄存器时 TXE 标志将被置位,如果设置了 SPIx CR1 寄存器中的 TXEIE位,将产生中断。

#### 数据接收过程:

对于接收器来说, 当数据传输完成时:

- 传送移位寄存器里的数据到接收缓冲器,并且 RXNE 标志被置位。
- 如果设置了 SPIx CR2 寄存器中的 RXNEIE 位,则产生中断。

在最后采样时钟沿,RXNE 位被设置,在移位寄存器中接收到的数据字被传送到接收缓冲器。读 SPIx\_DR 寄存器时,SPI 设备返回接收缓冲器中的数据。读 SPIx\_DR 寄存器将清除 RXNE 位。一旦传输开始,如果下一个将发送的数据被放进了发送缓冲器,就可以维持一个连续的传输流。在试图写发送缓冲器之前,需确认 TXE 标志应该为'1'。

注意: 当一个主机与多个从机通信时,从机需要在传输的某些时刻不被选中,那么该从机的 NSS 引脚必须被配置成 GPIO. 或者使用其他某个 GPIO 用来被软件翻转。

## 19.3.4 配置 SPI 为单工通信

SPI 模块能够以两种配置工作于单工方式:

- 1条时钟线和 1条双向数据线(BIDIMODE=1):
  - 设置 SPIx\_CR1 寄存器中的 BIDIMODE 位而启用此模式。在这个模式下,SCK 引脚作为时钟,主设备使用 MOSI 引脚而从设备使用 MISO 引脚作为数据通信。传输的方向由 SPIx\_CR1 寄存器里的 BIDIOE 控制,当这个位是'1'的时候,数据线是输出,否则是输入。
- 1条时钟线和 1条数据线(只接收或只发送)(BIDIMODE=0): 在这个模式下,SPI模块可以或者作为只发送,或者作为只接收:
  - 。 只发送模式类似于全双工模式(BIDIMODE=0, RXONLY=0): 数据在发送引脚(主模式时是 MOSI、从模式时是 MISO)上传输,而接收引脚(主模式时是 MISO、从模式时是 MOSI)可以作为通用的 I/O 使用。此时,软件不必理会接收缓冲器中的数据(如果读出数据寄存器,它不包含任何接收数据)。
  - 。 在只接收模式,可以通过设置 SPIx\_CR2 寄存器的 RXONLY 位而关闭 SPI 的输出功能;此时,发送引脚(主模式时是 MOSI、从模式时是 MISO)被释放,可以作为其它功能使用。

配置并使能 SPI 模块为只接收模式的方式是:

- 。 在主模式时,一旦使能 SPI,通信立即启动,当清除 SPE 位时立即停止当前的接收。在此模式下,不必读取 BSY 标志,在 SPI 通信期间这个标志始终为'1'。
- 。 在从模式时,只要 NSS 被拉低(或在 NSS 软件模式时, SSI 位为'0') 同时 SCK 有时钟脉冲, SPI 就一直在接收。

## 19.3.5 数据发送与接收过程

## 19.3.5.1 接收与发送缓冲器

在接收时,接收到的数据被存放在一个内部的接收缓冲器中;在发送时,在被发送之前,数据将首 先被存放在一个内部的发送缓冲器中。

对 SPIx\_DR 寄存器的读操作,将返回接收缓冲器的内容;写入 SPIx\_DR 寄存器的数据将被写入发送缓冲器中。



#### 19.3.5.2 主模式下开始传输

- 全双工模式(BIDIMODE=0 并且 RXONLY=0):
  - 。 当写入数据到 SPIx DR 寄存器(发送缓冲器)后,传输开始;
  - 在传送第一位数据的同时,数据被并行地从发送缓冲器传送到8位的移位寄存器中,然后按顺序被串行地移位送到MOSI引脚上:
  - 。 与此同时,在 MISO 引脚上接收到的数据,按顺序被串行地移位进入 8 位的移位寄存器中,然后被并行地传送到 SPIx DR 寄存器(接收缓冲器)中。
- 单向的只接收模式(BIDIMODE=0 并且 RXONLY=1):
  - SPE=1 时,传输开始;
  - 。 只有接收器被激活,在 MISO 引脚上接收到的数据,按顺序被串行地移位进入 8 位的移位 寄存器中,然后被并行地传送到 SPIx DR 寄存器(接收缓冲器)中。
- 双向模式,发送时(BIDIMODE=1 并且 BIDIOE=1)
  - 。 当写入数据到 SPIx DR 寄存器(发送缓冲器)后,传输开始;
  - 。 在传送第一位数据的同时,数据被并行地从发送缓冲器传送到 8 位的移位寄存器中,然后 按顺序被串行地移位送到 MOSI 引脚上;
  - 。不接收数据。
- 双向模式,接收时(BIDIMODE=1 并且 BIDIOE=0)
  - 。 SPE=1 并且 BIDIOE=0 时,传输开始;
  - 在 MOSI 引脚上接收到的数据,按顺序被串行地移位进入 8 位的移位寄存器中,然后被并行地传送到 SPIx DR 寄存器(接收缓冲器)中。
  - 。 不激活发送器,没有数据被串行地送到 MOSI 引脚上。

#### 19.3.5.3 从模式下开始传输

- 全双工模式(BIDIMODE=0 并且 RXONLY=0)
  - 当从设备接收到时钟信号并且第一个数据位出现在它的 MOSI 时,数据传输开始,随后的数据位依次移动进入移位寄存器;
  - 与此同时,在传输第一个数据位时,发送缓冲器中的数据被并行地传送到8位的移位寄存器,随后被串行地发送到 MISO 引脚上。软件必须保证在 SPI 主设备开始数据传输之前在发送寄存器中写入要发送的数据。
- 单向的只接收模式(BIDIMODE=0 并且 RXONLY=1)
  - 。 当从设备接收到时钟信号并且第一个数据位出现在它的 MOSI 时,数据传输开始,随 后数据位依次移动进入移位寄存器;
  - 。 不启动发送器,没有数据被串行地传送到 MISO 引脚上。
- 双向模式,发送时(BIDIMODE=1并且BIDIOE=1)
  - 当从设备接收到时钟信号并且发送缓冲器中的第一个数据位被传送到 MISO 引脚上的时候, 数据传输开始;
  - 。 在第一个数据位被传送到 MISO 引脚上的同时,发送缓冲器中要发送的数据被平行地传送 到 8 位的移位寄存器中,随后被串行地发送到 MISO 引脚上。软件必须保证在 SPI 主设备 开始数据传输之前在发送寄存器中写入要发送的数据:
  - 。 不接收数据。
- 双向模式,接收时(BIDIMODE=1 并且 BIDIOE=0)
  - 。 当从设备接收到时钟信号并且第一个数据位出现在它的 MOSI 时,数据传输开始;
  - 。 从 MISO 引脚上接收到的数据被串行地传送到 8 位的移位寄存器中,然后被平行地传送到



SPIx DR 寄存器 (接收缓冲器);

。 不启动发送器,没有数据被串行地传送到 MISO 引脚上。

## 19.3.5.4 处理数据的发送与接收

当数据从发送缓冲器传送到移位寄存器时,设置 TXE 标志(发送缓冲器空),它表示内部的发送缓冲器可以接收下一个数据;如果在 SPIx\_CR2 寄存器中设置了 TXEIE 位,则此时会产生一个中断;写入 SPIx DR 寄存器即可清除 TXE 位。

注意:在写入发送缓冲器之前,软件必须确认 TXE 标志为'1',否则新的数据会覆盖已经在发送缓冲器中的数据。

在采样时钟的最后一个边沿,当数据被从移位寄存器传送到接收缓冲器时,设置 RXNE 标志(接收缓冲器非空);它表示数据已经就绪,可以从 SPIx\_DR 寄存器读出;如果在 SPIx\_CR2 寄存器中设置了 RXNEIE 位,则此时会产生一个中断;读出 SPIx DR 寄存器即可清除 RXNIE 标志位。

在一些配置中,传输最后一个数据时,可以使用 BSY 标志等待数据传输的结束。

#### 19.3.5.5 主或从模式下(BIDIMODE=0 并且 RXONLY=0)全双工发送和接收过程模式

软件必须遵循下述过程,发送和接收数据(参见图19-4和图19-5):

- 1. 设置 SPE 位为'1', 使能 SPI 模块;
- 2. 在 SPIx\_DR 寄存器中写入第一个要发送的数据,这个操作会清除 TXE 标志;
- 3. 等待 TXE=1,然后写入第二个要发送的数据。等待 RXNE=1,然后读出 SPIx\_DR 寄存器并获得第一个接收到的数据,读 SPIx\_DR 的同时清除了 RXNE 位。重复这些操作,发送后续的数据同时接收 n-1 个数据:
- 4. 等待 RXNE=1, 然后接收最后一个数据;
- 5. 等待 TXE=1,在 BSY=0 之后关闭 SPI 模块。也可以在响应 RXNE 或 TXE 标志的上升沿产生的中断的处理程序中实现这个过程。



图 19-4 主模式、全双工模式下(BIDIMODE=0 并且 RXONLY=0)连续传输时, TXE/RXNE/BSY 的变化示意图





图 19-5 从模式、全双工模式下(BIDIMODE=0 并且 RXONLY=0)连续传输时,TXE/RXNE/BSY 的变化示意图

#### 19.3.5.6 只发送过程(BIDIMODE=0 并且 RXONLY=0)

在此模式下,传输过程可以简要说明如下,并且使用 BSY 位等待传输的结束(参见图 19-6 和图 19-7):

- 1. 设置 SPE 位为'1', 使能 SPI 模块;
- 2. 在 SPIx DR 寄存器中写入第一个要发送的数据,这个操作会清除 TXE 标志;
- 3. 等待 TXE=1, 然后写入第二个要发送的数据。重复这个操作,发送后续的数据:
- 4. 写入最后一个数据到 SPIx\_DR 寄存器之后,等待 TXE=1;然后等待 BSY=0,这表示最后一个数据的传输已经完成。

此过程也可以在响应 TXE 标志的上升沿产生的中断的处理程序中得以实现。

#### 注意:

- 对于不连续的传输,在写入 SPIx\_DR 寄存器的操作与设置 BSY 位之间有 2 个 APB 时钟周期的延迟,因此在只发送模式下,写入最后一个数据后,最好先等待 TXE=1,然后再等待 BSY=0。
- 只发送模式下,在传输 2 个数据之后,由于不会读出接收到的数据,SPIx\_SR 寄存器中的 OVR 位会变为'1'。





图 19-6 主设备只发送模式(BIDIMODE=0 并且 RXONLY=0)下连续传输时,TXE/BSY 变化示意图



图 19-7 从设备只发送模式(BIDIMODE=0 并且 RXONLY=0)下连续传输时,TXE/BSY 变化示意图

#### 19.3.5.7 双向发送过程(BIDIMODE=1 并且 BIDIOE=1)

在此模式下,操作过程类似于只发送模式,不同的是:在使能 SPI 模块之前,需要在 SPIx\_CR2 寄存器中同时设置 BIDIMODE 和 BIDIOE 位为'1'。

#### 19.3.5.8 单向只接收模式(BIDIMODE=0 并且 RXONLY=1)

在此模式下, 传输过程可以简要说明如下:

- 1. 在 SPIx CR2 寄存器中,设置 RXONLY=1;
- 2. 设置 SPE=1, 使能 SPI 模块:
  - 。 主模式下,立刻产生 SCK 时钟信号,在关闭 SPI (SPE=0) 之前,不断地接收串行数据;
  - 。 从模式下,当 SPI 主设备拉低 NSS 信号并产生 SCK 时钟时,接收串行数据。
- 3. 待 RXNE=1,然后读出 SPIx\_DR 寄存器以获得收到的数据(同时会清除 RXNE 位)。重复这个操作接收所有数据。

该过程也可以在响应 RXNE 标志的上升沿产生的中断的处理程序中得以实现。

注意:如果在最后一个数据传输结束后关闭SPI 模块,请按照本章节关闭SPI 节的建议操作。





图 19-8 只接收模式(BIDIMODE=0 并且 RXONLY=1)下连续传输时,RXNE 变化示意图

#### 19.3.5.9 单向接收过程(BIDIMODE=1 并且 BIDIOE=0)

在此模式下,操作过程类似于只接收模式,不同的是:在使能 SPI 模块之前,需要在 SPIx\_CR2 寄存器中设置 BIDIMODE 为'1'并清除 BIDIOE 位为'0'。

#### 19.3.5.10 连续和非连续传输

当在主模式下发送数据时,如果软件足够快,能够在检测到每次 TXE 的上升沿 (或 TXE 中断),并立即在正在进行的传输结束之前写入 SPIx\_DR 寄存器,则能够实现连续的通信;此时,在每个数据项的传输之间的 SPI 时钟保持连续,同时 BSY 位不会被清除。

如果软件不够快,则会导致不连续的通信;这时,在每个数据传输之间会被清除(见下图)。在主模式的只接收模式下(RXONLY=1),通信总是连续的,而且 BSY 标志始终为'1'。

在从模式下,通信的连续性由 SPI 主设备决定。不管怎样,即使通信是连续的,BSY 标志会在每个数据项之间至少有一个 SPI 时钟周期为低(参见图 19-7)。



图 19-9 非连续传输发送(BIDIMODE=0 并且 RXONLY=0)时,TXE/BSY 变化示意图

## 19.3.6 CRC 计算

CRC 校验用于保证全双工通信的可靠性。数据发送和数据接收分别使用单独的 CRC 计算器。通过对每一个接收位进行可编程的多项式运算来计算 CRC。CRC 的计算是在由 SPIx\_CR1 寄存器中CPHA 和 CPOL 位定义的采样时钟边沿进行的。

注意:该 SPI 接口提供了两种 CRC 计算方法,取决于所选的发送和/或接收的数据帧格式:8 位数据帧采用 CR8;16 位数据帧采用 CRC16。



CRC 计算是通过设置 SPIx\_CR1 寄存器中的 CRCEN 位启用的。设置 CRCEN 位时同时复位 CRC 寄存器(SPIx\_RXCRCR 和 SPIx\_TXCRCR)。在全双工和单发送模式下,如果传输是由软件控制(CPU 模式),需要在最后一个数据被写入 DR 寄存器后立即写 1 置位 CRCNEXT。在最后一个数据传输完成后,SPIx\_TXCRCR的值会被发出。

在单接收模式下,如果传输是由软件控制(CPU模式),需要在接收完倒数第二个数据的时候置位 CRCNEXT 位。CRC 数据会在最后一个数据之后接收,并且进行 CRC 结果比对。

在数据和 CRC 传输完成后,如果接收到的 CRC 数据与 SPIx\_RXCRCR 的内容不匹配,则 SPIx\_SR 寄存器的 CRCERR 标志位会被硬件置 1。

如果在 TX 缓冲器中还有数据, CRC 的数值仅在数据字节传输结束后传送。在传输 CRC 期间,

CRC 计算器关闭,寄存器的数值保持不变。

SPI 通信可以通过以下步骤使用 CRC:

- 1. 设置 CPOL、CPHA、LSBFirst、BR、SSM、SSI 和 MSTR 的值;
- 2. 在 SPIx\_CRCPR 寄存器输入多项式;
- 3. 通过设置 SPIx\_CR1 寄存器 CRCEN 位使能 CRC 计算,该操作也会清除寄存器 SPIx\_RXCRCR 和 SPIx\_TXCRC;
- 4. 设置 SPIx\_CR1 寄存器的 SPE 位启动 SPI 功能;
- 5. 启动通信并且维持通信,直到只剩最后一个字节或者半字;
  - · 在全双工和单发送模式下,如果是软件控制传输,那么需要在传输最后一个字节或者半字时通过置位 SPIx CR1 中的 CRCNEXT 位来指示在最后一个数据传输完成后会传输 CRC 值;
  - 。 在单接收模式下,需要在接收完倒数第二个数据开始接收最后一个数据的时候就置位 CRCNEXT 位,让 SPI 在接收完最后一个数据后进入 CRC 阶段。在 CRC 阶段的时候内部 CRC 计算会暂停。
- 6. 当最后一个字节或半字被发送后,SPI 进入 CRC 发送和校验阶段。在全双工和单接收模式下,接收到的 CRC 与 SPIx\_RXCRCR 值进行比较。如果比较结果不等,则 SPIx\_SR 上的 CRCERR 标志位被置起。如果设置了 SPIx\_CR2 寄存器的 ERRIE 时,则同时会产生中断。

#### 注意:

- 当 SPI 模块处于从设备模式时,请注意在时钟稳定之后再使能 CRC 计算,否则可能会得到错误的 CRC 计算结果。事实上,只要设置了 CRCEN 位,只要在 SCK 引脚上有输入时钟,不管 SPE 位的状态,都会进行 CRC 的计算。
- 当 SPI 时钟频率较高时,用户在发送 CRC 时必须小心。在 CRC 传输期间,使用 CPU 的时间应尽可能少;为了避免在接收最后的数据和 CRC 时出错,在发送 CRC 过程中应禁止函数调用。必须在发送/接收最后一个数据之前完成设置 CRCNEXT 位的操作。
- 当 SPI 时钟频率较高时,因为 CPU 的操作会影响 SPI 的带宽,建议采用 DMA 模式以避免 SPI 降低的速度。
- 当 SPI 被配置为从模式并且使用了 NSS 硬件模式, NSS 引脚应该在数据传输和 CRC 传输期间保持为低。

当配置 SPI 为从模式并且使用 CRC 的功能,即使 NSS 信号为高时,如果 SCK 引脚上有时钟脉冲,则 CRC 计算会继续执行。例如在多从机的环境下,当主设备交替地与不同的从设备进行通信时,就会出现 这种情况。

在不选中一个从设备(NSS 信号为高)转换到选中一个新的从设备(NSS 信号为低)的时候,为了



保持主从设备端下次 CRC 计算结果的同步,应该清除主从两端的 CRC 数值。

按照下述步骤清除 CRC 数值:

- 1. 关闭 SPI 模块 (SPE=0)。
- 2. 清除 CRCEN 位为'0'。
- 3. 设置 CRCEN 位为'1'。
- 4. 使能 SPI 模块 (SPE=1)。

## 19.3.7 状态标志

应用程序通过 3 个状态标志可以完全监控 SPI 总线的状态。

#### 19.3.7.1 发送缓冲器空闲标志(TXE)

此标志为'1'时表明发送缓冲器为空,可以写下一个待发送的数据进入缓冲器中。当写入 SPIx\_DR 时,TXE 标志被清除。

## 19.3.7.2 接收缓冲器非空(RXNE)

此标志为'1'时表明在接收缓冲器中包含有效的接收数据。读 SPI 数据寄存器可以清除此标志。

#### 19.3.7.3 忙标志(BSY)

BSY 标志由硬件设置与清除(写入此位无效果),此标志表明 SPI 通信层的状态。

当它被设置为'1'时,表明 SPI 正忙于通信,但有一个例外:在主模式的双向接收模式下(MSTR=1、BDM=1 并且 BDOE=0),在接收期间 BSY 标志保持为低。

在软件要关闭 SPI 模块并进入停机模式(或关闭设备时钟)之前,可以使用 BSY 标志检测传输是否结束,这样可以避免破坏最后一次传输,因此需要严格按照下述过程执行。

BSY 标志还可以用于在多主系统中避免写冲突。

除了主模式的双向接收模式(MSTR=1、BDM=1 并且 BDOE=0),当传输开始时,BSY 标志被置'1'。 以下情况时此标志将被清除为'0':

- 当传输结束(主模式下,如果是连续通信的情况例外);
- 当关闭 SPI 模块;
- 当产生主模式失效(MODF=1)。

如果通信不是连续的,则在每个数据项的传输之间, BSY 标志为低。

当通信是连续时:

- 主模式下: 在整个传输过程中, BSY 标志保持为高;
- 从模式下: 在每个数据项的传输之间, BSY 标志在一个 SPI 时钟周期中为低。

注意: 不要使用 BSY 标志处理每一个数据项的发送和接收, 最好使用 TXE 和 RXNE 标志。

## 19.3.8 关闭 SPI

当通讯结束,可以通过关闭 SPI 模块来终止通讯。清除 SPE 位即可关闭 SPI。

在某些配置下,如果再传输还未完成时,就关闭 SPI 模块并进入停机模式,则可能导致当前的传输被破坏,而且 BSY 标志也变得不可信。

为了避免发生这种情况,关闭 SPI 模块时,建议按照下述步骤操作:



- 在主或从模式下的全双工模式(BIDIMODE=0, RXONLY=0)
  - A. 等待 RXNE=1 并接收最后一个数据;
  - B. 等待 TXE=1;
  - C. 等待 BSY=0;
  - D. 关闭 SPI(SPE=0),最后进入停机模式(或关闭该模块的时钟)。
- 在主或从模式下的单向只发送模式(BIDIMODE=0,RXONLY=0)或双向的发送模式(BIDIMODE=1,BIDIOE=1)

在 SPIx DR 寄存器中写入最后一个数据后:

- A. 等待 TXE=1:
- B. 等待 BSY=0;
- C. 关闭 SPI (SPE=0), 最后进入停机模式(或关闭该模块的时钟)。
- 在主或从模式下的单向只接收模式(MSTR=1,BIDIMODE=0,RXONLY=1)或双向的接收模式 (MSTR=1,BIDIMODE=1,BIDIOE=0)

这种情况需要特别处理,以保证 SPI 不会开始一次新的传输:

- A. 等待倒数第二个(第 n-1 个) RXNE=1;
- B. 在关闭 SPI (SPE=0) 之前等待一个 SPI 时钟周期 (使用软件延迟);
- C. 在进入停机模式(或关闭该模块的时钟)之前等待最后一个 RXNE=1。

注意:在主模式下的单向只发送模式(MSTR=1,BDM=1,BDOE=0)时,传输过程中 BSY 标志始终 为低。

- 在从模式下的只接收模式(MSTR=0,BIDIMODE=0,RXONLY=1)或双向的接收模式 (MSTR=0,BIDIMODE=1,BIDIOE=0):
  - A. 可以在任何时候关闭 SPI (SPE=0), SPI 会在当前的传输结束后被关闭;
  - B. 如果希望进入停机模式,在进入停机模式(或关闭该模块的时钟)之前必须首先等待 BSY=0。

## 19.3.9 利用 DMA 的 SPI 通信

为了达到最大通信速度,需要及时往 SPI 发送缓冲器填数据,同样接收缓冲器中的数据也必须及时读走以防止溢出。为了方便高速率的数据传输,SPI 实现了一种采用简单的请求/应答的 DMA 机制。

当 SPIx\_CR2 寄存器上的对应使能位被设置时,SPI 模块可以发出 DMA 传输请求。发送缓冲器和接收缓冲器亦有各自的 DMA 请求:

- 发送时,在每次 TXE 被设置为'1'时发出 DMA 请求,DMA 控制器则写数据至 SPIx\_DR 寄存器, TXE 标志因此而被清除。
- 接收时,在每次 RXNE 被设置为'1'时发出 DMA 请求,DMA 控制器则从 SPIx\_DR 寄存器读出数据,RXNE 标志因此而被清除。

当只使用 SPI 发送数据时,只需使能 SPI 的发送 DMA 通道。此时,因为没有读取收到的数据,OVR 被置为'1'。当只使用 SPI 接收数据时,只需使能 SPI 的接收 DMA 通道。

在发送模式下,当 DMA 已经传输了所有要发送的数据(DMA\_ISR 寄存器的 TCIF 标志变为'1')后,可以通过监视 BSY 标志以确认 SPI 通信结束,这样可以避免在关闭 SPI 或进入停止模式时,破坏最后一个数据的传输。因此软件需要先等待 TXE=1,然后等待 BSY=0。

注意:在不连续的通信中,在写数据到 SPIx\_DR 的操作与 BSY 位被置为'1'之间,有 2 个 APB 时钟周期的延迟,因此,在写完最后一个数据后需要先等待 TXE=1 再等待 BSY=0。





图 19-10 使用 DMA 发送



图 19-11 使用 DMA 接收

#### 带 CRC 的 DMA 功能

当使能 SPI 使用 CRC 检验并且启用 DMA 模式时,在通信结束时,CRC 字节的发送和接收是自动完成的。数据和 CRC 传输结束时,SPIx SR 寄存器的 CRCERR 标志为'1'表示在传输期间发生错误。

## 19.3.10 错误标志

#### 19.3.10.1 主模式失效错误(MODF)

主模式失效仅发生在: NSS 引脚硬件模式管理下,主设备的 NSS 脚被拉低;或者在 NSS 引脚软件模式管理下,SSI 位被置为'0'时;MODF 位被自动置位。

主模式失效对 SPI 设备有以下影响:



- MODF 位被置为'1',如果设置了 ERRIE 位,则产生 SPI 中断;
- SPE 位被清为'0'。这将停止一切输出,并且关闭 SPI 接口;
- MSTR 位被清为'0',因此强迫此设备进入从模式。

下面的步骤用于清除 MODF 位:

- 1. 当 MODF 位被置为'1'时,执行一次对 SPIx SR 寄存器的读或写操作;
- 2. 然后写 SPIx\_CR1 寄存器。

在有多个 MCU 的系统中,为了避免出现多个从设备的冲突,必须先拉高该主设备的 NSS 脚,再对 MODF 位进行清零。在完成清零之后,SPE 和 MSTR 位可以恢复到它们的原始状态。

出于安全的考虑,当 MODF 位为'1'时,硬件不允许设置 SPE 和 MSTR 位。通常配置下,从设备的 MODF 位不能被置为'1'。然而,在多主配置里,一个设备可以在设置了 MODF 位的情况下,处于从设备模式,此时,MODF 位表示可能出现了多主冲突。中断程序可以执行一个复位或返回到默认状态来从错误状态中恢复。

#### 19.3.10.2 溢出错误(OVR)

当主设备已经发送了数据字节,而从设备还没有清除前一个数据字节产生的 RXNE 时,即为溢出错误。当产生溢出错误时,OVR 位被置为'1';当设置了 ERRIE 位时,则产生中断。

此时,接收器缓冲器的数据不是主设备发送的新数据,读 SPIx\_DR 寄存器返回的是之前未读的数据, 所有随后传送的数据都被丢弃。

依次读出 SPIx\_DR 寄存器和 SPIx\_SR 寄存器可将 OVR 清除。

## 19.3.10.3 CRC 错误(CRCERR)

当设置了 SPIx\_CR 寄存器上的 CRCEN 位时,CRC 错误标志用来核对接收数据的有效性。如果移位寄存器中接收到的值(发送方发送的 SPIx\_TXCRCR 数值)与接收方 SPIx\_RXCRCR 寄存器中的数值不匹配,则 SPIx\_SR 寄存器上的 CRCERR 标志被置位为'1'。

## 19.3.11 SPI 中断

表 19-1 SPI 中断

| 中断事件      | 事件标志   | 使能控制位  |
|-----------|--------|--------|
| 发送缓冲器空标志  | TXE    | TXEIE  |
| 接收缓冲器非空标志 | RXNE   | RXNEIE |
| 主模式失效事件   | MODF   | ERRIE  |
| 溢出错误      | OVR    |        |
| CRC 错误标志  | CRCERR |        |

## 19.4 SPI 寄存器

基地址: (SPI1, SPI2) = (0x4001 3000, 0x4000 3800)

空间大小: (SPI1, SPI2) = (0x400, 0x400)

可以用半字(16位)或字(32位)的方式操作这些外设寄存器。



# 19.4.1 SPI 控制寄存器 1(SPIx\_CR1)(x=1..2)

偏移地址: 0x00 复位值: 0x0000

| 15      | 14    | 13   | 12     | 11 | 10    | 9  | 8  | 7       | 6  | 5 4 3   | 2   | 1   | 0   |
|---------|-------|------|--------|----|-------|----|----|---------|----|---------|-----|-----|-----|
| BIDIMOD | BIDIO | CRCE | CRCNEX | DF | RXONL | SS | SS | LSBFIRS | SP | BR[2:0] | MST | CPO | CPH |
| E       | Е     | N    | Т      | F  | Υ     | M  | 1  | Т       | E  |         | R   | L   | Α   |
| rw      | rw    | rw   | rw     | rw | rw    | rw | rw | rw      | rw | rw      | rw  | rw  | rw  |

| rw          | rw                                                                                                                                                      | rw                                                                                                                                                                          | rw                      | rw  | rw           | rw          | rw | rw   | rw | rw | rw | rw | rw |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-----|--------------|-------------|----|------|----|----|----|----|----|
| 位 15        | BIDIMODE: 双向数据模式使能(Bidirectional data mode enable)  • 0: 选择"双线双向"模式  • 1: 选择"单线双向"模式                                                                    |                                                                                                                                                                             |                         |     |              |             |    |      |    |    |    |    |    |
| 位 14        | 和 BII<br>• 0:<br>• 1:                                                                                                                                   | BIDIOE: 双向模式下的输出使能(Output enable in bidirectional mode) 和 BIDIMODE 位一起决定在"单线双向"模式下数据的输出方向:  • 0: 输出禁止(只收模式)  • 1: 输出使能(只发模式) <i>这个"单线"数据线在主设备端为 MOSI 引脚,在从设备端为 MISO 引脚。</i> |                         |     |              |             |    |      |    |    |    |    |    |
| 位 13        | CRCEN: 使能 CRC(Hardware CRC calculation enable)  • 0: 禁止 CRC 计算  • 1: 使能 CRC 计算  注意: 只有当 SPI 禁止时(SPE=0),此位可以被写。                                          |                                                                                                                                                                             |                         |     |              |             |    |      |    |    |    |    |    |
| 位 12        | CRCNEXT: 下一个发送 CRC(Transmit CRC next)  • 0: 下一个发送的值来自发送缓冲区  • 1: 下一个发送的值来自发送 CRC 寄存器  注意:  在 SPIx_DR 寄存器写入最后一个数据后应马上设置该位。                               |                                                                                                                                                                             |                         |     |              |             |    |      |    |    |    |    |    |
| 位 <b>11</b> | <ul><li>0:</li><li>1:</li></ul>                                                                                                                         | 使用 <b>8</b><br>使用 <b>1</b> 6                                                                                                                                                | 格式(Da<br>位数据帧<br>6 位数据帧 | 格式运 | 生行发送<br>进行发送 | /接收<br>迭/接收 |    | 则出错。 |    |    |    |    |    |
| 位 10        | RXONLY: 只接收(Receive only) 该位和 BIDIMODE 位一起决定在"双线双向"模式下的传输方向。在多个从设备的配置中,在未被访问的从设备上该位被置 1,使得只有被访问的从设备有输出,从而不会造成数据线上数据冲突。 • 0: 全双工(发送和接收) • 1: 禁止输出(只接收模式) |                                                                                                                                                                             |                         |     |              |             |    |      |    |    |    |    |    |
| 位 9         |                                                                                                                                                         |                                                                                                                                                                             | 设备管理<br>位时,NSS          |     |              |             | _  |      | )  |    |    |    |    |



| 观测心力  | 中17月 XXX I                                       |
|-------|--------------------------------------------------|
|       | • 0: 禁止软件从设备管理<br>• 1: 启用软件从设备管理                 |
|       |                                                  |
| 位 8   | SSI: 内部从设备选择(Internal slave select)              |
|       | 该位只在SSM 位为1'时有意义。它决定了NSS 上的电平,在NSS 引脚上的I/O 操作无效。 |
|       | <i>3</i> X •                                     |
| 位 7   | LSBFIRST: 帧格式 (Frame format)                     |
|       | • 0: 先发送 MSB                                     |
|       | • 1: 先发送 LSB                                     |
|       | 注意:                                              |
|       | 当通信在进行时不能改变该位的值。                                 |
| 位 6   | SPE: SPI 使能(SPI enable )                         |
|       | • 0: 禁止 SPI 设备                                   |
|       | • 1: 开启 SPI 设备                                   |
|       | 注意:                                              |
|       | 当关闭SPI 设备时,请按照章节:"关闭SPI"节的过程操作。                  |
| 位 5:3 | BR[2:0]: 波特率控制(Baud rate control)                |
|       | • 000: f <sub>PCLK</sub> /2                      |
|       | • 001: f <sub>PCLK</sub> /4                      |
|       | • 010: f <sub>PCLK</sub> /8                      |
|       | • 011: fpclk/16                                  |
|       | • 100: f <sub>PCLK</sub> /32                     |
|       | • 101: fpclk/64                                  |
|       | • 110: fpclk/128                                 |
|       | • 111: fpclk/256                                 |
|       | 当通信正在进行的时候,不能修改该位域。                              |
| 位 2   | MSTR: 主设备选择(Master selection)                    |
|       | • 0: 配置为从设备                                      |
|       | • 1: 配置为主设备                                      |
|       | 注意:                                              |
|       | <i>当通信正在进行的时候,不能修改该位。</i>                        |
| 位 1   | CPOL: 时钟极性(Clock polarity)                       |
|       | • 0: 空闲状态时, SCK 保持低电平                            |
|       | • 1: 空闲状态时, SCK 保持高电平                            |
|       | 注意:                                              |
|       | <i>当通信正在进行的时候,不能修改该位。</i>                        |
| 位 0   | CPHA: 时钟相位(Clock phase)                          |
|       |                                                  |



- 0: 数据采样从第一个时钟边沿开始
- 1: 数据采样从第二个时钟边沿开始

注意:

当通信正在进行的时候, 不能修改该位。

# 19.4.2 SPI 控制寄存器 2(SPIx\_CR2)(x=1..2)

偏移地址: 0x04 复位值: 0x0000

| Res TXEIE RXNEIE ERRIE Res SSOE TXDMAEN RXDMAEN rw rw rw rw rw rw rw rw | ĺ | 15 14 13 12 11 10 9 8 |  |  |    |    | 7 | 6 | 5     | 4      | 3     | 2 | 1  | 0    |         |         |
|-------------------------------------------------------------------------|---|-----------------------|--|--|----|----|---|---|-------|--------|-------|---|----|------|---------|---------|
| rw rw rw rw rw rw                                                       |   |                       |  |  | Re | es |   |   | TXEIE | RXNEIE | ERRIE | R | es | SSOE | TXDMAEN | RXDMAEN |
|                                                                         |   |                       |  |  |    |    |   |   | rw    | rw     | rw    |   |    | rw   | rw      | rw      |

|        | rw rw rw rw rw                                                                                                       |
|--------|----------------------------------------------------------------------------------------------------------------------|
| 位 15:8 | Res: 保留<br>必须保持复位值。                                                                                                  |
| 位 7    | TXEIE: 发送缓冲区空中断使能(Tx buffer empty interrupt enable)  • 0: 禁止 TXE 中断  • 1: 允许 TXE 中断,当 TXE 标志置位为'1'时产生中断请求            |
| 位 6    | RXNEIE:接收缓冲区非空中断使能(RX buffer not empty interrupt enable)  • 0:禁止 RXNE 中断  • 1:允许 RXNE 中断,当 RXNE 标志置位时产生中断请求          |
| 位 5    | ERRIR: 错误中断使能(Error interrupt enable)错误(CRCERR、OVR、UDR、MODF)产生时,该位控制是否产生中断  O: 禁止错误中断  1: 允许错误中断                     |
| 位 4:3  | Res: 保留<br>必须保持复位值。                                                                                                  |
| 位 2    | SSOE: SS 输出使能(SS output enable)  • 0: 禁止在主模式下 SS 输出,该设备可以工作在多主设备模式  • 1: 设备开启时,开启主模式下 SS 输出,该设备不能工作在多主设备模式           |
| 位 1    | TXDMAEN: 发送缓冲区 DMA 使能(Tx buffer DMA enable)<br>当该位被设置时,TXE 标志一旦被置位就发出 DMA 请求<br>• 0: 禁止发送缓冲区 DMA<br>• 1: 启动发送缓冲区 DMA |
| 位 0    | RXDMAEN:接收缓冲区 DMA 使能(Rx buffer DMA enable)<br>当该位被设置时,RXNE 标志一旦被置位就发出 DMA 请求<br>• 0:禁止接收缓冲区 DMA<br>• 1:启动接收缓冲区 DMA   |



# 19.4.3 SPI 状态寄存器(SPIx\_SR)(x=1..2)

偏移地址: 0x08 复位值: 0x0002

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7   | 6   | 5    | 4      | 3   | 2      | 1   | 0    |
|----|----|----|----|----|----|---|---|-----|-----|------|--------|-----|--------|-----|------|
|    |    |    | Re | es |    |   |   | BSY | OVR | MODF | CRCERR | UDR | CHSIDE | TXE | RXNE |
|    |    |    |    |    |    |   |   | r   | r   | r    | rc w0  | r   | r      | r   | r    |

|        | rrrrc_w0rrrr                                                                                                                                        |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 15:8 | Res: 保留<br>必须保持复位值。                                                                                                                                 |
| 位 7    | BSY: 忙标志(Busy flag)  • 0: SPI 不忙  • 1: SPI 正忙于通信,或者发送缓冲非空 该位由硬件置位或者复位。  注意: 使用这个标志时需要特别注意,详见"19.3.7 状态标志"和"19.3.8 关闭 SPI"。                          |
| 位 6    | OVR: 溢出标志(Overrun flag)         • 0: 没有出现溢出错误         • 1: 出现溢出错误         该位由硬件置位,由软件序列复位。关于软件序列的详细信息,参考"19.4.7 SPI Tx CRC 寄存器(SPIx_TXCRCR)(x=12)"。 |
| 位 5    | MODF:模式错误(Mode fault)  • 0:没有出现模式错误  • 1:出现模式错误 该位由硬件置位,由软件序列复位。关于软件序列的详细信息,参考"19.3.10 错误标志"。                                                       |
| 位 4    | CRCERR: CRC 错误标志(CRC error flag)  • 0: 收到的 CRC 值和 SPIx_RXCRCR 寄存器中的值匹配  • 1: 收到的 CRC 值和 SPIx_RXCRCR 寄存器中的值不匹配 该位由硬件置位,由软件写'0'而复位。                   |
| 位 3    | UDR: 下溢标志位(Underrun flag)  • 0: 未发生下溢  • 1: 发生下溢 该标志位由硬件置'1',由一个软件序列清零,详见章节"19.3.10 错误标志"。  注意: SPI 模式下不使用。                                         |
| 位 2    | CHSIDE: 声道(Channel side)  • 0: 需要传输或者接收左声道  • 1: 需要传输或者接收右声道  注意: 在 SPI 模式下不使用。在 PCM 模式下无意义。                                                        |



| 位 1 | TXE: 发送缓冲为空(Transmit buffer empty)  • 0: 发送缓冲非空  • 1: 发送缓冲为空  |
|-----|---------------------------------------------------------------|
| 位 0 | RXNE:接收缓冲非空(Receive buffer not empty)  • 0:接收缓冲为空  • 1:接收缓冲非空 |

## 19.4.4 SPI 数据寄存器(SPIx\_DR)(x=1..2)

偏移地址: 0x0C 复位值: 0x0000

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

#### 位 15:0 DR[15:0]: 数据寄存器(Data register)

存放待发送或者已经收到的数据

数据寄存器对应两个缓冲区:一个用于写(发送缓冲);另外一个用于读(接收缓冲)。 写操作将数据写到发送缓冲区;读操作将返回接收缓冲区里的数据。

对 SPI 模式的注释:

根据 SPIx\_CR1 的 DFF 位对数据帧格式的选择,数据的发送和接收可以是 8 位或者 16 位的。为保证正确的操作,需要在启用 SPI 之前就确定好数据帧格式。对于 8 位的数据,缓冲器是 8 位的,发送和接收时只会用到 SPIx\_DR[7:0]。在接收时,SPIx\_DR[15:8]被强制为 0。

对于 16 位的数据,缓冲器是 16 位的,发送和接收时会用到整个数据寄存器,即 SPIx\_DR[15:0]。

## 19.4.5 SPI CRC 多项式寄存器(SPIx\_CRCPR)(x=1..2)

偏移地址: 0x10 复位值: 0x0007

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

位 15:0 CRCPOLY[15:0]: CRC 多项式寄存器(CRC polynomial register)

该寄存器包含了 CRC 计算时用到的多项式。其复位值为 0x0007,根据应用可以设置其他数值。

# 19.4.6 SPI Rx CRC 寄存器(SPIx\_RXCRCR)(x=1..2)

偏移地址: 0x14 复位值: 0x0000

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



位 15:0

RxCRC[15:0]:接收 CRC 寄存器(Rx CRC register)

在启用 CRC 计算时,RXCRC[15:0]中包含了依据收到的字节计算的 CRC 数值。当在 SPIx\_CR1 的 CRCEN 位写入'1'时,该寄存器被复位。

CRC 计算使用 SPIx CRCPR 中的多项式:

- 当数据帧格式被设置为 8 位时,仅低 8 位参与计算,并且按照 CRC8 的方法进行
- 当数据帧格式 为 16 位时,寄存器中的所有 16 位都参与计算,并且按照 CRC16 的标准 *注意*:
- 当BSY 标志为'1'时读该寄存器,将可能读到不正确的数值。
- 12S 模式下不使用。

### 19.4.7 SPI Tx CRC 寄存器(SPIx TXCRCR)(x=1..2)

偏移地址: 0x18 复位值: 0x0000

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

位 15:0

TxCRC[15:0]: 发送 CRC 寄存器(Tx CRC register)

在启用 CRC 计算时,TXCRC[15:0]中包含了依据将要发送的字节计算的 CRC 数值。当在 SPIx\_CR1 中的 CRCEN 位写入'1'时,该寄存器被复位。

CRC 计算使用 SPIx\_CRCPR 中的多项式:

- 当数据帧格式被设置为 8 位时,仅低 8 位参与计算,并且按照 CRC8 的方法进行
- 当数据帧格式为 16 位时,寄存器中的所有 16 个位都参与计算,并且按照 CRC16 的标准 注意:

当BSY 标志为'1'时读该寄存器,将可能读到不正确的数值。

## 19.4.8 SPI 控制寄存器 SPIx\_CR3(x=1..2)

地址偏移: 0x40

复位值: 0x0000 0000

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

| 位 15:8 | Res: 保留<br>必须保持复位值。                                                                          |
|--------|----------------------------------------------------------------------------------------------|
| 位7     | FlexLenEn: 使能数据包长度可配  • 0: 不使用 2~32 比特数据包长度可配功能。  • 1: 使用 2~32 比特数据包长度可配功能,数据位宽由 Len[4:0]定义。 |
| 位 6:5  | Res: 保留<br>必须保持复位值。                                                                          |



位 4: 0

LEN:数据包长度

• 00000: 禁止设置。

• 其它值:数据包长为 Len[4:0] + 1 个比特;例如 Len[4:0] = 5'b00101,数据包长为 6 比

特。



## 20 I2C 接口

内部集成电路(I2C)总线接口处理微控制器与串行 I2C 总线间的通信。它遵循 I2C 规范,支持标准模式(Standard mode, Sm)、快速模式(Fast mode, Fm)同时与 SMBus 2.0 兼容。

I2C 模块有多种用途,包括 CRC 码的生成和校验、SMBus(系统管理总线)和 PMBus(电源管理总线)。

根据特定设备的需要,该接口还支持 DMA 数据传输方式,减轻 CPU 的工作量。

## 20.1 I2C 主要特点

- 并行总线/I2C 总线协议转换器
- 多主机功能:该模块既可做主设备也可做从设备
- I2C 主设备功能:
  - 。 产生时钟
  - 。 产生起始和停止信号
- I2C 从设备功能:
  - 。 可编程的 I2C 地址检测
  - 。 可响应 2 个从地址的双地址能力
  - 。 停止位检测
- 产生和检测 7 位/10 位地址和广播呼叫
- 支持不同的通讯速度:
  - 。 标准速度(高达 100 kHz)
  - 。 快速(高达 400 kHz)
- 状态标志:
  - 。 发送器/接收器模式标志
  - 。 字节发送结束标志
  - 。 I2C 总线忙标志
- 错误标志
  - 。 主模式时的仲裁丢失
  - 。 地址/数据传输后的应答(ACK)错误
  - 。 检测到错位的起始或停止条件
  - 。 禁止拉长时钟功能时的上溢或下溢
- 2个中断向量
  - 。 1个中断用于地址/数据通讯成功
  - 。 1个中断用于错误
- 可选的拉长时钟功能
- 具单字节缓冲器的 DMA
- 可配置的 PEC (信息包错误检测)的产生或校验:
  - 。 发送模式中 PEC 值可以作为最后一个字节传输
  - 。 用于最后一个接收字节的 PEC 错误校验
- 兼容 SMBus 2.0



- 。 25 ms 时钟低超时延时
- 。 10 ms 主设备累积时钟低扩展时间
- 。 25 ms 从设备累积时钟低扩展时间
- 。 带 ACK 控制的硬件 PEC 产生/校验
- 。 支持地址分辨协议(ARP)
- 兼容 SMBus

## 20.2 I2C 功能描述

I2C 模块接收和发送数据,并将数据从串行转换成并行,或并行转换成串行。可以开启或禁止中断。接口通过数据引脚(SDA)和时钟引脚(SCL)连接到 I2C 总线。允许连接到标准(高达 100kHz)或快速(高达 400kHz)的 I2C 总线。

## 20.2.1 模式选择

接口可以下述 4 种模式中的一种运行:

- 从发送器模式
- 从接收器模式
- 主发送器模式
- 主接收器模式

该模块默认地工作于从模式。接口在生成起始条件后自动地自从模式切换到主模式; 当仲裁丢失或 产生停止信号时,则从主模式切换到从模式。允许多主机功能。

### 20.2.1.1 通信流

主模式时,I2C 接口启动数据传输并产生时钟信号。串行数据传输总是以起始条件开始并以停止条件结束。起始条件和停止条件都是在主模式下由软件控制产生。

从模式时,I2C 接口能识别它自己的地址(7 位或 10 位)和广播呼叫地址。软件能够控制开启或禁止广播呼叫地址的识别。

数据和地址按 8 位/字节进行传输,高位在前。跟在起始条件后的 1 或 2 个字节是地址(7 位模式为 1 个字节, 10 位模式为 2 个字节)。地址只在主模式发送。在一个字节传输的 8 个时钟后的第 9 个时钟期间,接收器必须回送一个应答位(ACK)给发送器。参考下图。



图 20-1 I2C 总线协议

软件可以开启或禁止应答(ACK),并可以设置 I2C 接口的地址(7 位、10 位地址或广播呼叫地址)。 I2C 接口的功能框图示于下图:





图 20-2 I2C 的功能框图

注意:在SMBus模式下,SMBALERT是可选信号。如果禁止了SMBus,则不能使用该信号。

## 20.2.2 I2C 从模式

默认情况下,I2C接口总是工作在从模式。自从模式切换到主模式,需要产生一个起始条件。

为了产生正确的时序,必须在 I2Cx\_CR2 寄存器中设定该模块的输入时钟。输入时钟的频率必须至少是:

- 标准模式下为: 2MHz
- 快速模式下为: 4MHz
- 一旦检测到起始条件,在 SDA 线上接收到的地址被送到移位寄存器。然后与芯片自己的地址 OAR1 和 OAR2(当 ENDUAL=1)或者广播呼叫地址(如果 ENGC=1)相比较:

注意:在10位地址模式时,比较包括头段序列(11110xx0),其中的xx是地址的两个最高有效位。

- 。 头段或地址不匹配: I2C 接口将其忽略并等待另一个起始条件。
- 。 头段匹配(仅 10 位模式): 如果 ACK 位被置'1', I2C 接口产生一个应答脉冲并等待 8 位从地址。
- 。 地址匹配: I2C 接口产生以下时序:
  - 如果 ACK 被置'1',则产生一个应答脉冲。
  - 硬件设置 ADDR 位;如果设置了 ITEVFEN 位,则产生一个中断。
  - 如果 ENDUAL=1,软件必须读 DUALF 位,以确认响应了哪个从地址。



在 10 位模式,接收到地址序列后,从设备总是处于接收器模式。在收到与地址匹配的头序列并且最低位为'1'(即 11110xx1)后,当接收到重复的起始条件时,将进入发送器模式。

在从模式下 TRA 位指示当前是处于接收器模式还是发送器模式。

#### 20.2.2.1 从发送器

在接收到地址和清除 ADDR 位后,从发送器将字节从 DR 寄存器经由内部移位寄存器发送到 SDA 线上。

从设备保持 SCL 为低电平,直到 ADDR 位被清除并且待发送数据已写入 DR 寄存器。(见下图中的 EV1 和 EV3)。

当收到应答脉冲时:

• TXE 位被硬件置位,如果设置了 ITEVFEN 和 ITBUFEN 位,则产生一个中断。
如果 TXE 位被置位,但在下一个数据发送结束之前没有新数据写入到 I2CX\_DR 寄存器,则 BTF 位被置位,在清除 BTF 之前 I2C 接口烙保持 SCI 为低电平,读出 I2CX\_SPI 之 巨 更 写 》 I2CX\_DR

位被置位,在清除 BTF 之前 I2C 接口将保持 SCL 为低电平;读出 I2Cx\_SR1 之后再写入 I2Cx\_DR 寄存器将清除 BTF 位。



图 20-3 从发送器的传送序列图

#### 说明:

- S=Start (起始条件), S<sub>r</sub>=重复的起始条件, P=Stop (停止条件), A=响应, NA=非响应, EVx=事件 (ITEVFEN=1 时产生中断)
- EV1: ADDR=1, 读 SR1 然后读 SR2 将清除该事件。
- EV3-1: TxE=1,移位寄存器空,数据寄存器空,写 DR。
- EV3: TxE=1,移位寄存器非空,数据寄存器空,写 DR 将清除该事件。
- EV3-2: AF=1, 在 SR1 寄存器的 AF 位写'0'可清除 AF 位。 注意:
  - EV1 和 EV3 1 事件拉长 SCL 低的时间, 直到对应的软件序列结束。
  - EV3 的软件序列必须在当前字节传输结束之前完成。

#### 20.2.2.2 从接收器

在接收到地址并清除 ADDR 后,从接收器将通过内部移位寄存器从 SDA 线接收到的字节存进 DR 寄存器。I2C 接口在接收到每个字节后都执行下列操作:

- 如果设置了 ACK 位,则产生一个应答脉冲
- 硬件设置 RxNE=1。如果设置了 ITEVFEN 和 ITBUFEN 位,则产生一个中断。



如果 RxNE 被置位,并且在接收新的数据结束之前 DR 寄存器未被读出,BTF 位被置位,在清除 BTF 之前 I2C接口将保持 SCL 为低电平;读出 I2Cx SR1 之后再写入 I2Cx DR 寄存器将清除 BTF 位。(见下图)。



图 20-4 从接收器的传送序列图

#### 说明:

- S=Start(起始条件), S<sub>r</sub>=重复的起始条件, P=Stop(停止条件), A=响应, NA=非响应, EVx=事件(ITEVFEN=1 时产生中断)
- EV1: ADDR=1, 读 SR1 然后读 SR2 将清除该事件。
- EV2: RxNE=1, 读 DR 将清除该事件。
- EV4: STOPF=1, 读 SR1 然后写 CR1 寄存器将清除该事件。
   注意:
  - EV1 事件拉长 SCL 低的时间,直到对应的软件序列结束。
  - EV2 的软件序列必须在当前字节传输结束之前完成。

## 20.2.2.3 关闭从通信

在传输完最后一个数据字节后,主设备产生一个停止条件,I2C 接口检测到这一条件时,设置 STOPF=1,如果设置了 ITEVFEN 位,则产生一个中断。然后 I2C 接口等待读 SR1 寄存器,再写 CR1 寄存器。(见上图的 EV4)。

## 20.2.3 I2C 主模式

在主模式时,I2C接口启动数据传输并产生时钟信号。串行数据传输总是以起始条件开始并以停止条件结束。当通过 START 位在总线上产生了起始条件,设备就进入了主模式。

以下是主模式所要求的操作顺序:

- 1. 在 I2Cx\_CR2 寄存器中设定该模块的输入时钟以产生正确的时序
- 2. 配置时钟控制寄存器
- 3. 配置上升时间寄存器
- 4. 编程 I2Cx CR1 寄存器启动外设
- 5. 置 I2Cx CR1 寄存器中的 START 位为 1,产生起始条件
- I2C 模块的输入时钟频率必须至少是:
- 标准模式下为: 2MHz
- 快速模式下为: 4MHz



#### 20.2.3.1 起始条件

当 BUSY=0 时,设置 START=1, I2C 接口将产生一个开始条件并切换至主模式(M/SL 位置位)。

注意:在主模式下,设置START 位将在当前字节传输完后由硬件产生一个重开始条件。

一旦发出开始条件,SB 位被硬件置位,如果设置了 ITEVFEN 位,则会产生一个中断。

然后主设备等待读 SR1 寄存器,紧跟着将从地址写入 DR 寄存器(见图 20-5 和图 20-6 的 EV5)。

#### 20.2.3.2 从地址的发送

从地址通过内部移位寄存器被送到 SDA 线上。

- 在 10 位地址模式时,发送一个头段序列产生以下事件:
  - 。 ADD10 位被硬件置位,如果设置了 ITEVFEN 位,则产生一个中断。

然后主设备等待读 SR1 寄存器,再将第二个地址字节写入 DR 寄存器(见图 20-5 和图 20-6)。

。 - ADDR 位被硬件置位,如果设置了 ITEVFEN 位,则产生一个中断。

随后主设备等待一次读 SR1 寄存器, 跟着读 SR2 寄存器(见图 20-5 和图 20-6)。

- 在7位地址模式时,只需送出一个地址字节。
  - 一旦该地址字节被送出:
  - ADDR 位被硬件置位,如果设置了 ITEVFEN 位,则产生一个中断。

随后主设备等待一次读 SR1 寄存器, 跟着读 SR2 寄存器(见图 20-5 和图 20-6)。

根据送出从地址的最低位,主设备决定进入发送器模式还是进入接收器模式。

- 在7位地址模式时:
  - 。 要进入发送器模式,主设备发送从地址时置最低位为'0'。
  - 。 要进入接收器模式,主设备发送从地址时置最低位为'1'。
- 在 10 位地址模式时
  - 。 要进入发送器模式,主设备先送头字节(11110xx0),然后送最低位为'0'的从地址。(这里 xx 代表 10 位地址中的最高 2 位。)
  - 。 要进入接收器模式,主设备先送头字节(11110xx0),然后送最低位为'1'的从地址。然后 再重新发送一个开始条件,后面跟着头字节(11110xx1)(这里 xx 代表 10 位地址中的最高 2 位。)

TRA 位指示主设备是在接收器模式还是发送器模式。

#### 20.2.3.3 主发送器

在发送了地址和清除了 ADDR 位后,主设备通过内部移位寄存器将字节从 DR 寄存器发送到 SDA线上。主设备等待, 直到 TxE 被清除,(见图 20-5 的 EV8)。

当收到应答脉冲时:

• TXE 位被硬件置位,如果设置了 INEVFEN 和 ITBUFEN 位,则产生一个中断。 如果 TXE 被置位并且在上一次数据发送结束之前没有写新的数据字节到 DR 寄存器,则 BTF 被 硬件置位,在清除 BTF 之前 I2C 接口将保持 SCL 为低电平;读出 I2Cx\_SR1 之后再写入 I2Cx\_DR 寄存器将清除 BTF 位。

#### 20.2.3.4 关闭通信

在 DR 寄存器中写入最后一个字节后,通过设置 STOP 位产生一个停止条件(见图 20-5 的 EV8 2),



然后 I2C 接口将自动回到从模式 (M/S 位清除)。

注意: 当TXE 或BTF 位置位时, 停止条件应安排在出现EV8 2 事件时。



图 20-5 主发送器传送序列图

#### 说明:

- S=Start (起始条件), S<sub>r</sub>=重复的起始条件, P=Stop (停止条件), A=响应, NA=非响应, EVx=事件(ITEVFEN=1 时产生中断)。
- EV5: SB=1, 读 SR1 然后将地址写入 DR 寄存器将清除该事件。
- EV6: ADDR=1, 读 SR1 然后读 SR2 将清除该事件。
- EV8 1: TxE=1,移位寄存器空,数据寄存器空,写 DR 寄存器。
- EV8: TxE=1, 移位寄存器非空, 数据寄存器空, 写入 DR 寄存器将清除该事件。
- EV8 2: TXE=1, BTF=1, 请求设置停止位。TXE 和 BTF 位由硬件在产生停止条件时清除。
- EV9: ADDR10=1, 读 SR1 然后写入 DR 寄存器将清除该事件。
   注意:
  - EV5、EV6、EV9、EV8\_1 和 EV8\_2 事件拉长 SCL 低的时间,直到对应的软件序列结束。
  - EV8 的软件序列必须在当前字节传输结束之前完成。

#### 20.2.3.5 主接收器

在发送地址和清除 ADDR 之后,I2C 接口进入主接收器模式。在此模式下,I2C 接口从 SDA 线接收数据字节,并通过内部移位寄存器送至 DR 寄存器。在每个字节后,I2C 接口依次执行以下操作:

- 1. 如果 ACK 位被置位,发出一个应答脉冲。
- 2. 硬件设置 RxNE=1,如果设置了 INEVFEN 和 ITBUFEN 位,则会产生一个中断(见图 20-6 的 EV7)。

如果 RxNE 位被置位,并且在接收新数据结束前,DR 寄存器中的数据没有被读走,硬件将设置 BTF=1,在清除 BTF 之前 I2C 接口将保持 SCL 为低电平,读出 I2Cx\_SR1 之后再读出 I2Cx\_DR 寄存器将清除 BTF 位。

#### 20.2.3.6 关闭通信

主设备在从设备接收到最后一个字节后发送一个 NACK。接收到 NACK 后,从设备释放对 SCL 和 SDA 线的控制;主设备就可以发送一个停止/重起始条件。

- 为了在收到最后一个字节后产生一个 NACK 脉冲,在读倒数第二个数据字节之后(在倒数第二个 RxNE 事件之后)必须清除 ACK 位。
- 为了产生一个停止/重起始条件,软件必须在读倒数第二个数据字节之后(在倒数第二个 RxNE 事件之后)设置 STOP/START 位。



• 在只接收一个字节数据的情况下,应该在 EV6 之后(在 EV6\_1 中,即在 ADDR 位被清除之后) 设置 NACK 和设置发送停止信号。



图 20-6 主接收器传送序列图

#### 说明:

- S=Start(起始条件), Sr=重复的起始条件, P=Stop(停止条件), A=响应, NA=非响应, EVx=事件(ITEVFEN=1 时产生中断)
- EV5: SB=1, 读 SR1 然后将地址写入 DR 寄存器将清除该事件。
- EV6: ADDR=1,读 SR1然后读SR2将清除该事件。在10位主接收模式下,该事件后应设置CR2的START=1。
- EV6\_1: 没有对应的事件标志,只适于接收1个字节的情况。恰好在 EV6 之后(即清除了 ADDR 之后),要清除响应和停止条件的产生位。
- EV7: RxNE=1, 读 DR 寄存器清除该事件。
- EV7 1: RxNE=1, 读 DR 寄存器清除该事件。设置 ACK=0 和 STOP 请求。
- EV9: ADDR10=1, 读 SR1 然后写入 DR 寄存器将清除该事件。
   注意:
  - 如果收到一个单独的字节,则是 NA 。
  - EV5、EV6 和 EV9 事件拉长 SCL 低电平,直到对应的软件序列结束。
  - EV7 的软件序列必须在当前字节传输结束前完成。
  - EV6 1 或 EV7 1 的软件序列必须在当前传输字节的 ACK 脉冲之前完成。

### 20.2.4 错误条件

以下条件可能造成通讯失败。

#### 20.2.4.1 总线错误(BERR)

在一个地址或数据字节传输期间,当 I2C 接口检测到一个外部的停止或起始条件则产生总线错误。此时:

- BERR 位被置位为'1';如果设置了ITERREN 位,则产生一个中断;
- 在从模式情况下,数据被丢弃,硬件释放总线:
  - 。 如果是错误的开始条件,从设备认为是一个重启动,并等待地址或停止条件。
  - 。 如果是错误的停止条件,从设备按正常的停止条件操作,同时硬件释放总线。
- 在主模式情况下,硬件不释放总线,同时不影响当前的传输状态。此时由软件决定是否要中止 当前的传输。



#### 20.2.4.2 应答错误(AF)

当接口检测到一个无应答位时,产生应答错误。此时:

- AF 位被置位,如果设置了 ITERREN 位,则产生一个中断:
- 当发送器接收到一个 NACK 时,必须复位通讯:
  - 。 如果是处于从模式,硬件释放总线。
  - 。 如果是处于主模式,软件必须生成一个停止条件。

#### 20.2.4.3 仲裁丢失(ARLO)

当 I2C 接口检测到仲裁丢失时产生仲裁丢失错误,此时:

- ARLO 位被硬件置位,如果设置了 ITERREN 位,则产生一个中断;
- I2C 接口自动回到从模式(M/SL 位被清除)。当 I2C 接口丢失了仲裁,则它无法在同一个传输中响应它的从地址,但它可以在赢得总线的主设备发送重起始条件之后响应;
- 硬件释放总线。

#### 20.2.4.4 过载/欠载错误(OVR)

在从模式下,如果禁止时钟延长,I2C接口正在接收数据时,当它已经接收到一个字节(RxNE=1), 但在 DR 寄存器中前一个字节数据还没有被读出,则发生过载错误。此时:

- 最后接收的数据被丢弃:
- 在过载错误时,软件应清除 RxNE 位,发送器应该重新发送最后一次发送的字节。

在从模式下,如果禁止时钟延长,I2C接口正在发送数据时,在下一个字节的时钟到达之前,新的数据还未写入DR寄存器(TxE=1),则发生欠载错误。此时:

- 在 DR 寄存器中的前一个字节将被重复发出;
- 用户应该确定在发生欠载错时,接收端应丢弃重复接收到的数据。发送端应按 I2C 总线标准在规定的时间更新 DR 寄存器。

在发送第一个字节时,必须在清除 ADDR 之后并且第一个 SCL 上升沿之前写入 DR 寄存器;如果不能做到这点,则接收方应该丢弃第一个数据。

## 20.2.5 SDA/SCL 线控制

- 如果允许时钟延长:
  - 。 发送器模式:如果 TxE=1 且 BTF=1: I2C 接口在传输前保持时钟线为低,以等待软件读取 SR1,然后把数据写进数据寄存器(缓冲器和移位寄存器都是空的)。
  - 。 接收器模式:如果 RxNE=1 且 BTF=1: I2C 接口在接收到数据字节后保持时钟线为低,以等待软件读 SR1,然后读数据寄存器 DR(缓冲器和移位寄存器都是满的)。
- 如果在从模式中禁止时钟延长:
  - 如果 RxNE=1,在接收到下个字节前 DR 还没有被读出,则发生过载错。接收到的最后一个字节丢失。
  - 。 如果 TxE=1,在必须发送下个字节之前却没有新数据写进 DR,则发生欠载错。相同的字节将被重复发出。
  - 。 不控制重复写冲突。



#### 20.2.6 SMBus

#### 20.2.6.1 介绍

系统管理总线(SMBus)是一个双线接口。通过它,各设备之间以及设备与系统的其他部分之间可以互相通信。它基于 I2C 操作原理。SMBus 为系统和电源管理相关的任务提供一条控制总线。一个系统利用 SMBus 可以和多个设备互传信息,而不需使用独立的控制线路。

SMBus 标准涉及以下三类设备。

- 从设备:接收或响应命令的设备。
- 主设备: 用来发送命令、产生时钟和终止发送的设备。
- 主机:一种专用的主设备,它提供与系统 CPU 的主接口。主机必须具有主-从机功能并且必须支持 SMBus 提醒协议。一个系统里只允许有一个主机。

#### 20.2.6.2 SMBus 和 I2C 之间的相似点

- 2条线的总线协议(1个时钟,1个数据)加可选的SMBus提醒线;
- 主从通信,主设备提供时钟;
- 多主机功能
- SMBus 数据格式类似于 I2C 的 7 位地址格式(见图 20-1);

#### 20.2.6.3 SMBus 和 I2C 之间的不同点

下表列出了 SMBus 和 I2C 的不同点。

表 20-1 SMBus 与 I2C 的差异

| SMBus               | 12C                |
|---------------------|--------------------|
| 最大传输速度 100kHz       | 最大传输速度 400kHz      |
| 最小传输速度 10kHz        | 无最小传输速度            |
| 35ms 时钟低超时          | 无时钟超时              |
| 固定的逻辑电平             | 逻辑电平由 VDD 决定       |
| 不同的地址类型(保留的、动态的等)   | 7 位、10 位和广播呼叫从地址类型 |
| 不同的总线协议(快速命令、处理呼叫等) | 无总线协议              |

#### 20.2.6.4 SMBus 应用用途

利用系统管理总线,设备可提供制造商信息,告诉系统它的型号/部件号,保存暂停事件的状态,报告不同类型的错误,接收控制参数,和返回它的状态。SMBus 为系统和电源管理相关的任务提供控制总线。

#### 20.2.6.5 设备标识

在系统管理总线上,任何一个作为从模式的设备都有一个唯一的地址,叫做从地址。保留的从地址表请参考 2.0 版的 SMBus 规范(http://smbus.org/specs/)。

### 20.2.6.6 总线协议

SMBus 技术规范支持 9 个总线协议。有关这些协议的详细资料和 SMBus 地址类型,请参考 2.0 版的



SMBus 规范(http://smbus.org/specs/)。这些协议由用户的软件来执行。

#### 20.2.6.7 地址解析协议(ARP)

通过给每个从设备动态地分配一个新的唯一地址,可以解决 SMBus 的从地址冲突。地址解析协议 (ARP) 具有以下的特性:

- 使用标准 SMBus 物理层仲裁机制分配地址;
- 当设备维持供电期间,分配的地址仍保持不变,也允许设备在断电后保留其地址。
- 在地址分配后,没有额外的 SMBus 的打包开销(也就是说访问分配地址的设备与访问固定地址的设备所用时间是一样的);
- 任何一个 SMBus 主设备可以遍历总线。

#### 20.2.6.8 唯一的设备标识符(UDID)

为了分配地址,需要一种区分每个设备的机制,每个设备必须拥有一个唯一的设备标识符。

关于在 ARP 上 128 位的 UDID 的详细信息,参考 2.0 版的 SMBus 规范(http://smbus.org/specs/)。

#### 20.2.6.9 SMBus 提醒模式

SMBus 提醒是一个带中断线的可选信号,用于那些希望扩展它们的控制能力而牺牲一个引脚的设备。SMBALERT 和 SCL、SDA 信号一样,是一种线与信号。SMBALERT 通常和 SMBus 广播呼叫地址一起使用。与 SMBus 有关的消息为 2 字节。

一个只具有从功能的设备,可以通过设置 I2Cx\_CR1 寄存器上的 ALERT 位,使用 SMBALERT 给主机发信号表示它希望进行通信。主机处理该中断并通过提醒响应地址 ARA(Alert Response Address,地址值为 0001100x)访问所有 SMBALERT 设备。只有那些将 SMBALERT 拉低的设备能应答 ARA。此状态是由 I2Cx\_SR1 寄存器中的 SMBALERT 状态标记来标识的。主机执行一个修改过的接收字节操作。由从发送设备提供的 7 位设备地址被放在字节的 7 个最高位上,第八个位可以是'0'或'1'。

如果多个设备把 SMBALERT 拉低,最高优先级设备(最小的地址)将在地址传输期间通过标准仲 裁赢得通信权。在确认从地址后,此设备不得再拉低它的 SMBALERT,如果当信息传输完成后,主机仍看到 SMBALERT 低,就知道需要再次读 ARA。

没有实现 SMBALERT 信号的主机可以定期访问 ARA。有关 SMBus 提醒模式的更多详细资料,请参考 2.0 版的 SMBus 规范(http://smbus.org/specs/)。

#### 20.2.6.10 超时错误

在定时规范上 I2C 和 SMBus 之间有很多差别。

SMBus 定义了一个时钟低超时,35ms 的超时。SMBus 规定 T<sub>LOW</sub>: SEXT 为从设备的累积时钟低扩展时间。SMBus 规定 T<sub>LOW</sub>: MEXT 为主设备的累积时钟低扩展时间。更多超时细节请参考 2.0 版的 SMBus 规范(http://smbus.org/specs/)。

I2Cx\_SR1 中的状态标志 Timeout 或 T<sub>Low</sub> 错误表明了这个特性的状态。

### 20.2.6.11 如何使用 SMBus 模式的接口

为了从 I2C 模式切换到 SMBus 模式,应该执行下列步骤:

- 1. 设置 I2Cx\_CR1 寄存器中的 SMBus 位;
- 2. 按应用要求配置 I2Cx CR1 寄存器中的 SMBTYPE 和 ENARP 位。

如果要把设备配置成主设备,产生起始条件的步骤见章节: "20.2.3 I2C 主模式"。否则,参见:



#### "20.2.2 I2C 从模式"。

软件程序必须处理多种 SMBus 协议。

- 如果 ENARP=1 且 SMBTYPE=0,使用 SMB 设备默认地址。
- 如果 ENARP=1 且 SMBTYPE=1,使用 SMB 主设备头字段。
- 如果 SMBALERT=1,使用 SMB 提醒响应地址。

### 20.2.7 DMA 请求

DMA 请求(当被使能时)仅用于数据传输。发送时数据寄存器变空或接收时数据寄存器变满,则产生 DMA 请求。DMA 请求必须在当前字节传输结束之前被响应。当为相应 DMA 通道设置的数据传输量已经完成时,DMA 控制器发送传输结束信号 ETO 到 I2C 接口,并且在中断允许时产生一个传输完成中断:

- 主发送器:在 EOT 中断服务程序中,需禁止 DMA 请求,然后在等到 BTF 事件后设置停止条件。
- 主接收器: 当要接收的数据数目大于或等于 2 时,DMA 控制器发送一个硬件信号 EOT\_1,它对应 DMA 传输(字节数一1)。如果在 I2Cx\_CR2 寄存器中设置了 LAST 位,硬件在发送完 EOT\_1 后的下一个字节,将自动发送 NACK。在中断允许的情况下,用户可以在 DMA 传输完成的中断服务程序中产生一个停止条件。

### 20.2.7.1 利用 DMA 发送

通过设置 I2Cx\_CR2 寄存器中的 DMAEN 位可以激活 DMA 模式。只要 TxE 位被置位,数据将由 DMA 从预置的存储区装载进 I2Cx\_DR 寄存器。为 I2C 分配一个 DMA 通道,须执行以下步骤(x 是通道号):

- 1. 在 DMA\_CPARx 寄存器中设置 I2Cx\_DR 寄存器地址。数据将在每个 TxE 事件后从存储器传送至这个地址。
- 2. 在 DMA\_CMARx 寄存器中设置存储器地址。数据在每个 TxE 事件后从这个存储区传送至 I2Cx DR。
- 3. 在 DMA CNDTRx 寄存器中设置所需的传输字节数。在每个 TxE 事件后,此值将被递减。
- 4. 利用 DMA CCRx 寄存器中的 PL[0:1]位配置通道优先级。
- 5. 设置 DMA\_CCRx 寄存器中的 DIR 位,并根据应用要求可以配置在整个传输完成一半或全 部完成时发出中断请求。
- 6. 通过设置 DMA\_CCTx 寄存器上的 EN 位激活通道。当 DMA 控制器中设置的数据传输数目已经完成时,DMA 控制器给 I2C 接口发送一个传输结束的EOT/EOT\_1 信号。在中断允许的情况下,将产生一个 DMA 中断。

注意:如果使用 DMA 进行发送时,不要设置 I2Cx\_CR2 寄存器的 ITBUFEN 位。

#### 20.2.7.2 利用 DMA 接收

通过设置 I2Cx\_CR2 寄存器中的 DMAEN 位可以激活 DMA 接收模式。每次接收到数据字节时,将由 DMA 把 I2Cx\_DR 寄存器的数据传送到设置的存储区(参考 DMA 说明)。设置 DMA 通道进行 I2C 接收,须执行以下步骤(x 是通道号):

- 1. 在 DMA\_CPARx 寄存器中设置 I2Cx\_DR 寄存器的地址。数据将在每次 RxNE 事件后从此地址传送到存储区。
- 2. 在 DMA\_CMARx 寄存器中设置存储区地址。数据将在每次 RxNE 事件后从 I2Cx DR 寄存器 传送



到此存储区。

- 3. 在 DMA\_CNDTRx 寄存器中设置所需的传输字节数。在每个 RxNE 事件后,此值将被递减。
- 4. 用 DMA\_CCRx 寄存器中的 PL[0:1]配置通道优先级。
- 5. 清除 DMA\_CCRx 寄存器中的 DIR 位,根据应用要求可以设置在数据传输完成一半或全部 完成时发出中断请求。
- 6. 设置 DMA\_CCRx 寄存器中的 EN 位激活该通道。当 DMA 控制器中设置的数据传输数目已经完成时,DMA 控制器给 I2C 接口发送一个传输结束的EOT/ EOT\_1 信号。在中断允许的情况下,将产生一个 DMA 中断。

注意:如果使用 DMA 进行接收时,不要设置 I2Cx\_CR2 寄存器的 ITBUFEN 位。

### 20.2.8 包错误校验(PEC)

包错误校验(PEC)计算器是用于提高通信的可靠性,这个计算器使用下述 CRC-8 多项式对每一位 串行数据进行计算:

#### $C(x) = x^8 + x^2 + x + 1$

- PEC 计算由 I2Cx\_CR1 寄存器的 ENPEC 位激活。PEC 使用 CRC-8 算法对所有信息字节进行计算,包括地址和读/写位在内。
  - 。 在发送时:在最后一个 TxE 事件时设置 I2Cx\_CR1 寄存器的 PEC 传输位,PEC 将在最后一个字节后被发送。
  - 。 在接收时:在最后一个 RxNE 事件之后设置 I2Cx\_CR1 寄存器的 PEC 位,如果下个接收到的字节不等于内部计算的 PEC,接收器发送一个 NACK。如果是主接收器,不管校对的结果如何,PEC 后都将发送 NACK。PEC 位必须在接收当前字节的 ACK 脉冲之前设置。
- 在 I2Cx SR1 寄存器中可获得 PECERR 错误标记/中断。
- 如果 DMA 和 PEC 计算器都被激活:
  - · 在发送时: 当 I2C 接口从 DMA 控制器处接收到 EOT 信号时,它在最后一个字节后自动发 送 PEC。
  - 。 在接收时: 当 I2C 接口从 DMA 处接收到一个 EOT\_1 信号时,它将自动把下一个字节作为 PEC,并且将检查它。在接收到 PEC 后产生一个 DMA 请求。
- 为了允许中间 PEC 传输,在 I2Cx\_CR2 寄存器中有一个控制位(LAST 位)用于判别是否真是最后一个 DMA 传输。如果确实是最后一个主接收器的 DMA 请求,在接收到最后一个字节后自动发送 NACK。
- 仲裁丢失时 PEC 计算失效。

## 20.3 I2C 中断请求

下表列出了所有的 I2C 中断请求

#### 表 20-2 I2C 中断请求表

| 中断事件             | 事件标志  | 开启控制位   |
|------------------|-------|---------|
| 起始位已发送(主)        | SB    | ITEVFEN |
| 地址已发送(主)或地址匹配(从) | ADDR  |         |
| 10 位头段已发送(主)     | ADD10 |         |
| 己收到停止(从)         | STOPF |         |



| 中断事件       | 事件标志     | 开启控制位             |  |  |  |  |
|------------|----------|-------------------|--|--|--|--|
| 数据字节传输完成   | BTF      |                   |  |  |  |  |
| 接收缓冲区非空    | RxNE     | ITEVFEN 和 ITBUFEN |  |  |  |  |
| 发送缓冲区空     | TxE      |                   |  |  |  |  |
| 总线错误       | BERR     | ITERREN           |  |  |  |  |
| 仲裁丢失 (主)   | ARLO     |                   |  |  |  |  |
| 响应失败       | AF       |                   |  |  |  |  |
| 过载/欠载      | OVR      |                   |  |  |  |  |
| PEC 错误     | PECERR   |                   |  |  |  |  |
| 超时/Tlow 错误 | TIMEOUT  |                   |  |  |  |  |
| SMBus 提醒   | SMBALERT |                   |  |  |  |  |

### 注意:

SB、ADDR、ADD10、STOPF、BTF、RxNE 和TxE 通过逻辑或汇到同一个中断通道中。
BERR、ARLO、AF、OVR、PECERR、TIMEOUT 和SMBALERT 通过逻辑或汇到同一个中断通道中。



图 20-7 I2C 中断映射图

# 20.4 I2C 调试模式

当微控制器进入调试模式(Cortex®-M3 核心处于停止状态)时,根据 DBG 模块中的



DBG\_I2Cx\_SMBUS\_TIMEOUT 配置位,SMBUS 超时控制或者继续正常工作或者可以停止。详见章节: "24.14.2 支持定时器、看门狗、bxCAN 和 I2C 的调试"。

## 20.5 I2C 寄存器

基地址: (I2C, I2C2) = (0x4000 5400, 0x4000 5800)

空间大小: (I2C, I2C2) = (0x400, 0x400)

可以用半字(16位)或字(32位)的方式操作这些外设寄存器。

## 20.5.1 控制寄存器 1(I2Cx\_CR1)(x=1..2)

偏移地址: 0x00 复位值: 0x0000

| 15   | 14 | 13   | 12 | 11 | 10 | 9   | 8               | 7  | 6   | 5    | 4    | 3      | 2  | 1    | 0 |
|------|----|------|----|----|----|-----|-----------------|----|-----|------|------|--------|----|------|---|
| SWRS | Re | ALER | PE | РО | AC | STO | STAR NOSTRETC E |    | ENG | ENPE | ENAR | SMBTYP | Re | SMBU | Р |
| Т    | S  | Т    | С  | S  | K  | Р   | Т               | Н  | С   | С    | Р    | Е      | S  | S    | E |
| rw   |    | rw   | rw | rw | rw | rw  | rw              | rw | rw  | rw   | rw   | rw     |    | rw   | r |
|      |    |      |    |    |    |     |                 |    |     |      |      |        |    |      | w |

|      | w                                                                                                                                                                                                                                                                     |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 15 | SWRST: 软件复位(Software reset)<br>当被置位时,I2C 处于复位状态。在复位该位前确信 I2C 的引脚被释放,总线是空的。<br>• 0: I2C 模块不处于复位状态<br>• 1: I2C 模块处于复位状态<br>注意: 该位可以用于BUSY 位为'1',在总线上又没有检测到停止条件时。                                                                                                        |
| 位 14 | Res: 保留<br>必须保持复位值。                                                                                                                                                                                                                                                   |
| 位 13 | ALERT: SMBus 提醒(SMBus alert)<br>软件可以设置或清除该位; 当 PE=0 时,由硬件清除。  • 0: 释放 SMBAlert 引脚使其变高。提醒响应地址头紧跟在 NACK 信号后面  • 1: 驱动 SMBAlert 引脚使其变低。提醒响应地址头紧跟在 ACK 信号后面                                                                                                               |
| 位 12 | PEC:数据包出错检测(Packet error checking)<br>软件可以设置或清除该位;当传送 PEC 后,或起始或停止条件时,或当 PE=0 时硬件<br>将其清除。  • 0: 无 PEC 传输  • 1: PEC 传输(在发送或接收模式)  注意:仲裁丢失时,PEC 的计算失效。                                                                                                                 |
| 位 11 | POS: 应答/PEC 位置(用于数据接收)(Acknowledge/PEC Position(for data reception))软件可以设置或清除该位,或当 PE=0 时,由硬件清除。  • 0: ACK 位控制当前移位寄存器内正在接收的字节的(N)ACK PEC 位表明当前移位寄存器内的字节是 PEC。  • 1: ACK 位控制在移位寄存器里接收的下一个字节的(N)ACK PEC 位表明在移位寄存器里接收的下一个字节是 PEC。  注意: POS 位只能用在 2 字节的接收配置中,必须在接收数据之前配置。 |



|      | 12C JX I                                                                                                                                                               |
|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | 为了NACK 第2 个字节,必须在清除 ADDR 为之后清除 ACK 位。为了检测第2 个字节的<br>PEC,必须在配置了 POS 位之后,拉伸 ADDR 事件时设置 PEC 位。                                                                            |
| 位 10 | ACK: 应答使能(Acknowledge enable)<br>软件可以设置或清除该位,或当 PE=0 时,由硬件清除。<br>• 0: 无应答返回<br>• 1: 在接收到一个字节后返回一个应答(匹配的地址或数据)                                                          |
| 位 9  | STOP: 停止条件产生 (Stop generation) 软件可以设置或清除该位; 或当检测到停止条件时,由硬件清除; 当检测到超时错误时,硬件将其置位。  • 在主模式下:                                                                              |
| 位 8  | START: 起始条件产生(Start generation)<br>软件可以设置或清除该位,或当起始条件发出后或 PE=0 时,由硬件清除。<br>• 在主模式下:<br>• 0: 无起始条件产生<br>• 1: 重复产生起始条件<br>• 在从模式下:<br>• 0: 无起始条件产生<br>• 1: 当总线空闲时,产生起始条件 |
| 位 7  | NOSTRETCH:禁止时钟延长(从模式)(Clock stretching disable (Slave mode))该位用于当 ADDR 或 BTF 标志被置位,在从模式下禁止时钟延长,直到它被软件复位。 • 0:允许时钟延长 • 1:禁止时钟延长                                         |
| 位 6  | ENGC: 广播呼叫使能(General call enable)  • 0: 禁止广播呼叫,以非应答响应地址 00h  • 1: 允许广播呼叫,以应答响应地址 00h                                                                                   |
| 位 5  | ENPEC: PEC 使能(PEC enable)  • 0: 禁止 PEC 计算  • 1: 开启 PEC 计算                                                                                                              |
| 位 4  | ENARP: ARP 使能(ARP enable) • 0: 禁止 ARP                                                                                                                                  |



|     | <ul> <li>1: 使能 ARP</li> <li>如果 SMBTYPE=0,使用 SMBus 设备的默认地址</li> <li>如果 SMBTYPE=1,使用 SMBus 的主地址</li> </ul>                                                                                         |
|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 3 | SMBTYPE: SMBus 类型(SMBus type)  • 0: SMBus 设备  • 1: SMBus 主机                                                                                                                                      |
| 位 2 | Res: 保留<br>必须保持复位值。                                                                                                                                                                              |
| 位 1 | SMBUS: SMBus 模式(SMBus mode)  • 0: I2C 模式  • 1: SMBus 模式                                                                                                                                          |
| 位 0 | PE: I2C 模块使能(Peripheral enable)  • 0: 禁用 I2C 模块;  • 1: 启用 I2C 模块: 根据 SMBus 位的设置,相应的 I/O 口需配置为复用功能。  注意: 如果清除该位时通讯正在进行,在当前通讯结束后,I2C 模块被禁用并返回空闲 状态。由于在通讯结束后发生 PE =0,所有的位被清除。在主模式下,通讯结束之前, 绝不能清除该位。 |

注意:当STOP,START 或者 PEC 位被设置时,在这些位被清除前,软件不能写 I2Cx\_CR1。否则会在 第二次STOP,START 或 PEC 请求时出现风险。

# 20.5.2 控制寄存器 2(I2Cx\_CR2)(x=1..2)

偏移地址: 0x04 复位值: 0x0000

| 15 | 14  | 13 | 12       | 11 | 10    | 9       | 8       | 8 7     |    | 5  | 4         | 3 | 2 | 1 | 0 |  |
|----|-----|----|----------|----|-------|---------|---------|---------|----|----|-----------|---|---|---|---|--|
|    | Res |    | Res LAST |    | DMAEN | ITBUFEN | ITEVTEN | ITERREN | Re | es | FREQ[5:0] |   |   |   |   |  |
|    |     |    | rw       | rw | rw    | rw      | rw      |         |    |    |           | r | W |   |   |  |

| 位 15:13 | Res: 保留<br>必须保持复位值。                                                                                                                 |
|---------|-------------------------------------------------------------------------------------------------------------------------------------|
| 位 12    | LAST: DMA 最后一次传输(DMA last transfer)  • 0: 下一次 DMA 的 EOT 不是最后的传输  • 1: 下一次 DMA 的 EOT 是最后的传输  注意: 该位在主接收模式使用,使得在最后一次接收数据时可以产生一个 NACK。 |
| 位 11    | DMAEN: DMA 请求使能(DMA requests enable)  • 0: 禁止 DMA 请求  • 1: 当 TxE=1 或 RxNE =1 时,允许 DMA 请求                                            |
| 位 10    | ITBUFEN:缓冲器中断使能(Buffer interrupt enable)                                                                                            |



| ו ליבוי אייינועל |                                                   |
|------------------|---------------------------------------------------|
|                  | • 0: 当 TxE=1 或 RxNE=1 时,不产生任何中断                   |
|                  | ● 1: 当 TxE=1 或 RxNE=1 时,产生事件中断(不管 DMAEN 是何种状态)    |
| 位 9              | ITEVTEN:事件中断使能(Event interrupt enable)            |
|                  | • 0: 禁止事件中断                                       |
|                  | • 1: 允许事件中断                                       |
|                  | 在下列条件下,将产生该中断:                                    |
|                  | ○ SB=1 (主模式)                                      |
|                  | ∘ ADDR=1(主/从模式)                                   |
|                  | ○ ADD10=1 (主模式)                                   |
|                  | o STOPF=1 (从模式)                                   |
|                  | o BTF=1, 但是没有 TxE 或 RxNE 事件                       |
|                  | o 如果 ITBUFEN=1,TxE 事件为 1                          |
|                  | o 如果 ITBUFEN=1,RxNE 事件为 1                         |
| 位 8              | ITERREN: 出错中断使能(Error interrupt enable)           |
|                  | • 0: 禁止出错中断                                       |
|                  | • 1: 允许出错中断                                       |
|                  | 在下列条件下,将产生该中断:                                    |
|                  | o BERR=1                                          |
|                  | o ARLO=1                                          |
|                  | o AF=1                                            |
|                  | o OVR=1                                           |
|                  | o PECERR=1                                        |
|                  | o TIMEOUT=1                                       |
|                  | o SMBAlert=1                                      |
| 位 7:6            | Res: 保留                                           |
|                  | 必须保持复位值。                                          |
| 位 5:0            | FREQ[5:0]: I2C 模块时钟频率(Peripheral clock frequency) |
|                  | 必须设置正确的输入时钟频率以产生正确的时序,允许的范围在 2~50MHz 之间:          |
|                  | • 000000: 禁用                                      |
|                  | • 000001: 禁用                                      |
|                  | • 000010: 2MHz                                    |
|                  | •                                                 |
|                  | • 110010: 50MHz                                   |
|                  |                                                   |

# 20.5.3 自身地址寄存器 1(I2Cx\_OAR1)(x=1..2)

复位偏移地址: 0x08 复位值: 0x0000

| 15      | 14  | 13 | 12 | 11 | 10 | 9 | 8     | 7 | 6 | 5 | 4     | 3  | 2 | 1 | 0      |
|---------|-----|----|----|----|----|---|-------|---|---|---|-------|----|---|---|--------|
| ADDMODE | Res |    |    |    |    |   | [9:8] |   |   | Α | DD[7: | 11 |   |   | ADD[0] |



| rw      | rw rw rw                                                                                          |
|---------|---------------------------------------------------------------------------------------------------|
| 位 15    | ADDMODE: 寻址模式(从模式)(Addressing mode(slave mode))  • 0: 7 位从地址(不响应 10 位地址)  • 1: 10 位从地址(不响应 7 位地址) |
| 位 14:10 | Res: 保留<br>必须保持复位值。                                                                               |
| 位 9:8   | ADD[9:8]:接口地址(Interface address)  • 7 位地址模式时不用关心  • 10 位地址模式时为地址的 9~8 位                           |
| 位 7:1   | ADD[7:1]:接口地址(Interface address)<br>地址的 <b>7~1</b> 位。                                             |
| 位 0     | ADD[0]:接口地址(Interface address)  • 7 位地址模式时不用关心  • 10 位地址模式时为地址第 0 位                               |

# 20.5.4 自身地址寄存器 2(I2Cx\_OAR2)(x=1..2)

偏移地址: 0x0C 复位值: 0x0000

| 15 | 14  | 13 | 12 | 11 | 10 | q | Q | 7 | 6 | 5         | 4  | 2      | 2 | 1 | 0 |  |
|----|-----|----|----|----|----|---|---|---|---|-----------|----|--------|---|---|---|--|
| 13 | 17  | 13 |    |    |    |   |   |   |   |           |    | ENDUAL |   |   |   |  |
|    | Res |    |    |    |    |   |   |   |   | ADD2[7:1] |    |        |   |   |   |  |
|    | rw  |    |    |    |    |   |   |   |   |           | rw |        |   |   |   |  |

| 位 15:8 | Res: 保留<br>必须保持复位值。                                                                                          |
|--------|--------------------------------------------------------------------------------------------------------------|
| 位 7:1  | ADD2[7:1]:接口地址(Interface address)<br>在双地址模式下地址的 <b>7~1</b> 位。                                                |
| 位 0    | ENDUAL: 双地址模式使能位(Dual addressing mode enable)  • 0: 在 7 位地址模式下,只有 OAR1 被识别  • 1: 在 7 位地址模式下,OAR1 和 OAR2 都被识别 |

# 20.5.5 数据寄存器(I2Cx\_DR)(x=1..2)

偏移地址: 0x10 复位值: 0x0000

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

| 位 15:8 | Res: 保留  |
|--------|----------|
|        | 必须保持复位值。 |



#### 位 7:0

DR[7:0]: 8 位数据寄存器 (8-bit data register)

用于存放接收到的数据或放置用于发送到总线的数据

- 发送器模式: 当写一个字节至 DR 寄存器时,自动启动数据传输。一旦传输开始 (TxE=1),如果能及时把下一个需传输的数据写入 DR 寄存器,I2C 模块将保持连续 的数据流
- 接收器模式:接收到的字节被拷贝到 DR 寄存器 (RxNE=1)。在接收到下一个字节 (RxNE=1)之前读出数据寄存器,即可实现连续的数据传送

#### 注意:

- 在从模式下, 地址不会被拷贝进数据寄存器 DR;
- 硬件不管理写冲突(如果 TxE=0, 仍能写入数据寄存器);
- 如果在处理 ACK 脉冲时发生 ARLO 事件,接收到的字节不会被拷贝到数据寄存器 里,因此不能读到它。

## 20.5.6 状态寄存器 1 (I2Cx SR1) (x=1..2)

偏移地址: 0x14 复位值: 0x0000

| 15     | 14     | 13 | 12    | 11   | 10   | 9    | 8    | 7  | 6   | 5  | 4    | 3    | 2  | 1   | 0 |
|--------|--------|----|-------|------|------|------|------|----|-----|----|------|------|----|-----|---|
| SMBALE | TIMEOU | Re | PECER | OVR  | AF   | ARLO | BERR | Tx | RxN | Re | STOP | ADD1 | BT | ADD | S |
| RT     | T      | S  | R     |      |      |      |      | Ε  | E   | S  | F    | 0    | F  | R   | В |
| rc_w0  | rc_w0  |    | rc_w0 | rc_w | rc_w | rc_w | rc_w | r  | r   |    | r    | r    | r  | r   | r |
|        |        |    |       | 0    | 0    | 0    | 0    |    |     |    |      |      |    |     |   |

#### 位 15

SMBALERT: SMBus 提醒 (SMBus alert)

- 在 SMBus 主机模式下:
  - o 0: 无 SMBus 提醒
  - o 1: 在引脚上产生 SMBAlert 提醒事件
- 在 SMBus 从机模式下:
  - o 0: 没有 SMBAlert 响应地址头序列
  - o 1: 收到 SMBAlert 响应地址头序列至 SMBAlert 变低

该位由软件写'0'清除,或在 PE=0 时由硬件清除。

#### 位 14

TIMEOUT: 超时或 Tlow 错误(Timeout or Tlow error)

- 0: 无超时错误
- 1: SCL 处于低已达到25ms (超时)

或主机低电平累积时钟扩展时间超过10ms(Tlow:mext);

或从设备低电平累积时钟扩展时间超过 25ms (Tlow:sext)。

当在从模式下设置该位:从设备复位通讯,硬件释放总线。

当在主模式下设置该位:硬件发出停止条件。

该位由软件写'0'清除,或在 PE=0 时由硬件清除

注意:这个功能仅在SMBus模式下运用。

位 13

Res: 保留

必须保持复位值。



| 位 12 | PECERR: 在接收时发生 PEC 错误(PEC Error in reception)  • 0: 无 PEC 错误: 接收到 PEC 后接收器返回 ACK(如果 ACK=1)  • 1: 有 PEC 错误: 接收到 PEC 后接收器返回 NACK(不管 ACK 是什么值)该位由软件写'0'清除,或在 PE=0 时由硬件清除。                                                                                                                      |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 11 | OVR: 过载/欠载 (Overrun/Underrun)  • 0: 无过载/欠载  • 1: 出现过载/欠载  • 当 NOSTRETCH=1 时,在从模式下该位被硬件置位,同时:  • 在接收模式中当收到一个新的字节时(包括 ACK 应答脉冲),数据寄存器里的内容还未被读出,则新接收的字节将丢失  • 在发送模式中当要发送一个新的字节时,却没有新的数据写入数据寄存器,同样的字节将被发送两次 该位由软件写'0'清除,或在 PE=0 时由硬件清除。  注意: 如果数据寄存器的写操作发生时间非常接近 SCL 的上升沿,发送的数据是不确定的,并发生保持时间错误。 |
| 位 10 | AF: 应答失败(Acknowledge failure)  • 0: 没有应答失败  • 1: 应答失败  当没有返回应答时,硬件将置该位为'1'。 该位由软件写'0'清除,或在 PE=0 时由硬件清除。                                                                                                                                                                                     |
| 位 9  | ARLO: 仲裁丢失(主模式)(Arbitration lost (master mode))  • 0: 没有检测到仲裁丢失  • 1: 检测到仲裁丢失  当接口失去对总线的控制给另一个主机时,硬件将将置该位为'1'。 该位由软件写'0'清除,或在 PE=0 时由硬件清除。在 ARLO 事件之后,I2C 接口自动切换回从模式(M/SL=0)  注意: 在SMBUS 模式下,在从模式下对数据的仲裁仅仅发生在数据阶段,或应答传输区间(不包括地址的应答)。                                                        |
| 位 8  | BERR: 总线出错(Bus error)  • 0: 无起始或停止条件出错  • 1: 起始或停止条件出错  当接口检测到错误的起始或停止条件,硬件将该位置'1' 该位由软件写'0'清除,或在 PE=0 时由硬件清除。                                                                                                                                                                              |
| 位 7  | TxE:数据寄存器为空(发送时)(Data register empty (transmitters))  • 0:数据寄存器非空  • 1:数据寄存器。 在发送数据时,数据寄存器为空时该位被置'1',在发送地址阶段不设置该位。 软件写数据到 DR 寄存器可清除该位;或在发生一个起始或停止条件后,或当 PE=0 时                                                                                                                              |



由硬件自动清除。 如果收到一个 NACK,或下一个要发送的字节是 PEC (PEC=1),该位不被置位。 注意: 在写入第1个要发送的数据后,或设置了BTF时写入数据,都不能清除TxE 位,这是因为数据寄存器仍然为空。 位 6 RxNE: 数据寄存器非空(接收时)(Data register not empty(receivers)) • 0: 数据寄存器为空; • 1: 数据寄存器非空。 在接收时,当数据寄存器不为空,该位被置'1'。在接收地址阶段,该位不被置位。软 件对数据寄存器的读写操作清除该位,或当 PE=0 时由硬件清除。 在发生 ARLO 事件时, RxNE 不被置位。 注意: 当设置了BTF 时,读取数据不能清除 RxNE 位,因为数据寄存器仍然为满。 位 5 Res: 保留 必须保持复位值。 位 4 STOPF: 停止条件检测位(从模式)(Stop detection (slave mode)) • 0: 没有检测到停止条件; 1: 检测到停止条件。 在一个应答之后(如果 ACK=1),当从设备在总线上检测到停止条件时,硬件将该位 置'1'。 软件读取 SR1 寄存器后,对 CR1 寄存器的写操作将清除该位,或当 PE=0 时,硬件清除 该位。 注意: 在收到 NACK 后, STOPF 位不被置位。推荐在 STOPF 被设置后, 执行完整清除 序列(READ SR1, 然后 WRITE CR1) 位.3 ADD10: 10 位头序列已发送(主模式)(10-bit header sent (Master mode)) • 0: 没有 ADD10 事件发生; • 1: 主设备已经将第一个地址字节发送出去。 在 10 位地址模式下, 当主设备已经将第一个字节发送出去时, 硬件将该位置'1'。 软件读取 SR1 寄存器后,对 CR1 寄存器的写操作将清除该位,或当 PE=0 时,硬件清除 该位。 注意:收到一个NACK后,ADD10位不被置位。 位 2 BTF: 字节发送结束(Byte transfer finished) • 0: 字节发送未完成 • 1: 字节发送结束 当 NOSTRETCH=0 时,在下列情况下硬件将该位置'1': • 在接收时, 当收到一个新字节(包括 ACK 脉冲)且数据寄存器还未被读取 (RxNE=1) • 在发送时, 当一个新数据将被发送且数据寄存器还未被写入新的数据(TxE=1) 在软件读取 SR1 寄存器后,对数据寄存器的读或写操作将清除该位;或在传输中发送 一个起始或停止条件后,或当 PE=0 时,由硬件清除该位 注意:在收到一个NACK 后,BTF 位不会被置位。如果下一个要传输的字节是PEC



| ו ליבוי אמיי שעני |                                                                                                |
|-------------------|------------------------------------------------------------------------------------------------|
|                   | (I2Cx_SR2 寄存器中TRA 为1',同时I2Cx_CR1 寄存器中PEC 为1'),BTF 位不会被置位。                                      |
| 位 1               | ADDR: 地址已被发送(主模式)/地址匹配(从模式)(Address sent(master mode)<br>/matched(slave mode))                 |
|                   | 在软件读取 SR1 寄存器后,对 SR2 寄存器的读操作将清除该位,或当 PE=0 时,由硬件清除该位。                                           |
|                   | • 地址匹配(从模式)                                                                                    |
|                   | 。 0: 地址不匹配或没有收到地址                                                                              |
|                   | o 1: 收到的地址匹配                                                                                   |
|                   | 当收到的从地址与 OAR 寄存器中的内容相匹配、或发生广播呼叫、或 SMBus 设备默认地址。或 SMBus 主机识别出 SMBus 提醒时,硬件就将该位置'1'(当对应的设置被使能时)。 |
|                   | • 地址已被发送(主模式)                                                                                  |
|                   | o 0: 地址发送没有结束                                                                                  |
|                   | o 1: 地址发送结束                                                                                    |
|                   | 10 位地址模式时,当收到地址的第二个字节的 ACK 后该位被置'1'。7 位地址模式时,当收到地址的 ACK 后该位被置'1'。                              |
|                   | 注意: 在收到 NACK 后,ADDR 位不会被置位。                                                                    |
| 位 0               | SB: 起始位(主模式)(Start bit(Master mode))                                                           |
|                   | • 0: 未发送起始条件                                                                                   |
|                   | • 1: 起始条件已发送                                                                                   |
|                   | 当发送出起始条件时该位被置'1'。                                                                              |
|                   | 软件读取 SR1 寄存器后,写数据寄存器的操作将清除该位,或当 PE=0 时,硬件清除该位。                                                 |
|                   | 1.7.0                                                                                          |

# 20.5.7 状态寄存器 2(I2Cx\_SR2)(x=1..2)

偏移地址: 0x18 复位值: 0x0000

| 15 | 14 | 13 | 12    | 11  | 10 | 9 | 8 | 7     | 6       | 5       | 4       | 3   | 2   | 1    | 0   |
|----|----|----|-------|-----|----|---|---|-------|---------|---------|---------|-----|-----|------|-----|
|    | •  |    | PEC[7 | :0] |    |   | • | DUALF | SMBHOST | SMB     | GENCALL | Res | TRA | BUSY | MSL |
|    |    |    |       |     |    |   |   |       |         | DEFAULT |         |     |     |      |     |
|    |    |    | r     |     |    |   |   | r     | r       | r       | r       |     | r   | r    | r   |

| 位 15:8 | PEC[7:0]: 数据包出错检测(Packet error checking register)<br>当 ENPEC=1 时,PEC[7:0]存放内部的 PEC 的值。                                              |
|--------|-------------------------------------------------------------------------------------------------------------------------------------|
| 位 7    | DUALF: 双标志(从模式)(Dual flag (Slave mode))  • 0:接收到的地址与 OAR1 内的内容相匹配  • 1:接收到的地址与 OAR2 内的内容相匹配  在产生一个停止条件或一个重复的起始条件时,或 PE=0 时,硬件将该位清除。 |
| 位 6    | SMBHOST: SMBus 主机头系列(从模式)(SMBus host header(Slave mode))                                                                            |



|     | **                                                                                                                                                                       |
|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     | • 0:未收到 SMBus 主机的地址         • 1:当 SMBTYPE=1 且 ENARP=1 时,收到 SMBus 主机地址 在产生一个停止条件或一个重复的起始条件时,或 PE=0 时,硬件将该位清除。                                                             |
| 位 5 | SMBDEFAULT: SMBus设备默认地址 从模式)(SMBus device default address(Slave mode))  • 0: 未收到 SMBus 设备的默认地址  • 1: 当 ENARP=1 时,收到 SMBus 设备的默认地址 在产生一个停止条件或一个重复的起始条件时,或 PE=0 时,硬件将该位清除。 |
| 位 4 | GENCALL:广播呼叫地址(从模式)(General call address(Slave mode))  • 0:未收到广播呼叫地址  • 1: 当 ENGC=1 时,收到广播呼叫的地址  在产生一个停止条件或一个重复的起始条件时,或 PE=0 时,硬件将该位清除。                                  |
| 位 3 | Res: 保留<br>必须保持复位值。                                                                                                                                                      |
| 位 2 | TRA: 发送/接收(Transmitter/receiver)  • 0: 接收到数据  • 1: 数据已发送 在整个地址传输阶段的结尾,该位根据地址字节的 R/W 位来设定。 在检测到停止条件(STOPF=1)、重复的起始条件或总线仲裁丢失(ARLO=1)后,或当 PE=0 时,硬件将其清除。                    |
| 位 1 | BUSY: 总线忙(Bus busy)  • 0: 在总线上无数据通讯;  • 1: 在总线上正在进行数据通讯。 在检测到 SDA 或 SCI 为低电平时,硬件将该位置'1'; 当检测到一个停止条件时,硬件将该位清除。 该位指示当前正在进行的总线通讯,当接口被禁用(PE=0)时该信息仍然被更新。                     |
| 位 0 | MSL: 主从模式 (Master/slave)  • 0: 从模式;  • 1: 主模式。  当接口处于主模式 (SB=1) 时,硬件将该位置位;  当总线上检测到一个停止条件、仲裁丢失 (ARLO=1 时)、或当 PE=0 时,硬件清除该位。                                              |

# 20.5.8 时钟控制寄存器(I2Cx\_CCR)(x=1..2)

偏移地址: 0x1C 复位值: 0x0000

注意:



要求 FPCLK1 至少应当是 2MHz 去实现 SM 模式 I2C 时钟,要求 FPCLK1 至少应当是 4MHz 去实现 FM 模式 I2C 时钟,这样可以正确地产生 400KHz 的快速时钟;要求 FPCLK1 应当是 10MHz 的整数倍,这样可以正确地产生最大的 400KHz 的 I2C FM 时钟。

CCR 寄存器只有在关闭 I2C 时(PE=0)才能设置。

| 15        | 14        |                                              | 13                                                                                                                                             | 12                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 11                                                                                                                               | 10                                                                                                                                        | 9                                                                                              | 8                                                                                                   | 7      | 6                                   | 5                                     | 4     | 3             | 2           | 1 | 0 |
|-----------|-----------|----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|--------|-------------------------------------|---------------------------------------|-------|---------------|-------------|---|---|
| F/S<br>rw | DUT<br>rw | r                                            | R                                                                                                                                              | es                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                  |                                                                                                                                           |                                                                                                |                                                                                                     |        | CCR[11<br>rw                        | .:0]                                  |       |               |             |   |   |
| 位 15      |           | • (                                          | ): 标准                                                                                                                                          | 上模式选<br>模式(<br>模式(                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Sm)的                                                                                                                             | J 12C                                                                                                                                     | er mod                                                                                         | le sele                                                                                             | ction  | )                                   |                                       |       |               |             |   |   |
| 位 14      |           | • (                                          | <b>)</b> : 快速                                                                                                                                  | 速模式 模式下                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | : T <sub>low</sub> /T                                                                                                            | Thigh=2                                                                                                                                   |                                                                                                |                                                                                                     | ty cyc | cle)                                |                                       |       |               |             |   |   |
| 位 13:1    | 2         |                                              | : 保留<br>须保持3                                                                                                                                   | 复位值。                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                  |                                                                                                                                           |                                                                                                |                                                                                                     |        |                                     |                                       |       |               |             |   |   |
| 位 11:0    |           | Fass 该 · 1 · 1 · 1 · 1 · 1 · 1 · 1 · 1 · 1 · | t/Stand 分在 12 C K 在 12 C K Thigh=C Thigh=triss 2 C 有 | 快速Mard mock to the process of the p | le(Ma<br>是置主相<br>或 SMI<br>T <sub>low</sub> =C <sup>l</sup><br>下<br>(基下,产<br>T <sub>PCLK1</sub> =1:<br><i>L L L L L L L L L L</i> | ster mo<br>莫式下的<br>Bus 模式<br>CR * T <sub>PCI</sub><br>w=2 * CO<br>w=2 * CO<br>Tiow=16 *<br>E 生 100<br>25ns,贝<br>Dx04,在<br>见数据号<br>CThigh+ | de))<br>J SCL<br>T<br>CR * T<br>OkHz)<br>CCR ><br>kHz 的<br>CCR ><br>F 册中<br>T <sub>low</sub> ) | PCLK1 )  (T <sub>PCLK1</sub> )  (T <sub>PCLK1</sub> )  (DUTY  (P)  (P)  (P)  (P)  (P)  (P)  (P)  (P | 的      | 图:<br>0x28(<br>个下允许<br>数的定。<br>操声滤。 | 40 *1<br>午的最<br><sup></sup> :义;<br>义; | 25ns= | 5000<br>⅓ 0x0 | ns)。<br>01; |   |   |

# 20.5.9 TRISE 寄存器(I2Cx\_TRISE)(x=1..2)

偏移地址: 0x20

复位值: 0x0002(主模式)

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



|        | Res                                                                                                                                                                                                                                                           | TRISE[5:0]                                                                             |
|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|
|        |                                                                                                                                                                                                                                                               | rw                                                                                     |
| 位 15:6 | Res: 保留<br>必须保持复位值。                                                                                                                                                                                                                                           |                                                                                        |
| 位 5:0  | TRISE[5:0]: 在快速/标准模式下的最大上升时间Fast/Standard mode(Master mode))这些位必须设置为 I2C 总线规范里给出的最大的 SCL 例如:标准模式中最大允许 SCL 上升时间为 1000 FREQ[5:0]中的值等于 0x08 且 TPCLK1=125ns,故 TRISE ns=8+1)。滤波器的值也可以加到 TRISE[5:0]内。如果分写入 TRISE[5:0]以确保 thigh 参数。 注意:只有当 I2C 被禁用(PE=0)时,才能设置 TRISE | 上升时间,增长步幅为 1。<br>Ons。如果在 I2Cx_CR2 寄存器中<br>[5:0]中必须写入 09h(1000ns/125<br>果结果不是一个整数,则将整数部 |



## 21 通用同步异步收发器(USART)

## 21.1 USART 介绍

通用同步异步收发器(USART)提供了一种灵活的方法与使用工业标准 NRZ 异步串行数据格式的外部设备之间进行全双工数据交换。USART 利用分数波特率发生器提供宽范围的波特率选择。

它支持同步单向通信和半双工单线通信,也支持 LIN(局部互连网),智能卡协议和 IrDA(红外数据组织)SIR ENDEC 规范,以及调制解调器(CTS/RTS)操作。它还允许多处理器通信。

使用多缓冲器配置的 DMA 方式,可以实现高速数据通信。

## 21.2 USART 主要特性

- 全双工异步通信
- NRZ 标准格式(标记/空格)
- 分数波特率发生器系统
  - 。 发送和接收共用的可编程波特率,最高达 4.5Mbit/s
- 可编程数据字长度(8位或9位)
- 可配置的停止位:支持1或2个停止位
- LIN 主同步断开符发送能力以及 LIN 从断开符检测能力
  - 。 当 USART 硬件配置成 LIN 时, 生成 13 位断开符; 检测 10/11 位断开符
- 发送方为同步传输提供时钟
- IrDA SIR 编码器解码器
  - 在正常模式下支持 3/16 位的持续时间
- 智能卡模拟功能
  - 。 智能卡接口支持 ISO7816-3 标准里定义的异步智能卡协议
  - 。 智能卡用到的 0.5 和 1.5 个停止位
- 单线半双工通信
- 可配置的使用 DMA 的多缓冲器通信
  - 。 在 SRAM 里利用集中式 DMA 缓冲接收/发送字节
- 单独的发送器和接收器使能位
- 检测标志
  - 。 接收缓冲器满
  - 。 发送缓冲器空
  - 。 传输结束标志
- 校验控制
  - 。 发送校验位
  - 。 对接收数据进行校验
- 四个错误检测标志
  - 。 溢出错误
  - 。 噪音错误
  - 。 帧错误



- 。 校验错误
- 10 个带标志的中断源
  - 。 CTS 改变
  - 。 LIN 断开符检测
  - 。 发送数据寄存器空
  - 。 发送完成
  - 。 接收数据寄存器满
  - 。 检测到总线为空闲
  - 。 溢出错误
  - 。 帧错误
  - 。噪音错误
  - 。 校验错误
- 多处理器通信:如果地址不匹配,则进入静默模式
- 从静默模式中唤醒(通过空闲总线检测或地址标志检测)
- 两种唤醒接收器的方式:
  - 。 地址位(MSB, 第9位)
  - 。 总线空闲

## 21.3 USART 功能概述

接口通过三个引脚与其他设备连接在一起(详见图 21-1 )。任何 USART 双向通信至少需要两个管脚:接收数据输入(RX)和发送数据输出(TX):

- RX: 接收数据串行输入。通过过采样技术来区别数据和噪音,从而恢复数据。
- TX: 发送数据输出。当发送器被禁止时,输出引脚恢复到它的 I/O 端口配置。当发送器被激活,但无待发送数据时,TX 引脚处于高电平。在单线和智能卡模式里,此 I/O 口被同时用于数据的发送和接收(在 USART 层次,数据在 SW\_RX 上收到)。

串行数据经由这些管脚在常规 USART 模式下被发送和接受, 其框架组成如下:

- 一个在发送或接收前应处于空闲状态的总线
- 一个起始位
- 一个数据字(8或9位),最低有效位在前
- 0.5, 1, 1.5, 2 个的停止位, 由此表明数据帧的结束
- 分数波特率发生器(12 位整数和 4 位小数)
- 一个状态寄存器(USARTx SR)
- 数据寄存器(USARTx DR)
- 一个波特率寄存器(USARTx BRR)(12 位的整数和 4 位小数)
- 一个智能卡模式下的保护时间寄存器(USARTx GTPR)

关于以上寄存器中每个位的具体定义,请参考寄存器描述章节:"21.6 USART 寄存器描述"。

在同步模式中需要下列引脚:

• CK: 发送器时钟输出。此引脚输出用于 SPI 主模式下同步传输的时钟,(在 Start 位和 Stop 位上没有时钟脉冲,软件可选地实现在最后一个数据位送出一个时钟脉冲)。数据可以在 RX 上同步被接收。这可以用来控制带有移位寄存器的外部设备(例如 LCD 驱动器)。时钟相位和极性都是软件可编程的。在智能卡模式里,CK 可以为智能卡提供时钟。



在硬件流控模式中需要下列引脚:

- CTS: 清除发送, 若是高电平, 在当前数据传输结束时阻断下一次的数据发送。
- RTS: 发送请求,若是低电平,表明 USART 准备好接收数据。



图 21-1 USART 框图

## 21.3.1 USART 特性描述

字长可以通过编程 USARTx\_CR1 寄存器中的 M 位,选择成 8 或 9 位(详见图 21-2)。TX 脚在起始位期间处于低电平,在停止位期间处于高电平。

空闲符号被视为完全由'1'组成的一个完整的数据帧,后面跟着包含了数据的下一帧的开始位('1'的位数也包括了停止位的位数)。

断开符号被视为在一个帧周期内全部收到'0'(包括停止位期间,也是'0')。在断开帧结束时,发送器再插入1或2个停止位('1')来应答起始位。

发送和接收由一共用的波特率发生器驱动,当发送器和接收器的使能位分别置位时,分别为其产生时钟。随后将有每个功能块的详细说明。





图 21-2 字长设置

## 21.3.2 发送器

发送器根据 M 位的状态发送 8 位或 9 位的数据字。当发送使能位(TE)被设置时,发送移位寄存器中的数据在 TX 脚上输出,相应的时钟脉冲在 CK 脚上输出。

#### 21.3.2.1 字符发送

在 USART 发送期间,在 TX 引脚上首先移出数据的最低有效位。在此模式里,USARTx\_DR 寄存器包含了一个内部总线和发送移位寄存器之间的缓冲器(详见图 21-1)。

每个字符之前都有一个低电平的起始位;之后跟着的停止位,其数目可配置。

USART 支持多种停止位的配置: 0.5、1、1.5 和 2 个停止位。

#### 注意:

- 1. 在数据传输期间不能复位 TE 位,否则将破坏 TX 脚上的数据,因为波特率计数器停止计数。正在传输的当前数据将丢失。
- 2. TE 位被激活后将发送一个空闲帧。

### 21.3.2.2 可配置的停止位

随每个字符发送的停止位的位数可以通过控制寄存器 2 的位 13、12 进行编程。

- 1 个停止位:停止位位数的默认值。
- 2 个停止位:可用于常规 USART 模式、单线模式以及调制解调器模式。
- 0.5 个停止位: 在智能卡模式下接收数据时使用。
- 1.5 个停止位:在智能卡模式下发送和接收数据时使用。

空闲帧包括了停止位。

断开帧是 10 位低电平, 后跟停止位(当 m=0 时); 或者 11 位低电平, 后跟停止位(m=1 时)。不



可能传输更长的断开帧(长度大于10或者11位)。



图 21-3 配置停止位

#### 配置步骤:

- 1. 通过在 USARTx\_CR1 寄存器上置 UE 位为'1'来激活 USART。
- 2. 编程 USARTx CR1 的 M 位来定义字长。
- 3. 在 USARTx CR2 中编程停止位的位数。
- 4. 如果采用多缓冲器通信,配置 USARTx\_CR3 中的 DMA 使能位(DMAT)。按多缓冲器通信中的描述配置 DMA 寄存器。
- 5. 利用 USARTx\_BRR 寄存器选择要求的波特率。
- 6. 设置 USARTx CR1 中的 TE 位,发送一个空闲帧作为第一次数据发送。
- 7. 把要发送的数据写进 USARTx\_DR 寄存器 (此动作清除 TXE 位)。在只有一个缓冲器的情况下,对每个待发送的数据重复该步骤。
- 8. 在 USARTx\_DR 寄存器中写入最后一个数据字后,要等待 TC=1,它表示最后一个数据帧的传输结束。当需要关闭 USART 或需要进入停机模式之前,需要确认传输结束,避免破坏最后一次传输。

#### 21.3.2.3 单字节通信

清零 TXE 位总是通过对数据寄存器的写操作来完成的。TXE 位由硬件来设置,它表明:

- 数据已经从TDR 移送到移位寄存器,数据发送已经开始。
- TDR 寄存器被清空。
- 下一个数据可以被写进 USARTx\_DR 寄存器而不会覆盖先前的数据。

如果 TXEIE 位被设置,此标志将产生一个中断。

如果此时 USART 正在发送数据,对 USARTx DR 寄存器的写操作把数据存进 TDR 寄存器,并在当前



传输结束时把该数据复制进移位寄存器。

如果此时 USART 没有在发送数据,处于空闲状态,对 USARTx\_DR 寄存器的写操作直接把数据放进移位寄存器,数据传输开始,TXE 位立即被置起。

当一帧发送完成时(停止位发送后)并且设置了 TXE 位,TC 位被置起,如果 USARTx\_CR1 寄存器中的 TCIE 位被置起时,则会产生中断。在 USARTx\_DR 寄存器中写入了最后一个数据字后,在关闭 USART 模块之前或设置微控制器进入低功耗模式(详见下图)之前,必须先等待 TC=1。

使用下列软件过程清除 TC 位:

- 1. 读一次 USARTx SR 寄存器;
- 2. 写一次 USARTx DR 寄存器。

注意: TC 位也可以通过软件对它写'0'来清除。此清零方式只推荐在多缓冲器通信模式下使用。



图 21-4 发送时 TC/TXE 的变化情况

#### 21.3.2.4 断开符号

设置 SBK 可发送一个断开符号。断开帧长度取决 M 位(见图 21-2)。如果设置 SBK=1,在完成当前数据发送后,将在 TX 线上发送一个断开符号。断开字符发送完成时(在断开符号的停止位时) SBK 被硬件复位。USART 在最后一个断开帧的结束处插入一逻辑'1',以保证能识别下一帧的起始位。

注意:如果在开始发送断开帧之前,软件又复位了SBK 位,断开符号将不被发送。如果要发送两个连续的断开帧,SBK 位应该在前一个断开符号的停止位之后置位。

#### 21.3.2.5 空闲符号

置位 TE 将使得 USART 在第一个数据帧前发送一空闲帧。

### 21.3.3 接收器

USART 可以根据 USARTx CR1 的 M 位接收 8 位或 9 位的数据字。

#### 21.3.3.1 起始位侦测

在 USART 中,如果辨认出一个特殊的采样序列,那么就认为侦测到一个起始位。该序列为: 1110X0X0X00000





图 21-5 起始位侦测

#### 注意:

- 如果该序列不完整,那么接收端将退出起始位侦测并回到空闲状态(不设置标志位)等待下降 沿。
- 如果 3 个采样点都为'0'(在第 3、5、7 位的第一次采样,和在第 8、9、10 的第二次采样都 为'0'),则确认收到起始位,这时设置 RXNE 标志位,如果 RXNEIE=1,则产生中断。
- 如果两次3个采样点上仅有2个是'0'(第3、5、7位的采样点和第8、9、10位的采样点),那
   么起始位仍然是有效的,但是会设置 NE 噪声标志位。如果不能满足这个条件,则中止起始位的侦测过程,接收器会回到空闲状态(不设置标志位)。
- 如果有一次3个采样点上仅有2个是'0'(第3、5、7位的采样点或第8、9、10位的采样点), 那么起始位仍然是有效的,但是会设置 NE 噪声标志位。

#### 21.3.3.2 字符接收

在 USART 接收期间,数据的最低有效位首先从 RX 脚移进。在此模式里,USARTx\_DR 寄存器包含的缓冲器位于内部总线和接收移位寄存器之间。

#### 配置步骤:

- 1. 将 USARTx\_CR1 寄存器的 UE 置 1 来激活 USART。
- 2. 编程 USARTx\_CR1 的 M 位定义字长。
- 3. 在 USARTx\_CR2 中编写停止位的个数。
- 4. 如果需多缓冲器通信,选择 USARTx\_CR3 中的 DMA 使能位(DMAR)。按多缓冲器通信所要求的配置 DMA 寄存器。
- 5. 利用波特率寄存器 USARTx BRR 选择希望的波特率。
- 6. 设置 USARTx CR1 的 RE 位。激活接收器,使它开始寻找起始位。

当一个字符被接收到时:

• RXNE 位被置位。它表明移位寄存器的内容被转移到 RDR。换句话说,数据已经被接收并且可



以被读出(包括与之有关的错误标志)。

- 如果 RXNEIE 位被设置,产生中断。
- 在接收期间如果检测到帧错误,噪音或溢出错误,错误标志将被置起,
- 在多缓冲器通信时,RXNE 在每个字节接收后被置起,并由 DMA 对数据寄存器的读操作而清零。
- 在单缓冲器模式里,由软件读 USARTx\_DR 寄存器完成对 RXNE 位清除。RXNE 标志也可以通过 对它写 0 来清除。RXNE 位必须在下一字符接收结束前被清零,以避免溢出错误。

注意: 在接收数据时, RE 位不应该被复位。如果 RE 位在接收时被清零, 当前字节的接收被丢失。

#### 21.3.3.3 断开符号

当接收到一个断开帧时, USART 像处理帧错误一样处理它。

#### 21.3.3.4 空闲符号

当一空闲帧被检测到时,其处理步骤和接收到普通数据帧一样,但如果 IDLEIE 位被设置将产生一个中断。

#### 21.3.3.5 溢出错误

如果 RXNE 还没有被复位,又接收到一个字符,则发生溢出错误。只有当 RXNE 位被清零后,数据才能从移位寄存器转移到 RDR 寄存器。RXNE 标记是接收到每个字节后被置位的。如果下一个数据已被收到或先前 DMA 请求还没被服务时,RXNE 标志仍是置起的,溢出错误产生。

当溢出错误产生时:

- ORE 位被置位。
- RDR 内容将不会丢失。读 USARTx DR 寄存器仍能得到先前的数据。
- 移位寄存器中以前的内容将被覆盖。随后接收到的数据都将丢失。
- 如果 RXNEIE 位被设置或 EIE 和 DMAR 位都被设置,中断产生。
- 顺序执行对 USARTx\_SR 和 USARTx\_DR 寄存器的读操作,可复位 ORE 位。

注意: 当 ORE 位置位时, 表明至少有1 个数据已经丢失。

#### 有两种可能性:

- 如果 RXNE=1, 上一个有效数据还在接收寄存器 RDR 上, 可以被读出。
- 如果 RXNE=0,这意味着上一个有效数据已经被读走,RDR 已经没有东西可读。当上一个有效数据在RDR 中被读取的同时又接收到新的(也就是丢失的)数据时,此种情况可能发生。在读序列期间(在USARTx\_SR 寄存器读访问和USARTx\_DR 读访问之间)接收到新的数据,此种情况也可能发生。

#### 21.3.3.6 噪音错误

使用过采样技术(同步模式除外),通过区别有效输入数据和噪音来进行数据恢复。





图 21-6 检测噪声的数据采样

表 21-1 检测噪声的数据采样

| 采样值 | NE 状态 | 接收的位 | 数据有效性 |
|-----|-------|------|-------|
| 000 | 0     | 0    | 有效    |
| 001 | 1     | 0    | 无效    |
| 010 | 1     | 0    | 无效    |
| 011 | 1     | 1    | 无效    |
| 100 | 1     | 0    | 无效    |
| 101 | 1     | 1    | 无效    |
| 110 | 1     | 1    | 无效    |
| 111 | 0     | 1    | 有效    |

当在接收帧中检测到噪音时:

- 在 RXNE 位的上升沿设置 NE 标志。
- 无效数据从移位寄存器传送到 USARTx\_DR 寄存器。
- 在单个字节通信情况下,没有中断产生。然而,如果 NE 标志位和 RXNE 标志位是同时被设置,RXNE 将产生中断。在多缓冲器通信情况下,如果已经设置了 USARTx\_CR3 寄存器中 EIE 位,将产生一个中断。

先读出 USARTx SR, 再读出 USARTx DR 寄存器, 将清除 NE 标志位。

#### 21.3.3.7 帧错误

当以下情况发生时检测到帧错误: 伴随同步失败或大量噪音, 停止位没有在预期的时间被接收识别。当帧错误被检测到时:

- FE 位被硬件置起。
- 无效数据从移位寄存器传送到 USARTX DR 寄存器。
- 在单字节通信时,没有中断产生。然而,这个位和 RXNE 位同时置起时,后者将产生中断。在 多缓冲器通信情况下,如果 USARTX CR3 寄存器中 EIE 位被置位的话,将产生中断。

顺序执行对 USARTx\_SR 和 USARTx\_DR 寄存器的读操作,可复位 FE 位。

#### 21.3.3.8 接收期间的可配置的停止位

被接收的停止位的个数可以通过控制寄存器 2 的控制位来配置,在正常模式时,可以是 1 或 2 个,



在智能卡模式里可能是 0.5 或 1.5 个。

- 1. 0.5 个停止位(智能卡模式中的接收):不对 0.5 个停止位进行采样。因此,如果选择 0.5 个停止位则不能检测帧错误和断开帧。
- 1 个停止位:对1个停止位的采样在第8,第9和第10采样点上进行。
- 3. 1.5 个停止位(智能卡模式): 当以智能卡模式发送时,器件必须检查数据是否被正确的发送出去。所以接收器功能块必须被激活(USARTx\_CR1 寄存器中的 RE=1),并且在停止位的发送期间采样数据线上的信号。如果出现校验错误,智能卡会在发送方采样 NACK 信号时,即总线上停止位对应的时间内时,拉低数据线,以此表示出现了帧错误。FE 在 1.5 个停止位结束时和RXNE 一起被置起。对 1.5 个停止位的采样是在第 16,第 17 和第 18 采样点进行的。1.5 个的停止位可以被分成 2 部分: 一个是 0.5 个时钟周期,期间不做任何事情。随后是 1 个时钟周期的停止位,在这段时间的中点处采样。详见章节: "21.3.11 智能卡"。
- 4. 2 个停止位:对 2 个停止位的采样是在第一停止位的第 8,第 9 和第 10 个采样点完成的。如果第一个停止位期间检测到一个帧错误,帧错误标志将被设置。第二个停止位不再检查帧错误。在第一个停止位结束时 RXNE 标志将被设置。

### 21.3.4 分数波特率的产生

接收器和发送器的波特率在 USARTDIV 的整数和小数寄存器中的值应设置成相同。

这里的 fcx 是给外设的时钟(PCLK1 用于 USART2/3,PCLK2 用于 USART1)。

USARTDIV 是一个无符号的定点数,这 12 位的值设置在 USARTx BRR 寄存器。

注意:在写入 USARTx\_BRR 之后,波特率计数器会被波特率寄存器的新值替换。因此,不要在通信进行中改变波特率寄存器的数值。

#### 如何从 USARTx BRR 寄存器值得到 USARTDIV

例 1:

如果DIV\_Mantissa=27,DIV\_Fraction=12(USARTx\_BRR=0x1BC),

于是:

Mantissa (USARTDIV) =27

Fraction (USARTDIV) =12/16=0.75

所以USARTDIV=27.75

例 2:

要求USARTDIV=25.62,

就有:

DIV Fraction=16\*0.62=9.92

最接近的整数是: 10=0x0A

DIV Mantissa=mantissa (25.620) =25=0x19

于是,USARTx\_BRR=0x19A

例 3:

要求USARTDIV=50.99



就有:

DIV\_Fraction=16\*0.99=15.84

最接近的整数是: 16=0x10 => DIV\_frac[3:0]溢出=> 进位必须加到小数部分

DIV\_Mantissa=mantissa(50.990 +进位)=51=0x33

于是: USARTx BRR=0x330, USARTDIV=51

表 21-2 设置波特率时的误差计算

| 波特率 |       | f <sub>PCLK</sub> =36MHz | 次 21 2 及且次 內    |       | f <sub>PCLK</sub> =72MHz |                  |       |
|-----|-------|--------------------------|-----------------|-------|--------------------------|------------------|-------|
| 序号  | Kbps  | 实际                       | 置于波特率寄存<br>器中的值 | 误差%   | 实际                       | 置于波特率 寄存<br>器中的值 | 误差%   |
| 1   | 2.4   | 2.400                    | 937.5           | 0%    | 2.4                      | 1875             | 0%    |
| 2   | 9.6   | 9.600                    | 234.375         | 0%    | 9.6                      | 468.75           | 0%    |
| 3   | 19.2  | 19.2                     | 117.1875        | 0%    | 19.2                     | 234.375          | 0%    |
| 4   | 57.6  | 57.6                     | 39.0625         | 0%    | 57.6                     | 78.125           | 0%    |
| 5   | 115.2 | 115.384                  | 19.5            | 0.15% | 115.2                    | 39.0625          | 0%    |
| 6   | 230.4 | 230.769                  | 9.75            | 0.16% | 230.769                  | 19.5             | 0.16% |
| 7   | 460.8 | 461.538                  | 4.875           | 0.16% | 461.538                  | 9.75             | 0.16% |
| 8   | 921.6 | 923.076                  | 2.4375          | 0.16% | 923.076                  | 4.875            | 0.16% |
| 9   | 2250  | 2250                     | 1               | 0%    | 2250                     | 2                | 0%    |
| 10  | 4500  | 不可能                      | 不可能             | 不可能   | 4500                     | 1                | 0%    |

#### 注意:

1.CPU 的时钟频率越低,则某一特定波特率的误差也越低。可以达到的波特率上限可以由这组数据 得到。

2.只有USART1 使用 PCLK2(最高 96MHz )。其它USART 使用 PCLK1(最高 48MHz )。

# 21.3.5 USART 接收器容忍时钟的变化

只有当整体的时钟系统地变化小于 USART 异步接收器能够容忍的范围,USART 异步接收器才能正常地工作。影响这些变化的因素有:

- DTRA: 由于发送器误差而产生的变化(包括发送器端振荡器的变化)。
- DQUANT:接收器端波特率取整所产生的误差。
- DREC: 接收器端振荡器的变化。
- DTCL:由于传输线路产生的变化(通常是由于收发器在由低变高的转换时序,与由高变低转换时序之间的不一致性所造成)。

需要满足: DTRA +DQUANT +DREC +DTCL < USART 接收器的容忍度

对于正常接收数据, USART 接收器的容忍度等于最大能容忍的变化, 它依赖于下述选择:

- 由 USARTx\_CR1 寄存器的 M 位定义的 10 或 11 位字符长度
- 是否使用分数波特率产生



#### 表 21-3 当 DIV\_Fraction=0 时, USART 接收器的容忍度

| M 位 | 认为 NF 是错误 | 不认为 NF 是错误 |
|-----|-----------|------------|
| 0   | 3.75%     | 4.375%     |
| 1   | 3.41%     | 3.97%      |

表 21-4 当 DIV\_Fraction!=0 时, USART 接收器的容忍度

| M 位 | 认为 NF 是错误 | 不认为 NF 是错误 |
|-----|-----------|------------|
| 0   | 3.33%     | 3.88%      |
| 1   | 3.03%     | 3.53%      |

注意: 在特殊的情况下,当收到的帧包含一些在 M=0 时,正好是 10 位(M=1 时是 11 位)的空闲帧,上面 2 个表格中的数据可能会有些微不同。

### 21.3.6 多处理器通信

通过 USART 可以实现多处理器通信(将几个 USART 连在一个网络里)。例如某个 USART 设备可以是主设备,它的 TX 输出和其他 USART 从设备的 RX 输入相连接;其他 USART 从设备各自的 TX 输出逻辑地连接在一起,并且和主设备的 RX 输入相连接。

在多处理器配置中,我们通常希望只有被寻址的接收者才被激活,来接收随后的数据。这样就可以减少未被寻址的接收器的参与,造成多余的 USART 服务开销。未被寻址的设备可启用其静默功能置于静默模式。在静默模式里:

- 任何接收状态位都不会被设置。
- 所有接收中断被禁止。
- USARTx\_CR1 寄存器中的 RWU 位被置 1。RWU 可以被硬件自动控制或在某个条件下由软件写入。

根据 USARTx CR1 寄存器中的 WAKE 位状态,USART 可以用二种方法进入或退出静默模式。

- 如果 WAKE 位被复位:进行空闲总线检测。
- 如果 WAKE 位被设置:进行地址标记检测。

#### 21.3.6.1 空闲总线检测(WAKE=0)

当 RWU 位被写 1 时,USART 进入静默模式。当检测到一空闲帧时,它被唤醒。随后 RWU 位被硬件清零,但是 USARTx\_SR 寄存器中的 IDLE 位并不置位。RWU 还可以被软件写 0。下图给出利用空闲总线检测来唤醒和进入静默模式的一个例子:



图 21-7 利用空闲总线检测的静默模式



#### 21.3.6.2 地址标记检测(WAKE=1)

在这个模式里,如果 MSB 是 1,该字节被认为是地址,否则被认为是数据。在一个地址字节中,目标接收器的地址被放在 4 个 LSB 中。这个 4 位地址被接收器同它自己地址做比较,接收器的地址被编程在 USARTx CR2 寄存器的 ADD。

如果接收到的字节与它的编程地址不匹配时,USART 进入静默模式。此时,硬件设置 RWU 位。接收该字节既不会设置 RXNE 标志也不会产生中断或发出 DMA 请求,因为 USART 已经在静默模式。

当接收到的字节与接收器内编程地址匹配时,USART 退出静默模式。然后 RWU 位被清零,随后的字节被正常接收。收到这个匹配的地址字节时将设置 RXNE 位,因为 RWU 位已被清零。

当接收缓冲器不包含数据时(USARTx\_SR 的 RXNE=0),RWU 位可以被写 0 或 1。否则,该次写操作被忽略。下图给出利用地址标记检测来唤醒和进入静默模式的例子。



图 21-8 利用地址标记检测的静默模式

### 21.3.7 校验控制

设置 USARTx\_CR1 寄存器上的 PCE 位,可以使能奇偶控制(发送时生成一个奇偶位,接收时进行奇偶校验)。根据 M 位定义的帧长度,可能的 USART 帧格式列在下表中。

| м 位 | PCE 位 | USART 帧                |
|-----|-------|------------------------|
| 0   | 0     | 起始位 8位数据 停止位           |
| 0   | 1     | 起始位  7 位数据  奇偶检验位  停止位 |
| 1   | 0     | 起始位  9 位数据  停止位        |
| 1   | 1     | 起始位  8 位数据  奇偶检验位  停止位 |

表 21-5 帧格式

注意:在用地址标记唤醒设备时,地址的匹配只考虑到数据的 MSB 位,而不用关心校验位。(MSB 是数据位中最后发出的,后面紧跟校验位或者停止位)

**偶校验**:校验位使得一帧中的 7 或 8 个 LSB 数据以及校验位中'1'的个数为偶数。

例如:数据=00110101,有4个'1',如果选择偶校验(在USARTx\_CR1中的PS=0),校验位将是'0'。

奇校验: 此校验位使得一帧中的 7 或 8 个 LSB 数据以及校验位中'1'的个数为奇数。

例如:数据=00110101,有4个'1',如果选择奇校验(在USARTx CR1中的PS=1),校验位将是'1'。

传输模式:如果 USARTx\_CR1 的 PCE 位被置位,写进数据寄存器的数据的 MSB 位被校验位替换后发送出去(如果选择偶校验偶数个'1',如果选择奇校验奇数个'1')。如果奇偶校验失败,



USARTx\_SR 寄存器中的 PE 标志被置'1',并且如果 USARTx\_CR1 寄存器的 PEIE 在被预先设置的话,中断产生。

### 21.3.8 LIN (局域互联网) 模式

LIN 模式是通过设置 USARTx\_CR2 寄存器的 LINEN 位选择。在 LIN 模式下,下列位必须保持为 0:

- USARTx CR2 寄存器的 CLKEN 位。
- USARTx\_CR3 寄存器的 STOP[1:0], SCEN, HDSEL 和 IREN。

#### 21.3.8.1 LIN 发送

章节 21.3.2 发送器所描述的同样步骤适用于 LIN 主发送,但和正常 USART 发送有以下区别:

- 清零 M 位以配置 8 位字长
- 置位 LINEN 位以进入 LIN 模式。这时,置位 SBK 将发送 13 位'0'作为断开符号。然后发一位'1',以允许对下一个开始位的检测。

#### 21.3.8.2 LIN 接收

当 LIN 模式被使能时,断开符号检测电路被激活。该检测完全独立于 USART 接收器。断开符号只要一出现就能检测到,不管是在总线空闲时还是在发送某数据帧其间。

当接收器被激活时(USARTx\_CR1 的 RE=1),电路监测 RX 上的起始信号。监测起始位的方法同检测断开符号或数据是一样的。当起始位被检测到后,电路对每个接下来的位,在每个位的第 8,9,10个过采样时钟点上进行采样。如果10个(当USARTx\_CR2的LBDL=0)或11个(当USARTx\_CR2的LBDL=1)连续位都是'0',并且又跟着一个定界符,USARTx\_SR 的 LBD 标志被设置。如果 LBDIE 位=1,中断产生。在确认断开符号前,要检查定界符,因为它意味 RX 线已经回到高电平。

如果在第 10 或 11 个采样点之前采样到了'1',检测电路取消当前检测并重新寻找起始位。如果 LIN 模式被禁止,接收器继续如正常 USART 那样工作,不需要考虑检测断开符号。

如果 LIN 模式没有被激活(LINEN=0),接收器仍然正常工作于 USART 模式,不会进行断开检测。

如果 LIN 模式被激活(LINEN=1),只要一发生帧错误(也就是停止位检测到'0',这种情况出现在断开帧),接收器就停止,直到断开符号检测电路接收到一个'1'(这种情况发生于断开符号没有完整的发出来),或一个定界符(这种情况发生于已经检测到一个完整的断开符号)。

图 21-9 说明了断开符号检测器状态机的行为和断开符号标志的关系。图 21-10 给出了一个断开帧的例子。





图 21-9 LIN 模式下的断开检测(11 位断开长度 - 设置了 LBDL 位)



图 21-10 LIN 模式下的断开检测与帧错误的检测

# 21.3.9 USART 同步模式

通过在 USARTx\_CR2 寄存器上写 CLKEN 位为'1'选择同步模式。



在同步模式里,下列位必须保持清零状态:

- USARTx CR2 寄存器中的 LINEN 位。
- USARTx\_CR3 寄存器中的 SCEN,HDSEL 和 IREN 位。

USART 允许用户以主模式方式控制双向同步串行通信。CK 脚是 USART 发送器时钟的输出。在起始位和停止位期间,CK 脚上没有时钟脉冲。根据 USARTx\_CR2 寄存器中 LBCL 位的状态,决定 在最后一个有效数据位期间产生或不产生时钟脉冲。USARTx\_CR2 寄存器的 CPOL 位允许用户选择时钟极性,USARTx CR2 寄存器上的 CPHA 位允许用户选择外部时钟的相位(见图 21-11、图 21-12 和图 21-13)。

在总线空闲期间,实际数据到来之前以及发送断开符号的时候,外部 CK 时钟不被激活。

同步模式时,USART 发送器和异步模式里工作一模一样。但是因为 CK 是与 TX 同步的(根据 CPOL和 CPHA),所以 TX 上的数据是随 CK 同步发出的。

同步模式的 USART 接收器工作方式与异步模式不同。如果 RE=1,数据在 CK 上采样(根据 CPOL 和 CPHA 决定在上升沿还是下降沿),不需要任何的过采样。但必须考虑建立时间和持续时间(取决于波特率,1/16位时间)。

#### 注意:

- 1. CK 脚同 TX 脚一起联合工作。因而,只有在使能了发送器(TE=1),并且发送数据时(写入数据至 USARTx\_DR 寄存器)才提供时钟。这意味着在没有发送数据时是不可能接收一个同步数据的。
- 2. 当使能了发送器或接收器时,LBCL,CPOL和CPHA位不能被改变。
- 3. 建议在同一条指令中设置 TE 和 RE,以减少接收器的建立时间和保持时间。
- 4. USART 只支持主模式:它不能用来自其他设备的输入时钟接收或发送数据(CK永远是输出)。





图 21-11 USART 同步传输的例子



图 21-12 USART 数据时钟时序示例(M=0)



图 21-13 USART 数据时钟时序示例(M=1)





图 21-14 RX 数据采样/保持时间

说明: 在智能卡模式下 CK 的功能不同, 有关细节请参考智能卡模式部分。

### 21.3.10 单线半双工通信

单线半双方模式通过设置 USARTx\_CR3 寄存器的 HDSEL 位选择。在这个模式里,下面的位必须保持清零状态:

- USARTX CR2 寄存器的 LINEN 和 CLKEN 位
- USARTX CR3 寄存器的 SCEN 和 IREN 位

USART 可以配置成遵循单线半双工协议。在单线半双工模式下,TX 和 RX 引脚在芯片内部互连。使用控制位"HALF DUPLEX SEL"(USARTX CR3 中的 HDSEL 位)选择半双工和全双工通信。

当 HDSEL 为'1'时:

- RX 不再被使用。
- 当没有数据传输时,TX 总是被释放。因此,它在空闲状态的或接收状态时表现为一个标准I/O口。这就意味该I/O在不被USART驱动时,必须配置成悬空输入(或开漏的输出高)。

除此以外,通信与正常 USART 模式类似。由软件来管理线上的冲突(例如通过使用一个中央仲裁器)。特别的是,发送从不会被硬件所阻碍。当 TE 位被设置时,只要数据一写到数据寄存器上,发送就继续。

# 21.3.11 智能卡

设置 USARTx CR3 寄存器的 SCEN 位选择智能卡模式。在智能卡模式下,下列位必须保持清零:

- USARTX CR2 寄存器的 LINEN 位。
- USARTx\_CR3 寄存器的 HDSEL 位和 IREN 位。

此外, CLKEN 位可以被设置, 以提供时钟给智能卡。

该接口符合 ISO7816-3 标准, 支持智能卡异步协议。USART 应该被设置为:

- 8 位数据位加校验位: 此时 USARTx CR1 寄存器中 M=1、PCE=1。
- 发送和接收时为 1.5 个停止位: 即 USARTx CR2 寄存器的 STOP=11。

注意: 也可以在接收时选择 0.5 个停止位,但为了避免在 2 种配置间转换,建议在发送和接收时使用 1.5 个停止位。

下图给出的例子说明了数据线上,在有校验错误和没校验错误两种情况下的信号。





图 21-15 ISO 7816-3 异步协议

当与智能卡相连接时,USART 的 TX 输出驱动一根智能卡也驱动的双向线。所以 TX 必须配置成开漏。智能卡是一个单线半双工通信协议。

- 从发送移位寄存器把数据发送出去,要被延时最小 1/2 波特时钟。在正常操作时,一个满的 发送移位寄存器将在下一个波特时钟沿开始向外移出数据。在智能卡模式里,此发送被延迟 1/2 波特时钟。
- 如果在接收一个设置为 0.5 或 1.5 个停止位的数据帧期间,检测到一奇偶校验错误,在完成接收该帧后(即停止位结束时),发送线被拉低一个波特时钟周期。这是告诉智能卡发送到 USART 的数据没有被正确地接收到。此 NACK 信号(拉低发送线一个波特时钟周期)在发送端将产生一个帧错误(发送端被配置成 1.5 个停止位)。应用程序可以根据协议处理重新发送数据。如果设置了 NACK 控制位,发生校验错误时接收器会给出一个 NACK 信号;否则就不会发送 NACK 信号。
- TC 标志的置起可以通过编程保护时间寄存器得以延时。在正常操作时,当发送移位寄存器 变空并且没有新的发送请求出现时,TC 被置起。在智能卡模式里,空的发送移位寄存器将 触发保护时间计数器开始向上计数,直到保护时间寄存器中的值。TC 在这段时间被强制拉 低。当保护时间计数器达到保护时间寄存器中的值时,TC 被置高。
- TC 标志的撤销不受智能卡模式的影响。
- 如果发送器检测到一个帧错误(收到接收器的 NACK 信号),发送器的接收功能模块不会把 NACK 当作起始位检测。根据 ISO 协议,接收到的 NACK 的持续时间可以是 1 或 2 波特时钟周 期
- 在接收器这边,如果一个校验错误被检测到,并且 NACK 被发送,接收器不会把 NACK 检测成 起始位。

#### 注意:

- 1.断开符号在智能卡模式里没有意义。一个带帧错误的00h 数据将被当成数据而不是断开符号。
- 2. 当来回切换 TE 位时,没有 IDLE 帧被发送。ISO 协议没有定义 IDLE 帧。

下图详述了 USART 是如何采样 NACK 信号的。在这个例子里,USART 正在发送数据,并且被配置成 1.5 个停止位。为了检查数据的完整性和 NACK 信号,USART 的接收功能块被激活。





图 21-16 使用 1.5 停止位检测奇偶检验错

USART 可以通过 CK 输出为智能卡提供时钟。在智能卡模式里,CK 不和通信直接关联,而是先通过一个 5 位预分频器简单地用内部的外设输入时钟来驱动智能卡的时钟。分频率在预分频寄存器 USARTx GTPR 中配置。CK 频率可以从 f<sub>CK</sub>/2 到 f<sub>CK</sub>/62,这里的 f<sub>CK</sub> 是外设输入时钟。

### 21.3.12 IrDA SIR ENDEC 功能模块

通过设置 USARTx\_CR3 寄存器的 IREN 位选择 IrDA 模式。在 IRDA 模式里,下列位必须保持清零:

- USARTX CR2 寄存器的 LINEN, STOP 和 CLKEN 位。
- USARTX CR3 寄存器的 SCEN 和 HDSEL 位。

IrDA SIR 物理层规定使用反相归零调制方案(RZI),该方案用一个红外光脉冲代表逻辑'0'(图 21-17)。SIR 发送编码器对从 USART 输出的 NRZ(非归零)比特流进行调制。输出脉冲流被传送到一个外部输出驱动器和红外 LED。USART 为 SIR ENDEC 最高只支持到 115.2Kbit/s 速率。在正常模式里,脉冲宽度规定为一个位周期的 3/16。

SIR 接收解码器对来自红外接收器的归零位比特流进行解调,并将接收到的 NRZ 串行比特流输出到 USART。在空闲状态里,解码器输入通常是高(标记状态)。发送编码器输出的极性和解码器的输入相 反。当解码器输入低时,检测到一个起始位。

- IrDA 是一个半双工通信协议。如果发送器忙(也就是 USART 正在送数据给 IrDA 编码器),IrDA 接收线上的任何数据将被 IrDA 解码器忽视。如果接收器忙(也就是 USART 正在接收从 IrDA 解码器来的解码数据),从 USART 到 IrDA 的 TX 上的数据将不会被 IrDA 编码。当接收数据时,应该避免发送,因为将被发送的数据可能被破坏。
- SIR 发送逻辑把'0'作为高脉冲发送,把'1'作为低电平发送。脉冲的宽度规定为正常模式时位周期的 3/16 (详见图 21-18)。
- SIR 接收逻辑把高电平状态解释为'1', 把低脉冲解释为'0'。
- 发送编码器输出与解码器输入有着相反的极性。当空闲时, SIR 输出处于低状态。
- SIR 解码器把 IrDA 兼容的接收信号转变成给 USART 的比特流。
- IrDA 规范要求脉冲要宽于 1.41μs。脉冲宽度是可编程的。接收器端的尖峰脉冲检测逻辑滤除宽度小于 2 个 PSC 周期的脉冲(PSC 是在 IrDA 低功耗波特率寄存器 USARTx\_GTPR 中编程的预分频值)。宽度小于 1 个 PSC 周期的脉冲一定会被滤除掉,但是那些宽度大于 1 个而小于 2 个 PSC 周期的脉冲可能被接收或滤除,那些宽度大于 2 个周期的将被视为一个有效的脉冲。当 PSC=0 时,IrDA 编码器/解码器不工作。
- 接收器可以与低功耗发送器通信。
- 在 IrDA 模式里, USARTX CR2 寄存器上的 STOP 位必须配置成 1 个停止位。



#### 21.3.12.1 IrDA 低功耗模式

#### 发送器

在低功耗模式,脉冲宽度不再持续 3/16 个位周期。取而代之,脉冲的宽度是低功耗波特率的 3 倍,它最小可以是 1.42 MHz。通常这个值是 1.8432MHz(1.42 MHz < PSC < 2.12 MHz)。一个低功耗模式可编程分频器把系统时钟进行分频以达到这个值。

#### 接收器

低功耗模式的接收类似于正常模式的接收。为了滤除尖峰干扰脉冲,USART 应该滤除宽度短于 1 个 PSC 的脉冲。只有持续时间大于 2 个周期的 IrDA 低功耗波特率时钟(USARTx\_GTPR 中的 PSC)的低电平信号才被接受为有效的信号。

#### 注意:

- 宽度小于2个大于1个PSC周期的脉冲可能会也可能不会被滤除。
- 接收器的建立时间应该由软件管理。IrDA 物理层技术规范规定了在发送和接收之间最小要有 10ms 的延时 (IrDA 是一个半双工协议)。



图 21-17 IrDA SIR ENDEC 框图



图 21-18 IrDA 数据调制(3/16)普通模式

# 21.3.13 利用 DMA 连续通信

USART 可以利用 DMA 连续通信。Rx 缓冲器和 Tx 缓冲器的 DMA 请求是分别产生的。

注意:参考"10.2.7 DMA 请求映射"以确定 USARTx 是否可用 DMA 控制器。如果不可用,应按章节 21.3.2 或章节 21.3.3 里所描述的方法使用 USART。在 USART2\_SR 寄存器里,可以清零 TXE/RXNE 标志来实现连续通信。



#### 21.3.13.1 利用 DMA 发送

使用 DMA 进行发送,可以通过设置 USARTx\_CR3 寄存器上的 DMAT 位激活。当 TXE 位被置为'1'时, DMA 就从指定的 SRAM 区传送数据到 USARTx\_DR 寄存器。为 USART 的发送分配一个 DMA 通道的步骤如下(x 表示通道号):

- 1. 在 DMA 控制寄存器上将 USARTx\_DR 寄存器地址配置成 DMA 传输的目的地址。在每个 TXE 事件后,数据将被传送到这个地址。
- 2. 在 DMA 控制寄存器上将存储器地址配置成 DMA 传输的源地址。在每个 TXE 事件后,将从此存储器区读出数据并传送到 USARTX DR 寄存器。
- 3. 在 DMA 控制寄存器中配置要传输的总的字节数。
- 4. 在 DMA 寄存器上配置通道优先级。
- 5. 根据应用程序的要求,配置在传输完成一半还是全部完成时产生 DMA 中断。
- 6. 在 DMA 寄存器上激活该通道。当传输完成 DMA 控制器指定的数据量时,DMA 控制器在该 DMA 通道的中断向量上产生一中断。

在发送模式下,当 DMA 传输完所有要发送的数据时,DMA 控制器设置 DMA\_ISR 寄存器的 TCIF 标志;监视 USARTx\_SR 寄存器的 TC 标志可以确认 USART 通信是否结束,这样可以在关闭 USART 或进入停机模式之前避免破坏最后一次传输的数据;软件需要先等待 TXE=1,再等待 TC=1。



图 21-19 利用 DMA 发送

#### 21.3.13.2 利用 DMA 接收

可以通过设置 USARTx\_CR3 寄存器的 DMAR 位激活使用 DMA 进行接收,每次接收到一个字节,DMA 控制器就把数据从 USARTx\_DR 寄存器传送到指定的 SRAM 区(参考 DMA 相关说明)。为 USART 的接收分配一个 DMA 通道的步骤如下(x 表示通道号):

- 1. 通过 DMA 控制寄存器把 USARTx\_DR 寄存器地址配置成传输的源地址。在每个 RXNE 事件 后,将从此地址读出数据并传输到存储器。
- 2. 通过 DMA 控制寄存器把存储器地址配置成传输的目的地址。在每个 RXNE 事件后,数据将从



USARTx DR 传输到此存储器区。

- 3. 在 DMA 控制寄存器中配置要传输的总的字节数。
- 4. 在 DMA 寄存器上配置通道优先级。
- 5. 根据应用程序的要求配置在传输完成一半还是全部完成时产生 DMA 中断。
- 6. 在 DMA 控制寄存器上激活该通道。

当接收完成 DMA 控制器指定的传输量时,DMA 控制器在该 DMA 通道的中断矢量上产生一中断。



图 21-20 利用 DMA 接收

#### 21.3.13.3 多缓冲器通信中的错误标志和中断产生

在多缓冲器通信的情况下,通信期间如果发生任何错误,在当前字节传输后将置起错误标志。如果中断使能位被设置,将产生中断。在单个字节接收的情况下,和 RXNE 一起被置起的帧错误、溢出错误和噪音标志,有单独的错误标志中断使能位;如果设置了此位,会在当前字节传输结束后,产生中断。

### 21.3.14 硬件流控制

利用 CTS 输入和 RTS 输出可以控制 2 个设备间的串行数据流。下图表明在这个模式里如何连接 2 个设备。



图 21-21 两个 USART 间的硬件流控制

通过将 UASRT CR3 中的 RTSE 和 CTSE 置位,可以分别独立地使能 RTS 和 CTS 流控制。



#### 21.3.14.1 RTS 流控制

如果 RTS 流控制被使能(RTSE=1),只要 USART 接收器准备好接收新的数据,RTS 就变成有效(接低电平)。当接收寄存器内有数据到达时,RTS 被释放,由此表明希望在当前帧结束时停止数据传输。下图是一个启用 RTS 流控制的通信的例子。



图 21-22 RTS 流控制

#### 21.3.14.2 CTS 流控制

如果 CTS 流控制被使能(CTSE=1),发送器在发送下一帧前检查 CTS 输入。如果 CTS 有效(被拉成低电平),则下一个数据被发送(假设那个数据是准备发送的,也就是 TXE=0),否则下一帧数据不被发出去。若 CTS 在传输期间被变成无效,当前的传输完成后停止发送。

当 CTSE=1 时,只要 CTS 输入变换状态,硬件就自动设置 CTSIF 状态位。它表明接收器是否准备好进行通信。如果设置了 USARTx\_CT3 寄存器的 CTSIE 位,则产生中断。下图是一个启用CTS 流控制通信的例子。



图 21-23 CTS 流控制

# 21.4 USART 中断请求

表 21-6 USART 中断请求

| 中断事件     | 事件标志 | 使能位    |
|----------|------|--------|
| 发送数据寄存器空 | TXE  | TXEIE  |
| CTS 标志   | СТЅ  | CTSIE  |
| 发送完成     | тс   | TCIE   |
| 接收数据就绪可读 | RXNE | RXNEIE |



| 中断事件                 | 事件标志          | 使能位     |
|----------------------|---------------|---------|
| 检测到数据溢出              | ORE           |         |
| 检测到空闲线路              | IDLE          | IDLEIE  |
| 奇偶检验错                | PE            | PEIE    |
| 断开标志                 | LBD           | LBDIE   |
| 噪声标志,多缓冲通信中的溢出错误和帧错误 | NE 或 ORE 或 FE | EIE (1) |

#### (1) 仅当使用 DMA 接收数据时, 才使用这个标志位。

USART 的各种中断事件被连接到同一个中断向量(见下图),有以下各种中断事件:

- 发送期间:发送完成、清除发送、发送数据寄存器空。
- 接收期间:空闲总线检测、溢出错误、接收数据寄存器非空、校验错误、LIN 断开符号检测、噪音标志(仅在多缓冲器通信)和帧错误(仅在多缓冲器通信)。

如果设置了对应的使能控制位,这些事件就可以产生各自的中断。



图 21-24 USART 中断映像图

# 21.5 USART 模式配置

表 21-7 USART 模式设置

| USART 模式   | USART1/2/3 |
|------------|------------|
| 异步模式       | ©          |
| 硬件流控制      | 0          |
| 多缓存通讯(DMA) | 0          |
| 多处理器通讯     | ©          |
| 同步         | 0          |



| USART 模式   | USART1/2/3 |
|------------|------------|
| 智能卡        | 0          |
| 半双工 (单线模式) | 0          |
| IrDA       | 0          |
| LIN        | 0          |

(1) ◎=支持该应用, ●=不支持该应用

## 21.6 USART 寄存器

基地址: (USART1, USART2, USART3) = (0x4001 3800, 0x4000 4400, 0x4000 4800)

空间大小: (USART1, USART2, USART3) = (0x400, 0x400, 0x400) 可以用半字(16位)或字(32位)的方式操作这些外设寄存器。

# 21.6.1 状态寄存器(USARTx\_SR)(x=1..5)

偏移地址: 0x00 复位值: 0x00C0

| 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  |  |
|----|----|----|----|----|----|-------|-------|-----|-------|-------|------|-----|----|----|----|--|
|    |    | R  | es |    |    | CTS   | LBD   | TXE | TC    | RXNE  | IDLE | ORE | NE | FE | PE |  |
|    |    |    |    |    |    | rc w0 | rc w0 | r   | rc w0 | rc w0 | r    | r   | r  | r  | r  |  |

|         | re_wo re_wo re_wo                                                                                                                                                                             |
|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 31:10 | Res: 保留<br>必须保持复位值。                                                                                                                                                                           |
| 位 9     | <ul> <li>CTS: CTS 标志(CTS flag)</li> <li>如果设置了 CTSE 位, 当 CTS 输入变化状态时,该位被硬件置高。由软件将其清零。</li> <li>如果 USARTx_CR3 中的 CTSIE 为'1',则产生中断。</li> <li>0: CTS 状态线上没有变化</li> <li>1: CTS 状态线上发生变化</li> </ul> |
| 位 8     | LBD: LIN 断开检测标志(LIN break detection flag)<br>当探测到 LIN 断开时,该位由硬件置'1',由软件清零(向该位写 0)。<br>• 0: 没有检测到 LIN 断开<br>• 1: 检测到 LIN 断开<br>注意: 若 USARTx_CR3 中的 LBDIE=1,当 LBD 为'1'时,产生中断。                   |
| 位 7     | TXE: 发送数据寄存器空(Transmit data register empty) 当 TDR 寄存器中的数据被硬件转移到移位寄存器的时候,该位被硬件置位。如果 USARTx_CR1 寄存器中的 TXEIE 为 1,则产生中断。对 USARTx_DR 的写操作,将该位清零。                                                   |



| 机灰心刀 |                                                                                                                                                                                                                                                                        |
|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | 注意: 单缓冲器传输中使用该位。                                                                                                                                                                                                                                                       |
| 位 6  | TC: 发送完成(Transmission complete)<br>当包含有数据的一帧发送完成后,并且 TXE=1 时,由硬件将该位置'1'。如果 USARTx_CR1 中<br>的 TCIE 为'1',则产生中断。由软件序列清除该位(先读 USARTx_SR,然后写入<br>USARTx_DR)。TC 位也可以通过写入'0'来清除,只有在多缓存通讯中才推荐这种清除程                                                                             |
|      | 序。                                                                                                                                                                                                                                                                     |
| 位 5  | RXNE: 读数据寄存器非空(Read data register not empty) 当 RDR 移位寄存器中的数据被转移到 USARTx_DR 寄存器中,该位被硬件置位。如果 USARTx_CR1 寄存器中的 RXNEIE 为 1,则产生中断。对 USARTx_DR 的读操作可以将该位清 零。RXNE 位也可以通过写入 0 来清除,只有在多缓存通讯中才推荐这种清除程序。                                                                          |
| 位 4  | IDLE: 监测到总线空闲(IDLE line detected) 当检测到总线空闲时,该位被硬件置位。如果 USARTx_CR1 中的 IDLEIE 为'1',则产生中断。由软件序列清除该位(先读 USARTx_SR,然后读 USARTx_DR)。  • 0: 没有检测到空闲总线  • 1: 检测到空闲总线  注意: IDLE 位不会再次被置高直到 RXNE 位被置起(即又检测到一次空闲总线)。                                                               |
| 位 3  | ORE: 过载错误(Overrun error) 当 RXNE 仍然是'1'的时候,当前被接收在移位寄存器中的数据,需要传送至 RDR 寄存器时,硬件将该位置位。如果 USARTx_CR1 中的 RXNEIE 为'1'的话,则产生中断。由软件序列将其清零(先读 USARTx_SR,然后读 USARTx_CR)。 • 0: 没有过载错误 • 1: 检测到过载错误 注意: 该位被置位时,RDR 寄存器中的值不会丢失,但是移位寄存器中的数据会被覆盖。如果设置了 EIE 位,在多缓冲器通信模式下,ORE 标志置位会产生中断的。 |
| 位 2  | NE: 噪声错误标志(Noise error flag)<br>在接收到的帧检测到噪音时,由硬件对该位置位。由软件序列对其清零(先读<br>USARTx_SR,再读 USARTx_DR)。<br>• 0: 没有检测到噪声<br>• 1: 检测到噪声<br>注意: 该位不会产生中断,因为它和 RXNE 一起出现,硬件会在设置 RXNE 标志时产生中<br>断。在多缓冲区通信模式下,如果设置了 EIE 位,则设置 NE 标志时会产生中断。                                            |
| 位 1  | FE: 帧错误(Framing error)<br>当检测到同步错位,过多的噪声或者检测到断开符,该位被硬件置位。由软件序列将其清零(先读 USARTx_SR,再读 USARTx_DR)。 • 0: 没有检测到帧错误                                                                                                                                                           |



• 1: 检测到帧错误或者 break 符

注意:

- 该位不会产生中断,因为它和RXNE 一起出现,硬件会在设置RXNE 标志时产生中断。
- 如果当前传输的数据既产生了帧错误,又产生了过载错误,硬件还是会继续该数据的 传输,并且只设置 ORE 标志位。
- 在多缓冲区通信模式下,如果设置了EIE 位,则设置FE 标志时会产生中断。

位 0 PE: 校验错误 (Parity error)

在接收模式下,如果出现奇偶校验错误,硬件对该位置位。由软件序列对其清零(依次读 USARTx\_SR 和 USARTx\_DR)。在清除 PE 位前,软件必须等待 RXNE 标志位被置'1'。如果 USARTx CR1 中的 PEIE 为'1',则产生中断。

- 0: 没有奇偶校验错误
- 1: 奇偶校验错误

### 21.6.2 数据寄存器(USARTx\_DR)(x=1..5)

偏移地址: 0x04 复位值: 不确定

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

| 位 31:9 | Res: 保留<br>必须保持复位值。                                                                   |
|--------|---------------------------------------------------------------------------------------|
| 位 8:0  | DR[8:0]: 数据值(Data value)                                                              |
|        | 包含了发送或接收的数据。由于它是由两个寄存器组成的,一个给发送用(TDR),一个给接收用(RDR),该寄存器兼具读和写的功能。                       |
|        | TDR 寄存器提供了内部总线和输出移位寄存器之间的并行接口(参见图 21-1)。RDR 寄存器提供了输入移位寄存器和内部总线之间的并行接口。                |
|        | 当使能校验位(USARTx_CR1 中 PCE 位被置位)进行发送时,写到 MSB 的值(根据数据的长度不同,MSB 是第 7 位或者第 8 位)会被后来的校验位该取代。 |
|        | 当使能校验位进行接收时,读到的 MSB 位是接收到的校验位。                                                        |

# 21.6.3 波特比率寄存器(USARTx\_BRR)(x=1..5)

偏移地址: 0x08 复位值: 0x0000

注意: 如果 TE 或 RE 被分别禁止, 波特计数器停止计数

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



| 15                 | 15   14   13   13   14   10   0   0   7   6   5   4 |  |  |  |  |  |  |  |  |  |  | 3 | 3 2 1 0  |           |  |  |
|--------------------|-----------------------------------------------------|--|--|--|--|--|--|--|--|--|--|---|----------|-----------|--|--|
| DIV_Mantissa[11:0] |                                                     |  |  |  |  |  |  |  |  |  |  |   | DIV_Frac | tion[3:0] |  |  |
| rw                 |                                                     |  |  |  |  |  |  |  |  |  |  |   | r        | W         |  |  |

| 位 31:16 | Res: 保留<br>必须保持复位值。                                                                                 |
|---------|-----------------------------------------------------------------------------------------------------|
| 位 15:4  | DIV_Mantissa[11:0]: USARTDIV 的整数部分(Mantissa of USARTDIV)<br>这 12 位定义了 USART 分频器除法因子(USARTDIV)的整数部分。 |
| 位 3:0   | DIV_Fraction[3:0]: USARTDIV 的小数部分(Fraction of USARTDIV) 这 4 位定义了 USART 分频器除法因子(USARTDIV)的小数部分。      |

# 21.6.4 控制寄存器 1(USARTx\_CR1)(x=1..5)

偏移地址: 0x0C 复位值: 0x0000

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

| 15 | 14  | 13 | 12 | 11   | 10  | 9  | 8    | 7     | 6    | 5      | 4      | 3  | 2  | 1   | 0   |
|----|-----|----|----|------|-----|----|------|-------|------|--------|--------|----|----|-----|-----|
| R  | les | UE | М  | WAKE | PCE | PS | PEIE | TXEIE | TCIE | RXNEIE | IDLEIE | TE | RE | RWU | SBK |
|    |     | rw | rw | rw   | rw  | rw | rw   | rw    | rw   | rw     | rw     | rw | rw | rw  | rw  |

|         | rw          | rw                                                                                                                      | rw                        | rw                | rw                           | rw   | rw    | rw     | rw            | rw          | rw  | rw  | rw   | rw |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------|---------------------------|-------------------|------------------------------|------|-------|--------|---------------|-------------|-----|-----|------|----|
| 位 31:14 |             | es: 保<br>·须保                                                                                                            | ¦留<br>持复位值                | . 0               |                              |      |       |        |               |             |     |     |      |    |
| 位 13    | 当<br>该<br>• | 该位<br>位由:<br>0: U                                                                                                       | ART 使能被清零,软件设置<br>SART 分级 | 在当前<br>和清零<br>预器和 | 前字节<br>零。<br>输出 <sup>。</sup> | 方传输完 | E成后 U | SART ( | 的分频器          | 和输出停        | 止工1 | 作,以 | 人减少功 | 耗。 |
| 位 12    | · · · ·     | M: 字长(Word length) 该位定义了数据字的长度,由软件对其设置和清零。 • 0: 一个起始位,8个数据位,n个停止位 • 1: 一个起始位,9个数据位,n个停止位 注意: 在数据传输过程中(发送或者接收时),不能修改这个位。 |                           |                   |                              |      |       |        |               |             |     |     |      |    |
| 位 11    | 这<br>•      | 位决:<br>0: 被                                                                                                             | 唤醒的;<br>定了把 U<br>按空闲总统    | SART「<br>线唤醒      | 唤醒的                          | •    |       | :对该位   | 近设置和清         | <b>š零</b> 。 |     |     |      |    |
| 位 10    | 用           | 该位                                                                                                                      |                           | 5进行               | <b></b> 便件相                  | 交验控制 | 制(对于  | 发送来    | 平说就是村<br>的最高位 |             |     |     |      |    |



|     | 位;如果 M=0,最高位就是第 8 位)插入校验位;对接收到的数据检查其校验位。软件对它置'1'或清零。一旦设置了该位,当前字节传输完成后,校验控制才生效。 • 0:禁止校验控制 • 1:使能校验控制                                                                                              |
|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 9 | PS: 校验选择(Parity selection)<br>当校验控制使能后,该位用来选择是采用偶校验还是奇校验。软件对它置'1'或清零。当前字节传输完成后,该选择生效。<br>• 0: 偶校验<br>• 1: 奇校验                                                                                     |
| 位 8 | PEIE: PE 中断使能(PE interrupt enable) 该位由软件设置或清除。  • 0: 禁止产生中断  • 1: 当 USARTx_SR 中的 PE 为'1'时,产生 USART 中断                                                                                             |
| 位 7 | TXEIE: 发送缓冲区空中断使能(TXE interrupt enable) 该位由软件设置或清除。  • 0: 禁止产生中断  • 1: 当 USARTx_SR 中的 TXE 为'1'时,产生 USART 中断                                                                                       |
| 位 6 | TCIE: 发送完成中断使能(Transmission complete interrupt enable)该位由软件设置或清除。 • 0: 禁止产生中断 • 1: 当 USARTx_SR 中的 TC 为'1'时,产生 USART 中断                                                                            |
| 位 5 | RXNEIE:接收缓冲区非空中断使能(RXNE interrupt enable)该位由软件设置或清除。  • 0:禁止产生中断  • 1: 当 USARTx_SR 中的 ORE 或者 RXNE 为'1'时,产生 USART 中断                                                                               |
| 位 4 | IDLEIE: IDLE 中断使能(IDLE interrupt enable) 该位由软件设置或清除。  • 0: 禁止产生中断  • 1: 当 USARTx_SR 中的 IDLE 为'1'时,产生 USART 中断                                                                                     |
| 位 3 | TE: 发送使能(Transmitter enable) 该位使能发送器。该位由软件设置或清除。  • 0: 禁止发送  • 1: 使能发送  注意:  • 在数据传输过程中,除了在智能卡模式下,如果 TE 位上有个 0 脉冲(即设置为 0'之后再设置为 1'),会在当前数据字传输完成后,发送一个前导符(空闲总线)。  • 当TE 被设置后,在真正发送开始之前,有一个比特时间的延迟。 |



位 2 RE: 接收使能(Receiver enable)

该位由软件设置或清除。

- 0: 禁止接收
- 1: 使能接收,并开始搜寻 RX 引脚上的起始位

位 1 RWU: 接收唤醒 (Receiver wakeup)

该位用来决定是否把 USART 置于静默模式。该位由软件设置或清除。当唤醒序列到来时,硬件也会将其清零。

- 0: 接收器处于正常工作模式
- 1: 接收器处于静默模式

注意:

- 在把USART 置于静默模式(设置RWU 位)之前,USART 必须已经先接收了一个数据字节。否则在静默模式下,不能被空闲总线检测唤醒。
- 当配置成地址标记检测唤醒(WAKE 位=1),在RXNE 位被置位时,不能用软件修改 RWU 位。

位 0 SBK: 发送断开帧 (Send break)

使用该位来发送断开字符。该位可以由软件设置或清除。操作过程应该是软件设置位它,然后在断开帧的停止位时,由硬件将该位复位。

- 0: 没有发送断开字符
- 1: 将要发送断开字符

# 21.6.5 控制寄存器 2(USARTx\_CR2)(x=1..5)

偏移地址: 0x10 复位值: 0x0000

| 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 | LINEN | STOP | [1:0] | CLKEN | CPOL | СРНА | LBCL | Res | LBDIE | LBDL | Res |   | ADD | [3:0] |   |
|     | rw    | r    | w     | rw    | rw   | rw   | rw   |     | rw    | rw   |     |   | r   | W     |   |

| 位 31:15 | Res: 保留<br>必须保持复位值。                                                                                                                                                                          |
|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 14    | LINEN: LIN 模式使能(LIN mode enable)         该位由软件设置或清除。         • 0: 禁止 LIN 模式         • 1: 使能 LIN 模式         在 LIN 模式下,可以用 USARTx_CR1 寄存器中的 SBK 位发送 LIN 同步断开符(低 13 位),         以及检测 LIN 同步断开符。 |
| 位 13:12 | STOP[1:0]: 停止位(STOP bits)         这 2 位用来设置停止位的位数。                                                                                                                                           |



|      | 週刊刊少开少权及证(USANI)                                                                                                                                                                                                                      |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | <ul><li>00: 1 个停止位</li><li>01: 0.5 个停止位</li></ul>                                                                                                                                                                                     |
|      | <ul><li>10: 2 个停止位</li><li>11: 1.5 个停止位</li></ul>                                                                                                                                                                                     |
| 位 11 | CLKEN: 时钟使能(Clock enable)<br>该位用来使能 CK 引脚。  • 0: 禁止 CK 引脚  • 1: 使能 CK 引脚                                                                                                                                                              |
| 位 10 | CPOL: 时钟极性 (Clock polarity) 在同步模式下,可以用该位选择 CK 引脚上时钟输出的极性。和 CPHA 位一起配合来产生需要的时钟/数据的采样关系。  • 0: 总线空闲时 CK 引脚上保持低电平  • 1: 总线空闲时 CK 引脚上保持高电平 注意: 在使能发送后不能改写该位。                                                                              |
| 位 9  | CPHA: 时钟相位(Clock phase)<br>在同步模式下,可以用该位选择 CK 引脚上时钟输出的相位。和 CPOL 位一起配合来产生<br>需要的时钟/数据的采样关系(参见图 10-12 和图 10-13)。<br>• 0: 在时钟的第一个边沿进行数据捕获<br>• 1: 在时钟的第二个边沿进行数据捕获<br>注意: 在使能发送后不能改写该位。                                                    |
| 位 8  | LBCL:最后一位时钟脉冲(Last bit clock pulse) 在同步模式下,使用该位来控制是否在 CK 引脚上输出最后发送的那个数据字节(MSB)对应的时钟脉冲:  • 0:最后一位数据的时钟脉冲不从 CK 输出  • 1:最后一位数据的时钟脉冲会从 CK 输出  注意:  1. 在使能发送后不能改写该位。  2. 最后一个数据位就是第8或者第9个发送的位(根据 USARTx_CR1 寄存器中的 M 位 所定义的 8 或者 9 位数据帧格式)。 |
| 位 7  | Res: 保留<br>必须保持复位值。                                                                                                                                                                                                                   |
| 位 6  | LBDIE: LIN 断开符检测中断使能(LIN break detection interrupt enable)断开符中断屏蔽(使用断开分隔符来检测断开符)。  • 0: 禁止中断  • 1: 只要 USARTx_SR 寄存器中的 LBD 为'1'就产生中断                                                                                                   |
| 位 5  | LBDL: LIN 断开符检测长度(LIN break detection length)<br>该位用来选择是 11 位还是 10 位的断开符检测。                                                                                                                                                           |



|       | <ul><li>0: 10 位的断开符检测</li><li>1: 11 位的断开符检测</li></ul>                                                             |
|-------|-------------------------------------------------------------------------------------------------------------------|
| 位 4   | Res: 保留<br>必须保持复位值。                                                                                               |
| 位 3:0 | ADD[3:0]:本设备的 USART 节点地址(Address of the USART node)该位域给出本设备 USART 节点的地址。这是在多处理器通信下的静默模式中使用的,使用地址标记来唤醒某个 USART 设备。 |

# 21.6.6 控制寄存器 3(USARTx\_CR3)(x=1..5)

偏移地址: 0x14 复位值: 0x0000

| 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 |    |    | CTSIE | CTSE | RTSE | DMAT | DMAR | SCEN | NACK | HDSEL | IRLP | IREN | EIE |    |
|    |     |    |    |       | rw    | rw   | rw   | rw  | rw |

| 位 31:11 | Res: 保留<br>必须保持复位值。                                                                                                                                                             |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 10    | CTSIE: CTS 中断使能(CTS interrupt enable)  • 0: 禁止中断  • 1: USARTx_SR 寄存器中的 CTS 为'1'时产生中                                                                                             |
| 位 9     | CTSE: CTS 使能(CTS enable)  • 0: 禁止 CTS 硬件流控制  • 1: CTS 模式使能 只有 CTS 输入信号有效(拉成低电平)时才能发送数据。如果在数据传输的过程中, CTS 信号变成无效,那么发完这个数据后,传输就停止下来。如果当 CTS 为无效时,向 数据寄存器里写数据,则要等到 CTS 有效时才会发送这个数据。 |
| 位 8     | RTSE: RTS 使能(RTS enable)  • 0: 禁止 RTS 硬件流控制  • 1: RTS 中断使能 只有接收缓冲区内有空余的空间时才请求下一个数据。当前数据发送完成后,发送操作就需要暂停下来。如果可以接收数据了,将 RTS 输出置为有效(拉至低电平)。                                         |
| 位 7     | DMAT: DMA 使能发送(DMA enable transmitter)<br>该位由软件设置或清除。  • 0: 禁止发送时的 DMA 模式  • 1: 使能发送时的 DMA 模式                                                                                   |
| 位 6     | DMAR: DMA 使能接收(DMA enable receiver)                                                                                                                                             |



|     | 该位由软件设置或清除。  • 0: 禁止接收时的 DMA 模式  • 1: 使能接收时的 DMA 模式                                                                                                                                                       |
|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 5 | SCEN: 智能卡模式使能 (Smartcard mode enable)         该位用来使能智能卡模式         • 0: 禁止智能卡模式         • 1: 使能智能卡模式                                                                                                       |
| 位 4 | NACK: 智能卡 NACK 使能(Smartcard NACK enable)  • 0: 在奇偶校验没有打开时,发送 NACK。  • 1: 在奇偶校验错误出现时,发送 NACK。                                                                                                              |
| 位 3 | HDSEL: 半双工选择(Half-duplex selection)         选择单线半双工模式         • 0: 不选择半双工模式         • 1: 选择半双工模式                                                                                                          |
| 位 2 | IRLP: 红外低功耗(IrDA low-power)<br>该位用来选择普通模式还是低功耗红外模式  • 0: 通常模式  • 1: 低功耗模式                                                                                                                                 |
| 位 1 | <ul> <li>IREN: 红外模式使能(IrDA mode enable)</li> <li>该位由软件设置或清除。</li> <li>0: 不使能红外模式</li> <li>1: 使能红外模式</li> </ul>                                                                                            |
| 位 0 | EIE: 错误中断使能(Error interrupt enable)<br>在多缓冲区通信模式下,当有帧错误、过载或者噪声错误时(USARTx_SR 中的 FE=1,或者<br>ORE=1,或者 NE=1)产生中断。<br>• 0: 禁止中断<br>• 1: 只要 USARTx_CR3 中的 DMAR=1,并且 USARTx_SR 中的 FE=1,或者 ORE=1,或者<br>NE=1,则产生中断 |

# 21.6.7 保护时间和预分频寄存器(USARTx\_GTPR)(x=1..5)

偏移地址: 0x18 复位值: 0x0000

| 31      | 30  | 29  | 28 | 27  | 26 | 25       | 24 | 23 | 22 | 21 | 20 | 19 | 9 : | 18 | 17 | 16 |
|---------|-----|-----|----|-----|----|----------|----|----|----|----|----|----|-----|----|----|----|
|         | Res |     |    |     |    |          |    |    |    |    |    |    |     |    |    |    |
|         |     |     |    |     |    |          |    |    |    |    |    |    |     |    |    |    |
| 4.5     |     | 4.4 | 12 | 4.2 | 11 | 10       | _  | 0  | -  | _  | -  | 4  | _   | 2  | -  | 0  |
| 15      |     | 14  | 13 | 12  | 11 | 10       | 9  | 8  | /  | 6  | 5  | 4  | 3   | 2  | 1  | U  |
| GT[7:0] |     |     |    |     |    | PSC[7:0] |    |    |    |    |    |    |     |    |    |    |



| 位 31:16 | Res: 保留<br>必须保持复位值。                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 15:8  | GT[7:0]:保护时间值(Guard time value) 该位域规定了以波特时钟为单位的保护时间。在智能卡模式下,需要这个功能。当保护时间过去后,才会设置发送完成标志。                                                                                                                                                                                                                                                                                                                                                                          |
| 位 7:0   | PSC[7:0]: 预分频器值(Prescaler value)  • 在红外(IrDA)低功耗模式下: PSC[7:0]=红外低功耗波特率  • 对系统时钟分频以获得低功耗模式下的频率: 源时钟被寄存器中的值(仅有 8 位有效)分频  • 000000000: 保留-不要写入该值  • 00000001: 对源时钟 1 分频  • 00000001: 对源时钟 2 分频  •  • -在红外(IrDA)的正常模式下: PSC 只能设置为 00000001  • 在智能卡模式下: PSC[4:0]: 预分频值 对系统时钟进行分频,给智能卡提供时钟。寄存器中给出的值(低 5 位有效)乘以 2 后,作为对源时钟的分频因子  • 00000: 保留,不要写入该值  • 00001: 对源时钟进行 2 分频  • 00010: 对源时钟进行 4 分频  • 00011: 对源时钟进行 4 分频  • 00011: 对源时钟进行 6 分频  •  注意: 位[7:5] 在智能卡模式下没有意义。 |



# 22 除法开方运算单元(DVSQ)

ARM Cortex-M3 中没有开方指令;除法支持带符号除法和不带符号数除法指令,但不能直接得到模数。但是在有些应用中,需要硬件支持除法和开方指令来提高程序运行速度和降低功耗。DVSQ 运算单元支持 32 位的无符号除法(UDIV)和带符号除法(SDIV),和 32 位无符号开方运算。除法运算同时支持 MOD 操作,运算完成后,商和余数同时更新到相应的寄存器供软件读取。

# 22.1 DVSQ 主要特性

- 支持 32 位带符号数和无符号数除法,支持无符号 32 位开方运算。在同一时刻, DVSQ 加速器 不能同时支持除法和开方运算,只能两者选其一来执行。32 位/32 位有符号或无符号整数除法 (同时获取商和余数)。无符号开方运算,可以通过软件选择高精度开方运算。
- 流水线设计,每个时钟完成 2 位(bit)运算。
- 运算时间根据运算数据不同而改变。
- 支持除零中断和溢出中断。

结构示图如下:



图 22-1 DVSQ 结构图

# 22.2 除法操作流程

#### 除法操作

结果寄存器 DVSQ\_RES 和余数寄存器 DVSQ\_REMAINDER 中保持的值始终为补码格式。如果执行无符号除法运算,则 DVSQ\_RES 寄存器和 DVSQ\_REMAINDER 寄存器中的值都为正数。如果执行带符号数除法,则 DVSQ\_RES 寄存器和 DVSQ\_REMAINDER 寄存器的符号位由输入的操作数决定:

- 如果被除数和除数的符号位不同,则商为负数;否则商为正数。
- 余数的符号位始终和除数的符号位相同。

#### 操作流程

可以通过快速启动和非快速启动两种方式启动除法运算。除法运算的操作流程示意图为:





图 22-2 除法运算流程示意图

# 22.3 除法运行时间

DVSQ 加速器通过被除数的数据决定运算时间,以尽快得到运算结果。运算时间如下表所示,其中运算时间定义为从运算开始到得到运算结果的时钟周期数,也就是 DVSQ\_CSR.BUSY 为高的持续时间。

运算时间[周期数] 被除数的绝对值(有效位的位置) 17 16 15 0000\_ (01、1x) xx\_xxxx\_xxxx\_xxxx\_xxxx\_xxxx\_xxxx 14 0000\_00 (01、1x) \_xxxx\_xxxx\_\_xxxx\_xxxx\_xxxx\_xxxx 13 0000\_0000\_ (01、1x) xx\_xxxx\_xxxx\_xxxx\_xxxx\_xxxx 0000\_0000\_00 (01、1x) \_xxxx\_\_xxxx\_xxxx\_xxxx\_xxxx 12 11 0000\_0000\_0000\_ (01、1x) xx\_\_xxxx\_xxxx\_xxxx\_xxxx  $0000\_0000\_0000\_00 \ (01\ \ 1x) \ \_xxxx\_xxxx\_xxxx\_xxxx\_xxxx$ 10

表 22-1 除法运算时间对应表



| 被除数的绝对值(有效位的位置)                                | 运算时间[周期数] |
|------------------------------------------------|-----------|
| 0000_0000_0000_0000_ (01、1x) xx_xxxx_xxxx      | 9         |
| 0000_0000_0000_0000_ (01、 1x) xx_xxxx_xxxx     | 8         |
| 0000_0000_0000_0000_0000_ (01、1x) xx_xxxx_xxxx | 7         |
| 0000_0000_0000_0000_00 (01、1x) _xxxx_xxxx      | 6         |
| 0000_0000_0000_0000_0000_ (01、1x) xx_xxxx      | 5         |
| 0000_0000_0000_0000_0000_00 (01\ 1x) _xxxx     | 4         |
| 0000_0000_0000_0000_0000_0000_ (01、1x) xx      | 3         |
| 0000_0000_0000_0000_0000_0000_00 (01、1x)       | 2         |
| 0000_0000_0000_0000_0000_0000_0000             | 1         |

### 22.4 开方操作描述

DVSQ 加速器只能进行无符号数开方,因此进行开方运算的时候 DVSQ\_RADICAND 和 DVSQ\_RES 中的值都是无符号数。

#### 操作流程



图 22-3 开方运算流程图

# 22.5 开方运行时间

DVSQ 加速器根据被开方数决定运算时间,同时 DVSQ\_CSR.HPRESQRT 也会影响开方运算时间。具体时间如下表,其中运算时间定义为从运算开始到得到运算结果的时钟周期数,也就是 DVSQ\_CSR.BUSY 为高的持续时间。

当 DVSQ\_CSR.HPRESQRT 为 0 时:



### 表 22-2 开放运行时间(DVSQ\_CSR. HPRESQRT=0)

| 被开方数(有效位的位置)                                   | 运算时间[周期数] |
|------------------------------------------------|-----------|
| (01、1x) xx_xxxx_xxxx_xxxx_xxxx_xxxx_xxxx_xxx   | 17        |
| 00 (01、1x) _xxxx_xxxx_xxxx_xxxx_xxxx_xxxx_xxxx | 16        |
| 0000_ (01、1x) xx_xxxx_xxxx_xxxx_xxxx_xxxx      | 15        |
| 0000_00 (01、1x) _xxxx_xxxxxxxx_xxxx_xxxx       | 14        |
| 0000_0000_ (01、1x) xx_xxxx_xxxx_xxxx_xxxx      | 13        |
| 0000_0000_00 (01、1x) _xxxxxxxx_xxxx_xxxx       | 12        |
| 0000_0000_0000_ (01、1x) xxxxxx_xxxx_xxxx_xxxx  | 11        |
| 0000_0000_0000_00 (01、1x)xxxx_xxxx_xxxx_xxxx   | 10        |
| 0000_0000_0000_0000_ (01、1x) xx_xxxx_xxxx_xxxx | 9         |
| 0000_0000_0000_0000_0000_ (01、1x) xx_xxxx_xxxx | 8         |
| 0000_0000_0000_0000_0000_ (01、1x) xx_xxxx_xxxx | 7         |
| 0000_0000_0000_0000_00 (01、1x) _xxxx_xxxx      | 6         |
| 0000_0000_0000_0000_0000_ (01、1x) xx_xxxx      | 5         |
| 0000_0000_0000_0000_0000_00 (01、1x) _xxxx      | 4         |
| 0000_0000_0000_0000_0000_0000_ (01、1x) xx      | 3         |
| 0000_0000_0000_0000_0000_0000_00 (01、1x)       | 2         |
| 0000_0000_0000_0000_0000_0000_0000             | 1         |

当 DVSQ\_CSR.HPRESQRT 为 1 时:

表 22-3 开放运行时间(DVSQ\_CSR. HPRESQRT=1)

| 被开方数(有效位的位置)                                  | 运算时间[周期数] |
|-----------------------------------------------|-----------|
| (01、1x) xx_xxxx_xxxx_xxxx_xxxx_xxxx_xxxx_xxx  | 33        |
| 00 (01、1x) _xxxx_xxxx_xxxx_xxxx_xxxx_xxxx     | 32        |
| 0000_ (01、1x) xx_xxxx_xxxx_xxxx_xxxx_xxxx     | 31        |
| 0000_00 (01、1x) _xxxx_xxxxxxxx_xxxx_xxxx      | 30        |
| 0000_0000_ (01、1x) xx_xxxx_xxxx_xxxx_xxxx     | 29        |
| 0000_0000_00 (01、1x) _xxxxxxxx_xxxx_xxxx      | 28        |
| 0000_0000_0000_ (01、1x) xxxxxx_xxxx_xxxx_xxxx | 27        |
| 0000_0000_0000_00 (01、1x)xxxx_xxxx_xxxx       | 26        |
| 0000_0000_0000_0000_ (01、1x) xx_xxxx_xxxx     | 25        |



| 被开方数(有效位的位置)                                   | 运算时间[周期数] |
|------------------------------------------------|-----------|
| 0000_0000_0000_0000_0000_ (01、1x) xx_xxxx_xxxx | 24        |
| 0000_0000_0000_0000_(01\ 1x) xx_xxxx_xxxx      | 23        |
| 0000_0000_0000_0000_00 (01、1x) _xxxx_xxxx      | 22        |
| 0000_0000_0000_0000_0000_ (01、1x) xx_xxxx      | 21        |
| 0000_0000_0000_0000_0000_00 (01、1x) _xxxx      | 20        |
| 0000_0000_0000_0000_0000_0000_ (01、1x) xx      | 19        |
| 0000_0000_0000_0000_0000_0000_00 (01、1x)       | 18        |
| 0000_0000_0000_0000_0000_0000_0000             | 1         |

### 22.6 中断

DVSQ 加速器内部的两个中断源共用芯片中的同一个中断号。当系统检测到中断请求后,需要通过 读 DVSQ\_CSR 寄存器来判断是除零中断还是溢出中断。在同一时刻,除零中断和溢出中断不能同时发生,只可能是其一。

- 带符号数除法溢出中断:
  - 。 可以通过配置 DVSQ CSR.OV INT EN 使能或关闭。
  - 。 当带符号数除法的被除数为 0x8000\_0000,除数为 0xFFFF\_FFFF 时,中断请求会被硬件置位。
  - 。 本中断情况可以通过软件或硬件清除:
    - 软件配置 DVSQ\_CSR.OV\_FLAG 为 0。
    - 开始下一次除法或开方运算。
- 除零中断:
  - 。 可以通过配置 DVSQ\_CSR.DZ\_INT\_EN 使能或关闭。
  - 。 当除数为0时,中断请求会被硬件置位。
  - 。 本中断请求可以通过软件或硬件清除:
    - 软件配置 DVSQ\_CSR.DZ\_FLAG 为 0。
    - 开始下一次除法或开方运算。

# 22.7 注意事项

#### 除法操作

因为 DVSQ\_DIVIDEND 寄存器和 DVSQ\_DIVISOR 寄存器的值在运算过程中不会被硬件改变,所以软件通过字节或半字写这两个寄存器的时候需要小心。比如软件字节写 DIVIDEND[7:0]后,DVSQ\_DIVIDEND 寄存器中的高 24 位为上一次除法运算写入的值,低 8 位为新写入的值。

当除法配置为快速启动后,无论是以字节、半字还是字写 DVSQ\_DIVISOR 寄存器都会使除法运算开始。

#### 开方运算

无论是字节写、半字写还是字写 DVSQ\_DIVISOR 寄存器都会使除法运算开始。

### 结果读取



如果在 DVSQ 还没有完成运算的时候访问 DVSQ\_RES 和 DVSQ\_REMAINDER 寄存器,将会使总线处于等待状态,在等待状态中也不能相应中断。软件可以通过轮询 DVSQ\_CSR.BUSY 的状态来判断 DVSQ\_RES 和 DVSQ\_REMAINDER 的值是否已经就绪。

如果在 DVSQ 还没有完成运算的时候,访问 DVSQ\_DIVIDEND/DVSQ\_DIVISOR/DVSQ\_RADICAND 寄存器 也会使总线处于等待状态。

## 22.8 DVSQ 寄存器

基地址: 0x4003 0000

空间大小: 0x400

## 22.8.1 被除数寄存器(DVSQ\_DIVIDEND)

偏移地址: 0x00

复位值: 0x0000 0000

软件配置除法运算所需的被除数值。如果在 DVSQ 加速器处于工作态时,对 DVSQ\_DIVIDEND 寄存器进行读写访问,则总线将处于等待状态直到 DVSQ 加速器的操作完成。DVSQ\_DIVIDEND 寄存器只能被软件写访问更新,硬件运算不会更新 DVSQ\_DIVIDEND 寄存器。

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

位 31:0

DIVIDEND[31:0]:被除数寄存器(Dividend)

读操作:读出寄存器里存储的值。 写操作:更新除法运算的被除数。

# 22.8.2 除数寄存器(DVSQ\_DIVISOR)

偏移地址: 0x04

复位值: 0x0000 0000

软件配置除法运算所需的除数值。当 DVSQ\_CSR.DFS=0 时,如果软件写 DVSQ\_DIVISOR 寄存器会立即使能除法运算。如果在 DVSQ 加速器处于工作态时。对 DVSQ\_DIVISOR 寄存器进行读写访问,则总线将处于等待状态直到 DVSQ 加速器的操作完成。DVSQ\_DIVISOR 寄存器只能被软件写访问更新,硬件运算不会更新 DVSQ\_DIVISOR 寄存器。

| 31                                  | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| DIVISOR[31:16]                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| rw                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 15                                  | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| DIVISOR[15:0]                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| rw                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 位 31:0 DIVISOR[31:0]:被除数的值(Divisor) |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |



# 22.8.3 控制和状态寄存器(DVSQ\_CSR)

偏移地址: 0x08

复位值: 0x0000 0000

本寄存器控制除法和开方运算工作,并返回 DVSQ 加速器的工作状态。DVSQ\_CSR 寄存器的值会被 DVSQ 加速器硬件更新。软件可以轮询 DVSQ\_CSR 寄存器来判断除法和开方运算是否已经完成。如果在 DVSQ 加速器处于工作态的时候对 DVSQ\_CSR 寄存器进行写操作,则总线将处于等待状态直到 DVSQ 加速器的操作完成。

|   | 31  | 30  | 29   | 28 | 27 | 26 | 25 | 24 | 23 | 22  | 21 | 20 | 19 | 18 | 17 | 16 |
|---|-----|-----|------|----|----|----|----|----|----|-----|----|----|----|----|----|----|
| В | USY | DIV | SQRT |    |    |    |    |    |    | Res |    |    |    |    |    |    |
|   | r   | r   | r    |    |    |    |    |    |    |     |    |    |    |    |    |    |

| 1 | 1 | 1 | 1         | 1 | 1 | 9 | 8 | 7      | 6      | 5        | 4      | 3        | 2  | 1        | 0      |
|---|---|---|-----------|---|---|---|---|--------|--------|----------|--------|----------|----|----------|--------|
| 5 | 4 | 3 | 2 1 0 Res |   |   |   |   |        |        |          |        |          |    |          |        |
|   |   |   |           |   |   | • |   | HPRESQ | OV_FLA | OV_INT_E | DZ_FLA | DZ_INT_E | DF | UNSIGN_D | DIV_SR |
|   |   |   |           |   |   |   |   | RT     | G      | N        | G      | N        | S  | IV       | T      |
|   |   |   |           |   |   |   |   | rw     | rw     | rw       | rw     | rw       | rw | rw       | rw     |

|        |                                                    | rw     | rw    | rw          | rw       | rw          | rw    | rw              | rw       |
|--------|----------------------------------------------------|--------|-------|-------------|----------|-------------|-------|-----------------|----------|
| 位 31   | BUSY: DVSQ 加                                       | 速器工作   | 状态标志  | s (Busy bit | :)       |             |       |                 |          |
|        | • 0: DVSQ 加達                                       | 速器处于图  | 空闲状态。 | ,           |          |             |       |                 |          |
|        | • 1: DVSQ 加達                                       | 束器处于]  | L作状态, | 表示有除        | 法或开方     | 7运算正在       | 工作。   | 0               |          |
|        | 位[31]BUSY 信                                        | _      | -     |             |          |             | DVS   | Q 加速器的          | 工作状      |
|        | 态,具体当[BU                                           |        | -     |             |          |             | TT 4  | →+₽ <i>//</i> ~ |          |
|        | ● 000: 标识 D<br>● 001: 标识 D<br>算。                   | –      |       |             |          |             | , ,   |                 | 开方运      |
|        | ● 010: 标识 D<br>算。                                  | VSQ 加速 | 器处于空  | 闲态,并且       | 且 DVSQ 力 | 加速器完成       | 的上    | 一个运算为           | 除法运      |
|        | ● 101:标识 D                                         | VSQ 加速 | 器处于工  | 作态,并且       | 且正在进行    | 厅的是开方       | 运算    | 0               |          |
|        | <ul><li>● 110:标识 D</li><li>● 其他值:没有</li></ul>      |        | 器处于工  | 作态,并且       | 且正在进行    | 行的是除法       | 运算    | 0               |          |
| 位 30   | DIV: 除法运算<br>● 0: 表示 DVS<br>● 1: 表示 DVS            | Q 加速器  | 进行的上  | 一个运算员       |          |             |       |                 |          |
| 位 29   | SQRT: 开方运<br>● 0: 表示 DVS<br>● 1: 表示 DVS            | Q 加速器  | 进行的上  | 一个运算员       | 成者当前:    |             |       |                 |          |
| 位 28:8 | Res: 保留<br>必须保持复位值                                 | 直。     |       |             |          |             |       |                 |          |
| 位 7    | HPRESQRT: 高<br>selection)<br>● 写操作:<br>。 0: DVSQ i | 执行普通料  | 青度开方: | 运算。         | 器(Hig    | h precision | n squ | are-root op     | peration |



|     | MAAT A 色新子丸(DV3Q)                                                                                                                                                  |
|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     | ● 读操作:读出寄存器里存储的值。<br>说明:见本表格说明部分。                                                                                                                                  |
| 位 6 | OV_FLAG: 带符号数除法溢出标志(Sign divide overflow flag)  • 写操作:                                                                                                             |
| 位 5 | OV_INT_EN: 带符号数除法溢出中断使能(Sign divide overflow interrupt enable)     写操作:                                                                                            |
| 位 4 | DZ_FLAG: 除数为 0 标志(Zero divisor flag)  ● 写操作:                                                                                                                       |
| 位 3 | DZ_INT_EN: 除数为 0 中断使能(Zero divisor interrupt enable)  ● 写操作:                                                                                                       |
| 位 2 | DFS: 快速启动除法运算关闭(Divide operation fast start disable)  • 写操作:  • 0: 使能快速启动除法运算。  • 1: 关闭快速启动除法运算。  • 读操作: 读出寄存器里存储的值。  DVSQ 加速器支持两种方式启动除法运算。默认方式为'快速启动',如果对 DIVISOR |



|     | 进行写操作,就立即启动除法运算。另一种启动方式为:软件置位 DVSQ_CSR[DIV_SRT]寄存器后才开始除法运算。由 DFS 位选择使用哪一种启动方式。 |
|-----|--------------------------------------------------------------------------------|
| 位 1 | UNSIGN_DIV: 无符号数除法(Unsign divide operation enable)  ● 写操作:                     |
| 位 0 | DIV_SRT: 开始除法运算(Divide operation start)  ● 写操作:                                |

#### 说明:

软件可以使用 Q notation 来增加开方运算的精度。

如果使用 Q notation 来进行开方运算,无符号 Qm.n 记号法需要 m+n 位作为被开方数 (m+n=32), 产生的结果为 Q (m/2). (n/2) 格式。这占用 n 位被开方数作为小数位 (n<31), 因此如果软件需要高精 度开方结果的时候,将比较大的影响被开方数的表示范围。

DVSQ 加速器提供了一种同时满足高精度开方和被开方数表示范围的方法,当HPRESQRT 被置位为1时,DVSQ 加速器内部附加32位 '0'到被开方数寄存器后面,即: DVSQ\_RADICAND ([RADICAND.0x000000000])。然后把这个新的数作为被开方数带入开方运算单元进行运算。这时被开方数为 Q32.32,开方结果为 Q16.16。这样被开方数的结果不会受到影响,并且同时达到高精度开方的要求。如果 HPRESQRT 被设置为 '0',则被开方数的小数位由软件决定,并且满足 M+n=32。

## 22.8.4 被开方数寄存器(DVSQ\_RADICAND)

偏移地址: 0x0C

复位值: 0x0000 0000

软件通过写 DVSQ\_RADICAND 寄存器配置开方运算的被开方数。如果在 DVSQ 加速器处于工作态时,对 DVSQ\_RADICAND 寄存器进行读写访问,则总线将处于等待状态直到 DVSQ 加速器的操作完成。 DVSQ\_RADICAND 寄存器只能被软件写访问更新,硬件运算不会更新 DVSQ\_RADICAND 寄存器。

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24      | 23       | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|---------|----------|----|----|----|----|----|----|----|
|    | •  |    |    | •  |    | F  | RADICAN | ID[31:16 | 5] | •  |    |    |    | •  |    |
|    |    |    |    |    |    |    | r       | w        |    |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8       | 7        | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    |    | RADICAI | ND[15:0] | ]  |    |    |    |    |    |    |
|    |    |    |    |    |    |    | r       | w        |    |    |    |    |    |    |    |
|    | rw |    |    |    |    |    |         |          |    |    |    |    |    |    |    |

位 31:0 RADICAND[31:0]:被开方数(Radicand)

# 22.8.5 结果寄存器(DVSQ\_RES)

偏移地址: 0x10

复位值: 0x0000 0000



DVSQ\_RES 寄存器存储除法运算的商或开方运算的平方根结果。在 DVSQ 加速器完成除法或开方运算后会自动更新 DVSQ\_RES 寄存器。如果在 DVSQ 加速器处于工作态时,对 DVSQ\_RES 寄存器进行读写访问,则总线将处于等待状态直到 DVSQ 加速器的操作完成。在 DVSQ 寄存器进行运算的时候有可能被系统中断服务程序打断,软件需要保存 DVSQ 加速器的上下文。因此 DVSQ\_RES 寄存器和 DVSQ\_REMAINDER 寄存器可以被软件写操作更新。

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24     | 23      | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|--------|---------|----|----|----|----|----|----|----|
|    |    |    |    |    |    |    | RESULT | [31:16] |    |    |    |    |    |    |    |
|    |    |    |    |    |    |    | r۱     | N       |    |    |    |    |    |    |    |
|    |    | 10 | 10 |    | 10 | •  | •      | _       | •  |    | _  |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8      | /       | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    |    | RESUL  | Γ[15:0] |    |    |    |    |    |    |    |
|    | rw |    |    |    |    |    |        |         |    |    |    |    |    |    |    |

位 31:0

RESULT[31:0]: 结果寄存器(Result)

- 写操作: 更新结果寄存器中的值。
- 读操作: 读出寄存器里存储的值。

## 22.8.6 余数寄存器(DVSQ REMAINDER)

偏移地址: 0x14

复位值: 0x0000 0000 • DVSQ\_REMAINDER 寄存器保存除法运算的余数结果。DVSQ 加速器进行除法运算或开方运算的时候都会自动更新 DVSQ\_REMAINDER 寄存器。如果在 DVSQ 加速器处于工作态时,对 DVSQ\_REMAINDER 寄存器进行读写访问,则总线将处于等待状态直到 DVSQ 加速器的操作完成。

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24      | 23       | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|---------|----------|----|----|----|----|----|----|----|
|    |    |    |    |    |    | R  | EMAIND  | ER[31:1  | 6] |    |    |    |    |    |    |
|    |    |    |    |    |    |    | r       | W        |    |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8       | 7        | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    |    |    |    |    |    | F  | REMAINE | DER[15:0 | )] |    |    |    |    |    |    |
|    |    |    |    |    |    |    | r       | W        |    |    |    |    |    |    |    |
|    |    |    |    |    |    |    |         |          |    |    |    |    |    |    |    |

位 31:0

REMAINDER[31:0]: 余数寄存器(Remainder)

- 写操作: 更新结果寄存器中的值
- 读操作: 读出寄存器里存储的值



## 23 器件电子签名(UID)

电子签名存放在闪存存储器模块的系统存储区域,可以通过 JTAG/SWD 或者 CPU 读取。它所包含的芯片识别信息在出厂时编写,用户固件或者外部设备可以读取电子签名,用以自动匹配不同配置的该芯片。

## 23.1 存储器容量寄存器

### 23.1.1 闪存容量寄存器

基地址: 0x1FFF F7E0

只读,它的内容在出厂时编写

| 15    | 14 | 13 | 12 | 11      | 10 | 9     | 8       | 7 | 6    | 5     | 4     | 3  | 2 | 1 | 0 |
|-------|----|----|----|---------|----|-------|---------|---|------|-------|-------|----|---|---|---|
|       |    |    |    |         |    | F_SIZ | E[15:0] |   |      |       |       |    |   |   |   |
|       |    |    |    |         |    |       | r       |   |      |       |       |    |   |   |   |
| 位 15: | 0  | _  |    | 闪存存!位指示 |    |       |         |   | 例: 0 | x0080 | =128K | 字节 |   |   |   |

### 23.1.2 UID 寄存器 (96 位)

基地址: 0x1FFF F7E8

产品唯一的身份标识非常适合:

- 用来作为序列号(例如 USB 字符序列号或者其他的终端应用)
- 用来作为密码,在编写闪存时,将此唯一标识与软件加解密算法结合使用,提高代码在闪存存储器内的安全性。
- 用来激活带安全机制的自举过程。

96 位的产品唯一身份标识所提供的参考号码对任意一个 HK32 微控制器,在任何情况下都是唯一的。用户无论在何种情况下,都不能修改这个身份标识。这个 96 位的产品唯一身份标识,按照用户不同的用法,可以以字节(8 位)为单位读取,也可以以半字(16 位)或者全字(32 位)读取。

### 23.1.2.1 UID0 寄存器(U\_ID0)

偏移地址: 0x00

复位值: 0xXXXXXXXX

说明: 此处 X 表示出厂前编程设置。

U ID0 为 UID 的 0 到 15 位。

| 15     | 14 | 13    | 12      | 11  | 10   | 9      | 8            | 7       | 6     | 5 | 4 | 3 | 2 | 1 | 0 |
|--------|----|-------|---------|-----|------|--------|--------------|---------|-------|---|---|---|---|---|---|
|        |    |       |         |     |      | U_ID   | 0[15:0]      |         |       |   |   |   |   |   |   |
|        |    |       |         |     |      |        | r            |         |       |   |   |   |   |   |   |
|        |    |       |         |     |      |        |              |         |       |   |   |   |   |   |   |
| 位 15:0 | )  | U_ID0 | [15:0]: | 唯一身 | 份标志: | 15:0 位 | <u>(</u> (Un | ique IC | bits) |   |   |   |   |   |   |

### 23.1.2.2 UID1 寄存器(U ID1)

偏移地址: 0x02

复位值: 0xXXXX XXXX



### 说明: 此处 X 表示出厂前编程设置。

U\_ID1为UID的16到31位。

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

位 15:0

U\_ID1[15:0]: 唯一身份标志 31:16 位。(Unique ID bits)

这个域的数值也预留作为未来的其它功能。

## 23.1.2.3 UID2 寄存器(U\_ID2)

偏移地址: 0x04

复位值: 0xXXXXXXXX

说明: 此处 X 表示出厂前编程设置。

U\_ID2 为 UID 的 32 到 63 位。

| 31         | 30                                                                                | 29 | 28     | 27     | 26   | 25    | 24      | 23           | 22      | 21       | 20 | 19  | 18 | 17 | 16 |
|------------|-----------------------------------------------------------------------------------|----|--------|--------|------|-------|---------|--------------|---------|----------|----|-----|----|----|----|
|            |                                                                                   |    |        |        |      | •     | U_ID2   | [31:16]      |         |          | •  | •   |    |    | •  |
|            | r                                                                                 |    |        |        |      |       |         |              |         |          |    |     |    |    |    |
| 15         | 1/                                                                                | 13 | 2      | 12     | 11   | 10    | Q       | Q            | 7       | 6        | 5  | 1 2 | 2  | 1  | 0  |
| 13         | 15   14   13   12   11   10   9   8   7   6   5   4   3   2   1   0   U ID2[15:0] |    |        |        |      |       |         |              |         |          |    |     |    |    |    |
|            |                                                                                   |    |        |        |      |       | 0_102   | .[13.0]      |         |          |    |     |    |    |    |
|            |                                                                                   |    |        |        |      |       |         | ı            |         |          |    |     |    |    |    |
| <i>(</i> ) |                                                                                   |    |        |        |      | \ IL. |         | <b>)</b> . / |         |          |    |     |    |    |    |
| 位 31:0     | )                                                                                 | U  | ID2[31 | :01: 唯 | 医一身份 | }标志 € | 53:32 1 | ⊽.(Un        | iaue ID | ) bits ) |    |     |    |    |    |

偏移地址: 0x08

复位值: OxXXXXXXXX

说明: 此处 X 表示出厂前编程设置。

U ID3 为 UID 的 64 到 95 位。

|       | •                                                  |    |    |    |    |    |       |         |    |    |    |     |    |    |    |
|-------|----------------------------------------------------|----|----|----|----|----|-------|---------|----|----|----|-----|----|----|----|
| 31    | 30                                                 | 29 | 28 | 27 | 26 | 25 | 24    | 23      | 22 | 21 | 20 | 19  | 18 | 17 | 16 |
|       |                                                    |    |    |    |    |    | U_ID3 | [31:16] |    |    |    |     |    |    |    |
|       |                                                    |    |    |    |    |    |       | r       |    |    |    |     |    |    |    |
| 15    | 14                                                 | 13 | 3  | 12 | 11 | 10 | 9     | 8       | 7  | 6  | 5  | 4 3 | 2  | 1  | 0  |
|       | U ID3[15:0]                                        |    |    |    |    |    | -     |         |    |    |    |     |    |    |    |
|       | r                                                  |    |    |    |    |    |       |         |    |    |    |     |    |    |    |
| 位 31: | 位 31:0 U_ID3[31:0]: 唯一身份标志 95:64 位(Unique ID bits) |    |    |    |    |    |       |         |    |    |    |     |    |    |    |



## 24 调试支持(DBG)

### 24.1 概况

器件使用 Cortex®-M3 内核,该内核内含硬件调试模块,支持复杂的调试操作。硬件调试模块允许内核在取指(指令断点)或访问数据(数据断点)时停止。内核停止时,内核的内部状态和系统的外部状态都是可以查询的。完成查询后,内核和外设可以被复原,程序将继续执行。

当器件连接到调试器并开始调试时,调试器将使用内核的硬件调试模块进行调试操作。

支持两种调试接口:

- 串行接口
- JTAG 调试接口



图 24-1 HK32F103x8xB 和 Cortex®-M3 级别的调试框图

注意:Cortex®-M3 内核内含的硬件调试模块是ARM®CoreSight 开发工具集的子集。

ARM®Cortex®-M3 内核提供集成的片上调试功能。它由以下部分组成:

- SWJ-DP: 串行/JTAG 调试端口
- AHP-AP: AHB 访问端口
- ITM: 执行跟踪单元
- FPB: 闪存指令断点
- DWT: 数据触发



- TPIU: 跟踪单元接口(仅支持 SWV 异步模式(TRACESWO 会被使用)) 它还包含专用于该芯片的调试特性:
- 灵活的调试引脚分配
- MCU 调试盒(支持低电源模式,控制外设时钟等)

注意: 更多ARM Cortex®-M3 内核的调试功能信息,请参考 Cortex®-M3(r1p1 版)技术参考手册(TRM)和 CoreSight 开发工具集(r1p0 版)TRM。

# 24.2 ARM®参考文献

- Cortex®-M3 (r1p1 版) 技术参考手册 (TRM)
- ARM®调试接口 V5
- ARM®CoreSight 开发工具集(r1p0 版)技术参考手册

# 24.3 SWJ 调试端口

器件内核集成了串行/JTAG 调试接口(SWJ-DP)。这是标准的 ARM® CoreSight 调试接口,包括 JTAG-DP 接口(5 个引脚)和 SW-DP 接口(2 个引脚)。

- JTAG 调试接口(JTAG-DP)为 AHP-AP 模块提供 5 针标准 JTAG 接口。
- 串行调试接口(SW-DP)为 AHP-AP模块提供2针(时钟+数据)接口。

在 SWJ-DP 接口中, SW-DP 接口的 2 个引脚和 JTAG 接口的 5 个引脚中的一些是复用的。



图 24-2 SWJ 调试端口

上面的图显示异步跟踪输出脚(TRACESWO)和 TDO 是复用的,因此异步跟踪功能只能在 SW-DP 调试接口上实现,不能在 JTAG-DP 调试接口上实现。

## 24.3.1 JTAG-DP 和 SW-DP 切换的机制

JTAG 调试接口是默认的调试接口。

如果调试器想要切换到 SW-DP,必须在 TMS/TCK 上输出一指定的 JTAG 序列(分别映射到 SWDIO和 SWCLK),该序列禁止 JTAG-DP,并激活 SW-DP。该方法可以只通过 SWCLK和 SWDIO两个引脚来激活 SW-DP接口。

指定的序列是:



- L. 输出超过 50 个 TCK 周期的 TMS(SWDIO) =1 信号
- 2. 输出 16 个 TMS(SWDIO)信号 0111100111100111(MSB)
- 3. 输出超过 50 个 TCK 周期的 TMS (SWDIO) =1 信号

### 24.3.2 SWJ 调试端口脚

该芯片的 5个普通 I/O 口可用作 SWJ-DP 接口引脚。这些引脚在所有的封装里都存在。

SWJ-DP 端口引脚名称 JTAG 调试接口 SW 调试接口 引脚分配 类型 描述 类型 调试功能 JTMS/SWDIO 输入/输出 串行数据输入/输出 PA13 输入 JTAG 模式选择 JTCK/SWCLK 输入 JTAG 时钟 输入 串行时钟 PA14 JTDI JTAG 数据输入 PA15 输入 JTDO/TRACESWO 输出 JTAG 数据输出 跟踪时为 TRACESWO 信号 PB3 **JNTRST** 输入 JTAG 模块复位 PB4

表 24-1 SWJ 调试端口引脚

## 24.3.3 灵活的 SWJ-DP 脚分配

复位(SYSRESETn 或 PORESETn)以后,属于 SWJ-DP 的所有 5 个引脚都立即被初始化为可被调试器使用的专用引脚(注意,并没有初始化跟踪输出脚,除非调试器对此脚进行定义)。

然而,该微控制器可以用复用重映射和调试 I/O 配置寄存器(AFIO\_MAPR)寄存器(详见章节: "9.4.2 复用重映射和调试 I/O 配置寄存器(AFIO\_MAPR)")来禁止 SWJ-DP 接口的部分或所有引脚的功能,这些专用引脚将被释放以用作普通 I/O 口。此寄存器被映射到和 Cortex®-M3 系统总线相连接的 APB 桥上。对此寄存器的设置将由用户代码而不是调试器完成。

- 3 个控制位用来配置 SWJ-DP 接口的引脚, 这 3 个位在系统复位时复位。
- AFIO\_MAPR(该微控制器中的地址是 0x40010004)
  - 。 读: APB, 无等待状态。
  - 。 写: APB,如果 AHB-APB 桥的写缓冲器满了,则一个等待状态位 26:24=SWJ\_CFG[2:0]由软件置位和复位。

这 3 位用来设置分配给 SWJ 调试接口的专用引脚数目,目的是在使用不同的调试接口时能释放尽可能多的引脚用作普通 I/O 口。

复位后的初始值是 000 (所有引脚都设置为 JTAG-DP 接口专用引脚),同时只能置位 3 个位中的一个 (禁止同时设置一个以上的位)。

| SWJ-CFG[2:0] | 配置为调试专用 的引脚                           | SWJ 接口的 I/O 口分配     |                     |           |          |            |  |  |
|--------------|---------------------------------------|---------------------|---------------------|-----------|----------|------------|--|--|
|              | #17 21 1441                           | PA13/JTMS/S<br>WDIO | PA14/JTCK/SW<br>CLK | PA15/JTDI | PB3/JTDO | PB4/JNTRST |  |  |
| 000          | 所有的 SWJ 引脚<br>(JTAG-DP+SW-<br>DP)复位状态 | 专用                  | 专用                  | 专用        | 专用       | 专用         |  |  |

表 24-2 灵活的 SWJ\_DP 引脚分配



| SWJ-CFG[2:0] | 配置为调试专用                                            | SWJ 接口的 I/O 口分配     |                     |           |          |            |  |  |  |
|--------------|----------------------------------------------------|---------------------|---------------------|-----------|----------|------------|--|--|--|
|              | 的引脚                                                | PA13/JTMS/S<br>WDIO | PA14/JTCK/SW<br>CLK | PA15/JTDI | PB3/JTDO | PB4/JNTRST |  |  |  |
| 001          | 所有的 SWJ 引脚<br>(JTAG-DP+SW-<br>DP) 除 了<br>JNTRST 引脚 | 专用                  | 专用                  | 专用        | 专用       | 释放         |  |  |  |
| 010          | JTAG-DP 接口禁止,SW-DP 接口允许                            | 专用                  | 专用                  | 释放        |          |            |  |  |  |
| 100          | JTAG-DP 接口和<br>SW-DP 接口都禁<br>止                     | 释放                  |                     |           |          |            |  |  |  |
| 其他           | 禁止                                                 |                     |                     |           |          |            |  |  |  |

#### 注意:

当 APB 桥的写缓冲区满了的时候,在写 AFIO\_MAPR 寄存器时需要多用一个 APB 周期。这是因为 JTAGSW 脚的释放需要 2 个 APB 周期,以保证输入内核的 nTRST 和 TCK 信号的平稳。

周期1: 输入1/0 的JTAGSW 信号到内核(nTRST, TDI 和TMS 为1, TCK 为0)。

周期 2: GPIO 控制器获得 SWJTAG I/O 引脚的控制信号(如对方向,上拉/下拉,施密特触发等的控制)。

### 24.3.4 JTAG 脚上的内部上拉和下拉

保证 JTAG 的输入引脚不是悬空的是非常必要的,因为他们直接连接到 D 触发器控制着调试模式。必须特别注意 SWCLK/TCK 引脚,因为他们直接连接到一些 D 触发器的时钟端。

为了避免任何未受控制的 I/O 电平,该芯片在 JTAG 输入脚上嵌入了内部上拉和下拉。

- JINTRST: 内部上拉
- JTDI: 内部上拉
- JTMS/SWDIO: 内部上拉
- TCK/SWCLK: 内部下拉
- 一旦 JTAG I/O 被用户代码释放,GPIO 控制器再次取得控制。这些 I/O 口的状态将恢复到复位时的状态:
  - JNTRST: 带上拉的输入
  - JTDI: 带上拉的输入
  - JTMS/SWDIO: 带上拉的输入
  - JICK/SWCLK: 带下拉的输入
  - JTDO: 浮动输入

软件可以把这些 I/O 口作为普通的 I/O 口使用。

注意: JTAG EEE 标准建议对 TDI, TMS 和 nTRST 上拉, 而对 TCK 没有特别的建议。但在该芯片中, JTCK 引脚带有下拉。内嵌的上拉和下拉使芯片不再需要外加外部电阻。



### 24.3.5 利用串行接口并释放不用的调试脚作为普通 I/O 口

为了利用串行调试接口来释放一些普通 I/O 口,用户软件必须在复位后设置 SWJ\_CFG=010,从而释放 PA15, PB3 和 PB4 用做普通 I/O 口。

在调试时,调试器进行以下操作:

- 在系统复位时,所有 SWJ 引脚被分配为专用引脚(JTAG-DP+SW-DP)。
- 在系统复位状态下,调试器发送指定 JTAG 序列,从 JTAG-DP 切换到 SW-DP。
- 仍然在系统复位状态下,调试器在复位地址处设置断点。
- 释放复位信号,内核停止在复位地址处。
- 从这里开始,所有的调试通信将使用 SW-DP 接口,其他 JTAG 引脚可以由用户代码改配为普通 I/O 口。

对于用户软件设计,应注意:

在复位后,这些专用引脚仍然处于带上拉的输入(nTRST, TMS, TDI),带下拉的输入(TCK),和 输出(TDO)状态,并持续一段时间,直到用户代码释放这些引脚。当这些引脚被配置成专用引脚时 (JTAG 或者 SW 或者 TRACE),修改相应的普通 I/O 口配置寄存器是无效的。

### 24.4 JTAG TAP 连接

器件内部串联了两个 JTAG TAP。边界扫描 TAP 专门用来进行测试(IR 寄存器为 5 位宽)和 Cortex®-M3 TAP(IR 寄存器为有 4 位宽)。

为了访问 Cortex®-M3 TAP 对芯片进行调试,必须:

- 1. 首先,必须将 BYPASS 指令移位输入 TMC TAP。
- 2. 其次,在移位输入 IR 时,每个扫描链包含 9 位(=5+4),对于不用的 TAP,必须输入 BYPASS 指令。
- 移位输入数据时,不用的 TAP 处于 BYPASS 模式下,因此数据扫描链需要额外添加一位。

注意:一旦使用了指定的JTAG 序列选择了串行调试接口,TMCTAP 自动被禁止(JTMS 被强制为高)。



图 24-3 HK32F103x8xB 的 JTAG TAP 连接



## 24.5 ID 代码和锁定机制

在器件微控制器内部有多个 ID 编码。强烈建议工具设计者使用映射在外部 PPB 存储器上地址为 0xE0042000 的 MCU DEVICE ID 来锁定调试器。

### 24.5.1 微控制器设备 ID 编码

微控制器内含一个 MCUID 编码。这个 ID 定义了 MCU 的部件号和硅片版本。它是 DBG\_MCU 的一个组成部分,并且映射到外部 PPB 总线上(详见章节: "24.14MCU 调试模块(MCUDBG)")。使用 JTAG 调试口(4~5 个引脚)或 SW 调试口(2 个引脚)或通过用户代码都可以访问此编码。即使当 MCU 处于系统复位状态下这个编码也可以被访问。

### 24.5.1.1 MCU 器件 ID 代码(DBGMCU\_IDCODE)

地址: 0xE0042000 只支持 32 位访问

只读=0xXXXXX410,其中 X 为内容不确定的位

| 31 30   | 29                                   | 28 27                      | 26                 | 25      | 24      | 23       | 22 | 21     | 2 | 0 | 19 | 18 | 17 | 16 |
|---------|--------------------------------------|----------------------------|--------------------|---------|---------|----------|----|--------|---|---|----|----|----|----|
|         |                                      |                            |                    |         | REV_I   | D[15:0]  |    |        |   |   |    |    |    |    |
|         |                                      |                            |                    |         |         | r        |    |        |   |   |    |    |    |    |
| 15 14   | 13                                   | 12                         | 11                 | 10      | 9       | 8        | 7  | 6      | 5 | 4 | 3  | 2  | 1  | 0  |
|         | Res                                  |                            |                    |         |         |          | DE | V_ID[1 |   | - |    |    |    |    |
|         |                                      |                            |                    |         |         |          |    | r      |   |   |    |    |    |    |
| 位 31:16 | 该域标<br>• 0x000<br>• 0x200<br>• 0x200 | [15:0]:                    | 版本。<br>A<br>B<br>Z | J(Revis | ion ide | entifier | )  |        |   |   |    |    |    |    |
| 位 15:12 | Res: 保<br>必须保                        | R留<br>持复位值                 | . О                |         |         |          |    |        |   |   |    |    |    |    |
| 位 11:0  | 这个部分                                 | [11:0]: 讠<br>分指示了<br>芯片: 设 | 设备编                | 码。      |         | ntifier) |    |        |   |   |    |    |    |    |

### 24.5.2 边界扫描 TAP

### 24.5.2.1 JTAGID 编码

器件的边界扫描 TAP 集成了 JTAG ID 编码:

0x06410041: 版本 A

• 0x16410041: 版本 B 和版本 Z

#### 24.5.3 Cortex-M3 TAP

ARM®Cortex®-M3 的 TAP 有一个 JTAGID 编码。这个 ID 编码是 ARM®默认的,且没有被修改过,只能通过 JTAG 调试口访问。此编码是 0x3BA00477(对应于 Cortex®-M3 r1p1)。



调试器/编程工具应该只通过 DEV\_ID(11:0)来识别芯片。

## 24.5.4 Cortex-M3 JEDEC-106 ID 代码

ARM®的 Cortex®-M3 有一个 JEDEC-106 ID 编码。它位于映射到内部 PPB 总线地址为 0xE00FF000-0xE00FFFFF 的 4KB ROM 表中。

# 24.6 JTAG 调试端口

标准的 JTAG 状态机是通过一个 4 位的指令寄存器(IR)和 5 个数据寄存器实现的(详见 Cortex®-*M3 r1p1 Technical Reference Manual*)。

表 24-3 JTAG 调试端口数据寄存器

| IR (3:0) | 数据寄存器        | 描述                                                      |
|----------|--------------|---------------------------------------------------------|
| 1111     | BYPASS[1 位]  |                                                         |
| 1110     | IDCODE[32 位] | ID 编码寄存器<br>0x3BA00477(ARM®Cortex-M3 r1p1-01rel0 ID 编码) |
| 1010     | DPACC[32 位]  | 调试接口寄存器 初始化调试端口,并允许访问调试接口寄存器。  ● 输入数据时:                 |
| 1011     | APACC[35 位]  | 存取接口寄存器 初始化存取接口并允许访问存取接口寄存器  ● 输入数据时:                   |
| 1000     | ABORT[35 位]  | 中止寄存器                                                   |



| IR (3:0) | 数据寄存器 | 描述                                                                   |
|----------|-------|----------------------------------------------------------------------|
|          |       | <ul><li> 位 31:1 未定义</li><li> 位 0=DAPABORT: 写 1 产生一个 DAP 中止</li></ul> |

#### 表 24-4 由 A[3:2]定义的 32 位调试接口寄存器地址

| 地址  | A(3:2)值 | 描述                                                                                                                                      |
|-----|---------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 0x0 | 00      | 未定义                                                                                                                                     |
| 0x4 | 01      | DPCTRL/STAT 寄存器,用于:     请求一个系统或调试的上电操作     配置 AP 访问的操作模式     控制比较,校验操作     读取一些状态位(溢出,上电响应)                                             |
| 0x8 | 10      | DPSELECT 寄存器 用来选择当前的访问端口和有效的 4 字长寄存器窗口  ● 位 31:24: APSEL 选择当前 AP  ● 位 23:8: 未定义  ● 位 7:4: APBANKSEL: 在当前 AP 上选择 4 字长寄存器窗口  ● 位 3:0: 未定义 |
| 0xC | 11      | DPRDBUFF 寄存器:用来使调试器获得前一次操作的最终结果(不用再请求一个新的 JTAG-DP 操作)                                                                                   |

## 24.7 SW 调试端口

## 24.7.1 SW 协议介绍

此同步串行协议使用 2 个引脚:

- SWCLK: 从主机到目标的时钟信号
- SWDIO: 双向数据信号

协议允许读写 2 个寄存器组(DPACC 和 APACC 寄存器组)。

数据位按 LSB 传输。

由于 SWDIO 为双向口,该引脚需有上拉 (ARM®建议使用 100KΩ 电阻)。

按协议每次 SWDIO 方向改变时,需插入一个转换时间。在该期间内主机和目标都不驱动此信号线。 转换时间的默认值是 1 个比特,但可以通过配置 SWCLK 频率来调节。

## 24.7.2 SW 协议序列

每个序列由 3 个阶段组成:

- 1. 主机发送包请求(8位)
- 2. 目标发送确认响应(3位)
- 3. 主机或目标发送数据(33位)



### 表 24-5 请求包 (8 位)

| 比特位 | 名称      | 描述                                      |
|-----|---------|-----------------------------------------|
| 0   | 起始      | 必须为1                                    |
| 1   | APnDP   | ● 0: 访问 DP<br>● 1: 访问 AP                |
| 2   | RnW     | <ul><li>0: 写请求</li><li>1: 读请求</li></ul> |
| 4:3 | A (3:2) | DP 或 AP 寄存器的地址(请参考 0)                   |
| 5   | Parity  | 前面比特位的校验位                               |
| 6   | Stop    | 0                                       |
| 7   | Park    | 不能由主机驱动,由于有上拉,目标永远读为1                   |

有关 DPACC 和 APACC 寄存器描述的详细资料,请参考 Cortex®-M3 r1p1 技术参考手册。包请求后总是跟一个(默认为1位)转换时间,此时主机和目标都不驱动线路。

表 24-6 ACK 定义(3位)

| 比特位 | 名称  | 描述                                                        |
|-----|-----|-----------------------------------------------------------|
| 02  | ACK | <ul><li>001: 失败</li><li>010: 等待</li><li>100: 成功</li></ul> |

当 ACK 为失败或等待,或者是一个回复读操作的 ACK, 此 ACK 后有一个转换时间。

表 24-7 传输数据(33 位)

| 比特位 | 名称          | 描述           |
|-----|-------------|--------------|
| 031 | WDATA/RDATA | 写或读的数据       |
| 32  | Parity      | 32 位数据的奇偶校验位 |

读操作的数据传输操作后有一个转换时间。

### 24.7.3 SW-DP 状态机(Reset, idlestates, IDcode)

SW-DP 状态机有一个内部 ID 编码用来识别 SW-DP, 它遵守 JEP-106 标准。此 ID 编码是 ARM®默认的编码,值为 0x1BA01477 (对应于 Cortex-M3 r1p1)。

注意: 在调试器读这个ID 编码之前, SW-DP 的状态机是不工作的。

- SW-DP 状态机在以下条件下将处于复位状态:
  - 。 上电复位。
  - 。 DP 从 JTAG 切换到 SWD 后。
  - 。 线路有超过 50 个周期的高电平。
- SW-DP 状态机在此条件下处于空闲状态:复位后,线路有至少 2 个周期的低电平。
- 当状态机处于 RESET 状态后,必须首先进入 IDLE 状态,并执行一个读 DP-SWID 寄存器的操作。否则,调试器在执行其他传输时,只能获得一个失败的 ACK 响应。



更详细的 SW-DP 状态机资料请参考 Cortex-M3 r1p1 技术参考手册和 Core Sight Design Kit r1p0 技术参考手册。

### 24.7.4 DP 和 AP 读/写访问

- 对 DP 的读操作没有延迟: 调试器将直接获得数据(如果"ACK=OK"),或者等待(如果"ACK=WAIT")。
- 对 AP 的读操作具有延迟。即前一次读操作的结果只能在下一次操作时获得。如果下一次的操作不是对 AP 的访问,则必须读 DP-RDBUFF 寄存器来获得上一次读操作的结果。
- DP-CTRL/STAT 寄存器的 READOK 标志位会在每次 AP 读操作和 RDBUFF 读操作后更新,以通知调试器 AP 的读操作是否成功。
- SW-DP 具有写缓冲区(DP 和 AP 都有写缓冲),这使得其他传输在进行时,仍然可以接受写操作。如果写缓冲区满,调试器将获得一个"WAIT"的 ACK 响应。读 IDCODE 寄存器,读 CTRL/STAT 寄存器和写 ABORT 寄存器操作在写缓冲区满时仍被接受。
- 由于 SWCLK 和 HCLK 的异步性,需要在写操作后(在奇偶校验位后)插入 2 个额外的 SWCLK 周期,以确保内部写操作正确完成。这两个额外的时钟周期需要在线路为低时插入(IDLE 状态下)。这个操作步骤在写 CTRL/STAT 寄存器以提出一个上电请求时尤其重要,否则下一个操作(在内核上电后才有效的操作)会立即执行,这将导致失败。

### 24.7.5 SW-DP 寄存器

当 APnDP=0 时,可以访问以下这些寄存器。

A (3:2) 读/写 SELECT 寄存器的 寄存器 描述 CTRLSEL 位 00 IDCODE 读 固定为 0x1BA01477 (用于识别 SW-DP)。 00 写 **ABORT** 读/写 DP-CTRL/STAT 01 请求一个系统或调试的上电操作; 配置 AP 访问的操作模式; 控制比较,校验操作; 读取一些状态位(溢出,上电响应)。 读/写 WIRE CONTROL 01 1 配置串行通信物理层协议(如转换时间长度等)。 10 读 **READ RESEND** 允许从一个错误的调试传输中恢复数据而不用重复最 初的 AP 传输。 10 写 **SELECT** 选择当前的访问端口和有效的4字长寄存器窗口。 **READ BUFFER** 由于 AP 的访问具有传递性(当前 AP 读操作的结果会 11 读/写 在下次 AP 传输时传出),因此这个寄存器非常必要。 这个寄存器会从 AP 捕获上一次读操作的数据结果, 因此可以获得数据而不必再启动一个新的 AP 传输。

表 24-8 SW-DP 寄存器

### 24.7.6 SW-AP 寄存器

当 APnDP=1 时,可以访问以下这些寄存器。

AP 寄存器的访问地址由以下两部分组成:

• A[3:2]的值。



• DPSELECT 寄存器的当前值。

# 24.8 对于 JTAG-DP 或 SWDP 都有效的 AHB-AP(AHB 访问端口)

功能:

- 系统访问是独立于处理器状态的
- JTAG-DP 和 SW-DP 都可以访问 AHB-AP
- AHB-AP 是总线矩阵的 AHB 主设备。因此,它可以访问所有的数据总线(Dcode 总线, System 总线,内部和外部 PPB 总线),只有 ICode 总线除外。
- 支持位寻址的传输
- 旁路 FPB 的 AHB-AP 传输

32 位 AHP-AP 寄存器的地址是 6-位宽(最多 64 个字或 256 个字节),由以下部分组成:

- 位[8:4]=DPSELECT 寄存器的位[7:4]APBANKSEL
- 位[3:2]=35 位 SW-DP 包请求中的 A (3:2)。

Cortex®-M3 的 AHB-AP 有 9 个 32 位的寄存器。

表 24-9 Cortex®-M3 AHB-AP 寄存器

|      | 次 24-5 COITEX - INIO ATTO-AT ATTO-AT |                                         |  |  |  |  |
|------|--------------------------------------|-----------------------------------------|--|--|--|--|
| 偏移地址 | 寄存器名                                 | 描述                                      |  |  |  |  |
| 0x00 | AHB-AP Control and Status Word       | 配置 AHB 接口的传输特性(长度,地址自加模式,当前传输状态,特权模式等)。 |  |  |  |  |
| 0x04 | AHB-AP Transfer Address              | -                                       |  |  |  |  |
| 0x0C | AHB-AP Data Read/Write               | -                                       |  |  |  |  |
| 0x10 | AHB-AP Banked Data0                  | 直接访问 4 个相连的字而不用重写访问地址。                  |  |  |  |  |
| 0x14 | AHB-AP Banked Data1                  |                                         |  |  |  |  |
| 0x18 | AHB-AP Banked Data2                  |                                         |  |  |  |  |
| 0x1C | AHB-AP Banked Data3                  |                                         |  |  |  |  |
| 0xF8 | AHB-AP Debug ROM Address             | 调试接口的基地址。                               |  |  |  |  |
| 0xFC | AHB-AP ID Register                   | -                                       |  |  |  |  |

更多信息请参考 Cortex®-M3 r1p1 技术参考手册。

# 24.9 内核调试

通过操作内核调试寄存器可以实行对内核的调试。对这些寄存器的访问通过先进高性能总线 (AHB-AP) 进行。处理器可以通过内部私有外设总线(PPB)直接访问这些寄存器。

它包括 4 个寄存器。

表 24-10 内核调试寄存器

| 寄存器   | 描述                                              |
|-------|-------------------------------------------------|
| DHCSR | 32 位的调试控制和状态寄存器此寄存器提供内核状态信息,允许内核进入调试模式,和提供单步功能。 |
| DCRSR | 17 位的内核寄存器调试选择寄存器                               |



| 寄存器   | 描述                                                           |  |  |  |  |  |
|-------|--------------------------------------------------------------|--|--|--|--|--|
|       | 此寄存器选择需要进行读写操作的内核寄存器。                                        |  |  |  |  |  |
| DCRDR | 32 位的内核寄存器调试数据寄存器<br>此寄存器存放由 DCRSR 选择的内核寄存器读出的或需要写入的数据。      |  |  |  |  |  |
| DEMCR | 32 位异常调试和监视控制寄存器<br>此寄存器提供向量传输和监视调试控制功能。TRCENA 位启动 TRACE 功能。 |  |  |  |  |  |

### 注意: 这些寄存器在系统复位时不复位, 仅在上电复位时复位。

更多详细资料请参考 Cortex®-M3 r1p1 技术参考手册。

为了在复位后立即使内核进入调试状态,需要:

- 使能调试和异常监视控制寄存器的位 0(VC\_CORRESET)。
- 使能调试控制和状态寄存器的位 0(C DEBUGEN)。

## 24.10 调试器主机在系统复位下的连接能力

该芯片的复位系统由下列复位源组成:

- POR (上电复位), 在每次上电时发起一次复位
- 内部看门狗复位
- 软件复位
- 外部复位

Cortex®-M3 将调试部分的复位(通常是 PORRESETn)和其他复位(SYSRESETn)区分开。因此,当内核处于系统复位状态时,调试器可以连接到内核,配置内核调试寄存器,使能调试允许位,这样操作使内核在系统复位被释放时立即进入调试状态而不执行任何指令。同样的,可以在内核处于复位状态下时配置调试特性。

注意: 强烈建议调试器在系统复位时连接内核(在复位向量处设置断点)。

### 24.11 FPB

FPB 单元:

- 实现硬件断点。
- 用系统区域的代码和数据取代代码区域的代码和数据。此特性可以用来纠正代码区域内的软件 错误。

软件补丁功能和硬件断点功能不能同时使用。

FPB 由以下部分组成:

- 2个内容比较器,用来比较代码区域取得的内容并重映射到系统区域的相关地址。
- 6个指令比较器,用来比较代码区域的指令。这些比较器可用来实现软件补丁或者硬件断点功能。

## 24.12 数据观察点触发(DWT)

DWT 模块由四个比较器组成,它们分别是:

- 一个硬件数据比较器
- 一个 PC 值取样器
- 一个数据地址取样器



DWT 还可用来获取某些侧面的信息。通过一些计数器可以获得以下数据:

- 时钟周期
- 分支指令
- 存取单元操作
- 睡眠周期
- CPI (每条指令的执行时间)
- 中断开销

## 24.13 指令跟踪微单元(ITM)

### 24.13.1 概述

ITM 是一应用驱动的跟踪源,它支持 *printf* 类的调试手段来跟踪操作系统(OS)和应用事件,并发布判定的系统信息。ITM 以包的形式发布跟踪信息,它由以下部分组成:

- 软件跟踪:软件可以通过直接写 ITM 激发寄存器来发布包信息。
- 硬件跟踪: ITM 会发布由 DWT 产生的信息包。
- 时间戳:时间戳被发布到相应的包上。ITM 包含一个 21 位的计数器以产生时间戳。Cortex-M3 的时钟或串行线观测器的位时钟率给计数器提供时钟。

由 ITM 发送的信息包输出到跟踪端口接口单元(TPIU),TPIU 再添加一些额外的包(参考 TPIU),然后输出完整的包序列给调试器。

用户在设置或使用 ITM 之前,必须先使能异常调试和监视控制寄存器的 TRCEN 位。

### 24.13.2 时间戳包,同步和溢出包

时间戳包包含了时间戳信息,普通的控制和同步信息。它使用一个 21 位的时间戳计数器(及可能的预分频器),此计数器在每个时间戳包发放时复位。计数器的时钟可以是 CPU 时钟也可以是 SWV 时钟。

同步包为  $0x80_00_00_00_00_0$ ,按 000000000000 发送给 TPIU (LSB 在前)。同步包是时间戳包的控制信号。

它也在每个 DWT 触发时发送,因此 DWT 必须配置为触发 ITM: 必须设置 DWT 控制寄存器的位 0 (CYCCNTENA)。此外,也必须设置 ITM 跟踪控制寄存器的位 2 (SYNCENA)。

注意:如果 SYNENA 位没有被置起,DWT 产生给 TPIU 的同步触发,将只发送 TPIU 同步包而不发送 ITM 同步包。

溢出包是一个特殊的时间戳包,该包指示数据已经被写但是 FIFO 已满。

表 24-11 主要的 ITM 寄存器

| 地址        | 寄存器             | 描述                          |
|-----------|-----------------|-----------------------------|
| @E0000FB0 | ITM Lock Access | 写入 0xC5ACCE55 允许写其他 ITM 寄存器 |



| 地址                     | 寄存器                          | 描述                                                                                                                                                                                                                                                                                                                                                                 |
|------------------------|------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| @E0000E80              | ITM Trace Control            | <ul> <li>● 位[31:24]: 总是 0</li> <li>● 位 23: busy</li> <li>● 位[22:16]: 7 位的 ATBID 用以识别跟踪数据源</li> <li>● 位[15:10]: 总是 0</li> <li>● 位[9:8]: 时间戳的预分频</li> <li>● 位[7:5]: 未定义</li> <li>● 位 4: 使能 SWV 功能即时间戳计数器使用 SWV 时钟</li> <li>● 位 3: 使能 DWT 的激发功能</li> <li>● 位 2: 此位必须设为 1 来使能 DWT 的产生同步触发功能,以使TPIU 能够发送同步包</li> <li>● 位 1: 时间戳使能</li> <li>● 位 0: ITM 的全局使能位</li> </ul> |
| @E0000E40              | ITM Trace Privilege          | <ul> <li>位3: 置'1'使能跟踪端口[31:24]</li> <li>位2: 置'1'使能跟踪端口[23:16]</li> <li>位1: 置'1'使能跟踪端口[15:8]</li> <li>位0: 置'1'使能跟踪端口[7:0]</li> </ul>                                                                                                                                                                                                                                |
| @E0000E00              | ITM Trace Enable             | 每个比特位使能相应的触发端口产生跟踪                                                                                                                                                                                                                                                                                                                                                 |
| @E0000000-<br>E000007C | Stimulus Port Registers 0-31 | 向选中的产生跟踪的触发端口(32个)写 32 位数据                                                                                                                                                                                                                                                                                                                                         |

### 关于配置的例子:

向 TUIU 输出一个简单值:

- 配置 TPIU 并使能 I/IO\_TRACEN 以使 MCU 分配 TRACE 的引脚(参见:"跟踪引脚分配"和"调试 MCU 配置寄存器");
- 向 ITM Lock Access 寄存器写入 0xC5ACCE55,以允许写其他 ITM 寄存器;
- 向 Trace Control 寄存器写入 0x00010005,使能 TPIU 的同步包并使能整个 ITM 功能,寄存器中的 ATBID 为 0x01;
- 向 ITM Trace Enable 寄存器写入 0x1,以使能触发端口 0;
- 向 ITM Trace Privilege 寄存器写入 0x1,关闭对触发端口 7:0 的屏蔽;
- 把需要输出的值写入触发端口 0 寄存器,这个步骤可以通过软件完成(使用 printf 功能)。

## 24.14 MCU 调试模块(MCUDBG)

MCU 调试模块协助调试器提供以下功能:

- 低功耗模式
- 在断点时提供定时器、看门狗、I2C 和 bxCAN 的时钟控制
- 对跟踪脚分配的控制

### 24.14.1 低功耗模式的调试支持

使用 WFI 和 WFE 可以进入低功耗模式。

MCU 支持多种低功耗模式,分别可以关闭 CPU 时钟,或降低 CPU 的能耗。

内核不允许在调试期间关闭 FCLK 或 HCLK。这些时钟对于调试操作是必要的,因此在调试期间,它们必须工作。MCU 使用一种特殊的方式,允许用户在低功耗模式下调试代码。



为实现这一功能,调试器必须先设置一些配置寄存器来改变低功耗模式的特性。

- 在睡眠模式下,调试器必须先置位 DBGMCU\_CR 寄存器的 DBG\_SLEEP 位。这将为 HCLK 提供与 FCLK(由代码配置的系统时钟)相同的时钟。
- 在停机/待机模式下,调试器必须先置位 DBG\_STOP/DBG\_STANDBY 位。这将激活内部 RC 振荡器,在停止模式下为 FCLK 和 HCLK 提供时钟。

### 24.14.2 支持定时器、看门狗、bxCAN 和 I2C 的调试

在产生断点时,有必要根据定时器和看门狗的不同用途选择计数器的工作模式:

- 在产生断点时, 计数器继续计数。这在输出 PWM 控制电机时常要用到。
- 在产生断点时, 计数器停止计数。这对于看门狗的计数器是必需的。

对于 bxCAN,用户可以选择在断点期间阻止接收寄存器的更新。对于 I2C,用户可以选择在断点期间阻止 SMBUS 超时。

### 24.14.3 MCU 调试配置寄存器

基地址: 0xE0042000

此寄存器允许在调试状态下下配置 MCU。包括:

- 支持低功耗模式
- 支持定时器和看门狗的计数器
- 支持 bxCAN 通信
- 分配跟踪引脚

DBGMCU\_CR 寄存器被映射到外部 PPB 总线,基地址为 0xE004 2000。寄存器由 PORESET 异步复位(不被系统复位所复位)。当内核处于复位状态下时,调试器可写该寄存器。如果调试器不支持这些特性,用户软件仍可写这些寄存器。

# 24.14.4 调试 MCU 配置寄存器(DBGMCU\_CR)

偏移地址: 0xE0042004

POR 复位: 0x00000000 (不被系统复位所复位)

只支持 32 位访问

| 31 | 30     | )   | 29  | 28 | 27    | 26 | 25   | 24    | 23 | 22    | 21 | 20     | 19   | 18        | 17      |       |    |       | 16   |       |
|----|--------|-----|-----|----|-------|----|------|-------|----|-------|----|--------|------|-----------|---------|-------|----|-------|------|-------|
|    | Res    |     |     |    |       |    |      |       |    |       |    |        | DB   | G_I2C2_SN | /BUS_TI | MEOUT |    |       |      |       |
|    |        |     |     |    |       |    |      |       |    |       |    | rw     |      |           |         |       |    |       |      |       |
|    | -      | _   |     | 1  |       | -  |      |       |    | _     |    |        | -    | -         | -       |       | 2  | _     |      |       |
|    | 1.     | 5   |     |    | 14    | 1  | 1    | 1     | 1  | 9     |    | 8      | 7    | 6         | 5       | 4     | 3  | 2     | 1    | 0     |
|    |        |     |     |    |       | 3  | 2    | 1     | 0  |       |    |        |      |           |         |       |    |       |      |       |
| DB | 3G_I2  | C1_ | _SM | D  | BG_C  | D  | BG_T | IMx_S | 5  | DBG_' | W  | DBG_IW | TRAC | E_M       | TRACE   | Re    | es | DBG_S | DBG  | DBG_  |
| BU | IS_TIN | ME  | OUT | A١ | N_STC | )  | TC   | )P    | ١  | NDG_  | ST | DG_STO | ODE[ | 1:0]      | _IOEN   |       |    | TANDB | _STO | SLEEP |
|    |        |     |     |    | Р     |    |      |       |    | OP    |    | Р      |      |           |         |       |    | Υ     | Р    |       |
|    | rv     | N   |     |    | rw    |    | r١   | ٧     |    | rw    |    | rw     | rv   | V         | rw      |       |    | rw    | rw   | rw    |

| 位 31:17 | Res: 保留<br>必须保持复位值。                                                                                                               |
|---------|-----------------------------------------------------------------------------------------------------------------------------------|
| 位 16    | DBG_I2C2_SMBUS_TIMEOUT: 当内核停止时停止 SMBUS 超时模式(I2C2 SMBUS timeout mode stopped when core is halted)  O: 与正常模式操作相同  1: 冻结 SMBUS 的超时控制 |



| 位 15    | DBG_I2C1_SMBUS_TIMEOUT: 当内核停止时停止 SMBUS 超时模式(I2C1 SMBUS timeout mode stopped when core is halted)  • 0: 与正常模式操作相同  • 1: 冻结 SMBUS 的超时控制                                                                                                                                                                    |
|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 位 14    | DBG_CAN_STOP: 当内核进入调试状态时,CAN 停止运行(Debug CAN stopped when core is halted)  • 0: CAN 仍然正常运行  • 1: CAN 的接收寄存器不继续接收数据                                                                                                                                                                                        |
| 位 13:10 | DBG_TIMx_STOP: 当内核进入调试状态时计数器停止工作(x=41)(Debug TIMx stopped when core is halted (x=41))  • 0: 选中定时器的计数器仍然正常工作  • 1: 选中定时器的计数器停止工作                                                                                                                                                                          |
| 位 9     | DBG_WWDG_STOP: 当内核进入调试状态时窗口看门狗停止工作(Debug window watch dog stopped when core is halted)  • 0: 窗口看门狗计数器仍然正常工作  • 1: 窗口看门狗计数器停止工作                                                                                                                                                                           |
| 位 8     | DBG_IWDG_STOP: 当内核进入调试状态时独立看门狗停止工作(Debug independent watch dog stopped when core is halted)  • 0: 看门狗计数器仍然正常工作  • 1: 看门狗计数器停止工作                                                                                                                                                                          |
| 位 7:6   | TRACE_MODE[1:0]: 跟踪引脚模式选择(Trace pin assignment control)和 TRACE_IOEN 一起适用控制跟踪引脚分配。  • 当 TRACE_IOEN=0 时 TRACE_MODE=xx: 不分配跟踪引脚(默认状态)  • 当 TRACE_IOEN=1 时  • TRACE_MODE=00: 跟踪引脚使用异步模式  • TRACE_MODE=01: 跟踪引脚使用同步模式,并且数据长度为 1  • TRACE_MODE=10: 跟踪引脚使用同步模式,并且数据长度为 2  • TRACE_MODE=11: 跟踪引脚使用同步模式,并且数据长度为 4 |
| 位 5     | TRACE_IOEN: 跟踪引脚分配使能(Trace pin assignment enable)  • 0: 不分配跟踪引脚  • 1: 分配跟踪引脚                                                                                                                                                                                                                             |
| 位 4:3   | Res: 保留<br>必须保持复位值。                                                                                                                                                                                                                                                                                      |
| 位 2     | DBG_STANDBY: 调试待机模式(Debug Standby mode)  • 0:(FCLK 关,HCLK 关)整个数字电路部分都断电 从软件的观点看,退出 STANDBY 模式与复位是一样的(除了一些状态位指示了微控                                                                                                                                                                                        |



| ALTON-CITY |                                                                                                                                                                                                                                                                                              |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | 制器刚从 STANDBY 状态退出)。 • 1:(FCLK 开,HCLK 开)数字电路部分不下电 FCLK 和 HCLK 时钟由内部 RL 振荡器提供时钟。另外,微控制器通过产生系统复位来退出 STANDBY 模式和复位是一样的。                                                                                                                                                                          |
| 位 1        | DBG_STOP:调试停机模式(Debug Stop mode)  • 0:(FCLK 关,HCLK 关) 在停止模式时,时钟控制器禁止一切时钟(包括 HCLK 和 FCLK)。当从 STOP 模式退出时,时钟的配置和复位之后的配置一样(微控制器由 8MHz 的内部 RC 振荡器(HSI)提供时钟)。因此,软件必须重新配置时钟控制系统启动 PLL,晶振等。  • 1:(FCLK 开,HCLK 开) 在停止模式时,FCLK 和 HCLK 时钟由内部 RC 振荡器提供。当退出停止模式时,软件必须重新配置时钟系统启动 PLL,晶振等(与配置此位为 0 时的操作一样)。 |
| 位 0        | DBG_SLEEP: 调试睡眠模式(Debug Sleep mode)  • 0: (FCLK 开,HCLK 关) 在睡眠模式时,FCLK 由原先已配置好的系统时钟提供,HCLK 则关闭。由于睡眠模式不会复位已配置好的时钟系统,因此从睡眠模式退出时,软件不需要重新配置时钟系统。  • 1: (FCLK 开,HCLK 开) 在睡眠模式时,FCLK 和 HCLK 时钟都由原先配置好的系统时钟提供。                                                                                       |

# 24.15 跟踪端口接口单元(TPIU)

# 24.15.1 导言

TPIU 在片上数据跟踪和 ITM 之间担当桥梁的作用。

输出的数据流封装成跟踪源 ID, 然后被追踪端口分析器采集。

内核嵌入了一个简单的专门为低价调试所设计的 TPIU(由一个特殊版本的 CoreSight TPIU 组成)。



图 24-4 TPIU 框图



### 24.15.2 跟踪引脚分配

### 异步模式

异步模式需要 1 个额外的引脚并且存在于所有的封装。此模式仅在串行调试接口有效(不支持 JTAG 调试接口)。

表 24-12 异步跟踪引脚分配

| TPUI 引脚  | 同步跟踪模式 | 引脚分配     |     |
|----------|--------|----------|-----|
|          | 类型     | 描述       |     |
| TRACESWO | 输出     | 异步跟踪数据输出 | PB3 |

#### TPUI 跟踪引脚分配

这些引脚在默认状态下不是专用引脚。可以通过设置 MCU 调试模块配置寄存器的 TRACE\_IOEN 和TRACE MODE 位分配这些引脚。必须由调试器完成设置。

此外,由跟踪的配置决定分配的引脚数(异步)。

异步模式: 需要1个额外引脚

调试器需要设置 MCU 调试模块配置寄存器的 TRACE\_IOEN 和 TRACE\_MODE[1:0]位来分配跟踪引脚。默认时,跟踪脚是不分配的。

此寄存器被映射到外部 PPB 并且被 PORESET 所复位(系统复位不复位此寄存器)。调试器可以在系统复位的状态下写该寄存器。

| DBGMCU_CR 寄存器 |                 | 引脚用途          | 跟踪引脚分配            |
|---------------|-----------------|---------------|-------------------|
| TRACE_IOEN    | TRACE_MODE[1:0] |               | PB3/JTDO/TRACESWO |
| 0             | xx              | 无跟踪<br>(默认状态) | 释放 <sup>(1)</sup> |
| 1             | 00              | 异步跟踪          | TRACESWO          |
| 1             | 01              | 保留            | 释放 (1)            |
| 1             | 10              | 保留            |                   |
| 1             | 11              | 保留            |                   |

表 24-13 灵活的跟踪引脚分配

(1) 使用串行调试接口时,此引脚被释放,使用 JTAG 调试接口时,此引脚用作 JTDO。

注意: TUIP 的输入时钟 TRACECLKIN 默认接地。所以在比特位 TRACE\_IOEN 被置位后,HCLK 需要两个时钟周期。

然后,调试器可以通过写 TPIU 的 SPP R 寄存器的 PROTOCOL[1:0]位来配置跟踪模式。

- PROTOCOL=01 或 10: 串行模式(曼彻斯特或 NRZ 编码)。默认状态为 01 然后通过写 TPIU 的 CPSPS R(Current Sync Port Size)寄存器的位[3:0]来配置跟踪端口的大小。
- 0x1: 1 个引脚(默认)
- 0x2: 2 个引脚
- 0x8: 4 个引脚



### 24.15.3 TPUI 格式器

协议格式器输出 16 个字节组成的帧:

- 7个数据字节
- 8个多用途字节,由以下部分组成:
  - 1位(LSB)用来区分数据字节(0)和 ID 字节(1)。
  - 。 7位(MSB)可以作为数据或跟踪源 ID 的变化。
- 1个辅助字节,其中的每个位都对应于8个多用途字节中的一个:
  - 。 如果对应的多用途字节是数据字节,那么这个位是数据的比特0位。
  - 。 如果对应字节是 ID 字节,这个位表明 ID 变化何时生效。

注意: 更多信息, 请参考 ARM® CoreSight Architecture Specificationv1.0(ARM® IHI 0029B)

### 24.15.4 TPUI 帧异步包

TPUI 会产生两种类型的同步包:

- 帧同步包(或全字同步包)该包为 0x7F\_FF\_FF\_FF (LSB 先发),这个序列只有在 0x7F 没有被作为 ID 源编码的时候才能使用。该包在帧之间周期性地输出。在连续模式里,一旦同步帧被发现,TPA 必须抛弃所有这些帧。
- 半字同步包该包为: 0x7F\_FF(LSB 先发)。它在帧之间或帧内周期性的输出。这些包只存在于连续模式中,并且使能 TPA 检测 IDLE 模式下的 TRACE 口(无 TRACE 被捕捉)。当被 TPA 检测到时,必须将其抛弃。

### 24.15.5 同步帧包的发送

由于内核的 TPIU 内没有同步计数寄存器,因此同步的触发只能由 DWT 产生。参见 DWT Control Register 寄存器(SYNCTAP[11:10]位)和 DWT Current PC Sampler Cycle Count 寄存器。

TPUI 帧同步包(0x7F FF FF FF)在下列情况时被发送:

- 在每个 TPIU 复位释放后。复位信号同步于 TRACECLKIN 时钟的上升沿释放,这意味着当 DBGMCU\_CFG 寄存器的 TRACE\_IOEN 位被置位时,同步包就被发送。这种情况下,包 0x7F FF FF 后面不跟任何格式的包。
- 在每个 DWT 触发时(假设已事先设置好 DWT),有以下两种情况:
  - 。 如果 ITM 的 SYNENA 位=0,只发送字 0x7F FF FF FF,后面不跟任何格式的数据包。
  - 如果 ITM 的 SYNENA 位=1, ITM 同步包将跟在(0x80\_00\_00\_00\_00) 后面,由 TPUI 编排格式(加上跟踪源 ID)。

## 24.15.6 同步模式

跟踪输出数据的引脚数可以为 4 个, 2 个或者 1 个, 由 TRACED (3:0)。

配置时钟输出到调试器(TRACECK)TRACECLKIN 在内部被驱动,并仅当使用 TRACE 时和 HCLK 相连接。

注意: 在此类同步模式中, 不需要提供稳定的时钟频率。

TRACE 的 I/O 端口(包括 TRACECK)由 TRACLKIN 的上升沿驱动(等同于 HCLK)。因此,TRACECK 的输出频率等于 HCLK/2。



### 24.15.7 异步模式

调试模块提供一个低成本的,只使用一个引脚的跟踪数据输出功能,即使用异步输出引脚TRACESWO。但显然,这样的输出数据带宽是有限的。TRACESWO 引脚与JTDO 引脚复用,只在 SW-DP 调试接口有效,因此该芯片的所有封装都提供这种功能。

异步模式需要 TRACECLKIN 引脚有平稳的频率提供。对标准的 UART(NRZ)捕捉机制来说,需要 5% 的正确度。曼彻斯特编码可放宽到 10%。

### 24.15.8 TRACECLKIN 在芯片内部的连接

TRACECLKIN 输入在该芯片内部与 HCLK 相连接。这意味着在使用异步跟踪模式时,应用程序应限制使用时间帧保证 CPU 频率的稳定。

### 注意: 重要: 当使用异步跟踪功能时需注意:

该芯片的初时时钟是内部 RC 振荡器,此振荡器在复位状态下的频率与复位后的频率不同。这是由于 RC 校准在复位状态下使用初始值,而这个值在复位释放后会更新。因此,不应该在系统复位状态下激活跟踪端口分析器(Trace Port Analyzer)的跟踪功能(置位 TRACE\_IOEN)。因为在复位状态下的同步帧包的比特宽度与复位后的包不同。

### 24.15.9 TPIU 寄存器

只有当 DEMCR 寄存器的 TRCENA 位被置位时,TPIU APB 寄存器才可以被读写。否则寄存器读出值为 0 (这一位的输出使能 TPIU 的 PCLK)。

表 24-14 重要的 TPIU 寄存器

| 地址         | 寄存器                         | 描述                                                                                                                                                                                                                                                                                                          |
|------------|-----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0xE0040004 | Current port size           | 跟踪端口的长度:                                                                                                                                                                                                                                                                                                    |
| 0xE00400F0 | Selected pin<br>protocol    | 跟踪端口协议的选择:<br>位[1:0]:<br>• 00: 同步跟踪模式<br>• 01: 串行输出一曼彻斯特编码(默认值)<br>• 10: 串行输出—NRZ<br>• 11: 未定义                                                                                                                                                                                                              |
| 0xE0040304 | Formatter and flush control | <ul> <li>● 位[31:9]: 总是 0</li> <li>● 位 8: Trigln: 总是 1,指示触发器</li> <li>● 位[7:4]: 总是 0</li> <li>● 位[3:2]: 总是 0</li> <li>● 位 1: EnFCont:</li> <li>○ 同步模式下 (Select Pin Protocol 寄存器的位[1:0]为 00),此位强制为 1,连续模式下格式器被自动使能。</li> <li>○ 异步模式下 (Select Pin Protocol 寄存器的位[1:0]不为 00),此比特可 以被置位或复位来选择是否使能格式器。</li> </ul> |



| 地址         | 寄存器                  |       | 描述                                                                                                            |
|------------|----------------------|-------|---------------------------------------------------------------------------------------------------------------|
|            |                      |       | ● 位 0: 总是 0<br>默认值为 0x102<br>注意:在同步模式下,由于 TRACECTL 信号没有外部引脚,因此格式器会<br>在连续模式下自动使能。这意味着格式器会插入一些控制包来识别跟踪<br>包的源。 |
| 0xE0040300 | Formatter and status | flush | 没有在 Cortex®-M3 中使用,读出值始终为 0x00000008                                                                          |

# 24.15.10 配置的例子

- 设置 Debug Exception and Monitor Control 寄存器的 TRCENA 位;
- 在 TPIU Current Port Size 寄存器中写入期望值(默认是 0x1,指示端口长度为 1bit);
- 向 TPIU Formatter and Flush Control 寄存器中写入 0x102 (默认值);
- 写 TPIU Select Pin Protocol 寄存器,选择异步模式。
- 向 DBGMCU Control 寄存器写入 0x20(置位 IO\_TRACEN),为异步模式分配 TRACE 的 I/O 口。 此时 ТРIU 将发出一个同步包(FF\_FF\_FF\_7F);
- 配置 ITM 并且写 ITM Stimulus 寄存器输出数据。



# 25 缩略语与术语

# 25.1 寄存器描述中的缩略语

| 缩写    | 全称                                   | 中文描述                                                     |
|-------|--------------------------------------|----------------------------------------------------------|
| r     | read-only                            | 只读                                                       |
| w     | write-only                           | 只写                                                       |
| rc_w0 | read/clear this field by writing '0' | 可读;可通过对该位域写 0 清除。<br>对该位域写 1,该位域值无变化。                    |
| rc_w1 | read/clear this field by writing '1' | 可读;可通过对该位域写 1 清除。<br>对该位域写 0,该位域值无变化。                    |
| rs    | read/set                             | 可读写,与 rw 有区别,通常设置该位域为 1 时启动某种硬件动作;当完成硬件动作后,该位域会被硬件自动清 0。 |
| rw    | read/write                           | 可读写该位或指定位。                                               |
| t     | toggle                               | 软件只能通过写1来翻转此位,写0无效。                                      |

# 25.2 缩略语

| 缩写   | 全称                                 | 中文描述                           |
|------|------------------------------------|--------------------------------|
| АНВ  | Advanced High-Performance Bus      | 高级高性能总线                        |
| АРВ  | Advanced Peripheral Bus            | 外围总线                           |
| GPIO | General Purpose Input Output       | 通用输入输出                         |
| HSI  | High-Speed Internal (Clock Signal) | 高速内部(时钟信号)                     |
| IAP  | In-Application Programming         | 在线应用编程                         |
| ICP  | In Circuit Programing              | 在电路编程                          |
| LSI  | Low-Speed Internal (Clock Signal)  | 低速内部(时钟信号)                     |
| MCU  | Microcontroller Unit               | 微控制单元                          |
| OBL  | Option Byte Loader                 | 选项字节装载器                        |
| SWD  | Serial Wire Debug                  | 内核集成的调试口,它是基于 SWD 协议的 2 线调试接口。 |

# 25.3 术语

| 名称          | 中文描述                        |  |
|-------------|-----------------------------|--|
| Byte        | 字节,8位数据长度。                  |  |
| Halfword    | 半字,16位的数据或指令长度。             |  |
| Option byte | 选项字节,保存在 Flash 中的 MCU 配置字节。 |  |
| Word        | 字,32位的数据或指令长度。              |  |



## 26 重要提示

**航顺芯片**和其他航顺商标均为深圳市航顺芯片技术研发有限公司的商标。本文档提及的其他商标或注册商标,由各自的所有人持有。

在未经深圳市航顺芯片技术研发有限公司同意下,不得以任何形式或途径修改本公司产品规格和数据表中的任何部分以及子部份。深圳市航顺芯片技术研发有限公司在以下方面保留权利:修改数据单和/或产品、停产任一产品或者终止服务不做通知;建议顾客获取最新版本的相关信息,在下定订单前进行核实以确保信息的及时性和完整性。所有的产品都依据订单确认时所提供的销售合同条款出售,条款内容包括保修范围、知识产权和责任范围。

深圳市航顺芯片技术研发有限公司保证在销售期间,产品的性能按照本公司的标准保修。公司认为有必要维持此项保修,会使用测试和其他质量控制技术。除了政府强制规定外,其他仪器的测量表没有必要进行特殊测试。

顾客认可本公司的产品的设计、生产的目的不涉及与生命保障相关或者用于其他危险的活动或者环境的其他系统或产品中。出现故障的产品会导致人身伤亡、财产或环境的损伤(统称高危活动)。人为在高危活动中使用本公司产品,本公司据此不作保修,并且不对顾客或者第三方负有责任。

深圳市航顺芯片技术研发有限公司将会提供与现在一样的技术支持、帮助、建议和信息,(全部包括关于购买的电路板或其他应用程序的设计,开发或调试)。特此声明,对于所有的技术支持、可销性或针对特定用途,及在支持技术无误下,电路板和其他应用程序可以操作或运行的,本公司将不作任何有关此类支持技术的担保,并对您在使用这项支持服务不负任何法律责任。

所有版权©深圳市航顺芯片技术研发有限公司 2015-2022

深圳市航顺芯片技术研发有限公司

联系电话: 0755-83247667

网址: www.hsxp-hk.com