

# 用户手册

**APM32F425xG\_F427xG**

**基于 Arm<sup>®</sup> Cortex<sup>®</sup>-M4F 内核的 32 位微控制器**

**版本: V1.2**

# 目录

|          |                               |           |
|----------|-------------------------------|-----------|
| <b>1</b> | <b>简介及文档描述规则 .....</b>        | <b>8</b>  |
| 1.1      | 简介 .....                      | 8         |
| 1.2      | 文档描述规则.....                   | 8         |
| <b>2</b> | <b>系统架构 .....</b>             | <b>11</b> |
| 2.1      | 术语全称、缩写描述.....                | 11        |
| 2.2      | 系统架构框图.....                   | 11        |
| 2.3      | 存储器映射 .....                   | 13        |
| 2.4      | 启动配置.....                     | 13        |
| <b>3</b> | <b>FLASH 存储器.....</b>         | <b>15</b> |
| 3.1      | 术语全称、缩写描述.....                | 15        |
| 3.2      | 简介 .....                      | 15        |
| 3.3      | 主要特征.....                     | 15        |
| 3.4      | FLASH 存储器结构.....              | 16        |
| 3.5      | FLASH 存储器功能说明 .....           | 16        |
| 3.6      | 寄存器地址映射 .....                 | 21        |
| 3.7      | 寄存器功能描述 .....                 | 22        |
| <b>4</b> | <b>外部存储器控制器 (EMMC) .....</b>  | <b>26</b> |
| 4.1      | 术语全称、缩写描述.....                | 26        |
| 4.2      | EMMC 概述 .....                 | 26        |
| 4.3      | SMC 简介 .....                  | 26        |
| 4.4      | SMC 结构框图.....                 | 27        |
| 4.5      | SMC 功能描述 .....                | 27        |
| 4.6      | SMC 寄存器地址映射 .....             | 32        |
| 4.7      | SMC 寄存器功能描述 .....             | 32        |
| 4.8      | DMC 简介 .....                  | 41        |
| 4.9      | DMC 主要特征.....                 | 41        |
| 4.10     | DMC 结构框图.....                 | 42        |
| 4.11     | DMC 功能描述 .....                | 42        |
| 4.12     | DMC 寄存器地址映射 .....             | 44        |
| 4.13     | DMC 寄存器功能描述 .....             | 44        |
| <b>5</b> | <b>系统配置控制器 (SYSCFG) .....</b> | <b>50</b> |

|           |                                |            |
|-----------|--------------------------------|------------|
| 5.1       | 术语全称、缩写描述.....                 | 50         |
| 5.2       | 主要特征.....                      | 50         |
| 5.3       | I/O 补偿单元 .....                 | 50         |
| 5.4       | 寄存器地址映射 .....                  | 50         |
| 5.5       | 寄存器功能描述 .....                  | 50         |
| <b>6</b>  | <b>复位与时钟 (RCM) .....</b>       | <b>54</b>  |
| 6.1       | 术语全称、缩写描述.....                 | 54         |
| 6.2       | 复位管理单元 (RMU) .....             | 54         |
| 6.3       | 时钟管理单元 (CMU) .....             | 56         |
| 6.4       | 寄存器地址映射 .....                  | 63         |
| 6.5       | 寄存器功能描述 .....                  | 64         |
| <b>7</b>  | <b>电源管理单元 (PMU) .....</b>      | <b>90</b>  |
| 7.1       | 术语全称、缩写描述.....                 | 90         |
| 7.2       | 简介 .....                       | 90         |
| 7.3       | 结构框图.....                      | 91         |
| 7.4       | 功能描述.....                      | 91         |
| 7.5       | 寄存器地址映射 .....                  | 96         |
| 7.6       | 寄存器功能描述 .....                  | 97         |
| <b>8</b>  | <b>嵌套向量中断控制器 (NVIC) .....</b>  | <b>99</b>  |
| 8.1       | 术语全称、缩写描述.....                 | 99         |
| 8.2       | 简介 .....                       | 99         |
| 8.3       | 主要特征.....                      | 99         |
| 8.4       | 中断和异常向量表 .....                 | 99         |
| <b>9</b>  | <b>外部中断/事件控制器 (EINT) .....</b> | <b>104</b> |
| 9.1       | 简介 .....                       | 104        |
| 9.2       | 主要特征.....                      | 104        |
| 9.3       | 功能描述.....                      | 104        |
| 9.4       | 寄存器地址映射 .....                  | 106        |
| 9.5       | 寄存器功能描述 .....                  | 106        |
| <b>10</b> | <b>直接存储访问 (DMA) .....</b>      | <b>109</b> |
| 10.1      | 简介 .....                       | 109        |
| 10.2      | 主要特征.....                      | 109        |
| 10.3      | 功能描述.....                      | 109        |

|           |                                 |            |
|-----------|---------------------------------|------------|
| 10.4      | DMA 寄存器地址映射 .....               | 114        |
| 10.5      | 寄存器功能描述 .....                   | 115        |
| <b>11</b> | <b>调试 MCU (DBGMCU) .....</b>    | <b>122</b> |
| 11.1      | 术语全称、缩写描述 .....                 | 122        |
| 11.2      | 简介 .....                        | 122        |
| 11.3      | 主要特征 .....                      | 122        |
| 11.4      | 功能描述 .....                      | 123        |
| 11.5      | 寄存器地址映射 .....                   | 123        |
| 11.6      | 寄存器功能描述 .....                   | 124        |
| <b>12</b> | <b>通用输入/输出引脚 (GPIO) .....</b>   | <b>129</b> |
| 12.1      | 术语全称、缩写描述 .....                 | 129        |
| 12.2      | 主要特征 .....                      | 129        |
| 12.3      | 结构框图 .....                      | 130        |
| 12.4      | 功能描述 .....                      | 130        |
| 12.5      | 寄存器地址映射 .....                   | 133        |
| 12.6      | 寄存器功能描述 .....                   | 133        |
| <b>13</b> | <b>定时器概述 .....</b>              | <b>138</b> |
| 13.1      | 术语全称、缩写描述 .....                 | 138        |
| 13.2      | 定时器类别及主要差异 .....                | 138        |
| <b>14</b> | <b>高级定时器 (TMR1/8) .....</b>     | <b>141</b> |
| 14.1      | 简介 .....                        | 141        |
| 14.2      | 主要特征 .....                      | 141        |
| 14.3      | 结构框图 .....                      | 142        |
| 14.4      | 功能描述 .....                      | 142        |
| 14.5      | 寄存器地址映射 .....                   | 157        |
| 14.6      | 寄存器功能描述 .....                   | 158        |
| <b>15</b> | <b>通用定时器 (TMR2/3/4/5) .....</b> | <b>176</b> |
| 15.1      | 简介 .....                        | 176        |
| 15.2      | 主要特征 .....                      | 176        |
| 15.3      | 结构框图 .....                      | 177        |
| 15.4      | 功能描述 .....                      | 177        |
| 15.5      | 寄存器地址映射 .....                   | 189        |
| 15.6      | 寄存器功能描述 .....                   | 190        |

|                                             |            |
|---------------------------------------------|------------|
| <b>16 通用定时器 (TMR9/10/11/12/13/14) .....</b> | <b>206</b> |
| 16.1 简介 .....                               | 206        |
| 16.2 TMR9/12 主要特征 .....                     | 206        |
| 16.3 TMR10/11/13/14 主要特征 .....              | 206        |
| 16.4 TMR9/12 结构框图 .....                     | 207        |
| 16.5 TMR10/11/13/14 结构框图 .....              | 208        |
| 16.6 功能描述 .....                             | 208        |
| 16.7 TMR9/12 寄存器地址映射 .....                  | 213        |
| 16.8 TMR9/12 寄存器功能描述 .....                  | 213        |
| 16.9 TMR10/11/13/14 寄存器地址映射 .....           | 222        |
| 16.10 TMR10/11/13/14 寄存器功能描述 .....          | 222        |
| <b>17 基本定时器 (TMR6/7) .....</b>              | <b>230</b> |
| 17.1 简介 .....                               | 230        |
| 17.2 主要特征 .....                             | 230        |
| 17.3 结构框图 .....                             | 230        |
| 17.4 功能描述 .....                             | 230        |
| 17.5 寄存器地址映射 .....                          | 232        |
| 17.6 寄存器功能描述 .....                          | 232        |
| <b>18 看门狗定时器 (WDT) .....</b>                | <b>236</b> |
| 18.1 简介 .....                               | 236        |
| 18.2 独立看门狗定时器 (IWDT) .....                  | 236        |
| 18.3 窗口看门狗定时器 (WWDT) .....                  | 237        |
| 18.4 IWDT 寄存器地址映射 .....                     | 239        |
| 18.5 IWDT 寄存器功能描述 .....                     | 239        |
| 18.6 WWDT 寄存器地址映射 .....                     | 241        |
| 18.7 WWDT 寄存器功能描述 .....                     | 241        |
| <b>19 实时时钟 (RTC) .....</b>                  | <b>243</b> |
| 19.1 术语全称、缩写描述 .....                        | 243        |
| 19.2 简介 .....                               | 243        |
| 19.3 主要特征 .....                             | 243        |
| 19.4 结构框图 .....                             | 243        |
| 19.5 功能描述 .....                             | 244        |
| 19.6 寄存器地址映射 .....                          | 249        |

|           |                               |            |
|-----------|-------------------------------|------------|
| 19.7      | 寄存器功能描述 .....                 | 249        |
| <b>20</b> | <b>通用同步异步收发器（USART） .....</b> | <b>265</b> |
| 20.1      | 术语全称、缩写描述 .....               | 265        |
| 20.2      | 简介 .....                      | 265        |
| 20.3      | 主要特征 .....                    | 265        |
| 20.4      | 功能描述 .....                    | 266        |
| 20.5      | 寄存器地址映射 .....                 | 279        |
| 20.6      | 寄存器功能描述 .....                 | 279        |
| <b>21</b> | <b>内部集成电路接口（I2C） .....</b>    | <b>287</b> |
| 21.1      | 术语全称、缩写描述 .....               | 287        |
| 21.2      | 简介 .....                      | 287        |
| 21.3      | 主要特征 .....                    | 287        |
| 21.4      | 结构框图 .....                    | 288        |
| 21.5      | 功能描述 .....                    | 289        |
| 21.6      | 寄存器地址映射 .....                 | 295        |
| 21.7      | 寄存器功能描述 .....                 | 295        |
| <b>22</b> | <b>串行外设接口（SPI） .....</b>      | <b>304</b> |
| 22.1      | 术语全称、缩写描述 .....               | 304        |
| 22.2      | 简介 .....                      | 304        |
| 22.3      | 主要特征 .....                    | 304        |
| 22.4      | 功能描述 .....                    | 305        |
| 22.5      | 寄存器地址映射 .....                 | 315        |
| 22.6      | 寄存器功能描述 .....                 | 315        |
| <b>23</b> | <b>四线串行外围接口（QSPI） .....</b>   | <b>320</b> |
| 23.1      | 术语全称、缩写描述 .....               | 320        |
| 23.2      | 简介 .....                      | 320        |
| 23.3      | 主要特征 .....                    | 320        |
| 23.4      | 功能描述 .....                    | 320        |
| 23.5      | 寄存器地址映射 .....                 | 330        |
| 23.6      | 寄存器功能描述 .....                 | 331        |
| <b>24</b> | <b>控制器局域网（CAN） .....</b>      | <b>345</b> |
| 24.1      | 术语全称、缩写描述 .....               | 345        |
| 24.2      | 简介 .....                      | 345        |

|           |                         |            |
|-----------|-------------------------|------------|
| 24.3      | 主要特性                    | 345        |
| 24.4      | 功能描述                    | 345        |
| 24.5      | 寄存器地址映射                 | 353        |
| 24.6      | 寄存器功能描述                 | 354        |
| <b>25</b> | <b>安全数字输入输出接口（SDIO）</b> | <b>371</b> |
| 25.1      | 术语全称、缩写描述               | 371        |
| 25.2      | 简介                      | 371        |
| 25.3      | 主要特征                    | 371        |
| 25.4      | 功能描述                    | 371        |
| 25.5      | 寄存器地址映射                 | 390        |
| 25.6      | 寄存器功能描述                 | 390        |
| <b>26</b> | <b>USB_OTGFS</b>        | <b>402</b> |
| 26.1      | 简介                      | 402        |
| 26.2      | OTG_FS 全局寄存器地址映射        | 402        |
| 26.3      | OTG_FS 全局寄存器功能描述        | 403        |
| 26.4      | OTG_FS 主机模式寄存器地址映射      | 416        |
| 26.5      | OTG_FS 主机模式寄存器功能描述      | 416        |
| 26.6      | OTG_FS 设备模式寄存器地址映射      | 423        |
| 26.7      | OTG_FS 设备模式寄存器功能描述      | 424        |
| <b>27</b> | <b>以太网（ETHERNET）</b>    | <b>438</b> |
| 27.1      | 简介                      | 438        |
| 27.2      | 以太网主要特征                 | 438        |
| 27.3      | 功能描述                    | 440        |
| 27.4      | MAC 寄存器地址映射             | 464        |
| 27.5      | MAC 寄存器功能描述             | 464        |
| 27.6      | MMC 寄存器地址映射             | 477        |
| 27.7      | MMC 寄存器功能描述             | 478        |
| 27.8      | PTP 寄存器地址映射             | 481        |
| 27.9      | PTP 寄存器功能描述             | 481        |
| 27.10     | DMA 寄存器地址映射             | 485        |
| 27.11     | DMA 寄存器功能描述             | 486        |
| <b>28</b> | <b>模数转换器（ADC）</b>       | <b>496</b> |
| 28.1      | 术语全称、缩写描述               | 496        |

|           |                         |            |
|-----------|-------------------------|------------|
| 28.2      | 简介                      | 497        |
| 28.3      | 主要特征                    | 497        |
| 28.4      | 功能描述                    | 498        |
| 28.5      | 寄存器地址映射                 | 508        |
| 28.6      | 寄存器功能描述                 | 509        |
| <b>29</b> | <b>数模转换器 (DAC)</b>      | <b>521</b> |
| 29.1      | 术语全称、缩写描述               | 521        |
| 29.2      | 简介                      | 521        |
| 29.3      | 结构框图                    | 521        |
| 29.4      | 功能描述                    | 521        |
| 29.5      | 寄存器地址映射                 | 524        |
| 29.6      | 寄存器功能描述                 | 525        |
| <b>30</b> | <b>随机数生成器 (RNG)</b>     | <b>531</b> |
| 30.1      | 简介                      | 531        |
| 30.2      | 主要特征                    | 531        |
| 30.3      | 功能描述                    | 531        |
| 30.4      | 寄存器地址映射                 | 532        |
| 30.5      | 寄存器功能描述                 | 532        |
| <b>31</b> | <b>循环冗余校验计算单元 (CRC)</b> | <b>534</b> |
| 31.1      | 简介                      | 534        |
| 31.2      | 功能描述                    | 534        |
| 31.3      | 寄存器地址映射                 | 534        |
| 31.4      | 寄存器功能描述                 | 534        |
| <b>32</b> | <b>芯片电子签名</b>           | <b>536</b> |
| 32.1      | 简介                      | 536        |
| 32.2      | 寄存器功能描述                 | 536        |
| <b>33</b> | <b>版本历史</b>             | <b>537</b> |

# 1 简介及文档描述规则

## 1.1 简介

本用户手册向应用程序开发人员提供关于如何使用 MCU（微控制器）系统架构、存储器和外设所涉及的全部信息。

关于 Arm® Cortex®-M4F 内核的相关信息，请参见 Arm® Cortex®-M4F 技术参考手册；关于型号信息、尺寸和器件的电气特性等详细数据，请参见对应的数据手册（datasheet）；有关 MCU 系列全部型号中，存储器映射、外设存在情况及其数目，请查阅相应数据手册。

在此说明：珠海极海半导体有限公司，在以下正文中，简称“Geehy”。

## 1.2 文档描述规则

### 1.2.1 “寄存器功能描述” 规则

- (1) 控制类（CTRL）寄存器，未特别说明，都是“软件置 1 和清 0”。
- (2) 控制类寄存器后面一般会有动词缩写以作区别，动词可以有：EN-Enable、CFG-Configure、D-Disable、SET-Setup、SEL-Select
- (3) 状态类寄存器缩写后面一般会有 FLG 以作区别。
- (4) 数值、数据类寄存器，一般会包括 V、VALUE、D、DATA，这些词后面不加动词，比如：xxPSC，CNT，后面一般不添加动词。

### 1.2.2 术语全称、缩写描述

表格 1 R/W 方式缩写及描述

| R/W 方式                  | 描述                                | 缩写    |
|-------------------------|-----------------------------------|-------|
| read/write              | 软件能读写此位。                          | R/W   |
| read-only               | 软件只能读此位。                          | R     |
| write-only              | 软件只能写此位，读此位将返回复位值。                | W     |
| read/clear              | 软件可以读此位，也可以通过写 1 清除此位，写 0 对此位无影响。 | RC_W1 |
| read/clear              | 软件可以读此位，也可以通过写 0 清除此位，写 1 对此位无影响。 | RC_W0 |
| read/clear by read      | 软件可以读此位，读此位将自动地清除它为 0，写该位无效。      | RC_R  |
| read/set                | 软件可以读也可以设置此位，写 0 对此位无影响。          | R/S   |
| read-only write trigger | 软件可以读此位，写 0 或 1 触发一个事件但对此位数值没有影响。 | RT_W  |
| toggle                  | 软件只能通过写 1 来翻转此位，写 0 对此位无影响。       | T     |

表格 2 常用寄存器功能描述术语全称、缩写

| 中文全称 | 英文全称   | 英文缩写 |
|------|--------|------|
| 使能   | Enable | EN   |

| 中文全称 | 英文全称        | 英文缩写 |
|------|-------------|------|
| 禁止   | Disable     | D    |
| 清除   | Clear       | CLR  |
| 选择   | Select      | SEL  |
| 配置   | Configure   | CFG  |
| 控制   | Control     | CTRL |
| 控制器  | Controller  | C    |
| 复位   | Reset       | RST  |
| 停止   | Stop        | STOP |
| 设置   | Set         | SET  |
| 装载   | Load        | LD   |
| 校准   | Calibration | CAL  |
| 初始化  | Initialize  | INIT |
| 错误   | Error       | ERR  |
| 状态   | Status      | STS  |
| 准备   | Ready       | RDY  |
| 软件   | Software    | SW   |
| 硬件   | Hardware    | HW   |
| 源    | Source      | SRC  |
| 系统   | System      | SYS  |
| 外设   | Peripheral  | PER  |
| 地址   | Address     | ADDR |
| 方向   | Direction   | DIR  |
| 时钟   | Clock       | CLK  |
| 输入   | Input       | I    |
| 输出   | Output      | O    |
| 中断   | Interrupt   | INT  |
| 数据   | Data        | DATA |
| 大小   | Size        | SIZE |
| 除法器  | Divider     | DIV  |
| 预分频器 | Prescaler   | PSC  |
| 乘法器  | Multiplier  | MUL  |
| 周期   | Period      | PRD  |

表格 3 模块全称、简写

| 中文全称        | 英文全称                                                    | 英文缩写    |
|-------------|---------------------------------------------------------|---------|
| 外部存储控制器     | External Memory Controller                              | EMMC    |
| 静态存储控制器     | Static Memory Controller                                | SMC     |
| 动态存储控制器     | Dynamic Memory Controller                               | DMC     |
| 复位与时钟管理单元   | Reset and Clock Management Unit                         | RCM     |
| 电源管理单元      | Power Management Unit                                   | PMU     |
| 备份寄存器       | Backup Register                                         | BAKPR   |
| 嵌套向量中断控制器   | Nested Vector Interrupt Controller                      | NVIC    |
| 外部中断/事件控制器  | External Interrupt /Event Controller                    | EINT    |
| 直接存储器存取     | Direct Memory Access                                    | DMA     |
| 调试 MCU      | Debug MCU                                               | DBG MCU |
| 通用输入/输出引脚   | General-Purpose Input Output Pin                        | GPIO    |
| 复用功能输入/输出引脚 | Alternate Function Input Output Pin                     | AFIO    |
| 定时器         | Timer                                                   | TMR     |
| 看门狗定时器      | Watchdog Timer                                          | WDT     |
| 独立看门狗       | Independent Watchdog Timer                              | IWDT    |
| 窗口看门狗       | Windows Watchdog Timer                                  | WWDT    |
| 实时时钟        | Real-Time Clock                                         | RTC     |
| 通用同步异步收发器   | Universal Synchronous Asynchronous Receiver Transmitter | USART   |
| 内部集成电路接口    | Inter-Integrated Circuit Interface                      | I2C     |
| 串行外设接口      | Serial Peripheral Interface                             | SPI     |
| 片上音频接口      | Inter-IC Sound Interface                                | I2S     |
| 四线串行外围接口    | Quad Serial Peripheral Interface                        | QSPI    |
| 控制器局域网      | Controller Area Network                                 | CAN     |
| 安全数字输入输出    | Secure Digital Input and Output                         | SDIO    |
| 全速 USB 接口   | Universal Serial Bus Full-Speed Device                  | USB     |
| 模拟数字转换器     | Analog-to-Digital Converter                             | ADC     |
| 数字模拟转换器     | Digital-to-Analog Converter                             | DAC     |
| 循环冗余校验计算单元  | Cyclic Redundancy Check Calculation Unit                | CRC     |
| 浮点运算单元      | Float Point Unit                                        | FPU     |

## 2 系统架构

### 2.1 术语全称、缩写描述

表格 4 术语全称、缩写描述

| 中文全称    | 英文全称                          | 英文缩写 |
|---------|-------------------------------|------|
| 高级高性能总线 | Advanced High-Performance Bus | AHB  |
| 高级外围总线  | Advanced Peripheral Bus       | APB  |
| 核心耦合存储器 | Core Couple Memory            | CCM  |

### 2.2 系统架构框图

产品中的 Arm® Cortex®-M4F 内核是带有 FPU 的，而其他系列的产品（除特殊说明）的 FPU 是处于内核之外的。

系统主要由一个主模块和八个从模块构成。

主模块分别是带有 FPU 的 Arm® Cortex®-M4F 内核的 I-bus、D-bus 和 S-bus，通用 DMA1，通用 DMA2，DMA2 外设总线，以太网 DMA 总线以及 USB OTG 总线。

从模块分别是内部 Flash 的 I-bus、D-bus，主内部存储器 SRAM1，辅内部存储器 SRAM2、SRAM3，AHB1 总线和 AHB1/APB 桥连接的所有外设设备，AHB2 总线上的外设，AHB3 总线上的 QSPI 和 EMMC。

总线矩阵提供一个平台，以支持主模块访问从模块，矩阵实现并发访问，并确保 CPU 在多个外设高速运行时，仍然有高效处理能力。此外，还配备一个 64 位的核心耦合存储，只能通过 CPU 进行访问。

总线的名称和描述如下表所示。

表格 5 总线名称

| 名称        | 描述                                                        |
|-----------|-----------------------------------------------------------|
| I-bus     | 连接 Arm® Cortex®-M4F 内核的指令总线与总线矩阵。<br>用于获取指令。              |
| D-bus     | 连接 Arm® Cortex®-M4F 内核的数据总线与总线矩阵。<br>用于文字加载和调试访问。         |
| S-bus     | 连接 Arm® Cortex®-M4F 内核的系统总线与总线矩阵。<br>用于访问外设和 SRAM 中的数据。   |
| DMA 存储器总线 | 连接 DMA 存储器主接口与总线矩阵。<br>通过 DMA 实现与存储器相关的传输。                |
| DMA 外设总线  | 连接 DMA 外设主接口与总线矩阵。<br>不仅能实现 DMA 访问 AHB 上的外设，还能实现存储器之间的传输。 |

| 名称         | 描述                                                               |
|------------|------------------------------------------------------------------|
| 以太网 DMA 总线 | 连接以太网 DMA 主接口与总线矩阵。<br>通过以太网 DMA 将数据载入/存储到存储器。                   |
| 总线矩阵       | 协调模块之间的访问，仲裁时使用轮询算法。                                             |
| AHB/APB 桥  | 桥在 AHB 和 APB 总线间提供同步连接。<br>当对 APB 寄存器进行非 32 位访问时，访问会被自动转换成 32 位。 |

图 1 APM32F425xG\_F427xG 系统架构框图



## 2.3 存储器映射

存储器映射分配的地址包括内核（包括内核外设）、片上 Flash（包括主存储区、系统存储区、选项字节）、片上 SRAM、总线外设（包括 AHB、APB 外设），各类地址具体信息请参见对应型号的数据手册。

### 2.3.1 嵌入式 SRAM

APM32F425 系列：产品带有备份 SRAM (4KB) 和系统 SRAM (192KB)。系统 SRAM 分为 3 块：SRAM1 (112KB)、SRAM2 (16KB) 和 CCM (64KB)。

APM32F427 系列：产品带有备份 SRAM (4KB) 和系统 SRAM (448KB)。系统 SRAM 分为 4 块：SRAM1 (112KB)、SRAM2 (16KB)、SRAM3 (256KB) 和 CCM (64KB)。

#### SRAM1、SRAM2 和 SRAM3

可以以字节、半字 (16 位) 或全字 (32 位) 访问主 SRAM1、辅 SRAM2 和辅 SRAM3。SRAM1、SRAM2 和 SRAM3 映射地址为 0x2000 xxxx，可被所有 AHB 访问主模块。

#### 核心耦合存储器 CCM

CCM (64KB) 映射地址为 0x1000 0000，只能由 CPU 通过 D-bus 访问它。

### 2.3.2 位段

Arm® Cortex®-M4F 存储器映像有两个位段 (bit-band) 区，它将每个在别名存储器区中的字映射到位段存储器的一个位。在别名存储区写入一个字，会有对位段区的目标执行读-改-写操作的相同效果。外设寄存器和 SRAM 都被映射到一个位段区里，允许执行单一位段的写和读操作。

下面给出一份映射公式：

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

## 2.4 启动配置

APM32F425xG\_F427xG 系列微控制器实现了一个特殊的机制，通过配置 BOOT[1:0]引脚，可以用有三种不同的启动模式，系统不仅仅可以从 Flash 存储器或系统存储器启动，还可以从内置 SRAM 启动。被选作启动区域的存储器是由选择的启动模式决定的。

表格 6 启动模式配置及其访问方式

| 启动模式配置   |          | 启动模式              | 访问方式                                                   |
|----------|----------|-------------------|--------------------------------------------------------|
| BOOT1 引脚 | BOOT0 引脚 |                   |                                                        |
| X        | 0        | 主闪存存储器<br>(Flash) | 主闪存存储器被映射到启动空间, 但仍然能够在它原有的地址访问它, 即闪存存储器的内容可以在两个地址区域访问。 |
| 0        | 1        | 系统存储器             | 系统存储器被映射到启动空间 (0x0000 0000), 但仍然能够在它原有的地址访问它。          |
| 1        | 1        | 内置 SRAM           | 只能在开始的地址区访问 SRAM。                                      |

注意:

- (1) 启动空间地址为 0x0000 0000
- (2) Flash 原有地址为 0x0800 0000
- (3) 系统存储器原有地址为 0x1FFF 0000
- (4) SRAM 的起始地址为 0x2000 0000
- (5) 用户可以通过设置 BOOT[1:0]引脚的状态, 选择在复位后的启动模式。
- (6) BOOT 引脚应在待机模式下保持用户需要的启动配置, 当从待机模式退出时, 引脚的值会被锁存。
- (7) 如果选择从内置 SRAM 启动, 那么在编写应用代码时, 必须使用 NVIC 的异常表和偏移寄存器, 重新将向量表映射至 SRAM 中。

### 物理重映射

当选择了 BOOT 引脚后, 可以通过软件程序修改 SYSCFG\_MMSEL 寄存器的 MMSEL 位, 将某些寄存器配置成允许从 I-Code 总线访问。具体配置见 SYSCFG 寄存器。

### 内嵌的 BootLoader

嵌入式 BootLoader 模式选择将通过以下某种串口接口重新编程 Flash:

- USART1
- USART3
- CAN2
- USB OTG\_FS 从设备模式

注意: 当选择 CAN2 或 USB OTG\_FS 从设备模式时, 高速外部时钟 (HSECLK) 的频率不能超过 16MHz。

## 3 Flash 存储器

### 3.1 术语全称、缩写描述

表格 7 术语全称、缩写描述

| 中文全称         | 英文全称                    | 英文缩写 |
|--------------|-------------------------|------|
| 闪存存储器控制器     | Flash Memory Controller | FMC  |
| 一次性可编程（存储器区） | One-time Programmable   | OTP  |
| 存储器加速器       | Flash Accelerator       | FACC |

### 3.2 简介

本章主要介绍 Flash 的存储结构、读、擦、写、读/写保护、解锁/锁定特性，及涉及到的寄存器功能描述。

### 3.3 主要特征

#### (1) Flash 存储器结构

- 分为主存储区、信息块
- 主存储区容量最高为 1MB
- 信息块分为系统存储器、OTP 区域和选项字节三个区域
- 系统存储区（ROM）容量为 30KB，存放 BootLoader 程序
- 96 位唯一 UID、容量等信息放在信息块中
- OTP 区域大小为 528Bytes，其中，512 OTP 字节的用于存储用户数据，剩下的 16 字节用于锁定对应的 OTP 数据块
- 选项字节区容量为 16Bytes

#### (2) 功能说明

- 对 Flash 进行操作：
  - 读取
  - 扇/全部擦除
  - 写入
  - 读/写保护
- 对选项字节进行操作：
  - 读取
  - 擦除
  - 写入
  - 读/写保护

## 3.4 Flash 存储器结构

表格 8 Flash 存储器结构

| 块    | 名称        | 地址范围                      | 大小 (字节) | 扇区   |
|------|-----------|---------------------------|---------|------|
| 主存储块 |           | 0x0800 0000 - 0x0800 3FFF | 16K     | 扇 0  |
|      |           | 0x0800 4000 - 0x0800 7FFF | 16K     | 扇 1  |
|      |           | 0x0800 8000 - 0x0800 BFFF | 16K     | 扇 2  |
|      |           | 0x0800 C000 - 0x0800 FFFF | 16K     | 扇 3  |
|      |           | 0x0801 0000 - 0x0801 FFFF | 64K     | 扇 4  |
|      |           | 0x0802 0000 - 0x0803 FFFF | 128K    | 扇 5  |
|      |           | ...                       | ...     | ...  |
|      |           | 0x080E 0000 - 0x080F FFFF | 128K    | 扇 11 |
| 信息块  | 系统存储(ROM) | 0x1FFF 0000 - 0x1FFF 77FF | 30K     | -    |
|      | OTP 区域    | 0x1FFF 7800 - 0x1FFF 7A0F | 528     | -    |
|      | 选项字节      | 0x1FFF C000 - 0x1FFF C00F | 16      | -    |

## 3.5 Flash 存储器功能说明

### 3.5.1 读取 Flash

Flash 读速度受等待周期的数量影响，而等待周期个数受 HCLK 的影响。假设等待周期为  $n$ , HCLK 范围的上升基数为  $X$ :

- 当  $(n+1)X$  小于最大值时:  
 $nX < HCLK \leq (n+1)X$
- 当  $(n+1)X$  大于最大值时:  
 $nX < HCLK \leq$  最大值

表格 9 受电压范围影响的  $X$  与 HCLK 最大值

| 电压范围 | 1.8V-2.1V | 2.1V-2.4V | 2.4V-2.7V | 2.7V-3.6V |
|------|-----------|-----------|-----------|-----------|
| X    | 20MHz     | 22MHz     | 24MHz     | 30MHz     |
| 最大值  | 160MHz    | 240MHz    | 240MHz    | 240MHz    |

注意: 当 PMU\_CTRL 寄存器的 VOSSEL=0 时, HCLK 最大值为 144MHz; VOSSEL=1 时, HCLK 最大值为 240MHz。

选择不同的等待周期可以调整 CPU 频率, 以便调整 Flash 的读速度。

#### 3.5.1.1 存储器加速器 (FACC)

FACC 加速器能够提高 Flash 的执行速度, 使得 Flash 在 CPU 高频率下以更少的等待周期执行程序。

## 预取缓冲区

当访问 Flash 需要插入等待周期时，可以通过 I-Code 总线预读取 Flash 的下一个指令行，提高访问速率。

### I-cache

I-cache 是指令缓冲存储器，在 I-cache 中的指令可以无延时被获取，系统可以将 64 行 128 位的指令存入 I-cache 中，通过 FMC\_ACCTRL 寄存器的 ICACHEEN 位使能 I-cache 功能。

### D-cache

D-cache 是数据缓冲存储器，系统通过 D-bus 访问 Flash 的数据缓冲区，依次减少等待时间。D-bus 的访问优先于 I-bus。系统可以将 8 行 128 位的指令存入 D-cache 中，通过 FMC\_ACCTRL 寄存器的 DCACHEEN 位使能 D-cache 功能。

## 3.5.2 主存储块

在对主存储区进行擦/写操作时，不能再对 Flash 进行读取操作。

### 并行位数

并行位数是指对 Flash 进行擦/写操作时要处理的字节数，通过编程 FMC\_CTRL 寄存器的 PGSIZE 位配置并行位数。决定因子和并行位数如下表所示：

表格 10 决定因子和并行位数的关系

| 电压范围 (V) | 1.8-2.1 | 2.1-2.4 | 2.4-2.7 | 2.7-3.6 | 2.7-3.6 (使用外部 VPP) |
|----------|---------|---------|---------|---------|--------------------|
| 并行位数     | 8-bit   | 16-bit  | 32-bit  | 64-bit  |                    |

### 3.5.2.1 擦主存储块

Flash 可支持扇区擦除和整片擦除（全擦除）。进行整片擦除时，不影响 OTP 扇区或配置扇区。

#### 主存储器页擦除

页擦除是根据程序选择的主存储区页进行独立擦除，不会对未选择擦除的页产生任何影响。

正确的页擦除（或闪存写入操作）结束后，FMC\_STS 寄存器的 OPRCMP 位将被置位，若使能了 OPCINTEN 中断则将触发一个操作完成中断。用户需要注意的是选择擦除的页必须是有效的页（主存储区有效的地址和未被写保护的地址）。

#### 主存储器片擦除

片擦除操作将会使 Flash 主存储区内所有内容全部被擦除，用户在使用时需要特别注意，以避免误操作导致重要数据丢失。

片擦除不影响 OTP 扇区或配置扇区。

### 3.5.2.2 写主存储块

Flash 支持字节、半字、字、双字写入操作，具体情况视并行位数决定。

注意：为保证写入正确，需要在写入前检查目的地址是否已经被擦除。Flash 单元需要经过擦除变为 1 后，才能被写入。

若目的地址存在写保护，则写入数据无效并触发一个写保护错误（FMC\_STS 寄存器的 WPROTERR 位置“1”）。

在 FMC\_STS 寄存器中，有三个写错误位，分别是 PGALGERR（编程对齐错误）、PGPRLERR（编程并行性错误）和 PGSEQERR（编程步骤顺序错误）。

#### 编程对齐错误

如果想对 Flash 进行超过 128 位行的数据编程操作，则会产生编程对齐错误，PGALGERR 位将被置 1。

#### 编程并行性错误

写操作的宽度若是和并行位数不一致，那么暂停写操作，并产生编程并行性错误，PGPRLERR 位置 1。

#### 编程步骤顺序错误

正确的编程顺序为：

- (1) 通过 FMC\_STS[BUSY]确定当前没有对 Flash 执行的操作
- (2) 将 FMC\_CTRL[PG]置 1
- (3) 进行写操作
- (4) 操作完成，等待 BUSY 位清零

如果编程顺序有误，则会产生编程步骤顺序错误，PGSEQERR 位置 1。

### 3.5.2.3 锁定/解锁

FMC\_CTRL[LOCK]只能置 1，以此锁定 Flash 控制寄存器，此时，无法对主存储块区域进行操作（即锁定）。

将关键字 0x4567 0123 和 0xCDEF 89AB 先后写入 FMC\_KEY 寄存器，系统检测到解锁序列，会将 FMC\_CTRL 寄存器的 LOCK 位清零，此时就能解锁 Flash 控制寄存器和主存储块。

### 3.5.2.4 缓存

如果 Flash 的写操作涉及到 D-cache 中某些数据，则将修改 Flash 和 D-cache 中的数据。

如果 Flash 的擦除操作涉及到 D-cache 或 I-cache 中的数据，那么在此之前应将

数据写入缓存，在此操作之后应复位缓存。

### 3.5.2.5 中断

在发生以下任一事件时，产生中断：

- 操作结束：擦/写操作结束
- 写保护错误：对写保护区域执行擦/写操作
- 编程错误：在擦/写/读期间出现错误

当 FMC\_CTRL 寄存器中 OPCINTEN 位或 ERRINTEN 位被置 1，且发生相应中断事件时，产生中断。

### 3.5.3 选项字节

选项字节的地址和构成如下表所示，具体的含义描述可见 FMC\_OPTCTRL 寄存器的相应位。

表格 11 选项字节说明

| 地址          | 位域    | 选项字节    | 功能描述        |
|-------------|-------|---------|-------------|
| 0x1FFF C000 | 1:0   | -       | -           |
|             | 3:2   | BORLVL  | 欠压复位等级      |
|             | 4     | -       | -           |
|             | 5     | WDTSEL  | 选择看门狗       |
|             | 6     | RSTSTOP | 进入停机模式时产生复位 |
|             | 7     | RSTSTDB | 进入待机模式时产生复位 |
|             | 15:8  | RPROT   | 读保护         |
| 0x1FFF C008 | 11:0  | NWPROT  | 无写保护        |
|             | 15:12 | -       | -           |

#### 3.5.3.1 擦/写选项字节

在对选项字节进行擦/写操作前，必须要解锁。

选项字节的编程顺序为：

- (1) 通过 FMC\_STS[BUSY]确定当前没有对 Flash 执行的操作
- (2) 向 FMC\_OPTCTRL 写入编程值
- (3) 将 FMC\_OPTCTRL[OPTSTART]置 1
- (4) 操作完成，等待 BUSY 位清零

#### 3.5.3.2 锁定/解锁

FMC\_OPTCTRL[OPTLOCK]只能置 1，以此锁定选项字节区域。

将关键字 0x0819 2A3B 和 0x4C5D 6E7F 先后写入 FMC\_OPTKEY 寄存器，系统检测到解锁序列，会将 FMC\_OPTCTRL 寄存器的 OPTLOCK 位清零，此时选

项字节就会解锁。

### 3.5.4 写保护

为了防止程序错乱而意外改写 Flash，在默认状态下，Flash 可多达 12 个用户扇区有写保护功能。FMC\_OPTCTRL[NWPROT]位域的对应位为低电平时，相应扇区被写保护，无法对该扇区进行擦/写操作。

#### 3.5.4.1 写保护错误

FMC\_STS[WPROTERR]是个写保护错误位，以下事件发生时，此位置 1：

- 对写保护区域执行擦/写操作
- 对无效扇区执行页擦除
- Flash 处于读保护但检测到擦/写请求
- 对锁定的 OTP 区域进行写操作

### 3.5.5 读保护

为了防止不受信任的代码读取 Flash 的数据，可选择对 Flash 使用读保护功能，通过配置 FMC\_OPTCTRL[RPROT]位域的值，选择读保护级别。读保护有三种级别，分别是级别 0、级别 1、级别 2。

不同读保护级别下的访问限制如下表所示。

表格 12 不同读级别的限制

| 存储区                   | 级别   | 从 Flash 自举 |   |   | 调试功能，从 RAM 或系统存储器自举 |   |                  |
|-----------------------|------|------------|---|---|---------------------|---|------------------|
|                       |      | 读          | 写 | 擦 | 读                   | 写 | 擦                |
| OTP                   | 级别 1 | √          | - | - | ×                   | - | -                |
|                       | 级别 2 | -          | - | - | -                   | - | -                |
| 选项字节                  | 级别 1 | -          | - | - | √                   | - | -                |
|                       | 级别 2 | -          | - | - | ×                   | - | -                |
| Flash 和<br>备份<br>SRAM | 级别 1 | -          | - | - | ×                   | - | × <sup>(1)</sup> |
|                       | 级别 2 | √          | - | - | -                   | × | -                |

注意：

(1) 表示只有级别 1 变到级别 0 时，才会擦除 Flash 和备份 SRAM 的数据。

(2) “√”表示允许操作，“×”表示不允许，“-”表示未定义。

#### 3.5.5.1 级别 0

当 FMC\_OPTCTRL[RPROT]=0xAA 时，表示不对 Flash 使用读保护功能。

#### 3.5.5.2 级别 1

当 FMC\_OPTCTRL[RPROT]=任意值（除 0xAA 和 0xCC 外），读保护级别为 1。

如果此时将级别调整回级别 0，那么会执行片擦除操作，将擦除 Flash 和备份 SRAM 的所有数据。片擦除只影响用户代码区域，被写保护的其他选项字节和

OTP 不受影响。

### 3.5.5.3 级别 2

当 FMC\_OPTCTRL[RPROT]=0xCC 时, 读保护级别为 2。此时:

- 保留级别 1 的读保护功能
- 不允许从 RAM 或系统存储器自举
- JTAG、SWV、ETM 和边界扫描被禁止
- 选项字节被锁定

注意: 当读保护级别设置为 2 时, 不能再降级。

## 3.5.6 OTP

下表为 OTP 结构。

表格 13 OTP 结构

| 地址          | [31:0]                  | [63:32]                 | [95:64]                  | [127:96]                  | 块      |
|-------------|-------------------------|-------------------------|--------------------------|---------------------------|--------|
| 0xFFFF 7800 | OTP0                    | OTP0                    | OTP0                     | OTP0                      | 数据块 0  |
| 0xFFFF 7810 | OTP0                    | OTP0                    | OTP0                     | OTP0                      |        |
| 0xFFFF 7820 | OTP1                    | OTP1                    | OTP1                     | OTP1                      | 数据块 1  |
| 0xFFFF 7830 | OTP1                    | OTP1                    | OTP1                     | OTP1                      |        |
| 0xFFFF 7840 | OTP2                    | OTP2                    | OTP2                     | OTP2                      | 数据块 2  |
| 0xFFFF 7850 | OTP2                    | OTP2                    | OTP2                     | OTP2                      |        |
| .....       | .....                   | .....                   | .....                    | .....                     | .....  |
| 0xFFFF 79E0 | OTP15                   | OTP15                   | OTP15                    | OTP15                     | 数据块 15 |
| 0xFFFF 79F0 | OTP15                   | OTP15                   | OTP15                    | OTP15                     |        |
| 0xFFFF 7A00 | LOCKB0<br>...<br>LOCKB3 | LOCKB4<br>...<br>LOCKB7 | LOCKB8<br>...<br>LOCKB11 | LOCKB12<br>...<br>LOCKB15 | 锁定块    |

OTP 由 16 个 32 位字节的数据块和 1 个 16 字节的锁定块组成。锁定块 n 用于锁定数据块 n (n=0...15), 只有当锁定块的值不为 0x00 时, 相应的数据块才能编程。锁定块的值只能是 0x00 或 0xFF, 否则 OTP 字节无法正常使用。

注意: OTP 的数据块和锁定块都无法擦除。

## 3.6 寄存器地址映射

表格 14 FMC 寄存器地址映射

| 寄存器名       | 描述            | 偏移地址 |
|------------|---------------|------|
| FMC_ACCTRL | Flash 访问控制寄存器 | 0x00 |
| FMC_KEY    | Flash 关键字寄存器  | 0x04 |

| 寄存器名        | 描述             | 偏移地址 |
|-------------|----------------|------|
| FMC_OPTKEY  | Flash 选项关键字寄存器 | 0x08 |
| FMC_STS     | Flash 状态寄存器    | 0x0C |
| FMC_CTRL    | Flash 控制寄存器    | 0x10 |
| FMC_OPTCTRL | Flash 选项控制寄存器  | 0x14 |

### 3.7 寄存器功能描述

#### 3.7.1 Flash 访问控制寄存器 (FMC\_ACCTRL)

偏移地址: 0x00

复位值: 0x0000 0000

| 位/域   | 名称            | R/W | 描述                                                                                                                                   |
|-------|---------------|-----|--------------------------------------------------------------------------------------------------------------------------------------|
| 6:0   | WAITP         | R/W | 等待周期 (Wait Period)<br>此位表示等待周期的个数。<br>000: 0 个<br>001: 1 个<br>010: 2 个<br>011: 3 个<br>100: 4 个<br>101: 5 个<br>.....<br>1111111:127 个 |
| 7     |               |     | 保留                                                                                                                                   |
| 8     | PREFEN        | R/W | 使能预取 (Prefetch Enable)<br>0: 禁用<br>1: 使能                                                                                             |
| 9     | ICACHEEN      | R/W | 使能指令缓冲区 (Instruction Cache Enable)<br>0: 禁用<br>1: 使能                                                                                 |
| 10    | DCACHEEN      | R/W | 使能数据缓冲区 (Data Cache Enable)<br>0: 禁用<br>1: 使能                                                                                        |
| 11    | ICACHERST     | R/W | 复位指令缓冲区 (Instruction Cache Reset)<br>0: 无效<br>1: 复位                                                                                  |
| 12    | DCACHERST     | R/W | 复位数据缓冲区 (Data Cache Reset)<br>0: 无效<br>1: 复位                                                                                         |
| 14:13 |               |     | 保留                                                                                                                                   |
| 15    | Prefetch more | R/W | 预取策略控制 (Prefetch More)<br>1: 预取缓冲区/CACHE 被访问后发起下一次预取<br>0: 预取缓冲区/同一 CACHELINE 被访问两次后发起下一次预取                                          |
| 31:16 |               |     | 保留                                                                                                                                   |

### 3.7.2 Flash 关键字寄存器 (FMC\_KEY)

偏移地址: 0x04

复位值: 0x0000 0000

| 位/域  | 名称  | R/W | 描述                               |
|------|-----|-----|----------------------------------|
| 31:0 | KEY | W   | 关键字 (Key)<br>解锁时, 需要将关键字输入进此寄存器。 |

### 3.7.3 Flash 选项关键字寄存器 (FMC\_OPTKEY)

偏移地址: 0x08

复位值: 0x0000 0000

| 位/域  | 名称     | R/W | 描述                                        |
|------|--------|-----|-------------------------------------------|
| 31:0 | OPTKEY | W   | 选项关键字 (Option Key)<br>解锁时, 需要将关键字输入进此寄存器。 |

### 3.7.4 Flash 状态寄存器 (FMC\_STS)

偏移地址: 0x0C

复位值: 0x0000 0000

| 位/域   | 名称       | R/W   | 描述                                                              |
|-------|----------|-------|-----------------------------------------------------------------|
| 0     | OPRCMP   | RC_W1 | 操作完成 (Operation Complete)<br>当对 Flash 操作结束后, 此位置 1。             |
| 1     | OPRERR   | RC_W1 | 操作错误 (Operation Error)<br>在操作过程中, 出现错误时, 此位置 1。                 |
| 3:2   | 保留       |       |                                                                 |
| 4     | WPROTERR | RC_W1 | 写保护错误 (Write Protection Error)<br>对 Flash 写保护区域进行擦/写操作时, 此位置 1。 |
| 5     | PGALGERR | RC_W1 | 编程对齐错误 (Programming Alignment Error)<br>发生编程对齐错误时, 此位置 1。       |
| 6     | PGPRLERR | RC_W1 | 编程并行性错误 (Programming Parallelism Error)<br>发生编程并行性错误时, 此位置 1。   |
| 7     | PGSEQERR | RC_W1 | 编程步骤顺序错误 (Programming Sequence Error)<br>发生编程步骤顺序错误时, 此位置 1。    |
| 15:8  | 保留       |       |                                                                 |
| 16    | BUSY     | R     | 忙碌 (Busy)<br>对 Flash 执行操作时, 此位置 1。                              |
| 31:17 | 保留       |       |                                                                 |

### 3.7.5 Flash 控制寄存器 (FMC\_CTRL)

偏移地址: 0x10

复位值: 0x8000 0000

只有没有任何正在进行的 Flash 操作时, 才能访问这个寄存器。

| 位/域 | 名称 | R/W | 描述                                        |
|-----|----|-----|-------------------------------------------|
| 0   | PG | R/W | 编程 (Programming)<br>此位置 1 时可以使能 Flash 编程。 |

| 位/域   | 名称       | R/W | 描述                                                                                                               |
|-------|----------|-----|------------------------------------------------------------------------------------------------------------------|
| 1     | SERS     | R/W | 扇擦除 (Sector Erase)<br>此位置 1 时可以使能扇擦除。                                                                            |
| 2     | MERS     | R/W | 片擦除 (Mass Erase)<br>此位置 1 时可以使能片擦除。                                                                              |
| 6:3   | SNUM     | R/W | 扇编号 (Sector Number)<br>此位域用于指定擦除的扇区。<br>0000: 扇区 0<br>0001: 扇区 1<br>0010: 扇区 2<br>.....<br>1011: 扇区 11<br>其他: 保留 |
| 7     |          |     | 保留                                                                                                               |
| 10:8  | PGSIZE   | R/W | 编程大小 (Program Size)<br>此位域用于选择并行位数。<br>000: 8-bit<br>001: 16-bit<br>010: 32-bit<br>011: 64-bit                   |
| 15:11 |          |     | 保留                                                                                                               |
| 16    | START    | R/S | 开始 (Start)<br>此位置 1 可以触发擦除操作。在 BUSY 位清零时清零。                                                                      |
| 23:17 |          |     | 保留                                                                                                               |
| 24    | OPCINTEN | R/W | 使能操作完成中断 (Operation Complete Interrupt Enable)<br>0: 禁用<br>1: 使能                                                 |
| 25    | ERRINTEN | R/W | 使能错误中断 (Error Interrupt Enable)<br>0: 禁用<br>1: 使能                                                                |
| 30:26 |          |     | 保留                                                                                                               |
| 31    | LOCK     | R/S | 锁定 (Lock)<br>此位置 1 时表示此寄存器锁定，检测到解锁序列时由硬件清零。                                                                      |

### 3.7.6 Flash 选项控制寄存器 (FMC\_OPTCTRL)

偏移地址: 0x14

复位值: 0x0FFF AAED

只有没有任何正在进行的 Flash 操作时，才能访问这个寄存器。

| 位/域 | 名称       | R/W | 描述                                                         |
|-----|----------|-----|------------------------------------------------------------|
| 0   | OPTLOCK  | R/S | 锁定选项 (Option Lock)<br>此位置 1 时表示此寄存器已锁定，检测到解锁序列时由硬件清零。      |
| 1   | OPTSTART | R/S | 开启选项 (Option Start)<br>此位由软件置 1 后可对选项字节进行操作，在 BUSY 位清零时清零。 |

| 位/域   | 名称      | R/W | 描述                                                                                                                                                                                         |
|-------|---------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:2   | BORLVL  | R/W | <p>欠压复位等级 (Brownout Reset Level)<br/> 当电源电压小于欠压复位级别的阈值时, 产生复位。</p> <p>00: 级别 3, 电压范围 2.7V-3.6V<br/> 01: 级别 2, 电压范围 2.4V-2.7V<br/> 10: 级别 1, 电压范围 2.1V-2.4V<br/> 11: 关闭, 电压范围 1.8V-2.1V</p> |
| 4     |         |     | 保留                                                                                                                                                                                         |
| 5     | WDTSEL  | R/W | <p>选择看门狗 (Watchdog Select)<br/> 0: 硬件看门狗<br/> 1: 软件看门狗</p> <p>注意: 当 WDTSEL 模式从硬件切换到软件或从软件切换到硬件时, 需要执行系统复位才能更改生效。</p>                                                                       |
| 6     | RSTSTOP | R/W | <p>进入停机模式时产生复位 (Reset in STOP Mode)<br/> 0: 进入 Stop 模式时产生复位<br/> 1: 进入 Stop 模式时不产生复位</p>                                                                                                   |
| 7     | RSTSTDB | R/W | <p>进入待机模式时产生复位 (Reset in STANDBY Mode)<br/> 0: 进入 Standby 模式时产生复位<br/> 1: 进入 Standby 模式时不产生复位</p>                                                                                          |
| 15:8  | RPROT   | R/W | <p>读保护 (Read Protect)<br/> 此位域用于选择读保护的级别。<br/> 0xAA: 级别 0<br/> 0xCC: 级别 2<br/> 其他: 级别 1</p>                                                                                                |
| 27:16 | NWPROT  | R/W | <p>无写保护 (No Write Protect)<br/> 0: 开启写保护<br/> 1: 关闭写保护</p>                                                                                                                                 |
| 31:28 |         |     | 保留                                                                                                                                                                                         |

## 4 外部存储器控制器 (EMMC)

### 4.1 术语全称、缩写描述

表格 15 术语全称、缩写描述

| 中文全称      | 英文全称                                     | 英文缩写  |
|-----------|------------------------------------------|-------|
| 静态随机存储器   | Static Random Access Memory              | SRAM  |
| 只读存储器     | Read Only Memory                         | ROM   |
| 伪静态随机存储器  | Pseudo Static Random Access Memory       | PSRAM |
| 随机存取存储器   | Random Access Memory                     | RAM   |
| 同步动态随机存储器 | Synchronous Dynamic Random Access Memory | SDRAM |
| 复用        | Multiplex                                | MUX   |
| 宽度        | Width                                    | WID   |
| 闪存        | Flash Memory                             | FM    |
| 访问        | Access                                   | ACC   |
| 等待        | Wait                                     | W     |
| 信号        | Signal                                   | S     |
| 极性        | Polarity                                 | POL   |
| 异步        | Asynchronous                             | ASYN  |
| 突发        | Burst                                    | BURST |
| 时序        | Timing                                   | TIM   |
| 建立        | Setup                                    | SET   |
| 保持        | Hold                                     | HLD   |
| 空         | Empty                                    | E     |

### 4.2 EMMC 概述

EMMC 包括 SMC (静态存储控制器)、DMC (动态存储控制器)。SMC 负责控制 SRAM、PSRAM、NandFlash、NorFlash、PCCard，DMC 控制 SDRAM。

### 4.3 SMC 简介

SMC 是用来管理扩展静态存储器的外设。可以将 AHB 传输信号转换到适当的外部设备。内部存在四个存储块，每个存储块都对应控制不同类型的存储器，通过片选信号加以区别。任一时刻只访问一个外部设备。每个存储块都可以单独配置，时序可编程以适用外部设备。

## 4.4 SMC 结构框图

SMC 主要有五个部分：AHB 总线接口、配置寄存器、NORFlash 控制器、NANDFlash/PC 卡控制器和外部设备接口，具体情况如下图：



## 4.5 SMC 功能描述

### 4.5.1 SMC 访问规则

SMC 是内部 CPU 通过 AHB 总线访问外部静态存储器的接口。在 AHB 总线上，32 位长度数据的操作会被转换成连续的 16 或 8 位操作。为了保证数据传输时的一致性，SMC 在对外部读写操作时需要遵从以下规则：

- (1) AHB 访问外部数据宽度等于存储器数据宽度时，可正常传输。
- (2) AHB 访问外部数据宽度大于存储器数据宽度时，自动将访问操作切割成与外部数据宽度一致进行传输。
- (3) AHB 访问外部数据宽度小于存储器数据宽度时，如果外部存储器具有字节选择功能，则可以通过字节通道正常传输数据；如果不具有该功能，则不允许写操作，只允许读操作。

### 4.5.2 外部设备地址映射

SMC 将外部设备分成多个存储块，不同的存储块对应控制不同的外部设备，具体分类见下表：

表格 16 外部设备地址映射表

| 起始地址        | 结束地址        | 存储块            | 支持存储器类型   |
|-------------|-------------|----------------|-----------|
| 0x6000 0000 | 0x6FFF FFFF | 存储块 1 (4*64MB) | NOR/PSRAM |
| 0x7000 0000 | 0x7FFF FFFF | 存储块 2 (4*64MB) | NAND      |
| 0x8000 0000 | 0x8FFF FFFF | 存储块 3 (4*64MB) | NAND      |
| 0x9000 0000 | 0x9FFF FFFF | 存储块 4 (4*64MB) | PC 卡      |

### 4.5.3 NOR 闪存和 PSRAM

#### 4.5.3.1 地址映射

存储块 1 用于控制 NOR/PSRAM 存储器，内部分成 4 块 64MB 同等大小的区域，各个区域的选择取决于 HADDR[27:26]的值，具体信息如下：

表格 17 存储块 1 地址映射

| HADDR[27:26] | 起始地址        | 结束地址        | 区域块   |
|--------------|-------------|-------------|-------|
| 00           | 0x6000 0000 | 0x63FF FFFF | 区域块 1 |
| 01           | 0x6400 0000 | 0x67FF FFFF | 区域块 2 |
| 10           | 0x6800 0000 | 0x6BFF FFFF | 区域块 3 |
| 11           | 0x6C00 0000 | 0x6FFF FFFF | 区域块 4 |

HADDR 是需要转换到外部存储器的内部 AHB 地址线，它是字节地址，但是外部存储器有一些是不按字节访问的，所以会出现地址不一致的情况。为了避免这种情况产生的错误，SMC 会遵从下述规则进行相应的调整：

- 当外部存储器数据宽度为 8 位时，HADDR[25:0]与 SMC\_A[25:0]对应连接，而 SMC\_A[25:0]与外部存储器地址线相连。
- 当外部存储器数据宽度为 16 位时，HADDR[25:1]与 SMC\_A[24:0]对应连接，而 SMC\_A[24:0]与外部存储器地址线相连。

#### 4.5.3.2 接口信号和控制器

存储块 1 支持 NOR Flash、PSRAM、SRAM 和 ROM 外部存储器。存储块 1 中的四个区域都存在对应的片选信号 NE[x] (x=1...4)，所有其它信号都是共享的，具体接口信号及功能如下：

表格 18 NOR Flash 接口信号

| SMC 信号名称 | 信号方向 | 功能                 |
|----------|------|--------------------|
| CLK      | 输出   | 同步时钟信号             |
| NE[x]    | 输出   | 片选信号，x=1...4       |
| NOE      | 输出   | 读使能信号              |
| NEW      | 输出   | 写使能信号              |
| NWAIT    | 输入   | NOR 闪存要求 SMC 等待的信号 |

| SMC 信号名称   | 信号方向  | 功能                  |
|------------|-------|---------------------|
| A[25:0]    | 输出    | 非复用: A[25:0]全部为地址总线 |
|            | 输出    | 复用: A[25:16]为地址总线   |
| AD[15:0]   | 输入/输出 | 非复用: 双向数据总线         |
|            | 输入/输出 | 复用: 双向地址/数据总线       |
| NL (=NADV) | 输出    | 地址有效信号              |

表格 19 PSRAM 接口信号

| SMC 信号名称   | 信号方向  | 功能                 |
|------------|-------|--------------------|
| CLK        | 输出    | 同步时钟信号             |
| NE[x]      | 输出    | 片选信号, $x=1\dots 4$ |
| NOE        | 输出    | 读使能信号              |
| NEW        | 输出    | 写使能信号              |
| NWAIT      | 输入    | PSRAM 要求 SMC 等待的信号 |
| A[25:0]    | 输出    | 地址总线               |
| D[15:0]    | 输入/输出 | 双向数据总线             |
| NL (=NADV) | 输出    | 地址有效信号             |
| NBL[1]     | 输出    | 高字节使能              |
| NBL[0]     | 输出    | 低字节使能              |

注意: 控制器的输出信号在内部时钟的上升沿变化。在同步写模式下, 输出的数据在存储器时钟的下降沿变化。

NOR Flash/PSRAM 控制器给外部存储器提供了可编程的时序参数, 具体包含参数如下表:

表格 20 可编程的 NOR/PSRAM 时序参数

| 参数     | 功能                             | 访问方式      | 单位              | 最小 | 最大  |
|--------|--------------------------------|-----------|-----------------|----|-----|
| 数据产生时间 | 突发模式下产生第一个数据所需的时钟数目            | 同步        | 存储器时钟周期 (CLK)   | 2  | 17  |
| 时钟分频因子 | 存储器访问的时钟周期 (CLK) 与 AHB 时钟周期的比例 | 同步        | AHB 时钟周期 (HCLK) | 2  | 16  |
| 总线恢复时间 | 总线恢复阶段的时间                      | 异步或同步读    |                 | 1  | 16  |
| 数据建立时间 | 数据建立阶段的时间                      | 异步        |                 | 2  | 256 |
| 地址保持时间 | 地址保持阶段的时间                      | 异步, 复用 IO |                 | 2  | 16  |
| 地址建立时间 | 地址建立阶段的时间                      | 异步        |                 | 1  | 16  |

#### 4.5.4 NAND 闪存和 PC 卡

##### 4.5.4.1 地址映射

存储块 2、3 和 4 是用来访问 NAND 闪存和 PC 卡，同样在每个存储块内也被分为不同的区域，不同区域对应效果不一样，具体分布如下表：

表格 21 存储块 2、3、4 地址映射

| SMC 存储块       | 存储空间 | 起始地址        | 结束地址        |
|---------------|------|-------------|-------------|
| 存储块 2-NAND 闪存 | 通用   | 0x7000 0000 | 0x73FF FFFF |
|               | 属性   | 0x7800 0000 | 0x7BFF FFFF |
| 存储块 3-NAND 闪存 | 通用   | 0x8000 0000 | 0x83FF FFFF |
|               | 属性   | 0x8800 0000 | 0x8BFF FFFF |
| 存储块 4-PC 卡    | 通用   | 0x9000 0000 | 0x93FF FFFF |
|               | 属性   | 0x9800 0000 | 0x9BFF FFFF |
|               | I/O  | 0x9C00 0000 | 0x9FFF FFFF |

NAND 闪存存储块中又在低字节一部分区域划分了三个块，通过 HADDR[17:16] 来选择对不同块进行访问，三个块的具体划分及其选择如下表：

表格 22 NAND 存储块划分

| HADDR[17:16] | 地址范围              | 块名称 |
|--------------|-------------------|-----|
| 00           | 0x000000-0x00FFFF | 数据块 |
| 01           | 0x010000-0x01FFFF | 命令块 |
| 1X           | 0x020000-0x03FFFF | 地址块 |

为实现对 NAND 存储器的正常读写，需要有以下步骤：

- (1) 向存储器发送命令
- (2) 向存储器发送需要读写的地址
- (3) 读写数据

对应的三步操作需要操作的地址，便对应存储块中所划分的三个块。向存储器发送命令便是对命令块写入相应命令值；向存储器发送地址便是向地址块发送相应地址值；读写数据便是在数据块中读写，最终写入或读出 NAND 的内部单元，对应单元的地址便是在地址块写入的地址。

##### 4.5.4.2 接口信号和控制器

NAND/PC 卡控制器可以控制三个存储块，存储块 2、3 支持 NAND Flash，存储块 4 支持 PC 卡设备，三个存储块也都有各自的片选信号，具体接口及功能如下：

表格 23 NAND Flash 接口信号

| SMC 信号名称       | 信号方向  | 功能                       |
|----------------|-------|--------------------------|
| NCE[x]         | 输出    | 片选信号, x=2,3              |
| NOE (=NRE)     | 输出    | 读使能信号                    |
| NEW            | 输出    | 写使能信号                    |
| NWAIT/INT[3:2] | 输入    | NAND Flash 就绪/忙输入信号      |
| A[17]          | 输出    | NAND Flash 地址锁存信号 (ALE)  |
| A[16]          | 输出    | NAND Flash 命令锁存信号 (CLE)  |
| D[15:0]        | 输入/输出 | 8 位复用: D[7:0]双向地址/数据总线   |
|                | 输入/输出 | 16 位复用: D[15:0]双向地址/数据总线 |

表格 24 PC 卡接口信号

| SMC 信号名称 | 信号方向  | 功能                         |
|----------|-------|----------------------------|
| NCE4_1   | 输出    | 片选信号 1                     |
| NCE4_2   | 输出    | 片选信号 2 (选择 16 位或 8 位操作)    |
| NOE      | 输出    | 读使能信号                      |
| NEW      | 输出    | 写使能信号                      |
| NWAIT    | 输入    | PC 卡等待信号                   |
| INTR     | 输入    | PC 卡中断信号                   |
| CD       | 输入    | PC 卡检测信号                   |
| A[10:0]  | 输出    | 地址总线                       |
| NIOS16   | 输入    | 16 位传输 I/O 空间的数据传输宽度 (须接地) |
| NIORD    | 输出    | I/O 空间输出使能                 |
| NIOWR    | 输出    | I/O 空间写使能                  |
| NREG     | 输出    | 对通用空间或者属性空间访问的选择           |
| D[15:0]  | 输出/输入 | 双向数据总线                     |

NAND Flash/PC 卡控制器给外部存储器提供了可编程的时序参数, 具体包含参数如下表:

表格 25 可编程 NAND/PC 卡时序参数

| 参数          | 功能                              | 操作模式     | 单位              | 最小 | 最大  |
|-------------|---------------------------------|----------|-----------------|----|-----|
| 存储器数据总线高阻时间 | 启动写操作后保持数据总线为高阻态的时间             | 写<br>读/写 | AHB 时钟周期 (HCLK) | 0  | 255 |
| 存储器保持时间     | 发送命令结束后保持地址的时钟数目, 写操作时也是数据的保持时间 |          |                 | 1  | 254 |
| 存储器等待时间     | 发出的最短持续时间                       |          |                 | 2  | 256 |

| 参数      | 功能              | 操作模式 | 单位 | 最小 | 最大  |
|---------|-----------------|------|----|----|-----|
| 存储器建立时间 | 发出命令之前建立地址的时钟数目 |      |    | 1  | 255 |

## 4.6 SMC 寄存器地址映射

表格 26 SMC 寄存器地址映射

| 寄存器名            | 描述                       | 偏移地址                                |
|-----------------|--------------------------|-------------------------------------|
| SMC_CSCTRL1...4 | SRAM/NOR 闪存片选控制寄存器 1...4 | $8^*(x-1)$ , $x=1...4$              |
| SMC_CSTIM1...4  | SRAM/NOR 闪存片选时序寄存器 1...4 | $0x04 + 8^*(x-1)$ , $x=1...4$       |
| SMC_WRTTIM1...4 | SRAM/NOR 闪存写时序寄存器 1...4  | $0x104 + 8^*(x-1)$ , $x=1...4$      |
| SMC_CTRL2...4   | PC 卡/NAND 闪存控制寄存器 2...4  | $0x40 + 0x20 * (x-1)$ , $x=2...4$   |
| SMC_STSINT2...4 | FIFO 状态和中断寄存器 2...4      | $0x44 + 0x20 * (x-1)$ , $x=2...4$   |
| SMC_CMSTIM2...4 | 通用存储空间时序寄存器 2...4        | $0x48 + 0x20 * (x-1)$ , $x=2...4$   |
| SMC_AMSTIM2...4 | 属性存储空间时序寄存器 2...4        | $0x4C + 0x20 * (x-1)$ , $x=2...4$   |
| SMC_IOSTIM4     | I/O 空间时序寄存器 4            | 0xB0                                |
| SMC_ECCRS2/3    | ECC 结果寄存器 2/3            | $0x54 + 0x20 * (x-1)$ , $x=2$ 或 $3$ |

## 4.7 SMC 寄存器功能描述

### 4.7.1 NOR 闪存和 PSRAM 控制寄存器

#### 4.7.1.1 SRAM/NOR 闪存片选控制寄存器 1...4 (SMC\_CSCTRL1...4)

偏移地址:  $8^*(x-1)$ ,  $x=1...4$

复位值: 0x0000 30DX

| 位/域 | 名称       | R/W | 描述                                                                                                                           |
|-----|----------|-----|------------------------------------------------------------------------------------------------------------------------------|
| 0   | MBKEN    | R/W | 使能对应的存储器块 (Enable the Corresponding Memory Bank)<br>0: 禁用<br>1: 使能                                                           |
| 1   | ADMUXEN  | R/W | 使能地址/数据复用 (Address/Data Multiplexing Enable)<br>该位仅对 NORFlash 和 PSRAM 有效。<br>0: 禁用<br>1: 地址低 16 位和数据共用数据总线                   |
| 3:2 | MTYPECFG | R/W | 配置存储器类型 (Memory Type Configure)<br>00: SRAM、ROM (Bank2~Bank4 复位后的默认值)<br>01: PSRAM<br>10: NORFlash (Bank1 复位后的默认值)<br>其他: 保留 |

| 位/域 | 名称         | R/W | 描述                                                                                                                                          |
|-----|------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------|
| 5:4 | MDBWIDCFG  | R/W | 配置存储器数据总线宽度 (Memory Data Bus Width Configure)<br>00: 8 位<br>01: 16 位<br>其他: 保留                                                              |
| 6   | NORFMACCEN | R/W | 使能访问 NORFlash (NORFlash Memory Access Enable))<br>0: 禁用<br>1: 使能                                                                            |
| 7   |            |     | 保留                                                                                                                                          |
| 8   | BURSTEN    | R/W | 使能突发模式 (Burst Mode Enable)<br>在同步模式下, 可使用突发模式访问存储器。<br>0: 禁用<br>1: 使能                                                                       |
| 9   | WSPOLCFG   | R/W | 配置等待信号极性 (Wait Signal Polarity Configure)<br>该位仅在突发模式下有效。<br>0: 低有效<br>1: 高有效                                                               |
| 10  | WRAPBEN    | R/W | 使能非对齐的突发模式 (Wrapped Burst Mode Enable))<br>该位仅在突发模式下有效。<br>0: 禁用<br>1: 使能                                                                   |
| 11  | WTIMCFG    | R/W | 配置等待时序 (Wait Timing Configure)<br>该位用来配置存储器是在等待状态前一个周期产生 NWAIT 信号, 还是在等待期间产生。该位仅在突发模式下有效。<br>0: NWAIT 信号在等待前的一个数据周期有效<br>1: NWAIT 信号在等待期间有效 |
| 12  | WREN       | R/W | 使能写存储器 (Write Memory Enable)<br>该位用来使能 SMC 对存储器的写操作。<br>0: 禁用写, 否则产生一个 AHB 错误<br>1: 允许写                                                     |
| 13  | WAITEN     | R/W | 等待使能 (Wait Enable)<br>该位用来使能 NWAIT 信号插入等待状态, 该位仅在突发模式下有效。<br>0: 禁用<br>1: 使能                                                                 |
| 14  | EXTMODEEN  | R/W | 使能扩展模式 (Extended Mode Enable)<br>在扩展模式下, 可使用 SMC_WRTTIM 寄存器, 实现读、写使用不同的时序的功能。<br>0: 禁用<br>1: 使能                                             |
| 15  | WSASYNCEN  | R/W | 使能异步传输期间的等待信号 (Wait Signal During Asynchronous Transfers Enable)<br>该位用来在异步协议期间 SMC 可使用 NWAIT 信号。<br>0: 禁用<br>1: 使能                         |

| 位/域   | 名称           | R/W | 描述                                                                                                                                   |
|-------|--------------|-----|--------------------------------------------------------------------------------------------------------------------------------------|
| 18:16 | CRAMPSIZECFG | R/W | 配置 CRAM 页大小 (CRAM Page Size Configure)<br>000: 当跨越页面边界时没有突发分裂<br>001: 128 字节<br>010: 256 字节<br>011: 512 字节<br>100: 1024 字节<br>其他: 保留 |
| 19    | WRBURSTEN    | R/W | 使能突发写 PSRAM (Write PSRAM Burst Enable)<br>该位使能写操作的同步突发传输协议。<br>0: 写操作为异步模式<br>1: 写操作为同步模式                                            |
| 31:20 |              |     | 保留                                                                                                                                   |

#### 4.7.1.2 SRAM/NOR 闪存片选时序寄存器 1...4 (SMC\_CSTIM1...4)

偏移地址: 0x04 + 8\*(x-1), x=1...4

复位值: 0x0FFF FFFF

| 位/域   | 名称         | R/W | 描述                                                                                                                                                                                                |
|-------|------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0   | ADDRSETCFG | R/W | 配置地址建立时间 (Address Setup Time Configure)<br>仅适用于 SRAM、ROM 和异步总线复用模式的 NOR 闪存操作。<br>0000: 1 个 HCLK 时钟周期<br>0001: 2 个 HCLK 时钟周期<br>.....<br>1111: 16 个 HCLK 时钟周期<br>注意: 同步操作中, 该参数无含义, 始终为 1 个存储器时钟周期 |
| 7:4   | ADDRHLDCFG | R/W | 配置地址保持时间 (Address-Hold Time Configure)<br>仅适用于 SRAM、ROM 和异步总线复用模式的 NOR 闪存操作。<br>0000: 保留<br>0001: 2 个 HCLK 时钟周期<br>.....<br>1111: 16 个 HCLK 时钟周期<br>注意: 同步操作中, 该参数无含义, 始终为 1 个存储器时钟周期             |
| 15:8  | DATASETCFG | R/W | 配置数据建立时间 (Data Setup Time Configure)<br>仅适用于 SRAM、ROM 和异步总线复用模式的 NOR 闪存操作。<br>0000 0000: 保留<br>0000 0001: 2 个 HCLK 时钟周期<br>0000 0010: 3 个 HCLK 时钟周期<br>.....<br>1111 1111: 256 个 HCLK 时钟周期        |
| 19:16 | BUSTURNCFG | R/W | 配置总线恢复时间 (Bus Turnaround Phase Duration Configure)<br>这些位用来配置一次读操作后在总线上的延迟时间, 仅适用于总线复用模式的 NOR 闪存操作。<br>0000: 1 个 HCLK 时钟周期<br>0001: 2 个 HCLK 时钟周期<br>.....<br>1111: 16 个 HCLK 时钟周期                |

| 位/域   | 名称          | R/W | 描述                                                                                                                                                                                                                                                                                            |
|-------|-------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23:20 | CLKDIVCFG   | R/W | <p>配置时钟分频系数 (Clock Divide Factor Configure)<br/>           CLK 来自 HCLK 的分频, 这些位用来配置 CLK 时钟输出信号的频率, 仅适用于在同步模式。</p> <p>0000: 保留<br/>           0001: 2 分频<br/>           0010: 3 分频<br/>           .....<br/>           1111: 16 分频</p> <p>注意: 在访问异步 NOR 闪存、SRAM 或 ROM 时, 该参数无效。</p>            |
| 27:24 | DATALATCFG  | R/W | <p>配置数据保持时间 (Data Latency Configure)<br/>           这些位用来配置在读取第一个数据前等待的存储器周期数目, 仅适用于同步突发模式的 NOR 闪存操作。</p> <p>0000: 2 个 CLK 时钟周期<br/>           0001: 3 个 CLK 时钟周期<br/>           .....<br/>           1111: 17 个 CLK 时钟周期</p> <p>注意: 在访问异步 NOR 闪存、SRAM 或 ROM 时, 该参数无效, 操作 CRAM 时, 该参数为 0。</p> |
| 29:28 | ASYNCACCCFG | R/W | <p>配置异步访问模式 (Asynchronous Access Mode Configure)<br/>           仅在 SMC_CSCTRLX 寄存器的 EXTMODEEN 位为 1 时生效。</p> <p>00: 访问模式 A<br/>           01: 访问模式 B<br/>           10: 访问模式 C<br/>           11: 访问模式 D</p>                                                                                   |
| 31:30 | 保留          |     |                                                                                                                                                                                                                                                                                               |

#### 4.7.1.3 SRAM/NOR 闪存写时序寄存器 1...4 (SMC\_WRTTIM1...4)

偏移地址: 0x104 + 8\*(x-1), x=1...4

复位值: 0x0FFF FFFF

| 位/域 | 名称         | R/W | 描述                                                                                                                                                                                                                                                               |
|-----|------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0 | ADDRSETCFG | R/W | <p>配置地址建立时间 (Address Setup Time Configure)<br/>           仅适用于 SRAM、ROM 和异步总线复用模式的 NOR 闪存操作。</p> <p>0000: 1 个 HCLK 时钟周期<br/>           0001: 2 个 HCLK 时钟周期<br/>           .....<br/>           1111: 16 个 HCLK 时钟周期</p> <p>注意: 同步操作中, 该参数无含义, 始终为 1 个存储器时钟周期</p> |
| 7:4 | ADDRHLDCFG | R/W | <p>配置地址保持时间 (Address-Hold Time Configure)<br/>           仅适用于 SRAM、ROM 和异步总线复用模式的 NOR 闪存操作。</p> <p>0000: 保留<br/>           0001: 2 个 HCLK 时钟周期<br/>           .....<br/>           1111: 16 个 HCLK 时钟周期</p> <p>注意: 同步操作中, 该参数无含义, 始终为 1 个存储器时钟周期</p>             |

| 位/域   | 名称          | R/W | 描述                                                                                                                                                                                                                                                                                                           |
|-------|-------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:8  | DATASETCFG  | R/W | <p>配置数建立时间 (Data-Setup Time Configure)<br/>         仅适用于 SRAM、ROM 和异步总线复用模式的 NOR 闪存操作。<br/>         0000 0000: 保留<br/>         0000 0001: 2 个 HCLK 时钟周期<br/>         0000 0010: 3 个 HCLK 时钟周期<br/>         .....<br/>         1111 1111: 256 个 HCLK 时钟周期</p>                                                 |
| 19:16 | BUSTURNCFG  | R/W | <p>配置总线恢复时间 (Bus Turnaround Phase Duration Configure)<br/>         这些位用来配置一次读操作后在总线上的延迟时间，仅适用于总线复用模式的 NOR 闪存操作。<br/>         0000: 1 个 HCLK 时钟周期<br/>         0001: 2 个 HCLK 时钟周期<br/>         .....<br/>         1111: 16 个 HCLK 时钟周期</p>                                                                   |
| 23:20 | CLKDIVCFG   | R/W | <p>配置 CLK 信号的时钟分频比 (Clock Divide Ratio for CLK signal Configure)<br/>         CLK 时钟输出信号的周期，用 HCLK 周期数表示。<br/>         0000: 保留<br/>         0001: CLK 周期=2×HCLK 周期<br/>         0010: CLK 周期=3×HCLK 周期<br/>         1111: CLK 周期=16×HCLK 周期 (复位后的默认值)<br/>         在异步 NOR Flash、SRAM 或 ROM 访问模式下，该位无效。</p> |
| 27:24 | DATLATCFG   | R/W | <p>配置数据延迟时间 (用于同步突发 NOR Flash) (Data Latency Configure)<br/>         该位用来定义获取首个数据前要发送给存储器的存储器时钟周期数(+2)。<br/>         0000: 首次突发访问时，2 个 CLK 时钟周期的数据延迟<br/>         ...<br/>         1111: 首次突发访问时，17 个 CLK 时钟周期的数据延迟 (复位后的默认值)<br/>         在异步 NOR Flash、SRAM 或 ROM 访问模式下，该位无效。</p>                          |
| 29:28 | ASYNCACCCFG | R/W | <p>配置异步访问模式 (Asynchronous Access Mode Configure)<br/>         这些位用来配置异步访问模式，仅在 SMC_CSCTRLX 寄存器的 EXTMODEEN 位为 1 时生效。<br/>         00: 访问模式 A<br/>         01: 访问模式 B<br/>         10: 访问模式 C<br/>         11: 访问模式 D</p>                                                                                      |
| 31:30 |             |     | 保留                                                                                                                                                                                                                                                                                                           |

## 4.7.2 NAND 闪存和 PC 卡控制寄存器

### 4.7.2.1 PC 卡/NAND 闪存控制寄存器 2...4 (SMC\_CTRL2...4)

偏移地址: 0x40 + 0x20 \* (x-1), x=2...4

复位值: 0x0000 0018

| 位/域   | 名称       | R/W | 描述                                                                                                                                                       |
|-------|----------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     |          |     | 保留                                                                                                                                                       |
| 1     | WAITFEN  | R/W | 使能 PC 卡/NANDFlash 等待功能 (PC Card/NANDFlash Wait Feature Enable)<br>0: 禁用<br>1: 使能                                                                         |
| 2     | MBKEN    | R/W | 使能 PC 卡/NAND 存储器块 (PC Card/NAND Flash Memory Bank Enable)<br>0: 禁用<br>1: 使能                                                                              |
| 3     | MTYPECFG | R/W | 配置存储器类型 (Memory Type Configure)<br>0: PC 卡、CF 卡、CF+卡或 PCMCIA<br>1: NAND 闪存                                                                               |
| 5:4   | DBWIDCFG | R/W | 配置数据总线宽度 (Databus Width Configure)<br>对于 PC Card, 必须使用 16 位。<br>00: 8 位<br>01: 16 位<br>其他保留                                                              |
| 6     | ECCEN    | R/W | 使能 ECC 计算电路 (ECC Computation Logic Enable)<br>0: 禁用并复位 ECC<br>1: 使能                                                                                      |
| 8:7   |          |     | 保留                                                                                                                                                       |
| 12:9  | C2RDCFG  | R/W | 配置 CLE 至 RE 的延迟 (CLE To RE Delay Configure)<br>配置 “CLE 变为低电平” 至 “RE 变为低电平” 的时间。<br>0000: 1 个 HCLK 周期<br>0000: 2 个 HCLK 周期<br>.....<br>1111: 16 个 HCLK 周期 |
| 16:13 | A2RDCFG  | R/W | 配置 ALE 至 RE 的延迟 (ALE To RE Delay Configure)<br>配置 “ALE 变为低电平” 至 “RE 变为低电平” 的时间<br>0000: 1 个 HCLK 周期<br>0000: 2 个 HCLK 周期<br>.....<br>1111: 16 个 HCLK 周期  |
| 19:17 | ECCPSCFG | R/W | 配置 ECC 页面大小 (ECC Page Size Configure)<br>000: 256 字节<br>001: 512 字节<br>010: 1024 字节<br>011: 2048 字节<br>100: 4096 字节<br>101: 8192 字节                      |
| 31:20 |          |     | 保留                                                                                                                                                       |

#### 4.7.2.2 FIFO 状态和中断寄存器 2...4 (SMC\_STSINT2...4)

偏移地址: 0x44 + 0x20 \* (x-1), x=2...4

复位值: 0x0000 0040

| 位/域  | 名称     | R/W | 描述                                                                                       |
|------|--------|-----|------------------------------------------------------------------------------------------|
| 0    | IREFLG | R/W | 产生中断上升沿标志 (Interrupt Rising Edge Generate Flag)<br>该位由硬件置 1, 软件清 0。<br>0: 没有产生<br>1: 产生  |
| 1    | IHLFLG | R/W | 产生中断高电平标志 (Interrupt High-Level Generate Flag)<br>该位由硬件置 1, 软件清 0。<br>0: 没有产生<br>1: 产生   |
| 2    | IFEFLG | R/W | 产生中断下降沿标志 (Interrupt Falling Edge Generate Flag)<br>该位由硬件置 1, 软件清 0。<br>0: 没有产生<br>1: 产生 |
| 3    | IREDEN | R/W | 使能中断上升沿检测 (Interrupt Rising Edge Detection Enable)<br>0: 禁用<br>1: 使能                     |
| 4    | IHLDEN | R/W | 使能中断高电平检测 (Interrupt High-Level Detection Enable)<br>0: 禁用<br>1: 使能                      |
| 5    | IFEDEN | R/W | 使能中断下降沿检测 (Interrupt Falling Edge Detection Enable)<br>0: 禁用<br>1: 使能                    |
| 6    | FEFLG  | R   | FIFO 空标志 (FIFO Empty Flag)<br>0: 不空<br>1: 空                                              |
| 31:7 |        |     | 保留                                                                                       |

#### 4.7.2.3 通用存储空间时序寄存器 2...4 (SMC\_CMSTIM2...4)

偏移地址:  $0x48 + 0x20 * (x-1)$ ,  $x=2...4$

复位值: 0xFCFC FCFC

| 位/域 | 名称   | R/W | 描述                                                                                                                                                                                                    |
|-----|------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0 | SETx | R/W | 配置在通用空间 x 的建立时间 (Common Memory x Setup Time Configure)<br>该位以 HCLK 为时钟周期, 定义了发送命令之前建立地址的时间。<br>0000 0000: 1 个 HCLK 周期<br>0000 0001: 2 个 HCLK 周期<br>.....<br>1111 1110: 255 个 HCLK 周期<br>1111 1111: 保留 |

| 位/域   | 名称    | R/W | 描述                                                                                                                                                                                                                                                                                                                              |
|-------|-------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:8  | WAITx | R/W | <p>配置在通用空间 x 的等待时间 (Common Memory x Wait Time Configure)</p> <p>该位以 HCLK 为时钟周期, 定义了保持命令的最小时间, 定义的时间结束后, 若等待信号有效低则命令保持时间变长。</p> <p>0000 0000: 保留</p> <p>0000 0001: 2 个 HCLK 周期 (+由 NWAIT 信号变低引入的等待周期)</p> <p>0000 0010: 3 个 HCLK 周期</p> <p>.....</p> <p>1111 1110: 255 个 HCLK 周期 (+由 NWAIT 信号变低引入的等待周期)</p> <p>1111 1111: 保留</p> |
| 23:16 | HLDx  | R/W | <p>配置在通用空间 x 的保持时间 (Common Memory x Hold Time Configure)</p> <p>该位以 HCLK 为时钟周期, 定义了发送命令后, 地址信号保持的时间。</p> <p>0000 0000: 保留</p> <p>0000 0001: 写访问 1 个 HCLK 周期, 读访问 3 个 HCLK 周期</p> <p>.....</p> <p>1111 1110: 写访问 254 个 HCLK 周期, 读访问 256 个 HCLK 周期</p> <p>1111 1111: 保留</p>                                                       |
| 31:24 | HIZx  | R/W | <p>配置在通用空间 x 数据总线的高阻时间 (Common Memory x Databus Hiz Time Configure)</p> <p>该位以 HCLK 为时钟周期, 定义了数据总线高阻态的时间, 仅对写操作生效。</p> <p>0000 0000: 1 个 HCLK 周期</p> <p>0000 0001: 2 个 HCLK 周期</p> <p>.....</p> <p>1111 1110: 255 个 HCLK 周期</p> <p>1111 1111: 保留</p>                                                                            |

#### 4.7.2.4 属性存储空间时序寄存器 2...4 (SMC\_AMSTIM2...4)

偏移地址: 0x4C + 0x20 \* (x-1), x=2...4

复位值: 0xFCFC FCFC

| 位/域   | 名称    | R/W | 描述                                                                                                                                                                                                                                                                                                                      |
|-------|-------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0   | SETx  | R/W | <p>配置在属性空间 x 的建立时间 (Attribute Memory x Setup Time Configure)</p> <p>该位以 HCLK 为时钟周期, 定义了发送命令前建立地址信号的时间。</p> <p>0000 0000: 1 个 HCLK 周期<br/> 0000 0001: 2 个 HCLK 周期<br/> .....<br/> 1111 1110: 255 个 HCLK 周期<br/> 1111 1111: 保留</p>                                                                                        |
| 15:8  | WAITx | R/W | <p>配置在属性空间 x 的等待时间 (Attribute Memory x Wait Time Configure)</p> <p>该位以 HCLK 为时钟周期, 定义了保持命令的最长时间, 定义的时间结束后, 若等待信号有效则命令保持时间变长。</p> <p>0000 0000: 保留<br/> 0000 0001: 2 个 HCLK 周期 (+由 NWAIT 信号变低引入的等待周期)<br/> 0000 0010: 3 个 HCLK 周期<br/> .....<br/> 1111 1110: 255 个 HCLK 周期 (+由 NWAIT 信号变低引入的等待周期)<br/> 1111 1111: 保留</p> |
| 23:16 | HLDx  | R/W | <p>配置在属性空间 x 的保持时间 (Attribute Memory x Hold Time Configure)</p> <p>该位以 HCLK 为时钟周期, 定义了发送命令后, 地址信号保持的时间。</p> <p>0000 0000: 保留<br/> 0000 0001: 写访问 1 个 HCLK 周期, 读访问 3 个 HCLK 周期<br/> .....<br/> 1111 1110: 写访问 254 个 HCLK 周期, 读访问 256 个 HCLK 周期<br/> 1111 1111: 保留</p>                                                    |
| 31:24 | HIZx  | R/W | <p>配置在属性空间 x 数据总线的高阻时间 (Attribute Memory x Databus Hiz Time Configure)</p> <p>该位以 HCLK 为时钟周期, 定义了数据总线高阻态的时间, 仅对写操作生效。</p> <p>0000 0000: 0 个 HCLK 周期<br/> 0000 0001: 1 个 HCLK 周期<br/> .....<br/> 1111 1111: 255 个 HCLK 周期</p>                                                                                            |

#### 4.7.2.5 I/O 空间时序寄存器 4 (SMC\_IOSTIM4)

偏移地址: 0xB0

复位值: 0xFCFC FCFC

| 位/域   | 名称   | R/W | 描述                                                                                                                                                                                                                                                                                                                                              |
|-------|------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0   | SET  | R/W | <p>配置在 I/O 空间 x 的建立时间 (I/O x Setup Time Configure)<br/>           该位以 HCLK 为时钟周期, 定义了发送命令前建立地址信号的时间。</p> <p>0000 0000: 1 个 HCLK 周期<br/>           0000 0001: 2 个 HCLK 周期<br/>           .....<br/>           1111 1111: 256 个 HCLK 周期</p>                                                                                                       |
| 15:8  | WAIT | R/W | <p>配置在 I/O 空间 x 的等待时间 (I/O x Wait Time Configure)<br/>           该位以 HCLK 为时钟周期, 定义了保持命令的最长时间, 定义的时间结束后, 若等待信号有效低, 则命令保持时间变长。</p> <p>0000 0000: 保留<br/>           0000 0001: 2 个 HCLK 周期 (+由 NWAIT 信号变低引入的等待周期)<br/>           0000 0010: 3 个 HCLK 周期<br/>           .....<br/>           1111 1111: 256 个 HCLK 周期 (+由卡的 NWAIT 信号变低引入的等待周期)</p> |
| 23:16 | HLD  | R/W | <p>配置在 I/O 空间 x 的保持时间 (I/O x Hold Time Configure)<br/>           该位以 HCLK 为时钟周期, 定义了发送命令后, 地址信号保持的时间。</p> <p>0000 0000: 保留<br/>           0000 0001: 1 个 HCLK 周期<br/>           0000 0010: 2 个 HCLK 周期<br/>           .....<br/>           1111 1111: 255 个 HCLK 周期</p>                                                                         |
| 31:24 | HIZ  | R/W | <p>配置在 I/O 空间 x 数据总线的高阻时间 (I/O x Databus Hiz Time Configure)<br/>           该位以 HCLK 为时钟周期, 定义了数据总线高阻态的时间, 仅对写操作生效。</p> <p>0000 0000: 0 个 HCLK 周期<br/>           0000 0001: 1 个 HCLK 周期<br/>           .....<br/>           1111 1111: 255 个 HCLK 周期</p>                                                                                        |

#### 4.7.2.6 ECC 结果寄存器 2/3 (SMC\_ECCRS2/3)

偏移地址: 0x54 + 0x20 \* (x-1), x=2 或 3

复位值: 0x0000 0000

| 位/域  | 名称    | R/W | 描述                  |
|------|-------|-----|---------------------|
| 31:0 | ECCRS | R   | ECC 结果 (ECC Result) |

## 4.8 DMC 简介

DMC 一个动态存储控制器, 外接片外 SDR-SDRAM。

## 4.9 DMC 主要特征

- 16 位数据宽度

- 支持 256MB 片外 SDR-SDRAM, 最大支持 13-bit 行地址, 12-bit 列地址, 4 bank 的 16-bit SDRAM
- SDR-SDRAM 的 timing and size 可配置
- 支持 SDR-SDRAM power-down 模式
- 支持 SDR-SDRAM auto-refresh 和 self-refresh 模式

## 4.10 DMC 结构框图

图 3 DMC 结构框图



## 4.11 DMC 功能描述

### 4.11.1 DMC 外部存储器接口

前缀 “N” 的信号表示低有效信号。

表格 27 DMC 引脚

| 信号名称 | 输入/输出 | 管脚  | 功能 |
|------|-------|-----|----|
| A0   | 输出    | PF0 | 地址 |
| A1   | 输出    | PF1 | 地址 |
| A2   | 输出    | PF2 | 地址 |
| A3   | 输出    | PF3 | 地址 |
| A4   | 输出    | PF4 | 地址 |
| A5   | 输出    | PF5 | 地址 |

| 信号名称   | 输入/输出 | 管脚                 | 功能       |
|--------|-------|--------------------|----------|
| A6     | 输出    | PF12               | 地址       |
| A7     | 输出    | PF13               | 地址       |
| A8     | 输出    | PF14               | 地址       |
| A9     | 输出    | PF15               | 地址       |
| A10    | 输出    | PG0                | 地址       |
| A11    | 输出    | PG1                | 地址       |
| A12    | 输出    | PG2                | 地址       |
| A13    | 输出    | PG3                | 地址       |
| D0     | 输入/输出 | PD14               | 双向数据     |
| D1     | 输入/输出 | PD15               | 双向数据     |
| D2     | 输入/输出 | PD0                | 双向数据     |
| D3     | 输入/输出 | PD1                | 双向数据     |
| D4     | 输入/输出 | PE7                | 双向数据     |
| D5     | 输入/输出 | PE8                | 双向数据     |
| D6     | 输入/输出 | PE9                | 双向数据     |
| D7     | 输入/输出 | PE10               | 双向数据     |
| D8     | 输入/输出 | PE11               | 双向数据     |
| D9     | 输入/输出 | PE12               | 双向数据     |
| D10    | 输入/输出 | PE13               | 双向数据     |
| D11    | 输入/输出 | PE14               | 双向数据     |
| D12    | 输入/输出 | PE15               | 双向数据     |
| D13    | 输入/输出 | PD8                | 双向数据     |
| D14    | 输入/输出 | PD9                | 双向数据     |
| D15    | 输入/输出 | PD10               | 双向数据     |
| BA0    | 输出    | PG4                | Bank 地址  |
| BA1    | 输出    | PG5                | Bank 地址  |
| CKE    | 输出    | PC3 <sup>(1)</sup> | 时钟使能     |
| CLK/CK | 输出    | PG8                | 时钟       |
| LDQM   | 输入    | PE0                | 16 位数据写入 |
| UNQM   | 输入    | PE1                | 16 位数据读取 |
| NWE    | 输出    | PC0                | 写使能      |
| NCAS   | 输出    | PG15               | 列地址位选通命令 |
| NRAS   | 输出    | PF11               | 行地址位选通命令 |

| 信号名称 | 输入/输出 | 管脚  | 功能 |
|------|-------|-----|----|
| NCS  | 输出    | PC2 | 片选 |

注意：(1) DMC\_CKE 映射引脚详见数据手册。

#### 4.11.2 DMC 配置举例

配置切换寄存器 DMC\_SW 置 1 使能 DMC;

SDRAM 时钟频率最大值为 120MHZ;

配置寄存器 RCM\_CFG 的位[9:8]决定 SDRAM 的时钟频率;

例如：16M×4Banks×16-bit 的 SDRAM

- 行地址对应引脚：A0-A13，共 14 位
- 列地址对应引脚：A0-A9，共 10 位
- Bank 地址对应引脚：BA0、BA1，为 2 位

配置寄存器 DMC\_CFG 的行地址宽度位置 1101;

配置寄存器 DMC\_CFG 的列地址宽度位置 1001;

配置寄存器 DMC\_CFG 的 Bank 地址宽度位置 01。

#### 4.12 DMC 寄存器地址映射

表格 28 DMC 寄存器地址映射

| 寄存器名      | 描述      | 偏移地址   |
|-----------|---------|--------|
| DMC_CFG   | 配置寄存器   | 0x0000 |
| DMC_TIM0  | 时序寄存器 0 | 0x0004 |
| DMC_TIM1  | 时序寄存器 1 | 0x0008 |
| DMC_CTRL1 | 控制寄存器 1 | 0x000C |
| DMC_REF   | 刷新寄存器   | 0x0010 |
| DMC_SW    | 切换寄存器   | 0x0400 |
| DMC_CTRL2 | 控制寄存器 2 | 0x0404 |

#### 4.13 DMC 寄存器功能描述

##### 4.13.1 配置寄存器 (DMC\_CFG)

偏移地址：0x0000

复位值：0x0014 1388

| 位/域 | 名称 | R/W | 描述 |
|-----|----|-----|----|
| 2:0 |    |     | 保留 |

| 位/域   | 名称     | R/W | 描述                                                                                                                                        |
|-------|--------|-----|-------------------------------------------------------------------------------------------------------------------------------------------|
| 4:3   | BAWCFG | R/W | 配置 bank 地址宽度 (Bank Address Width Configure)<br>00: 地址宽度为 1 (2 个 bank 有效)<br>01: 地址宽度为 2 (4 个 bank 有效)<br>其他: 保留                           |
| 8:5   | RAWCFG | R/W | 配置行地址宽度 (Row Address Width Configure)<br>0000-1001: 保留<br>1010: 行地址位数是 11 位<br>1011: 行地址位数是 12 位<br>.....<br>1101: 行地址位数是 14 位<br>其他: 保留  |
| 12:9  | CAWCFG | R/W | 配置列地址宽度 (Column Address Width Configure)<br>0000-0110: 保留<br>0111: 列地址位数是 8 位<br>1000: 列地址位数是 9 位<br>.....<br>1011: 列地址位数是 12 位<br>其他: 保留 |
| 14:13 | DWCFG  | R/W | 配置数据宽度 (Data Width Configure)<br>可以外接 8 位和 16 位数据总线宽度的 SDRAM 设备<br>00: SDRAM 数据位宽 8 位<br>01: SDRAM 数据位宽 16 位<br>其他: 保留                    |
| 31:15 |        |     | 保留                                                                                                                                        |

#### 4.13.2 时序寄存器 0 (DMC\_TIM0)

偏移地址: 0x0004

复位值: 0x019A 5252

| 位/域 | 名称        | R/W | 描述                                                                                                                                        |
|-----|-----------|-----|-------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0 | CASLSEL0  | R/W | 选择 CAS 等待时间 (CAS Latency Select)<br>CAS = CASLSEL0+ (ECASLSEL1<< 2)<br>00: 1 个时钟周期<br>01: 2 个时钟周期<br>10: 3 个时钟周期<br>11: 4 个时钟周期<br>其他: 保留 |
| 5:2 | RASMINSEL | R/W | 选择 RAS 最小时间 (RAS Minimum Time Select)<br>这些位用来选择行激活和预充电之间的最长时间。<br>0000: 1 个时钟周期<br>0001: 2 个时钟周期<br>.....<br>1111: 16 个时钟周期              |
| 8:6 | DTIMSEL   | R/W | 选择 RAS 到 CAS 的延迟时间 (RAS To CAS Delay Time Select)<br>000: 1 个时钟周期<br>001: 2 个时钟周期<br>.....                                                |

| 位/域   | 名称        | R/W | 描述                                                                                                                                                                         |
|-------|-----------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |           |     | 111: 8 个时钟周期                                                                                                                                                               |
| 11:9  | PCPSEL    | R/W | 选择预充电周期 (Precharge Period Select)<br>000: 1 个时钟周期<br>001: 2 个时钟周期<br>.....<br>111: 8 个时钟周期                                                                                 |
| 13:12 | WRTIMSEL  | R/W | 对于写操作, 选择最后一个数据到下一次预充电的时间 (Select Time Between the Last Data and The Next Precharge for Write Operation)<br>00: 1 个时钟周期<br>01: 2 个时钟周期<br>10: 3 个时钟周期<br>11: 4 个时钟周期       |
| 17:14 | ARPSEL    | R/W | 选择自动刷新周期 (Auto-Refresh Period Select)<br>这些位用来定义两次自动刷新命令间的最长时间间隔。<br>0000: 1 个时钟周期<br>0001: 2 个时钟周期<br>.....<br>1111: 16 个时钟周期                                             |
| 21:18 | XSR0      | R/W | 退出自刷新切换至激活命令或自动刷新读命令之间的最小间隔时间<br>$XSR = XSR0 + (EXSR1 \ll 4)$<br>XSR = 0 ~ 511 对应 1 ~ 512 SDCLK 时钟周期                                                                       |
| 25:22 | ATACP     | R/W | 刷新命令到激活命令的延时周期 (Delay Period from Refresh Command to Active Command)<br>此位定义了刷新命令和激活命令之间的延迟, 以及两个连续刷新命令之间的延迟。<br>0000: 1 个时钟周期<br>0001: 2 个时钟周期<br>.....<br>1111: 16 个时钟周期 |
| 26    | ECASLSEL1 | R/W | 扩展 CAS 等待时间 (Extended CAS Latency)<br>见 CASLSEL0 解释                                                                                                                        |
| 31:27 | EXSR1     | R/W | 退出自刷新切换至激活命令或自动刷新读命令之间的最小间隔时间<br>见 XSR0 解释                                                                                                                                 |

#### 4.13.3 时序寄存器 1 (DMC\_TIM1)

偏移地址: 0x0008

复位值: 0x0007 4E20

| 位/域   | 名称       | R/W | 描述                                                                                                                 |
|-------|----------|-----|--------------------------------------------------------------------------------------------------------------------|
| 15:0  | STBTIM   | R/W | 稳定时间 (Stable Time)<br>SDRAM 上电后, 经过多少个时钟周期后才接收其他命令。                                                                |
| 19:16 | ARNUMCFG | R/W | 配置初始化过程中自动刷新数量 (Number of Auto-Refresh During Initialization Configure)<br>0000: 1 个自动刷新<br>0001: 2 个自动刷新<br>..... |

| 位/域   | 名称 | R/W | 描述             |
|-------|----|-----|----------------|
|       |    |     | 1111: 16 个自动刷新 |
| 31:20 |    |     | 保留             |

#### 4.13.4 控制寄存器 1 (DMC\_CTRL1)

偏移地址: 0x000C

复位值: 0x0000 3048

| 位/域 | 名称       | R/W | 描述                                                                                                                                                                                 |
|-----|----------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | INIT     | R/W | 初始化 SDRAM (SDRAM Initialize)<br>0: 无效<br>1: 初始化 SDRAM。SDRAM 初始化完后, 硬件自动置 0 此位。                                                                                                     |
| 1   | SRMEN    | R/W | 将 SDRAM 设置为自刷新模式 (Put SDRAM in Self-Refresh Mode Enable)<br>0: 无效<br>1: 使能                                                                                                         |
| 2   | PDMEN    | R/W | 使能将 SDRAM 设置为掉电模式 (Put SDRAM in Power-Down Mode Enable)<br>0: 禁用<br>1: 使能                                                                                                          |
| 3   | PCACFG   | R/W | 配置预充电方式 (Precharge Algorithm Configure)<br>0: 读取操作完毕后立即行预充电<br>1: 读取操作完毕后延迟一段时候后才对行预充电                                                                                             |
| 4   | FRBSREN  | R/W | 进入自刷新模式前全刷新 (Full Refresh Before Entering Self-Refresh Mode)<br>0: 进入自刷新模式前仅仅刷新一行<br>1: 进入自刷新模式前刷新所有行                                                                              |
| 5   | FRASREN  | R/W | 退出自刷新模式前全刷新 (Full Refresh After Exit Self-Refresh Mode)<br>0: 退出自刷新模式后仅仅刷新一行<br>1: 退出自刷新模式后刷新所有行                                                                                   |
| 8:6 | RDNUMCFG | R/W | 配置读取路径中插入寄存器的数量 (Configure Number of Registers Inserted in Read Data Path)<br>RDNUMCFG 有读延时粗调功能, 结合控制寄存器 2 的延时控制位可以将读数据正确锁存。<br>000: 0 个寄存器<br>001: 1 个寄存器<br>.....<br>111: 7 个寄存器 |
| 9   | MODESET  | R/W | 模式设置 (Mode Setup)<br>1: 更新 SDRAM 模式寄存器。完成模式寄存器更新后, 硬件自动清零该位                                                                                                                        |
| 10  |          |     | 保留                                                                                                                                                                                 |
| 11  | SRMFLG   | R   | 自刷新模式标志 (Self-refresh Mode Flag)<br>0: SDRAM 当前不处于自刷新模式中<br>1: 当前 SDRAM 处于自刷新模式中, 当 FRBSREN 位置 1 时此位有效。                                                                            |

| 位/域   | 名称         | R/W | 描述                                                                                                                                     |
|-------|------------|-----|----------------------------------------------------------------------------------------------------------------------------------------|
| 15:12 | BANKNUMCFG | R/W | 配置打开 bank 数量 (Number of Open Banks Configure)<br>SDRAM 内部 bank 被打开的数量。<br>0000: 1 个 bank<br>0001: 2 个 bank<br>.....<br>1111: 16 个 bank |
| 31:16 |            |     | 保留                                                                                                                                     |

#### 4.13.5 刷新寄存器 (DMC\_REF)

偏移地址: 0x0010

复位值: 0x0000 00C3

| 位/域   | 名称      | R/W | 描述                                                     |
|-------|---------|-----|--------------------------------------------------------|
| 15:0  | RCYCCFG | R/W | 配置刷新周期 (Refresh Cycle Configure)<br>指定连续两次刷新间隔多少个时钟周期。 |
| 31:16 |         |     | 保留                                                     |

#### 4.13.6 切换寄存器 (DMC\_SW)

偏移地址: 0x0400

复位值: 0x0000 0000

| 位/域  | 名称   | R/W | 描述                                                                      |
|------|------|-----|-------------------------------------------------------------------------|
| 0    | MCSW | R/W | 切换存储控制器功能 (Memory Controller Function Switch)<br>0: 选择 SMC<br>1: 选择 DMC |
| 31:1 |      |     | 保留                                                                      |

#### 4.13.7 控制寄存器 2 (DMC\_CTRL2)

偏移地址: 0x0404

复位值: 0x0000 002E

| 位/域 | 名称      | R/W | 描述                                                                                                                                          |
|-----|---------|-----|---------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | CPHACFG | R/W | 配置时钟相位 (Clock Phase Configure)<br>0: SDRAM_CLK 不反向<br>1: SDRAM_CLK 反向                                                                       |
| 1   | RDDEN   | R/W | 使能 RD 延时 (RD Delay Function Enable)<br>0: 使能<br>1: 禁用                                                                                       |
| 4:2 | RDDCFG  | R/W | 配置 RD 延时时钟 (RD Clock Delay Configure)<br>此位段为 RDDCFG 的低 3 位, 与[11:10]位组合使用。<br>00000: 1 个系统时钟<br>00001: 2 个系统时钟<br>.....<br>11111: 32 个系统时钟 |
| 5   | WPEN    | R/W | 使能写管道 (Write Pipe Enable)<br>0: 禁用<br>1: 使能                                                                                                 |

| 位/域   | 名称      | R/W | 描述                                                                             |
|-------|---------|-----|--------------------------------------------------------------------------------|
| 6     | BUFFEN  | R/W | 使能 DMC 加速模块 (DMC Accelerate Module Enable)<br>通过缓冲区开启, 回环突发数据传输, 提高 SDRAM 读性能。 |
| 7     | WRPBSEL | R/W | 选择回环突发类型 (WRAP Burst Type Selection)<br>0: 回环突发长度为 4 节拍传输<br>1: 回环突发长度为 8 节拍传输 |
| 9:8   | 保留      |     |                                                                                |
| 11:10 | RDDCFG2 | R/W | 配置 RD 延时时钟 (RD Clock Delay Configure)<br>此位段为 RDDCFG 的高 2 位, 与[4:2]位组合使用。      |
| 31:12 | 保留      |     |                                                                                |

## 5 系统配置控制器 (SYSCFG)

### 5.1 术语全称、缩写描述

表格 29 术语全称、缩写描述

| 中文全称    | 英文全称             | 英文缩写   |
|---------|------------------|--------|
| 系统配置控制器 | System Configure | SYSCFG |

### 5.2 主要特征

- (1) 配置存储器的重映射
- (2) 选择 MAC PHY 接口
- (3) 配置 GPIO 的外部中断
- (4) 控制 I/O 补偿单元

### 5.3 I/O 补偿单元

当 I/O 输出缓冲区速度被配置为 50MHz 或 100MHz 时, I/O 端口噪声会对电源电压有影响, 所以当电源电压为 2.4~3.6V 时, 可以使能补偿单元, 控制  $t_{f(I/O)out}/t_{r(I/O)out}$  斜率, 能够降低对电源的影响。

### 5.4 寄存器地址映射

表格 30 SYSCFG 寄存器地址映射

| 寄存器名            | 描述        | 偏移地址 |
|-----------------|-----------|------|
| SYSCFG_MMSEL    | 存储映射选择寄存器 | 0x00 |
| SYSCFG_PMCFG    | 外设模式配置寄存器 | 0x04 |
| SYSCFG_EINTCFG1 | 外部中断寄存器 1 | 0x08 |
| SYSCFG_EINTCFG2 | 外部中断寄存器 2 | 0x0C |
| SYSCFG_EINTCFG3 | 外部中断寄存器 3 | 0x10 |
| SYSCFG_EINTCFG4 | 外部中断寄存器 4 | 0x14 |
| SYSCFG_CCCTRL   | 补偿单元控制寄存器 | 0x20 |

### 5.5 寄存器功能描述

#### 5.5.1 存储映射选择寄存器 (SYSCFG\_MMSEL)

偏移地址: 0x00

复位值: 0x0000 000X (复位后, X 的值与 BOOT 引脚的设置相同)

该寄存器用于通过软件配置在地址为 0x0000 0000 访问的存储器区域，从而旁路 BOOT 引脚。

| 位/域  | 名称    | R/W | 描述                                                                                                                                                                                                                                                                 |
|------|-------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0  | MMSEL | R/W | 存储映射选择 (Memory Mapping Select)<br>控制内存映射地址 0x0000 0000。重置后这些位的参数由实际 BOOT 决定。<br>00: 主闪存映射地址: 0x0000 0000<br>01: 系统闪存映射地址: 0x0000 0000<br>10: SMC Bank1 (NOR/PSRAM1 和 2) 映射地址: 0x0000 0000<br>DMC SDRAM Bank 1 映射地址: 0x0000 0000<br>11: 嵌入式 SRAM1 映射地址: 0x0000 0000 |
| 31:2 |       |     | 保留                                                                                                                                                                                                                                                                 |

### 5.5.2 外设模式配置寄存器 (SYSCFG\_PMCFG)

偏移地址: 0x04

复位值: 0x0000 0000

| 位/域   | 名称      | R/W | 描述                                                                                                                              |
|-------|---------|-----|---------------------------------------------------------------------------------------------------------------------------------|
| 22:0  |         |     | 保留                                                                                                                              |
| 23    | ENETSEL | R/W | 选择以太网物理层接口 (Ethernet PHY Interface Select)<br>控制物理层接口。<br>0: MII 接口<br>1: RMII PHY 接口<br>注意: 应在 ENET 复位时, ENET 时钟被使能前, 对此位进行操作。 |
| 31:24 |         |     | 保留                                                                                                                              |

### 5.5.3 外部中断寄存器 1 (SYSCFG\_EINTCFG1)

以下几个 SYSCFG 外部中断寄存器的 EINTx [3:0]的值所代表选择的外部中断源如下表所示。

表格 31 不同值所选择外部中断源

| EINTx [3:0] | 外部中断源    |
|-------------|----------|
| 0000        | PA[x] 引脚 |
| 0001        | PB[x] 引脚 |
| 0010        | PC[x] 引脚 |
| 0011        | PD[x] 引脚 |
| 0100        | PE[x] 引脚 |
| 0101        | PF[x] 引脚 |
| 0110        | PG[x] 引脚 |
| 0111        | PH[x] 引脚 |
| 其他          | 保留       |

偏移地址: 0x08

复位值: 0x0000 0000

这些位由软件控制进行改写来选择 EINTx(x=0...3)的外部中断源。

| 位/域   | 名称    | R/W | 描述                                                           |
|-------|-------|-----|--------------------------------------------------------------|
| 3:0   | EINT0 | R/W | EINT0 配置位 (EINT0 Configure)<br>这些位由软件控制进行改写来选择 EINT0 的外部中断源。 |
| 7:4   | EINT1 | R/W | EINT1 配置位 (EINT1 Configure)<br>这些位由软件控制进行改写来选择 EINT1 的外部中断源。 |
| 11:8  | EINT2 | R/W | EINT2 配置位 (EINT2 Configure)<br>这些位由软件控制进行改写来选择 EINT2 的外部中断源。 |
| 15:12 | EINT3 | R/W | EINT3 配置位 (EINT3 Configure)<br>这些位由软件控制进行改写来选择 EINT3 的外部中断源。 |
| 31:16 |       |     | 保留                                                           |

#### 5.5.4 外部中断寄存器 2 (SYSCFG\_EINTCFG2)

偏移地址: 0x0C

复位值: 0x0000 0000

这些位由软件控制进行改写来选择 EINTx(x=4...7)的外部中断源。

| 位/域   | 名称    | R/W | 描述                                                           |
|-------|-------|-----|--------------------------------------------------------------|
| 3:0   | EINT4 | R/W | EINT4 配置位 (EINT4 Configure)<br>这些位由软件控制进行改写来选择 EINT4 的外部中断源。 |
| 7:4   | EINT5 | R/W | EINT5 配置位 (EINT5 Configure)<br>这些位由软件控制进行改写来选择 EINT5 的外部中断源。 |
| 11:8  | EINT6 | R/W | EINT6 配置位 (EINT6 Configure)<br>这些位由软件控制进行改写来选择 EINT6 的外部中断源。 |
| 15:12 | EINT7 | R/W | EINT7 配置位 (EINT7 Configure)<br>这些位由软件控制进行改写来选择 EINT7 的外部中断源。 |
| 31:16 |       |     | 保留                                                           |

#### 5.5.5 外部中断寄存器 3 (SYSCFG\_EINTCFG3)

偏移地址: 0x10

复位值: 0x0000 0000

这些位由软件控制进行改写来选择 EINTx(x=8...11)的外部中断源。

| 位/域   | 名称     | R/W | 描述                                                              |
|-------|--------|-----|-----------------------------------------------------------------|
| 3:0   | EINT8  | R/W | EINT8 配置位 (EINT8 Configure)<br>这些位由软件控制进行改写来选择 EINT8 的外部中断源。    |
| 7:4   | EINT9  | R/W | EINT9 配置位 (EINT9 Configure)<br>这些位由软件控制进行改写来选择 EINT9 的外部中断源。    |
| 11:8  | EINT10 | R/W | EINT10 配置位 (EINT10 Configure)<br>这些位由软件控制进行改写来选择 EINT10 的外部中断源。 |
| 15:12 | EINT11 | R/W | EINT11 配置位 (EINT11 Configure)<br>这些位由软件控制进行改写来选择 EINT11 的外部中断源。 |
| 31:16 |        |     | 保留                                                              |

#### 5.5.6 外部中断寄存器 4 (SYSCFG\_EINTCFG4)

偏移地址: 0x14

复位值: 0x0000 0000

这些位由软件控制进行改写来选择 EINTx(x=12...15)的外部中断源。

注意: 此寄存器每个位的值为 0x1000 时, 是保留位, 即 PI[15:12]未使用。

| 位/域   | 名称     | R/W | 描述                                                              |
|-------|--------|-----|-----------------------------------------------------------------|
| 3:0   | EINT12 | R/W | EINT12 配置位 (EINT12 Configure)<br>这些位由软件控制进行改写来选择 EINT12 的外部中断源。 |
| 7:4   | EINT13 | R/W | EINT13 配置位 (EINT13 Configure)<br>这些位由软件控制进行改写来选择 EINT13 的外部中断源。 |
| 11:8  | EINT14 | R/W | EINT14 配置位 (EINT14 Configure)<br>这些位由软件控制进行改写来选择 EINT14 的外部中断源。 |
| 15:12 | EINT15 | R/W | EINT15 配置位 (EINT15 Configure)<br>这些位由软件控制进行改写来选择 EINT15 的外部中断源。 |
| 31:16 |        |     | 保留                                                              |

### 5.5.7 补偿单元控制寄存器 (SYSCFG\_CCCTRL)

偏移地址: 0x20

复位值: 0x0000 0000

| 位/域  | 名称     | R/W | 描述                                                                           |
|------|--------|-----|------------------------------------------------------------------------------|
| 0    | CCPD   | R/W | 补偿单元掉电 (Compensation Cell Power-down)<br>0: I/O 补偿单元进入掉电模式<br>1: 使能 I/O 补偿单元 |
| 7:1  |        |     | 保留                                                                           |
| 8    | RDYFLG | R   | 补偿单元准备标志 (Compensation Cell Ready Flag)<br>0: 未准备好<br>1: 已准备好                |
| 31:9 |        |     | 保留                                                                           |

## 6 复位与时钟 (RCM)

### 6.1 术语全称、缩写描述

表格 32 术语全称、缩写描述

| 中文全称    | 英文全称                       | 英文缩写   |
|---------|----------------------------|--------|
| 复位与时钟管理 | Reset and Clock Management | RCM    |
| 复位      | Reset                      | RST    |
| 上电复位    | Power-On Reset             | POR    |
| 掉电复位    | Power-Down Reset           | PDR    |
| 高速外部时钟  | High Speed External Clock  | HSECLK |
| 低速外部时钟  | Low Speed External Clock   | LSECLK |
| 高速内部时钟  | High Speed Internal Clock  | HSICLK |
| 低速内部时钟  | Low Speed Internal Clock   | LSICLK |
| 锁相环     | Phase Locked Loop          | PLL    |
| 主要时钟输出  | Main clock output          | MCO    |
| 校准      | Calibrate                  | CAL    |
| 调整      | Trim                       | TRM    |
| 时钟安全系统  | Clock Security System      | CSS    |
| 不可屏蔽中断  | Non Maskable Interrupt     | NMI    |

### 6.2 复位管理单元 (RMU)

复位分为三类：系统复位、电源复位、备份区域复位。

#### 6.2.1 系统复位

##### 6.2.1.1 “系统复位” 复位源

复位源分为外部复位源和内部复位源。

外部复位源：

- NRST 引脚上的低电平。

内部复位源：

- 窗口看门狗终止计数 (WWDT 复位)
- 独立看门狗终止计数 (IWDT 复位)
- 软件复位 (SW 复位)
- 电源复位
- 低功耗管理复位

以上任一事件发生时，都能产生一个系统复位。另外，可以通过查看 **RCM\_CSTS**（控制/状态寄存器）中的复位标志位识别复位事件来源。

系统复位时，会将除了 **RCM\_CSTS**（控制/状态寄存器）的复位标志位和备份区域中的寄存器以外的所有寄存器复位到复位状态。

### 软件复位

将带有 FPU 的 Arm® Cortex®-M4F 中断应用和复位控制寄存器中的 **SYSRESETREQ** 置“1”时，可实现软件复位。

### 低功耗管理复位

低功耗管理复位的产生有两种情况，一种是进入待机模式时，另一种是进入停止模式时。在这两种情况下，如果把用户选择字节中的 **RSTSTDB**（待机模式时）或 **RSTSTOP**（停止模式时）置 0，系统将被复位而不是进入待机模式或停止模式。

#### 6.2.1.2 “系统复位”复位电路

复位源均作用于 **NRST** 引脚，该引脚在复位过程中保持低电平。

内部复位源通过脉冲发生器在 **NRST** 引脚产生延时至少  $20\mu\text{s}$  的脉冲，引起 **NRST** 保持电平产生复位。外部复位源则直接将 **NRST** 引脚电平拉低产生复位。

“系统复位”复位电路见下图。

图 4 “系统复位”复位电路



#### 6.2.2 电源复位

##### “电源复位”复位源

“电源复位”复位源如下：

- 上电复位 (POR)
- 掉电复位 (PDR)
- 欠压复位 (BOR)
- 从待机模式退出 (被唤醒)

以上任一事件发生时，产生电源复位。

电源复位将复位除了备份区域外的所有寄存器。

### 6.2.3 备份域复位

“备份域复位”复位源

“备份域复位”复位源如下：

- 软件复位，设置 RCM\_BDCTRL (备份域控制寄存器) 中的 BDRST 位
- 在  $V_{DD}$  和  $V_{BAT}$  掉电后， $V_{DD}$  或  $V_{BAT}$  又上电

以上任一事件发生时，产生备份域复位。

备份区域复位拥有两个专门的复位，它们只影响备份区域。

## 6.3 时钟管理单元 (CMU)

整个系统的时钟源有：HSECLK、LSECLK、HSICLK、LSICLK、PLL1。关于时钟源的特性，请参见数据手册的“电气特性”中的相关章节。

### 6.3.1 外部时钟源

外部时钟信号包括 HSECLK (高速外部时钟信号) 和 LSECLK (低速外部时钟信号)。

外部的时钟源有两种：

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

两种时钟源的硬件配置如下图所示。

图 5 HSECLK/LSECLK 的时钟源硬件配置

| 时钟源      | 硬件配置                                                                               |
|----------|------------------------------------------------------------------------------------|
| 外部时钟     |  |
| 晶体/陶瓷谐振器 |  |

为了减少时钟输出的失真和缩短启动稳定时间，晶体/陶瓷谐振器和负载电容器必须尽可能地靠近振荡器引脚。负载电容 ( $C_{L1}$ 、 $C_{L2}$ ) 的值必须根据所选择的振荡器来调整。

### 6.3.1.1 HSECLK 高速外部时钟信号

HSECLK 时钟信号由 HSECLK 外部晶体/陶瓷谐振器和 HSECLK 外部时钟两种时钟源产生。

表格 33 产生 HSECLK 的时钟源

| 名称                     | 说明                                                                                                                                                                                                                                                                              |
|------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 外部时钟源 (HSECLK 旁路)      | <p>通过 OSC_IN 引脚给 MCU 提供时钟。<br/>信号可以有普通的函数信号发送器 (调试时)、晶体振荡器、其它信号发生器产生。波形可以是 50% 占空比的方波、正弦波或三角波，最高频率可达 26MHz。</p> <p>硬件连接上，必须连到 OSC_IN 引脚，同时保证 OSC_OUT 引脚悬空 (处于高阻态)。在 MCU 配置上，用户可通过设置在 RCM_CTRL (时钟控制寄存器) 中的 HSEBCFG 和 HSEEN 位来选择这一模式。</p>                                        |
| 外部晶体/陶瓷谐振器 (HSECLK 晶体) | <p>通过谐振器给 MCU 提供时钟，谐振器包括晶体谐振器、陶瓷谐振器。<br/>频率范围是 4~26MHz。</p> <p>需要 OSC_IN、OSC_OUT 连接谐振器，可以通过设置时钟控制寄存器里 RCM_CTRL (时钟控制寄存器) 中的 HSEEN 位，启动和关闭。<br/>在时钟控制寄存器 RCM_CTRL (时钟控制寄存器) 中的 HSERDYFLG 位用来指示高速外部振荡器是否稳定。在启动后，直到这一位被硬件置“1”，时钟才被释放出来。如果在 RCM_INT (时钟中断寄存器) 中允许产生中断，将会产生相应中断。</p> |

### 6.3.1.2 LSECLK 低速外部时钟信号

LSECLK 时钟信号由 LSECLK 外部晶体/陶瓷谐振器和 LSECLK 外部时钟两种时

钟源产生。

表格 34 产生 LSECLK 的时钟源

| 名称                     | 说明                                                                                                                                                                                                                                                         |
|------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 外部时钟源 (LSECLK 旁路)      | <p>通过 OSC32_IN 引脚给 MCU 提供时钟。<br/>信号可以有普通的函数信号发送器 (调试时)、晶体振荡器、其它信号发生器产生。波形可以是 50% 占空比的方波、正弦波或三角波，信号频率需为 32.768kHz。</p> <p>硬件连接上，必须连到 OSC32_IN 引脚，同时保证 OSC32_OUT 引脚悬空。在 MCU 配置上，用户可通过设置在 RCM_BDCTRL (备份域控制寄存器) 里的 LSEBCFG 和 LSEEN 位来选择这个模式。</p>              |
| 外部晶体/陶瓷谐振器 (LSECLK 晶体) | <p>通过谐振器给 MCU 提供时钟，谐振器包括晶体谐振器、陶瓷谐振器。频率是 32.768kHz。</p> <p>需要 OSC32_IN、OSC32_OUT 连接谐振器，可以通过在 RCM_BDCTRL (时钟备份域控制寄存器) 里的 LSEEN 位启动和关闭。</p> <p>在 RCM_BDCTRL 里的 LSERDYFLG 指示 LSECLK 晶体振荡是否稳定。在启动阶段，直到这个位被硬件置“1”后，LSECLK 时钟信号才被释放出来。如果在时钟中断寄存器里被允许，可产生中断申请。</p> |

### 6.3.2 内部时钟源

内部时钟包含 **HSICLK** (高速内部时钟信号) 和 **LSICLK** (低速内部时钟信号)。

#### 6.3.2.1 HSICLK 高速内部时钟信号

HSICLK 时钟信号由内部 16MHz 的 RC 振荡器产生。

不同芯片的 RC 振荡器频率不同，且同一颗芯片随着温度、电压的变化也会存在差异。每个芯片的 HSICLK 时钟频率在出厂前已经被厂家校准到 1% (25°C,  $V_{DD}=V_{DDA}=3.3V$ )，系统复位时，工厂校准值被装载到 RCM\_CTRL 寄存器中。另外，用户可以依据现场的应用环境 (温度、电压)，通过设置 RCM\_CTRL 寄存器中的 HSITRM 位作进一步的频率调整。

HSIRDYFLG 位可以用来指示 HSICLK RC 振荡器是否稳定。在时钟启动过程中，直到 HSIRDYFLG 位被硬件置 1，HSICLK RC 输出时钟才被释放。HSICLK RC 可由 RCM\_CTRL 中的 HSIEN 位来启动或关闭。

与 HSECLK 晶体振荡器相比，RC 振荡器能够在不需要任何外部器件的条件下提供系统时钟。它的启动时间比 HSECLK 晶体振荡器短；即使在校准之后，其时钟频率精度仍不如 HSECLK 晶体振荡器。

#### 6.3.2.2 LSICLK 低速内部时钟信号

##### LSICLK 主要特征

LSICLK 由 RC 振荡器产生，范围是 28kHz (20kHz 和 35kHz 之间。随着温度、电压的变化，频率也会产生变化。可以在停机和待机模式下保持运行，为独立看门狗和自动唤醒单元提供时钟。

LSICLK 可以通过 RCM\_CSTS 寄存器的 LSIEN 位来启动或关闭。在 RCM\_CSTS 里的 LSIRDYFLG 位指示低速内部振荡器是否稳定。在启动阶段，直到这个位被硬件设置为“1”后，时钟才被释放。如果在 RCM\_INT 寄存器里被允许，将产生 LSICLK 就绪中断请求信号。

### 6.3.3 PLL 锁相环

产品提供一个 PLL (PLL1)，一般由 HSICLK 或 HSECLK 振荡器作为它们的时钟源。

发生以下两种情况之一时，将由硬件禁止这个 PLL1：

- 进入停机或待机状态
- 系统时钟直接或间接选用 HSECLK 作为时钟源，而 HSECLK 发生故障

在配置 PLL1 相关系数时，需要保证在不使能它的情况下进行。

锁相环，主要为系统时钟产生最大为 240MHz 高频时钟信号。PLL1 的时钟输出频率由 RCM\_PLL1CFG 寄存器进行配置，通过设置算式中的乘法/除法因子调整时钟频率，配置时应使 PLL1 处于禁止状态。

### 6.3.4 时钟树

图 6 APM32F425xG\_F427xG 时钟树



注意：

(1) HCLK 是指 AHB 时钟信号。

- (2) PLCK1, PLCK2 分别是指连接 APB1, APB2 的时钟信号。
- (3) FCLK 是带有 FPU 的 Arm® Cortex®-M4F 的自由运行时钟。
- (4) 可通过多个预分频器配置 AHB、APB2（高速 APB）和 APB1（低速 APB）域的频率。其中，AHB 域最大频率为 240MHz, APB2 域的最大频率是 120MHz, 而 APB1 域的最大允许频率是 60MHz。
- (5) 系统时钟能得到的最大频率是 240MHz。
- (6) OTG\_FS 的时钟源是频率为 48MHz 的 PLL1CLK。
- (7) 需要设置相应的使能位，外设才能获得时钟信号。
- (8) ADC 时钟可以分为模拟电路时钟和数字电路时钟。时钟管理单元为 ADC 的模拟电路时钟提供了一个预分频器，使得 ADC 能够在 PCLK2 的 2/4/6/8 分频后的时钟频率下工作，此时的时钟供所有 ADC 使用。ADC 的数字电路时钟频率等于 PCLK2，通过 RCM\_APB2CLKEN 寄存器的相应位分别使能 ADC1/2/3 时钟。
- (9) SysTick（系统定时器）可由 HCLK8 分频后的时钟信号提供，通过对 SysTick 控制与状态寄存器的设置，可选择不同时钟源。
- (10) 所有 TMRxCLK（定时器时钟）频率分配由硬件按以下 2 种情况自动设置：
- 如果相应的 APB 预分频系数是 1，定时器的时钟频率与所在 APB 总线频率一致。
  - 如果相应 APB 预分频系数是 2~16，定时器的时钟频率被设为与其相连的 APB 总线频率的 2 倍。
- (11) MCO1/2 的最大输出频率为 100MHz。
- (12) PLL1 的结构请参见 PLL 锁相环章节与 PLLx 配置寄存器。

### 6.3.5 RTC 的时钟源选择

通过设置 RCM\_BDCTRL（备份域控制寄存器）里的 RTCSRCSEL 位可选择由 HSECLK 被分频成 1MHz 的时钟信号、LSECLK 或 LSICLK 作为 RTC 的时钟源。只有备份域复位时，时钟源的选择可以改变。

由于 LSECLK 在备份域里，HSECLK、LSICLK 不在备份域内，因此，选择不同的时钟作为 RTC 时钟源，RTC 的工作情况存在差异，具体情况见下表：

表格 35 选择不同时钟源时 RTC 的工作情况

| 时钟源                 | 工作情况                                                                                                     |
|---------------------|----------------------------------------------------------------------------------------------------------|
| LSECLK 被选为 RTC 时钟   | 只要 $V_{BAT}$ 维持供电，尽管 $V_{DD}$ 供电被切断，RTC 仍继续工作                                                            |
| LSICLK 被选为自动唤醒单元时钟  | 如果 $V_{DD}$ 供电被切断，自动唤醒单元的状态不能被保证。                                                                        |
| HSECLK 分频后作为 RTC 时钟 | 如果 $V_{DD}$ 供电被切断或内部电压调压器被关闭（1.2V 域的供电被切断），则 RTC 状态不确定，故必须设置 PMU_CTRL（电源控制寄存器）的 BPWEN 位（取消后备区域的写保护）为“1”。 |

### 6.3.6 IWDT 的时钟源选择

当 IWDT（独立看门狗）启动时，LSICLK 振荡器将被强制打开，等到稳定后把

时钟信号供给 IWDT。LSICLK 在被强制打开后，将一直处于打开状态，不能被关闭。

### 6.3.7 MCO 的时钟源选择

有两个微控制器时钟输出引脚，MCO1（PA8）和 MCO2（PC9），当端口（PA8、PC9）的相应的 GPIO 端口被配置为对应复用功能时，可通过配置 RCM\_CFG（时钟配置寄存器）中的 MCOxSEL 位和 MCOxPSC 位，选择时钟信号输出到 MCO 引脚。具体时钟信号可参见时钟树或寄存器功能描述。

### 6.3.8 SYSCLK 的时钟源选择

当进行系统复位后，HSICLK 振荡器将（直接或间接）被选作系统时钟，且不能被停止。如果要切换 SYSCLK 时钟源，必须要等目标时钟源准备就绪（即目标时钟源稳定）。目标时钟源可以是 HSICLK、HSECLK、PLLCLK。

RCM\_CTRL 和 RCM\_CFG 寄存器的状态位可指示已准备好的时钟和已被选作的 SYSCLK 时钟源。

### 6.3.9 CSS 时钟安全系统

为了防止由于外部晶振短路导致 MCU 无法正常运行的情况，MCU 可通过软件激活 CSS 时钟安全系统。安全系统被激活后，如果 HSECLK 振荡器直接或间接（作为 PLL 输入时钟且 PLL 作为系统时钟）被用作系统时钟，那么当 HSECLK 发生故障时，外部 HSECLK 振荡器被关闭，系统时钟自动切换至 HSICLK，此时选择 HSECLK 为时钟输入且作为系统时钟输入源的 PLLCLK 也会被关闭。

注意：CSS 被软件激活并且 HSECLK 出现故障时，会产生 CSS 中断和 NMI（不可屏蔽中断）。由于 CSS 中断被清除前 NMI 不断被执行，所以需要设置 RCM\_INT 寄存器里的 CSSCLR 位来清除中断。

### 6.3.10 基于 TMR5 的内/外部时钟测量

通过 TMR5 通道 4 的输入捕获功能，可以间接测量某些时钟源发生器的频率，电路图如下所示：

图 7 TMR5 测量时钟频率电路图



TMR5 的通道 4 可以选择通过配置 TMR5\_OPT 寄存器的 RMPSEL 位，连接一个 GPIO 端口或一个 MCU 的内部时钟。

### 6.3.11 基于 TMR11 的内/外部时钟测量

当 HSICLK 作为系统时钟源时, 可以通过 TMR11 测试外部晶振频率。如下图所示, 用户可以通过配置 TMR11\_OPT 寄存器的 RMPSEL 位, 选择是由 I/O 端口或是由内部时钟触发 TI1。

图 8 TMR11 测量时钟频率电路图



## 6.4 寄存器地址映射

表格 36 RCM 寄存器地址映射

| 寄存器名            | 描述                  | 偏移地址 |
|-----------------|---------------------|------|
| RCM_CTRL        | 时钟控制寄存器             | 0x00 |
| RCM_PLL1CFG     | PLL1 配置寄存器          | 0x04 |
| RCM_CFG         | 时钟配置寄存器             | 0x08 |
| RCM_INT         | 时钟中断寄存器             | 0x0C |
| RCM_AHB1RST     | AHB1 外设复位寄存器        | 0x10 |
| RCM_AHB2RST     | AHB2 外设复位寄存器        | 0x14 |
| RCM_AHB3RST     | AHB3 外设复位寄存器        | 0x18 |
| RCM_APB1RST     | APB1 外设复位寄存器        | 0x20 |
| RCM_APB2RST     | APB2 外设复位寄存器        | 0x24 |
| RCM_AHB1CLKEN   | AHB1 外设时钟使能寄存器      | 0x30 |
| RCM_AHB2CLKEN   | AHB2 外设时钟使能寄存器      | 0x34 |
| RCM_AHB3CLKEN   | AHB3 外设时钟使能寄存器      | 0x38 |
| RCM_APB1CLKEN   | APB1 外设时钟使能寄存器      | 0x40 |
| RCM_APB2CLKEN   | APB2 外设时钟使能寄存器      | 0x44 |
| RCM_LPAHB1CLKEN | 低功耗下 AHB1 外设时钟使能寄存器 | 0x50 |
| RCM_LPAHB2CLKEN | 低功耗下 AHB2 外设时钟使能寄存器 | 0x54 |
| RCM_LPAHB3CLKEN | 低功耗下 AHB3 外设时钟使能寄存器 | 0x58 |
| RCM_LPAPB1CLKEN | 低功耗下 APB1 外设时钟使能寄存器 | 0x60 |

| 寄存器名            | 描述                  | 偏移地址 |
|-----------------|---------------------|------|
| RCM_LPAPB2CLKEN | 低功耗下 APB2 外设时钟使能寄存器 | 0x64 |
| RCM_BDCTRL      | 备份域控制寄存器            | 0x70 |
| RCM_CSTS        | 时钟控制/状态寄存器          | 0x74 |
| RCM_SSCCFG      | 扩频时钟配置寄存器           | 0x80 |

## 6.5 寄存器功能描述

### 6.5.1 时钟控制寄存器 (RCM\_CTRL)

偏移地址: 0x00

复位值: 0x0000 XX83, X 代表未定义

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

| 位/域  | 名称        | R/W | 描述                                                                                                                                                                                                                                                        |
|------|-----------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | HSIEN     | R/W | 使能高速内部时钟 (High Speed Internal Clock Enable)<br>由软件置 1 或清 0。<br>HSICLK 是 RC 振荡器, 以下条件中的一个出现时, 会硬件置 1: 上电启动、软件复位、从待机模式唤醒、停机模式唤醒、外部高速时钟源 (作为系统时钟或通过 PLL 提供系统时钟) 发生故障。当 HSICLK 作为系统时钟源或通过 PLL 提供系统时钟时, 该位不能清 0。<br>0: 关闭 HSICLK RC 振荡器<br>1: 开启 HSICLK RC 振荡器 |
| 1    | HSIRDYFLG | R   | 高速内部时钟就绪标志 (High Speed Internal Clock Ready Flag)<br>0: HSICLK RC 振荡器未稳定<br>1: HSICLK RC 振荡器已稳定                                                                                                                                                           |
| 2    |           |     | 保留                                                                                                                                                                                                                                                        |
| 7:3  | HSITRM    | R/W | 调整高速内部时钟 (High Speed Internal Clock Trim)<br>产品在出厂时会将 HSICLK 校准到 $16\text{MHz} \pm 1\%$ , 但随着温度、电压的变化而变化, 可通过此位调整 HSICLK RC 振荡器的频率。                                                                                                                       |
| 15:8 | HSICAL    | R   | 校准内部高速时钟 (High Speed Internal Clock Calibrate)<br>在出厂时会将 HSICLK 校准到 $16\text{MHz} \pm 1\%$ , 在系统启动时, 会将校准参数自动写入寄存器。                                                                                                                                       |
| 16   | HSEEN     | R/W | 使能高速外部时钟 (High Speed External Clock Enable)<br>进入待机或停机模式时, 该位由硬件清 0, 关闭 HSECLK; 当 HSECLK 作为系统时钟源或通过 PLL 提供系统时钟时, 该位不能清 0。<br>0: 禁用<br>1: 使能                                                                                                               |
| 17   | HSERDYFLG | R   | 高速外部时钟就绪标志 (High Speed External Clock Ready Flag)<br>HSECLK 稳定后由硬件置 1, 软件清 0。<br>0: HSECLK 未稳定<br>1: HSECLK 已稳定                                                                                                                                           |
| 18   | HSEBCFG   | R/W | 配置高速外部时钟旁路模式 (High Speed External Clock Bypass Configure)<br>旁路模式指外部时钟作为 HSECLK 时钟源, 否则谐振器作为 HSECLK 时钟源。<br>0: 非旁路模式                                                                                                                                      |

| 位/域   | 名称         | R/W | 描述                                                                                                                                       |
|-------|------------|-----|------------------------------------------------------------------------------------------------------------------------------------------|
|       |            |     | 1: 旁路模式                                                                                                                                  |
| 19    | CSSEN      | R/W | 使能时钟安全系统 (Clock Security System Enable)<br>0: 禁用<br>1: 使能<br>注意: 只有 HSECLK 谐振器稳定时才能将此位置 1。                                               |
| 23:20 | 保留         |     |                                                                                                                                          |
| 24    | PLL1EN     | R/W | 使能 PLL1 (PLL1 Enable)<br>当进入待机和停止模式时, 该位由硬件清零; 当 PLL1CLK 已配置为 (或者配置过程中) 系统时钟的时钟源, 该位不能清 0; 其他情况可由软件置 1 或清 0。<br>0: PLL1 关闭<br>1: PLL1 使能 |
| 25    | PLL1RDYFLG | R   | PLL1 时钟就绪标志 (PLL1 Clock Ready Flag)<br>PLL1 锁定后由硬件置 1。<br>0: PLL1 未锁定<br>1: PLL1 锁定                                                      |
| 31:26 | 保留         |     |                                                                                                                                          |

### 6.5.2 PLL1 配置寄存器 (RCM\_PLL1CFG)

偏移地址: 0x04

复位值: 0x2400 3010

以字, 半字和字节形式访问, 无等待周期。

寄存器的用来配置各种参数以输出不同时钟信号。

$$f_{(VCO\ clock)} = f_{(PLL1\ clock\ input)} \times (PLL1A/PLL1B)$$

$$f_{(PLL1\ clock\ output)} = f_{(VCO\ clock)} / PLL1C$$

$$f_{(OTG\_FS, SDIO, RNG\ clock\ output)} = f_{(VCO\ clock)} / PLLD$$

| 位/域  | 名称    | R/W | 描述                                                                                                                                                                                                                                                           |
|------|-------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5:0  | PLL1B | R/W | 除数 (Division Factor B)<br>用于计算 VCO 的时钟频率, 这些位只能在 PLL 被禁止时写入。<br>000000: PLLB=0 (错误)<br>000001: PLLB=1 (错误)<br>000010: PLLB=2<br>000011: PLLB=3<br>.....<br>111110: PLLB=62<br>111111: PLLB=63                                                                |
| 14:6 | PLL1A | R/W | 乘法系数 (PLL Multiplication Factor A)<br>用于计算 VCO 的频率。计算公式为 $f_{(VCO\ output)} = f_{(VCO\ input)} \times PLL1A$ , 只有在 PLL1A 为 50~432 时, 公式才成立。<br>00000000: PLLA=0 (错误)<br>00000001: PLLA=1 (错误)<br>.....<br>000110010: PLLA=50<br>.....<br>110110000: PLLA=432 |

| 位/域   | 名称      | R/W | 描述                                                                                                                                                                      |
|-------|---------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |         |     | 110110001: PLLA=433 (错误)<br>.....<br>111111111: PLLA=511 (错误)                                                                                                           |
| 15    |         |     | 保留                                                                                                                                                                      |
| 17:16 | PLL1C   | R/W | 除数 (Division Factor C)<br>用于计算 PLL1 的输出时钟频率。<br>00: PLL1C=2<br>01: PLL1C=4<br>10: PLL1C=6<br>11: PLL1C=8<br>注意: 只有在 PLL1 被禁止时才能写入此位。                                    |
| 21:18 |         |     | 保留                                                                                                                                                                      |
| 22    | PLLCLKS | R/W | PLL 时钟源 (PLL Clock Source)<br>此位由软件置位或清除, 用来选择 PLL1 的时钟源。<br>0: HSICLK 作为时钟源<br>1: HSECLK 作为时钟源<br>注意: 只有在 PLL1 被禁止时才能写入此位。                                             |
| 23    |         |     | 保留                                                                                                                                                                      |
| 27:24 | PLLD    | R/W | 除数 (Division Factor)<br>用于计算 OTG_FS、RNG、SDIO 的时钟频率。<br>0000: PLLD=0 (错误)<br>0001: PLLD=1 (错误)<br>0010: PLLD=2<br>0011: PLLD=3<br>0100: PLLD=4<br>.....<br>1111: PLLD=15 |
| 31:28 |         |     | 保留                                                                                                                                                                      |

### 6.5.3 时钟配置寄存器 (RCM\_CFG)

偏移地址: 0x08

复位值: 0x0000 0000

此寄存器所有位都由软件置位或清零。

访问: 以字, 半字和字节形式访问, 0 到 2 个等待周期。

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

| 位/域 | 名称      | R/W | 描述                                                                                                                                                                                               |
|-----|---------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0 | SCLKSEL | R/W | 选择系统时钟源 (System Clock Source Select)<br>在从停止或待机模式中返回时或直接或间接作为系统时钟的 HSECLK 出现故障时, 由硬件强制选择 HSICLK 作为系统时钟 (如果时钟安全系统已经启动)。<br>00: HSICLK 作为系统时钟<br>01: HSECLK 作为系统时钟<br>10: PLL1CLK 作为系统时钟<br>11: 保留 |

| 位/域   | 名称         | R/W | 描述                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:2   | SCLKSELSTS | R   | <p>系统时钟的时钟源选择状态 (System Clock Selection Status)<br/>指示哪一个时钟源被作为系统时钟；由硬件置 1 或清 0。</p> <p>00: HSICLK 作为系统时钟<br/>01: HSECLK 作为系统时钟<br/>10: PLL1CLK 输出作为系统时钟<br/>11: 无应用</p>                                                                                                                                                                                                           |
| 7:4   | AHPSC      | R/W | <p>配置 AHB 时钟预分频 (AHB Clock Prescaler Factor Configure)<br/>控制 AHB 时钟的预分频系数。</p> <p>0xxx: SYSCLK 不分频<br/>1000: SYSCLK 2 分频<br/>1001: SYSCLK 4 分频<br/>1010: SYSCLK 8 分频<br/>1011: SYSCLK 16 分频<br/>1100: SYSCLK 64 分频<br/>1101: SYSCLK 128 分频<br/>1110: SYSCLK 256 分频<br/>1111: SYSCLK 512 分频</p> <p>注意：在此位被写入后的 1 至 16 个 AHB 时钟周期后，才能根据新的分频系数对时钟信号进行分频。当使用以太网时，HCLK 不能小于 25MHz。</p> |
| 9:8   | SDRAMPSC   | R/W | <p>配置 SDRAM 时钟预分频系数 (SDRAM Clock Prescaler Factor Configure)<br/>配置 SDRAM 时钟的预分频系数。</p> <p>00: 不分频 <math>f_{SDRAM}=f_{DMC}</math><br/>01: 二分频 <math>f_{SDRAM}=f_{DMC}/2</math><br/>其他: 四分频 <math>f_{SDRAM}=f_{DMC}/4</math></p>                                                                                                                                                    |
| 12:10 | APB1PSC    | R/W | <p>配置 APB1 时钟预分频系数 (APB1 Clock Prescaler Factor Configure)<br/>来控制低速的 APB1 时钟 (PCLK1) 的预分频系数。</p> <p>0xx: HCLK 不分频<br/>100: HCLK 2 分频<br/>101: HCLK 4 分频<br/>110: HCLK 8 分频<br/>111: HCLK 16 分频</p> <p>注意：PCLK1 不得大于 60MHz。</p>                                                                                                                                                    |
| 15:13 | APB2PSC    | R/W | <p>配置 APB2 时钟预分频系数 (APB2 Clock Prescaler Factor Configure)<br/>来控制低速的 APB2 时钟 (PCLK2) 的预分频系数。</p> <p>0xx: HCLK 不分频<br/>100: HCLK 2 分频<br/>101: HCLK 4 分频<br/>110: HCLK 8 分频<br/>111: HCLK 16 分频</p> <p>注意：PCLK2 不得大于 120MHz。</p>                                                                                                                                                   |
| 20:16 | RTCPSC     | R/W | 配置 RTC 时钟预分频系数 (RTC Clock Prescaler Factor Configure)                                                                                                                                                                                                                                                                                                                              |

| 位/域   | 名称      | R/W | 描述                                                                                                                                                                                                                   |
|-------|---------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |         |     | 控制预分频系数，使 HSECLK 分频产生一个 1MHz 的时钟信号以提供给 RTC。<br>0000X: 无时钟<br>00010: HSECLK2 分频<br>00011: HSECLK3 分频<br>00100: HSECLK4 分频<br>.....<br>11110: HSECLK30 分频<br>11111: HSECLK31 分频<br>注意：此位必须在 RTC 选择 HSECLK 作为时钟源前被配置完成。 |
| 22:21 | MCO1SEL | R/W | 选择微控制器时钟输出 1 (Main Clock Output1 Select)<br>由软件置位或清零。<br>00: HSICLK 作为时钟输出<br>01: LSECLK 作为时钟输出<br>10: HSECLK 作为时钟输出<br>11: PLL1CLK 作为时钟输出                                                                           |
| 23    |         |     | 保留                                                                                                                                                                                                                   |
| 26:24 | MCO1PSC | R/W | 配置微控制器时钟输出 1 的预分频系数 (MCO Clock Output1 Prescaler Factor Configure)<br>0XX: 不分频<br>100: 2 分频<br>101: 3 分频<br>110: 4 分频<br>111: 5 分频                                                                                   |
| 29:27 | MCO2PSC | R/W | 配置微控制器时钟输出 2 的预分频系数 (MCO Clock Output2 Prescaler Factor Configure)<br>0XX: 不分频<br>100: 2 分频<br>101: 3 分频<br>110: 4 分频<br>111: 5 分频                                                                                   |
| 31:30 | MCO2SEL | R/W | 选择微控制器时钟输出 2 (Main Clock Output2 Select)<br>00: SYSCLK 作为时钟输出<br>01: 保留<br>10: HSECLK 作为时钟输出<br>11: PLL1CLK 作为时钟输出                                                                                                   |

#### 6.5.4 时钟中断寄存器 (RCM\_INT)

偏移地址: 0x0C

复位值: 0x0000 0000

访问: 以字, 半字和字节形式访问, 无等待周期。

| 位/域 | 名称         | R/W | 描述                                                                                                                                                           |
|-----|------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | LSIRDYFLG  | R   | LSICLK 就绪中断标志 (LSICLK Ready Interrupt Flag)<br>LSICLK 稳定且 LSIRDYEN 位被置 1 时, 由硬件置 1; 由软件置 1<br>LSIRDYCLR 清 0 该位。<br>0: 无 LSICLK 就绪中断<br>1: 发生 LSICLK 就绪中断     |
| 1   | LSERDYFLG  | R   | LSECLK 就绪中断标志 (LSECLK Ready Interrupt Flag)<br>LSECLK 稳定且 LSERDYEN 位被置 1 时, 由硬件置 1; 由软件置 1<br>LSERDYCLR 清 0 该位。<br>0: 无 LSECLK 就绪中断<br>1: 发生 LSECLK 就绪中断     |
| 2   | HSIRDYFLG  | R   | HSICLK 就绪中断标志 (HSICLK Ready Interrupt Flag)<br>HSICLK 稳定且 HSIRDYEN 位被置 1 时, 由硬件置 1; 由软件置 1<br>HSIRDYCLR 清 0 该位。<br>0: 无 HSICLK 就绪中断<br>1: 发生 HSICLK 就绪中断     |
| 3   | HSERDYFLG  | R   | HSECLK 就绪中断标志 (HSECLK Ready Interrupt Flag)<br>HSECLK 稳定且 HSERDYEN 位被置 1 时, 由硬件置 1; 由软件置 1<br>HSERDYCLR 清 0 该位。<br>0: 无 HSECLK 就绪中断<br>1: 发生 HSECLK 就绪中断     |
| 4   | PLL1RDYFLG | R   | PLL1 就绪中断标志 (PLL1 Ready Interrupt Flag)<br>PLL1 稳定且 PLL1RDYEN 位被置 1 时, 由硬件置 1; 由软件置 1<br>PLL1RDYCLR 清 0 该位。<br>0: 没有发生 PLL1 时钟就绪中断<br>1: 发生了 PLL1 时钟就绪中断     |
| 6:5 |            |     | 保留                                                                                                                                                           |
| 7   | CSSFLG     | R   | 时钟安全系统中断标志 (Clock Security System Interrupt Flag)<br>在外部高速振荡器时钟出现故障时, 由硬件置 1。<br>软件将 CSSCLR 置 1 以清 0 此位。<br>0: 无 HSE 时钟失效产生的安全系统中断<br>1: HSE 时钟失效导致了时钟安全系统中断 |
| 8   | LSIRDYEN   | R/W | 使能 LSICLK 就绪中断 (LSICLK Ready Interrupt Enable)<br>使能或关闭内部 28kHz RC 振荡器就绪中断。<br>0: 禁用<br>1: 使能                                                                |
| 9   | LSERDYEN   | R/W | 使能 LSECLK 就绪中断 (LSECLK Ready Interrupt Enable)<br>使能外部 32kHz RC 振荡器就绪中断。<br>0: 禁用<br>1: 使能                                                                   |
| 10  | HSIRDYEN   | R/W | 使能 HSICLK 就绪中断 (HSICLK Ready Interrupt Enable)<br>使能内部 8MHz RC 振荡器就绪中断。<br>0: 禁用<br>1: 使能                                                                    |

| 位/域   | 名称         | R/W | 描述                                                                                            |
|-------|------------|-----|-----------------------------------------------------------------------------------------------|
| 11    | HSERDYEN   | R/W | 使能 HSCLKE 就绪中断 (HSCLK Ready Interrupt Enable)<br>使能外部 4~16MHz 振荡器就绪中断。<br>0: 禁用<br>1: 使能      |
| 12    | PLL1RDYEN  | R/W | 使能 PLL1 就绪中断 (PLL1 Ready Interrupt Enable)<br>使能 PLL1 就绪中断。<br>0: 禁用<br>1: 使能                 |
| 15:13 | 保留         |     |                                                                                               |
| 16    | LSIRDYCLR  | W   | 清除 LSICLK 就绪中断 (LSICLK Ready Interrupt Clear)<br>清除 LSI 就绪中断标志位 LSIRDYFLG。<br>0: 无作用<br>1: 清除 |
| 17    | LSERDYCLR  | W   | 清除 LSECLK 就绪中断 (LSECLK Ready Interrupt Clear)<br>清除 LSE 就绪中断标志位 LSERDYFLG。<br>0: 无作用<br>1: 清除 |
| 18    | HSIRDYCLR  | W   | 清除 HSICLK 就绪中断 (HSICLK Ready Interrupt Clear)<br>清除 HSI 就绪中断标志位 HSIRDYFLG。<br>0: 无作用<br>1: 清除 |
| 19    | HSERDYCLR  | W   | 清除 HSECLK 就绪中断 (HSECLK Ready Interrupt Clear)<br>清除 HSE 就绪中断标志位 HSERDYFLG。<br>0: 无作用<br>1: 清除 |
| 20    | PLL1RDYCLR | W   | 清除 PLL1 就绪中断 (PLL1 Ready Interrupt Clear)<br>清除 PLL1 就绪中断标志位 PLL1RDYFLG。<br>0: 无作用<br>1: 清除   |
| 22:21 | 保留         |     |                                                                                               |
| 23    | CSSCLR     | W   | 清除时钟安全系统中断 (Clock Security System Interrupt Clear)<br>清除安全系统中断标志位 CSSFLG。<br>0: 无作用<br>1: 清除  |
| 31:24 | 保留         |     |                                                                                               |

### 6.5.5 AHB1 外设复位寄存器 (RCM\_AHB1RST)

偏移地址: 0x10

复位值: 0x0000 0000

访问: 以字, 半字和字节形式访问, 无等待周期。

| 位/域 | 名称    | R/W | 描述                                      |
|-----|-------|-----|-----------------------------------------|
| 0   | PARST | R/W | 复位端口 A (GPIOA Reset)<br>0: 无作用<br>1: 复位 |

| 位/域   | 名称        | R/W | 描述                                            |
|-------|-----------|-----|-----------------------------------------------|
| 1     | PBRST     | R/W | 复位端口 B (GPIOB Reset)<br>0: 无作用<br>1: 复位       |
| 2     | PCRST     | R/W | 复位端口 C (GPIOC Reset)<br>0: 无作用<br>1: 复位       |
| 3     | PDRST     | R/W | 复位端口 D (GPIOD Reset)<br>0: 无作用<br>1: 复位       |
| 4     | PERST     | R/W | 复位端口 E (GPIOE Reset)<br>0: 无作用<br>1: 复位       |
| 5     | PFRST     | R/W | 复位端口 F (GPIOF Reset)<br>0: 无作用<br>1: 复位       |
| 6     | PGRST     | R/W | 复位端口 G (GPIOG Reset)<br>0: 无作用<br>1: 复位       |
| 7     | PHRST     | R/W | 复位端口 H (GPIOH Reset)<br>0: 无作用<br>1: 复位       |
| 11:8  |           |     | 保留                                            |
| 12    | CRCRST    | R/W | 复位 CRC (CRC Reset)<br>0: 无作用<br>1: 复位         |
| 20:13 |           |     | 保留                                            |
| 21    | DMA1RST   | R/W | 复位 DMA1 (DMA1 Reset)<br>0: 无作用<br>1: 复位       |
| 22    | DMA2RST   | R/W | 复位 DMA2 (DMA2 Reset)<br>0: 无作用<br>1: 复位 ADC   |
| 24:23 |           |     | 保留                                            |
| 25    | ETHRST    | R/W | 复位 ETH (ETH Reset)<br>0: 无作用<br>1: 复位         |
| 28:26 |           |     | 保留                                            |
| 29    | OTGFS2RST | R/W | 复位 OTG_FS2 (OTG_FS2 Reset)<br>0: 无作用<br>1: 复位 |
| 31:30 |           |     | 保留                                            |

### 6.5.6 AHB2 外设复位寄存器 (RCM\_AHB2RST)

偏移地址: 0x14

复位值: 0x0000 0000

访问: 以字, 半字和字节形式访问, 无等待周期。

| 位/域  | 名称       | R/W | 描述                                          |
|------|----------|-----|---------------------------------------------|
| 5:0  | 保留       |     |                                             |
| 6    | RNGRST   | R/W | 复位 RNG (RNG Reset)<br>0: 无作用<br>1: 复位       |
| 7    | OTGFSRST | R/W | 复位 OTG_FS (OTG_FS Reset)<br>0: 无作用<br>1: 复位 |
| 31:8 | 保留       |     |                                             |

### 6.5.7 AHB3 外设复位寄存器 (RCM\_AHB3RST)

偏移地址: 0x18

复位值: 0x0000 0000

访问: 以字, 半字和字节形式访问, 无等待周期。

| 位/域  | 名称      | R/W | 描述                                      |
|------|---------|-----|-----------------------------------------|
| 0    | EMMCRST | R/W | 复位 EMMC (EMMC Reset)<br>0: 无作用<br>1: 复位 |
| 1    | QSPIRST | R/W | 复位 QSPI (QSPI Reset)<br>0: 无作用<br>1: 复位 |
| 31:2 | 保留      |     |                                         |

### 6.5.8 APB1 外设复位寄存器 (RCM\_APB1RST)

偏移地址: 0x20

复位值: 0x0000 0000

访问: 以字, 半字和字节形式访问, 无等待周期。

所有位都可以由软件置位或清 0。

| 位/域 | 名称      | R/W | 描述                                      |
|-----|---------|-----|-----------------------------------------|
| 0   | TMR2RST | R/W | 复位 TMR2 (TMR2 Reset)<br>0: 无作用<br>1: 复位 |
| 1   | TMR3RST | R/W | 复位 TMR3 (TMR3 Reset)<br>0: 无作用<br>1: 复位 |
| 2   | TMR4RST | R/W | 复位 TMR4 (TMR4 Reset)<br>0: 无作用<br>1: 复位 |
| 3   | TMR5RST | R/W | 复位 TMR5 (TMR5 Reset)<br>0: 无作用          |

| 位/域   | 名称        | R/W | 描述                                          |
|-------|-----------|-----|---------------------------------------------|
|       |           |     | 1: 复位                                       |
| 4     | TMR6RST   | R/W | 复位 TMR6 (TMR6 Reset)<br>0: 无作用<br>1: 复位     |
| 5     | TMR7RST   | R/W | 复位 TMR7 (TMR7 Reset)<br>0: 无作用<br>1: 复位     |
| 6     | TMR12RST  | R/W | 复位 TMR12 (TMR12 Reset)<br>0: 无作用<br>1: 复位   |
| 7     | TMR13RST  | R/W | 复位 TMR13 (TMR13 Reset)<br>0: 无作用<br>1: 复位   |
| 8     | TMR14RST  | R/W | 复位 TMR14 (TMR14 Reset)<br>0: 无作用<br>1: 复位   |
| 10:9  |           |     | 保留                                          |
| 11    | WWDTRST   | R/W | 复位 WWDT (WWDT Reset)<br>0: 无作用<br>1: 复位     |
| 13:12 |           |     | 保留                                          |
| 14    | SPI2RST   | R/W | 复位 SPI2 (SPI2 Reset)<br>0: 无作用<br>1: 复位     |
| 15    | SPI3RST   | R/W | 复位 SPI3 (SPI3 Reset)<br>0: 无作用<br>1: 复位     |
| 16    |           |     | 保留                                          |
| 17    | USART2RST | R/W | 复位 USART2 (USART2 Reset)<br>0: 无作用<br>1: 复位 |
| 18    | USART3RST | R/W | 复位 USART3 (USART3 Reset)<br>0: 无作用<br>1: 复位 |
| 19    | UART4RST  | R/W | 复位 UART4 (UART4 Reset)<br>0: 无作用<br>1: 复位   |
| 20    | UART5RST  | R/W | 复位 UART5 (UART5 Reset)<br>0: 无作用<br>1: 复位   |
| 21    | I2C1RST   | R/W | 复位 I2C1 (I2C1 Reset)<br>0: 无作用<br>1: 复位     |

| 位/域   | 名称      | R/W | 描述                                                 |
|-------|---------|-----|----------------------------------------------------|
| 22    | I2C2RST | R/W | 复位 I2C2 (I2C2 Reset)<br>0: 无作用<br>1: 复位            |
| 23    | I2C3RST | R/W | 复位 I2C3 (I2C3 Reset)<br>0: 无作用<br>1: 复位            |
| 24    | 保留      |     |                                                    |
| 25    | CAN1RST | R/W | 复位 CAN1 (CAN1 Reset)<br>0: 无作用<br>1: 复位            |
| 26    | CAN2RST | R/W | 复位 CAN2 (CAN2 Reset)<br>0: 无作用<br>1: 复位            |
| 27    | 保留      |     |                                                    |
| 28    | PMURST  | R/W | 复位 PMU 时钟 (PMU Clock reset)<br>0: 无作用<br>1: 复位     |
| 29    | DACRST  | R/W | 复位 DAC 接口 (DAC Interface Reset)<br>0: 无作用<br>1: 复位 |
| 31:30 | 保留      |     |                                                    |

### 6.5.9 APB2 外设复位寄存器 (RCM\_APB2RST)

偏移地址: 0x24

复位值: 0x0000 0000

访问: 以字, 半字和字节形式访问, 无等待周期。

所有位都可以由软件置位或清 0。

| 位/域 | 名称        | R/W | 描述                                          |
|-----|-----------|-----|---------------------------------------------|
| 0   | TMR1RST   | R/W | 复位 TMR1 (TMR1 Reset)<br>0: 无作用<br>1: 复位     |
| 1   | TMR8RST   | R/W | 复位 TMR8 (TMR8 Reset)<br>0: 无作用<br>1: 复位     |
| 3:2 | 保留        |     |                                             |
| 4   | USART1RST | R/W | 复位 USART1 (USART1 Reset)<br>0: 无作用<br>1: 复位 |
| 5   | USART6RST | R/W | 复位 USART6 (USART6 Reset)<br>0: 无作用<br>1: 复位 |
| 7:6 | 保留        |     |                                             |

| 位/域   | 名称        | R/W | 描述                                                                  |
|-------|-----------|-----|---------------------------------------------------------------------|
| 8     | ADCRST    | R/W | 复位 ADC 接口 (ADC Interface Reset)<br>0: 无作用<br>1: 复位<br>注意: 作用于所有 ADC |
| 10:9  | 保留        |     |                                                                     |
| 11    | SDIORST   | R/W | 复位 SDIO (SDIO Reset)<br>0: 无作用<br>1: 复位                             |
| 12    | SPI1RST   | R/W | 复位 SPI1 (SPI1 Reset)<br>0: 无作用<br>1: 复位                             |
| 13    | 保留        |     |                                                                     |
| 14    | SYSCFGRST | R/W | 复位 SYSCFG 模块 (SYSCFG Module Reset)<br>0: 无作用<br>1: 复位               |
| 15    | 保留        |     |                                                                     |
| 16    | TMR9RST   | R/W | 复位 TMR9 (TMR9 Reset)<br>0: 无作用<br>1: 复位                             |
| 17    | TMR10RST  | R/W | 复位 TMR10 (TMR10 Reset)<br>0: 无作用<br>1: 复位                           |
| 18    | TMR11RST  | R/W | 复位 TMR11 (TMR11 Reset)<br>0: 无作用<br>1: 复位                           |
| 31:19 | 保留        |     |                                                                     |

### 6.5.10 AHB1 外设时钟使能寄存器 (RCM\_AHB1CLKEN)

偏移地址: 0x30

复位值: 0x0010 0000

访问: 以字, 半字和字节形式访问, 无等待周期。

| 位/域 | 名称   | R/W | 描述                                               |
|-----|------|-----|--------------------------------------------------|
| 0   | PAEN | R/W | 使能端口 A 时钟 (GPIOA Clock Enable)<br>0: 禁用<br>1: 使能 |
| 1   | PBEN | R/W | 使能端口 B 时钟 (GPIOB Clock Enable)<br>0: 禁用<br>1: 使能 |
| 2   | PCEN | R/W | 使能端口 C 时钟 (GPIOC Clock Enable)<br>0: 禁用<br>1: 使能 |

| 位/域   | 名称         | R/W | 描述                                                                          |
|-------|------------|-----|-----------------------------------------------------------------------------|
| 3     | PDEN       | R/W | 使能端口 D 时钟 (GPIOD Clock Enable)<br>0: 禁用<br>1: 使能                            |
| 4     | PEEN       | R/W | 使能端口 E 时钟 (GPIOE Clock Enable)<br>0: 禁用<br>1: 使能                            |
| 5     | PFEN       | R/W | 使能端口 F 时钟 (GPIOF Clock Enable)<br>0: 禁用<br>1: 使能                            |
| 6     | PGEN       | R/W | 使能端口 G 时钟 (GPIOG Clock Enable)<br>0: 禁用<br>1: 使能                            |
| 7     | PHEN       | R/W | 使能端口 H 时钟 (GPIOH Clock Enable)<br>0: 禁用<br>1: 使能                            |
| 11:8  |            |     | 保留                                                                          |
| 12    | CRCEN      | R/W | 使能 CRC 时钟 (CRC Clock Enable)<br>0: 禁用<br>1: 使能                              |
| 17:13 |            |     | 保留                                                                          |
| 18    | BAKPSRAMEN | R/W | 使能备份域 SRAM 接口时钟 (Backup SRAM Interface Clock Enable)<br>0: 禁用<br>1: 使能      |
| 19    |            |     | 保留                                                                          |
| 20    | DRAMEN     | R/W | 使能时钟单元的数据 RAM 时钟 (Clock Management Data RAM Clock Enable)<br>0: 禁用<br>1: 使能 |
| 21    | DMA1EN     | R/W | 使能 DMA1 时钟 (DMA1 Clock Enable)<br>0: 禁用<br>1: 使能                            |
| 22    | DMA2EN     | R/W | 使能 DMA2 时钟 (DMA2 Clock Enable)<br>0: 禁用<br>1: 使能                            |
| 24:23 |            |     | 保留                                                                          |
| 25    | ETHEN      | R/W | 使能 ETH (ETH Clock Enable)<br>0: 禁用<br>1: 使能                                 |
| 26    | ETHTXEN    | R/W | 使能 ETH 发送时钟 (ETH Transmission Clock Enable)<br>0: 禁用<br>1: 使能               |

| 位/域  | 名称       | R/W | 描述                                                         |
|------|----------|-----|------------------------------------------------------------|
| 27   | ETHRXEN  | R/W | 使能 ETH 接收时钟 (ETH Reception Clock Enable)<br>0: 禁用<br>1: 使能 |
| 28   | ETHPTPEN | R/W | 使能 ETH PTP 时钟 (ETH PTP Clock Enable)<br>0: 禁用<br>1: 使能     |
| 29   | OTGFS2EN | R/W | 使能 OTG_FS2 时钟 (OTG_FS2 Clock Enable)<br>0: 禁用<br>1: 使能     |
| 31:0 | 保留       |     |                                                            |

### 6.5.11 AHB2 外设时钟使能寄存器 (RCM\_AHB2CLKEN)

偏移地址: 0x34

复位值: 0x0000 0000

访问: 以字, 半字和字节形式访问, 无等待周期。

| 位/域  | 名称      | R/W | 描述                                                   |
|------|---------|-----|------------------------------------------------------|
| 5:0  | 保留      |     |                                                      |
| 6    | RNGEN   | R/W | 使能 RNG 时钟 (RNG Clock Enable)<br>0: 禁用<br>1: 使能       |
| 7    | OTGFSEN | R/W | 使能 OTG_FS 时钟 (OTG_FS Clock Enable)<br>0: 禁用<br>1: 使能 |
| 31:8 | 保留      |     |                                                      |

### 6.5.12 AHB3 外设时钟使能寄存器 (RCM\_AHB3CLKEN)

偏移地址: 0x38

复位值: 0x0000 0000

访问: 以字, 半字和字节形式访问, 无等待周期。

| 位/域  | 名称     | R/W | 描述                                               |
|------|--------|-----|--------------------------------------------------|
| 0    | EMMCEN | R/W | 使能 EMMC 时钟 (EMMC Clock Enable)<br>0: 禁用<br>1: 使能 |
| 1    | QSPIEN | R/W | 使能 QSPI 时钟 (QSPI Clock Enable)<br>0: 禁用<br>1: 使能 |
| 31:2 | 保留     |     |                                                  |

### 6.5.13 APB1 外设时钟使能寄存器 (RCM\_APB1CLKEN)

偏移地址: 0x40

复位值: 0x0000 0000

访问: 以字, 半字和字节形式访问, 无等待周期。

所有位都可以由软件置位或清 0。

| 位/域   | 名称       | R/W | 描述                                                   |
|-------|----------|-----|------------------------------------------------------|
| 0     | TMR2EN   | R/W | 使能 TMR2 时钟 (TMR2 Clock Enable)<br>0: 禁用<br>1: 使能     |
| 1     | TMR3EN   | R/W | 使能 TMR3 时钟 (TMR3 Clock Enable)<br>0: 禁用<br>1: 使能     |
| 2     | TMR4EN   | R/W | 使能 TMR4 时钟 (TMR4 Clock Enable)<br>0: 禁用<br>1: 使能     |
| 3     | TMR5EN   | R/W | 使能 TMR5 时钟 (TMR5 Clock Enable)<br>0: 禁用<br>1: 使能     |
| 4     | TMR6EN   | R/W | 使能 TMR6 时钟 (TMR6 Clock Enable)<br>0: 禁用<br>1: 使能     |
| 5     | TMR7EN   | R/W | 使能 TMR7 时钟 (TMR7 Clock Enable)<br>0: 禁用<br>1: 使能     |
| 6     | TMR12EN  | R/W | 使能 TMR12 时钟 (TMR12 Clock Enable)<br>0: 禁用<br>1: 使能   |
| 7     | TMR13EN  | R/W | 使能 TMR13 时钟 (TMR13 Clock Enable)<br>0: 禁用<br>1: 使能   |
| 8     | TMR14EN  | R/W | 使能 TMR14 时钟 (TMR14 Clock Enable)<br>0: 禁用<br>1: 使能   |
| 10:9  |          |     | 保留                                                   |
| 11    | WWDTEN   | R/W | 使能 WWDT 时钟 (WWDT Clock Enable)<br>0: 禁用<br>1: 使能     |
| 13:12 |          |     | 保留                                                   |
| 14    | SPI2EN   | R/W | 使能 SPI2 时钟 (SPI2 Clock Enable)<br>0: 禁用<br>1: 使能     |
| 15    | SPI3EN   | R/W | 使能 SPI3 时钟 (SPI3 Clock Enable)<br>0: 禁用<br>1: 使能     |
| 16    |          |     | 保留                                                   |
| 17    | USART2EN | R/W | 使能 USART2 时钟 (USART2 Clock Enable)<br>0: 禁用<br>1: 使能 |

| 位/域   | 名称       | R/W | 描述                                                         |
|-------|----------|-----|------------------------------------------------------------|
| 18    | USART3EN | R/W | 使能 USART3 时钟 (USART3 Clock Enable)<br>0: 禁用<br>1: 使能       |
| 19    | UART4EN  | R/W | 使能 UART4 时钟 (UART4 Clock Enable)<br>0: 禁用<br>1: 使能         |
| 20    | UART5EN  | R/W | 使能 UART5 时钟 (UART5 Clock Enable)<br>0: 禁用<br>1: 使能         |
| 21    | I2C1EN   | R/W | 使能 I2C1 时钟 (I2C1 Clock Enable)<br>0: 禁用<br>1: 使能           |
| 22    | I2C2EN   | R/W | 使能 I2C2 时钟 (I2C2 Clock Enable)<br>0: 禁用<br>1: 使能           |
| 23    | I2C3EN   | R/W | 使能 I2C3 时钟 (I2C3 Clock Enable)<br>0: 禁用<br>1: 使能           |
| 24    |          |     | 保留                                                         |
| 25    | CAN1EN   | R/W | 使能 CAN1 时钟 (CAN1 Clock Enable)<br>0: 禁用<br>1: 使能           |
| 26    | CAN2EN   | R/W | 使能 CAN2 时钟 (CAN2 Clock Enable)<br>0: 禁用<br>1: 使能           |
| 27    |          |     | 保留                                                         |
| 28    | PMUEN    | R/W | 使能 PMU 时钟 (PMU Clock Enable)<br>0: 禁用<br>1: 使能             |
| 29    | DACEN    | R/W | 使能 DAC 接口时钟 (DAC Interface Clock Enable)<br>0: 禁用<br>1: 使能 |
| 31:30 |          |     | 保留                                                         |

#### 6.5.14 APB2 外设时钟使能寄存器 (RCM\_APB2CLKEN)

偏移地址: 0x44

复位值: 0x0000 0000

访问: 以字, 半字和字节形式访问, 无等待周期。

所有位都可以由软件置位或清 0。

| 位/域 | 名称     | R/W | 描述                                               |
|-----|--------|-----|--------------------------------------------------|
| 0   | TMR1EN | R/W | 使能 TMR1 时钟 (TMR1 Clock Enable)<br>0: 禁用<br>1: 使能 |

| 位/域   | 名称       | R/W | 描述                                                            |
|-------|----------|-----|---------------------------------------------------------------|
| 1     | TMR8EN   | R/W | 使能 TMR8 时钟 (TMR8 Clock Enable)<br>0: 禁用<br>1: 使能              |
| 3:2   | 保留       |     |                                                               |
| 4     | USART1EN | R/W | 使能 USART1 时钟 (USART1 Clock Enable)<br>0: 禁用<br>1: 使能          |
| 5     | USART6EN | R/W | 使能 USART6 时钟 (USART6 Clock Enable)<br>0: 禁用<br>1: 使能          |
| 7:6   | 保留       |     |                                                               |
| 8     | ADC1EN   | R/W | 使能 ADC1 接口时钟 (ADC1 Interface Clock Enable)<br>0: 禁用<br>1: 使能  |
| 9     | ADC2EN   | R/W | 使能 ADC2 接口时钟 (ADC2 Interface Clock Enable)<br>0: 禁用<br>1: 使能  |
| 10    | ADC3EN   | R/W | 使能 ADC3 接口时钟 (ADC3 Interface Clock Enable)<br>0: 禁用<br>1: 使能  |
| 11    | SDIOEN   | R/W | 使能 SDIO 时钟 (SDIO Clock Enable)<br>0: 禁用<br>1: 使能              |
| 12    | SPI1EN   | R/W | 使能 SPI1 时钟 (SPI1 Clock Enable)<br>0: 禁用<br>1: 使能              |
| 13    | 保留       |     |                                                               |
| 14    | SYSCFGEN | R/W | 使能 SYSCFG 模块时钟 (SYSCFG Module Clock Enable)<br>0: 禁用<br>1: 使能 |
| 15    | 保留       |     |                                                               |
| 16    | TMR9EN   | R/W | 使能 TMR9 时钟 (TMR9 Clock Enable)<br>0: 禁用<br>1: 使能              |
| 17    | TMR10EN  | R/W | 使能 TMR10 时钟 (TMR10 Clock Enable)<br>0: 禁用<br>1: 使能            |
| 18    | TMR11EN  | R/W | 使能 TMR11 时钟 (TMR11 Clock Enable)<br>0: 禁用<br>1: 使能            |
| 31:19 | 保留       |     |                                                               |

### 6.5.15 低功耗下 AHB1 外设时钟使能寄存器 (RCM\_LPAHB1CLKEN)

偏移地址: 0x50

复位值: 0x3E6F 90FF

访问: 以字, 半字和字节形式访问, 无等待周期。

此寄存器的作用是, 在低功耗 (睡眠) 模式下, 使能 AHB1 的外设的时钟。

| 位/域   | 名称      | R/W | 描述                                                 |
|-------|---------|-----|----------------------------------------------------|
| 0     | PAEN    | R/W | 使能端口 A 时钟 (GPIOA Clock Enable)<br>0: 禁用<br>1: 使能   |
| 1     | PBEN    | R/W | 使能端口 B 时钟 (GPIOB Clock Enable)<br>0: 禁用<br>1: 使能   |
| 2     | PCEN    | R/W | 使能端口 C 时钟 (GPIOC Clock Enable)<br>0: 禁用<br>1: 使能   |
| 3     | PDEN    | R/W | 使能端口 D 时钟 (GPIOD Clock Enable)<br>0: 禁用<br>1: 使能   |
| 4     | PEEN    | R/W | 使能端口 E 时钟 (GPIOE Clock Enable)<br>0: 禁用<br>1: 使能   |
| 5     | PFEN    | R/W | 使能端口 F 时钟 (GPIOF Clock Enable)<br>0: 禁用<br>1: 使能   |
| 6     | PGEN    | R/W | 使能端口 G 时钟 (GPIOG Clock Enable)<br>0: 禁用<br>1: 使能   |
| 7     | PHEN    | R/W | 使能端口 H 时钟 (GPIOH Clock Enable)<br>0: 禁用<br>1: 使能   |
| 11:8  |         |     | 保留                                                 |
| 12    | CRCEN   | R/W | 使能 CRC 时钟 (CRC Clock Enable)<br>0: 禁用<br>1: 使能     |
| 14:13 |         |     | 保留                                                 |
| 15    | FMCEN   | R/W | 使能 FMC 时钟 (FMC Clock Enable)<br>0: 禁用<br>1: 使能     |
| 16    | SRAM1EN | R/W | 使能 SRAM1 时钟 (SRAM1 Clock Enable)<br>0: 禁用<br>1: 使能 |
| 17    | SRAM2EN | R/W | 使能 SRAM2 时钟 (SRAM2 Clock Enable)<br>0: 禁用<br>1: 使能 |

| 位/域   | 名称         | R/W | 描述                                                                     |
|-------|------------|-----|------------------------------------------------------------------------|
| 18    | BAKPSRAMEN | R/W | 使能备份域 SRAM 接口时钟 (Backup SRAM Interface Clock Enable)<br>0: 禁用<br>1: 使能 |
| 19    | SRAM3EN    | R/W | 使能 SRAM3 时钟 (SRAM3 Clock Enable)<br>0: 禁用<br>1: 使能                     |
| 20    | 保留         |     |                                                                        |
| 21    | DMA1EN     | R/W | 使能 DMA1 时钟 (DMA1 Clock Enable)<br>0: 禁用<br>1: 使能                       |
| 22    | DMA2EN     | R/W | 使能 DMA2 时钟 (DMA2 Clock Enable)<br>0: 禁用<br>1: 使能                       |
| 24:23 | 保留         |     |                                                                        |
| 25    | ETHEN      | R/W | 使能 ETH (ETH Clock Enable)<br>0: 禁用<br>1: 使能                            |
| 26    | ETHTXEN    | R/W | 使能 ETH 发送时钟 (ETH Transmission Clock Enable)<br>0: 禁用<br>1: 使能          |
| 27    | ETHRXEN    | R/W | 使能 ETH 接收时钟 (ETH Reception Clock Enable)<br>0: 禁用<br>1: 使能             |
| 28    | ETHPTPEN   | R/W | 使能 ETH PTP 时钟 (ETH PTP Clock Enable)<br>0: 禁用<br>1: 使能                 |
| 29    | OTGFS2EN   | R/W | 使能 OTG_FS2 时钟 (OTG_FS2 Clock Enable)<br>0: 禁用<br>1: 使能                 |
| 31:30 | 保留         |     |                                                                        |

### 6.5.16 低功耗下 AHB2 外设时钟使能寄存器 (RCM\_LPAHB2CLKEN)

偏移地址: 0x54

复位值: 0x0000 00C0

访问: 以字, 半字和字节形式访问, 无等待周期。

此寄存器的作用是, 在低功耗 (睡眠) 模式下, 使能 AHB2 的外设的时钟。

| 位/域 | 名称    | R/W | 描述                                             |
|-----|-------|-----|------------------------------------------------|
| 5:0 | 保留    |     |                                                |
| 6   | RNGEN | R/W | 使能 RNG 时钟 (RNG Clock Enable)<br>0: 禁用<br>1: 使能 |

| 位/域  | 名称      | R/W | 描述                                                   |
|------|---------|-----|------------------------------------------------------|
| 7    | OTGFSEN | R/W | 使能 OTG_FS 时钟 (OTG_FS Clock Enable)<br>0: 禁用<br>1: 使能 |
| 31:8 | 保留      |     |                                                      |

### 6.5.17 低功耗下 AHB3 外设时钟使能寄存器 (RCM\_LPAHB3CLKEN)

偏移地址: 0x58

复位值: 0x0000 0003

访问: 以字, 半字和字节形式访问, 无等待周期。

此寄存器的作用是, 在低功耗 (睡眠) 模式下, 使能 AHB3 的外设的时钟。

| 位/域  | 名称     | R/W | 描述                                               |
|------|--------|-----|--------------------------------------------------|
| 0    | EMMCEN | R/W | 使能 EMMC 时钟 (EMMC Clock Enable)<br>0: 禁用<br>1: 使能 |
| 1    | QSPIEN | R/W | 使能 QSPI 时钟 (QSPI Clock Enable)<br>0: 禁用<br>1: 使能 |
| 31:2 | 保留     |     |                                                  |

### 6.5.18 低功耗下 APB1 外设时钟使能寄存器 (RCM\_LPAPB1CLKEN)

偏移地址: 0x60

复位值: 0x36FE C9FF

访问: 以字, 半字和字节形式访问, 无等待周期。

所有位都可以由软件置位或清 0。

此寄存器的作用是, 在低功耗 (睡眠) 模式下, 使能 APB1 的外设的时钟。

| 位/域 | 名称     | R/W | 描述                                               |
|-----|--------|-----|--------------------------------------------------|
| 0   | TMR2EN | R/W | 使能 TMR2 时钟 (TMR2 Clock Enable)<br>0: 禁用<br>1: 使能 |
| 1   | TMR3EN | R/W | 使能 TMR3 时钟 (TMR3 Clock Enable)<br>0: 禁用<br>1: 使能 |
| 2   | TMR4EN | R/W | 使能 TMR4 时钟 (TMR4 Clock Enable)<br>0: 禁用<br>1: 使能 |
| 3   | TMR5EN | R/W | 使能 TMR5 时钟 (TMR5 Clock Enable)<br>0: 禁用<br>1: 使能 |
| 4   | TMR6EN | R/W | 使能 TMR6 时钟 (TMR6 Clock Enable)<br>0: 禁用<br>1: 使能 |
| 5   | TMR7EN | R/W | 使能 TMR7 时钟 (TMR7 Clock Enable)<br>0: 禁用<br>1: 使能 |

| 位/域   | 名称       | R/W | 描述                                                   |
|-------|----------|-----|------------------------------------------------------|
| 6     | TMR12EN  | R/W | 使能 TMR12 时钟 (TMR12 Clock Enable)<br>0: 禁用<br>1: 使能   |
| 7     | TMR13EN  | R/W | 使能 TMR13 时钟 (TMR13 Clock Enable)<br>0: 禁用<br>1: 使能   |
| 8     | TMR14EN  | R/W | 使能 TMR14 时钟 (TMR14 Clock Enable)<br>0: 禁用<br>1: 使能   |
| 10:9  | 保留       |     |                                                      |
| 11    | WWDTEN   | R/W | 使能 WWDT 时钟 (WWDT Clock Enable)<br>0: 禁用<br>1: 使能     |
| 13:12 | 保留       |     |                                                      |
| 14    | SPI2EN   | R/W | 使能 SPI2 时钟 (SPI2 Clock Enable)<br>0: 禁用<br>1: 使能     |
| 15    | SPI3EN   | R/W | 使能 SPI3 时钟 (SPI3 Clock Enable)<br>0: 禁用<br>1: 使能     |
| 16    | 保留       |     |                                                      |
| 17    | USART2EN | R/W | 使能 USART2 时钟 (USART2 Clock Enable)<br>0: 禁用<br>1: 使能 |
| 18    | USART3EN | R/W | 使能 USART3 时钟 (USART3 Clock Enable)<br>0: 禁用<br>1: 使能 |
| 19    | UART4EN  | R/W | 使能 UART4 时钟 (UART4 Clock Enable)<br>0: 禁用<br>1: 使能   |
| 20    | UART5EN  | R/W | 使能 UART5 时钟 (UART5 Clock Enable)<br>0: 禁用<br>1: 使能   |
| 21    | I2C1EN   | R/W | 使能 I2C1 时钟 (I2C1 Clock Enable)<br>0: 禁用<br>1: 使能     |
| 22    | I2C2EN   | R/W | 使能 I2C2 时钟 (I2C2 Clock Enable)<br>0: 禁用<br>1: 使能     |
| 23    | I2C3EN   | R/W | 使能 I2C3 时钟 (I2C3 Clock Enable)<br>0: 禁用<br>1: 使能     |
| 24    | 保留       |     |                                                      |

| 位/域   | 名称     | R/W | 描述                                                         |
|-------|--------|-----|------------------------------------------------------------|
| 25    | CAN1EN | R/W | 使能 CAN1 时钟 (CAN1 Clock Enable)<br>0: 禁用<br>1: 使能           |
| 26    | CAN2EN | R/W | 使能 CAN2 时钟 (CAN2 Clock Enable)<br>0: 禁用<br>1: 使能           |
| 27    | 保留     |     |                                                            |
| 28    | PMUEN  | R/W | 使能 PMU 时钟 (PMU Clock Enable)<br>0: 禁用<br>1: 使能             |
| 29    | DACEN  | R/W | 使能 DAC 接口时钟 (DAC Interface Clock Enable)<br>0: 禁用<br>1: 使能 |
| 31:30 | 保留     |     |                                                            |

### 6.5.19 低功耗下 APB2 外设时钟使能寄存器 (RCM\_LPAPB2CLKEN)

偏移地址: 0x64

复位值: 0x0007 5F33

访问: 以字, 半字和字节形式访问, 无等待周期。

所有位都可以由软件置位或清 0。

此寄存器的作用是, 在低功耗 (睡眠) 模式下, 使能 APB2 的外设的时钟。

| 位/域 | 名称       | R/W | 描述                                                           |
|-----|----------|-----|--------------------------------------------------------------|
| 0   | TMR1EN   | R/W | 使能 TMR1 时钟 (TMR1 Clock Enable)<br>0: 禁用<br>1: 使能             |
| 1   | TMR8EN   | R/W | 使能 TMR8 时钟 (TMR8 Clock Enable)<br>0: 禁用<br>1: 使能             |
| 3:2 | 保留       |     |                                                              |
| 4   | USART1EN | R/W | 使能 USART1 时钟 (USART1 Clock Enable)<br>0: 禁用<br>1: 使能         |
| 5   | USART6EN | R/W | 使能 USART6 时钟 (USART6 Clock Enable)<br>0: 禁用<br>1: 使能         |
| 7:6 | 保留       |     |                                                              |
| 8   | ADC1EN   | R/W | 使能 ADC1 接口时钟 (ADC1 Interface Clock Enable)<br>0: 禁用<br>1: 使能 |
| 9   | ADC2EN   | R/W | 使能 ADC2 接口时钟 (ADC2 Interface Clock Enable)<br>0: 禁用<br>1: 使能 |

| 位/域   | 名称       | R/W | 描述                                                            |
|-------|----------|-----|---------------------------------------------------------------|
| 10    | ADC3EN   | R/W | 使能 ADC3 接口时钟 (ADC3 Interface Clock Enable)<br>0: 禁用<br>1: 使能  |
| 11    | SDIOEN   | R/W | 使能 SDIO 时钟 (SDIO Clock Enable)<br>0: 禁用<br>1: 使能              |
| 12    | SPI1EN   | R/W | 使能 SPI1 时钟 (SPI1 Clock Enable)<br>0: 禁用<br>1: 使能              |
| 13    | 保留       |     |                                                               |
| 14    | SYSCFGEN | R/W | 使能 SYSCFG 模块时钟 (SYSCFG Module Clock Enable)<br>0: 禁用<br>1: 使能 |
| 15    | 保留       |     |                                                               |
| 16    | TMR9EN   | R/W | 使能 TMR9 时钟 (TMR9 Clock Enable)<br>0: 禁用<br>1: 使能              |
| 17    | TMR10EN  | R/W | 使能 TMR10 时钟 (TMR10 Clock Enable)<br>0: 禁用<br>1: 使能            |
| 18    | TMR11EN  | R/W | 使能 TMR11 时钟 (TMR11 Clock Enable)<br>0: 禁用<br>1: 使能            |
| 31:19 | 保留       |     |                                                               |

### 6.5.20 备份域控制寄存器 (RCM\_BDCTRL)

偏移地址: 0x70

复位值: 0x0000 0000, 只能由 RTC 域复位有效复位

访问: 以字、半字和字节形式访问, 0 到 3 等待周期

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

注意: 当 PMU\_CTRL 中的 BPWEN 位被置 1 后, LSEEN、LSEBCFG、RTCSRSEL 和 RTCCLKEN 才能进行改动。

| 位/域 | 名称        | R/W | 描述                                                                                                  |
|-----|-----------|-----|-----------------------------------------------------------------------------------------------------|
| 0   | LSEEN     | R/W | 使能 LSECLK (Low-Speed External Oscillator Enable)<br>0: 禁用<br>1: 使能                                  |
| 1   | LSERDYFLG | R   | LSECLK 就绪标志 (Low-Speed External Clock Ready Flag)<br>LSECLK 稳定时硬件置 1, 不稳定时硬件清 0。<br>0: 未就绪<br>1: 就绪 |

| 位/域   | 名称       | R/W | 描述                                                                                                                                                                                                                                |
|-------|----------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2     | LSEBCFG  | R/W | <p>配置 LSECLK 为旁路模式 (Low-Speed External Clock Bypass Mode Configure)</p> <p>旁路模式指外部时钟作为 LSECLK 时钟源, 否则谐振器作为 LSECLK 时钟源。</p> <p>0: 非旁路模式<br/>1: 旁路模式</p>                                                                            |
| 7:3   | 保留       |     |                                                                                                                                                                                                                                   |
| 9:8   | RTCSRSEL | R/W | <p>选择 RTC 时钟源 (RTC Clock Source Select)</p> <p>先设置 RTCRST 位复位 RTC 域, 再选择 RTC 时钟源, 无法直接配置该寄存器修改。</p> <p>00: 无时钟<br/>01: LSECLK 作为 RTC 时钟<br/>10: LSICLK 作为 RTC 时钟<br/>11: HSECLK 在分频后作为 RTC 时钟 (分频因子由 RCM_CFG 寄存器的 RTCPSC 位决定)</p> |
| 14:10 | 保留       |     |                                                                                                                                                                                                                                   |
| 15    | RTCCLKEN | R/W | <p>使能 RTC 时钟 (RTC Clock Enable)</p> <p>0: 禁用<br/>1: 使能</p>                                                                                                                                                                        |
| 16    | BDRST    | R/W | <p>复位备份域软件 (Backup Domain Software Reset)</p> <p>由软件置 1 或清 0。</p> <p>0: 复位未激活<br/>1: 复位备份域 (只影响 LSECLK 振荡器、RTC 实时时钟和寄存器 RCM_BDCTRL)</p>                                                                                           |
| 31:17 | 保留       |     |                                                                                                                                                                                                                                   |

### 6.5.21 时钟控制/状态寄存器 (RCM\_CSTS)

偏移地址: 0x74

复位值: 0x0E00 0000, 除复位标志外由系统复位清除, 复位标志只能由电源复位清除。

访问: 以字、半字和字节形式访问, 0 到 3 等待周期。

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

| 位/域  | 名称        | R/W | 描述                                                                                                                     |
|------|-----------|-----|------------------------------------------------------------------------------------------------------------------------|
| 0    | LSIEN     | R/W | <p>使能内部低速振荡器 (Low-Speed Internal Oscillator Enable)</p> <p>由软件置 1 或清 0。</p> <p>0: 禁用<br/>1: 使能</p>                     |
| 1    | LSIRDYFLG | R   | <p>内部低速振荡器就绪 (Low-Speed Internal Oscillator Ready Flag)</p> <p>LSICLK 稳定时硬件置 1, 不稳定时硬件清 0。</p> <p>0: 未就绪<br/>1: 就绪</p> |
| 23:2 | 保留        |     |                                                                                                                        |

| 位/域 | 名称         | R/W  | 描述                                                                                                                                  |
|-----|------------|------|-------------------------------------------------------------------------------------------------------------------------------------|
| 24  | RSTFLGCLR  | RT_W | 清除复位标志 (Reset Flag Clear)<br>由软件置位或清除复位标志, 包括 RSTFLGCLR。<br>0: 禁用<br>1: 清除复位标志                                                      |
| 25  | BORRSTFLG  | R    | 欠压复位标志 (BOR Flag)<br>当欠压复位发生时由硬件置位, 否则通过将 RSTFLGCLR 置位清除。<br>0: 没有发生复位<br>1: 复位发生                                                   |
| 26  | PINRSTFLG  | R    | 引脚复位标志 (PIN Reset Flag)<br>在引脚复位发生时由硬件置位, 否则通过将 RSTFLGCLR 置位清除。<br>0: 没有发生复位<br>1: 复位发生                                             |
| 27  | PODRSTFLG  | R    | 上电/掉电复位标志 (POR/PDR Reset Flag)<br>由硬件置 1; 由软件通过写 RSTFLGCLR 位清除。<br>0: 无上电/掉电复位发生<br>1: 发生上电/掉电复位                                    |
| 28  | SWRSTFLG   | R    | 软件复位标志 (Software Reset Flag)<br>由硬件置 1; 由软件通过写 RSTFLGCLR 位清除。<br>0: 没有发生复位<br>1: 发生复位                                               |
| 29  | IWDTRSTFLG | R    | 独立看门狗复位标志 (Independent Watchdog Reset Flag)<br>当独立看门狗复位发生在 V <sub>DD</sub> 区域时由硬件置 1; 由软件通过写 RSTFLGCLR 位清除。<br>0: 没有发生复位<br>1: 发生复位 |
| 30  | WWDTRSTFLG | R    | 窗口看门狗复位标志 (Window Watchdog Reset Flag)<br>当窗口看门狗复位发生时由硬件置 1; 由软件通过写 RSTFLGCLR 位清除。<br>0: 没有发生复位<br>1: 发生复位                          |
| 31  | LPWRRSTFLG | R    | 低功耗复位标志 (Low Power Reset Flag)<br>当低功耗管理复位发生时由硬件置 1; 由软件通过写 RSTFLGCLR 位清除。<br>0: 没有发生复位<br>1: 发生复位                                  |

### 6.5.22 扩频时钟配置寄存器 (RCM\_SS\_CFG)

偏移地址: 0x80

复位值: 0x0000 0000

访问: 以字、半字和字节形式访问, 0 到 3 等待周期。

因为扩频时钟只作用于 PLL1, 所以只能在 PLL1 没有被使能时写入这个寄存器, 对扩频时钟进行配置。

| 位/域   | 名称      | R/W | 描述                                                                 |
|-------|---------|-----|--------------------------------------------------------------------|
| 12:0  | MODPCFG | R/W | 配置调制周期 (Modulation Period Configure)<br>由软件置 1 或清 0。<br>配置调制周期的输入。 |
| 27:13 | STEP    | R/W | 增量步长 (Incrementation Step)<br>由软件置 1 或清 0。<br>配置调制幅度的输入。           |
| 29:28 | 保留      |     |                                                                    |
| 30    | SSSEL   | R/W | 选择扩谱 (Spread Spectrum Select)<br>由软件置位或清除。<br>0: 中心扩谱<br>1: 向下扩谱   |
| 31    | SSEN    | R/W | 使能扩频调制 (Spread Spectrum Enable)<br>由软件置 1 或清 0。<br>0: 禁用<br>1: 使能  |

## 7 电源管理单元 (PMU)

### 7.1 术语全称、缩写描述

表格 37 术语全称、缩写描述

| 中文全称    | 英文全称                   | 英文缩写 |
|---------|------------------------|------|
| 电源管理单元  | Power Management Unit  | PMU  |
| 上电复位    | Power On Reset         | POR  |
| 掉电复位    | Power Down Reset       | PDR  |
| 欠压复位    | Brown-out Reset        | BOR  |
| 电源电压检测器 | Power Voltage Detector | PVD  |

### 7.2 简介

电源是一个系统稳定运行的基础，工作电压为 1.8~3.6V，可以通过内置的电压调节器提供 1.2V 的电源，若主电源  $V_{DD}$  掉电，则通过  $V_{BAT}$  给后备供电区域供电。

## 7.3 结构框图

表格 38 电源结构框图



## 7.4 功能描述

### 7.4.1 电源域

产品的电源域有: V<sub>DD</sub> 电源域、V<sub>DDA</sub> 电源域、1.2V 电源域、备份电源域。

#### 7.4.1.1 V<sub>DD</sub> 电源域

通过 V<sub>DD</sub>/V<sub>SS</sub> 引脚供电, 给电压调节器和 I/O 供电。

#### 电压调节器

给 1.2V 电源域供电, 有以下几种工作模式:

- 正常模式: 此模式下 1.2V 供电区域全功率运行, 在此模式下, 可通过寄存器 PMU\_CTRL 的 VOSSEL 位选择输出电压的级别。

- 停止模式: 此模式下 1.2V 供电区域工作在低功耗状态, 所有时钟关闭, 外设停止工作, 设置的电压输出级别保持不变。
- 待机模式: 此模式下 1.2V 供电区域停止供电, 除了备用电路, 寄存器和 SRAM 内容都会丢失。

#### 7.4.1.2 $V_{DDA}$ 电源域

通过  $V_{DDA}/V_{SSA}$ 、 $V_{REF+}/V_{REF-}$  引脚供电, 给 ADC、DAC、HSICLK、LSICLK、PLL、复位模块供电。

#### 独立 ADC 电源和参考电压

独立的 ADC 电源可以提高转换精度, 具体电源引脚如下:

- $V_{DDA}$ : ADC 的电源引脚
- $V_{SSA}$ : 独立电源地引脚
- $V_{REF+}/V_{REF-}$ : ADC 参考电压引脚

#### 7.4.1.3 1.2V 电源域

由电压调节器供电, 给内核、Flash、SRAM 和数字外设供电。

#### 7.4.1.4 备份电源域

当  $V_{DD}$  存在时, 后备供电区域由  $V_{DD}$  供电。当  $V_{DD}$  掉电时, 后备供电区域由  $V_{BAT}$  供电, 用来保存后备寄存器的内容和维持 RTC 功能。给 LSECLK 晶体谐振器、RTC、备份寄存器、备份 SRAM、PC13、PC14、PC15 以及唤醒逻辑供电。

### 7.4.2 电源管理

#### 7.4.2.1 上电复位与掉电复位 (POR 与 PDR)

当检测到  $V_{DD}/V_{DDA}$  低于阈值电压  $V_{POR}$  和  $V_{PDR}$  时, 芯片将会自动保持为复位状态, 上电复位和掉电复位的波形图如下, POR、PDR、迟滞电压、迟滞时间请参见数据手册。

图 9 上电复位和掉电复位的波形图



#### 7.4.2.2 欠压复位 (BOR)

当检测到  $V_{DD}/V_{DDA}$  低于阈值电压  $V_{BOR}$  时，芯片将会自动保持为复位状态， $V_{BOR}$  可通过选项字节配置。以下为  $V_{BOR}$  的 4 个阈值：

- $V_{BOR0}$ : BOR 关闭，电压范围为 1.80~2.10V
- $V_{BOR1}$ : BOR 级别 1，电压范围为 2.10~2.40V
- $V_{BOR2}$ : BOR 级别 2，电压范围为 2.40~2.70V
- $V_{BOR3}$ : BOR 级别 3，电压范围为 2.70~3.60V

图 10 BOR 阈值波形图



### 7.4.2.3 电源电压监测器 (PWD)

PVD 可设置一阈值，可监测  $V_{DD}/V_{DDA}$  高于还是低于该阈值。如果使能中断，可触发中断，提前处理  $V_{DD}/V_{DDA}$  超过阈值的情况。

PVD 的使用方法如下：

- (1) 配置寄存器 PMU\_CTRL 的 PVDEN 位置 1 使能 PVD。
- (2) 配置寄存器 PMU\_CTRL 的 PLSEL[2:0]位选择 PVD 的电压阈值。
- (3) 配置寄存器 PMU\_CSTS 的 PVDOFLG 位表明  $V_{DD}$  的值是高于还是低于 PVD 的阈值。
- (4) 当检测到  $V_{DD}/V_{DDA}$  低于或高于 PVD 阈值时，将产生 PVD 中断。

PVD 的阈值波形图见下图。PWD 阈值、迟滞电压请参见数据手册。

图 11 PVD 阈值波形图



### 7.4.3 功耗控制

#### 7.4.3.1 低功耗模式降低功耗

低功耗模式有三种：睡眠模式、停止模式和待机模式。通过关闭内核、时钟源、设置调压器来降低功耗。

每种低功耗模式的功耗、唤醒启动时间、唤醒方式、唤醒后数据的保存有差异；功耗越低，唤醒时间越长，唤醒方式越少，唤醒后保存的数据越少。用户可以根据需求选择最合适的低功耗模式。下图是三种低功耗模式的差异。

表格 39 “睡眠模式、停止模式和待机模式”差异

| 模式 | 说明 | 进入方式      | 唤醒方式 | 电压调节器 | 对 1.2V 区域时钟的影响 | 对 $V_{DD}$ 区域时钟的影响 |
|----|----|-----------|------|-------|----------------|--------------------|
| 睡眠 |    | 调用 WFI 命令 | 任一中断 | 开     |                | 无                  |

| 模式 | 说明                                     | 进入方式                                       | 唤醒方式                                                                   | 电压调节器      | 对 1.2V 区域时钟的影响               | 对 VDD 区域时钟的影响          |
|----|----------------------------------------|--------------------------------------------|------------------------------------------------------------------------|------------|------------------------------|------------------------|
|    | Arm® Cortex®-M4F 内核停止, 所有外设包括内核的外设仍在工作 | 调用 WFE 命令                                  | 唤醒事件                                                                   | 开          | 只关闭内核时钟, 对其它时钟以及 ADC 的时钟没有影响 | 无                      |
| 停止 | 所有的时钟都已停止                              | PDDSCFG 和 LPDSCFG 位 +SLEEPDEEP 位+WFI 或 WFE | 任一外部中断                                                                 | 开启或处于低功耗模式 |                              | HSICLK                 |
| 待机 | 1.2V 电源关闭                              | PDDSCFG 位 +SLEEPDEEP 位+WFI 或 WFE           | WKUP 引脚的上升沿、RTC 闹钟事件、RTC 唤醒事件、RTC 时间戳事件、RTC 入侵事件、NRST 引脚上的外部复位、IWDT 复位 | 关          | 关闭所有 1.2V 区域的时钟              | HSECLK 和 HSECLK 的振荡器关闭 |

## 睡眠模式

睡眠模式特点见下表:

表格 40 睡眠模式特点

| 特性   | 说明                                                                                                                    |
|------|-----------------------------------------------------------------------------------------------------------------------|
| 进入   | 通过执行 WFI 或 WFE 指令时立即进入睡眠模式。<br>当 SLEEPONEINT 置 0, 且执行 WFI 或 WFE 指令, 立即进入睡眠模式; 当 SLEEPONEINT 置 1, 系统先退出中断程序, 立即进入睡眠模式。 |
| 唤醒   | 若执行 WFI 指令进入睡眠模式, 则通过任意中断唤醒; 若执行 WFE 指令进入睡眠模式, 则通过事件唤醒。                                                               |
| 睡眠时  | 内核停止工作, 所有外设仍在运行, 且保存睡眠前内核寄存器、内存的数据。                                                                                  |
| 唤醒延时 | 无                                                                                                                     |
| 唤醒后  | 若通过中断唤醒, 先进入中断, 然后退出中断, 之后才执行 WFI 指令后的程序, 若通过事件唤醒, 直接执行 WFE 指令后的程序。                                                   |

## 停止模式

停止模式特点见下表:

表格 41 停止模式特点

| 特性   | 说明                                                                                                                                                                     |
|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 进入   | 内核寄存器的 SLEEPDEEP 位置 1, 寄存器 PMU_CTRL 中的 PDDSCFG 位置 0, 然后执行 WFI 或 WFE 指令时立即进入停止模式;<br>寄存器 PMU_CTRL 的 LPDSCFG 位置 0 时调压器工作在正常模式, 寄存器 PMU_CTRL 的 LPDSCFG 位置 1 时调节器工作在低功耗模式。 |
| 唤醒   | 若执行 WFI 指令进入停止模式, 则通过任意中断唤醒; 若执行 WFE 指令进入停止模式, 则通过事件唤醒。                                                                                                                |
| 停止时  | 内核停止工作, 外设也停止工作, 保存停止前内核寄存器、内存的数据。                                                                                                                                     |
| 唤醒延时 | HSICLK 振荡器唤醒时间+电压调节器从低功耗唤醒的时间。                                                                                                                                         |
| 唤醒后  | 若通过中断唤醒, 先进入中断, 然后退出中断, 之后才执行 WFI 指令后的程序。若通过事件唤醒, 直接执行 WFE 指令后的程序。                                                                                                     |

### 待机模式

待机模式特点见下表:

表格 42 待机模式

| 特性   | 说明                                                                                            |
|------|-----------------------------------------------------------------------------------------------|
| 进入   | 内核寄存器的 SLEEPDEEP 位置 1, 寄存器 PMU_CTRL 中的 PDDSCFG 位置 1, WUEFLG 位置 0, 然后执行 WFI 或 WFE 指令时立即进入待机模式。 |
| 唤醒   | 通过 WKUP 引脚的上升沿, RTC 闹钟、唤醒、入侵事件或 NRST 引脚外部复位及 IWDT 复位唤醒。                                       |
| 待机时  | 内核停止工作, 外设也停止工作, 内核寄存器、内存的数据会丢失。                                                              |
| 唤醒延时 | 芯片复位的时间。                                                                                      |
| 唤醒后  | 程序重新开始执行。                                                                                     |

#### 7.4.3.2 运行模式降低功耗

在运行模式, 可通过降低系统时钟、关闭或者降低 APB/AHB 总线上的外设时钟降低运行模式功耗。

#### 7.4.3.3 RTC 复用功能从低功耗模式下唤醒

RTC 复用功能包括 RTC 闹钟、RTC 唤醒事件、RTC 入侵事件和 RTC 时间戳事件, 这些功能都可将 MCU 从停止模式或待机模式下唤醒, RTC 提供可编程时基, 便于定期从停止或待机模式唤醒器件。

## 7.5 寄存器地址映射

表格 43 PMU 寄存器地址映射

| 寄存器名     | 描述         | 偏移地址 |
|----------|------------|------|
| PMU_CTRL | 电源控制寄存器    | 0x00 |
| PMU_CSTS | 电源控制/状态寄存器 | 0x04 |

## 7.6 寄存器功能描述

### 7.6.1 电源控制寄存器 (PMU\_CTRL)

偏移地址: 0x00

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

| 位/域   | 名称       | R/W   | 描述                                                                                                                                                         |
|-------|----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | LPDSCFG  | R/W   | 低功耗深度睡眠配置 (Low Power Deepsleep Configure)<br>配置在停机模式下调压器的工作状态。<br>0: 开启<br>1: 低功耗模式                                                                        |
| 1     | PDDSCFG  | R/W   | 配置掉电深度睡眠 (Pown Down Deep Sleep Configure)<br>在 CPU 进入深度睡眠下, 在待机、停机模式下配置调压器的状态。<br>0: 进入停机模式时, 调压器由 LPDSCFG 位控制<br>1: 进入待机模式                                |
| 2     | WUFLGCLR | RC_W1 | 清除唤醒标志 (Wakeup Flag Clear)<br>0: 无效<br>1: 通过写 1 在 2 个系统时钟周期后清除唤醒标志                                                                                         |
| 3     | SBFLGCLR | RC_W1 | 清除待机标志 (Standby Flag Clear)<br>0: 无效<br>1: 写 1 清除待机标志                                                                                                      |
| 4     | PVDEN    | R/W   | 使能电源电压监测器 (Power Voltage Detector Enable)<br>0: 禁用<br>1: 使能                                                                                                |
| 7:5   | PLSEL    | R/W   | 选择 PVD 电压阈值 (PVD Level Select)<br>000: 2.0V<br>001: 2.1V<br>010: 2.3V<br>011: 2.5V<br>100: 2.6V<br>101: 2.7V<br>110: 2.8V<br>111: 2.9V<br>注意: 详细说明参见“数据手册” |
| 8     | BPWEN    | R/W   | 使能写备份区域 (Backup Domain Write Access Enable)<br>备份区域指 RTC、备份寄存器, 复位后禁止写访问, 写 1 允许写访问。<br>0: 禁用写<br>1: 使能写                                                   |
| 9     | FPDSM    | R/W   | 停止模式下 Flash 掉电 (Flash power-down in Stop mode)<br>0: 进入停止模式时 Flash 不掉电<br>1: 进入停止模式时 Flash 掉电                                                              |
| 13:10 |          |       | 保留                                                                                                                                                         |
| 14    | VOSSEL   | R/W   | 选择调压器输出电压级别 (Regulator Voltage Scaling Output Selection)<br>0: 级别 2 模式<br>1: 级别 1 模式                                                                       |

| 位/域   | 名称 | R/W | 描述 |
|-------|----|-----|----|
| 31:15 |    |     | 保留 |

## 7.6.2 电源控制/状态寄存器 (PMU\_CSTS)

偏移地址: 0x04

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

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

| 位/域   | 名称      | R/W | 描述                                                                                                                                                                                                                                                                                                            |
|-------|---------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | WUEFLG  | R   | <p>唤醒事件产生标志 (Wakeup Event Flag)<br/>         该位由硬件设置, 标志是否在 WKUP 引脚上发生唤醒事件或者 RTC 阔钟唤醒事件、RTC 入侵事件、RTC 时间戳事件或 RTC 唤醒事件。<br/>         0: 未发生<br/>         1: 已发生<br/>         注意: 使能 WKUP 引脚, 当 WKUP 引脚已经是高电平时, 会检测到事件。</p>                                                                                      |
| 1     | SBFLG   | R   | <p>待机标志 (Standby Flag)<br/>         该位由硬件置 1, 只能由 POR/PDR (上电/掉电复位) 或设置电源控制寄存器 (PMU_CTRL) 的 SBFLGCLR 位清除。<br/>         0: 未进入过待机模式<br/>         1: 已进入过待机模式</p>                                                                                                                                               |
| 2     | PVDOFLG | R   | <p>PVD 输出标志位 (PVD Output Flag)<br/>         表示 <math>V_{DD}/V_{DDA}</math> 是否高于由 PLSEL[2:0]选定的 PVD 阀值。<br/>         当 PVD 被 PVDEN 位使能后该位才有效。<br/>         0: <math>V_{DD}/V_{DDA}</math> 高于 PVD 阀值<br/>         1: <math>V_{DD}/V_{DDA}</math> 低于 PVD 阀值<br/>         注意: 复位后或者进入待机模式时 (PVD 停止工作), 该位为 0。</p> |
| 3     | BKPRFLG | R   | <p>备份调压器就绪标志 (Backup Regulator Ready Flag)<br/>         该位由硬件置 1, 表示备份调压器是否就绪。<br/>         0: 未就绪<br/>         1: 就绪</p>                                                                                                                                                                                     |
| 7:4   |         |     | 保留                                                                                                                                                                                                                                                                                                            |
| 8     | WKUPCFG | R/W | <p>WKUP 引脚配置 (WKUP Pin Configure)<br/>         WKUP 作为普通 I/O 时, WKUP 引脚上的事件不能唤醒处在待机模式下的 CPU; 不当做普通 I/O 时, 才能唤醒 CPU。<br/>         0: 配置普通 I/O<br/>         1: 可唤醒 MCU<br/>         注意: 在系统复位时清除此位。</p>                                                                                                         |
| 9     | BKPREN  | R/W | <p>使能备份调压器 (Backup Regulator Enable)<br/>         0: 禁用<br/>         1: 使能</p>                                                                                                                                                                                                                                |
| 13:10 |         |     | 保留                                                                                                                                                                                                                                                                                                            |
| 14    | VOSRFLG | R   | <p>调压器输出分级电压就绪标志 (Regulator Voltage Scaling Output Selection Ready Flag)<br/>         0: 未就绪<br/>         1: 就绪</p>                                                                                                                                                                                           |
| 31:15 |         |     | 保留                                                                                                                                                                                                                                                                                                            |

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

### 8.1 术语全称、缩写描述

表格 44 术语全称、缩写描述

| 中文全称   | 英文全称                   | 英文缩写 |
|--------|------------------------|------|
| 不可屏蔽中断 | Non Maskable Interrupt | NMI  |

### 8.2 简介

产品中的 Cortex-M4F 内核集成了嵌套向量中断控制器 (Nested Vectored Interrupt Controller (NVIC)), 它和内核紧密耦合, 能高效、低延迟处理异常和中断、电源管理控制。更多关于 NVIC 的说明请参见《Cortex-M4F 技术参考手册》。

### 8.3 主要特征

- (1) 88 个可屏蔽中断通道 (不包括 16 个 Arm® Cortex®-M4F 中断线)
- (2) 低延时的异常和中断处理
- (3) 电源管理控制
- (4) 系统控制寄存器的实现

### 8.4 中断和异常向量表

表格 45 APM32F425xG\_F427xG 中断和异常向量表

| 异常类型          | 向量编号 | 优先级 | 向量地址                      | 描述             |
|---------------|------|-----|---------------------------|----------------|
| -             | -    | -   | 0x0000_0000               | 保留             |
| Reset         | -    | -3  | 0x0000_0004               | 复位             |
| NMI           | -    | -2  | 0x0000_0008               | 不可屏蔽中断         |
| HardFault     | -    | -1  | 0x0000_000C               | 各种硬件故障         |
| MemManage     | -    | 可设置 | 0x0000_0010               | 存储器管理          |
| BusFault      | -    | 可设置 | 0x0000_0014               | -              |
| UsageFault    | -    | 可设置 | 0x0000_0018               | -              |
| -             | -    | -   | 0x0000_001C 至 0x0000_002B | 保留             |
| SVCall        | -    | 可设置 | 0x0000_002C               | SWI 指令实现系统服务调用 |
| Debug Monitor | -    | 可设置 | 0x0000_0030               | 调试监控器          |

| 异常类型       | 向量编号 | 优先级 | 向量地址        | 描述                 |
|------------|------|-----|-------------|--------------------|
| -          | -    | -   | 0x0000_0034 | 保留                 |
| PendSV     | -    | 可设置 | 0x0000_0038 | 可挂起系统服务请求          |
| SysTick    | -    | 可设置 | 0x0000_003C | 系统节拍定时器            |
| WWDT       | 0    | 可设置 | 0x0000_0040 | 窗口看门狗中断            |
| PVD        | 1    | 可设置 | 0x0000_0044 | 电源电压通过 EINT 线检测中断  |
| TAMP_STAMP | 2    | 可设置 | 0x0000_0048 | 侵入和时间戳通过 EINT 线中断  |
| RTC_WKUP   | 3    | 可设置 | 0x0000_004C | RTC 通过 EINT 线 唤醒中断 |
| FLASH      | 4    | 可设置 | 0x0000_0050 | 闪存全局中断             |
| RCM        | 5    | 可设置 | 0x0000_0054 | RCM 中断             |
| EINT0      | 6    | 可设置 | 0x0000_0058 | EINT 线 0 中断        |
| EINT1      | 7    | 可设置 | 0x0000_005C | EINT 线 1 中断        |
| EINT2      | 8    | 可设置 | 0x0000_0060 | EINT 线 2 中断        |
| EINT3      | 9    | 可设置 | 0x0000_0064 | EINT 线 3 中断        |
| EINT4      | 10   | 可设置 | 0x0000_0068 | EINT 线 4 中断        |
| DMA1_STR0  | 11   | 可设置 | 0x0000_006C | DMA1 数据流 0 全局中断    |
| DMA1_STR1  | 12   | 可设置 | 0x0000_0070 | DMA1 数据流 1 全局中断    |
| DMA1_STR2  | 13   | 可设置 | 0x0000_0074 | DMA1 数据流 2 全局中断    |
| DMA1_STR3  | 14   | 可设置 | 0x0000_0078 | DMA1 数据流 3 全局中断    |
| DMA1_STR4  | 15   | 可设置 | 0x0000_007C | DMA1 数据流 4 全局中断    |
| DMA1_STR5  | 16   | 可设置 | 0x0000_0080 | DMA1 数据流 5 全局中断    |
| DMA1_STR6  | 17   | 可设置 | 0x0000_0084 | DMA1 数据流 6 全局中断    |
| ADC        | 18   | 可设置 | 0x0000_0088 | ADC1 和 ADC2 全局中断   |
| CAN1_TX    | 19   | 可设置 | 0x0000_008C | CAN1 发送中断          |
| CAN1_RX0   | 20   | 可设置 | 0x0000_0090 | CAN1 接收 0 中断       |
| CAN1_RX1   | 21   | 可设置 | 0x0000_0094 | CAN1 接收 1 中断       |
| CAN1_SCE   | 22   | 可设置 | 0x0000_0098 | CAN1 SCE 中断        |

| 异常类型                   | 向量编号 | 优先级 | 向量地址        | 描述                              |
|------------------------|------|-----|-------------|---------------------------------|
| EINT9_5                | 23   | 可设置 | 0x0000_009C | EINT 线[9:5]中断                   |
| TMR1_BRK_TMR9          | 24   | 可设置 | 0x0000_00A0 | TMR1 刹车中断<br>/TMR9 全局中断         |
| TMR1_UP_TMR10          | 25   | 可设置 | 0x0000_00A4 | TMR1 更新中断<br>/TMR10 全局中断        |
| TMR1_TRG_COM_T<br>MR11 | 26   | 可设置 | 0x0000_00A8 | TMR1 触发和通信<br>中断/TMR11 全局<br>中断 |
| TMR1_CC                | 27   | 可设置 | 0x0000_00AC | TMR1 捕获比较中<br>断                 |
| TMR2                   | 28   | 可设置 | 0x0000_00B0 | TMR2 中断                         |
| TMR3                   | 29   | 可设置 | 0x0000_00B4 | TMR3 中断                         |
| TMR4                   | 30   | 可设置 | 0x0000_00B8 | TMR4 中断                         |
| I2C1_EV                | 31   | 可设置 | 0x0000_00BC | I2C1 事件中断                       |
| I2C1_ER                | 32   | 可设置 | 0x0000_00C0 | I2C1 错误中断                       |
| I2C2_EV                | 33   | 可设置 | 0x0000_00C4 | I2C2 事件中断                       |
| I2C2_ER                | 34   | 可设置 | 0x0000_00C8 | I2C2 错误中断                       |
| SPI1                   | 35   | 可设置 | 0x0000_00CC | SPI1 中断                         |
| SPI2                   | 36   | 可设置 | 0x0000_00D0 | SPI2 中断                         |
| USART1                 | 37   | 可设置 | 0x0000_00D4 | USART1 中断                       |
| USART2                 | 38   | 可设置 | 0x0000_00D8 | USART2 中断                       |
| USART3                 | 39   | 可设置 | 0x0000_00DC | USART3 中断                       |
| EINT15_10              | 40   | 可设置 | 0x0000_00E0 | EINT 线[15:10]中断                 |
| RTC_Alarm              | 41   | 可设置 | 0x0000_00E4 | RTC 闹钟中断                        |
| OTG_FS1 WKUP           | 42   | 可设置 | 0x0000_00E8 | OTG_FS1 通过<br>EINT 线唤醒中断        |
| TMR8_BRK_TMR12         | 43   | 可设置 | 0x0000_00EC | TMR8 刹车中断<br>/TMR12 全局中断        |
| TMR8_UP_TMR13          | 44   | 可设置 | 0x0000_00F0 | TMR8 更新中断<br>/TMR13 全局中断        |
| TMR8_TRG_COM_T<br>MR14 | 45   | 可设置 | 0x0000_00F4 | TMR8 触发和通信<br>中断/TMR14 全局<br>中断 |
| TMR8_CC                | 46   | 可设置 | 0x0000_00F8 | TMR8 捕获比较中<br>断                 |
| DMA1_STR7              | 47   | 可设置 | 0x0000_00FC | DMA1 数据流 7 全<br>局中断             |

| 异常类型      | 向量编号 | 优先级 | 向量地址        | 描述                            |
|-----------|------|-----|-------------|-------------------------------|
| EMMC      | 48   | 可设置 | 0x0000_0100 | EMMC 中断                       |
| SDIO      | 49   | 可设置 | 0x0000_0104 | SDIO 中断                       |
| TMR5      | 50   | 可设置 | 0x0000_0108 | TMR5 中断                       |
| SPI3      | 51   | 可设置 | 0x0000_010C | SPI3 中断                       |
| UART4     | 52   | 可设置 | 0x0000_0110 | UART4 中断                      |
| UART5     | 53   | 可设置 | 0x0000_0114 | UART5 中断                      |
| TMR6_DAC  | 54   | 可设置 | 0x0000_0118 | TMR6 中断/DAC1 和 DAC2 欠载运行 错误中断 |
| TMR7      | 55   | 可设置 | 0x0000_011C | TMR7 中断                       |
| DMA2_STR0 | 56   | 可设置 | 0x0000_0120 | DMA2 数据流 0 中断                 |
| DMA2_STR1 | 57   | 可设置 | 0x0000_0124 | DMA2 数据流 1 中断                 |
| DMA2_STR2 | 58   | 可设置 | 0x0000_0128 | DMA2 数据流 2 中断                 |
| DMA2_STR3 | 59   | 可设置 | 0x0000_012C | DMA2 数据流 3 中断                 |
| DMA2_STR4 | 60   | 可设置 | 0x0000_0130 | DMA2 数据流 4 中断                 |
| ETH       | 61   | 可设置 | 0x0000_0134 | 以太网全局中断                       |
| ETH_WKUP  | 62   | 可设置 | 0x0000_0138 | 以太网通过 EINT 线唤醒中断              |
| CAN2_TX   | 63   | 可设置 | 0x0000_013C | CAN2 发送中断                     |
| CAN2_RX0  | 64   | 可设置 | 0x0000_0140 | CAN2 接收 0 中断                  |
| CAN2_RX1  | 65   | 可设置 | 0x0000_0144 | CAN2 接收 1 中断                  |
| CAN2_SCE  | 66   | 可设置 | 0x0000_0148 | CAN2 SCE 中断                   |
| OTG_FS1   | 67   | 可设置 | 0x0000_014C | OTG_FS1 全局中断                  |
| DMA2_STR5 | 68   | 可设置 | 0x0000_0150 | DMA2 数据流 5 中断                 |
| DMA2_STR6 | 69   | 可设置 | 0x0000_0154 | DMA2 数据流 6 中断                 |
| DMA2_STR7 | 70   | 可设置 | 0x0000_0158 | DMA2 数据流 7 中断                 |
| USART6    | 71   | 可设置 | 0x0000_015C | USART6 全局中断                   |
| I2C3_EV   | 72   | 可设置 | 0x0000_0160 | I2C3 事件中断                     |
| I2C3_ER   | 73   | 可设置 | 0x0000_0164 | I2C3 错误中断                     |

| 异常类型         | 向量编号  | 优先级 | 向量地址                         | 描述                       |
|--------------|-------|-----|------------------------------|--------------------------|
| -            | 74-79 | -   | 0x0000_0168 至<br>0x0000_017C | 保留                       |
| RNG          | 80    | 可设置 | 0x0000_0180                  | RNG 全局中断                 |
| FPU          | 81    | 可设置 | 0x0000_0184                  | FPU 全局中断                 |
| -            | 82-84 | 可设置 | 0x0000_0188 至<br>0x0000_0190 | 保留                       |
| OTG_FS2 WKUP | 85    | 可设置 | 0x0000_0194                  | OTG_FS2 通过<br>EINT 线唤醒中断 |
| OTG_FS2      | 86    | 可设置 | 0x0000_0198                  | OTG_FS2 全局中<br>断         |
| QSPI         | 87    | 可设置 | 0x0000_019C                  | QSPI 全局中断                |

## 9 外部中断/事件控制器 (EINT)

### 9.1 简介

中断/事件分为内部中断/事件、外部中断/事件。在该手册中，外部中断指从 I/O 引脚输入信号引起的中断/事件，在中断向量表中指 EINTx；其它中断指内部中断/事件。

事件可分为硬件事件、软件事件。硬件事件是通过外部/内核硬件信号产生事件，软件事件是通过指令产生事件。

中断需经过中断处理函数实现需要处理的工作。事件不需要经过中断处理函数，可硬件触发预先设置的工作。外部事件，例如可通过事件 GPIO 输出脉冲；内部事件，例如通过一个 TMR 的更新事件触发另一个 TMR 工作。

### 9.2 主要特征

- (1) 支持 23 个事件/中断请求
- (2) 每个事件/中断线都可独立屏蔽
- (3) 每个外部事件/中断线都可独立触发
- (4) 每个外部中断线都有专用的状态位
- (5) 检测脉冲宽度低于 APB2 时钟宽度的外部信号

### 9.3 功能描述

#### 9.3.1 “外部中断与事件”类别及差异点

“外部中断与事件”按照触发源、配置及执行过程，可分为：外部硬件中断、外部硬件事件、外部软件事件、外部软件中断，差异点见下表：

表格 46 “外部中断与事件”分类及差异点

| 名称     | 触发源  | 配置及执行过程                                                                                                                 |
|--------|------|-------------------------------------------------------------------------------------------------------------------------|
| 外部硬件中断 | 外部信号 | <p>(1) 设置触发方式，允许中断请求，使能对应外设中断线（在 NVIC 中使能）；</p> <p>(2) 当外部中断线上产生了和配置一致的边沿时，产生中断请求，对应的挂起位被置 1。在挂起寄存器对应位写 1，将清除该中断请求。</p> |
| 外部硬件事件 | 外部信号 | <p>(1) 设置触发方式，使能事件线；</p> <p>(2) 当外部事件线上产生了和配置一致的边沿时，产生 1 个事件请求脉冲，对应的挂起位不被置 1。</p>                                       |

| 名称     | 触发源                   | 配置及执行过程                                                                                                   |
|--------|-----------------------|-----------------------------------------------------------------------------------------------------------|
| 外部软件事件 | 软件中断寄存器/发送事件 (SEV) 指令 | (1) 使能事件线;<br>(2) 对应事件线的软件中断事件寄存器写 1, 产生 1 个事件请求脉冲, 对应的挂起位不被置 1。                                          |
| 外部软件中断 | 软件中断寄存器               | (1) 允许中断请求, 使能对应外设中断线 (在 NVIC 中使能);<br>(2) 对应中断线的软件中断事件寄存器写 1, 产生中断请求, 对应的挂起位被置 1。在挂起寄存器对应位写 1, 将清除该中断请求。 |

### 9.3.2 内核唤醒

使用 WFI、WFE 指令都可以使内核停止工作。使用 WFI 指令, 任一中断可唤醒内核; 使用 WFE 指令, 需通过事件唤醒。

使用中断唤醒, 会触发中断处理函数, 正常的中断配置即可唤醒内核。使用事件唤醒内核不触发中断处理函数, 会减少唤醒时间。

#### 9.3.2.1 事件唤醒

##### 触发内部中断 (内部硬件事件) 但不触发中断处理函数唤醒

- (1) 使能外设中的一个内部中断, 但不使能 NVIC 中对应的中断, 避免触发中断处理函数;
- (2) 在内核的系统控制器中使能 SEVONPEND 位, 执行 WFE 指令使内核进入睡眠;
- (3) 产生中断唤醒内核, 当内核从 WFE 恢复后, 需要清除相应外设的中断挂起位和外设 NVIC 中断通道挂起位 (在 NVIC 中断清除挂起寄存器中)。

##### 通过 EINT 线事件 (外部硬件事件) 唤醒

- (1) 配置 EINT 线为事件模式;
- (2) 执行 WFE 指令使内核进入睡眠;
- (3) 产生中断唤醒内核, CPU 从 WFE 恢复后, 因为对应事件线的挂起位没有被置位, 不必清除相应外设的中断挂起位或 NVIC 中断通道挂起位。

### 9.3.3 外部中断与事件线映射

表格 47 外部中断与事件线映射

| 外部中断与事件通道名称                   | 外部中断与事件线编号 |
|-------------------------------|------------|
| PA0/PB0/PC0/PE0/PF0/PG0/PH0   | EINT 0     |
| PA1/PB1/PC1/PE1/PF1/PG1/PH1   | EINT 1     |
| ...                           | ...        |
| PA15/PB15/PC15/PE15/PF15/PG15 | EINT 15    |
| PVD 输出                        | EINT 16    |

| 外部中断与事件通道名称  | 外部中断与事件线编号 |
|--------------|------------|
| RTC Alarm 事件 | EINT 17    |
| OTG_FS1 唤醒事件 | EINT 18    |
| 以太网唤醒事件      | EINT 19    |
| OTG_FS2 唤醒事件 | EINT 20    |
| RTC 侵入和时间戳事件 | EINT 21    |
| RTC 唤醒事件     | EINT 22    |
| 保留           | EINT 23    |
| 保留           | EINT 24    |
| 保留           | EINT 25    |
| 保留           | EINT 26    |
| 保留           | EINT 27    |
| 保留           | EINT 28    |
| 保留           | EINT 29    |
| 保留           | EINT 30    |
| 保留           | EINT 31    |

## 9.4 寄存器地址映射

表格 48 EINT 寄存器地址映射

| 寄存器名        | 描述         | 偏移地址 |
|-------------|------------|------|
| EINT_IMASK  | 中断屏蔽寄存器    | 0x00 |
| EINT_EMASK  | 事件屏蔽寄存器    | 0x04 |
| EINT_RTEN   | 使能上升沿触发寄存器 | 0x08 |
| EINT_FTEN   | 使能下降沿触发寄存器 | 0x0C |
| EINT_SWINTE | 软件中断事件寄存器  | 0x10 |
| EINT_IPEND  | 中断挂起寄存器    | 0x14 |

## 9.5 寄存器功能描述

### 9.5.1 中断屏蔽寄存器 (EINT\_IMASK)

偏移地址: 0x00

复位值: 0x0000 0000

| 位/域   | 名称     | R/W | 描述                                                                         |
|-------|--------|-----|----------------------------------------------------------------------------|
| 22:0  | IMASKx | R/W | 屏蔽线 x 上的中断请求 (Interrupt Request Mask on Line x) (x=0~22)<br>0: 屏蔽<br>1: 开放 |
| 31:23 |        |     | 保留                                                                         |

### 9.5.2 事件屏蔽寄存器 (EINT\_EMASK)

偏移地址: 0x04

复位值: 0x0000 0000

| 位/域   | 名称     | R/W | 描述                                                                     |
|-------|--------|-----|------------------------------------------------------------------------|
| 22:0  | EMASKx | R/W | 屏蔽线 x 上的事件请求 (Event Request Mask on Line x) (x=0~22)<br>0: 屏蔽<br>1: 开放 |
| 31:23 |        |     | 保留                                                                     |

### 9.5.3 使能上升沿触发寄存器 (EINT\_RTEN)

偏移地址: 0x08

复位值: 0x0000 0000

| 位/域   | 名称    | R/W | 描述                                                                                                  |
|-------|-------|-----|-----------------------------------------------------------------------------------------------------|
| 22:0  | RTENx | R/W | 使能线 x 上的上升沿触发事件和中断 (Rising Trigger Event and Interrupt Enable of Line x) (x=0~22)<br>0: 禁用<br>1: 使能 |
| 31:23 |       |     | 保留                                                                                                  |

注意: 由于外部唤醒线是边沿触发, 所以这些线上不能有毛刺信号。在写 EINT\_RTEN 寄存器时, 若上升沿信号在外部中断线上则不能被识别, 置位挂起位也不会置位。在同一中断线上, 上升沿触发和下降沿触发可以同时被设置。

### 9.5.4 使能下降沿触发寄存器 (EINT\_FTEN)

偏移地址: 0x0C

复位值: 0x0000 0000

| 位/域   | 名称    | R/W | 描述                                                                                                   |
|-------|-------|-----|------------------------------------------------------------------------------------------------------|
| 22:0  | FTENx | R/W | 使能线 x 上的下降沿触发事件和中断 (Falling Trigger Event and Interrupt Enable of Line x) (x=0~22)<br>0: 禁用<br>1: 使能 |
| 31:23 |       |     | 保留                                                                                                   |

注意: 由于外部唤醒线是边沿触发, 所以这些线上不能有毛刺信号; 在写 EINT\_FTEN 寄存器时, 若上升沿信号在外部中断线上则不能被识别, 置位挂起位也不会置位; 在同一中断线上, 上升沿触发和下降沿触发可以同时被设置。

### 9.5.5 软件中断事件寄存器 (EINT\_SWINTE)

偏移地址: 0x10

复位值: 0x0000 0000

| 位/域   | 名称                   | R/W | 描述                                                                                                                                                                                                                        |
|-------|----------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 22:0  | SWINTEX <sub>x</sub> | R/W | 线 x 上的软件中断 (Software Interrupt Event on Line x) (x=0~22)<br>软件置 1, 对 EINT_IPEND 的对应位写入 1 清 0。<br>当该位为 0 时, 写 1 将置位 EINT_IPEND 的挂起位。若置位 EINT_IMASK (EINT_EMASK) 开放中断 (事件) 请求, 则此时将产生一个中断 (事件)。<br>0: 无作用<br>1: 软件产生中断 (事件) |
| 31:23 |                      |     | 保留                                                                                                                                                                                                                        |

### 9.5.6 中断挂起寄存器 (EINT\_IPEND)

偏移地址: 0x14

复位值: 0xXXXX XXXX

| 位/域   | 名称                 | R/W   | 描述                                                                                                                                                       |
|-------|--------------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 22:0  | IPEND <sub>x</sub> | RC_W1 | 发生线 x 上的中断挂起标志 (Interrupt Pending Occur of Line x Flag) (x=0~22)<br>当在外部中断线上发生了 EINT_RTEN/EINT_FTEN 对应的边沿触发请求时, 由硬件置 1; 可通过改变边沿检测的极性清 0, 或通过向该位写入 1 清 0。 |
| 31:23 |                    |       | 保留                                                                                                                                                       |

## 10 直接存储访问 (DMA)

### 10.1 简介

DMA (Direct Memory Access: 直接存储器访问) 在无须 CPU 干预的情况下，可实现外设与存储器或存储器与存储器之间数据的高速传输，从而节省 CPU 资源来做其他操作。

产品一共有两个 DMA 控制器，共 16 个数据流。每个数据流对应 8 个通道，但每个数据流同一时刻只能使用 1 个通道。每个数据流可设置优先级，仲裁器可根据数据流的优先级协调各个数据流对应的 DMA 请求的优先级。

### 10.2 主要特征

- (1) 两个 DMA，每个 DMA 有 8 个数据流，每个数据流有 8 个通道
- (2) 双 AHB 主接口，一个为存储器接口，一个为外设接口
- (3) 数据传输有三种：外设到存储器、存储器到外设、存储器到存储器
- (4) 每个数据流都有连接专门的硬件 DMA 请求
- (5) 多个请求同时发生时支持软件优先级和硬件优先级
- (6) 每个数据流都有 5 个事件标志和独立中断
- (7) 支持循环传输模式
- (8) 数据传输数目可编程，最大到 65535
- (9) 可配置源和目标的传输宽度为字节、半字或字
- (10) 支持源和目标增量模式
- (11) 可配置突发增量大小为单次、4 个、8 个或 16 个节拍

### 10.3 功能描述

#### 10.3.1 DMA 请求

若外设或存储器需要使用 DMA 传输数据，就必须先发送 DMA 请求，等待 DMA 同意之后才开始数据传输。

两个 DMA 一共有 16 个数据流，每个数据流都连接着不同的外设通道，每个数据流都有 5 个事件标志 (DMA 半传输、DMA 传输完成、DMA 传输出错、DMA FIFO 错误、直接模式错误)。

表格 49 DMA1 请求映射表

| 外设请求 | 数据流 0               | 数据流 1                 | 数据流 2               | 数据流 3                 | 数据流 4                 | 数据流 5     | 数据流 6                | 数据流 7               |
|------|---------------------|-----------------------|---------------------|-----------------------|-----------------------|-----------|----------------------|---------------------|
| 通道 0 | SPI3_RX             | -                     | SPI3_RX             | SPI2_RX               | SPI2_TX               | SPI3_TX   | -                    | SPI3_TX             |
| 通道 1 | I2C1_RX             | -                     | TMR7_UP             | -                     | TMR7_UP               | I2C1_RX   | I2C1_TX              | I2C1_TX             |
| 通道 2 | TMR4_CH1            | -                     | -                   | TMR4_CH2              | -                     | -         | TMR4_UP              | TMR4_CH3            |
| 通道 3 | -                   | TMR2_UP<br>TMR2_CH3   | I2C3_RX             | -                     | I2C3_TX               | TMR2_CH1  | TMR2_CH2<br>TMR2_CH4 | TMR2_UP<br>TMR2_CH4 |
| 通道 4 | UART5_RX            | USART3_RX             | UART4_RX            | USART3_TX             | UART4_TX              | USART2_RX | USART2_TX            | UART5_TX            |
| 通道 5 | -                   | -                     | TMR3_CH4<br>TMR3_UP | -                     | TMR3_CH1<br>TMR3_TRIG | TMR3_CH2  | -                    | TMR3_CH3            |
| 通道 6 | TMR5_CH3<br>TMR5_UP | TMR5_CH4<br>TMR5_TRIG | TMR5_CH1            | TMR5_CH4<br>TMR5_TRIG | TMR5_CH2              | -         | TMR5_UP              | -                   |
| 通道 7 | -                   | TMR6_UP               | I2C2_RX             | I2C2_RX               | USART3_TX             | DAC1      | DAC2                 | I2C2_TX             |

表格 50 DMA2 请求映射表

| 外设请求 | 数据流 0     | 数据流 1     | 数据流 2                            | 数据流 3    | 数据流 4                             | 数据流 5     | 数据流 6                            | 数据流 7                             |
|------|-----------|-----------|----------------------------------|----------|-----------------------------------|-----------|----------------------------------|-----------------------------------|
| 通道 0 | ADC1      | -         | TMR8_CH1<br>TMR8_CH2<br>TMR8_CH3 | -        | ADC1                              | -         | TMR1_CH1<br>TMR1_CH2<br>TMR1_CH3 | -                                 |
| 通道 1 | -         | -         | ADC2                             | ADC2     | -                                 | -         | -                                | -                                 |
| 通道 2 | ADC3      | ADC3      | -                                | -        | -                                 | -         | -                                | -                                 |
| 通道 3 | SPI1_RX   | -         | SPI1_RX                          | SPI1_TX  | QSPI_RX                           | SPI1_TX   | -                                | QSPI_TX                           |
| 通道 4 | -         | -         | USART1_RX                        | SDIO     | -                                 | USART1_RX | SDIO                             | USART1_TX                         |
| 通道 5 | -         | USART6_RX | USART6_RX                        | -        | -                                 | -         | USART6_TX                        | USART6_TX                         |
| 通道 6 | TMR1_TRIG | TMR1_CH1  | TMR1_CH2                         | TMR1_CH1 | TMR1_CH4<br>TMR1_TRIG<br>TMR1_COM | TMR1_UP   | TMR1_CH3                         | -                                 |
| 通道 7 | -         | TMR8_UP   | TMR8_CH1                         | TMR8_CH2 | TMR8_CH3                          | -         | -                                | TMR8_CH4<br>TMR8_TRIG<br>TMR8_COM |

### 10.3.2 仲裁器

发生多个 DMA 通道请求时，需要用到仲裁器来管理先后响应的顺序。管理分两个阶段：第一阶段软件阶段分为最高、高、中等和低四个优先级；第二阶段硬件阶段，在软件优先级相同的情况下，数据流编号越低优先级越高。

### 10.3.3 FIFO

FIFO 用来在源数据传输到目标地址之前临时存放数据，每个数据流都有 1 个独立的 4 字 FIFO，可通过软件来控制 FIFO 阈值为 1/4、1/2、3/4 或满。

DMA 传输模式有两种：

- 第一种为直接模式，在每个外设请求后都立即启动对存储器的单次传输，若 DMA 配置为存储器到外设传输数据，DMA 会将一个数据存放在 FIFO 内，一旦外设触发 DMA 请求，就将数据发送过去。直接模式需要将源和目标地址的数据宽度配置相同，不支持突发模式，不支持存储器到存储器的传输方式。
- 第二种为 FIFO 模式，先配置 FIFO 阈值，当数据存储量达到阈值时，将 FIFO 内容传输到目标，FIFO 模式适用于在源地址和目标地址数据宽度不同时使用，支持突发模式，FIFO 可将数据先存放起来，然后根据需求输出数据。

### 10.3.4 端口

DMA 控制器通过存储器端口和外设端口与存储器和外设进行数据传输，DMA2 的存储器端口和外设端口都连接在 AHB 矩阵总线上。DMA2 存储器和外设可以访问内部 Flash，内部 SRAM，AHB1 外设、APB1 外设、APB2 外设、AHB2 外设和外部存储器。DMA1 的存储器端口比 DMA2 减少了 AHB2 外设的访问权，DMA1 的外设端口只连接到 APB1 外设，所以 DMA1 不能实现存储器到存储器的传输。

### 10.3.5 DMA 初始化参数配置

#### 10.3.5.1 传输模式

DMA2 支持外设到存储器、存储器到外设和存储器到存储器三种传输模式，DMA1 支持外设到存储器和存储器到外设两种传输模式。

传输模式可通过 DMA\_SCFG 寄存器的 DIRCFG 位控制。

#### 10.3.5.2 递增模式

通过 DMA\_SCFG 寄存器的 PERIM 和 MEMIM 位控制外设和存储器的递增模式，当两个位都置 1 时，配置为递增模式，增量为 DMA\_SCFG 寄存器 PERSIZECFG 和 MENSIZECFG 位的值。PERSIZECFG 和 MENSIZECFG 位用来设置外设和存储器的数据大小为字节、半字和字。

#### 10.3.5.3 单次传输和突发模式

突发传输是指在传输阶段增大每次传输的数据量以此来提高传输速度的高速传

输，突发传输过程中要占用 AHB 总线。

单次和突发传输可通过 DMA\_SCFG 寄存器的 PBCFG 和 MBCFG 位来控制，可配置为单次传输、4 个节拍的增量突发传输、8 个节拍的增量突发传输、16 个节拍的增量突发传输。该增量由 PERSIZECFG 和 MENSIZECFG 位的值决定。仅在支持递增模式的前提下才能使能突发模式。

突发模式需结合 FIFO 使用，FIFO 阈值选择必须适合存储器的突发大小，具体如下表所示。

表格 51 FIFO 阈值配置

| MENSIZECFG | FIFO 阈值 | MBCFG=01     | MBCFG=10     | MBCFG=11      |
|------------|---------|--------------|--------------|---------------|
| 字节         | 1/4     | 4 个节拍的 1 次突发 | 禁止           | 禁止            |
|            | 1/2     | 4 个节拍的 2 次突发 | 8 个节拍的 1 次突发 |               |
|            | 3/4     | 4 个节拍的 3 次突发 | 禁止           |               |
|            | 满       | 4 个节拍的 4 次突发 | 8 个节拍的 2 次突发 | 16 个节拍的 1 次突发 |
| 半字         | 1/4     | 禁止           | 禁止           | 禁止            |
|            | 1/2     | 4 个节拍的 1 次突发 |              |               |
|            | 3/4     | 禁止           |              |               |
|            | 满       | 4 个节拍的 2 次突发 | 8 个节拍的 1 次突发 |               |
| 字          | 1/4     | 禁止           | 禁止           | 禁止            |
|            | 1/2     |              |              |               |
|            | 3/4     |              |              |               |
|            | 满       | 4 个节拍的 1 次突发 |              |               |

#### 10.3.5.4 循环模式

循环模式用来处理循环缓冲区和连续的数据流，循环模式会在传输结束后将数据项数目自动的配置为初始值，继续进行数据的传输。

循环模式可通过 DMA\_SCFG 寄存器的 CIRCMEN 位控制。

#### 10.3.5.5 双缓冲区模式

设置 DMA\_SCFG 寄存器的 DBM 置 1 可开启双缓冲区模式，并自动激活循环模式，在双缓冲区模式下，DMA\_M1ADDR 寄存器被激活。当传输完 DMA\_M0ADDR 寄存器地址指针所对应的存储区后，将切换至 DMA\_M1ADDR 寄存器地址指针所对应的存储区继续传输，一直循环调用。当 DMA 在访问 DMA\_M1ADDR 时，DMA\_SCFG 寄存器的 CTARG 位置 1，同时可向 DMA\_M0ADDR 寄存器写或读数据。

该模式不支持存储器到存储器传输。

### 10.3.5.6 流控制器

流控制器可通过 DMA\_SCFG 寄存器的 PERFC 位配置为 DMA 或外设。

DMA 作为流控制器时，在使能数据流前配置 DMA\_NDATA 寄存器，设置要传输的数据项数目。

外设作为流控制器时，传输数据项数目未知，硬件强制将 DMA\_NDATA 寄存器的值置为 0xFFFF 执行，完成传输后，外设通过硬件向 DMA 发出指令，然后读取寄存器的值。传输的数据数目=0xFFFF-DMA\_NDATA。

在外设作为流控制器时禁止循环模式，选择存储器到存储器模式时，PERFC 位由硬件强制清零，只能选择 DMA 作为流控制器。

### 10.3.6 中断

每个数据流都有 5 种类型的中断事件，分别是半传输、传输完成、传输错误、FIFO 错误和直接模式错误。

表格 52 DMA 中断请求

| 中断事件    | 事件标志位    | 使能中断位  |
|---------|----------|--------|
| 半传输     | HTXIFLGx | HTXIEN |
| 传输完成    | TXCIFLGx | TXCIEN |
| 传输错误    | TXEIFLGx | TXEIEN |
| FIFO 错误 | FEIFLGx  | FEIEN  |
| 直接模式错误  | DMEIFLGx | DMEIEN |

## 10.4 DMA 寄存器地址映射

表格 53 DMA 寄存器地址映射

| 寄存器名        | 描述                    | 偏移地址              |
|-------------|-----------------------|-------------------|
| DMA_LINTSTS | DMA 低中断状态寄存器          | 0x00              |
| DMA_HINTSTS | DMA 高中断状态寄存器          | 0x04              |
| DMA_LIFCLR  | DMA 低中断标志清零寄存器        | 0x08              |
| DMA_HIFCLR  | DMA 高中断标志清零寄存器        | 0x0C              |
| DMA_SCFG    | DMA 数据流 x 配置寄存器       | 0x10+0x18×(数据流编号) |
| DMA_NDATA   | DMA 数据流 x 数据项数寄存器     | 0x14+0x18×(数据流编号) |
| DMA_PADDR   | DMA 数据流 x 外设地址寄存器     | 0x18+0x18×(数据流编号) |
| DMA_M0ADDR  | DMA 数据流 x 存储器 0 地址寄存器 | 0x1C+0x18×(数据流编号) |
| DMA_M1ADDR  | DMA 数据流 x 存储器 1 地址寄存器 | 0x20+0x18×(数据流编号) |
| DMA_FCTRL   | DMA 数据流 x FIFO 控制寄存器  | 0x24+0x18×(数据流编号) |

## 10.5 寄存器功能描述

### 10.5.1 DMA 低中断状态寄存器 (DMA\_LINTSTS)

偏移地址: 0x00

复位值: 0x0000 0000

| 位/域         | 名称                   | R/W | 描述                                                                                                                                                 |
|-------------|----------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------|
| 22、16、6、0   | FEIFLG <sub>x</sub>  | R   | 数据流 xFIFO 错误中断标志 (x=0...3) (Stream x FIFO Error Interrupt Flag)<br>这些位由硬件置 1, 软件在 DMA_LIFCLR 寄存器的相应位上写 1 清 0。<br>0: 无 FIFO 错误事件<br>1: 产生 FIFO 错误事件 |
| 23、17、7、1   | 保留                   |     |                                                                                                                                                    |
| 24、18、8、2   | DMEIFLG <sub>x</sub> | R   | 数据流 x 直接模式错误中断标志 (x=0...3) ((Stream x Direct Mode Error Interrupt Flag)<br>这些位由硬件置 1, 软件在 DMA_LIFCLR 寄存器的相应位上写 1 清 0。<br>0: 无直接模式错误<br>1: 产生直接模式错误 |
| 25、19、9、3   | TXEIFLG <sub>x</sub> | R   | 数据流 x 传输错误中断标志 (x=0...3) (Stream x Transfer Error Interrupt Flag)<br>这些位由硬件置 1, 软件在 DMA_LIFCLR 寄存器的相应位上写 1 清 0。<br>0: 无传输错误<br>1: 产生传输错误           |
| 26、20、10、4  | HTXIFLG <sub>x</sub> | R   | 数据流 x 半传输中断标志 (x=0...3) (Stream x Half Transfer Interrupt Flag)<br>这些位由硬件置 1, 软件在 DMA_LIFCLR 寄存器的相应位上写 1 清 0。<br>0: 无半传输事件<br>1: 产生半传输事件           |
| 27、21、11、5  | TXCIFLG <sub>x</sub> | R   | 数据流 x 传输完成标志 (x=0...3) (Stream x Transfer Complete Interrupt Flag)<br>这些位由硬件置 1, 软件在 DMA_LIFCLR 寄存器的相应位上写 1 清 0。<br>0: 无传输完成事件<br>1: 产生传输完成事件      |
| 31:28、15:12 | 保留                   |     |                                                                                                                                                    |

### 10.5.2 DMA 高中断状态寄存器 (DMA\_HINTSTS)

偏移地址: 0x04

复位值: 0x0000 0000

| 位/域         | 名称       | R/W | 描述                                                                                                                                                 |
|-------------|----------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------|
| 22、16、6、0   | FEIFLGx  | R   | 数据流 xFIFO 错误中断标志 (x=4...7) (Stream x FIFO Error Interrupt Flag)<br>这些位由硬件置 1, 软件在 DMA_HIFCLR 寄存器的相应位上写 1 清 0。<br>0: 无 FIFO 错误事件<br>1: 产生 FIFO 错误事件 |
| 23、17、7、1   | 保留       |     |                                                                                                                                                    |
| 24、18、8、2   | DMEIFLGx | R   | 数据流 x 直接模式错误中断标志 (x=4...7) ((Stream x Direct Mode Error Interrupt Flag)<br>这些位由硬件置 1, 软件在 DMA_HIFCLR 寄存器的相应位上写 1 清 0。<br>0: 无直接模式错误<br>1: 产生直接模式错误 |
| 25、19、9、3   | TXEIFLGx | R   | 数据流 x 传输错误中断标志(x=4...7)(Stream x Transfer Error Interrupt Flag)<br>这些位由硬件置 1, 软件在 DMA_HIFCLR 寄存器的相应位上写 1 清 0。<br>0: 无传输错误<br>1: 产生传输错误             |
| 26、20、10、4  | HTXIFLGx | R   | 数据流 x 半传输中断标志 (x=4...7) (Stream x Half Transfer Interrupt Flag)<br>这些位由硬件置 1, 软件在 DMA_HIFCLR 寄存器的相应位上写 1 清 0。<br>0: 无半传输事件<br>1: 产生半传输事件           |
| 27、21、11、5  | TXCIFLGx | R   | 数据流 x 传输完成标志(x=4...7)(Stream x Transfer Complete Interrupt Flag)<br>这些位由硬件置 1, 软件在 DMA_HIFCLR 寄存器的相应位上写 1 清 0。<br>0: 无传输完成事件<br>1: 产生传输完成事件        |
| 31:28、15:12 | 保留       |     |                                                                                                                                                    |

### 10.5.3 DMA 低中断标志清零寄存器 (DMA\_LIFCLR)

偏移地址: 0x08

复位值: 0x0000 0000

| 位/域       | 名称        | R/W | 描述                                                                                                                               |
|-----------|-----------|-----|----------------------------------------------------------------------------------------------------------------------------------|
| 22、16、6、0 | CFEIFLGx  | W   | 数据流 xFIFO 错误中断标志清零(x=0...3)(Stream x Clear FIFO Error Interrupt Flag)<br>0: 无效<br>1: DMA_LINTSTS 寄存器中相应的 FEIFLGx 标志清零            |
| 23、17、7、1 | 保留        |     |                                                                                                                                  |
| 24、18、8、2 | CDMEIFLGx | W   | 数据流 x 直接模式错误中断标志清零 (x=0...3) ((Stream x Clear Direct Mode Error Interrupt Flag)<br>0: 无效<br>1: DMA_LINTSTS 寄存器中相应的 DMEIFLGx 标志清零 |

| 位/域         | 名称        | R/W | 描述                                                                                                                        |
|-------------|-----------|-----|---------------------------------------------------------------------------------------------------------------------------|
| 25、19、9、3   | CTXEIFLGx | W   | 数据流 x 传输错误中断标志清零(x=0...3)(Stream x Clear Transfer Error Interrupt Flag)<br>0: 无效<br>1: DMA_LINTSTS 寄存器中相应的 TXEIFLGx 标志清零  |
| 26、20、10、4  | CHTXIFLGx | W   | 数据流 x 半传输中断标志清零(x=0...3)(Stream x Clear Half Transfer Interrupt Flag)<br>0: 无效<br>1: DMA_LINTSTS 寄存器中相应的 HTXIFLGx 标志清零    |
| 27、21、11、5  | CTXCIFLGx | W   | 数据流 x 传输完成标志清零(x=0...3)(Stream x Clear Transfer Complete Interrupt Flag)<br>0: 无效<br>1: DMA_LINTSTS 寄存器中相应的 TXCIFLGx 标志清零 |
| 31:28、15:12 | 保留        |     |                                                                                                                           |

#### 10.5.4 DMA 高中断标志清零寄存器 (DMA\_HIFCLR)

偏移地址: 0x0C

复位值: 0x0000 0000

| 位/域         | 名称        | R/W | 描述                                                                                                                            |
|-------------|-----------|-----|-------------------------------------------------------------------------------------------------------------------------------|
| 22、16、6、0   | CFEIFLGx  | W   | 数据流 xFIFO 错误中断标志清零(x=4...7)(Stream x Clear FIFO Error Interrupt Flag)<br>0: 无效<br>1: DMA_HINTSTS 寄存器中相应的 FEIFLGx 标志清零         |
| 23、17、7、1   | 保留        |     |                                                                                                                               |
| 24、18、8、2   | CDMEIFLGx | W   | 数据流 x 直接模式错误中断标志清零(x=4...7)(Stream x Clear Direct Mode Error Interrupt Flag)<br>0: 无效<br>1: DMA_HINTSTS 寄存器中相应的 DMEIFLGx 标志清零 |
| 25、19、9、3   | CTXEIFLGx | W   | 数据流 x 传输错误中断标志清零(x=4...7)(Stream x Clear Transfer Error Interrupt Flag)<br>0: 无效<br>1: DMA_HINTSTS 寄存器中相应的 TXEIFLGx 标志清零      |
| 26、20、10、4  | CHTXIFLGx | W   | 数据流 x 半传输中断标志清零(x=4...7)(Stream x Clear Half Transfer Interrupt Flag)<br>0: 无效<br>1: DMA_HINTSTS 寄存器中相应的 HTXIFLGx 标志清零        |
| 27、21、11、5  | CTXCIFLGx | W   | 数据流 x 传输完成标志清零(x=4...7)(Stream x Clear Transfer Complete Interrupt Flag)<br>0: 无效<br>1: DMA_HINTSTS 寄存器中相应的 TXCIFLGx 标志清零     |
| 31:28、15:12 | 保留        |     |                                                                                                                               |

#### 10.5.5 DMA 数据流 x 配置寄存器 (DMA\_SCFG) (x=0...7)

偏移地址: 0x10+0x18×(数据流编号)

复位值: 0x0000 0000

| 位/域   | 名称         | R/W | 描述                                                                                                                                                                                                           |
|-------|------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | EN         | R/W | <p>使能数据流 (Stream Enable)</p> <p>0: 禁用<br/>1: 使能</p> <p>以下情况该位由硬件清 0:</p> <ol style="list-style-type: none"> <li>1. DMA 传输结束时</li> <li>2. AHB 主总线出现传输错误时</li> <li>3. 存储器 AHB 端口上的 FIFO 阈值与突发大小不兼容时</li> </ol> |
| 1     | DMEIEN     | R/W | <p>使能直接模式错误中断 (Direct Mode Error Interrupt Enable)</p> <p>0: 禁用<br/>1: 使能</p>                                                                                                                                |
| 2     | TXEIEN     | R/W | <p>使能传输错误中断 (Transfer Error Interrupt Enable)</p> <p>0: 禁用<br/>1: 使能</p>                                                                                                                                     |
| 3     | HTXIEN     | R/W | <p>使能半传输中断 (Half Transfer Interrupt Enable)</p> <p>0: 禁用<br/>1: 使能</p>                                                                                                                                       |
| 4     | TXCIEN     | R/W | <p>使能传输完成中断 (Transfer Complete Interrupt Enable)</p> <p>0: 禁用<br/>1: 使能</p>                                                                                                                                  |
| 5     | PERFC      | R/W | <p>外设流控制器 (Peripheral Flow Controller)</p> <p>0: DMA 为流控制器<br/>1: 外设为流控制器</p> <p>该位只有在 EN 位为 0 时才允许写入；选择存储器到存储器模式后，该位由硬件自动强制清零。</p>                                                                          |
| 7:6   | DIRCFG     | R/W | <p>配置数据传输方向 (Data Transfer Direction Configure)</p> <p>00: 外设到存储器<br/>01: 存储器到外设<br/>10: 存储器到存储器<br/>11: 保留</p> <p>这些位只有在 EN 位为 0 时才允许写入。</p>                                                                |
| 8     | CIRCMEN    | R/W | <p>使能循环模式 (Circular Mode Enable)</p> <p>该位由软件置 1 和清 0，也可由硬件清 0。</p> <p>0: 禁用<br/>1: 使能</p> <p>若设置外设为流控制器且使能数据流，该位由硬件自动强制清 0。<br/>若 DMA 传输结束时切换目标存储区且使能数据流，该位由硬件自动强制置 1。</p>                                  |
| 9     | PERIM      | R/W | <p>外设增量模式 (Memory Increment Mode)</p> <p>0: 外设地址指针固定<br/>1: 每次数据传输后，外设地址指针递增</p> <p>该位只有在 EN 位为 0 时才允许写入。</p>                                                                                                |
| 10    | MEMIM      | R/W | <p>存储器递增模式 (Memory Increment Mode)</p> <p>0: 存储器地址指针固定<br/>1: 每次数据传输后，存储器地址指针递增</p> <p>该位只有在 EN 位为 0 时才允许写入。</p>                                                                                             |
| 12:11 | PERSIZECFG | R/W | 配置外设数据大小 (Peripheral Data Size Configure)                                                                                                                                                                    |

| 位/域   | 名称         | R/W | 描述                                                                                                                                                                                                     |
|-------|------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |            |     | 00: 字节 (8 位)<br>01: 半字 (16 位)<br>10: 字 (32 位)<br>11: 保留<br>这些位只有在 EN 位为 0 时才允许写入。                                                                                                                      |
| 14:13 | MEMSIZECFG | R/W | 配置存储器数据大小 (Memory Data Size Configure)<br>00: 字节 (8 位)<br>01: 半字 (16 位)<br>10: 字 (32 位)<br>11: 保留<br>这些位只有在 EN 位为 0 时才允许写入。<br>在直接模式下, 当 EN 位为 1 时, MEMSIZECFG 位由硬件强制置为与 PERSIZECFG 位相同的值。             |
| 15    | PERIOSIZE  | R/W | 外设增量偏移量 (Peripheral increment offset size)<br>0: 用于计算外设地址的偏移量与 PERSIZECFG 相关<br>1: 用于计算外设地址的偏移量固定为 4<br>若位 PERIM 为 0, 此位无意义, 该位只有在 EN 位为 0 时才允许写入。<br>若选择直接模式或位 PBCFG 不配置为 00, 且当使能数据流时, 该位由硬件强制置为低电平。 |
| 17:16 | PRILCFG    | R/W | 配置优先级 (Priority Level Configure)<br>00: 低<br>01: 中<br>10: 高<br>11: 非常高<br>这些位只有在 EN 位为 0 时才允许写入。                                                                                                       |
| 18    | DBM        | R/W | 双缓冲区模式 (Double Buffer Mode)<br>0: 传输结束时不切换缓冲区<br>1: DMA 传输结束时切换目标存储器<br>该位只有在 EN 位为 0 时才允许写入。                                                                                                          |
| 19    | CTARG      | R/W | 当前目标 (仅在双缓冲区模式下) (Current Target (only in double buffer mode))<br>该位由硬件置 1 和清 0, 也可由软件写入。<br>0: 当前目标存储器为存储器 0<br>1: 当前目标存储器为存储器 1                                                                      |
| 20    |            |     | 保留                                                                                                                                                                                                     |
| 22:21 | PBCFG      | R/W | 配置外设突发传输 (Peripheral Burst Transfer Configure)<br>00: 单次传输<br>01: INCR4 (4 个节拍的增量突发传输)<br>10: INCR8 (8 个节拍的增量突发传输)<br>11: INCR16 (16 个节拍的增量突发传输)<br>该位只有在 EN 位为 0 时才允许写入。<br>在直接模式下, 这些位强制清 0。         |
| 24:23 | MBCFG      | R/W | 配置存储器突发传输 (Memory Burst Transfer Configure)<br>00: 单次传输<br>01: INCR4 (4 个节拍的增量突发传输)                                                                                                                    |

| 位/域   | 名称    | R/W | 描述                                                                                                                                               |
|-------|-------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------|
|       |       |     | 10: INCR8 (8个节拍的增量突发传输)<br>11: INCR16 (16个节拍的增量突发传输)<br>该位只有在 EN 位为 0 时才允许写入。<br>在直接模式下, 这些位强制清 0。                                               |
| 27:25 | CHSEL | R/W | 选择通道 (Channel Selection)<br>000: 选择通道 0<br>001: 选择通道 1<br>010: 选择通道 2<br>011: 选择通道 3<br>100: 选择通道 4<br>101: 选择通道 5<br>110: 选择通道 6<br>111: 选择通道 7 |
| 31:28 |       |     | 保留                                                                                                                                               |

#### 10.5.6 DMA 数据流 x 数据项数寄存器 (DMA\_NDATA) (x=0...7)

偏移地址: 0x14+0x18× (数据流编号)

复位值: 0x0000 0000

| 位/域   | 名称    | R/W | 描述                                                                                                                                                                                                           |
|-------|-------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0  | NDATA | R/W | 传输的数据项数目 (Number of Data Items to Transfer)<br>传输的数据项数目为 0~65535, 只有禁止数据流时, 才允许对此寄存器进行操作, 使能数据流后, 该寄存器为只读, 用来指示要传输的剩余数据项数目。每次 DMA 传输后, 该寄存器递减。<br>传输完成后此寄存器为 0, 以下情况会自动重载初始值:<br>1. 以循环模式配置数据流<br>2. 重新使能数据流 |
| 31:16 |       |     | 保留                                                                                                                                                                                                           |

#### 10.5.7 DMA 数据流 x 外设地址寄存器 (DMA\_PADDR) (x=0...7)

偏移地址: 0x18+0x18× (数据流编号)

复位值: 0x0000 0000

| 位/域  | 名称    | R/W | 描述                                                                      |
|------|-------|-----|-------------------------------------------------------------------------|
| 31:0 | PADDR | R/W | 外设地址 (Peripheral Address)<br>读/写数据的外设数据寄存器的基址。<br>该位只有在 EN 位为 0 时才允许写入。 |

#### 10.5.8 DMA 数据流 x 存储器 0 地址寄存器 (DMA\_M0ADDR) (x=0...7)

偏移地址: 0x1C+0x18× (数据流编号)

复位值: 0x0000 0000

| 位/域  | 名称     | R/W | 描述                                                                                                                                                                          |
|------|--------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | M0ADDR | R/W | 存储器 0 地址 (Memory 0 Address)<br>读/写数据的存储器 0 的基址。<br>这些位受到写保护, 只有在以下情况才能写入: <ul style="list-style-type: none"><li>● 禁止数据流</li><li>● 使能数据流且 DMA_SCFG 寄存器的 CTARG 位置 1</li></ul> |

### 10.5.9 DMA 数据流 x 存储器 1 地址寄存器 (DMA\_M1ADDR) (x=0...7)

偏移地址: 0x20+0x18× (数据流编号)

复位值: 0x0000 0000

| 位/域  | 名称     | R/W | 描述                                                                                                                                                                                                                                          |
|------|--------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | M1ADDR | R/W | <p>存储器 1 地址 (Memory 1 Address)<br/>           读/写数据的存储器 1 的基址。<br/>           该寄存器仅适用于双缓冲模式。<br/>           这些位受到写保护, 只有在以下情况才能写入:</p> <ul style="list-style-type: none"> <li>● 禁止数据流</li> <li>● 使能数据流且 DMA_SCFG 寄存器的 CTARG 位清 0</li> </ul> |

### 10.5.10 DMA 数据流 xFIFO 控制寄存器 (DMA\_FCTRL) (x=0...7)

偏移地址: 0x24+0x18× (数据流编号)

复位值: 0x0000 0000

| 位/域  | 名称     | R/W | 描述                                                                                                                                                                                                                                                                                                                      |
|------|--------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0  | FTHSEL | R/W | <p>选择 FIFO 阈值 (FIFO Threshold Select)<br/>           00: FIFO 容量的 1/4<br/>           01: FIFO 容量的 1/2<br/>           10: FIFO 容量的 3/4<br/>           11: FIFO 完整容量<br/>           在直接模式下, 这些位无效, 该位只有在 EN 位为 1 时才允许写入。</p>                                                                                              |
| 2    | DMDEN  | R/W | <p>禁止直接模式 (Direct Mode Disable)<br/>           0: 使能直接模式<br/>           1: 禁止直接模式<br/>           该位只有在 EN 位为 0 时才允许写入; 选择存储器到存储器模式且 EN 位为 1 时, 该位由硬件置 1。</p>                                                                                                                                                            |
| 5:3  | FSTS   | R   | <p>FIFO 状态 (FIFO Status)<br/>           000: 0&lt;fifo_level&lt;1/4<br/>           001: 1/4&lt;fifo_level&lt;1/2<br/>           010: 1/2&lt;fifo_level&lt;3/4<br/>           011: 3/4&lt;fifo_level&lt;满<br/>           100: FIFO 空<br/>           101: FIFO 满<br/>           其他: 无意义<br/>           在直接模式下, 这些位无效。</p> |
| 6    |        |     | 保留                                                                                                                                                                                                                                                                                                                      |
| 7    | FEIEN  | R/W | <p>使能 FIFO 错误中断 (FIFO Error Interrupt Enable)<br/>           0: 禁用<br/>           1: 使能</p>                                                                                                                                                                                                                             |
| 31:8 |        |     | 保留                                                                                                                                                                                                                                                                                                                      |

## 11 调试 MCU (DBGMCU)

### 11.1 术语全称、缩写描述

表格 54 术语全称、缩写描述

| 中文全称         | 英文全称                        | 英文缩写   |
|--------------|-----------------------------|--------|
| 内核自由运行时钟     | Free Clock                  | FCLK   |
| 串行/JTAG 调试端口 | Serial Wire/JTAG Debug Port | SWJ-DP |

### 11.2 简介

APM32F425xG\_F427xG 微控制器系列使用 Arm® Cortex®-M4F 内核，Arm® Cortex®-M4F 内核内含硬件调试模块，支持复杂的调试操作。在调试时该模块可以使运行的内核在断点时停下来，达到查询内核内部状态和系统外部状态的效果，并且在查询完成后恢复内核与外设的运行，继续执行程序。

支持两种调试接口：

- 串行接口
- JTAG 调试接口

注意：Arm® Cortex®-M4F 内核内含的硬件调试模块是 Arm CoreSight 开发工具集的子集。更多 Arm® Cortex®-M4F 内核的调试功能信息，请参见 Cortex®-M4F (r1p1 版) 技术参考手册 (TRM) 和 CoreSight 开发工具集 (r1p0 版) TRM。

### 11.3 主要特征

- (1) 可代替内核访问 AHB 总线矩阵
- (2) 灵活的调试引脚分配
- (3) MCU 调试盒 (支持低电源模式，控制外设时钟等)

图 12 APM32F425xG\_F427xG 级别和 Arm® Cortex®-M4F 级别的调试框图



## 11.4 功能描述

### 11.4.1 调试引脚功能配置

- (1) 实现芯片的在线编程和调试
- (2) 利用 KEIL/IAR 等软件实现在线调试及下载编程
- (3) 灵活实现离线编程器的制作

表格 55 引脚功能配置

| 引脚名称 | JTAG 调试端口 |    |             | SW 调试端口  |     |          |
|------|-----------|----|-------------|----------|-----|----------|
|      | 名称        | 类型 | 描述          | 名称       | 类型  | 描述       |
| PA13 | JTMS      | I  | JTAG 测试模式选择 | SWDIO    | I/O | 串行数据输入输出 |
| PA14 | JTCK      | I  | JTAG 测试时钟   | SWCLK    | I   | 串行时钟输入   |
| PA15 | JTDI      | I  | JTAG 测试数据输入 | -        | -   | -        |
| PB3  | JTDO      | O  | JTAG 测试数据输出 | TRACESWO | O   | 串行信息输出   |
| PB4  | NJTRST    | I  | JTAG 测试复位   | -        | -   | -        |

### 11.4.2 ID 编码

#### 11.4.2.1 微控制器设备 ID 编码

APM32F 微控制器系列内含一个 MCU ID 编码。使用 JTAG 或 SW 调试口或用户代码都可以进行访问。

#### 11.4.2.2 边界扫描 TAP

##### JTAG ID 编码

APM32F 微控制器系列的边界扫描 TAP 集成了 JTAG ID 编码，对于 APM32F425xG\_F427xG 系列产品，其 JTAG ID 编码是 0x04190B47，即 4bits 改版次数+12bits Device ID+4bits 0+12bits 公司编码。

#### 11.4.2.3 Arm® Cortex®-M4F TAP

Arm® Cortex®-M4F 的 TAP 有一个 JTAG ID 编码，编码是 0x4BA00477。

#### 11.4.2.4 Arm® Cortex®-M4F JEDEC-106 ID 代码

Arm® Cortex®-M4F 有一个 JEDEC-106 ID 编码。它位于映射到内部 PPB 总线地址为 0xE0042000 的 4KB ROM 表中。

## 11.5 寄存器地址映射

表格 56 寄存器地址映射

| 寄存器名          | 描述        | 地址          |
|---------------|-----------|-------------|
| DBGMCU_IDCODE | 设备 ID 寄存器 | 0xE004 2000 |

| 寄存器名         | 描述                | 地址          |
|--------------|-------------------|-------------|
| DBGMCU_CFG   | 调试 MCU 配置寄存器      | 0xE004 2004 |
| DBGMCU_APB1F | 调试 MCU APB1 冻结寄存器 | 0xE004 2008 |
| DBGMCU_APB2F | 调试 MCU APB2 冻结寄存器 | 0xE004 200C |

## 11.6 寄存器功能描述

### 11.6.1 设备 ID 寄存器 (DBGMCU\_IDCODE)

地址: 0xE004 2000

复位值: 0xXXXX XXXX, X 表示未定义位

只支持 32 位访问。

| 位/域   | 名称  | R/W | 描述                                                                                             |
|-------|-----|-----|------------------------------------------------------------------------------------------------|
| 11:0  | EQR | R   | 设备识别 (Equipment Recognition)<br>APM32F425xG_F427xG 系列产品: 0x419<br>调试器/编程工具通过 EQR (11:0) 来识别芯片。 |
| 15:12 | 保留  |     |                                                                                                |
| 31:16 | WVR | R   | 晶圆版本识别 (Wafer Version Recognition)<br>该域标识晶圆信息<br>APM32F425xG_F427xG 系列产品版本 A: 0x1000          |

### 11.6.2 调试 MCU 配置寄存器 (DBGMCU\_CFG)

地址: 0xE004 2004

复位值: 0x0000 0000 (不受系统复位影响, 仅上电复位)

此寄存器可以在调试状态下配置 MCU, 包括支持定时器和看门狗的计数器、低功耗模式、CAN 通信和分配跟踪引脚。

只支持 32 位访问。

| 位/域 | 名称              | R/W | 描述                                                                                                                                   |
|-----|-----------------|-----|--------------------------------------------------------------------------------------------------------------------------------------|
| 0   | SLEEP_CLK_STS   | R/W | 调试睡眠模式时, 配置时钟状态 (Configure Clock Status When MCU is Debugged in Sleep Mode)<br>0: FCLK 开, HCLK 关<br>1: FCLK 开, HCLK 开, 由系统时钟提供       |
| 1   | STOP_CLK_STS    | R/W | 调试停机模式时, 配置时钟状态 (Configure Clock Status When MCU is Debugged in Stop Mode)<br>0: FCLK 关, HCLK 关<br>1: FCLK 开, HCLK 开, 由 HSICLK 提供    |
| 2   | STANDBY_CLK_STS | R/W | 调试待机模式时, 配置时钟状态 (Configure Clock Status When MCU is Debugged in Standby Mode)<br>0: FCLK 关, HCLK 关<br>1: FCLK 开, HCLK 开, 由 HSICLK 提供 |
| 4:3 | 保留              |     |                                                                                                                                      |
| 5   | TRACE_IOEN      | R/W | 使能跟踪调试引脚 (Trace Debug Pin Enable)<br>0: 禁用跟踪调试引脚<br>1: 使能跟踪调试引脚                                                                      |

| 位/域  | 名称         | R/W | 描述                                                                                                                                                        |
|------|------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:6  | TRACE_MODE | R/W | 配置跟踪调试引脚模式 (Trace Debug Pin Mode Configure)<br>仅当 TRACE_IOEN=1 时, 可配置跟踪调试引脚模式:<br>00: 异步模式<br>01: 同步模式, 数据长度为 1<br>10: 同步模式, 数据长度为 2<br>11: 同步模式, 数据长度为 4 |
| 31:8 |            |     | 保留                                                                                                                                                        |

### 11.6.3 调试 MCU APB1 冻结寄存器 (DBGMCU\_APB1F)

地址: 0xE004 2008

复位值: 0x0000 0000 (不受系统复位影响)

此寄存器用于在调试时配置 MCU。

涉及一些 APB 外设:

- 冻结定时器计数器
- 冻结 I2C SMBus 超时
- 冻结支持系统窗口监管机构和独立的看门狗计数器

此寄存器由 POR 异步重置 (而不是系统重置), 它可以由调试器在系统重置下编写。只支持 32 位访问。

| 位/域 | 名称       | R/W | 描述                                                                                                                        |
|-----|----------|-----|---------------------------------------------------------------------------------------------------------------------------|
| 0   | TMR2_STS | R/W | 内核停止时, 配置 TMR2 的工作状态 (Configure Timer2 Work Status When Core is in Halted)<br>内核停止时, TMR2 计数器是否继续工作<br>0: 继续工作<br>1: 停止工作 |
| 1   | TMR3_STS | R/W | 内核停止时, 配置 TMR3 的工作状态 (Configure Timer3 Work Status When Core is in Halted)<br>内核停止时, TMR3 计数器是否继续工作<br>0: 继续工作<br>1: 停止工作 |
| 2   | TMR4_STS | R/W | 内核停止时, 配置 TMR4 的工作状态 (Configure Timer4 Work Status When Core is in Halted)<br>内核停止时, TMR4 计数器是否继续工作<br>0: 继续工作<br>1: 停止工作 |
| 3   | TMR5_STS | R/W | 内核停止时, 配置 TMR5 的工作状态 (Configure Timer5 Work Status When Core is in Halted)<br>内核停止时, TMR5 计数器是否继续工作<br>0: 继续工作<br>1: 停止工作 |
| 4   | TMR6_STS | R/W | 内核停止时, 配置 TMR6 的工作状态 (Configure Timer6 Work Status When Core is in Halted)<br>内核停止时, TMR6 计数器是否继续工作<br>0: 继续工作<br>1: 停止工作 |

| 位/域   | 名称                     | R/W | 描述                                                                                                                                                                       |
|-------|------------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5     | TMR7_STS               | R/W | 内核停止时, 配置 TMR7 的工作状态 (Configure Timer7 Work Status When Core is in Halted)<br>内核停止时, TMR7 计数器是否继续工作<br>0: 继续工作<br>1: 停止工作                                                |
| 6     | TMR12_STS              | R/W | 内核停止时, 配置 TMR12 的工作状态 (Configure Timer12 Work Status When Core is in Halted)<br>内核停止时, TMR12 计数器是否继续工作<br>0: 继续工作<br>1: 停止工作                                             |
| 7     | TMR13_STS              | R/W | 内核停止时, 配置 TMR13 的工作状态 (Configure Timer13 Work Status When Core is in Halted)<br>内核停止时, TMR13 计数器是否继续工作<br>0: 继续工作<br>1: 停止工作                                             |
| 8     | TMR14_STS              | R/W | 内核停止时, 配置 TMR14 的工作状态 (Configure Timer14 Work Status When Core is in Halted)<br>内核停止时, TMR14 计数器是否继续工作<br>0: 继续工作<br>1: 停止工作                                             |
| 9     |                        |     | 保留                                                                                                                                                                       |
| 10    | RTC_STS                | R/W | 内核停止时, 配置 RTC 的工作状态 (Configure RTC Work Status When Core is in Halted)<br>内核停止时, RTC 计数器是否继续工作<br>0: 继续工作<br>1: 停止工作                                                     |
| 11    | WWDT_STS               | R/W | 内核停止时, 配置窗口看门狗的工作状态 (Configure Window Watchdog Work Status When Core is in Halted)<br>内核停止时, WWDT 是否继续工作<br>0: 继续工作<br>1: 停止工作                                           |
| 12    | IWDT_STS               | R/W | 内核停止时, 配置独立看门狗的工作状态 (Configure Independent Watchdog Work Status When Core is in Halted)<br>内核停止时, IWDT 是否继续工作<br>0: 继续工作<br>1: 停止工作                                      |
| 20:13 |                        |     | 保留                                                                                                                                                                       |
| 21    | I2C1_SMBUS_TIMEOUT_STS | R/W | 内核停止时, 配置 I2C1_SMBUS_TIMEOUT 的工作状态 (Configure I2C1_SMBUS_TIMEOUT Work Status When Core is in Halted)<br>内核停止时, I2C1_SMBUS_TIMEOUT 是否继续工作<br>0: 正常工作<br>1: 冻结 SMBUS 的超时模式 |

| 位/域   | 名称                         | R/W | 描述                                                                                                                                                                          |
|-------|----------------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 22    | I2C2_SMBUS_TIME<br>OUT_STS | R/W | 内核停止时, 配置 I2C2_SMBUS_TIMEOUT 的工作状态<br>(Configure I2C2_SMBUS_TIMEOUT Work Status When Core is in Halted)<br>内核停止时, I2C2_SMBUS_TIMEOUT 是否继续工作<br>0: 正常工作<br>1: 冻结 SMBUS 的超时模式 |
| 23    | I2C3_SMBUS_TIME<br>OUT_STS | R/W | 内核停止时, 配置 I2C3_SMBUS_TIMEOUT 的工作状态<br>(Configure I2C3_SMBUS_TIMEOUT Work Status When Core is in Halted)<br>内核停止时, I2C3_SMBUS_TIMEOUT 是否继续工作<br>0: 正常工作<br>1: 冻结 SMBUS 的超时模式 |
| 24    |                            |     | 保留                                                                                                                                                                          |
| 25    | CAN1_STS                   | R/W | 内核停止时, 配置 CAN1 的工作状态 (Configure Controller Area Network Work Status When Core is in Halted)<br>内核停止时, CAN1 是否继续工作<br>0: 正常工作<br>1: 冻结 CAN1 接收寄存器                            |
| 26    | CAN2_STS                   | R/W | 内核停止时, 配置 CAN2 的工作状态 (Configure Controller Area Network Work Status When Core is in Halted)<br>内核停止时, CAN2 是否继续工作<br>0: 正常工作<br>1: 冻结 CAN2 接收寄存器                            |
| 31:27 |                            |     | 保留                                                                                                                                                                          |

#### 11.6.4 调试 MCU APB2 冻结寄存器 (DBGMCU\_APB2F)

地址: 0xE004 200C

复位值: 0x0000 0000 (不受系统复位影响)

此寄存器用于在调试时配置 MCU。

涉及 APB 外设: 冻结定时器计数器。

此寄存器由 POR 异步重置 (而不是系统重置), 它可以由调试器在系统重置下编写。只支持 32 位访问。

| 位/域  | 名称       | R/W | 描述                                                                                                                        |
|------|----------|-----|---------------------------------------------------------------------------------------------------------------------------|
| 0    | TMR1_STS | R/W | 内核停止时, 配置 TMR1 的工作状态 (Configure Timer1 Work Status When Core is in Halted)<br>内核停止时, TMR1 计数器是否继续工作<br>0: 继续工作<br>1: 停止工作 |
| 1    | TMR8_STS | R/W | 内核停止时, 配置 TMR8 的工作状态 (Configure Timer8 Work Status When Core is in Halted)<br>内核停止时, TMR8 计数器是否继续工作<br>0: 继续工作<br>1: 停止工作 |
| 15:2 |          |     | 保留                                                                                                                        |

| 位/域   | 名称        | R/W | 描述                                                                                                                           |
|-------|-----------|-----|------------------------------------------------------------------------------------------------------------------------------|
| 16    | TMR9_STS  | R/W | 内核停止时, 配置 TMR9 的工作状态 (Configure Timer9 Work Status When Core is in Halted)<br>内核停止时, TMR9 计数器是否继续工作<br>0: 继续工作<br>1: 停止工作    |
| 17    | TMR10_STS | R/W | 内核停止时, 配置 TMR10 的工作状态 (Configure Timer10 Work Status When Core is in Halted)<br>内核停止时, TMR10 计数器是否继续工作<br>0: 继续工作<br>1: 停止工作 |
| 18    | TMR11_STS | R/W | 内核停止时, 配置 TMR11 的工作状态 (Configure Timer11 Work Status When Core is in Halted)<br>内核停止时, TMR11 计数器是否继续工作<br>0: 继续工作<br>1: 停止工作 |
| 31:19 | 保留        |     |                                                                                                                              |

## 12 通用输入/输出引脚 (GPIO)

### 12.1 术语全称、缩写描述

表格 57 术语全称、缩写描述

| 中文全称         | 英文全称                                | 英文缩写  |
|--------------|-------------------------------------|-------|
| P 通道金属氧化物半导体 | P-channel Metal Oxide Semiconductor | P-MOS |
| N 通道金属氧化物半导体 | N-channel Metal Oxide Semiconductor | N-MOS |

### 12.2 主要特征

GPIO 端口可以通过 32 位的配置寄存器 (GPIOx\_CFGLOW/GPIOx\_CFGHIG) 和两个 32 位的数据寄存器 (GPIOx\_IDATA/GPIOx\_ODATA) 配置以下功能：

- (1) 输入模式
  - 模拟输入
  - 浮空输入
  - 上拉输入
  - 下拉输入
- (2) 输出模式
  - 推挽输出
  - 开漏输出
  - 可配置最大输出速率
- (3) 复用模式
  - 推挽复用功能
  - 开漏复用功能
- (4) 模拟功能
- (5) GPIO 都可以作为外部中断/唤醒线
- (6) 支持锁定 I/O 配置功能

## 12.3 结构框图

图 13.5 伏兼容 GPIO 结构框图



注意: (1)  $V_{DD\_FT}$  和  $V_{DD}$  不一样,  $V_{DD\_FT}$  对 5 伏兼容 GPIO 引脚是特殊的。

## 12.4 功能描述

GPIO 的每个引脚都可以通过软件配置上拉、下拉、浮空和模拟输入, 或者推挽/开漏输出输入模式以及复用功能。所有的 GPIO 接口都具有外部中断能力。

### 12.4.1 复位期间和刚复位后的 IO 状态

GPIO 在复位期间和刚复位后, 复用功能未开启, I/O 端口将会被配置为浮空输入模式, 此情况下输入模式禁用上拉/下拉电阻。复位后 JTAG 引脚被置于输入上拉或下拉模式, 具体配置如下:

- PA15: JTDI 置于上拉模式
- PA14: JTCK 置于下拉模式
- PA13: JTMS 置于上拉模式
- PB4: JNTRST 置于上拉模式
- PB3: JTDO 置于浮空模式

### 12.4.2 输入模式

在输入模式中可以设置为上拉、下拉、浮空和模拟输入。

当 GPIO 配置为输入模式时, 所有的 GPIO 引脚内部都有一个内部弱上拉和弱下拉电阻, 它们可以被激活也可以被断开。

#### 上拉、下拉、浮空模式

在 (上拉、下拉、浮空) 输入模式中:

- 施密特触发器打开
- 禁止输出缓冲器
- 根据输入配置的不同, 连接弱上拉和下拉电阻

- 输入数据寄存器 `GPIOx_IDATA` 在每个 `AHB1` 时钟周期捕捉 I/O 引脚上的数据
- 通过输入数据寄存器 `GPIOx_IDATA` 读取 I/O 状态

浮空输入模式的初始电平状态不确定，且易受外界干扰；连接设备时，由外部的输入电平决定（阻抗非常高的除外）。

上拉/下拉输入模式的初始电平状态，如果是上拉则为高电平，如果为下拉则为低电平。连接设备时，由外部的输入电平及负载阻抗决定。

### 模拟输入模式

在模拟输入模式中：

- 禁止输出缓冲器
- 禁止施密特触发器输入，施密特触发器的输出值强置为 0
- 禁用弱上拉和下拉电阻
- 端口输入状态寄存器的值为 0

图 14 输入模式结构



### 12.4.3 输出模式

在输出模式中可以设置为推挽输出和开漏输出。

当 GPIO 配置为输出引脚时，可以配置端口的输出速度和选择输出驱动模式（推挽/开漏）。

在输出模式中：

- 施密特触发器打开
- 激活输出缓冲器
- 禁止弱上拉和下拉电阻
- 推挽模式：
  - 双 MOS 管以轮流方式工作，输出数据寄存器可控制 I/O 输出的高低电平
  - 通过输出数据寄存器 `GPIOx_ODATA` 读取最后写入的值
- 开漏模式：
  - 只有 N-MOS 管工作，输出数据寄存器可以控制 I/O 输出高阻态或低电平

- 通过输入数据寄存器 `GPIOx_IDATA` 读取 I/O 的实际状态

图 15 输出模式 I/O 结构



#### 12.4.4 复用模式

在复用模式中可以设置为推挽复用和开漏复用。

在推挽/开漏复用模式中：

- 打开输出缓冲器
- 由外设驱动输出缓冲器
- 激活施密特触发输入
- 禁止弱上拉和下拉电阻
- I/O 引脚上的数据，在每个 AHB1 时钟周期采样并存入端口输入状态寄存器
- 开漏模式中，通过输入数据寄存器 `GPIOx_IDATA` 可以读取 I/O 的实际状态
- 推挽模式中，通过输出数据寄存器 `GPIOx_ODATA` 读取最后写入的值

图 16 复用模式 I/O 结构



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

所有的 GPIO 端口都有外部中断功能，如果要使用外部中断线，端口必须要配置成输入模式。

#### 12.4.6 位设置和位清除

在对 GPIOx\_IDATA 的一些位进行编程时，软件不需要禁止中断。可以通过对 GPIOx\_BSC 和 BSC 寄存器中想要更改的位置 1 实现在 AHB1 写操作中，只更改一个或者多个位的功能。

#### 12.4.7 GPIO 锁定功能

锁定功能可以用在电源驱动模块。GPIO 的锁定机制可以保护 I/O 端口的配置。通过配置锁定寄存器 (GPIOx\_LOCK) 可以锁定 I/O 的配置，当一个端口位执行了锁定程序，到下一次复位之前，将不能再修改端口位的配置。

#### 12.4.8 OSC32\_IN/OSC32\_OUT 引脚

仅当关闭 LSECLK 振荡器时，可分别将 OSC32\_IN 和 OSC32\_OUT 引脚用作通用 PC14 I/O 和 PC15 I/O。由 RCC\_BDCTRL[LSEEN]位控制。LSECLK 的优先级高于 GPIO 功能。

#### 12.4.9 OSC\_IN/OSC\_OUT 引脚

仅当关闭 HSECLK 振荡器时，可分别将 OSC\_IN 和 OSC\_OUT 引脚用作通用 PH0 I/O 和 PH1 I/O。由 RCC\_BDCTRL[HSEEN]位控制。HSECLK 的优先级高于 GPIO 功能。

### 12.5 寄存器地址映射

表格 58 GPIO 寄存器地址映射

| 寄存器名        | 描述             | 偏移地址 |
|-------------|----------------|------|
| GPIOx_MODE  | 端口模式寄存器        | 0x00 |
| GPIOx_OMODE | 端口输出模式寄存器      | 0x04 |
| GPIOx_OSSEL | 端口输出速度寄存器      | 0x08 |
| GPIOx_PUPD  | 端口上拉/下拉寄存器     | 0x0C |
| GPIOx_IDATA | 端口输入数据寄存器      | 0x10 |
| GPIOx_ODATA | 端口输出清除寄存器      | 0x14 |
| GPIOx_BSC   | 端口置位/复位寄存器     | 0x18 |
| GPIOx_LOCK  | 端口锁定寄存器        | 0x1C |
| GPIOx_ALFL  | 端口复用功能低 8 位寄存器 | 0x20 |
| GPIOx_ALFH  | 端口复用功能高 8 位寄存器 | 0x24 |

### 12.6 寄存器功能描述

必须以字 (32 位) 的方式操作这些外设寄存器。

注意：因为 PIx 的 x 的值为 0...11，所以相应的寄存器的位需要视情况而定。

### 12.6.1 端口模式寄存器 (GPIOx\_MODE) (x=A...H)

偏移地址: 0x00

复位值: 0xA800 0000 (端口 A)

0x0000 0280 (端口 B)

0x0000 0000 (其他端口)

| 位/域     | 名称         | R/W | 描述                                                                                                                   |
|---------|------------|-----|----------------------------------------------------------------------------------------------------------------------|
| 2y+1:2y | MODEy[1:0] | R/W | 配置端口 x 引脚 y 模式 (y=0...15) (Port x Pin y Mode Configure)<br>00: 输入模式 (复位后的状态)<br>01: 通用输出模式<br>10: 复用功能模式<br>11: 模拟模式 |

### 12.6.2 端口输出模式寄存器 (GPIOx\_OMODE) (x=A...H)

偏移地址: 0x04

复位值: 0x0000 0000

| 位/域   | 名称     | R/W | 描述                                                                                            |
|-------|--------|-----|-----------------------------------------------------------------------------------------------|
| 15:0  | OMODEy | R/W | 配置端口 x 引脚 y 输出模式 (y=0...15) (Port x Pin y Output Mode Configure)<br>0: 推挽输出 (复位状态)<br>1: 开漏输出 |
| 31:16 | 保留     |     |                                                                                               |

### 12.6.3 端口输出速度寄存器 (GPIOx\_OSSEL) (x=A...H)

偏移地址: 0x08

复位值: 0x0C00 0000 (端口 A)

0x0000 00C0 (端口 B)

0x0000 0000 (其他端口)

| 位/域     | 名称          | R/W | 描述                                                                                                                          |
|---------|-------------|-----|-----------------------------------------------------------------------------------------------------------------------------|
| 2y+1:2y | OSSELy[1:0] | R/W | 选择端口 x 引脚 y 输出速度 (y=0...15) (Port x Pin y Output Speed Select)<br>00: 低速<br>01: 中速<br>10: 高速<br>11: 极高速<br>由软件写配置 I/O 口的速度。 |

### 12.6.4 端口上拉/下拉寄存器 (GPIOx\_PUPD) (x=A...H)

偏移地址: 0x0C

复位值: 0x6400 0000 (端口 A)

0x0000 0100 (端口 B)

0x0000 0000 (其他端口)

| 位/域     | 名称         | R/W | 描述                                                                                                                                                                |
|---------|------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2y+1:2y | PUPDy[1:0] | R/W | <p>配置端口 x 引脚 y 上拉/下拉 (y=0...15) (Port x Pin y Pull-up/Pull-down Configure)</p> <p>这些位通过软件写操作来配置端口位的上拉/下拉。</p> <p>00: 禁用上拉/下拉<br/>01: 上拉<br/>10: 下拉<br/>11: 保留</p> |

#### 12.6.5 端口输入数据寄存器 (GPIOx\_IDATA) (x=A...H)

偏移地址: 0x10

复位值: 0x0000 XXXX

| 位/域   | 名称     | R/W | 描述                                                                                                 |
|-------|--------|-----|----------------------------------------------------------------------------------------------------|
| 15:0  | IDATAy | R   | <p>端口 x 引脚 y 输入数据 (y=0....15) (Port x Pin y Input Data)</p> <p>这些位只能进行读操作, 用来存储相应的 I/O 端口的输入值。</p> |
| 31:16 |        |     | 保留                                                                                                 |

#### 12.6.6 端口输出数据寄存器 (GPIOx\_ODATA) (x=A...H)

偏移地址: 0x14

复位值: 0x0000 0000

| 位/域   | 名称     | R/W | 描述                                                                                                                                    |
|-------|--------|-----|---------------------------------------------------------------------------------------------------------------------------------------|
| 15:0  | ODATAy | R/W | <p>端口 x 引脚 y 输出数据 (y=0....15) (Port x Pin y Output Data)</p> <p>可以通过软件进行读写操作。</p> <p>对于设置/清除, 可以通过写入 GPIOx_BSC 寄存器来单独设置 ODATAy 位。</p> |
| 31:16 |        |     | 保留                                                                                                                                    |

#### 12.6.7 端口置位/复位寄存器 (GPIOx\_BSC) (x=A...H)

偏移地址: 0x18

复位值: 0x0000 0000

| 位/域   | 名称  | R/W | 描述                                                                                                                                                                                                   |
|-------|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0  | Bsy | W   | <p>端口 x 引脚 y 的设置位 (y=0...15) (Port x Pin y Set Bit)</p> <p>这些位只能进行写操作, 读这些位时返回 0x0000 的数值。</p> <p>这些位用来影响对应的 ODATAy 位。</p> <p>0: 无影响<br/>1: 设置对应的 ODATAy 位</p>                                       |
| 31:16 | Bcy | W   | <p>端口 x 引脚 y 复位 (y=0...15) (Port x Pin y Reset Bit)</p> <p>这些位只能进行写操作, 读这些位时返回 0x0000 的数值。</p> <p>这些位用来影响对应的 ODATAy 位。</p> <p>0: 无影响<br/>1: 对应的 ODATAy 位清 0</p> <p>若 Bsy 位和 Bcy 位同时设置, Bsy 有优先权。</p> |

#### 12.6.8 端口锁定寄存器 (GPIOx\_LOCK) (x=A..G)

偏移地址: 0x1C

复位值: 0x0000 0000

该寄存器保护 GPIO 的配置在程序运行期间误修改。若再次修改 GPIO 配置，需系统复位后才能修改。配置 GPIO 锁定功能时，需对该寄存器执行指定的序列才能启动 GPIO 锁定功能。

| 位/域   | 名称      | R/W | 描述                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------|---------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0  | LOCKy   | R/W | <p>配置端口 x 引脚 y 的锁定位 (y=0...15) (Port x Pin y Lock Configure)</p> <p>0: 不锁定端口 x 引脚 y 的配置<br/>1: 锁定端口 x 引脚 y 的配置</p> <p>这些位可以进行读写操作，但是只能在 LOCKKEY=0 时写入。</p>                                                                                                                                                                                                                                                          |
| 16    | LOCKKEY | R/W | <p>锁定键 (Lock Key)</p> <p>该位决定端口配置锁键位是否被激活。</p> <p>0: 不激活<br/>1: 激活，GPIOx_LOCK 寄存器锁定直到下一次 MUC 复位产生。</p> <p>锁定键写序列：</p> <p>写 LOCK[16]=1+LOCK[15:0]<br/>写 LOCK[16]=0+LOCK[15:0]<br/>写 LOCK[16]=1+LOCK[15:0]</p> <p>读 LOCK</p> <p>读 LOCK[16]=1 (此读操作可以选择，要确认是否激活锁定键)</p> <p>注意：</p> <p>在操作锁键的写入序列期间，LOCKy 的值不能改变。</p> <p>操作锁键写入序列中的任何错误将中止锁键。</p> <p>在端口任意位上的第一个锁序列之后，LOCKKEY 位上的任何读访问都将返回 “1”，直到下一个 MCU 重置或外围设备重置。</p> |
| 31:17 |         |     | 保留                                                                                                                                                                                                                                                                                                                                                                                                                  |

### 12.6.9 端口复用功能低 8 位寄存器 (GPIOx\_ALFL) (x=A...H)

偏移地址: 0x20

复位值: 0x0000 0000

| 位/域  | 名称      | R/W | 描述                                                                                                                                                                                                                                                                                                                                            |
|------|---------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | ALFSELy | R/W | <p>选择端口 x 引脚 y 的复用功能 (y=0....7) (Port x Pin y Alternate Function Select)</p> <p>这些位可以通过软件进行读操作，用来配置端口的复用功能。</p> <p>ALFSELy 选择：</p> <p>0000: AF0<br/>0001: AF1<br/>0010: AF2<br/>0011: AF3<br/>0100: AF4<br/>0101: AF5<br/>0110: AF6<br/>0111: AF7<br/>1000: AF8<br/>1001: AF9<br/>1010: AF10<br/>1011: AF11<br/>1100: AF12<br/>1101: AF13</p> |

| 位/域 | 名称 | R/W | 描述                       |
|-----|----|-----|--------------------------|
|     |    |     | 1110: AF14<br>1111: AF15 |

### 12.6.10 端口复用功能高 8 位寄存器 (**GPIOx\_ALFH**) (x=A...H)

偏移地址: 0x24

复位值: 0x0000 0000

| 位/域  | 名称      | R/W | 描述                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------|---------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | ALFSELy | R/W | <p>选择端口 x 引脚 y 的复用功能 (y=8....15) (Port x Pin y Alternate Function Select)</p> <p>这些位可以通过软件进行读操作, 用来配置端口的复用功能。</p> <p>ALFSELy 选择:</p> <ul style="list-style-type: none"> <li>0000: AF0</li> <li>0001: AF1</li> <li>0010: AF2</li> <li>0011: AF3</li> <li>0100: AF4</li> <li>0101: AF5</li> <li>0110: AF6</li> <li>0111: AF7</li> <li>1000: AF8</li> <li>1001: AF9</li> <li>1010: AF10</li> <li>1011: AF11</li> <li>1100: AF12</li> <li>1101: AF13</li> <li>1110: AF14</li> <li>1111: AF15</li> </ul> |

## 13 定时器概述

### 13.1 术语全称、缩写描述

表格 59 术语全称、缩写描述

| 中文全称 | 英文全称    | 英文缩写 |
|------|---------|------|
| 定时器  | Timer   | TMR  |
| 更新   | Update  | U    |
| 请求   | Request | R    |
| 事件   | Event   | EV   |
| 捕捉   | Compare | C    |
| 比较   | Compare | C    |
| 长度   | Length  | LEN  |

### 13.2 定时器类别及主要差异

在本次系列产品中，一共可分为三类定时器：高级定时器、通用定时器和基本定时器（看门狗定时器在其它章节中描述）。

高级定时器包含了通用定时器和基本定时器的功能，高级定时器是有四个捕获/比较通道，支持定时功能、输入捕获和输出比较功能、刹车以及互补输出功能，是一个 16 位可以向上/下计数的定时器。

通用定时器的功能比高级定时器简单，主要差异点在通道总数、互补输出通道组数、刹车功能。

而基本定时器是一个只能实现定时功能、没有外部接口的定时器。

产品包含的定时器主要差异见下表：

表格 60 产品包含的定时器主要差异

| 项目   | 具体内容/类别 | 高级定时器 |      | 通用定时器      |                | 通用定时器   |        | 基本定时器 |
|------|---------|-------|------|------------|----------------|---------|--------|-------|
| 名称   | —       | TMR1  | TMR8 | TMR2/3/4/5 | TMR10/11/13/14 | TMR9/12 | TMR6/7 |       |
| 时基单元 | 计数器     | 16 位  |      | 32 位       | 16 位           | 16 位    | 16 位   |       |
|      | 预分频器    | 16 位  |      | 16 位       | 16 位           | 16 位    | 16 位   |       |
|      | 计数模式    | 向上    | 向上   | 向下         | 向上             | 向上      | 向上     |       |
| 通道   | 输入通道    | 4     |      | 4          | 1              | 2       | 0      |       |
|      | 捕获比较通道  | 4     |      | 4          | 1              | 2       | 0      |       |

| 项目 | 具体内容/类别   | 高级定时器 | 通用定时器 | 通用定时器 |     | 基本定时器 |
|----|-----------|-------|-------|-------|-----|-------|
|    | 输出通道      | 7     | 4     | 1     | 2   | 0     |
|    | 互补输出通道    | 3     | 0     | 0     | 0   | 0     |
| 功能 | 产生 DMA 请求 | 可以    | 可以    | 不可以   | 不可以 | 可以    |
|    | PWM 模式    | 有     | 有     | 有     | 有   | 无     |
|    | 单脉冲模式     | 有     | 有     | 有     | 有   | 无     |
|    | 强制输出模式    | 有     | 有     | 有     | 有   | 无     |
|    | 死区插入      | 有     | 无     | 无     | 无   | 无     |

### 定时器术语

表格 61 引脚定义术语

| 名称                                      | 描述               |
|-----------------------------------------|------------------|
| TMRx_ETR                                | 定时器 x 外部触发信号     |
| TMRx_CH1、TMRx_CH2、TMRx_CH3、<br>TMRx_CH4 | 定时器 x 通道 1/2/3/4 |
| TMRx_ChN                                | 定时器 x 互补输出通道 y   |
| TMRx_BKIN                               | 定时器 x 刹车信号       |

表格 62 内部信号定义术语

| 名称              | 描述                 |
|-----------------|--------------------|
| ETR             | TMRx_ETR 外部触发信号    |
| ETRF            | 外部触发滤波             |
| ETRP            | 外部触发分频             |
| ITR, ITR0, ITR1 | 内部触发               |
| TRGI            | 时钟/触发器/从模式控制器的触发输入 |
| TIF_ED          | 定时器输入滤波边缘检测        |
| CK_PSC          | 分频时钟               |
| CK_CNT          | 计数器时钟              |
| PSC             | 预分频器               |
| CNT             | 计数器                |
| AUTORLD         | 自动装载寄存器            |

| 名称             | 描述        |
|----------------|-----------|
| Tix, TI1       | 定时器输入     |
| TixF, TI1F,    | 定时器输入滤波   |
| TI1_ED         | 定时器输入边缘检测 |
| TixFPx, TI1FP1 | 定时器输入滤波极性 |
| Icx, IC1       | 输入捕获      |
| IcxPS, IC1PS   | 输入捕获预分频   |
| TRC            | 触发捕获      |
| BRK            | 刹车信号      |
| -              |           |
| OCx, OC1       | 定时器输出比较通道 |
| OCxREF, OC1REF | 输出比较参考信号  |
| -              |           |
| TGI            | 触发中断      |
| BI             | 刹车中断      |
| Ccxl, CC1I     | 捕获/比较中断   |
| UEV            | 更新事件      |
| UIFLG          | 更新中断标志    |

## 14 高级定时器 (TMR1/8)

### 14.1 简介

高级定时器以时基单元为核心，拥有输入捕获、输出比较和刹车输入等功能，含有一个 16 位的自动装载计数器。高级定时器相比较其它定时器增加了互补输出、重复计数以及可编程的死区插入等功能，更加适合用于电机的控制。

### 14.2 主要特征

#### (1) 时基单元

- 计数器：16 位计数器，可以向上计数，向下计数，中央对齐计数
- 预分频器：16 位可编程预分频器
- 重复计数器：16 位的重复计数器
- 自动重装载功能

#### (2) 时钟源选择

- 内部时钟
- 外部输入
- 外部触发
- 内部触发

#### (3) 输入捕获功能

- 计数功能
- PWM 输入模式（脉冲宽度、频率、占空比测量）
- 编码器接口模式

#### (4) 输出比较功能

- PWM 输出模式
- 强制输出模式
- 单脉冲模式
- 互补输出和死区插入

#### (5) 定时功能

#### (6) 刹车功能

#### (7) 定时器的主/从模式控制器

- 定时器之间可以同步和级联
- 支持多种从模式、同步信号

#### (8) 中断输出和 DMA 请求事件

- 更新事件（计数器上/下溢出，计数器初始化）
- 触发事件（计数器启动、停止、内/外部触发）
- 捕获/比较事件
- 刹车信号输入事件

(9) 支持定位用增量（正交）编码器和霍尔传感器电路

## 14.3 结构框图

图 17 高级定时器结构框图



## 14.4 功能描述

### 14.4.1 时钟源选择

高级定时器一共有四种时钟源。

#### 内部时钟

是来自 RCM 的 TMRx\_CLK，即定时器本身的驱动时钟。当禁止从模式控制器，则预分频的时钟源 CK\_PSC 由内部时钟 CK\_INT 驱动。

#### 外部时钟模式 1

来自定时器自身的输入通道 T11/2/3/4，经过极性选择和滤波以后生成的触发信号，连接到从模式控制器，进而控制计数器的工作。其中通道 1 的输入经过上升

沿、下降沿双沿检测而生成的脉冲信号进行逻辑相或以后的信号就是 **TI1F\_ED** 信号，即 **TIF\_ED** 双边沿信号。特别的是 **PWM** 输入只能由 **TI1/2** 输入。

## 外部时钟模式 2

来自于外部触发接口（**ETR**）经过极性选择、分频、滤波以后的信号，经过触发输入选择器，连接到从模式控制器，从而控制计数器的工作。

## 内部触发输入

设置定时器工作于从模式，时钟源为其他定时器的输出信号，此时钟源没有滤波，可以实现定时器之间的同步或级联。主模式的定时器可以对从模式定时器执行复位、启动、停止或提供时钟。

### 14.4.2 时基单元

高级定时器里的时基单元包含四个寄存器

- 16 位计数器寄存器（**CNT**）
- 16 位自动重装载寄存器（**AUTORLD**）
- 16 位预分频寄存器（**PSC**）
- 8 位重复次数寄存器（**REPCNT**）

重复次数寄存器是高级定时器特有的。

## 计数器 CNT

高级定时器中的计数器中一共有三种计数模式：

- 向上计数模式
- 向下计数模式
- 中央对齐模式

## 向上计数模式

通过配置控制寄存器（**TMRx\_CTRL1**）中的 **CNTDIR** 位，设置为向上计数模式。

当计数器处于向上计数模式时，计数器从 0 开始向上计数，当每来一个脉冲计数器就会增加 1，一直到计数器（**TMRx\_CNT**）值与自动重装载（**TMRx\_AUTORLD**）的值相等时，计数器会再次从 0 开始计数，此时产生一个计数器向上溢出事件，其中自动重装载的值（**TMRx\_AUTORLD**）是提前写入的。如果使用重复计数器，则当向上计数的重复次数达到重复计数器寄存器中的次数加一次(**TMRx\_REPCNT+1**)后，将生成更新事件。否则，将在每次计数器上溢时产生更新事件，此时重复计数的影子寄存器、自动重装载的影子寄存器和预分频的缓冲区都将会被更新。可以通过配置控制寄存器 **TMRx\_CTRL1** 中的 **UD** 位，禁止更新事件。

下图为向上计数模式下，分频因子为 1 或 2 的时序图：

图 18 向上计数模式下, 分频因子为 1 或 2 的时序图



### 向下计数模式

通过配置控制寄存器 (TMRx\_CTRL1) 中的 CNTDIR 位, 设置为向下计数模式。

当计数器处于向下计数模式时, 计数器从自动重装载的值 (TMRx\_AUTORLD) 开始向下计数, 当每来一个脉冲计数器就会减 1, 一直减到 0 时, 计数器会重新从 (TMRx\_AUTORLD) 开始计数, 与此同时便会产生一个计数器向下溢出事件, 自动重装载的值 (TMRx\_AUTORLD) 是提前写入的。如果使用重复计数器, 则当向下计数的重复次数达到重复计数器寄存器中的次数加一次 (TMRx\_REPCNT+1) 后, 将生成更新事件。否则, 将在每次计数器下溢时产生更新事件, 此时, 重复计数的影子寄存器、自动重装载的影子寄存器和预分频的缓冲区都将会被更新。可以配置 TMRx\_CTRL1 寄存器中的 UD 位, 禁止更新事件。

图 19 向下计数模式下，分频因子为 1 或 2 的时序图



### 中央对齐模式

通过配置控制寄存器 (TMRx\_CTRL1) 中的 CAMSEL 位，设置为中央对齐模式。

当计数器处于中央对齐模式时，计数器从 0 开始向上计数到自动重装载的值 (TMRx\_AUTORLD)，然后从自动重装载的值 (TMRx\_AUTORLD) 再向下计数到 0，以此往复。在向上计数时，当计数器的值为 (AUTORLD-1) 时会产生一个计数器上溢事件；在向下计数时，计数器的值为 1 时会产生一个计数器下溢事件。

图 20 中央对齐模式下，分频因子为 1 或 2 的时序图



### 重复计数器 REPCNT

在基本/通用定时器中没有重复计数器 REPCNT，也就表明了在基本/通用定时器中发生上溢事件或者下溢事件时，直接就会产生更新事件，而在高级定时器里，因为重复计数器的存在，高级定时器发生上/下溢事件时，只有当重复计数器的值为 0 时才会产生更新事件。

例如，如果高级定时器需要在发生上/下溢事件时就产生更新事件，应将重复计数器的值置 0。

如果在向上计数模式时，使用了重复计数器功能，每当计数器向上计数到 AUTORLD 时，发生上溢事件，此时重复计数器的值会减 1，直到重复计数器的值为 0 时会产生更新事件。

即在发生  $N+1$  个（ $N$  为重复计数器的值）上/下溢事件时产生更新事件。

图 21 向上计数模式下, 设置 REPCNT=2 的时序图



### 预分频器 PSC

预分频器是 16 位的且是可编程的, 它可以将计数器的时钟频率进行 1~65536 之间任意值的分频 (由 **TMRx\_PSC** 寄存器控制), 经过分频后的时钟将会驱动计数器 **CNT** 计数。预分频器带有缓冲器, 它能够在运行中被改变。

#### 14.4.3 输入捕获

##### 输入捕获通道

高级定时器有四个独立的捕获/比较独立通道, 每一个捕获/比较的通道都围绕着一个捕获/比较寄存器。

在输入捕获中, 被测量的信号会从定时器的外部引脚 **T1/2/3/4** 进入首先经过边沿检测器和输入滤波器, 然后进入捕获通道, 每个捕获通道都有相对应的捕获寄存器, 当发生捕获时, 计数器 **CNT** 的值将会被锁存在捕获寄存器 **CCx** 中。在进入捕获寄存器之前, 信号还会经过预分频器, 用于设定经过多少事件进行一次捕获。

##### 输入捕获应用

输入捕获用来捕获外部事件, 并且可以赋予时间标记表明事件的发生时刻, 可以测量脉冲跳变沿事件 (测量频率或者脉宽), 如: 在输入引脚上如果出现了被选择的边沿, **TMRx\_CCx** 寄存器会捕获计数器当前的值, 同时状态寄存器 **TMRx\_STS** 的 **CCxIFLG** 位被置 1, 如果 **CCxIEN=1**, 便会产生中断。

捕获模式下可以测量一个波形的时序、频率、周期和占空比。在输入捕获模式中将边沿选择设定为上升沿检测, 当捕获通道出现上升沿时, 发生第一次捕获, 此时计数器 **CNT** 的值会被锁存在捕获寄存器 **CCx** 中, 同时会进入捕获中断, 在中断服务程序中记录一次捕获, 记下此时的值, 当检测到下一个上升沿时, 发生第二次捕获, 计数器 **CNT** 的值会再次锁存在捕获寄存器 **CCx** 中, 此时再次进入捕

获中断，读取捕获寄存器的值，通过捕获就会得出此脉冲信号的周期。

#### 14.4.4 输出比较

输出比较一共有八种模式：冻结、匹配时通道 x 为有效电平、匹配时通道 x 为无效电平、翻转、强制为无效、强制为有效、PWM 模式 1 和 PWM 模式 2。由 **TMRx\_CCMx** 寄存器中的 **OCxMOD** 位配置，在输出比较模式中可以控制输出信号的波形。

#### 输出比较应用

输出比较模式中，定时器产生脉冲的位置、极性、频率和时间都是可以控制的。

当计数器的值和捕获/比较寄存器的值相等时，通过配置 **TMRx\_CCMx** 寄存器中的 **OCxMOD** 位和输出极性 **TMRx\_CCEN** 寄存器中的 **CCxPOL** 位，通道的输出可以被置高电平、低电平或者翻转。

在 **TMRx\_STS** 寄存器中的 **CCxIFLG=1** 时，如果 **TMRx\_DIEN** 寄存器中的 **CCxIEN=1** 产生中断；**TMRx\_CTRL2** 寄存器中的 **CCDSEL=1** 产生 DMA 请求。

#### 14.4.5 PWM 输出模式

PWM 模式是定时器对外输出可以调节的脉冲信号，其中信号的脉宽是由比较寄存器 **CCx** 的值决定，周期是由自动重装载 **AUTORLD** 的值决定。

PWM 输出模式分为 PWM 模式 1 和 PWM 模式 2。PWM 模式 1 和 PWM 模式 2 分为向上计数和向下计数和中央对齐计数。PWM 模式 1 中如果计数器 **CNT** 的值小于比较寄存器 **CCx** 的值，输出有效电平，否则反之。

设置 **CCx=5**, **AUTORLD=7**, 在 PWM 模式 1 下的时序图：

图 22 PWM1 向上计数模式的时序图



图 23 PWM1 向下计数模式的时序图



图 24 PWM1 中央对齐模式的时序图



PWM 模式 2 中如果计数器 CNT 的值小于比较寄存器 CCx 的值，输出无效电平，否则反之。

设置 CCx=5, AUTORLD=7, 在 PWM 模式 2 下的时序图：

图 25 PWM2 向上计数模式的时序图



图 26 PWM2 向下计数模式的时序图



图 27 PWM2 中央对齐模式的时序图



#### 14.4.6 PWM 输入模式

PWM 输入模式是输入捕获的一个特例。

PWM 输入模式，只有 TI1FP1、TI1FP2 连接到了从模式控制器，所以只能从通道 TMRx\_CH1 和 TMRx\_CH2 输入，且需要占用 CH1、CH2 的捕获寄存器。

在 PWM 输入模式中，PWM 信号从 TMRx\_CH1 进入，信号会被分成两路，一路可以测量周期，一路可以测量占空比。在配置中只需设置其中一路的极性，另一路会自动配置为相反的极性。

在此模式中，从模式控制器要配置成复位模式 (TMRx\_SMCTRL 寄存器的 SMFSEL 位)。

图 28 PWM 输入模式时序图



#### 14.4.7 单脉冲模式

单脉冲模式是定时器比较输出中一种特殊情况，也是 PWM 输出模式的特例。

设置 **TMRx\_CTRL1** 寄存器的 **SPMEN** 位选择单脉冲模式，计数器启动后，在未发生更新事件之前有一定个数的脉冲输出，当发生更新事件后计数器停止计数，后续不再有变化的 PWM 波形输出。

单脉冲模式通过程序在一定可控延迟后，产生一个脉宽可控的脉冲，延时时间为 **TMRx\_CCx** 寄存器的值定义；在增计数模式下延时时间为 **CCx**，脉冲宽度为 **AUTORLD-CCx**；在减计数模式下延时时间为 **AUTORLD-CCx**，脉冲宽度为 **CCx**。

图 29 单脉冲模式下的时序图



#### 14.4.8 寄存器对输出波形的影响

以下寄存器会影响定时器输出波形的电平，详细信息可参见“寄存器功能描述”。

(1) **TMRx\_CCEN** 寄存器中的 **CCxEN**、**CCxNEN** 位：

- **CCxNEN=0**、**CCxEN=0**：关闭输出（输出禁止，无效状态）

- CCxNEN=1、CCxEN=1: 开启输出 (输出使能, 正常输出)
- (2) TMRx\_BDT 寄存器中的 MOEN 位:
- MOEN=0: 空闲模式
  - MOEN=1: 运行模式
- (3) TMRx\_CTRL2 寄存器中的 OCxOIS、OCxNOIS 位:
- OCxOIS=0、OCxNOIS=0: 空闲时 (MOEN=0) 死区后的输出电平为 0
  - OCxOIS=1、OCxNOIS=1: 空闲时 (MOEN=0) 死区后的输出电平为 1
- (4) TMRx\_BDT 寄存器中的 RMOS 位:
- RMOS 的应用环境: 对应互补通道、定时器运行模式下 (MOEN=1)、定时器不工作 (CCxEN=0、CCxNEN=0) 或工作 (CCxEN=1、CCxNEN=1) 情况下
- (5) TMRx\_BDT 寄存器中的 IMOS 位:
- IMOS 的应用环境: 对应互补通道、定时器空闲模式下 (MOEN=0)、定时器不工作 (CCxEN=0、CCxNEN=0) 或工作 (CCxEN=1、CCxNEN=1) 情况下
- (6) TMRx\_CCEN 寄存器的 CCxPOL、CCxNPOL 位:
- CCxPOL=0、CCxNPOL=0: 输出极性, 高电平有效
  - CCxPOL=1、CCxNPOL=1: 输出极性, 低电平有效

下图罗列了影响输出波形的寄存器结构关系:

图 30 影响输出波形的寄存器结构关系



#### 14.4.9 刹车功能

刹车的信号源为时钟故障事件和外部输入接口。

其中 **TMRx\_BDT** 寄存器中的 **BRKEN** 位可以使能刹车功能, **BRKPOL** 位配置刹车输入信号的极性。

发生刹车事件时, 可以根据相关控制位的状态修改输出脉冲信号电平。

图 31 发生刹车事件的时序图



#### 14.4.10 互补输出和死区插入

互补输出是高级定时器特有的输出, 高级定时器有三组互补输出通道。插入死区时间用于生成互补的输出信号, 确保通道互补的两路信号不会同时有效。根据定时器连接的输出器件以及特性来设定死区时间。

配置 **TMRx\_BDT** 寄存器的 **DTS** 位可以控制死区的持续时间。

图 32 带死区插入的互补输出



#### 14.4.11 强制输出模式

强制输出模式下无视比较结果，直接根据配置指令输出相应电平。

- TMRx\_CCMx 寄存器的 CCxSEL=00，设定 CCx 通道为输出。
- TMRx\_CCMx 寄存器的 OCxMOD=100/101，设定强制 OCxREF 信号为无效/有效状态。

在此模式中仍会产生相应的中断和 DMA 请求。

#### 14.4.12 编码器接口模式

编码器接口模式相当于是一个带有方向选择的外部时钟，在编码器接口模式中，计时器的内容可一直指示编码器的位置。

选择编码器接口的方法如下：

- 通过设置 TMRx\_SMCTRL 寄存器的 SMFSEL 位，可以设定计数器是在 TI1 通道/TI2 通道边沿计数，或者同时在 TI1 和 TI2 的边沿计数。
- 通过设置 TMRx\_CCEN 寄存器中的 CC1POL 和 CC2POL 位，可以选择 TI1 和 TI2 的极性。
- 通过设置 TMRx\_CCM1 寄存器中的 IC1F 和 IC2F 位，可以选择是否进行滤波。

两个输入 TI1 和 TI2 可以作为增量编码器的接口，计数器由在 TI1 和 TI2 经过滤波和边沿选择后的信号 TI1FP1 和 TI2FP2 的有效跳变驱动。

根据 TI1 和 TI2 的输入信号，产生计数脉冲和方向信号：

- 根据输入信号的跳变顺序，计数器会向上/向下计数。
- 将控制寄存器 TMRx\_CTRL1 的 CNTDIR 设置为只读（任一输入端的跳变都会重新计算 CNTDIR）。

计数器计数方向改变机制如下图：

表格 63 计数方向与编码器的关系

| 有效边沿    |     | 仅在 TI1 计数 |      | 仅在 TI2 计数 |      | 在 TI1 和 TI2 计数 |      |
|---------|-----|-----------|------|-----------|------|----------------|------|
| 相对信号的电平 |     | 高         | 低    | 高         | 低    | 高              | 低    |
| TI1FP1  | 上升沿 | 向下计数      | 向上计数 | —         |      | 向下计数           | 向上计数 |
|         | 下降沿 | 向上计数      | 向下计数 |           |      | 向上计数           | 向下计数 |
| TI2FP2  | 上升沿 | —         |      | 向上计数      | 向下计数 | 向上计数           | 向下计数 |
|         | 下降沿 |           |      | 向下计数      | 向上计数 | 向下计数           | 向上计数 |

外部的增量编码器可以不用外部接口逻辑直接与 MCU 连接，所以使用比较器将编码器的差动输出转换到数字信号来增加抗噪声干扰。

在下图的实例中：

- 将 IC1FP1 映射到 TI1
- 将 IC2FP2 映射到 TI2

- IC1FP1 和 IC2FP2 都不反相
- 输入信号在上升沿和下降沿有效
- 使能计数器

图 33 编码器模式下的计数器操作实例



例如：当 TI1 处在低电平时，如果 TI2 出现上升沿状态，计数器向上计数。

图 34 IC1FP1 反相的编码器接口模式实例



例如：当 TI1 处于低电平时，TI2 发生上升沿跳变，计数器向下计数。

#### 14.4.13 从模式

TMRx 定时器可以进行外部的触发同步：

- 复位模式
- 门控模式
- 触发模式

可设置 TMRx\_SMCTRL 寄存器中的 SMFSEL 位来选择是哪种模式。

SMFSEL=100 设定复位模式，SMFSEL=101 设定门控模式，SMFSEL=110 设定

触发模式。

复位模式下，在发生一个触发输入事件时，计数器和预分频器会被初始化，选中的触发输入（TRGI）的上升沿重新初始化计数器，并且产生一个更新寄存器的信号。

门控模式下，计数器的使能依赖于选中的输入端的高电平，当触发输入为高时，计数器的时钟开启，一旦触发输入变为低，则计数器停止（但不复位），计数器的启动和停止都是受控制的。

触发模式下，计数器的使能依赖于选中的输入端上的事件，计数器在触发输入的上升沿启动（但不复位），只有计数器的启动是受控制的。

#### 14.4.14 定时器互连

TMRx 各个定时器可以互相连接实现定时器之间的同步或级联。需要配置一个定时器处于主模式，另一个定时器处于从模式。

定时器处于主模式时可以对从模式定时器的计数器进行复位、启动、停止和提供时钟源等。

图 35 定时器 1 主/从模式的例子



在定时器互连中可以：

- 将一个定时器作为另一个寄存器的预分频器
- 用一个定时器的使能信号启动另一个寄存器
- 用一个定时器的更新事件启动另一个寄存器
- 用一个定时器的使能选通另一个定时器
- 用一个外部触发同步两个定时器

#### 14.4.15 中断和 DMA 请求

定时器在工作时产生事件时会发生中断：

- 更新事件（计数器上/下溢出，计数器初始化）
- 触发事件（计数器启动、停止、内/外部触发）
- 捕获/比较事件

### ● 刹车信号输入事件

其中一些内部中断事件可以产生 DMA 请求，还有专门的接口允许或者禁止触发 DMA 请求。

#### 14.4.16 调试模式

TMR1/8 可以在调试模式下配置，选择停止还是继续工作。取决于 DBGMCU\_APB2F 寄存器的 TMRx\_STS 位。

#### 14.4.17 在外部事件时清除 OCxREF 信号

此功能是用于输出比较和 PWM 模式。

在一个通道中，用 ETRF 输入端口的高电平将 OCxREF 的信号降为低电平，捕获/比较寄存器 TMRx\_CCMx 中的 OCxCEN 的位置 1，OCxREF 信号会保持为低电平直到下一次发生更新事件。

将 TMRx 置于 PWM 模式，关闭外部触发预分频器，禁止外部触发模式 2。当 ETRF 输入为高时，通过设置 OCxCEN=0，输出的 OCxREF 信号如下图。

图 36 OCxREF 时序图



将 TMRx 置于 PWM 模式，关闭外部触发预分频器，禁止外部触发模式 2。当 ETRF 输入为高时，通过设置 OCxCEN=1，输出的 OCxREF 信号如下图。

图 37 OCxREF 时序图



### 14.5 寄存器地址映射

下表中将高级定时器的所有寄存器映射到一个 16 位可寻址（编址）空间。

表格 64 高级定时器寄存器地址映射

| 寄存器名         | 描述              | 偏移地址 |
|--------------|-----------------|------|
| TMRx_CTRL1   | 控制寄存器 1         | 0x00 |
| TMRx_CTRL2   | 控制寄存器 2         | 0x04 |
| TMRx_SMCTRL  | 从模式控制寄存器        | 0x08 |
| TMRx_DIEN    | DMA/中断使能寄存器     | 0x0C |
| TMRx_STS     | 状态寄存器           | 0x10 |
| TMRx_CEG     | 控制事件产生寄存器       | 0x14 |
| TMRx_CCM1    | 捕获/比较模式寄存器 1    | 0x18 |
| TMRx_CCM2    | 捕获/比较模式寄存器 2    | 0x1C |
| TMRx_CCEN    | 捕获/比较使能寄存器      | 0x20 |
| TMRx_CNT     | 计数器寄存器          | 0x24 |
| TMRx_PSC     | 预分频寄存器          | 0x28 |
| TMRx_AUTORLD | 自动重装载寄存器        | 0x2C |
| TMRx_REPCNT  | 重复计数寄存器         | 0x30 |
| TMRx_CC1     | 通道 1 捕获/比较寄存器   | 0x34 |
| TMRx_CC2     | 通道 2 捕获/比较寄存器   | 0x38 |
| TMRx_CC3     | 通道 3 捕获/比较寄存器   | 0x3C |
| TMRx_CC4     | 通道 4 捕获/比较寄存器   | 0x40 |
| TMRx_BDT     | 刹车和死区寄存器        | 0x44 |
| TMRx_DCTRL   | DMA 控制寄存器       | 0x48 |
| TMRx_DMADDR  | 连续模式的 DMA 地址寄存器 | 0x4C |

## 14.6 寄存器功能描述

### 14.6.1 控制寄存器 1 (TMRx\_CTRL1)

偏移地址: 0x00

复位值: 0x0000

| 位/域 | 名称    | R/W | 描述                                                                                                                                            |
|-----|-------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | CNTEN | R/W | <p>使能计数器 (Counter Enable)<br/>           0: 禁用<br/>           1: 使能</p> <p>定时器配置为外部时钟、门控模式和编码器模式时, 需要通过软件对该位写 1 启动定期工作; 配置为触发模式时, 可硬件写 1。</p> |

| 位/域   | 名称     | R/W | 描述                                                                                                                                                                                                                                                                                                                        |
|-------|--------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1     | UD     | R/W | <p>禁止更新 (Update Disable)<br/>更新事件可引起 AUTORLD、PSC、CCx 产生更新设置的数值。</p> <p>0: 允许更新事件 (UEV)<br/>更新事件可以由以下任一情况产生:<br/>计数器溢出/下溢;<br/>设置 UEG 位;<br/>从模式控制器产生的更新。</p> <p>1: 禁止更新事件</p>                                                                                                                                             |
| 2     | URSSEL | R/W | <p>更新请求源 (Update Request Source Select)<br/>如果使能了中断或 DMA, 更新事件可产生更新中断或 DMA 请求, 通过该位可选择不同的更新请求源。</p> <p>0: 计数器上溢或下溢;<br/>设置 UEG 位;<br/>通过从模式控制器产生的更新。</p> <p>1: 计数器上溢或下溢</p>                                                                                                                                               |
| 3     | SPMEN  | R/W | <p>使能单脉冲模式 (Single Pulse Mode Enable)<br/>产生更新事件时, 可改变通道的输出电平; 在该模式下, 会清除 CNTEN 位, 停止计数器, 后续不再改变通道的输出电平。</p> <p>0: 禁用<br/>1: 使能</p>                                                                                                                                                                                       |
| 4     | CNTDIR | R/W | <p>配置计数器计数方向 (Counter Direction)<br/>当计数器配置为中央对齐模式或编码器模式时, 该位为只读。</p> <p>0: 向上计数<br/>1: 向下计数</p>                                                                                                                                                                                                                          |
| 6:5   | CAMSEL | R/W | <p>选择中央对齐模式 (Center Aligned Mode Select)<br/>中央对齐模式下, 计数器交替的向上向下计数; 否则只向上或向下计数。<br/>不同的中央对齐模式, 影响输出通道的输出比较中断标志位置 1 的时机。<br/>在计数器禁止时 (CNTEN=0) 时, 选择中央对齐模式。</p> <p>00: 边沿对齐模式<br/>01: 中心对齐模式 1 (在向下计数时, 输出通道的输出比较中断标志位置 1)<br/>10: 中心对齐模式 2 (在向上计数时, 输出通道的输出比较中断标志位置 1)<br/>11: 中心对齐模式 3 (在向上/下计数时, 输出通道的输出比较中断标志位置 1)</p> |
| 7     | ARPEN  | R/W | <p>TMRx_AUTORLD 寄存器自动重装载缓冲使能 (Auto-reload Preload Enable)<br/>禁止缓存区时, 程序修改 TMRx_AUTORLD 会立刻修改装入计数器的数值; 使能缓存区时, 程序修改 TMRx_AUTORLD 会在下一个更新事件修改装入计数器的数值。</p> <p>0: 禁用<br/>1: 使能</p>                                                                                                                                          |
| 9:8   | CLKDIV | R/W | <p>时钟分频系数 (Clock Division)<br/>死区、数字滤波器的配置由 CK_INT 提供时钟, 通过设置改位可调整死区时间、数字滤波器的采用时钟。</p> <p>00: <math>t_{DTS}=t_{CK\_INT}</math><br/>01: <math>t_{DTS}=2 \times t_{CK\_INT}</math><br/>10: <math>t_{DTS}=4 \times t_{CK\_INT}</math><br/>11: 保留</p>                                                                         |
| 15:10 |        |     | 保留                                                                                                                                                                                                                                                                                                                        |

### 14.6.2 控制寄存器 2 (TMRx\_CTRL2)

偏移地址: 0x04

复位值: 0x0000

| 位/域 | 名称     | R/W | 描述                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----|--------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | CCPEN  | R/W | 使能捕获/比较预装载 (Capture/Compare Preloaded Enable)<br>该位影响 CCxEN、CCxNEN、OCxMOD 数值的改变。禁止预装载时，程序修改会立刻影响定时器的设置；使能预装载时，只在设置了 COMG 会后更新，从而影响定时器的设置。该位只在具有互补输出的通道起作用。<br>0: 禁用<br>1: 使能                                                                                                                                                                                                                                 |
| 1   |        |     | 保留                                                                                                                                                                                                                                                                                                                                                                                                           |
| 2   | CCUSEL | R/W | 选择捕获/比较控制更新 (Capture/compare Control Update Select) 仅在捕获比较预装载使能 (CCPEN=1) 时，且只对互补输出通道才起作用。<br>0: 只能通过设置 COMG 位更新<br>1: 可以通过设置 COMG 位或者 TRGI 上的上升沿更新                                                                                                                                                                                                                                                          |
| 3   | CCDSEL | R/W | 选择发出捕获/比较的 DMA 请求 (Capture/compare DMA Select)<br>0: 当发生 CCx 事件时，送出 CCx 的 DMA 请求<br>1: 当发生更新事件时，送出 CCx 的 DMA 请求                                                                                                                                                                                                                                                                                              |
| 6:4 | MMSEL  | R/W | 选择定时器主模式下用于 TRGO 的信号 (Master Mode Signal Select)<br>工作在主模式的定时器的信号可用于 TRGO，从而影响处在从模式且与主定时器级联的定时器工作，具体影响可从模式的定时器配置有关。<br>000: 复位，主模式定时器的复位信号用于 TRGO<br>001: 使能，主模式定时器的计数器使能信号用于 TRGO<br>010: 更新，主模式定时器的更新事件用于 TRGO<br>011: 比较脉冲，主模式定时器捕获/比较成功 (CCxIFLG=1) 时输出一个脉冲信号用于 TRGO<br>100: 比较模式 1, OC1REF 用于触发 TRGO<br>101: 比较模式 2, OC2REF 用于触发 TRGO<br>110: 比较模式 3, OC3REF 用于触发 TRGO<br>111: 比较模式 4, OC4REF 用于触发 TRGO |
| 7   | TI1SEL | R/W | TI1 选择 (Timer Input 1 Selection)<br>0: TMRx_CH1 引脚连到 TI1 输入<br>1: TMRx_CH1、TMRx_CH2 和 TMRx_CH3 引脚经异或后连到 TI1 输入                                                                                                                                                                                                                                                                                               |
| 8   | OC1OIS | R/W | 配置 OC1 输出空闲状态 (OC1 Output Idel State Configure)<br>仅在当 MOEN=0 时，实现了 OC1N，只影响 OC1 死区时间后的电平状态。<br>0: OC1=0<br>1: OC1=1<br>注意：当 TMRx_BDT 寄存器中 LOCKCFG 位级别为 1、2 或 3 时，该位不能修改。                                                                                                                                                                                                                                    |

| 位/域 | 名称      | R/W | 描述                                                                                                                                                                                                                              |
|-----|---------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9   | OC1NOIS | R/W | <p>配置 OC1N 输出空闲状态 (OC1N Output Idle State Configure)<br/>         仅在当 MOEN=0、实现了 OC1N, 只影响 OC1N 死区时间后的电平状态。<br/>         0: OC1N=0<br/>         1: OC1N=1<br/>         注意: 当 TMRx_BDT 寄存器中 PLOCKCFG 位级别为 1、2 或 3 时, 该位不能修改。</p> |
| 10  | OC2OIS  | R/W | 配置 OC2 输出空闲状态。参考 OC1OIS 位                                                                                                                                                                                                       |
| 11  | OC2NOIS | R/W | 配置 OC2N 输出空闲状态。参考 OC1NOIS 位                                                                                                                                                                                                     |
| 12  | OC3OIS  | R/W | 配置 OC3 输出空闲状态。参考 OC1OIS 位                                                                                                                                                                                                       |
| 13  | OC3NOIS | R/W | 配置 OC3N 输出空闲状态。参考 OC1NOIS 位                                                                                                                                                                                                     |
| 14  | OC4OIS  | R/W | 配置 OC4 输出空闲状态。参考 OC1OIS 位                                                                                                                                                                                                       |
| 15  |         |     | 保留                                                                                                                                                                                                                              |

#### 14.6.3 从模式控制寄存器 (TMRx\_SMCTRL)

偏移地址: 0x08

复位值: 0x0000

| 位/域 | 名称     | R/W | 描述                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|--------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0 | SMFSEL | R/W | <p>选择从模式功能 (Slave Mode Function Select)<br/>         000: 禁用从模式, 定时器可作为主模式定时器影响从模式定时器的工作; 如果 CTRL1_CNTEN=1, 则预分频器直接由内部时钟驱动。<br/>         001: 编码器模式 1, 根据 TI1FP1 的电平, 计数器在 TI2FP2 的边沿计数。<br/>         010: 编码器模式 2, 根据 TI2FP2 的电平, 计数器在 TI1FP1 的边沿计数。<br/>         011: 编码器模式 3, 根据另一个信号的输入电平, 计数器在 TI1FP1、TI2FP2 的边沿计数。<br/>         100: 复位模式, 从模式定时器在收到 TRGI 的上升沿信号后复位计数器, 并产生更新寄存器的信号。<br/>         101: 门控模式, 从模式定时器在收到 TRGI 高电平信号时, 启动计数器工作; 收到 TRGI 低电平时停止计数器工作; 再收到 TRGI 高电平信号时, 继续工作; 整个期间不复位计数器。<br/>         110: 触发模式, 从模式定时器在收到 TRGI 的上升沿信号后, 启动计数器工作。<br/>         111: 外部时钟模式 1, 选择 TRGI 的上升沿信号作为时钟源驱动计数器工作。</p> |
| 3   |        |     | 保留                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 6:4 | TRGSEL | R/W | <p>选择触发输入信号 (Trigger Input Signal Select)<br/>         为了避免在改变该位值时产生错误的边沿检测, 须在 SMFSEL=0 时改变。<br/>         000: 内部触发 ITR0<br/>         001: 内部触发 ITR1<br/>         010: 内部触发 ITR2<br/>         011: 内部触发 ITR3<br/>         100: 通道 1 输入边沿检测器 TIF_ED</p>                                                                                                                                                                                                                                                                                                                                                                         |

| 位/域   | 名称     | R/W | 描述                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------|--------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |        |     | 101: 通道 1 滤波后定时器输入 TI1FP1<br>110: 通道 2 滤波后的定时器输入 TI2FP2<br>111: 外部触发输入 (ETRF)                                                                                                                                                                                                                                                                                                                                                              |
| 7     | MSMEN  | R/W | 使能主/从模式 (Master/slave Mode Enable)<br>0: 无效<br>1: 使能主/从模式                                                                                                                                                                                                                                                                                                                                                                                  |
| 11:8  | ETFCFG | R/W | 配置外部触发滤波器 (External Trigger Filter Configure)<br>0000: 禁用滤波器, 以 $f_{DTS}$ 采样<br>0001: DIV=1, N=2<br>0010: DIV=1, N=4<br>0011: DIV=1, N=8<br>0100: DIV=2, N=6<br>0101: DIV=2, N=8<br>0110: DIV=4, N=6<br>0111: DIV=4, N=8<br>1000: DIV=8, N=6<br>1001: DIV=8, N=8<br>1010: DIV=16, N=5<br>1011: DIV=16, N=6<br>1100: DIV=16, N=8<br>1101: DIV=32, N=5<br>1110: DIV=32, N=6<br>1111: DIV=32, N=8<br>采样频率=定时器时钟频率/DIV; 滤波长度=N, 每 N 个事件产生一个跳变。 |
| 13:12 | ETPCFG | R/W | 配置外部触发信号预分频器 (External Trigger Prescaler Configure)<br>ETR (外部触发输入) 的信号经过分频后为 ETRP, ETRP 的信号频率最多是 TMRxCLK 频率的 1/4; 当 ETR 频率过高时, 须经过分频降低 ETRP 的频率。<br>00: 禁用预分频器<br>01: ETR 信号 2 分频<br>10: ETR 信号 4 分频<br>11: ETR 信号 8 分频                                                                                                                                                                                                                   |
| 14    | ECEN   | R/W | 使能外部时钟模式 2 (External Clock Enable Mode2)<br>0: 禁用<br>1: 使能<br>设置 ECEN 位与选择外部时钟模式 1 将 TRGI 连接到 ETRF 具有相同作用。从模式 (复位、门控、触发) 可以与外部时钟模式 2 同时使用, 但此时 TRGI 不能连到 ETRF。当外部时钟模式 1 和外部时钟模式 2 同时使能时, 外部时钟的输入是 ETRF。                                                                                                                                                                                                                                    |
| 15    | ETPOL  | R/W | 配置外部触发极性 (External Trigger Polarity Configure)<br>该位决定外部触发 ETR 是否反相。<br>0: 外部触发 ETR 不反相, 高电平或上升沿有效<br>1: 外部触发 ETR 反相, 低电平或下降沿有效                                                                                                                                                                                                                                                                                                            |

表格 65 TMRx 内部触发连接

| 从定时器 | ITR1 (TS=000) | ITR1 (TS=001) | ITR2 (TS=010) | ITR3 (TS=011) |
|------|---------------|---------------|---------------|---------------|
| TMR1 | TMR5          | TMR2          | TMR3          | TMR4          |
| TMR8 | TMR1          | TMR2          | TMR4          | TMR5          |

#### 14.6.4 DMA/中断使能寄存器 (TMRx\_DIEN)

偏移地址: 0x0C

复位值: 0x0000

| 位/域 | 名称     | R/W | 描述                                                                                   |
|-----|--------|-----|--------------------------------------------------------------------------------------|
| 0   | UIEN   | R/W | 使能更新中断 (Update Interrupt Enable)<br>0: 禁用<br>1: 使能                                   |
| 1   | CC1IEN | R/W | 使能捕获/比较通道 1 中断 (Capture/Campare Channel1 Interrupt Enable)<br>0: 禁用<br>1: 使能         |
| 2   | CC2IEN | R/W | 使能捕获/比较通道 2 中断 (Capture/Campare Channel2 Interrupt Enable)<br>0: 禁用<br>1: 使能         |
| 3   | CC3IEN | R/W | 使能捕获/比较通道 3 中断 (Capture/Campare Channel3 Interrupt Enable)<br>0: 禁用<br>1: 使能         |
| 4   | CC4IEN | R/W | 使能捕获/比较通道 4 中断 (Capture/Campare Channel4 Interrupt Enable)<br>0: 禁用<br>1: 使能         |
| 5   | COMIEN | R/W | 使能 COM 中断 (COM Interrupt Enable)<br>0: 禁用<br>1: 使能                                   |
| 6   | TRGIEN | R/W | 使能触发中断 (Trigger Interrupt Enable)<br>0: 禁用<br>1: 使能                                  |
| 7   | BRKIEN | R/W | 使能刹车中断 (Break Interrupt Enable)<br>0: 禁用<br>1: 使能                                    |
| 8   | UDIEN  | R/W | 使能更新的 DMA 请求 (Update DMA Request Enable)<br>0: 禁用<br>1: 使能                           |
| 9   | CC1DEN | R/W | 使能捕获/比较通道 1 的 DMA 请求 (Capture/Campare Channel1 DMA Request Enable)<br>0: 禁用<br>1: 使能 |
| 10  | CC2DEN | R/W | 使能捕获/比较通道 2 的 DMA 请求 (Capture/Campare Channel2 DMA Request Enable)                   |

| 位/域 | 名称     | R/W | 描述                                                                                   |
|-----|--------|-----|--------------------------------------------------------------------------------------|
|     |        |     | 0: 禁用<br>1: 使能                                                                       |
| 11  | CC3DEN | R/W | 使能捕获/比较通道 3 的 DMA 请求 (Capture/Compare Channel3 DMA Request Enable)<br>0: 禁用<br>1: 使能 |
| 12  | CC4DEN | R/W | 使能捕获/比较通道 4 的 DMA 请求 (Capture/Compare Channel4 DMA Request Enable)<br>0: 禁用<br>1: 使能 |
| 13  | COMDEN | R/W | 使能的 DMA 请求 (COM DMA Request Enable)<br>0: 禁用<br>1: 使能                                |
| 14  | TRGDEN | R/W | 使能触发 DMA 请求 (Trigger DMA Request Enable)<br>0: 禁用<br>1: 使能                           |
| 15  |        |     | 保留                                                                                   |

#### 14.6.5 状态寄存器 (TMRx\_STS)

偏移地址: 0x10

复位值: 0x0000

| 位/域 | 名称      | R/W   | 描述                                                                                                                                                                                                                                                                                                                                                   |
|-----|---------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | UIFLG   | RC_W0 | 产生更新事件中断标志位 (Update Event Interrupt Generate Flag)<br>0: 没有发生更新事件中断<br>1: 发生更新事件中断<br>计数器数值重新装载或重新初始化时, 会产生更新事件, 该位由硬件置 1, 软件清 0; 更新事件的产生的情况有以下情况:<br>(1) TMRx_CTRL1 寄存器的 UD=0, 重复计数器数值上/下溢时产生更新事件;<br>(2) TMRx_CTRL1 寄存器的 URSSEL=0 和 UD=0, 配置 TMRx_CEG 寄存器的 UEG=1 产生更新事件, 需要通过软件初始化计数器;<br>(3) TMRx_CTRL1 寄存器的 URSSEL=0 和 UD=0, 计数器被触发事件初始化时产生更新事件。 |
| 1   | CC1IFLG | RC_W0 | 捕获/比较通道 1 中断标志 (Capture/Compare Channel1 Interrupt Flag)<br>当捕获比较通道 1 配置为输出时:<br>0: 无匹配发生<br>1: TMRx_CNT 的值与 TMRx_CC1 的值相匹配<br>当捕获比较通道 1 配置为输入时:<br>0: 没有发生输入捕获<br>1: 发生输入捕获<br>捕获事件发生时由硬件置 1, 可以由软件清 0 或者读 TMRx_CC1 寄存器时清 0。                                                                                                                        |

| 位/域   | 名称       | R/W   | 描述                                                                                                                                                                         |
|-------|----------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2     | CC2IFLG  | RC_W0 | 捕获/比较通道 2 中断标志 (Captuer/Compare Channel2 Interrupt Flag)<br>参考 STS_CC1IFLG                                                                                                 |
| 3     | CC3IFLG  | RC_W0 | 捕获/比较通道 3 中断标志 (Captuer/Compare Channel3 Interrupt Flag)<br>参考 STS_CC1IFLG                                                                                                 |
| 4     | CC4IFLG  | RC_W0 | 捕获/比较通道 4 中断标志 (Captuer/Compare Channel4 Interrupt Flag)<br>参考 STS_CC1IFLG                                                                                                 |
| 5     | COMIFLG  | RC_W0 | 产生 COM 事件中断标志 (COM Event Interrupt Generate Flag)<br>0: 无 COM 事件产生<br>1: COM 中断等待响应<br>产生 COM 事件后, 该位由硬件置 1, 软件清 0。                                                        |
| 6     | TRGIFLG  | RC_W0 | 产生触发事件中断标志 (Trigger Event Interrupt Generate Flag)<br>0: 没有发生触发事件中断<br>1: 发生触发事件中断<br>发生触发事件时, 该位由硬件置 1, 软件清 0。                                                            |
| 7     | BRKIFLG  | RC_W0 | 产生刹车事件中断标志 (Brake Event Interrupt Generate Flag)<br>0: 没有发生刹车事件<br>1: 发生刹车事件<br>刹车输入有效的情况下, 该位由硬件置 1; 无效的情况下, 可以通过软件清 0。                                                   |
| 8     |          |       | 保留                                                                                                                                                                         |
| 9     | CC1RCFLG | RC_W0 | 捕获/比较通道 1 重复捕获标志 (Captuer/Compare Channel1 Repetition Capture Flag)<br>0: 没有发生重复捕获<br>1: 发生重复捕获<br>计数器的值被捕获到 TMRx_CC1 寄存器中, 此时 CC1IFLG=1; 只有当通道被配置为输入捕获时, 该位由硬件置 1, 软件清 0。 |
| 10    | CC2RCFLG | RC_W0 | 捕获/比较通道 2 重复捕获标志 (Captuer/Compare Channel2 Repetition Capture Flag)<br>参考 STS_CC1RCFLG                                                                                     |
| 11    | CC3RCFLG | RC_W0 | 捕获/比较通道 3 重复捕获标志 (Captuer/Compare Channel3 Repetition Capture Flag)<br>参考 STS_CC1RCFLG                                                                                     |
| 12    | CC4RCFLG | RC_W0 | 捕获/比较通道 4 重复捕获标志 (Captuer/Compare Channel4 Repetition Capture Flag)<br>参考 STS_CC1RCFLG                                                                                     |
| 15:13 |          |       | 保留                                                                                                                                                                         |

#### 14.6.6 控制事件产生寄存器 (TMRx\_CEG)

偏移地址: 0x14

复位值: 0x0000

| 位/域 | 名称  | R/W | 描述                                      |
|-----|-----|-----|-----------------------------------------|
| 0   | UEG | W   | 产生更新事件 (Update Event Generate)<br>0: 无效 |

| 位/域  | 名称    | R/W | 描述                                                                                                                                                                                                                                                                                                                                                |
|------|-------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |       |     | <p>1: 初始化计数器, 产生更新事件<br/>此位由软件置 1, 硬件清 0。<br/>注意: 产生更新事件时, 预分频器的计数器会清 0, 但是预分频系数不变。如果在向下计数模式下计数器会读取 TMRx_AUTORLD 的值; 如果在中央对齐模式下或者向上计数模式下计数器会被清 0。</p>                                                                                                                                                                                             |
| 1    | CC1EG | W   | <p>产生捕获/比较通道 1 事件 (Capture/Compare Channel1 Event Generation)<br/>0: 无效<br/>1: 产生捕获/比较事件<br/>该位由软件置 1, 硬件自动清 0。<br/>如果通道 1 处于输出模式:<br/>当 CC1IFLG=1 时, 如果设置了 CC1IEN 和 CC1DEN 位, 则产生相应的中断和 DMA 请求。<br/>如果通道 1 处于输入模式:<br/>捕获计数器的值存储在 TMRx_CC1 寄存器中; 配置 CC1IFLG=1, 如果还设置了 CC1IEN 和 CC1DEN 位, 则产生相应的中断和 DMA 请求; 如果此时 CC1IFLG=1, 则需要配置 CC1RCFLG=1。</p> |
| 2    | CC2EG | W   | <p>产生捕获/比较通道 2 事件 (Capture/Compare Channel2 Event Generation)<br/>参考 CC1EG 描述</p>                                                                                                                                                                                                                                                                 |
| 3    | CC3EG | W   | <p>产生捕获/比较通道 3 事件 (Capture/Compare Channel3 Event Generation)<br/>参考 CC1EG 描述</p>                                                                                                                                                                                                                                                                 |
| 4    | CC4EG | W   | <p>产生捕获/比较通道 4 事件 (Capture/Compare Channel4 Event Generation)<br/>参考 CC1EG 描述</p>                                                                                                                                                                                                                                                                 |
| 5    | COMG  | W   | <p>产生捕获/比较控制更新事件 (Capture/Compare Control Update Event Generate)<br/>0: 无效<br/>1: 产生捕获/比较更新事件<br/>该位由软件置 1, 硬件自动清 0。<br/>注意: COMG 位只有在互补输出的通道有效。</p>                                                                                                                                                                                              |
| 6    | TEG   | W   | <p>产生触发事件 (Trigger Event Generate)<br/>0: 无效<br/>1: 产生触发事件<br/>该位由软件置 1, 硬件自动清 0。</p>                                                                                                                                                                                                                                                             |
| 7    | BEG   | W   | <p>产生刹车事件 (Brake Event Generate)<br/>0: 无效<br/>1: 产生刹车事件<br/>该位由软件置 1, 硬件自动清 0。</p>                                                                                                                                                                                                                                                               |
| 15:8 |       |     | 保留                                                                                                                                                                                                                                                                                                                                                |

#### 14.6.7 捕获/比较模式寄存器 1 (TMRx\_CCM1)

偏移地址: 0x18

复位值: 0x0000

可通过 CCxSEL 位配置定时器为输入 (捕获模式) 或输出 (比较模式)。该寄存器其它位的作用在输入和输出模式下不同, 同一个位在输出模式和输入模式下的

功能是不同的。寄存器中的 OC<sub>x</sub> 描述了通道在输出模式下的功能，寄存器中的 IC<sub>x</sub> 描述了通道在输入模式下的功能。

#### 输出比较模式：

| 位/域 | 名称     | R/W | 描述                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|--------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0 | CC1SEL | R/W | <p>选择捕获/比较通道 1 (Capture/Compare Channel1 Selection)<br/> 该位定义了输入/输出的方向以及选择输入引脚。</p> <p>00: CC1 通道为输出<br/> 01: CC1 通道为输入, IC1 映射在 TI1 上<br/> 10: CC1 通道为输入, IC1 映射在 TI2 上<br/> 11: CC1 通道为输入, IC1 映射在 TRC 上, 仅工作在内部触发输入<br/> 注意: 该位仅在通道关闭时 (TMRx_CCEN 寄存器的 CC1EN=0 时) 可写。</p>                                                                                                                                                                                                                                                                        |
| 2   | OC1FEN | R/W | <p>快速使能输出比较通道 1 (Output Compare Channel1 Fast Enable)<br/> 0: 禁用<br/> 1: 使能<br/> 该位用来提高捕获/比较输出对触发输入事件的响应。</p>                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 3   | OC1PEN | R/W | <p>使能输出比较通道 1 预装载 (Output Compare Channel1 Preload Enable)<br/> 0: 禁用预装载功能, 通过程序写入 TMRx_CC1 寄存器的数值, 会马上起作用。<br/> 1: 启用预装载功能, 通过程序写入 TMRx_CC1 寄存器的数值, 会在产生更新事件后起作用。<br/> 注意: 当保护级别为 3 级时且通道配置为输出时, 该位不能被修改。当不确定预装载寄存器情况, 仅在单脉冲模式 (SPMEN=1) 下, 可以使用 PWM 模式, 否则不确定其接下来的输出比较结果。</p>                                                                                                                                                                                                                                                                     |
| 6:4 | OC1MOD | R/W | <p>配置输出比较通道 1 模式 (Output Compare Channel1 Mode Configure)<br/> 000: 冻结。输出比较对 OC1REF 无影响<br/> 001: 匹配时输出置为高。计数器 CNT 的值和捕获比较寄存器的值 CC<sub>x</sub> 生匹配时, 强制 OC1REF 为高电平<br/> 010: 匹配时输出置为低。计数器的值和捕获比较寄存器的值发生匹配时, 强制 OC1REF 为低电平<br/> 011: 匹配时输出翻转。计数器的值和捕获比较寄存器的值发生匹配时, 转 OC1REF 的电平<br/> 100: 强制输出为低。强制 OC1REF 为低电平<br/> 101: 强制输出为高。强制 OC1REF 为高电平<br/> 110: PWM 模式 1 (计数器值&lt;输出比较值时置为高, 否则反之)<br/> 111: PWM 模式 2 (计数器值&gt;输出比较值时置为高, 否则反之)<br/> 注意: 当保护级别为 3 级时且通道配置为输出时, 该位不能被修改。在 PWM 模式 1 和 2 中, OC1REF 电平在比较结果改变或者输出比较模式从冻结模式转换到 PWM 模式时改变。</p> |
| 7   | OC1CEN | R/W | <p>使能输出比较通道 1 清除 (Output Compare Channel1 Clear Enable)<br/> 0: OC1REF 不受 ETRF 输入影响。<br/> 1: 检测到 ETRF 输入高电平时, OC1REF=0</p>                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 9:8 | CC2SEL | R/W | <p>通道 2 模式选择 (Capture/Compare Channel2 Select)<br/> 该位定义了输入/输出的方向以及选择输入引脚。</p> <p>00: CC2 通道为输出<br/> 01: CC2 通道为输入, IC2 映射在 TI2 上<br/> 10: CC2 通道为输入, IC2 映射在 TI1 上<br/> 11: CC2 通道为输入, IC2 映射在 TRC 上, 仅工作在内部触发输入</p>                                                                                                                                                                                                                                                                                                                               |

| 位/域   | 名称     | R/W | 描述                                                    |
|-------|--------|-----|-------------------------------------------------------|
|       |        |     | 注意: 该位仅在通道关闭时 (TMRx_CCEN 寄存器的 CC2EN=0 时) 可写。          |
| 10    | OC2FEN | R/W | 快速使能输出比较通道 2 (Output Compare Channel2 Preload Enable) |
| 11    | OC2PEN | R/W | 使能输出比较通道 2 缓冲 (Output Compare Channel2 Buffer Enable) |
| 14:12 | OC2MOD | R/W | 输出比较通道 2 模式 (Output Compare Channel1 Mode)            |
| 15    | OC2CEN | R/W | 使能输出通道 2 比较清除 (Output Compare Channel2 Clear Enable)  |

#### 输入捕获模式:

| 位/域 | 名称     | R/W | 描述                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----|--------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0 | CC1SEL | R/W | 选择输入/捕获通道 1 (Capture/Compare Channel1 Select)<br>00: CC1 通道为输出<br>01: CC1 通道为输入, IC1 映射在 TI1 上<br>10: CC1 通道为输入, IC1 映射在 TI2 上<br>11: CC1 通道为输入, IC1 映射在 TRC 上, 仅工作在内部触发输入<br>注意: 该位仅在通道关闭时 (TMRx_CCEN 位的 CC1EN=0 时) 可写。                                                                                                                                                                                                                                     |
| 3:2 | IC1PSC | R/W | 配置输入捕获通道 1 预分频因子 (Input Capture Channel1 Prescaler Configuration)<br>00: PSC=1<br>01: PSC=2<br>10: PSC=4<br>11: PSC=8<br>PSC 是预分频因子, 每 PSC 个事件触发一次捕获。                                                                                                                                                                                                                                                                                                        |
| 7:4 | IC1F   | R/W | 配置输入捕获通道 1 滤波器 (Input Capture Channel1 Filter Configuration)<br>0000: 禁用滤波器, 以 $f_{DTs}$ 采样<br>0001: DIV=1, N=2<br>0010: DIV=1, N=4<br>0011: DIV=1, N=8<br>0100: DIV=2, N=6<br>0101: DIV=2, N=8<br>0110: DIV=4, N=6<br>0111: DIV=4, N=8<br>1000: DIV=8, N=6<br>1001: DIV=8, N=8<br>1010: DIV=16, N=5<br>1011: DIV=16, N=6<br>1100: DIV=16, N=8<br>1101: DIV=32, N=5<br>1110: DIV=32, N=6<br>1111: DIV=32, N=8<br>采样频率=定时器时钟频率/DIV; 滤波器长度=N, 表示每 N 个事件产生一个跳变。 |
| 9:8 | CC2SEL | R/W | 选择捕获/比较通道 2 (Capture/Compare Channel2 Select)<br>00: CC2 通道为输出<br>01: CC2 通道为输入, IC2 映射在 TI2 上<br>10: CC2 通道为输入, IC2 映射在 TI1 上                                                                                                                                                                                                                                                                                                                               |

| 位/域   | 名称     | R/W | 描述                                                                                       |
|-------|--------|-----|------------------------------------------------------------------------------------------|
|       |        |     | 11: CC2 通道为输入, IC2 映射在 TRC 上, 仅工作在内部触发输入<br>注意: 该位仅在通道关闭时 (TMRx_CCEN 寄存器的 CC2EN=0 时) 可写。 |
| 11:10 | IC2PSC | R/W | 配置输入捕获通道 2 预分频因子 (Input Capture Channel2 Prescaler Configuration)                        |
| 15:12 | IC2F   | R/W | 配置输入捕获通道 2 滤波器 (Input Capture Channel2 Filter Configuration)                             |

#### 14.6.8 捕获/比较模式寄存器 2 (TMRx\_CCM2)

偏移地址: 0x1C

复位值: 0x0000

参看以上 CCM1 寄存器的描述。

输出比较模式:

| 位/域   | 名称     | R/W | 描述                                                                                                                                                                                                                                                      |
|-------|--------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0   | CC3SEL | R/W | 选择捕获/比较通道 3 (Capture/Compare Channel1 Selection)<br>该位定义了输入/输出的方向以及选择输入引脚。<br>00: CC3 通道为输出<br>01: CC3 通道为输入, IC3 映射在 TI3 上<br>10: CC3 通道为输入, IC3 映射在 TI4 上<br>11: CC3 通道为输入, IC3 映射在 TRC 上, 仅工作在内部触发输入<br>注意: 该位仅在通道关闭时 (TMRx_CCEN 寄存器的 CC3EN=0 时) 可写。 |
| 2     | OC3FEN | R/W | 快速使能输出比较通道 3 (Output Compare Channel3 Fast Enable)<br>0: 禁用<br>1: 使能<br>该位用来提高捕获/比较输出对触发输入事件的响应。                                                                                                                                                        |
| 3     | OC3PEN | R/W | 使能输出比较通道 3 预装载 (Output Compare Channel3 Preload Enable)                                                                                                                                                                                                 |
| 6:4   | OC3MOD | R/W | 配置输出比较通道 3 模式 (Output Compare Channel3 Mode Configure)                                                                                                                                                                                                  |
| 7     | OC3CEN | R/W | 使能输出比较通道 3 清除 (Output Compare Channel3 Clear Enable)<br>0: OC3REF 不受 ETRF 输入影响。<br>1: 检测到 ETRF 输入高电平时, OC1REF=0                                                                                                                                         |
| 9:8   | CC4SEL | R/W | 选择通道 4 模式 (Capture/Compare Channel4 Selection)<br>该位定义了输入/输出的方向以及选择输入引脚。<br>00: CC4 通道为输出<br>01: CC4 通道为输入, IC4 映射在 TI4 上<br>10: CC4 通道为输入, IC4 映射在 TI3 上<br>11: CC4 通道为输入, IC4 映射在 TRC 上, 仅工作在内部触发输入<br>注意: 该位仅在通道关闭时 (TMRx_CCEN 寄存器的 CC4EN=0 时) 可写。   |
| 10    | OC4FEN | R/W | 快速使能输出比较通道 4 (Output Compare Channel4 Preload Enable)                                                                                                                                                                                                   |
| 11    | OC4PEN | R/W | 使能输出比较通道 4 缓冲 (Output Compare Channel4 Buffer Enable)                                                                                                                                                                                                   |
| 14:12 | OC4MOD | R/W | 配置输出比较通道 4 模式 (Output Compare Channel4 Mode Configure)                                                                                                                                                                                                  |
| 15    | OC4CEN | R/W | 使能输出通道 4 比较清除 (Output Compare Channel4 Clear Enable)                                                                                                                                                                                                    |

### 输入捕获模式:

| 位/域   | 名称     | R/W | 描述                                                                                                                                                                                                                         |
|-------|--------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0   | CC3SEL | R/W | 选择输入/捕获通道 3 (Capture/Compare Channel3 Select)<br>00: CC3 通道为输出<br>01: CC3 通道为输入, IC3 映射在 TI3 上<br>10: CC3 通道为输入, IC3 映射在 TI4 上<br>11: CC3 通道为输入, IC3 映射在 TRC 上, 仅工作在内部触发输入<br>注意: 该位仅在通道关闭时 (TMRx_CCEN 寄存器的 CC3EN=0 时) 可写。 |
| 3:2   | IC3PSC | R/W | 配置输入捕获通道 3 预分频因子 (Input Capture Channel3 Prescaler Configuration)<br>00: PSC=1<br>01: PSC=2<br>10: PSC=4<br>11: PSC=8<br>PSC 是预分频因子, 每 PSC 个事件触发一次捕获。                                                                      |
| 7:4   | IC3F   | R/W | 配置输入捕获通道 3 滤波器 (Input Capture Channel3 Filter Configuration)                                                                                                                                                               |
| 9:8   | CC4SEL | R/W | 选择捕获/比较通道 4 (Capture/Compare Channel4 Select)<br>00: CC4 通道为输出<br>01: CC4 通道为输入, IC4 映射在 TI4 上<br>10: CC4 通道为输入, IC4 映射在 TI3 上<br>11: CC4 通道为输入, IC4 映射在 TRC 上, 仅工作在内部触发输入<br>注意: 该位仅在通道关闭时 (TMRx_CCEN 寄存器的 CC4EN=0 时) 可写。 |
| 11:10 | IC4PSC | R/W | 配置输入捕获通道 4 预分频因子 (Input Capture Channel4 Prescaler Configuration)                                                                                                                                                          |
| 15:12 | IC4F   | R/W | 配置输入捕获通道 4 滤波器 (Input Capture Channel4 Filter Configuration)                                                                                                                                                               |

### 14.6.9 捕获/比较使能寄存器 (TMRx\_CCEN)

偏移地址: 0x20

复位值: 0x0000

| 位/域 | 名称     | R/W | 描述                                                                                                                                                                                     |
|-----|--------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | CC1EN  | R/W | 使能捕获/比较通道 1 输出 (Capture/Compare Channel1 Output Enable)<br>捕获/比较通道 1 配置为输出时:<br>0: 禁用输出<br>1: 开启输出<br>捕获/比较通道 1 配置为输入时:<br>该位决定了计数器的值 CNT 是否能捕获进入 TMRx_CC1 寄存器中。<br>0: 禁用捕获<br>1: 开启捕获 |
| 1   | CC1POL | R/W | 配置捕获/比较通道 1 输出极性 (Capture/Compare Channel1 Output Polarity Configure)<br>CC1 通道配置为输出时:<br>0: OC1 高电平有效<br>1: OC1 低电平有效                                                                 |

| 位/域   | 名称      | R/W | 描述                                                                                                                                          |
|-------|---------|-----|---------------------------------------------------------------------------------------------------------------------------------------------|
|       |         |     | CC1 通道配置为输入时：<br>0: 不反相: 在 IC1 的上升沿进行捕获, IC1 作为外部触发器时不反相。<br>1: 反相, 在 IC1 的下降沿进行捕获, IC1 作为外部触发器时反相。<br>注意: 当保护级别为 2 或者 3 时, 该位不能被修改         |
| 2     | CC1NEN  | R/W | 使能捕获/比较通道 1 互补输出 (Capture/Compare Channel1 Complementary Output Enable)<br>0: 禁用<br>1: 开启                                                   |
| 3     | CC1NPOL | R/W | 捕获/比较通道 1 互补输出极性 (Capture/Compare Channel1 Complementary Output Polarity)<br>0: OC1N 高电平有效<br>1: OC1N 低电平有效<br>注意: 当保护级别为 2 或者 3 时, 该位不能被修改 |
| 4     | CC2EN   | R/W | 使能捕获/比较通道 2 输出 (Capture/Compare Channel2 Output Enable)<br>参考 CCEN_CC1EN                                                                    |
| 5     | CC2POL  | R/W | 配置捕获/比较通道 2 输出极性 (Capture/Compare Channel2 Output Polarity Configure)<br>参考 CCEN_CC1POL                                                     |
| 6     | CC2NEN  | R/W | 使能捕获/比较通道 1 互补输出 (Capture/Compare Channel1 Complementary Output Enable)<br>参考 CCEN_CC1NEN                                                   |
| 7     | CC2NPOL | R/W | 配置捕获/比较通道 2 互补输出极性 (Capture/Compare Channel2 Complementary Output Polarity Configure)<br>参考 CCEN_CC1NPOL                                    |
| 8     | CC3EN   | R/W | 使能捕获/比较通道 3 输出 (Capture/Compare Channel3 Output Enable)<br>参考 CCEN_CC1EN                                                                    |
| 9     | CC3POL  | R/W | 配置捕获/比较通道 3 输出极性 (Capture/Compare Channel3 Output Polarity Configure)<br>参考 CCEN_CC1POL                                                     |
| 10    | CC3NEN  | R/W | 使能捕获/比较通道 3 互补输出 (Capture/Compare Channel3 Complementary Output Enable)<br>参考 CCEN_CC1NEN                                                   |
| 11    | CC3NPOL | R/W | 配置捕获/比较通道 3 互补输出极性 (Capture/Compare Channel3 Complementary Output Polarity Configure)<br>参考 CCEN_CC1NPOL                                    |
| 12    | CC4EN   | R/W | 使能捕获/比较通道 4 输出 (Capture/Compare Channel4 Output Enable)<br>参考 CCEN_CC1EN                                                                    |
| 13    | CC4POL  | R/W | 捕获/比较通道 4 输出极性 (Capture/Compare Channel4 Output Polarity)<br>参考 CCEN_CC1POL                                                                 |
| 15:14 |         |     | 保留                                                                                                                                          |

#### 14.6.10 计数器寄存器 (TMRx\_CNT)

偏移地址: 0x24

复位值: 0x0000

| 位/域  | 名称  | R/W | 描述                    |
|------|-----|-----|-----------------------|
| 15:0 | CNT | R/W | 计数器数值 (Counter Value) |

#### 14.6.11 预分频寄存器 (TMRx\_PSC)

偏移地址: 0x28

复位值: 0x0000

| 位/域  | 名称  | R/W | 描述                                                                |
|------|-----|-----|-------------------------------------------------------------------|
| 15:0 | PSC | R/W | 预分频器数值 (Prescaler Value)<br>计数器的时钟频率 (CK_CNT) = fck_PSC / (PSC+1) |

#### 14.6.12 自动重装载寄存器 (TMRx\_AUTORLD)

偏移地址: 0x2C

复位值: 0xFFFF

| 位/域  | 名称      | R/W | 描述                                                   |
|------|---------|-----|------------------------------------------------------|
| 15:0 | AUTORLD | R/W | 自动重装载数值 (Auto Reload Value)<br>自动重装载的值为空时, 计数器不进行计数。 |

#### 14.6.13 重复计数寄存器 (TMRx\_REPCNT)

偏移地址: 0x30

复位值: 0x0000

| 位/域  | 名称     | R/W | 描述                                                                                                             |
|------|--------|-----|----------------------------------------------------------------------------------------------------------------|
| 7:0  | REPCNT | R/W | 重复计数数值 (Repetition Counter Value)<br>当重复计数器计数值减为 0 时产生更新事件, 计数器重新从 REPCNT 数值开始计数; 新写入该寄存器的新值只有在下次周期更新事件发生时才有效。 |
| 15:8 | 保留     |     |                                                                                                                |

#### 14.6.14 通道 1 捕获/比较寄存器 (TMRx\_CC1)

偏移地址: 0x34

复位值: 0x0000

| 位/域  | 名称  | R/W | 描述                                                                                                                                                                                                                                                                                                                                 |
|------|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0 | CC1 | R/W | 捕获/比较通道 1 数值 (Capture/Compare Channel1 Value)<br>捕获/比较通道 1 配置为输入模式:<br>CC1 包含上次输入捕获通道 1 事件传输的计数器数值。<br>捕获/比较通道 1 配置为输出模式:<br>CC1 包含了当前装入捕获/比较寄存器数值<br>捕获比较通道 1 的值 CC1 与计数器的值 CNT 比较, 在 OC1 上产生输出信号。<br>当输出比较预装载禁止 (TMRx_CCM1 寄存器的 OC1PEN=0) 时, 写入的数值会立即影响输出比较结果;<br>当输出比较预装载使能 (TMRx_CCM1 寄存器的 OC1PEN=1) 时, 写入的值会在产生更新事件时影响输出比较结果。 |

#### 14.6.15 通道 2 捕获/比较寄存器 (TMRx\_CC2)

偏移地址: 0x38

复位值: 0x0000

| 位/域  | 名称  | R/W | 描述                                                           |
|------|-----|-----|--------------------------------------------------------------|
| 15:0 | CC2 | R/W | 捕获/比较通道 2 数值 (Capture/Compare Channel2 Value)<br>参考 TMRx_CC1 |

#### 14.6.16 通道 3 捕获/比较寄存器 (TMRx\_CC3)

偏移地址: 0x3C

复位值: 0x0000

| 位/域  | 名称  | R/W | 描述                                                           |
|------|-----|-----|--------------------------------------------------------------|
| 15:0 | CC3 | R/W | 捕获/比较通道 3 数值 (Capture/Compare Channel3 Value)<br>参考 TMRx_CC1 |

#### 14.6.17 通道 4 捕获/比较寄存器 (TMRx\_CC4)

偏移地址: 0x40

复位值: 0x0000

| 位/域  | 名称  | R/W | 描述                                                           |
|------|-----|-----|--------------------------------------------------------------|
| 15:0 | CC4 | R/W | 捕获/比较通道 4 数值 (Capture/Compare Channel4 Value)<br>参考 TMRx_CC1 |

#### 14.6.18 刹车和死区寄存器 (TMRx\_BDT)

偏移地址: 0x44

复位值: 0x0000

注意: 根据锁定设置, AOEN、BRKPOL、BRKEN、IMOS、RMOS 和 DTS[7:0]位均可被写保护, 有必要在第一次写入 TMRx\_BDT 寄存器时对它们进行配置。

| 位/域 | 名称      | R/W | 描述                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----|---------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0 | DTS     | R/W | <p>设置互补输出通道的死区持续时间 (Dead Time Setup)<br/>DT 为死区持续时间, DT 与寄存器 DTS 的关系如下:<br/>DTS[7:5]=0xx=&gt;DT=DTS[7:0]×T<sub>DTS</sub>, T<sub>DTS</sub>=TDTS;<br/>DTS[7:5]=10x=&gt;DT= (64+DTS[5:0]) ×T<sub>DTS</sub>, T<sub>DTS</sub>=2×T<sub>DTS</sub>;<br/>DTS[7:5]=110=&gt;DT= (32+DTS[4:0]) ×T<sub>DTS</sub>, T<sub>DTS</sub>=8×T<sub>DTS</sub>;<br/>DTS[7:5]=111=&gt;DT= (32+DTS[4:0]) ×T<sub>DTS</sub>, T<sub>DTS</sub>=16×T<sub>DTS</sub>;<br/>例: 假设 T<sub>DTS</sub>=125ns (8MHZ), 死区时间设置如下:<br/>若步长时间为 125ns, 可设置死区时间范围是 0 到 15875ns;<br/>若步长时间为 250ns, 可设置死区时间范围是 16us 到 31750ns;<br/>若步长时间为 1us, 可设置死区时间范围是 32us 到 63us;<br/>若步长时间为 2us, 可设置死区时间范围是 64us 到 126us。<br/>注意: 一旦 LOCK 级别 (TMRx_BDT 寄存器中的 LOCKCFG 位) 设为 1、2 或 3, 则不能修改这些位。</p> |
| 9:8 | LOCKCFG | R/W | <p>配置锁定写保护模式 (Lock Write Protection Mode Configuration)<br/>00: 无锁定写保护, 可直接写寄存器<br/>01: 锁定写保护级别 1<br/>不能写入 TMRx_BDT 的 DTS、BRKEN、BRKPOL、AOEN 位和 TMRx_CTRL2 寄存器的 OCxOIS 和 OCxNOIS 位。<br/>10: 锁定写保护级别 2<br/>不能写入保护级别 1 的所有位, 也不能写入 TMRx_CCEN 寄存器中的 CCxPOL 和 OCxNPOL 位、TMRx_BDT 寄存器的 RMOS 和 IMOS 位。<br/>11: 锁定写保护级别 3</p>                                                                                                                                                                                                                                                                                                                                                                                                                  |

| 位/域 | 名称     | R/W | 描述                                                                                                                                                                                                                              |
|-----|--------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |        |     | <p>不能写入保护级别 2 的所有位，也不能写入 TMRx_CCMx 的寄存器的 OCxMOD 和 OCxPEN 位。</p> <p>注意：在系统复位后，只能写一次锁定写保护位。</p>                                                                                                                                   |
| 10  | IMOS   | R/W | <p>配置空闲模式下的关闭状态 (Idle Mode Off-state Configure)</p> <p>空闲模式指 MOEN=0，关闭是指 CCxEN=0；该位描述的是在 MOEN=0，CCxEN 由 0 变为 1，配置该位不同的数值，对输出波形的影响。</p> <p>0: 禁用 OCx/OCxN 输出</p> <p>1: 若 CCxEN =1，先在死区期间输出无效电平 (具体电平数值受极性配置影响)，在死区结束后，输出空闲电平</p> |
| 11  | RMOS   | R/W | <p>配置运行模式下的关闭状态 (Run Mode Off-state Configure)</p> <p>运行模式指 MOEN=1，关闭是指 CCxEN=0；该位描述的是在 MOEN=1，CCxEN 由 0 变为 1 时，配置该位不同的数值，对输出波形的影响。</p> <p>0: 禁用 OCx/OCxN 输出</p> <p>1: OCx/OCxN 先输出无效电平 (具体电平数值受极性配置影响)</p>                     |
| 12  | BRKEN  | R/W | <p>使能刹车功能 (Brake Function Enable)</p> <p>0: 禁用</p> <p>1: 使能</p> <p>注意：当保护级别为 1 时，该位不能修改。</p>                                                                                                                                    |
| 13  | BRKPOL | R/W | <p>配置刹车输入极性 (Brake Polarity Configure)</p> <p>0: 刹车输入 BRK 在低电平有效</p> <p>1: 刹车输入 BRK 在高电平有效</p> <p>注意：当保护级别为 1 时，该位不能被修改。对该位的写操作需要一个 APB 时钟延迟后才能使用。</p>                                                                          |
| 14  | AOEN   | R/W | <p>使能自动输出 (Automatic Output Enable)</p> <p>0: MOEN 只能被软件置 1</p> <p>1: MOEN 可以被软件置 1 或者在下一个更新事件时自动值置 1 (刹车输入无效)</p> <p>注意：当保护级别为 1 时，该位不能修改。</p>                                                                                 |
| 15  | MOEN   | R/W | <p>使能 PWM 主输出 (PWM Main Output Enable)</p> <p>0: 禁用 OCx 和 OCxN 输出或者强制输出空闲状态</p> <p>1: 当设置了 TMRx_CCEN 寄存器的 CCxEN 和 CCxNEN 位，开启 OCx 和 OCxN 输出</p> <p>刹车输入有效时硬件异步清 0。</p> <p>注意：由软件置 1 还是自动置 1 取决于 TMRx_BDT 寄存器的 AOEN 位。</p>       |

#### 14.6.19 DMA 控制寄存器 (TMRx\_DCTRL)

偏移地址: 0x48

复位值: 0x0000

| 位/域 | 名称     | R/W | 描述                                                                                                                                                                                         |
|-----|--------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4:0 | DBADDR | R/W | <p>设置 DMA 基地址 (DMA Base Address Setup)</p> <p>这些位定义了 DMA 在连续模式下的基地址 (当对 TMRx_DMADDR 寄存器进行读或写时)，DBADDR 定义为从 TMRx_CTRL1 寄存器所在地址开始的偏移量：</p> <p>00000: TMRx_CTRL1</p> <p>00001: TMRx_CTRL2</p> |

| 位/域   | 名称    | R/W | 描述                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|-------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |       |     | 00010: TMRx_SMCTRL<br>.....                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 7:5   |       |     | 保留                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 12:8  | DBLEN | R/W | <p>设置 DMA 突发传送长度 (DMA Burst Transfer Length Setup)<br/>         这些位定义 DMA 在连续模式下的传送长度、传输的次数，其中传输的数据可以是 16 位和 8 位。<br/>         当读写 TMRx_DMADDR 寄存器时，定时器进行一次连续传输传送；<br/>         00000: 1 次传输<br/>         00001: 2 次传输<br/>         00010: 3 次传输<br/>         .....<br/>         10001: 18 次传输<br/>         传输的地址公式如下：<br/>         传输的地址=TMRx_CTRL1 的地址 (从地址) +DBADDR+DMA 索引；<br/>         DMA 索引=DBLEN<br/>         例如：DBLEN=7, DBADDR=TMR2_CTRL1 (从地址) 表示待传输数据的地址，则 TMRx_CTRL1 的地址+DBADDR+7，表示了将要写入/读出数据的地址，<br/>         数据的传输将发生在：TMRx_CTRL1 的地址+从 DBADDR 开始的 7 个寄存器。<br/>         根据设置的 DMA 数据长度不同，数据传输也会发生变化：<br/>         (1) 当传输数据设置为 16 位时，数据会传输给 7 个寄存器<br/>         (2) 当传输数据设置为 8 位时，第一个寄存器的数据是第一个的数据的 MSB 位，第二个寄存器的数据是第一个数据的 LSB 位，数据仍然会传输给 7 个寄存器。</p> |
| 15:13 |       |     | 保留                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

#### 14.6.20 连续模式的 DMA 地址寄存器 (TMRx\_DMADDR)

偏移地址: 0x4C

复位值: 0x0000

| 位/域  | 名称     | R/W | 描述                                                                                                                                                                                                                                                                                                                                                      |
|------|--------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0 | DMADDR | R/W | <p>DMA 突发传送寄存器 (DMA Register for Burst Transfer)<br/>         TMRx_DMADDR 寄存器的读或写操作访问会导致对以下地址所在寄存器的存取操作：<br/>         TMRx_CTRL1 地址+ (DBADDR+DMA 索引) ×4<br/>         其中：<br/>         “TMRx_CTRL1 地址”是控制寄存器 1 (TMRx_CTRL1) 所在的地址；<br/>         “DBADDR”是 TMRx_DCTRL 寄存器中定义的基地址；<br/>         “DMA 索引”是由 DMA 自动控制的偏移量，它取决于 TMRx_DCTRL 寄存器中定义的 DBLEN。</p> |

## 15 通用定时器 (TMR2/3/4/5)

### 15.1 简介

通用定时器以时基单元为核心，拥有输入捕获和输出比较等功能，可以用来测量脉冲宽度、频率和占空比，以及产生输出波形。含有一个 32 位的自动重装载计数器（实现向上、向下和中央对齐计数）。

定时器和定时器之间是相互独立的，它们可以实现同步和级联。

### 15.2 主要特征

#### (1) 时基单元

- 计数器：32 位计数器，支持向上、向下和中央对齐计数。
- 预分频器：16 位可编程预分频器
- 自动重装载功能

#### (2) 时钟源选择

- 内部时钟
- 外部输入
- 外部触发
- 内部触发

#### (3) 输入捕获功能

- 计数功能
- PWM 输入
- 编码器接口模式

#### (4) 输出比较功能

- PWM 输出模式
- 强制输出模式
- 单脉冲模式

#### (5) 定时器的主/从模式控制器

- 定时器之间可以同步和级联
- 支持多种从模式、同步信号

#### (6) 中断和 DMA 请求事件

- 更新事件（计数器上/下溢出，计数器初始化）
- 触发事件（计数器启动、停止、内/外部触发）
- 输入捕获
- 输出比较

#### (7) 支持定位用增量（正交）编码器和霍尔传感器电路

## 15.3 结构框图

图 38 通用定时器结构框图



## 15.4 功能描述

### 15.4.1 时钟源选择

通用定时器一共有四种时钟源。

#### 内部时钟

是来自 RCM 的 TMRx\_CLK，即定时器本身的驱动时钟，当禁止从模式控制器，则预分频的时钟源 CK\_PSC 由内部时钟 CK\_INT 驱动。

#### 外部时钟模式 1

来自定时器自身的输入通道 T11/2/3/4，经过极性选择和滤波以后生成的触发信号，连接到从模式控制器，进而控制计数器的工作。其中通道 1 的输入经过上升沿、下降沿双沿检测而生成的脉冲信号进行逻辑相或以后的信号就是 T11F\_ED 信号，即 T1F\_ED 双边沿信号。特别的是 PWM 输入只能由 T11/2 输入。

#### 外部时钟模式 2

来自于外部触发接口（ETR）经过极性选择、分频、滤波以后的信号，经过触发输入选择器，连接到从模式控制器，从而控制计数器的工作。

### 内部触发输入

设置定时器工作于从模式，时钟源为其他定时器的输出信号，此时钟源没有滤波，可以实现定时器之间的同步或级联。主模式的定时器可以对从模式定时器执行复位、启动、停止或提供时钟。

#### 15.4.2 时基单元

通用定时器里的时基单元包含三个寄存器：

- 32 位计数器寄存器（CNT）
- 32 位自动重装载寄存器（AUTORLD）
- 16 位预分频寄存器（PSC）

### 计数器 CNT

通用定时器中的计数器中一共有三种计数模式：

- 向上计数模式
- 向下计数模式
- 中央对齐模式

### 向上计数模式

通过配置控制寄存器（TMRx\_CTRL1）中的 CNTDIR 位，设置为向上计数模式。

当计数器处于向上计数模式时，计数器从 0 开始向上计数，当每来一个脉冲计数器就会增加 1，一直到计数器（TMRx\_CNT）值与自动重装载（TMRx\_AUTORLD）的值相等时，计数器会再次从 0 开始计数，此时产生一个计数器向上溢出事件，其中自动重装载的值（TMRx\_AUTORLD）是提前写入的。

当计数器溢出时，会产生更新事件，此时自动重装载的影子寄存器和预分频的缓冲区都将会被更新。可以通过配置控制寄存器 TMRx\_CTRL1 中的 UD 位，禁止更新事件。

下图为向上计数模式下，分频因子为 1 或 2 的时序图：

图 39 向上计数模式下，分频因子为 1 或 2 的时序图



### 向下计数模式

通过配置控制寄存器 (TMRx\_CTRL1) 中的 CNTDIR 位，设置为向下计数模式。

当计数器处于向下计数模式时，计数器从自动重装载的值 (TMRx\_AUTORLD) 开始向下计数，当每来一个脉冲计数器就会减 1，一直减到 0 时，计数器会重新从 (TMRx\_AUTORLD) 开始计数，与此同时便会产生一个计数器向下溢出事件，自动重装载的值 (TMRx\_AUTORLD) 是提前写入的。

计数器溢出时，会产生更新事件，此时，自动重装载的影子寄存器和预分频的缓冲区都将会被更新。可以配置 TMRx\_CTRL1 寄存器中的 UD 位，禁止更新事件。

图 40 向下计数模式下，分频因子为 1 或 2 的时序图



### 中央对齐模式

通过配置控制寄存器 (TMRx\_CTRL1) 中的 CAMSEL 位，设置为中央对齐模式。

当计数器处于中央对齐模式时，计数器从 0 开始向上计数到自动重装载的值 (TMRx\_AUTORLD)，然后从自动重装载的值 (TMRx\_AUTORLD) 再向下计数到 0，以此往复。在向上计数时，当计数器的值为 (AUTORLD-1) 时会产生一个计数器上溢事件；在向下计数时，计数器的值为 1 时会产生一个计数器下溢事件。

图 41 中央对齐模式下，分频因子为 1 或 2 的时序图



### 预分频器 PSC

预分频器是 16 位的且是可编程的，它可以将计数器的时钟频率进行 1~65536 之间任意值的分频（由 **TMRx\_PSC** 寄存器控制），经过分频后的时钟将会驱动计数器 **CNT** 计数。预分频器带有缓冲器，它能够在运行中被改变。

#### 15.4.3 输入捕获

##### 输入捕获通道

通用定时器有四个独立的捕获/比较独立通道，每一个捕获/比较的通道都围绕着一个捕获/比较寄存器。

在输入捕获中，被测量的信号会从定时器的外部引脚 **T1/2/3/4** 进入首先经过边沿检测器和输入滤波器，然后进入捕获通道，每个捕获通道都有相对应的捕获寄存器，当发生捕获时，计数器 **CNT** 的值将会被锁存在捕获寄存器 **CCx** 中。在进入捕获寄存器之前，信号还会经过预分频器，用于设定经过多少事件进行一次捕获。

##### 输入捕获应用

输入捕获用来捕获外部事件，并且可以赋予时间标记表明事件的发生时刻，可以测量脉冲跳变沿事件（测量频率或者脉宽），如：在输入引脚上如果出现了被选择的边沿，**TMRx\_CCx** 寄存器会捕获计数器当前的值，同时状态寄存器 **TMRx\_STS** 的 **CCxIFLG** 位被置 1，如果 **CCxIEN=1**，便会产生中断。

捕获模式下可以测量一个波形的时序、频率、周期和占空比。在输入捕获模式中将边沿选择设定为上升沿检测，当捕获通道出现上升沿时，发生第一次捕获，此时计数器 **CNT** 的值会被锁存在捕获寄存器 **CCx** 中，同时会进入捕获中断，在中断服务程序中记录一次捕获，记下此时的值，当检测到下一个上升沿时，发生第二次捕获，计数器 **CNT** 的值会再次锁存在捕获寄存器 **CCx** 中，此时再次进入捕获中断，读取捕获寄存器的值，通过捕获就会得出此脉冲信号的周期。

#### 15.4.4 输出比较

输出比较一共有八种模式：冻结、匹配时通道 x 为有效电平、匹配时通道 x 为无效电平、翻转、强制为无效、强制为有效、**PWM** 模式 1 和 **PWM** 模式 2。由 **TMRx\_CCMx** 寄存器中的 **OCxMOD** 位配置，在输出比较模式中可以控制输出信号的波形。

##### 输出比较应用

输出比较模式中，定时器产生脉冲的位置、极性、频率和时间都是可以控制的。

当计数器的值和捕获/比较寄存器的值相等时，通过配置 **TMRx\_CCMx** 寄存器中的 **OCxMOD** 位和输出极性 **TMRx\_CCEN** 寄存器中的 **CCxPOL** 位，通道的输出可以被置高电平、低电平或者翻转。

在 **TMRx\_STS** 寄存器中的 **CCxIFLG=1** 时，如果 **TMRx\_DIEN** 寄存器中的 **CCxIEN=1** 产生中断；**TMRx\_CTRL2** 寄存器中的 **CCDSEL=1** 产生 DMA 请求。

#### 15.4.5 PWM 输出模式

**PWM** 模式是定时器对外输出可以调节的脉冲信号，其中信号的脉宽是由比较寄存器 **CCx** 的值决定，周期是由自动重装载 **AUTORLD** 的值决定。

**PWM** 输出模式分为 **PWM** 模式 1 和 **PWM** 模式 2；**PWM** 模式 1 和 **PWM** 模式 2 分为向上计数和向下计数和中央对齐计数；**PWM** 模式 1 中如果计数器 **CNT** 的值小于比较寄存器 **CCx** 的值，输出有效电平，否则反之。

设置 **CCx=5**, **AUTORLD=7**, 在 **PWM** 模式 1 下的时序图：

图 42 PWM1 向上计数模式的时序图



图 43 PWM1 向下计数模式的时序图



图 44 PWM1 中央对齐模式的时序图



PWM 模式 2 中如果计数器 CNT 的值小于比较寄存器 CCx 的值，输出无效电平，否则反之。

设置 CCx=5, AUTORLD=7, 在 PWM 模式 2 下的时序图：

图 45 PWM2 向上计数模式的时序图



图 46 PWM2 向下计数模式的时序图



图 47 PWM2 中央对齐模式的时序图



#### 15.4.6 PWM 输入模式

PWM 输入模式是输入捕获的一个特例。

PWM 输入模式，只有 TI1FP1、TI1FP2 连接到了从模式控制器，所以只能从通道 TMRx\_CH1 和 TMRx\_CH2 输入，且需要占用 CH1、CH2 的捕获寄存器。

在 PWM 输入模式中，PWM 信号从 TMRx\_CH1 进入，信号会被分成两路，一路可以测量周期，一路可以测量占空比。在配置中只需设置其中一路的极性，另一

路会自动配置会相反的极性。

在此模式中，从模式控制器要配置成复位模式（**TMRx\_SMCTRL** 寄存器的 **SMFSEL** 位）。

图 48 PWM 输入模式时序图



#### 15.4.7 单脉冲模式

单脉冲模式是定时器比较输出中一种特殊情况，也是 PWM 输出模式的特例。

设置 **TMRx\_CTRL1** 寄存器的 **SPMEN** 位选择单脉冲模式，计数器启动后，在未发生更新事件之前有一定个数的脉冲输出，当发生更新事件后计数器停止计数，后续不再有变化的 PWM 波形输出。

单脉冲模式通过程序在一定可控延迟后，产生一个脉宽可控的脉冲，延时时间为 **TMRx\_CCx** 寄存器的值定义。在增计数模式下延时时间为 **CCx**，脉冲宽度为 **AUTORLD-CCx**；在减计数模式下延时时间为 **AUTORLD-CCx**，脉冲宽度为 **CCx**。

图 49 单脉冲模式下的时序图



#### 15.4.8 强制输出模式

强制输出模式下无视比较结果，直接根据配置指令输出相应电平。

- TMRx\_CCMx 寄存器的 CCxSEL=00，设定 CCx 通道为输出。
- TMRx\_CCMx 寄存器的 OCxMOD=100/101，设定强制 OCxREF 信号为无效/有效状态。

在此模式中仍会产生相应的中断和 DMA 请求。

#### 15.4.9 编码器接口模式

编码器接口模式相当于是一个带有方向选择的外部时钟，在编码器接口模式中，计时器的内容可一直指示编码器的位置。

选择编码器接口的方法如下：

- 通过设置 TMRx\_SMCTRL 寄存器的 SMFSEL 位，可以设定计数器是在 TI1 通道/TI2 通道边沿计数，或者同时在 TI1 和 TI2 的边沿计数。
- 通过设置 TMRx\_CCEN 寄存器中的 CC1POL 和 CC2POL 位，可以选择 TI1 和 TI2 的极性。
- 通过设置 TMRx\_CCM1 寄存器中的 IC1F 和 IC2F 位，可以选择是否进行滤波。

两个输入 TI1 和 TI2 可以作为增量编码器的接口，计数器由在 TI1 和 TI2 经过滤波和边沿选择后的信号 TI1FP1 和 TI2FP2 的有效跳变驱动。

根据 TI1 和 TI2 的输入信号，产生计数脉冲和方向信号：

- 根据输入信号的跳变顺序，计数器会向上/向下计数。
- 将控制寄存器 TMRx\_CTRL1 的 CNTDIR 设置为只读（任一输入端的跳变都会重新计算 CNTDIR）。

计数器计数方向改变机制如下图：

表格 66 计数方向与编码器的关系

| 有效边沿    |     | 仅在 TI1 计数 |      | 仅在 TI2 计数 |      | 在 TI1 和 TI2 计数 |      |
|---------|-----|-----------|------|-----------|------|----------------|------|
| 相对信号的电平 |     | 高         | 低    | 高         | 低    | 高              | 低    |
| TI1FP1  | 上升沿 | 向下计数      | 向上计数 | —         |      | 向下计数           | 向上计数 |
|         | 下降沿 | 向上计数      | 向下计数 |           |      | 向上计数           | 向下计数 |
| TI2FP2  | 上升沿 | —         |      | 向上计数      | 向下计数 | 向上计数           | 向下计数 |
|         | 下降沿 |           |      | 向下计数      | 向上计数 | 向下计数           | 向上计数 |

外部的增量编码器可以不用外部接口逻辑直接与 MCU 连接，所以使用比较器将编码器的差动输出转换到数字信号来增加抗噪声干扰。

在下图的实例中：

- 将 IC1FP1 映射到 TI1
- 将 IC2FP2 映射到 TI2
- IC1FP1 和 IC2FP2 都不反相

- 输入信号在上升沿和下降沿有效
- 使能计数器

图 50 编码器模式下的计数器操作实例



例如：当 TI1 处在低电平时，如果 TI2 出现上升沿状态，计数器向上计数。

图 51 IC1FP1 反相的编码器接口模式实例



例如：当 TI1 处于低电平时，TI2 发生上升沿跳变，计数器向下计数。

#### 15.4.10 从模式

TMRx 定时器可以进行外部的触发同步：

- 复位模式
- 门控模式
- 触发模式

可设置 TMRx\_SMCTRL 寄存器中的 SMFSEL 位来选择是哪种模式。

SMFSEL=100 设定复位模式，SMFSEL=101 设定门控模式，SMFSEL=110 设定

触发模式。

复位模式下，在发生一个触发输入事件时，计数器和预分频器会被初始化，选中的触发输入（TRGI）的上升沿重新初始化计数器，并且产生一个更新寄存器的信号。

门控模式下，计数器的使能依赖于选中的输入端的高电平，当触发输入为高时，计数器的时钟开启，一旦触发输入变为低，则计数器停止（但不复位），计数器的启动和停止都是受控制的。

触发模式下，计数器的使能依赖于选中的输入端上的事件，计数器在触发输入的上升沿启动（但不复位），只有计数器的启动是受控制的。

#### 15.4.11 定时器互连

详情见“14.4.14 定时器互连”章节。

#### 15.4.12 中断和 DMA 请求

定时器在工作时产生事件时会发生中断：

- 更新事件（计数器上/下溢出，计数器初始化）
- 触发事件（计数器启动、停止、内/外部触发）
- 捕获/比较事件

其中一些内部中断事件可以产生 DMA 请求，还有专门的接口允许或者禁止触发 DMA 请求。

#### 15.4.13 调试模式

TMR2/3/4/5 可以在调试模式下配置，选择停止还是继续工作，取决于 DBGMCU\_APB1F 寄存器的 TMRx\_STS 位。

#### 15.4.14 在外部事件时清除 OCxREF 信号

此功能是用于输出比较和 PWM 模式。

在一个通道中，用 ETRF 输入端口的高电平将 OCxREF 的信号降为低电平，捕获/比较寄存器 TMRx\_CCMx 中的 OCxCEN 的位置 1，OCxREF 信号会保持为低电平直到下一次发生更新事件。

将 TMRx 置于 PWM 模式，关闭外部触发预分频器，禁止外部触发模式 2。当 ETRF 输入为高时，通过设置 OCxCEN=0，输出的 OCxREF 信号如下图。

图 52 OCxREF 时序图



将 TMRx 置于 PWM 模式，关闭外部触发预分频器，禁止外部触发模式 2，当 ETRF 输入为高时，通过设置 OCxCEN=1，输出的 OCxREF 信号如下图。

图 53 OCxREF 时序图



## 15.5 寄存器地址映射

下表中将通用定时器的所有寄存器映射到一个 16 位可寻址（编址）空间。

表格 67 通用定时器寄存器地址映射

| 寄存器名        | 描述           | 偏移地址 |
|-------------|--------------|------|
| TMRx_CTRL1  | 控制寄存器 1      | 0x00 |
| TMRx_CTRL2  | 控制寄存器 2      | 0x04 |
| TMRx_SMCTRL | 从模式控制寄存器     | 0x08 |
| TMRx_DIEN   | DMA/中断使能寄存器  | 0x0C |
| TMRx_STS    | 状态寄存器        | 0x10 |
| TMRx_CEG    | 控制事件产生寄存器    | 0x14 |
| TMRx_CCM1   | 捕获/比较模式寄存器 1 | 0x18 |
| TMRx_CCM2   | 捕获/比较模式寄存器 2 | 0x1C |
| TMRx_CCEN   | 使能捕获/比较通道寄存器 | 0x20 |
| TMRx_CNT    | 计数器寄存器       | 0x24 |
| TMRx_PSC    | 预分频寄存器       | 0x28 |

| 寄存器名         | 描述              | 偏移地址 |
|--------------|-----------------|------|
| TMRx_AUTORLD | 自动重装载寄存器        | 0x2C |
| TMRx_CC1     | 通道 1 捕获/比较寄存器   | 0x34 |
| TMRx_CC2     | 通道 2 捕获/比较寄存器   | 0x38 |
| TMRx_CC3     | 通道 3 捕获/比较寄存器   | 0x3C |
| TMRx_CC4     | 通道 4 捕获/比较寄存器   | 0x40 |
| TMRx_DCTRL   | DMA 控制寄存器       | 0x48 |
| TMRx_DMADDR  | 连续模式的 DMA 地址寄存器 | 0x4C |
| TMR2_OPT     | TMR2 选项寄存器      | 0x50 |
| TMR5_OPT     | TMR5 选项寄存器      | 0x50 |

## 15.6 寄存器功能描述

### 15.6.1 控制寄存器 1 (TMRx\_CTRL1)

偏移地址: 0x00

复位值: 0x0000

| 位/域 | 名称     | R/W | 描述                                                                                                                                                        |
|-----|--------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | CNTEN  | R/W | 使能计数器 (Counter Enable)<br>0: 禁用<br>1: 使能<br>定时器配置为外部时钟、门控模式和编码器模式时, 需要通过软件对该位写 1 启动定期工作; 配置为触发模式时, 可硬件写 1。                                                |
| 1   | UD     | R/W | 禁止更新 (Update Disable)<br>更新事件可引起 AUTORLD、PSC、CCx 产生更新设置的数值。<br>0: 允许更新事件 (UEV)<br>更新事件可以由以下任一情况产生:<br>计数器溢出/下溢;<br>设置 UEG 位;<br>从模式控制器产生的更新。<br>1: 禁止更新事件 |
| 2   | URSEL  | R/W | 更新请求源 (Update Request Source Select)<br>如果使能了中断或 DMA, 更新事件可产生更新中断或 DMA 请求, 通过该位可选择不同的更新请求源。<br>0: 计数器上溢或下溢<br>设置 UEG 位<br>通过从模式控制器产生的更新<br>1: 计数器上溢或下溢    |
| 3   | SPMEN  | R/W | 使能单脉冲模式 (Single Pulse Mode Enable)<br>产生更新事件时, 可改变通道的输出电平; 在该模式下, 会清除 CNTEN 位, 停止计数器, 后续不再改变通道的输出电平。<br>0: 禁用<br>1: 使能                                    |
| 4   | CNTDIR | R/W | 配置计数器计数方向 (Counter Direction)                                                                                                                             |

| 位/域   | 名称     | R/W | 描述                                                                                                                                                                                                                                                                                                 |
|-------|--------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |        |     | 当计数器配置为中央对齐模式或编码器模式时，该位为只读。<br>0: 向上计数<br>1: 向下计数                                                                                                                                                                                                                                                  |
| 6:5   | CAMSEL | R/W | 选择中央对齐模式 (Center Aligned Mode Select),<br>中央对齐模式下，计数器交替的向上向下计数；否则只向上或向下计数。<br>不同的中央对齐模式，影响输出通道的输出比较中断标志位置 1 的时机；<br>在计数器禁止时 (CNTEN=0) 时，选择中央对齐模式。<br>00: 边沿对齐模式<br>01: 中心对齐模式 1 (在向下计数时，输出通道的输出比较中断标志位置 1)<br>10: 中心对齐模式 2 (在向上计数时，输出通道的输出比较中断标志位置 1)<br>11: 中心对齐模式 3 (在向上/下计数时，输出通道的输出比较中断标志位置 1) |
| 7     | ARPEN  | R/W | TMRx_AUTORLD 寄存器自动重装载缓冲使能 (Auto-reload Preload Enable)<br>禁止缓存区时，程序修改 TMRx_AUTORLD 会立刻修改装入计数器的数值；使能缓存区时，程序修改 TMRx_AUTORLD 会在下一个更新事件修改装入计数器的数值。<br>0: 禁用<br>1: 使能                                                                                                                                   |
| 9:8   | CLKDIV | R/W | 时钟分频系数 (Clock Division)<br>数字滤波器的配置由 CK_INT 提供时钟，通过设置位可调整数字滤波器的采用时钟。<br>00: $t_{DTS}=t_{CK\_INT}$<br>01: $t_{DTS}=2 \times t_{CK\_INT}$<br>10: $t_{DTS}=4 \times t_{CK\_INT}$<br>11: 保留                                                                                                            |
| 15:10 |        |     | 保留                                                                                                                                                                                                                                                                                                 |

### 15.6.2 控制寄存器 2 (TMRx\_CTRL2)

偏移地址: 0x04

复位值: 0x0000

| 位/域 | 名称     | R/W | 描述                                                                                                              |
|-----|--------|-----|-----------------------------------------------------------------------------------------------------------------|
| 2:0 |        |     | 保留                                                                                                              |
| 3   | CCDSEL | R/W | 选择发出捕获/比较的 DMA 请求 (Capture/Compare DMA Select)<br>0: 当发生 CCx 事件时，送出 CCx 的 DMA 请求<br>1: 当发生更新事件时，送出 CCx 的 DMA 请求 |

| 位/域  | 名称     | R/W | 描述                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|--------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6:4  | MMSEL  | R/W | <p>选择定时器主模式下用于 TRGO 的信号 (Master Mode Signal Select)</p> <p>工作在主模式的定时器的信号可用于 TRGO, 从而影响处在从模式且与主定时器级联的定时器工作, 具体影响可从模式的定时器配置有关。</p> <p>000: 复位, 主模式定时器的复位信号用于 TRGO<br/> 001: 使能, 主模式定时器的计数器使能信号用于 TRGO<br/> 010: 更新, 主模式定时器的更新事件用于 TRGO<br/> 011: 比较脉冲, 主模式定时器捕获/比较成功 (CCxIFLG=1) 时输出一个脉冲信号用于 TRGO<br/> 100: 比较模式 1, OC1REF 用于触发 TRGO<br/> 101: 比较模式 2, OC2REF 用于触发 TRGO<br/> 110: 比较模式 3, OC3REF 用于触发 TRGO<br/> 111: 比较模式 4, OC4REF 用于触发 TRGO</p> |
| 7    | TI1SEL | R/W | <p>TI1 选择 (Timer Input 1 Selection)</p> <p>0: TMRx_CH1 引脚连到 TI1 输入<br/> 1: TMRx_CH1、TMRx_CH2 和 TMRx_CH3 引脚经异或后连到 TI1 输入</p>                                                                                                                                                                                                                                                                                                                     |
| 15:8 |        |     | 保留                                                                                                                                                                                                                                                                                                                                                                                                                                              |

### 15.6.3 从模式控制寄存器 (TMRx\_SMCTRL)

偏移地址: 0x08

复位值: 0x0000

| 位/域 | 名称     | R/W | 描述                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|--------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0 | SMFSEL | R/W | <p>选择从模式功能 (Slave Mode Function Select)</p> <p>000: 禁用从模式, 定时器可作为主模式定时器影响从模式定时器的工作; 如果 CTRL1_CNTEN=1, 则预分频器直接由内部时钟驱动。</p> <p>001: 编码器模式 1, 根据 TI1FP1 的电平, 计数器在 TI2FP2 的边沿计数。</p> <p>010: 编码器模式 2, 根据 TI2FP2 的电平, 计数器在 TI1FP1 的边沿计数。</p> <p>011: 编码器模式 3, 根据另一个信号的输入电平, 计数器在 TI1FP1、TI2FP2 的边沿计数。</p> <p>100: 复位模式, 从模式定时器在收到 TRGI 的上升沿信号后复位计数器, 并产生更新寄存器的信号。</p> <p>101: 门控模式, 从模式定时器在收到 TRGI 高电平信号时, 启动计数器工作; 收到 TRGI 低电平时停止计数器工作; 再收到 TRGI 高电平信号时, 继续工作; 整个期间不复位计数器。</p> <p>110: 触发模式, 从模式定时器在收到 TRGI 的上升沿信号后, 启动计数器工作。</p> <p>111: 外部时钟模式 1, 选择 TRGI 的上升沿信号作为时钟源驱动计数器工作。</p> |
| 3   |        |     | 保留                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 6:4 | TRGSEL | R/W | <p>选择触发输入信号 (Trigger Input Signal Select)</p> <p>为了避免在改变该位值时产生错误的边沿检测, 须在 SMFSEL=0 时改变。</p> <p>000: 内部触发 ITR0<br/> 001: 内部触发 ITR1</p>                                                                                                                                                                                                                                                                                                                                                                                                                                           |

| 位/域   | 名称     | R/W | 描述                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------|--------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |        |     | 010: 内部触发 ITR2<br>011: 内部触发 ITR3<br>100: 通道 1 输入边沿检测器 TIF_ED<br>101: 通道 1 滤波后定时器输入 TI1FP1<br>110: 通道 2 滤波后的定时器输入 TI2FP2<br>111: 外部触发输入 (ETRF)                                                                                                                                                                                                                                                                                              |
| 7     | MSMEN  | R/W | 使能主/从模式 (Master/slave Mode Enable)<br>0: 无效<br>1: 使能主/从模式                                                                                                                                                                                                                                                                                                                                                                                  |
| 11:8  | ETFCFG | R/W | 配置外部触发滤波器 (External Trigger Filter Configure)<br>0000: 禁用滤波器, 以 $f_{DTs}$ 采样<br>0001: DIV=1, N=2<br>0010: DIV=1, N=4<br>0011: DIV=1, N=8<br>0100: DIV=2, N=6<br>0101: DIV=2, N=8<br>0110: DIV=4, N=6<br>0111: DIV=4, N=8<br>1000: DIV=8, N=6<br>1001: DIV=8, N=8<br>1010: DIV=16, N=5<br>1011: DIV=16, N=6<br>1100: DIV=16, N=8<br>1101: DIV=32, N=5<br>1110: DIV=32, N=6<br>1111: DIV=32, N=8<br>采样频率=定时器时钟频率/DIV; 滤波长度=N, 每 N 个事件产生一个跳变。 |
| 13:12 | ETPCFG | R/W | 配置外部触发信号预分频器 (External Trigger Prescaler Configure)<br>ETR (外部触发输入) 的信号经过分频后为 ETRP, ETRP 的信号频率最多是 TMRxCLK 频率的 1/4; 当 ETR 频率过高时, 须经过分频降低 ETRP 的频率。<br>00: 禁用预分频器<br>01: ETR 信号 2 分频<br>10: ETR 信号 4 分频<br>11: ETR 信号 8 分频                                                                                                                                                                                                                   |
| 14    | ECEN   | R/W | 使能外部时钟模式 2 (External Clock Enable Mode2)<br>0: 禁用<br>1: 使能<br>设置 ECEN 位与选择外部时钟模式 1 将 TRG1 连接到 ETRF 具有相同作用; 从模式 (复位、门控、触发) 可以与外部时钟模式 2 同时使用, 但此时 TRGI 不能连到 ETRF; 当外部时钟模式 1 和外部时钟模式 2 同时使能时, 外部时钟的输入是 ETRF。                                                                                                                                                                                                                                  |
| 15    | ETPOL  | R/W | 配置外部触发极性 (External Trigger Polarity Configure)<br>该位决定外部触发 ETR 是否反相。<br>0: 外部触发 ETR 不反相, 高电平或上升沿有效<br>1: 外部触发 ETR 反相, 低电平或下降沿有效                                                                                                                                                                                                                                                                                                            |

表格 68 TMRx 内部触发连接

| 从定时器 | ITR0 (TS=000) | ITR1 (TS=001) | ITR2 (TS=010) | ITR3 (TS=011) |
|------|---------------|---------------|---------------|---------------|
| TMR2 | TMR1          | TMR8          | TMR3          | TMR4          |
| TMR3 | TMR1          | TMR2          | TMR5          | TMR4          |
| TMR4 | TMR1          | TMR2          | TMR3          | TMR8          |
| TMR5 | TMR2          | TMR3          | TMR4          | TMR8          |

#### 15.6.4 DMA/中断使能寄存器 (TMRx\_DIEN)

偏移地址: 0x0C

复位值: 0x0000

| 位/域 | 名称     | R/W | 描述                                                                                   |
|-----|--------|-----|--------------------------------------------------------------------------------------|
| 0   | UIEN   | R/W | 使能更新中断 (Update Interrupt Enable)<br>0: 禁用<br>1: 使能                                   |
| 1   | CC1IEN | R/W | 使能捕获/比较通道 1 中断 (Capture/Campare Channel1 Interrupt Enable)<br>0: 禁用<br>1: 使能         |
| 2   | CC2IEN | R/W | 使能捕获/比较通道 2 中断 (Capture/Campare Channel2 Interrupt Enable)<br>0: 禁用<br>1: 使能         |
| 3   | CC3IEN | R/W | 使能捕获/比较通道 3 中断 (Capture/Campare Channel3 Interrupt Enable)<br>0: 禁用<br>1: 使能         |
| 4   | CC4IEN | R/W | 使能捕获/比较通道 4 中断 (Capture/Campare Channel4 Interrupt Enable)<br>0: 禁用<br>1: 使能         |
| 5   |        |     | 保留                                                                                   |
| 6   | TRGIEN | R/W | 使能触发中断 (Trigger Interrupt Enable)<br>0: 禁用<br>1: 使能                                  |
| 7   |        |     | 保留                                                                                   |
| 8   | UDIEN  | R/W | 使能更新的 DMA 请求 (Update DMA Request Enable)<br>0: 禁用<br>1: 使能                           |
| 9   | CC1DEN | R/W | 使能捕获/比较通道 1 的 DMA 请求 (Capture/Campare Channel1 DMA Request Enable)<br>0: 禁用<br>1: 使能 |
| 10  | CC2DEN | R/W | 使能捕获/比较通道 2 的 DMA 请求 (Capture/Campare Channel2 DMA Request Enable)<br>0: 禁用          |

| 位/域 | 名称     | R/W | 描述                                                                                   |
|-----|--------|-----|--------------------------------------------------------------------------------------|
|     |        |     | 1: 使能                                                                                |
| 11  | CC3DEN | R/W | 使能捕获/比较通道 3 的 DMA 请求 (Capture/Compare Channel3 DMA Request Enable)<br>0: 禁用<br>1: 使能 |
| 12  | CC4DEN | R/W | 使能捕获/比较通道 4 的 DMA 请求 (Capture/Compare Channel4 DMA Request Enable)<br>0: 禁用<br>1: 使能 |
| 13  |        |     | 保留                                                                                   |
| 14  | TRGDEN | R/W | 使能触发 DMA 请求 (Trigger DMA Request Enable)<br>0: 禁用<br>1: 使能                           |
| 15  |        |     | 保留                                                                                   |

### 15.6.5 状态寄存器 (TMRx\_STS)

偏移地址: 0x10

复位值: 0x0000

| 位/域 | 名称      | R/W   | 描述                                                                                                                                                                                                                                                                                                                                         |
|-----|---------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | UIFLG   | RC_W0 | 产生更新事件中断标志位 (Update Event Interrupt Generate Flag)<br>0: 没有发生更新事件中断<br>1: 发生更新事件中断<br>计数器数值重新装载或重新初始化时, 会产生更新事件, 该位由硬件置 1, 软件清 0; 更新事件的产生的情况有以下情况:<br>(1) TMRx_CTRL1 寄存器的 UD=0, 上/下溢时产生更新事件;<br>(2) TMRx_CTRL1 寄存器的 URSEL=0 和 UD=0, 配置 TMRx_CEG 寄存器的 UG=1 产生更新事件, 需要通过软件初始化计数器;<br>(3) TMRx_CTRL1 寄存器的 URSEL=0 和 UD=0, 计数器被触发事件初始化时产生更新事件。 |
| 1   | CC1IFLG | RC_W0 | 捕获/比较通道 1 中断标志 (Captuer/Compare Channel1 Interrupt Flag)<br>当捕获比较通道 1 配置为输出时:<br>0: 无匹配发生<br>1: TMRx_CNT 的值与 TMRx_CC1 的值相匹配<br>当捕获比较通道 1 配置为输入时:<br>0: 没有发生输入捕获<br>1: 发生输入捕获<br>捕获事件发生时由硬件置 1, 可以由软件清 0 或者读 TMRx_CC1 寄存器时清 0。                                                                                                              |
| 2   | CC2IFLG | RC_W0 | 捕获/比较通道 2 中断标志 (Captuer/Compare Channel2 new Interrupt Flag)<br>参考 STS_CC1IFLG                                                                                                                                                                                                                                                             |

| 位/域   | 名称       | R/W   | 描述                                                                                                                                                                                                    |
|-------|----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3     | CC3IFLG  | RC_W0 | 捕获/比较通道 3 中断标志 (Captuer/Compare Channel3 Interrupt Flag)<br>参考 <code>STS_CC1IFLG</code>                                                                                                               |
| 4     | CC4IFLG  | RC_W0 | 捕获/比较通道 4 中断标志 (Captuer/Compare Channel4 Interrupt Flag)<br>参考 <code>STS_CC1IFLG</code>                                                                                                               |
| 5     |          |       | 保留                                                                                                                                                                                                    |
| 6     | TRGIFLG  | RC_W0 | 产生触发事件中断标志 (Trigger Event Interrupt Generate Flag)<br>0: 没有发生触发事件中断<br>1: 发生触发事件中断<br>发生触发事件时, 该位由硬件置 1, 软件清 0。                                                                                       |
| 8:7   |          |       | 保留                                                                                                                                                                                                    |
| 9     | CC1RCFLG | RC_W0 | 捕获/比较通道 1 重复捕获标志 (Captuer/Compare Channel1 Repetition Capture Flag)<br>0: 没有发生重复捕获<br>1: 发生重复捕获<br>计数器的值被捕获到 <code>TMRx_CC1</code> 寄存器中, 此时 <code>CC1IFLG=1</code> ; 只有当通道被配置为输入捕获时, 该位由硬件置 1, 软件清 0。 |
| 10    | CC2RCFLG | RC_W0 | 捕获/比较通道 2 重复捕获标志 (Captuer/compare Channel2 Repetition Capture Flag)<br>参考 <code>STS_CC1RCFLG</code>                                                                                                   |
| 11    | CC3RCFLG | RC_W0 | 捕获/比较通道 3 重复捕获标志 (Captuer/compare Channel3 Repetition Capture Flag)<br>参考 <code>STS_CC1RCFLG</code>                                                                                                   |
| 12    | CC4RCFLG | RC_W0 | 捕获/比较通道 4 重复捕获标志 (Captuer/compare Channel4 Repetition Capture Flag)<br>参考 <code>STS_CC1RCFLG</code>                                                                                                   |
| 15:13 |          |       | 保留                                                                                                                                                                                                    |

### 15.6.6 控制事件产生寄存器 (`TMRx_CEG`)

偏移地址: 0x14

复位值: 0x0000

| 位/域 | 名称    | R/W | 描述                                                                                                                                                                                                       |
|-----|-------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | UEG   | W   | 产生更新事件 (Update Event Generate)<br>0: 无效<br>1: 初始化计数器, 产生更新事件<br>此位由软件置 1, 硬件清 0。<br>注意: 产生更新事件时, 预分频器的计数器会清 0, 但是预分频系数不变。<br>如果在向下计数模式下计数器会读取 <code>TMRx_AUTORLD</code> 的值; 如果在中央对齐模式下或者向上计数模式中计数器会被清 0。 |
| 1   | CC1EG | W   | 产生捕获/比较通道 1 事件 (Capture/Compare Channel1 Event Generation)<br>0: 无效                                                                                                                                      |

| 位/域  | 名称    | R/W | 描述                                                                                                                                                                                                                                                                     |
|------|-------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |       |     | <p>1: 产生捕获/比较事件<br/>该位由软件置 1, 硬件自动清 0。<br/>如果通道 1 处于输出模式<br/>当 CC1IFLG=1 时, 如果设置了 CC1IEN 和 CC1DEN 位, 则产生相应的中断和 DMA 请求。<br/>如果通道 1 处于输入模式<br/>捕获计数器的值存储在 TMRx_CC1 寄存器中; 配置 CC1IFLG=1, 如果还设置了 CC1IEN 和 CC1DEN 位, 则产生相应的中断和 DMA 请求; 如果此时 CC1IFLG=1, 则需要配置 CC1RCFLG=1。</p> |
| 2    | CC2EG | W   | <p>产生捕获/比较通道 2 事件 (Capture/Compare Channel2 Event Generation)<br/>参考 CC1EG 描述</p>                                                                                                                                                                                      |
| 3    | CC3EG | W   | <p>产生捕获/比较通道 3 事件 (Capture/Compare Channel3 Event Generation)<br/>参考 CC1EG 描述</p>                                                                                                                                                                                      |
| 4    | CC4EG | W   | <p>产生捕获/比较通道 4 事件 (Capture/Compare Channel4 Event Generation)<br/>参考 CC1EG 描述</p>                                                                                                                                                                                      |
| 5    |       |     | 保留                                                                                                                                                                                                                                                                     |
| 6    | TEG   | W   | <p>产生触发事件 (Trigger Event Generate)<br/>0: 无效<br/>1: 产生触发事件<br/>该位由软件置 1, 硬件自动清 0。</p>                                                                                                                                                                                  |
| 15:7 |       |     | 保留                                                                                                                                                                                                                                                                     |

### 15.6.7 捕获/比较模式寄存器 1 (TMRx\_CCM1)

偏移地址: 0x18

复位值: 0x0000

可通过 CCxSEL 位配置定时器为输入（捕获模式）或输出（比较模式）。该寄存器其它位的作用在输入和输出模式下不同，同一个位在输出模式和输入模式下的功能是不同的。寄存器中的 OCx 描述了通道在输出模式下的功能，寄存器中的 Icx 描述了通道在输入模式下的功能。

**输出比较模式:**

| 位/域 | 名称     | R/W | 描述                                                                                                                                                                                                                                                                   |
|-----|--------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0 | CC1SEL | R/W | <p>选择捕获/比较通道 1 (Capture/Compare Channel1 Selection)<br/>该位定义了输入/输出的方向以及选择输入引脚。<br/>00: CC1 通道为输出<br/>01: CC1 通道为输入, IC1 映射在 TI1 上<br/>10: CC1 通道为输入, IC1 映射在 TI2 上<br/>11: CC1 通道为输入, IC1 映射在 TRC 上, 仅工作在内部触发输入<br/>注意: 该位仅在通道关闭时 (TMRx_CCEN 寄存器的 CC1EN=0 时) 可写。</p> |
| 2   | OC1FEN | R/W | <p>快速使能输出比较通道 1 (Output Compare Channel1 Fast Enable)<br/>0: 禁用<br/>1: 使能<br/>该位用来提高捕获/比较输出对触发输入事件的响应。</p>                                                                                                                                                           |

| 位/域   | 名称     | R/W | 描述                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|--------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3     | OC1PEN | R/W | <p>使能输出比较通道 1 预装载 (Output Compare Channel1 Preload Enable)</p> <p>0: 禁用预装载功能, 通过程序写入 <code>TMRx_CC1</code> 寄存器的数值, 会马上起作用。</p> <p>1: 启用预装载功能, 通过程序写入 <code>TMRx_CC1</code> 寄存器的数值, 会在产生更新事件后起作用。</p> <p>注意: 当保护级别为 3 级时且通道配置为输出时, 该位不能被修改。当不确定预装载寄存器情况, 仅在单脉冲模式 (<code>SPMEN=1</code>) 下, 可以使用 PWM 模式, 否则不确定其接下来的输出比较结果。</p>                                                                                                                                                                                                                                                                                                                                                      |
| 6:4   | OC1MOD | R/W | <p>配置输出比较通道 1 模式 (Output Compare Channel1 Mode Configure)</p> <p>000: 冻结。输出比较对 <code>OC1REF</code> 无影响</p> <p>001: 匹配时输出置为高。计数器 <code>CNT</code> 的值和捕获比较寄存器的值 <code>CCx</code> 发生匹配时, 强制 <code>OC1REF</code> 为高电平</p> <p>010: 匹配时输出置为低。计数器的值和捕获比较寄存器的值发生匹配时, 强制 <code>OC1REF</code> 为低电平</p> <p>011: 匹配时输出翻转。计数器的值和捕获比较寄存器的值发生匹配时, 翻转 <code>OC1REF</code> 的电平</p> <p>100: 强制输出为低。强制 <code>OC1REF</code> 为低电平</p> <p>101: 强制输出为高。强制 <code>OC1REF</code> 为高电平</p> <p>110: PWM 模式 1 (计数器值&lt;输出比较值时置为高, 否则反之)</p> <p>111: PWM 模式 2 (计数器值&gt;输出比较值时置为高, 否则反之)</p> <p>注意: 当保护级别为 3 级时且通道配置为输出时, 该位不能被修改。在 PWM 模式 1 和 2 中, <code>OC1REF</code> 电平在比较结果改变或者输出比较模式从冻结模式转换到 PWM 模式时改变。</p> |
| 7     | OC1CEN | R/W | <p>使能输出比较通道 1 清除 (Output Compare Channel1 Clear Enable)</p> <p>0: <code>OC1REF</code> 不受 <code>ETRF</code> 输入影响。</p> <p>1: 检测到 <code>ETRF</code> 输入高电平时, <code>OC1REF=0</code></p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 9:8   | CC2SEL | R/W | <p>通道 2 模式选择 (Capture/Compare Channel2 Select)</p> <p>该位定义了输入/输出的方向以及选择输入引脚。</p> <p>00: CC2 通道为输出</p> <p>01: CC2 通道为输入, IC2 映射在 TI2 上</p> <p>10: CC2 通道为输入, IC2 映射在 TI1 上</p> <p>11: CC2 通道为输入, IC2 映射在 TRC 上, 仅工作在内部触发输入</p> <p>注意: 该位仅在通道关闭时 (<code>TMRx_CCEN</code> 寄存器的 <code>CC2EN=0</code> 时) 可写。</p>                                                                                                                                                                                                                                                                                                                                                                       |
| 10    | OC2FEN | R/W | 快速使能输出比较通道 2 (Output Compare Channel2 Preload Enable)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 11    | OC2PEN | R/W | 使能输出比较通道 2 缓冲 (Output Compare Channel2 Buffer Enable)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 14:12 | OC2MOD | R/W | 输出比较通道 2 模式 (Output Compare Channel2 Mode)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 15    | OC2CEN | R/W | 使能输出通道 2 比较清除 (Output Compare Channel2 Clear Enable)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

#### 输入捕获模式:

| 位/域 | 名称     | R/W | 描述                                                                                                                                                                                                |
|-----|--------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0 | CC1SEL | R/W | <p>选择输入/捕获通道 1 (Capture/Compare Channel1 Select)</p> <p>00: CC1 通道为输出</p> <p>01: CC1 通道为输入, IC1 映射在 TI1 上</p> <p>10: CC1 通道为输入, IC1 映射在 TI2 上</p> <p>11: CC1 通道为输入, IC1 映射在 TRC 上, 仅工作在内部触发输入</p> |

| 位/域   | 名称     | R/W | 描述                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|--------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |        |     | 注意: 该位仅在通道关闭时 (TMRx_CCEN 寄存器的 CC1EN=0 时) 可写。                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 3:2   | IC1PSC | R/W | 配置输入捕获通道 1 预分频因子 (Input Capture Channel1 Perscaler Configure)<br>00: PSC=1<br>01: PSC=2<br>10: PSC=4<br>11: PSC=8<br>PSC 是预分频因子, 每 PSC 个事件触发一次捕获。                                                                                                                                                                                                                                                                                                            |
| 7:4   | IC1F   | R/W | 配置输入捕获通道 1 滤波器 (Input Capture Channel1 Filter Configuration)<br>0000: 禁用滤波器, 以 $f_{DTs}$ 采样<br>0001: DIV=1, N=2<br>0010: DIV=1, N=4<br>0011: DIV=1, N=8<br>0100: DIV=2, N=6<br>0101: DIV=2, N=8<br>0110: DIV=4, N=6<br>0111: DIV=4, N=8<br>1000: DIV=8, N=6<br>1001: DIV=8, N=8<br>1010: DIV=16, N=5<br>1011: DIV=16, N=6<br>1100: DIV=16, N=8<br>1101: DIV=32, N=5<br>1110: DIV=32, N=6<br>1111: DIV=32, N=8<br>采样频率=定时器时钟频率/DIV; 滤波器长度=N, 表示每 N 个事件产生一个跳变。 |
| 9:8   | CC2SEL | R/W | 选择捕获/比较通道 2 (Capture/Compare Channel2 Select)<br>00: CC2 通道为输出<br>01: CC2 通道为输入, IC2 映射在 TI2 上<br>10: CC2 通道为输入, IC2 映射在 TI1 上<br>11: CC2 通道为输入, IC2 映射在 TRC 上, 仅工作在内部触发输入<br>注意: 该位仅在通道关闭时 (TMRx_CCEN 寄存器的 CC2EN=0 时) 可写。                                                                                                                                                                                                                                   |
| 11:10 | IC2PSC | R/W | 配置输入捕获通道 2 预分频因子 (Input Capture Channel2 Perscaler Configuration)                                                                                                                                                                                                                                                                                                                                                                                            |
| 15:12 | IC2F   | R/W | 配置输入捕获通道 2 滤波器 (Input Capture Channel2 Filter Configuration)                                                                                                                                                                                                                                                                                                                                                                                                 |

### 15.6.8 捕获/比较模式寄存器 2 (TMRx\_CCM2)

偏移地址: 0x1C

复位值: 0x0000

参看以上 CCM1 寄存器的描述。

输出比较模式:

| 位/域   | 名称     | R/W | 描述                                                                                                                                                                                                                                                                         |
|-------|--------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0   | CC3SEL | R/W | <p>选择捕获/比较通道 3 (Capture/Compare Channel1 Selection)<br/> 该位定义了输入/输出的方向以及选择输入引脚。<br/> 00: CC3 通道为输出<br/> 01: CC3 通道为输入, IC3 映射在 TI3 上<br/> 10: CC3 通道为输入, IC3 映射在 TI4 上<br/> 11: CC3 通道为输入, IC3 映射在 TRC 上, 仅工作在内部触发输入<br/> 注意: 该位仅在通道关闭时 (TMRx_CCEN 寄存器的 CC3EN=0 时) 可写。</p> |
| 2     | OC3FEN | R/W | <p>快速使能输出比较通道 3 (Output Compare Channel3 Fast Enable)<br/> 0: 禁用<br/> 1: 使能<br/> 该位用来提高捕获/比较输出对触发输入事件的响应。</p>                                                                                                                                                              |
| 3     | OC3PEN | R/W | 使能输出比较通道 3 预装载 (Output Compare Channel3 Preload Enable)                                                                                                                                                                                                                    |
| 6:4   | OC3MOD | R/W | 配置输出比较通道 3 模式 (Output Compare Channel3 Mode Configure)                                                                                                                                                                                                                     |
| 7     | OC3CEN | R/W | <p>使能输出比较通道 3 清除 (Output Compare Channel3 Clear Enable)<br/> 0: OC3REF 不受 ETRF 输入影响。<br/> 1: 检测到 ETRF 输入高电平时, OC1REF=0</p>                                                                                                                                                 |
| 9:8   | CC4SEL | R/W | <p>选择通道 4 模式 (Capture/compare Channel4 Selection)<br/> 该位定义了输入/输出的方向以及选择输入引脚。<br/> 00: CC4 通道为输出<br/> 01: CC4 通道为输入, IC4 映射在 TI4 上<br/> 10: CC4 通道为输入, IC4 映射在 TI3 上<br/> 11: CC4 通道为输入, IC4 映射在 TRC 上, 仅工作在内部触发输入<br/> 注意: 该位仅在通道关闭时 (TMRx_CCEN 寄存器的 CC4EN=0 时) 可写。</p>   |
| 10    | OC4FEN | R/W | 快速使能输出比较通道 4 (Output Compare Channel4 Preload Enable)                                                                                                                                                                                                                      |
| 11    | OC4PEN | R/W | 使能输出比较通道 4 缓冲 (Output Compare Channel4 Buffer Enable)                                                                                                                                                                                                                      |
| 14:12 | OC4MOD | R/W | 配置输出比较通道 4 模式 (Output Compare Channel4 Mode Configure)                                                                                                                                                                                                                     |
| 15    | OC4CEN | R/W | 使能输出通道 4 比较清除 (Output Compare Channel4 Clear Enable)                                                                                                                                                                                                                       |

#### 输入捕获模式:

| 位/域 | 名称     | R/W | 描述                                                                                                                                                                                                                                          |
|-----|--------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0 | CC3SEL | R/W | <p>选择输入/捕获通道 3 (Capture/Compare Channel3 Select)<br/> 00: CC3 通道为输出<br/> 01: CC3 通道为输入, IC3 映射在 TI3 上<br/> 10: CC3 通道为输入, IC3 映射在 TI4 上<br/> 11: CC3 通道为输入, IC3 映射在 TRC 上, 仅工作在内部触发输入<br/> 注意: 该位仅在通道关闭时 (TMRx_CCEN 寄存器的 CC3EN=0 时) 可写。</p> |
| 3:2 | IC3PSC | R/W | <p>配置输入捕获通道 3 预分频因子 (Input Capture Channel3 Prescaler Configuration)<br/> 00: PSC=1<br/> 01: PSC=2<br/> 10: PSC=4</p>                                                                                                                       |

| 位/域   | 名称     | R/W | 描述                                                                                                                                                                                                                         |
|-------|--------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |        |     | 11: PSC=8<br>PSC 是预分频因子, 每 PSC 个事件触发一次捕获。                                                                                                                                                                                  |
| 7:4   | IC3F   | R/W | 配置输入捕获通道 3 滤波器 (Input Capture Channel3 Filter Configuration)                                                                                                                                                               |
| 9:8   | CC4SEL | R/W | 选择捕获/比较通道 4 (Capture/Compare Channel4 Select)<br>00: CC4 通道为输出<br>01: CC4 通道为输入, IC4 映射在 TI4 上<br>10: CC4 通道为输入, IC4 映射在 TI3 上<br>11: CC4 通道为输入, IC4 映射在 TRC 上, 仅工作在内部触发输入<br>注意: 该位仅在通道关闭时 (TMRx_CCEN 寄存器的 CC4EN=0 时) 可写。 |
| 11:10 | IC4PSC | R/W | 配置输入捕获通道 4 预分频因子 (Input Capture Channel4 Perscaler Configuration)                                                                                                                                                          |
| 15:12 | IC4F   | R/W | 配置输入捕获通道 4 滤波器 (Input Capture Channel4 Filter Configuration)                                                                                                                                                               |

### 15.6.9 使能捕获/比较通道寄存器 (TMRx\_CCEN)

偏移地址: 0x20

复位值: 0x0000

| 位/域 | 名称     | R/W | 描述                                                                                                                                                                                                                                                            |
|-----|--------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | CC1EN  | R/W | 使能捕获/比较通道 1 输出 (Capture/Compare Channel1 Output Enable)<br>捕获/比较通道 1 配置为输出时:<br>0: 禁用输出<br>1: 开启输出<br>捕获/比较通道 1 配置为输入时:<br>该位决定了计数器的值 CNT 是否能捕获进入 TMRx_CC1 寄存器中:<br>0: 禁用捕获<br>1: 开启捕获                                                                        |
| 1   | CC1POL | R/W | 配置捕获/比较通道 1 输出极性 (Capture/Compare Channel1 Output Polarity Configure)<br>CC1 通道配置为输出时:<br>0: OC1 高电平有效<br>1: OC1 低电平有效<br>CC1 通道配置为输入时:<br>0: 不反相: 在 IC1 的上升沿进行捕获, IC1 作为外部触发器时不反相。<br>1: 反相, 在 IC1 下降沿进行捕获, IC1 作为外部触发器时反相。<br>注意: 当保护级别为 2 或者 3 时, 该位不能被修改。 |
| 3:2 | 保留     |     |                                                                                                                                                                                                                                                               |
| 4   | CC2EN  | R/W | 使能捕获/比较通道 2 输出 (Capture/Compare Channel2 Output Enable)<br>参考 CCEN_CC1EN                                                                                                                                                                                      |
| 5   | CC2POL | R/W | 配置捕获/比较通道 2 输出极性 (Capture/Compare Channel2 Output Polarity Configure)<br>参考 CCEN_CC1POL                                                                                                                                                                       |
| 7:6 | 保留     |     |                                                                                                                                                                                                                                                               |

| 位/域   | 名称     | R/W | 描述                                                                                      |
|-------|--------|-----|-----------------------------------------------------------------------------------------|
| 8     | CC3EN  | R/W | 使能捕获/比较通道 3 输出 (Capture/Compare Channel3 Output Enable)<br>参考 CCEN_CC1EN                |
| 9     | CC3POL | R/W | 配置捕获/比较通道 3 输出极性 (Capture/Compare Channel3 Output Polarity Configure)<br>参考 CCEN_CC1POL |
| 11:10 | 保留     |     |                                                                                         |
| 12    | CC4EN  | R/W | 使能捕获/比较通道 4 输出 (Capture/Compare Channel4 Output Enable)<br>参考 CCEN_CC1EN                |
| 13    | CC4POL | R/W | 捕获/比较通道 4 输出极性 (Capture/Compare Channel4 Output Polarity)<br>参考 CCEN_CC1POL             |
| 15:14 | 保留     |     |                                                                                         |

表格 69 标准 OCx 通道的输出控制位

| CCxEN 位 | OCx 输出状态                |
|---------|-------------------------|
| 0       | 禁止输出 (OCx=0, OCx_EN=0)  |
| 1       | OCx=OCxREF+极性, OCx_EN=1 |

注意：连接到标准 OCx 通道的外部 I/O 引脚状态，取决于 OCx 通道状态和 GPIO 以及 AFIO 寄存器。

### 15.6.10 计数器寄存器 (TMRx\_CNT)

偏移地址: 0x24

复位值: 0x00000000

| 位/域  | 名称  | R/W | 描述                    |
|------|-----|-----|-----------------------|
| 31:0 | CNT | R/W | 计数器数值 (Counter Value) |

### 15.6.11 预分频寄存器 (TMRx\_PSC)

偏移地址: 0x28

复位值: 0x0000

| 位/域  | 名称  | R/W | 描述                                                                |
|------|-----|-----|-------------------------------------------------------------------|
| 15:0 | PSC | R/W | 预分频器数值 (Prescaler Value)<br>计数器的时钟频率 (CK_CNT) = fCK_Psc / (PSC+1) |

### 15.6.12 自动重装载寄存器 (TMRx\_AUTORLD)

偏移地址: 0x2C

复位值: 0xFFFF FFFF

| 位/域  | 名称      | R/W | 描述                                                  |
|------|---------|-----|-----------------------------------------------------|
| 31:0 | AUTORLD | R/W | 自动重装载数值 (Auto Reload Value)<br>自动重装载的值为空时，计数器不进行计数。 |

### 15.6.13 通道 1 捕获/比较寄存器 (TMRx\_CC1)

偏移地址: 0x34

复位值: 0x0000 0000

| 位/域  | 名称  | R/W | 描述                                                                                                                                                                                                                                                                                                                                                                     |
|------|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | CC1 | R/W | <p>捕获/比较通道 1 数值 (Capture/Compare Channel1 Value)</p> <p>捕获/比较通道 1 配置为输入模式:</p> <p>CC1 包含上次输入捕获通道 1 事件传输的计数器数值。</p> <p>捕获/比较通道 1 配置为输出模式:</p> <p>CC1 包含了当前装入捕获/比较寄存器数值。</p> <p>捕获比较通道 1 的值 CC1 与计数器的值 CNT 比较, 在 OC1 上产生输出信号。</p> <p>当输出比较预装载禁止 (TMRx_CCM1 寄存器的 OC1PEN=0) 时, 写入的数值会立即影响输出比较结果;</p> <p>当输出比较预装载使能 (TMRx_CCM1 寄存器的 OC1PEN=1) 时, 写入的值会在产生更新事件时影响输出比较结果。</p> |

#### 15.6.14 通道 2 捕获/比较寄存器 (TMRx\_CC2)

偏移地址: 0x38

复位值: 0x0000 0000

| 位/域  | 名称  | R/W | 描述                                                                      |
|------|-----|-----|-------------------------------------------------------------------------|
| 31:0 | CC2 | R/W | <p>捕获/比较通道 2 数值 (Capture/Compare Channel2 Value)</p> <p>参考 TMRx_CC1</p> |

#### 15.6.15 通道 3 捕获/比较寄存器 (TMRx\_CC3)

偏移地址: 0x3C

复位值: 0x0000 0000

| 位/域  | 名称  | R/W | 描述                                                                      |
|------|-----|-----|-------------------------------------------------------------------------|
| 31:0 | CC3 | R/W | <p>捕获/比较通道 3 数值 (Capture/Compare Channel3 Value)</p> <p>参考 TMRx_CC1</p> |

#### 15.6.16 通道 4 捕获/比较寄存器 (TMRx\_CC4)

偏移地址: 0x40

复位值: 0x0000 0000

| 位/域  | 名称  | R/W | 描述                                                                      |
|------|-----|-----|-------------------------------------------------------------------------|
| 31:0 | CC4 | R/W | <p>捕获/比较通道 4 数值 (Capture/Compare Channel4 Value)</p> <p>参考 TMRx_CC1</p> |

#### 15.6.17 DMA 控制寄存器 (TMRx\_DCTRL)

偏移地址: 0x48

复位值: 0x0000

| 位/域 | 名称     | R/W | 描述                                                                                                                                                                                                                                 |
|-----|--------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4:0 | DBADDR | R/W | <p>设置 DMA 基地址 (DMA Base Address Setup)</p> <p>这些位定义了 DMA 在连续模式下的基地址 (当对 TMRx_DMADDR 寄存器进行读或写时), DBADDR 定义为从 TMRx_CTRL1 寄存器所在地址开始的偏移量:</p> <p>00000: TMRx_CTRL1</p> <p>00001: TMRx_CTRL2</p> <p>00010: TMRx_SMCTRL</p> <p>.....</p> |

| 位/域   | 名称    | R/W | 描述                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|-------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:5   |       |     | 保留                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 12:8  | DBLEN | R/W | <p>设置 DMA 突发传送长度 (DMA Burst Transfer Length Setup)<br/>         这些位定义 DMA 在连续模式下的传送长度、传输的次数，其中传输的数据可以是 16 位和 8 位。<br/>         当读写 TMRx_DMADDR 寄存器时，定时器进行一次连续传输传送；<br/>         00000: 1 次传输<br/>         00001: 2 次传输<br/>         00010: 3 次传输<br/>         .....<br/>         10001: 18 次传输<br/>         传输的地址公式如下：<br/>         传输的地址=TMRx_CTRL1 的地址 (从地址) +DBADDR+DMA 索引；<br/>         DMA 索引=DBLEN<br/>         例如：DBLEN=7, DBADDR=TMR2_CTRL1 (从地址) 表示待传输数据的地址，则 TMRx_CTRL1 的地址+DBADDR+7，表示了将要写入/读出数据的地址。<br/>         数据的传输将发生在：TMRx_CTRL1 的地址+从 DBADDR 开始的 7 个寄存器。<br/>         根据设置的 DMA 数据长度不同，数据传输也会发生变化：<br/>         1) 当传输数据设置为 16 位时，数据会传输给 7 个寄存器。<br/>         2) 当传输数据设置为 8 位时，第一个寄存器的数据是第一个的数据的 MSB 位，第二个寄存器的数据是第一个数据的 LSB 位，数据仍然会传输给 7 个寄存器。</p> |
| 15:13 |       |     | 保留                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

### 15.6.18 连续模式的 DMA 地址寄存器 (TMRx\_DMADDR)

偏移地址: 0x4C

复位值: 0x0000

| 位/域  | 名称     | R/W | 描述                                                                                                                                                                                                                                                                                                                                                      |
|------|--------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0 | DMADDR | R/W | <p>DMA 突发传送寄存器 (DMA Register for Burst Transfer)<br/>         TMRx_DMADDR 寄存器的读或写操作访问会导致对以下地址所在寄存器的存取操作：<br/>         TMRx_CTRL1 地址+ (DBADDR+DMA 索引) ×4<br/>         其中：<br/>         “TMRx_CTRL1 地址”是控制寄存器 1 (TMRx_CTRL1) 所在的地址；<br/>         “DBADDR”是 TMRx_DCTRL 寄存器中定义的基地址；<br/>         “DMA 索引”是由 DMA 自动控制的偏移量，它取决于 TMRx_DCTRL 寄存器中定义的 DBLEN。</p> |

### 15.6.19 TMR2 选项寄存器 (TMR2\_OPT)

偏移地址: 0x50

复位值: 0x0000

| 位/域   | 名称     | R/W | 描述                                                          |
|-------|--------|-----|-------------------------------------------------------------|
| 9:0   |        |     | 保留                                                          |
| 11:10 | RMPSEL | R/W | 定时器 2 内部触发 1 重映射选择 (Timer2 Internal Trigger 1 Remap Select) |

| 位/域   | 名称 | R/W | 描述                                                                                                                                  |
|-------|----|-----|-------------------------------------------------------------------------------------------------------------------------------------|
|       |    |     | 00: TMR8_TRGOUT<br>01: PTP 触发输出连接到 TMR2_ITR1<br>10: OTG_FS1 SOF 连接到 TMR2_ITR1 输入<br>11: OTG_FS2 SOF 连接到 TMR2_ITR1 输入<br>注意: 通过软件清除。 |
| 15:12 |    |     | 保留                                                                                                                                  |

### 15.6.20 TMR5 选项寄存器 (TMR5\_OPT)

偏移地址: 0x50

复位值: 0x0000

| 位/域  | 名称     | R/W | 描述                                                                                                                                                                                                                      |
|------|--------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5:0  |        |     | 保留                                                                                                                                                                                                                      |
| 7:6  | RMPSEL | R/W | 定时器 5 通道 4 输入重映射选择 (Timer5 Channel4 Input Remap Select)<br>00: TMR5 通道 4 连接到 GPIO<br>01: LSICLK 内部时钟与 TMR5_CH4 输入连接, 用于校准<br>10: LSECLK 内部时钟与 TMR5_CH4 输入连接, 用于校准<br>11: RTC 唤醒中断连接到 TMR5_CH4 输入连接, 用于校准<br>注意: 通过软件清除。 |
| 15:8 |        |     | 保留                                                                                                                                                                                                                      |

## 16 通用定时器 (TMR9/10/11/12/13/14)

### 16.1 简介

通用定时器以时基单元为核心，拥有输入捕获和输出比较等功能，可以用来测量脉冲宽度、频率和占空比，以及产生输出波形。含有一个 16 位的自动重装载计数器（实现向上计数）。

### 16.2 TMR9/12 主要特征

- (1) 时基单元
  - 计数器：16 位计数器，可以向上计数
  - 预分频器：16 位可编程预分频器
  - 自动重装载功能
- (2) 时钟源
  - 内部时钟
- (3) 定时器功能
  - 输入捕获
  - 输出比较
  - PWM 输出模式
  - 强制输出模式
  - 单脉冲模式输出
- (4) 定时器的主/从模式控制器
  - 定时器之间可以同步和级联
  - 支持多种从模式、同步信号
- (5) 中断事件
  - 更新事件（计数器上溢，计数器初始化）
  - 触发事件（计数器启动、停止、内/外部触发）
  - 输入捕获
  - 输出比较

### 16.3 TMR10/11/13/14 主要特征

- (1) 时基单元
  - 计数器：16 位计数器，可以向上计数
  - 预分频器：16 位可编程预分频器
  - 自动重装载功能
- (2) 时钟源
  - 内部时钟
- (3) 定时器功能

- 输入捕获
- 输出比较
- PWM 输出模式
- 强制输出模式
- 单脉冲模式输出

(4) 中断事件

- 更新事件 (计数器上溢, 计数器初始化)
- 输入捕获
- 输出比较

## 16.4TMR9/12 结构框图

图 54 通用定时器 TMR9/12 结构框图



## 16.5TMR10/11/13/14 结构框图

图 55 通用定时器 TMR10/11/13/14 结构框图



## 16.6 功能描述

### 16.6.1 时钟源

#### 内部时钟

是来自 RCM 的 TMRx\_CLK, 即定时器本身的驱动时钟, 当禁止从模式控制器, 则预分频的时钟源 CK\_PSC 由内部时钟 CK\_INT 驱动。

### 16.6.2 时基单元

通用定时器里的时基单元包含三个寄存器:

- 16 位计数器寄存器 (CNT)
- 16 位自动重装载寄存器 (AUTORLD)
- 16 位预分频寄存器 (PSC)

#### 计数器 CNT

通用定时器中的计数器只有向上计数模式。

#### 向上计数模式

当计数器处于向上计数模式时, 计数器从 0 开始向上计数, 当每来一个脉冲计数器就会增加 1, 一直到计数器 (TMRx\_CNT) 值与自动重装载

(TMRx\_AUTORLD) 的值相等时, 计数器会再次从 0 开始计数, 此时产生一个计数器向上溢出事件, 其中自动重装载的值 (TMRx\_AUTORLD) 是提前写入的。

当计数器溢出时, 会产生更新事件, 此时自动重装载寄存器和预分频寄存器都将会被更新。可以通过配置控制寄存器 TMRx\_CTRL1 中的 UD 位, 禁止更新事件。

下图为向上计数模式下，分频因子为 1 或 2 的时序图：

图 56 向上计数模式下，分频因子为 1 或 2 的时序图



### 预分频器 PSC

预分频器是 16 位的且是可编程的，它可以将计数器的时钟频率进行 1~65536 之间任意值的分频（由 **TMRx\_PSC** 寄存器控制），经过分频后的时钟将会驱动计数器 **CNT** 计数。预分频器带有缓冲器，它能够在运行中被改变。

#### 16.6.3 输入捕获

##### 输入捕获通道

通用定时器有四个独立的捕获/比较独立通道，每一个捕获/比较的通道都围绕着一个捕获/比较寄存器。

在输入捕获中，被测量的信号会从定时器的外部引脚 **T1/2/3/4** 进入首先经过边沿检测器和输入滤波器，然后进入捕获通道，每个捕获通道都有相对应的捕获寄存器。当发生捕获时，计数器 **CNT** 的值将会被锁存在捕获寄存器 **CCx** 中。在进入捕获寄存器之前，信号还会经过预分频器，用于设定经过多少事件进行一次捕获。

## 输入捕获应用

输入捕获用来捕获外部事件，并且可以赋予时间标记表明事件的发生时刻，可以测量脉冲跳变沿事件（测量频率或者脉宽），如：在输入引脚上如果出现了被选择的边沿，**TMRx\_CCx** 寄存器会捕获计数器当前的值，同时状态寄存器 **TMRx\_STS** 的 **CCxIFLG** 位被置 1，如果 **CCxIEN=1**，便会产生中断。

捕获模式下可以测量一个波形的时序、频率、周期和占空比。在输入捕获模式中将边沿选择设定为上升沿检测，当捕获通道出现上升沿时，发生第一次捕获，此时计数器 **CNT** 的值会被锁存在捕获寄存器 **CCx** 中，同时会进入捕获中断，在中断服务程序中记录一次捕获，记下此时的值，当检测到下一个上升沿时，发生第二次捕获，计数器 **CNT** 的值会再次锁存在捕获寄存器 **CCx** 中，此时再次进入捕获中断，读取捕获寄存器的值，通过捕获就会得出此脉冲信号的周期。

## 16.6.4 输出比较

输出比较一共有八种模式：冻结，匹配时通道 x 为有效电平、匹配时通道 x 为无效电平、翻转、强制为无效、强制为有效、**PWM** 模式 1 和 **PWM** 模式 2。由 **TMRx\_CCMx** 寄存器中的 **OCxMOD** 位配置，在输出比较模式中可以控制输出信号的波形。

## 输出比较应用

输出比较模式中，定时器产生脉冲的位置、极性、频率和时间都是可以控制的。

当计数器的值和捕获/比较寄存器的值相等时，通过配置 **TMRx\_CCMx** 寄存器中的 **OCxMOD** 位和输出极性 **TMRx\_CCEN** 寄存器中的 **CCxPOL** 位，通道的输出可以被置高电平、低电平或者翻转。

在 **TMRx\_STS** 寄存器中的 **CCxIFLG=1** 时，如果 **TMRx\_DIEN** 寄存器中的 **CCxIEN=1** 产生中断；**TMRx\_CTRL2** 寄存器中的 **CCDSEL=1** 产生 DMA 请求。

## 16.6.5 PWM 输入模式（仅用于 **TMR9/12**）

**PWM** 输入模式是输入捕获的一个特例。

**PWM** 输入模式，只有 **TI1FP1**、**TI1FP2** 连接到了从模式控制器，所以只能从通道 **TMRx\_CH1** 和 **TMRx\_CH2** 输入，且需要占用 **CH1**、**CH2** 的捕获寄存器。

在 **PWM** 输入模式中，**PWM** 信号从 **TMRx\_CH1** 进入，信号会被分成两路，一路可以测量周期，一路可以测量占空比。在配置中只需设置其中一路的极性，另一路会自动配置为相反的极性。

在此模式中，从模式控制器要配置成复位模式（**TMRx\_SMCTRL** 寄存器的 **SMFSEL** 位）。

图 57 PWM 输入模式时序图



### 16.6.6 PWM 输出模式

PWM 模式是定时器对外输出可以调节的脉冲信号，其中信号的脉宽是由比较寄存器 CC<sub>x</sub> 的值决定，周期是由自动重装载 AUTORLD 的值决定。

PWM 输出模式分为 PWM 模式 1 和 PWM 模式 2。PWM 模式 1 和 PWM 模式 2 只能向上计数；PWM 模式 1 中如果计数器 CNT 的值小于比较寄存器 CC<sub>x</sub> 的值，输出有效电平，否则反之。

设置 CC<sub>x</sub>=5, AUTORLD=7, 在 PWM 模式 1 下的时序图：

图 58 PWM1 向上计数模式的时序图



PWM 模式 2 中如果计数器 CNT 的值小于比较寄存器 CC<sub>x</sub> 的值，输出无效电平，否则反之。

设置 CC<sub>x</sub>=5, AUTORLD=7, 在 PWM 模式 2 模式下的时序图：

图 59 PWM2 向上计数模式的时序图



### 16.6.7 单脉冲模式

单脉冲模式是定时器比较输出中一种特殊情况，也是 PWM 输出模式的特例。

设置 **TMRx\_CTRL1** 寄存器的 **SPMEN** 位选择单脉冲模式，计数器启动后，在未发生更新事件之前有一定个数的脉冲输出，当发生更新事件后计数器停止计数，后续不再有变化的 PWM 波形输出。

单脉冲模式通过程序在一定可控延迟后，产生一个脉宽可控的脉冲，延时时间为 **TMRx\_CCx** 寄存器的值定义。在增计数模式下延时时间为 **CCx**，脉冲宽度为 **AUTORLD-CCx**；在减计数模式下延时时间为 **AUTORLD-CCx**，脉冲宽度为 **CCx**。

图 60 单脉冲模式下的时序图



### 16.6.8 强制输出模式

强制输出模式下无视比较结果，直接根据配置指令输出相应电平：

- **TMRx\_CCMx** 寄存器的 **CCxSEL=00**，设定 **CCx** 通道为输出，
- **TMRx\_CCMx** 寄存器的 **OCxMOD=100/101**，设定强制 **OCxREF** 信号为无效/有效状态。

在此模式中仍会产生相应的中断和 DMA 请求。

### 16.6.9 调试模式

TMR9/10/11/12/13/14 可以在调试模式下配置，选择停止还是继续工作。取决于 DBGMCU\_APB1F 寄存器或 DBGMCU\_APB2F 寄存器的 TMRx\_STS 位。

## 16.7 TMR9/12 寄存器地址映射

下表中将 TMR9/12 的所有寄存器映射到一个 16 位可寻址（编址）空间。

表格 70 TMR9/12 寄存器地址映射

| 寄存器名         | 描述            | 偏移地址 |
|--------------|---------------|------|
| TMRx_CTRL1   | 控制寄存器 1       | 0x00 |
| 保留           | -             | 0x04 |
| TMRx_SMCTRL  | 从模式控制寄存器      | 0x08 |
| TMRx_DIEN    | DMA/中断使能寄存器   | 0x0C |
| TMRx_STS     | 状态寄存器         | 0x10 |
| TMRx_CEG     | 控制事件产生寄存器     | 0x14 |
| TMRx_CCM1    | 捕获/比较模式寄存器 1  | 0x18 |
| TMRx_CCEN    | 捕获/比较使能寄存器    | 0x20 |
| TMRx_CNT     | 计数器寄存器        | 0x24 |
| TMRx_PSC     | 预分频寄存器        | 0x28 |
| TMRx_AUTORLD | 自动重装载寄存器      | 0x2C |
| TMRx_CC1     | 通道 1 捕获/比较寄存器 | 0x34 |
| TMRx_CC2     | 通道 2 捕获/比较寄存器 | 0x38 |

## 16.8 TMR9/12 寄存器功能描述

### 16.8.1 控制寄存器 1 (TMRx\_CTRL1)

偏移地址: 0x00

复位值: 0x0000

| 位/域 | 名称    | R/W | 描述                                                                                                                                                                  |
|-----|-------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | CNTEN | R/W | <p>使能计数器 (Counter Enable)<br/>           0: 禁用<br/>           1: 使能<br/>           定时器配置为外部时钟或门控模式时，需要通过软件对该位写 1 启动定期工作；配置为触发模式时，可硬件写 1。</p>                        |
| 1   | UD    | R/W | <p>禁止更新 (Update Disable)<br/>           更新事件可引起 AUTORLD、PSC、CCx 产生更新设置的数值。<br/>           0: 允许更新事件 (UEV)<br/>           更新事件可以由以下任一情况产生：<br/>           计数器上溢；</p> |

| 位/域   | 名称     | R/W | 描述                                                                                                                                                                                       |
|-------|--------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |        |     | 设置 UEG 位。<br>1: 禁止更新事件                                                                                                                                                                   |
| 2     | URSSEL | R/W | 更新请求源 (Update Request Source Select)<br>如果使能了中断, 更新事件可产生更新中断, 通过该位可选择不同的更新请求源。<br>0: 计数器上溢;<br>设置 UEG 位。<br>1: 计数器上溢                                                                     |
| 3     | SPMEN  | R/W | 使能单脉冲模式 (Single Pulse Mode Enable)<br>产生更新事件时, 可改变通道的输出电平; 在该模式下, 会清除 CNTEN 位, 停止计数器, 后续不再改变通道的输出电平。<br>0: 禁用<br>1: 使能                                                                   |
| 6:4   |        |     | 保留                                                                                                                                                                                       |
| 7     | ARPEN  | R/W | TMRx_AUTORLD 寄存器自动重装载缓冲使能 (Auto-reload Preload Enable)<br>禁止缓存区时, 程序修改 TMRx_AUTORLD 会立刻修改装入计数器的数值; 使能缓存区时, 程序修改 TMRx_AUTORLD 会在下一个更新事件修改装入计数器的数值。<br>0: 禁用<br>1: 使能                      |
| 9:8   | CLKDIV | R/W | 时钟分频系数 (Clock Division)<br>数字滤波器的配置由 CK_INT 提供时钟, 通过设置位可调整数字滤波器的采用时钟。<br>00: $t_{DTS}=t_{CK\_INT}$<br>01: $t_{DTS}=2 \times t_{CK\_INT}$<br>10: $t_{DTS}=4 \times t_{CK\_INT}$<br>11: 保留 |
| 15:10 |        |     | 保留                                                                                                                                                                                       |

### 16.8.2 从模式控制寄存器 (TMRx\_SMCTRL)

偏移地址: 0x08

复位值: 0x0000

| 位/域 | 名称     | R/W | 描述                                                                                                                                                                                                                                                                                                                                                           |
|-----|--------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0 | SMFSEL | R/W | 选择从模式功能 (Slave Mode Function Select)<br>000: 禁用从模式, 定时器可作为主模式定时器影响从模式定时器的工作; 如果 CTRL1_CNTEN=1, 则预分频器直接由内部时钟驱动。<br>001: 保留<br>010: 保留<br>011: 保留<br>100: 复位模式, 从模式定时器在收到 TRGI 的上升沿信号后复位计数器, 并产生更新寄存器的信号。<br>101: 门控模式, 从模式定时器在收到 TRGI 高电平信号时, 启动计数器工作; 收到 TRGI 低电平时停止计数器工作; 再收到 TRGI 高电平信号时, 继续工作; 整个期间不复位计数器。<br>110: 触发模式, 从模式定时器在收到 TRGI 的上升沿信号后, 启动计数器工作。 |

| 位/域  | 名称     | R/W | 描述                                                                                                                                                                                                                                                         |
|------|--------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |        |     | 111: 外部时钟模式 1, 选择 TRGI 的上升沿信号作为时钟源驱动计数器工作。                                                                                                                                                                                                                 |
| 3    |        |     | 保留                                                                                                                                                                                                                                                         |
| 6:4  | TRGSEL | R/W | 选择触发输入信号 (Trigger Input Signal Select)<br>为了避免在改变该位值时产生错误的边沿检测, 须在 SMFSEL=0 时改变。<br>000: 内部触发 ITR0<br>001: 内部触发 ITR1<br>010: 内部触发 ITR2<br>011: 内部触发 ITR3<br>100: 通道 1 输入边沿检测器 TIF_ED<br>101: 通道 1 滤波后定时器输入 TI1FP1<br>110: 通道 2 滤波后的定时器输入 TI2FP2<br>111: 保留 |
| 7    | MSMEN  | R/W | 使能主/从模式 (Master/slave Mode Enable)<br>0: 无效<br>1: 使能主/从模式                                                                                                                                                                                                  |
| 15:8 |        |     | 保留                                                                                                                                                                                                                                                         |

表格 71 TMRx 内部触发连接

| 从定时器  | ITR0 (TS=000) | ITR1 (TS=001) | ITR2 (TS=010) | ITR3 (TS=011) |
|-------|---------------|---------------|---------------|---------------|
| TMR2  | TMR1          | TMR8          | TMR3          | TMR4          |
| TMR3  | TMR1          | TMR2          | TMR5          | TMR4          |
| TMR4  | TMR1          | TMR2          | TMR3          | TMR8          |
| TMR5  | TMR2          | TMR3          | TMR4          | TMR8          |
| TMR9  | TMR2          | TMR3          | TMR10         | TMR11         |
| TMR12 | TMR4          | TMR5          | TMR13         | TMR14         |

### 16.8.3 DMA/中断使能寄存器 (TMRx\_DIEN)

偏移地址: 0x0C

复位值: 0x0000

| 位/域 | 名称     | R/W | 描述                                                                           |
|-----|--------|-----|------------------------------------------------------------------------------|
| 0   | UIEN   | R/W | 使能更新中断 (Update Interrupt Enable)<br>0: 禁用<br>1: 使能                           |
| 1   | CC1IEN | R/W | 使能捕获/比较通道 1 中断 (Capture/Campare Channel1 Interrupt Enable)<br>0: 禁用<br>1: 使能 |
| 2   | CC2IEN | R/W | 使能捕获/比较通道 2 中断 (Capture/Campare Channel2 Interrupt Enable)<br>0: 禁用          |

| 位/域  | 名称     | R/W | 描述                                                  |
|------|--------|-----|-----------------------------------------------------|
|      |        |     | 1: 使能                                               |
| 5:3  |        |     | 保留                                                  |
| 6    | TRGIEN | R/W | 使能触发中断 (Trigger Interrupt Enable)<br>0: 禁用<br>1: 使能 |
| 15:7 |        |     | 保留                                                  |

#### 16.8.4 状态寄存器 (TMRx\_STS)

偏移地址: 0x10

复位值: 0x0000

| 位/域 | 名称      | R/W   | 描述                                                                                                                                                                                                                                                                                                                                       |
|-----|---------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | UIFLG   | RC_W0 | 产生更新事件中断标志位 (Update Event Interrupt Generate Flag)<br>0: 没有发生更新事件中断<br>1: 发生更新事件中断<br>计数器数值重新装载或重新初始化时, 会产生更新事件, 该位由硬件置 1, 软件清 0; 更新事件的产生的情况有以下情况:<br>(1) TMRx_CTRL1 寄存器的 UD=0, 上溢时产生更新事件;<br>(2) TMRx_CTRL1 寄存器的 URSEL=0 和 UD=0, 配置 TMRx_CEG 寄存器的 UG=1 产生更新事件, 需要通过软件初始化计数器;<br>(3) TMRx_CTRL1 寄存器的 URSEL=0 和 UD=0, 计数器被触发事件初始化时产生更新事件。 |
| 1   | CC1IFLG | RC_W0 | 捕获/比较通道 1 中断标志 (Captuer/Compare Channel1 Interrupt Flag)<br>当捕获比较通道 1 配置为输出时:<br>0: 无匹配发生<br>1: TMRx_CNT 的值与 TMRx_CC1 的值相匹配<br>当捕获比较通道 1 配置为输入时:<br>0: 没有发生输入捕获<br>1: 发生输入捕获<br>捕获事件发生时由硬件置 1, 可以由软件清 0 或者读 TMRx_CC1 寄存器时清 0。                                                                                                            |
| 2   | CC2IFLG | RC_W0 | 捕获/比较通道 2 中断标志 (Captuer/Compare Channel2 new Interrupt Flag)<br>参考 STS_CC1IFLG                                                                                                                                                                                                                                                           |
| 5:3 |         |       | 保留                                                                                                                                                                                                                                                                                                                                       |
| 6   | TRGIFLG | RC_W0 | 产生触发事件中断标志 (Trigger Event Interrupt Generate Flag)<br>0: 没有发生触发事件中断<br>1: 发生触发事件中断<br>发生触发事件时, 该位由硬件置 1, 软件清 0。                                                                                                                                                                                                                          |
| 8:7 |         |       | 保留                                                                                                                                                                                                                                                                                                                                       |

| 位/域   | 名称       | R/W   | 描述                                                                                                                                                                                         |
|-------|----------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9     | CC1RCFLG | RC_W0 | <p>捕获/比较通道 1 重复捕获标志 (Captuer/Compare Channel1 Repetition Capture Flag)</p> <p>0: 没有发生重复捕获<br/>1: 发生重复捕获</p> <p>计数器的值被捕获到 TMRx_CC1 寄存器中, 此时 CC1IFLG=1; 只有当通道被配置为输入捕获时, 该位由硬件置 1, 软件清 0。</p> |
| 10    | CC2RCFLG | RC_W0 | <p>捕获/比较通道 2 重复捕获标志 (Captuer/compare Channel2 Repetition Capture Flag)</p> <p>参考 STS_CC1RCFLG</p>                                                                                          |
| 15:11 | 保留       |       |                                                                                                                                                                                            |

### 16.8.5 控制事件产生寄存器 (TMRx\_CEG)

偏移地址: 0x14

复位值: 0x0000

| 位/域  | 名称    | R/W | 描述                                                                                                                                                                                                                                                                                                                                |
|------|-------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | UEG   | W   | <p>产生更新事件 (Update Event Generate)</p> <p>0: 无效<br/>1: 初始化计数器, 产生更新事件</p> <p>此位由软件置 1, 硬件清 0。</p> <p>注意: 产生更新事件时, 预分频器的计数器会清 0, 但是预分频系数不变。如果在向下计数模式下, 计数器会读取 TMRx_AUTORLD 的值; 如果在中央对齐模式下或者向上计数模式中, 计数器会被清 0。</p>                                                                                                                   |
| 1    | CC1EG | W   | <p>产生捕获/比较通道 1 事件 (Capture/Compare Channel1 Event Generation)</p> <p>0: 无效<br/>1: 产生捕获/比较事件</p> <p>该位由软件置 1, 硬件自动清 0。</p> <p>如果通道 1 处于输出模式:</p> <p>当 CC1IFLG=1 时, 如果设置了 CC1IEN 位, 则产生相应的中断。</p> <p>如果通道 1 处于输入模式:</p> <p>捕获计数器的值存储在 TMRx_CC1 寄存器中; 配置 CC1IFLG=1, 如果还设置了 CC1IEN 位, 则产生相应的中断; 如果此时 CC1IFLG=1, 则需要配置 CC1RCFLG=1。</p> |
| 2    | CC2EG | W   | <p>产生捕获/比较通道 2 事件 (Capture/Compare Channel2 Event Generation)</p> <p>参考 CC1EG 描述</p>                                                                                                                                                                                                                                              |
| 5:3  | 保留    |     |                                                                                                                                                                                                                                                                                                                                   |
| 6    | TEG   | W   | <p>产生触发事件 (Trigger Event Generate)</p> <p>0: 无效<br/>1: 产生触发事件</p> <p>该位由软件置 1, 硬件自动清 0。</p>                                                                                                                                                                                                                                       |
| 15:7 | 保留    |     |                                                                                                                                                                                                                                                                                                                                   |

### 16.8.6 捕获/比较模式寄存器 1 (TMRx\_CCM1)

偏移地址: 0x18

复位值: 0x0000

可通过 CC<sub>x</sub>SEL 位配置定时器为输入（捕获模式）或输出（比较模式）。该寄存器其它位的作用在输入和输出模式下不同，同一个位在输出模式和输入模式下的功能是不同的。寄存器中的 OC<sub>x</sub> 描述了通道在输出模式下的功能，寄存器中的 I<sub>Cx</sub> 描述了通道在输入模式下的功能。

#### 输出比较模式：

| 位/域 | 名称     | R/W | 描述                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----|--------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0 | CC1SEL | R/W | <p>选择捕获/比较通道 1 (Capture/Compare Channel1 Select)<br/>         该位定义了输入/输出的方向以及选择输入引脚。</p> <p>00: CC1 通道为输出<br/>         01: CC1 通道为输入, IC1 映射在 TI1 上<br/>         10: CC1 通道为输入, IC1 映射在 TI2 上<br/>         11: CC1 通道为输入, IC1 映射在 TRC 上, 仅工作在内部触发输入<br/>         注意: 该位仅在通道关闭时 (TMRx_CCEN 寄存器的 CC1EN=0 时) 可写。</p>                                                                                                                                                                                                                                                                                                             |
| 2   | OC1FEN | R/W | <p>快速使能输出比较通道 1 (Output Compare Channel1 Fast Enable)<br/>         0: 禁用<br/>         1: 使能<br/>         该位用来提高捕获/比较输出对触发输入事件的响应。</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 3   | OC1PEN | R/W | <p>使能输出比较通道 1 预装载 (Output Compare Channel1 Preload Enable)<br/>         0: 禁用预装载功能, 通过程序写入 TMRx_CC1 寄存器的数值, 会马上起作用。<br/>         1: 启用预装载功能, 通过程序写入 TMRx_CC1 寄存器的数值, 会在产生更新事件后起作用。<br/>         注意: 当保护级别为 3 级时且通道配置为输出时, 该位不能被修改。当不确定预装载寄存器情况, 仅在单脉冲模式 (SPMEN=1) 下, 可以使用 PWM 模式, 否则不确定其接下来的输出比较结果。</p>                                                                                                                                                                                                                                                                                                                       |
| 6:4 | OC1MOD | R/W | <p>配置输出比较通道 1 模式 (Output Compare Channel1 Mode Configure)<br/>         000: 冻结。输出比较对 OC1REF 无影响<br/>         001: 匹配时输出置为高。计数器 CNT 的值和捕获比较寄存器的值 CC<sub>x</sub> 发生匹配时, 强制 OC1REF 为高电平<br/>         010: 匹配时输出置为低。计数器的值和捕获比较寄存器的值发生匹配时, 强制 OC1REF 为低电平<br/>         011: 匹配时输出翻转。计数器的值和捕获比较寄存器的值发生匹配时, 翻转 OC1REF 的电平<br/>         100: 强制输出为低。强制 OC1REF 为低电平<br/>         101: 强制输出为高。强制 OC1REF 为高电平<br/>         110: PWM 模式 1 (计数器值&lt;输出比较值时置为高, 否则反之)<br/>         111: PWM 模式 2 (计数器值&gt;输出比较值时置为高, 否则反之)<br/>         注意: 当保护级别为 3 级时且通道配置为输出时, 该位不能被修改。在 PWM 模式 1 和 2 中, OC1REF 电平在比较结果改变或者输出比较模式从冻结模式转换到 PWM 模式时改变。</p> |
| 7   |        |     | 保留                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

| 位/域   | 名称     | R/W | 描述                                                                                                                                                                                                                                                 |
|-------|--------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9:8   | CC2SEL | R/W | 通道 2 模式选择 (Capture/Compare Channel2 Select)<br>该位定义了输入/输出的方向以及选择输入引脚。<br>00: CC2 通道为输出<br>01: CC2 通道为输入, IC2 映射在 TI2 上<br>10: CC2 通道为输入, IC2 映射在 TI1 上<br>11: CC2 通道为输入, IC2 映射在 TRC 上, 仅工作在内部触发输入<br>注意: 该位仅在通道关闭时 (TMRx_CCEN 寄存器的 CC2EN=0 时) 可写。 |
| 10    | OC2FEN | R/W | 快速使能输出比较通道 2 (Output Compare Channel2 Preload Enable)                                                                                                                                                                                              |
| 11    | OC2PEN | R/W | 使能输出比较通道 2 缓冲 (Output Compare Channel2 Buffer Enable)                                                                                                                                                                                              |
| 14:12 | OC2MOD | R/W | 输出比较通道 2 模式 (Output Compare Channel2 Mode)                                                                                                                                                                                                         |
| 15    |        |     | 保留                                                                                                                                                                                                                                                 |

#### 输入捕获模式:

| 位/域 | 名称     | R/W | 描述                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----|--------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0 | CC1SEL | R/W | 选择输入/捕获通道 1 (Capture/Compare Channel1 Select)<br>00: CC1 通道为输出<br>01: CC1 通道为输入, IC1 映射在 TI1 上<br>10: CC1 通道为输入, IC1 映射在 TI2 上<br>11: CC1 通道为输入, IC1 映射在 TRC 上, 仅工作在内部触发输入<br>注意: 该位仅在通道关闭时 (TMRx_CCEN 位的 CC1EN=0 时) 可写。                                                                                                                                                                                  |
| 3:2 | IC1PSC | R/W | 配置输入捕获通道 1 预分频因子 (Input Capture Channel1 Prescaler Configure)<br>00: PSC=1<br>01: PSC=2<br>10: PSC=4<br>11: PSC=8<br>PSC 是预分频因子, 每 PSC 个事件触发一次捕获。                                                                                                                                                                                                                                                         |
| 7:4 | IC1F   | R/W | 配置输入捕获通道 1 滤波器 (Input Capture Channel1 Filter Configure)<br>0000: 禁用滤波器, 以 $f_{DTs}$ 采样<br>0001: DIV=1, N=2<br>0010: DIV=1, N=4<br>0011: DIV=1, N=8<br>0100: DIV=2, N=6<br>0101: DIV=2, N=8<br>0110: DIV=4, N=6<br>0111: DIV=4, N=8<br>1000: DIV=8, N=6<br>1001: DIV=8, N=8<br>1010: DIV=16, N=5<br>1011: DIV=16, N=6<br>1100: DIV=16, N=8<br>1101: DIV=32, N=5<br>1110: DIV=32, N=6<br>1111: DIV=32, N=8 |

| 位/域   | 名称     | R/W | 描述                                                                                                                                                                                                                         |
|-------|--------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |        |     | 采样频率=定时器时钟频率/DIV; 滤波器长度=N, 表示每 N 个事件产生一个跳变。                                                                                                                                                                                |
| 9:8   | CC2SEL | R/W | 选择捕获/比较通道 2 (Capture/Compare Channel2 Select)<br>00: CC2 通道为输出<br>01: CC2 通道为输入, IC2 映射在 TI2 上<br>10: CC2 通道为输入, IC2 映射在 TI1 上<br>11: CC2 通道为输入, IC2 映射在 TRC 上, 仅工作在内部触发输入<br>注意: 该位仅在通道关闭时 (TMRx_CCEN 寄存器的 CC2EN=0 时) 可写。 |
| 11:10 | IC2PSC | R/W | 配置输入捕获通道 2 预分频因子 (Input Capture Channel2 Prescaler Configuration)                                                                                                                                                          |
| 15:12 | IC2F   | R/W | 配置输入捕获通道 2 滤波器 (Input Capture Channel2 Filter Configuration)                                                                                                                                                               |

### 16.8.7 捕获/比较使能寄存器 (TMRx\_CCEN)

偏移地址: 0x20

复位值: 0x0000

| 位/域 | 名称      | R/W | 描述                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----|---------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | CC1EN   | R/W | 使能捕获/比较通道 1 输出 (Capture/Compare Channel1 Output Enable)<br>捕获/比较通道 1 配置为输出时:<br>0: 禁用输出<br>1: 开启输出<br>捕获/比较通道 1 配置为输入时:<br>该位决定了计数器的值 CNT 是否能捕获进入 TMRx_CC1 寄存器中。<br>0: 禁用捕获<br>1: 开启捕获                                                                                                                                                                                                                                                                                |
| 1   | CC1POL  | R/W | 配置捕获/比较通道 1 输出极性 (Capture/Compare Channel1 Output Polarity Configure)<br>CC1 通道配置为输出时:<br>0: OC1 高电平有效<br>1: OC1 低电平有效<br>CC1 通道配置为输入时:<br>CC1POL 和 CC1NPOL 同时控制触发或捕获的信号 TI1FP1 和 TI2FP1 的极性。<br>00: 不反相/上升沿:<br>TIxFP1 不反相 (门控、编码器模式下触发), 在 TIxFP1 的上升沿捕获 (复位触发、捕获、外部时钟和触发模式)。<br>01: 反相/下降沿:<br>TIxFP1 反相 (门控、编码器模式下触发), 在 TIxFP1 的上升沿捕获 (复位触发、捕获、外部时钟和触发模式)。<br>10: 保留<br>11: 不反相/上升和下降沿:<br>TIxFP1 不反相 (门控模式下触发, 不能用于编码器模式), 在 TIxFP1 的上升沿捕获 (复位触发、捕获、外部时钟和触发模式)。 |
| 2   |         |     | 保留                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 3   | CC1NPOL | R/W | 配置捕获/比较通道 1 输出极性 Capture/Compare Channel1 Output Polarity Configure<br>CC1 通道配置为输出时:                                                                                                                                                                                                                                                                                                                                                                                  |

| 位/域  | 名称      | R/W | 描述                                                                                      |
|------|---------|-----|-----------------------------------------------------------------------------------------|
|      |         |     | CC1NPOL 一直保持清除状态。<br>CC1 通道配置为输入时：<br>该位 CC1POL 同时控制触发或捕获的信号 TI1FP1 和 TI2FP1 的极性。       |
| 4    | CC2EN   | R/W | 使能捕获/比较通道 2 输出 (Capture/Compare Channel2 Output Enable)<br>参考 CCEN_CC1EN                |
| 5    | CC2POL  | R/W | 配置捕获/比较通道 2 输出极性 (Capture/Compare Channel2 Output Polarity Configure)<br>参考 CCEN_CC1POL |
| 6    |         |     | 保留                                                                                      |
| 7    | CC2NPOL | R/W | 配置捕获/比较通道 2 输出极性 Capture/Compare Channel2 Output Polarity Configure)<br>参考 CCEN_CC1NPOL |
| 15:8 |         |     | 保留                                                                                      |

表格 72 标准 OCx 通道的输出控制位

| CCxEN 位 | OCx 输出状态                |
|---------|-------------------------|
| 0       | 禁止输出 (OCx=0, OCx_EN=0)  |
| 1       | OCx=OCxREF+极性, OCx_EN=1 |

注意：连接到标准 OCx 通道的外部 I/O 引脚状态，取决于 OCx 通道状态和 GPIO 以及 AFIO 寄存器。

### 16.8.8 计数器寄存器 (TMRx\_CNT)

偏移地址: 0x24

复位值: 0x0000

| 位/域  | 名称  | R/W | 描述                    |
|------|-----|-----|-----------------------|
| 15:0 | CNT | R/W | 计数器数值 (Counter Value) |

### 16.8.9 预分频寄存器 (TMRx\_PSC)

偏移地址: 0x28

复位值: 0x0000

| 位/域  | 名称  | R/W | 描述                                                                |
|------|-----|-----|-------------------------------------------------------------------|
| 15:0 | PSC | R/W | 预分频器数值 (Prescaler Value)<br>计数器的时钟频率 (CK_CNT) = fCK_PSC / (PSC+1) |

### 16.8.10 自动重装载寄存器 (TMRx\_AUTORLD)

偏移地址: 0x2C

复位值: 0xFFFF

| 位/域  | 名称      | R/W | 描述                                                  |
|------|---------|-----|-----------------------------------------------------|
| 15:0 | AUTORLD | R/W | 自动重装载数值 (Auto Reload Value)<br>自动重装载的值为空时，计数器不进行计数。 |

### 16.8.11 通道 1 捕获/比较寄存器 (TMRx\_CC1)

偏移地址: 0x34

复位值: 0x0000

| 位/域  | 名称  | R/W | 描述                                                                                                                                                                                                                                                                                                                                                                     |
|------|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0 | CC1 | R/W | <p>捕获/比较通道 1 数值 (Capture/Compare Channel1 Value)</p> <p>捕获/比较通道 1 配置为输入模式:</p> <p>CC1 包含上次输入捕获通道 1 事件传输的计数器数值。</p> <p>捕获/比较通道 1 配置为输出模式:</p> <p>CC1 包含了当前装入捕获/比较寄存器数值。</p> <p>捕获比较通道 1 的值 CC1 与计数器的值 CNT 比较, 在 OC1 上产生输出信号。</p> <p>当输出比较预装载禁止 (TMRx_CCM1 寄存器的 OC1PEN=0) 时, 写入的数值会立即影响输出比较结果;</p> <p>当输出比较预装载使能 (TMRx_CCM1 寄存器的 OC1PEN=1) 时, 写入的值会在产生更新事件时影响输出比较结果。</p> |

### 16.8.12 通道 2 捕获/比较寄存器 (TMRx\_CC2)

偏移地址: 0x38

复位值: 0x0000

| 位/域  | 名称  | R/W | 描述                                                                      |
|------|-----|-----|-------------------------------------------------------------------------|
| 15:0 | CC2 | R/W | <p>捕获/比较通道 2 数值 (Capture/Compare Channel2 Value)</p> <p>参考 TMRx_CC1</p> |

## 16.9 TMR10/11/13/14 寄存器地址映射

下表中将 TMR10/11/13/14 的所有寄存器映射到一个 16 位可寻址 (编址) 空间。

表格 73 TMR10/11/13/14 寄存器地址映射

| 寄存器名         | 描述            | 偏移地址 |
|--------------|---------------|------|
| TMRx_CTRL1   | 控制寄存器 1       | 0x00 |
| TMRx_DIEN    | DMA/中断使能寄存器   | 0x0C |
| TMRx_STS     | 状态寄存器         | 0x10 |
| TMRx_CEG     | 控制事件产生寄存器     | 0x14 |
| TMRx_CCM1    | 捕获/比较模式寄存器 1  | 0x18 |
| TMRx_CCEN    | 捕获/比较使能寄存器    | 0x20 |
| TMRx_CNT     | 计数器寄存器        | 0x24 |
| TMRx_PSC     | 预分频寄存器        | 0x28 |
| TMRx_AUTORLD | 自动重装载寄存器      | 0x2C |
| TMRx_CC1     | 通道 1 捕获/比较寄存器 | 0x34 |
| TMR11_OPT    | 选项寄存器         | 0x50 |

## 16.10 TMR10/11/13/14 寄存器功能描述

### 16.10.1 控制寄存器 1 (TMRx\_CTRL1)

偏移地址: 0x00

复位值: 0x0000

| 位/域   | 名称     | R/W | 描述                                                                                                                                                                                                                                          |
|-------|--------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | CNTEN  | R/W | <p>使能计数器 (Counter Enable)</p> <p>0: 禁用<br/>1: 使能</p> <p>定时器配置为外部时钟或门控模式时, 需要通过软件对该位写 1 启动定期工作; 配置为触发模式时, 可硬件写 1。</p>                                                                                                                        |
| 1     | UD     | R/W | <p>禁止更新 (Update Disable)</p> <p>更新事件可引起 AUTORLD、PSC、CCx 产生更新设置的数值。</p> <p>0: 允许更新事件 (UEV)<br/>更新事件可以由以下任一情况产生:<br/>计数器上溢;<br/>设置 UEG 位。</p> <p>1: 禁止更新事件</p>                                                                                |
| 2     | URSEL  | R/W | <p>更新请求源 (Update Request Source Select)</p> <p>如果使能了中断或 DMA, 更新事件可产生更新中断或 DMA 请求, 通过该位可选择不同的更新请求源。</p> <p>0: 计数器上溢;<br/>设置 UEG 位。</p> <p>1: 计数器上溢</p>                                                                                       |
| 6:3   | 保留     |     |                                                                                                                                                                                                                                             |
| 7     | ARPEN  | R/W | <p>TMRx_AUTORLD 寄存器自动重装载缓冲使能 (Auto-reload Preload Enable)</p> <p>禁止缓存区时, 程序修改 TMRx_AUTORLD 会立刻修改装入计数器的数值; 使能缓存区时, 程序修改 TMRx_AUTORLD 会在下一个更新事件修改装入计数器的数值。</p> <p>0: 禁用<br/>1: 使能</p>                                                         |
| 9:8   | CLKDIV | R/W | <p>时钟分频系数 (Clock Division)</p> <p>数字滤波器的配置由 CK_INT 提供时钟, 通过设置位可调整数字滤波器的采用时钟。</p> <p>00: <math>t_{DTS}=t_{CK\_INT}</math><br/>01: <math>t_{DTS}=2 \times t_{CK\_INT}</math><br/>10: <math>t_{DTS}=4 \times t_{CK\_INT}</math><br/>11: 保留</p> |
| 15:10 | 保留     |     |                                                                                                                                                                                                                                             |

### 16.10.2 DMA/中断使能寄存器 (TMRx\_DIEN)

偏移地址: 0x0C

复位值: 0x0000

| 位/域 | 名称     | R/W | 描述                                                                                       |
|-----|--------|-----|------------------------------------------------------------------------------------------|
| 0   | UIEN   | R/W | <p>使能更新中断 (Update Interrupt Enable)</p> <p>0: 禁用<br/>1: 使能</p>                           |
| 1   | CC1IEN | R/W | <p>使能捕获/比较通道 1 中断 (Capture/Campare Channel1 Interrupt Enable)</p> <p>0: 禁用<br/>1: 使能</p> |

| 位/域  | 名称 | R/W | 描述 |
|------|----|-----|----|
| 15:2 |    |     | 保留 |

### 16.10.3 状态寄存器 (TMRx\_STS)

偏移地址: 0x10

复位值: 0x0000

| 位/域   | 名称       | R/W   | 描述                                                                                                                                                                                                                                                                                                 |
|-------|----------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | UIFLG    | RC_W0 | <p>产生更新事件中断标志位 (Update Event Interrupt Generate Flag)</p> <p>0: 没有发生更新事件中断<br/>1: 发生更新事件中断</p> <p>计数器数值重新装载或重新初始化时, 会产生更新事件, 该位由硬件置 1, 软件清 0; 更新事件的产生的情况有以下情况:</p> <p>(1) TMRx_CTRL1 寄存器的 UD=0, 上溢时产生更新事件;<br/>(2) TMRx_CTRL1 寄存器的 URSEL=0 和 UD=0, 配置 TMRx_CEG 寄存器的 UG=1 产生更新事件, 需要通过软件初始化计数器。</p> |
| 1     | CC1IFLG  | RC_W0 | <p>捕获/比较通道 1 中断标志 (Captuer/Compare Channel1 Interrupt Flag)</p> <p>当捕获比较通道 1 配置为输出时:</p> <p>0: 无匹配发生<br/>1: TMRx_CNT 的值与 TMRx_CC1 的值相匹配</p> <p>当捕获比较通道 1 配置为输入时:</p> <p>0: 没有发生输入捕获<br/>1: 发生输入捕获</p> <p>捕获事件发生时由硬件置 1, 可以由软件清 0 或者读 TMRx_CC1 寄存器时清 0。</p>                                         |
| 8:2   |          |       | 保留                                                                                                                                                                                                                                                                                                 |
| 9     | CC1RCFLG | RC_W0 | <p>捕获/比较通道 1 重复捕获标志 (Captuer/Compare Channel1 Repetition Capture Flag)</p> <p>0: 没有发生重复捕获<br/>1: 发生重复捕获</p> <p>计数器的值被捕获到 TMRx_CC1 寄存器中, 此时 CC1IFLG=1; 只有当通道被配置为输入捕获时, 该位由硬件置 1, 软件清 0。</p>                                                                                                         |
| 15:10 |          |       | 保留                                                                                                                                                                                                                                                                                                 |

### 16.10.4 控制事件产生寄存器 (TMRx\_CEG)

偏移地址: 0x14

复位值: 0x0000

| 位/域 | 名称  | R/W | 描述                                                                                                                                                                                                          |
|-----|-----|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | UEG | W   | <p>产生更新事件 (Update Event Generate)</p> <p>0: 无效<br/>1: 初始化计数器, 产生更新事件</p> <p>此位由软件置 1, 硬件清 0。</p> <p>注意: 产生更新事件时, 预分频器的计数器会清 0, 但是预分频系数不变。如果在向下计数模式下计数器会读取 TMRx_AUTORLD 的值; 如果在中央对齐模式下或者向上计数模式中计数器会被清 0。</p> |

| 位/域  | 名称    | R/W | 描述                                                                                                                                                                                                                                                                                                                 |
|------|-------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1    | CC1EG | W   | <p>产生捕获/比较通道 1 事件 (Capture/Compare Channel1 Event Generation)</p> <p>0: 无效<br/>1: 产生捕获/比较事件<br/>该位由软件置 1, 硬件自动清 0。<br/>如果通道 1 处于输出模式:<br/>当 CC1IFLG=1 时, 如果设置了 CC1IEN 位, 则产生相应的中断。<br/>如果通道 1 处于输入模式:<br/>捕获计数器的值存储在 TMRx_CC1 寄存器中; 配置 CC1IFLG=1, 如果还设置了 CC1IEN 位, 则产生相应的中断; 如果此时 CC1IFLG=1, 则需要配置 CC1RCFLG=1。</p> |
| 15:2 |       |     | 保留                                                                                                                                                                                                                                                                                                                 |

### 16.10.5 捕获/比较模式寄存器 1 (TMRx\_CCM1)

偏移地址: 0x18

复位值: 0x0000

可通过 CCxSEL 位配置定时器为输入 (捕获模式) 或输出 (比较模式)。该寄存器其它位的作用在输入和输出模式下不同, 同一个位在输出模式和输入模式下的功能是不同的。寄存器中的 OCx 描述了通道在输出模式下的功能, 寄存器中的 Icxx 描述了通道在输入模式下的功能。

**输出比较模式:**

| 位/域 | 名称     | R/W | 描述                                                                                                                                                                                                                                                                              |
|-----|--------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0 | CC1SEL | R/W | <p>选择捕获/比较通道 1 (Capture/Compare Channel1 Select)<br/>该位定义了输入/输出的方向以及选择输入引脚。</p> <p>00: CC1 通道为输出<br/>01: CC1 通道为输入, IC1 映射在 TI1 上<br/>10: 保留<br/>11: 保留<br/>注意: 该位仅在通道关闭时 (TMRx_CCEN 寄存器的 CC1EN=0 时) 可写。</p>                                                                    |
| 2   | OC1FEN | R/W | <p>快速使能输出比较通道 1 (Output Compare Channel1 Fast Enable)</p> <p>0: 禁用<br/>1: 使能<br/>该位用来提高捕获/比较输出对触发输入事件的响应。</p>                                                                                                                                                                   |
| 3   | OC1PEN | R/W | <p>使能输出比较通道 1 预装载 (Output Compare Channel1 Preload Enable)</p> <p>0: 禁用预装载功能, 通过程序写入 TMRx_CC1 寄存器的数值, 会马上起作用。<br/>1: 启用预装载功能, 通过程序写入 TMRx_CC1 寄存器的数值, 会在产生更新事件后起作用。<br/>注意: 当保护级别为 3 级时且通道配置为输出时, 该位不能被修改。当不确定预装载寄存器情况, 仅在单脉冲模式 (SPMEN=1) 下, 可以使用 PWM 模式, 否则不确定其接下来的输出比较结果。</p> |

| 位/域  | 名称     | R/W | 描述                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------|--------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6:4  | OC1MOD | R/W | <p>配置输出比较通道 1 模式 (Output Compare Channel1 Mode Configure)</p> <p>000: 冻结。输出比较对 OC1REF 无影响</p> <p>001: 匹配时输出置为高。计数器 CNT 的值和捕获比较寄存器的值 CCx 发生匹配时, 强制 OC1REF 为高电平</p> <p>010: 匹配时输出置为低。计数器的值和捕获比较寄存器的值发生匹配时, 强制 OC1REF 为低电平</p> <p>011: 匹配时输出翻转。计数器的值和捕获比较寄存器的值发生匹配时, 翻转 OC1REF 的电平</p> <p>100: 强制输出为低。强制 OC1REF 为低电平</p> <p>101: 强制输出为高。强制 OC1REF 为高电平</p> <p>110: PWM 模式 1 (计数器值&lt;输出比较值时置为高, 否则反之)</p> <p>111: PWM 模式 2 (计数器值&gt;输出比较值时置为高, 否则反之)</p> <p>注意: 当保护级别为 3 级时且通道配置为输出时, 该位不能被修改。在 PWM 模式 1 和 2 中, OC1REF 电平在比较结果改变或者输出比较模式从冻结模式转换到 PWM 模式时改变。</p> |
| 15:7 |        |     | 保留                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

#### 输入捕获模式:

| 位/域 | 名称     | R/W | 描述                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----|--------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0 | CC1SEL | R/W | <p>选择输入/捕获通道 1 (Capture/Compare Channel1 Select)</p> <p>00: CC1 通道为输出</p> <p>01: CC1 通道为输入, IC1 映射在 TI1 上</p> <p>10: 保留</p> <p>11: 保留</p> <p>注意: 该位仅在通道关闭时 (TMRx_CCEN 位的 CC1EN=0 时) 可写。</p>                                                                                                                                                                                                                                                                        |
| 3:2 | IC1PSC | R/W | <p>配置输入捕获通道 1 预分频因子 (Input Capture Channel1 Prescaler Configure)</p> <p>00: PSC=1</p> <p>01: PSC=2</p> <p>10: PSC=4</p> <p>11: PSC=8</p> <p>PSC 是预分频因子, 每 PSC 个事件触发一次捕获。</p>                                                                                                                                                                                                                                                                                       |
| 7:4 | IC1F   | R/W | <p>配置输入捕获通道 1 滤波器 (Input Capture Channel1 Filter Configure)</p> <p>0000: 禁用滤波器, 以 <math>f_{DTs}</math> 采样</p> <p>0001: DIV=1, N=2</p> <p>0010: DIV=1, N=4</p> <p>0011: DIV=1, N=8</p> <p>0100: DIV=2, N=6</p> <p>0101: DIV=2, N=8</p> <p>0110: DIV=4, N=6</p> <p>0111: DIV=4, N=8</p> <p>1000: DIV=8, N=6</p> <p>1001: DIV=8, N=8</p> <p>1010: DIV=16, N=5</p> <p>1011: DIV=16, N=6</p> <p>1100: DIV=16, N=8</p> <p>1101: DIV=32, N=5</p> <p>1110: DIV=32, N=6</p> |

| 位/域  | 名称 | R/W | 描述                                                               |
|------|----|-----|------------------------------------------------------------------|
|      |    |     | 1111: DIV=32, N=8<br>采样频率=定时器时钟频率/DIV; 滤波器长度=N, 表示每 N 个事件产生一个跳变。 |
| 15:8 |    |     | 保留                                                               |

### 16.10.6 捕获/比较使能寄存器 (TMRx\_CCEN)

偏移地址: 0x20

复位值: 0x0000

| 位/域  | 名称      | R/W | 描述                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------|---------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | CC1EN   | R/W | 使能捕获/比较通道 1 输出 (Capture/Compare Channel1 Output Enable)<br>捕获/比较通道 1 配置为输出时:<br>0: 禁用输出<br>1: 开启输出<br>捕获/比较通道 1 配置为输入时:<br>该位决定了计数器的值 CNT 是否能捕获进入 TMRx_CC1 寄存器中。<br>0: 禁用捕获<br>1: 开启捕获                                                                                                                                                                                                                                                                                |
| 1    | CC1POL  | R/W | 配置捕获/比较通道 1 输出极性 (Capture/Compare Channel1 Output Polarity Configure)<br>CC1 通道配置为输出时:<br>0: OC1 高电平有效<br>1: OC1 低电平有效<br>CC1 通道配置为输入时:<br>CC1POL 和 CC1NPOL 同时控制触发或捕获的信号 TI1FP1 和 TI2FP1 的极性。<br>00: 不反相/上升沿:<br>TixFP1 不反相 (门控、编码器模式下触发), 在 TixFP1 的上升沿捕获 (复位触发、捕获、外部时钟和触发模式)。<br>01: 反相/下降沿:<br>TixFP1 反相 (门控、编码器模式下触发), 在 TixFP1 的上升沿捕获 (复位触发、捕获、外部时钟和触发模式)。<br>10: 保留<br>11: 不反相/上升和下降沿:<br>TixFP1 不反相 (门控模式下触发, 不能用于编码器模式), 在 TixFP1 的上升沿捕获 (复位触发、捕获、外部时钟和触发模式)。 |
| 2    |         |     | 保留                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 3    | CC1NPOL | R/W | 配置捕获/比较通道 1 输出极性 Capture/Compare Channel1 Output Polarity Configure<br>CC1 通道配置为输出时:<br>CC1NPOL 一直保持清除状态<br>CC1 通道配置为输入时:<br>该位 CC1POL 同时控制触发或捕获的信号 TI1FP1 的极性。                                                                                                                                                                                                                                                                                                       |
| 15:4 |         |     | 保留                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

表格 74 标准 OCx 通道的输出控制位

| CCxEN 位 | OCx 输出状态                |
|---------|-------------------------|
| 0       | 禁止输出 (OCx=0, OCx_EN=0)  |
| 1       | OCx=OCxREF+极性, OCx_EN=1 |

注意：连接到标准 OCx 通道的外部 I/O 引脚状态，取决于 OCx 通道状态和 GPIO 以及 AFIO 寄存器。

#### 16.10.7 计数器寄存器 (TMRx\_CNT)

偏移地址: 0x24

复位值: 0x0000

| 位/域  | 名称  | R/W | 描述                    |
|------|-----|-----|-----------------------|
| 15:0 | CNT | R/W | 计数器数值 (Counter Value) |

#### 16.10.8 预分频寄存器 (TMRx\_PSC)

偏移地址: 0x28

复位值: 0x0000

| 位/域  | 名称  | R/W | 描述                                                                        |
|------|-----|-----|---------------------------------------------------------------------------|
| 15:0 | PSC | R/W | 预分频器数值 (Prescaler Value)<br>计数器的时钟频率 (CK_CNT) = $f_{CK\_PSC} / (PSC + 1)$ |

#### 16.10.9 自动重装载寄存器 (TMRx\_AUTORLD)

偏移地址: 0x2C

复位值: 0xFFFF

| 位/域  | 名称      | R/W | 描述                                                  |
|------|---------|-----|-----------------------------------------------------|
| 15:0 | AUTORLD | R/W | 自动重装载数值 (Auto Reload Value)<br>自动重装载的值为空时，计数器不进行计数。 |

#### 16.10.10 通道 1 捕获/比较寄存器 (TMRx\_CC1)

偏移地址: 0x34

复位值: 0x0000

| 位/域  | 名称  | R/W | 描述                                                                                                                                                                                                                                                                                                                               |
|------|-----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0 | CC1 | R/W | 捕获/比较通道 1 数值 (Capture/Compare Channel1 Value)<br>捕获/比较通道 1 配置为输入模式：<br>CC1 包含上次输入捕获通道 1 事件传输的计数器数值。<br>捕获/比较通道 1 配置为输出模式：<br>CC1 包含了当前装入捕获/比较寄存器数值。<br>捕获比较通道 1 的值 CC1 与计数器的值 CNT 比较，在 OC1 上产生输出信号。<br>当输出比较预装载禁止 (TMRx_CCM1 寄存器的 OC1PEN=0) 时，写入的数值会立即影响输出比较结果；<br>当输出比较预装载使能 (TMRx_CCM1 寄存器的 OC1PEN=1) 时，写入的值会在产生更新事件时影响输出比较结果。 |

#### 16.10.11 选项寄存器 (TMR11\_OPT)

偏移地址: 0x50

复位值: 0x0000

| 位/域  | 名称     | R/W | 描述                                                                                                                                                                     |
|------|--------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0  | RMPSEL | R/W | 定时器 11 输入 1 重映射选择 (Timer11 Input 1 Remap Select)<br>00: TMR11 通道 1 连接到 GPIO<br>01: TMR11 通道 1 连接到 GPIO<br>10: HSECLK_RTC 时钟连接到 TMR11_CH1 输入<br>11: TMR11 通道 1 连接到 GPIO |
| 15:2 |        |     | 保留                                                                                                                                                                     |

## 17 基本定时器 (TMR6/7)

### 17.1 简介

基本定时器 TMR6 和 TMR7 有一个无符号的 16 位计数器、自动重装载寄存器、预分频器和触发控制器。

基本定时器可以用作通用定时器来生成时间基准，还为 DAC 提供时钟，通过配置可以产生 DMA 请求。

### 17.2 主要特征

- (1) 计数器：16 位计数器，只能向上计数
- (2) 预分频器：16 位可编程预分频器
- (3) 时钟源：只有内部时钟
- (4) 单脉冲模式
- (5) 为 DAC 提供时钟

### 17.3 结构框图

图 61 基本定时器结构框图



### 17.4 功能描述

#### 17.4.1 时钟源选择

基本定时器由内部时钟源 TMRx\_CLK 驱动。

配置 TMRx\_CTRL1 寄存器的 CNTEN 位使能计数器，置位 CNTEN 位时，内部时钟 CK\_INT 经过控制器和预分频器产生 CK\_INT 驱动计数器。

## 17.4.2 时基单元

基本定时器的时基单元包含三个寄存器：

- 16 位计数器寄存器 (CNT)
- 16 位自动重装载寄存器 (AUTORLD)
- 16 位预分频寄存器 (PSC)

### 计数器 CNT

基本定时器中只有一种计数模式：向上计数模式。

#### 向上计数模式

当计数器处于向上计数模式时，计数器从 0 开始向上计数，当每来一个脉冲计数器就会增加 1，一直到计数器 (TMRx\_CNT) 值与自动重装载 (TMRx\_AUTORLD) 的值相等，然后计数器会重新从 0 开始计数，产生一个计数器向上溢出事件，自动重装载的值 (TMRx\_AUTORLD) 是提前写入的。

禁止更新事件，设置 TMRx\_CTRL1 寄存器中的 UD 位置 1。

产生更新中断或 DMA 请求，设置 TMRx\_CTRL1 寄存器中的 URSSEL 位。

在发生一个更新事件时，自动重装载寄存器和预分频寄存器都将会被更新。

图 62 计数器时序图，内部时钟分频系数为 1 或 2



## 预分频器 PSC

预分频器是 16 位的且是可编程的，它可以将计数器的时钟频率进行 1~65536 之间任意值的分频（由 **TMRx\_PSC** 寄存器控制），经过分频后的时钟将会驱动计数器 **CNT** 计数。预分频器带有缓冲器，它能够在运行中被改变。

### 17.4.3 调试模式

TMR6/7 可以在调试模式下配置，选择停止还是继续工作。取决于 **DBGMCU\_APB1F** 寄存器的 **TMRx\_STS** 位。

## 17.5 寄存器地址映射

下表中将基本定时器的所有寄存器映射到一个 16 位可寻址（编址）空间。

表格 75 TMR6/7 寄存器地址映射

| 寄存器名         | 描述          | 偏移地址 |
|--------------|-------------|------|
| TMRx_CTRL1   | 控制寄存器 1     | 0x00 |
| TMRx_CTRL2   | 控制寄存器 2     | 0x04 |
| TMRx_DIEN    | DMA/中断使能寄存器 | 0x0C |
| TMRx_STS     | 状态寄存器       | 0x10 |
| TMRx_CEG     | 控制事件产生寄存器   | 0x14 |
| TMRx_CNT     | 计数器寄存器      | 0x24 |
| TMRx_PSC     | 预分频寄存器      | 0x28 |
| TMRx_AUTORLD | 自动重装载寄存器    | 0x2C |

## 17.6 寄存器功能描述

### 17.6.1 控制寄存器 1 (TMRx\_CTRL1)

偏移地址: 0x00

复位值: 0x0000

| 位/域 | 名称    | R/W | 描述                                                                                                                                                                                                                       |
|-----|-------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | CNTEN | R/W | <p>使能计数器 (Counter Enable)<br/>           0: 禁用<br/>           1: 使能<br/>           定时器配置为外部时钟、门控模式和编码器模式时，需要通过软件对该位写 1 启动定期工作；配置为触发模式时，可硬件写 1。</p>                                                                       |
| 1   | UD    | R/W | <p>禁止更新 (Update Disable)<br/>           更新事件可引起 AUTORLD、PSC、CCx 产生更新设置的数值。<br/>           0: 允许更新事件 (UEV)<br/>           更新事件可以由以下任一情况产生：<br/>           计数器上溢；<br/>           设置 UEG 位；<br/>           从模式控制器产生的更新。</p> |

| 位/域  | 名称    | R/W | 描述                                                                                                                                                                               |
|------|-------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |       |     | 1: 禁止更新事件                                                                                                                                                                        |
| 2    | URSEL | R/W | <p>更新请求源 (Update Request Source Select)<br/>如果使能了中断或 DMA, 更新事件可产生更新中断或 DMA 请求, 通过该位可选择不同的更新请求源。</p> <p>0: 计数器上溢;<br/>    设置 UEG 位;<br/>    通过从模式控制器产生的更新。</p> <p>1: 计数器上溢</p>    |
| 3    | SPMEN | R/W | <p>使能单脉冲模式 (Single Pulse Mode Enable)<br/>产生更新事件时, 可改变通道的输出电平; 在该模式下, 会清除 CNTEN 位, 停止计数器, 后续不再改变通道的输出电平。</p> <p>0: 禁用<br/>1: 使能</p>                                              |
| 6:4  |       |     | 保留                                                                                                                                                                               |
| 7    | ARPEN | R/W | <p>TMRx_AUTORLD 寄存器自动重装载缓冲使能 (Auto-reload Preload Enable)<br/>禁止缓存区时, 程序修改 TMRx_AUTORLD 会立刻修改装入计数器的数值; 使能缓存区时, 程序修改 TMRx_AUTORLD 会在下一个更新事件修改装入计数器的数值。</p> <p>0: 禁用<br/>1: 使能</p> |
| 15:8 |       |     | 保留                                                                                                                                                                               |

### 17.6.2 控制寄存器 2 (TMRx\_CTRL2)

偏移地址: 0x04

复位值: 0x0000

| 位/域  | 名称    | R/W | 描述                                                                                                                                                                                                                                             |
|------|-------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0  |       |     | 保留                                                                                                                                                                                                                                             |
| 6:4  | MMSEL | R/W | <p>选择定时器主模式下用于 TRGO 的信号 (Master Mode Signal Select)<br/>工作在主模式的定时器的信号可用于 TRGO, 从而影响处在从模式且与主定时器级联的定时器工作, 具体影响可从模式的定时器配置有关。</p> <p>000: 复位, 主模式定时器的复位信号用于 TRGO<br/>001: 使能, 主模式定时器的计数器使能信号用于 TRGO<br/>010: 更新, 主模式定时器的更新事件用于 TRGO<br/>其他: 保留</p> |
| 15:7 |       |     | 保留                                                                                                                                                                                                                                             |

### 17.6.3 DMA/中断使能寄存器 (TMRx\_DIEN)

偏移地址: 0x0C

复位值: 0x0000

| 位/域 | 名称   | R/W | 描述                                                             |
|-----|------|-----|----------------------------------------------------------------|
| 0   | UIEN | R/W | <p>使能更新中断 (Update Interrupt Enable)</p> <p>0: 禁用<br/>1: 使能</p> |

| 位/域  | 名称    | R/W | 描述                                                         |
|------|-------|-----|------------------------------------------------------------|
| 7:1  |       |     | 保留                                                         |
| 8    | UDIEN | R/W | 使能更新的 DMA 请求 (Update DMA Request Enable)<br>0: 禁用<br>1: 使能 |
| 15:9 |       |     | 保留                                                         |

#### 17.6.4 状态寄存器 (TMRx\_STS)

偏移地址: 0x10

复位值: 0x0000

| 位/域  | 名称    | R/W   | 描述                                                                                                                                                                                                                                                                            |
|------|-------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | UIFLG | RC_W0 | 产生更新事件中断标志位 (Update Event Interrupt Generate Flag)<br>0: 没有发生更新事件中断<br>1: 发生更新事件中断<br>计数器数值重新装载或重新初始化时, 会产生更新事件, 该位由硬件置 1, 软件清 0; 更新事件的产生的情况有以下情况:<br>(1) TMRx_CTRL1 寄存器的 UD=0, 上溢时产生更新事件;<br>(2) TMRx_CTRL1 寄存器的 URSEL=0 和 UD=0, 配置 TMRx_CEG 寄存器的 UG=1 产生更新事件, 需要通过软件初始化计数器。 |
| 15:1 |       |       | 保留                                                                                                                                                                                                                                                                            |

#### 17.6.5 控制事件产生寄存器 (TMRx\_CEG)

偏移地址: 0x14

复位值: 0x0000

| 位/域  | 名称  | R/W | 描述                                                                                                                                                                                      |
|------|-----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | UEG | W   | 产生更新事件 (Update Event Generate)<br>0: 无效<br>1: 初始化计数器, 产生更新事件<br>此位由软件置 1, 硬件清 0。<br>注意: 产生更新事件时, 预分频器的计数器会清 0, 但是预分频系数不变。如果在向下计数模式下计数器会读取 TMRx_AUTORLD 的值; 如果在中央对齐模式下或者向上计数模式中计数器会被清 0。 |
| 15:1 |     |     | 保留                                                                                                                                                                                      |

注意: 连接到标准 OCx 通道的外部 I/O 引脚状态, 取决于 OCx 通道状态和 GPIO 以及 AFIO 寄存器。

#### 17.6.6 计数器寄存器 (TMRx\_CNT)

偏移地址: 0x24

复位值: 0x0000

| 位/域  | 名称  | R/W | 描述                    |
|------|-----|-----|-----------------------|
| 15:0 | CNT | R/W | 计数器数值 (Counter Value) |

#### 17.6.7 预分频寄存器 (TMRx\_PSC)

偏移地址: 0x28

复位值: 0x0000

| 位/域  | 名称  | R/W | 描述                                                                        |
|------|-----|-----|---------------------------------------------------------------------------|
| 15:0 | PSC | R/W | 预分频器数值 (Prescaler Value)<br>计数器的时钟频率 (CK_CNT) = $f_{CK\_PSC} / (PSC + 1)$ |

### 17.6.8 自动重装载寄存器 (TMRx\_AUTORLD)

偏移地址: 0x2C

复位值: 0xFFFF

| 位/域  | 名称      | R/W | 描述                                                   |
|------|---------|-----|------------------------------------------------------|
| 15:0 | AUTORLD | R/W | 自动重装载数值 (Auto Reload Value)<br>自动重装载的值为空时, 计数器不进行计数。 |

# 18 看门狗定时器 (WDT)

## 18.1 简介

看门狗是用来监测由软件错误引起的系统故障。片上一共有两个看门狗设备：独立看门狗和窗口看门狗，它们提高了安全性、使时间更加精确以及使用变得更加灵活。

独立看门狗只有在计数器减到 0 时，会复位，在没有减到 0 之前，刷新计数器的值不会发生复位。

窗口看门狗在计数器减到 0x3F 时会发生复位，当计数器计数的值在配置寄存器的窗口值之前，刷新计数器也会发生复位。

## 18.2 独立看门狗定时器 (IWDT)

### 18.2.1 简介

独立看门狗是由一个八位预分频器 IWDT\_PSC、12 位递减计数器、12 位重装载寄存器 IWDT\_CNTRLD、关键字寄存器 IWDT\_KEY 和状态寄存器 IWDT\_STS 组成。

独立看门狗有独立的时钟源，即使是在主时钟失效的情况下，它仍然有效。

独立看门狗适用于需要独立的环境但对精确度要求不高的场所。

### 18.2.2 结构框图

图 63 独立看门狗结构框图



注意：看门狗功能处于  $V_{DD}$  供电区，可以在停机或者待机模式下正常工作。

### 18.2.3 功能描述

#### 18.2.3.1 关键字寄存器

在关键字寄存器中写入 0xCCCC 开启独立看门狗，此时计数器开始向下计数，当计数器计数到 0x000 时，产生一次复位。

在关键字寄存器中写入 0xAAAA，重装载寄存器的值会被重新加载到计数器，以此来阻止看门狗复位。

在关键字寄存器中写入 0X5555，用来改写预分频寄存器和重装载寄存器的值。

#### 18.2.3.2 寄存器访问保护

预分频寄存器和重装载寄存器具有写保护功能，如果要改写这两个寄存器则需要写 0x5555 到关键字寄存器中，如果将其他的值写入关键字寄存器将会再次启动对寄存器的保护。

写 0xAAAA 到关键字寄存器中，也会启动写保护功能。

#### 18.2.3.3 硬件看门狗

启动了“硬件看门狗”功能之后，当系统上电复位，看门狗会自动运行。如果没有向关键字寄存器中写入 0xAAAA，计数器计数结束后，产生复位。

#### 18.2.3.4 调试模式

独立看门狗可以在调试模式下配置，选择停止还是继续工作。取决于 DBGMCU\_APB1F 寄存器的 IWDT\_STS 位。

表格 76 LSICLK=28kHz 时，最小/最大超时值

| PSC | 最小超时值   | 最大超时值   |
|-----|---------|---------|
| 0   | 0.125ms | 512ms   |
| 1   | 0.25ms  | 1024ms  |
| 2   | 0.5ms   | 2048ms  |
| 3   | 1ms     | 4096ms  |
| 4   | 2ms     | 8192ms  |
| 5   | 4ms     | 16384ms |
| 6   | 8ms     | 32768ms |

## 18.3 窗口看门狗定时器 (WWDT)

### 18.3.1 简介

窗口看门狗含有一个 7 位自由运行递减计数器、预分频器、控制寄存器 WWDT\_CTRL、配置寄存器 WWDT\_CFG 和状态寄存器 WWDT\_STS。

窗口看门狗时钟来自 PCLK1，计数器时钟由 CK 计数器时钟经过预分频分频得到（由配置寄存器配置）。

窗口看门狗适用于需要精确计时的场合。

### 18.3.2 结构框图

图 64 窗口看门狗结构框图



### 18.3.3 功能描述

使能窗口看门狗定时器，复位条件：

- 计数器计数小于 0x40 时，产生复位。
- 计数器计数到窗口寄存器的值之前，重装载计数器产生复位。

发生复位后，看门狗总是关闭状态，需要设置 `WWDT_CTRL` 控制寄存器的 `WWDTEN` 位才能开启看门狗。

窗口看门狗的计数器是自由状态，在看门狗禁止的情况下，计数器仍然继续递减计数。计数器必须要在窗口寄存器的值和 `0x40` 之间重装载，来避免复位。

设置配置寄存器的 `EWIEN` 位可以开启提前唤醒中断，当计数到 `0x40` 会产生中断，进入中断服务程序（ISR）可以用来防止窗口看门狗复位。如果要清除 `EWIEN` 中断需要在状态寄存器中写入 0。

窗口看门狗特有的窗口可以有效地监测程序是否故障，例如：假定一个程序段运行的时间是  $T$ ，设定窗口寄存器的值稍稍小于  $(TR-T)$ ，如果在窗口内没有重装载寄存器，说明程序出现了故障，当计数器计数到 `0x3F` 时，则会产生复位。

图 65 窗口看门狗时序图



窗口看门狗定时器超时的计算公式：

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

其中：

- $T_{WWDT}$ : WWDT 超时时间
- $T_{PCLK1}$ : 以 APB1 (单位为 ms) 为时钟周期

在  $PCLK1=36MHz$  时的最小/最大超时值：

表格 77  $PCLK1=30MHz$  时, 最小/最大超时值

| WTB | 最小超时值     | 最大超时值   |
|-----|-----------|---------|
| 0   | 136.53μs  | 8.74ms  |
| 1   | 273.07μs  | 17.48ms |
| 2   | 546.13μs  | 34.95ms |
| 3   | 1092.27μs | 69.91ms |

## 18.4 IWDT 寄存器地址映射

表格 78 IWDT 寄存器地址映射

| 寄存器名        | 描述        | 偏移地址 |
|-------------|-----------|------|
| IWDT_KEY    | 关键字寄存器    | 0x00 |
| IWDT_PSC    | 预分频寄存器    | 0x04 |
| IWDT_CNTRLD | 计数器重装载寄存器 | 0x08 |
| IWDT_STS    | 状态寄存器     | 0x0C |

## 18.5 IWDT 寄存器功能描述

可以用半字 (16 位) 或字 (32 位) 的方式操作这些外设寄存器。

### 18.5.1 关键字寄存器 (IWDT\_KEY)

偏移地址: 0x00

复位值: 0x0000 0000 (在待机模式复位)

| 位/域   | 名称  | R/W | 描述                                                                                                                                                                                                                   |
|-------|-----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0  | KEY | W   | 允许访问 IWDT 寄存器关键字值 (Allow Access IWDT Register Key Value)<br>写入 0x5555 表示允许访问 IWDT_PSC 和 IWDT_CNTRLD 寄存器。<br>软件写入 0xAAAA 表示执行重装载计数器, 需要一定的间隔写入, 防止看门狗复位。<br>写入 0xCCCC, 启动看门狗 (硬件看门狗不受此命令字限制)。<br>该寄存器只写, 读出值为 0x0000。 |
| 31:16 |     |     | 保留                                                                                                                                                                                                                   |

### 18.5.2 预分频寄存器 (IWDT\_PSC)

偏移地址: 0x04

复位值: 0x0000 0000

| 位/域  | 名称  | R/W | 描述                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0  | PSC | R/W | <p>配置预分频系数 (Prescaler Factor Configure)<br/>           有写保护功能, 向 IWDT_KEY 寄存器写入 0x5555 时允许访问该寄存器;<br/>           写该寄存器过程中, 当 IWDT_STS 寄存器的 PSCUFLG=0 时, 才能改变预分频因子; 读该寄存器过程中, 当 PSCUFLG=0 时, 读取 PSC 寄存器的数值才有效。</p> <p>000: PSC=4<br/>           001: PSC=8<br/>           010: PSC=16<br/>           011: PSC=32<br/>           100: PSC=64<br/>           101: PSC=128<br/>           110: PSC=256<br/>           111: PSC=256</p> |
| 31:3 | 保留  |     |                                                                                                                                                                                                                                                                                                                                                                                                                                    |

### 18.5.3 计数器重装载寄存器 (IWDT\_CNTRLRD)

偏移地址: 0x08

复位值: 0x0000 0FFF (待机模式时复位)

| 位/域   | 名称      | R/W | 描述                                                                                                                                                                                                                                               |
|-------|---------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11:0  | CNTRLRD | R/W | <p>设置看门狗计数器重装载值 (Watchdog Counter Reload Value Setup)<br/>           有写保护功能, 定义 IWDT_KEY 寄存器写入 0xAAAA 时载入看门狗计数器的值。在写该寄存器过程中, CNTUFLG=0 时, 才能对此寄存器进行修改。在读该寄存器过程中, 当 IWDT_STS 寄存器中的 CNTUFLG=0 时, 读取的数值才是有效的。</p> <p>看门狗超时周期可通过此重装载值和时钟预分频值来计算。</p> |
| 31:12 | 保留      |     |                                                                                                                                                                                                                                                  |

### 18.5.4 状态寄存器 (IWDT\_STS)

偏移地址: 0x0C

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

| 位/域  | 名称      | R/W | 描述                                                                                                                                                       |
|------|---------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | PSCUFLG | R   | <p>更新看门狗预分频器系数标志 (Watchdog Prescaler Factor Update Flag)<br/>           更新预分频器系数时, 由硬件置 1; 预分频器系数更新结束后, 由硬件清 0; 预分频器系数只有在 PSCUFLG 位被清 0 时更新。</p>         |
| 1    | CNTUFLG | R   | <p>更新看门狗计数器重装载值标志 (Watchdog Counter Reload Value Update Flag)<br/>           更新计数器重装载值时, 由硬件置 1; 计数器重装载值更新结束后, 由硬件清 0; 计数器重装载值只有在 CNTUFLG 位被清 0 时更新。</p> |
| 31:2 | 保留      |     |                                                                                                                                                          |

## 18.6 WWDT 寄存器地址映射

表格 79 WWDT 寄存器地址映射

| 寄存器名      | 描述    | 偏移地址 |
|-----------|-------|------|
| WWDT_CTRL | 控制寄存器 | 0x00 |
| WWDT_CFG  | 配置寄存器 | 0x04 |
| WWDT_STS  | 状态寄存器 | 0x08 |

## 18.7 WWDT 寄存器功能描述

可以用半字（16 位）或字（32 位）的方式操作这些外设寄存器。

### 18.7.1.1 控制寄存器 (WWDT\_CTRL)

偏移地址: 0x00

复位值: 0x0000 007F

| 位/域  | 名称     | R/W | 描述                                                                                                            |
|------|--------|-----|---------------------------------------------------------------------------------------------------------------|
| 6:0  | CNT    | R/W | 设置计数器数值 (Counter Value Setup)<br>该计数器是 7 位, CNT6 是最高有效位<br>这些位用来存储看门狗的计数器值, 当计数值从 0x40 减到 0x3F 时, 产生 WWDT 复位。 |
| 7    | WWDTEN | R/S | 使能窗口看门狗 (Window Watchdog Enable)<br>该位由软件置 1 且只能在复位后由硬件清除。当 WWDTEN=1, WWDT 可以产生复位。<br>0: 禁用<br>1: 使能          |
| 31:8 |        |     | 保留                                                                                                            |

### 18.7.1.2 配置寄存器 (WWDT\_CFG)

偏移地址: 0x04

复位值: 0x0000 007F

| 位/域   | 名称    | R/W | 描述                                                                                                                     |
|-------|-------|-----|------------------------------------------------------------------------------------------------------------------------|
| 6:0   | WIN   | R/W | 设置窗口值 (Window Value Setup)<br>该窗口值是 7 位, 用来和向下计数器作比较。                                                                  |
| 8:7   | TBPSC | R/W | 配置时基预分频系数 (Timer Base Prescaler Factor Configure)<br>PCLK1/4096 的基础上再分频<br>00: 不分频<br>01: 2 分频<br>10: 4 分频<br>11: 8 分频 |
| 9     | EWIEN | R/S | 使能提前唤醒中断 (Early Wakeup Interrupt Enable)<br>0: 无作用<br>1: 则当计数器值达到 0x40 时, 即产生中断; 此中断在复位后由硬件清除。                         |
| 31:10 |       |     | 保留                                                                                                                     |

### 18.7.1.3 状态寄存器 (WWDT\_STS)

偏移地址: 0x08

复位值: 0x0000 0000

| 位/域  | 名称     | R/W   | 描述                                                                                                                 |
|------|--------|-------|--------------------------------------------------------------------------------------------------------------------|
| 0    | EWIFLG | RC_W0 | 发生提前唤醒中断标志 (Early Wakeup Interrupt Occur Flag)<br>0: 未发生<br>1: 当计数器值达到 0x40 时由硬件置 1; 若中断未被使能, 该位也会被置 1; 由软件写 0 清除。 |
| 31:1 | 保留     |       |                                                                                                                    |

## 19 实时时钟 (RTC)

### 19.1 术语全称、缩写描述

表格 80 术语全称、缩写描述

| 中文全称 | 英文全称      | 英文缩写 |
|------|-----------|------|
| 秒    | Second    | SEC  |
| 闹钟   | Alarm     | ALR  |
| 预分频器 | Prescaler | PSC  |

### 19.2 简介

拥有采取 BCD 编码的亚秒、时间、日期寄存器，以及相应的闹钟寄存器，结合外部引脚可实现时间戳功能，带时钟校准功能及时间补偿。

### 19.3 主要特征

- (1) 时基单元
- (2) 时钟校准
- (3) 亚秒、时间、日期
- (4) 时间误差补偿
- (5) 闹钟（亚秒、时间、日期屏蔽）
- (6) 时间戳
- (7) 侵入检测
- (8) 2 种 RTC 输出
- (9) 备份域
- (10) 多种中断控制
- (11) 低功耗自动唤醒

### 19.4 结构框图

图 66 RTC 结构框图



注意：

(1) 复用功能输出：RTC\_OUT 是由以下两种的其中一种形式输出

- RTC\_CALIB: 通过 RTC\_CTRL 寄存器的 CALOEN 位开启此输出, 当 LSECLK 的频率是 32.768kHz 时, 时钟输出为 512Hz 或者 1Hz。
- RTC\_ALARM: 通过 RTC\_CTRL 寄存器的 OUTSEL 位开启此输出, 闹钟 A。

(2) 复用功能输入:

- RTC\_TS: 时间戳事件
- RTC\_TAMP1: 侵入事件检测 1

(3) RTC\_AF1 的复用功能与 PC13 相连。

## 19.5 功能描述

### 19.5.1 时基单元

#### 时钟源

RTC 有 3 个时钟源：

- 外部 LSECLK 晶振
- 外部 HSECLK 晶振
- 内部 LSICLK

通过配置时钟控制器 CCM 的寄存器选择不同的时钟源。

#### 预分频器

在备份电源供电情况下, RTC 外设的功耗需尽量降到最低, 为了兼顾功耗问题, RTC 内部采用双预分频器, 7 位的异步预分频器 APSC、15 位的同步预分频器 SPSC。

RTCCLK 先经过异步预分频器, 分频后的时钟到达同步预分频器, 合理配置两个

预分频器，能产生 1Hz 的时钟供日期使用。

使用预分频器时，建议异步预分频器尽可能调高，降低功耗。

同步预分频值同时也会用作亚秒计数器重载值。

### 19.5.2 时钟校准

#### 时钟同步

RTC 根据外部高精度时钟，结合寄存器 RTC\_SHIFT 可实现时钟同步。主要通过前后两次获取亚秒时段的时间戳，检测到 RTC 时钟与外部时钟的偏差。由于同步预分频值用作亚秒计数器重载值，而寄存器 RTC\_SHIFT 的 SFSEC 位又作用于亚秒计数器，因而调节 SFSEC 位，即可实现对 RTC 时钟的微调，人为增加、减少几个周期。

#### 参考时钟

RTC 内部拥有参考时钟检测，可用来补偿外部 LSECLK 晶振的偏差。设置 RCLKDEN 位使能参考时钟检测，外部 50Hz 或 60Hz 的参考时钟经 RTC\_REFIN 引脚与 RTC 内部 1Hz 时钟比较，通过这种机制自动补偿 LSECLK 分频后的 1Hz 时钟。

使能参考时钟检测后，时钟单元的同步、异步预分频器必须配置为默认值。

参考时钟检测不能与时钟同步同时使用，在待机模式下需要禁用参考时钟检测。

#### RTC 粗略数字校准

RTC\_DCAL 寄存器可配置为正校准或负校准，以提前或推迟更新日期，因此可调节有效频率。

#### RTC 精密数字校准

RTC 默认采用  $2^{20}$  个 RTCCLK 为一个校准周期，另外也可通过寄存器中的 CALW16CFG、CALW8CFG 设置为  $2^{19}$ 、 $2^{18}$  个 RTCCLK 为一个校准周期。当采用 LSECLK 作 RTCCLK 时钟源，RTC 的校准周期为 32s、16s、8s。

- 16s 校准周期，硬件设定 RECALF[0] 为 “0”
- 8s 校准周期，硬件设定 RECALF[1:0] 为 “00”

以 32s 的校准周期为例，校准的机制是在校准周期内，增添或减少一部分 RTCCLK 信号。

- 当使用 RECALF 时，每  $2^{20}$  个 RTCCLK 减少 RECALF 个 RTCCLK
- 当使用 ICALFEN，ICALFEN=1 时，每  $2^{11}$  个 RTCCLK 增添 1 个 RTCCLK
- 当使用 RECALF，ICALFEN 时，每  $2^{20}$  个 RTCCLK 增添 ( $512 * ICALFEN - RECALF$ ) 个 RTCCLK

### 19.5.3 RTC 写保护

为防止意外写入导致 RTC 计数异常，RTC 寄存器采用写保护机制，只有解除写保护，才能对写保护的寄存器进行操作。

上电后，RTC 寄存器进入写保护状态，系统复位不能解除写保护。当需要解除写保护时，通过往寄存器 **RTC\_WRPROM** 依次写入特殊的关键字“0xCA”、“0x53”。如果写入错误的关键字，RTC 立马又开启写保护。

### 19.5.4 日期寄存器

RTC 拥有采用 BCD 编码的亚秒、时间、日期影子寄存器，分别为 **RTC\_SUBSEC**、**RTC\_TIME**、**RTC\_DATE**。访问影子寄存器可以获得当前的日期，或者直接从日期寄存器获取日期。通过配置寄存器 **RTC\_CTRL** 的 **TIMEFCFG** 位，可选取 24 小时、12 小时的时间制。

RTC 每两个 **RTCCLK** 周期更新影子寄存器，并将标志位 **RSFLG** 置起，当从停机或待机唤醒后，一般不会更新影子寄存器，需要等待最多 1~2 个 **RTCCLK** 周期。系统复位引发影子寄存器的复位。

影子寄存器与  $f_{APB1}$  同步。

通过配置寄存器 **RTC\_CTRL** 的 **RCMCFG** 位，可选择读取日期的方式。

#### **RCMCFG=0，从影子寄存器读取日期**

该模式下，建议  $f_{APB1}$  大于  $7*f_{RTCCLK}$ ，当  $f_{APB1}$  过小，为确保读取日期值正常，需两次读取影子寄存器，两次获取的日期相同，则日期读取成功。

影子寄存器更新后，标志位 **RSFLG** 置起，软件必须等待 **RSFLG** 置位后读取日期，每次读取日期后，需手动清除 **RSFLG** 标志。

从停机或待机唤醒，由于影子寄存器未更新，因而第一时间需要清除 **RSFLG** 标志。

#### **RCMCFG=1，从日期寄存器读取日期**

当  $f_{APB1}$  小于  $7*f_{RTCCLK}$ ，或从低功耗唤醒时，建议直接从日期寄存器读取日期。

读取日期时未等待 **RSFLG** 标志置 1，并且刚好处于日期寄存器变化的阶段，则需读取两次日期。因而也建议读取两次日期寄存器，当两次读取日期值相同时，说明日期读取成功。

### 19.5.5 时间补偿

由于季节变化，有些时候需要进行时间补偿，使其更适合日常需求。RTC 内部集成时间补偿单元及其夏令时标志，用户可根据自身需求选择是否开启时间补偿。

通过设置寄存器 **RTC\_CTRL** 的 **STCCFG** 位，令夏季增加 1 小时；设置寄存器 **RTC\_CTRL** 的 **WTCCFG** 位，令冬季减少 1 小时。**BAKP** 标志用于记录夏令时是否设置。

### 19.5.6 可编程的闹钟

作为一个实时时钟，RTC 内部集成闹钟功能，主要通过闹钟配置寄存器、闹钟屏蔽，结合日期寄存器运作。

通过寄存器 RTC\_ALRMA/RTC\_ALRMASS 和 RTC\_ALRMB/RTC\_ALRMBSS 配置闹钟及其闹钟屏蔽，闹钟屏蔽告知 RTC 需要关注闹钟的时段。使能闹钟功能后，当关注的时段到了设定值时，闹钟才会触发，此时闹钟标志置起，如果开启了闹钟中断，则触发中断处理。

选取“秒”作为闹钟的时段，同步预分频值需要大于 3，闹钟才能正常运作。

### 19.5.7 时间戳

RTC 具有时间戳功能，RTC\_TS 引脚结合时间戳寄存器工作。

通过寄存器 RTC\_CTRL 的 TSETECFG 位设置时间戳检测极性，当 RTC\_TS 引脚识别到外部时间戳边沿信号时，RTC 自动将当前日期锁存在亚秒、时间、日期时间戳寄存器中，同时时间戳标志位 TSFLG 置 1。如果开启时间戳中断，则触发时间戳中断处理。

当 TSFLG 标志位置 1 时，此时又有一个时间戳事件，将导致时间戳溢出，标志位 TSOVRFLG 置 1。如果在清除 TSFLG 标志后，又立马检测到时间戳事件，TSFLG、TSOVRFLG 标志都会置 1。

#### TAMPER 复用功能

RTC\_TAMP1 复用功能可映射到 RTC\_AF1 或 RTC\_AF2，由 RTC\_TACFG 寄存器的 TP1MSEL 位决定。修改 TP1MSEL 后需清零 TP1EN 位，以避免 TP1FLG 意外置位。

### 19.5.8 备份域

备份域寄存器在切断主电源  $V_{DD}$  后，自动由  $V_{BAT}$  供电。系统复位、NRST 引脚复位、低功耗模式唤醒后的复位，都不会影响备份域寄存器。当  $V_{BAT}$  断电或者发生侵入事件时，将导致备份域寄存器复位。

备份域寄存器可用于缓存用户数据，利用其系统复位数据不发生变化的特性，可作为状态标志实现某种功能应用。

### 19.5.9 侵入检测

侵入检测是一种防止侵入造成数据泄露的数据自毁型保护装置，通过硬件电路设计，把侵入检测信号发送到侵入检测引脚。

侵入检测有多个侵入检测引脚，每个引脚由单独寄存器位使能。为更好地检测到真实的侵入事件，信号滤波可配置，同时每个引脚都可配置侵入检测极性。

#### 侵入检测极性

通过寄存器 RTC\_TACFG 中的 TpxAL 位，可选取低电平/上升沿、高电平/下降沿

作为侵入检测极性。

## 侵入信号滤波器

寄存器 **RTC\_TACFG** 中的 **TPSFSEL** 位用于配置侵入检测的采样频率，  
**RTC\_TACFG** 中的 **TPFCSEL** 位用于配置连续检测多少个有效侵入信号，才产生  
侵入事件。

特别地，如果在使能侵入检测引脚前，侵入检测引脚上已产生过侵入信号，此时  
使能侵入检测引脚会立即产生一个侵入事件。

## 侵入时间戳

某些时刻，为更好地记录侵入检测事件，RTC 能够把当前侵入时间戳锁存，通过  
寄存器 **RTC\_TACFG** 中的 **TPTSEN** 位即可快速使能该功能，无需额外使能时间  
戳功能。

### 19.5.10 自动唤醒

自动唤醒相对 RTC 闹钟，其硬件结构更简单，也没有 RTC 闹钟繁琐的配置过  
程，因而用于唤醒低功耗是个不错的方案。

RTC 内部有一个 16 位的自减型重装载计数器，用于自动唤醒装置。

该计数器的时钟由寄存器 **RTC\_CTRL** 的 **WUCLKSEL** 位选择，通过选取不同的  
时钟，自动唤醒的周期可配置成 122 $\mu$ s 到 36h 之间。先关闭自动唤醒，即清除  
**WUTEN**，当 **WUTWFLG** 标志位置 1 时，配置 **RTC\_CTRL** 寄存器的  
**WUCLKSEL** 位和重装载寄存器 **RTC\_AUTORLD**。

当计数器自减到 0 时，产生唤醒事件，**WUTFLG** 标志位置 1，进入下一轮自动唤  
醒之前，必须清除该标志位。

### 19.5.11 RTC 输出

RTC 输出把内部的 RTC 校准时钟、闹钟信号、自动唤醒信号输送给外部。

#### RTC 校准时钟

校准时钟输出一般用于观察 RTC 时钟源的精度，观测值用于时钟源的校准。通  
过 **RTC\_CTRL** 寄存器的 **CALOSEL** 位选取 512Hz、1Hz 信号输出源，  
**RTC\_CTRL** 寄存器的 **CALOEN** 位使能校准输出。

#### 校准复用功能输出

当置位 **RTC\_CTRL** 寄存器的 **CALOEN** 位时，**RTC\_AF1** 会使能校准复用功能。

#### 闹钟、自动唤醒信号

当闹钟或者自动唤醒运行的情况下，二者的事件可作为脉冲信号对外输出。  
**RTC\_CTRL** 寄存器的 **OUTSEL** 位选取信号输出源，**POLCFG** 位配置输出极性。

## 19.6 寄存器地址映射

表格 81 RTC 寄存器地址映射

| 寄存器名         | 描述             | 偏移地址      |
|--------------|----------------|-----------|
| RTC_TIME     | RTC 时间寄存器      | 0x00      |
| RTC_DATE     | RTC 日期寄存器      | 0x04      |
| RTC_CTRL     | RTC 控制寄存器      | 0x08      |
| RTC_STS      | RTC 状态寄存器      | 0x0C      |
| RTC_PSC      | RTC 预分频寄存器     | 0x10      |
| RTC_AUTORLD  | RTC 自动重装载寄存器   | 0x14      |
| RTC_DCAL     | RTC 粗略校准寄存器    | 0x18      |
| RTC_ALRMA    | RTC 闹钟 A 寄存器   | 0x1C      |
| RTC_ALRMB    | RTC 闹钟 B 寄存器   | 0x20      |
| RTC_WRPROT   | RTC 写保护寄存器     | 0x24      |
| RTC_SUBSEC   | RTC 亚秒寄存器      | 0x28      |
| RTC_SHIFT    | RTC 移位寄存器      | 0x2C      |
| RTC_TSTIME   | RTC 时间戳时间寄存器   | 0x30      |
| RTC_TSDATE   | RTC 时间戳日期寄存器   | 0x34      |
| RTC_TSSUBSEC | RTC 时间戳亚秒寄存器   | 0x38      |
| RTC_CAL      | RTC 校准寄存器      | 0x3C      |
| RTC_TACFG    | RTC 侵入和复用配置寄存器 | 0x40      |
| RTC_ALRMASS  | RTC 闹钟 A 亚秒寄存器 | 0x44      |
| RTC_ALRMBSS  | RTC 闹钟 B 亚秒寄存器 | 0x48      |
| RTC_BAKPx    | RTC 备份寄存器      | 0x50-0x9C |

## 19.7 寄存器功能描述

### 19.7.1 RTC 时间寄存器 (RTC\_TIME)

偏移地址: 0x00

备份域复位值: 0x0000 0000

系统复位: RCMCFG =0: 0x0000 0000; RCMCFG =1: 0xXXXX XXXX

RTC\_TIME 是时间影子寄存器, 该寄存器只能在初始化模式下写入, 处于写保护状态。

| 位/域 | 名称   | R/W | 描述                                                                  |
|-----|------|-----|---------------------------------------------------------------------|
| 3:0 | SECU | R/W | 设置秒个位的值以 BCD 格式存储 (Set Up the Units Digit of Seconds in BCD Format) |

| 位/域   | 名称       | R/W | 描述                                                                  |
|-------|----------|-----|---------------------------------------------------------------------|
| 6:4   | SECT     | R/W | 设置秒十位的值以 BCD 格式存储 (Set Up the Tens Digit of Seconds in BCD Format)  |
| 7     | 保留       |     |                                                                     |
| 11:8  | MINU     | R/W | 设置分个位的值以 BCD 格式存储 (Set Up the Units Digit of Minutes in BCD Format) |
| 14:12 | MINT     | R/W | 设置分十位的值以 BCD 格式存储 (Set Up the Tens Digit of Minutes in BCD Format)  |
| 15    | 保留       |     |                                                                     |
| 19:16 | HRU      | R/W | 设置小时个位的值以 BCD 格式存储 (Set Up the Units Digit of Hours in BCD Format)  |
| 21:20 | HRT      | R/W | 设置小时十位的值以 BCD 格式存储 (Set Up the Tens Digit of Hours in BCD Format)   |
| 22    | TIMEFCFG | R/W | 配置时间格式 (Time Format Configure)<br>0: AM 或 24 小时制<br>1: PM           |
| 31:23 | 保留       |     |                                                                     |

### 19.7.2 RTC 日期寄存器 (RTC\_DATE)

偏移地址: 0x04

备份域复位值: 0x0000 2101

RTC\_DATE 是日期影子寄存器, 该寄存器只能在初始化模式下写入, 处于写保护状态。

系统复位: RCMCFG =0: 0x0000 0000; RCMCFG =1: 0xXXXX XXXX

| 位/域   | 名称      | R/W | 描述                                                                       |
|-------|---------|-----|--------------------------------------------------------------------------|
| 3:0   | DAYU    | R/W | 设置日个位的值以 BCD 格式存储 (Set Up the Units Digit of Days in BCD Format)         |
| 5:4   | DAYT    | R/W | 设置日十位的值以 BCD 格式存储 (Set Up the Tens Digit of Days in BCD Format)          |
| 7:6   | 保留      |     |                                                                          |
| 11:8  | MONU    | R/W | 设置月个位的值以 BCD 格式存储 (Set Up the Units Digit of Months in BCD Format)       |
| 12    | MONT    | R/W | 设置月十位的值以 BCD 格式存储 (Set Up the Tens Digit of Months in BCD Format)        |
| 15:13 | WEEKSEL | R/W | 选择日期单位 (Week Day Units Select)<br>000: 禁用<br>001: 星期一<br>...<br>111: 星期日 |
| 19:16 | YRU     | R/W | 设置年个位的值以 BCD 格式存储 (Set Up the Units Digit of Years in BCD Format)        |
| 23:20 | YRT     | R/W | 设置年十位的值以 BCD 格式存储 (Set Up the Tens Digit of Years in BCD Format)         |
| 31:24 | 保留      |     |                                                                          |

### 19.7.3 RTC 控制寄存器 (RTC\_CTRL)

偏移地址: 0x08

备份域复位值: 0x0000 0000

系统复位: 0xXXXX XXXX

注意:

- (1) 该寄存器的位 7, 6 和 4 只能在初始化模式下写入。
- (2) 不建议在日期的小时数在增加的时候去改写此寄存器, 因为可能会屏蔽正确的小时增量。
- (3) 改写 STCCFG 和 WTCCFG 的值将在下一秒生效。
- (4) 该寄存器处于写保护下。

| 位/域 | 名称       | R/W | 描述                                                                                                                                                               |
|-----|----------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0 | WUCLKSEL | R/W | 选择唤醒时钟 (Wakeup Clock Select)<br>000: RTC/16<br>001: RTC/8<br>010: RTC/4<br>011: RTC/2<br>10x: clk_spre(通常是 1Hz)<br>11x: clk_spre(通常是 1Hz)和将 216 加到 WUAUTORE 计数器值 |
| 3   | TSETECFG | R/W | 配置时间戳事件触发边沿 (Time Stamp Event Trigger Edge Configure)<br>该位表示 RTC_TS 是在上升沿还是下降沿生成一个时间戳事件。<br>0: 上升沿<br>1: 下降沿<br>该位要在 TSEN=0 时才能改变。                              |
| 4   | RCLKDEN  | R/W | 使能 RTC_REFIN 参考时钟检测 (RTC_REFIN Reference Clock Detection Enable)<br>0: 禁用<br>1: 使能<br>SPSC 必须为 0x00FF。                                                           |
| 5   | RCMCFG   | R/W | 配置读取日期值模式 (Read Calendar Value Mode Configure)<br>0: 从影子寄存器读取日期值, 影子寄存器每两个 RTCCLK 周期更新一次<br>1: 从日期寄存器读取日期值<br>如果 APB1 时钟频率低于 RTCCLK 频率的 7 倍, RCMCFG 必须置 1。       |
| 6   | TIMEFCFG | R/W | 配置时间格式 (Time Format Configure)<br>0: 24 小时/天格式<br>1: AM/PM 时间格式                                                                                                  |
| 7   | DCALEN   | R/W | 使能粗略数字校准 (Coarse Digital Calibration Enable)<br>0: 禁用<br>1: 使能<br>APSC 需 $\geq 6$ 。                                                                              |
| 8   | ALRAEN   | R/W | 使能报警 A 功能 (Alarm A Function Enable)<br>0: 禁用<br>1: 使能                                                                                                            |
| 9   | ALRBEN   | R/W | 使能报警 B 功能 (Alarm B Function Enable)                                                                                                                              |

| 位/域   | 名称      | R/W | 描述                                                                                                                                                                      |
|-------|---------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |         |     | 0: 禁用<br>1: 使能                                                                                                                                                          |
| 10    | WUTEN   | R/W | 使能唤醒计时器 (Wakeup Timer Enable)<br>0: 禁用<br>1: 使能                                                                                                                         |
| 11    | TSEN    | R/W | 使能时间戳 (Time Stamp Enable)<br>0: 禁用<br>1: 使能                                                                                                                             |
| 12    | ALRAIEN | R/W | 使能报警 A 中断 (Alarm A Interrupt Enable)<br>0: 禁用<br>1: 使能                                                                                                                  |
| 13    | ALRBIEN | R/W | 使能报警 B 中断 (Alarm B Interrupt Enable)<br>0: 禁用<br>1: 使能                                                                                                                  |
| 14    | WUTIEN  | R/W | 使能唤醒计时器中断 (Wakeup Timer Interrupt Enable)<br>0: 禁用<br>1: 使能                                                                                                             |
| 15    | TSIEN   | R/W | 使能时间戳中断 (Time Stamp Interrupt Enable)<br>0: 禁用<br>1: 使能                                                                                                                 |
| 16    | STCCFG  | R/W | 配置夏季时间变化 (Summer Time Change Configure)<br>读过程中该位会一直保持为 0; 如果在初始化模式以外设置该位, 日期时间加 1。<br>0: 无效<br>1: 当前时间增加 1 小时, 用于校准夏季时间变化                                              |
| 17    | WTCCFG  | R/W | 配置冬季时间变化 (Winter Time Change Configure)<br>读过程中该位会一直保持为 0; 如果在初始化模式以外设置该位, RCT_TIME 寄存器的 HRx 为 0 时, 该位无效, HRx 不为 0 时, 日期时间减 1。<br>0: 无效<br>1: 当前时间减少 1 小时, 用于校准冬季时间变化   |
| 18    | BAKP    | R/W | 设置备份值 (Backup Value Setup)<br>该位表示夏季时间是否已经发生变化, 由用户写入。                                                                                                                  |
| 19    | CALOSEL | R/W | 选择校准输出值 (Calibration Output Value Select)<br>CALOEN=1 时, 该位用于选择 RTC_CALIB 的输出信号。<br>0: 512Hz<br>1: 1Hz<br>上述频率在 RTCCLK 为 32.768kHz 和预分频器处于默认值 (APSC=127, SPSC=255) 时有效。 |
| 20    | POLCFG  | R/W | 配置输出极性 (Output Polarity Configure)<br>该位表示 ALRAFLG/ALRBFLG/WUTFLG 位置 1 时 (取决于 OUTSEL 位), 引脚的电平状态。<br>0: 高电平<br>1: 低电平                                                   |
| 22:21 | OUTSEL  | R/W | 选择输出方式 (Output Way Select)<br>该位用于选择 RTC_ALARM 输出关联的标志位。                                                                                                                |

| 位/域   | 名称     | R/W | 描述                                                                       |
|-------|--------|-----|--------------------------------------------------------------------------|
|       |        |     | 00: 禁用<br>01: 闹钟 A 输出<br>10: 闹钟 B 输出<br>11: 唤醒输出                         |
| 23    | CALOEN | R/W | 使能校准输出 (Calibration Output Enable)<br>该位使能 RTC_CAL 输出。<br>0: 禁用<br>1: 使能 |
| 31:24 | 保留     |     |                                                                          |

#### 19.7.4 RTC 状态寄存器 (RTC\_STS)

偏移地址: 0x0C

备份域复位值: 0x0000 0007

系统复位: 0xFFFF XXXX

该寄存器 (除 RTC\_STS[13:8]位外) 处于写保护状态。

| 位/域 | 名称       | R/W   | 描述                                                                                                                                                                                                   |
|-----|----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | ALRAWFLG | R     | 发生闹钟 A 写入标志 (Alarm A Write Occur Flag)<br>当 RTC_CTRL 的 ALRAEN=0 后, 闹钟 A 的值发生变化, 由硬件置 1; 在初始化模式下由硬件清除。<br>0: 不可以更新闹钟 A<br>1: 可以更新闹钟 A                                                                 |
| 1   | ALRBWFLG | R     | 发生闹钟 B 写入标志 (Alarm B Write Occur Flag)<br>当 RTC_CTRL 的 ALRBEN=0 后, 闹钟 B 的值发生变化, 由硬件置 1; 在初始化模式下由硬件清除。<br>0: 不可以更新闹钟 B<br>1: 可以更新闹钟 B                                                                 |
| 2   | WUTWFLG  | R     | 发生唤醒计时器写入标志 (Wakeup Timer Write Occur Flag)<br>在 WUTEN=0 且唤醒定时器的值可以被改变时此位由硬件置位。<br>0: 不允许更新唤醒定时器配置<br>1: 允许更新唤醒计时器配置                                                                                 |
| 3   | SOPFLG   | R     | 发生移位操作挂起标志 (Shift Operation Pending Occur Flag)<br>0: 未发生<br>1: 发生<br>当通过向 RTC_SHIFT 寄存器写入产生一个移位操作时, 该位立即由硬件置 1。当相应的移位操作执行完毕后, 该位由软件清 0。对 SOPFLG 写入无效。                                               |
| 4   | INITSFLG | R     | 发生日期初始化状态标志 (Initialization State Occur Flag)<br>当日期中“年”字段不为“0”时, 该位由硬件置位。<br>0: 未发生<br>1: 发生                                                                                                        |
| 5   | RSFLG    | RC_W0 | 发生日期影子寄存器同步标志 (Registers Synchronization Occur Flag)<br>当日期寄存器中的内容复制到影子寄存器 (RTC_SUBSEC、RTC_TIME 和 RTC_DATE) 中时, 该位由硬件置 1; 当移位操作被挂起 (SOPFLG=1) 或处于忽略影子寄存器模式 (RCMCFG=1) 时, 在初始化模式下该位由硬件清 0; 该位也可由软件清除。 |

| 位/域   | 名称       | R/W   | 描述                                                                                                                                          |
|-------|----------|-------|---------------------------------------------------------------------------------------------------------------------------------------------|
|       |          |       | 在初始化模式下, 该位由硬件/软件清除。<br>0: 未同步<br>1: 同步                                                                                                     |
| 6     | RINITFLG | R     | 发生日期寄存器初始化标志 (Register Initialization Occur Flag)<br>该位置“1”, RTC 处在初始化状态, 时间、日期和预分频器寄存器可被更新。<br>0: 不可以初始化<br>1: 初始化                         |
| 7     | INITEN   | R/W   | 使能初始化模式 (Initialization Mode Enable)<br>0: 自由运行模式<br>1: 初始化模式, 可以用来编程 RTC_TIME 和 RTC_DATE, 以及 RTC_PSC。计数器停止计数, 一直到 INITEN 复位之后, 计数器从新值开始计数。 |
| 8     | ALRAFLG  | RC_W0 | 发生闹钟 A 匹配标志 (Alarm A Match Occur Flag)<br>当 RTC_TIME 和 RTC_DATE 与闹钟 A 寄存器 RTC_ALRMA 匹配时, 该标志由硬件置位。<br>该标志由软件写 0 清除。                         |
| 9     | ALRBFLG  | RC_W0 | 发生闹钟 B 匹配标志 (Alarm B Match Occur Flag)<br>当 RTC_TIME 和 RTC_DATE 与闹钟 B 寄存器 RTC_ALRMB 匹配时, 该标志由硬件置位。<br>该标志由软件写 0 清除。                         |
| 10    | WUTFLG   | RC_W0 | 发生唤醒计时器标志 (Wakeup Timer Occur Flag)<br>当自动刷新计数器计数到 0 时, 由硬件值 1; 由软件写 0 清除。<br>在 WUTFLG 再次置 1 的 1.5 个 RTCCCLK 周期之前清除该标志。                     |
| 11    | TSFLG    | RC_W0 | 发生时间戳标志 (Time Stamp Occur Flag)<br>当产生时间戳事件时该标志由硬件置 1; 由软件写 0 清除。                                                                           |
| 12    | TSOVRFLG | RC_W0 | 发生时间戳溢出标志 (Time Stamp Overflow Occur Flag)<br>在 TSFLG=1 且产生时间戳事件时该标志位由硬件置 1; 由软件写 0 清除。<br>该位建议在 TSFLG 标志位清除后再清除。                           |
| 13    | TP1FLG   | RC_W0 | 发生 RTC_TP1FLG 检测标志 (RTC_TP1FLG Detection Occur Flag)<br>在 RTC_TP1FLG 输入检测到侵入事件时该标志由硬件置 1; 由软件写 0 清除。                                        |
| 14    | TP2FLG   | RC_W0 | 发生 RTC_TP2FLG 检测标志 (RTC_TP2FLG Detection Occur Flag)<br>当在 RTC_TP2FLG 输入检测到侵入事件时该标志由硬件置 1; 由软件写 0 清除。                                       |
| 15    |          |       | 保留                                                                                                                                          |
| 16    | RCALPFLG | R     | 发生重新校准挂起标志 (Recalibration Pending Occur Flag)<br>当软件向 RTC_CAL 做写操作时该位自动置 1, 此时 RTC_CAL 寄存器被锁定。<br>当有其他新的校准设置执行时, 该位返回 0。                    |
| 31:17 |          |       | 保留                                                                                                                                          |

### 19.7.5 RTC 预分频寄存器 (RTC\_PSC)

偏移地址: 0x10

备份域复位值: 0x007F 00FF

系统复位: 0xXXXX XXXX

该寄存器只能在初始化模式下写入, 初始化必须由两次独立的写访问完成, 处于写保护状态。

| 位/域   | 名称   | R/W | 描述                                                                             |
|-------|------|-----|--------------------------------------------------------------------------------|
| 14:0  | SPSC | R/W | 同步预分频器系数 (Synchronous Prescaler Coefficient)<br>ck_spre 频率=ck_apre 频率/(SPSC+1) |
| 15    |      |     | 保留                                                                             |
| 22:16 | APSC | R/W | 异步预分频器系数 (Asynchronous Prescaler Coefficient)<br>ck_apre 频率=RTCCLK 频率/(APSC+1) |
| 31:23 |      |     | 保留                                                                             |

### 19.7.6 RTC 自动重装载寄存器 (RTC\_AUTORLD)

偏移地址: 0x14

备份域复位值: 0x0000 FFFF

系统复位: 0xXXXX XXXX

该寄存器只能在 RTC\_STS 的 WUTEFLG 置 1 时写入, 处于写保护状态。

| 位/域   | 名称       | R/W | 描述                                                                                                                                                                                                                                                                                                                                                 |
|-------|----------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0  | WUAUTORE | R/W | 设置唤醒自动重载值 (Wakeup Auto-reload Value Setup)<br>当激活唤醒计时器(WUTEN=1)时, 每个 CLK_WUAUTORE 周期会将该标志位置 1 一次, 通过 RTC_CTRL 寄存器的 WUCLKSEL 位设置 CLK_WUAUTORE 周期。<br>当 WUCLKSEL[2]=1 时, 唤醒计时器被设置为 17 位, WUCLKSEL[1] 其实是 WUAUTORE[16], 是重加载到计时器中的最关键的位。<br>设置 WUTEN 后, WUTFLG 的第一个断言出现 CLK_WUAUTORE 循环。<br>禁止使用 WUCLKSEL[2:0]=011(RTCCLK/2)从 WUAUTORE[15:0]到 0x0000。 |
| 31:16 |          |     | 保留                                                                                                                                                                                                                                                                                                                                                 |

### 19.7.7 RTC 粗略校准寄存器 (RTC\_DCAL)

偏移地址: 0x18

备份域复位值: 0x0000 0000

系统复位: 0xXXXX XXXX

| 位/域  | 名称      | R/W | 描述                                                                                                                                                                                                                                                                              |
|------|---------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4:0  | DCAL    | R/W | 数字校准 (Digital Calibration)<br>DCALCFG=0 (正校准)<br>00000: + 0 ppm<br>00001: + 4 ppm (四舍五入值)<br>00010: + 8 ppm (四舍五入值)<br>..<br>11111: + 126 ppm (四舍五入值)<br>DCALCFG=1 (负校准)<br>00000: - 0 ppm<br>00001: - 2 ppm (四舍五入值)<br>00010: - 4 ppm (四舍五入值)<br>..<br>11111: - 63 ppm (四舍五入值) |
| 6:5  |         |     | 保留                                                                                                                                                                                                                                                                              |
| 7    | DCALCFG | R/W | 配置数字校准 (Digital Calibration Configure)<br>0: 正校准-增加日期更新频率<br>1: 负校准-减少日期更新频率                                                                                                                                                                                                    |
| 31:8 |         |     | 保留                                                                                                                                                                                                                                                                              |

### 19.7.8 RTC 闹钟 A 寄存器 (RTC\_ALRMA)

偏移地址: 0x1C

备份域复位值: 0x0000 0000

系统复位: 0xXXXX XXXX

该寄存器只能在 RTC\_STS 的 ALRWFLG 置 1 或初始化模式下写入, 处于写保护状态。

| 位/域   | 名称     | R/W | 描述                                                                                                      |
|-------|--------|-----|---------------------------------------------------------------------------------------------------------|
| 3:0   | SECU   | R/W | 设置秒个位的值以 BCD 格式存储 (Set Up the Units Digit of Seconds in BCD Format)                                     |
| 6:4   | SECT   | R/W | 设置秒十位的值以 BCD 格式存储 (Set Up the Tens Digit of Seconds in BCD Format)                                      |
| 7     | SECMEN | R/W | 使能 Alarm A “秒” 屏蔽 (Alarm A Seconds Mask Enable)<br>0: 若 “秒” 匹配, 置位 Alarm A<br>1: 屏蔽 “秒” 的值对 Alarm A 的影响 |
| 11:8  | MINU   | R/W | 设置分个位的值以 BCD 格式存储 (Set Up the Units Digit of Minutes in BCD Format)                                     |
| 14:12 | MINT   | R/W | 设置分十位的值以 BCD 格式存储 (Set Up the Tens Digit of Minutes in BCD Format)                                      |
| 15    | MINMEN | R/W | 使能 Alarm A “分” 屏蔽 (Alarm A Minutes Mask Enable)<br>0: 若 “分” 匹配, 置位 Alarm A<br>1: 屏蔽 “分” 的值对 Alarm A 的影响 |
| 19:16 | HRU    | R/W | 设置小时个位的值以 BCD 格式存储 (Set Up the Units Digit of Hours in BCD Format)                                      |
| 21:20 | HRT    | R/W | 设置小时十位的值以 BCD 格式存储 (Set Up the Tens Digit of Hours in BCD Format)                                       |

| 位/域   | 名称       | R/W | 描述                                                                                                      |
|-------|----------|-----|---------------------------------------------------------------------------------------------------------|
| 22    | TIMEFCFG | R/W | 配置时间格式 (Time Format Configure)<br>0: AM 或 24 小时制<br>1: PM                                               |
| 23    | HRMEN    | R/W | 使能 Alarm A “时” 屏蔽 (Alarm A Hours Mask Enable)<br>0: 若 “小时” 匹配, 置位 Alarm A<br>1: 屏蔽 “小时” 的值对 Alarm A 的影响 |
| 27:24 | DAYU     | R/W | 设置日个位的值以 BCD 格式存储 (Set Up the Units Digit of Days in BCD Format)                                        |
| 29:28 | DAYT     | R/W | 设置日十位的值以 BCD 格式存储 (Set Up the Tens Digit of Days in BCD Format)                                         |
| 30    | WEEKSEL  | R/W | 选择日期 (Week Day Select)<br>0: DAYU 表示日期<br>1: DAYU 表示星期的数。DAYT 无作用。                                      |
| 31    | DATEMEN  | R/W | 使能 Alarm A 日期屏蔽 (Alarm A Date Mask Enable)<br>0: 若日期/星期匹配, 置位 Alarm A<br>1: 屏蔽日期/星期的值对 Alarm A 的影响      |

### 19.7.9 RTC 闹钟 B 寄存器 (RTC\_ALRMB)

偏移地址: 0x20

备份域复位值: 0x0000 0000

系统复位: 0xXXXX XXXX

该寄存器只能在 RTC\_STS 的 ALRWFLG 置 1 或初始化模式下写入, 处于写保护状态。

| 位/域   | 名称       | R/W | 描述                                                                                                      |
|-------|----------|-----|---------------------------------------------------------------------------------------------------------|
| 3:0   | SECU     | R/W | 设置秒个位的值以 BCD 格式存储 (Set Up the Units Digit of Seconds in BCD Format)                                     |
| 6:4   | SECT     | R/W | 设置秒十位的值以 BCD 格式存储 (Set Up the Tens Digit of Seconds in BCD Format)                                      |
| 7     | SECMEN   | R/W | 使能 Alarm B “秒” 屏蔽 (Alarm B Seconds Mask Enable)<br>0: 若 “秒” 匹配, 置位 Alarm B<br>1: 屏蔽 “秒” 的值对 Alarm B 的影响 |
| 11:8  | MINU     | R/W | 设置分个位的值以 BCD 格式存储 (Set Up the Units Digit of Minutes in BCD Format)                                     |
| 14:12 | MINT     | R/W | 设置分十位的值以 BCD 格式存储 (Set Up the Tens Digit of Minutes in BCD Format)                                      |
| 15    | MINMEN   | R/W | 使能 Alarm B “分” 屏蔽 (Alarm B Minutes Mask Enable)<br>0: 若 “分” 匹配, 置位 Alarm B<br>1: 屏蔽 “分” 的值对 Alarm B 的影响 |
| 19:16 | HRU      | R/W | 设置小时个位的值以 BCD 格式存储 (Set Up the Units Digit of Hours in BCD Format)                                      |
| 21:20 | HRT      | R/W | 设置小时十位的值以 BCD 格式存储 (Set Up the Tens Digit of Hours in BCD Format)                                       |
| 22    | TIMEFCFG | R/W | 配置时间格式 (Time Format Configure)<br>0: AM 或 24 小时制<br>1: PM                                               |

| 位/域   | 名称      | R/W | 描述                                                                                                 |
|-------|---------|-----|----------------------------------------------------------------------------------------------------|
| 23    | HRMEN   | R/W | 使能 Alarm B “时”屏蔽 (Alarm B Hours Mask Enable)<br>0: 若“小时”匹配, 置位 Alarm B<br>1: 屏蔽“小时”的值对 Alarm B 的影响 |
| 27:24 | DAYU    | R/W | 设置日个位的值以 BCD 格式存储 (Set Up the Units Digit of Days in BCD Format)                                   |
| 29:28 | DAYT    | R/W | 设置日十位的值以 BCD 格式存储 (Set Up the Tens Digit of Days in BCD Format)                                    |
| 30    | WEEKSEL | R/W | 选择日期 (Week Day Select)<br>0: DAYU 表示日期<br>1: DAYU 表示星期的数。DAYT 无作用。                                 |
| 31    | DATEMEN | R/W | 使能 Alarm B 日期屏蔽 (Alarm B Date Mask Enable)<br>0: 若日期/星期匹配, 置位 Alarm B<br>1: 屏蔽日期/星期的值对 Alarm B 的影响 |

#### 19.7.10 RTC 写保护寄存器 (RTC\_WRPROT)

偏移地址: 0x24

复位值: 0x0000 0000

| 位/域  | 名称  | R/W | 描述                                                                     |
|------|-----|-----|------------------------------------------------------------------------|
| 7:0  | KEY | W   | 设置写保护键值 (Write Protection Key Value Setup)<br>此字节由软件编写, 读取此字节始终为 0x00。 |
| 31:8 | 保留  |     |                                                                        |

#### 19.7.11 RTC 亚秒寄存器 (RTC\_SUBSEC)

偏移地址: 0x28

备份域复位值: 0x0000 0000

系统复位: 0xXXXX XXXX

| 位/域   | 名称     | R/W | 描述                                                                                                                                                                 |
|-------|--------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0  | SUBSEC | R   | 设置亚秒值 (Sub Second Value Setup)<br>SUBSEC 是同步预分频器计数器中的值。由下列公式决定:<br>亚秒值=(SPSC-SUBSEC)/(SPSC+1)<br>当一个移位操作执行完毕后, SUBSEC 可能大于 SPSC。那么正确的时间/日期比 RTC_TIME/RTC_DATE 少一秒。 |
| 31:16 | 保留     |     |                                                                                                                                                                    |

#### 19.7.12 RTC 移位寄存器 (RTC\_SHIFT)

偏移地址: 0x2C

备份域复位值: 0x0000 0000

系统复位: 0xXXXX XXXX

该寄存器处于写保护状态。

| 位/域  | 名称    | R/W | 描述                                                                                                |
|------|-------|-----|---------------------------------------------------------------------------------------------------|
| 14:0 | SFSEC | W   | 设置减少若干分之一秒 (Subtract a Fraction of a Second Setup)<br>此位域只能写入, 读取此字节始终为 0。当正在执行一个操作时, 对此位进行写操作无效。 |

| 位/域   | 名称        | R/W | 描述                                                                                                                                                                                                                                                                                                                |
|-------|-----------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |           |     | <p>设置的 SFSEC 值将会被添加到同步预分频器计数器中。如果计数器是倒计时的，时钟会被延迟，延迟时间由以下公式决定：</p> $\text{Delay (seconds)} = \text{SFSEC}/(\text{SPSC}+1)$ <p>当与 ADD1SECEN 同时作用时，推进时钟将增加若干分之一秒，具体的增加值由以下公式决定：</p> $\text{Advance(seconds)} = (1 - (\text{SFSEC}/(\text{SPSC}+1)))$ <p>对此位写操作可清除 RSFLG 位。软件持续运行直到 RSFLG 置 1，以此确保影子寄存器的值与移位时间同步。</p> |
| 30:15 |           |     | 保留                                                                                                                                                                                                                                                                                                                |
| 31    | ADD1SECEN | W   | <p>使能增加一秒 (Add One Second Enable)</p> <p>0: 不增加<br/>1: 时钟/日期增加一秒</p> <p>此位只能写入，读取此字节始终为 0。当正在执行一个操作时，对此位进行写操作无效。</p> <p>当与 SFSEC 同时作用时，可以增加时钟的值，增加值为若干分之一秒。</p>                                                                                                                                                   |

### 19.7.13 RTC 时间戳时间寄存器 (RTC\_TSTIME)

偏移地址: 0x30

备份域复位值: 0x0000 0000

系统复位: 0xXXXX XXXX

当 RTC\_STS 中 TSFLG 置 1 时，该寄存器才有效。当 TSFLG 位复位时，清除该寄存器的内容。

| 位/域   | 名称       | R/W | 描述                                                                    |
|-------|----------|-----|-----------------------------------------------------------------------|
| 3:0   | SECU     | R   | 设置秒个位的值以 BCD 格式存储 (Set Up the Units Digit of Seconds in BCD Format)   |
| 6:4   | SECT     | R   | 设置秒十位的值以 BCD 格式存储 (Set Up the Tens Digit of Seconds in BCD Format)    |
| 7     |          |     | 保留                                                                    |
| 11:8  | MINU     | R   | 设置分个位的值以 BCD 格式存储 (Set Up the Units Digit of Minutes in BCD Format)   |
| 14:12 | MINT     | R   | 设置分十位的值以 BCD 格式存储 (Set Up the Tens Digit of Minutes in BCD Format)    |
| 15    |          |     | 保留                                                                    |
| 19:16 | HRU      | R   | 设置小时个位的值以 BCD 格式存储 (Set Up the Units Digit of Hours in BCD Format)    |
| 21:20 | HRT      | R   | 设置小时十位的值以 BCD 格式存储 (Set Up the Tens Digit of Hours in BCD Format)     |
| 22    | TIMEFCFG | R   | <p>配置时间格式 (Time Format Configure)</p> <p>0: AM 或 24 小时制<br/>1: PM</p> |
| 31:23 |          |     | 保留                                                                    |

### 19.7.14 RTC 时间戳日期寄存器 (RTC\_TSDATE)

偏移地址: 0x34

备份域复位值: 0x0000 0000

系统复位: 0xXXXX XXXX

当 RTC\_STS 的 TSFLG 位置 1 时, 该寄存器才有效。当 TSFLG 位复位时清除该寄存器。

| 位/域   | 名称      | R/W | 描述                                                                       |
|-------|---------|-----|--------------------------------------------------------------------------|
| 3:0   | DAYU    | R   | 设置日个位的值以 BCD 格式存储 (Set Up the Units Digit of Days in BCD Format)         |
| 5:4   | DAYT    | R   | 设置日十位的值以 BCD 格式存储 (Set Up the Tens Digit of Days in BCD Format)          |
| 7:6   | 保留      |     |                                                                          |
| 11:8  | MONU    | R   | 设置月个位的值以 BCD 格式存储 (Set Up the Units Digit of Months in BCD Format)       |
| 12    | MONT    | R   | 设置月十位的值以 BCD 格式存储 (Set Up the Tens Digit of Months in BCD Format)        |
| 15:13 | WEEKSEL | R   | 选择日期单位 (Week Day Units Select)<br>000: 禁用<br>001: 星期一<br>...<br>111: 星期日 |
| 31:16 | 保留      |     |                                                                          |

### 19.7.15 RTC 时间戳亚秒寄存器 (RTC\_TSSUBSEC)

偏移地址: 0x38

备份域复位值: 0x0000 0000

系统复位: 0xXXXX XXXX

当 RTC\_STS 寄存器的 TSFLG 位置 1 时, 该寄存器才有效。当 TSFLG 位复位时清除该寄存器的内容。

| 位/域   | 名称     | R/W | 描述                                                                      |
|-------|--------|-----|-------------------------------------------------------------------------|
| 15:0  | SUBSEC | R   | 设置亚秒值 (Sub Second Value Setup)<br>当发生时间戳事件时, SUBSEC[15:0]是同步预分频器计数器中的值。 |
| 31:16 | 保留     |     |                                                                         |

### 19.7.16 RTC 精密校准寄存器 (RTC\_CAL)

该寄存器处于写保护状态。

偏移地址: 0x3C

备份域复位值: 0x0000 0000

系统复位: 0xXXXX XXXX

| 位/域  | 名称     | R/W | 描述                                                                                                                                                                     |
|------|--------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8:0  | RECALF | R/W | 减少校准频率 (Reduced Calibration Frequency)<br>减少日期频率: 在 $2^{20}$ 个 RTCCLK 脉冲内 (若输出频率为 32768Hz, 则 32 秒) 屏蔽 RECALF 个脉冲将减少日期的频率 (分辨率为 0.9537 ppm)。<br>增加日期频率: 与 ICALFEN 同时作用。 |
| 12:9 | 保留     |     |                                                                                                                                                                        |

| 位/域   | 名称       | R/W | 描述                                                                                                                                                                                                                                                        |
|-------|----------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13    | CAL16CFG | R/W | 配置 16 秒校准周期 (16 Second Calibration Cycle Period Configure)<br>当 CAL16CFG 置 1, 使用 16 秒校准周期, 不能和 CAL8CFG 位同时置 1。<br>当 CAL16CFG=1 时, RECALF[0]始终为 0。                                                                                                         |
| 14    | CAL8CFG  | R/W | 配置 8 秒校准周期 (8 Second Calibration Cycle Period Configure)<br>当 CAL8CFG 置 1, 使用 8 秒校准周期, 不能和 CAL16CFG 位同时置 1。<br>当 CAL8CFG=1 时, RECALF[1:0]始终为 00。                                                                                                          |
| 15    | ICALFEN  | R/W | 使能增加校准频率 (Increase Calibration Frequency Enable)<br>0: 不增加 RTCCLK 脉冲<br>1: 每 $2^{11}$ 个脉冲增加一个 RTCCLK 脉冲 (频率增加 488.5 ppm)<br>与 RECALF 同时作用, 使用高分辨率时会降低日期的频率。若输入频率为 32768Hz, 则在 32 秒窗口中增加 RTCCLK 脉冲的数量由下列公式决定:<br>$(512 * \text{ICALFEN}) - \text{RECALF}.$ |
| 31:16 | 保留       |     |                                                                                                                                                                                                                                                           |

### 19.7.17 RTC 侵入和复用配置寄存器(RTC\_TACFG)

偏移地址: 0x40

备份域复位值: 0x0000 0000

系统复位: 0xXXXX XXXX

| 位/域  | 名称       | R/W | 描述                                                                                                                                                                                                                      |
|------|----------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | TP1EN    | R/W | 使能 RTC_TAMP1 输入检测 (RTC_TAMP1 Input Detection Enable)<br>0: 禁用<br>1: 使能                                                                                                                                                  |
| 1    | TP1ALCFG | R/W | 配置 RTC_TAMP1 输入的有效电平 (RTC_TAMP1 Input Active Level Configure)<br>当 TPFCSEL!=00 时, 该位决定 RTC_TAMP1 输入在保持高/低电平会触发一个侵入检测事件。<br>0: 低电平<br>1: 高电平<br>当 TPFCSEL=00 时, 该位决定 RTC_TAMP1 输入在上升/下降沿时触发一个侵入检测事件。<br>0: 上升沿<br>1: 下降沿 |
| 2    | TPIEN    | R/W | 使能侵入中断 (Tamper Interrupt Enable)<br>0: 禁用<br>1: 使能                                                                                                                                                                      |
| 6:3  | 保留       |     |                                                                                                                                                                                                                         |
| 7    | TPTSEN   | R/W | 使能侵入检测事件的时间戳 (Tamper Detection Event Timestamp Enable)<br>该位决定侵入检测事件产生的时间戳是否保存。<br>0: 不保存<br>1: 保存<br>该位在 RTC_CTRL 寄存器 TSEN=0 时依然有效。                                                                                    |
| 10:8 | TPSFSEL  | R/W | 选择侵入采样频率 (Tamper Sampling Frequency Select)                                                                                                                                                                             |

| 位/域   | 名称        | R/W | 描述                                                                                                                                                                                                                                             |
|-------|-----------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |           |     | <p>这些位决定每个 RTC_TAMPx 输入的采样频率。</p> <p>0x0: RTCCLK/32768<br/> 0x1: RTCCLK/16384<br/> 0x2: RTCCLK/8192<br/> 0x3: RTCCLK/4096<br/> 0x4: RTCCLK/2048<br/> 0x5: RTCCLK/1024<br/> 0x6: RTCCLK/512<br/> 0x7: RTCCLK/256</p>                            |
| 12:11 | TPFCSEL   | R/W | <p>选择 RTC_TAMPx 过滤器计数 (RTC_TAMPx Filter Count Select)</p> <p>这些位决定在特定电平 (TAMP*TRG) 上连续几次采样后激活入侵事件。</p> <p>TPFCSEL 对每次 RTC_TAMPx 输入都有效。</p> <p>0x0: 在 RTC_TAMPx 输入转换为有效电平的边沿激活入侵事件<br/> 0x1: 连续 2 次采样<br/> 0x2: 连续 4 次采样<br/> 0x3: 连续 8 次采样</p> |
| 14:13 | TPPRDUSEL | R/W | <p>选择 RTC_TAMPx 预充电时长 (RTC_TAMPx Precharge Duration Select)</p> <p>这些位决定采样前上拉电阻启用几个 RTCCLK 周期; 对每次 RTC_TAMPx 输入都有效。</p> <p>0x0: 1<br/> 0x1: 2<br/> 0x2: 4<br/> 0x3: 8</p>                                                                      |
| 15    | TPPUDIS   | R/W | <p>禁止 RTC_TAMPx 上拉功能 (RTC_TAMPx Pull-up Function Disable)</p> <p>该位决定是否所有 RTC_TAMPx 引脚在采样前进行预充电。</p> <p>0: 使能 (使能内部上拉)<br/> 1: 禁止</p>                                                                                                          |
| 16    | TP1MSEL   | R/W | <p>选择 RTC_TAMP1 映射 (RTC_TAMP1 Mapping Select)</p> <p>0: RTC_AF1 作为 RTC_TAMP1<br/> 1: 保留</p> <p>默认值为 0, 其他值会使 RTC_TAMP1 映射异常。</p> <p>注意: 当此位被更改时, TP1EN 必须被重置, 以避免不必要的设置 TP1FLG。</p>                                                            |
| 17    | TSMSEL    | R/W | <p>选择时间戳映射 (Timestamp Mapping Select)</p> <p>0: RTC_AF1 作为时间戳<br/> 1: 保留</p> <p>默认值为 0, 其他值会使时间戳映射异常。</p>                                                                                                                                      |
| 18    | ALRMOT    | R/W | <p>配置 RTC_ALARM 输出形式 (RTC_ALARM Output Type Configure)</p> <p>0: 开漏输出<br/> 1: 推挽输出</p>                                                                                                                                                         |
| 31:19 |           |     | 保留                                                                                                                                                                                                                                             |

### 19.7.18 RTC 闹钟 A 亚秒寄存器 (RTC\_ALRMASS)

偏移地址: 0x44

备份域复位值: 0x0000 0000

系统复位: 0xXXXX XXXX

该寄存器只能在 RTC\_CTRL 的 ALRAEN 复位或初始化模式下写入, 处于写保护状态。

该寄存器处在写保护状态。

| 位/域   | 名称      | R/W | 描述                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------|---------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14:0  | SUBSEC  | R/W | 设置亚秒值 (Sub Second Value Setup)<br>亚秒值与同步预分频器计数器中的值进行比较来确定是否激活闹钟 A, 仅比较位 0 到 MASKSEL-1。                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 23:15 |         |     | 保留                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 27:24 | MASKSEL | R/W | 选择屏蔽从此位开始的最有效位 (Mask the Most-significant Bits Starting at This Bit Select)<br>0x0: 不对闹钟 A 进行比较。闹钟在秒单元增加 1 时设置<br>0x1: 在对闹钟 A 比较时, SUBSEC[14:1] 不参与, 仅 SUBSEC[0] 参与<br>0x2: 在对闹钟 A 比较时, SUBSEC[14:2] 不参与, 仅 SUBSEC[1:0] 参与<br>0x3: 在对闹钟 A 比较时, SUBSEC[14:3] 不参与, 仅 SUBSEC[2:0] 参与<br>...<br>0xC: 在对闹钟 A 比较时, SUBSEC[14:12] 不参与, 仅 SUBSEC[11:0] 参与<br>0xD: 在对闹钟 A 比较时, SUBSEC[14:13] 不参与, 仅 SUBSEC[12:0] 参与<br>0xE: 在对闹钟 A 比较时, SUBSEC[14] 不参与, 仅 SUBSEC[13:0] 参与<br>0xF: 在对闹钟 A 比较时, 15 个 SUBSEC 位都要参与, 只有全部匹配才能激活闹钟。<br>同步计数器溢出位 (位 15) 从不进行比较。仅在移位操作后, 该位不为 0。 |
| 31:28 |         |     | 保留                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

### 19.7.19 RTC 闹钟 B 亚秒寄存器 (RTC\_ALRMBSS)

偏移地址: 0x48

备份域复位值: 0x0000 0000

系统复位: 0xXXXX XXXX

该寄存器只能在 RTC\_CTRL 的 ALRBEN 复位或初始化模式下写入, 该寄存器处在写保护状态。

| 位/域   | 名称      | R/W | 描述                                                                                     |
|-------|---------|-----|----------------------------------------------------------------------------------------|
| 14:0  | SUBSEC  | R/W | 设置亚秒值 (Sub Second Value Setup)<br>亚秒值与同步预分频器计数器中的值进行比较来确定是否激活闹钟 B, 仅比较位 0 到 MASKSEL-1。 |
| 23:15 |         |     | 保留                                                                                     |
| 27:24 | MASKSEL | R/W | 选择屏蔽从此位开始的最有效位 (Mask the Most-significant Bits Starting at This Bit Select)            |

| 位/域   | 名称 | R/W | 描述                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|----|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |    |     | 0x0: 不对闹钟 B 进行比较。闹钟在秒单元增加 1 时设置<br>0x1: 在对闹钟 B 比较时, SUBSEC[14:1]不参与, 仅 SUBSEC[0]参与<br>0x2: 在对闹钟 B 比较时, SUBSEC[14:2]不参与, 仅 SUBSEC[1:0]参与<br>3: 在对闹钟 B 比较时, SUBSEC[14:3]不参与, 仅 SUBSEC[2:0]参与<br>...<br>0xC: 在对闹钟 B 比较时, SUBSEC[14:12]不参与, 仅 SUBSEC[11:0]参与<br>0xD: 在对闹钟 B 比较时, SUBSEC[14:13]不参与, 仅 SUBSEC[12:0]参与<br>0xE: 在对闹钟 B 比较时, SUBSEC[14]不参与, 仅 SUBSEC[13:0]参与<br>0xF: 在对闹钟 B 比较时, 15 个 SUBSEC 位都要参与, 只有全部匹配才能激活闹钟。<br>同步计数器溢出位(位 15)从不进行比较。仅在移位操作后, 该位不为 0。 |
| 31:28 |    |     | 保留                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

### 19.7.20 RTC 备份寄存器 (RTC\_BAKPx) (x=0-19)

偏移地址: 0x50-0x9C

备份域复位值: 0x0000 0000

复位值: 0xXXXX XXXX

| 位/域  | 名称   | R/W | 描述                                                                                                                                                        |
|------|------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | BAKP | R/W | 设置备份值 (Backup Value Setup)<br>切断 $V_{DD}$ 电源将由 $V_{BAT}$ 供电, 所以此位域不受系统复位影响。当发生侵入检测事件或禁用闪存读出保护时, 此寄存器复位, 且只要 TP1FLG=1, 则一直保持复位。<br>即使设备在低功耗模式下运行此位域的内容也有效。 |

## 20 通用同步异步收发器 (USART)

### 20.1 术语全称、缩写描述

表格 82 术语全称、缩写描述

| 中文全称  | 英文全称                  | 英文缩写 |
|-------|-----------------------|------|
| 清除发送  | Clear to Send         | CTS  |
| 请求发送  | Request to Send       | RTS  |
| 最高有效位 | Most Significant Bit  | MSB  |
| 最低有效位 | Least Significant Bit | LSB  |
| 保护    | Guard                 | GRD  |
| 过载    | Overrun               | OVR  |

### 20.2 简介

USART（通用同步异步收发器）是一个可以灵活地与外部设备进行全双工、半双工数据交换的串行通信设备，且同时满足外部设备对工业标准 NRZ 异步串行数据格式的要求。USART 还提供宽范围的波特率选择，且支持多处理器通信。

USART 不仅支持标准的异步收发模式，也支持一些其他的串行数据交换模式，如 LIN 协议、智能卡协议、IrDA SIR ENDEC 规范和硬件流控制模式。

USART 还支持使用 DMA 功能，以实现高速数据通信。

### 20.3 主要特征

- (1) 全双工异步通信
- (2) 单线半双工通信
- (3) NRZ 标准格式
- (4) 可编程的串口特性：
  - 数据位：8 位或 9 位
  - 校验位：偶校验、奇校验、无校验
  - 支持 0.5、1、1.5、2 个停止位
- (5) 校验控制
  - 发送校验位
  - 校验接收的数据
- (6) 选择速度和时钟容忍度采用可编程的 8 倍或 16 倍过采样率
- (7) 独立的发送器和接收器使能位

- (8) 可编程的波特率发生器
- (9) 多处理器通信:
  - 若地址不匹配，则进入静默模式
  - 通过空闲总线检测或地址标记检测，从静默模式中唤醒
- (10) 同步发送模式
- (11) LIN 断开帧的生成与检测
- (12) 支持 ISO7816-3 标准的智能卡接口
- (13) 支持 IrDA 协议
- (14) 支持硬件流控制
- (15) 可利用 DMA 连续通信
- (16) 状态标志位:
  - 发送检测标志：发送寄存器为空、接收寄存器不为空、发送完成
  - 错误检测标志：溢出错误、噪音错误、奇偶校验错误、帧错误
- (17) 多个中断源:
  - 发送寄存器为空
  - 发送完成
  - CTS 改变
  - 接收寄存器不为空
  - 过载错误
  - 总线空闲
  - 奇偶校验错误
  - LIN 断开检测
  - 噪音错误
  - 溢出错误
  - 帧错误

## 20.4 功能描述

表格 83 USART 引脚描述

| 引脚         | 类型                     | 描述                            |
|------------|------------------------|-------------------------------|
| USART_RX   | 输入                     | 数据接收                          |
| USART_TX   | 输出<br>I/O (单线模式/智能卡模式) | 数据发送<br>当发送器被使能且不发送数据时，默认为高电平 |
| USART_CK   | 输出                     | 时钟输出                          |
| USART_nRTS | 输出                     | 硬件流控制模式中请求发送                  |
| USART_nCTS | 输入                     | 硬件流控制模式中清除发送                  |
| IrDA_RDI   | 输入                     | IrDA 模式中的数据输入                 |

| 引脚       | 类型 | 描述            |
|----------|----|---------------|
| IrDA_TDO | 输出 | IrDA 模式中的数据输出 |

#### 20.4.1 单线半双工通信

USART\_CTRL3 寄存器的 HDEN 位决定是否进入单线半双工模式。

当 USART 进入单线半双工模式时：

- USART\_CTRL2 寄存器的 CLKEN 位、LINMEN 位, USART\_CTRL3 寄存器的 IREN 位、SCEN 位必须清 0。
- 禁止使用 RX 引脚。
- TX 脚应配置成开漏输出，并在芯片内部与 RX 引脚相连。
- 发送数据和接收数据不可同时进行，在数据发送前，不可以接收数据。若需要接收数据，必须在 USART\_STS 寄存器的 TXCFLG 位置 1 后才可开启使能接收。
- 若总线上出现数据冲突，需要使用软件管理分配通信过程。

#### 20.4.2 帧格式

通过 USART\_CTRL1 寄存器控制数据帧的帧格式：

- DBLCFG 位控制字符长度，可设置为 8 位或 9 位。
- PCEN 位控制是否开启校验位。
- PCFG 位控制校验位为奇校验还是偶校验。

表格 84 帧格式

| DBLCFG 位 | PCEN 位 | USART 数据帧           |
|----------|--------|---------------------|
| 0        | 0      | 起始位+8 位数据+停止位       |
| 0        | 1      | 起始位+7 位数据+奇偶检验位+停止位 |
| 1        | 0      | 起始位+9 位数据+停止位       |
| 1        | 1      | 起始位+8 位数据+奇偶检验位+停止位 |

#### 可配置的停止位

可以通过 USART\_CTRL2 寄存器的 STOPCFG 位来配置 4 种不同的停止位。

- 1 个停止位：默认的停止位。
- 0.5 个停止位：智能卡模式里接收数据时使用。
- 2 个停止位：常规模式、单线模式、硬件流控制模式使用。
- 1.5 个停止位：智能卡模式里发送与接收数据时使用。

#### 校验位

USART\_CTRL1 的 PCFG 位决定奇偶校验位，当 PCFG=0 时，为偶校验，反之为奇校验。

- 偶校验：帧数据和校验位 1 的个数为偶数时，偶校验位为 0，否则为 1。

- 奇校验：帧数据和校验位 1 的个数为偶数时，奇校验位为 1，否则为 0。

### 20.4.3 发送器

当寄存器 **USART\_CTRL1** 的 **TXEN** 位被设置时，发送移位寄存器将通过 **TX** 脚输出数据，相应的时钟脉冲通过 **CK** 脚输出。

#### 20.4.3.1 字符发送

**USART** 发送期间，数据的最低有效位会先被 **TX** 引脚移出。在此模式下，**USART\_DATA** 寄存器有一个缓冲器，处于内部总线和发送移位寄存器之间。

一个数据帧由起始位、字符、停止位组成的，所以每个字符前面都有一个低电平的起始位；之后有一个数目可配置的高电平的停止位。

#### 发送配置步骤

- (1) 置位 **USART\_CTRL1** 寄存器的 **UEN** 位，使能 **USART**。
- (2) 通过设置 **USART\_CTRL1** 寄存器的 **DBLCFG** 位来决定字长。
- (3) 通过设置 **USART\_CTRL2** 寄存器的 **STOPCFG** 位来决定停止位位数。
- (4) 若选择多缓冲器通信，需在 **USART\_CTRL3** 寄存器中使能 **DMA**。
- (5) 在 **USART\_BR** 寄存器中设置通信的波特率。
- (6) 使能 **USART\_CTRL1** 寄存器的 **TXEN** 位，发送一个空闲帧。
- (7) 等待 **USART\_STS** 寄存器的 **TXBITLE** 位置 1。
- (8) 向 **USART\_DATA** 寄存器写入数据（如果未使能 **DMA**，则每个需要发送的字节都要重复步骤 7~8）。
- (9) 等待 **USART\_STS** 寄存器的 **TXCF** 位置 1，表示发送完成。

注意：不能在发送数据期间复位 **TXEN** 位，否则 **TX** 脚上的数据会被破坏，因为波特率发生器停止计数，正在发送的数据也将丢失。

#### 20.4.3.2 单字节通信

对 **USART\_DATA** 寄存器进行写操作可以将 **TXBITLE** 位清零。当 **TXBITLE** 位被硬件置位时，移位寄存器接收到由数据发送寄存器转移过来的数据，数据发送就开始了，此时数据发送寄存器被清空。可以在数据寄存器中写入下一个数据，且不会覆盖前面的数据。

- (1) 若 **USART\_CTRL1** 寄存器中的 **TXBIE** 置 1，则会产生一个中断。
- (2) 若 **USART** 处于发送数据的状态时，对数据寄存器进行写操作，把数据存到 **DATA** 寄存器，并在当前数据发送结束时把该数据转移到移位寄存器中。

- (3) 若 USART 处于空闲状态时, 对数据寄存器进行写操作, 把数据放到移位寄存器中, 开始发送数据, TXBEFLG 位置 1。
- (4) 当一个数据发送完成并设置了 TXBEFLG 位时, TXCFLG 位被置 1, 此时若 USART\_CTRL1 寄存器中的 TXCIEN 位被置 1, 则会产生一个中断。
- (5) 在 USART\_DATA 寄存器中写入最后一个数据后, 在进入低功耗模式之前或关闭 USART 模块之前, 必须先等待 TXCFLG 置 1。

#### 20.4.3.3 断开帧

断开帧被视为在一个帧周期内全部收到 0。设置 USART\_CTRL1 寄存器的 TXBF 位可发送一个断开帧, 断开帧的长度由 USART\_CTRL1 寄存器的 DBLCFG 位决定。若将 TXBF 位置位, 则当前数据发送完成后, TX 线上将发送一个断开帧, 断开帧发送完成后 TXBF 位被复位。在断开帧结束时, 发送器再插入 1 或 2 个停止位来应答起始位。

注意: 若在开始发送断开帧之前就复位了 TXBF 位, 将不再发送断开帧。若要发送两个连续的断开帧, 应该在前一个断开符的停止位之后置起 TXBF 位。

#### 20.4.3.4 空闲帧

空闲帧被视为完全由 1 组成的一个完整的数据帧, 后面跟着包含了数据的下一帧的开始位。将 USART\_CTRL1 寄存器的 TXEN 位置 1, 可以在第一个数据帧前发送一个空闲帧。

### 20.4.4 接收器

#### 20.4.4.1 字符接收

USART 接收期间, RX 脚会首先引进数据的最低有效位。在此模式下, USART\_DATA 寄存器有一个缓冲器, 处于内部总线和接收移位寄存器之间。数据一位一位地送入缓冲器, 接收满后, 对应的接收寄存器不为空, 此时用户可读取 USART\_DATA。

#### 接收配置步骤

- (1) 置位 USART\_CTRL1 寄存器的 UEN 位, 使能 USART。
- (2) 通过设置 USART\_CTRL1 寄存器的 DBLCFG 位来决定字长。
- (3) 通过设置 USART\_CTRL2 寄存器的 STOPCFG 位来决定停止位位数。
- (4) 若选择多缓冲器通信, 需在 USART\_CTRL3 寄存器中使能 DMA。
- (5) 在 USART\_BR 寄存器中设置通信的波特率。
- (6) 设置 USART\_CTRL1 的 RXEN 位, 使能接收。

注意:

- (1) 不能在接收数据期间复位 RXEN 位, 否则将丢失正在接收的字节。
- (2) 接收器在接收一个数据帧的过程中, 若检测到溢出错误、噪音错误或帧错误等, 错误标志位被置 1。

- (3) 当数据从移位寄存器中被转移到 USART\_DATA 寄存器中时, USART\_STS 寄存器的 RXBNEFLG 位被硬件置位。
- (4) 若设置 RXBNEIEN 位, 将产生一个中断。
- (5) 在单缓冲器模式中, 软件读取 USART\_DATA 寄存器, 能清除 RXBNEFLG 位, 也可对其写 0 清除。
- (6) 再多缓冲器模式中, 每个字节被接收后, USART\_STS 寄存器的 RXBNEFLG 位都会被置 1, 且 DMA 对数据寄存器进行读操作而清零。

#### 20.4.4.2 断开帧

当接收器接收到一个断开帧时, USART 会像接收到帧错误一样处理它。

#### 20.4.4.3 空闲帧

当接收器接收到一个空闲帧时, USART 会像接收到普通数据帧一样处理它。如果设置 USART\_CTRL1 的 IDLEIEN 位, 将产生一个中断。

#### 20.4.4.4 过采样率

USART\_CTRL1 寄存器的 OSMCFG 位决定过采样率。

若过采样率为波特率的 8 倍, 则速度较高, 但时钟容忍度较小, 若为 16 倍则相反。

#### 20.4.4.5 溢出错误

若 USART\_STS 寄存器的 RXBNEFLG 位置 1, 同时接收到一个新的字符, 则会产生溢出错误。只有当 RXEN 复位后才能把数据从移位寄存器转移到 DATA 寄存器。接收到字节后 RXBNEFLG 位会置 1, 该位需要在接收到下一个数据或尚未处理上一个 DMA 请求前复位, 否则将产生溢出错误。

##### 当产生溢出错误时

- USART\_STS 的 OVREFLG 位置 1。
- 不会丢失 DATA 寄存器中的数据。
- 覆盖之前接收到的移位寄存器中的数据, 但不会保存后面接收到的数据。
- 若 USART\_CTRL1 的 RXBNEIEN 位置 1, 则会产生一个中断。
- 当 OVREFLG 位置 1 时, 表明已经有数据丢失。可分为两种可能:
  - 当 RXBNEFLG=1 时, 上一个有效数据还在 DATA 寄存器上, 可以进行读操作。
  - 当 RXBNEFLG=0 时, DATA 寄存器中没有有效数据。
- 对 USART\_STS 和 USART\_DATA 寄存器依次进行读操作, 可以复位 OVREFLG 位。

#### 20.4.4.6 噪音错误

当接收器在接收过程中检测到噪音时:

- 在 USART\_STS 寄存器的 RXBNEFLG 位的上升沿设置 NE 标志。

- 无效数据从移位寄存器发送到 **USART\_DATA** 寄存器。

注意：8 倍过采样率不能在 LIN、智能卡和 IrDA 模式下使用。

#### 20.4.4.7 帧错误

若因为噪音过大或没有同步而没有在预计的接收时间接收和识别到停止位，会检测到帧错误。

当接收器在接收过程中检测到帧错误时：

- (1) 置位 **USART\_STS** 寄存器的 **FEFLG** 位。
- (2) 无效数据从移位寄存器发送到 **USART\_DATA** 寄存器。
- (3) 在单字节通信时不会产生中断，但在多缓冲区通信时置位 **USART\_CTRL3** 寄存器的 **ERRIEN** 位就会产生一个中断。

#### 20.4.5 波特率发生器

波特率分频系数（**USARTDIV**）是一个 16 位的数字，包含 12 位整数部分和 4 位小数部分。Tx/Rx 波特率与系统时钟的关系：

公式 1 适用于智能卡、LIN 和 IrDA 模式下的波特率

$$\text{波特率} = \text{PCLK} / (16 \times \text{USARTDIV}) \quad (\text{公式 1})$$

公式 2 适用于标准 USART（包括 SPI 模式）的波特率

$$\text{波特率} = \text{PCLK} / (8 \times (2 - \text{OVER8}) \times \text{USARTDIV}) \quad (\text{公式 2})$$

USART2/3 的系统时钟为 PCLK1，USART1 的系统时钟为 PCLK2。必须在时钟控制单元使能系统时钟之后再使能 USART。

示例 1：

如果 **IBR**=0d20 且 **IBR**=0d12 (**USART\_BRR**=0x14C)

则尾数(**USARTDIV**)=0d20

小数(**USARTDIV**)=12/16=0.75

因此 **USARTDIV**=0d20.75

#### 20.4.6 多处理器通信

在多处理器通信中，多个 USART 连接组成一个网络。在该网络中，两个设备进行通信，其余不参与通信的设备，为减轻 USART 的负担，可启用静默模式。在静默模式中，不会设置任何接收状态位，禁止所有接收中断。

当启用静默模式后，有两种方法可退出静默模式：

- **WUPMCFG** 位被清除，总线空闲可退出静默模式。
- **WUPMCFG** 位被置位，收到地址标记可退出静默模式。

#### 空闲总线检测 (**WUPMCFG=0**)

当 RXMUTEEN 置 1 时，USART 则进入静默模式，当检测到空闲帧时，能从静默模式中被唤醒，同时 RXMUTEEN 位被硬件清 0。RXMUTEEN 还可以通过软件清 0。

图 67 空闲总线退出静默模式



#### 地址标记检测 (WUPMCFG=1)

如果地址标志位为 1，该字节被认为是地址。地址字节低 4 位存放地址，当接收器收到地址字节时，会先与自己的地址作比较。若地址不匹配，则进入静默模式，若地址匹配，则接收器从静默模式中被唤醒，并准备接收下一个字节。若退出静默模式后再次收到地址字节，但地址与自己的地址不匹配，则接收器会再次进入静默模式。

图 68 地址标记退出静默模式



#### 20.4.7 同步模式

同步模式支持主模式下的全双工同步串行通信，比异步模式多了一个可以输出同步时钟的信号线 USART\_CK。

USART\_CTRL2 寄存器的 CLKEN 位决定是否进入同步模式。

当 USART 进入同步模式时：

- USART\_CTRL2 寄存器的 LINMEN 位, USART\_CTRL3 寄存器的 IREN, HDEN 和 SCEN 位必须清 0。
- 数据帧的起始位和停止位无时钟输出。
- 数据帧的最后一个数据位是否产生 USART\_CK 时钟, 由寄存器 USART\_CTRL2 的 LBCPOEN 位决定。
- USART\_CK 的时钟极性由 USART\_CTRL2 寄存器的 CPOL 位决定。
- USART\_CK 的相位由 USART\_CTRL2 寄存器的 CPHA 位决定。
- 总线空闲或出现断开帧时不能激活外部 CK 时钟。

图 69 USART 同步发送的例子



图 70 USART 同步发送时序图 (DBLCFG=0)



图 71 USART 同步发送时序图 (DBLCFG=1)



#### 20.4.8 LIN 模式

USART\_CTRL2 寄存器的 LINMEN 位决定是否进入 LIN 模式。

当进入 LIN 模式时：

- 数据帧都为 8 位数据位和 1 位停止位。
- USART\_CTRL2 寄存器的 CLKEN 位、STOPCFG 位，  
USART\_CTRL3 寄存器的 IREN 位、HDEN 位和 SCEN 位都需清 0。

USART 在 LIN 主模式下能生成断开帧，断开帧检测长度可通过 USART\_CTRL2 的 LBDLCFG 位设置为 10 位、11 位。断开帧检测电路独立于 USART 接收器，无论是空闲状态，还是数据发送状态，RX 脚都会检测到断开帧，且 USART\_STS 寄存器的 LBDFLG 位置 1，若此时使能 USART\_CTRL2 的 LBDIEN 位，则会产生中断。

#### 空闲状态检测断开帧

在空闲状态下，若 RX 脚上检测到断开帧，接收器会接收到一个为 0 的数据帧并会产生 FEFLG。

图 72 空闲状态检测断开帧



### 数据发送状态检测断开帧

在数据发送的过程中，若 RX 脚检测到断开帧，则当前发送的数据帧会产生 FEFLG。

图 73 数据发送状态检测断开帧



### 20.4.9 智能卡模式

智能卡模式是一种采用单线半双工通信的模式，该接口支持 ISO7816-3 标准协议，能控制读写符合该标准协议的智能卡。

USART\_CTRL3 寄存器的 SCEN 位决定是否进入智能卡模式。

当 USART 进入智能卡模式时：

- USART\_CTRL2 寄存器的 LINMEN 位，USART\_CTRL3 寄存器的 IREN 位、HDEN 位必须清 0。
- 数据帧格式为 8 个数据位加 1 个校验位，使用 0.5 或 1.5 个停止位。  
(为了避免在两种配置间转换，建议在发送和接收数据时使用 1.5 个停止位)。
- 可以置位 USART\_CTRL2 寄存器的 CLKEN 位，为智能卡提供时钟。
- 在通信期间，当接收方检测到奇偶校验错误时，为了通知发送方未成功接收数据，数据线会在半个波特率时钟后被拉低，并保持拉低 1 个波特率时钟。
- 断开帧在智能卡模式里没有意义，一个带帧错误的 00h 数据将被当成数据而不是断开符号。

图 74 ISO7816-3 标准协议



#### 20.4.10 红外 (IrDA SIR) 功能模式

IrDA 模式是一个半双工协议，发送数据和接收数据不能同时进行，且数据发送与接收之间需要延时 10ms 以上。

USART\_CTRL3 寄存器的 IREN 位决定是否进入 IrDA 模式。

当 USART 进入 IrDA 模式时：

- USART\_CTRL2 寄存器的 CLKEN 位、STOPCFG 位和 LINMEN 位，USART\_CTRL3 寄存器的 HDEN 位、SCEN 位都必须清 0。
- 数据帧使用 1 个停止位，波特率小于 115200Hz。
- 使用红外光脉冲 (RZI) 表示逻辑 0，所以在正常模式下，他的脉宽为 3/16 个波特率周期。IrDA 低功耗模式下，为确保 IrDA 正常检测到该脉冲，建议脉宽大于 3 个 DIV 分频时钟。

图 75 IrDA 模式框图



#### 20.4.11 硬件流控制

硬件流控制功能是通过 nCTS 引脚和 nRTS 引脚，来控制两个设备间的串行数据流。

图 76 两个 USART 之间的硬件流控制



## CTS 流控制

USART\_CTRL3 寄存器的 CTSEN 位决定是否使能 CTS 流控制，若使能 CTS 流控制，发送器会检测 nCTS 引脚的数据帧是否可以被发送。若 USART\_STS 寄存器的 TXBEFLG 位=0 且 nCTS 被拉成低电平，则数据帧可以被发送。若 nCTS 在发送期间变为高电平，那么在当前的数据帧发送完成后，发送器将停止发送。

## RTS 流控制

USART\_CTRL3 寄存器的 RTSEN 位决定是否使能 RTS 流控制，若使能 RTS 流控制，当接收器接收数据时，nRTS 被拉成低电平，当一个数据帧接收完成时，nRTS 变为高电平以通知发送器停止发送数据帧。

### 20.4.12 DMA 多缓冲器通信

为了减轻处理器的负担，USART 可以用 DMA 方式访问数据缓冲区。

#### 使用 DMA 方式发送

USART\_CTRL3 寄存器上的 DMATXEN 位决定是否使用 DMA 方式发送。当用 DMA 发送时，在指定的 SRAM 区的数据会被 DMA 发送到发送缓冲区。

用 DMA 方式发送的配置步骤：

- (1) 清零 USART\_STS 寄存器的 TXCFLG 位。
- (2) 把存放数据的 SRAM 存储器的地址设置为 DMA 源地址。
- (3) 把 USART\_DATA 寄存器的地址设置为 DMA 目的地址。
- (4) 设置要发送的数据字节数。
- (5) 设置通道优先级。
- (6) 设置中断使能。
- (7) 使能 DMA 通道。
- (8) 等待 USART\_STS 寄存器的 TXCFLG 位置 1，表示发送完成。

#### 使用 DMA 方式接收

USART\_CTRL3 寄存器的 DMARXEN 位决定是否使用 DMA 方式接收，当用 DMA 接收时，每收到一个字节，接收缓冲区的数据会被 DMA 发送到指定的 SRAM 区。

用 DMA 方式接收的配置步骤：

- (1) 把 USART\_DATA 寄存器的地址设置为 DMA 源地址。
- (2) 把存放数据的 SRAM 存储器的地址设置为 DMA 目的地址。
- (3) 设置要发送的数据字节数。

- (4) 设置通道优先级。
- (5) 设置中断使能。
- (6) 使能 DMA 通道。

#### 20.4.13 中断请求

表格 85 USART 中断请求

| 中断事件         | 事件标志位    | 使能位      |
|--------------|----------|----------|
| 接收寄存器不为空     | RXBNEFLG | RXBNEIEN |
| 过载错误         | OVREFLG  |          |
| 检测到线路空闲      | IDLEFLG  |          |
| 奇偶检验错误       | PEFLG    | PEIEN    |
| LIN 断开帧标志    | LBDFLG   | LBDIEN   |
| DMA 模式下的接收错误 | NEFLG    | ERRIEN   |
|              | OVREFLG  |          |
|              | FEFLG    |          |
| 数据发送寄存器空     | TXBEFLG  | TXBEIEN  |
| 发送完成         | TXCFLG   | TXCIEN   |
| CTS 标志       | CTSFLG   | CTSIEN   |

USART 的中断请求都连接在同一个中断控制器上，中断请求在发送到中断控制器之前都是逻辑或关系。

图 77 USART 中断映射



#### 20.4.14 USART 支持功能对比

表格 86 USART 支持功能对比

| USART 模式    | USART1 | USART2 | USART3 | UART4 | UART5 | USART6 |
|-------------|--------|--------|--------|-------|-------|--------|
| 半双工 (单线模式)  | √      | √      | √      | √     | √     | √      |
| 多处理器通讯      | √      | √      | √      | √     | √     | √      |
| 同步          | √      | √      | √      | —     | —     | √      |
| 异步模式        | √      | √      | √      | √     | √     | √      |
| LIN         | √      | √      | √      | √     | √     | √      |
| 智能卡         | √      | √      | √      | —     | —     | √      |
| IrDA        | √      | √      | √      | √     | √     | √      |
| 硬件流控制       | √      | √      | √      | —     | —     | √      |
| 多缓存通讯 (DMA) | √      | √      | √      | √     | √     | √      |

注意：“√”表示支持该功能，“—”表示不支持该功能。

## 20.5 寄存器地址映射

表格 87 USART 寄存器地址映射

| 寄存器名        | 描述          | 偏移地址 |
|-------------|-------------|------|
| USART_STS   | 状态寄存器       | 0x00 |
| USART_DATA  | 数据寄存器       | 0x04 |
| USART_BR    | 波特率寄存器      | 0x08 |
| USART_CTRL1 | 控制寄存器 1     | 0x0C |
| USART_CTRL2 | 控制寄存器 2     | 0x10 |
| USART_CTRL3 | 控制寄存器 3     | 0x14 |
| USART_GTPSC | 保护时间和预分频寄存器 | 0x18 |

## 20.6 寄存器功能描述

### 20.6.1 状态寄存器 (USART\_STS)

偏移地址: 0x00

复位值: 0x0000 00C0

| 位/域 | 名称    | R/W | 描述                                                                                                                                                              |
|-----|-------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | PEFLG | R   | 发生校验错误标志 (Parity Error Occur Flag)<br>0: 无错误<br>1: 出现校验错误<br>在接收模式中, 当出现奇偶校验错误时, 由硬件置 1;<br>由软件清 0, 需等 RXBNEFLG 置位后, 先读取 USART_STS 寄存器, 再读 USART_DATA 寄存器完成清 0。 |

| 位/域 | 名称       | R/W   | 描述                                                                                                                                                                                               |
|-----|----------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1   | FEFLG    | R     | <p>发生帧错误标志 (Frame Error Occur Flag)</p> <p>0: 无帧错误</p> <p>1: 出现帧错误或断开符</p> <p>当出现同步错位、过多噪音或断开符时, 由硬件置 1;</p> <p>由软件清 0, 先读取 USART_STS 寄存器, 再读 USART_DATA 寄存器完成清 0。</p>                           |
| 2   | NEFLG    | R     | <p>发生噪音错误标志 (Noise Error Occur Flag)</p> <p>0: 无噪音</p> <p>1: 出现噪音错误</p> <p>当出现噪音错误时, 由硬件置 1;</p> <p>由软件清 0, 先读取 USART_STS 寄存器, 再读 USART_DATA 寄存器完成清 0。</p>                                       |
| 3   | OVREFLG  | R     | <p>发生过载错误标志 (Overrun Error Occur Flag)</p> <p>0: 未出现过载错误</p> <p>1: 出现过载错误</p> <p>当 RXBNEFLG 位被置位, 且移位寄存器中的数据要发送到接收寄存器时, 由硬件置 1;</p> <p>由软件清 0, 先读取 USART_STS 寄存器, 再读 USART_DATA 寄存器完成清 0。</p>    |
| 4   | IDLEFLG  | R     | <p>检测到空闲总线标志 (IDLE Line Detected Flag)</p> <p>0: 未检测到空闲总线</p> <p>1: 检测到空闲总线</p> <p>当检测到空闲总线时, 由硬件置 1;</p> <p>由软件清 0, 先读取 USART_STS 寄存器, 再读 USART_DATA 寄存器完成清 0。</p>                              |
| 5   | RXBNEFLG | RC_W0 | <p>接收数据缓冲器不为空标志 (Receive Data Buffer Not Empty Flag)</p> <p>0: 接收数据缓冲器为空</p> <p>1: 接收数据缓冲器不为空</p> <p>当数据寄存器接收到接收移位寄存器发送的数据时, 由硬件置 1;</p> <p>由软件清 0, 读取 USART_DATA 成清 0, 或者对该位写 0 清除。</p>         |
| 6   | TXCFLG   | RC_W0 | <p>发送数据完成标志 (Transmit Data Complete Flag)</p> <p>0: 发送数据未完成</p> <p>1: 发送数据完成</p> <p>当数据的最后一帧发送完成且 TXBEFLG 置位时, 由硬件置 1;</p> <p>由软件清 0, 先读取 USART_STS 寄存器、再写 USART_DATA 寄存器完成清 0, 或者对该位写 0 清除。</p> |
| 7   | TXBEFLG  | R     | <p>发送数据缓冲器为空标志 (Transmit Data Buffer Empty Flag)</p> <p>0: 发送数据缓冲器不为空</p> <p>1: 发送数据缓冲器为空</p> <p>当移位寄存器接收到发送数据寄存器发送的数据时, 由硬件置 1;</p> <p>由软件清 0, 写 USART_DATA 寄存器完成清 0。</p>                       |
| 8   | LBDFLG   | RC_W0 | <p>检测到 LIN 断开标志 (LIN Break Detected Flag)</p> <p>0: 没有检测到 LIN 断开</p> <p>1: 检测到 LIN 断开</p> <p>当检测到 LIN 断开时, 由硬件置 1;</p> <p>由软件清 0, 对该位写 0 清除。</p>                                                 |

| 位/域   | 名称     | R/W   | 描述                                                                                                                             |
|-------|--------|-------|--------------------------------------------------------------------------------------------------------------------------------|
| 9     | CTSFLG | RC_W0 | CTS 变化标志 (CTS Change Flag)<br>0: nCTS 状态线上没有变化<br>1: nCTS 状态线上发生变化<br>若 CTSEN 位置位, 当 nCTS 输入切换时, 由硬件置 1;<br>由软件清 0, 对该位写 0 清除。 |
| 31:10 | 保留     |       |                                                                                                                                |

### 20.6.2 数据寄存器 (USART\_DATA)

偏移地址: 0x04

复位值: 0xXXXX XXXX, X=未定义位

| 位/域  | 名称   | R/W | 描述                                                                                                                                         |
|------|------|-----|--------------------------------------------------------------------------------------------------------------------------------------------|
| 8:0  | DATA | R/W | 数据值 (Data Value)<br>发送数据值或接收数据值; 接收数据时从中读取, 发送数据时向该寄存器写入数据。<br>如果使能了奇偶校验位, 如果是 9 个数据位, 则 DATA 的第 8 位是校验位; 如果是 8 个数据位, 则 DATA 的第 7 位是奇偶校验位。 |
| 31:9 | 保留   |     |                                                                                                                                            |

### 20.6.3 波特率寄存器 (USART\_BR)

偏移地址: 0x08

复位值: 0x0000 0000

| 位/域   | 名称        | R/W | 描述                                                                                             |
|-------|-----------|-----|------------------------------------------------------------------------------------------------|
| 3:0   | FBR[3:0]  | R/W | USART 波特率分频系数的小数部分 (Fraction of USART Baud Rate Divider factor)<br>USART 波特率分频系数的小数部分由这 4 位决定。 |
| 15:4  | IBR[15:4] | R/W | USART 波特率分频系数的整数部分 (Integer of USART Baud Rate Divider factor)<br>USART 波特率分频系数的整数部分由这 12 位决定。 |
| 31:16 | 保留        |     |                                                                                                |

### 20.6.4 控制寄存器 1 (USART\_CTRL1)

偏移地址: 0x0C

复位值: 0x0000 0000

| 位/域 | 名称   | R/W | 描述                                                                                    |
|-----|------|-----|---------------------------------------------------------------------------------------|
| 0   | TXBF | R/W | 发送断开帧 (Transmit Break Frame)<br>0: 未发送<br>1: 将要发送<br>此位可由软件置位, 在发送断开帧的停止位时, 由硬件将其清 0。 |

| 位/域 | 名称       | R/W | 描述                                                                                                                                                                                                                     |
|-----|----------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1   | RXMUTEEN | R/W | <p>使能接收静默模式 (Receive Mute Mode Enable)</p> <p>0: 正常工作模式<br/>1: 静默模式</p> <p>此位由软件置位或清 0, 或当检测到唤醒序列时, 硬件将其清 0。</p> <p>USART 要先接收一个数据才可置于静默模式, 这样才能被空闲总线检测唤醒。</p> <p>在地址标记检测唤醒中, 若置位 RXBNEFLG 位, 则 RXMUTEEN 位不能被软件修改。</p> |
| 2   | RXEN     | R/W | <p>使能接收 (Receive Enable)</p> <p>0: 禁用<br/>1: 使能, 并开始检测 RX 引脚上的起始位</p>                                                                                                                                                  |
| 3   | TXEN     | R/W | <p>使能发送 (Transmit Enable)</p> <p>0: 禁用<br/>1: 使能</p> <p>除了在智能卡模式下, 任何时候发送数据时, 如果此位上有个 0 脉冲, 那么在当前数据发送完成后, 会发送一个空闲总线。</p> <p>置位此位后, 会延迟一个比特时间发送。</p>                                                                    |
| 4   | IDLEIEN  | R/W | <p>使能 IDLE 中断 (IDLE Interrupt Enable)</p> <p>0: 禁用<br/>1: 当 IDLEFLG 置位时, 产生中断</p>                                                                                                                                      |
| 5   | RXBNEIEN | R/W | <p>使能接收缓冲区非空中断 (Receive Buffer Not Empty Interrupt Enable)</p> <p>0: 禁用<br/>1: 当 OVREFLG 或 RXBNEFLG 置位时, 产生中断</p>                                                                                                      |
| 6   | TXCIEN   | R/W | <p>使能发送完成中断 (Transmit Complete Interrupt Enable)</p> <p>0: 禁用<br/>1: 当 TXCFLG 置位时, 产生中断</p>                                                                                                                            |
| 7   | TXBEIEN  | R/W | <p>使能发送缓冲区空中断 (Transmit Buffer Empty Interrupt Enable)</p> <p>0: 禁用产生中断<br/>1: 当 TXBEFLG 置位时, 产生中断</p>                                                                                                                 |
| 8   | PEIEN    | R/W | <p>使能校验错误中断 (Parity Error Interrupt Enable)</p> <p>0: 禁用产生中断<br/>1: 当 PEFLG 置位时, 产生中断</p>                                                                                                                              |
| 9   | PCFG     | R/W | <p>配置奇偶校验位 (Odd/Even Parity Configure)</p> <p>0: 偶校验<br/>1: 奇校验</p> <p>需要等当前正在发送的字节完成后, 选择才会生效。</p>                                                                                                                    |
| 10  | PCEN     | R/W | <p>使能检验控制 (Parity Control Enable)</p> <p>0: 禁用<br/>1: 使能</p> <p>若置位此位, 发送数据时在最高位插入一个校验位; 接收数据时, 检查接收的数据的校验位是否正确。</p> <p>需要等当前正在发送的字节完成后, 校验控制才会生效。</p>                                                                 |
| 11  | WUPMCFG  | R/W | <p>配置唤醒方式 (Wakeup Method Configure)</p> <p>0: 空闲总线唤醒<br/>1: 地址标记唤醒</p>                                                                                                                                                 |

| 位/域   | 名称     | R/W | 描述                                                                                                             |
|-------|--------|-----|----------------------------------------------------------------------------------------------------------------|
| 12    | DBLCFG | R/W | 配置数据位长度 (Data Bits Length Configure)<br>0: 1 个起始位, 8 个数据位, n 个停止位<br>1: 1 个起始位, 9 个数据位, n 个停止位<br>发送数据时不能修改此位。 |
| 13    | UEN    | R/W | 使能 USART (USART Enable)<br>0: 禁用 USART 分频器和输出<br>1: 使能 USART 模块                                                |
| 14    |        |     | 保留                                                                                                             |
| 15    | OSMCFG | R/W | 配置过采样模式 (Oversampling Mode Configure)<br>0: 16 倍过采样<br>1: 8 倍过采样<br>只有在未使能 USART 时才能置位此位。                      |
| 31:16 |        |     | 保留                                                                                                             |

### 20.6.5 控制寄存器 2 (USART\_CTRL2)

偏移地址: 0x10

复位值: 0x0000 0000

| 位/域 | 名称        | R/W | 描述                                                                                                                      |
|-----|-----------|-----|-------------------------------------------------------------------------------------------------------------------------|
| 3:0 | ADDR[3:0] | R/W | 设置 USART 设备节点地址 (USART Device Node Address Setup)<br>此位只作用于多处理器通信下的静默模式, 依据检测到的地址标记是否一致来决定进入静默模式还是唤醒。                   |
| 4   |           |     | 保留                                                                                                                      |
| 5   | LBDLCFG   | R/W | 配置 LIN 断开符检测长度 (LIN Break Detection Length Configure)<br>0: 10 位<br>1: 11 位                                             |
| 6   | LBDIEN    | R/W | 使能 LIN 断开符检测中断 (LIN Break Detection Interrupt Enable)<br>0: 禁用<br>1: 当 LBDFLG 位置位, 产生中断                                 |
| 7   |           |     | 保留                                                                                                                      |
| 8   | LBCPOEN   | R/W | 使能输出最后一位时钟脉冲 (Last Bit Clock Pulse Output Enable)<br>0: 不从 CK 输出<br>1: 从 CK 输出<br>此位只作用于同步模式; UART4 和 UART5 上不存在此位。     |
| 9   | CPHA      | R/W | 配置时钟相位 (Clock Phase Configure)<br>此位表明在第几个时钟边沿进行采样<br>0: 第一个<br>1: 第二个<br>此位只作用于同步模式; UART4 和 UART5 上不存在此位。             |
| 10  | CPOL      | R/W | 配置时钟极性 (Clock Polarity Configure)<br>当 USART 处于空闲状态时, CK 引脚的状态<br>0: 低电平<br>1: 高电平<br>此位只作用于同步模式, UART4 和 UART5 上不存在此位。 |
| 11  | CLKEN     | R/W | 使能时钟 (CK 引脚) (Clock Enable (CK pin))                                                                                    |

| 位/域   | 名称      | R/W | 描述                                                                                     |
|-------|---------|-----|----------------------------------------------------------------------------------------|
|       |         |     | 0: 禁用<br>1: 使能<br>UART4 和 UART5 上不存在此位。                                                |
| 13:12 | STOPCFG | R/W | 配置停止位 (STOP Bit Configure)<br>00: 1 个停止位<br>01: 0.5 个停止位<br>10: 2 个停止位<br>11: 1.5 个停止位 |
| 14    | LINMEN  | R/W | 使能 LIN 模式 (LIN Mode Enable)<br>0: 禁用<br>1: 使能                                          |
| 31:15 |         |     | 保留                                                                                     |

注意：在使能发送后不能改写这三个位 (CPOL、CPHA、LBCPOEN)。

### 20.6.6 控制寄存器 3 (USART\_CTRL3)

偏移地址: 0x14

复位值: 0x0000 0000

| 位/域 | 名称       | R/W | 描述                                                                                                                                               |
|-----|----------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | ERRIEN   | R/W | 使能错误中断 (Error Interrupt Enable)<br>0: 禁用<br>1: 使能, 当 DMARXEN 置位并且 FEFLG、OVREFLG 或 NEFLG 其中一个置位时, 产生中断。                                           |
| 1   | IREN     | R/W | 使能红外功能 (IrDA Function Enable)<br>0: 禁用<br>1: 使能                                                                                                  |
| 2   | IRLPEN   | R/W | 使能红外低功耗模式 (IrDA Low-power Mode Enable)<br>0: 普通模式<br>1: 低功耗模式                                                                                    |
| 3   | HDEN     | R/W | 使能半双工模式 (Half-duplex Mode Enable)<br>0: 禁用<br>1: 使能                                                                                              |
| 4   | SCNACKEN | R/W | 在智能卡功能下, 使能出现校验错误时发送 NACK (NACK Transmit Enable During Parity Error in Smartcard Function)<br>0: 不发送 NACK<br>1: 发送 NACK<br>UART4 和 UART5 上不存在此位。 |
| 5   | SCEN     | R/W | 使能智能卡功能 (Smartcard Function Enable)<br>0: 禁用<br>1: 使能<br>UART4 和 UART5 上不存在此位。                                                                   |
| 6   | DMARXEN  | R/W | 使能 DMA 接收 (DMA Receive Enable)<br>0: 禁用<br>1: 使能                                                                                                 |

| 位/域   | 名称      | R/W | 描述                                                                                                                                                                                                                                                                          |
|-------|---------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7     | DMATXEN | R/W | 使能 DMA 发送 (DMA Transmit Enable)<br>0: 禁用<br>1: 使能                                                                                                                                                                                                                           |
| 8     | RTSEN   | R/W | 使能 RTS 硬件流控制功能 (RTS Hardware Flow Control Function Enable)<br>0: 禁用<br>1: 使能 RTS 中断<br>RTS: Require To Send 发送请求, 为输出信号, 说明已准备好接收。<br>当接收缓冲区有空间时才请求接收数据; 当可以接收数据时, RTS 输出被拉至低电平。<br>UART4 和 UART5 上不存在此位。                                                                   |
| 9     | CTSEN   | R/W | 使能 CTS 硬件流控制功能 (CTS Hardware Flow Control Function Enable)<br>0: 禁用<br>1: 使能<br>CTS: Clear To Send 发送清除, 为输入信号。<br>当 CTS 输入信号为低电平时, 才能发送数据, 否则无法发送数据; 若在发送数据时, CTS 信号被拉高, 那么当这个数据发送完成后, 将停止数据发送; 如果在 CTS 为高电平时对数据寄存器进行写操作, 则要等 CTS 有效时才会将这个数据发送出去。<br>UART4 和 UART5 上不存在此位。 |
| 10    | CTSIEN  | R/W | 使能 CTS 中断 (CTS Interrupt Enable)<br>0: 禁用<br>1: CTSFLG 置位时产生中断<br>UART4 和 UART5 上不存在此位。                                                                                                                                                                                     |
| 11    | SAMCFG  | R/W | 配置采样方法 (Sample Method Configure)<br>0: 三次采样<br>1: 单次采样, 禁止噪音检测标志<br>只有在未使能 USART 时才能置位此位。                                                                                                                                                                                   |
| 31:12 |         |     | 保留                                                                                                                                                                                                                                                                          |

### 20.6.7 保护时间和预分频寄存器 (USART\_GTPSC)

偏移地址: 0x18

复位值: 0x0000 0000

| 位/域   | 名称   | R/W | 描述                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0   | PSC  | R/W | <p>设置预分频系数 (Prescaler Factor Setup)<br/>           对系统时钟进行分频提供时钟；在不同的工作模式下，PSC 的有效位存在差异，具体如下：<br/>           在红外低功耗模式下：<br/> <b>PSC[7:0]</b>有效。<br/>           00000000: 保留<br/>           00000001: 1 分频<br/>           00000010: 2 分频<br/>           .....<br/>           11111111: 255 分频<br/>           在红外的正常模式下：<br/> <b>PSC</b>只能设置为 00000001<br/>           在智能卡模式下：<br/> <b>PSC[7:5]</b>无效，<b>PSC[4:0]</b>有效<br/>           00000: 保留<br/>           00001: 2 分频<br/>           00010: 4 分频<br/>           00011: 6 分频<br/>           .....<br/>           11111: 62 分频<br/> <b>UART4 和 UART5 上不存在此位。</b></p> |
| 15:8  | GRDT | R/W | <p>设置保护时间值 (Guard Time Value Setup)<br/>           在发送数据完成后，需等待保护时间才将 TXCFLG 置位；时间单位是波特时钟；可应用于智能卡模式；<b>UART4 和 UART5 上不存在此位。</b></p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 31:16 |      |     | 保留                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

## 21 内部集成电路接口 (I2C)

### 21.1 术语全称、缩写描述

表格 88 术语全称、缩写描述

| 中文全称    | 英文全称                        | 英文缩写  |
|---------|-----------------------------|-------|
| 串行数据线   | Serial Data                 | SDA   |
| 串行时钟线   | Serial Clock                | SCL   |
| 系统管理总线  | System Management Bus       | SMBus |
| 时钟      | Clock                       | CLK   |
| 高速串行时钟  | Serial Clock High           | SCLH  |
| 低速串行时钟  | Serial Clock Low            | SCLL  |
| 地址解析协议  | Address Resolution Protocol | ARP   |
| 否认应答    | Negative Acknowledgement    | NACK  |
| 数据包出错检测 | Packet Error Checking       | PEC   |
| 地址分辨协议  | Address Resolution Protocol | ARP   |

### 21.2 简介

I2C 是一种短距离总线通信协议，物理实现上，I2C 总线由两根信号线（SDA 与 SCL）和一个地线组成，两根信号线为双向发送的。

- 两根信号线，SCL 时钟线、SDA 数据线。由 SCL 为 SDA 提供时序，SDA 串行发送/接收数据
- SCL、SDA 这两根信号线均为双向
- 两个系统使用 I2C 总线通信时共地

### 21.3 主要特征

- (1) 多主机功能
- (2) 主机可产生时钟、起始位和停止位
- (3) 从机功能
  - 可编程的 I2C 地址检测
  - 双地址模式
  - 检测停止位
- (4) 7 位和 10 位寻址模式
- (5) 响应广播
- (6) 两种通信速度

- 标准模式
- 快速模式

(7) 可编程的时钟延长

(8) 状态标志

- 发送器/接收器模式标志
- 字节发送结束标志
- 总线忙标志

(9) 错误标志

- 仲裁丢失
- 应答错误
- 检测到错误的起始位或停止位

(10) 中断源

- 地址/数据通信成功
- 错误中断

(11) 支持 DMA 功能

(12) 可编程的 PEC

- 发送模式中最后发送
- 接收最后一个字节后进行 PEC 错误校验

(13) SMBus 特定功能

- 硬件 PEC
- 地址解析协议

## 21.4 结构框图

图 78 I2C 功能结构图



接口可配置为以下模式：

- 从机发送
- 从机接收
- 主机发送
- 主机接收

当 I2C 接口初始状态下，工作模式为从机模式。当 I2C 接口发送起始信号后，将自动从从机模式转换为主机模式。

## 21.5 功能描述

表格 89 I2C 总线专有名词说明

| 专有名词 | 说明                                       |
|------|------------------------------------------|
| 发送器  | 发送数据到总线的设备                               |
| 接收器  | 从总线接收数据的设备                               |
| 主机   | 初始化数据发送，产生时钟信号和结束数据发送的设备                 |
| 从机   | 由主机寻址的设备                                 |
| 多主   | 不破坏信息的前提下同时控制总线的多个主机                     |
| 同步   | 同步两个或更多设备之间的时钟信号的过程                      |
| 仲裁   | 如果超过一个主机同时尝试控制总线时，只有一个主机可控制，且控制的主机信息不被破坏 |

### 21.5.1 I2C 物理层

I2C 通讯设备之间的常用连接方式如下图：

图 79 常见 I2C 通信连接图



物理层特点：

- (1) 支持多设备的总线（多个设备共用的信号线），在 I2C 通信总线中，可连接多个通信主机与通信从机。

- (2) 一个 I2C 总线只使用两条总线线路，一条双向串行数据线（SDA），一条串行时钟线（SCL）。数据线用于发送数据，时钟线用于数据收发同步。
- (3) 每一个连接在总线上的设备都具有独立的地址（七位或十位），主机根据设备地址寻址访问从设备。
- (4) 总线需要接上拉电阻到电源，I2C 总线空闲状态下，输出为高阻态，所有设备空闲时，都输出高阻态，上拉电阻把总线拉成高电平。
- (5) 通信模式：标准模式（高达 100kHz）、快速模式（高达 400kHz）。
- (6) 多主机同时使用总线时，防止数据冲突，采取总线仲裁方式决定哪个设备占用总线。
- (7) 可编程建立和保持时间，可对 I2C 中 SCL 的高电平时间与低电平时间进行编程。

### 21.5.2 I2C 协议层

#### 协议层特点

- (1) 数据以帧的形式发送，每一帧中由 1 个字节（8 位）组成。
- (2) 在 SCL 的上升沿阶段，SDA 需要保持稳定，SDA 在 SCL 为低期间作出改变。
- (3) 除了数据帧，I2C 总线还有起始信号、停止信号和应答信号。
  - 起始位：在 SCL 为稳定的高电平期间，SDA 的一个下降沿启动发送。
  - 停止位：在 SCL 为稳定的高电平期间，SDA 的一个上升沿停止发送。
  - 应答位：用于表示一个字节发送成功。总线发送器（无论主机还是从机，在发送 8 个位的数据后，SDA 将释放（由输出变为输入），在第九个时钟脉冲期间，接收器将 SDA 拉低，来应答接收到的数据。

#### I2C 通信读写过程

图 80 主机写数据到从机



图 81 主机由从机读取数据



备注：

- (1) ：此数据由主机发送到从机
- (2) **S**：起始信号
- (3) **SLAVE ADDRESS**：从机地址
- (4) ：此数据由从机发送到主机
- (5) **R/W**：发送方向选择位
- (6) 1 为读取
- (7) 0 为写入
- (8) **P**：停止信号

起始信号产生后，所有从机都将等待主机发送的从机地址信号，I2C 总线中，每个设备的地址都是唯一的，当地址信号与设备地址匹配后，从机将被选中，没被选中的从机将忽略以后的数据信号。

#### 主机方向为写数据时

广播完地址后，接收到应答信号，主机向从机发发送数据，数据长度为一个字节，主机每次发完一个字节数据后，都需等待从机发送的应答信号，当发送的所有字节完成后，主机向从机发送一个停止信号（STOP），表示为发送完成。

#### 主机方向为读数据时

广播完地址后，接收到应答信号，从机开始向主机发送数据，数据包的大小为 8 位，从机每发送完一个字节数据，都要等待主机的应答信号，当主机想停止接收数据时，需要向从机返回一个非应答信号，则从机自动停止数据发送。

#### 21.5.3 数据有效性

数据发送过程中，时钟信号 SCL 高电平期间，SDA 线上数据必须稳定，只有当 SCL 在低电平期间 SDA 的电平状态才能发生改变，每个数据比特发送都需要一个时钟脉冲。

图 82 SDA 时序图



#### 21.5.4 起始和停止信号

所有数据发送都必定有起始信号（START）和停止信号（STOP）。

下图的 START 信号定义为：SCL 为高电平时，SDA 由高电平向低电平转换。

图 83 START



下图的 STOP 信号定义为：SCL 为高电平时，SDA 由低电平向高电平转换。

图 84 STOP



#### 21.5.5 仲裁

仲裁也是为了解决多主机情况下的总线控制冲突。仲裁过程在主机发生，与从机无关。

只有在总线空闲时，主机才可以启动发送。两个主机可能在 START 信号的最短保持时间内在总线上产生一个有效的 START 信号。这种情况需要仲裁决定哪个主机完成发送。

仲裁是按位来进行的，在每一位仲裁期间，当 SCL 为高，每个主机都会检查 SDA 电平是否和自己发送的相同，仲裁过程需要持续很多位。理论上，如果两个主机发送的内容完全相同，那它们能够成功发送而不发生仲裁失败。如果一个主机发送高电平，但是检测到 SDA 为低电平，则发生仲裁失败错误，关闭自身 SDA 输出，另一个主机完成自身发送。

图 85 SDA 时序图



注意：Master1 仲裁失败

### 21.5.6 SMBus 特定功能

系统管理总线（System Management Bus，简称 SMBus），结构简单的单端双线制总线，可实现轻量级的通信需求。

SMBus 常见于计算机主板，主要用于电源发送 ON/OFF 指令。SMBus 为 I2C 的衍生总线。主要用于计算机主板上的低带宽设备通信，与电源相关芯片。

#### 地址解析协议

SMBus 规范中包含一个地址解析协议，可实现动态地址分配。动态识别硬件和软件使得总线能够支持热拔插，总线设备被自动识别并分配唯一地址。

#### SMBus 警报

SMBus 报警是一个带中断线的可选信号，通过占用引脚实现扩展设备的控制能力。

### 21.5.7 错误标志位

表格 90 I2C 通信存在以下几种错误标志位

| 错误标志位                       | 错误标志位说明                                                          |
|-----------------------------|------------------------------------------------------------------|
| 应答错误标志位(AEFLG)              | 没有收到应答                                                           |
| 总线错误标志位(BERRFLG)            | 检测到一个外部的停止或起始条件                                                  |
| 仲裁丢失标志位(ALFLG)              | 接口检测到仲裁丢失                                                        |
| 过载/欠载错误标志位(OVRURFLG)        | 从模式下，接收数据未读出，下一个数据已经到达，发生过载错误。发送数据时钟已经到达，数据仍未写入 DATA 寄存器，发生欠载错误。 |
| 超时或 $T_{low}$ 错误标志位(TTEFLG) | SCL 拉低超过一定时间                                                     |
| PEC 比较错误标志位(PECEFLG)        | CRC 值不相等                                                         |

### 21.5.8 报文错误检验 (PEC)

I2C 模块具有一个 PEC 模块，通过 CRC-8 计算器来进行对 I2C 数据的报文检

验，计算器使用的 CRC-8 多项式为：  $C(x)=X^8+X^2+X+1$ 。

将 PECEN 位置 1，使能 PEC 功能，PEC 模块会把 I2C 总线发送的所有数据都计算，其中包括地址数据。

### 21.5.9 DMA 模式

根据 I2C 的软件流程，当发送寄存器为空或者接收寄存器满时，MCU 需要写入或者读取字节，此时通过 I2C 的 DMA 功能，能够更快速的完成该操作。

#### DMA 发送

设置 I2C\_CTRL2 寄存器中的 DMAEN 位使能 DMA 模式，当发送寄存器为空时（TXBEFLG 置 1），数据将通过 DMA 从存储区直接载入到 DATA 寄存器。

#### DMA 接收

设置 I2C\_CTRL2 寄存器中的 DMAEN 位使能 DMA 模式，当接收寄存器满时（RXBNEFLG 置 1），DMA 将 DATA 寄存器数据发送到设定的存储区。

### 21.5.10 I2C 中断

表格 91 I2C 中断请求

| 中断事件             | 事件标志位     | 中断控制位          |
|------------------|-----------|----------------|
| 发送起始位完成          | STARTFLG  | EVIEN          |
| 发送完成/地址匹配地址信号    | ADDRFLG   |                |
| 10 位地址头段发送完成     | ADDR10FLG |                |
| 接收到停止信号          | STOPFLG   |                |
| 数据字节发送完成         | BT CFLG   |                |
| 接收缓冲器非空          | RXBNEFLG  | EVIEN 和 BUFIEN |
| 发送缓冲区空           | TXBEFLG   |                |
| 总线错误             | BERRFLG   | ERRIEN         |
| 仲裁丢失             | ALFLG     |                |
| 应答错误             | AEFLG     |                |
| 过载/欠载            | OVRURFLG  |                |
| PEC 错误           | PECEFLG   |                |
| 超时或 $T_{low}$ 错误 | TTEFLG    |                |
| SMBus 警报         | ALERTEN   |                |

## 21.6 寄存器地址映射

表格 92 I2C 寄存器地址映射

| 寄存器名         | 描述        | 偏移地址 |
|--------------|-----------|------|
| I2C_CTRL1    | 控制寄存器 1   | 0x00 |
| I2C_CTRL2    | 控制寄存器 2   | 0x04 |
| I2C_SADDR1   | 从机地址寄存器 1 | 0x08 |
| I2C_SADDR2   | 从机地址寄存器 2 | 0x0C |
| I2C_DATA     | 数据寄存器     | 0x10 |
| I2C_STS1     | 状态寄存器 1   | 0x14 |
| I2C_STS2     | 状态寄存器 2   | 0x18 |
| I2C_CLKCTRL  | 主机时钟控制寄存器 | 0x1C |
| I2C_RISETMAX | 最大上升时间寄存器 | 0x20 |

## 21.7 寄存器功能描述

### 21.7.1 控制寄存器 1 (I2C\_CTRL1)

偏移地址: 0x00

复位值: 0x0000

| 位/域 | 名称      | R/W | 描述                                                                                                     |
|-----|---------|-----|--------------------------------------------------------------------------------------------------------|
| 0   | I2CEN   | R/W | 使能 I2C (I2C Enable)<br>0: 禁用<br>1: 使能                                                                  |
| 1   | SMBEN   | R/W | 使能 SMBus 模式 (SMBus Mode Enable)<br>0: I2C 模式<br>1: SMBus 模式                                            |
| 2   |         |     | 保留                                                                                                     |
| 3   | SMBTCFG | R/W | 配置 SMBus 类型 (SMBus Type Configure)<br>0: SMBus 设备<br>1: SMBus 主机                                       |
| 4   | ARPEN   | R/W | 使能 ARP (ARP Enable)<br>0: 禁用<br>1: 使能<br>如果 SMBTCFG=0, 使用 SMBus 设备的默认地址<br>如果 SMBTCFG=1, 使用 SMBus 的主地址 |
| 5   | PECEN   | R/W | 使能 PEC (PEC Enable)<br>0: 禁用<br>1: 使能                                                                  |

| 位/域 | 名称          | R/W | 描述                                                                                                                                                                                  |
|-----|-------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6   | SRBEN       | R/W | 使能从机响应广播 (Slave Responds Broadcast Enable)<br>0: 禁用<br>1: 使能<br>注意: 广播地址是 0x00                                                                                                      |
| 7   | CLKSTRETCHD | R/W | 禁止从机模式时钟延长时间 (Slave Mode Clock Stretching Disable)<br>0: 使能<br>1: 禁止<br>在从机模式下允许延长时钟低电平时间可避免发生过载和欠载错误。                                                                              |
| 8   | START       | R/W | 发送起始位 (Start Bit Transfer)<br>可软件置 1、清 0, 当发送起始位或 I2CEN=0 时, 由硬件清 0。<br>0: 不发送<br>1: 发送                                                                                             |
| 9   | STOP        | R/W | 发送停止位 (Stop Bit Transfer)<br>可软件置 1、清 0; 当发送停止位时, 由硬件清 0; 当检测到超时错误时, 由硬件置 1。<br>0: 不发送<br>1: 发送                                                                                     |
| 10  | ACKEN       | R/W | 发送应答使能 (Acknowledge Transfer Enable)<br>可软件置 1、清 0; 当 I2CEN=0 时, 由硬件清除。<br>0: 不发送<br>1: 发送                                                                                          |
| 11  | ACKPOS      | R/W | 配置接收数据应答/PEC 位置 (Acknowledge /PEC Position Configure)<br>可软件置 1、清 0; 当 I2CEN=0 时, 由硬件清除。<br>0: 接收当前字节时是否发送 NACK/ACK, PEC 是否处于移位寄存器中<br>1: 接收下一个字节时是否发送 NACK/ACK, PEC 是否处于移位寄存器的下一字节 |
| 12  | PEC         | R/W | 使能发送 PEC (Packet Error Check Transfer Enable)<br>可软件置 1、清 0; 当发送 PEC 后, 或发送起始位、停止位, 或当 I2CEN=0 时, 由硬件清 0。<br>0: 禁用<br>1: 使能                                                         |
| 13  | ALERTEN     | R/W | 使能 SMBus 提醒 (SMBus Alert Enable)<br>可软件置 1、清 0; 当 I2CEN=0 时, 由硬件清 0。<br>0: 释放 SMBAlert 引脚使其变高, 提醒发送 NACK 信号后即时发送响应地址头<br>1: 驱动 SMBAlert 引脚使其变低, 提醒发送 ACKEN 信号后即时发送响应地址头             |
| 14  |             |     | 保留                                                                                                                                                                                  |
| 15  | SWRST       | R/W | 软件配置 I2C 处于软件复位状态 (Software Configure I2C under Reset State)<br>0: 未复位<br>1: 复位, 在复位 I2C 前应确保 I2C 引脚被释放、总线是空闲状态。                                                                    |

### 21.7.2 控制寄存器 2 (I2C\_CTRL2)

偏移地址: 0x04

复位值: 0x0000

| 位/域   | 名称      | R/W | 描述                                                                                                                                                                                                               |
|-------|---------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5:0   | CLKFCFG | R/W | 配置 I2C 时钟频率 (I2C Clock Frequency Configure)<br>该时钟频率是指 I2C 模块的时钟, 即从 APB 总线输入的时钟。<br>000000: 禁用<br>000001: 禁用<br>000010: 2MHz<br>...<br>111100: 60MHz<br>大于 111100: 禁用<br>I2C 总线最小的时钟频率: 标准模式为 1MHz, 快速模式为 4MHz。 |
| 7:6   |         |     | 保留                                                                                                                                                                                                               |
| 8     | ERRIEN  | R/W | 使能出错中断 (Error Interrupt Enable)<br>0: 禁用<br>1: 使能以下任何状态寄存器中的位置 1 时, 将产生该中断:<br>SMBALTFLG、TTEFLG、PECEFLG、OVRURFLG、AEFLG、<br>ALFLG、STS1_BERRFLG                                                                    |
| 9     | EVIEN   | R/W | 使能事件中断 (Event Interrupt Enable)<br>0: 禁用<br>1: 使能, 以下任何状态寄存器中的位置 1 时, 将产生该中断: STARTFLG、<br>ADDRFLG、ADDR10FLG、STOPFLG、BTCFLG、TXBEFLG 置 1 且<br>BUFIEN 置 1、RXBNEFLG 置 1 且 BUFIEN 置 1。                               |
| 10    | BUFIEN  | R/W | 使能缓冲器中断 (Buffer Interrupt Enable)<br>0: 禁用<br>1: 使能, 以下任何状态寄存器中的位置 1 时, 将产生该中断: TXBEFLG、<br>RXBNEFLG                                                                                                             |
| 11    | DMAEN   | R/W | 使能 DMA 请求 (DMA Requests Enable)<br>0: 禁用<br>1: 当 TXBEFLG=1 或 RXBNEFLG=1 时, 使能 DMA 请求                                                                                                                             |
| 12    | LTCFG   | R/W | 配置 DMA 最后一次发送 (DMA Last Transfer Configure)<br>配置下一次 DMA 的 EOT 是否为接收的最后一次发送, 只用于主机接收<br>模式。<br>0: 不是<br>1: 是                                                                                                     |
| 15:13 |         |     | 保留                                                                                                                                                                                                               |

### 21.7.3 从机模式地址寄存器 1 (I2C\_SADDR1)

偏移地址: 0x08

复位值: 0x0000

| 位/域 | 名称      | R/W | 描述                                                                              |
|-----|---------|-----|---------------------------------------------------------------------------------|
| 0   | ADDR[0] | R/W | 设置从机地址 (Slave Address Setup)<br>地址模式为 7 位时, 该位无效; 地址模式为 10 位时, 该位是地址的<br>第 0 位。 |

| 位/域   | 名称        | R/W | 描述                                                                            |
|-------|-----------|-----|-------------------------------------------------------------------------------|
| 7:1   | ADDR[7:1] | R/W | 设置从机地址 (Slave Address Setup)<br>从机地址的第 7:1 位。                                 |
| 9:8   | ADDR[9:8] | R/W | 设置从机地址 (Slave Address Setup)<br>地址模式为 7 位时, 该位无效; 地址模式为 10 位时, 该位是地址的第 9:8 位。 |
| 14:10 | 保留        |     |                                                                               |
| 15    | ADDRLEN   | R/W | 配置从机地址长度 (Slave Address Length Configure)<br>0: 7 位地址模式<br>1: 10 位地址模式        |

#### 21.7.4 从机模式地址寄存器 2 (I2C\_SADDR2)

偏移地址: 0x0C

复位值: 0x0000

| 位/域  | 名称         | R/W | 描述                                                                                                                                                                                                             |
|------|------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | ADDRNUM    | R/W | 配置从机地址数量 (Slave Address Number Configure)<br>从机 7 位地址模式下, 可配置为识别单地址模式、双地址模式; 单地址模式下只识别 ADDR1; 双地址模式下识别 ADDR1 和 ADDR2。<br>在 7 位地址模式下可识别单个或双地址寄存器, 具体情况如下:<br>0: 识别 1 个地址 (ADDR1)<br>1: 识别 2 个地址 (ADDR1 和 ADDR2) |
| 7:1  | ADDR2[7:1] | R/W | 设置从机双地址模式地址 (Slave Dual Address Mode Address Setup)<br>在双地址模式下地址的 7:1 位。                                                                                                                                       |
| 15:8 | 保留         |     |                                                                                                                                                                                                                |

#### 21.7.5 数据寄存器 (I2C\_DATA)

偏移地址: 0x10

复位值: 0x0000

| 位/域  | 名称   | R/W | 描述                                                                                 |
|------|------|-----|------------------------------------------------------------------------------------|
| 7:0  | DATA | R/W | 数据寄存器 (Data Register)<br>在 I2C 发送模式下, 将要发送的数据写到这个寄存器; 在 I2C 接收模式下, 从这个寄存器读取接收到的数据。 |
| 15:8 | 保留   |     |                                                                                    |

#### 21.7.6 状态寄存器 1 (I2C\_STS1)

偏移地址: 0x14

复位值: 0x0000

| 位/域 | 名称       | R/W | 描述                                                                                                                                 |
|-----|----------|-----|------------------------------------------------------------------------------------------------------------------------------------|
| 0   | STARTFLG | R   | 发送起始位完成标志 (Start Bit Sent Finished Flag)<br>0: 未发送<br>1: 已发送<br>发出起始位时, 由硬件置 1; 软件先读 STS1 寄存器、再写 DATA 寄存器可清除该位; 当 I2CEN=0 时由硬件清 0。 |

| 位/域 | 名称        | R/W | 描述                                                                                                                                                                                                                                                                           |
|-----|-----------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1   | ADDRFLG   | R   | <p>地址发送完成/接收匹配标志 (Address Transfer Complete /Receive Match Flag)</p> <p>从机模式是否接收到匹配地址:</p> <p>0: 未接收到<br/>1: 已接收</p> <p>主机模式地址发送是否完成:</p> <p>0: 未完成<br/>1: 已完成</p> <p>该位由硬件置 1; 软件先读 STS1 寄存器、再读 STS2 寄存器可清除该位; 当 I2CEN=0 时由硬件清 0。</p>                                       |
| 2   | BT CFLG   | R   | <p>完成数据字节发送标志 (Byte Transfer Complete Flag)</p> <p>0: 未完成<br/>1: 已完成</p> <p>在接收数据时, 如果未读取 DATA 寄存器中收到的数据, 此时又收到一个新的数据时, 由硬件置 1;</p> <p>发送数据时, DATA 寄存器为空的情况下, 将要发送移位寄存器中的数据时, 由硬件置 1。</p> <p>软件先读 STS1 寄存器、再对 DATA 寄存器执行读或写操作可清除该位; 在发送中发送一个起始位、停止位, 或当 I2CEN=0 时由硬件清 0。</p> |
| 3   | ADDR10FLG | R   | <p>主机已发送 10 位地址的地址头标志 (10-Bit Address Header Transmit Flag)</p> <p>0: 未发送<br/>1: 已发送</p> <p>该位由硬件置 1; 软件先读 STS1 寄存器、再写 DATA 寄存器可清除该位; I2CEN=0 时由硬件清 0。</p>                                                                                                                   |
| 4   | STOPFLG   | R   | <p>停止位检测标志 (Stop Bit Detection Flag)</p> <p>0: 未检测到<br/>1: 检测到</p> <p>如果 ACKEN=1, 在一个应答之后, 当从机在总线上检测到停止位时, 由硬件置 1; 软件读取 STS1 寄存器后、对 CTRL1 寄存器进行写操作可清除该位; 当 I2CEN=0 时由硬件清 0。</p>                                                                                              |
| 5   |           |     | 保留                                                                                                                                                                                                                                                                           |
| 6   | RXBNEFLG  | R   | <p>接收缓冲器不为空标志 (Receive Buffer Not Empty Flag)</p> <p>0: 接收缓冲器为空<br/>1: 接收缓冲器不为空</p> <p>当 DATA 寄存器有数据时, 由硬件置 1;</p> <p>当 BT CFLG 置 1 时, 由于数据寄存器仍然为满, 读取 DATA 寄存器不能清除 RXBNEFLG 位; 软件读写 DATA 寄存器可清除该位; 当 I2CEN=0 时由硬件清 0。</p>                                                   |
| 7   | TXBEFLG   | R   | <p>发送缓冲器为空标志 (Transmit Buffer Empty Flag)</p> <p>0: 发送缓冲器不为空<br/>1: 发送缓冲器为空</p> <p>DATA 寄存器的内容为空时由硬件置 1; 软件写第 1 个数据到 DATA 寄存器时, 会立刻将数据搬到移位寄存器中, 此时 DATA 寄存器的数据为空, 无法清除该位。</p> <p>软件写数据到 DATA 寄存器可清除该位; 发送起始位、停止位, 或当 I2CEN=0 时由硬件清 0。</p>                                    |

| 位/域 | 名称        | R/W   | 描述                                                                                                                                                                                                                                                                                                                                                                                       |
|-----|-----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8   | BERRFLG   | RC_W0 | <p>总线错误标志 (Bus Error Flag)<br/>           0: 未发生总线错误<br/>           1: 发生总线错误<br/>           总线错误是指起始位、停止位异常; 检测到错误时由硬件置 1; 软件写 0 可清除该位; I2CEN=0 时由硬件清 0。</p>                                                                                                                                                                                                                            |
| 9   | ALFLG     | RC_W0 | <p>主模式下的仲裁丢失标志 (Master Mode Arbitration Lost Flag)<br/>           0: 未发生仲裁丢失<br/>           1: 发生仲裁丢失, I2C 接口自动切换回从模式<br/>           “主模式下的仲裁丢失”是指该主机失去对总线的控制; 该位由硬件置 1; 软件写 0 可清除该位; I2CEN=0 时由硬件清 0。</p>                                                                                                                                                                               |
| 10  | AEFLG     | RC_W0 | <p>应答错误标志 (Acknowledge Error Flag)<br/>           0: 未发生应答错误<br/>           1: 发生应答错误<br/>           由硬件置 1; 软件写 0 可清除该位; I2CEN=0 时由硬件清 0。</p>                                                                                                                                                                                                                                           |
| 11  | OVRURFLG  | RC_W0 | <p>发生过载或欠载标志 (Overrun/Underrun Flag)<br/>           0: 未发生<br/>           1: 发生<br/>           CLKSTRETCHD=1、且满足以下条件之一时由硬件置 1:<br/>           (1) 从机接收模式下, DATA 寄存器中的数据未被读出时, 又收到新的数据 (该数据会丢失), 此时发生过载;<br/>           (2) 从机发送模式中, DATA 寄存器没有写入数据, 依然要发送数据 (相同的数据会发送 2 次), 此时发生欠载。<br/>           软件写 0 可清除该位; I2CEN=0 时由硬件清 0。</p>                                                     |
| 12  | PECEFLG   | RC_W0 | <p>接收时出现 PEC 错误标志 (PEC Error in Reception Flag)<br/>           0: 无 PEC 错误: 在 ACKEN=1 的情况下接收到 PEC 后接收器返回 ACKEN<br/>           1: 有 PEC 错误: 不管 ACKEN 是什么值, 只要接收到 PEC 后接收器都会返回 NACK<br/>           软件写 0 可清除该位; I2CEN=0 时由硬件清 0。</p>                                                                                                                                                       |
| 13  |           |       | 保留                                                                                                                                                                                                                                                                                                                                                                                       |
| 14  | TTEFLG    | RC_W0 | <p>超时或 <math>T_{low}</math> 错误标志 (Timeout or <math>T_{low}</math> Error Flag)<br/>           0: 无超时错误<br/>           1: 发生超时错误, 从模式下, 从机复位, 总线被释放; 主模式下, 硬件发送停止位。<br/>           以下情况之一发生超时错误, 由硬件置 1:<br/>           (1) SCL 保持低电平大于 25ms;<br/>           (2) 主设备的 SCL 低电平扩展时间累计超过 10ms;<br/>           (3) 从设备的 SCL 低电平扩展时间累计超过 25ms。<br/>           软件写 0 可清除该位; I2CEN=0 时由硬件清 0。</p> |
| 15  | SMBALTFGL | RC_W0 | <p>发生 SMBus 警报标志 (SMBus Alert Occur Flag)<br/>           0: SMBus 主机模式, 无警报;<br/>           SMBus 从机模式, 无警报, SMBAlert 引脚电平不变<br/>           1: SMBus 主机模式, 在引脚上产生警报;<br/>           SMBus 从机模式, 收到警报, 引起 SMBAlert 引脚电平变低<br/>           由硬件置 1; 软件写 0 可清除该位; I2CEN=0 时由硬件清 0。</p>                                                                                                        |

### 21.7.7 状态寄存器 2 (I2C\_STS2)

偏移地址: 0x18

复位值: 0x0000

| 位/域 | 名称          | R/W | 描述                                                                                                                                                                                             |
|-----|-------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | MSFLG       | R   | 主从模式标志 (Master Slave Mode Flag)<br>0: 从机模式<br>1: 主机模式<br>配置 I2C 为主模式时, 由硬件置 1;<br>以下条件之一硬件清 0:<br>(1) 产生停止位<br>(2) 丢失总线仲裁<br>(3) I2CEN=0                                                       |
| 1   | BUSBSYFLG   | R   | 总线忙碌标志 (Bus Busy Flag)<br>0: 总线空闲 (无通信)<br>1: 总线忙 (正在通信)<br>SDA 或 SCL 为低电平时, 由硬件置 1; 产生停止位后, 硬件清 0。                                                                                            |
| 2   | TRFLG       | R   | 发送器模式/接收器模式标志 (Transmitter / Receiver Mode Flag)<br>0: 设备是接收器模式 (读)<br>1: 设备是发送器模式 (写)<br>依据 R/W 决定位的数值;<br>满足以下条件之一由硬件清 0:<br>(1) 产生停止位<br>(2) 产生重复的起始位<br>(3) 总线仲裁丢失<br>(4) I2CEN=0          |
| 3   |             |     | 保留                                                                                                                                                                                             |
| 4   | GENCALLFLG  | R   | 从模式接收到广播地址 (0x00) 标志 (Slave Mode Received General Call Address Flag)<br>0: 未收到广播地址<br>1: 收到广播地址<br>由硬件置 1, 满足以下条件之一由硬件清 0:<br>(1) 产生停止位<br>(2) 产生重复的起始位<br>(3) I2CEN=0                         |
| 5   | SMBDADDRFLG | R   | SMBus 设备从模式接收到默认地址标志 (SMBus Device Received Default Address Flag in Slave Mode)<br>0: 未收到默认地址<br>1: 当 ARPEN=1 时, 收到默认地址<br>由硬件置 1, 满足以下条件之一由硬件清 0:<br>(1) 产生停止位<br>(2) 产生重复的起始位<br>(3) I2CEN=0 |
| 6   | SMMHADDR    | R   | SMBus 设备从模式收到主机头地址标志 (SMBus Device Received Master Header Flag in Slave Mode)<br>0: 未收到主机头地址                                                                                                   |

| 位/域  | 名称          | R/W | 描述                                                                                                                                                                                           |
|------|-------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |             |     | 1: 当同时满足 SMBTSEL=1 和 ARPEN=1 时, 收到主机头地址由硬件置 1, 满足以下条件之一由硬件清 0:<br>(1) 产生停止位<br>(2) 产生重复的起始位<br>(3) I2CEN=0                                                                                   |
| 7    | DUALADDRFLG | R   | 从模式接收到双地址匹配标志 (Slave Mode Received Dual Address Match Flag)<br>0: 接收到的地址与 ADDR1 寄存器的内容匹配<br>1: 接收到的地址与 ADDR2 寄存器的内容匹配<br>由硬件置 1, 满足以下条件之一由硬件清 0:<br>(1) 产生停止位<br>(2) 产生重复的起始位<br>(3) I2CEN=0 |
| 15:8 | PECVALUE    | R   | 存储 PEC 值 (Save Packet Error Checking Value)<br>当 PECEN=1 时, 内部的 PEC 的值存放在 PECVALUE 里。                                                                                                        |

### 21.7.8 主机时钟控制寄存器 (I2C\_CLKCTRL)

偏移地址: 0x1C

复位值: 0x0000

| 位/域   | 名称          | R/W | 描述                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|-------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11:0  | CLKS [11:0] | R/W | 设置主模式下快速/标准模式的时钟 (Clock Setup in Fast/Standard Master Mode)<br>在 I2C 标准模式或 SMBus 模式中:<br>$T_{high} = CLKS \times T_{PCLK1}$<br>$T_{low} = CLKS \times T_{PCLK1}$<br>I2C 快速模式中:<br>当 FDUTYCFG=0 时:<br>$T_{high} = CLKS \times T_{PCLK1}$<br>$T_{low} = 2 \times CLKS \times T_{PCLK1}$<br>当 FDUTYCFG=1 时:<br>$T_{high} = 9 \times CLKS \times T_{PCLK1}$<br>$T_{low} = 16 \times CLKS \times T_{PCLK1}$ |
| 13:12 | 保留          |     |                                                                                                                                                                                                                                                                                                                                                                                                        |
| 14    | FDUTYCFG    | R/W | 配置快速模式下的占空比 (Fast Mode Duty Cycle Configure)<br>此处定义占空比 = $T_{low}/T_{high}$<br>0: SCLK 占空比 2<br>1: SCLK 占空比 16/9                                                                                                                                                                                                                                                                                      |
| 15    | SPEEDCFG    | R/W | 配置主模式速度 (Master Mode Speed Configure)<br>0: 标准模式<br>1: 快速模式                                                                                                                                                                                                                                                                                                                                            |

### 21.7.9 最大上升时间寄存器 (I2C\_RISETMAX)

偏移地址: 0x20

复位值: 0x0002

| 位/域  | 名称       | R/W | 描述                                                                                                                          |
|------|----------|-----|-----------------------------------------------------------------------------------------------------------------------------|
| 5:0  | RISETMAX | R/W | 主模式下快速/标准模式的最大上升时间 (Master Mode Maximum Rise Time in Fast/Standard Mode)<br>时间单位是 $T_{PCLK1}$ , RISETMAX 为 SCL 最大上升时间单位加 1。 |
| 15:6 |          |     | 保留                                                                                                                          |

## 22 串行外设接口 (SPI)

### 22.1 术语全称、缩写描述

表格 93 术语全称、缩写描述

| 中文全称     | 英文全称                  | 英文缩写 |
|----------|-----------------------|------|
| 最高有效位    | Most Significant Bit  | MSB  |
| 最低有效位    | Least Significant Bit | LSB  |
| 主机输出从机输入 | Master Out Slave In   | MOSI |
| 主机输入从机输出 | Master In Slave Out   | MISO |
| 串行时钟线    | Serial Clock          | SCK  |
| 发送       | Transmit              | TX   |
| 接收       | Receive               | RX   |
| 忙        | Busy                  | BSY  |

### 22.2 简介

SPI 接口可以配置为支持 SPI 协议，默认工作在 SPI 模式。

串行外设接口 (SPI) 提供了基于 SPI 协议的数据发送和数据接收功能，允许芯片与外部设备以半双工、全双工、同步和串行方式通信，可以工作于主机或者从机模式。

### 22.3 主要特征

- (1) 具有 3 线全双工同步传输接收的主从操作
- (2) 2 线可实现（第三根双向数据线可选带/不带）单工同步传输
- (3) 选择 8 位或者 16 位传输帧格式
- (4) 具有多主设备模式
- (5) 具有专用的发送和接收标志，可触发中断
- (6) 具有 SPI 总线忙状态标志
- (7) SPI 通信速率最高可达 60Mbit/s
- (8) 时钟的极性和相位可编程
- (9) 数据顺序可编程，选择 MSB 或者 LSB 在前
- (10) 主模式故障、过载以及 CRC 错误标志可触发中断
- (11) 具有 DMA 传输和接收缓冲器

- (12) SPI TI 模式
- (13) 通过硬件 CRC 进行计算、发送和校验

## 22.4 功能描述

### 22.4.1 SPI 信号线描述

表格 94 SPI 信号线描述

| 引脚名称 | 描述                                                                                                                       |
|------|--------------------------------------------------------------------------------------------------------------------------|
| SCK  | 主设备: SPI 时钟输出<br>从设备: SPI 时钟输入                                                                                           |
| MISO | 主设备: 输入引脚, 接收数据<br>从设备: 输出引脚, 发送数据<br>数据方向: 从设备到主设备                                                                      |
| MOSI | 主设备: 输出引脚, 发送数据<br>从设备: 输入引脚, 接收数据<br>数据方向: 主设备到从设备                                                                      |
| NSS  | 软件 NSS 模式: NSS 引脚可以它用。<br>主设备硬件 NSS 模式: 为 NSS 输出, 单主模式。<br>NSS 关闭输出: 允许操作多主环境。<br>从设备硬件 NSS 模式: NSS 信号设置为低电平, 作为从机的片选信号。 |

### 22.4.2 时钟信号的相位和极性

时钟极性和时钟相位是 SPI\_CTRL1 寄存器的 CPOL 和 CPHA 位。

时钟极性 CPOL 是指 SPI 处于空闲状态时, SCK 信号线的电平信号。

- CPOL=0 时, SCK 信号线在空闲状态为低电平
- CPOL=1 时, SCK 信号线在空闲状态为高电平

时钟相位 CPHA 是指数据的采样时刻:

- CPHA=0 时, MOSI 或 MISO 数据线上的信号将会在 SCK 时钟线的“奇数边沿”被采样。
- CPHA=1 时, MOSI 或 MISO 数据线上的信号将会在 SCK 时钟线的“偶数边沿”被采样。

根据时钟相位 CPHA 和时钟极性 CPOL 的不同状态, 可以将 SPI 分成四种模式。

表格 95 SPI 的四种模式

| SPI 模式 | CPHA | CPOL | 采样时刻 | 空闲时 SCK 时钟 |
|--------|------|------|------|------------|
| 0      | 0    | 0    | 奇数边沿 | 低电平        |
| 1      | 0    | 1    | 奇数边沿 | 高电平        |
| 2      | 1    | 0    | 偶数边沿 | 低电平        |
| 3      | 1    | 1    | 偶数边沿 | 高电平        |

### 22.4.3 数据帧格式

通过配置 SPI\_CTRL1 寄存器中的 LSBSEL 位，设定是 MSB 在先还是 LSB 在先。

通过配置 SPI\_CTRL1 寄存器的 DFLSEL 位，选择是 8/16 位数据帧格式进行发送/接收。

### 22.4.4 NSS 模式

软件 NSS 模式：通过配置 SPI\_CTRL1 寄存器的 SSEN 位来选择启动或者禁止此模式，内部 NSS 信号电平由 SPI\_CTRL1 寄存器的 ISSEL 位驱动。

硬件 NSS 模式：

- 启动 NSS 输出：SPI 处于主模式时，使能 SSOEN 位，NSS 引脚被拉至低电平，SPI 将自动进入从机模式。
- 关闭 NSS 输出：允许操作在多主环境。

### 22.4.5 SPI 模式

#### 22.4.5.1 SPI 主模式

在主模式中，在 SCK 引脚产生串行时钟。

主模式配置：

- 配置 SPI\_CTRL1 寄存器中的 MSMSEL=1。
- 通过配置 SPI\_CTRL1 寄存器中的 CPOL 和 CPHA 位，选择极性和相位。
- 通过配置 SPI\_CTRL1 寄存器的 DFLSEL 位选择 8/16 位数据帧格式。
- 通过配置 SPI\_CTRL1 寄存器的 LSBSEL 选择是 LSB 先行还是 MSB 先行。
- NSS 配置：
  - NSS 引脚工作在输入模式：硬件模式下，需要在整个数据帧传输期间把 NSS 引脚连接在高电平；软件模式下，需要设置 SPI\_CTRL1 寄存器中的 SSEN 位和 ISSEL 位。
  - NSS 工作在输出模式中，需要配置 SPI\_CTRL2 寄存器的 SSOEN 位。
- 配置 SPI\_CTRL2 寄存器中的 FRFCFG 位选择 TI 模式协议进行串行通信。
- 配置 SPI\_CTRL1 寄存器中 SPIEN 位，使能 SPI。

在主模式中：MOSI 引脚是数据输出，MISO 是数据输入。

#### TI 协议

在从模式下，SPI 接口支持 TI 协议。通过 SPI\_CTRL2 寄存器的 FRFCFG 位控制。时钟极性和相位都遵循 TI 协议。NSS 管理也特定于 TI 协议，不用配置 SPI\_CTRL1 和 SPI\_CTRL2 寄存器。

#### 22.4.5.2 SPI 从模式

在从模式中，SCK 引脚接收主设备传来的串行时钟。

从模式配置：

- 配置 SPI\_CTRL1 寄存器中的 MSMSEL=0。
- 通过配置 SPI\_CTRL1 寄存器中的 CPOL 和 CPHA 位，选择极性和相位。
- 通过配置 SPI\_CTRL1 寄存器的 DFLSEL 位选择 8/16 位数据帧格式。
- 通过配置 SPI\_CTRL1 寄存器的 LSBSEL 选择是 LSB 先行还是 MSB 先行。
- **NSS 配置：**
  - 硬件模式下：在完整的数据帧传输过程中，NSS 引脚必须为低电平。
  - 软件模式下：设置 SPI\_CTRL1 寄存器中的 SSEN 位并清除 ISSEL 位（TI 模式不需要此步骤）。
- 配置 SPI\_CTRL2 寄存器中的 FRFCFG 位选择 TI 模式协议进行串行通信。
- 配置 SPI\_CTRL1 寄存器中 SPIEN 位，使能 SPI。

在从模式中：MOSI 引脚是数据输入，MISO 引脚是数据输出。

#### TI 协议

在从模式下，SPI 接口支持 TI 协议。通过 SPI\_CTRL2 寄存器的 FRFCFG 位控制。时钟极性和相位都遵循 TI 协议。NSS 管理也特定于 TI 协议，不用配置 SPI\_CTRL1 和 SPI\_CTRL2 寄存器。

处于从模式时，SPI 波特率预分频器可以使用任意波特率来控制 MISO 引脚状态切换到高阻态的时刻，所以可以非常灵活地确定此时刻。波特率一般为外部主时钟波特率。SPI\_CTRL1 寄存器的 BRSEL[2:0]设置的波特率值和芯片内部电路同步决定 MISO 引脚状态变为高阻态的时间。

#### 22.4.5.3 SPI 的半双工通信

一条时钟线加一条双向数据线：

- 通过设置 SPI\_CTRL1 寄存器的 BMEN 启动此模式
- 通过设置 SPI\_CTRL1 寄存器的 BMOEN 位控制数据线是输入还是输出
- SCK 引脚作为时钟，主设备中使用 MOSI 引脚传输数据，从设备中使用 MISO 引脚传输数据

#### 22.4.6 SPI 不同模式下数据发送和接收过程

表格 96 SPI 的运行模式

| 模式         | 配置               | 数据引脚              |
|------------|------------------|-------------------|
| 主设备的全双工模式  | BMEN=0, RXOMEN=0 | MOSI 发送; MISO 接收  |
| 主设备的单向接收模式 | BMEN=0, RXOMEN=1 | MOSI 不使用; MISO 接收 |

| 模式         | 配置               | 数据引脚              |
|------------|------------------|-------------------|
| 主设备的双向发送模式 | BMEN=1, BMOEN=1  | MOSI 发送; MISO 不使用 |
| 主设备的双向接收模式 | BMEN=1, BMOEN=0  | MOSI 不使用; MISO 接收 |
| 从设备的全双工模式  | BMEN=0, RXOMEN=0 | MOSI 接收, MISO 发送  |
| 从设备的单向接收模式 | BMEN=0, RXOMEN=1 | MOSI 接收, MISO 不使用 |
| 从设备的双向发送模式 | BMEN=1, BMOEN=1  | MOSI 不使用, MISO 发送 |
| 从设备的双向接收模式 | BMEN=1, BMOEN=0  | MOSI 接收, MISO 不使用 |

图 86 全双工模式连接



图 87 半双工模式连接（主机用来接收，从机用来发送）



图 88 半双工模式连接（主机只发送，从机接收）



图 89 双向线连接



#### 22.4.6.1 处理数据的发送与接收

##### 数据发送

完成模式配置之后，SPI 模块使能保持在空闲状态。

主模式下：软件写入一个数据帧到发送缓冲器中，发送过程开始。

从模式下：SCK 引脚上的 SCK 信号开始跳变，与此同时 NSS 引脚电位低，发送过程开始（数据开始发送前，确保数据已提前写入发送缓冲区）。

SPI 发送一个数据帧时，会将数据帧从数据缓冲区加载到移位寄存器中，之后开始发送数据。数据帧发送一位后，TXBEFLG 置 1。如果需要连续发送数据，软件需要等到 TXBEFLG=1 向 SPI\_DATA 寄存器中写入数据。TXBEFLG 标志是由硬件置 1，软件清零。

##### 数据接收

在数据接收过程中 BSYFLG 标志会一直置 1。

在采样时钟的最后一个边沿，接收到的数据从移位寄存器传送到接收缓冲区，设置 RXBNEFLG 标志，软件通过读取数据寄存器（SPI\_DATA）中的数据获取接收缓冲区中的内容。如果设置了 SPI\_CTRL2 寄存器的 RXBNEIEN 位，此时会产生中断，在读取数据之后会自动清除 BSYFLG 标志。

#### 22.4.6.2 主/从设备下的全双工发送和接收模式

##### 主设备下的全双工模式

- 写数据到 SPI\_DATA 寄存器（发送缓冲器）后，开始数据传输。
- SPI 发送第一位数据时，数据从发送缓冲器传送到移位寄存器中，按照顺序被串行的传送到 MOSI 引脚中。
- MISO 引脚上接收的数据，按照顺序被串行的传送到 SPI\_DATA 寄存器（接收缓冲器）中。

发送和接收是同时进行的。

### 从设备下的全双工模式

- 从设备接收到时钟信号，**MOSI** 引脚出现第一个数据位时，开始数据传输，之后的数据位会被依次传送到移位寄存器中。
- SPI 发送第一位数据时，数据从发送缓冲器传送到移位寄存器中，按照顺序被串行的传送到 **MISO** 引脚中。
- 软件必须保证在 SPI 主设备开始传输数据之前确保已写入要发送的数据。

发送和接收是同步进行的。

### 主/从设备下的全双工发送和接收过程

- (1) 使能 SPI 模块：配置 **SPI\_CTRL1** 寄存器的 **SPIEN=1**。
- (2) 将第一个要发送的数据写入 **SPI\_DATA** 寄存器中，会清除 **TXBEEFLG** 标志。
- (3) 等待 **TXBEEFLG** 标志位置 1 (硬件控制)，写入需要发送的第二个数据位。
- (4) 等待 **RXBNEFLG** 标志位值置 1 (硬件控制) 读出 **SPI\_DATA** 寄存器中的第一个接收的数据，与此同时清除 **RXBNEFLG** 标志 (软件清零)。重复操作，同时发送和接收数据。
- (5) 等待 **RXBNEFLG=1**，接收最后一个数据。
- (6) 等待 **TXBEEFLG=1**，在 **BSYFLG=0** 之后关闭 SPI 模块。

### 22.4.6.3 主/从设备下的双向发送模式

#### 主设备下的双向发送

- 数据写入到 **SPI\_DATA** 寄存器后，开始传输。
- 发送缓冲器中的数据并行的传送到移位寄存器中，之后按顺序串行传送到 **MOSI** 引脚上。

#### 从设备下的双向发送

- 从设备接收到时钟信号，**MISO** 引脚出现第一个数据位时，开始数据传输。
- 与此同时，发送缓冲器需要发送的数据并行的传送到移位寄存器中，随后被串行发送到 **MISO** 引脚上。在数据开始发送前，确保数据已提前写入发送缓冲区。

### 主/从设备下的双向发送过程

- (1) 使能 SPI 模块：配置 **SPI\_CTRL1** 寄存器的 **SPIEN=1**。
- (2) 将第一个要发送的数据写入 **SPI\_DATA** 寄存器中，会清除 **TXBEEFLG** 标志。

(3) 等待 TXBEFLG=1, 写入第二个数据, 重复操作, 发送后面的数据。

(4) 写入最后一个数据后, 等待 TXBEFLG=1、BSYFLG=0, 发送完成。

#### 22.4.6.4 主/从设备下的单向/双向接收模式

- (1) 使能 SPI 模块: 配置 SPI\_CTRL1 寄存器的 SPIEN=1。
- (2) 主设备中: 立即产生 SCK 时钟, SPI 关闭之前, 不断接收数据。
- (3) 从设备中: SPI 主设备拉低 NSS 且产生时钟时, 接收数据。
- (4) 等到 RXBNEFLG 标志置 1, 通过 SPI\_DATA 读取数据, 重复操作接收数据。

#### 22.4.7 CRC 功能

SPI 模块含有两个 CRC 计算单元分别用来数据接收和数据发送。

CRC 计算单元是在 SPI\_CRCPOLY 寄存器来定义多项式。

通过配置 SPI\_CTRL1 寄存器中的 CRCEN 位使能 CRC 计算, 同时复位 CRC 寄存器 (SPI\_RXCRC 和 SPI\_TXCRC)。

为了得到传输计算的 CRC 值, 当最后一个数据写入发送缓冲器后, 需要设置 SPI\_CTRL1 的 CRCNXT 位。指示硬件在发送最后一个数据之后, 发送 CRC 数值, CRCNXT 位被清除。与此同时, 比较 CRC 和 SPI\_RXCRC 的值, 如果出现了不匹配的情况, 需要设置 SPI\_STS 寄存器的 CRCEFLG 位, 在设置了 SPI\_CTRL2 寄存器的ERRIEN 位时, 会发生中断。

注意:

- (1) 当 SPI 处于从设备下并且使用了 CRC 功能, 在 NSS 引脚时高电平时 CRC 计算仍会继续。例如: 当主设备与多个从设备交替通信时, 就会出现上述情况, 则需要避免 CRC 的错误操作。
- (2) 一个从设备从未选中 (NSS 为高电平) 到选中 (NSS 为低电平 0) 过程中, 需要清除主从两端的 CRC 数值, 来保持主从设备端下次 CRC 计算结果的同步。
- (3) 当 SPI 处于从设备模式时, 要在时钟稳定之后再使能 CRC 计算。
- (4) 当 SPI 时钟频率过高时, CPU 的操作会影响 SPI 的带宽, 建议采用 DMA 模式避免 SPI 速度的降低。
- (5) 当 SPI 时钟频率过高时, 在 CRC 传输期间内, 减少 CPU 的使用频率, 在发送 CRC 过程中禁止函数调用来避免接收最后的数据和 CRC 时出错。
- (6) 在从模式下使用了 NSS 硬件模式, NSS 引脚应该在数据传输和 CRC 传输期间保持为低。

#### 清除 CRC 数值顺序

- (1) 关闭 SPI (SPIEN=0)
- (2) 将 CRCEN 位清零
- (3) 将 CRCEN 位置 1

(4) 使能 SPI (SPIEN=1)

#### 22.4.8 DMA 功能

SPI 中的请求/应答 DMA 机制，方便了高速率的数据传输，提高了系统效率，能够及时向 SPI 发送缓冲器传送数据，同时接收缓冲器也能及时读取数据防止溢出。

SPI 只发送数据时，只需要使能 DMA 的发送通道；SPI 只接收数据时，只需要使能 DMA 的接收通道。

通过配置 SPI\_CTRL2 寄存器的 TXDEN 和 RXDEN 位，使能 SPI 模式的 DMA 功能。

- 发送时：TXBEFLG 标志位置 1 时发出 DMA 请求，DMA 控制器写数据到 SPI\_DATA 寄存器中，此时 TXBEFLG 标志位被清除。
- 接收时：RXBNEFLG 标志位置 1 时发出 DMA 请求，DMA 控制器从 SPI\_DATA 寄存器中读取数据，此时 RXBNEFLG 标志位被清除。

通过监视 BSYFLG 标志位，确认在发送模式下 DMA 传送所有需要发送的数据后 SPI 通信是否结束，可以避免破坏最后一个数据的传输。

#### 带 CRC 的 DMA 功能

结束通信时，如果 SPI 同时使能 CRC 运算和 DMA 功能，CRC 字节的发送和接收会自动完成。

在数据和 CRC 传输结束时，如果 SPI\_STS 寄存器中的 CRCEFLG 标志位置 1，说明传输期间发生了错误。

#### 22.4.9 关闭 SPI

数据传输结束后，通过关闭 SPI 模块结束通讯。在一些配置中，如果在数据还没有传输完成下关闭了 SPI，可能会造成数据传输错误。不同的运行模式需要不同的方法关闭 SPI。

##### 主模式/全双工从模式

- (1) 等待 RXBNEFLG 标志位置 1，接收最后一个数据
- (2) 等待 TXBEFLG 标志位置 1
- (3) 等待 BSYFLG 标志位清零
- (4) 关闭 SPI (设置 SPI\_CTRL1 寄存器的 SPIEN=0)

##### 主模式/从模式单向只发送/双向发送模式

在最后的数据写入 SPI\_DATA 寄存器后：

- (1) 等待 TXBEFLG 标志位置 1
- (2) 等待 BSYFLG 标志位清零

(3) 关闭 SPI (设置 SPI\_CTRL1 寄存器的 SPIEN=0)

#### 主模式/从模式单向只接收/双向接收模式

- (1) 等待第 n-1 个 RXBNEFLG 标志位置 1
- (2) 在关闭 SPI (设置 SPI\_CTRL1 寄存器的 SPIEN=0) 之前等待一个 SPI 时钟周期
- (3) 在进入停机模式之前等待最后一个 RXBNEFLG 标志位置 1

#### 从模式只接收/双向接收模式

在任意时刻都可以关闭 SPI (设置 SPI\_CTRL1 寄存器的 SPIEN=0)，会在传输结束后关闭。如果要进入停机模式，需要等到 BSYFLG 标志位清零。

### 22.4.10 SPI 中断

#### 22.4.10.1 状态标志位

##### 发送缓冲器空闲标志 TXBEFLG

TXBEFLG=1 说明发送缓冲器位空，可以写入下一个待发送的数据，当数据写入 SPI\_DATA 寄存器时，清除 TXBEFLG 标志位。

##### 接收缓冲器非空闲标志 RXBNEFLG

RXBNEFLG=1 说明接收缓冲器中含有有效数据，可以通过 SPI\_DATA 寄存器来读取数据，清除 RXBNEFLG 标志。

##### 忙标志 BSYFLG

BSYFLG 标志由硬件设置和清除，可以表明 SPI 通信层的状态。BSYFLG=1 时，表明 SPI 正在通信，但是在主设备下的双线接收模式，在接收数据期间 BSYFLG=0。

使用 BSYFLG 标志可以检测传输是否结束，避免破坏最后一次传输数据。

BSYFLG 标志位可以用于在多主模式下避免写入数据的冲突。

当出现传输结束（主模式的连续通信除外）、SPI 关闭以及主模式失效的情况，BSYFLG 标志将会清零。

通讯不连续时，在数据项和数据项之间，BSYFLG=0。

通讯连续时：

- 主模式中：传输的整个过程，BSYFLG=1
- 从模式中：每个数据的传输之间，BSYFLG 在一个 SCK 时钟周期保持为低

注意：最好使用 TXBEFLG 和 RXBNEFLG 标志来处理每一个数据项的发送和接收。

## 22.4.10.2 错误标志位

### 主模式错误 MEFLG

**MEFLG** 是一个错误标志位。主模式错误发生在：在硬件 **NSS** 模式中，主设备的 **NSS** 引脚被拉低；在软件 **NSS** 模式中，**ISSEL** 位被清零时；**MEFLG** 位被自动置位。

主模式失效的影响：**MEFLG** 置 1，在设置了 **ERRIEN** 的情况下，产生 SPI 中断；**SPIEN** 被清零，输出停止，关闭 SPI 接口；**MSMSEL** 被清零，设备强制进入从模式。

清除 **MEFLG** 标志位的操作：**MEFLG** 位置 1 时，需要对 **SPI\_STS** 寄存器进行读或者写操作，然后写入 **SPI\_CTRL1** 寄存器。

**MEFLG** 标志位为 1 时，不允许设置 **SPIEN** 和 **MSMSEL** 位。

### 溢出错误 OVRFLG

溢出错误：当主设备发送了数据之后，**RXBNEFLG** 标志位还为 1，说明此时发生为溢出错误。此时 **OVRFLG** 位置 1，如果还设置了 **ERRIEN** 位，将产生中断。

发生溢出错误后，接受缓冲器的数据不是主设备发送的数据，此时读取 **SPI\_DATA** 寄存器的值是之前没有读取的数据，而在之后发送的数据不会被读取。

根据顺序读出 **SPI\_DATA** 寄存器和 **SPI\_STS** 寄存器可以清除 **OVRFLG** 标志。

### CRC 错误标志 CRCEFLG

通过设置 **SPI\_CTRL1** 寄存器的 **CRCEN** 位，启动 CRC 计算，CRC 错误标志，可以核对接收的数据是否有效。

当 **SPI\_TXCRC** 寄存器发送的值与 **SPI\_RXCRC** 寄存器中的数值不匹配时，产生 CRC 错误，此时 **SPI\_STS** 寄存器中的 **CRCEFLG** 标志位置 1。

对 **SPI\_STS** 寄存器的 **CRCEFLG** 位写 0，清除 **CRCEFLG**。

### TI 帧格式错误标志 FREFLG

如果 SPI 在从模式下支持 TI 协议，则在通信期间出现 **NSS** 脉冲时将检测到 TI 帧格式错误。此错误出现时，**SPI\_STS[FREFLG]=1**，且不会关闭 SPI，但会忽略 **NSS** 脉冲，并且 SPI 会等待下一个 **NSS** 脉冲到达再开始新的传输。由于错误检测可能导致丢失两个数据字节，因此数据可能会损坏。

读取 **SPI\_STS** 寄存器时 **FREFLG** 标志清零。如果 **ERRIEN=1**，则检测到帧格式错误时将产生一个中断。此时无法保证数据的连续性，应关闭 SPI，并在重新使能从 SPI 后，由主机重启通信。

表格 97 SPI 中断请求

| 中断标志     | 中断事件      | 使能控制位    | 清除方式                               |
|----------|-----------|----------|------------------------------------|
| TXBEFLG  | 发送缓冲器空标志  | TXBEIEN  | 写 SPI_DATA 寄存器                     |
| RXBNEFLG | 接收缓冲器非空标志 | RXBNEIEN | 读 SPI_DATA 寄存器                     |
| MEFLG    | 主模式失效事件   | ERRIEN   | 读/写 SPI_STS 寄存器, 然后写 SPI_CTRL1 寄存器 |
| OVRFLG   | 溢出错误      |          | 读 SPI_DATA 寄存器, 然后读 SPI_STS 寄存器    |
| CRCEFLG  | CRC 错误标志  |          | 写 0 到 CRCEFLG 位                    |
| FREFLG   | TI 帧格式错误  |          | 读 SPI_STS 寄存器                      |

## 22.5 寄存器地址映射

表格 98 SPI 寄存器地址映射

| 寄存器名        | 描述             | 偏移地址 |
|-------------|----------------|------|
| SPI_CTRL1   | SPI 控制寄存器 1    | 0x00 |
| SPI_CTRL2   | SPI 控制寄存器 2    | 0x04 |
| SPI_STS     | SPI 状态寄存器      | 0x08 |
| SPI_DATA    | SPI 数据寄存器      | 0x0C |
| SPI_CRCPOLY | SPI CRC 多项式寄存器 | 0x10 |
| SPI_RXCRC   | SPI 接收 CRC 寄存器 | 0x14 |
| SPI_TXCRC   | SPI 发送 CRC 寄存器 | 0x18 |

## 22.6 寄存器功能描述

可以用半字（16 位）或字（32 位）的方式操作这些外设寄存器。

### 22.6.1 SPI 控制寄存器 1 (SPI\_CTRL1)

偏移地址: 0x00

复位值: 0x0000

| 位/域 | 名称   | R/W | 描述                                                                                                                                                                |
|-----|------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | CPHA | R/W | <p>配置时钟相位 (Clock Phase Configure)<br/>           该位表明在几个时钟边沿开始采样。<br/>           0: 在第 1 个时钟边沿<br/>           1: 在第 2 个时钟边沿<br/>           注意: 通信进行时, 不能修改该位。</p> |
| 1   | CPOL | R/W | <p>配置时钟极性 (Clock Polarity Configure)<br/>           当 SPI 处于空闲状态时, SCK 保持的电平状态。<br/>           0: 低电平<br/>           1: 高电平<br/>           注意: 通信进行时, 不能修改该位。</p> |

| 位/域 | 名称     | R/W | 描述                                                                                                                                                                                                                                                  |
|-----|--------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2   | MSMCFG | R/W | <p>配置主/从模式 (Master/Slave Mode Configure)</p> <p>0: 配置为从模式<br/>1: 配置为主模式</p> <p>注意: 通信进行时, 不能修改该位。</p>                                                                                                                                               |
| 5:3 | BRSEL  | R/W | <p>选择波特率分频系数 (Baud Rate Divider Factor Select)</p> <p>000: DIV=2<br/>001: DIV=4<br/>010: DIV=8<br/>011: DIV=16<br/>100: DIV=32<br/>101: DIV=64<br/>110: DIV=128<br/>111: DIV=256</p> <p>波特率=<math>F_{PCLK}/DIV</math></p> <p>注意: 通信进行时, 不能修改该位。</p> |
| 6   | SPIEN  | R/W | <p>使能 SPI 设备 (SPI Device Enable)</p> <p>0: 禁用<br/>1: 使能</p> <p>注意: 当关闭 SPI 设备时, 请按照关闭 SPI 的过程操作。</p>                                                                                                                                                |
| 7   | LSBSEL | R/W | <p>选择 LSB 首位传输 (LSB First Transfer Select)</p> <p>0: 先发送最高有效位 (MSB)<br/>1: 先发送最低有效位 (LSB)</p>                                                                                                                                                       |
| 8   | ISSEL  | R/W | <p>选择内部从设备 (Internal Slave Device Select)</p> <p>当 <b>CTRL1_SSEN=1</b> 时 (软件 NSS 模式), 可配置该位选择内部 NSS 电平</p> <p>0: 内部 NSS 为低电平<br/>1: 内部 NSS 为高电平</p>                                                                                                 |
| 9   | SSEN   | R/W | <p>使能软件从设备 (Software Slave Device Enable)</p> <p>0: 禁用软件 NSS 模式, 内部 NSS 电平由外部 NSS 引脚决定<br/>1: 启用软件 NSS 模式, 内部 NSS 电平由 <b>SPI_CTRL1</b> 寄存器的 ISSEL 位决定</p>                                                                                           |
| 10  | RXOMEN | R/W | <p>使能仅接收模式 (Receive Only Mode Enable)</p> <p>0: 同时发送和接收<br/>1: 仅接收模式</p> <p><b>RXOMEN</b> 位和 <b>BMEN</b> 位一起决定了双线双向模式下的传输方向, 在多个从设备的配置中, 为了避免数据传输冲突的发生, 需要在未被访问的从设备上使 <b>RXOMEN</b> 位置 1。</p>                                                       |
| 11  | DFLSEL | R/W | <p>选择数据帧长度 (Data Frame Length Format Select)</p> <p>0: 8 位数据帧格式<br/>1: 16 位数据帧格式</p> <p>注意: 为确保正确操作, 只应在禁止 SPI ( SPIEN="0" ) 时对此位执行写操作。</p>                                                                                                         |
| 12  | CRCNXT | R/W | <p>使能下一个传输数据是 CRC (CRC Transfer Next Enable)</p> <p>0: 下一个传输数据来自发送缓冲区<br/>1: 下一个传输数据来自 CRC 寄存器</p> <p>注意: 在 <b>SPI_DATA</b> 寄存器写入最后一个数据后, 马上设置 <b>CRCNXT</b> 位。</p>                                                                                 |

| 位/域 | 名称    | R/W | 描述                                                                                                                                                                                 |
|-----|-------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13  | CRCEN | R/W | <p>使能 CRC 校验 (CRC Calculate Enable)<br/>           0: 禁用<br/>           1: 使能<br/>           CRC 校验功能仅应用于全双工模式。<br/>           注意: 为确保正确操作, 只应在禁止 SPI ( SPIEN="0" ) 时对此位执行写操作。</p> |
| 14  | BMOEN | R/W | <p>使能双向模式的输出 (Bidirectional Mode Output Enable)<br/>           0: 禁用, 即仅接收模式<br/>           1: 使能, 即仅发送模式<br/>           在 BMEN=1 即单线双向模式下, 该位决定传输线的传输方向。</p>                      |
| 15  | BMEN  | R/W | <p>使能双向模式 (Bidirectional Mode Enable)<br/>           0: 双线单向模式<br/>           1: 单线双向模式<br/>           单线双向传输指: 数据主机的 MOSI 引脚和从机的 MISO 引脚之间传输。</p>                                 |

## 22.6.2 SPI 控制寄存器 2 (SPI\_CTRL2)

偏移地址: 0x04

复位值: 0x0000

| 位/域 | 名称       | R/W | 描述                                                                                                                                                 |
|-----|----------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | RXDEN    | R/W | <p>使能接收缓冲区 DMA (Receive Buffer DMA Enable)<br/>           当 RXDEN=1 时, RXBNEFLG 标志一旦被置位就发出 DMA 请求。<br/>           0: 禁用<br/>           1: 启动</p>   |
| 1   | TXDEN    | R/W | <p>使能发送缓冲区 DMA (Transmit Buffer DMA Enable)<br/>           当该位被设置时, TXBEFLG 标志一旦被置位就发出 DMA 请求。<br/>           0: 禁用<br/>           1: 启动</p>       |
| 2   | SSOEN    | R/W | <p>使能 SS 输出 (SS Output Enable)<br/>           SS 输出在主模式下。<br/>           0: 禁用 SS 输出, 可以工作在多主机模式。<br/>           1: 开启 SS 输出, 不能工作在多主机模式。</p>      |
| 3   | 保留       |     |                                                                                                                                                    |
| 4   | FRFCFG   | R/W | <p>配置帧格式 (Frame Format Configure)<br/>           0: SPI 摩托罗拉模式<br/>           1: SPI TI 模式</p>                                                     |
| 5   | ERRIEN   | R/W | <p>使能错误中断 (Error Interrupt Enable)<br/>           0: 禁用<br/>           1: 使能<br/>           产生错误时, ERRIEN 位控制是否产生中断。</p>                           |
| 6   | RXBNEIEN | R/W | <p>使能接收缓冲区非空中断 (Receive Buffer Not Empty Interrupt Enable)<br/>           0: 禁用<br/>           1: 允许<br/>           当 RXBNEFLG 标志位置 1 时产生中断请求。</p> |

| 位/域  | 名称      | R/W | 描述                                                                                                 |
|------|---------|-----|----------------------------------------------------------------------------------------------------|
| 7    | TXBEIEN | R/W | 使能发送缓冲区空中断 (Transmit Buffer Empty Interrupt Enable)<br>0: 禁用<br>1: 使能<br>当 TXBEFLG 标志位置 1 时产生中断请求。 |
| 15:8 |         |     | 保留                                                                                                 |

### 22.6.3 SPI 状态寄存器 (SPI\_STS)

偏移地址: 0x08

复位值: 0x0002

| 位/域  | 名称       | R/W   | 描述                                                                                                               |
|------|----------|-------|------------------------------------------------------------------------------------------------------------------|
| 0    | RXBNEFLG | R     | 接收缓冲非空标志 (Receive Buffer Not Empty Flag)<br>0: 空<br>1: 非空                                                        |
| 1    | TXBEFLG  | R     | 发送缓冲器为空标志 (Transmit Buffer Empty Flag)<br>0: 非空<br>1: 空                                                          |
| 3:2  |          |       | 保留                                                                                                               |
| 4    | CRCEFLG  | RC_W0 | 发生 CRC 错误标志 (CRC Error Occur Flag)<br>该位表示接收的 CRC 值和 RXCRC 寄存器的值是否匹配<br>0: 匹配<br>1: 不匹配<br>该位由硬件置位, 软件对该位写 0 清除。 |
| 5    | MEFLG    | R     | 发生模式错误标志 (Mode Error Occur Flag)<br>0: 未发生<br>1: 发生<br>由硬件置位。                                                    |
| 6    | OVRFLG   | R     | 发生上溢标志 (Overrun Occur Flag)<br>0: 未发生<br>1: 发生<br>由硬件置位。                                                         |
| 7    | BSYFLG   | R     | SPI 忙标志 (SPI Busy Flag)<br>0: SPI 空闲<br>1: SPI 正在通信<br>由硬件置位或者清除。                                                |
| 8    | FREFLG   | R     | 帧格式错误标志 (Frame Format Error Flag)<br>0: 未发生<br>1: 发生<br>注意: 在 TI 从模式下工作时, 使用此标志。该位由硬件置 1, 读取 SPI_STS 寄存器时清 0。    |
| 15:9 |          |       | 保留                                                                                                               |

### 22.6.4 SPI 数据寄存器 (SPI\_DATA)

偏移地址: 0x0C

复位值: 0x0000

| 位/域  | 名称   | R/W | 描述                                                                                                                                                                                                                              |
|------|------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0 | DATA | R/W | <p>发送接收数据寄存器 (Transmit Receive Data register)<br/>           写该寄存器时, 会将数据写入发送缓冲区; 读该寄存器时, 是读取接收缓冲区的数据。<br/>           缓冲区的大小和数据帧的长度保持一致, 即对于 8 位数据, 发送、接收数据时只会用到 DATA[7:0], DATA[15:8]是无效; 对于 16 位数据, 发送、接收时会用到 DATA[15:0]。</p> |

### 22.6.5 SPI CRC 多项式寄存器 (SPI\_CRCPOLY)

偏移地址: 0x10

复位值: 0x0007

| 位/域  | 名称      | R/W | 描述                                                                                                          |
|------|---------|-----|-------------------------------------------------------------------------------------------------------------|
| 15:0 | CRCPOLY | R/W | <p>设置 CRC 多项式数值 (CRC Polynomial Value Setup)<br/>           该寄存器是包含了 CRC 计算的 CRC 多项式, 可修改, 复位值是 0x0007。</p> |

### 22.6.6 SPI 接收 CRC 寄存器 (SPI\_RXCRC)

偏移地址: 0x14

复位值: 0x0000

| 位/域  | 名称    | R/W | 描述                                                                                                                                                                                                                                                               |
|------|-------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0 | RXCRC | R   | <p>接收数据的 CRC 数值 (Receive Data CRC Value)<br/>           硬件计算接收数据的 CRC 数据存储在改寄存器; 位数和数据帧的长度一致, 即如果接收数据是 8 位的, CRC 计算按 CRC8 方式; 如果接收数据是 16 位, CRC 计算按 CRC16 计算。<br/>           当 CRCEN 置位时, 硬件清除该寄存器。<br/>           注意: 当 BSYFLG 位置 1 时, 读取 RXCRC 寄存器数值有可能错误。</p> |

### 22.6.7 SPI 发送 CRC 寄存器 (SPI\_TXCRC)

偏移地址: 0x18

复位值: 0x0000

| 位/域  | 名称    | R/W | 描述                                                                                                                                                                                                                                                                |
|------|-------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0 | TXCRC | R   | <p>发送数据的 CRC 数值 (Transmit Data CRC Value)<br/>           硬件计算发送数据的 CRC 数据存储在改寄存器; 位数和数据帧的长度一致, 即如果发送数据是 8 位的, CRC 计算按 CRC8 方式; 如果发送数据是 16 位, CRC 计算按 CRC16 计算。<br/>           当 CRCEN 置位时, 硬件清除该寄存器。<br/>           注意: 当 BSYFLG 位置 1 时, 读取 RXCRC 寄存器数值有可能错误。</p> |

## 23 四线串行外围接口 (QSPI)

### 23.1 术语全称、缩写描述

表格 99 术语全称、缩写描述

| 中文全称      | 英文全称                                                | 英文缩写   |
|-----------|-----------------------------------------------------|--------|
| 四线串行外围接口  | Quad Serial Peripheral Interface                    | QSPI   |
| 电可擦除只读存储器 | Electrically Erasable Programmable Read-Only Memory | EEPROM |

### 23.2 简介

QSPI 是一个串行数据总线接口，由时钟 (SCLK)，片选信号 (CS)，和 4 条数据线 (IO[0:3]) 组成。连接单，双或四线外部 SPI Flash 存储介质。该接口有四种传输模式：发送和接收，仅发送，仅接收，EEPROM 读。传输模式由软件进行控制。

### 23.3 主要特征

- (1) 可编程的时钟极性和时钟相位
- (2) 集成了用于发送和接收的 FIFO，FIFO 深度为 8，位宽为 32-bit
- (3) 具有 4 种传输模式，支持 4-bit 到 32-bit 之间的数据帧大小传输
- (4) 支持硬件或软件控制片选信号线
- (5) 在四线传输模式下，支持时钟延展
- (6) 支持可变指令长度、地址长度、等待周期和数据帧大小
- (7) 在接收串行数据时，采样时间的可编程延时，可达到更高的串行数据位采样比率

### 23.4 功能描述

#### 23.4.1 传输模式

在串行总线传输数据时，QSPI 在不同模式下的运行。传输模式 (TXMODE) 由控制寄存器 1 (QSPI\_CTRL1) 的 TXMODE 确定。

#### 发送和接收

当 TXMODE=2'b00 时，发送和接收逻辑都是有效的。当数据写入到发送 FIFO 中且数据的数量大于 FIFO 发送阈值 (QSPI\_TFTL 寄存器的 TFTH) 时，传输开始。数据串行被传输到发送数据线上并到达目标设备。与此同时。接收数据线上的数据会从接收移位寄存器中送到接收 FIFO 中。

图 90 发送和接收状态下的 QSPI 传送 FIFO 状态



仅发送

当 TXMODE=2'b01 时，只有发送逻辑单元有效。接收逻辑单元无效，当数据写入到发送 FIFO 中且数据的数量大于 FIFO 发送阀值 (QSPI\_TFTL 寄存器的 TFTH) 时，传输开始，数据串行的被送到发送数据线上并到达目标设备。接收数据线上的数据会被忽略。因此没有数据会被存储到接收 FIFO 中。

以下的图片展示了分别在串行传送开始之前和传送完成之后的 FIFO 水平。在这个例子中，两个数据帧从 QSPI 以连续传送形式发送到外部串行设备中。

图 91 发送状态下的 QSPI 传送 FIFO 状态



仅接收

当 **TXMODE=2'b10** 时，只有接收逻辑单元有效，发送逻辑单元无效。不会有数据被发送。接收数据线上的数据会从接收移位寄存器中送到接收 FIFO 中。为了开始一次传输，一个无效的数据需要被写入到发送 FIFO 中。

以下的图片展示了分别在在串行传送开始之前和传送完成之后的 FIFO 水平。在此示例中，QSPI 连续接收到来自外部串行设备的两个数据。

图 92 仅接收状态下的 QSPI 传送 FIFO 状态



### EEPROM (电可擦除只读存储器) 读取

当 TXMODE=2'b11 时，发送的数据被用于发送指令/地址给对应的外部设备。通常需要用三个数据帧（8 位指令码，8 位高地址，8 位低地址）。在发送数据的过程中接收逻辑单元不会捕捉接受数据线上的任何数据直至发送 FIFO 为空。即当发送 FIFO 为空，接受逻辑单元开始有效，开始接收数据，直至 QSPI 接收的数据帧数量与 QSPI\_CTRL2 寄存器中的 NDF 字段的值再加一相等为止。

以下的图片展示了分别在在串行传送开始之前和传送完成之后的 FIFO 水平。在此示例中，QSPI 连续接收到来自外部串行设备的两个数据。

图 93 EEPROM 读取传输模式下的 FIFO 状态



### 23.4.2 数据传送

数据传送由外部主机设备启动。进入传输 FIFO 后，有效数据的数量比 QSPI\_TFTL 寄存器的 TFTH 量大，同时一个外部从机设备被选定。当数据正在传输时，寄存器状态设定为 BUSY 标志。必须等 BUSY 标志清除后才能尝试进行一个新的外部传送。

### 23.4.3 时钟比

#### 时钟比描述

QSPI 是一个过采样的结构。对于操作的主机模式来说，外围设备时钟 (`sclk_out`) 周期是一个多重的内核时钟 (`qspi_clk`)。

当 QSPI 宏单元被设定为主机设备时，比特率时钟的最大频率 (`sclk_out`) 是 `qspi_clk` 频率的一半。这允许移位控制逻辑在 `sclk_out` 的一个时钟边缘捕捉数据，并在相反边缘衍生数据。

`sclk_out` 频率可以从以下公式中获得：

$$F_{sclk\_out} = F_{qspi\_clk} / SCKDIV$$

注意：

- (1) SCKDIV 可编程寄存器保持在一个均值为 0-65534 的范围之间。如果 SCKDIV=0，`sclk_out` 就被禁用。
- (2) 只有正在进行活跃的传送时，`sclk_out` 线才会切换。而其余的时间，它都会停留在一个非活跃的状态。

下图说明 `sclk_out` 和 `qspi_clk` 之间的最大比率。



#### 最大比频率比概要

(`sclk_out/sclk_in`) 比特率和 QSPI 外围设备时钟 (`qspi_clk`) 之间的频率比规则总结如下：

$$F_{qspi\_clk} \geq 2 \times (\text{maximum } F_{sclk\_out})$$

#### 23.4.4 接收和发送 FIFO 缓冲器

QSPI 运用的 FIFO 缓冲器是内部 D 类触发器，串行规范说明一个串行传送（数据帧）长度为 4-32 位，所以传输和接收 FIFO 缓冲器的长度固定为 32 位。小于 32 位的数据帧在被写入传输 FIFO 缓冲器时必须右对齐。移位控制逻辑会自动地对在接收 FIFO 缓冲器接收到的数据作右对齐调整。QSPI\_TFTL 决定产生中断的 FIFO 条目水平。

AHB 向 QSPI 数据寄存器 (QSPI\_DATA) 发出读取指令，数据就会从接收 FIFO 中弹出。当 FIFO 条目数量大于或者等于 FIFO 阈值加 1 时，接收 FIFO 就会发生 FIFO 全中断请求 (qspi\_rxf\_intr)。由可编程序寄存器 QSPI\_RFTL 设定的阈值决定了产生中断的 FIFO 条目水平。

阈值允许向处理器发送 FIFO 将要空的指示。当接收移位逻辑尝试传送数据到几乎满的接收 FIFO 时会产生接收 FIFO 超额中断。然后，这些新接收的数据会丢失。如果尝试从一个空的接收 FIFO 读取数据会产生接收 FIFO 下溢中断，这种情况处理器会被警告读取的数据是无效的。

#### 23.4.5 接收数据 (RXD) 采样延迟

当 QSPI 被设定为主机时，可以包含其它的逻辑以便延迟接收数据信号的默认采样时间。额外的逻辑有助于提高串行总线的可实现频率最大值。

在主机发出的 `sclk_out` 信号和从机发出的 `RXD` 信号之间往返路线上的延迟可以认为是接收信号的计时。从主机的角度看，已经不是正常的采样时间。以下图例说明这个情况：

图 95 接受数据 (RXD) 样本延迟描述



从机使用主机发出的 `sclk_out` 信号作为闸门，以便获得 `RXD` 信号的数据映射到串行总线上。从机设备对 `sclk_out` 发出信号在路由和采样的延迟，意味着在主机采集 `RXD` 信号样品之前，`RXD` 比特未稳定到正确的值。

以下图例展示了一个 `RXD` 信号的路由延迟如何在主机采集端口的默认时间下，产生了不正确的 `RXD` 值结果。如果没有接收样本延迟逻辑，将会需要提高传送的波特率以便保证接收数据信号的安装时间是在范围内的，而这会导致降低串行接口频率的结果。

当 `RXD` 样品延迟逻辑被包含时，可以动态地编辑延迟值以便使 `RXD` 信号的采样时间从默认值变为 `qspi_clk` 的周期数量。`RXD` 样品延迟逻辑可设定为同时利用 `qspi_clk` 的正极边缘和负极边缘收集 `RXD` 信号样品。这样会增加在一个 `sclk_out` 周期内的采样点数量，和有助于满足更高频率的计时。QSPI 利用 `QSPI_RSD` 寄存器改变 `RXD` 信号的采样点。

图 96 利用 QSPI 采集 RXD 信号样品



### 23.4.6 QSPI 中断

#### qspi\_txe\_intr

当传输 FIFO 等于或小于其阈值时被设定。由可编程序寄存器 QSPI\_RFTL 设定的阈值决定了产生中断的 FIFO 条目水平。当数据被写入传输 FIFO 缓冲器时，中断会被硬件清除，使其超过阈值水平。

#### qspi\_txo\_intr

当一个 AHB 接入尝试写入已经完全写满的传输 FIFO 中时被设定。当已设定后，从 AHB 写入的数据被忽略。直到传输 FIFO 溢出中断清除寄存器 (QSPI\_TFOIC) 被读取之前，中断仍然保持设置状态。

#### qspi\_rxf\_intr

当接收 FIFO 等于或大于其阈值加 1 时被设定，需要在中断内读取接收 FIFO 缓冲器以防止溢出。由可编程序寄存器 QSPI\_RFTL 设定的阈值决定了产生中断的 FIFO 条目水平。当数据从接收 FIFO 缓冲器被读取时，中断会被硬件清除，使其超过阈值水平。

#### qspi\_rxo\_intr

当接收逻辑尝试在已经写满的接收 FIFO 中放入数据时被设定。当已设定后，新接收的数据被忽略。直到接收 FIFO 溢出中断清除寄存器 (QSPI\_RFOIC) 被读取之前，中断仍然保持设置状态。

### qspi\_rxu\_intr

当一个 AHB 接入尝试从空的接收 FIFO 中读取时被设定。当已设定后，从接收 FIFO 中读取为零。直到接收 FIFO 下溢中断清除寄存器 (QSPI\_RFUIC) 被读取之前，中断仍然保持设置状态。

#### 23.4.7 增强 SPI 模式的写入操作

QSPI 写入操作可分为指令阶段、地址阶段和数据阶段这三部分。

以下寄存器位置被用于一个写入操作：

- QSPI\_CTRL1 的 FRF 位指定帧传输的格式
- QSPI\_CTRL3 的 INSLEN 位指定指令的长度
- QSPI\_CTRL3 的 ADDRLEN 位指定地址长度
- QSPI\_CTRL1 的 DFS 位指定数据长度

只有在指令和地址都被写入到数据寄存器中，QSPI 才会开启一次写传输。

要发起一个 Quad 写入操作，QSPI\_CTRL1 的 FRF 必须分别被设定为 10。这意味着设置了传送的类型，对于每个写入指令，数据都会以 QSPI\_CTRL1 的 FRF 位指定的格式传送。

以下是增强 SPI 模式写入操作可能发生的情况：

- Case A: 指令和地址都以标准 SPI 格式传输
- Case B: 指令以标准格式传输，地址以增强 SPI 格式传输
- Case C: 指令和地址都以增强 SPI 格式传输

### 增强 SPI 模式读取操作

QSPI 读取操作可分为指令阶段，地址阶段，等待周期和数据阶段这四个阶段。

等待周期可以利用 QSPI\_CTRL3 的 WAITCYC 来编程。等待周期被运用于锁定并更改从机的模式，从输入变为输出，且可随设备不同而变化。对于一个读取操作，QSPI 一次性发出指令和控制数据，等收到数据帧的 NDF (QSPI\_CTRL2 寄存器) 数量后，然后禁用从机选择信号。要发起一个 Quad 读取操作，QSPI\_CTRL1 的 FRF 分别设定为 00/01/10。而这会设定了传送的类型，每一个读取指令数据将以 QSPI\_CTRL1 的 FRF 中规定的形式进行传送。

以下是增强 SPI 模式写入操作可能出现的四种情况：

- Case A: 指令和地址都以标准 SPI 格式传输
- Case B: 指令以标准格式传输，地址以增强 SPI 格式传输
- Case C: 指令和地址都以增强 SPI 格式传输
- Case D: 没有指令读取、地址读取传输

### 时钟延展功能

在 QSPI 和外部 SPI 设备传输数据时，由于软件可能无法保证传输的时效性，因此在 QSPI 发送数据时，发送 FIFO 可能为空导致没有有效的数据可以被发送而产生下溢错误。在接收时，接收 FIFO 可能满导致接下来的数据无法被正常接收

而产生上溢错误。为了避免上述问题，软件必须放弃本次传输而重新开始一次传输。

为解决上述情况，**QSPI** 提供了时钟延展功能。若在一次发送数据传输结束之前发送 **FIFO** 为空，**QSPI** 会关闭时钟信号。直到发送 **FIFO** 中有足够的数据（数据量高于发送数据阀值 **TFTH**）后，**QSPI** 重新输出时钟信号并继续本次传输。若在一次接受数据结束之前接收 **FIFO** 已满，**QSPI** 会关闭时钟信号，直到接收 **FIFO** 中的数据被读走（数据量低于接收数据阀值 **QSPI\_RFTL**）。

设置 **QSPI\_CTRL3** 寄存器的第 30 位可以开启或关闭时钟延展功能。若时钟延展功能被开启，必须将本次传输数据帧的长度填写到 **QSPI\_CTRL2** 寄存器中。

### 23.4.8 DMA 功能

**QSPI** 中的请求/应答 **DMA** 机制，方便了高速率的数据传输，提高了系统效率。

通过配置 **QSPI\_DMACTRL** 寄存器的 **RDMAEN** 和 **TDMAEN** 位，使能 **QSPI** 的 **DMA** 功能。

- 发送时：当发送 **FIFO** 电平寄存器 **QSPI\_TFL** 内的有效数据等于或低于 **DMATDL** 位配置的值时，会产生 **DMA** 发送数据请求。
- 接收时：当接收 **FIFO** 电平寄存器 **QSPI\_RFL** 内的有效数据等于或高于 **DMARDL** 位配置的值时，会产生 **DMA** 接收数据请求。

### 23.4.9 XIP 功能

#### 23.4.9.1 XIP 模式概述

**QSPI** 支持 **eXecute In Place (XIP)** 模式。该模式下，**QSPI** 充当 **SPI** 存储器的内存映射接口，可以直接执行从 **SPI** 存储器中读取的代码而不需要先复制代码。

#### 23.4.9.2 XIP 操作配置流程

**XIP** 操作仅在双、四线 **SPI** 模式下支持。通常，**XIP** 操作包括指令阶段、地址阶段和数据阶段。其中，**XIP** 操作是否包括指令阶段，由 **Flash** 存取器特性决定。

当 **Flash** 支持指令阶段时，设置 **XIP** 传输的配置流程如下：

- (1) 在 **QSPI\_SWITCH** 寄存器中配置外部访问存储空间和数据大小端类型；
- (2) 在 **QSPI\_CTRL1** 寄存器中设置帧格式值、传输模式和数据帧大小；
- (3) 在 **QSPI\_BR** 寄存器中设置时钟分频；
- (4) 在 **QSPI\_CTRL3** 中设置地址长度、等待周期等；
- (5) 在 **XIP\_INCR\_INST** 和 **XIP\_WRAP\_INST** 寄存器中写入指令操作码；
- (6) 在 **XIP\_CTRL** 寄存器中设置 **XIP** 预取及传输类型、等待周期、指令长度、指令和地址传输类型及指令使能等；
- (7) 在 **XIP\_SER** 寄存器中配置从机使能；
- (8) 在 **XIP\_EN** 寄存器中配置 **XIP** 使能。

当 Flash 不支持指令阶段时，设置 XIP 传输的配置流程如下：

- (1) 在 QSPI\_SWITCH 寄存器中配置外部访问存储空间和数据大小端类型；
- (2) 在 QSPI\_CTRL1 寄存器中设置帧格式值、传输模式和数据帧大小；
- (3) 在 QSPI\_BR 寄存器中设置时钟分频；
- (4) 在 QSPI\_CTRL3 中设置地址长度、等待周期等；
- (5) 在 XIP\_CTRL 寄存器中设置 XIP 预取及传输类型、等待周期和地址传输类型等；
- (6) 在 XIP\_SER 寄存器中配置从机使能；
- (7) 在 XIP\_EN 寄存器中配置 XIP 使能。

注意：最大地址长度为 32。

#### 23.4.9.3 XIP 和非 XIP

XIP 和非 XIP 是相互排斥的，当启动新的 XIP 或非 XIP 时，需要按照顺序安排两次传输。

可以在 XIP 传输过程中发起一个非 XIP（读取或写入）事务。在串行接口上，一次只能进行一个事务。QSPI 按照先到先服务的原则对事务进行优先处理，这意味着如果 SPI 接口上已经有一个非 XIP 传输正在进行中，那么 XIP 传输请求将等到当前传输完成后才进行，反之亦然。

XIP 操作和非 XIP 操作都有各自固定的寄存器进行传输配置。

#### 23.4.9.4 XIP 连续传输和非连续传输

QSPI 支持连续传输和非连续传输模式。

XIP 为连续传输时，需要按照 Flash 特性配置对应的指令（由 Flash 特性决定是否支持）、地址（连续传输数据的基地址）等。将指令、地址发送到外接 Flash 后，QSPI 从基址开始进行连续数据读取传输。其中，指令和地址只需要发送一次，后续数据在基地址上进行增量读取传输。

XIP 为非连续传输时，每次读取一个数据都需要发送一次完整的指令（由 Flash 特性决定是否支持）、地址，然后进行对应地址的数据读取传输。

相较于 XIP 的连续传输，XIP 的非连续传输每次都需要发送一个完整的指令和地址，然后才可以进行数据读取传输，这就增加了系统的延迟。

通过将 XIP\_CTRL[CONT\_XFER\_EN]位设置为 1，可以启用 QSPI 的连续 XIP 模式。

QSPI 会由于以下任一条件而退出连续模式：

- 在 XIP 接口上接收到非 XIP 命令（实际上是将 xip\_en 使能信号驱动为 0）。
- 当 CPU 指向非连续地址时，从设备选中将被取消，然后 QSPI 发起新的 XIP 请求。

#### 23.4.9.5 XIP 操作中的数据预取

QSPI 支持 XIP 的数据预取功能，控制器在当前 XIP 事务期间预取连续突发的数据。如果下一个事务请求是针对连续地址的，数据可以直接从 RX FIFO 中读取，而无需等待新的地址和数据发送到设备，这提高了系统的整体性能。

如果在预取完成后出现新的 XIP 请求，则开始一个新的 XIP 操作，此时会清空上一个 XIP 请求中预取的数据，开始新的传输和 XIP 预取操作。

如果启用了 XIP 连续模式和预取功能，则数据将从设备中预取，并且芯片选择引脚保持激活状态。在连续请求期间，数据将从 RX FIFO 中读取，并且 QSPI 将为连续地址预取数据。这个过程会持续，直到接收到非连续地址或者检测到非 XIP 请求。在这种情况下，预取的数据将从 FIFO 中清除，并启动新的传输。

## 23.5 寄存器地址映射

表格 100 QSPI 寄存器地址映射

| 寄存器名          | 描述                | 偏移地址  |
|---------------|-------------------|-------|
| QSPI_CTRL1    | 控制寄存器 1           | 0x00  |
| QSPI_CTRL2    | 控制寄存器 2           | 0x04  |
| QSPI_SSIEN    | 使能寄存器             | 0x08  |
| QSPI_SLAEN    | 从机使能寄存器           | 0x10  |
| QSPI_BR       | 波特率寄存器            | 0x14  |
| QSPI_TFTL     | 传输 FIFO 阈值电平寄存器   | 0x18  |
| QSPI_RFTL     | 接收 FIFO 阈值电平寄存器   | 0x1C  |
| QSPI_TFL      | 发送 FIFO 电平寄存器     | 0x20  |
| QSPI_RFL      | 接收 FIFO 电平寄存器     | 0x24  |
| QSPI_STS      | 状态寄存器             | 0x28  |
| QSPI_INTEN    | 中断使能寄存器           | 0x2C  |
| QSPIISTS      | 中断状态寄存器           | 0x30  |
| QSPI_RIS      | 原始中断状态寄存器         | 0x34  |
| QSPI_TFOIC    | 发送 FIFO 溢出中断清除寄存器 | 0x38  |
| QSPI_RFOIC    | 接收 FIFO 溢出中断清除寄存器 | 0x3C  |
| QSPI_RFUIC    | 接收 FIFO 下溢中断清除寄存器 | 0x40  |
| QSPI_ICF      | 中断清除寄存器           | 0x48  |
| QSPI_DMACTRL  | DMA 控制寄存器         | 0x4C  |
| QSPI_DMATDL   | DMA 发送数据电平寄存器     | 0x50  |
| QSPI_DMARDL   | DMA 接收数据电平寄存器     | 0x54  |
| QSPI_DATA     | 数据寄存器             | 0x60  |
| QSPI_RSD      | RX 样本延迟寄存器        | 0xF0  |
| QSPI_CTRL3    | 控制寄存器 3           | 0xF4  |
| XIP_INCR_INST | XIP INCR 转移操作码寄存器 | 0x100 |
| XIP_WRAP_INST | XIP WRAP 转移操作码寄存器 | 0x104 |
| XIP_CTRL      | XIP 控制寄存器         | 0x108 |

| 寄存器名        | 描述              | 偏移地址  |
|-------------|-----------------|-------|
| XIP_SER     | 从机使能寄存器         | 0x10C |
| QSPI_SWITCH | QSPI SWITCH 寄存器 | 0x200 |
| XIP_EN      | XIP 使能寄存器       | 0x204 |

## 23.6 寄存器功能描述

### 23.6.1 控制寄存器 1 (QSPI\_CTRL1)

偏移地址: 0x00

复位值: 0x0000 4007

该寄存器控制了串行数据的传送。当 QSPI 启动时，不能写入该寄存器。通过写入 QSPI\_CTRL2 寄存器启动或者禁用 QSPI。

| 位/域 | 名称  | R/W | 描述                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-----|-----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4:0 | DFS | RW  | <p>数据帧大小 (Data Frame Size)<br/>         选择数据帧长度。当数据帧大小编程为小于 32 位时，接收数据由接收逻辑自动右对齐，并以接收 FIFO 零填充高位。在写入传输 FIFO 之前，必须对传输数据进行右调整。传输逻辑在传输数据时忽略未使用的高位。</p> <p>如果 SPI_FRF =01，则 DFS 值必须是 2 的倍数。<br/>         如果 SPI_FRF =10，则 DFS 值必须是 4 的倍数。</p> <p>0x0 (DFS_01_BIT): 保留<br/>         0x1 (DFS_02_BIT): 保留<br/>         0x2 (DFS_03_BIT): 保留<br/>         0x3 (DFS_04_BIT): 04-bit 串行数据传输<br/>         0x4 (DFS_05_BIT): 05-bit 串行数据传输<br/>         0x5 (DFS_06_BIT): 06-bit 串行数据传输<br/>         0x6 (DFS_07_BIT): 07-bit 串行数据传输<br/>         0x7 (DFS_08_BIT): 08-bit 串行数据传输<br/>         0x8 (DFS_09_BIT): 09-bit 串行数据传输<br/>         0x9 (DFS_10_BIT): 10-bit 串行数据传输<br/>         0xA (DFS_11_BIT): 11-bit 串行数据传输<br/>         0xB (DFS_12_BIT): 12-bit 串行数据传输<br/>         0xC (DFS_13_BIT): 13-bit 串行数据传输<br/>         0xD (DFS_14_BIT): 14-bit 串行数据传输<br/>         0xE (DFS_15_BIT): 15-bit 串行数据传输<br/>         0xF (DFS_16_BIT): 16-bit 串行数据传输<br/>         0x10 (DFS_17_BIT): 17-bit 串行数据传输<br/>         0x11 (DFS_18_BIT): 18-bit 串行数据传输<br/>         0x12 (DFS_19_BIT): 19-bit 串行数据传输<br/>         0x13 (DFS_20_BIT): 20-bit 串行数据传输<br/>         0x14 (DFS_21_BIT): 21-bit 串行数据传输<br/>         0x15 (DFS_22_BIT): 22-bit 串行数据传输<br/>         0x16 (DFS_23_BIT): 23-bit 串行数据传输<br/>         0x17 (DFS_24_BIT): 24-bit 串行数据传输<br/>         0x18 (DFS_25_BIT): 25-bit 串行数据传输<br/>         0x19 (DFS_26_BIT): 26-bit 串行数据传输<br/>         0x1A (DFS_27_BIT): 27-bit 串行数据传输<br/>         0x1B (DFS_28_BIT): 28-bit 串行数据传输</p> |

| 位/域   | 名称     | R/W | 描述                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|--------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |        |     | 0x1C (DFS_29_BIT): 29-bit 串行数据传输<br>0x1D (DFS_30_BIT): 30-bit 串行数据传输<br>0x1E (DFS_31_BIT): 31-bit 串行数据传输<br>0x1F (DFS_32_BIT): 32-bit 串行数据传输                                                                                                                                                                                                                                                   |
| 9:5   |        |     | 保留                                                                                                                                                                                                                                                                                                                                                                                             |
| 11:10 | TXMODE | R/W | 传送模式 (Transfer Mode)<br>选择串行通讯的传输模式。此字段不影响传输的重复性，仅指示接收或发送数据是否有效。<br>在仅发送模式下，从外部设备接收的数据无效，且不存储在接收 FIFO 内存中。<br>在仅接收模式下，发送的数据无效。在第一次写入发送 FIFO 之后，在传送期间重新发送同一个字。<br>在发送和接收模式下，发送和接收数据均有效。从外部设备接收的数据存储在接收 FIFO 存储器中。<br>0x0 (TX_AND_RX): 发送和接收，不适用于增强型 SPI 操作模式<br>0x1 (TX_ONLY): 仅发送模式，或以增强 SPI 操作模式写入<br>0x2 (RX_ONLY): 仅接收模式，或在增强 SPI 操作模式下读取<br>0x3 (EEPROM_READ): EEPROM 读取模式，不适用于增强 SPI 操作模式 |
| 13:12 |        |     | 保留                                                                                                                                                                                                                                                                                                                                                                                             |
| 14    | SSTEN  | R/W | 使能片选反转 (Chip Select Reversal Enable)<br>当工作在普通 SPI 模式且时钟相位 (SCPH) 为 0，这个寄存器控制数据帧之间的片选信号线。<br>0: 在连续的帧之间片选信号线无反转。<br>1: 在连续的帧之间片选信号线将会发生反转，当片选信号线是高电平时，CLK 信号的电平将是默认值。                                                                                                                                                                                                                          |
| 21:15 |        |     | 保留                                                                                                                                                                                                                                                                                                                                                                                             |
| 23:22 | FRF    | R/W | 帧格式 (Frame Format)<br>选择数据帧格式来发送/接收数据。<br>00 (SPI_STANDARD): 标准 SPI 模式<br>01 (SPI_DUAL): Dual SPI 模式<br>10 (SPI_QUAD): Quad SPI 模式<br>11: 保留                                                                                                                                                                                                                                                   |
| 31:24 |        |     | 保留                                                                                                                                                                                                                                                                                                                                                                                             |

### 23.6.2 控制寄存器 2 (QSPI\_CTRL2)

偏移地址: 0x04

复位值: 0x0000 0000

| 位/域   | 名称  | R/W | 描述                                                                                                                                        |
|-------|-----|-----|-------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0  | NDF | R/W | 数据帧数量 (Data Frame Number)<br>当 TXMODE=10 或者 TXMODE=11 时，此寄存器字段设置 QSPI 连续接收的数据帧数。QSPI 继续接收串行数据，直到接收的数据帧数等于该寄存器值加上 1，这使在连续传输中接收最多 64KB 的数据。 |
| 31:16 |     |     | 保留                                                                                                                                        |

### 23.6.3 使能寄存器 (QSPI\_SSIE)

偏移地址: 0x08

复位值: 0x0000 0000

| 位/域  | 名称 | R/W | 描述                                                                                                            |
|------|----|-----|---------------------------------------------------------------------------------------------------------------|
| 0    | EN | R/W | 使能 QSPI (QSPI Enable)<br>启用或禁用所有 QSPI 操作。当禁用时，所有串行传输都会即刻停止。当设备被禁用，发送和接收 FIFO 缓冲器被清除。启用时，无法对某些 QSPI 控制寄存器进行编程。 |
| 31:1 |    |     | 保留                                                                                                            |

### 23.6.4 从机使能寄存器 (QSPI\_SLAEN)

偏移地址: 0x10

复位值: 0x0000 0000

| 位/域  | 名称    | R/W | 描述                                    |
|------|-------|-----|---------------------------------------|
| 0    | SLAEN | R/W | 使能从机 (Slave Enable)<br>0: 禁用<br>1: 使能 |
| 31:1 |       |     | 保留                                    |

### 23.6.5 波特率寄存器 (QSPI\_BR)

偏移地址: 0x14

复位值: 0x0000 0000

| 位/域   | 名称     | R/W | 描述                                                                                                                                                                                                                                                                                                                                     |
|-------|--------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0  | CLKDIV | R/W | SSI 时钟分频器 (Clock Divider)<br>此字段的 LSB 始终设置为 0，不受写操作的影响，这确保在这个寄存器中保存了一个偶数。如果该值为 0，则串行输出时钟 (sclk_out) 被禁用。<br>sclk_out 输出的频率由以下方程式得出：<br>$F_{sclk\_out} = F_{qspi\_clk} / SCKDIV$<br>SCKDIV 是 2 到 65534 之间的任意一个偶数。<br>例如：<br>在 $F_{qspi\_clk} = 3.6864\text{MHz}$ 和 $SCKDIV = 2$ 时，那么<br>$F_{sclk\_out} = 3.6864 / 2 = 1.8432\text{MHz}$ |
| 31:16 |        |     | 保留                                                                                                                                                                                                                                                                                                                                     |

### 23.6.6 传输 FIFO 阈值电平寄存器 (QSPI\_TFL)

偏移地址: 0x18

复位值: 0x0000 0000

| 位/域 | 名称  | R/W | 描述                                                                                                                                                                                                              |
|-----|-----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0 | TFT | R/W | 发送 FIFO 阈值 (Transmit FIFO Threshold)<br>传输 FIFO 控制器触发中断的条目级别 (或更低) 的控制。<br>FIFO 深度可设置在 8-256 范围内，该寄存器的大小与访问 FIFO 所需的地址位的数量相同。<br>如果试图将此值设置为大于或等于 FIFO 的深度，则此字段将不被写入并停留其当前值。当发送 FIFO 条目数小于或等于该值时，将触发发送 FIFO 空中断。 |

| 位/域   | 名称   | R/W | 描述                                                                                                                                           |
|-------|------|-----|----------------------------------------------------------------------------------------------------------------------------------------------|
| 15:3  |      |     | 保留                                                                                                                                           |
| 18:16 | TFTH | R/W | 传输启动 FIFO 电平 (Transfer Start FIFO Level)<br>用于控制传输 FIFO 中的条目级别，在该级别之上传输将在串行线路上开始。<br>该寄存器可用于确保在串行线路上开始写入操作之前，传输 FIFO 中存在足够的数据。这些字段仅对主操作模式有效。 |
| 31:19 |      |     | 保留                                                                                                                                           |

### 23.6.7 接收 FIFO 阈值电平寄存器 (QSPI\_RFTL)

偏移地址: 0x1C

复位值: 0x0000 0000

| 位/域  | 名称  | R/W | 描述                                                                                                                                                                                                                 |
|------|-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0  | RFT | R/W | 接收 FIFO 阈值 (Receive FIFO Threshold)<br>接收 FIFO 控制器触发中断的条目的级别 (或更高级别) 的控制。<br>FIFO 深度可设置在 8-256 范围内；该寄存器的大小与访问 FIFO 所需的地址位的数量相同。<br>如果试图将此值设置为大于 FIFO 的深度，则此字段将不被写入并停留其当前值。当接收 FIFO 条目数大于或等于该值加 1 时，将触发接收 FIFO 满中断。 |
| 31:3 |     |     | 保留                                                                                                                                                                                                                 |

### 23.6.8 发送 FIFO 电平寄存器 (QSPI\_TFL)

偏移地址: 0x20

复位值: 0x0000 0000

| 位/域  | 名称  | R/W | 描述                                                       |
|------|-----|-----|----------------------------------------------------------|
| 3:0  | TFL | R   | 发送 FIFO 电平 (Transmit FIFO Level)<br>包含发送 FIFO 中的有效数据条目数。 |
| 31:4 |     |     | 保留                                                       |

### 23.6.9 接收 FIFO 电平寄存器 (QSPI\_RFL)

偏移地址: 0x24

复位值: 0x0000 0000

| 位/域  | 名称  | R/W | 描述                                                      |
|------|-----|-----|---------------------------------------------------------|
| 3:0  | RFL | R   | 接收 FIFO 电平 (Receive FIFO Level)<br>包含接收 FIFO 中的有效数据条目数。 |
| 31:4 |     |     | 保留                                                      |

### 23.6.10 状态寄存器 (QSPI\_STS)

偏移地址: 0x28

复位值: 0x0000 0006

| 位/域  | 名称    | R/W | 描述                                                                                                                                                                                    |
|------|-------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | BUSYF | R   | <p>SSI Busy 标志 (SSI Busy Flag)<br/>         设置时, 表示正在进行串行传输; 清除时, 表示 QSPI 空闲或禁用状态。<br/>         1: QSPI 正在活跃地传输数据<br/>         0: QSPI 在闲置或禁用状态</p>                                   |
| 1    | TFNF  | R   | <p>发送 FIFO 未满标志 (Transmit FIFO Not Full Flag)<br/>         当发送 FIFO 包含一个或多个空位置时设置, 当 FIFO 满时清除。<br/>         1: 发送 FIFO 未满<br/>         0: 发送 FIFO 已满</p>                             |
| 2    | TFEF  | R   | <p>发送 FIFO 空标志 (Transmit FIFO Empty Flag)<br/>         当传输 FIFO 完全为空时, 该位被设置。当传输 FIFO 包含一个或多个有效条目时, 该位被清除。该位字段不请求中断。<br/>         1: 传输 FIFO 已空<br/>         0: 传输 FIFO 非空</p>        |
| 3    | RFNEF | R   | <p>接收 FIFO 非空标志 (Receive FIFO Not Empty Flag)<br/>         当接收 FIFO 包含一个或多个条目时设置, 当接收 FIFO 为空时清除。软件可以对该位进行轮询, 以完全清空接收 FIFO。<br/>         1: 接收 FIFO 非空<br/>         0: 接收 FIFO 已空</p> |
| 4    | RFFF  | R   | <p>接收 FIFO 满标志 (Receive FIFO Full Flag)<br/>         当接收 FIFO 完全满时, 该位被设置。当接收 FIFO 包含一个或多个空位置时, 该位被清除。<br/>         1: 接收 FIFO 已满<br/>         0: 接收 FIFO 未满</p>                      |
| 31:5 |       |     | 保留                                                                                                                                                                                    |

### 23.6.11 中断使能寄存器 (QSPI\_INTEN)

偏移地址: 0x2C

复位值: 0x0000 007F

| 位/域 | 名称    | R/W | 描述                                                                                                                                     |
|-----|-------|-----|----------------------------------------------------------------------------------------------------------------------------------------|
| 0   | TFEIE | R/W | <p>传输 FIFO 中断使能 (Transmit FIFO Interrupt Enable)<br/>         0: qspi_txe_intr 中断被屏蔽<br/>         1: qspi_txe_intr 中断使能</p>            |
| 1   | TFOIE | R/W | <p>传输 FIFO 溢出中断使能 (Transmit FIFO Overflow Interrupt Enable)<br/>         0: qspi_txo_intr 中断被屏蔽<br/>         1: qspi_txo_intr 中断使能</p> |
| 2   | RFUIE | R/W | <p>接收 FIFO 下溢中断使能 (Receive FIFO Underflow Interrupt Enable)<br/>         0: qspi_rxu_intr 中断被屏蔽<br/>         1: qspi_rxu_intr 中断使能</p> |
| 3   | RFOIE | R/W | <p>接收 FIFO 溢出中断使能 (Receive FIFO Overflow Interrupt Enable)<br/>         0: qspi_rxo_intr 中断被屏蔽<br/>         1: qspi_rxo_intr 中断使能</p>  |

| 位/域  | 名称    | R/W | 描述                                                                                                    |
|------|-------|-----|-------------------------------------------------------------------------------------------------------|
| 4    | RFFIE | R/W | 接收 FIFO 满中断使能 (Receive FIFO Full Interrupt Enable)<br>0: qspi_rxf_intr 中断被屏蔽<br>1: qspi_rxf_intr 中断使能 |
| 31:5 |       |     | 保留                                                                                                    |

### 23.6.12 中断状态寄存器 (QSPIISTS)

偏移地址: 0x30

复位值: 0x0000 0000

| 位/域  | 名称    | R/W | 描述                                                                                                                |
|------|-------|-----|-------------------------------------------------------------------------------------------------------------------|
| 0    | TFEIF | R   | 发送 FIFO 空中断状态 (Transmit FIFO Empty Interrupt Status)<br>0: qspi_txe_intr 屏蔽后中断未激活<br>1: qspi_txe_intr 屏蔽后中断激活     |
| 1    | TFOIF | R   | 发送 FIFO 溢出中断状态 (Transmit FIFO Overflow Interrupt Status)<br>0: qspi_txo_intr 屏蔽后中断未激活<br>1: qspi_txo_intr 屏蔽后中断激活 |
| 2    | RFUIF | R   | 接收 FIFO 下溢中断状态 (Receive FIFO Underflow Interrupt Status)<br>0: qspi_rxu_intr 屏蔽后中断未激活<br>1: qspi_rxu_intr 屏蔽后中断激活 |
| 3    | RFOIF | R   | 接收 FIFO 溢出中断状态 (Receive FIFO Overflow Interrupt Status)<br>0: qspi_rxo_intr 屏蔽后中断未激活<br>1: qspi_rxo_intr 屏蔽后中断激活  |
| 4    | RFFIF | R   | 接收 FIFO 满中断状态 (Receive FIFO Full Interrupt Status)<br>0: qspi_rxf_intr 屏蔽后中断未激活<br>1: qspi_rxf_intr 屏蔽后中断激活       |
| 31:5 |       |     | 保留                                                                                                                |

### 23.6.13 原始中断状态寄存器 (QSPIRIS)

偏移地址: 0x34

复位值: 0x0000 0000

| 位/域 | 名称    | R/W | 描述                                                                                                                         |
|-----|-------|-----|----------------------------------------------------------------------------------------------------------------------------|
| 0   | TFEIF | R   | 发送 FIFO 空原始中断状态 (Transmit FIFO Empty Raw Interrupt Status)<br>0: qspi_txe_intr 中断在屏蔽之前未激活<br>1: qspi_txe_intr 中断在屏蔽前激活     |
| 1   | TFOIF | R   | 发送 FIFO 溢出原始中断状态 (Transmit FIFO Overflow Raw Interrupt Status)<br>0: qspi_txo_intr 中断在屏蔽之前未激活<br>1: qspi_txo_intr 中断在屏蔽前激活 |
| 2   | RFUIF | R   | 接收 FIFO 下溢原始中断状态 (Receive FIFO Underflow Raw Interrupt Status)<br>0: qspi_rxu_intr 中断在屏蔽之前未激活<br>1: qspi_rxu_intr 中断在屏蔽前激活 |

| 位/域  | 名称    | R/W | 描述                                                                                                                        |
|------|-------|-----|---------------------------------------------------------------------------------------------------------------------------|
| 3    | RXOIR | R   | 接收 FIFO 溢出原始中断状态 (Receive FIFO Overflow Raw Interrupt Status)<br>0: qspi_rxo_intr 中断在屏蔽之前未激活<br>1: qspi_rxo_intr 中断在屏蔽前激活 |
| 4    | RXFIR | R   | 接收 FIFO 满原始中断状态 (Receive FIFO Full Raw Interrupt Status)<br>0: qspi_rxf_intr 屏蔽后中断未激活<br>1: qspi_rxf_intr 屏蔽后中断激活         |
| 31:5 |       |     | 保留                                                                                                                        |

### 23.6.14 发送 FIFO 溢出中断清除寄存器 (QSPI\_TFOIC)

偏移地址: 0x38

复位值: 0x0000 0000

| 位/域  | 名称    | R/W | 描述                                                                                                         |
|------|-------|-----|------------------------------------------------------------------------------------------------------------|
| 0    | TFOIC | R   | 清除发送 FIFO 溢出中断 (Transmit FIFO Overflow Interrupt Clear)<br>反映了中断的状态。<br>从该寄存器读取将清除 qspi_txo_intr 中断, 写入无效。 |
| 31:1 |       |     | 保留                                                                                                         |

### 23.6.15 接收 FIFO 溢出中断清除寄存器 (QSPI\_RFOIC)

偏移地址: 0x3C

复位值: 0x0000 0000

| 位/域  | 名称    | R/W | 描述                                                                                                         |
|------|-------|-----|------------------------------------------------------------------------------------------------------------|
| 0    | RFOIC | R   | 清除接收 FIFO 溢出中断 (Receive FIFO Overflow Interrupt Clear)<br>反映了中断的状态。<br>从该寄存器中读取将清除 qspi_rxo_intr 中断, 写入无效。 |
| 31:1 |       |     | 保留                                                                                                         |

### 23.6.16 接收 FIFO 下溢中断清除寄存器 (QSPI\_RFUIC)

偏移地址: 0x40

复位值: 0x0000 0000

| 位/域  | 名称    | R/W | 描述                                                                                                           |
|------|-------|-----|--------------------------------------------------------------------------------------------------------------|
| 0    | RFUIC | R   | 清除接收 FIFO 下溢中断 (Receive FIFO Underflow Interrupt Clear)<br>反映了中断的状态。<br>从这个寄存器中读取将清除 qspi_rxu_intr 中断, 写入无效。 |
| 31:1 |       |     | 保留                                                                                                           |

### 23.6.17 中断清除寄存器 (QSPI\_ICF)

偏移地址: 0x48

复位值: 0x0000 0000

| 位/域  | 名称  | R/W | 描述                                                                                                                                |
|------|-----|-----|-----------------------------------------------------------------------------------------------------------------------------------|
| 0    | ICF | R   | 清除中断 (Interrupt Clear)<br>如果下面的任何中断处于活动状态，则设置该寄存器被置位。<br>读取会清除 qspi_txo_intr、qspi_rxu_intr、qspi_rxo_intr 和 qspi_mst_intr 中断，写入无效。 |
| 31:1 |     |     | 保留                                                                                                                                |

### 23.6.18 DMA 控制寄存器 (QSPI\_DMACTRL)

偏移地址: 0x4C

复位值: 0x0000 0000

| 位/域  | 名称     | R/W | 描述                                                |
|------|--------|-----|---------------------------------------------------|
| 0    | RDMAEN | R/W | 接收 DMA 使能 (Receive DMA Enable)<br>0: 禁用<br>1: 使能  |
| 1    | TDMAEN | R/W | 发送 DMA 使能 (Transmit DMA Enable)<br>0: 禁用<br>1: 使能 |
| 31:2 |        |     | 保留                                                |

### 23.6.19 DMA 发送数据电平寄存器 (QSPI\_DMATDL)

偏移地址: 0x50

复位值: 0x0000 0000

| 位/域  | 名称     | R/W | 描述                                                                                                           |
|------|--------|-----|--------------------------------------------------------------------------------------------------------------|
| 2:0  | DMATDL | R/W | 发送数据电平线 (Data Level Transmit)<br>当发送 FIFO 内的有效数据等于或低于 DMATDL 配置值时，会产生 DMA 发送数据请求，TDMAEN=1 时有效。<br>配置范围为 0~7。 |
| 31:3 |        |     | 保留                                                                                                           |

### 23.6.20 DMA 接收数据电平寄存器 (QSPI\_DMARDL)

偏移地址: 0x54

复位值: 0x0000 0000

| 位/域  | 名称     | R/W | 描述                                                                                                                     |
|------|--------|-----|------------------------------------------------------------------------------------------------------------------------|
| 2:0  | DMARDL | R/W | 接收数据电平线 (Data Level Receive)<br>当接收 FIFO 内的有效数据等于或高于 DMARDL 配置值+1 时，会产生 DMA 接收数据请求，RDMAEN=1 时，生成 dma_rx_req。配置范围为 0~7。 |
| 31:3 |        |     | 保留                                                                                                                     |

### 23.6.21 数据寄存器 (QSPI\_DATA)

偏移地址: 0x60

复位值: 0x0000 0000

| 位/域  | 名称   | R/W | 描述                                                                                                                   |
|------|------|-----|----------------------------------------------------------------------------------------------------------------------|
| 31:0 | DATA | R/W | <p>数据 (Data)</p> <p>写入此寄存器时, 必须右调整数据, 读取数据会自动右对齐。</p> <p>读取 (Read) = 接收 FIFO 缓冲器</p> <p>写入 (Write) = 发送 FIFO 缓冲器</p> |

### 23.6.22 RX 样本延迟寄存器 (QSPI\_RSD)

偏移地址: 0xF0

复位值: 0x0000 0000

| 位/域   | 名称  | R/W | 描述                                                                                                                                                         |
|-------|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0   | RSD | R/W | <p>接收数据 (RXD) 样本延迟 (Receive Data (RXD) Sampling Delay)</p> <p>用于延迟 RXD 输入端口的采样。</p> <p>每个值表示 RXD 样本上的单个 qspi_clk 延迟。</p>                                   |
| 15:8  |     |     | 保留                                                                                                                                                         |
| 16    | RSE | R/W | <p>接收数据 (RXD) 采样边缘 (Receive Data (RXD) Sampling Edge)</p> <p>用于用 qspi_clk 确定 RXD 信号的采样边缘。</p> <p>将该位设置为 1, 之后将使用 qspi_clk 的下降沿对输入数据进行采样, 否则将使用上升沿进行采样。</p> |
| 31:17 |     |     | 保留                                                                                                                                                         |

### 23.6.23 控制寄存器 3 (QSPI\_CTRL3)

偏移地址: 0xF4

复位值: 0x0000 0200

| 位/域 | 名称  | R/W | 描述                                                                                                                                                                                                                                                                                                      |
|-----|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0 | IAT | R/W | <p>传送格式的地址和指令 (Transmit Format Address and Instruction)</p> <p>选择 QSPI 是在标准 SPI 模式还是在 CTRL0[SPI_FRF] 字段中选择的 SPI 模式下传输指令/地址。</p> <p>00 (TT0): 在标准 SPI 模式下发出指令和地址</p> <p>01 (TT1): 在标准 SPI 模式下发出指令<br/>在 QSPI_CTRL1[SPI_FRF] 规定的模式下发出地址。</p> <p>10 (TT2): 在 SPI_FRF 规定的模式下发出指令和地址</p> <p>11 (TT3): 保留</p> |

| 位/域   | 名称                    | R/W | 描述                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|-----------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5:2   | ADDRLEN               | R/W | <p>传输的地址长度 (Transmitted Address Length)<br/> 只有在这些位被编译到 FIFO 之后, 传输才能开始。</p> <p>0x0 (ADDR_L0): 没有地址<br/> 0x1 (ADDR_L4): 4 位地址长度<br/> 0x2 (ADDR_L8): 8 位地址长度<br/> 0x3 (ADDR_L12): 12 位地址长度<br/> 0x4 (ADDR_L16): 16 位地址长度<br/> 0x5 (ADDR_L20): 20 位地址长度<br/> 0x6 (ADDR_L24): 24 位地址长度<br/> 0x7 (ADDR_L28): 28 位地址长度<br/> 0x8 (ADDR_L32): 32 位地址长度<br/> 0x9 (ADDR_L36): 36 位地址长度<br/> 0xA (ADDR_L40): 40 位地址长度<br/> 0xB (ADDR_L44): 44 位地址长度<br/> 0xC (ADDR_L48): 48 位地址长度<br/> 0xD (ADDR_L52): 52 位地址长度<br/> 0xE (ADDR_L56): 56 位地址长度<br/> 0xF (ADDR_L60): 60 位地址长度</p> |
| 7:6   |                       |     | 保留                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 9:8   | INSLEN                | R/W | <p>四线模式下指令的长度 (Instruction Length in Four-wire Mode)</p> <p>00 (INST_L0): 没有指令<br/> 01 (INST_L4): 4 位指令<br/> 10 (INST_L8): 8 位指令<br/> 11 (INST_L16): 16 位指令</p>                                                                                                                                                                                                                                                                                                                                                                                                       |
| 10    |                       |     | 保留                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 15:11 | WAITCYC               | R/W | <p>等待的时钟个数 (Wait Cycles)<br/> 在四线模式下, 在发送/接受数据之前的需要等待的时钟个数。</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 18:16 |                       |     | 保留                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 19    | XIP_DFS_HC            | R   | <p>XIP 传输数据帧大小 (XIP Transmit Data Frame Size)</p> <p>0: 无效<br/> 1: XIP 传输数据帧大小固定为 QSPI_CTRL1[DFS]中编程的值</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 20    | XIP_INST_EN           | R   | <p>XIP 指令使能位 (XIP Instruction Enable)</p> <p>0: XIP 传输不具有指令阶段<br/> 1: XIP 传输将具有指令阶段</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 21    | SSIC_XIP_CONT_XFER_EN | R   | <p>XIP 模式下启用连续传输 (Enable Continuous Transmission in XIP Mode)</p> <p>0: 未启用 XIP 中的连续传输模式<br/> 1: 启用 XIP 中的连续传输模式, QSPI 将保持从设备选中状态, 直到检测到非 XIP 传输</p>                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 28:22 |                       |     | 保留                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

| 位/域 | 名称              | R/W | 描述                                                                                                                                                 |
|-----|-----------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------|
| 29  | XIP_PREFETCH_EN | R   | XIP 模式下启用预取功能 (Enable Prefetch Function in XIP Mode)<br>0: 未启用 XIP 传输中预取功能<br>1: 启用 XIP 传输中预取功能。QSPI 将从下一个连续位置预取数据帧, 若下一个 XIP 请求不是连续的, 则预取的数据将被丢弃。 |
| 30  | CSEN            | R/W | 使能时钟拉伸 (Clock Stretch Enable)<br>SPI 传输能力。如果写入, FIFO 变成空, QSPI 将延长时钟, 直到 FIFO 有足够的数据继续传输。如果读取, 接收 FIFO 变成满, QSPI 将停止时钟, 直到从 FIFO 读取数据为止。           |
| 31  |                 |     | 保留                                                                                                                                                 |

### 23.6.24 XIP INCR 转移操作码寄存器 (XIP\_INCR\_INST)

偏移地址: 0x100

复位值: 0x0000 0000

| 位/域   | 名称        | R/W | 描述                                                                                                                                                  |
|-------|-----------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0  | INCR_INST | R/W | XIP INCR 转移操作码 (XIP INCR Transfer Operation Code)<br>当 XIP_CTRL[XIP_INST_EN]设为 1 时, QSPI 发送所有 XIP 请求 INCR 类型转移时要发送的指令操作码。指令长度由 XIP_CTRL[INST_L]位确定。 |
| 31:16 |           |     | 保留                                                                                                                                                  |

### 23.6.25 XIP WRAP 转移操作码寄存器 (XIP\_WRAP\_INST)

偏移地址: 0x104

复位值: 0x0000 0000

| 位/域   | 名称        | R/W | 描述                                                                                                                                                  |
|-------|-----------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0  | WRAP_INST | R/W | XIP WRAP 传输操作码 (XIP WRAP Transfer Operation Code)<br>当 XIP_CTRL[XIP_INST_EN]设为 1 时, QSPI 发送所有 XIP 请求 WRAP 类型转移时要发送的指令操作码。指令长度由 XIP_CTRL[INST_L]位确定。 |
| 31:16 |           |     | 保留                                                                                                                                                  |

### 23.6.26 XIP 控制寄存器 (XIP\_CTRL)

偏移地址: 0x108

复位值: 0x0800 0401

| 位/域 | 名称  | R/W | 描述                                                                                                                     |
|-----|-----|-----|------------------------------------------------------------------------------------------------------------------------|
| 1:0 | FRF | R/W | 帧格式 (Frame Format)<br>选择数据帧格式以传输/接收数据。<br>0x0 (RSVD): 保留<br>0x1 (SPI_DUAL): Dual SPI 模式<br>0x2 (SPI_QUAD): Quad SPI 模式 |

| 位/域   | 名称              | R/W | 描述                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|-----------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |                 |     | 0x3: 保留                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 3:2   | TRANS_TY<br>PE  | R/W | <p>地址和指令传输格式 (Transmission Format of Address and Instruction)</p> <p>选择 QSPI 将以标准 SPI 模式还是在 QSPI_CTRL1[FRF]字段中选择的 SPI 模式传输指令/地址。</p> <p>0x0 (TT0): 指令和地址将以标准 SPI 模式发送。</p> <p>0x1 (TT1): 指令将以标准 SPI 模式发送, 地址将以 XIP_CTRL[FRF]指定的模式发送。</p> <p>0x2 (TT2): 指令和地址将以 XIP_CTRL[FRF]指定的模式发送。</p> <p>0x3 (TT3): 保留。</p>                                                                                                                                                                                                                                     |
| 7:4   | ADDR_L          | R/W | <p>地址长度 (Address Length)</p> <p>0x0 (ADDR_L0): 无地址</p> <p>0x1 (ADDR_L4): 4 位地址长度</p> <p>0x2 (ADDR_L8): 8 位地址长度</p> <p>0x3 (ADDR_L12): 12 位地址长度</p> <p>0x4 (ADDR_L16): 16 位地址长度</p> <p>0x5 (ADDR_L20): 20 位地址长度</p> <p>0x6 (ADDR_L24): 24 位地址长度</p> <p>0x7 (ADDR_L28): 28 位地址长度</p> <p>0x8 (ADDR_L32): 32 位地址长度</p> <p>0x9 (ADDR_L36): 36 位地址长度</p> <p>0xA (ADDR_L40): 40 位地址长度</p> <p>0xB (ADDR_L44): 44 位地址长度</p> <p>0xC (ADDR_L48): 48 位地址长度</p> <p>0xD (ADDR_L52): 52 位地址长度</p> <p>0xE (ADDR_L56): 56 位地址长度</p> <p>0xF (ADDR_L60): 60 位地址长度</p> |
| 8     |                 |     | 保留                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 10:9  | INST_L          | R/W | <p>双/四线模式下指令长度 (Instruction Length in Dual/Four-wire Mode)</p> <p>0x0 (INST_L0): 无指令</p> <p>0x1 (INST_L4): 4 位指令长度</p> <p>0x2 (INST_L8): 8 位指令长度</p> <p>0x3 (INST_L16): 16 位指令长度</p>                                                                                                                                                                                                                                                                                                                                                               |
| 12:11 |                 |     | 保留                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 17:13 | WAIT_CYCL<br>ES | R/W | <p>等待的时钟个数 (Wait Cycles)</p> <p>双/四线 XIP 传输模式下, 在发送/接收数据之前需要等待的时钟个数。</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 18    | DFS_HC          | R/W | <p>XIP 传输数据帧大小 (XIP Transmission Data Frame Size)</p> <p>0: 无效</p> <p>1: XIP 传输数据帧大小固定为 QSPI_CTRL1[DFS]中编程的值</p>                                                                                                                                                                                                                                                                                                                                                                                                                                   |

| 位/域   | 名称                  | R/W | 描述                                                                                                                                      |
|-------|---------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------|
|       |                     |     | 注意：在配置 XIP 传输时，该位默认配置为 1。                                                                                                               |
| 21:19 | 保留                  |     |                                                                                                                                         |
| 22    | INST_EN             | R/W | XIP 指令使能位 (XIP Instruction Enable)<br>0: XIP 传输不具有指令阶段<br>1: XIP 传输将具有指令阶段                                                              |
| 23    | CONT_XFE<br>R_EN    | R/W | XIP 模式下启用连续传输 (Enable XIP Mode Continuous Transmission)<br>0: 未启用 XIP 中的连续传输模式<br>1: 启用 XIP 中的连续传输模式，QSPI 将保持从设备选中状态，直到检测到非 XIP 传输      |
| 28:24 | 保留                  |     |                                                                                                                                         |
| 29    | XIP_PREFE<br>TCH_EN | R/W | XIP 模式下启用预取功能 (Enable Prefetch in XIP Mode)<br>0: 未启用 XIP 传输中预取功能<br>1: 启用 XIP 传输中预取功能，QSPI 将从下一个连续位置预取数据帧，若下一个 XIP 请求不是连续的，则预取的数据将被丢弃。 |
| 31:30 | 保留                  |     |                                                                                                                                         |

### 23.6.27 从机使能寄存器 (XIP\_SER)

偏移地址: 0x10C

复位值: 0x0000 0000

| 位/域  | 名称  | R/W | 描述                                                      |
|------|-----|-----|---------------------------------------------------------|
| 0    | SER | R/W | 从机选择使能标志 (Slave Select Enable Flag)<br>0: 未选择<br>1: 已选择 |
| 31:1 | 保留  |     |                                                         |

### 23.6.28 IO 转换寄存器 (QSPI\_SWITCH)

偏移地址: 0x200

复位值: 0x0000 0000

| 位/域  | 名称               | R/W | 描述                                                                                                                                                      |
|------|------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | SWITCH           | R/W | 切换 PC CARD/QSPI 访问外部存储空间 (Switch PC CARD/QSPI to Access External Memory Space)<br>0: PC CARD 可访问 0x90000000~9FFFFFFF<br>1: QSPI 可访问 0x90000000~9FFFFFFF |
| 1    | LITTLE<br>ENDIAN | R/W | 小端使能 (Little Endian)<br>0: 大端读取<br>1: 小端读取                                                                                                              |
| 31:2 | 保留               |     |                                                                                                                                                         |

### 23.6.29 XIP 使能寄存器 (XIP\_EN)

偏移地址: 0x204

复位值: 0x0000 0000

| 位/域  | 名称     | R/W | 描述                                                        |
|------|--------|-----|-----------------------------------------------------------|
| 0    | XIP_EN | R/W | XIP 使能位 (XIP Enable)<br>0: 未启用 XIP 传输模式<br>1: 启动 XIP 传输模式 |
| 31:1 | 保留     |     |                                                           |

## 24 控制器局域网 (CAN)

### 24.1 术语全称、缩写描述

表格 101 术语全称、缩写描述

| 中文全称   | 英文全称                     | 英文缩写 |
|--------|--------------------------|------|
| 控制局域网  | Controller Area Network  | CAN  |
| 先进先出队列 | First Input First Output | FIFO |
| 请求     | Request                  | REQ  |

### 24.2 简介

CAN 是 ISO 国际标准化的串行通信协议，支持 CAN 协议 2.0A 和 2.0B。在 CAN 协议中，发送者以广播形式把报文发送给所有接收者。节点在接收报文时，会经过过滤器组，根据标识符决定是否需要该报文，这种设计节省了 CPU 的开销。

### 24.3 主要特性

- (1) 支持 CAN 协议 2.0A 和 2.0B
- (2) 通信波特率最大为 1Mbit/s
- (3) 发送功能：
  - 有 3 个发送邮箱
  - 发送报文优先级可配置
  - 可记录发送时间
- (4) 接收功能：
  - 有 2 个 3 级深度的接收 FIFO
  - 有 28 个过滤器组
  - 可记录接收时间

### 24.4 功能描述

#### 24.4.1 CAN 物理层特性

CAN 总线上可以有多个通讯节点，每个节点由一个 CAN 的控制器和收发器组成，控制器和收发器之间通过 CAN\_TX 和 CAN\_RX 连接传输逻辑信号，收发器和总线之间通过 CAN\_High 和 CAN\_Low 连接传输差分信号。

## 24.4.2 报文结构

图 97 标准数据帧



图 98 扩展数据帧



注意：

- (1) 帧起始：用来通知各个节点将有数据传输。
- (2) 仲裁段：有多个报文被发送时，用来决定哪个报文能被传输。此段主要内容是 ID 信息，标准格式下 ID 为 11 位，扩展格式下 ID 为 29 位。
- (3) 控制段：此段最主要的是数据长度码（DLC），用来表示报文中的数据段有多少个字节。数据段最多 8 个字节。
- (4) 数据段：包含节点要发送的数据信息。
- (5) CRC 段：CRC 校验码用来确保报文正确传输。
- (6) ACK 段：此段包含 ACK 槽位和 ACK 界定符位，ACK 槽中发送节点发送隐性位，接收节点将在这一位发送显性位表示应答。
- (7) 帧结束：由发送节点发送的 7 个隐性位表示结束。

## 24.4.3 工作模式

CAN 有三个主要的工作模式：初始化模式、正常模式和睡眠模式。

### 24.4.3.1 初始化模式

配置寄存器 CAN\_MCTRL 的 INITREQ 位置 1 请求进入初始化模式，INITFLG 位清 0 确认进入初始化模式。

配置寄存器 CAN\_MCTRL 的 INITREQ 位清 0 请求退出初始化模式，INITFLG 位清 0 确认退出初始化模式。

初始化模式下，禁止报文接收和发送。

### 24.4.3.2 正常模式

通过软件配置寄存器 CAN\_MCTRL 的 INITREQ 位清 0，请求从初始化模式进入

正常模式，等待硬件对 INITFLG 位清 0 确认进入正常模式。

正常模式下，可以正常接收和发送报文。

#### 24.4.3.3 睡眠模式

配置寄存器 CAN\_MCTRL 的 SLEEPREQ 位置 1 请求进入睡眠模式。

睡眠模式下 CAN 的时钟停止工作，软件可以正常访问邮箱寄存器，此时 CAN 处于低功耗状态。

#### 24.4.4 通信模式

有四种通信模式分别是：静默模式、环回模式、静默环回模式和正常模式。只能在初始化模式下选择不同的通信模式。

##### 24.4.4.1 静默模式

配置寄存器 CAN\_BITTIM 的 SILMEN 位置 1，选择静默模式。

该模式下，只能向总线发送隐性位（逻辑 1），不能发送显性位（逻辑 0），可以从总线接收数据。

图 99 CAN 工作在静默模式



##### 24.4.4.2 环回模式

配置寄存器 CAN\_BITTIM 的 LBKMEN 位置 1，选择环回模式。

该模式下，发送的数据直接传到输入端接收，不从总线上接收数据，可以向总线发送所有数据。

图 100 CAN 工作在环回模式



#### 24.4.4.3 环回静默模式

配置寄存器 CAN\_BITTIM 的 LBKMEN 和 SILMEN 位同时置 1，选择环回静默模式。

该模式下，发送的数据直接传到输入端接收，不从总线上接收数据，只能向总线发送隐性位（逻辑 1），不能发送显性位（逻辑 0）。

图 101 CAN 工作在静默环回模式



#### 24.4.4.4 正常模式

该模式下，可以向总线发送数据和接收数据。

图 102 CAN 工作在正常模式



## 24.4.5 数据发送

### 24.4.5.1 发送邮箱状态转换

发送邮箱状态转换过程：

- (1) 先选择空置邮箱进行设置，通过配置寄存器 CAN\_TXMIDx 的 TXMREQ 位置 1 向 CAN 总线控制器提交发送请求，然后邮箱马上进入挂号状态。
- (2) 多个邮箱在挂号状态情况下，进行优先级调度，当邮箱成为最高优先级时，进入预定状态。
- (3) 当发送邮箱中的报文向总线发送时，进入发送状态。
- (4) 报文发送成功后，邮箱重新变成空置状态。

### 24.4.5.2 发送优先级

当有多个报文同时等待发送时，通过配置寄存器 CAN\_MCTRL 的 TXFPCFG 位决定发送顺序：

- 当 TXFPCFG 位置 0 时，优先级由报文标识符决定，标识符最小，优先级最高，标识符相等，则邮箱号小的先被发送。
- 当 TXFPCFG 位置 1 时，优先级由发送请求的顺序来决定。

### 24.4.5.3 中止

通过配置寄存器 CAN\_TXSTS 的 ABREQFLG 位置 1，发送中止请求。

若邮箱处于挂号或预定状态，立马中止发送请求；若邮箱处于发送状态，两种状况：一种是邮箱发送成功，则邮箱变为空置状态，此时，CAN\_TXSTS 寄存器的 TXSUSFLG 位由硬件置 1；另一种是邮箱发送失败，则邮箱变为预定状态，发送请求被中止。

### 24.4.5.4 禁止自动重传

一般在时间触发通信模式下，需要禁止自动重传。

在禁止自动重传模式下，报文只被发送一次，不管发送的结果如何（成功、出错或仲裁丢失），硬件不会再自动发送报文。

当发送过程结束后，CAN\_TXSTS 寄存器的 REQCFLG 位置 1，发送的结果会在 TXSUSFLG、ARBLSTFLG 和 TXERRFLG 位上

## 24.4.6 数据接收

### 24.4.6.1 接收 FIFO

CAN 一共有两个接收 FIFO，每个 FIFO 有三个邮箱，寄存器 CAN\_RXF 的 FMNUM[1:0]位反映当前存放的报文数目；RFOM 位置 1 来释放接收 FIFO 的输出邮箱；FFULLFLG 为满状态标志位；FOVRFLG 为溢出状态标志位。

### 24.4.6.2 接收 FIFO 状态转换

一开始 FIFO 处于空状态，接收到报文后变为挂号状态。

当 FIFO 处于挂号状态但 3 个邮箱已满时，接收下一个有效报文变为溢出状态，

溢出状态的报文丢弃分两种情况：

- 若禁用 FIFO 锁定功能，则最后收到的报文被新报文覆盖。
- 若启用 FIFO 锁定功能，则新收到的报文被丢弃。

#### 24.4.7 过滤机制

过滤器的作用：在接收节点根据报文标识符，决定是否需要此报文，过滤后只接收需要的报文。CAN 控制器有 28 个过滤器组。

##### 24.4.7.1 位宽

每个过滤器组都可以配置两种位宽。

图 103 1 个 32 位过滤器

|    |                    |            |                    |             |                   |               |                  |   |
|----|--------------------|------------|--------------------|-------------|-------------------|---------------|------------------|---|
| ID | CAN_FiBANK1[31:24] |            | CAN_FiBANK1[23:16] |             | CAN_FiBANK1[15:8] |               | CAN_FiBANK1[7:0] |   |
|    | STDID[10:3]        | STDID[2:0] | EXTID[17:13]       | EXTID[12:5] | EXTID[4:0]        | IDTYP<br>ESEL | TXRFR<br>EQ      | 0 |

图 104 2 个 16 位过滤器

|    |                   |                |                  |               |                   |             |                  |              |               |
|----|-------------------|----------------|------------------|---------------|-------------------|-------------|------------------|--------------|---------------|
| ID | CAN_FiBANK1[15:8] |                | CAN_FiBANK1[7:0] |               | CAN_FiBANK2[15:8] |             | CAN_FiBANK2[7:0] |              |               |
|    | STDID[10:3]       | STDID<br>[2:0] | TXRFR<br>REQ     | IDTYP<br>ESEL | EXTID<br>[17:15]  | STDID[12:5] | STDID<br>[2:0]   | TXRFR<br>REQ | IDTYP<br>ESEL |

##### 24.4.7.2 过滤模式

###### 屏蔽位模式

该模式下，只需要把报文标识符的某几位作为列表形成掩码，报文 ID 需要与掩码相同才能被接收。

表格 102 屏蔽位模式举例

|        |   |   |   |   |   |   |   |   |       |
|--------|---|---|---|---|---|---|---|---|-------|
| ID     | 1 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | ..... |
| 掩码     | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | ..... |
| 筛选的 ID | 1 | X | 1 | 1 | 0 | X | X | 0 | ..... |

###### 标识符列表模式

该模式下，报文 ID 的每一位都需要与过滤器标识符相同才能被接收。

表格 103 标识符列表模式举例

|        |   |   |   |   |   |   |   |   |   |
|--------|---|---|---|---|---|---|---|---|---|
| ID     | 1 | 1 | 1 | 0 | 1 | 0 | 0 | 1 | 1 |
| ID     | 1 | 1 | 1 | 0 | 1 | 0 | 0 | 1 | 1 |
| 筛选的 ID | 1 | 1 | 1 | 0 | 1 | 0 | 0 | 1 | 1 |

##### 24.4.7.3 过滤器优先级

优先级规则如下：

- 位宽 32 位过滤器优先级高于位宽 16 位的过滤器
- 在位宽相同情况下，标识符列表模式优先级高于屏蔽位模式
- 位宽和模式都相同情况下，过滤序号小的优先级高

#### 24.4.8 位时序及波特率

##### 24.4.8.1 位时序

APM32 的 CAN 外设位时序中包含三段：同步段（SYNC\_SEG）、时间段 1（BS1）、时间段 2（BS2），采样点位于 BS1 及 BS2 段的交界处。

- 同步段（SYNC\_SEG）：此段占用一个时间单元。
- 时间段 1（BS1）：此段占用 1 到 16 个时间单元，它包含 CAN 标准里的 PROP\_SEG 和 PHASE\_SEG1。
- 时间段 2（BS2）：此段占用 1 到 8 个时间单元，它代表 CAN 标准里的 PHASE\_SEG2。

##### 24.4.8.2 波特率的计算

BS1 段时间： $T_{s1}=T_q * (TIMSEG1[3:0]+1)$

BS2 段时间： $T_{s2}=T_q * (TIMSEG2[2:0]+1)$

一个数据位的时间： $T_{1bit}=T_q+T_{s1}+T_{s2}$

波特率= $1/T_{1bit}$

$T_q = (BRPSC+1) * T_{PCLK}$

#### 24.4.9 出错管理

通过配置寄存器 CAN\_ERRSTS 的 TXERRCNT 位发送错误计数器和寄存器 CAN\_ERRSTS 的 RXERRCNT 位接收错误计数器来反映 CAN 总线的错误管理。

通过配置寄存器 CAN\_INTEN 的 ERRIEN 位来控制错误状态下产生中断。

##### 24.4.9.1 离线恢复

当 CAN 错误状态寄存器的 TXERRCNT 大于 255 时，CAN 总线控制器就进入离线状态，此时寄存器 CAN\_ERRSTS 的 BOFLG 位置 1，该状态下 CAN 总线控制器不能接收和发送报文。

通过配置寄存器 CAN\_MCTRL 的 ALBOFFM 位来决定离线恢复方式：

- 若 ALBOFFM 位置 1，一旦硬件检测到 128 次 11 位连续的隐性位，则自动退出离线状态。
- 若 ALBOFFM 位置 0，软件请求进入再退出初始化模式后，退出离线状态。

#### 24.4.10 中断

产生发送中断的事件：

- 硬件将寄存器 CAN\_TXSTS 的 REQCFLG0 位置 1, 发送邮箱 0 变为空置状态
- 硬件将寄存器 CAN\_TXSTS 的 REQCFLG1 位置 1, 发送邮箱 1 变为空置状态
- 硬件将寄存器 CAN\_TXSTS 的 REQCFLG2 位置 1, 发送邮箱 2 变为空置状态

**产生 FIFO0 中断的事件:**

- 硬件将寄存器 CAN\_RXF0 的 FMNUM0[1:0]位为非 0 时, FIFO0 接收到一个新的报文
- 硬件将寄存器 CAN\_RXF0 的 FFULLFLG0 位置 1, FIFO0 满
- 硬件将寄存器 CAN\_RXF0 的 FOVRFLG0 位置 1, FIFO0 溢出

**产生 FIFO1 中断的事件:**

- 硬件将寄存器 CAN\_RXF1 的 FMNUM1[1:0]位为非 0 时, FIFO1 接收到一个新的报文
- 硬件将寄存器 CAN\_RXF1 的 FFULLFLG1 位置 1, FIFO1 满
- 硬件将寄存器 CAN\_RXF1 的 FOVRFLG1 位置 1, FIFO1 溢出

**产生状态改变和错误中断的事件:**

- 硬件将寄存器 CAN\_INTEN 的 SLEEPEN 位置 1, 进入睡眠模式
- 硬件将寄存器 CAN\_INTEN 的 WUPIEN 位置 1, 唤醒中断使能
- 硬件将寄存器 CAN\_ERRSTS 的 ERRWFLG 位置 1, 表示出错次数已达到阈值
- 硬件将寄存器 CAN\_ERRSTS 的 ERRPFLG 位置 1, 表示出错次数达到被动错误的阈值
- 硬件将寄存器 CAN\_ERRSTS 的 LERRC[2:0]位, 表明上次出错的情况

图 105 事件标志和中断产生



## 24.5 寄存器地址映射

CAN1 基地址: 0x4000\_6400

CAN2 基地址: 0x4000\_6800

注意: CAN1 和 CAN2 除基地址外, 寄存器及偏移地址完全相同。

表格 104 CAN 寄存器地址映射

| 寄存器名        | 描述                 | 偏移地址                |
|-------------|--------------------|---------------------|
| CAN_MCTRL   | CAN 主控制寄存器         | 0x00                |
| CAN_MSTS    | CAN 主状态寄存器         | 0x04                |
| CAN_TXSTS   | CAN 发送状态寄存器        | 0x08                |
| CAN_RXF0    | CAN 接收 FIFO 0 寄存器  | 0x0C                |
| CAN_RXF1    | CAN 接收 FIFO 1 寄存器  | 0x10                |
| CAN_INTEN   | CAN 中断使能寄存器        | 0x14                |
| CAN_ERRSTS  | CAN 错误状态寄存器        | 0x18                |
| CAN_BITTIM  | CAN 位时序寄存器         | 0x1C                |
| CAN_TXMIDx  | 发送邮箱标识符寄存器         | 0x180, 0x190, 0x1A0 |
| CAN_TXDLENx | 发送邮箱数据长度寄存器        | 0x184, 0x194, 0x1A4 |
| CAN_TXMDLx  | 发送邮箱低字节数据寄存器       | 0x188, 0x198, 0x1A8 |
| CAN_TXMDHx  | 发送邮箱高字节数据寄存器       | 0x18C, 0x19C, 0x1AC |
| CAN_RXMIDx  | 接收 FIFO 邮箱标识符寄存器   | 0x1B0, 0x1C0        |
| CAN_RXDLENx | 接收 FIFO 邮箱数据长度寄存器  | 0x1B4, 0x1C4        |
| CAN_RXMDLx  | 接收 FIFO 邮箱低字节数据寄存器 | 0x1B8, 0x1C8        |
| CAN_RXMDHx  | 接收 FIFO 邮箱高字节数据寄存器 | 0x1BC, 0x1CC        |
| CAN_FCTRL   | CAN 过滤器控制寄存器       | 0x200               |
| CAN_FMCFG   | CAN 过滤器模式寄存器       | 0x204               |
| CAN_FSCFG   | CAN 过滤器位宽配置寄存器     | 0x20C               |
| CAN_FFASS   | CAN 过滤器 FIFO 关联寄存器 | 0x214               |
| CAN_FACT    | CAN 过滤器激活寄存器       | 0x21C               |
| CAN_FIBANKx | CAN 过滤器组 i 的寄存器 x  | 0x240...0x31C       |

## 24.6 寄存器功能描述

### 24.6.1 CAN 控制和状态寄存器

#### 24.6.1.1 CAN 主控制寄存器 (CAN\_MCTRL)

偏移地址: 0x00

复位值: 0x0001 0002

| 位/域 | 名称       | R/W | 描述                                                                                         |
|-----|----------|-----|--------------------------------------------------------------------------------------------|
| 0   | INITREQ  | R/W | 请求进入初始化模式 (Request to Enter Initialization Mode)<br>0: 从初始化模式进入正常工作模式<br>1: 从正常工作模式进入初始化模式 |
| 1   | SLEEPREQ | R/W | 请求进入睡眠模式 (Request to Enter Sleep Mode)                                                     |

| 位/域   | 名称      | R/W | 描述                                                                                                                                                                                                                  |
|-------|---------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |         |     | <p>0: 退出睡眠模式<br/>1: 请求进入睡眠模式<br/>若 AWUPCFG 位置 1, 当 RX 信号检测到 CAN 报文时, 该位由硬件清零; 复位后该位置 1, 复位后处于睡眠模式。</p>                                                                                                              |
| 2     | TXFPCFG | R/W | <p>配置发送 FIFO 优先级 (Transmit FIFO Priority Configure)<br/>该位用来决定在多个报文同时等待发送时, 由哪些参数决定发送优先级。<br/>0: 由报文的标识符来决定<br/>1: 由发送请求的顺序来决定</p>                                                                                  |
| 3     | RXFLOCK | R/W | <p>配置接收 FIFO 锁定模式 (Receive FIFO Locked Mode Configure)<br/>该位用来决定接收溢出时 FIFO 是否被锁定, 且当接收 FIFO 的报文未被读出时, 下一个收到的报文如何处理。<br/>0: 未被锁定, 当接收 FIFO 的报文未被读出, 下一个收到的报文会覆盖原有的报文<br/>1: 被锁定, 当接收 FIFO 的报文未被读出, 下一个收到的报文会被丢弃</p> |
| 4     | ARTXMD  | R/W | <p>禁止自动重传报文 (Automatic Retransmission Message Disable)<br/>0: 使能自动重传, 报文将一直自动重传直到发送成功<br/>1: 禁止自动重传, 报文只被发送一次</p>                                                                                                   |
| 5     | AWUPCFG | R/W | <p>配置自动唤醒模式 (Automatic Wakeup Mode Configure)<br/>0: 软件唤醒睡眠模式, 通过清除 CAN_MCTRL 寄存器的 SLEEPREQ 位唤醒<br/>1: 硬件唤醒睡眠模式, 通过检测 CAN 报文唤醒</p>                                                                                  |
| 6     | ALBOFFM | R/W | <p>自动退出离线状态条件管理 (Automatic Leaving Bus-Off Status Condition Management)<br/>0: 软件对 CAN_MCTRL 寄存器的 INITREQ 位进行置 1 随后清 0 后, 当硬件检测到 128 次 11 位连续的隐性位, 则退出离线状态<br/>1: 当硬件检测到 128 次 11 位连续的隐性位, 则自动退出离线状态</p>            |
| 14:7  |         |     | 保留                                                                                                                                                                                                                  |
| 15    | SWRST   | R/S | <p>软件复位 CAN (Software Reset CAN)<br/>0: 正常工作<br/>1: CAN 被强行复位, 复位后 CAN 进入睡眠模式, 硬件自动对该位清 0</p>                                                                                                                       |
| 16    | DBGFRZE | R/W | <p>冻结调试 (Debug Freeze)<br/>0: 无效<br/>1: 调试时, CAN 的接收/发送无法工作, 但仍可以正常读写和控制接收 FIFO</p>                                                                                                                                 |
| 31:17 |         |     | 保留                                                                                                                                                                                                                  |

#### 24.6.1.2 CAN 主状态寄存器 CAN\_MSTS)

偏移地址: 0x04

复位值: 0x0000 0C02

| 位/域 | 名称      | R/W | 描述                                                                                                                                |
|-----|---------|-----|-----------------------------------------------------------------------------------------------------------------------------------|
| 0   | INITFLG | R   | <p>正处于初始化模式标志 (Being Initialization Mode Flag)<br/>该位由硬件置 1 和清 0。<br/>0: 退出初始化模式<br/>1: 处于初始化模式, 该位是对 CAN_MCTRL 寄存器初始化请求位的确认。</p> |

| 位/域   | 名称        | R/W   | 描述                                                                                                                                 |
|-------|-----------|-------|------------------------------------------------------------------------------------------------------------------------------------|
| 1     | SLEEPFLG  | R     | 正处于睡眠模式标志 (Being Sleep Mode Flag)<br>该位由硬件置 1 和清 0<br>0: 退出睡眠模式<br>1: 处于睡眠模式, 该位是对 CAN_MCTRL 寄存器睡眠模式请求位的确认。                        |
| 2     | ERRIFLG   | RC_W1 | 发生错误中断标志 (Error Interrupt Occur Flag)<br>该位由硬件置 1, 软件写 1 清 0。<br>0: 未发生<br>1: 发生                                                   |
| 3     | WUPIFLG   | RC_W1 | 发生唤醒中断标志 (Wakeup Interrupt Occur Flag)<br>当进入睡眠模式且检测到 SOF 唤醒时, 该位由硬件置 1; 软件写 1 清 0。<br>0: 未从睡眠模式唤醒<br>1: 从睡眠模式唤醒                   |
| 4     | SLEEPIFLG | RC_W1 | 已进入睡眠模式中断标志 (Being Sleep Mode Interrupt Flag)<br>当进入睡眠模式时, 该位由硬件置 1, 触发相应的中断; 退出睡眠模式是由硬件清 0, 软件写 1 清 0。<br>0: 未进入睡眠模式<br>1: 进入睡眠模式 |
| 7:5   |           |       | 保留                                                                                                                                 |
| 8     | TXMFLG    | R     | 正处于发送模式标志 (Being Transmit Mode Flag)<br>0: CAN 不处于发送模式<br>1: CAN 处于发送模式                                                            |
| 9     | RXMFLG    | R     | 正处于接收模式标志 (Being Receive Mode Flag)<br>0: CAN 不处于接收模式<br>1: CAN 处于接收模式                                                             |
| 10    | LSAMVALUE | R     | CAN 接收引脚上次采样值 (CAN Rx Pin Last Sample Value)                                                                                       |
| 11    | RXSIGL    | R     | CAN 接收引脚信号电平 (CAN Rx Pin Signal Level)                                                                                             |
| 31:12 |           |       | 保留                                                                                                                                 |

#### 24.6.1.3 CAN 发送状态寄存器 CAN\_TXSTS)

偏移地址: 0x08

复位值: 0x1C00 0000

| 位/域 | 名称        | R/W   | 描述                                                                                                                                  |
|-----|-----------|-------|-------------------------------------------------------------------------------------------------------------------------------------|
| 0   | REQCFLG0  | RC_W1 | 邮箱 0 请求完成标志 (Mailbox 0 Request Completed Flag)<br>当邮箱 0 的上次请求发送或中止完成时, 该位由硬件置 1; 当收到发送请求时, 由硬件清 0; 软件写 1 清 0。<br>0: 正在发送<br>1: 已完发送 |
| 1   | TXSUSFLG0 | RC_W1 | 邮箱 0 发送成功标志 (Mailbox 0 Transmission Success Flag)<br>当邮箱 0 发送尝试成功后, 由硬件置 1; 软件写 1 清 0。<br>0: 上次发送尝试失败<br>1: 上次发送尝试成功                |

| 位/域   | 名称         | R/W   | 描述                                                                                                                                  |
|-------|------------|-------|-------------------------------------------------------------------------------------------------------------------------------------|
| 2     | ARBLSTFLG0 | RC_W1 | 邮箱 0 仲裁丢失标志 (Mailbox 0 Arbitration Lost Flag)<br>当邮箱 0 仲裁丢失时由硬件置 1; 软件写 1 清 0。<br>0: 无意义<br>1: 丢失                                   |
| 3     | TXERRFLG0  | RC_W1 | 邮箱 0 发送失败标志 (Mailbox 0 Transmission Error Flag)<br>当邮箱 0 发送失败时, 由硬件置 1; 软件写 1 清 0。<br>0: 无意义<br>1: 发送失败                             |
| 6:4   | 保留         |       |                                                                                                                                     |
| 7     | ABREQFLG0  | R/S   | 邮箱 0 放弃请求标志 (Mailbox 0 Abort Request Flag)<br>若邮箱 0 中没有等待发送的报文, 则该位无效。<br>0: 邮箱 0 的发送报文被清除, 由硬件清 0<br>1: 置 1 中止邮箱 0 的发送请求           |
| 8     | REQCFLG1   | RC_W1 | 邮箱 1 请求完成标志 (Mailbox 1 Request Completed Flag)<br>当邮箱 1 的上次请求发送或中止完成时, 该位由硬件置 1; 当收到发送请求时, 由硬件清 0; 软件写 1 清 0。<br>0: 正在发送<br>1: 已完发送 |
| 9     | TXSUSFLG1  | RC_W1 | 邮箱 1 发送成功标志 (Mailbox 1 Transmission Success Flag)<br>当邮箱 1 发送尝试成功后, 由硬件置 1; 软件写 1 清 0。<br>0: 上次发送尝试失败<br>1: 上次发送尝试成功                |
| 10    | ARBLSTFLG1 | RC_W1 | 邮箱 1 仲裁丢失标志 (Mailbox 1 Arbitration Lost Flag)<br>当邮箱 1 仲裁丢失时由硬件置 1; 软件写 1 清 0。<br>0: 无意义<br>1: 丢失                                   |
| 11    | TXERRFLG1  | RC_W1 | 邮箱 1 发送失败标志 (Mailbox 1 Transmission Error Flag)<br>当邮箱 1 发送失败时, 由硬件置 1; 软件写 1 清 0。<br>0: 无意义<br>1: 发送失败                             |
| 14:12 | 保留         |       |                                                                                                                                     |
| 15    | ABREQFLG1  | R/S   | 邮箱 1 放弃请求标志 (Mailbox 1 Abort Request Flag)<br>若邮箱 1 中没有等待发送的报文, 则该位无效。<br>0: 邮箱 1 的发送报文被清除, 由硬件清 0<br>1: 置 1 中止邮箱 1 的发送请求           |
| 16    | REQCFLG2   | RC_W1 | 邮箱 2 请求完成标志 (Mailbox 2 Request Completed Flag)<br>当邮箱 2 的上次请求发送或中止完成时, 该位由硬件置 1; 当收到发送请求时, 由硬件清 0; 软件写 1 清 0。<br>0: 正在发送<br>1: 已完发送 |
| 17    | TXSUSFLG2  | RC_W1 | 邮箱 2 发送成功标志 (Mailbox 2 Transmission Success Flag)<br>当邮箱 2 发送尝试成功后, 由硬件置 1; 软件写 1 清 0。<br>0: 上次发送尝试失败<br>1: 上次发送尝试成功                |

| 位/域   | 名称         | R/W   | 描述                                                                                                                                                    |
|-------|------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 18    | ARBLSTFLG2 | RC_W1 | 邮箱 2 仲裁丢失标志 (Mailbox 2 Arbitration Lost Flag)<br>当邮箱 2 仲裁丢失时由硬件置 1; 软件写 1 清 0。<br>0: 无意义<br>1: 丢失                                                     |
| 19    | TXERRFLG2  | RC_W1 | 邮箱 2 发送失败标志 (Mailbox 2 Transmission Error Flag)<br>当邮箱 2 发送失败时, 由硬件置 1; 软件写 1 清 0。<br>0: 无意义<br>1: 发送失败                                               |
| 22:20 | 保留         |       |                                                                                                                                                       |
| 23    | ABREQFLG2  | R/S   | 邮箱 2 放弃请求标志 (Mailbox 2 Abort Request Flag)<br>若邮箱 2 中没有等待发送的报文, 则该位无效。<br>0: 邮箱 2 的发送报文被清除, 由硬件清 0<br>1: 置 1 中止邮箱 2 的发送请求                             |
| 25:24 | EMNUM[1:0] | R     | 空邮箱编号 (Empty Mailbox Number)<br>该位适用于存在空邮箱的情况。当所有的发送邮箱全空时, 表示优先级最低的发送邮箱编号; 当邮箱非空但不是全空时, 表示下一个要发送的邮箱编号。                                                |
| 26    | TXMEFLG0   | R     | 发送邮箱 0 为空标志 (Transmit Mailbox 0 Empty Flag)<br>发送邮箱 0 为空时, 该位由硬件置 1。<br>0: 邮箱 0 中有待发送的报文<br>1: 邮箱 0 中没有待发送的报文                                         |
| 27    | TXMEFLG1   | R     | 发送邮箱 1 空标志 (Transmit Mailbox 1 Empty Flag)<br>发送邮箱 1 为空时, 该位由硬件置 1。<br>0: 邮箱 1 中有待发送的报文<br>1: 邮箱 1 中没有待发送的报文                                          |
| 28    | TXMEFLG2   | R     | 发送邮箱 2 空标志 (Transmit Mailbox 2 Empty Flag)<br>发送邮箱 2 为空时, 该位由硬件置 1。<br>0: 邮箱 2 中有待发送的报文<br>1: 邮箱 2 中没有待发送的报文                                          |
| 29    | LOWESTP0   | R     | 邮箱 0 的发送优先级最低标志 (the Lowest Transmission Priority Flag For Mailbox 0)<br>0: 无意义<br>1: 邮箱 0 的优先级在等待发送报文的邮箱中最低<br>注意: 若只有 1 个邮箱在等待, 则 LOWESTP[2:0]被清 0。 |
| 30    | LOWESTP1   | R     | 邮箱 1 的发送优先级最低标志 (the Lowest Transmission Priority Flag For Mailbox 1)<br>0: 无意义<br>1: 邮箱 1 的优先级在等待发送报文的邮箱中最低                                          |
| 31    | LOWESTP2   | R     | 邮箱 2 的发送优先级最低标志 (the Lowest Transmission Priority Flag For Mailbox 2)<br>0: 无意义<br>1: 邮箱 2 的优先级在等待发送报文的邮箱中最低                                          |

#### 24.6.1.4 CAN 接收 FIFO 0 寄存器 (CAN\_RXF0)

偏移地址: 0x0C

复位值: 0x0000 0000

| 位/域  | 名称          | R/W   | 描述                                                                                                                                                                                             |
|------|-------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0  | FMNUM0[1:0] | R     | 接收 FIFO0 中的报文数目 (the Number of Message in Receive FIFO0)<br>这些位用来反映当前接收 FIFO0 中存放的报文数目。每新接收到 1 个报文, FMNUM0 位加 1; 每释放输出邮箱的报文, FMNUM0 位减 1。                                                      |
| 2    | 保留          |       |                                                                                                                                                                                                |
| 3    | FFULLFLG0   | RC_W1 | 接收 FIFO0 满标志 (Receive FIFO0 Full Flag)<br>当 FIFO0 中有 3 个报文时, 表明 FIFO0 已满; 该位由硬件置 1, 软件写 1 清 0。<br>0: 未满<br>1: 已满                                                                               |
| 4    | FOVRFLG0    | RC_W1 | 接收 FIFO0 溢出标志 (Receive FIFO0 Overrun Flag)<br>当 FIFO0 中有 3 个报文时, 此时又收到新报文, 表明 FIFO0 溢出; 该位由硬件置 1, 软件写 1 清 0。<br>0: 未产生溢出<br>1: 产生溢出                                                            |
| 5    | RFOM0       | R/S   | 释放接收 FIFO0 输出邮箱以接收报文 (Release Receive FIFO0 Output Mailbox to Receive Message)<br>该位由硬件置 1, 软件清 0。若 FIFO 中无报文, 则无效。当 FIFO 中有 2 个以上的报文时, 想要访问第 2 个报文必须先释放输出邮箱。<br>0: 无意义<br>1: 释放接收 FIFO0 的输出邮箱 |
| 31:6 | 保留          |       |                                                                                                                                                                                                |

#### 24.6.1.5 CAN 接收 FIFO 1 寄存器 (CAN\_RXF1)

偏移地址: 0x10

复位值: 0x0000 0000

| 位/域 | 名称          | R/W   | 描述                                                                                                                                        |
|-----|-------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0 | FMNUM1[1:0] | R     | 接收 FIFO1 中的报文数目 (the Number of Message in Receive FIFO1)<br>这些位用来反映当前接收 FIFO1 中存放的报文数目。每新接收到 1 个报文, FMNUM1 位加 1; 每释放输出邮箱的报文, FMNUM1 位减 1。 |
| 2   | 保留          |       |                                                                                                                                           |
| 3   | FFULLFLG1   | RC_W1 | 接收 FIFO1 满标志 (Receive FIFO1 Full Flag)<br>当 FIFO1 中有 3 个报文时, 表明 FIFO1 已满; 该位由硬件置 1, 软件写 1 清 0。<br>0: 未满<br>1: 已满                          |
| 4   | FOVRFLG1    | RC_W1 | 接收 FIFO1 溢出标志 (Receive FIFO1 Overrun Flag)<br>当 FIFO1 中有 3 个报文时, 此时又收到新报文, 表明 FIFO1 溢出; 该位由硬件置 1, 软件写 1 清 0。<br>0: 未产生溢出<br>1: 产生溢出       |
| 5   | RFOM1       | R/S   | 释放接收 FIFO1 输出邮箱以接收报文 (Release Receive FIFO1 Output Mailbox to Receive Message)                                                            |

| 位/域  | 名称 | R/W | 描述                                                                                                           |
|------|----|-----|--------------------------------------------------------------------------------------------------------------|
|      |    |     | 该位由硬件置 1, 软件清 0。若 FIFO 中无报文, 则无效。当 FIFO 中有 2 个以上的报文时, 想要访问第 2 个报文必须先释放输出邮箱。<br>0: 无意义<br>1: 释放接收 FIFO1 的输出邮箱 |
| 31:6 | 保留 |     |                                                                                                              |

#### 24.6.1.6 CAN 中断使能寄存器 (CAN\_INTEN)

偏移地址: 0x14

复位值: 0x0000 0000

| 位/域 | 名称        | R/W | 描述                                                                                                                                                                              |
|-----|-----------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | TXMEIEN   | R/W | 使能发送邮箱为空中断 (Transmit Mailbox Empty Interrupt Enable)<br>当 REQCFLGx 位置 1 时, 表明已完成发送, 发送邮箱为空, 若该位置 1 则产生中断。<br>0: 不产生中断<br>1: 产生中断                                                |
| 1   | FMIEN0    | R/W | 使能 FIFO0 中报文数量为非 0 时产生中断 (Interrupt Enable When The Number Of FIFO0 Message Is Not 0)<br>当 FIFO0 的 FMNUM0[1:0] 位为非 0 时, 表明 FIFO0 的报文数量非 0, 若该位置 1 则产生中断。<br>0: 不产生中断<br>1: 产生中断 |
| 2   | FFULLIEN0 | R/W | 使能 FIFO0 满中断 (FIFO0 Full Interrupt Enable)<br>当 FIFO0 的 FFULLFLG0 位置 1 时, 表明 FIFO0 的报文已满, 若该位置 1 则产生中断。<br>0: 不产生中断<br>1: 产生中断                                                  |
| 3   | FOVRIEN0  | R/W | 使能 FIFO0 过载中断 (FIFO0 Overrun Interrupt Enable)<br>当 FIFO0 的 FOVRFLG0 位置 1 时, 表明已 FIFO0 已过载, 若该位置 1 则产生中断。<br>0: 不产生中断<br>1: 产生中断                                                |
| 4   | FMIEN1    | R/W | 使能 FIFO1 中报文数量为非 0 时产生中断 (Interrupt Enable When the Number of FIFO1 Message is not 0)<br>当 FIFO1 的 FMNUM1[1:0] 位为非 0 时, 表明 FIFO1 的报文数量非 0, 若该位置 1 则产生中断。<br>0: 不产生中断<br>1: 产生中断 |
| 5   | FFULLIEN1 | R/W | 使能 FIFO1 满中断 (FIFO1 Full Interrupt Enable)<br>当 FIFO1 的 FFULLFLG1 位置 1 时, 表明 FIFO1 的报文已满, 若该位置 1 则产生中断。<br>0: 不产生中断<br>1: 产生中断                                                  |

| 位/域   | 名称        | R/W | 描述                                                                                                                                                       |
|-------|-----------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6     | FOVRIEN1  | R/W | 使能 FIFO 1 过载中断 (FIFO1 Overrun Interrupt Enable)<br>当 FIFO1 的 FOVRFLG1 位置 1 时, 表明已 FIFO1 已过载, 若该位置 1 则产生中断。<br>0: 不产生中断<br>1: 产生中断                        |
| 7     | 保留        |     |                                                                                                                                                          |
| 8     | ERRWIEN   | R/W | 使能错误警告中断 (Error Warning Interrupt Enable)<br>当 ERRWFLG 位置 1 时, 出现错误警告; 若该位置 1, 则设置 ERRIFLG, 产生警告错误中断。<br>0: 不设置 ERRIFLG 位<br>1: ERRIFLG 位置 1             |
| 9     | ERRPIEN   | R/W | 使能被动错误中断 (Error Passive Interrupt Enable)<br>当 ERRPFLG 位置 1 时, 出现被动错误; 若该位置 1, 则设置 ERRIFLG, 产生被动错误中断。<br>0: 不设置 ERRIFLG 位<br>1: ERRIFLG 位置 1             |
| 10    | BOFFIEN   | R/W | 使能离线中断 (Bus-Off Interrupt Enable)<br>当 BOFFFLG 位置 1 时, 出现离线; 若该位置 1, 则设置 ERRIFLG, 产生离线中断。<br>0: 不设置 ERRIFLG 位<br>1: ERRIFLG 位置 1                         |
| 11    | LECIEN    | R/W | 使能上次错误号中断 (Last Error Code Interrupt Enable)<br>当将测到错误、硬件设置 LERRC[2:0], 记录上次错误代码, 如果该位置 1, 则设置 ERRIFLG, 产生上次错误中断。<br>0: 不设置 ERRIFLG 位<br>1: ERRIFLG 位置 1 |
| 14:12 | 保留        |     |                                                                                                                                                          |
| 15    | ERRIEN    | R/W | 使能错误中断 (Error Interrupt Enable)<br>当对应的错误状态寄存器置 1 时, 若该位置 1, 则产生错误中断。<br>0: 不产生中断<br>1: 产生中断                                                             |
| 16    | WUPIEN    | R/W | 使能唤醒中断 (Wakeup Interrupt Enable)<br>当 WUPINT 位置 1 时, 若该位置 1, 则产生唤醒中断。<br>0: 不产生中断<br>1: 产生中断                                                             |
| 17    | SLEEPPIEN | R/W | 使能睡眠中断 (Sleep Interrupt Enable)<br>当 SLEEPIFLG 位置 1 时, 若该位置 1, 则产生睡眠中断。<br>0: 不产生中断<br>1: 产生中断                                                           |
| 31:18 | 保留        |     |                                                                                                                                                          |

#### 24.6.1.7 CAN 错误状态寄存器 (CAN\_ERRSTS)

偏移地址: 0x18

复位值: 0x0000 0000

| 位/域   | 名称       | R/W | 描述                                                                                                                                                                                                              |
|-------|----------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | ERRWFGL  | R   | 出现错误警告标志 (Error Warning Occur Flag)<br>当接收错误计数器或发送错误计数器的值 $\geq 96$ 时, 该位由硬件置 1。<br>0: 未出现错误警告<br>1: 出现错误警告                                                                                                     |
| 1     | ERRPFLG  | R   | 出现被动错误标志 (Error Passive Occur Flag)<br>当接收错误计数器或发送错误计数器的值 $>127$ 时, 该位由硬件置 1。<br>0: 未出现被动错误<br>1: 出现被动错误                                                                                                        |
| 2     | BOFLG    | R   | 进入离线标志 (Enter Bus-Off Flag)<br>当发送错误计数器 TXERRCNT 的值 $>255$ 时, CAN 进入离线状态, 该位由硬件置 1。<br>0: CAN 未进入离线状态<br>1: CAN 进入离线状态                                                                                          |
| 3     |          |     | 保留                                                                                                                                                                                                              |
| 6:4   | LERRC    | R/W | 记录上次错误代码 (Record Last Error Code)<br>当检测到 CAN 总线上的错误时, 依据错误类别由硬件设置; 当正确发送或接收报文时, 由硬件清 0。<br>000: 没有错误<br>001: 位填充错<br>010: 格式 (Form) 错<br>011: 确认 (ACK) 错<br>100: 隐性位错<br>101: 显性位错<br>110: CRC 错<br>111: 由软件设置 |
| 15:7  |          |     | 保留                                                                                                                                                                                                              |
| 23:16 | TXERRCNT | R   | 9 位发送错误计数器的低 8 位 (Least Significant Byte of the 9-Bit Transmit Error Counter)<br>此计数器依据 CAN 协议的故障界定机制的发送部分实现。                                                                                                   |
| 31:24 | RXERRCNT | R   | 接收错误计数器 (Receive Error Counter)<br>接收错误计数器是依据 CAN 协议的故障界定机制的接收部分实现, 当出现接收错误时, 根据出错的条件, 计数器加 1 或加 8, 接收成功后减 1, 当计数器的值 $>127$ , 设置计数器值为 120。                                                                      |

#### 24.6.1.8 CAN 位时序寄存器 (CAN\_BITTIM)

偏移地址: 0x1C

复位值: 0x0123 0000

| 位/域   | 名称      | R/W | 描述                                                                                       |
|-------|---------|-----|------------------------------------------------------------------------------------------|
| 9:0   | BRPSC   | R/W | 配置波特率预分频器系数 (Baud Rate Prescaler Factor Setup)<br>时间单元 $t_q = (BRPSC+1) \times t_{PCLK}$ |
| 15:10 |         |     | 保留                                                                                       |
| 19:16 | TIMSEG1 | R/W | 设置时间段 1 (Time Segment1 Setup)<br>时间段 1 占用的时间 $t_{BS1} = t_{CAN} \times (TIMSEG1+1)$ 。    |

| 位/域   | 名称      | R/W | 描述                                                                                                   |
|-------|---------|-----|------------------------------------------------------------------------------------------------------|
| 22:20 | TIMSEG2 | R/W | 设置时间段 2 (Time Segment2 Setup)<br>时间段 2 占用的时间 $t_{BS2} = t_{CAN} x (TIMSEG2+1)$ 。                     |
| 23    |         |     | 保留                                                                                                   |
| 25:24 | RSYNJW  | R/W | 重新同步跳跃宽度 (Resynchronization Jump Width)<br>CAN 硬件在每位中可以延长或缩短多少的时间 $t_{RJW} = t_{CAN} x (RSYNJW+1)$ 。 |
| 29:26 |         |     | 保留                                                                                                   |
| 30    | LBKMEN  | R/W | 使能环回模式 (Loop Back Mode Enable)<br>0: 禁用<br>1: 使能                                                     |
| 31    | SILMEN  | R/W | 使能静默模式 (Silent Mode Enable)<br>0: 正常状态<br>1: 静默模式                                                    |

注意: 当 CAN 处于初始化模式时, 该寄存器只能由软件访问。

## 24.6.2 CAN 邮箱寄存器

本节描述发送和接收邮箱寄存器。

除了下述例外, 发送和接收邮箱几乎一样:

- CAN\_RXDLEN $x$  寄存器的 FMIDX 域;
- 接收邮箱是只读的;
- 发送邮箱只有在它为空时才是可写的, CAN\_TXSTS 寄存器的相应 TXMEFLG 位为 1, 表示发送邮箱为空。

共有 3 个发送邮箱和 2 个接收邮箱。每个接收邮箱为 3 级深度的 FIFO, 并且只能访问 FIFO 中最先收到的报文。

### 24.6.2.1 发送邮箱标识符寄存器 (CAN\_TXMID $x$ ) ( $x=0...2$ )

偏移地址: 0x180, 0x190, 0x1A0

复位值: 0xFFFF XXXX, X=未定义位 (除了第 0 位, 复位时 TXMREQ=0)

| 位/域   | 名称                       | R/W | 描述                                                                                                                              |
|-------|--------------------------|-----|---------------------------------------------------------------------------------------------------------------------------------|
| 0     | TXMREQ                   | R/W | 请求发送邮箱数据 (Transmit Mailbox Data Request)<br>0: 邮箱中的数据发送完成时, 邮箱为空, 该位由硬件清 0<br>1: 软件写 1, 使能请求发送邮箱数据                              |
| 1     | TXRFREQ                  | R/W | 请求发送远程帧 (Transmit Remote Frame Request)<br>0: 数据帧<br>1: 远程帧                                                                     |
| 2     | IDTYPESEL                | R/W | 选择标识符类型 (Identifier Type Select)<br>0: 标准标识符<br>1: 扩展标识符                                                                        |
| 20:3  | EXTID[17:0]              | R/W | 设置扩展标识符 (Extended Identifier Setup)<br>扩展身份标识的低字节。                                                                              |
| 31:21 | STDID[10:0]/EXTID[28:18] | R/W | 标准标识符或扩展标识符 (Standard Identifier Or Extended Identifier)<br>根据 IDTYPESEL 位的内容, 这些位是标准标识符 STDID[10:0], 还是扩展标识符的高字节 EXTID[28:18]。 |

注意：

(1) 当其所属的邮箱处在等待发送的状态时，该寄存器是写保护的。

(2) 该寄存器实现了发送请求控制功能（第 0 位）—复位值为 0。

#### 24.6.2.2 发送邮箱数据长度寄存器 (CAN\_TXDLEN $x$ ) ( $x=0\ldots2$ )

偏移地址: 0x184, 0x194, 0x1A4

复位值: 0xXXXX XXXX

当邮箱不在空置状态时，该寄存器的所有位为写保护。

| 位/域  | 名称     | R/W | 描述                                          |
|------|--------|-----|---------------------------------------------|
| 3:0  | DLCODE | R/W | 设置发送数据长度码 (Transmit Data Length Code Setup) |
| 31:4 |        |     | 保留                                          |

#### 24.6.2.3 发送邮箱低字节数据寄存器 (CAN\_TXMDL $x$ ) ( $x=0\ldots2$ )

偏移地址: 0x188, 0x198, 0x1A8

复位值: 0xXXXX XXXX

当邮箱不在空置状态时，该寄存器的所有位为写保护，报文包含 0 到 7 个字节数据，且从字节 0 开始。

| 位/域   | 名称        | R/W | 描述                                    |
|-------|-----------|-----|---------------------------------------|
| 7:0   | DATABYTE0 | R/W | 报文数据字节 0 (Data Byte 0 of the Message) |
| 15:8  | DATABYTE1 | R/W | 报文数据字节 1 (Data Byte 1 of the Message) |
| 23:16 | DATABYTE2 | R/W | 报文数据字节 2 (Data Byte 2 of the Message) |
| 31:24 | DATABYTE3 | R/W | 报文数据字节 3 (Data Byte 3 of the Message) |

#### 24.6.2.4 发送邮箱高字节数据寄存器 (CAN\_TXMDH $x$ ) ( $x=0\ldots2$ )

偏移地址: 0x18C, 0x19C, 0x1AC

复位值: 0xXXXX XXXX, X=未定义位

当邮箱不在空置状态时，该寄存器的所有位为写保护。

| 位/域   | 名称        | R/W | 描述                                     |
|-------|-----------|-----|----------------------------------------|
| 7:0   | DATABYTE4 | R/W | 报文数据字节 4 (Data Byte 4 of the Message)。 |
| 15:8  | DATABYTE5 | R/W | 报文数据字节 5 (Data Byte 5 of the Message)  |
| 23:16 | DATABYTE6 | R/W | 报文数据字节 6 (Data Byte 6 of the Message)  |
| 31:24 | DATABYTE7 | R/W | 报文数据字节 7 (Data Byte 7 of the Message)  |

#### 24.6.2.5 接收 FIFO 邮箱标识符寄存器 (CAN\_RXMID $x$ ) ( $x=0\ldots1$ )

偏移地址: 0x1B0, 0x1C0

复位值: 0xXXXX XXXX, X=未定义位

| 位/域 | 名称 | R/W | 描述 |
|-----|----|-----|----|
| 0   |    |     | 保留 |

| 位/域   | 名称                       | R/W | 描述                                                                                                                              |
|-------|--------------------------|-----|---------------------------------------------------------------------------------------------------------------------------------|
| 1     | RFTXREQ                  | R   | 发送请求远程帧 (Remote Frame Transmission Request)<br>0: 数据帧<br>1: 远程帧                                                                 |
| 2     | IDTYPESEL                | R   | 选择标识符类型 (Identifier Type Select)<br>0: 标准标识符<br>1: 扩展标识符                                                                        |
| 20:3  | EXTID[17:0]              | R   | 设置扩展标识符 (Extended Identifier Setup)<br>扩展标识符的低字节。                                                                               |
| 31:21 | STDID[10:0]/EXTID[28:18] | R   | 标准标识符或扩展标识符 (Standard Identifier Or Extended Identifier)<br>根据 IDTYPESEL 位的内容, 这些位是标准标识符 STDID[10:0], 还是扩展标识符的高字节 EXTID[28:18]。 |

注意: 所有接收邮箱寄存器都是只读的。

#### 24.6.2.6 接收 FIFO 邮箱数据长度寄存器 (CAN\_RXDLENx) (x=0...1)

偏移地址: 0x1B4, 0x1C4

复位值: 0xXXXXXX XXXX

| 位/域   | 名称     | R/W | 描述                                                                             |
|-------|--------|-----|--------------------------------------------------------------------------------|
| 3:0   | DLCODE | R   | 设置接收数据长度码 (Receive Data Length Code Setup)<br>该位表示帧内的数据长度; 对于远程帧, DLCODE 恒为 0。 |
| 7:4   |        |     | 保留                                                                             |
| 15:8  | FMIDX  | R   | 设置过滤器匹配序号 (Filter Match Index Setup)                                           |
| 31:16 |        |     | 保留                                                                             |

注意: 所有接收邮箱寄存器都是只读的。

#### 24.6.2.7 接收 FIFO 邮箱低字节数据寄存器 (CAN\_RXMDLx) (x=0...1)

偏移地址: 0x1B8, 0x1C8, 报文包含 0 到 8 个字节数据, 且从字节 0 开始。

复位值: 0xXXXXXX XXXX

| 位/域   | 名称        | R/W | 描述                                    |
|-------|-----------|-----|---------------------------------------|
| 7:0   | DATABYTE0 | R   | 报文数据字节 0 (Data Byte 0 of the Message) |
| 15:8  | DATABYTE1 | R   | 报文数据字节 1 (Data Byte 0 of the Message) |
| 23:16 | DATABYTE2 | R   | 报文数据字节 2 (Data Byte 0 of the Message) |
| 31:24 | DATABYTE3 | R   | 报文数据字节 3 (Data Byte 0 of the Message) |

注意: 所有接收邮箱寄存器都是只读的。

#### 24.6.2.8 接收 FIFO 邮箱高字节数据寄存器 (CAN\_RXMDHx) (x=0...1)

偏移地址: 0x1BC, 0x1CC

复位值: 0xXXXXXX XXXX, X=未定义位

| 位/域  | 名称        | R/W | 描述                                    |
|------|-----------|-----|---------------------------------------|
| 7:0  | DATABYTE4 | R   | 报文数据字节 4 (Data Byte 0 of the Message) |
| 15:8 | DATABYTE5 | R   | 报文数据字节 5 (Data Byte 0 of the Message) |

| 位/域   | 名称        | R/W | 描述                                    |
|-------|-----------|-----|---------------------------------------|
| 23:16 | DATABYTE6 | R   | 报文数据字节 6 (Data Byte 0 of the Message) |
| 31:24 | DATABYTE7 | R   | 报文数据字节 7 (Data Byte 0 of the Message) |

注意：所有接收邮箱寄存器都是只读的。

### 24.6.3 CAN 过滤器寄存器

#### 24.6.3.1 CAN 过滤器控制寄存器 (CAN\_FCTRL)

偏移地址: 0x200

复位值: 0x2A1C 0E01

| 位/域   | 名称      | R/W | 描述                                                                                                                                    |
|-------|---------|-----|---------------------------------------------------------------------------------------------------------------------------------------|
| 0     | FINITEN | R/W | 使能过滤器初始化模式 (Filter Init Mode Enable)<br>0: 正常模式<br>1: 初始化模式                                                                           |
| 7:1   | 保留      |     |                                                                                                                                       |
| 13:8  | CAN2SB  | R/W | CAN2 起始存储区 (CAN2 Start Bank)<br>该位用来定义 CAN2 的起始存储区, 范围: 0-27<br>注意: 当 CAN2SB=28d 时, CAN1 的所有过滤器都可以使用; 当 CAN2SB=0 时, CAN2 的所有过滤器都可以使用。 |
| 31:14 | 保留      |     |                                                                                                                                       |

注意：该寄存器的非保留位完全由软件控制。

#### 24.6.3.2 CAN 过滤器模式配置寄存器 (CAN\_FMCFG)

偏移地址: 0x204

复位值: 0x0000 0000

| 位/域   | 名称     | R/W | 描述                                                                             |
|-------|--------|-----|--------------------------------------------------------------------------------|
| 27:0  | FMCFGx | R/W | 配置过滤器 x 模式 (Filter Mode Configure)<br>x 取值为 0-27。<br>0: 标识符屏蔽位模式<br>1: 标识符列表模式 |
| 31:28 | 保留     |     |                                                                                |

注意：只有在设置 CAN\_FCTRL (FINITEN=1), 使过滤器处于初始化模式下, 才能对该寄存器写入。

#### 24.6.3.3 CAN 过滤器位宽配置寄存器 (CAN\_FSCFG)

偏移地址: 0x20C

复位值: 0x0000 0000

| 位/域   | 名称     | R/W | 描述                                                                               |
|-------|--------|-----|----------------------------------------------------------------------------------|
| 27:0  | FSCFGx | R/W | 配置过滤器 x 位宽 (Filterx Scale Configure)<br>x 取值为 0-27。<br>0: 2 个 16 位<br>1: 单个 32 位 |
| 31:28 | 保留     |     |                                                                                  |

注意：只有在设置 CAN\_FCTRL (FINITEN=1), 使过滤器处于初始化模式下, 才能对该寄存器写入。

#### 24.6.3.4 CAN 过滤器 FIFO 关联寄存器 (CAN\_FFASS)

偏移地址: 0x214

复位值: 0x0000 0000

| 位/域 | 名称      | R/W | 描述                                                                                                 |
|-----|---------|-----|----------------------------------------------------------------------------------------------------|
| 0   | FFASS0  | R/W | 配置过滤器 0 与 FIFO 关联 (Configure Filter0 Associated with FIFO)<br>0: 过滤器与 FIFO0 关联<br>1: 过滤器与 FIFO1 关联 |
| 1   | FFASS1  | R/W | 配置过滤器 1 与 FIFO 关联 (Configure Filter1 Associated with FIFO)<br>具体描述参考 FFASS0。                       |
| 2   | FFASS2  | R/W | 配置过滤器 2 与 FIFO 关联 (Configure Filter2 Associated with FIFO)<br>具体描述参考 FFASS0。                       |
| 3   | FFASS3  | R/W | 配置过滤器 3 与 FIFO 关联 (Configure Filter3 Associated with FIFO)<br>具体描述参考 FFASS0。                       |
| 4   | FFASS4  | R/W | 配置过滤器 4 与 FIFO 关联 (Configure Filter4 Associated with FIFO)<br>具体描述参考 FFASS0。                       |
| 5   | FFASS5  | R/W | 配置过滤器 5 与 FIFO 关联 (Configure Filter5 Associated with FIFO)<br>具体描述参考 FFASS0。                       |
| 6   | FFASS6  | R/W | 配置过滤器 6 与 FIFO 关联 (Configure Filter6 Associated with FIFO)<br>具体描述参考 FFASS0。                       |
| 7   | FFASS7  | R/W | 配置过滤器 7 与 FIFO 关联 (Configure Filter7 Associated with FIFO)<br>具体描述参考 FFASS0。                       |
| 8   | FFASS8  | R/W | 配置过滤器 8 与 FIFO 关联 (Configure Filter8 Associated with FIFO)<br>具体描述参考 FFASS0。                       |
| 9   | FFASS9  | R/W | 配置过滤器 9 与 FIFO 关联 (Configure Filter9 Associated with FIFO)<br>具体描述参考 FFASS0。                       |
| 10  | FFASS10 | R/W | 配置过滤器 10 与 FIFO 关联 (Configure Filter10 Associated with FIFO)<br>具体描述参考 FFASS0。                     |
| 11  | FFASS11 | R/W | 配置过滤器 11 与 FIFO 关联 (Configure Filter11 Associated with FIFO)<br>具体描述参考 FFASS0。                     |
| 12  | FFASS12 | R/W | 配置过滤器 12 与 FIFO 关联 (Configure Filter12 Associated with FIFO)<br>具体描述参考 FFASS0。                     |
| 13  | FFASS13 | R/W | 配置过滤器 13 与 FIFO 关联 (Configure Filter13 Associated with FIFO)<br>具体描述参考 FFASS0。                     |
| 14  | FFASS14 | R/W | 配置过滤器 14 与 FIFO 关联 (Configure Filter14 Associated with FIFO)<br>具体描述参考 FFASS0。                     |
| 15  | FFASS15 | R/W | 配置过滤器 15 与 FIFO 关联 (Configure Filter15 Associated with FIFO)<br>具体描述参考 FFASS0。                     |
| 16  | FFASS16 | R/W | 配置过滤器 16 与 FIFO 关联 (Configure Filter16 Associated with FIFO)<br>具体描述参考 FFASS0。                     |
| 17  | FFASS17 | R/W | 配置过滤器 17 与 FIFO 关联 (Configure Filter17 Associated with FIFO)<br>具体描述参考 FFASS0。                     |
| 18  | FFASS18 | R/W | 配置过滤器 18 与 FIFO 关联 (Configure Filter18 Associated with FIFO)<br>具体描述参考 FFASS0。                     |
| 19  | FFASS19 | R/W | 配置过滤器 19 与 FIFO 关联 (Configure Filter19 Associated with FIFO)<br>具体描述参考 FFASS0。                     |

| 位/域   | 名称      | R/W | 描述                                                                             |
|-------|---------|-----|--------------------------------------------------------------------------------|
| 20    | FFASS20 | R/W | 配置过滤器 20 与 FIFO 关联 (Configure Filter20 Associated with FIFO)<br>具体描述参考 FFASS0。 |
| 21    | FFASS21 | R/W | 配置过滤器 21 与 FIFO 关联 (Configure Filter21 Associated with FIFO)<br>具体描述参考 FFASS0。 |
| 22    | FFASS22 | R/W | 配置过滤器 22 与 FIFO 关联 (Configure Filter22 Associated with FIFO)<br>具体描述参考 FFASS0。 |
| 23    | FFASS23 | R/W | 配置过滤器 23 与 FIFO 关联 (Configure Filter23 Associated with FIFO)<br>具体描述参考 FFASS0。 |
| 24    | FFASS24 | R/W | 配置过滤器 24 与 FIFO 关联 (Configure Filter24 Associated with FIFO)<br>具体描述参考 FFASS0。 |
| 25    | FFASS25 | R/W | 配置过滤器 25 与 FIFO 关联 (Configure Filter25 Associated with FIFO)<br>具体描述参考 FFASS0。 |
| 26    | FFASS26 | R/W | 配置过滤器 26 与 FIFO 关联 (Configure Filter26 Associated with FIFO)<br>具体描述参考 FFASS0。 |
| 27    | FFASS27 | R/W | 配置过滤器 27 与 FIFO 关联 (Configure Filter27 Associated with FIFO)<br>具体描述参考 FFASS0。 |
| 31:28 |         |     | 保留                                                                             |

注意：只有在设置 CAN\_FCTRL (FINITEN=1)，使过滤器处于初始化模式下，才能对该寄存器写入。

#### 24.6.3.5 CAN 过滤器激活寄存器 (CAN\_FACT)

偏移地址: 0x21C

复位值: 0x0000 0000

| 位/域 | 名称    | R/W | 描述                                         |
|-----|-------|-----|--------------------------------------------|
| 0   | FACT0 | R/W | 激活过滤器 0 (Filter0 Active)<br>0: 禁用<br>1: 激活 |
| 1   | FACT1 | R/W | 激活过滤器 1 (Filter1 Active)<br>具体描述参考 FACT0。  |
| 2   | FACT2 | R/W | 激活过滤器 2 (Filter2 Active)<br>具体描述参考 FACT0。  |
| 3   | FACT3 | R/W | 激活过滤器 3 (Filter3 Active)<br>具体描述参考 FACT0。  |
| 4   | FACT4 | R/W | 激活过滤器 4 (Filter4 Active)<br>具体描述参考 FACT0。  |
| 5   | FACT5 | R/W | 激活过滤器 5 (Filter5 Active)<br>具体描述参考 FACT0。  |
| 6   | FACT6 | R/W | 激活过滤器 6 (Filter6 Active)<br>具体描述参考 FACT0。  |
| 7   | FACT7 | R/W | 激活过滤器 7 (Filter7 Active)<br>具体描述参考 FACT0。  |
| 8   | FACT8 | R/W | 激活过滤器 8 (Filter8 Active)<br>具体描述参考 FACT0。  |

| 位/域   | 名称     | R/W | 描述                                          |
|-------|--------|-----|---------------------------------------------|
| 9     | FACT9  | R/W | 激活过滤器 9 (Filter9 Active)<br>具体描述参考 FACT0。   |
| 10    | FACT10 | R/W | 激活过滤器 10 (Filter10 Active)<br>具体描述参考 FACT0。 |
| 11    | FACT11 | R/W | 激活过滤器 11 (Filter11 Active)<br>具体描述参考 FACT0。 |
| 12    | FACT12 | R/W | 激活过滤器 12 (Filter12 Active)<br>具体描述参考 FACT0。 |
| 13    | FACT13 | R/W | 激活过滤器 13 (Filter13 Active)<br>具体描述参考 FACT0。 |
| 14    | FACT14 | R/W | 激活过滤器 14 (Filter14 Active)<br>具体描述参考 FACT0。 |
| 15    | FACT15 | R/W | 激活过滤器 15 (Filter15 Active)<br>具体描述参考 FACT0。 |
| 16    | FACT16 | R/W | 激活过滤器 16 (Filter16 Active)<br>具体描述参考 FACT0。 |
| 17    | FACT17 | R/W | 激活过滤器 17 (Filter17 Active)<br>具体描述参考 FACT0。 |
| 18    | FACT18 | R/W | 激活过滤器 18 (Filter18 Active)<br>具体描述参考 FACT0。 |
| 19    | FACT19 | R/W | 激活过滤器 19 (Filter19 Active)<br>具体描述参考 FACT0。 |
| 20    | FACT20 | R/W | 激活过滤器 20 (Filter20 Active)<br>具体描述参考 FACT0。 |
| 21    | FACT21 | R/W | 激活过滤器 21 (Filter21 Active)<br>具体描述参考 FACT0。 |
| 22    | FACT22 | R/W | 激活过滤器 22 (Filter22 Active)<br>具体描述参考 FACT0。 |
| 23    | FACT23 | R/W | 激活过滤器 23 (Filter23 Active)<br>具体描述参考 FACT0。 |
| 24    | FACT24 | R/W | 激活过滤器 24 (Filter24 Active)<br>具体描述参考 FACT0。 |
| 25    | FACT25 | R/W | 激活过滤器 25 (Filter25 Active)<br>具体描述参考 FACT0。 |
| 26    | FACT26 | R/W | 激活过滤器 26 (Filter26 Active)<br>具体描述参考 FACT0。 |
| 27    | FACT27 | R/W | 激活过滤器 27 (Filter27 Active)<br>具体描述参考 FACT0。 |
| 31:28 |        |     | 保留                                          |

#### 24.6.3.6 CAN 过滤器组 i 的寄存器 x (CAN\_FiBANKx) (i=0...27; x=1...2)

偏移地址: 0x240...0x31C

CAN\_F0BANK1 偏移地址: 0x240 CAN\_F0BANK2 偏移地址: 0x244

CAN\_F1BANK1 偏移地址: 0x248 CAN\_F1BANK2 偏移地址: 0x24C

依此类推得到后面的偏移地址

复位值: 0xXXXX XXXX

| 位/域  | 名称         | R/W | 描述                                                                                                                                                                                                                                                                                      |
|------|------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | FBIT[31:0] | R/W | <p>设置过滤器位 (Filter Bits Setup)</p> <p>标识符列表模式:</p> <ul style="list-style-type: none"> <li>0: FBITx 为显性位</li> <li>1: FBITx 位为隐性位</li> </ul> <p>标识符屏蔽位模式:</p> <ul style="list-style-type: none"> <li>0: FBITx 不用于比较</li> <li>1: FBITx 必须匹配</li> </ul> <p>注意: x 取值为 0~31, 表示 FBIT 的位编号。</p> |

注意: 在产品中共有 28 组过滤器: i=0...27。每组过滤器由 2 个 32 位的寄存器, CAN\_FiBANK[2:1]组成。只有在 CAN\_FACT 寄存器相应的 FACTx 位清 0, 或 CAN\_FCTRL 寄存器的 FINITEN 位为 1 时, 才能修改相应的过滤器寄存器。

## 25 安全数字输入输出接口 (SDIO)

### 25.1 术语全称、缩写描述

表格 105 术语全称、缩写描述

| 中文全称   | 英文全称                       | 英文缩写 |
|--------|----------------------------|------|
| 先入先出队列 | First Input First Output   | FIFO |
| 命令状态机  | Command Path State Machine | CPSM |
| 数据状态机  | Data Path State Machine    | DPSM |

### 25.2 简介

安全数字输入/输出接口能够连接 SD 卡, SD I/O 卡, 多媒体卡 (MMC) 和 CE-ATA 卡主机接口, 提供 APB2 系统总线与 SD 存储卡、SD I/O 卡、MMC 和 CE-ATA 设备之间的数据传输。

### 25.3 主要特征

- (1) SD 卡: 与 SD 存储卡规格版本 2.0 全兼容。
- (2) SD I/O 卡: 与 SD I/O 卡规格版本 2.0 全兼容: 支持两种不同的总线模式: 1 位 (默认) 和 4 位。
- (3) MMC: 与多媒体卡系统规格书 4.2 及之前版本全兼容。有三种不同的数据总线模式: 1 位 (默认) 、4 位和 8 位。
- (4) CE-ATA: 与 CE-ATA 数字协议版本 1.1 全兼容。
- (5) 8 位总线模式下数据传输速率达 48MHz。
- (6) 中断和 DMA 请求。
- (7) 数据和命令输出使能信号, 用于控制外部双向驱动器。

注意: 当前版本的 SDIO 在同一时间里只支持一个 SD/SD IO/MMC 4.2 卡, 但可支持多个 MMC4.1 或以前版本的卡。

### 25.4 功能描述

SDIO 结构主要有两部分:

SDIO 适配器: 实现 MMC/SD/SD I/O 卡的相关功能, 由控制单元、数据单元、命令单元组成。控制单元管理时钟信号, 数据单元管理数据传输, 命令单元管理命令传输。

APB2 总线接口: 操作 SDIO 适配器中的寄存器, 用于数据传输的 FIFO 单元, 产生中断和 DMA 请求信号。

图 106 SDIO 结构框图



表格 106 SDIO 引脚定义

| 引脚          | 方向 | 说明                           |
|-------------|----|------------------------------|
| SDIO_CK     | 输出 | MMC/SD/SD I/O 卡时钟, 从主机到卡的时钟线 |
| SDIO_CMD    | 双向 | MMC/SD/SD I/O 卡命令, 双向命令信号    |
| SDIO_D[7:0] | 双向 | MMC/SD/SD I/O 卡数据, 双向数据总线    |

#### 25.4.1 SDIO 总线拓扑

上电复位后, 主机必须通过特殊的基于消息的总线协议初始化设备。

每个消息有以下部分中的一个来表示:

- 命令: 命令是启动一个操作的令牌, 主机到卡, 命令串行传输到 CMD 线上。
- 响应: 从卡到主机, 作为先前收到命令的应答, 响应串行传输在 CMD 上。
- 数据: 可以从主机到卡或者从卡到主机。通过数据线传送。用于数据传输的数据线数目可以是 1 (D0)、4 (D0-D3)、8 (D0-D7)。

在多媒体卡/SD/SD I/O 总线上的基本操作是命令/响应结构。

在 SD/SD I/O 存储器卡上传送的数据时以数据块的形式传输; 在 MMC 上传送的数据时以数据块或数据流的形式传输; 在 CE-ATA 设备上传送的数据也是以数据块的形式传输。

图 107 SDIO “无响应”和“无数据”操作



图 108 SDIO (多) 数据块读操作



图 109 SDIO (多) 数据块写操作



图 110 SDIO 数据流读操作



图 111 SDIO 数据流写操作



#### 25.4.2 SDIO 适配器

SDIO 产生的信号有以下几种：

- **SDIO\_CLK:** SDIO 控制器提供给卡的时钟。每个时钟周期在命令线 (SDIO\_CMD) 和所有的数据线 (SDIO\_D) 上直接发送一位命令或数据。对于 MMC 卡 V3.31 版本, SDIO\_CLK 频率在 0-20MHz, 对于 MMC 卡 V4.2 版本在 0-48MHz 之间, 对于 SD 或 SD I/O 卡在 0-25MHz 之间。
- **SDIO\_CMD:** 该信号是双向命令通道, 用于卡的初始化和命令传输。命令从 SDIO 控制器到卡, 响应从卡发送到主机。CMD 信号有两种操作模式: 初始化的开漏模式 (用于 MMC 卡 V3.31 及以前版本) 和命令发送的推挽模式 (SD、SD I/O、MMC 卡 4.2 版本初始化也是推挽模式)。
- **SDIO\_D[7:0]:** 信号线均为双向数据通道, 处于推挽模式。默认情况下, 上电或复位后, 只有 D0 用于数据传输, SDIO 适配器可配置更宽的数据总线用于数据传输, 使用 D0-D3、D0-D7 (仅使用于 MMC V4.2)。

#### 控制单元

控制单元包括电源管理和时钟管理功能。

## 命令单元

命令单元实现向卡发送命令与接收卡发送的命令，数据传输由命令状态机（CPSM）控制。

## 命令状态机





## 数据单元

数据单元实现主机与卡之间的数据传输。当数据宽度为 8 位, 数据传输使用 **SDIO\_D[7:0]** 信号线。当数据宽度为 4 位, 数据传输使用 **SDIO\_D[3:0]** 信号线。当数据宽度为 1 位, 数据传输使用 **SDIO\_D[0]** 信号线。

数据传输流由数据状态机 (DPSM) 控制。

## 数据状态机



| DS_Send 发送数据到卡  |           |
|-----------------|-----------|
| 1. 数据已发送        | → DS_Busy |
| 2. DPSM被关闭      | → DS_Idle |
| 3. 数据FIFO下溢错误发送 | → DS_Idle |
| 4. 内部CRC错误      | → DS_Idle |

| DS_Busy 等待CRC状态标志 |           |
|-------------------|-----------|
| 1. 数据已发送          | → DS_Busy |
| 2. DPSM被关闭        | → DS_Idle |
| 3. 数据FIFO下溢错误发送   | → DS_Idle |
| 4. 内部CRC错误        | → DS_Idle |

| DS_WaitR 等待接收数据的起始位 |              |
|---------------------|--------------|
| 1. 数据接收结束           | → DS_Idle    |
| 2. DPSM被关闭          | → DS_Idle    |
| 3. 数据超时             | → DS_Idle    |
| 4. 在超时前收到起始位        | → DS_Receive |

| DS_Receive 接收卡的数据并将其写入数据FIFO |               |
|------------------------------|---------------|
| 1. 数据块已接收                    | → DS_WaitR    |
| 2. 数据传输结束                    | → DS_WaitR    |
| 3. 数据FIFO下溢发送                | → DS_Idle     |
| 4. 数据已经接收并且读等待开始并使能SDI/O模式   | → DS_Readwait |
| 5. DPSM被关闭或CRC错误             | → DS_Idle     |

| DS_Readwait 等待“读等待停止”指令 |            |
|-------------------------|------------|
| 1. “读等待停止”使能            | → DS_WaitR |
| 2. DPSM被关闭              | → DS_Idle  |

### 25.4.3 APB2 接口

APB2 接口实现了访问 SDIO 寄存器、数据 FIFO 和生成中断和 DMA 请求。它包括数据 FIFO 单元、寄存器单元和中断/DMA 请求控制逻辑。

#### SDIO 中断

当至少一个已经被选中的状态标志为高时，中断逻辑产生中断请求。中断使能允许寄存器允许中断逻辑产生相应中断。

## 数据 FIFO

数据 FIFO 单元有一个数据缓冲区，用于接收与发送 FIFO。FIFO 包括一个每个字的宽度为 32 位，深度为 32 字的数据缓冲区。发送 FIFO 被用在当需要写数据到卡上，待传输的数据通过 APB2 总线写入发送 FIFO，SDIO 适配器中的数据单元从发送 FIFO 读取数据，再发送到卡。接收 FIFO 用于从卡读取数据时，从卡读取数据，然后将待传数据写入接收 FIFO。

## 寄存器单元

寄存器单元包括所有的系统寄存器，生成信号用于控制卡与控制器之间的通信。

### 25.4.4 卡功能说明

#### 25.4.4.1 卡寄存器

卡内部定义了接口寄存器：OCR、CID、CSD、EXT\_CSD、RCA、DSR、SCR。这些寄存器只能通过相应命令访问。OCR、CID、CSD 和 SCR 寄存器包括卡的特定信息，RCA 和 DSR 寄存器时配置寄存器，存储实际的配置参数。EXT\_CSD 寄存器同时包括卡的特定信息和实际的结构参数。

**OCR 寄存器：**32 位操作条件寄存器存储卡的 V<sub>DD</sub> 电压描述和存储模式指示 (MMC)。另外，该寄存器包括一个状态信息位。如果卡上电过程已经完成该状态位置位。该寄存器在 MMC 和 SD 卡之间有点不同。主机可以使用 CMD1 (MMC)，ACMD41 (SD 存储卡)，CMD5 (SD I/O) 来获取该寄存器的内容。

**CID 寄存器：**卡识别寄存器 (CID) 是 128 位宽。它包含在卡识别阶段使用的卡识别信息。每个读/写 (RW) 卡应具有唯一的标识号。

**CSD 寄存器：**卡特定数据寄存器提供访问卡中的内容信息。CSD 定义数据格式、错误校正类型、最大数据访问时间、数据传输速度等。

**扩展 CSD 寄存器：**只有 MMC4.2 有该寄存器。扩展 CSD 寄存器定义卡属性和选择模式。它的长度为 512 字节。最高 320 字节为属性段，定义了卡的功能，并且不能由主机修改。最低 192 字节是模式段，定义了卡工作在哪种配置下。

**RCA 寄存器：**可写的 16 位相对卡地址寄存器存放卡地址，该地址在卡的初始化期间由卡向外发布。这个地址用于卡识别过程之后，所寻址的主机和卡通信。

**DSR 寄存器：**16 位驱动阶段寄存器，可用于在扩展操作条件下提高总线性能 (取决于总线长度、传输速率等参数)。

**SCR 寄存器：**仅 SD/SD I/O 有这个寄存器。

#### 25.4.4.2 命令

控制卡的命令有以下四种不同的类型：

表格 107 命令类型

| 命令类型                    | 意义                       |
|-------------------------|--------------------------|
| 广播命令 (BC)               | 发送到所有卡, 没有响应返回           |
| 带响应的广播命令 (BCR)          | 发送到所有卡, 同时收到从所有卡返回的响应    |
| 寻址 (点对点) 命令 (AC)        | 发送到寻址卡上, SDIO_D 线上没有数据传输 |
| 寻址 (点对点) 的数据传输命令 (ADTC) | 发送到寻址卡上, SDIO_D 线上有数据传输  |

### 命令格式

所有命令格式都是 48 位的固定码长, 需要 1.92us (25MHz) 0.96us (50MHz) 和 0.92us (52MHz) 的发送时间。

表格 108 表命令格式

| 位  | 47  | 46  | [45:40] | [39:8] | [7:1] | 0   |
|----|-----|-----|---------|--------|-------|-----|
| 宽度 | 1   | 1   | 6       | 32     | 7     | 1   |
| 数值 | 0   | 1   | -       | -      | -     | 1   |
| 说明 | 开始位 | 传输位 | 命令索引    | 参数     | CRC7  | 结束位 |

SD I/O 支持两种响应类型, 两种类型都有 CRC 错误检测。

- 48 位短响应
- 136 位长响应

表格 109 短响应格式

| 位  | 47  | 46  | [45:40] | [39:8] | [7:1]            | 0   |
|----|-----|-----|---------|--------|------------------|-----|
| 宽度 | 1   | 1   | 6       | 32     | 7                | 1   |
| 数值 | 0   | 0   | -       | -      | -                | 1   |
| 说明 | 开始位 | 传输位 | 命令索引    | 参数     | CRC7 或 (1111111) | 结束位 |

表格 110 长响应格式

| 位  | 135 | 134 | [133:128] | [127:1]   | 0   |
|----|-----|-----|-----------|-----------|-----|
| 宽度 | 1   | 1   | 6         | 127       | 1   |
| 数值 | 0   | 0   | 111111    | -         | 1   |
| 说明 | 开始位 | 传输位 | 保留        | CID 或 CSD | 结束位 |

### 命令描述

表格 111 基本命令

| 命令索引 | 类型 | 参数        | 响应格式 | 简称            | 说明         |
|------|----|-----------|------|---------------|------------|
| CMD0 | bc | [31:0]填充位 | -    | GO_IDLE_STATE | 复位所有卡到空闲状态 |

| 命令索引  | 类型  | 参数                                                                        | 响应格式 | 简称                   | 说明                                          |
|-------|-----|---------------------------------------------------------------------------|------|----------------------|---------------------------------------------|
| CMD1  | bc  | [31:0]OCR                                                                 | R3   | SEND_OP_COND         | 在空闲状态, 请求卡通过 CMD 线发送响应(包含操作条件寄存器的内容)        |
| CMD2  | bcr | [31:0]填充位                                                                 | R2   | ALL_SEND_CID         | 请求任何卡通过 CMD 线发送 CID 数据(所有连接到主机的卡都会响应)       |
| CMD3  | bcr | [31:0]填充位                                                                 | R6   | SEND_RELATIVE_ADDR   | 请求卡发布新的相对卡地址(RCA)                           |
| CMD4  | bc  | [31:16]DSR<br>[15:0]填充位                                                   | -    | SET_DSR              | 设置所有卡的 DSR 寄存器                              |
| CMD5  | bcr | [31:25]保留位<br>[24]S18R<br>[23:0]I/O OCR                                   | R4   | IO_SEND_OP_COND      | 仅适用于 I/O 卡。查询所有 IO 卡的电压范围                   |
| CMD6  | ac  | [31:26]设为 0<br>[25:24]访问<br>[23:16]索引<br>[15:8]值<br>[7:3]设为 0<br>[2:0]命令集 | R1b  | SWITCH               | 仅适用于 MMC 卡。切换所选卡操作模式或修改 EXT_CSD 寄存器         |
| CMD7  | ac  | [31:16]RCA<br>[15:0]填充位                                                   | R1b  | SELECT/DESELECT_CARD | 用于卡在状态上的切换。                                 |
| CMD8  | bcr | [31:12]保留位<br>[11:8]工作电压(VHS)<br>[7:0]检查模式                                | R7   | SEND_IF_COND         | 向 SD 卡发送接口条件, 包括主机供电电压信息和询问卡是否支持电压。保留位应设为 0 |
| CMD9  | ac  | [31:16]RCA<br>[15:0]填充位                                                   | R2   | SEND_CSD             | 被选定的卡通过 CMD 发送到他的卡特定数据(CSD)                 |
| CMD10 | ac  | [31:16]RCA<br>[15:0]填充位                                                   | R2   | SEND_CID             | 被选定的卡通过 CMD 发送到他的卡标识(CID)                   |
| CMD12 | ac  | [31:0]填充位                                                                 | R1b  | STOP_TRANSMISSION    | 强制卡停止传输                                     |

| 命令索引  | 类型   | 参数                      | 响应格式 | 简称                | 说明                       |
|-------|------|-------------------------|------|-------------------|--------------------------|
| CMD13 | ac   | [31:16]RCA<br>[15:0]填充位 | R1   | SEND_STATUS       | 被选定的卡发送它的状态寄存器           |
| CMD14 | adtc | [31:0]填充位               | R1   | BUSTEST_R         | 主机从卡中读取反向的总线测试数据模式       |
| CMD15 | ac   | [31:16]RCA<br>[15:0]填充位 | -    | GO_INACTIVE_STATE | 将被选定的卡转换到非激活(Inactive)状态 |
| CMD19 | adtc | [31:0]填充位               | R1   | BUSTEST_W         | 主机向卡发送总线测试模式             |

表格 112 面向块的写命令

| 命令索引  | 类型   | 参数                       | 响应格式 | 简称                   | 说明                                                           |
|-------|------|--------------------------|------|----------------------|--------------------------------------------------------------|
| CMD23 | ac   | [31:16]设为 0<br>[15:0]块数目 | R1   | SET_BLOCK_COUNT      | 定义在后续的多个块或写命令中传输块的数目                                         |
| CMD24 | adtc | [31:0]数据地址               | R1   | WRITE_BLOCK          | 按照 SET_BLOCKLEN 命令选择的长度写一个块                                  |
| CMD25 | adtc | [31:0]数据地址               | R1   | WRITE_MULTIPLE_BLOCK | 连续写入数据块，直到收到 STOP_TRANSMISSION 命令或达到了指定的块数目                  |
| CMD26 | adtc | [31:0]填充位                | R1   | PROGAM_CID           | 对卡识别寄存器编程。对每个卡只能发送一次该命令。该编程涉及到硬件更改，防止首次编程后以后的操作。通过该命令保留给生产厂商 |
| CMD27 | adtc | [31:0]填充位                | R1   | PROGAM_CSD           | 对卡的 CSD 中可编程的位编程                                             |
| CMD28 | ac   | [31:0]数据地址               | R1b  | SET_WRITE_PROT       | 如果卡有写保护功能，该命令设置指定组的写保护位。写保护特性设置在卡的特殊数据区 (WP_GRP_SIZE)        |
| CMD29 | ac   | [31:0]数据地址               | R1b  | CLR_WRITE_PROT       | 如果卡有写保护功能，该命令将清除寻址组的写保护位                                     |
| CMD30 | adtc | [31:0]写保护数据地址            | R1   | SEND_WRITE_PROT      | 如果卡有写保护功能，该命令请求卡发送写保护位状态                                     |

## 25.4.5 特定操作

### 25.4.5.1 SD I/O 卡操作

SD I/O 卡（包括 I/O 卡与组合卡）支持以下特定操作：

- 读等待操作
- 暂停/恢复操作
- 中断

只有设置 SDIO\_DCTRL 的 SDIOEN 位时，SDIO 才支持这些操作；但读暂停除外，它不需要特殊的硬件操作。

#### SD I/O 读等待操作

读等待（RW）仅用于 SD I/O 的 1 位和 4 位模式。读等待操作允许一个主机给卡执行一个读多个块操作时发信号，以停止数据传输，同时允许主机发送命令到 SD I/O 卡内任何功能函数。

在收到第一个数据块之前即可以开始读等待过程，使能数据通道（DTEN 位置 1）、使能 SDIO 特定操作（SDIOEN 位置 1）、开始读等待，同时数据传输方式为从卡到 SDIO 主机，DPSM 将直接从空闲进入读等待状态。

在读等待状态时，2 个 SDIO\_CK 时钟周期后，DPSM 驱动 SDIO\_D2 为 0，在此状态，如果设置了 RWSTOP 位，则 DPSM 会在等待状态多停留 2 个 SDIO\_CK 时钟周期，（根据 SDIO 规范）并在一个时钟周期中驱动 SDIO\_D2 为 1。然后 DPSM 开始等待从卡里接收数据。在接收数据块时，即使设置了开始等待，DPSM 也不会进入读等待。

SDIO 卡不能以上读等待操作，SDIO 可以停止 SDIO\_CK 进入读等待，在接收到当前数据块结束后 2 个 SDIO\_CK 周期后，DPSM 停止时钟，在设置读等待开始位后恢复时钟。

图 112 使用 SDIO\_D2 信号线的读等待操作



图 113 通过停止 SDIO\_CLK 的读等待操作



### SDIO 中断

当设置了 SDIOEN 位, SDIO 主机在 SDIO\_D1 信号线上检测 SDIO 中断。

#### 25.4.5.2 CE-ATA 特定操作

CE-ATA 设备有以下特定操作:

- 接收命令完成信号
- 发送命令完成关闭信号

只有在设置了 SDIO\_CMD 的 ATACMD 位时, SDIO 才支持这些操作。

### 命令完成信号

CE-ATA 定义了命令完成信号, 设备使用该信号通知主机 ATA 命令完成或者遇到错误, ATA 命令终止。

### 命令完成关闭信号

主机可通过发送命令完成关闭信号、取消设备返回命令完成信号的功能。

如果未设置 ATACMD 的“允许 CMD 结束位”, 设置了 INTDIS 中的“非终端使能位”, 则在收到一个短响应后的八个位周期后, 发送命令完成关闭信号。

#### 25.4.6 卡状态寄存器功能描述

响应格式 R1 包含了一个 32 位的卡状态域, 这个域是用于向卡主机发送卡的状态信息 (这些信息有可能存在本地的状态寄存器中)。除非特别说明, 卡返回的状态始终是与之前的命令相关的。

下表定义了不同的状态信息:

表格 113 不同的状态信息类型

| 缩写 | 定义                                               |
|----|--------------------------------------------------|
| E  | 错误位                                              |
| S  | 状态位                                              |
| R  | 检测位, 并依据实际的命令响应而设置                               |
| X  | 检测位, 在命令的执行中设置。<br>SDIO 卡主机通过发送状态命令读出这些位而查询卡的状态。 |

表格 114 清除条件

| 缩写 | 定义                                  |
|----|-------------------------------------|
| A  | 依据卡的当前状态                            |
| B  | 始终与之前的命令相关。接收到正确的命令即可清除（具有一个命令的延迟）。 |
| C  | 读即可清除                               |

表格 115 卡状态

| 位    | 名称                | 类型 | 数值                                                                                        | 说明                                                                    | 清除条件 |
|------|-------------------|----|-------------------------------------------------------------------------------------------|-----------------------------------------------------------------------|------|
| 1:0  | 保留给生产厂家的测试模式      |    |                                                                                           |                                                                       |      |
| 2    | 保留给与应用相关的命令       |    |                                                                                           |                                                                       |      |
| 3    | AKE_SEQ_ERROR     | ER | 0=无错误<br>1=错误                                                                             | 验证的顺序有错误                                                              | C    |
| 4    | 保留给 SD I/O 卡      |    |                                                                                           |                                                                       |      |
| 5    | APP_CMD           | SR | 0=不允许<br>1=允许                                                                             | 卡期望 ACMD，或指示命令已经被解释为 ACMD 命令                                          | C    |
| 6    | 保留                |    |                                                                                           |                                                                       |      |
| 7    | SWITCH_ERROR      | EX | 0=无错误<br>1=转换错                                                                            | 卡没有按照 SWITCH 命令的要求转换到希望的模式                                            | B    |
| 8    | READY_FOR_DATA    | SR | 0=未就绪<br>1=就绪                                                                             | 与总线上的缓冲器空的信号相对应                                                       |      |
| 12:9 | CURRENT_STATE     | SR | 0=空闲<br>1=就绪<br>2=识别<br>3=待机<br>4=发送<br>5=数据<br>6=接收<br>7=编程<br>8=断开<br>9=忙测试<br>10~15=保留 | 当收到命令时卡内状态机的状态。如果命令的执行导致状态的变化，这个变化将会在下个命令的响应中反映出来。这四个位按十进制数 0 至 15 解释 | B    |
| 13   | ERASE_RESET       |    | 0=清除<br>1=设置                                                                              | 因为收到一个擦除顺序之外的命令（非 CMD35、CMD36、CMD38 或 CMD13 命令），进入擦除过程的序列被中止          | C    |
| 14   | CARD_ECC_DISABLED | SX | 0=允许<br>1=不允许                                                                             | 执行命令时没有使用内部的 ECC                                                      | A    |
| 15   | WP_ERASE_SKIP     | EX | 0=未保护<br>1=已保护                                                                            | 遇到已经存在的写保护数据块，仅有部分地址空间被擦除                                             | C    |

| 位  | 名称                 | 类型 | 数值             | 说明                                                                                                                      | 清除条件 |
|----|--------------------|----|----------------|-------------------------------------------------------------------------------------------------------------------------|------|
| 16 | CID/CSD_OVERWRITE  | EX | 0=无错误<br>1=错误  | 可以是任何一个下述的错误：<br>已经写入了 CID 寄存器，不能覆盖<br>CSD 的只读部分与卡的内容不匹配<br>试图进行拷贝或永久写保护的反向操<br>作，即恢复原状或解除写保护                           | C    |
| 17 | 保留                 |    |                |                                                                                                                         |      |
| 18 | 保留                 |    |                |                                                                                                                         |      |
| 19 | ERROR              | EX | 0=无错误<br>1=错误  | 产生了与执行上一个主机命令相关的<br>(标准中未定义)<br>卡内部的错误 (例如：读或写错误)                                                                       | C    |
| 20 | CC_ERROR           | ER | 0=无错误<br>1=错误  | (标准中未定义) 卡内部发生错误，<br>与主机的命令无关。                                                                                          | C    |
| 21 | CARD_ECC_FAILED    | EX | 0=成功<br>1=失败   | 卡的内部实施了 ECC 校验，但在更<br>正数据时失败                                                                                            | C    |
| 22 | ILLEGAL_COMMAND    | ER | 0=无错误<br>1=错误  | 对于当前的卡状态，命令非法                                                                                                           | B    |
| 23 | COM_CRC_ERROR      | ER | 0=无错误<br>1=错误  | 之前的命令中 CRC 校验错误                                                                                                         | B    |
| 24 | LOCK_UNLOCK_FAILED | EX | 0=无错误<br>1=错误  | 在上锁/解锁中有命令的顺序错误或<br>检测到密码错误                                                                                             | C    |
| 25 | CARD_IS_LOCKED     | SR | 0=卡未锁<br>1=卡已锁 | 当设置了该位，表示卡已经被锁住                                                                                                         | A    |
| 26 | WP_VIOLATION       | EX | 0=无错误<br>1=错误  | 试图对一个写保护的数据块编程                                                                                                          | C    |
| 27 | ERASE_PARAM        | EX | 0=无错误<br>1=错误  | 擦除时选择了非法的擦除组                                                                                                            | C    |
| 28 | ERASE_SEQ_ERROR    |    | 0=无错误<br>1=错误  | 发送擦除命令的顺序错误                                                                                                             | C    |
| 29 | BLOCK_LEN_ERROR    |    | 0=无错误<br>1=错误  | SET_BLOCKLEN 命令的参数超出了<br>卡的最大允许范围，或先前定义的<br>数据块长度对于当前命令来说是非法的<br>(例如：主机发出一个写命令，当前<br>的块长度小于卡所允许的最小长度，<br>同时又不允许写入部分数据块) | C    |
| 30 | ADDRESS_MISALIGN   |    | 0=无错误<br>1=错误  | 命令中的地址参数 (与当前的数据块<br>长度对照) 定义的第一个数据块未与<br>卡的物理块对齐。<br>一个数据块或数据流读/写操作<br>(即使从一个合法的地址开始) 试图<br>读或写未与物理块对齐的数据块             | C    |

| 位  | 名称                   | 类型  | 数值            | 说明                                                               | 清除条件 |
|----|----------------------|-----|---------------|------------------------------------------------------------------|------|
| 31 | ADDRESS_OUT_OF_RANGE | ERX | 0=无错误<br>1=错误 | 命令中的地址参数超出了卡的允许范围。<br>一个数据块或数据流读/写操作（即使从一个合法的地址开始）试图读或写超出卡的容量的部分 | C    |

#### 25.4.6.1 SD 状态寄存器功能描述

SD 状态包含与 SD 存储器卡特定功能相关的一些与未来应用相关状态位，SD 状态的长度是一个 512 位的数据块。收到 ACMD13 命令 (CMD55, 然后是 CMD13) 后，这个寄存器的内容被传送到 SDIO 卡主机。只有卡处于传输状态时 (卡已被选择) 才能发送 ACMD13 命令。

下表定义了不同的 SD 状态寄存器信息。

表格 116 SD 状态寄存器信息

| 缩写 | 定义                                              |
|----|-------------------------------------------------|
| E  | 错误位                                             |
| S  | 状态位                                             |
| R  | 检测位，并依据实际的命令响应而设置                               |
| X  | 检测位，在命令的执行中设置。<br>SDIO 卡主机通过发送状态命令读出这些位而查询卡的状态。 |

注意：表中有关类型和清除条件域的缩写见定义。

表格 117 清除条件

| 缩写 | 定义                                  |
|----|-------------------------------------|
| A  | 依据卡的当前状态                            |
| B  | 始终与之前的命令相关。接收到正确的命令即可清除 (具有一个命令的延迟) |
| C  | 读即可清除置                              |

表格 118 SD 状态

| 位       | 名称            | 类型  | 数值                                   | 说明      | 清除条件 |
|---------|---------------|-----|--------------------------------------|---------|------|
| 311:0   | 保留给生产厂商       |     |                                      |         |      |
| 399:312 | 保留            |     |                                      |         |      |
| 401:400 | ERASE_OFFSET  | -   | -                                    | -       | -    |
| 407:402 | ERASE_TIMEOUT | S R | 在擦除时增加的固定偏移数值                        | (见以下说明) | A    |
| 423:408 | ERASE_SIZE    | S R | 擦除<br>UNIT_OF_ERASE_AU<br>指定的范围的超时数值 | (见以下说明) | A    |

| 位       | 名称                     | 类型  | 数值                                                                                                 | 说明                                                                                    | 清除条件 |
|---------|------------------------|-----|----------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|------|
| 427:424 | 保留                     | S R | 一次可以擦除的 AU 数目                                                                                      | (见以下说明)                                                                               | A    |
| 431:428 | AU_SIZE                | S R | AU 的大小 (见以下说明)                                                                                     | (见以下说明)                                                                               | A    |
| 439:432 | PERFORMANCE_MOVE       | S R | 以 1MB/秒为单位的传输性能 (见以下说明)                                                                            | (见以下说明)                                                                               | A    |
| 447:440 | SPEED_CLASS            | S R | 卡的速度类型 (见以下说明)                                                                                     | (见以下说明)                                                                               | A    |
| 479:448 | SIZE_OF_PROTECTED_AREA | S R | 受保护的区域大小 (见以下说明)                                                                                   | (见以下说明)                                                                               | A    |
| 495:480 | SD_CARD_TYPE           | S R | '00xxh'=在物理规范版本 1.01 ~2.00 的 SD 存储器卡 ('x'表示任意值)。<br>已定义的卡有：<br>'0000'=通用 SD 读写卡<br>'0001'=SD ROM 卡 | 这个域的低 8 位可以在未来定义 SD 存储卡的不同变种 (每个位可以用于定义不同的 SD 类型)。高 8 位可以用于定义那些不遵守当前的 SD 物理层规范的 SD 卡。 | A    |
| 508:496 | 保留                     |     |                                                                                                    |                                                                                       |      |
| 509     | SECURED_MODE           | S R | 0=未处于保密模式<br>1=处于保密模式                                                                              | 卡处于保密操作模式 (详见“SD 保密规范 ”)。                                                             | A    |
| 511:510 | DAT_BUS_WIDTH          | S R | 00=1 (默认)<br>01=保留<br>10=4 位宽<br>11=保留                                                             | 由 SET_BUS_WIDTH 命令定义的当前数据总线宽度                                                         | A    |

### **SIZE\_OF\_PROTECTED\_AREA**

标准容量卡和高容量卡设置该位的方式不同：

- 对于标准容量卡，受保护区域的容量由下式计算：  
受保护区域=SIZE\_OF\_PROTECTED\_AREA \* MULT \* BLOCK\_LEN  
SIZE\_OF\_PROTECTED\_AREA 的单位是 MULT \* BLOCK\_LEN。
- 对于高容量卡，受保护区域的容量由下式计算：  
受保护区域=SIZE\_OF\_PROTECTED\_AREA  
SIZE\_OF\_PROTECTED\_AREA 的单位是字节。

### **SPEED\_CLASS**

这 8 位指示速度的类型和可以通过计算  $PW/2$  的数值（ $PW$  是写的性能）。

表格 119 速度类型代码

| SPEED_CLASS | 数值定义 |
|-------------|------|
| 00h         | 类型 0 |
| 01h         | 类型 2 |
| 02h         | 类型 4 |
| 03h         | 类型 6 |
| 04h~FFh     | 保留   |

### **PERFORMANCE\_MOVE**

这 8 位以 1MB/秒为单位指示移动性能（ $Pm$ ）。如果卡不用 RU（纪录单位）移动数据，应该认为  $Pm$  是无穷大。设置这个域为 FFh 表示无穷大。

表格 120 移动性能代码

| PERFORMANCE_MOVE | 数值定义    |
|------------------|---------|
| 00h              | 未定义     |
| 01h              | 1MB/秒   |
| 02h              | 2MB/秒   |
| .....            | .....   |
| Feh              | 254MB/秒 |
| FFh              | 无穷大     |

### **AU\_SIZE**

这 4 位指示 AU 的长度，数值是 16K 字节为单位 2 的幂次的倍数。

表格 121 AU\_SIZE 代码

| AU_SIZE | 数值定义  |
|---------|-------|
| 00h     | 未定义   |
| 01h     | 16KB  |
| 02h     | 32KB  |
| 03h     | 64KB  |
| 04h     | 128KB |
| 05h     | 256KB |
| 06h     | 512KB |
| 07h     | 1MB   |
| 08h     | 2MB   |

| AU_SIZE | 数值定义 |
|---------|------|
| 09h     | 4MB  |
| Ah~Fh   | 保留   |

依据卡的容量，最大的 AU 长度由下表定义。卡可以在 RU 长度和最大的 AU 长度之间设置任意的 AU 长度。

表格 122 最大的 AU 长度

| 容量          | 最大的 AU 长度 |
|-------------|-----------|
| 16MB~64MB   | 512KB     |
| 128MB~256MB | 1MB       |
| 512MB       | 2MB       |
| 1GB~32GB    | 4MB       |

### ERASE\_SIZE

这个 16 位域给出了  $N_{ERASE}$  的值，当  $N_{ERASE}$  个 AU 被擦除时，  
ERASE\_TIMEOUT 定义超时时间。

如果主机能够确定某次擦除中  $N_{ERASE}$  的值，那么就可以显示擦除的进度。

表格 123 ERASE\_SIZE 代码

| ERASE_SIZE | 数值定义       |
|------------|------------|
| 0000h      | 不支持擦除的超时计算 |
| 0001h      | 1 个 AU     |
| 0002h      | 2 个 AU     |
| 0003h      | 3 个 AU     |
| .....      | .....      |
| FFFFh      | 65535 个 AU |

### ERASE\_TIMEOUT

这 6 位给出了  $T_{ERASE}$ ，当多个 AU 被擦除时， $T_{ERASE}$  给出了从偏移量算起的擦除超时。

表格 124 擦除超时代码

| ERASE_TIMEOUT | 数值定义       |
|---------------|------------|
| 00            | 不支持擦除的超时计算 |
| 01            | 1 秒        |
| 02            | 2 秒        |
| 03            | 3 秒        |
| .....         | .....      |

| ERASE_TIMEOUT | 数值定义 |
|---------------|------|
| 63            | 63 秒 |

### ERASE\_OFFSET

这 2 位给出了 TOFFSET，当 ERASE\_SIZE 和 ERASE\_TIMEOUT 同为 0 时这个数值没有意义。

表格 125 擦除偏移代码

| ERASE_OFFSET | 数值定义 |
|--------------|------|
| 0            | 0 秒  |
| 1            | 1 秒  |
| 2            | 2 秒  |
| 3            | 3 秒  |

## 25.5 寄存器地址映射

表格 126 SDIO 寄存器地址映射

| 寄存器名          | 描述               | 偏移地址                        |
|---------------|------------------|-----------------------------|
| SDIO_PWRCTRL  | SDIO 电源控制寄存器     | 0x00                        |
| SDIO_CLKCTRL  | SDIO 时钟控制寄存器     | 0x04                        |
| SDIO_ARG      | SDIO 参数寄存器       | 0x08                        |
| SDIO_CMD      | SDIO 命令寄存器       | 0x0C                        |
| SDIO_CMDRES   | SDIO 命令响应寄存器     | 0x10                        |
| SDIO_RESx     | SDIO 响应 x 寄存器    | 0x14 + 4* (x-1), 其中 x=1...4 |
| SDIO_DATATIME | SDIO 数据定时器寄存器    | 0x24                        |
| SDIO_DATALEN  | SDIO 数据长度寄存器     | 0x28                        |
| SDIO_DCTRL    | SDIO 数据控制寄存器     | 0x2C                        |
| SDIO_DCNT     | SDIO 数据计数器寄存器    | 0x30                        |
| SDIO_STS      | SDIO 状态寄存器       | 0x34                        |
| SDIO_ICF      | SDIO 清除中断寄存器     | 0x38                        |
| SDIO_MASK     | SDIO 中断屏蔽寄存器     | 0x3C                        |
| SDIO_FIFOCNT  | SDIO 计数器寄存器      | 0x48                        |
| SDIO_FIFODATA | SDIO 数据 FIFO 寄存器 | 0x80                        |

## 25.6 寄存器功能描述

设备通过可以在 APB2 上操作的 32 位控制寄存器与系统通信，必须以字（32

位) 的方式操作这些外设寄存器。

### 25.6.1 SDIO 电源控制寄存器 (SDIO\_PWRCTRL)

偏移地址: 0x00

复位值: 0x0000 0000

| 位/域  | 名称      | R/W | 描述                                                                                                                |
|------|---------|-----|-------------------------------------------------------------------------------------------------------------------|
| 1:0  | PWRCTRL | R/W | 控制电源 (Power Supply Control)<br>选择卡时钟的当前功能状态。<br>00: 电源关闭, 卡的时钟停止。<br>01: 保留。<br>10: 保留的上电状态。<br>11: 上电状态, 卡的时钟开启。 |
| 31:2 |         |     | 保留                                                                                                                |

注意: 写入数据后的 3 个 SDIOCLK (48 MHz) 时钟周期及 2 个 PCLK2 时钟周期内不能写入这个寄存器。

### 25.6.2 SDIO 时钟控制寄存器 (SDIO\_CLKCTRL)

偏移地址: 0x04

复位值: 0x0000 0000

SDIO\_CLKCTRL 寄存器控制 SDIO\_CLK 输出时钟。

| 位/域   | 名称       | R/W | 描述                                                                                                                                                  |
|-------|----------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0   | CLKDIV   | R/W | 时钟分频系数 (Clock Divide Factor)<br>这个域定义了输入时钟 (SDIOCLK) 与输出时钟 (SDIO_CLK) 间的分频系数:<br>SDIO_CLK 频率=SDIOCLK/[CLKDIV + 2]。                                  |
| 8     | CLKEN    | R/W | 使能时钟 (Clock Enable)<br>0: 禁用<br>1: 使能                                                                                                               |
| 9     | PWRSAV   | R/W | 配置省电模式 (Power Saving Mode Configuration)<br>通过禁止 SDIO_CLK 在总线活动外输出来减少功耗。<br>0: 允许<br>1: 禁止                                                          |
| 10    | BYPASSEN | R/W | 使能旁路时钟分频器 (Clock Divider Bypass Enable)<br>驱动 SDIO_CLK 输出信号前, 需要对 SDIOCLK 分频, 但如果旁路了分频器, 那么 SDIOCLK 直接驱动 SDIO_CLK 输出信号。<br>0: 禁用<br>1: 使能           |
| 12:11 | WBSEL    | R/W | 选择总线模式宽度 (Wide Bus Mode Select)<br>选择不同位的总线模式, 对应不同 SDIO_D 位。<br>00: 默认, 使用 SDIO_D0<br>01: 4 位, 使用 SDIO_D[3:0]<br>10: 8 位, 使用 SDIO_D[7:0]<br>11: 保留 |
| 13    | DEPSEL   | R/W | 选择 SDIO_CLK 相位 (SDIO_CLK Dephasing Select)<br>选择 SDIOCLK 上升沿或者下降沿产生 SDIO_CLK。<br>0: 上升沿<br>1: 下降沿                                                   |

| 位/域   | 名称    | R/W | 描述                                                 |
|-------|-------|-----|----------------------------------------------------|
| 14    | HFCEN | R/W | 使能硬件流控制 (HW Flow Control Enable)<br>0: 禁用<br>1: 使能 |
| 31:15 |       |     | 保留                                                 |

注意：

- (1) 当 SD/SD I/O 卡或多媒体卡处于识别模式, SDIO\_CLK 的频率必须低于 400kHz。
- (2) 当所有卡都被赋予了相应的地址后, 时钟频率可以改变到卡总线允许的最大频率。
- (3) 写入数据后的 3 个 SDIOCLK (48 MHz)时钟周期及 2 个 PCLK2 时钟周期内不能写入这个寄存器。对于 SD I/O 卡, 在读等待期间可以停止 SDIO\_CLK, 此时 SDIO\_CLKCTRL 寄存器不控制 SDIO\_CLK。

### 25.6.3 SDIO 参数寄存器 (SDIO\_ARG)

偏移地址: 0x08

复位值: 0x0000 0000

命令参数也是命令的一部分, SDIO\_ARG 寄存器包含 32 位命令参数并且和命令一起发送到卡中。

| 位/域  | 名称     | R/W | 描述                                 |
|------|--------|-----|------------------------------------|
| 31:0 | CMDARG | R/W | 命令参数 (Command Argument)<br>存储命令参数。 |

### 25.6.4 SDIO 命令寄存器 (SDIO\_CMD)

偏移地址: 0x0C

复位值: 0x0000 0000

SDIO\_CMD 寄存器包含命令索引和命令类型位。

| 位/域 | 名称       | R/W | 描述                                                                                                                                                                                             |
|-----|----------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5:0 | CMDINDEX | R/W | 命令索引 (Command Index)<br>命令索引作为命令的一部分与其一起发送到卡中。                                                                                                                                                 |
| 7:6 | WAITRES  | R/W | 等待响应 (Wait for Response)<br>指示 CPSM 是否需要等待响应, 如果需要等待响应, 则指示响应类型。<br>00: 无响应, 期待 CMDSENT 标志<br>01: 短响应, 期待 CMDREND 或 CCRCFAIL 标志<br>10: 无响应, 期待 CMDSENT 标志<br>11: 长响应, 期待 CMDREND 或 CCRCFAIL 标志 |
| 8   | WAITINT  | R/W | CPSM 等待中断请求 (CPSM Waits for Interrupt Request)<br>CPSM 开启或关闭命令超时控制并等待中断请求。<br>0: 开启<br>1: 关闭                                                                                                   |
| 9   | WENDDATA | R/W | CPSM 等待数据传输结束 (CmdPend 内部信号) (CPSM Waits for Ends of Data Transfer (CmdPend Internal Signal))<br>0: 无效<br>1: CPSM 在开始发送一个命令之前等待数据传输结束。                                                         |

| 位/域   | 名称      | R/W | 描述                                                                                        |
|-------|---------|-----|-------------------------------------------------------------------------------------------|
| 10    | CPSMEN  | R/W | 使能命令通道状态机 (CPSM) (Command Path State Machine (CPSM) Enable)<br>使能 CPSM。<br>0: 禁用<br>1: 使能 |
| 11    | SDIOSC  | R/W | SD I/O 暂停命令 (SD I/O Suspend Command)<br>0: 无效<br>1: 将要发送的命令是一个暂停命令 (只能用于 SD I/O 卡)。       |
| 12    | CMDCPEN | R/W | 使能 CMD 完成 (Enable CMD Completion)<br>使能命令完成信号。<br>0: 禁用<br>1: 使能                          |
| 13    | INTEN   | R/W | 使能中断 (Interrupt Enable)<br>0: 使能<br>1: 禁止                                                 |
| 14    | ATACMD  | R/W | CE-ATA 命令 (CE-ATA Command)<br>0: 无效<br>1: CPSM 转至 CMD61                                   |
| 31:15 |         |     | 保留                                                                                        |

注意：

- (1) 写入数据后的 3 个 SDIOCLK (48 MHz) 时钟周期及 2 个 PCLK2 时钟周期内不能写入这个寄存器。
- (2) 多媒体卡可以发送 2 种响应：48 位长的短响应，或 136 位长的长响应。SD 卡和 SD I/O 卡只能发送短响应，参数可以根据响应的类型而变化，软件将根据发送的命令区分响应的类型。CE-ATA 设备只发送短响应。

### 25.6.5 SDIO 命令响应寄存器 (SDIO\_CMDRES)

偏移地址: 0x10

复位值: 0x0000 0000

| 位/域  | 名称     | R/W | 描述                                                     |
|------|--------|-----|--------------------------------------------------------|
| 5:0  | CMDRES | R   | 响应的命令索引 (Response Command Index)<br>存储最后收到的命令响应中的命令索引。 |
| 31:6 |        |     | 保留                                                     |

### 25.6.6 SDIO 响应 x 寄存器 (SDIO\_RESx)

偏移地址: 0x14 + 4\* (x-1)，其中 x=1...4

复位值: 0x0000 0000

SDIO\_RES1/2/3/4 寄存器包含卡的状态，即收到响应的部分信息。

| 位/域  | 名称       | R/W | 描述   |
|------|----------|-----|------|
| 31:0 | CARDSTSx | R   | 见下表。 |

根据响应状态，卡的状态长度是 32 位或 127 位。

表格 127 响应类型和 SDIO\_RESPx 寄存器

| 寄存器       | 短响应       | 长响应         |
|-----------|-----------|-------------|
| SDIO_RES1 | 卡状态[31:0] | 卡状态[127:96] |
| SDIO_RES2 | 不用        | 卡状态[95:64]  |
| SDIO_RES3 | 不用        | 卡状态[63:32]  |
| SDIO_RES4 | 不用        | 卡状态[31:1]   |

总是先收到卡状态的最高位，SDIO\_RES3 寄存器的最低位始终为 0。

#### 25.6.7 SDIO 数据定时器寄存器 (SDIO\_DATATIME)

偏移地址: 0x24

复位值: 0x0000 0000

| 位/域  | 名称       | R/W | 描述                                                    |
|------|----------|-----|-------------------------------------------------------|
| 31:0 | DATATIME | R/W | 数据超时时间 (Data Timeout Period)<br>记录以卡总线时钟周期为单位的数据超时时间。 |

注意: 在写入数据控制寄存器进行数据传输之前, 必须先写入数据定时器寄存器和数据长度寄存器。

#### 25.6.8 SDIO 数据长度寄存器 (SDIO\_DATALEN)

偏移地址: 0x28

复位值: 0x0000 0000

| 位/域   | 名称      | R/W | 描述                                |
|-------|---------|-----|-----------------------------------|
| 24:0  | DATALEN | R/W | 数据长度 (Data Length)<br>要传输的数据字节长度。 |
| 31:25 |         |     | 保留                                |

注意: 对于块数据传输, SDIO\_DATALEN 中的数值必须是数据块长度的倍数。在写入 SDIO\_DCTRL 进行数据传输之前, 必须先写入 SDIO\_DATATIME 和 SDIO\_DATALEN。

#### 25.6.9 SDIO 数据控制寄存器 (SDIO\_DCTRL)

偏移地址: 0x2C

复位值: 0x0000 0000

SDIO\_DCTRL 寄存器控制数据通道状态机 (DPSM)。

| 位/域 | 名称      | R/W | 描述                                                                       |
|-----|---------|-----|--------------------------------------------------------------------------|
| 0   | DTEN    | R/W | 使能数据传输 (Data Transfer Enabled)<br>0: 禁用<br>1: 使能                         |
| 1   | DTDRCFG | R/W | 配置数据传输方向 (Data Transfer Direction Configuration)<br>0: 控制器至卡<br>1: 卡至控制器 |
| 2   | DTSEL   | R/W | 选择数据传输模式 (Data Transfer Mode Select)<br>0: 块数据传输<br>1: 流数据传输             |

| 位/域   | 名称     | R/W | 描述                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|--------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3     | DMAEN  | R/W | 使能 DMA (DMA Enable)<br>0: 禁用<br>1: 使能                                                                                                                                                                                                                                                                                                                                                                  |
| 7:4   | DBSIZE | R/W | 数据块长度 (Data Block Size)<br>定义数据块长度:<br>0000: 块长度=20=1 字节<br>0001: 块长度=21=2 字节<br>0010: 块长度=22=4 字节<br>0011: 块长度=23=8 字节<br>0100: 块长度=24=16 字节<br>0101: 块长度=25=32 字节<br>0110: 块长度=26=64 字节<br>0111: 块长度=27=128 字节<br>1000: 块长度=28=256 字<br>1001: 块长度=29=512 字<br>1010: 块长度=210=1024 字节<br>1011: 块长度=211=2048 字节<br>1100: 块长度=212=4096 字节<br>1101: 块长度=213=8192 字节<br>1110: 块长度=214=16384 字节<br>1111: 保留 |
| 8     | RWSTR  | R/W | 读等待开始 (Read Wait Start)<br>0: 无效<br>1: 开始读等待操作                                                                                                                                                                                                                                                                                                                                                         |
| 9     | RWSTOP | R/W | 使能读等待停止 (Read Wait Stop Enable)<br>如果设置了 RWSTR, 可使能停止读操作。<br>0: 禁用<br>1: 使能                                                                                                                                                                                                                                                                                                                            |
| 10    | RDWAIT | R/W | 读等待模式 (Read Wait Mode)<br>0: 控制停止 SDIO_D2<br>1: 控制使用 SDIO_CK                                                                                                                                                                                                                                                                                                                                           |
| 11    | SDIOF  | R/W | 使能 SD I/O 功能 (SD I/O Enable Functions)<br>如果设置了该位, 则 DPSM 执行 SD I/O 卡特定的操作。                                                                                                                                                                                                                                                                                                                            |
| 31:12 |        |     | 保留                                                                                                                                                                                                                                                                                                                                                                                                     |

### 25.6.10 SDIO 数据计数器寄存器 (SDIO\_DCNT)

偏移地址: 0x30

复位值: 0x0000 0000

当 DPSM 从空闲状态进入 Wait\_R 或 Wait\_S 状态时, SDIO\_DCNT 从 SDIO\_DATALEN 加载数值, 数据传输过程中, 该计数器向下计数至 0, 然后 DPSM 进入空闲状态并设置 DATAEND 标志。

| 位/域  | 名称      | R/W | 描述                                         |
|------|---------|-----|--------------------------------------------|
| 24:0 | DATACNT | R   | 数据计数数值 (Data Count Number)<br>存储待传输的数据字节数。 |

| 位/域   | 名称 | R/W | 描述 |
|-------|----|-----|----|
| 31:25 |    |     | 保留 |

注意：只能在数据传输结束时读这个寄存器。

### 25.6.11 SDIO 状态寄存器 (SDIO\_STS)

偏移地址: 0x34

复位值: 0x0000 0000

SDIO\_STS 是一个只读寄存器，它包含两类标志：

(1) 静态标志 (位[23:22、10:0]): 写入 SDIO 中断清除寄存器，可以清除这些位。

(2) 动态标志 (位[21:11]): 这些位的状态变化根据它们对应的那部分逻辑而变化。

| 位/域 | 名称       | R/W | 描述                                                                                      |
|-----|----------|-----|-----------------------------------------------------------------------------------------|
| 0   | COMRESP  | R   | 已收到命令响应 (CRC 检测失败) (Command Response Received)                                          |
| 1   | DBDR     | R   | 已发送/接收数据块 (CRC 检测失败) (Data Block Sent/Received)                                         |
| 2   | CMDRESTO | R   | 命令响应超时 (Command Response Timeout)<br>命令超时时间为 64 个 SDIO_CLK 时钟周期。                        |
| 3   | DATATO   | R   | 数据超时 (Data Timeout)                                                                     |
| 4   | TXUDRER  | R   | 发送 FIFO 下溢错误 (Transmit FIFO Underrun Error)                                             |
| 5   | RXOVRER  | R   | 接收 FIFO 上溢错误 (Received FIFO Overrun Error)                                              |
| 6   | CMDRES   | R   | 已接收到响应 (CRC 检测成功) (Command Response)                                                    |
| 7   | CMDSENT  | R   | 命令已发送 (不需要响应) (Command Sent (No Response Required))                                     |
| 8   | DATAEND  | R   | 数据结束 (数据计数器, SDIO_DCNT=0)                                                               |
| 9   | SBE      | R   | 在总线模式宽度下，没有在所有数据信号上检测到起始位 (Start Bit Not Detected On All Data Signals In Wide Bus Mode) |
| 10  | DBCP     | R   | 已发送/接收数据块 (Data Block Sent/Received)                                                    |
| 11  | CMDACT   | R   | 正在传输命令 (Command Transfer In Progress)                                                   |
| 12  | TXACT    | R   | 正在发送数据 (Data Transmit In Progress)                                                      |
| 13  | RXACT    | R   | 正在接收数据 (Data Receive In Progress)                                                       |
| 14  | TXFHF    | R   | 发送 FIFO 半空 (Transmit FIFO Half Empty):<br>FIFO 中至少还可以写入 8 个字。                           |
| 15  | RXFHF    | R   | 接收 FIFO 半满 (Receive FIFO Half Full)<br>FIFO 中至少还有 8 个字。                                 |
| 16  | TXFF     | R   | 发送 FIFO 满 (Transmit FIFO Full)                                                          |
| 17  | RXFF     | R   | 接收 FIFO 满 (Receive FIFO Full)<br>若使用了硬件流控制，当 FIFO 还差 2 个字满时， RXFF 信号变为有效。               |
| 18  | TXFE     | R   | 发送 FIFO 空 (Transmit FIFO Empty)<br>若使用了硬件流控制，当 FIFO 包含 2 个字时， TXFE 信号变为有效。              |
| 19  | RXFE     | R   | 接收 FIFO 空 (Receive FIFO Empty)                                                          |

| 位/域   | 名称      | R/W | 描述                                                                              |
|-------|---------|-----|---------------------------------------------------------------------------------|
| 20    | TXDA    | R   | 在发送 FIFO 中的数据可用 (Data Available In Transmit FIFO)                               |
| 21    | RXDA    | R   | 在接收 FIFO 中的数据可用 (Data Available In Receive FIFO)                                |
| 22    | SDIOINT | R   | 收到 SDIO 中断 (SDIO Interrupt Received)                                            |
| 23    | ATAEND  | R   | 在 CMD61 接收到 CE-ATA 命令完成信号 (CE-ATA Command Completion Signal Received For CMD61) |
| 31:24 |         |     | 保留                                                                              |

### 25.6.12 SDIO 清除中断寄存器 (SDIO\_ICF)

偏移地址: 0x38

复位值: 0x0000 0000

SDIO\_ICF 是一个只写寄存器, 在对应寄存器位置位将清除 SDIO\_STS 状态寄存器中的对应位。

| 位/域 | 名称     | R/W | 描述                                                                        |
|-----|--------|-----|---------------------------------------------------------------------------|
| 0   | CRCE   | R/W | COMRESP 标志清除位 (COMRESP Flag Clear)<br>清除 COMRESP 标志。<br>0: 无效<br>1: 清除    |
| 1   | DBCE   | R/W | DBDR 标志清除位 (DBDR Flag Clear)<br>清除 DBDR 标志。<br>0: 无效<br>1: 清除             |
| 2   | CRTO   | R/W | CMDRESTO 标志清除位 (CMDRESTO Flag Clear)<br>清除 CMDRESTO 标志。<br>0: 无效<br>1: 清除 |
| 3   | DTO    | R/W | DATATO 标志清除位 (DATATO Flag Clear)<br>清除 DATATO 标志。<br>0: 无效<br>1: 清除       |
| 4   | TXFUE  | R/W | TXUDRER 标志清除 (TXUDRER Flag Clear)<br>清除 TXUDRER 标志。<br>0: 无效<br>1: 清除     |
| 5   | RXFOE  | R/W | RXOVRER 标志清除位 (RXOVRER Flag Clear)<br>清除 RXOVRER 标志。<br>0: 无效<br>1: 清除    |
| 6   | CMDRES | R/W | CMDRES 标志清除位 (CMDRES Flag Clear)<br>清除 CMDRES 标志。<br>0: 无效<br>1: 清除       |

| 位/域   | 名称      | R/W | 描述                                                                     |
|-------|---------|-----|------------------------------------------------------------------------|
| 7     | CMDSENT | R/W | CMDSENT 标志清除位 (CMDSENT Flag Clear)<br>清除 CMDSENT 标志。<br>0: 无效<br>1: 清除 |
| 8     | DATAEND | R/W | DATAEND 标志清除位 (DATAEND Flag Clear)<br>清除 DATAEND 标志。<br>0: 无效<br>1: 清除 |
| 9     | SBE     | R/W | SBE 标志清除位 (SBE Flag Clear)<br>清除 SBE 标志。<br>0: 无效<br>1: 清除             |
| 10    | DBCP    | R/W | DBCP 标志清除位 (DBCP Flag Clear)<br>清除 DBCP 标志。<br>0: 无效<br>1: 清除          |
| 21:11 |         |     | 保留                                                                     |
| 22    | SDIOIT  | R/W | SDIOIT 标志清除位 (SDIOIT Flag Clear)<br>清除 SDIOIT 标志。<br>0: 无效<br>1: 清除    |
| 23    | ATAEND  | R/W | ATAEND 标志清除位 (ATAEND Flag Clear)<br>清除 ATAEND 标志。<br>0: 无效<br>1: 清除    |
| 31:24 |         |     | 保留                                                                     |

### 25.6.13 SDIO 中断屏蔽寄存器 (SDIO\_MASK)

偏移地址: 0x3C

复位值: 0x0000 0000

由软件置位或清零。

在对应位置 1, SDIO\_MASK 中断屏蔽寄存器决定哪一个状态位产生中断。

| 位/域 | 名称       | R/W | 描述                                                                                               |
|-----|----------|-----|--------------------------------------------------------------------------------------------------|
| 0   | CCRCFAIL | R/W | 使能命令块 CRC 检测失败产生中断 (Command CRC Fail Interrupt Enable)<br>允许/关闭命令块 CRC 检测失败中断。<br>0: 禁用<br>1: 使能 |
| 1   | DCRCFAIL | R/W | 使能数据块 CRC 检测失败产生中断 (Data CRC Fail Interrupt Enable)<br>允许/关闭数据块 CRC 检测失败中断。<br>0: 禁用<br>1: 使能    |

| 位/域 | 名称       | R/W | 描述                                                                                                    |
|-----|----------|-----|-------------------------------------------------------------------------------------------------------|
| 2   | CMDTO    | R/W | 使能命令超时产生中断 (Command Timeout Interrupt Enable)<br>允许/关闭命令超时中断。<br>0: 禁用<br>1: 使能                       |
| 3   | DATATO   | R/W | 使能数据超时产生中断 (Data Timeout interrupt Enable)<br>允许/关闭数据超时中断。<br>0: 禁用<br>1: 使能                          |
| 4   | TXURER   | R/W | 发送 FIFO 下溢错误产生中断 (Tx FIFO Underrun Error Interrupt Enable)<br>允许/关闭发送 FIFO 下溢错误中断。<br>0: 禁用<br>1: 使能  |
| 5   | RXORER   | R/W | 使能接收 FIFO 上溢错误产生中断 (Rx FIFO Overrun Error Interrupt Enable)<br>允许/关闭接收 FIFO 上溢错误中断。<br>0: 禁用<br>1: 使能 |
| 6   | CMDRESRC | R/W | 使能接收到响应产生中断 (Command Response Received Interrupt Enable)<br>允许/关闭接收到响应中断。<br>0: 禁用<br>1: 使能           |
| 7   | CMDSENT  | R/W | 使能命令已发送产生中断 (Command Sent Interrupt Enable)<br>由软件设置/清除该位, 允许/关闭命令已发送中断。<br>0: 禁用<br>1: 使能            |
| 8   | DATAEND  | R/W | 使能数据传输结束产生中断 (Data End Interrupt Enable)<br>允许/关闭数据传输结束中断。<br>0: 禁用<br>1: 使能                          |
| 9   | STRTER   | R/W | 使能起始位错误产生中断 (Start Bit Error Interrupt Enable)<br>允许/关闭起始位错误中断。<br>0: 禁用<br>1: 使能                     |
| 10  | DBEND    | R/W | 使能数据块传输结束产生中断 (Data Block End Interrupt Enable)<br>允许/关闭数据块传输结束中断。<br>0: 禁用<br>1: 使能                  |
| 11  | CMDACT   | R/W | 使能正在传输命令产生中断 (Command Acting Interrupt Enable)<br>允许/关闭正在传输命令中断。<br>0: 禁用<br>1: 使能                    |

| 位/域 | 名称      | R/W | 描述                                                                                                            |
|-----|---------|-----|---------------------------------------------------------------------------------------------------------------|
| 12  | TXACT   | R/W | 使能正在发送数据产生中断 (Data Transmit Acting Interrupt Enable)<br>允许/关闭正在发送数据中断。<br>0: 禁用<br>1: 使能                      |
| 13  | RXACT   | R/W | 正在接收数据产生中断 (Data Receive Acting Interrupt Enable)<br>允许/关闭正在接收数据中断。<br>0: 禁用<br>1: 使能                         |
| 14  | TXHFERT | R/W | 使能发送 FIFO 半空产生中断 (Tx FIFO Half Empty Interrupt Enable)<br>允许/关闭发送 FIFO 半空中断。<br>0: 禁用<br>1: 使能                |
| 15  | RXHFFUL | R/W | 使能接收 FIFO 半满产生中断 (Rx FIFO Half Full Interrupt Enable)<br>允许/关闭接收 FIFO 半满中断。<br>0: 禁用<br>1: 使能                 |
| 16  | TXFUL   | R/W | 使能发送 FIFO 满产生中断 (Tx FIFO Full Interrupt Enable)<br>允许/关闭发送 FIFO 满中断。<br>0: 禁用<br>1: 使能                        |
| 17  | RXFUL   | R/W | 使能接收 FIFO 满产生中断 (Rx FIFO Full Interrupt Enable)<br>允许/关闭接收 FIFO 满中断。<br>0: 禁用<br>1: 使能                        |
| 18  | TXEPT   | R/W | 使能发送 FIFO 空产生中断 (Tx FIFO Empty Interrupt Enable)<br>允许/关闭发送 FIFO 空中断。<br>0: 禁用<br>1: 使能                       |
| 19  | RXFEIE  | R/W | 使能接收 FIFO 空产生中断 (Rx FIFO Empty Interrupt Enable)<br>允许/关闭接收 FIFO 空中断。<br>0: 禁用<br>1: 使能                       |
| 20  | TXDAVB  | R/W | 使能发送 FIFO 中的数据有效产生中断 (Data Available in Tx FIFO Interrupt Enable)<br>允许/关闭发送 FIFO 中的数据有效中断。<br>0: 禁用<br>1: 使能 |
| 21  | RXDAVB  | R/W | 使能接收 FIFO 中的数据有效产生中断 (Data Available in Rx FIFO Interrupt Enable)<br>允许/关闭接收 FIFO 中的数据有效中断。<br>0: 禁用<br>1: 使能 |

| 位/域   | 名称         | R/W | 描述                                                                                                                                        |
|-------|------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------|
| 22    | SDIOINTREC | R/W | 使能允许 SDIO 模式中断已接收中断 (SDIO Mode Interrupt Received Interrupt Enable)<br>允许/关闭 SDIO 模式中断已接收中断功能。<br>0: 禁用<br>1: 使能                          |
| 23    | ATACLPREC  | R/W | 使能允许接收到 CE-ATA 命令完成信号产生中断 (CE-ATA Command Completion Signal Received Interrupt Enable)<br>允许/关闭在收到 CE-ATA 命令完成信号产生中断功能。<br>0: 禁用<br>1: 使能 |
| 31:24 | 保留         |     |                                                                                                                                           |

#### 25.6.14 SDIO FIFO 计数器寄存器 (SDIO\_FIFOCNT)

偏移地址: 0x48

复位值: 0x0000 0000

| 位/域   | 名称      | R/W | 描述                                                                                                                          |
|-------|---------|-----|-----------------------------------------------------------------------------------------------------------------------------|
| 23:0  | FIFOCNT | R   | 接收和发送 FIFO 数目 (Receive And Transmit FIFO Number)<br>将要写入 FIFO 或将要从 FIFO 读出数据字的数目。<br>注意: 如果数据长度不是 4 的倍数, 则最后剩下的字节可以当成一个字处理。 |
| 31:24 | 保留      |     |                                                                                                                             |

#### 25.6.15 SDIO 数据 FIFO 寄存器 (SDIO\_FIFODATA)

偏移地址: 0x80

复位值: 0x0000 0000

| 位/域  | 名称   | R/W | 描述                                                                          |
|------|------|-----|-----------------------------------------------------------------------------|
| 31:0 | DATA | R/W | 接收或发送 FIFO 数据 (Receive And Transmit FIFO Data)<br>将要写入 FIFO 或将要从 FIFO 读出数据。 |

## 26 USB\_OTGFS

### 26.1 简介

该芯片一共内嵌两个独立的 USB 控制器。

OTG\_FS 可同时支持主机和从机功能，符合 USB 2.0 规范的 On-The-Go 补充标准，也可配置为“仅主机”或“仅从机”模式，完全符合 USB 2.0 规范，支持主机协商协议(HNP) 和会话请求协议(SRP)。主机模式下，支持全速 (FS, 12Mb/s) 和低速 (LS, 1.5Mb/s) 传输；从机模式下，仅支持全速 (FS, 12Mb/s) 传输。

### 26.2 OTG\_FS 全局寄存器地址映射

表格 128 OTG\_FS 全局寄存器地址映射

| 寄存器名              | 描述                             | 偏移地址  |
|-------------------|--------------------------------|-------|
| OTG_FS_GCTRLSTS   | 全速 OTG 控制状态寄存器                 | 0x00  |
| OTG_FS_GINT       | 全速 OTG 中断寄存器                   | 0x04  |
| OTG_FS_GAHBCFG    | 全速 OTG AHB 配置寄存器               | 0x08  |
| OTG_FS_GUSBCFG    | 全速 OTG USB 配置寄存器               | 0x0C  |
| OTG_FS_GRSTCTRL   | 全速 OTG 复位控制寄存器                 | 0x10  |
| OTG_FS_GCINT      | 全速 OTG 模块中断寄存器                 | 0x14  |
| OTG_FS_GINTMASK   | 全速 OTG 模块中断屏蔽寄存器               | 0x18  |
| OTG_FS_GRXSTS     | 全速 OTG 读取调试接收状态寄存器             | 0x1C  |
| OTG_FS_GRXSTSP    | 全速 OTG 状态读取和出栈寄存器              | 0x20  |
| OTG_FS_GRXFIFO    | 全速 OTG 接收 FIFO 大小寄存器           | 0x24  |
| OTG_FS_GTXFCFG    | 全速 OTG TXFIFO 配置寄存器            | 0x28  |
| OTG_FS_GNPTXFQSTS | 全速 OTG 非周期性 TXFIFO 队列状态寄存器     | 0x2C  |
| OTG_FS_GGCCFG     | 全速 OTG 通用模块配置寄存器               | 0x38  |
| OTG_FS_GCID       | 全速 OTG 模块 ID 寄存器               | 0x3C  |
| OTG_FS_GHPTXFSIZE | 全速 OTG 主机周期性 TXFIFO 大小寄存器      | 0x100 |
| OTG_FS_DTXFIFO1   | 全速 OTG 设备 IN 端点 TXFIFO 大小寄存器 1 | 0x104 |
| OTG_FS_DTXFIFO2   | 全速 OTG 设备 IN 端点 TXFIFO 大小寄存器 2 | 0x108 |
| OTG_FS_DTXFIFO3   | 全速 OTG 设备 IN 端点 TXFIFO 大小寄存器 3 | 0x10C |

## 26.3 OTG\_FS 全局寄存器功能描述

### 26.3.1 全速 OTG 控制状态寄存器 (OTG\_FS\_GCTRLSTS)

偏移地址: 0x00

复位值: 0x0000 0800

| 位/域   | 名称      | R/W | 描述                                                                                                                                                                                                                                                           |
|-------|---------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | SREQSUC | R   | 会话请求成功 (Session Request Success)<br>0: 会话请求失败<br>1: 会话请求成功<br>注意: 只能在设备模式下使用                                                                                                                                                                                 |
| 1     | SREQ    | R/W | 请求会话 (Session Request)<br>0: 无请求会话<br>1: 请求会话<br>当设置 OTG_FS_GINT 寄存器中的 HNSUCCHG 位时, 写 0 清除该位。<br>当 HNSUCCHG 清 0 时, 该位也会清 0。<br>当使用 USB 1.1 全速串行收发器接口来会话请求时, 要在该寄存器的<br>BSVD 位清 0 后, 等待 V <sub>BUS</sub> 放电到 0.2 V。放电时间会因为 PHY 的不同<br>存在差异。<br>注意: 只能在设备模式下使用 |
| 7:2   | 保留      |     |                                                                                                                                                                                                                                                              |
| 8     | HNSUC   | R   | 主机协商成功 (Host Negotiation Success)<br>该寄存器中的 HNPREQ 置 1 时, 该位清 0<br>0: 主机协商失败<br>1: 主机协商成功<br>注意: 只能在设备模式下使用                                                                                                                                                  |
| 9     | HNPREQ  | R/W | HNP 请求 (Host Negotiation Protocol Request)<br>0: 不发送 HNP 请求<br>1: 发送 HNP 请求<br>当设置 OTG_FS_GINT 寄存器中的 HNSUCCHG 位时, 写 0 清除该位。<br>当 HNSUCCHG 清 0 时, 该位也会清 0。<br>注意: 只能在设备模式下使用                                                                                  |
| 10    | HHNPEN  | R/W | 使能主机设置 HNP (Host Set HNP Enable)<br>0: 禁用<br>1: 使能<br>注意: 只能在主机模式下使用                                                                                                                                                                                         |
| 11    | DHNPE   | R/W | 使能设备 HNP (Device HNP Enable)<br>0: 禁用<br>1: 使能<br>注意: 只能在设备模式下使用                                                                                                                                                                                             |
| 15:12 | 保留      |     |                                                                                                                                                                                                                                                              |
| 16    | CIDSTS  | R   | 连接器 ID 状态 (Connector ID Status)<br>0: OTG_FS 控制器处于 A 设备模式<br>1: OTG_FS 控制器处于 B 设备模式<br>注意: 在设备以及主机模式下均可使用                                                                                                                                                    |

| 位/域   | 名称     | R/W | 描述                                                                                                                                         |
|-------|--------|-----|--------------------------------------------------------------------------------------------------------------------------------------------|
| 17    | LSDEBT | R   | 长/短去抖动时间 (Long/Short Debounce Time)<br>指示检测到的去抖动时间。长的用于物理连接，短的用于软（程序）连接。<br>0: 长去抖动时间 (100ms+2.5μs)<br>1: 短去抖动时间 (2.5μs)<br>注意: 仅可在主机模式下使用 |
| 18    | ASVD   | R   | A 会话有效 (A-Session Valid)<br>0: 无效<br>1: 有效<br>注意: 只能在主机模式下访问                                                                               |
| 19    | BSVD   | R   | B 会话有效 (B-Session Valid)<br>在 OTG 模式下，此位可用于确认设备是否处于连接状态。<br>0: 无效<br>1: 有效<br>注意: 只能在设备模式下访问                                               |
| 31:20 | 保留     |     |                                                                                                                                            |

### 26.3.2 全速 OTG 中断寄存器 (OTG\_FS\_GINT)

偏移地址: 0x04

复位值: 0x0000 0000

| 位/域   | 名称         | R/W   | 描述                                                                                                                                     |
|-------|------------|-------|----------------------------------------------------------------------------------------------------------------------------------------|
| 1:0   | 保留         |       |                                                                                                                                        |
| 2     | SEFLG      | RC_W1 | 会话结束标志位 (Session End Flag)<br>当 $V_{BUS} < 0.8V$ 时，表示 $V_{BUS}$ 不用于 B 会话，该位置 1。                                                        |
| 7:3   | 保留         |       |                                                                                                                                        |
| 8     | SREQSUCCHG | RC_W1 | 改变会话请求成功位 (Session Request Success Bit Change)<br>如果 SREQSUC 位的值有所改变，此位置 1。                                                            |
| 9     | HNSUCCHG   | RC_W1 | 改变主机协商成功位 (Host Negotiation Success Bit Change)<br>如果 HNSUC 位的值有所改变，此位置 1。                                                             |
| 16:10 | 保留         |       |                                                                                                                                        |
| 17    | HNFLG      | RC_W1 | 主机协商标志位 (Host Negotiation Flag)<br>当检测到 USB 主机协商请求时该位置 1。                                                                              |
| 18    | ADTOFLG    | RC_W1 | A 器件超时标志位 (A-Device Timeout Flag)<br>此位如果置 1，则表示 A 器件等待 B 器件连接时超时。                                                                     |
| 19    | DEBDFLG    | RC_W1 | 去抖动完成标志位 (Debounce Done Flag)<br>设备连接且去抖动结束时该位置 1；产生中断后，USB 复位。<br>该位仅在 OTG_FS_GUSBCFG 寄存器中的 HNPEN 和 SRPEN 位置 1 时有效。<br>注意: 只能在主机模式下访问 |
| 31:20 | 保留         |       |                                                                                                                                        |

### 26.3.3 全速 OTG AHB 配置寄存器 (OTG\_FS\_GAHBCFG)

偏移地址: 0x08

复位值: 0x0000 0000

| 位/域  | 名称       | R/W | 描述                                                                                                                                                                                        |
|------|----------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | GINTMASK | R/W | 屏蔽全局中断 (Global Interrupt Mask)<br>0: 屏蔽全局中断<br>1: 取消屏蔽全局中断                                                                                                                                |
| 6:1  | 保留       |     |                                                                                                                                                                                           |
| 7    | TXFEL    | R/W | TXFIFO 空级别 (TXFIFO Empty Level)<br>设备模式下:<br>0: TXFE 中断表示 IN 端点 TXFIFO 为半空<br>1: TXFE 中断表示 IN 端点 TXFIFO 为全空<br>主机模式下:<br>0: NPTXFEM 中断表示非周期性 TXFIFO 为半空<br>1: NPTXFEM 中断表示非周期性 TXFIFO 为全空 |
| 8    | PTXFEL   | R/W | 周期性 TXFIFO 空级别 (Periodic TXFIFO Empty Level)<br>0: PTXFE 中断表示周期性 TXFIFO 为半空<br>1: PTXFE 中断表示周期性 TXFIFO 为全空<br>注意: 只能在主机模式下访问                                                              |
| 31:9 | 保留       |     |                                                                                                                                                                                           |

#### 26.3.4 全速 OTG USB 配置寄存器 (OTG\_FS\_GUSBCFG)

偏移地址: 0x0C

复位值: 0x0000 0A00

| 位/域   | 名称      | R/W | 描述                                                                                                                                                                  |
|-------|---------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0   | SEFLG   | R/W | 校准 FS 超时 (FS Timeout Calibrate)<br>PHY 的额外延迟包含 PHY 的时钟数量以及 FS 超时间隔, 数据线的状态会因 PHY 的不同存在差异。<br>OTG_FS 的超时值为 16~18 个位时间。                                               |
| 5:3   | 保留      |     |                                                                                                                                                                     |
| 6     | FSSTSEL | W   | 选择全速串行收发器 (Full-Speed Serial Transceiver Select)<br>0: USB2.0 全速 ULPI PHY<br>1: USB1.1 全速串行收发器<br>此位始终为 1。                                                          |
| 7     | 保留      |     |                                                                                                                                                                     |
| 8     | SRPEN   | R/W | 使能 SRP (SRP Enable)<br>0: 禁用<br>1: 使能<br>如果禁止了 SRP 功能, 则无法请求连接器件激活 $V_{BUS}$ , 也不能开始会话。                                                                             |
| 9     | HNPEN   | R/W | 使能 HNP (HNP Enable)<br>0: 禁用<br>1: 使能                                                                                                                               |
| 13:10 | TRTIM   | R/W | USB 周转时间 (USB Turnaround Time)<br>$f_{PHYCLK}=48MHz$ , 以 $f_{PHYCLK}$ 为单位。<br>$TRTIM=4 \times f_{AHBCLK} + f_{PHYCLK}$<br>例:<br>当 $f_{AHBCLK}=72MHz$ 时, TRTIM 设置为 7 |

| 位/域   | 名称     | R/W | 描述                                                             |
|-------|--------|-----|----------------------------------------------------------------|
| 28:14 | 保留     |     |                                                                |
| 29    | FHMODE | R/W | 强制主机模式 (Forced Host Mode)<br>0: 正常模式<br>1: 主机模式                |
| 30    | FDMODE | R/W | 强制设备模式 (Forced Device Mode)<br>0: 正常模式<br>1: 设备模式              |
| 31    | CTXP   | R/W | 发送数据包损坏 (Corrupt TX Packet)<br>调试位, 禁止置 1<br>注意: 在设备和主机模式下进行访问 |

### 26.3.5 全速 OTG 复位寄存器 (OTG\_FS\_GRSTCTRL)

偏移地址: 0x10

复位值: 0x2000 0000

| 位/域 | 名称       | R/W | 描述                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----|----------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | CSRST    | R/S | <p>软件复位模块 (Core Soft Reset)<br/>该位控制 HCLK 和 PCLK 复位<br/>除以下各位外, 将各个中断和所有控制状态寄存器位清零:</p> <ul style="list-style-type: none"> <li>● OTG_FS_PCGCTRL 中的 GCLK 位</li> <li>● OTG_FS_PCGCTRL 中的 PCLKSTOP 位</li> <li>● OTG_FS_HCFG 中的 PHYCLKSEL 位</li> <li>● OTG_FS_DCFG 中的 DSPDSEL 位</li> </ul> <p>将 AHB 从机复位为空闲状态, 清空 TXFIFO 和 RXFIFO, 当结束 AHB 传输后, 应尽快中止 AHB 的所有事务, 立即中止 USB 上的所有事务。</p> <p>一般在以下两种情况下使用软件复位:</p> <ul style="list-style-type: none"> <li>● 软件开发期间。</li> <li>● 用户动态更改以上所列 USB 配置寄存器中的 PHY 选择位后。用户更改 PHY 时, 将为 PHY 选择相应的时钟并用于 PHY 域中。一旦选择了新的时钟, 则必须复位 PHY 域, 才能保证正常运行。</li> </ul> |
| 1   | HSRST    | R/S | <p>软件复位 HCLK (HCLK Soft Reset)<br/>该位用于刷新 AHB 时钟域的控制逻辑。<br/>清除该中断时, 需要清除对应的屏蔽中断状态控制位; 当中断状态位未清零时, 可以读取该位置 1 后的事件状态。</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 2   | HFCNTRST | R/S | <p>复位主机帧计数器 (Host Frame Counter Reset)<br/>通过写该位复位主机中的帧数计数器, 复位后, 后续发送的 SOF 帧号为 0。<br/>注意: 只在主机模式下访问。</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 3   | 保留       |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 4   | RXFFLU   | R/S | <p>刷新 RXFIFO (RXFIFO Flush)<br/>该位用于刷新整个 RXFIFO, 在对该位执行写操作之前, 需要确保模块未对 RXFIFO 执行读写操作。<br/>该位清 0 后, 其他操作才可执行 (通常需要等待 8 个时钟周期)。</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 5   | TXFFLU   | R/S | 刷新 TXFIFO (TXFIFO Flush)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

| 位/域   | 名称      | R/W | 描述                                                                                                                                                                                                                                                                                                     |
|-------|---------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |         |     | 该位用于刷新一个或所有 TXFIFO，在对该位执行写操作之前，需要确保模块未对 TXFIFO 执行读写操作。                                                                                                                                                                                                                                                 |
| 10:6  | TXFNUM  | R/W | <p>TXFIFO 编号 (TXFIFO Number)<br/>使用 TXFIFO 刷新位刷新 FIFO 编号，这些位只能在刷新 TXFFIO 清 0 后更改。</p> <p>主机模式下：</p> <p>00000: 刷新非周期性 TXFIFO<br/>00001: 刷新周期性 TXFIFO<br/>10000: 刷新所有 TXFIFO</p> <p>设备模式下：</p> <p>00000: 刷新 TXFIFO 0<br/>00001: 刷新 TXFIFO 1<br/>.....<br/>00101: 刷新 TXFIFO 15<br/>10000: 刷新所有 TXFIFO</p> |
| 30:11 |         |     | 保留                                                                                                                                                                                                                                                                                                     |
| 31    | AHBMIDL | R   | <p>AHB 主设备空闲 (AHB Master Idle)<br/>该位表示 AHB 主设备是否处于空闲状态。</p>                                                                                                                                                                                                                                           |

### 26.3.6 全速 OTG 模块中断寄存器 (OTG\_FS\_GCINT)

偏移地址: 0x14

复位值: 0x0400 0020

为了避免在初始化前产生中断，软件必须在使能中断位前将此寄存器清零。

| 位/域 | 名称       | R/W   | 描述                                                                                                                                                                                                                             |
|-----|----------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | CURMOSEL | R     | <p>选择当前工作模式 (Current Mode of Operation Select)<br/>0: 设备模式<br/>1: 主机模式</p>                                                                                                                                                     |
| 1   | MMIS     | RC_W1 | <p>模式不匹配中断 (Mode Mismatch Interrupt)<br/>访问以下寄存器时，该位置 1:</p> <ul style="list-style-type: none"> <li>在设备模式下访问主机模式寄存器</li> <li>在主机模式下访问设备模式寄存器</li> </ul>                                                                        |
| 2   | OTG      | R     | <p>OTG 中断 (OTG Interrupt)<br/>该位被置 1 时表示发生 OTG 协议事件。<br/>通过读取 OTG_FS_GINT 寄存器确定引发 OTG 中断的事件，在清除该寄存器的相应位后才能清零此位。</p>                                                                                                            |
| 3   | SOF      | RC_W1 | <p>帧起始中断 (Start of Frame Interrupt)<br/>当此位被置位时:</p> <ul style="list-style-type: none"> <li>主机模式下，表示 USB 已发送一个 SOF (FS) 或者 Keep-Alive (LS);</li> <li>设备模式下，表示 USB 已接收到一个 SOF，可以通过读取设备状态寄存器获取当前的帧编号。仅在 FS 模式运行下产生中断。</li> </ul> |
| 4   | RXFNONE  | R     | RXFIFO 非空中断 (RXFIFO Nonempty Interrupt)<br>该位表示 RXFIFO 中还有数据包没有被读取。                                                                                                                                                            |
| 5   | NPTXFEM  | R     | 非周期性 TXFIFO 空中断 (Nonperiodic TXFIFO Empty Interrupt)                                                                                                                                                                           |

| 位/域   | 名称        | R/W   | 描述                                                                                                                                                                                                                           |
|-------|-----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |           |       | 当非周期性 TXFIFO 为非空且请求队列中存在可写入条目的空间时, 将触发此中断。<br>注意: 仅在主机模式下访问                                                                                                                                                                  |
| 6     | GINNPNAKE | R     | 全局非周期性 IN NAK 有效中断 (Global IN Nonperiodic NAK Effective Interrupt)<br>该位表示 OTG_FS_DCTRL 寄存器的 GINAKSET 位有效; 可以通过清除 OTG_FS_DCTRL 寄存器的 GINAKCLR 位, 清除该位。<br>由于 STALL 优先级高于 NAK 位, 所以产生此中断并不能说明 USB 已发送 NAK 信号。<br>注意: 仅在设备模式下访问 |
| 7     | GONAKE    | R     | 全局 OUT NAK 有效中断 (Global OUT NAK Effective Interrupt)<br>该位表示 OTG_FS_DCTRL 寄存器的 GONAKSET 有效; 可以通过清除 OTG_FS_DCTRL 中的 GONALCLR 位, 清除该位。<br>注意: 仅在设备模式下访问                                                                        |
| 9:8   |           |       | 保留                                                                                                                                                                                                                           |
| 10    | ESUS      | RC_W1 | 早期挂起中断 (Early Suspend Interrupt)<br>当 USB 处于空闲状态已经达到 3ms 时, 该位置 1。<br>注意: 仅在设备模式下访问                                                                                                                                          |
| 11    | USBSUS    | RC_W1 | USB 挂起中断 (USB Suspend Interrupt)<br>当检测到 USB 挂起时, 该位置 1; 当 USB 空闲状态保持 3ms 时, USB 进入挂起状态。<br>注意: 仅在设备模式下访问                                                                                                                    |
| 12    | USBRST    | RC_W1 | USB 复位中断 (USB Reset Interrupt)<br>当在 USB 上检测到复位时, 该位置 1。<br>注意: 仅在设备模式下访问                                                                                                                                                    |
| 13    | ENUMD     | RC_W1 | 枚举完成中断 (Enumeration Done Interrupt)<br>当完成速度枚举时, 该位置 1。<br>注意: 仅在设备模式下访问                                                                                                                                                     |
| 14    | ISOPD     | RC_W1 | 丢弃同步 OUT 数据包中断 ((Isochronous OUT Packet Dropped Interrupt)<br>当 RXFIFO 空间不足, 模块无法向 RXFIFO 写入同步 OUT 数据包时, 该位置 1。<br>注意: 仅在设备模式下访问                                                                                             |
| 15    | EOPF      | RC_W1 | 周期性帧结束中断 (End of Periodic Frame Interrupt)<br>该位表示当前帧达到 OTG_FS_DCFG 寄存器中的 PFITV 位所指定的周期。<br>注意: 仅在设备模式下访问                                                                                                                    |
| 17:16 |           |       | 保留                                                                                                                                                                                                                           |
| 18    | INEP      | R     | IN 端点中断 (IN Endpoint Interrupt)<br>当一个 IN 端点存在挂起中断时, 该位置 1。<br>通过读取 OTG_FS_DAEPINT 寄存器确定发生中断的 IN 端点的编号, 通过读取 OTG_FS_DIEPINTx 寄存器确定触发中断的原因。<br>如果要清除该位, 要先清除 OTG_FS_DIEPINTx 寄存器的相应状态位。<br>注意: 仅在设备模式下访问                      |
| 19    | ONEP      | R     | OUT 端点中断 (OUT Endpoint Interrupt)                                                                                                                                                                                            |

| 位/域   | 名称        | R/W   | 描述                                                                                                                                                                                                                                     |
|-------|-----------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |           |       | <p>当一个 OUT 端点存在挂起中断时, 该位置 1。</p> <p>通过读取 OTG_FS_DAEPIINT 寄存器确定发生中断的 OUT 端点的编号, 通过读取 OTG_FS_DOEPINTx 寄存器确定触发中断的原因。</p> <p>如果要清除该位, 要先清除 OTG_FS_DOEPINTx 寄存器的相应状态位。</p> <p>注意: 仅在设备模式下访问</p>                                             |
| 20    | IIINTX    | RC_W1 | <p>未完成 IN 同步传输中断 (Incomplete Isochronous IN Transfer Interrupt)</p> <p>当前帧中至少有一个同步 IN 端点上的传输未完成时, 该位置 1。</p> <p>该中断与 EOPF 同时触发。</p> <p>注意: 仅在设备模式下访问</p>                                                                               |
| 21    | IP_OUTTX  | RC_W1 | <p>未完成周期性传输中断 (Incomplete Periodic Transfer Interrupt)</p> <p>此位在不同模式下, 此位置 1 时指示的中断不同。</p> <p>在主机模式下, 计划在当前帧应完成的周期性事务仍处于挂起状态 (即未完成), 将触发未完成周期性传输中断。</p> <p>在设备模式下, 当前帧中至少有一个同步 OUT 端点上的传输未完成时, 将触发未完成 OUT 同步传输中断, 该中断与 EOPF 同时触发。</p> |
| 23:22 | 保留        |       |                                                                                                                                                                                                                                        |
| 24    | HPORT     | R     | <p>主机端口中断 (Host Port Interrupt)</p> <p>当主机模式下全速 OTG 控制器端口的状态发生变化时, 该位置 1。</p> <p>注意: 仅在主机模式下访问</p>                                                                                                                                     |
| 25    | HCHAN     | R     | <p>主机通道中断 (Host Channels Interrupt)</p> <p>当主机通道上存在挂起中断时, 该位置 1。</p> <p>注意: 仅在主机模式下访问</p>                                                                                                                                              |
| 26    | PTXFE     | R     | <p>周期性 TXFIFO 空中断 (Periodic TXFIFO Empty Interrupt)</p> <p>当周期性 TXFIFO 为空且请求队列中存在可写入条目的空间时, 将触发此中断。注意: 仅在主机模式下访问</p>                                                                                                                   |
| 27    | 保留        |       |                                                                                                                                                                                                                                        |
| 28    | CINSTSCHG | RC_W1 | <p>连接器 ID 线更改状态中断 (Connector ID Status Change Interrupt)</p> <p>当连接器 ID 线状态发生更改时, 该位置 1。</p> <p>注意: 在主机和设备模式下均可访问</p>                                                                                                                  |
| 29    | DEDIS     | RC_W1 | <p>断开连接中断 (Device Disconnect Interrupt)</p> <p>当检测到设备断开连接时, 该位置 1。</p> <p>注意: 仅在主机模式下访问</p>                                                                                                                                            |
| 30    | SREQ      | RC_W1 | <p>会话请求/新会话中断 (Session Request/New Session Interrupt)</p> <p>在不同模式下, 触发此中断的条件:</p> <ul style="list-style-type: none"> <li>● 主机模式下, 检测到会话请求</li> <li>● 设备模式下, VBUS 在 B 器件的范围内</li> </ul>                                                |
| 31    | RWAKE     | RC_W1 | <p>恢复/远程唤醒中断 (Resume/Remote Wakeup Interrupt)</p> <p>在不同模式下, 触发此中断的条件:</p> <ul style="list-style-type: none"> <li>● 主机模式下, 在 USB 上检测到远程唤醒信号</li> <li>● 设备模式下, 在 USB 总线上检测到恢复信号</li> </ul>                                              |

### 26.3.7 全速 OTG 模块中断屏蔽寄存器 (OTG\_FS\_GINTMASK)

偏移地址: 0x18

复位值: 0x0000 0000

此寄存器用于屏蔽中断, 但中断寄存器的相应位仍会置 1。

| 位/域 | 名称         | R/W | 描述                                                                                                            |
|-----|------------|-----|---------------------------------------------------------------------------------------------------------------|
| 0   |            |     | 保留                                                                                                            |
| 1   | MMISM      | R/W | 屏蔽模式不匹配中断 (Mode Mismatch Interrupt Mask)<br>0: 屏蔽<br>1: 不屏蔽                                                   |
| 2   | OTGM       | R/W | 屏蔽 OTG 中断 (OTG Interrupt Mask)<br>0: 屏蔽<br>1: 不屏蔽                                                             |
| 3   | SOFM       | R/W | 屏蔽帧起始中断 (Frame Start Interrupt Mask)<br>0: 屏蔽<br>1: 不屏蔽                                                       |
| 4   | RXFNONEM   | R/W | 屏蔽 RXFIFO 非空中断 (RXFIFO Nonempty Interrupt Mask)<br>0: 屏蔽<br>1: 不屏蔽                                            |
| 5   | NPTXFEMM   | R/W | 屏蔽非周期性 TXFIFO 空中断 (Nonperiodic TXFIFO Empty Interrupt Mask)<br>0: 屏蔽<br>1: 不屏蔽<br>注意: 仅在主机模式下访问               |
| 6   | GINNPNAKEM | R/W | 屏蔽全局非周期性 IN NAK 有效中断 (Global IN Nonperiodic NAK Effective Interrupt Mask)<br>0: 屏蔽<br>1: 不屏蔽<br>注意: 仅在设备模式下访问 |
| 7   | GONAKEM    | R/W | 屏蔽全局 OUT NAK 有效中断 (Global OUT NAK Effective Interrupt Mask)<br>0: 屏蔽<br>1: 不屏蔽<br>注意: 仅在设备模式下访问               |
| 9:8 |            |     | 保留                                                                                                            |
| 10  | ESUSM      | R/W | 屏蔽早期挂起中断 (Early Suspend Interrupt Mask)<br>0: 屏蔽<br>1: 不屏蔽<br>注意: 仅在设备模式下访问                                   |
| 11  | USBSUSM    | R/W | 屏蔽 USB 挂起中断 (USB Suspend Interrupt Mask)<br>0: 屏蔽<br>1: 不屏蔽<br>注意: 仅在设备模式下访问                                  |
| 12  | USBRSTM    | R/W | 屏蔽 USB 复位中断 (USB Reset Interrupt Mask)<br>0: 屏蔽<br>1: 不屏蔽<br>注意: 仅在设备模式下访问                                    |

| 位/域   | 名称        | R/W | 描述                                                                                                                                            |
|-------|-----------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 13    | ENUMDM    | R/W | 屏蔽完成枚举中断 (Enumeration Done Interrupt Mask)<br>0: 屏蔽<br>1: 不屏蔽<br>注意: 仅在设备模式下访问                                                                |
| 14    | ISOPDM    | R/W | 屏蔽丢弃同步 OUT 数据包中断 ((Isochronous OUT Packet Dropped Interrupt Mask)<br>0: 屏蔽<br>1: 不屏蔽<br>注意: 仅在设备模式下访问                                         |
| 15    | EOPFM     | R/W | 屏蔽周期性帧结束中断 (End of Periodic Frame Interrupt Mask)<br>0: 屏蔽<br>1: 不屏蔽<br>注意: 仅在设备模式下访问                                                         |
| 16    |           |     | 保留                                                                                                                                            |
| 17    | EPMISM    | R/W | 屏蔽端点不匹配中断 (Endpoint Mismatch Interrupt Mask)<br>0: 屏蔽<br>1: 不屏蔽<br>注意: 仅在设备模式下访问                                                              |
| 18    | INEPM     | R/W | 屏蔽 IN 端点中断 (IN Endpoint Interrupt Mask)<br>0: 屏蔽<br>1: 不屏蔽<br>注意: 仅在设备模式下访问                                                                   |
| 19    | OUTEPM    | R/W | 屏蔽 OUT 端点中断 (OUT Endpoint Interrupt Mask)<br>0: 屏蔽<br>1: 不屏蔽<br>注意: 仅在设备模式下访问                                                                 |
| 20    | IIINTXM   | R/W | 屏蔽未完成 IN 同步传输中断 (Incomplete Isochronous IN Transfer Interrupt Mask)<br>0: 屏蔽<br>1: 不屏蔽<br>注意: 仅在设备模式下访问                                       |
| 21    | IP_OUTTXM | R/W | 屏蔽未完成周期性传输中断 (Incomplete Periodic Transfer Interrupt Mask)<br>主机模式下, 此位控制是否屏蔽未完成周期性传输中断。<br>设备模式下, 此位控制是否屏蔽未完成 OUT 同步传输中断。<br>0: 屏蔽<br>1: 不屏蔽 |
| 23:22 |           |     | 保留                                                                                                                                            |
| 24    | HPORTM    | R/W | 屏蔽主机端口中断 (Host Port Interrupt Mask)<br>0: 屏蔽<br>1: 不屏蔽<br>注意: 仅在主机模式下访问                                                                       |
| 25    | HCHM      | R/W | 屏蔽主机通道中断 (Host Channels Interrupt Mask)<br>0: 屏蔽<br>1: 不屏蔽                                                                                    |

| 位/域 | 名称       | R/W | 描述                                                                                                  |
|-----|----------|-----|-----------------------------------------------------------------------------------------------------|
|     |          |     | 注意：仅在主机模式下访问                                                                                        |
| 26  | PTXFEM   | R/W | 屏蔽周期性 TXFIFO 空中断 (Periodic TXFIFO Empty Interrupt Mask)<br>0: 屏蔽<br>1: 不屏蔽<br>注意：仅在主机模式下访问          |
| 27  |          |     | 保留                                                                                                  |
| 28  | CIDSTSCM | R/W | 屏蔽连接器 ID 线更改状态中断 (Connector ID Status Change Interrupt Mask)<br>0: 屏蔽<br>1: 不屏蔽<br>注意：在主机和设备模式下均可访问 |
| 29  | DEDISM   | R/W | 屏蔽断开连接中断 (Device Disconnect Interrupt Mask)<br>0: 屏蔽<br>1: 不屏蔽<br>注意：仅在设备模式下访问                      |
| 30  | SREQM    | R/W | 屏蔽会话请求/新会话中断 (Session Request/New Session Interrupt Mask)<br>0: 屏蔽<br>1: 不屏蔽                        |
| 31  | RWAKEM   | R/W | 屏蔽恢复/远程唤醒中断 (Resume/Remote Wakeup Interrupt Mask)<br>0: 屏蔽<br>1: 不屏蔽<br>注意：在主机和设备模式下均可访问            |

### 26.3.8 全速 OTG 读取调试接收状态寄存器/全速 OTG 状态读取和出栈寄存器 (OTG\_FS\_GRXSTS/OTG\_FS\_GRXSTSP)

读取偏移地址：0x1C

出栈偏移地址：0x20

复位值：0x0000 0000

#### 主机模式

| 位/域   | 名称    | R/W | 描述                                                                                                  |
|-------|-------|-----|-----------------------------------------------------------------------------------------------------|
| 3:0   | CHNUM | R   | 通道编号 (Channel Number)<br>该位表示接受的数据包是由哪个通道传输的。                                                       |
| 14:4  | BCNT  | R   | 字节计数 (Byte Count)<br>该位表示接收的 IN 数据包的字节数。                                                            |
| 16:15 | DPID  | R   | 数据 PID (Data Packet ID)<br>该位表示接收的数据包的 ID (PID)<br>00: DATA0<br>10: DATA1<br>01: DATA2<br>11: MDATA |

| 位/域   | 名称   | R/W | 描述                                                                                                                   |
|-------|------|-----|----------------------------------------------------------------------------------------------------------------------|
| 20:17 | PSTS | R   | 数据包状态 (Packet Status)<br>该位表示接收的数据包的状态。<br>0010: 接收到 IN 数据包<br>0011: IN 传输完成<br>0101: 数据同步错误<br>0111: 通道停止<br>其他: 保留 |
| 31:21 |      |     | 保留                                                                                                                   |

### 设备模式

| 位/域   | 名称    | R/W | 描述                                                                                                                                                      |
|-------|-------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0   | EPNUM | R   | 端点编号 (Endpoint Number)<br>该位表示接受的数据包是由哪个端点传输的。                                                                                                          |
| 14:4  | BCNT  | R   | 字节计数 (Byte Count)<br>该位表示接收的数据包的字节数                                                                                                                     |
| 16:15 | DPID  | R   | 数据 PID (Data PID)<br>该位表示接收的数据包的 ID (PID)<br>00: DATA0<br>10: DATA1<br>01: DATA2<br>11: MDATA                                                           |
| 20:17 | PSTS  | R   | 数据包状态 (Packet Status)<br>该位表示接收的数据包的状态<br>0001: 全局 OUT NAK<br>0010: 接收到 OUT 数据包<br>0011: OUT 传输完成<br>0100: 完成 SETUP 事件<br>0110: 接收到 SETUP 数据包<br>其他: 保留 |
| 24:21 | FNUM  | R   | 帧编号 (Frame Number)<br>支持同步 OUT 端点时这些位有效。<br>这些位是 USB 上接收的数据包帧编号的 4 个最低有效位。                                                                              |
| 31:25 |       |     | 保留                                                                                                                                                      |

### 26.3.9 全速 OTG 接收 FIFO 大小寄存器 (OTG\_FS\_GRXFIFO)

偏移地址: 0x24

复位值: 0x0000 0200

| 位/域   | 名称     | R/W | 描述                                                      |
|-------|--------|-----|---------------------------------------------------------|
| 15:0  | RXFDEP | R/W | RXFIFO 深度 (RXFIFO Depth)<br>RXFIFO 以字为单位, 深度范围: 16~256。 |
| 31:16 |        |     | 保留                                                      |

### 26.3.10 全速 OTG TXFIFO 配置寄存器 (OTG\_FS\_GTXFCFG)

偏移地址: 0x28

复位值: 0x0000 0200

### 主机模式

| 位/域   | 名称       | R/W | 描述                                                                                        |
|-------|----------|-----|-------------------------------------------------------------------------------------------|
| 15:0  | NPTXSA   | R/W | 非周期性 TXFIFO RAM 起始地址 (Nonperiodic TXFIFO RAM Start Address)<br>该位表示非周期性 TXFIFO RAM 的起始地址。 |
| 31:16 | NPTXFDEP | R/W | 非周期性 TXFIFO 深度 (Nonperiodic TXFIFO Depth)<br>TXFIFO 以字为单位, 深度范围为: 16~256。                 |

### 设备模式

| 位/域   | 名称       | R/W | 描述                                                                                        |
|-------|----------|-----|-------------------------------------------------------------------------------------------|
| 15:0  | EPTXSA   | R/W | 端点 0 TXFIFO RAM 起始地址 (Endpoint0 TXFIFO RAM Start Address)<br>该位表示端点 0 的 TXFIFO RAM 的起始地址。 |
| 31:16 | EPTXFDEP | R/W | 端点 0 TXFIFO 深度 (Endpoint0 TXFIFO Depth)<br>TXFIFO 以字为单位, 深度范围为: 16~256。                   |

## 26.3.11 全速 OTG 非周期性 TXFIFO 队列状态寄存器 (OTG\_FS\_GNPTXFQSTS)

偏移地址: 0x2C

复位值: 0x0008 0200

| 位/域   | 名称      | R/W | 描述                                                                                                                                                                                                                     |
|-------|---------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0  | NPTXFSA | R   | 非周期性 TXFIFO 可用空间 (Nonperiodic TXFFIO Space Available)<br>这些位表示非周期性 TXFIFO 的可用空间的大小。(以 32 位字为单位) 0x0: 非周期性 TXFIFO 满<br>0x1: 1 个字<br>0x2: 2 个字<br>.....<br>0xn: n 个字可用 (0≤n≤256)<br>其他: 保留                               |
| 23:16 | NPTXRSA | R   | 非周期性发送请求队列可用空间 (Nonperiodic Transmit Request Space Available)<br>该位表示非周期性发送请求队列的可用空间大小。<br>主机模式下: 保存 IN 和 OUT 请求<br>设备模式下: 只有 IN 请求<br>0x0: 队列已满<br>0x0: 1 个位置<br>0x2: 2 个位置<br>.....<br>0xn: n 位置可用 (0≤n≤8)<br>其他: 保留 |
| 30:24 | NPTXRQ  | R   | 非周期性发送请求队列 (Nonperiodic Transmit Request Queue)<br>位 24: 终止 (选定通道/端点的最后数据)<br>位[26:25]:                                                                                                                                |

| 位/域 | 名称 | R/W | 描述                                                                                                           |
|-----|----|-----|--------------------------------------------------------------------------------------------------------------|
|     |    |     | 00: IN/OUT 令牌<br>01: 发送数据包长度为 0 (设备模式下 IN/主机模式下 OUT)<br>10: PING/CPLIT 令牌<br>11: 停止通道指令<br>位[30:27]: 通道/端点编号 |
| 31  |    |     | 保留                                                                                                           |

### 26.3.12 全速 OTG 通用模块配置寄存器 (OTG\_FS\_GGCCFG)

偏移地址: 0x38

复位值: 0x0000 0000

| 位/域   | 名称      | R/W | 描述                                                                                                      |
|-------|---------|-----|---------------------------------------------------------------------------------------------------------|
| 15:0  |         |     | 保留                                                                                                      |
| 16    | PWEN    | R/W | 使能掉电 (Power Down Enable)<br>该位用于激活收发器。<br>0: 掉电激活<br>1: 掉电失活 (激活收发器)                                    |
| 17    |         |     | 保留                                                                                                      |
| 18    | ADVBSEN | R/W | 使能 A 设备 V <sub>BUS</sub> 感应功能 (A Device V <sub>BUS</sub> Sensing Enable)<br>0: 禁用<br>1: 使能              |
| 19    | BDVBSEN | R/W | 使能 B 设备 V <sub>BUS</sub> 感应功能 (B Device V <sub>BUS</sub> Sensing Enable)<br>0: 禁用<br>1: 使能              |
| 20    | SOFPOUT | R/W | PAD 输出 SOF 脉冲 (SOF Pulse Available on PAD Output)<br>该位选择 SOF 脉冲能否从 PAD 输出。<br>0: 不能<br>1: 能            |
| 21    | VBSDIS  | R/W | 禁止 V <sub>BUS</sub> 感应 (VBUS Sensing Disable)<br>0: 支持 V <sub>BUS</sub> 感应<br>1: 禁止 V <sub>BUS</sub> 感应 |
| 31:22 |         |     | 保留                                                                                                      |

### 26.3.13 全速 OTG 模块 ID 寄存器 (OTG\_FS\_GCID)

偏移地址: 0x3C

复位值: 0x0000 1100

| 位/域  | 名称  | R/W | 描述                                    |
|------|-----|-----|---------------------------------------|
| 31:0 | PID | R/W | 产品 ID (Product ID)<br>可以通过该位编程产品的 ID。 |

### 26.3.14 全速 OTG 主机周期性 TXFIFO 大小寄存器 (OTG\_FS\_GHPTXFSIZE)

偏移地址: 0x100

复位值: 0x0200 0600

| 位/域   | 名称        | R/W | 描述                                                                     |
|-------|-----------|-----|------------------------------------------------------------------------|
| 15:0  | HPDTXFSA  | R/W | 主机周期性 TXFIFO 起始地址 (Host Periodic TXFIFO Start Address)                 |
| 31:16 | HPDTXFDEP | R/W | 主机周期性 TXFIFO 深度 (Host Periodic TXFIFO Depth)<br>TXFIFO 以字为单位, 最小值为 16。 |

### 26.3.15 全速 OTG 设备 IN 端点 TXFIFO 大小寄存器 x

(OTG\_FS\_DIEPTXFIFOx) (x=1~3)

偏移地址: 0x104+4(x-1)

复位值: 0x0200 0400

x 为 FIFO 编号。

| 位/域   | 名称         | R/W | 描述                                                                                                                       |
|-------|------------|-----|--------------------------------------------------------------------------------------------------------------------------|
| 15:0  | INEPTXFRSA | R/W | IN 端点 TXFIFOx RAM 起始地址 (IN Endpoint TXFIFOx Transmit RAM Start Address)<br>这些位表示 IN 端点 TXFIFOx RAM 的起始地址, 需要与 32 位存储器对齐。 |
| 31:16 | INEPTXFDEP | R/W | IN 端点 TXFIFO 深度 (IN Endpoint TXFIFO Depth)<br>TXFIFO 以字为单位, 最小值为 16。                                                     |

## 26.4 OTG\_FS 主机模式寄存器地址映射

表格 129 OTG\_FS 主机模式寄存器地址映射

| 寄存器名             | 描述                             | 偏移地址       |
|------------------|--------------------------------|------------|
| OTG_FS_HCFG      | 全速 OTG 主机配置寄存器                 | 0x400      |
| OTG_FS_HFIVL     | 全速 OTG 主机帧间隔寄存器                | 0x404      |
| OTG_FS_HFIFM     | 全速 OTG 主机帧信息寄存器                | 0x408      |
| OTG_FS_HPTXSTS   | 全速 OTG 主机定期发送状态寄存器             | 0x410      |
| OTG_FS_HACHINT   | 全速 OTG 主机所有通道中断寄存器             | 0x414      |
| OTG_FS_HACHIMASK | 全速 OTG 主机所有通道中断屏蔽寄存器           | 0x418      |
| OTG_FS_HPORTCSTS | 全速 OTG 主机端口控制状态寄存器             | 0x440      |
| OTG_FS_HCHX      | 全速 OTG 主机通道 X 特性寄存器(X=0...7)   | 0x500+20*X |
| OTG_FS_HCHINTX   | 全速 OTG 主机通道 X 中断寄存器(X=0...7)   | 0x508+20*X |
| OTG_FS_HCHIMASKX | 全速 OTG 主机通道 X 中断屏蔽寄存器(X=0...7) | 0x50C+20*X |
| OTG_FS_HCHTSIZEX | 全速 OTG 主机通道 X 传输大小寄存器(X=0...7) | 0x510+20*X |

## 26.5 OTG\_FS 主机模式寄存器功能描述

### 26.5.1 全速 OTG 主机配置寄存器 (OTG\_FS\_HCFG)

偏移地址: 0x400

复位值: 0x0000 0000

| 位/域  | 名称        | R/W | 描述                                                                                                                                                                                                                                                                                                                                                                                                        |
|------|-----------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0  | PHYCLKSEL | R/W | <p>选择 FS/LS PHY 时钟 (FS/LS PHY Clock Select)</p> <ul style="list-style-type: none"> <li>● 处于 FS 模式时:           <ul style="list-style-type: none"> <li>01: PHY 时钟为 48MHz</li> <li>其他: 保留</li> </ul> </li> <li>● 处于 LS 模式时:           <ul style="list-style-type: none"> <li>00: 保留</li> <li>01: PHY 时钟为 48MHz</li> <li>10: PHY 时钟为 6MHz</li> <li>11: 保留</li> </ul> </li> </ul> <p>注意: 此位的值被更改后需要进行软件复位。</p> |
| 2    | FSSPT     | R   | <p>支持 FS (FS Support)</p> <p>主机连接设备后, 可选择主机是否跟随设备支持的最大速度。若此位置 1, 那么就算设备支持 HS 模式, 主机最高支持 FS。</p> <p>0: 主机可支持 HS/FS/LS</p> <p>1: 主机仅支持 FS/LS</p>                                                                                                                                                                                                                                                            |
| 31:3 | 保留        |     |                                                                                                                                                                                                                                                                                                                                                                                                           |

### 26.5.2 全速 OTG 主机帧间隔寄存器 (OTG\_FS\_HFIVL)

偏移地址: 0x404

复位值: 0x0000 EA60

只有使能了端口 (将 OTG\_FS\_HPORTCSTS 寄存器的 PEN 位置 1) 后, 才能编辑此寄存器。

| 位/域   | 名称   | R/W | 描述                                                                                                                       |
|-------|------|-----|--------------------------------------------------------------------------------------------------------------------------|
| 15:0  | FIVL | R/W | <p>帧间隔 (Frame Interval)</p> <p>此位用于控制两个连续的 SOF (FS)、micro-SOF (HS)、Keep-Alive (LS) 之间的时间间隔。</p> <p>时间间隔=帧持续时间×PHY 时钟</p> |
| 31:16 | 保留   |     |                                                                                                                          |

### 26.5.3 全速 OTG 主机帧信息寄存器 (OTG\_FS\_HFIFM)

偏移地址: 0x408

复位值: 0x0000 3FFF

| 位/域   | 名称     | R/W | 描述                                                                                                                         |
|-------|--------|-----|----------------------------------------------------------------------------------------------------------------------------|
| 15:0  | FNUM   | R   | <p>帧序号 (Frame Number)</p> <p>此位用于指示当前的帧序号。当达到 0x3FFF 则此位清零。</p>                                                            |
| 31:16 | FRTIME | R   | <p>帧剩余时间 (Frame Remaining Time)</p> <p>此位用于指示当前的帧剩余时间。初始值为 OTG_FS_HFIVL 的值, 每过去一个 PHY 时钟, 此位的值减 1, 当达到 0 时此位重新装载帧间隔的值。</p> |

### 26.5.4 全速 OTG 主机定期发送状态寄存器 (OTG\_FS\_HPTXSTS)

偏移地址: 0x410

复位值: 0x0008 0100

| 位/域   | 名称     | R/W | 描述                                                                                                                                                                                                         |
|-------|--------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0  | FSPACE | R/W | 周期性发送数据 FIFO 空余空间 (Periodic Transmit Data FIFO Available Space)<br>此位表示周期性 TXFIFO 的空闲空间 (以 32 位字为单位)。<br>0x0: TXFIFO 已满<br>0x1: 1 个字<br>0x2: 2 个字<br>0xn: n 个字可用 (0<n<512)<br>其他: 保留                       |
| 23:16 | QSPACE | R   | 周期性发送请求队列可用空间 (Periodic Transmit Request Queue Available Space)<br>此位表示周期性发送请求队列的可用空间。<br>0x0: 队列已满<br>0x1: 1 个位置<br>0x2: 2 个位置<br>0xn: n 个位置可用 (0<n<8)<br>其他: 保留                                          |
| 31:24 | QTOP   | R   | 周期性发送队列头 (Top of the Periodic Transmit Request Queue)<br>此位表示周期性发送请求队列中正在处理的事务。<br>[24]: 结束<br>[26:25]: 类型<br>00: IN/OUT<br>01: 零长度数据包<br>11: 禁用通道命令<br>[30:27]: 通道/端点序号<br>[31]: 奇/偶帧<br>0: 偶数帧<br>1: 奇数帧 |

### 26.5.5 全速 OTG 主机所有通道中断寄存器 (OTG\_FS\_HACHINT)

偏移地址: 0x414

复位值: 0x0000 0000

| 位/域   | 名称     | R/W | 描述                                                              |
|-------|--------|-----|-----------------------------------------------------------------|
| 15:0  | ACHINT | R   | 所有通道中断 (All Channels Interrupts)<br>第 X 位代表通道 X 的中断。最多有 16 个通道。 |
| 31:16 |        |     | 保留                                                              |

### 26.5.6 全速 OTG 主机所有通道中断屏蔽寄存器 (OTG\_FS\_HACHIMASK)

偏移地址: 0x418

复位值: 0x0000 0000

| 位/域   | 名称       | R/W | 描述                                                                                          |
|-------|----------|-----|---------------------------------------------------------------------------------------------|
| 15:0  | ACHIMASK | R/W | 屏蔽所有通道中断 (All Channels Interrupts Mask)<br>第 X 位代表通道 X 的中断屏蔽。最多有 16 个通道。<br>0: 屏蔽<br>1: 不屏蔽 |
| 31:16 |          |     | 保留                                                                                          |

### 26.5.7 全速 OTG 主机端口控制状态寄存器 (OTG\_FS\_HPORTCSTS)

偏移地址: 0x440

复位值: 0x0000 0000

| 位/域   | 名称       | R/W   | 描述                                                                                                       |
|-------|----------|-------|----------------------------------------------------------------------------------------------------------|
| 0     | PCNNTFLG | R     | 端口连接标志 (Port Connect Flag)<br>0: 端口未连接<br>1: 端口已连接                                                       |
| 1     | PCINTFLG | RC_W1 | 端口连接中断标志 (Port Connect Interrupt Flag)<br>当端口连接到设备时, 此位置 1。                                              |
| 2     | PEN      | RC_W0 | 使能端口 (Port Enable)<br>端口复位序列后, 程序无法对此位进行写操作, 只能通过模块使能端口, 对此位清零则禁止端口。<br>0: 禁用<br>1: 使能                   |
| 3     | PENCHG   | RC_W1 | 改变端口使能位 (PEN Bit Change)<br>此寄存器的 PEN 位改变时, 此位置 1。                                                       |
| 4     | POVC     | R     | 端口过载 (Port Overcurrent)<br>此位表示端口有无过载。<br>0: 无过载<br>1: 过载                                                |
| 5     | POVCCCHG | RC_W1 | 改变端口过载位 (POVC Bit Change)<br>POVC 位改变时, 此位置 1。                                                           |
| 6     | PRS      | R/W   | 端口恢复 (Port Resume)<br>0: 未驱动恢复信号<br>1: 驱动恢复信号                                                            |
| 7     | PSUS     | R/S   | 挂起端口 (Port Suspend)<br>0: 端口未挂起<br>1: 端口挂起                                                               |
| 8     | PRST     | R/W   | 复位端口 (Port Reset)<br>此位置 1 并保持 10ms 以上, 端口才启动复位。<br>0: 未处于复位状态<br>1: 处于复位状态                              |
| 9     |          |       | 保留                                                                                                       |
| 11:10 | PDLSTS   | R     | 端口数据队列状态 (Port Data Line Status)<br>此位表示此时 USB 数据线的逻辑电平。<br>[10]位表示 OTG_FS_FS_DP<br>[11]位表示 OTG_FS_FS_DM |
| 12    | PP       | R/W   | 端口电源 (Port Power)<br>此位控制端口的电源通电情况, 如果有过载, 则会掉电 (清 0)。<br>0: 掉电<br>1: 通电                                 |

| 位/域   | 名称      | R/W | 描述                                                                                                                                                             |
|-------|---------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16:13 | PTSEL   | R/W | 选择端口测试模式 (Port Test Mode Select)<br>0000: 禁用测试<br>0001: Test_J<br>0010: Test_K<br>0011: Test_SE0_NAK<br>0100: Test_Packet<br>0101: Test_Force_Enable<br>其他: 保留 |
| 18:17 | PSPDSEL | R   | 选择端口速度 (Port Speed Select)<br>01: 全速<br>10: 低速<br>11: 保留                                                                                                       |
| 31:19 |         |     | 保留                                                                                                                                                             |

### 26.5.8 全速 OTG 主机通道 X 特性寄存器 (OTG\_FS\_HCHX) (X=0…7)

偏移地址: 0x500+20\*X

复位值: 0x0000 0000

| 位/域   | 名称       | R/W | 描述                                                                                                            |
|-------|----------|-----|---------------------------------------------------------------------------------------------------------------|
| 10:0  | MAXPSIZE | R/W | 最大数据包大小 (Maximum Data Packet Size)<br>此位表示连接主机的设备端点的最大数据包的大小。                                                 |
| 14:11 | EDPNUM   | R/W | 端点序号 (Endpoint Number)<br>此位表示连接主机的设备端点的序号。                                                                   |
| 15    | EDPDRT   | R/W | 端点方向 (Endpoint Direction)<br>0: OUT<br>1: IN                                                                  |
| 16    |          |     | 保留                                                                                                            |
| 17    | LSDV     | R/W | 低速设备 (Low-speed Device)<br>此位表示连接了低速设备。                                                                       |
| 19:18 | EDPTYP   | R/W | 端点类型 (Endpoint Type)<br>此位选择端点的传输类型。<br>00: 控制<br>01: 同步<br>10: 批量<br>11: 中断                                  |
| 21:20 | CNTSEL   | R/W | 选择计数器作用 (Count Function Select)<br>此寄存器中, 这个位只用作表示周期性端点每帧必须执行的事务数。<br>00: 保留<br>01: 1 个<br>10: 2 个<br>11: 3 个 |
| 28:22 | DVADDR   | R/W | 设备地址 (Device Address)<br>此位表示连接主机的设备地址。                                                                       |

| 位/域 | 名称    | R/W | 描述                                                                            |
|-----|-------|-----|-------------------------------------------------------------------------------|
| 29  | ODDF  | R/W | 奇数帧 (Odd Frame)<br>此位控制 OTG 主机是否以奇数帧传输。<br>0: 偶数帧<br>1: 奇数帧<br>注意: 只适用于周期性事务。 |
| 30  | CHINT | R/S | 通道中断 (Channel Interrupt)<br>0: 不中断<br>1: 停止通过通道传输数据                           |
| 31  | CHEN  | R/S | 使能通道 (Channel Enable)<br>0: 禁用<br>1: 使能                                       |

### 26.5.9 全速 OTG 主机通道 X 中断寄存器 (OTG\_FS\_HCHINTX) (X=0…7)

偏移地址: 0x508+20\*X

复位值: 0x0000 0000

| 位/域   | 名称       | R/W   | 描述                                                                         |
|-------|----------|-------|----------------------------------------------------------------------------|
| 0     | TSFCMPN  | RC_W1 | 传输正常完成 (Transfer Complete Normally)                                        |
| 1     | TSFCMPAN | RC_W1 | 传输异常完成 (Transfer Complete Abnormally)                                      |
| 2     |          |       | 保留                                                                         |
| 3     | RXSTALL  | RC_W1 | 收到 STALL 响应中断 (STALL Response Received Interrupt)                          |
| 4     | RXNAK    | RC_W1 | 收到 NAK 响应中断 (NAK Response Received Interrupt)                              |
| 5     | RXTXACK  | RC_W1 | 收到/发送 ACK 响应中断 (ACK Response Received/Transmitted Interrupt)               |
| 6     |          |       | 保留                                                                         |
| 7     | TERR     | RC_W1 | 事务中断 (Transaction Error)<br>表示发生以下错误:<br>CRC 校验失败<br>超时<br>位填充错误<br>EOP 错误 |
| 8     | BABBLE   | RC_W1 | 串扰错误 (Babble Error)                                                        |
| 9     | FOVR     | RC_W1 | 帧溢出错误 (Frame Overrun Error)                                                |
| 10    | DTOG     | RC_W1 | 数据翻转错误 (Data Toggle Error)                                                 |
| 31:11 |          |       | 保留                                                                         |

### 26.5.10 全速 OTG 主机通道 X 中断屏蔽寄存器 (OTG\_FS\_HCHIMASKX) (X=0…7)

偏移地址: 0x50C+20\*X

复位值: 0x0000 0000

| 位/域   | 名称        | R/W | 描述                                                                                |
|-------|-----------|-----|-----------------------------------------------------------------------------------|
| 0     | TSFCMPNM  | R/W | 屏蔽传输正常完成 (Transfer Complete Normally Mask)<br>0: 屏蔽<br>1: 不屏蔽                     |
| 1     | TSFCMPANM | R/W | 屏蔽传输异常完成 (Transfer Complete Abnormally Mask)<br>0: 屏蔽<br>1: 不屏蔽                   |
| 2     | 保留        |     |                                                                                   |
| 3     | RXSTALLM  | R/W | 屏蔽收到 STALL 响应中断 (STALL Response Received Interrupt Mask)<br>0: 屏蔽<br>1: 不屏蔽       |
| 4     | RXNAKM    | R/W | 屏蔽收到 NAK 响应中断 (NAK Response Received Interrupt Mask)<br>0: 屏蔽<br>1: 不屏蔽           |
| 5     | RXTXACKM  | R/W | 屏蔽收到/发送 ACK 响应中断 (ACK Response Received/Transmitted Interrupt)<br>0: 屏蔽<br>1: 不屏蔽 |
| 6     | RXNYETM   | R/W | 屏蔽收到 NYET 响应中断 (NYET Response Received Interrupt Mask)<br>0: 屏蔽<br>1: 不屏蔽         |
| 7     | TERRM     | R/W | 屏蔽事务中断 (Transaction Error Mask)<br>0: 屏蔽<br>1: 不屏蔽                                |
| 8     | BABBLEM   | R/W | 屏蔽串扰错误 (Babble Error Mask)<br>0: 屏蔽<br>1: 不屏蔽                                     |
| 9     | FOVRM     | R/W | 屏蔽帧溢出错误 (Frame Overrun Error Mask)<br>0: 屏蔽<br>1: 不屏蔽                             |
| 10    | DTOGM     | R/W | 屏蔽数据翻转错误 (Data Toggle Error Mask)<br>0: 屏蔽<br>1: 不屏蔽                              |
| 31:11 | 保留        |     |                                                                                   |

### 26.5.11 全速 OTG 主机通道 X 传输大小寄存器 (OTG\_FS\_HCHTSIZEX) (X=0…7)

偏移地址: 0x510+20\*X

复位值: 0x0000 0000

| 位/域   | 名称      | R/W | 描述                                                                                                              |
|-------|---------|-----|-----------------------------------------------------------------------------------------------------------------|
| 18:0  | TSFSIZE | R/W | 传输大小 (Transfer Size)<br>● 对于 IN: 此位的值为保留给传输缓冲区的大小, 一般为最大数据包的整数倍。<br>● 对于 OUT: 此位的值为主机要传输的字节数。                   |
| 28:19 | PCKTCNT | R/W | 数据包计数 (Packet Count)<br>此位表示发送或接收的数据包的值, 每传输一个数据包, 此位的值减 1, 当减为 0 时, 表示传输完成。                                    |
| 30:29 | DATAPID | R/W | 数据 PID (Data PID)<br>此位为数据通信的初始 PID。<br>00: DATA0<br>01: DATA2<br>10: DATA1<br>11: MDATA (控制传输) / SETUP (非控制传输) |
| 31    |         |     | 保留                                                                                                              |

## 26.6 OTG\_FS 设备模式寄存器地址映射

表格 130 OTG\_FS 设备模式寄存器地址映射

| 寄存器名             | 描述                                       | 偏移地址      |
|------------------|------------------------------------------|-----------|
| OTG_FS_DCFG      | 全速 OTG 设备配置寄存器                           | 0x800     |
| OTG_FS_DCTRL     | 全速 OTG 设备控制寄存器                           | 0x804     |
| OTG_FS_DSTS      | 全速 OTG 设备状态寄存器                           | 0x808     |
| OTG_FS_DINIMASK  | 全速 OTG 设备 IN 端点中断屏蔽寄存器                   | 0x810     |
| OTG_FS_DOUTIMASK | 全速 OTG 设备 OUT 端点中断屏蔽寄存器                  | 0x814     |
| OTG_FS_DAEPINT   | 全速 OTG 设备所有端点中断寄存器                       | 0x818     |
| OTG_FS_DAEPIMASK | 全速 OTG 设备所有端点中断屏蔽寄存器                     | 0x81C     |
| OTG_FS_DVBUSDTIM | 全速 OTG 设备 VBUS 释放时间寄存器                   | 0x828     |
| OTG_FS_DVBUSPTIM | 全速 OTG 设备 VBUS 脉冲时间寄存器                   | 0x82C     |
| OTG_FS_DIEIMASK  | 全速 OTG 设备 IN 端点 FIFO 空中断屏蔽寄存器            | 0x834     |
| OTG_FS_DIEPCTRL0 | 全速 OTG 设备 IN 端点 0 控制寄存器                  | 0x900     |
| OTG_FS_DIEPCTRLx | 全速 OTG 设备 IN 端点 x 控制寄存器                  | 0x900+20x |
| OTG_FS_DIEPINTx  | 全速 OTG 设备 IN 端点 x 中断寄存器 (x=0...3)        | 0x908+20x |
| OTG_FS_DIEPTRS0  | 全速 OTG 设备 IN 端点 0 传输大小寄存器                | 0x910     |
| OTG_FS_DIEPTRSx  | 全速 OTG 设备 IN 端点 x 传输大小寄存器 (x=1...3)      | 0x910+20x |
| OTG_FS_DITXFSTSx | 全速 OTG 设备 IN 端点 x TXFIFO 状态寄存器 (x=0...3) | 0x918+20x |
| OTG_FS_DOEPCTRL0 | 全速 OTG 设备 OUT 端点 0 控制寄存器                 | 0xB00     |
| OTG_FS_DOEPCTRLx | 全速 OTG 设备 OUT 端点 x 控制寄存器 (x=1...3)       | 0xB00+20x |

| 寄存器名            | 描述                                   | 偏移地址      |
|-----------------|--------------------------------------|-----------|
| OTG_FS_DOEPINTx | 全速 OTG 设备 OUT 端点 x 中断寄存器 (x=0...3)   | 0xB08+20x |
| OTG_FS_DOEPTRS0 | 全速 OTG 设备 OUT 端点 0 传输大小寄存器           | 0xB10     |
| OTG_FS_DOEPTRSx | 全速 OTG 设备 OUT 端点 x 传输大小寄存器 (x=1...3) | 0xB10+20x |
| OTG_FS_PCGCTRL  | 全速 OTG 电源和时钟门控控制寄存器                  | 0xE00     |

## 26.7 OTG\_FS 设备模式寄存器功能描述

### 26.7.1 全速 OTG 设备配置寄存器 (OTG\_FS\_DCFG)

偏移地址: 0x800

复位值: 0x0220 0000

| 位/域   | 名称      | R/W | 描述                                                                                                                                                                             |
|-------|---------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0   | DSPDSEL | R/W | 选择设备速度 (Device Speed Select)<br>此位选择连接主机的设备最大枚举速度。<br>11: FS (48MHz)<br>其他: 保留                                                                                                 |
| 2     | SENDOUT | R/W | 在非零长度状态发送接收 OUT 数据包 (Send the Received OUT Packet on Nonzero-length Status)<br>0: 接收到 OUT 数据包后将数据包发送给应用程序，并根据端点的 NAK 和 STALL 位回复握手信号<br>1: 接收到 OUT 数据包 (非零长度) 后, 回复 STALL 握手信号 |
| 3     |         |     | 保留                                                                                                                                                                             |
| 10:4  | DADDR   | R/W | 设备地址 (Device Address)<br>此位存储设备的地址, 参数来源于 SetAddress 命令。                                                                                                                       |
| 12:11 | PFITV   | R/W | 周期性微帧间距 (Periodic (Micro)Frame Interval)<br>此位配置确定周期性帧中断程序的时间点, 可以确定帧的同步通信是否全部完成。<br>00: 80%帧间隔<br>01: 85%帧间隔<br>10: 90%帧间隔<br>11: 95%帧间隔                                      |
| 31:13 |         |     | 保留                                                                                                                                                                             |

### 26.7.2 全速 OTG 设备控制寄存器 (OTG\_FS\_DCTRL)

偏移地址: 0x804

复位值: 0x0000 0000

| 位/域 | 名称     | R/W | 描述                                                                                                         |
|-----|--------|-----|------------------------------------------------------------------------------------------------------------|
| 0   | RWKUPS | R/W | 远程唤醒信号 (Remote Wakeup Signaling)<br>程序通过将此位置 1 使模块退出挂起状态, 唤醒 USB 主机。<br>注意: 根据协议, 此位置 1 后, 需在 1~15ms 内清 0。 |

| 位/域   | 名称       | R/W | 描述                                                                                                                                                |
|-------|----------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 1     | SDCNNT   | R/W | 软断开 (Soft Disconnect)<br>软断开是指主机接收不到“设备已连接”的信号，设备也接收不到信号。<br>0: 正常。主机能收到设备连接事件<br>1: 软断开                                                          |
| 2     | GINAKSTS | R   | 全局 IN 应答状态 (Global IN NAK Status)<br>此位决定是否根据 TXFIFO 中的数据可用性回复握手信号。<br>0: 是<br>1: 否，所有非周期性 IN 端点都回复握手信号                                           |
| 3     | GONAKSTS | R   | 全局 OUT 应答状态 (Global OUT NAK Status)<br>0: 根据 FIFO 状态和 NAK 和 STALL 位的状态发送握手信号<br>1: 不接收数据，除 SETUP 事务外的所有数据包都回复 NAK 信号                              |
| 6:4   | TESTSEL  | R/W | 选择测试模式 (Test Mode Select)<br>000: 禁用测试<br>001: Test_J<br>010: Test_K<br>011: Test_SE0_NAK<br>100: Test_Packet<br>101: Test_Force_Enable<br>其他: 保留 |
| 7     | GINAKSET | W   | 设置全局 IN 应答 (Global IN NAK Setup)<br>将全局非周期性 IN NAK 置 1，使非周期性 IN 端点发送 NAK 信号。<br>只有 OTG_FS_GCINT 寄存器的 GINNPNAKE 位清 0 时，此位才能置 1。                    |
| 8     | GINAKCLR | W   | 清除全局 IN 应答 (Global IN NAK Clear)<br>将全局非周期性 IN NAK 清 0。                                                                                           |
| 9     | GONAKSET | W   | 设置全局 OUT 应答 (Global OUT NAK Setup)<br>将全局 OUT NAK 置 1，使 OUT 端点发送 NAK 信号。<br>只有 OTG_FS_GCINT 寄存器的 GONAKE 位清 0 时，此位才能置 1。                           |
| 10    | GONAKCLR | W   | 清除全局 OUT 应答 (Global OUT NAK Clear)<br>将全局 OUT NAK 清 0。                                                                                            |
| 11    | POPROGCM | R/W | 上电编程完成 (Power-on Programming Complete)<br>此位表示寄存器被唤醒后完成了编程操作。                                                                                     |
| 31:12 |          |     | 保留                                                                                                                                                |

### 26.7.3 全速 OTG 设备状态寄存器 (OTG\_FS\_DSTS)

偏移地址: 0x808

复位值: 0x0000 0010

| 位/域 | 名称      | R/W | 描述                                                                                              |
|-----|---------|-----|-------------------------------------------------------------------------------------------------|
| 0   | SUSSTS  | R   | 挂起状态 (Suspend Status)<br>当 USB 总线被闲置 3ms 以上，模块就进入挂起状态，此位置 1。当 USB 线上有活动或模块接收到远程唤醒信号时，模块会退出挂起状态。 |
| 2:1 | ENUMSPD | R   | 枚举速度 (Enumerated Speed)                                                                         |

| 位/域   | 名称     | R/W | 描述                                                            |
|-------|--------|-----|---------------------------------------------------------------|
|       |        |     | 通过 chirp 序列检测后, 全速 OTG 的枚举速度。<br>11: 全速 (48MHz)<br>其他: 保留     |
| 3     | ERTERR | R   | 不规则错误 (Erratic Error)<br>如果出现任何不规则错误, 此位置 1, 此时只有执行软断开才能恢复通信。 |
| 7:4   |        |     | 保留                                                            |
| 21:8  | SOFNUM | R   | 接收 SOF 的帧序号 (Frame Number of the Received SOF)                |
| 31:22 |        |     | 保留                                                            |

#### 26.7.4 全速 OTG 设备 IN 端点中断屏蔽寄存器 (OTG\_FS\_DINIMASK)

偏移地址: 0x810

复位值: 0x0000 0000

| 位/域  | 名称       | R/W | 描述                                                                                     |
|------|----------|-----|----------------------------------------------------------------------------------------|
| 0    | TSFCMPM  | R/W | 屏蔽传输完成中断 (Transfer Completed Interrupt Mask)<br>0: 屏蔽<br>1: 不屏蔽                        |
| 1    | EPDISM   | R/W | 屏蔽端点禁止中断 (Endpoint Disable Interrupt Mask)<br>0: 屏蔽<br>1: 不屏蔽                          |
| 2    |          |     | 保留                                                                                     |
| 3    | TOM      | R/W | 屏蔽超时中断 (Timeout Interrupt Mask)<br>0: 屏蔽<br>1: 不屏蔽                                     |
| 4    | ITXEMPM  | R/W | 屏蔽 TXFIFO 空时接收到 IN 令牌中断 (IN Token Received when TxFIFO Empty Mask)<br>0: 屏蔽<br>1: 不屏蔽  |
| 5    | IEPMMM   | R/W | 屏蔽接收到端点不匹配的 IN 令牌中断 (IN Token Received with Endpoint Mismatch Mask)<br>0: 屏蔽<br>1: 不屏蔽 |
| 6    | IEPNAKEM | R/W | 屏蔽 IN 端点 NAK 有效中断 (IN Endpoint NAK Effective Mask)<br>0: 屏蔽<br>1: 不屏蔽                  |
| 31:7 |          |     | 保留                                                                                     |

#### 26.7.5 全速 OTG 设备 OUT 端点中断屏蔽寄存器 (OTG\_FS\_DOUTIMASK)

偏移地址: 0x814

复位值: 0x0000 0000

| 位/域  | 名称       | R/W | 描述                                                                                       |
|------|----------|-----|------------------------------------------------------------------------------------------|
| 0    | TSFCMPM  | R/W | 屏蔽传输完成中断 (Transfer Completed Interrupt Mask)<br>0: 屏蔽<br>1: 不屏蔽                          |
| 1    | EPDISM   | R/W | 屏蔽端点禁止中断 (Endpoint Disable Interrupt Mask)<br>0: 屏蔽<br>1: 不屏蔽                            |
| 2    |          |     | 保留                                                                                       |
| 3    | SETPCMPM | R/W | 屏蔽 SETUP 阶段完成中断 (SETUP Phase Complete Mask)<br>0: 屏蔽<br>1: 不屏蔽                           |
| 4    | OTXEMPM  | R/W | 屏蔽端点被禁止时接收到 OUT 令牌中断 (OUT Token Received when Endpoint Disabled Mask)<br>0: 屏蔽<br>1: 不屏蔽 |
| 31:5 |          |     | 保留                                                                                       |

#### 26.7.6 全速 OTG 设备所有端点中断寄存器 (OTG\_FS\_DAEPIINT)

偏移地址: 0x818

复位值: 0x0000 0000

| 位/域   | 名称       | R/W | 描述                                                                                      |
|-------|----------|-----|-----------------------------------------------------------------------------------------|
| 15:0  | INEPINT  | R   | 所有 IN 端点中断 (All IN Endpoint Interrupts)<br>第 X 位代表 IN 端点 X 的中断。最多有 16 个 IN 端点。          |
| 31:16 | OUTEPINT | R   | 所有 OUT 端点中断 (All OUT Endpoint Interrupts)<br>第 X 位代表 OUT 端点 (X-16) 的中断。最多有 16 个 OUT 端点。 |

#### 26.7.7 全速 OTG 设备所有端点中断屏蔽寄存器 (OTG\_FS\_DAEPIMASK)

偏移地址: 0x81C

复位值: 0x0000 0000

| 位/域   | 名称    | R/W | 描述                                                                                                                  |
|-------|-------|-----|---------------------------------------------------------------------------------------------------------------------|
| 15:0  | AINM  | R/W | 屏蔽所有 IN 端点中断 (All IN Endpoint Interrupts Mask)<br>第 X 位代表 IN 端点 X 的中断屏蔽。最多有 16 个 IN 端点。<br>0: 屏蔽<br>1: 不屏蔽          |
| 31:16 | AOUTM | R/W | 屏蔽所有 OUT 端点中断 (All OUT Endpoint Interrupts Mask)<br>第 X 位代表 OUT 端点 (X-16) 的中断屏蔽。最多有 16 个 OUT 端点。<br>0: 屏蔽<br>1: 不屏蔽 |

#### 26.7.8 全速 OTG 设备 V<sub>BUS</sub> 释放时间寄存器 (OTG\_FS\_DVBUSDTIM)

偏移地址: 0x828

复位值: 0x0000 17D7

| 位/域  | 名称       | R/W | 描述                                                                |
|------|----------|-----|-------------------------------------------------------------------|
| 15:0 | VBUSDTIM | R/W | 设备 V <sub>BUS</sub> 释放时间 (Device V <sub>BUS</sub> Discharge Time) |

| 位/域   | 名称 | R/W | 描述                                                            |
|-------|----|-----|---------------------------------------------------------------|
|       |    |     | SRP 期间 V <sub>BUS</sub> 发出脉冲后的放电时间。<br>值=放电时间 (PHY 时钟数) /1024 |
| 31:16 |    |     | 保留                                                            |

### 26.7.9 全速 OTG 设备 V<sub>BUS</sub>脉冲时间寄存器 (OTG\_FS\_DVBUSPTIM)

偏移地址: 0x82C

复位值: 0x0000 05B8

| 位/域   | 名称       | R/W | 描述                                                                                                             |
|-------|----------|-----|----------------------------------------------------------------------------------------------------------------|
| 11:0  | VBUSPTIM | R/W | 设备 V <sub>BUS</sub> 脉冲时间 (Device VBUS Pulsing Time)<br>SRP 期间 V <sub>BUS</sub> 脉冲时间。<br>值=脉冲时间 (PHY 时钟数) /1024 |
| 31:12 |          |     | 保留                                                                                                             |

### 26.7.10 全速 OTG 设备 IN 端点 FIFO 空中断屏蔽寄存器

#### (OTG\_FS\_DIEIMASK)

偏移地址: 0x834

复位值: 0x0000 0000

| 位/域   | 名称   | R/W | 描述                                                                                                                                |
|-------|------|-----|-----------------------------------------------------------------------------------------------------------------------------------|
| 15:0  | INEM | R/W | 屏蔽 IN 端点发送空的 FIFO 中断 (IN Endpoint Tx FIFO Empty Interrupt Mask)<br>第 X 位代表 IN 端点 X 的 TXFE 中断屏蔽。最多有 16 个 IN 端点。<br>0: 屏蔽<br>1: 不屏蔽 |
| 31:16 |      |     | 保留                                                                                                                                |

### 26.7.11 全速 OTG 设备 IN 端点 0 控制寄存器 (OTG\_FS\_DIEPCTRL0)

偏移地址: 0x900

复位值: 0x0000 0000

| 位/域  | 名称     | R/W | 描述                                                                                                   |
|------|--------|-----|------------------------------------------------------------------------------------------------------|
| 1:0  | MAXPS  | R/W | 最大数据包大小 (Maximum Packet Size)<br>此位配置端点的最大数据包的大小。<br>00: 64 字节<br>01: 32 字节<br>10: 16 字节<br>11: 8 字节 |
| 14:2 |        |     | 保留                                                                                                   |
| 15   | USBAEP | R   | USB 活动端点 (USB Active Endpoint)<br>该位表示是否在当前配置和接口中端点是否被激活。<br>此位总置 1。                                 |
| 16   |        |     | 保留                                                                                                   |
| 17   | NAKSTS | R   | NAK 状态 (NAK Status)<br>0: 模块根据 FIFO 状态回复非 NAK 握手信号                                                   |

| 位/域   | 名称     | R/W | 描述                                                                                                   |
|-------|--------|-----|------------------------------------------------------------------------------------------------------|
|       |        |     | 1: 模块在此端点上回复 NAK 握手信号, 此时即使 TXFIFO 还有空间, 模块仍然会停止发送数据。                                                |
| 19:18 | EPTYPE | R   | 端点类型 (Endpoint Type)<br>此位由硬件置 00, 表示端点为控制类型。                                                        |
| 20    |        |     | 保留                                                                                                   |
| 21    | STALLH | R/S | STALL 握手 (STALL Handshake)<br>程序只能将此位置 1, 直到端点接收到 SETUP 令牌, 此位清 0。<br>STALL 的优先级高于 NAK。              |
| 25:22 | TXFNUM | R/W | TXFIFO 编号 (TXFIFO Number)<br>为 IN 端点 0 设置单独的 FIFO 编号。                                                |
| 26    | NAKCLR | W   | 清除 NAK (NAK Clear)<br>对该位进行写操作时端点 0 的 NAK 位清 0。                                                      |
| 27    | NAKSET | W   | 设置 NAK (NAK Set)<br>对该位进行写操作使 NAK 位置 1。                                                              |
| 29:28 |        |     | 保留                                                                                                   |
| 30    | EPDIS  | R   | 禁止端点 (Endpoint Disable)<br>可以通过该位置 1 停止端点上的数据发送。<br>该位需要端点禁止中断位置 1 前清 0; 该位只能在 EPEN 置 1 后才能置 1。      |
| 31    | EPEN   | R   | 使能端点 (Endpoint Enable)<br>该位置 1 后, 端点开始发送数据。<br>当触发以下任一中断时, 此位清 0:<br>● SETUP 完成<br>● 禁止端点<br>● 传输完成 |

### 26.7.12 全速 OTG 设备 IN 端点 x 控制寄存器 (OTG\_FS\_DIEPCTRLx) (x=1~3, 端点编号)

偏移地址: 0x900+0x20\*x; x=1~3

复位值: 0x0000 0000

| 位/域   | 名称      | R/W | 描述                                                                                                                                             |
|-------|---------|-----|------------------------------------------------------------------------------------------------------------------------------------------------|
| 10:0  | MAXPS   | R/W | 最大数据包大小 (Maximum Packet Size)<br>此位配置端点的最大数据包的大小 (以字节为单位)。                                                                                     |
| 14:11 |         |     | 保留                                                                                                                                             |
| 15    | USBAEP  | R/W | USB 活动端点 (USB Active Endpoint)<br>该位表示是否在当前配置和接口中端点是否被激活。<br>当 USB 复位后, 该位清 0 (端点 0 除外)。                                                       |
| 16    | EOF_PID | R   | 奇偶帧 (Even Odd Frame)<br>此位用于指示端点发送/接收的帧编号 (对于同步 IN) 或数据包的 PID (对于中断/批量 IN)。<br>用于同步 IN 端点:<br>0: 偶数帧<br>1: 奇数帧<br>端点数据 PID (Endpoint Data PID) |

| 位/域   | 名称      | R/W   | 描述                                                                                                                                                                                                |
|-------|---------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |         |       | 用于中断/批量 IN 端点：<br>0: DATA0<br>1: DATA1                                                                                                                                                            |
| 17    | NAKSTS  | R     | NAK 状态 (NAK Status)<br>0: 模块根据 FIFO 状态回复非 NAK 握手信号<br>1: 模块在此端点上回复 NAK 握手信号, 此时对于非同步 IN: 即使 TXFIFO 还有可用数据, 模块仍然会停止发送数据; 对于同步 IN, 即使 TXFIFO 还有可用数据, 模块也会发送零长度数据包<br>注意: 模块总是通过 ACK 握手响应 SETUP 数据包。 |
| 19:18 | EPTYPE  | R/W   | 选择端点类型 (Endpoint Type)<br>00: 控制<br>01: 同步<br>10: 批量<br>11: 中断                                                                                                                                    |
| 20    |         |       | 保留                                                                                                                                                                                                |
| 21    | STALLH  | RW/RS | STALL 握手 (STALL Handshake)<br>● 用于非控制、非同步 IN 端点 (读写方式为 R/W):<br>此位置 1 时, 设备对来自 USB 主机所有的令牌都回复 STALL。此位只能由软件清 0。<br>● 用于控制端点 (读写方式为 R/S):<br>此位置 1 时, 表示模块接收到 SETUP 令牌。                            |
| 25:22 | TXFNUM  | R/W   | TXFIFO 编号 (TXFIFO Number)<br>这些位表示与端点相关联的 FIFO 编号, 需要为每个有效的 IN 端点设置单独的 FIFO 编号                                                                                                                    |
| 26    | NAKCLR  | W     | 清除 NAK (NAK Clear)<br>对该位进行写操作时, 端点的 NAK 位清 0。                                                                                                                                                    |
| 27    | NAKSET  | W     | 设置 NAK (NAK Set)<br>对该位进行写操作时, 端点的 NAK 位置 1。<br>该位可以控制 NAK 握手信号的发送。                                                                                                                               |
| 28    | DPIDSET | W     | 设置 DATA0 PID (DATA0 PID Set)<br>● 用于中断/批量 IN 端点:<br>对该位进行写操作时将 PID 设置为 DATA0。<br>设置偶数帧 (Even Frame Set)<br>● 用于同步 IN 端点:<br>对该位进行写操作会将 EOF_PID 设置为偶数帧。                                            |
| 29    | OFSET   | W     | 设置奇数帧 (Odd Frame Set)<br>用于同步 IN 端点, 对该位进行写操作会将 EOF_PID 设置为奇数帧。                                                                                                                                   |
| 30    | EPDIS   | R/S   | 禁止端点 (Endpoint Disable)<br>可以通过该位置 1 停止端点上的数据发送。<br>该位需要端点禁止中断位置 1 前清 0; 该位只能在 EPEN 置 1 后才能置 1。                                                                                                   |
| 31    | EPEN    | R/S   | 使能端点 (Endpoint Enable)<br>该位置 1 后, 端点开始发送数据。<br>当触发以下任一中断时, 此位清 0:                                                                                                                                |

| 位/域 | 名称 | R/W | 描述                                                                                           |
|-----|----|-----|----------------------------------------------------------------------------------------------|
|     |    |     | <ul style="list-style-type: none"> <li>● SETUP 完成</li> <li>● 禁止端点</li> <li>● 传输完成</li> </ul> |

### 26.7.13 全速 OTG 设备 IN 端点 x 中断寄存器 (OTG\_FS\_DIEPINTx)

(x=0~3, 端点编号)

偏移地址: 0x908+0x20\*x; x=0~3

复位值: 0x0000 0080

OTG\_FS\_GCINT 寄存器的 ONEP 位置 1 时, 读取该寄存器;

读取 OTG\_FS\_DAEPINT 寄存器获取设备端点 x 中断寄存器的准确端点编号, 之后读取该寄存器; 只有当该寄存器的相应位清 0 后 OTG\_FS\_DAEPINT 寄存器和 OTG\_FS\_GCINT 寄存器的相应位才可以清 0。

| 位/域  | 名称      | R/W   | 描述                                                                                                                             |
|------|---------|-------|--------------------------------------------------------------------------------------------------------------------------------|
| 0    | TSFCMP  | RC_W1 | 传输完成中断 (Transfer Complete Interrupt)<br>此位表示该端点上的传输已完成。                                                                        |
| 1    | EPDIS   | RC_W1 | 禁止端点中断 (Endpoint Interrupt Disable)<br>此位表示已禁止端点。                                                                              |
| 2    |         |       | 保留                                                                                                                             |
| 3    | TO      | RC_W1 | 超时中断 (Timeout Interrupt)<br>此位只适用于控制 IN 端点, 表示对最近收到的 IN 令牌响应已超时。                                                               |
| 4    | ITXEMP  | RC_W1 | FIFO 为空时接收 IN 令牌中断 (Receive IN Token Interrupt)<br>此位只适用于非周期性 IN 端点, 表示当端点对应的 TXFIFO 为空时, 接收到 IN 令牌。                           |
| 5    |         |       | 保留                                                                                                                             |
| 6    | IEPNAKE | RC_W1 | IN 端点 NAK 有效 (IN Endpoint NAK Effective)<br>此位表示模块对 NAK 采样, 即 IN 端点的 NAK 位已经生效。<br>当 OTG_FS_DIEPCTRLx 寄存器的 NAKCLR 位被写时, 此位清 0。 |
| 7    | TXFE    | R     | TXFIFO 为空中断 (TXFIFO Empty Interrupt)<br>当该端点的 TXFIFO 为空时, 产生中断。                                                                |
| 31:8 |         |       | 保留                                                                                                                             |

### 26.7.14 全速 OTG 设备 IN 端点 0 传输大小寄存器 (OTG\_FS\_DIEPTRS0)

偏移地址: 0x910

复位值: 0x0000 0000

OTG\_FS\_DIEPCTRLx 寄存器的 EPEN 位置 1 后, 该寄存器才可以进行修改;

OTG\_FS\_DIEPCTRLx 寄存器的 EPEN 位清 0 后, 才可以读取该寄存器。

| 位/域   | 名称     | R/W | 描述                                                            |
|-------|--------|-----|---------------------------------------------------------------|
| 6:0   | EPTRS  | R/W | 端点传输大小 (Endpoint Transfer Size)<br>此位表示端点 0 在一次数据传输中包含的数据量。   |
| 18:7  |        |     | 保留                                                            |
| 20:19 | EPPCNT | R/W | 端点数据包计数 (Endpoint Packet Count)<br>此位表示端点 0 在一次数据传输中包含的数据包数量。 |

| 位/域   | 名称 | R/W | 描述 |
|-------|----|-----|----|
| 31:21 |    |     | 保留 |

### 26.7.15 全速 OTG 设备 IN 端点 x 传输大小寄存器 (OTG\_FS\_DIEPTRSx) (x=1~3, 端点编号)

偏移地址: 0x910+0x20\*x; x=1~3

复位值: 0x0000 0000

OTG\_FS\_DIEPCTRLx 寄存器的 EPEN 位置 1 后, 该寄存器才可以进行修改;

OTG\_FS\_DIEPCTRLx 寄存器的 EPEN 位清 0 后, 才可以读取该寄存器。

| 位/域   | 名称     | R/W | 描述                                                                                                                                                                                            |
|-------|--------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 18:0  | EPTRS  | R/W | 端点传输大小 (Endpoint Transfer Size)<br>此位表示端点 x 在一次数据传输中包含的数据量 (以字节为单位)。                                                                                                                          |
| 28:19 | EPPCNT | R/W | 端点数据包计数 (Endpoint Packet Count)<br>此位表示端点 x 在一次数据传输中包含的数据包数量。                                                                                                                                 |
| 30:29 | TXDCNT | R/W | 计数发送数据包 (Transmit PacketCount)<br><ul style="list-style-type: none"> <li>对于周期性 IN 端点, 此位表示在 USB 上每帧必须发送的数据包数目。</li> <li>对于计算同步 IN 端点, 此位计算端点的数据 PID。</li> </ul> 01: 1 个<br>10: 2 个<br>11: 3 个 |
| 31    |        |     | 保留                                                                                                                                                                                            |

### 26.7.16 全速 OTG 设备 IN 端点 x TXFIFO 状态寄存器 (OTG\_FS\_DITXFSTSx) (x=0~3, 端点编号)

偏移地址: 0x918+0x20\*x; x=0~3

| 位/域   | 名称       | R/W | 描述                                                                                                                                                                                  |
|-------|----------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0  | INEPTXFS | R   | IN 端点 TXFIFO 可用空间 (IN Endpoint TXFIFO Space Available)<br>此位表示 IN 端点 TXFIFO 的可用空间 (以字为单位)。<br>0x0: IN 端点 TXFIFO 已满<br>0x1: 1 个字节<br>0x2: 2 个字节<br>0xn: n 个字节可用 (0<n<512)<br>其他值: 保留 |
| 31:16 |          |     | 保留                                                                                                                                                                                  |

### 26.7.17 全速 OTG 设备 OUT 端点 0 控制寄存器 (OTG\_FS\_DOEPCTRL0)

偏移地址: 0xB00

复位值: 0x0000 8000

| 位/域 | 名称    | R/W | 描述                                                                          |
|-----|-------|-----|-----------------------------------------------------------------------------|
| 1:0 | MAXPS | R   | 最大数据包大小 (Maximum Packet Size)<br>此位配置端点的最大数据包的大小。<br>00: 64 字节<br>01: 32 字节 |

| 位/域   | 名称     | R/W | 描述                                                                                                                                                          |
|-------|--------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |        |     | 10: 16 字节<br>11: 8 字节                                                                                                                                       |
| 14:2  |        |     | 保留                                                                                                                                                          |
| 15    | USBAEP | R   | USB 活动端点 (USB Active Endpoint)<br>该位表示是否在当前配置和接口中端点是否被激活。<br>此位总置 1。                                                                                        |
| 16    |        |     | 保留                                                                                                                                                          |
| 17    | NAKSTS | R   | NAK 状态 (NAK Status)<br>0: 模块根据 FIFO 状态回复非 NAK 握手信号<br>1: 模块在此端点上回复 NAK 握手信号, 此时即使 RXFIFO 还有空间, 模块仍然会停止接收数据。                                                 |
| 19:18 | EPTYPE | R   | 端点类型 (Endpoint Type)<br>该位由硬件置 00, 表示端点为控制类型。                                                                                                               |
| 20    | SNMEN  | R/W | 使能监听模式 (Snoop Mode Enable)<br>在监听模式下, 在 OUT 数据包传输到存储区之前不检查其正确性。                                                                                             |
| 21    | STALLH | R/S | STALL 握手 (STALL Handshake)<br>程序只能将此位置 1, 直到端点接收到 SETUP 令牌, 此位清 0。<br>STALL 的优先级高于 NAK。                                                                     |
| 25:22 |        |     | 保留                                                                                                                                                          |
| 26    | NAKCLR | W   | 清除 NAK (NAK Clear)<br>对此位进行写操作时端点 0 的 NAK 位清 0。                                                                                                             |
| 27    | NAKSET | W   | 设置 NAK (NAK Set)<br>对此位进行写操作时使 NAK 位置 1。                                                                                                                    |
| 29:28 |        |     | 保留                                                                                                                                                          |
| 30    | EPDIS  | R   | 禁止端点 (Endpoint Disable)<br>可以通过该位置 1 停止端点上的数据发送。<br>该位需要端点禁止中断位置 1 前清 0; 该位只能在 EPEN 置 1 后才能置 1。                                                             |
| 31    | EPEN   | W   | 使能端点 (Endpoint Enable)<br>该位置 1 后, 端点开始发送数据。<br>当触发以下任一中断时, 此位清 0: <ul style="list-style-type: none"><li>● SETUP 完成</li><li>● 禁止端点</li><li>● 传输完成</li></ul> |

### 26.7.18 全速 OTG 设备 OUT 端点 x 控制寄存器 (OTG\_FS\_DOEPCTRLx) (x=1~3, 端点编号)

偏移地址: 0xB00+0x20\*x; x=1~3

复位值: 0x0000 0000

| 位/域   | 名称    | R/W | 描述                                                         |
|-------|-------|-----|------------------------------------------------------------|
| 10:0  | MAXPS | R/W | 最大数据包大小 (Maximum Packet Size)<br>此位配置端点的最大数据包的大小 (以字节为单位)。 |
| 14:11 |       |     | 保留                                                         |

| 位/域   | 名称      | R/W   | 描述                                                                                                                                                                                       |
|-------|---------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15    | USBAEP  | R/W   | USB 活动端点 (USB Active Endpoint)<br>该位表示是否在当前配置和接口中端点是否被激活。<br>当 USB 复位后, 该位清 0 (端点 0 除外)。                                                                                                 |
| 16    | EOF_PID | R     | 奇偶帧 (Even Odd Frame)<br>此位用于指示端点发送/接收的帧编号 (对于同步 IN) 或数据包的 PID (对于中断/批量 IN)。<br>用于同步 IN 端点:<br>0: 偶数帧<br>1: 奇数帧<br>端点数据 PID (Endpoint Data PID)<br>用于中断/批量 IN 端点:<br>0: DATA0<br>1: DATA1 |
| 17    | NAKSTS  | R     | NAK 状态 (NAK Status)<br>0: 模块根据 FIFO 状态回复非 NAK 握手信号<br>1: 模块在此端点上回复 NAK 握手信号, 此时, 对于 OUT 端点, 即使 RXFIFO 还有剩余空间, 模块仍然会停止接收数据<br>注意: 模块总是通过 ACK 握手响应 SETUP 数据包。                              |
| 19:18 | EPTYPE  | R/W   | 选择端点类型 (Endpoint Type)<br>00: 控制<br>01: 同步<br>10: 批量<br>11: 中断                                                                                                                           |
| 20    | SNMEN   | R/W   | 使能监听模式 (Snoop Mode Enable)<br>在监听模式下, 在 OUT 数据包传输到存储区之前不检查其正确性。                                                                                                                          |
| 21    | STALLH  | RW/RS | STALL 握手 (STALL Handshake)<br>● 用于非控制、非同步 IN 端点 (读写方式为 R/W):<br>此位置 1 时, 设备对来自 USB 主机所有的令牌都回复 STALL。此位只能由软件清 0。<br>● 用于控制端点 (读写方式为 R/S):<br>此位置 1 时, 表示模块接收到 SETUP 令牌。                   |
| 25:22 |         |       | 保留                                                                                                                                                                                       |
| 26    | NAKCLR  | W     | 清除 NAK (NAK Clear)<br>对该位进行写操作时端点的 NAK 位清 0。                                                                                                                                             |
| 27    | NAKSET  | W     | 设置 NAK (NAK Set)<br>对该位进行写操作时, 端点的 NAK 位置 1。<br>该位可以控制 NAK 握手信号的发送。                                                                                                                      |
| 28    | DPIDSET | W     | 设置 DATA0 PID (DATA0 PID Set)<br>● 用于中断/批量 IN 端点:<br>对该位进行写操作时将 PID 设置为 DATA0。<br>设置偶数帧 (Even Frame Set)<br>● 用于同步 IN 端点:<br>对该位进行写操作会将 EOF_PID 设置为偶数帧。                                   |
| 29    | OFSET   | W     | 设置奇数帧 (Odd Frame Set)<br>● 用于同步 OUT 端点:                                                                                                                                                  |

| 位/域 | 名称    | R/W | 描述                                                                                                                                                                             |
|-----|-------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |       |     | <p>对该位进行写操作会将 EOF_PID 设置为奇数帧。</p> <ul style="list-style-type: none"> <li>● 用于中断/批量 OUT 端点:</li> </ul> <p>对该位进行写操作时将 PID 设置为 DATA1。</p>                                         |
| 30  | EPDIS | R/S | <p>禁止端点 (Endpoint Disable)</p> <p>可以通过该位置 1 停止端点上的数据发送。</p> <p>该位需要端点禁止中断位置 1 前清 0; 该位只能在 EPEN 置 1 后才能置 1。</p>                                                                 |
| 31  | EPEN  | R/S | <p>使能端点 (Endpoint Enable)</p> <p>该位置 1 后, 端点开始发送数据。</p> <p>当触发以下任一中断时, 此位清 0:</p> <ul style="list-style-type: none"> <li>● SETUP 完成</li> <li>● 禁止端点</li> <li>● 传输完成</li> </ul> |

### 26.7.19 全速 OTG 设备 OUT 端点 x 中断寄存器 (OTG\_FS\_DAEPINTx) (x=0~3, 端点编号)

偏移地址: 0xB08+0x20\*x; x=0~3

复位值: 0x0000 0080

OTG\_FS\_GCINT 寄存器的 ONEP 位置 1 时, 读取该寄存器;

读取 OTG\_FS\_DAEPINTx 寄存器获取设备端点 x 中断寄存器的准确端点编号,

之后读取该寄存器; 只有当该寄存器的相应位清 0 后, OTG\_FS\_DAEPINT 寄存器和 OTG\_FS\_GCINT 寄存器的相应位才可以清 0。

| 位/域  | 名称      | R/W   | 描述                                                                                                                       |
|------|---------|-------|--------------------------------------------------------------------------------------------------------------------------|
| 0    | TSFCMP  | RC_W1 | <p>传输完成中断 (Transfer Complete Interrupt)</p> <p>此位表示该端点上的传输已完成。</p>                                                       |
| 1    | EPDIS   | RC_W1 | <p>禁止端点中断 (Endpoint Interrupt Disable)</p> <p>此位表示已禁止端点。</p>                                                             |
| 2    |         |       | 保留                                                                                                                       |
| 3    | SETPCMP | RC_W1 | <p>完成 SETUP 阶段中断 (SETUP Phase Complete Interrupt)</p> <p>此位只适用于控制 OUT 端点, 表示已完成 SETUP 阶段, 产生中断后可以对接收的 SETUP 数据进行解码。</p>  |
| 4    | RXOTDIS | RC_W1 | <p>禁止时接收 OUT 令牌中断 (Receive OUT Token When Disable Interrupt)</p> <p>此位只适用于控制 OUT 端点, 表示未使能端点就接收到 OUT 令牌。</p>             |
| 5    |         |       | 保留                                                                                                                       |
| 6    | RXBSP   | RC_W1 | <p>接收连续的 SETUP 数据包中断 (Receive Back-to-Back SETUP Packet Interrupt)</p> <p>此位只适用于控制 OUT 端点, 表示端点已收到连续三个以上的 SETUP 数据包。</p> |
| 31:7 |         |       | 保留                                                                                                                       |

### 26.7.20 全速 OTG 设备 OUT 端点 0 传输大小寄存器 (OTG\_FS\_DOEPTRS0)

偏移地址: 0xB10

复位值: 0x0000 0000

OTG\_FS\_DOEPTRLx 寄存器的 EPEN 位置 1 后, 该寄存器才可以进行修改;

OTG\_FS\_DOEPTRLx 寄存器的 EPEN 位清 0 后, 才可以读取该寄存器。

| 位/域   | 名称     | R/W | 描述                                                                                            |
|-------|--------|-----|-----------------------------------------------------------------------------------------------|
| 6:0   | EPTRS  | R/W | 端点传输大小 (Endpoint Transfer Size)<br>此位表示端点 0 在一次数据传输中包含的数据量 (以字节为单位)。                          |
| 18:7  | 保留     |     |                                                                                               |
| 19    | EPPCNT | R/W | 端点数据包计数 (Endpoint Packet Count)<br>当 RXFIFO 被写入一个数据包后, 此位被减为 0。                               |
| 28:20 | 保留     |     |                                                                                               |
| 30:29 | SPCNT  | R/W | SETUP 数据包计数 (SETUP Packet Count)<br>这些位表示可以连续接收 SETUP 数据包的数量<br>01: 1 个<br>10: 2 个<br>11: 3 个 |
| 31    | 保留     |     |                                                                                               |

### 26.7.21 全速 OTG 设备 OUT 端点 x 传输大小寄存器 (OTG\_FS\_DOEPTRSx) (x=1~3, 端点编号)

偏移地址: 0xB10+0x20\*x; x=1~3

复位值: 0x0000 0000

OTG\_FS\_DOEPTRLx 寄存器的 EPEN 位置 1 后, 该寄存器才可以进行修改;

OTG\_FS\_DOEPTRLx 寄存器的 EPEN 位清 0 后, 才可以读取该寄存器

| 位/域   | 名称        | R/W | 描述                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------|-----------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 18:0  | EPTRS     | R/W | 端点传输大小 (Endpoint Transfer Size)<br>此位表示端点 x 在一次数据传输中包含的数据量 (以字节为单位)。                                                                                                                                                                                                                                                                                                                                                            |
| 28:19 | EPPCNT    | R/W | 端点数据包计数 (Endpoint Packet Count)<br>此位表示端点 x 在一次数据传输中包含的数据包数量。                                                                                                                                                                                                                                                                                                                                                                   |
| 30:29 | PID_SPCNT | R/W | 接收数据 PID 或计数 SETUP 数据包 (Receive Data PID or SETUP Packet Count)<br><ul style="list-style-type: none"> <li>● 对于同步 OUT 端点, 此位表示上一个接收的数据包 PID。           <ul style="list-style-type: none"> <li>00: DATA0</li> <li>01: DATA2</li> <li>10: DATA1</li> <li>11: MDATA</li> </ul> </li> <li>● 对于控制 OUT 端点, 此位表示端点能连续收到的 SETUP 数据包的数目。           <ul style="list-style-type: none"> <li>01: 1 个</li> <li>10: 2 个</li> </ul> </li> </ul> |

| 位/域 | 名称 | R/W | 描述      |
|-----|----|-----|---------|
|     |    |     | 11: 3 个 |
| 31  |    |     | 保留      |

### 26.7.22 全速 OTG 电源和时钟门控控制寄存器 (OTG\_FS\_PCGCTRL)

偏移地址: 0xE00

复位值: 0x0000 0000

此寄存器适用于主机模式和设备模式。

| 位/域  | 名称       | R/W | 描述                                                                                                                                      |
|------|----------|-----|-----------------------------------------------------------------------------------------------------------------------------------------|
| 0    | PCLKSTOP | R/W | PHY 时钟停止 (PHY Clock Stop)<br>0: 当 USB 通信恢复或会话重新启动时, 允许启动 PHY 时钟<br>1: 当挂起 USB 通信、会话无效或设备断开连接时, 停止 PHY 时钟                                |
| 1    | GCLK     | R/W | 门控 HCLK (Gate HCLK)<br>0: 当 USB 通信恢复或会话重新启动时, 允许对除了 AHB 总线从接口、主接口和唤醒之外的模块停止提供时钟<br>1: 当挂起 USB 通信或会话无效时, 对除了 AHB 总线从接口、主接口和唤醒之外的模块停止提供时钟 |
| 3:2  |          |     | 保留                                                                                                                                      |
| 4    | PHYSUS   | R/W | 挂起 PHY (PHY Suspend)<br>该位表示 PHY 挂起。                                                                                                    |
| 31:5 |          |     | 保留                                                                                                                                      |

## 27 以太网 (Ethernet)

注意：仅 APM32F425xG\_F427xG 系列产品有此模块。

### 27.1 简介

以太网提供了可配置、灵活的外设，用以满足客户的各种应用需求。它支持与外部物理层相连的两个工业标准接口：默认情况下使用的 MII 和 RMII，其中 MII 仅在 IEEE 802.3 规范中定义。它有多种应用领域，如交换机、网络接口卡等。且以太网可以借助外设按照 IEEE 802.3-2002 标准发送和接收数据。

以太网遵守以下标准：

- 用于以太网 MAC 的 IEEE802.3-2002
- 用于规定联网时钟同步精度的 IEEE1588-2008 标准
- 用于 AHB 主/从端口的 AMBA 2.0
- RMII 联盟的 RMII 规范

### 27.2 以太网主要特征

#### 27.2.1 MAC 主要特征

- (1) 符合 IEEE802.3 规范的 MII 接口与 PHY 通信
- (2) 支持 10/100Mbps 数据发送速率
- (3) 半双工操作
  - 支持 CSMA/CD 协议
  - 提供背压流量控制
- (4) 全双工操作
  - 支持 IEEE 802.3x 流量控制
  - 如果流量控制输入信号消失，自动发送的零量程暂停帧
  - 可将接收到的暂停帧转发到用户应用程序
- (5) 发送路径中帧数据 (SFD) 插入，接收路径中删除的报头和帧起始数据
- (6) 自动生成 CRC 和 pad，接收帧时可自动去除
- (7) 可编程帧间隙
- (8) 可编程帧长度，最高支持 16KB 的巨型帧
- (9) 地址过滤模式
  - 四个 48 位 DA 地址过滤器，可屏蔽每个字节
  - 三个 48 位 SA 地址过滤器，可屏蔽每个字节
  - 64 位 Hash 滤波器，适用于多播和单播地址
  - 可发送所有多播地址帧
  - 支持混合模式，可发送所有帧，不过滤网络监视
  - 发送所有传入数据包时均附有一份状态报告

- (10) 独立的发送、接收和控制接口
- (11) 32 位数据发送接口和接收接口
- (12) 对接收帧进行 IEEE 802.1Q VLAN 变量检测
- (13) MDIO 主接口（可选），用于 PHY 设备配置和管理
- (14) 通过 RMON/MIB 计数器进行强制网络统计
- (15) 检测 LAN 唤醒帧和 AMD Magic Packet<sup>TM</sup>帧
- (16) 支持以太网帧时间戳，每个帧给出 64 位时间戳
- (17) 可编程阈值功能的 2KB 发送 FIFO 和可配置阈值功能的 2KB 接收 FIFO
- (18) 接收 FIFO 多帧存储时，在 EOF 传输后向接收 FIFO 插入接收状态矢量，使这些帧的接收状态不被接收 FIFO 存储
- (19) 在存储转发模式下，可以在接收时过滤所有的错误帧，且不转发给应用程序
- (20) 为接收 FIFO 中丢失或损坏的帧生成脉冲以支持数据统计
- (21) 选择转发小尺寸的好帧
- (22) 增强型接收中可以检查 IPv4 头校验和以及在 IPv4 或 IPv6 数据包中封装的 TCP、UDP 或 ICMP 校验和
- (23) 校验和卸载接收到的由以太网帧封装的 IPv4 和 TCP 数据包
- (24) 发送到 MAC 的存储转发机制
- (25) 根据接收 FIFO 填充级别自动生成将发送至 MAC 内核的暂停帧控制或背压信号
- (26) 发送时处理冲突帧的自动重新发送
- (27) 丢弃过度冲突、延迟冲突、过度延迟和下溢条件下的帧
- (28) 通过软件控制刷新 Tx FIFO
- (29) 计算 IPv4 头校验和与 TCP、UDP 或 ICMP 校验和并插入在存储转发模式下发送的帧中
- (30) 调试时通过 MII 内部回送

### 27.2.2 PTP 主要特征

- (1) 发送帧和接收帧时间戳
- (2) 粗略校准和精密校准
- (3) 系统时间大于目标时间时触发中断
- (4) 输出秒脉冲

### 27.2.3 DMA 主要特征

- (1) 可在 AHB 主接口选择 AHB 突发类型
- (2) 从 AHB 主端口选择地址对齐突发
- (3) AHB 从接口中支持所有 AHB 突发类型
- (4) 双缓冲区（环）或链表（链）描述符链接
- (5) 数据缓冲区支持的字节对齐寻址
- (6) 优化面向包的 DMA 发送
- (7) 描述符架构，允许以最小的 CPU 干预发送大数据块（每个描述符可以发送多达 8KB 的数据）
- (8) 报告正常工作和传输错误时的综合状态
- (9) 用于发送和接收 DMA 引擎的单个可编程突发大小，用于最佳的主机总线
- (10) 可编程中断选项
- (11) 控制发送/接收完成中断
- (12) 发送引擎和接收引擎间采用循环调度仲裁或固定优先级仲裁
- (13) 当前 Tx/Rx 描述符指针、缓冲区指针作为状态寄存器

## 27.3 功能描述

### 27.3.1 复用功能映射

下表显示了 MAC 信号和相应的 MII/RMII 信号映射。

表格 131 复用功能映射

| 端口       | AF11                            |
|----------|---------------------------------|
|          | ETH                             |
| PA0-WKUP | ETH_MII_CRS                     |
| PA1      | ETH_MII_RX_CLK/ETH_RMII_REF_CLK |
| PA2      | ETH_MDIO                        |
| PA3      | ETH_MII_COL                     |
| PA7      | ETH_MII_RX_DV/ETH_RMII_CRS_DV   |
| PB0      | ETH_MII_RXD2                    |
| PB1      | ETH_MII_RXD3                    |
| PB5      | ETH_PPS_OUT                     |
| PB8      | ETH_MII_TXD3                    |
| PB10     | ETH_MII_RX_ER                   |

| 端口   | AF11                         |
|------|------------------------------|
|      | ETH                          |
| PB11 | ETH_MII_TX_EN/ETH_RMII_TX_EN |
| PB12 | ETH_MII_TXD0/ETH_RMII_TXD0   |
| PB13 | ETH_MII_TXD1/ETH_RMII_TXD1   |
| PC1  | ETH_MDC                      |
| PC2  | ETH_MII_TXD2                 |
| PC3  | ETH_MII_TX_CLK               |
| PC4  | ETH_MII_RXD0/ETH_RMII_RXD0   |
| PC5  | ETH_MII_RXD1/ETH_RMII_RXD1   |
| PE2  | ETH_MII_TXD3                 |
| PG8  | ETH_PPS_OUT                  |
| PG11 | ETH_MII_TX_EN/ETH_RMII_TX_EN |
| PG13 | ETH_MII_TXD0/ETH_RMII_TXD0   |
| PG14 | ETH_MII_TXD1/ETH_RMII_TXD1   |

### 27.3.2 SMI、MII 和 RMII

以太网外设包括带专用 DMA 控制器的 MAC 802.3。它支持默认情况下使用的 MII 和 RMII，并通过选择位切换。还包括用于与外部 PHY 通信的 SMI。通过配置寄存器可以选择 MAC 控制器和 DMA 控制器的模式和功能。

在发送数据时，先将数据由系统存储器以 DMA 的方式发送至 TX FIFO 缓冲后通过 MAC 内核发送。通过线路接收的以太网帧经过 DMA 发送到系统存储器之前由 RX FIFO 存储。

注意：使用以太网时 AHB 时钟频率至少为 25MHz。

#### 27.3.2.1 站管理接口 (SMI)

SMI 支持访问 32 个 PHY，应用程序通过 2 线时钟和数据线从 32 个 PHY 中选择一个 PHY，然后访问任意 PHY 寄存器。任意给定时间内只能对一个 PHY 中的一个寄存器进行寻址。

MDC 时钟线和 MDIO 数据线在微控制器中都作为复用功能 I/O：

- **MDC：**周期性时钟，提供以 2.5MHz 传输数据时的参考时序。MDC 的最短高/低电平时间均为 160ns。MDC 的最小周期为 400ns。空闲状态下 SMI 管理接口将 MDC 时钟信号驱动为低电平。
- **MDIO：**数据输入/输出比特流，用于通过 MDC 时钟信号与 PHY 设备同步传输状态。

#### SMI 帧格式

表格 132 帧格式

| 管理帧格式 |                                                                                                                                                                               |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 报头    | 每个操作都可以通过报头字段启动，报头字段用来与 PHY 设备建立同步，与 MDIO 线上 32 个连续的逻辑“1”位及 MDC 上的 32 个周期对应。                                                                                                  |
| 起始    | 由<01>模式定义，用来验证线的状态为默认逻辑“1”——逻辑“0”——逻辑“1”状态的转变。                                                                                                                                |
| 操作    | 定义正在发生操作的类型。                                                                                                                                                                  |
| PADDR | PHY 地址有 5 位，允许 32 个唯一的 PHY 地址。地址的 MSB 位是第一个发送和接收的。                                                                                                                            |
| RADDR | 寄存器地址有 5 位，可在选择的 PHY 设备中对 32 个不同的寄存器进行寻址。地址的 MSB 位是第一个发送和接收的。                                                                                                                 |
| TA    | 在 RADDR 和 DATA 间定义了一个 2 位模式，以避免在读操作期间出现竞争现象。当执行读操作时，MAC 控制器驱动 TA 的 2 个位为 MDIO 线上的高阻态。PHY 设备将驱动 TA 的第一位为高阻态，第二位驱动为“0”。<br>当执行写操作时，MAC 控制器对 TA 驱动<10>模式。PHY 设备驱动 TA 的 2 个位为高阻态。 |
| 数据    | 数据字段为 16 位。MAC_DATA 寄存器的位 15 为首位。                                                                                                                                             |
| 空闲    | MDIO 线驱动为高阻态。禁止三态驱动器，PHY 的上拉电阻使线路保持逻辑“1”状态。                                                                                                                                   |

### SMI 时钟选择

MAC 启动管理读/写操作。SMI 时钟是一个以 AHB 时钟为时钟源的分频时钟。分频系数取决于 MAC\_ADDR 寄存器中设置的时钟范围。

表格 133 时钟范围

| CR 位        | HCLK 时钟    | MDC 时钟     |
|-------------|------------|------------|
| 000         | 60-100MHz  | AHB 时钟/42  |
| 001         | 100-150MHz | AHB 时钟/62  |
| 010         | 20-35MHz   | AHB 时钟/16  |
| 011         | 35-60MHz   | AHB 时钟/26  |
| 100         | 150-180MHz | AHB 时钟/102 |
| 101、110、111 | 保留         | -          |

### SMI 写操作

当 MAC\_ADDR 的 MB 位和 MW 位被应用程序置 1 时，SMI 通过发送 PHY 地址、PHY 中的寄存器地址以及写入数据来触发 PHY 寄存器的写操作。当执行写操作时，应用程序不能修改 MAC\_ADDR 和 MAC\_DATA 寄存器。完成写操作后，SMI 将复位 MB 位。

### SMI 读操作

当设置 MAC\_ADDR 中的 MB 位、且 MW 位清零时，SMI 将通过发送 PHY 地址和 PHY 中的寄存器地址来触发 PHY 寄存器的读操作。当执行读操作时，应用程序不能修改 MAC\_ADDR 和 MAC\_DATA 寄存器。完成读操作后，SMI 将复位

MB 位，然后将从 PHY 中读取的数据更新到 MAC\_DATA 寄存器。

### 27.3.2.2 介质独立接口 (MII)

MII 定义了 MAC 子层与 PHY 在 10 Mbit/s 和 100 Mbit/s 的数据传输速率下的互连。

信号如下：

- (1) MII\_TX\_EN: 发送使能信号，MAC 当前正针对 MII 发送半字节
- (2) MII\_RX\_DV: 数据接收有效信号，PHY 当前正针对 MII 接收已恢复并解码的半字节
- (3) MII\_TXD [3:0]: 数据发送信号
- (4) MII\_RXD [3:0]: 数据接收信号
- (5) MII\_RX\_ER: 接收错误信号
- (6) MII\_TX\_CLK: 连续时钟信号，为 TX 数据传输提供参考时序
- (7) MII\_RX\_CLK: 连续时钟信号，为 RX 数据传输提供参考时序
- (8) MII\_CRS: 载波侦听信号
- (9) MII\_COL: 冲突检测信号

表格 134 TX 接口信号编码

| MII_TX_EN | MII_TXD [3:0] | 说明     |
|-----------|---------------|--------|
| 0         | 0000-1111     | 正常帧间隔  |
| 1         | 0000-1111     | 正常数据发送 |

表格 135 RX 接口信号编码

| MII_RX_DV | MII_RX_ER | MII_RXD [3:0] | 说明     |
|-----------|-----------|---------------|--------|
| 0         | 0         | 0000-1111     | 正常帧间隔  |
| 0         | 1         | 0000          | 正常帧间隔  |
| 0         | 1         | 0001-1101     | 保留     |
| 0         | 1         | 1110          | 错误载波检测 |
| 0         | 1         | 1111          | 保留     |
| 1         | 0         | 0000-1111     | 正常数据接收 |
| 1         | 1         | 0000-1111     | 数据接收错误 |

#### MII 时钟源

必须向外部 PHY 提供 25MHz 时钟才能生成 TX\_CLK 和 RX\_CLK 时钟信号，通过 MCO 引脚输出该信号。此时必须配置 PLL 倍频才可以通过 25 MHz 外部石英晶体在 MCO 引脚上获得所需频率。

### 27.3.2.3 精简介质独立接口 (RMII)

RMII 降低了以太网外设与外部 PHY 在 10/100Mbit/s 下微控制器的引脚数。根据 IEEE 802.3u 标准, MII 有 16 个数据和控制信号的引脚。RMII 将引脚数减少为 7 个。

RMII 在 MAC 和 PHY 之间实例化。有助于将 MAC 的 MII 转换为 RMII。RMII 具有以下特性:

- (1) 单独的 2 位宽的发送和接收数据路径
- (2) 10-Mbit/s 和 100-Mbit/s 的运行速率
- (3) 参考时钟为 50MHz
- (4) 从外部提供相同的参考时钟给 MAC 和外部以太网 PHY

#### RMII 时钟源

使用外部 50MHz 时钟或嵌入式 PLL 生成 50MHz 频率信号驱动 PHY。

### 27.3.2.4 MII/RMII 选择

在以太网控制器未处于复位模式或使能时钟时, 应用程序需设置 MII/RMII 模式。

### 27.3.3 介质访问控制 (MAC 802.3)

适用于 LAN 的 IEEE 802.3 国际标准的访问方法是 CSMA/CD。以太网外设由一个带 MII 的 MAC 802.3 控制器和一个专用 DMA 控制器组成。

- (1) 下述系统使用 LAN CSMA/CD 子层:
  - 支持半双工和全双工
  - 冲突检测访问方法仅适用于半双工
  - 基带系统和宽带系统的数据速率为 10Mbit/s 和 100Mbit/s
  - 支持 MAC 控制帧子层
- (2) MAC 子层功能:
  - 数据封装
    - 组帧
    - 寻址
    - 错误检测
  - 介质访问管理
    - 介质分配
    - 竞争解决
- (3) MAC 子层工作模式:
  - 半双工: 用 CSMA/CD 算法争用物理介质
  - 全双工: 当物理介质支持同步发送和接收, 且有两个均为全双工的站点与 LAN 相连时, 不用解决竞争问题就可以同时发送和接收数据。

### 27.3.3.1 MAC 802.3 帧格式

IEEE 802.3-2002 标准规定 MAC 使用 MAC 子层和可选 MAC 控制子层(10/100 Mbit/s)。

- (1) 为使用 CSMA/CD MAC 的数据通信系统指定了两个帧格式：
  - 基本 MAC 帧格式
  - 标记 MAC 帧格式
- (2) 字段的帧结构：
  - 报头：7 字节，用于同步
  - 起始帧定界符：1 字节，指示帧的开始
  - 目标地址和源地址：MAC 地址字段（6 字节），指示目标站和源站地址
- (3) 地址指定基于以下类型：
  - 单个地址：与网络中的特殊站有关的物理地址。
  - 组地址：与给定网络中一个或多个站有关的多目标地址。有多播组地址和广播地址两种多播地址。
  - Qtag 前缀：在源地址和 MAC 客户端长度/类型字段中插入的 4 字节字段。该字段是对基本帧（未标记）的扩展，用于获得标记的 MAC 帧。未标记的 MAC 帧没有。
  - 数据和 PAD：n 字节，数据完全透明，意味着数据字段中可能出现任意的字节数。如存在 PAD，其大小由数据的大小决定。
  - MAC 客户端长度/类型：2 字节，有不同含义。
  - 帧检查序列：包含 CRC 值的 4 字节。CRC 计算基于下列字段：源地址、目标地址、Qtag 前缀、长度/类型、LLC 数据和 PAD。

### 27.3.3.2 MAC 帧发送

DMA 控制发送时的所有操作。DMA 把从系统存储器读取的以太网帧推入 FIFO。再将帧弹出并发送到 MAC 内核。当帧发送结束时，从 MAC 内核获取发送状态并传回 DMA。FIFO 填充级别指示给 DMA，使其使用 AHB 接口在所需的系统存储器突发中启动数据获取。来自 AHB 主接口的数据将推入 FIFO。发送 FIFO 的深度为 2KB。

#### 发送协议

MAC 控制以太网帧的发送。为满足 IEEE 802.3/802.3z 规范执行以下功能：

- 生成报头和 SFD
- 生成发送帧状态
- 在半双工模式下生成阻塞信号
- 控制半双工模式下的流量（背压）
- 控制 Jabber 超时
- 包含符合 IEEE 1588 的时间戳快照逻辑

#### 发送 CRC：自动 CRC 和 pad 生成

为了满足 IEEE 802.3 的最小数据字段的要求，当从应用程序接收的字节数少于

60 时发送帧会附加零，使数据长度为 46 字节。**MAC** 可以设置不附加填充值。计算 FCS 字段的 **CRC** 并将其附加到正在发送的数据。如果将 **MAC** 设置为不附加 **CRC** 值到以太网帧的末尾，则不发送 **CRC**。但将 **MAC** 设置为向小于 60 字节的帧附加填充时，**CRC** 附加在填充帧的末尾。

## 发送数据包

数据包的发送分为发送单数据包和多个数据包，其操作方式不同。

## 发送调度程序

**MAC** 负责调度 MII 上的帧发送。可以保持两个发送帧之间的间隔，并在半双工模式下遵循截断二进制指数回退算法。**MAC** 在满足 **IFG** 计数器和回退延迟条件后使能发送。

## 发送流量控制

在全双工模式下，当 **MAC\_FCTRL[TXFCTRLLEN]=1** 时，**MAC** 将生成暂停帧并在需要时发送。暂停帧与 **CRC** 附加在一起发送。暂停帧的生成可以通过两种方式启动。当应用程序将 **FCTRLB** 位置 1 或接收 **FIFO** 已满时，将发送暂停帧。

## 发送 FIFO 刷新

由 **ETH\_DMAOPMOD** 寄存器的 **FTXF** 位控制清空发送 **FIFO**。即使 **Tx FIFO** 正在向 **MAC** 内核发送帧，**Tx FIFO** 和对应的指针也会立即清零到初始状态，导致 **MAC** 发送器中生成下溢事件，且中止帧发送。帧的状态将同时标记下溢事件和帧清空事件。

## 发送状态字

在向 **MAC** 内核传输以太网帧结束及内核完成帧的发送后，将会提供发送状态给应用程序。

## 发送校验和减荷

通信协议实现校验和字段，有助于了解通过网络发送数据的完整性。因为在 IP 数据报上封装 **TCP** 和 **UDP** 是以太网最广泛的用途，所以以太网控制器具有发送校验和减荷功能，这个功能支持发送路径中的校验和计算、插入及接收路径中的错误检测。

## 冲突期间的重新发送

在半双工模式下，向 **MAC** 发送帧时，在 **MAC** 线接口上可能发生冲突事件。甚至可能在接收到帧结束之前 **MAC** 就指示重试。然后重新发送并再次将帧从 **FIFO** 中弹出。

## MII/RMII

来自 MII 的每个半字节都在 RMII 上发送，一次发送双位，发送顺序由低到高。

### 27.3.3.3 MAC 帧接收

MAC 将接收到的帧推入 Rx FIFO。一旦此 FIFO 的状态超过配置的接收阈值就会将其指示给 DMA，以便 DMA 向 AHB 接口发起预配置的突发传输。

#### 接收协议

接收到帧时去除帧的报头和 SFD。当检测到 SFD 后，MAC 向 RX FIFO 发送以太网帧数据，从 SFD 后面的第一个字节开始发送。使能 IEEE 1588 时间戳功能后，一旦在 MII 上检测到 SFD，都将获取系统时间的快照。除非 MAC 过滤并丢弃帧，否则此时间戳将被发送给应用程序。

#### 接收多帧

由于接收数据后状态立即可用，所以只要 FIFO 未满就可以存储帧。

#### 接收 CRC：自动 CRC 和 pad 去除

MAC 将检查接收帧中的 CRC 错误并计算其中的 32 位 CRC。不管是否自动去除 pad/CRC，MAC 都将接收整个帧来计算所接收帧的 CRC 校验。

#### 接收帧控制器

当 MAC\_FRAF[RXA]=0 时，MAC 将根据目标地址和源地址执行帧过滤。如果过滤失败，帧被丢弃且不会发送到应用程序。当过滤参数动态改变时过滤失败，则剩余的帧被丢弃且立即更新接收状态字。在以太网掉电模式下，所有接收到的帧都被丢弃且不会转发给应用程序。

#### 接收校验和减荷

由 MAC\_CFG 寄存器中的 IPC 位控制接收校验和减荷。此功能用于检测和处理接收的以太网帧中的 IPv4 和 IPv6 帧以确保数据完整性。MAC 通过检查接收的以太网帧的类型字段识别 IPv4 或 IPv6 帧。此识别方法也适用于带 VLAN 标记的帧。

#### 接收流量控制

MAC\_FCTRL[RXFCTRLLEN]控制暂停帧检测功能。设置该位时 MAC 检测接收暂停帧并且帧发送暂停，具体时间由接收的暂停帧内设置的延迟决定。使能接收流量控制后开始监视接收帧的目标地址与控制帧的多播地址是否匹配。如果匹配，MAC 将根据 MAC\_FRAF[PCTRLF]位决定接收的控制帧是否发送到应用程序。

#### 错误处理

表格 136 错误处理情况

| 发生情况                                       | 处理结果                                                                          |
|--------------------------------------------|-------------------------------------------------------------------------------|
| 从 MAC 接收 EOF 数据之前 Rx FIFO 已满。              | 丢弃整个帧，ETH_DMAMFABOCNT 寄存器中的上溢计数器递增。                                           |
| 使用 ETH_DMAOPMOD 寄存器中的 FERRF 和 FUF 位使能对应功能。 | Rx FIFO 可过滤错误帧和过小帧。                                                           |
| 将接收 FIFO 配置为在存储转发模式下工作。                    | 过滤并丢弃所有错误帧。                                                                   |
| 直通模式下，如果在从 Rx FIFO 读取帧的 SOF 时，该帧的状态和长度可用。  | 可丢弃整个错误帧。DMA 可清空正在从 FIFO 读取的错误帧。然后停止到 DMA 的数据传输，从内部读取并丢弃其余的帧。如果可用，则可以启动下一帧传输。 |

### 接收状态字

以太网帧接收结束时，MAC 向 DMA 输出接收状态。接收状态的详细说明与 RXDESO[31:0]相同。

### 帧长度接口

应用和 MAC 之间的数据发送和接收以传输完整帧的形式进行。应用层需要知道从入站端口接收的帧的长度以便将帧传输到出站端口。MAC 内核在每次帧接收结束时提供每个接收的帧的长度。

### MII/RMII 接收位序

每个半字节都从在 RMII 上接收的双位发送到 MII，发送顺序由低到高。

#### 27.3.3.4 MAC 中断

各种事件都可以令 MAC 内核产生中断，MAC\_ISTS 寄存器描述了各种事件中断。设置中断屏蔽寄存器中相应的屏蔽位可阻止产生事件中断。对相应的状态寄存器和其它寄存器进行读操作可清除中断。

#### 27.3.3.5 MAC 过滤

##### 地址过滤

检查所有接收的帧的目标地址和源地址并报告相应的地址过滤状态。地址检查取决于帧过滤寄存器的设置。还可以识别过滤的帧：多播帧或广播帧。地址过滤使用站的 MAC 地址和多播散列表进行地址检查。

##### 单播目标地址过滤

MAC 支持 4 个用于单播完美过滤的 MAC 地址。若 MAC\_FRAF[HUC]=0，MAC 会比较接收的单播地址的所有 48 位与设置的 MAC 地址是否匹配。

##### 组播目标地址过滤

MAC\_FRAF 寄存器的 PM 控制是否将 MAC 设置为通过所有组播帧。当复位 PM

位时, **MAC\_FRAF** 寄存器中的 **HMC** 位控制过滤组播地址。

### 散列或完美地址过滤

当设置 **MAC\_FRAF** 寄存器中的 **HPF** 位、**HUC** 位及 **HMC** 位时, **DA** 过滤配置为在其 **DA** 与散列过滤或完美过滤匹配时允许帧通过。此配置适用于单播帧和组播帧。如果 **HPF** 位复位, 则只有一种过滤方式。

### 广播地址过滤

在默认模式下, **MAC** 不过滤广播帧。但如果 **MAC\_FRAF[DISBF]=1**, 则会丢弃所有广播帧。

### 单播源地址过滤

**MAC** 根据接收的帧的源地址执行完美过滤。默认情况下, **MAC** 将 **SA** 字段与 **SA** 寄存器中的值比较。当设置相应寄存器中的位 30 时, **MAC** 地址寄存器配置为包含 **SA** 进行比较。若 **MAC\_FRAF[SAFEN]=0**, **SA** 过滤的结果将呈现在接收状态字中的状态位。否则 **MAC** 丢弃未通过 **SA** 过滤的帧。

### 反向过滤

在最终输出时分别由 **MAC\_FRAF** 的 **DAIF** 和 **SAIF** 位控制目标地址和源地址过滤。**DAIF** 位适用于单播和组播 **DA** 帧, 设置此位时将反转单播/组播目标地址过滤的结果。当设置 **SAIF** 位时, 将反转单播 **SA** 过滤的结果。

表格 137 目标地址过滤

| 帧类型 | PR | HUC | HMC | DAIF | PM | DISBF | HPF | DA 过滤操作                                |
|-----|----|-----|-----|------|----|-------|-----|----------------------------------------|
| 广播  | 1  | X   | X   | X    | X  | X     | X   | 通过                                     |
|     | 0  | X   | X   | X    | X  | 0     | X   | 通过                                     |
|     | 0  | X   | X   | X    | X  | 1     | X   | 不通过                                    |
| 单播  | 1  | X   | X   | X    | X  | X     | X   | 所有帧通过                                  |
|     | 0  | 0   | X   | 0    | X  | X     | X   | 完美/组过滤匹配时通过                            |
|     | 0  | 0   | X   | 1    | X  | X     | X   | 完美/组过滤匹配时不通过                           |
|     | 0  | 1   | X   | 0    | X  | X     | 0   | 散列过滤匹配时通过                              |
|     | 0  | 1   | X   | 1    | X  | X     | 0   | 散列过滤匹配时不通过                             |
|     | 0  | 1   | X   | 0    | X  | X     | 1   | 散列或完美/组过滤匹配时通过                         |
|     | 0  | 1   | X   | 1    | X  | X     | 1   | 散列或完美/组过滤匹配时不通过                        |
| 多播  | 1  | X   | X   | X    | X  | X     | X   | 所有帧通过                                  |
|     | X  | X   | X   | X    | 1  | X     | X   | 所有帧通过                                  |
|     | 0  | X   | 0   | 0    | 0  | X     | X   | 如果 PCTRLF=0x, 完美/组过滤匹配时通过, 并丢弃暂停控制帧    |
|     | 0  | X   | 1   | 0    | 0  | X     | 0   | 如果 PCTRLF=0x, 散列过滤匹配时通过, 并丢弃暂停控制帧      |
|     | 0  | X   | 1   | 0    | 0  | X     | 1   | 如果 PCTRLF=0x, 散列或完美/组过滤匹配时通过, 并丢弃暂停控制帧 |

| 帧类型 | PR | HUC | HMC | DAIF | PM | DISBF | HPF | DA 过滤操作                                 |
|-----|----|-----|-----|------|----|-------|-----|-----------------------------------------|
|     | 0  | X   | 0   | 1    | 0  | X     | X   | 如果 PCTRLF=0x, 完美/组过滤匹配时不通过, 并丢弃暂停控制帧    |
|     | 0  | X   | 1   | 1    | 0  | X     | 0   | 如果 PCTRLF=0x, 散列过滤匹配时不通过, 并丢弃暂停控制帧      |
|     | 0  | X   | 1   | 1    | 0  | X     | 1   | 如果 PCTRLF=0x, 散列或完美/组过滤匹配时不通过, 并丢弃暂停控制帧 |

表格 138 源地址过滤器

| 帧类型 | PR | SAIF | SAFEN | SA 过滤操作                |
|-----|----|------|-------|------------------------|
| 单播  | 1  | X    | X     | 所有帧通过                  |
|     | 0  | 0    | 0     | 完美/组过滤匹配时通过, 但不丢弃未通过的帧 |
|     | 0  | 1    | 0     | 完美/组过滤匹配时不通过, 但不丢弃帧    |
|     | 0  | 0    | 1     | 完美/组过滤器匹配时通过并丢弃不通过的帧   |
|     | 0  | 1    | 1     | 完美/组过滤器匹配时不通过并丢弃不通过的帧  |

### 27.3.3.6 MAC 回送模式

MAC 可以回送接收到的帧。由 **MAC\_CFG** 寄存器的 **LBM** 位控制此功能，此功能默认情况下禁止。

### 27.3.3.7 MAC 管理计数 (MMC)

MMC 有一个控制寄存器、两个中断状态寄存器，及两个包含屏蔽中断寄存器掩来收集有关接收帧和发送帧的信息。这些寄存器都可从应用程序中访问。

接收 MMC 计数器更新通过地址过滤的帧。除非丢弃的帧为小于 6 字节的矮帧，否则不更新已丢弃的帧。

#### 良好帧

(1) 如果发送时不存在以下错误，则发送帧为“良好帧”：

- 帧下溢
- 无载波/载波丢失
- Jabber 超时
- 延迟冲突
- 过度延迟
- 过度冲突

(2) 如果接收时不存在以下错误，则接收帧为“良好帧”：

- 矮帧
- CRC 错误
- MII\_RXER 输入错误
- 对齐错误 (仅限 10/100Mb/s)
- 长度错误 (仅限非类型帧)
- 超出范围 (仅限非类型帧, 超过最大尺寸)

(3) 帧类型决定最大帧尺寸，如下：

- 无标记帧的最大尺寸=1518
- VLAN 帧的最大尺寸=1522

### 27.3.3.8 电源管理 (PMT)

PMT 支持接收网络远程唤醒帧和魔术数据包帧。可为 MAC 接收的唤醒帧和魔术数据包帧生成中断。可通过 MAC\_PMTCTRLSTS 寄存器的 WKUPFEN 位和 MPEN 位使能 PMT 模块。在 PMT 中使能掉电模式时，MAC 丢弃所有接收的帧且不会转发给应用。仅当接收到远程唤醒帧或魔术数据包帧且使能相应检测时才会退出掉电模式。

#### 检测远程唤醒帧

当 MAC 处于睡眠模式且已使能 MAC\_PMTCTRLSTS[WKUPFEN]=1 时，MAC 可在接收到远程唤醒帧后恢复正常工作。

#### 检测魔术数据包

使用 AMD 公司的技术可对网络上处于睡眠模式下的设备上电。MAC 接收到一个称为魔术数据包的特定信息包，其地址是网络上的节点。只检查发送到设备或多播地址的魔术数据包，以确定它们是否满足唤醒要求。

#### 掉电期间的系统注意事项

使能 EINT 19 中断线时以太网 PMT 模块可以在系统处于停止模式时检测帧。MAC 接收器状态机在掉电模式时应保持使能。

### 27.3.3.9 精密时间协议 (IEEE1588 PTP)

IEEE 1588 标准定义了一种协议。适用于通过支持多播消息传输的局域网进行通信的系统，同步异构系统，包括固定精度、分辨率和稳定性不同的时钟。支持使用网络通信、局域计算和分布式对象等技术实现的测量和控制系统中的精密时钟同步。支持亚秒范围的系统级同步精度，且需要的网络和本地时钟计算资源最小。这种称为精密时间协议通过 UDP/IP 发送。系统或网络分为主节点和从节点，用于分配时序/时钟信息。该协议通过交换 PTP 消息将从节点同步到主节点。

#### 使用 PTP 发送帧

当帧的 SFD 在 MII 上输出时将捕获时间戳。可标记每个发送帧来指示是否需要捕获该帧的时间戳。不用处理发送帧就可以识别 PTP 帧。发送描述符中的控制位控制帧。捕获到的时间戳以提供帧状态的方式返回给应用。时间戳会随帧的发送状态发送回相应的发送描述符内，使得时间戳与特定 PTP 帧相连。64 位时间戳信息写回 TXDES2 和 TXDES3 字段，其中 TXDES2 保持时间戳的 32 个最低有效位。

#### 使用 PTP 接收帧

使能 IEEE 1588 时间戳功能时，MII 上接收的所有帧的时间戳将被以太网 MAC 捕获。MAC 在完成帧接收时提供时间戳。捕获到的时间戳以提供帧状态的方式返回给应用。时间戳会随帧的接收状态发送回相应的接收描述符内。64 位时间戳信息会写回 RXDES2 和 RXDES3 字段，其中 RXDES2 保持时间戳的 32 个最低有效位。

### 参考时序源

要获取时间快照，内核需要一个 64 位的参考时间。PTP 参考时钟输入的作用为在内部生成参考时间及捕获时间戳。生成的参考时钟的频率不能小于时间戳计数器的分辨率。主节点与各从节点间的同步精度目标约为 100ns。

### 校准方法

在一个过程中同步或更新系统时间为粗略校准方法，为了减少系统时间抖动而同步或更新系统时间为精密校准方法。

### 系统时间校准方法

64 位 PTP 时间由 PTP 输入参考时钟 HCLK 刷新。为了获取 MII 上发送或接收的以太网帧的时间戳，将该时间用作时钟源。可使用粗略校准或精密校准两种方法初始化或校准系统时间定时器。

### 系统时间初始化

时间戳功能由 PTP\_TSCTRL 寄存器的 TSEN 位控制。设置后需对时间戳计数器进行初始化才能使能时间戳。

### 与 TMR2 内部相连的 PTP 触发

为避免系统时间大于目标时间时使用中断导致命令执行时间出现不确定性，可在系统时间大于目标时间时将内部连接到 TMR2 输入触发的 PTP 触发输出信号置为高电平。

### PTP 脉冲每秒输出信号

PTP 脉冲用于检查网络中所有节点间的同步性。可为两个时钟提供每秒脉冲数 (PPS)输出信号，以便能测试本地从时钟与主参考时钟之间的差值。PPS 输出的脉冲宽度为 125ms。

#### 27.3.4 DMA 控制器

DMA 用于包的数据传输。可设置该控制器在发送帧和接收帧完成等正常/错误条件下产生 CPU 中断。DMA 具有单独的发送器和接收器及相应的控制和状态寄存器。发送器把在系统存储器中的数据传输到 Tx FIFO，接收器把 Rx FIFO 接收到的数据传输到系统存储器。DMA 描述符可以以最少的 CPU 干预将数据从源地址传输到目标地址。DMA 和 CPU 的通信方式分为以下两种数据结构：

- 控制和状态寄存器

- 描述符列表和数据缓冲区

#### 27.3.4.1 主机总线突发访问

DMA 尝试在 AHB 主接口上进行固定长度的突发传输。突发的最大长度取决于 ETH\_DMABMOD 寄存器的 PBL 位。接收和发送描述符用可能的最大突发大小访问要读取的 16 个字节。

#### 27.3.4.2 主机数据缓冲区对齐

发送和接收数据缓冲区不限制起始地址对齐。在我们的系统中，缓冲区的起始地址可以和四个字节中的任何一个对齐。DMA 总是在地址与总线宽度对齐时开始传输，且在以太网帧的开始或结束传输时使用不需要的字节通道传输空数据。

#### 27.3.4.3 计算缓冲区大小

DMA 只更新发送和接收描述符的状态，不更新大小。大小需要用驱动程序计算。发送 DMA 会向 MAC 内核发送正确的字节数。

#### 27.3.4.4 DMA 仲裁器

DMA 内的仲裁器会在发送通道和接收通道分别访问 AHB 主接口之间进行仲裁。可以使用循环调度和固定优先级两类仲裁。

#### 27.3.4.5 对 DMA 的错误响应

如果从机对 DMA 通道发起的数据传输给出错误响应，则相应的 DMA 将停止所有操作并更新 ETH\_DMASTS 寄存器中的 FBERRFLG 位和 ERRB 位。

#### 27.3.4.6 Tx DMA

Tx DMA 分为两种模式：默认模式和 OSF 模式。

##### 处理发送帧

发送 DMA 期望数据缓冲区包含完整的以太网帧，不包括报头、pad 和 FCS。DA、SA 和类型/长度字段包含有效数据。当发送描述符指示 MAC 内核禁止插入 CRC 或 pad 时，缓冲区必须有完整的包含 CRC 字节的以太网帧。帧由第一个描述符和最后一个描述符定界，可以是数据链接或跨越多个缓冲区。

##### 暂停发送轮询

当 DMA 检测到所有的描述符，且 ETH\_DMASTS 寄存器的 TXBU 位被设置时会暂停发送轮询。或检测到由下溢导致的发送错误时，中止帧发送。相应的发送描述符 0 位将置 1。如果发生第二个条件，将设置 ETH\_DMASTS 寄存器的 AINTS 位与 TXUNF 位，且信息被写入发送描述符 0，也会暂停发送轮询。

#### 27.3.4.7 常规发送描述符功能描述

常规发送描述符结构由 4 个 32 位字组成，如果时间戳已激活或 IPv4 校验和减荷已激活，则必须使用增强的描述符。

### 发送描述符字 0 (TXDES0)

| 位/域 | 名称    | R/W | 描述                                                                                                                                                                                  |
|-----|-------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | DEF   | R/W | <p>延迟 (Deferred)<br/>当设置此位时, 表示由于载波的存在, MAC 在发送前延迟。该位仅在半双工模式下有效。</p> <p>0: 无延迟<br/>1: 有延迟</p>                                                                                       |
| 1   | UFERR | R/W | <p>下溢错误 (Underflow Error)<br/>当设置此位时, 该位表示 MAC 终止帧, 因为数据从主机内存到达较晚。下流错误表明 DMA 在发送帧时遇到了一个空的发送缓冲区。发送过程进入挂起状态。</p>                                                                      |
| 2   | EDEF  | R/W | <p>过多的延迟 (Excessive Deferral)<br/>如果将 MAC_CFG[4]置 1, 则该位表示发送已经结束。</p>                                                                                                               |
| 6:3 | CCNT  | R/W | <p>冲突次数 (Collision Count)<br/>该位域的值表示帧被发送之前发生的冲突次数。TXDES0[8]置 1 时无效。</p>                                                                                                            |
| 7   | VLANF | R/W | <p>VLAN 格式 (VLAN Frame)<br/>设置此位时, 表示发送帧是 VLAN 类型的帧。</p>                                                                                                                            |
| 8   | EC    | R/W | <p>过度冲突 (Excessive Collision)<br/>当设置此位时, 该位表示在尝试发送当前帧时, 连续 16 次碰撞后发送被终止。如果设置 MAC_CFG[9], 则该位在第一次碰撞后设置, 帧的发送将中止。</p>                                                                |
| 9   | LC    | R/W | <p>延迟冲突 (Late Collision)<br/>设置此位时, 表示由于冲突窗口后发生冲突而终止帧发送。如果设置了下溢错误则此位无效。</p>                                                                                                         |
| 10  | NC    | R/W | <p>无载波 (No Carrier)<br/>当设置时, 此位表示在发送过程中不断监听形成 PHY 的载波检测信号。</p>                                                                                                                     |
| 11  | LSC   | R/W | <p>丢失载波 (Loss of Carrier)<br/>当设置此位时, 表示帧发送过程中丢失载波。只当 MAC 工作在半双工模式对无冲突发送的帧有效。</p>                                                                                                   |
| 12  | IPERR | R/W | <p>IP 有效负载错误 (IP Payload Error)<br/>该位置 1 时, MAC 发送器在 TCP、UDP 或 ICMP IP 数据包有效负载中检测到错误。发送器将从应用程序接收的 TCP、UDP 或 ICMP IP 数据包实际字节数检查 IPv4 或 IPv6 报头中接收的有效负载长度进行对照, 如果出现不匹配, 则显示错误状态。</p> |
| 13  | FF    | R/W | <p>帧刷新 (Frame Flushed)<br/>当设置此位时, 该位表示 DMA 或 MTL 由于 CPU 给出的软件刷新命令而刷新帧。</p>                                                                                                         |
| 14  | JTO   | R/W | <p>Jabber 超时 (Jabber Timeout)<br/>设置此位时, 表示 MAC 发送器经历了 Jabber 超时。只有当 MAC_CFG 寄存器的 JDIS 位没有被设置时, 才会设置该位。</p>                                                                         |
| 15  | ERRS  | R/W | <p>错误汇总 (Error Summary)<br/>值为以下位的或运算结果:<br/>TXDES0[1]: UFERR<br/>TXDES0[2]: EDEF<br/>TXDES0[8]: EC<br/>TXDES0[9]: LC<br/>TXDES0[10]: NC</p>                                        |

| 位/域   | 名称     | R/W | 描述                                                                                                                                                                                                                                                       |
|-------|--------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |        |     | TXDES0[11]: LSC<br>TXDES0[12]: IPERR<br>TXDES0[13]: FF<br>TXDES0[14]: JTO<br>TXDES0[16]: IHERR                                                                                                                                                           |
| 16    | IHERR  | R/W | <b>IP 报头错误 (IP Header Error)</b><br>该位置 1 时, 指示 MAC 发送器在 IP 数据报头中检测到错误。发送器将对照从应用程序接收的报头字节数检查 IPv4 数据包的报头长度, 如果出现不匹配, 则指示错误状态。如果 IPv6 帧的主报头长度不是 40 个字节, 则报告一个报头错误。如果 IPv4 帧的报头长度字段的值小于 0x5, 也会报告一个报头错误。此外, IPv4 或 IPv6 帧的以太网长度/类型字段值必须与随数据包接收的 IP 报头版本匹配。 |
| 17    | TXTSS  | R/W | <b>发送时间戳状态 (TX Timestamp Status)</b><br>此状态位表示已捕获相应发送帧的时间戳。当设置此位时, TXDES2 和 TXDES3 具有为发送帧捕获的时间戳值。该位域仅在描述符中最后段控制位 (TXDES0[29]) 被设置时有效。<br>使能增强的描述符时, TXTSS=1 表示 TXDES6 和 TXDES7 中存有时间戳值。                                                                  |
| 19:18 | 保留     |     |                                                                                                                                                                                                                                                          |
| 20    | TXCH   | R/W | <b>次链接地址 (Second Address Chained)</b><br>该位置 1 时, 描述符中的第二个地址是下一个描述符地址, 而非第二个缓冲区地址, 且 TXDES1[28:16] 为“无关”值。TXDES0[21]优先级高于 TXDES0[20]。                                                                                                                    |
| 21    | TXENDR | R/W | <b>环发送结束 (Transmit End of Ring)</b><br>该位置 1 时, 描述符列表已到达其最后一个描述符。DMA 会返回描述符列表的基址, 并形成一个描述符环。                                                                                                                                                             |
| 23:22 | CHINS  | R/W | <b>控制校验和插入 (Checksum Insertion Control)</b><br>这些位控制校验和的计算与插入。位编码如下所示:<br>00: 禁用插入校验和<br>01: 使能 IP 报头校验和的计算与插入<br>10: 使能有效负载校验和及 IP 报头校验和的计算与插入, 但不会在硬件中计算伪报头校验和<br>11: 使能有效负载校验和及 IP 报头校验和的计算与插入, 并在硬件中计算伪报头校验和。                                        |
| 24    | 保留     |     |                                                                                                                                                                                                                                                          |
| 25    | TXTSEN | R/W | <b>发送时间戳使能 (Transmit Timestamp Enable)</b><br>该位置 1 且 TSEN 置 1 时, 将针对描述符所描述的发送帧激活 IEEE1588 硬件时间戳功能。该位仅在 TXDES0[28]=1 的情况下有效。                                                                                                                             |
| 26    | DISP   | R/W | <b>禁止填充 (Disable Pad)</b><br>0: DMA 会自动为不足 64 字节的帧添加补位项和 CRC, 是否添加 CRC 字段与 TXDES0[27]无关<br>1: MAC 不会自动为不足 64 字节的帧添加补位项<br>该位仅在 TXDES0[28]=1 的情况下有效。                                                                                                      |
| 27    | DISC   | R/W | <b>禁止 CRC (Disable CRC)</b><br>该位置 1 时, MAC 不会将 CRC 附加到所发送帧的末尾。该位仅在 TXDES0[28]=1 的情况下有效。                                                                                                                                                                 |
| 28    | FS     | R/W | 首段 (First Segment)                                                                                                                                                                                                                                       |

| 位/域 | 名称   | R/W | 描述                                                                                                                  |
|-----|------|-----|---------------------------------------------------------------------------------------------------------------------|
|     |      |     | 该位置 1 时, 表示缓冲区中包含帧的首段。                                                                                              |
| 29  | LS   | R/W | 末段 (Last Segment)<br>该位置 1 时, 表示缓冲区中包含帧的末段。                                                                         |
| 30  | INTC | R/W | 完成后中断 (Interrupt on Completion)<br>该位置 1 时, 当前帧发送完毕后, 发送一个中断。                                                       |
| 31  | OWN  | R/W | 所属位 (Own)<br>0: 该描述符属于 CPU<br>1: 该描述符属于 DMA<br>DMA 在完成帧发送或描述符中分配的缓冲区为空时清除此位。该帧的第一个描述符的所有位应该在所有属于同一帧的后续描述符被设置之后进行设置。 |

#### 发送描述符字 1 (TXDES1)

| 位/域   | 名称    | R/W | 描述                                                                                                               |
|-------|-------|-----|------------------------------------------------------------------------------------------------------------------|
| 12:0  | TXBS1 | R/W | 发送缓冲区 1 大小 (Transmit Buffer 1 Size)<br>这些位表示第一个数据缓冲区大小。如果该位为 0, DMA 将忽略该缓冲区并使用缓冲区 2 或下一个描述符, 具体取决于 TXDES0[20]的值。 |
| 15:13 |       |     | 保留                                                                                                               |
| 28:16 | TXBS2 | R/W | 发送缓冲区 2 大小 (Transmit Buffer 2 Size)<br>这些位以字节表示第二数据缓冲区大小。如果 TXDES0[20]=1, 则该字段无效。                                |
| 31:29 |       |     | 保留                                                                                                               |

#### 发送描述符字 2 (TXDES2)

| 位/域  | 名称             | R/W | 描述                                                                                                                                                                                                                                                                                                                |
|------|----------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | TXADDR1_TXFTSL | R/W | 发送缓冲区 1 地址指针/发送帧时间戳低位 (Transmit Buffer 1 Address Pointer / Transmit Frame Timestamp Low)<br>向 DMA 指示数据在存储器中的位置, 当所有数据发送完毕后, DMA 可利用这些位传回时间戳数据。<br>TXADDR1: 当 TXDES0[31]=1 时, 这些位表示缓冲区 1 的物理地址。缓冲区地址对齐方式没有限制。<br>TXFTSL: 在将 TXDES0[31]清零前, DMA 将使用为相应发送帧所捕获的时间戳的 32 个最低有效位更新该字段。只有在该帧的时间戳功能被激活且 LS=1 时, 该位域才包含时间戳。 |

#### 发送描述符字 3 (TXDES3)

| 位/域  | 名称             | R/W | 描述                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|----------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | TXADDR2_TXFTSH | R/W | <p>发送缓冲区 2 地址指针（下一描述符地址）/发送帧时间戳高位（Transmit Buffer 2 Address Pointer (Next descriptor address) / Transmit Frame Timestamp High）<br/> 向 DMA 指示数据在存储器中的位置，当所有数据发送完毕后，DMA 可利用这些位传回时间戳数据。</p> <p>TXADDR2：当 TXDES0[31]=1 且使用描述符环结构时，这些位表示缓冲区 2 的物理地址。如果 TXDES1[24]=1，则该地址包含下一个描述符所在物理寄存器的指针。只有在 TXDES1[24]=1 时，缓冲区地址指针才与总线宽度相符。</p> <p>TXFTSH：在将 TXDES0[31] 清零前，DMA 将使用为相应发送帧所捕获的时间戳的 32 个最高有效位更新该字段。只有在该帧的时间戳功能被激活且 LS=1 时，该位域才包含时间戳。</p> |

#### 27.3.4.8 增强发送描述符功能描述

如果时间戳或 IPv4 校验和减荷已激活，则必须使用增强的描述符。增强的描述符由 8 个 32 位字组成，即描述符正常大小的两倍。TXDES0、TXDES1、

TXDES2 和 TXDES3 的定义与常规发送描述符相同。TXDES6 和 TXDES7 包含时间戳。

选择增强的描述符模式时，需要为每个描述符分配 32 个字节的内存。如果未使用时间戳或 IPv4 校验和减荷，则可以禁止增强的描述符格式，而软件可使用默认大小为 16 字节的常规描述符。

#### 发送描述符字 4 (TXDES4)

| 位/域  | 名称 | R/W | 描述 |
|------|----|-----|----|
| 31:0 |    |     | 保留 |

#### 发送描述符字 5 (TXDES5)

| 位/域  | 名称 | R/W | 描述 |
|------|----|-----|----|
| 31:0 |    |     | 保留 |

#### 发送描述符字 6 (TXDES6)

| 位/域  | 名称     | R/W | 描述                                                                                                             |
|------|--------|-----|----------------------------------------------------------------------------------------------------------------|
| 31:0 | TXFTSL | R/W | <p>发送帧时间戳低位（Transmit Frame Timestamp Low）<br/> 该位域由 DMA 使用为相应发送帧所捕获的时间戳的 32 个最低有效位更新。只有在 LS=1 时，该位域才包含时间戳。</p> |

#### 发送描述符字 7 (TXDES7)

| 位/域  | 名称     | R/W | 描述                                                                                                              |
|------|--------|-----|-----------------------------------------------------------------------------------------------------------------|
| 31:0 | TXFTSH | R/W | <p>发送帧时间戳高位（Transmit Frame Timestamp High）<br/> 该位域由 DMA 使用为相应发送帧所捕获的时间戳的 32 个最高有效位更新。只有在 LS=1 时，该位域才包含时间戳。</p> |

### 27.3.4.9 Rx DMA

#### 获取接收描述符

接收器始终尝试获取一个额外的描述符加入即将接收到的帧。

当以下任意操作发生时，即尝试获取描述符：

- (1) 已发出接收轮询要求命令
- (2) DMA 运行后，ETH\_DMAOPMOD 寄存器的 STRX 位立即置位
- (3) 当前传输的帧结束前，描述符数据缓冲区已满
- (4) 接收过程因 RDES0[OWN]=0 而挂起，且接收到新帧
- (5) 接收数据帧完成，但接收描述符未关闭

#### 处理接收帧

只有当帧大小不小于为接收 FIFO 设置的阈值字节数的帧通过地址过滤时，或在存储转发模式下将整个帧写入 FIFO 时，MAC 才会将接收的帧传输到存储器。

#### 接收时停止

如果接收过程挂起时检测到新的接收帧，则 DMA 将重新获取存储器中的当前描述符。若该描述符为 DMA 所有，将重新接收帧。若为主机所有，则默认情况下，DMA 将丢弃 Rx FIFO 顶部的当前帧且丢失帧计数器递增。如果 Rx FIFO 中存储了多个帧，将重复执行上述过程。设置 ETH\_DMAOPMOD 寄存器的 DISFRXF 位后可避免丢弃或刷新 Rx FIFO 顶部的帧。此时 RXBU 位置 1 且接收过程返回挂起状态。

### 27.3.4.10 常规接收描述符功能描述

常规接收描述符结构由 4 个 32 位字组成，如果时间戳功能或 IPv4 校验和减荷已激活，则必须使用增强的描述符。

#### 接收描述符字 0 (RXDES0)

| 位/域 | 名称       | R/W | 描述                                                                                                                                                                                                                                                                                                    |
|-----|----------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | PERR_ESA | R/W | <p>负载校验和错误/扩展状态可用 (Payload Checksum Error / Extended Status Available)</p> <p>当设置此位时，核心计算出的 TCP、UDP 或 ICMP 校验和不匹配接收到的封装的 TCP、UDP 或 ICMP 段的校验和字段。当接收到的有效载荷字节数与接收到的以太网帧中封装的 IPv4 或 IPv6 数据报的长度字段的值不匹配时，也会设置此位。</p> <p>使能增强的描述符格式后，该位具有 ESA 功能。ESA 置 1 时，表示 RXDES4 中存在扩展状态。只有 RXDES0[8]=1 时，ESA 才有效。</p> |
| 1   | CERR     | R/W | <p>CRC 错误 (CRC Error)</p> <p>当设置此位时，在接收帧上发生 CRC 错误。该位仅在 RXDES0[8]=1 时有效</p>                                                                                                                                                                                                                           |

| 位/域 | 名称         | R/W | 描述                                                                                                                                                                                                                                                                                       |
|-----|------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2   | DERR       | R/W | <p><b>Dribble 帧错误 (Dribble Error)</b><br/>当设置此位时, 接收帧具有非整数字节的倍数。该位仅在 MII 模式下有效。</p>                                                                                                                                                                                                      |
| 3   | RERR       | R/W | <p><b>接收错误 (Receive Error)</b><br/>当设置此位时, 在帧接收期间发出 RX_DV 信号时, 会产生 RX_ERR 信号。</p>                                                                                                                                                                                                        |
| 4   | RXWDTTO    | R/W | <p><b>接收看门狗超时 (Receive Watchdog Timeout)</b><br/>当设置此位时, 接收看门狗定时器在接收当前帧时已超时, 当前帧在看门狗超时后被截断。</p>                                                                                                                                                                                          |
| 5   | FT         | R/W | <p><b>帧类型 (Frame Type)</b><br/>0: 接收帧是以太网类型的帧<br/>1: 接收帧是 IEEE802.3 帧<br/>当设置或重置此位时, 对小于 14 字节的短帧无效。</p>                                                                                                                                                                                 |
| 6   | LC         | R/W | <p><b>延迟冲突 (Late Collision)</b><br/>当设置此位时, 在以半双工模式接收帧时发生了延迟冲突。</p>                                                                                                                                                                                                                      |
| 7   | IPCERR_TSV | R/W | <p><b>IPv 报头校验和错误/时间戳有效 (IPv header Checksum Error / Time Stamp Valid)</b><br/>当设置此位时, IPv4 或 IPv6 报头中存在错误。<br/>原因可能是: 以太网类型字段与 IP 报头版本字段值不一致、与 IPv4 中报头的校验和不匹配, 或以太网帧缺少所需的 IP 报头字节数。<br/>使能增强的描述符格式后, 该位具有 TSV 功能。TSV=1 时, 表示将在 RXDES6 和 RXDES7 中写入时间戳快照。只有 RXDES0[8]=1 时, TSV 才有效。</p> |
| 8   | LDES       | R/W | <p><b>最后描述符 (Last Descriptor)</b><br/>当设置此位时, 该描述符所指向的缓冲区是帧的最后缓冲区。</p>                                                                                                                                                                                                                   |
| 9   | FDES       | R/W | <p><b>开头描述符 (First Descriptor)</b><br/>当设置此位时, 该描述符包含帧的第一个缓冲区。如果第一个缓冲区的大小是 0, 第二个缓冲区包含帧的开头。如果第二个缓冲区的大小也是 0, 则下一个描述符包含帧的开头。</p>                                                                                                                                                           |
| 10  | VLANF      | R/W | <p><b>VLAN 帧 (VLAN Frame)</b><br/>当设置此位时, 该描述符所指的帧是带有 MAC 标记的 VLAN 帧。</p>                                                                                                                                                                                                                |
| 11  | OFERR      | R/W | <p><b>上溢错误 (Overflow Error)</b><br/>当设置此位时, 接收的帧由于 Rx FIFO 中的缓冲区溢出而损坏。</p>                                                                                                                                                                                                               |
| 12  | LERR       | R/W | <p><b>长度错误 (Length Error)</b><br/>当设置此位时, 收到的帧的实际长度, 并且长度/类型字段不匹配。<br/>只有 RXDES0[5]=0 时, 该位才有效。</p>                                                                                                                                                                                      |
| 13  | SADDRF     | R/W | <p><b>源地址过滤失败 (Source Address Filter Fail)</b><br/>当设置此位时, 帧的 SA 字段没有通过 MAC 中的 SA 过滤器。</p>                                                                                                                                                                                               |
| 14  | DESERR     | R/W | <p><b>描述符错误 (Descriptor Error)</b><br/>当设置此位时, 该位表示由于帧不适合当前描述符缓冲区而导致的帧截断, 并且 DMA 没有下一个描述符。帧被截断了。<br/>注意: 该字段仅在设置了最后描述符 (RXDES0[8]) 时有效。</p>                                                                                                                                              |
| 15  | ERRS       | R/W | <p><b>错误汇总 (Error Summary)</b><br/>值为以下位的或运算结果:<br/>RXDES0[0]: PERR_ESA<br/>RXDES0[1]: CERR<br/>RXDES0[3]: RERR</p>                                                                                                                                                                      |

| 位/域   | 名称    | R/W | 描述                                                                                                                              |
|-------|-------|-----|---------------------------------------------------------------------------------------------------------------------------------|
|       |       |     | RXDES0[4]: RXWDTTO<br>RXDES0[6]: LC<br>RXDES0[7]: IPCERR_TSV<br>RXDES0[11]: OFERR<br>RXDES0[14]: DESERR                         |
| 29:16 | FL    | R/W | 帧长度 (Frame Length)<br>此位域表示被发送到主机内存的接收帧的字节长度。该位只有在 RXDES0[8]=1 且 RXDES0[14]=0 时才有效。<br>当 RXDES0[8]=0 且 ERRS=0 时表示已为当前帧发送的累计字节数。 |
| 30    | ADDRF | R/W | 目的地址过滤失败 (Destination Address Filter Fail)<br>当设置此位时，表示 MAC 中 DA 过滤失败的帧。                                                        |
| 31    | OWN   | R/W | 所属位 (Own)<br>0: 该描述符属于 CPU<br>1: 该描述符属于 DMA<br>DMA 在完成帧接收或描述符中分配的缓冲区为满时清除此位。                                                    |

表格 139 正常描述符格式中的配置

| 位 0<br>(PERRC_ESA) | 位 5<br>(FT) | 位 7<br>(IPCERR_TSV) | 帧状态                                            |
|--------------------|-------------|---------------------|------------------------------------------------|
| 0                  | 0           | 0                   | IEEE 802.3 类型帧                                 |
| 1                  | 0           | 1                   | 既不是 IPv4 也不是 IPv6 的类型帧                         |
| 0                  | 1           | 0                   | IPv4/IPv6 类型帧，未检测到校验和错误                        |
| 1                  | 1           | 0                   | IPv4/IPv6 类型帧，检测到有效负载校验和错误                     |
| 0                  | 1           | 1                   | IPv4/IPv6 类型帧，检测到 IP 报头校验和错误                   |
| 1                  | 1           | 1                   | IPv4/IPv6 类型帧，检测到 IP 报头和有效负载校验和错误              |
| 1                  | 0           | 0                   | IPv4/IPv6 类型帧，无 IP 报头校验和错误，有效负载检查因有效负载不受支持而被绕过 |
| 0                  | 0           | 1                   | 保留                                             |

### 接收描述符字 1 (RXDES1)

| 位/域  | 名称    | R/W | 描述                                                                                                                                                                                          |
|------|-------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12:0 | RXBS1 | R/W | 接收缓冲区 1 大小 (Receive Buffer 1 Size)<br>0: DMA 将忽略该缓冲区，并根据 RXCH 位的值使用缓冲区 2 或下一个描述符。<br>其他：指第一个数据缓冲区大小。缓冲区大小必须是 4、8 或 16 的倍数，这取决于总线宽度，即使缓冲区 2 地址指针的值没有对齐。在缓冲区大小不是 4、8 或 16 的倍数的情况下，产生的行为是未定义的。 |
| 13   |       |     | 保留                                                                                                                                                                                          |
| 14   | RXCH  | R/W | 次地址链接 (Second Address Chained)<br>设置此位时，表示描述符中的第二个地址是下一个描述符地址，而不是第二个缓冲区地址。忽略 RXBS2 的值。RXER 优先于 RXCH。                                                                                        |
| 15   | RXER  | R/W | 环接收结束 (Receive End of Ring)                                                                                                                                                                 |

| 位/域   | 名称    | R/W | 描述                                                                                                                                                                                                  |
|-------|-------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |       |     | 设置此位时, 表示描述符列表到达了最终的描述符。DMA 返回到列表的基地址, 创建一个描述符环。                                                                                                                                                    |
| 28:16 | RXBS2 | R/W | <p>接收缓冲区 2 大小 (Receive Buffer 2 Size)<br/>           指第二个数据缓冲区大小。缓冲区大小必须是 4、8 或 16 的倍数, 这取决于总线宽度, 即使缓冲区 1 地址指针的值没有对齐。在缓冲区大小不是 4、8 或 16 的倍数的情况下, 产生的行为是未定义的。<br/>           如果设置了 RXCH 位, 此位域无效。</p> |
| 30:29 | 保留    |     |                                                                                                                                                                                                     |
| 31    | DINTC | R/W | <p>禁止完成中断 (Interrupt on Completion Disable)<br/>           设置此位时, 会阻止 RXFLG 位的设置, 使接收的帧在由该描述符指示的缓冲区中结束, 从而禁止引发主机中断。</p>                                                                             |

### 接收描述符字 2 (RXDES2)

| 位/域  | 名称             | R/W | 描述                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|----------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RXADDR1_RXFTSL | R/W | <p>接收缓冲区 1 地址指针/接收时间戳低位 (Receive Buffer 1 Address Pointer / Receive Frame Timestamp Low)<br/>           向 DMA 指示数据在存储器中的位置, 当所有数据发送完毕后, DMA 可利用这些位传回时间戳数据。<br/> <b>RXADDR1:</b> 当 RXDES0[OWN]=1 时, 这些位表示缓冲区 1 的物理地址。除了当使用 RXDES2 的值存储帧起点时, 地址是由 DMA 使用配置的值生成的。在发送帧开始期间, DMA 将在 RXDES2[3:0]=0 的情况下执行写操作, 但帧数据会根据实际的缓冲区地址指针进行移位。当地址指针指向存储有帧中间部分或最后部分的缓冲区时, DMA 将忽略 RXDES2[3:0] 之外。缓冲区地址对齐方式没有限制。<br/> <b>RXFTSL:</b> 在将 RXDES0[OWN] 清零前, DMA 将使用为相应发送帧所捕获的时间戳的 32 个最低有效位更新该字段。只有在该帧的时间戳功能被激活且 LS=1 时, 该位域才包含时间戳。</p> |

### 接收描述符字 3 (RXDES3)

| 位/域  | 名称             | R/W | 描述                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|----------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RXADDR2_RXFTSH | R/W | <p>接收缓冲区 2 地址指针 (下一描述符地址) /发送帧时间戳高位 (Receive Buffer 2 Address Pointer (Next Descriptor Address) / Receive Frame Timestamp High)<br/>           向 DMA 指示数据在存储器中的位置, 当所有数据发送完毕后, DMA 可利用这些位传回时间戳数据。<br/> <b>RXADDR1:</b> 当 RXDES0[OWN]=1 且使用描述符环结构时, 这些位表示缓冲区 2 的物理地址。如果 RXDES[24]=1, 则该地址包含下一个描述符所在物理寄存器的指针。只有在 RXDES1[24]=1 时, 缓冲区地址指针才与总线宽度相符。当 RXDES[24]=0 时, 除了当使用 RXDES2 的值存储帧起点时, 地址是由 DMA 使用配置的值生成的。当地址指针指向存储有帧中间部分或最后部分的缓冲区时, DMA 将忽略 RXDES2[3:0] 之外, 缓冲区地址对齐方式没有限制。<br/> <b>RXFTSH:</b> 在将 RXDES0[OWN] 清零前, DMA 将使用为相应发送帧所捕获的时间戳的 32 个最低有效位更新该字段。只有在该帧的时间戳功能被激活且 LS=1 时, 该位域才包含时间戳。</p> |

#### 27.3.4.11 增强接收描述符功能描述

如果时间戳或 IPv4 校验和减荷已激活，则必须使用增强的描述符。增强的描述符由 8 个 32 位字组成，即描述符正常大小的两倍。RXDES0、RXDES1、RXDES2 和 RXDES3 的定义与常规接收描述符相同。RXDES4 包含扩展状态，RXDES6 和 RXDES7 包含时间戳。

选择增强的描述符模式时，需要为每个描述符分配 32 个字节的内存。如果未使用时间戳或 IPv4 校验和减荷，则可以禁止增强的描述符格式，而软件可使用默认大小为 16 字节的常规描述符。

#### 接收描述符字 4 (RXDES4)

当存在与 IPv4 校验和或时间戳相关联的状态时才有效。

| 位/域  | 名称     | R/W | 描述                                                                                                                                                                                                                                                                                                                                                                                 |
|------|--------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0  | IPPT   | R/W | <p>IP 有效负载字节 (IP Payload Type)<br/>如果激活 IPv4 校验和减荷，表示 IP 数据报中封装的有效负载类型。当 IP 报头出错或存在分段的 IP 时，这些位为“00”。<br/>000: 未知，或未处理 IP 有效负载<br/>001: UDP<br/>010: TCP<br/>011: ICMP<br/>1xx: 保留</p>                                                                                                                                                                                             |
| 3    | IPHERR | R/W | <p>IP 报头错误 (IP Header Error)<br/>设置此位时，由内核计算的 16 位 IPv4 报头校验和与接收的校验和不匹配，或 IP 数据报版本与以太网类型值不匹配。</p>                                                                                                                                                                                                                                                                                  |
| 4    | IPPERR | R/W | <p>IP 有效负载错误 (IP Payload Error)<br/>设置此位时，由内核计算的 16 位 IP 有效负载校验和与接收的校验和不匹配。当 TCP、UDP 或 ICMP 段长度与 IP 报头字段中的有效负载长度值不匹配时也会置 1。</p>                                                                                                                                                                                                                                                    |
| 5    | IPCBP  | R/W | <p>绕过 IP 校验和 (IP Checksum Bypassed)<br/>设置此位时，绕过校验和减荷引擎。</p>                                                                                                                                                                                                                                                                                                                       |
| 6    | IPV4P  | R/W | <p>接收到 IPv4 数据包 (Receive IPv4 Packet)<br/>设置此位时，接收到 IPv4 数据包。</p>                                                                                                                                                                                                                                                                                                                  |
| 7    | IPV6P  | R/W | <p>接收到 IPv6 数据包 (Receive IPv6 Packet)<br/>设置此位时，接收到 IPv6 数据包。</p>                                                                                                                                                                                                                                                                                                                  |
| 11:8 | PTPMT  | R/W | <p>PTP 消息类型 (PTP Message Type)<br/>0000: 未接收到 PTP 消息<br/>0001: SYNC (所有时钟类型)<br/>0010: Follow_Up (所有时钟类型)<br/>0011: Delay_Req (所有时钟类型)<br/>0100: Delay_Resp (所有时钟类型)<br/>0101: Pdelay_Req (在点对点透明时钟中) 或 Announce (在普通时钟或边界时钟中)<br/>0110: Pdelay_Resp (在点对点透明时钟中) 或 Management (在普通时钟或边界时钟中)<br/>0111: Pdelay_Resp_Follow_Up (在点对点透明时钟中) 或 Signaling (在普通时钟或边界时钟中)<br/>1xxx: 保留</p> |
| 12   | PTPFT  | R/W | PTP 帧类型 (PTP Frame Type)                                                                                                                                                                                                                                                                                                                                                           |

| 位/域   | 名称   | R/W | 描述                                                                                   |
|-------|------|-----|--------------------------------------------------------------------------------------|
|       |      |     | 0: 通过 UDP-IPv4 或 UDP-IPv6 发送<br>1: 通过以太网发送<br>仅当消息类型为非零时才有效。接收到的数据包类型可通过位 6 或位 7 识别。 |
| 13    | PTPV | R/W | PTP 版本 (PTP Version)<br>接收的 PTP 消息使用的版本格式<br>0: 版本 1<br>1: 版本 2<br>仅当消息类型为非零时才有效。    |
| 31:14 |      |     | 保留                                                                                   |

#### 接收描述符字 5 (RXDES5)

| 位/域  | 名称 | R/W | 描述 |
|------|----|-----|----|
| 31:0 |    |     | 保留 |

#### 接收描述符字 6 (RXDES6)

| 位/域  | 名称     | R/W | 描述                                                                                                                                |
|------|--------|-----|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RXFTSL | R/W | 接收帧时间戳低位 (Receive Frame Timestamp Low)<br>该位域由 DMA 使用为相应接收帧所捕获的时间戳的 32 个最低有效位更新。DMA 仅为接收帧的最后描述符更新该位域。当同时设置该位域和 RXFTSH 时，视为时间戳已损坏。 |

#### 接收描述符字 7 (RXDES7)

| 位/域  | 名称     | R/W | 描述                                                                                                                                 |
|------|--------|-----|------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RXFTSH | R/W | 接收帧时间戳高位 (Receive Frame Timestamp High)<br>该位域由 DMA 使用为相应接收帧所捕获的时间戳的 32 个最高有效位更新。DMA 仅为接收帧的最后描述符更新该位域。当同时设置该位域和 RXFTSL 时，视为时间戳已损坏。 |

### 27.3.4.12 DMA 中断

存在正常中断和异常中断两组中断。向 **ETH\_DMASTS** 寄存器的对应位进行写操作可清除中断。当组内所有使能的中断都清除时，其汇总位也被清零。如果引发中断的原因是 **MAC** 内核，则 **ETH\_DMASTS** 寄存器中的 **PMTFLG** 或 **TSTFLG** 位都被置为高电平。

### 27.3.5 以太网中断

以太网控制器有两个中断向量：一个用于正常以太网操作，一个用于仅当映射到 **EINT 19** 时的以太网唤醒事件。第一个以太网向量为 **MAC** 和 **DMA** 生成的中断而保留。第二个为发生唤醒事件时 **PMT** 生成的中断而保留。唤醒事件对 **EINT 19** 的映射使内核退出低功耗模式并产生中断。

当映射到 **EINT 19** 的以太网唤醒事件发生、同时使能了 **MAC PMT** 中断和带上升沿检测的 **EINT 19** 中断时，会产生两个中断。

## 27.4 MAC 寄存器地址映射

表格 140 寄存器地址映射

| 寄存器名称          | 描述            | 偏移地址 |
|----------------|---------------|------|
| MAC_CFG        | 配置寄存器         | 0x00 |
| MAC_FRAF       | 帧过滤寄存器        | 0x04 |
| MAC_HTH        | Hash 表高位寄存器   | 0x08 |
| MAC_HTL        | Hash 表低位寄存器   | 0x0C |
| MAC_ADDR       | MII 地址寄存器     | 0x10 |
| MAC_DATA       | MII 数据寄存器     | 0x14 |
| MAC_FCTRL      | 接收流量控制寄存器     | 0x18 |
| MAC_VLANT      | VLAN 标记寄存器    | 0x1C |
| MAC_REMWKUPFFL | 远程唤醒帧过滤寄存器    | 0x28 |
| MAC_PMTCTRLSTS | PMT 控制和状态寄存器  | 0x2C |
| MAC_DBG        | 调试寄存器         | 0x34 |
| MAC_ISTS       | 中断状态寄存器       | 0x38 |
| MAC_IMASK      | 中断屏蔽寄存器       | 0x3C |
| MAC_ADDR0H     | MAC 地址 0 高寄存器 | 0x40 |
| MAC_ADDR0L     | MAC 地址 0 低寄存器 | 0x44 |
| MAC_ADDR1H     | MAC 地址 1 高寄存器 | 0x48 |
| MAC_ADDR1L     | MAC 地址 1 低寄存器 | 0x4C |
| MAC_ADDR2H     | MAC 地址 2 高寄存器 | 0x50 |
| MAC_ADDR2L     | MAC 地址 2 低寄存器 | 0x54 |
| MAC_ADDR3H     | MAC 地址 3 高寄存器 | 0x58 |
| MAC_ADDR3L     | MAC 地址 3 低寄存器 | 0x5C |

## 27.5 MAC 寄存器功能描述

### 27.5.1 配置寄存器 (MAC\_CFG)

偏移地址: 0x00

复位值: 0x0000 8000

| 位/域 | 名称   | R/W | 描述                                                                                             |
|-----|------|-----|------------------------------------------------------------------------------------------------|
| 1:0 |      |     | 保留                                                                                             |
| 2   | RXEN | R/W | 使能接收器 (Receiver Enable)<br>MAC 的接收状态机能够从 MII 接收帧。复位该位后, MAC 接收状态机将在当前帧接收完成后关闭, 不再从 MII 接收到任何帧。 |

| 位/域 | 名称     | R/W | 描述                                                                                                                                                                                                                                                                                |
|-----|--------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3   | TXEN   | R/W | 使能发送器 (Transmitter Enable)<br>MAC 的发送状态机能够在 MII 上进行发送。复位该位后, 当前帧完成发送后, 将关闭 MAC 发送状态机, 不再发送任何帧。                                                                                                                                                                                    |
| 4   | DC     | R/W | 延期检查 (Deferral Check)<br>延期检查功能使能 MAC。当发送状态机延迟超过 24288 位乘以 10 或 100 Mbps 的模式时, MAC 标识帧中止状态, 同时在发送帧的状态时设置过度延迟误差。<br>当该位复位时, 直到 CRS 信号变为无效信号之前, 该位都禁止延期检查功能, MAC 发生延迟。该位仅在半双工模式下适用。                                                                                                 |
| 6:5 | BL     | R/W | 后退限制 (Back Off Limit)<br>该位决定了在冲突后重试时 MAC 在重新发送尝试前等待的时间延迟 (1000mbps 为 4096 位时间, 10/100mbps 为 512 位时间)的随机整数。<br>该位仅在半双工模式下使用。<br>00: $k = \min(n, 10)$<br>01: $k = \min(n, 8)$<br>10: $k = \min(n, 4)$<br>11: $k = \min(n, 1)$<br>其中 $n$ =重传尝试的次数。随机整数 $r$ 的取值范围为 $0 \leq r < 2^k$ |
| 7   | ACS    | R/W | 去除自动 Pad/CRC (Automatic Pad or CRC Stripping)<br>MAC 只有在位长度小于 1536 字节时, 才会在传入帧时去除 Pad 或 FCS。所有接收到的位长度大于或等于 1536 字节的帧都被传递给应用程序, 而不用去除 Pad 或 FCS。当这个位被重置时, MAC 将不修改所有传入的帧发送给主机。                                                                                                     |
| 8   |        |     | 保留                                                                                                                                                                                                                                                                                |
| 9   | DISR   | R/W | 禁用重试 (Disable Retry)<br>MAC 只尝试一次发送。当 MII 接口发生冲突时, MAC 会忽略当前帧的发送, 并在发送帧状态下报告一个冲突错误较大的帧中止。复位该位时, 根据 BL 位的设置重新尝试 MAC。该位仅在半双工模式下使用。                                                                                                                                                  |
| 10  | IPC    | R/W | IPv4 校验和减荷 (IPv4 Checksum Offload)<br>MAC 计算所有接收到的以太网帧有效负载的 16 位 1 的补码和。它还检查接收以太网帧的 IPv4 头校验和对接收帧是否正确, 并在接收状态字中给出状态。复位此位时禁止此功能。                                                                                                                                                   |
| 11  | DM     | R/W | 双工模式 (Duplex Mode)<br>MAC 工作在全双工模式下, 可以同时发送和接收。                                                                                                                                                                                                                                   |
| 12  | LBM    | R/W | 环回模式 (Loopback Mode)<br>当设置此位时, MAC 在 MII 上以环回模式运行。MII 接收时钟输入 (RX_CLK)需要环回正常工作, 因为发送时钟内部没有环回。                                                                                                                                                                                     |
| 13  | DISRXO | R/W | 禁止接收自身 (Disable Receive Own)<br>当 phy_txen_o 确认为半双工模式时, MAC 禁止接收帧。当这个位被复位时, MAC 接收到所有由 PHY 发送的数据包。如果 MAC 工作在全双工模式, 则不适用此位。                                                                                                                                                        |
| 14  | SSEL   | R/W | 选择速度 (Speed select)<br>0: 10Mbps<br>1: 100Mbps                                                                                                                                                                                                                                    |
| 15  |        |     | 保留                                                                                                                                                                                                                                                                                |
| 16  | DISCRS | R/W | 在发送过程中禁止载波侦听 (Disable Carrier Sense During Transmission)                                                                                                                                                                                                                          |

| 位/域   | 名称     | R/W | 描述                                                                                                                                                                                                                                              |
|-------|--------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |        |     | 设置为高时，在半双工模式下帧发送时 MAC 发射机忽略 MII CRS 信号。此请求导致在此类发送过程中没有由于载波丢失或无载波而产生的错误。设置为低时，MAC 发送器产生载波侦听错误，甚至可以中止发送。                                                                                                                                          |
| 19:17 | IFG    | R/W | <p>帧间隔 (Inter-Frame Gap)<br/>         这些位用来控制发送过程中帧之间的最小间隙。<br/>         000: 96 位时间<br/>         001: 88 位时间<br/>         010: 80 位时间<br/>         ...<br/>         111: 40 位时间<br/>         在半双工模式下，最小 IFG 只能配置为 64 位(IFG = 100)，不考虑较低的值。</p> |
| 21:20 |        |     | 保留                                                                                                                                                                                                                                              |
| 22    | JDIS   | R/W | <p>禁止 Jabber (Jabber Disable)<br/>         MAC 关闭发送端的 Jabber 定时器。MAC 最多可以发送 16384 字节的帧。当这个位复位时，如果应用程序在发送过程中发送超过 2048 字节的数据，MAC 就会切断发送器。</p>                                                                                                     |
| 23    | WDTDIS | R/W | <p>禁止看门狗 (Watchdog Disable)<br/>         MAC 关闭接收端看门狗定时器。MAC 最多可以接收 16384 字节的帧。当该位复位时，MAC 不允许接收帧超过 2048 字节或看门狗超时寄存器。在看门狗限制字节数后，MAC 将禁止接收到任何字节。</p>                                                                                              |
| 24    |        |     | 保留                                                                                                                                                                                                                                              |
| 25    | CST    | R/W | <p>去除类型帧的 CRC (CRC Stripping for Type Frames)<br/>         所有以太类型帧的最后 4 个字节在转发给应用程序之前被去除并删除。</p>                                                                                                                                                |
| 31:26 |        |     | 保留                                                                                                                                                                                                                                              |

### 27.5.2 帧过滤寄存器 (MAC\_FRAF)

偏移地址: 0x04

复位值: 0x0000 0000

| 位/域 | 名称   | R/W | 描述                                                                                                                        |
|-----|------|-----|---------------------------------------------------------------------------------------------------------------------------|
| 0   | PR   | R/W | <p>混合模式 (Promiscuous Mode)<br/>         地址过滤模块将通过所有传入的帧，不管目的地址或源地址。接收状态字的 SA 或 DA 状态位总是被清除。</p>                           |
| 1   | HUC  | R/W | <p>散列单播 (Hash Unicast)<br/>         MAC 根据 hash 表对单播帧进行目的地址过滤。复位后 MAC 对单播帧执行完美的目的地址过滤，它将 DA 字段与 DA 寄存器中编程的值进行比较。</p>      |
| 2   | HMC  | R/W | <p>散列多播 (Hash Multicast)<br/>         MAC 根据 hash 表对接收的组播帧进行目的地址过滤。复位后 MAC 对组播帧执行完美的目的地址过滤，它将 DA 字段与 DA 寄存器中编程的值进行比较。</p> |
| 3   | DAIF | R/W | <p>DA 反过滤 (DA Inverse Filtering)<br/>         地址检查块以反过滤的方式对单播和组播帧的 DA 地址进行比较。复位后正常的帧过滤将被执行。</p>                           |

| 位/域   | 名称     | R/W | 描述                                                                                                                                                                                                                                                            |
|-------|--------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4     | PM     | R/W | 通过所有组播 (Pass All Multicast)<br>所有接收到的目的地址为组播地址 (目的地址字段的第一个为 1) 的帧都会被传递。复位后组播帧的过滤取决于 HMC 位。                                                                                                                                                                    |
| 5     | DISBF  | R/W | 禁止广播帧 (Disable Broadcast Frames)<br>地址过滤器过滤所有传入的广播帧。复位后地址过滤器发送所有接收到的广播帧。                                                                                                                                                                                      |
| 7:6   | PCTRLF | R/W | 通过控制帧 (Pass Control Frames)<br>这些位控制所有控制帧的转发(包括单播和多播暂停帧)。<br>00: MAC 过滤所有到达应用程序的控制帧。<br>01: 即使除暂停帧外的所有控制帧没有通过地址过滤器, MAC 也会将它们转发给应用程序。<br>10: 即使控制帧没有通过地址过滤器, MAC 也会将它们转发给应用程序。<br>11: MAC 转发通过地址过滤器的控制帧。<br>注意: 将设置 MAC_FCTRL 的 RXFCTRLLEN 位时, 使能 MAC 为全双工模式。 |
| 8     | SAIF   | R/W | SA 反过滤 (SA Inverse Filtering)<br>地址检查块对 SA 的地址比较以反过滤的方式进行。SA 与 SA 寄存器匹配的帧将被标记为 SA 地址过滤器失败。复位后 SA 与 SA 寄存器不匹配的帧将被标记为 SA 地址过滤器失败。                                                                                                                               |
| 9     | SAFEN  | R/W | 使能源地址过滤(Source Address Filter Enable)<br>MAC 将接收帧的 SA 字段与使能的 SA 寄存器中编程的值进行比较。如果比较失败, MAC 丢弃帧。复位后 MAC 根据 SA 地址比较, 将接收到的帧转发给接收状态的更新 SAFEN 位的应用程序。                                                                                                               |
| 10    | HPF    | R/W | Hash 或完美过滤器 (Hash or Perfect Filter)<br>如果匹配 HMC 或 HUC 位设置的完美过滤或 Hash 过滤, 它将配置地址过滤器通过帧。当此位低且 HUC 或 HMC 位被设置时, 帧只在匹配 Hash 过滤器时被传递。                                                                                                                             |
| 30:11 |        |     | 保留                                                                                                                                                                                                                                                            |
| 31    | RXA    | R/W | 接收全部 (Receive All)<br>MAC 接收模块将发送所有接收到的帧, 不管它们是否通过了地址过滤器。SA 或 DA 过滤的结果更新在接收状态字的相应位。当这个位被重置时, 接收模块只将这些帧传递给通过 SA 或 DA 地址过滤器的应用程序。                                                                                                                               |

### 27.5.3 Hash 表高位寄存器 (MAC\_HTH)

偏移地址: 0x08

复位值: 0x0000 0000

| 位/域  | 名称  | R/W | 描述                                           |
|------|-----|-----|----------------------------------------------|
| 31:0 | HTH | R/W | Hash 表高位 (Hash Table High)<br>Hash 表的高 32 位。 |

### 27.5.4 Hash 表低位寄存器 (MAC\_HTL)

偏移地址: 0x0C

复位值: 0x0000 0000

| 位/域  | 名称  | R/W | 描述                                          |
|------|-----|-----|---------------------------------------------|
| 31:0 | HTL | R/W | Hash 表低位 (Hash Table Low)<br>Hash 表的低 32 位。 |

### 27.5.5 MII 地址寄存器 (MAC\_ADDR)

偏移地址: 0x10

复位值: 0x0000 0000

| 位/域   | 名称 | R/W | 描述                                                                                                                                                                                                                                                         |
|-------|----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | MB | R/W | <p>MII 忙碌 (MII Busy)<br/>写入 MAC_HT 寄存器此位有效。在 PHY 寄存器访问期间，软件将该位设置为 1，表示正在进行读或写访问。因此，直到 MAC 清除这个位之前，在一个 PHY 写操作中 MII 数据应该保持有效。对于读操作，清除该位之后 MAC_HT 有效。后续的读写操作必须在上一个操作完成后才能进行。</p>                                                                             |
| 1     | MW | R/W | <p>MII 写操作 (MII Write)<br/>该位向 PHY 表示这是一个使用 MII 数据寄存器的写操作。如果没有设置此位，则表示这是一个读操作，数据将放入 MII 数据寄存器中。</p>                                                                                                                                                        |
| 4:2   | CR | R/W | <p>时钟范围 (Clock Range)<br/>CR 时钟范围的选择决定了 HCLK 的频率，用于决定 MDC 时钟的频率：<br/>选择 HCLK MDC 时钟<br/>000: 60-100 MHz-HCLK/42<br/>001: 100-150 MHz-HCLK / 62<br/>010: 20-35 MHz-HCLK/16<br/>011: 35-60 MHz-HCLK/26<br/>100: 150-240 MHz-HCLK/102<br/>101、110、111: 保留</p> |
| 5     |    |     | 保留                                                                                                                                                                                                                                                         |
| 10:6  | MR | R/W | <p>MII 寄存器 (MII Register)<br/>这些位在选定的 PHY 设备中选择所需的寄存器。</p>                                                                                                                                                                                                 |
| 15:11 | PA | R/W | <p>物理层地址 (Physical Layer Address)<br/>表示 32 个可能的 PHY 设备中哪些正在被访问。</p>                                                                                                                                                                                       |
| 31:16 |    |     | 保留                                                                                                                                                                                                                                                         |

### 27.5.6 MII 数据寄存器 (MAC\_DATA)

偏移地址: 0x14

复位值: 0x0000 0000

| 位/域   | 名称 | R/W | 描述                                                                                |
|-------|----|-----|-----------------------------------------------------------------------------------|
| 15:0  | MD | R/W | <p>MII 数据 (MII Data)<br/>执行管理读操作后从 PHY 读取的 16 位数据值，或执行管理写操作前写入 PHY 的 16 位数据值。</p> |
| 31:16 |    |     | 保留                                                                                |

### 27.5.7 接收流量控制寄存器 (MAC\_FCTRL)

偏移地址: 0x18

复位值: 0x0000 0000

| 位/域 | 名称         | R/W | 描述                                                                                                                                                             |
|-----|------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | FCTRLB/BPA | R/W | <p>流量控制繁忙/激活回压 (Flow Control Busy/Back Pressure Activate)<br/>在全双工模式下发起暂停控制帧，这个位应该在写到流量控制寄存器之前读为 0。应用程序必须将这个位设置为 1，才能初始化一个暂停控制帧。在控制帧的发送过程中，此位继续被设置为表示帧发送正在</p> |

| 位/域   | 名称                | R/W | 描述                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|-------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |                   |     | <p>进行中。在完成暂停控制帧发送后，MAC 将该位重置为 0。不能在清除此位之前写入流控制寄存器。</p> <p>在半双工模式下，如果设置了 <b>TXFCTRLLEN</b> 位则激活回压功能。当设置了这个位（并且设置了 <b>RXFCTRLLEN</b>）时，回压由 MAC 内核声明。在回压期间，当 MAC 接收到新帧时，发射器开始发送 JAM 模式，导致碰撞。当 MAC 配置为全双工模式时，BPA 自动关闭。</p>                                                                                                                                                                       |
| 1     | <b>TXFCTRLLEN</b> | R/W | <p>使能发送流控制（Transmit Flow Control Enable）</p> <p>在全双工模式下，当设置此位时，MAC 使能流控操作发送暂停帧。当该位被重置时，关闭 MAC 的流控制操作，MAC 不发送任何暂停帧。</p> <p>在半双工模式下，当设置此位时，MAC 启用回压操作。</p> <p>当这个位被重置时，回压特性将被禁用。</p>                                                                                                                                                                                                           |
| 2     | <b>RXFCTRLLEN</b> | R/W | <p>使能接收流控制（Receive Flow Control Enable）</p> <p>当设置此位时，MAC 将对接收到的暂停帧进行解码，并在指定的暂停时间内禁用其发射器。</p> <p>当该位被重置时，将禁止暂停帧的解码功能。</p>                                                                                                                                                                                                                                                                    |
| 3     | <b>UNPFDETE</b>   | R/W | <p>单播暂停帧检测（Unicast Pause Frame Detect）</p> <p>当设置此位时，除了使用唯一的组播地址检测暂停帧外，MAC 还使用 <b>MAC_ADDR0H</b> 和 <b>MAC_ADDR0L</b> 寄存器中指定的单播地址检测暂停帧。</p> <p>当该位被重置时，MAC 只检测到 802.3x 标准中指定的唯一组播地址的暂停帧。</p>                                                                                                                                                                                                  |
| 5:4   | <b>PTSEL</b>      | R/W | <p>选择暂停阈值（Pause Threshold Select）</p> <p>设置暂停帧自动重传的 <b>Pause</b> 定时器的阈值。阈值应该总是小于以位 [31:16] 配置的暂停时间。例如，如果 <b>PT</b> = 100H (256 槽位时间)，<b>PTSEL</b> = 01，那么在第一个 PAUSE 帧发送后，如果在 228 (256-28) 槽位时间发起第二个 PAUSE 帧，则自动发送第二个 PAUSE 帧。</p> <p>选择阈值</p> <p>00: 暂停时间- 4 槽位时间</p> <p>01: 暂停时间- 28 槽位时间</p> <p>10: 暂停时间- 144 槽位时间</p> <p>11: 暂停时间- 256 槽位时间</p> <p>槽位时间定义为 MII 接口发送 512 位 (64 字节) 的时间</p> |
| 6     |                   |     | 保留                                                                                                                                                                                                                                                                                                                                                                                           |
| 7     | <b>ZQPDIS</b>     | R/W | <p>禁止零量程暂停（Zero-quanta Pause Disable）</p> <p>当设置此位时，该位禁止在 FIFO 层的流量控制信号失效时自动产生零量程暂停控制帧。</p> <p>当该位被重置时，使能自动零量程暂停控制帧生成的正常操作。</p>                                                                                                                                                                                                                                                              |
| 15:8  |                   |     | 保留                                                                                                                                                                                                                                                                                                                                                                                           |
| 31:16 | <b>PT</b>         | R/W | <p>暂停时间（Pause Time）</p> <p>该位保存了在发送控制帧中使用的值。如果该位被配置为双同步到 MII 时钟域，那么只有在目标时钟域至少 4 个时钟周期之后，才应该对该寄存器执行连续的写操作。</p>                                                                                                                                                                                                                                                                                |

### 27.5.8 VLAN 标记寄存器 (MAC\_VLANT)

偏移地址: 0x1C

复位值: 0x0000 0000

此寄存器包含 IEEE 802.1Q VLAN 标记，用于标识 VLAN 帧。MAC 将接收帧（长度/类型）的第 13 和第 14 字节与 0x8100 比较，下面 2 字节与 VLAN 标记比较；如果匹配成功，则设置接收帧状态的接收 VLAN 位。帧的合法长度从 1518 字节增加到 1522 字节。

| 位/域   | 名称        | R/W | 描述                                                                                                                                                                                                                                                                                |
|-------|-----------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0  | VLANTID   | R/W | <p>VLAN 标记标识符 (VLAN Tag Identifier)<br/>包含 802.1Q VLAN 标识，用于识别 VLAN 帧，并与接收帧的第 15 字节和第 16 字节进行比较。位[15:13]是用户优先级，位[12]是规范格式指示器，位[11:0]是 VLAN 标记的 VLAN 标识符。当设置了 VLANTCOMP 位时，只使用位[11:0]进行比较。如果 VLANTID 为全 0，则 MAC 不检查第 15 字节和第 16 字节的 VLAN 标识比较，将 Type 值为 0x8100 的所有帧声明为 VLAN 帧。</p> |
| 16    | VLANTCOMP | R/W | <p>12 位 VLAN 标记比较 (12-bit VLAN Tag Comparison)<br/>设置此位后，将使用 12 位的 VLAN 标识符，而不是完整的 16 位 VLAN 标记进行比较和过滤。VLAN 标记的位[11:0]与接收到的 VLAN 标记帧中相应的位进行比较。<br/>当该位重置时，接收 VLAN 帧的第 15 和第 16 字节的所有 16 位都用于比较。</p>                                                                               |
| 31:17 | 保留        |     |                                                                                                                                                                                                                                                                                   |

### 27.5.9 远程唤醒帧过滤寄存器 (MAC\_REMWKUPFFL)

偏移地址: 0x28

复位值: 0x0000 0000

应用程序将通过此地址对远程唤醒帧过滤寄存器进行写/读操作。实际上，唤醒帧过滤寄存器是八个（不透明的）此类唤醒帧过滤寄存器。对偏移 (0x0028) 的这个地址所进行的八个连续写操作会写入/读取所有唤醒帧过滤寄存器。此寄存器包含第七个 MAC 地址的高 16 位。

#### 唤醒帧过滤寄存器 x (MAC\_WKUPFFLx) (x=0-3)

| 位/域  | 名称       | R/W | 描述                                                                                                                                                                           |
|------|----------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | FLXBMASK | R/W | <p>过滤器 x 字节屏蔽 (Filter x Byte Mask)<br/>该寄存器定义过滤器 x 检测帧的哪些字节来确定帧是否为唤醒帧。<br/>MSB[31]必须为零。位 y[30:0] 为字节屏蔽。如果将字节屏蔽的位 y (字节数) 置 1，则传入帧的过滤器 x 偏移+y 由 CRC 模块处理；否则将忽略过滤器 x 偏移+y。</p> |

#### 唤醒帧过滤寄存器 4 (MAC\_WKUPFFL4)

| 位/域  | 名称     | R/W | 描述                                                                                                                                                                     |
|------|--------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0  | FL0COM | R/W | <p>过滤器 0 命令 (Filter 0 Command)<br/>该 4 位命令控制过滤器 x 操作。位 3 指定地址类型，定义模式的目标地址类型。当该位置 1 时，模式只适用于多播帧。当该位复位时，模式只适用于单播帧。位 2 和位 1 为保留位。位 0 为过滤器 x 的使能位；如果位 0 置 1，则将使能过滤器 x。</p> |
| 7:4  | 保留     |     |                                                                                                                                                                        |
| 11:8 | FL1COM | R/W | <p>过滤器 1 命令 (Filter 1 Command)<br/>该 4 位命令控制过滤器 x 操作。位 3 指定地址类型，定义模式的目标地址类型。当该位置 1 时，模式只适用于多播帧。当该位复位时，模</p>                                                            |

| 位/域   | 名称     | R/W | 描述                                                                                                                                                             |
|-------|--------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |        |     | 式只适用于单播帧。位 2 和位 1 为保留位。位 0 为过滤器 x 的使能位；如果位 0 置 1，则将使能过滤器 x。                                                                                                    |
| 15:12 |        |     | 保留                                                                                                                                                             |
| 19:16 | FL2COM | R/W | 过滤器 2 命令 (Filter 2 Command)<br>该 4 位命令控制过滤器 x 操作。位 3 指定地址类型，定义模式的目标地址类型。当该位置 1 时，模式只适用于多播帧。当该位复位时，模式只适用于单播帧。位 2 和位 1 为保留位。位 0 为过滤器 x 的使能位；如果位 0 置 1，则将使能过滤器 x。 |
| 23:20 |        |     | 保留                                                                                                                                                             |
| 27:24 | FL3COM | R/W | 过滤器 3 命令 (Filter 3 Command)<br>该 4 位命令控制过滤器 x 操作。位 3 指定地址类型，定义模式的目标地址类型。当该位置 1 时，模式只适用于多播帧。当该位复位时，模式只适用于单播帧。位 2 和位 1 为保留位。位 0 为过滤器 x 的使能位；如果位 0 置 1，则将使能过滤器 x。 |
| 31:28 |        |     | 保留                                                                                                                                                             |

#### 唤醒帧过滤寄存器 5 (MAC\_WKUPFFL5)

| 位/域   | 名称     | R/W | 描述                                                                                                                                 |
|-------|--------|-----|------------------------------------------------------------------------------------------------------------------------------------|
| 7:0   | FL0OFF | R/W | 过滤器 0 偏移 (Filter 0 Offset)<br>该寄存器定义过滤器 x 要检测的帧的偏移 (在帧范围内)。该 8 位模式偏移是要检测的过滤器 x 第一个字节的偏移。允许的最小值为 12，表示帧的第 13 个字节 (偏移值 0 表示帧的第一个字节)。 |
| 15:8  | FL1OFF | R/W | 过滤器 1 偏移 (Filter 1 Offset)<br>该寄存器定义过滤器 x 要检测的帧的偏移 (在帧范围内)。该 8 位模式偏移是要检测的过滤器 x 第一个字节的偏移。允许的最小值为 12，表示帧的第 13 个字节 (偏移值 0 表示帧的第一个字节)。 |
| 23:16 | FL2OFF | R/W | 过滤器 2 偏移 (Filter 2 Offset)<br>该寄存器定义过滤器 x 要检测的帧的偏移 (在帧范围内)。该 8 位模式偏移是要检测的过滤器 x 第一个字节的偏移。允许的最小值为 12，表示帧的第 13 个字节 (偏移值 0 表示帧的第一个字节)。 |
| 31:24 | FL3OFF | R/W | 过滤器 3 偏移 (Filter 3 Offset)<br>该寄存器定义过滤器 x 要检测的帧的偏移 (在帧范围内)。该 8 位模式偏移是要检测的过滤器 x 第一个字节的偏移。允许的最小值为 12，表示帧的第 13 个字节 (偏移值 0 表示帧的第一个字节)。 |

#### 唤醒帧过滤寄存器 6 (MAC\_WKUPFFL6)

| 位/域   | 名称       | R/W | 描述                                                                            |
|-------|----------|-----|-------------------------------------------------------------------------------|
| 15:0  | FL0CRC16 | R/W | 过滤器 0 CRC-16 (Filter 0 CRC-16)<br>该寄存器包含根据模式计算的 CRC_16 值，以及对唤醒过滤寄存器模块编程的字节屏蔽。 |
| 31:16 | FL1CRC16 | R/W | 过滤器 1 CRC-16 (Filter 1 CRC-16)<br>该寄存器包含根据模式计算的 CRC_16 值，以及对唤醒过滤寄存器模块编程的字节屏蔽。 |

#### 唤醒帧过滤寄存器 7 (MAC\_WKUPFFL7)

| 位/域   | 名称       | R/W | 描述                                                                             |
|-------|----------|-----|--------------------------------------------------------------------------------|
| 15:0  | FL2CRC16 | R/W | 过滤器 2 CRC-16 (Filter 2 CRC-16)<br>该寄存器包含根据模式计算的 CRC_16 值, 以及对唤醒过滤寄存器模块编程的字节屏蔽。 |
| 31:16 | FL3CRC16 | R/W | 过滤器 3 CRC-16 (Filter 3 CRC-16)<br>该寄存器包含根据模式计算的 CRC_16 值, 以及对唤醒过滤寄存器模块编程的字节屏蔽。 |

### 27.5.10 PMT 控制和状态寄存器 (MAC\_PMTCTRLSTS)

偏移地址: 0x2C

复位值: 0x0000 0000

此寄存器会配置唤醒时间请求并监视唤醒事件。

| 位/域   | 名称       | R/W  | 描述                                                                                                                           |
|-------|----------|------|------------------------------------------------------------------------------------------------------------------------------|
| 0     | PD       | R/S  | 掉电 (Power Down)<br>当此位置 1 时, 将丢弃所有接收到的帧。接收到魔术数据包或唤醒帧时, 此位会自动清零, 同时禁止掉电模式。此位清零后收到的帧会转发到应用程序。只有使能魔术数据包或使能唤醒帧位置 1 时, 才可以将此位置 1。 |
| 1     | MPEN     | R/W  | 使能魔术数据包 (Magic Packet Enable)<br>当此位置 1 时, 该位使能由于魔术包接收而产生电源管理事件。                                                             |
| 2     | WKUPFEN  | R/W  | 使能唤醒帧 (Wakeup Frame Enable)<br>当此位置 1 时, 此位使能由于唤醒帧接收而产生电源管理事件。                                                               |
| 4:3   | 保留       |      |                                                                                                                              |
| 5     | MPRX     | RC_R | 接收到魔术数据包 (Magic Packet Received)<br>当此位置 1 时, 表示因接收魔术数据包而生成了电源管理事件。读取此寄存器可清零此位。                                              |
| 6     | WKUPFRX  | RC_R | 接收到唤醒帧 (Wakeup Frame Received)<br>当此位置 1 时, 表示因接收唤醒帧而生成了电源管理事件。读取此寄存器可清零此位。                                                  |
| 8:7   | 保留       |      |                                                                                                                              |
| 9     | GUN      | R/W  | 全局单播 (Global Unicast)<br>当此位置 1 时, 它会将 MAC 地址确认所过滤的任意单播包使能为唤醒帧。                                                              |
| 30:10 | 保留       |      |                                                                                                                              |
| 31    | WKUPFRST | R/S  | 唤醒帧过滤寄存器指针复位 (Wakeup Frame Filter Register Pointer Reset)<br>当此位置 1 时, 会将远程唤醒帧过滤寄存器指针复位为 000b。它会在 1 个时钟周期后自动清零。              |

### 27.5.11 调试寄存器 (MAC\_DBG)

偏移地址: 0x34

复位值: 0x0000 0000

此寄存器给出了发送及接收数据路径和 FIFO 的所有主要模块的状态。全零时表示 MAC 内核处于空闲状态 (FIFO 为空) 并且数据路径中没有活动。

| 位/域   | 名称       | R/W | 描述                                                                                                                                                 |
|-------|----------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | RPESTS   | R   | MAC MII 接收协议引擎状态 (MAC MII Receive Protocol Engine Status)<br>设置为高时, 表示 MAC MII 接收协议引擎正在主动接收数据, 而不是 IDLE 状态。                                        |
| 2:1   | RFCFCSTS | R   | MAC 接收帧 FIFO 控制器状态 (MAC Receive Frame FIFO Controller Status)<br>设置为高时, 表示 MAC 接收帧 FIFO 控制器的 FIFO 读写控制器为活跃状态。<br>0: 写控制器状态<br>1: 读控制器状态            |
| 3     |          |     | 保留                                                                                                                                                 |
| 4     | RWCSTS   | R   | RX FIFO 写控制器有效状态 (RX FIFO Write Controller Active Status)<br>设置为高时, 表示 RX FIFO 写控制器有效, 正在将接收到的帧发送给 FIFO。                                           |
| 6:5   | RRCSTS   | R   | RX FIFO 读控制器有效状态 (RX FIFO Read Controller State)<br>00: IDLE 状态<br>01: 读取帧数据<br>10: 读取帧状态 (或时间戳)<br>11: 刷新帧数据和状态                                   |
| 7     |          |     | 保留                                                                                                                                                 |
| 9:8   | RXFSTS   | R   | RX FIFO 填充级别状态 (RX FIFO Full – Level Status)<br>00: RX FIFO 为空<br>01: RX FIFO 填充水平低于流量控制失效阈值<br>10: RX FIFO 填充水平高于流量控制激活阈值<br>11: RX FIFO 满        |
| 15:10 |          |     | 保留                                                                                                                                                 |
| 16    | TPESTS   | R   | MAC MII 发送协议引擎状态 (MAC MII Transmit Protocol Engine Status)<br>设置为高时, 表示 MAC MII 发送协议引擎正在积极发送数据, 而不是 IDLE 状态。                                       |
| 18:17 | TFCSTS   | R   | MAC 帧发送控制器状态 (MAC Transmit Frame Controller Status)<br>00: IDLE 状态<br>01: 等待前一个帧或 IFG 或回退周期结束的状态<br>10: 生成和发送暂停帧 (在全双工模式)<br>11: 发送输入的帧            |
| 19    | TXPAUSED | R   | 暂停 MAC 发射机 (MAC Transmitter in Pause)<br>设置为高时, 表示 MAC 发射机处于暂停状态 (全双工模式), 因此不发送任何帧。                                                                |
| 21:20 | TRCSTS   | R   | TX FIFO 读控制器状态 (TX FIFO Read Controller Status)<br>00: IDLE 状态<br>01: 读状态 (向 MAC 发送器发送数据)<br>10: 等待来自 MAC 发送器的 TX 状态<br>11: 写入收到的 TX 状态或刷新 TX FIFO |
| 22    | TWCSTS   | R   | TX FIFO 写控制器状态 (TX FIFO Write Controller Status)                                                                                                   |

| 位/域   | 名称        | R/W | 描述                                                                                 |
|-------|-----------|-----|------------------------------------------------------------------------------------|
|       |           |     | 设置为高时, 表示 TX FIFO 写控制器是活跃的, 正在向 TX FIFO 发送数据。                                      |
| 23    |           |     | 保留                                                                                 |
| 24    | TXFSTS    | R   | TX FIFO 非空状态 (TX FIFO Not Empty Status)<br>设置为高时, 表示 TX FIFO 非空, 还有一些数据等待发送。       |
| 25    | TXSTSFSTS | R   | TX 状态 FIFO 满状态 (TX Status FIFO Full Status)<br>设置为高时, 表示 TX FIFO 满。因此不能再接受任何帧进行发送。 |
| 31:26 |           |     | 保留                                                                                 |

### 27.5.12 中断状态寄存器 (MAC\_ISTS)

偏移地址: 0x38

复位值: 0x0000 0000

| 位/域   | 名称      | R/W | 描述                                                                                                       |
|-------|---------|-----|----------------------------------------------------------------------------------------------------------|
| 2:0   |         |     | 保留                                                                                                       |
| 3     | PMTIS   | R   | PMT 状态 (PMT Interrupt Status)<br>该位在断电模式下接收到一个魔术包或远程唤醒帧时被设置。当由于 PMT 控制和状态寄存器的读操作而清除位[6:5]时, 该位被清除。       |
| 4     | MMCIS   | R   | MMC 中断状态 (MMC Interrupt Status)<br>当任一位[6:5]被设置为高时, 该位被设置为高, 只有当所有这些位都是低时才被清除。                           |
| 5     | MMCRXIS | R   | MMC 接收中断状态 (MMC Receive Interrupt Status)<br>当 MMC 接收中断寄存器中产生一个中断时, 该位被设置为高。当这个中断寄存器中的所有位被清除时, 这个位也被清除。  |
| 6     | MMCTXIS | R   | MMC 发送中断状态 (MMC Transmit Interrupt Status)<br>当 MMC 发送中断寄存器中产生一个中断时, 该位被设置为高。当这个中断寄存器中的所有位被清除时, 这个位也被清除。 |
| 8:7   |         |     | 保留                                                                                                       |
| 9     | TSIS    | R   | 时间戳中断状态 (Timestamp Interrupt Status)<br>系统时间值等于或超过目标时间寄存器中指定的值时, 此位置 1。读取此寄存器时清零。                        |
| 15:10 |         |     | 保留                                                                                                       |

### 27.5.13 中断屏蔽寄存器 (MAC\_IMASK)

偏移地址: 0x3C

复位值: 0x0000 0000

| 位/域 | 名称    | R/W | 描述                                                                                   |
|-----|-------|-----|--------------------------------------------------------------------------------------|
| 2:0 |       |     | 保留                                                                                   |
| 3   | PMTIM | R/W | PMT 中断屏蔽 (PMT Interrupt Mask)<br>设置该位时, 由于在寄存器“中断状态寄存器”中设置了 PMT 中断状态位, 因此该位禁止产生中断信号。 |
| 8:4 |       |     | 保留                                                                                   |
| 9   | TSTIM | R/W | 时间戳触发中断屏蔽 (Time Stamp Trigger Interrupt Mask)<br>如果此位置 1, 则会禁止生成时间戳中断。               |

| 位/域   | 名称 | R/W | 描述 |
|-------|----|-----|----|
| 15:10 |    |     | 保留 |

### 27.5.14 MAC 地址 0 高寄存器 (MAC\_ADDR0H)

偏移地址: 0x40

复位值: 0x8000 FFFF

| 位/域   | 名称     | R/W | 描述                                                                                                              |
|-------|--------|-----|-----------------------------------------------------------------------------------------------------------------|
| 15:0  | ADDR0H | R/W | MAC 地址 0 高位[47:32] (MAC Address 0)<br>包含前 6 字节 MAC 地址 0 的前 16 位(47:32)。MAC 使用该字段过滤接收到的帧，并在发送流控制（暂停）帧中插入 MAC 地址。 |
| 30:16 |        |     | 保留                                                                                                              |
| 31    | AL1    | R   | 始终为 1 (Always 1)                                                                                                |

### 27.5.15 MAC 地址 0 低寄存器 (MAC\_ADDR0L)

偏移地址: 0x44

复位值: 0xFFFF FFFF

| 位/域  | 名称     | R/W | 描述                                                                                                         |
|------|--------|-----|------------------------------------------------------------------------------------------------------------|
| 31:0 | ADDR0L | R/W | MAC 地址 0 低位[31:0] (MAC Address 0)<br>该位域包含前 6 字节 MAC 地址 0 的低 32 位。这是 MAC 用来过滤接收到的帧，并在发送流控制（暂停）帧中插入 MAC 地址。 |

### 27.5.16 MAC 地址 1 高寄存器 (MAC\_ADDR1H)

偏移地址: 0x48

复位值: 0x0000 FFFF

| 位/域   | 名称        | R/W | 描述                                                                                                                                                                                                                                       |
|-------|-----------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0  | ADDR1H    | R/W | MAC 地址 1 高位[47:32] (MAC Address 1)<br>包含前 6 字节 MAC 地址 1 的前 16 位(47:32)。MAC 使用该字段过滤接收到的帧，并在发送流控制（暂停）帧中插入 MAC 地址。                                                                                                                          |
| 23:16 |           |     | 保留                                                                                                                                                                                                                                       |
| 29:24 | MASKBCTRL | R/W | 屏蔽字节控制 (Mask Byte Control)<br>这些位用于比较每个 MAC 地址 1 字节的屏蔽控制位。当它们设为高电平时，MAC 内核不会将接收到的 DA/SA 的相应字节与 MAC 地址 1 寄存器的内容进行比较。每个位都用于控制字节的屏蔽，如下所示：<br>位 29: ADDR1H [15:8]<br>位 28: ADDR1H [7:0]<br>位 27: ADDR1L [31:24]<br>...<br>位 24: ADDR1L [7:0] |
| 30    | ADDRSEL   | R/W | 选择地址 (Address Select)<br>0: 使用 MAC 地址 1 [47:0] 与接收帧的 DA 字段进行比较<br>1: 使用 MAC 地址 1 [47:0] 与接收帧的 SA 字段进行比较                                                                                                                                  |
| 31    | ADDREN    | R/W | 使能地址 (Address Enable)<br>0: 地址过滤器会忽略用于过滤的地址<br>1: 地址过滤器使用 MAC 地址 1 实现过滤                                                                                                                                                                  |

### 27.5.17 MAC 地址 1 低寄存器 (MAC\_ADDR1L)

偏移地址: 0x4C

复位值: 0xFFFF FFFF

| 位/域  | 名称     | R/W | 描述                                                                                                |
|------|--------|-----|---------------------------------------------------------------------------------------------------|
| 31:0 | ADDR1L | R/W | MAC 地址 1 低位[31:0] (MAC Address 1)<br>该位域包含前 6 字节 MAC 地址 1 的低 32 位。如果初始化之后，应用程序未加载此位域的内容，则不会定义该内容。 |

### 27.5.18 MAC 地址 2 高寄存器 (MAC\_ADDR2H)

偏移地址: 0x50

复位值: 0x0000 FFFF

| 位/域   | 名称        | R/W | 描述                                                                                                                                                                                                                                       |
|-------|-----------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0  | ADDR2H    | R/W | MAC 地址 2 高位[47:32] (MAC Address 2)<br>包含前 6 字节 MAC 地址 2 的前 16 位(47:32)。                                                                                                                                                                  |
| 23:16 | 保留        |     |                                                                                                                                                                                                                                          |
| 29:24 | MASKBCTRL | R/W | 屏蔽字节控制 (Mask Byte Control)<br>这些位用于比较每个 MAC 地址 2 字节的屏蔽控制位。当它们设为高电平时，MAC 内核不会将接收到的 DA/SA 的相应字节与 MAC 地址 2 寄存器的内容进行比较。每个位都用于控制字节的屏蔽，如下所示：<br>位 29: ADDR2H [15:8]<br>位 28: ADDR2H [7:0]<br>位 27: ADDR2L [31:24]<br>...<br>位 24: ADDR2L [7:0] |
| 30    | ADDRSEL   | R/W | 选择地址 (Address Select)<br>0: 使用 MAC 地址 2 [47:0] 与接收帧的 DA 字段进行比较<br>1: 使用 MAC 地址 2 [47:0] 与接收帧的 SA 字段进行比较                                                                                                                                  |
| 31    | ADDREN    | R/W | 使能地址 (Address Enable)<br>0: 地址过滤器会忽略用于过滤的地址<br>1: 地址过滤器使用 MAC 地址 2 实现过滤                                                                                                                                                                  |

### 27.5.19 MAC 地址 2 低寄存器 (MAC\_ADDR2L)

偏移地址: 0x54

复位值: 0xFFFF FFFF

| 位/域  | 名称     | R/W | 描述                                                                                                |
|------|--------|-----|---------------------------------------------------------------------------------------------------|
| 31:0 | ADDR2L | R/W | MAC 地址 2 低位[31:0] (MAC Address 2)<br>该位域包含前 6 字节 MAC 地址 2 的低 32 位。如果初始化之后，应用程序未加载此位域的内容，则不会定义该内容。 |

### 27.5.20 MAC 地址 3 高寄存器 (MAC\_ADDR3H)

偏移地址: 0x58

复位值: 0x0000 FFFF

| 位/域  | 名称     | R/W | 描述                                                                      |
|------|--------|-----|-------------------------------------------------------------------------|
| 15:0 | ADDR3H | R/W | MAC 地址 3 高位[47:32] (MAC Address 3)<br>包含前 6 字节 MAC 地址 3 的前 16 位[47:32]。 |

| 位/域   | 名称        | R/W | 描述                                                                                                                                                                                                                                                                                                                |
|-------|-----------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23:16 |           |     | 保留                                                                                                                                                                                                                                                                                                                |
| 29:24 | MASKBCTRL | R/W | <p>屏蔽字节控制 (Mask Byte Control)<br/>           这些位用于比较每个 MAC 地址 3 字节的屏蔽控制位。当它们设为高电平时, MAC 内核不会将接收到的 DA/SA 的相应字节与 MAC 地址 3 寄存器的内容进行比较。每个位都用于控制字节的屏蔽, 如下所示:</p> <p>位 29: ADDR3H [15:8]<br/>           位 28: ADDR3H [7:0]<br/>           位 27: ADDR3L [31:24]<br/>           ...<br/>           位 24: ADDR3L [7:0]</p> |
| 30    | ADDRSEL   | R/W | <p>选择地址 (Address Select)<br/>           0: 使用 MAC 地址 3 [47:0] 与接收帧的 DA 字段进行比较<br/>           1: 使用 MAC 地址 3 [47:0] 与接收帧的 SA 字段进行比较</p>                                                                                                                                                                            |
| 31    | ADDREN    | R/W | <p>使能地址 (Address Enable)<br/>           0: 地址过滤器会忽略用于过滤的地址<br/>           1: 地址过滤器使用 MAC 地址 3 实现过滤</p>                                                                                                                                                                                                            |

### 27.5.21 MAC 地址 3 低寄存器 (MAC\_ADDR3L)

偏移地址: 0x5C

复位值: 0xFFFF FFFF

| 位/域  | 名称     | R/W | 描述                                                                                                                     |
|------|--------|-----|------------------------------------------------------------------------------------------------------------------------|
| 31:0 | ADDR3L | R/W | <p>MAC 地址 3 低位[31:0] (MAC Address 3)<br/>           该位域包含前 6 字节 MAC 地址 3 的低 32 位。如果初始化之后, 应用程序未加载此位域的内容, 则不会定义该内容。</p> |

## 27.6 MMC 寄存器地址映射

表格 141 MMC 寄存器地址映射

| 寄存器名          | 描述                | 偏移地址  |
|---------------|-------------------|-------|
| MMC_CTRL      | 控制寄存器             | 0x100 |
| MMC_RXINT     | 接收中断寄存器           | 0x104 |
| MMC_TXINT     | 发送中断寄存器           | 0x108 |
| MMC_RXINTMASK | 屏蔽接收中断寄存器         | 0x10C |
| MMC_TXINTMASK | 屏蔽发送中断寄存器         | 0x110 |
| MMC_TXGFSCCNT | 单个冲突后发送的良好帧计数器寄存器 | 0x14C |
| MMC_TXGFMCCNT | 多个冲突后发送的良好帧计数器寄存器 | 0x150 |
| MMC_TXGFCNT   | 发送的良好帧计数器寄存器      | 0x168 |
| MMC_RXFCECNT  | 接收帧含 CRC 错误计数器寄存器 | 0x194 |
| MMC_RXFAECNT  | 接收帧含对齐错误计数器寄存器    | 0x198 |
| MMC_RXGUNCNT  | 接收的良好单播帧计数器寄存器    | 0x1C4 |

## 27.7 MMC 寄存器功能描述

### 27.7.1 控制寄存器 (MMC\_CTRL)

偏移地址: 0x100

复位值: 0x0000 0000

| 位/域  | 名称        | R/W | 描述                                                                                                                                                                                                        |
|------|-----------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | CNTRST    | R/W | 计数器复位 (Counter Reset)<br>设置此位时, 复位所有计数器。该位在 1 个时钟周期后自动清零                                                                                                                                                  |
| 1    | CNTSTOPRO | R/W | 计数器停止翻转 (Counter Stop Rollover)<br>设置此位时, 计数器达到其最大值后不会返回到零。                                                                                                                                               |
| 2    | RSTOR     | R/W | 读取时复位 (Reset on Read)<br>设置此位时, 读取 MMC 计数器后, 该计数器复位。读取最低有效字节通道后计数器清零。                                                                                                                                     |
| 3    | MCNTF     | R/W | 冻结 MMC 计数器 (MMC Counter Freeze)<br>设置此位时, 会冻结所有 MMC 计数器, 使其保持为当前值。(该位清零后, 才会因存在发送帧或接收帧更新 MMC 计数器)                                                                                                         |
| 4    | MCNTP     | R/W | 预设 MMC 计数器 (MMC Counter Preset)<br>当此位为 1 时, 所有的计数器都将根据 MCNTVALP 位的值被预设为几乎满值或几乎一半值。该位将在 1 个时钟周期后自动清零。该位连同 MCNTVALP 位用于调试和测试由于 MMC 计数器变为半全值或全值而导致的中断产生。                                                    |
| 5    | MCNTVALP  | R/W | 预设 MMC 计数器值 (MMC Counter Value Preset)<br>当 MCNTP 位置 1 时:<br>当 MCNTVALP 为低电平, 所有 MMC 计数器均预设为几乎一半值。所有帧计数器均预设为 0x7FFF_FFF0 (一半值-16)。<br>当 MCNTVALP 为高电平, 所有 MMC 计数器均预设为几乎满值。所有帧计数器均预设为 0xFFFF_FFF0 (满值-16)。 |
| 31:6 |           |     | 保留                                                                                                                                                                                                        |

### 27.7.2 接收中断寄存器 (MMC\_RXINT)

偏移地址: 0x104

复位值: 0x0000 0000

| 位/域   | 名称     | R/W  | 描述                                                                                    |
|-------|--------|------|---------------------------------------------------------------------------------------|
| 4:0   |        |      | 保留                                                                                    |
| 5     | RXFCE  | RC_R | 接收的帧含 CRC 错误 (Received Frames Include CRC Errors)<br>当接收帧计数器存在 CRC 错误且达到其最大值的一半时设置该位。 |
| 6     | RXFAE  | RC_R | 接收的帧含对齐错误 (Received Frames Include Alignment Errors)<br>当接收帧计数器存在对齐错误且达到其最大值的一半时设置该位。 |
| 16:7  |        |      | 保留                                                                                    |
| 17    | RXGUNF | RC_R | 接收的良好单播帧 (Received Good Unicast Frames)<br>当接收到的良好单播帧计数器达到其最大值的一半时设置该位。               |
| 31:18 |        |      | 保留                                                                                    |

### 27.7.3 发送中断寄存器 (MMC\_TXINT)

偏移地址: 0x108

复位值: 0x0000 0000

| 位/域   | 名称       | R/W  | 描述                                                                                             |
|-------|----------|------|------------------------------------------------------------------------------------------------|
| 13:0  | 保留       |      |                                                                                                |
| 14    | TXGFSCOL | RC_R | 单个冲突后发送的良好帧 (Good Frames Transmitted After Single Collision)<br>当单个冲突后发送的良好帧计数器达到其最大值的一半时设置该位。 |
| 15    | TXGFMCOL | RC_R | 多个冲突后发送的良好帧 (Good Frames Transmitted After More Collisions)<br>多个冲突后发送的良好帧计数器达到其最大值的一半时设置该位。   |
| 20:16 | 保留       |      |                                                                                                |
| 21    | TXGF     | RC_R | 发送的良好帧 (Good Frames Transmitted)<br>当发送的良好帧计数器达到其最大值的一半时设置该位。                                  |
| 31:22 | 保留       |      |                                                                                                |

#### 27.7.4 屏蔽接收中断寄存器 (MMC\_RXINTMASK)

偏移地址: 0x10C

复位值: 0x0000 0000

| 位/域   | 名称      | R/W | 描述                                                                                        |
|-------|---------|-----|-------------------------------------------------------------------------------------------|
| 4:0   | 保留      |     |                                                                                           |
| 5     | RXFCEM  | R/W | 屏蔽接收的帧 CRC 错误 (Received Frames CRC Error Mask)<br>设置该位时, 当接收帧计数器存在 CRC 错误且达到其最大值的一半时屏蔽中断。 |
| 6     | RXFAEM  | R/W | 屏蔽接收的帧对齐错误 (Received Frames Alignment Error Mask)<br>设置该位时, 当接收帧计数器存在对齐错误且达到其最大值的一半时屏蔽中断。 |
| 16:7  | 保留      |     |                                                                                           |
| 17    | RXGUNFM | R/W | 屏蔽接收的良好单播帧 (Received Good Unicast Frames Mask)<br>设置该位时, 当接收到的良好单播帧计数器达到其最大值的一半时屏蔽中断。     |
| 31:18 | 保留      |     |                                                                                           |

#### 27.7.5 屏蔽发送中断寄存器 (MMC\_TXINTMASK)

偏移地址: 0x110

复位值: 0x0000 0000

| 位/域  | 名称        | R/W | 描述                                                                                                     |
|------|-----------|-----|--------------------------------------------------------------------------------------------------------|
| 13:0 | 保留        |     |                                                                                                        |
| 14   | TXGFSCOLM | R/W | 屏蔽单个冲突后发送的良好帧 (Transmitted Good Frames Single Collision Mask)<br>设置该位时, 当单个冲突后发送的良好帧计数器达到其最大值的一半时屏蔽中断。 |
| 15   | TXGFMCOLM | R/W | 屏蔽多个冲突后发送的良好帧 (Transmitted Good Frames More Collisions Mask)<br>设置该位时, 多个冲突后发送的良好帧计数器达到其最大值的一半时屏蔽中断。   |

| 位/域   | 名称    | R/W | 描述                                                                          |
|-------|-------|-----|-----------------------------------------------------------------------------|
| 20:16 |       |     | 保留                                                                          |
| 21    | TXGFM | R/W | 屏蔽发送的良好帧 (Transmitted Good Frames Mask)<br>设置该位时, 当发送的良好帧计数器达到其最大值的一半时屏蔽中断。 |
| 31:22 |       |     | 保留                                                                          |

### 27.7.6 单个冲突后发送的良好帧计数器寄存器 (MMC\_TXGFSCCNT)

偏移地址: 0x14C

复位值: 0x0000 0000

| 位/域  | 名称        | R/W | 描述                                                                                   |
|------|-----------|-----|--------------------------------------------------------------------------------------|
| 31:0 | TXGFSCCNT | R   | 单个冲突后发送的良好帧计数器 (Transmitted Good Frames Single Collision Counter)<br>单个冲突后发送的良好帧计数器。 |

### 27.7.7 多个冲突后发送的良好帧计数器寄存器 (MMC\_TXGFMCCNT)

偏移地址: 0x150

复位值: 0x0000 0000

| 位/域  | 名称        | R/W | 描述                                                                                  |
|------|-----------|-----|-------------------------------------------------------------------------------------|
| 31:0 | TXGFMCCNT | R   | 多个冲突后发送的良好帧计数器 (Transmitted Good Frames More Collisions Counter)<br>多个冲突后发送的良好帧计数器。 |

### 27.7.8 发送的良好帧计数器寄存器 (MMC\_TXGFCNT)

偏移地址: 0x168

复位值: 0x0000 0000

| 位/域  | 名称      | R/W | 描述                                                        |
|------|---------|-----|-----------------------------------------------------------|
| 31:0 | TXGFCNT | R   | 发送的良好帧计数器 (Transmitted Good Frames Counter)<br>发送的良好帧计数器。 |

### 27.7.9 接收帧含 CRC 错误计数器寄存器 (MMC\_RXFCECNT)

偏移地址: 0x194

复位值: 0x0000 0000

| 位/域  | 名称       | R/W | 描述                                                                      |
|------|----------|-----|-------------------------------------------------------------------------|
| 31:0 | RXFCECNT | R   | 接收的帧含 CRC 错误计数器 (Received Frames CRC Error Counter)<br>接收的帧含 CRC 错误计数器。 |

### 27.7.10 接收帧含对齐错误计数器寄存器 (MMC\_RXFAECNT)

偏移地址: 0x198

复位值: 0x0000 0000

| 位/域  | 名称       | R/W | 描述                                                                      |
|------|----------|-----|-------------------------------------------------------------------------|
| 31:0 | RXFAECNT | R   | 接收的帧含对齐错误计数器 (Received Frames Alignment Error Counter)<br>接收的帧含对齐错误计数器。 |

### 27.7.11 接收的良好单播帧计数器寄存器 (MMC\_RXGUNCNT)

偏移地址: 0x1C4

复位值: 0x0000 0000

| 位/域  | 名称       | R/W | 描述                                                                 |
|------|----------|-----|--------------------------------------------------------------------|
| 31:0 | RXGUNCNT | R   | 接收的良好单播帧计数器 (Received Good Unicast Frames Counter)<br>接收的良好单播帧计数器。 |

## 27.8 PTP 寄存器地址映射

用于支持符合 IEEE 1588 标准的精确网络时钟同步功能的寄存器。

表格 142 PTP 寄存器地址映射

| 寄存器名        | 描述         | 偏移地址  |
|-------------|------------|-------|
| PTP_TSCTRL  | 时间戳控制寄存器   | 0x700 |
| PTP_SUBSECI | 亚秒增量寄存器    | 0x704 |
| PTP_TSH     | 时间戳高位寄存器   | 0x708 |
| PTP_TSL     | 时间戳低位寄存器   | 0x70C |
| PTP_TSHUD   | 时间戳高位更新寄存器 | 0x710 |
| PTP_TSLUD   | 时间戳低位更新寄存器 | 0x714 |
| PTP_TSA     | 时间戳加数寄存器   | 0x718 |
| PTP_TTSH    | 目标时间戳高位寄存器 | 0x71C |
| PTP_TTSL    | 目标时间戳低位寄存器 | 0x720 |
| PTP_TSSTS   | 时间戳状态寄存器   | 0x728 |
| PTP_PPSCTRL | PPS 控制寄存器  | 0x72C |

## 27.9 PTP 寄存器功能描述

### 27.9.1 时间戳控制寄存器 (PTP\_TSCTRL)

偏移地址: 0x700

复位值: 0x0000 2000

| 位/域 | 名称      | R/W | 描述                                                                                                  |
|-----|---------|-----|-----------------------------------------------------------------------------------------------------|
| 0   | TSEN    | R/W | 使能时间戳 (Time Stamp Enable)<br>0: 禁用<br>1: 使能<br>由于保持的系统时间处于挂起状态, 所以在将此位置为高电平后, 始终都需要初始化时间戳功能 (系统时间)。 |
| 1   | TSUDSEL | R/W | 选择时间戳更新方式 (Time Stamp Update Mode Select)<br>选择更新系统时间戳的方式。<br>0: 粗略更新<br>1: 精密更新                    |

| 位/域 | 名称       | R/W | 描述                                                                                                                                                                          |
|-----|----------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2   | TSSTINIT | R/W | 初始化时间戳系统时间 (Time Stamp System Time Initialize)<br>设置此位时，在时间戳高位更新寄存器和时间戳低位更新寄存器中指定的值初始化系统时间。在设置此位之前，必须读取为零。初始化完成后，此位清零。                                                      |
| 3   | TSSTUD   | R/W | 更新时间戳系统时间 (Time Stamp System Time Update)<br>设置此位时，在时间戳高位更新寄存器和时间戳低位更新寄存器中指定的值更新系统时间。在设置此位之前，TSSTINIT 和 TSSTUD 必须读取为零。更新完成后，此位清零。                                           |
| 4   | TSTRGIEN | R/W | 使能时间戳触发中断 (Time Stamp Trigger Interrupt Enable)<br>设置此位时，如果目标时间寄存器中写入的值小于系统时间，将产生时间戳中断。产生时间戳触发中断时，此位清零。                                                                     |
| 5   | TSADDUD  | R/W | 更新时间戳加数寄存器 (Time Stamp Addend Register Update)<br>设置此位时，会将时间戳加数寄存器的内容更新到 PTP 进行精密校准。更新结束时此位清零。在设置此位之前，必须读取为零。                                                               |
| 7:6 |          |     | 保留                                                                                                                                                                          |
| 8   | TSSNEN   | R/W | 使能接收帧的时间戳快照 (Time Stamp Snapshot for Received Frames Enable)<br>设置此位时，内核接收的全部帧使能时间戳快照。                                                                                      |
| 9   | TSSUBRO  | R/W | 时间戳亚秒翻转 (Time Stamp Subsecond Rollover)<br>0: 亚秒寄存器的翻转值达到 0xFFFF FFFF。亚秒增量根据 PTP 参考时钟频率和此位的值进行编程。<br>1: 若亚秒计数器值达到 0x3B9A C9FF (十进制 999 999 999) 且时间戳 (高位) 秒数递增，则时间戳低位寄存器翻转。 |
| 10  | LISTVSEL | R/W | 选择监听版本 (Listening Version Select)<br>选择监听 PTP 数据包的版本格式。<br>0: 版本 1<br>1: 版本 2                                                                                               |
| 11  | TSSPTPEN | R/W | 使能 PTP 以太网帧时间戳快照 (Time Stamp Snapshot for PTP Ethernet Frames Enable)<br>设置此位时，拍摄在以太网帧中含有 PTP 消息的帧的时间戳快照。默认拍摄 UDP-IP-Ethernet PTP 数据包的快照。                                   |
| 12  | TSS6EN   | R/W | 使能 IPv6 帧时间戳快照 (Time stamp snapshot for IPv6 frames Enable)<br>设置此位时，拍摄 IPv6 帧的时间戳快照。                                                                                       |
| 13  | TSS4EN   | R/W | 使能 IPv4 帧时间戳快照 (Time Stamp Snapshot for IPv4 Frames Enable)<br>设置此位时，拍摄 IPv4 帧的时间戳快照。                                                                                       |
| 14  | TSSMESEL | R/W | 选择消息时间戳快照 (Time Stamp Snapshot for Message Select)<br>0: 拍摄除 Announce、Management 和 Signaling 以外其它所有消息的快照<br>1: 拍摄事件消息的时间戳快照 (SYNC、Delay_Re、Pdelay_Req 或 Pdelay_Resp)        |
| 15  | TSSMNSEL | R/W | 选择节点时间戳快照 (Time Stamp Snapshot for Master Node Select)                                                                                                                      |

| 位/域   | 名称           | R/W | 描述                                                                                                                        |
|-------|--------------|-----|---------------------------------------------------------------------------------------------------------------------------|
|       |              |     | 0: 从节点<br>1: 主节点                                                                                                          |
| 17:16 | TSCLKNSEL    | R/W | 选择时间戳时钟节点 (Time stamp Clock Node Select)<br>00: 普通时钟<br>01: 边界时钟<br>10: 端对端透明时钟<br>11: 点对点透明时钟                            |
| 18    | TSSPTPFMACEN | R/W | 使能时间戳 PTP 帧过滤 MAC 地址 (Time Stamp PTP Frame Filtering MAC Address Enable)<br>当设置此位时且 PTP 直接通过以太网发送时, 此位将使用 MAC 地址过滤 PTP 帧。 |
| 31:19 |              |     | 保留                                                                                                                        |

表格 143 时间戳快照的消息

| TSCLKNSEL | TSSMNSEL | TSSMESEL | 拍摄快照的消息                                                         |
|-----------|----------|----------|-----------------------------------------------------------------|
| 0X        | 无关       | 0        | SYNC, Follow_Up, Delay_Req, Delay_Resp                          |
|           | 1        | 1        | Delay_Req                                                       |
|           | 0        | 1        | SYNC                                                            |
| 10        | X        | 0        | SYNC, Follow_Up, Delay_Req, Delay_Resp                          |
|           |          | 1        | SYNC, Follow_Up                                                 |
|           |          | 0        | SYNC, Follow_Up, Delay_Req, Delay_Resp, Pdelay_Req, Pdelay_Resp |
| 11        |          | 1        | SYNC, Pdelay_Req, Pdelay_Resp                                   |

注意: X=不适用。

### 27.9.2 亚秒增量寄存器 (PTP\_SUBSECI)

偏移地址: 0x704

复位值: 0x0000 0000

| 位/域  | 名称        | R/W | 描述                                                                    |
|------|-----------|-----|-----------------------------------------------------------------------|
| 7:0  | STSUBSECI | R/W | 系统时间亚秒增加值 (System Time Subseconds Increment)<br>在每次更新时都会被增加到系统时间亚秒值中。 |
| 31:8 |           |     | 保留                                                                    |

### 27.9.3 时间戳高位寄存器 (PTP\_TSH)

偏移地址: 0x708

复位值: 0x0000 0000

| 位/域  | 名称    | R/W | 描述                                          |
|------|-------|-----|---------------------------------------------|
| 31:0 | STSEC | R   | 系统时间秒值 (System Time Second Value)<br>系统秒时间。 |

### 27.9.4 时间戳低位寄存器 (PTP\_TSL)

偏移地址: 0x70C

复位值: 0x0000 0000

| 位/域  | 名称       | R/W | 描述                                                                                         |
|------|----------|-----|--------------------------------------------------------------------------------------------|
| 30:0 | STSUBSEC | R   | 系统时间亚秒值 (System Time Subseconds Value)<br>系统亚秒时间, 精度为 0.46ns。                              |
| 31   | STSEL    | R   | 选择系统时间 (System Time Select)<br>此位表示系统时间的正负值。<br>0: 正<br>1: 负<br>由于系统时间始终应为正值, 所以一般情况下该位为零。 |

#### 27.9.5 时间戳高位更新寄存器 (PTP\_TSHUD)

偏移地址: 0x710

复位值: 0x0000 0000

| 位/域  | 名称      | R/W | 描述                                                             |
|------|---------|-----|----------------------------------------------------------------|
| 31:0 | TSUDSEC | R/W | 时间戳更新秒值 (Time Stamp Update Second Value)<br>要初始化或增加到系统时间中的秒时间。 |

#### 27.9.6 时间戳低位更新寄存器 (PTP\_TSLUD)

偏移地址: 0x714

复位值: 0x0000 0000

| 位/域  | 名称         | R/W | 描述                                                                                                                                                      |
|------|------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 30:0 | TSUDSUBSEC | R/W | 时间戳更新亚秒值 (Time Stamp Update Subseconds Value)<br>要初始化或增加到系统时间中的亚秒时间。精度为 0.46ns。                                                                         |
| 31   | TSUDSEL    | R/W | 选择时间戳更新 (Time Stamp Update Select)<br>此位表示系统时间的正负值。<br>0: 正<br>1: 负<br>当 TSSTINIT 位置位时, 该位为 0。当 TSSTUD 位和该位同时置 1 时, 则要从系统时间中减去时间戳更新寄存器的值。否则其将被增加到系统时间中。 |

#### 27.9.7 时间戳加数寄存器 (PTP\_TSA)

偏移地址: 0x718

复位值: 0x0000 0000

| 位/域  | 名称  | R/W | 描述                                                                 |
|------|-----|-----|--------------------------------------------------------------------|
| 31:0 | TSA | R/W | 时间戳加数值 (Time Stamp Addend Value)<br>要添加到累加器寄存器的 32 位时间值, 用来实现时间同步。 |

#### 27.9.8 目标时间戳高位寄存器 (PTP\_TTSRH)

偏移地址: 0x71C

复位值: 0x0000 0000

| 位/域  | 名称    | R/W | 描述                                                                                   |
|------|-------|-----|--------------------------------------------------------------------------------------|
| 31:0 | TTSRH | R/W | 目标时间戳高位值 (Target Time Stamp High Value)<br>存储秒时间。当时间戳的值匹配或同时超过两个目标时间戳寄存器时, MAC 产生中断。 |

### 27.9.9 目标时间戳低位寄存器 (PTP\_TTSL)

偏移地址: 0x720

复位值: 0x0000 0000

| 位/域  | 名称   | R/W | 描述                                                                                  |
|------|------|-----|-------------------------------------------------------------------------------------|
| 31:0 | TTSL | R/W | 目标时间戳低位值 (Target Time Stamp Low Value)<br>存储纳秒时间。当时间戳的值匹配或同时超过两个目标时间戳寄存器时，MAC 产生中断。 |

### 27.9.10 时间戳状态寄存器 (PTP\_TSSTS)

偏移地址: 0x728

复位值: 0x0000 0000

| 位/域  | 名称       | R/W | 描述                                                                             |
|------|----------|-----|--------------------------------------------------------------------------------|
| 0    | TSSECOVR | R   | 时间戳秒值上溢 (Time Stamp Second Value Overflow)<br>设置此位时，时间戳的秒值已上溢，超过了 0xFFFF FFFF。 |
| 1    | TTSRD    | R   | 达到目标时间戳的值 (Target Time Stamp Value Reached)<br>设置此位时，系统时间值大于或等于 PTP_TTS 寄存器的值。 |
| 31:2 |          |     | 保留                                                                             |

### 27.9.11 PPS 控制寄存器 (PTP\_PPSCTRL)

偏移地址: 0x72C

复位值: 0x0000 0000

| 位/域  | 名称      | R/W | 描述                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|---------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0  | PPSFSEL | R   | PPS 频率选择 (PPS Frequency Selection)<br>PPS 输出频率设置为 $2^{PPSFSEL} \text{Hz}$<br>0000: 1Hz, 二进制翻转脉冲宽度为 125ms, 数字翻转脉冲宽度为 100ms<br>0001: 2Hz, 二进制翻转, 占空比为 50% (不建议使用数字翻转)<br>0010: 4Hz, 二进制翻转, 占空比为 50% (不建议使用数字翻转)<br>0011: 8Hz, 二进制翻转, 占空比为 50% (不建议使用数字翻转)<br>0100: 16Hz, 二进制翻转, 占空比为 50% (不建议使用数字翻转)<br>...<br>1111: 32768Hz, 二进制翻转, 占空比为 50% (不建议使用数字翻转)<br>注意: PPS 输出在更高的频率下具有不规则波形, 所以使用数字翻转时尽量不要使用频率为 1Hz 以外的 PPS 输出。 |
| 31:4 |         |     | 保留                                                                                                                                                                                                                                                                                                                                                                                                                      |

## 27.10 DMA 寄存器地址映射

表格 144 DMA 寄存器地址映射

| 寄存器名        | 描述        | 偏移地址   |
|-------------|-----------|--------|
| ETH_DMABMOD | DMA 模式寄存器 | 0x1000 |
| ETH_DMATXPD | 发送轮询请求寄存器 | 0x1004 |
| ETH_DMARXPD | 接收轮询请求寄存器 | 0x1008 |

| 寄存器名            | 描述             | 偏移地址   |
|-----------------|----------------|--------|
| ETH_DMARXDLADDR | 接收描述符列表地址寄存器   | 0x100C |
| ETH_DMATXDLADDR | 发送描述符列表地址寄存器   | 0x1010 |
| ETH_DMASTS      | 状态寄存器          | 0x1014 |
| ETH_DMAOPMOD    | 操作模式寄存器        | 0x1018 |
| ETH_DMAINTEN    | 中断使能寄存器        | 0x101C |
| ETH_DMAMFABOCNT | 丢失帧和缓冲区上溢计数寄存器 | 0x1020 |
| ETH_DMARXFLGWDT | 接收中断看门狗定时器寄存器  | 0x1024 |
| ETH_DMAHTXD     | 当前主机发送描述符寄存器   | 0x1048 |
| ETH_DMAHRXD     | 当前主机接收描述符寄存器   | 0x104C |
| ETH_DMAHTXBADDR | 当前主机发送缓冲区地址寄存器 | 0x1050 |
| ETH_DMAHRXBADDR | 当前主机接收缓冲区地址寄存器 | 0x1054 |

## 27.11 DMA 寄存器功能描述

### 27.11.1 DMA 总线模式寄存器 (ETH\_DMABMOD)

偏移地址: 0x1000

复位值: 0x0002 0101

| 位/域  | 名称    | R/W | 描述                                                                                                                                                                                                                                                                                                                         |
|------|-------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | SWR   | R/W | 软件复位 (Software Reset)<br>当这个位被设置时, MAC DMA 控制器将重置 MAC 的逻辑和所有内部寄存器。在所有时钟域的重置操作完成后, 它将被自动清除。在重新编程任何寄存器之前, 应该在这个位中读取一个 0 值。                                                                                                                                                                                                   |
| 1    | DAS   | R/W | DMA 仲裁方案 (DMA Arbitration Scheme)<br>指定通道 0 的发送和接收路径之间的仲裁方案。<br>0: 采用 Rx:Tx 的加权循环调度, 在[15:14]给出<br>1: Rx 优先级高于 Tx                                                                                                                                                                                                          |
| 6:2  | DSL   | R/W | 描述符跳过长度 (Descriptor Skip Length)<br>这个位指定在两个未链接的描述符之间跳过的 Word、Dword 或 Lword 的数量。地址跳跃从当前描述符的末尾开始到下一个描述符的开始。当 DSL 值等于 0 时, DMA 在环形模式中将描述符表视为连续的。                                                                                                                                                                             |
| 7    | EDFEN | R/W | 使能增强描述符格式 (Enhanced Descriptor Format Enable)<br>设置此位时, 使能增强描述符格式, 并将描述符大小增加至 32 字节。如果已激活时间戳功能或 IPv4 校验和减荷, 则此位必须置 1。                                                                                                                                                                                                      |
| 13:8 | PBL   | R/W | 可编程突发长度 (Programmable Burst Length)<br>这些位指示在一个 DMA 事务中要发送的最大节拍数。这是在单个块读写中使用的最大值。每次在主机总线上启动突发发送时, DMA 总是尝试按照 PBL 中指定的突发。PBL 可以用允许值 1、2、4、8、16 和 32 编程。任何其他值都会导致未定义的行为。当 USP 设置为高电平时, 此 PBL 值仅适用于 Tx DMA 事务。<br>PBL 值有以下限制: 最大可能节拍数受到 MTL 层的 Tx FIFO 和 Rx FIFO 的大小和 DMA 上的数据总线宽度的限制。FIFO 有一个限制, 即支持的最大节拍是 FIFO 深度的一半, 除非指定。 |

| 位/域   | 名称    | R/W | 描述                                                                                                                                                                                                                             |
|-------|-------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:14 | PR    | R/W | <p>优先比 (Priority Ratio)<br/>           这些位控制 Rx 直接存储器存取和 Tx 直接存储器存取之间加权轮循仲裁的优先级比。只有当位[1]复位时，这些位才有效。</p> <p>00: 优先级比为 1:1<br/>           01: 优先级比为 2:1<br/>           10: 优先级比为 3:1<br/>           11: 优先级比为 4:1</p>            |
| 16    | FB    | R/W | <p>固定突发 (Fixed Burst)<br/>           这个位控制 AHB 主接口是否执行固定突发发送。设置后，在正常突发发送开始时，AHB 接口仅使用 SINGLE、INCR4、INCR8 或 INCR16。当复位时，AHB 接口使用单次和 INCR 突发发送操作。</p>                                                                            |
| 22:17 | RPBL  | R/W | <p>接收 DMA 可编程突发长度 (Rx DMA PBL)<br/>           此字段指示在一个 Rx DMA 事务中要发送的最大节拍数。这是在单个块读写中使用的最大值。</p> <p>每次在主机总线上开始突发发送时，Rx DMA 总是尝试按照 RPBL 位中指定的突发。可以用 1、2、4、8、16 和 32 的值编程 RPBL。任何其他值都会导致未定义的行为。</p> <p>只有 USP 设置为高电平时，该字段才有效。</p> |
| 23    | USP   | R/W | <p>使用单独的 PBL (Use Separate PBL)<br/>           当设置为高电平时，该位配置 Rx DMA 使用在位[22:17]中配置的值作为 PBL。以位[13:8]为单位的 PBL 值仅适用于 Tx DMA 操作。</p> <p>当重置为低电平时，位[13:8]中的 PBL 值适用于两种 DMA 引擎。</p>                                                  |
| 24    | PBLx4 | R/W | <p>PBLx4 模式 (PBLx4 Mode)<br/>           当设置为高电平时，该位会将编程的 PBL 值乘以四倍。因此，DMA 根据 PBL 值以最大 4、8、16、32、64 和 128 个节拍发送数据。</p>                                                                                                          |
| 25    | AAL   | R/W | <p>地址对齐的节拍 (Address-Aligned Beats)<br/>           当此位设置高电平且 FB 位等于 1 时，AHB 接口生成所有与起始地址 LS 位对齐的突发。如果 FB 位等于 0，第一个突发 (访问数据缓冲区的起始地址) 是不对齐的，但随后的突发是对齐到该地址的。</p>                                                                    |
| 26    | MB    | R/W | <p>混合突发 (Mixed Burst)<br/>           当这个位设置为高电平，FB 位为低电平，AHB 主接口开始所有长度超过 16 的突发 INCR，而它恢复到固定突发发送的突发长度为 16 或更少。</p>                                                                                                             |
| 31:27 |       |     | 保留                                                                                                                                                                                                                             |

### 27.11.2 发送轮询请求寄存器 (ETH\_DMATXPD)

偏移地址: 0x1004

复位值: 0x0000 0000

| 位/域  | 名称   | R/W | 描述                                                                                                                                                       |
|------|------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | TXPD | R/W | <p>发送轮询请求 (Transmit Poll Demand)<br/>           当用任何值写入这些位时，DMA 读取 ETH_DMATXPD 寄存器所指向的当前描述符。如果描述符不可用，发送返回挂起状态，且 ETH_DMASTS 寄存器的位[2]置位。如果描述符可用，则继续发送。</p> |

### 27.11.3 接收轮询请求寄存器 (ETH\_DMARXPD)

偏移地址: 0x1008

复位值: 0x0000 0000

| 位/域  | 名称   | R/W | 描述                                                                                                                                                                    |
|------|------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RXPD | R/W | <p>接收轮询请求 (Receive Poll Demand)</p> <p>当用任何值写入这些位时, DMA 读取 ETH_DMAHRXD 寄存器所指向的当前描述符。如果描述符不可用 (由主机拥有), 发送返回挂起状态, 且 ETH_DMASTS 寄存器的位[7]置位。如果描述符可用, 则 Rx DMA 返回活动状态。</p> |

#### 27.11.4 接收描述符列表地址寄存器 (ETH\_DMARXDLADDR)

偏移地址: 0x100C

复位值: 0x0000 0000

| 位/域  | 名称    | R/W | 描述                                                                                                                                                  |
|------|-------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RXSTA | R/W | <p>接收列表起始处 (Start of Receive List)</p> <p>该字段包含接收描述符列表中第一个描述符的基地址。32 位、64 位或 128 位总线宽度的 LSB 位[1:0、2:0 或 3:0]被忽略, DMA 内部将其视为全零。因此, 这些 LSB 位是只读的。</p> |

#### 27.11.5 发送描述符列表地址寄存器 (ETH\_DMATXDLADDR)

偏移地址: 0x1010

复位值: 0x0000 0000

| 位/域  | 名称    | R/W | 描述                                                                                                                                                   |
|------|-------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | TXSTA | R/W | <p>发送列表起始处 (Start of Transmit List)</p> <p>该字段包含接收描述符列表中第一个描述符的基地址。32 位、64 位或 128 位总线宽度的 LSB 位[1:0、2:0 或 3:0]被忽略, DMA 内部将其视为全零。因此, 这些 LSB 位是只读的。</p> |

#### 27.11.6 状态寄存器 (ETH\_DMASTS)

偏移地址: 0x1014

复位值: 0x0000 0000

| 位/域 | 名称     | R/W   | 描述                                                                                                                                                                      |
|-----|--------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | TXFLG  | RC_W1 | <p>发送标志 (Transmit Flag)</p> <p>帧发送已完成, 且首个描述符中的 TXDES1[31]位置 1。</p>                                                                                                     |
| 1   | TXSFLG | RC_W1 | <p>发送停止标志 (Transmit Stopped Flag)</p> <p>此位在发送停止时设置。</p>                                                                                                                |
| 2   | TXBU   | RC_W1 | <p>发送缓冲区不可用 (Transmit Buffer Unavailable)</p> <p>该位表示主机拥有发送列表中的下一个描述符, DMA 无法获取。发送暂停。位[22:20]解释发送进程的状态转换。要恢复处理发送描述符, 主机应该通过设置 TXDES0[31]来更改描述符的所有权, 然后发出一个发送轮询需求命令。</p> |
| 3   | TXJTO  | RC_W1 | <p>发送 Jabber 超时 (Transmit Jabber Timeout)</p> <p>该位表示发送 Jabber 定时器超时, 发送进程将被终止, 并处于停止状态。这将导致发送 Jabber 超时 TXDES0[14]标志被置位。</p>                                           |
| 4   | RXOVF  | RC_W1 | <p>接收上溢 (Receive Overflow)</p> <p>此位表示接收缓冲区在帧接收期间发生溢出。如果将部分帧发送给应用程序, 则在 RXDES0[11]中设置溢出状态。</p>                                                                          |
| 5   | TXUNF  | RC_W1 | <p>发送下溢 (Transmit Underflow)</p> <p>这个位表示发送缓冲区在帧发送期间有一个下溢。发送被挂起, 并设置了下溢错误 TXDES0[1]。</p>                                                                                |

| 位/域   | 名称       | R/W   | 描述                                                                                                                                                                                                                                                                                                                                                                                        |
|-------|----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6     | RXFLG    | RC_W1 | 接收标志 (Receive Flag)<br>帧接收完成, 特定的帧状态信息被更新在描述符中。接收保持运行状态。                                                                                                                                                                                                                                                                                                                                  |
| 7     | RXBU     | RC_W1 | 接收缓冲不可用 (Receive Buffer Unavailable)<br>该位表示主机拥有接收列表中的下一个描述符, DMA 无法获取它。接收进程挂起。要恢复处理接收描述符, 主机应该更改描述符的所有权, 并发出一个接收轮询请求命令。如果没有发出接收轮询请求, 接收进程将在接收到下一个确认的传入帧时恢复。仅当前一个接收描述符为 DMA 所有时才设置此位。                                                                                                                                                                                                     |
| 8     | RXSFLG   | RC_W1 | 接收停止标志 (Receive Stopped Flag)<br>当接收进程进入停止状态时此位置 1。                                                                                                                                                                                                                                                                                                                                       |
| 9     | RXWTOFLG | RC_W1 | 接收看门狗超时标志 (Receive Watchdog Timeout Flag)<br>当接收到的帧的长度大于 2048 个字节时此位置 1。                                                                                                                                                                                                                                                                                                                  |
| 10    | ETXFLG   | RC_W1 | 提前发送标志 (Early Transmit Flag)<br>要发送的帧已经完全发送到发送 FIFO。                                                                                                                                                                                                                                                                                                                                      |
| 12:11 |          |       | 保留                                                                                                                                                                                                                                                                                                                                                                                        |
| 13    | FBERRFLG | RC_W1 | 致命的总线错误标志 (Fatal Bus Error Flag)<br>该位表示发生了总线错误, 如位[25:23]所述。当设置此位时, 相应的 DMA 引擎禁用其所有总线访问。                                                                                                                                                                                                                                                                                                 |
| 14    | ERXFLG   | RC_W1 | 提前接收标志 (Early Receive Flag)<br>这个位表示 DMA 填充了数据包的第一个数据缓冲区。当软件将 1 写入该位或该寄存器的位[6]被设置时, 该位将被清除。                                                                                                                                                                                                                                                                                               |
| 15    | AINTS    | RC_W1 | 异常中断汇总 (Abnormal Interrupt Summary)<br>当在 ETH_DMAINTEEN 寄存器中启用相应的中断位时, 异常中断汇总位的值是以下位的逻辑或运算结果:<br>ETH_DMASTS[1]: 发送过程中停止<br>ETH_DMASTS[3]: 发送 Jabber 超时<br>ETH_DMASTS[4]: 接收上溢<br>ETH_DMASTS[5]: 发送下溢<br>ETH_DMASTS[7]: 接收缓冲不可用<br>ETH_DMASTS[8]: 接收过程中停止<br>ETH_DMASTS[9]: 接收看门狗超时<br>ETH_DMASTS[10]: 提前发送中断<br>ETH_DMASTS[13]: 致命的总线错误<br>只有非屏蔽位影响异常中断汇总位。这是一个粘性位, 必须在每次清除导致设置此位的对应位时清除。 |
| 16    | NINTS    | RC_W1 | 正常中断汇总 (Normal Interrupt Summary)<br>当相应的中断位在 ETH_DMAINTEEN 寄存器中启用时, 正常中断汇总位的值是以下位的逻辑或运算结果:<br>ETH_DMASTS[0]: 发送中断<br>ETH_DMASTS[2]: 发送缓冲不可用<br>ETH_DMASTS[6]: 接收中断<br>ETH_DMASTS[14]: 提前接收中断<br>只有未屏蔽位影响正常中断汇总位。这是一个粘性位, 必须在每次清除导致设置此位的对应位时清除。                                                                                                                                           |
| 19:17 | RXSTS    | R     | 接收过程状态 (Receive Process State)<br>该字段表示接收 DMA FSM 状态。此字段不产生中断。                                                                                                                                                                                                                                                                                                                            |

| 位/域   | 名称     | R/W | 描述                                                                                                                                                                                                                                          |
|-------|--------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |        |     | 000: 停止: 发出复位或停止接收命令<br>001: 运行: 获取接收发送描述符<br>010: 保留<br>011: 运行: 等待接收报文<br>100: 挂起: 接收描述符不可用<br>101: 运行: 关闭接收描述符<br>110: 保留<br>111: 运行: 正在将接收包数据从接收缓冲区发送到主机内存                                                                              |
| 22:20 | TXSTS  | R   | 发送过程状态 (Transmit Process State)<br>该字段表示发送 DMA FSM 状态。此字段不产生中断。<br>000: 停止: 发出复位或停止发送命令<br>001: 运行: 获取发送描述符<br>010: 运行: 等待状态<br>011: 运行: 从主机内存缓冲区读取数据并排队发送缓冲区(Tx FIFO)<br>100、101: 保留<br>110: 挂起: 发送描述符不可用或发送缓冲区下溢<br>111: 运行: 关闭发送描述符      |
| 25:23 | ERRB   | R   | 错误位 (Error Bits)<br>该字段表示引起总线错误的错误类型, 例如 AHB 接口的错误响应。该字段仅在位[13]设置时有效。此字段不产生中断。<br>000: Rx DMA 写数据发送过程中出现错误<br>011: Tx DMA 读取数据发送过程中出现错误<br>100: Rx DMA 描述符写访问时出错<br>101: Tx DMA 描述符写访问时出错<br>110: Rx DMA 描述符读访问时出错<br>111: Tx DMA 描述符读访问时出错 |
| 26    |        |     | 保留                                                                                                                                                                                                                                          |
| 27    | MMCFLG | R   | MMC 标志 (MMC Flag)<br>该位反映了 MAC 的 MMC 模块中的一个中断事件。软件必须在 MAC 中读取相应的寄存器, 以获得中断的确切原因, 并清除中断源, 使该位清 0。当这个位为高电平时, 使能后会产生中断。                                                                                                                        |
| 28    | PMTFLG | R   | PMT 标志 (PMT Flag)<br>该位表示 MAC 的 PMT 模块中的一个中断事件。软件必须读取 MAC 中的 PMT 控制和状态寄存器来获得中断的确切原因, 并清除其源来将这个位清 0。当这个位为高电平时, 使能后会产生中断。                                                                                                                     |
| 29    | TSTFLG | R   | 时间戳触发标志 (Timestamp Trigger Flag)<br>此位表示 MAC 的时间戳发生器块中的一个中断事件。软件必须读取 MAC 中相应的寄存器, 以获得中断的确切原因, 并清除其源, 将该位清 0。当这个位为高电平时, 使能后会产生中断。                                                                                                            |
| 31:30 |        |     | 保留                                                                                                                                                                                                                                          |

### 27.11.7 操作模式寄存器 (ETH\_DMAOPMOD)

偏移地址: 0x1018

复位值: 0x0000 0000

| 位/域   | 名称       | R/W | 描述                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------|----------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     |          |     | 保留                                                                                                                                                                                                                                                                                                                                                                                                        |
| 1     | STRX     | R/W | <p>开始或停止接收 (Start or Stop Receive)</p> <p>当设置此位时, 接收进程将处于运行状态。DMA 尝试从接收列表中获取描述符并处理传入的帧。从列表中的当前位置尝试获取描述符, 该位置是由 <b>ETH_DMARXDLADDR</b> 寄存器设置的地址, 或者在接收进程之前停止时保留的位置。如果 DMA 不拥有该描述符, 则接收被挂起, 并设置 <b>ETH_DMASTS[7]</b>。“开始接收”命令只有在接收停止后才有效。如果在设置 <b>ETH_DMARXDLADDR</b> 寄存器之前发出命令, DMA 行为是不可预测的。</p> <p>当这个位被清除时, Rx DMA 操作在当前帧的发送后停止。接收列表中的下一个描述符位置将被保存, 并在重新启动接收进程后成为当前位置。停止接收命令只在接收进程处于“运行”或“挂起”状态时有效。</p> |
| 2     | OSECF    | R/W | <p>操作第二帧 (Operate on Second Frame)</p> <p>当设置此位时, 它指示 DMA 处理发送数据的第二帧, 甚至在获得第一帧的状态之前。</p>                                                                                                                                                                                                                                                                                                                  |
| 4:3   | RXTHCTRL | R/W | <p>接收阈值控制 (Receive Threshold Control)</p> <p>这两个位控制接收 FIFO 的阈值水平。发送到 DMA 开始时, 在接收 FIFO 的帧大小大于阈值。此外, 长度小于阈值的全帧将自动发送。</p> <p>当配置的“接收 FIFO 大小”为 128 字节时, 不使用 11。这些位只在 RXSF 位为 0 时有效, 当 RXSF 位为 1 时被忽略。</p> <p>00: 64<br/>01: 32<br/>10: 96<br/>11: 128</p>                                                                                                                                                   |
| 5     |          |     | 保留                                                                                                                                                                                                                                                                                                                                                                                                        |
| 6     | FUF      | R/W | <p>转发小型正常帧 (Forward Undersized Good Frames)</p> <p>当设置时, Rx FIFO 转发过小的帧, 包括填充字节和 CRC。当复位时, Rx FIFO 丢弃所有小于 64 字节的帧, 除非一个帧因为接收阈值较低而已经发送, 例如 RTC=01。</p>                                                                                                                                                                                                                                                     |
| 7     | FERRF    | R/W | <p>转发错误帧 (Forward Error Frames)</p> <p>当这个位被重置时, Rx FIFO 丢弃带有错误状态的帧。但是, 如果帧的开始字节指针已经转移到读控制器端 (在阈值模式), 那么帧不会被丢弃。</p> <p>如果帧的起始字节没有在 ARI 总线上发送 (输出), Rx FIFO 丢弃错误帧。</p>                                                                                                                                                                                                                                     |
| 12:8  |          |     | 保留                                                                                                                                                                                                                                                                                                                                                                                                        |
| 13    | STTX     | R/W | <p>启动或停止发送命令 (Start or Stop Transmission Command)</p> <p>当这个位被设置时, 发送被放置在运行状态, DMA 检查当前位置的发送列表以获取要发送的帧。描述符获取尝试从列表中的当前位置或从之前发送停止时保留的位置获取。如果 DMA 不拥有当前描述符, 发送进入挂起状态, 并且 <b>ETH_DMASTS[2]</b> 被设置。只有在发送停止时, 该命令才会生效。如果在设置 <b>ETH_DMATXDLADDR</b> 寄存器之前发出命令, 那么 DMA 行为是不可预测的。</p> <p>当该位重置时, 当前帧完成发送后, 发送进程处于停止状态。发送列表中的下一个描述符位置将被保存, 当发送重新启动时它将成为当前位置。停止发送命令只有在当前帧发送完成或发送处于“挂起”状态时才有效。</p>                   |
| 16:14 | TXTCTRL  | R/W | 发送阈值控制 (Transmit Threshold Control)                                                                                                                                                                                                                                                                                                                                                                       |

| 位/域   | 名称      | R/W | 描述                                                                                                                                                                                       |
|-------|---------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |         |     | 这些位控制发送 FIFO 的阈值水平。发送开始时，发送 FIFO 内的帧大小大于阈值。此外，长度小于阈值的完整帧也被发送。这些位仅在位[21]复位时使用。<br>000: 64<br>001: 128<br>010: 192<br>011: 256<br>100: 40<br>101: 32<br>110: 24<br>111: 16                 |
| 19:17 |         |     | 保留                                                                                                                                                                                       |
| 20    | FTXF    | R/W | 刷新发送 FIFO (Flush Transmit FIFO)<br>当设置此位时，发送 FIFO 控制器逻辑将重置为其默认值，因此 Tx FIFO 中的所有数据将丢失或刷新。当刷新操作完成时，将在内部清除此位。在清除此位之前，不应该写入操作模式寄存器。                                                          |
| 21    | TXSF    | R/W | 发送、存储和转发 (Transmit Store and Forward)<br>当设置此位时，如果发送 FIFO 中有一个完整帧，发送会启动。当设置此位时，位[16:14]中指定的 TTC 值将被忽略。只有在发送停止时，才能更换此位。                                                                   |
| 23:22 |         |     | 保留                                                                                                                                                                                       |
| 24    | DISFRXF | R/W | 禁用接收帧的刷新 (Disable Flushing of Received Frames)<br>当该位被设置时，Rx DMA 不会像正常情况下重置该位时那样因为接收描述符或缓冲区不可用而刷新任何帧。                                                                                    |
| 25    | RXSF    | R/W | 接收、存储和转发 (Receive Store and Forward)<br>当这个位被设置时，向 Rx FIFO 写入完整的帧后可以读取帧，且忽略 RTC 位。当这个位被重置时，Rx FIFO 以直通模式运行，受 RTC 位指定的阈值限制。                                                               |
| 26    | DISDT   | R/W | 关闭 TCP/IP 校验错误帧的丢弃功能 (Disable Dropping of TCP/IP Checksum Error Frames)<br>当设置此位时，MAC 不会丢弃只有接收校验和卸载引擎检测到的错误帧。这样的帧在 MAC 接收到的以太网帧中没有任何错误，但只有在封装的负载中有错误。当这个位被重置时，如果 FERRF 位被重置，所有的错误帧都会被丢弃。 |
| 31:27 |         |     | 保留                                                                                                                                                                                       |

### 27.11.8 中断使能寄存器 (ETH\_DMAINTEN)

偏移地址: 0x101C

复位值: 0x0000 0000

| 位/域 | 名称    | R/W | 描述                                                                              |
|-----|-------|-----|---------------------------------------------------------------------------------|
| 0   | TXIEN | R/W | 使能发送中断 (Transmit Interrupt Enable)<br>当该位通过位[16]置 1 时，使能发送中断。当该位被重置时，发送中断被禁用。   |
| 1   | TXSEN | R/W | 使能发送停止 (Transmit Stopped Enable)<br>当该位通过位[15]置 1 时，使能发送停止中断。当该位被重置时，发送停止中断将被禁用 |

| 位/域   | 名称      | R/W | 描述                                                                                                                                                                                                                                                                                                                                       |
|-------|---------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2     | TXBUEN  | R/W | 使能发送缓冲区不可用 (Transmit Buffer Unavailable Enable)<br>当该位通过位[16]置1时, 使能发送缓冲区不可用中断。当该位被重置时, 发送缓冲区不可用中断将被禁用。                                                                                                                                                                                                                                  |
| 3     | TXJTOEN | R/W | 使能发送 Jabber 超时 (Transmit Jabber Timeout Enable)<br>当该位通过位[15]置1时, 使能发送 Jabber 超时中断。当该位被重置时, 发送 Jabber 超时中断将被禁用。                                                                                                                                                                                                                          |
| 4     | RXOVFEN | R/W | 使能接收上溢中断 (Receive Overflow Interrupt Enable)<br>当该位通过位[15]置1时, 使能接收溢出中断。当该位被重置时, 溢出中断将被禁用。                                                                                                                                                                                                                                               |
| 5     | TXUNFEN | R/W | 使能发送下溢中断 (Transmit Underflow Interrupt Enable)<br>当该位通过位[15]置1时, 使能发送下溢中断。当该位被重置时, 下溢中断将被禁用。                                                                                                                                                                                                                                             |
| 6     | RXIEN   | R/W | 使能接收中断 (Receive Interrupt Enable)<br>当该位通过位[16]置1时, 使能接收中断。当该位被重置时, 接收中断将被禁用。                                                                                                                                                                                                                                                            |
| 7     | RXBUEN  | R/W | 使能接收缓冲区不可用 (Receive Buffer Unavailable Enable)<br>当该位通过位[15]置1时, 使能接收缓冲区不可用中断。当该位重置时, 接收缓冲区不可用中断将被禁用。                                                                                                                                                                                                                                    |
| 8     | RXSEN   | R/W | 使能接收停止 (Receive Stopped Enable)<br>当该位通过位[15]置1时, 使能接收停止中断。当该位被重置时, 接收停止中断将被禁用。                                                                                                                                                                                                                                                          |
| 9     | RXWTOEN | R/W | 使能接收看门狗超时 (Receive Watchdog Timeout Enable)<br>当该位通过位[15]置1时, 使能接收看门狗超时中断。当该位重置时, 接收看门狗超时中断将被禁用。                                                                                                                                                                                                                                         |
| 10    | ETXIEN  | R/W | 使能提前发送中断 (Early Transmit Interrupt Enable)<br>当该位通过位[15]置1时, 使能提前发送中断。当该位被重置时, 提前发送中断将被禁用。                                                                                                                                                                                                                                               |
| 12:11 |         |     | 保留                                                                                                                                                                                                                                                                                                                                       |
| 13    | FBERREN | R/W | 使能致命总线错误 (Fatal Bus Error Enable)<br>当该位通过位[15]置1时, 使能致命总线错误中断。当该位被重置时, 致命总线错误使能中断将被禁用。                                                                                                                                                                                                                                                  |
| 14    | ERXIEN  | R/W | 使能提前接收中断 (Early Receive Interrupt Enable)<br>当该位通过位[16]置1时, 使能提前接收中断。当该位被重置时, 早期接收中断将被禁用。                                                                                                                                                                                                                                                |
| 15    | AINSEN  | R/W | 使能异常中断汇总 (Abnormal Interrupt Summary Enable)<br>当设置此位时, 使能异常中断汇总。当该位被重置时, 异常中断汇总将被禁用。该位使能下列中断:<br>ETH_DMASTS[1]: 发送过程中停止<br>ETH_DMASTS[3]: 发送 Jabber 超时<br>ETH_DMASTS[4]: 接收上溢<br>ETH_DMASTS[5]: 发送下溢<br>ETH_DMASTS[7]: 接收缓冲区不可用<br>ETH_DMASTS[8]: 接收过程中停止<br>ETH_DMASTS[9]: 接收看门狗超时<br>ETH_DMASTS[10]: 提前发送中断<br>ETH_DMASTS[13]: 致命总线错误 |

| 位/域   | 名称      | R/W | 描述                                                                                                                                                                                                                  |
|-------|---------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16    | NINTSEN | R/W | <p>使能正常中断汇总 (Normal Interrupt Summary Enable)<br/> 当设置此位时, 将启用正常中断汇总。当该位被重置时, 正常中断汇总将被禁用。此位使能下列中断:</p> <p>ETH_DMASTS[0]: 发送中断<br/> ETH_DMASTS[2]: 发送缓冲区不可用<br/> ETH_DMASTS[6]: 接收中断<br/> ETH_DMASTS[14]: 提前接收中断</p> |
| 31:17 |         |     | 保留                                                                                                                                                                                                                  |

### 27.11.9 丢失帧和缓冲区上溢计数寄存器 (ETH\_DMAMFABOCNT)

偏移地址: 0x1020

复位值: 0x0000 0000

| 位/域   | 名称         | R/W  | 描述                                                                                                        |
|-------|------------|------|-----------------------------------------------------------------------------------------------------------|
| 15:0  | MISFCNT    | RC_R | <p>控制器丢失帧计数器 (Controller Missed Frame Counter)<br/> 表示由于主机接收缓冲区不可用而被控制器丢失的帧数。这个计数器在 DMA 每次丢弃一个传入帧时增加。</p> |
| 16    | MISFCNTOVF | RC_R | 丢失帧计数器溢出位 (Overflow Bit for Missed Frame Counter)                                                         |
| 27:17 | AMISFCNT   | RC_R | <p>应用程序丢失帧计数器 (Application Missed Frame Counter)<br/> 表示应用程序丢失的帧数。</p>                                    |
| 28    | OVFCNTOVF  | RC_R | FIFO 溢出计数器溢出位 (Overflow Bit for FIFO Overflow Counter)                                                    |
| 31:29 |            |      | 保留                                                                                                        |

### 27.11.10 接收标志看门狗定时器寄存器 (ETH\_DMARXFLGWDT)

偏移地址: 0x1024

复位值: 0x0000 0000

| 位/域  | 名称       | R/W | 描述                                                                                                                                                                                                                                                 |
|------|----------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0  | RXWDTCNT | R/W | <p>RXFLG 看门狗定时器计数 (RXFLG Watchdog Timer Count)<br/> 该位表示设置看门狗定时器的系统时钟周期数乘以 256。看门狗定时器在 Rx DMA 完成一个 RXFLG 状态位没有被设置的帧的发送后被程序设定的值触发, 因为相应的描述符 RXDES1[31]中的设置。看门狗定时器超时后, 设置 RXFLG 位, 停止定时器。因为 RXFLG 自动设置接收帧的 RXDES1[31]使得 RXFLG 位设置为高电平, 看门狗定时器复位。</p> |
| 31:8 |          |     | 保留                                                                                                                                                                                                                                                 |

### 27.11.11 当前主机发送描述符寄存器 (ETH\_DMAHTXD)

偏移地址: 0x1048

复位值: 0x0000 0000

| 位/域  | 名称        | R/W | 描述                                                                                   |
|------|-----------|-----|--------------------------------------------------------------------------------------|
| 31:0 | HTXDADDRP | R   | <p>主机发送描述符地址指针 (Host Transmit Descriptor Address Pointer)<br/> 在操作期间由 DMA 更新的指针。</p> |

### 27.11.12 当前主机接收描述符寄存器 (ETH\_DMAHRXD)

偏移地址: 0x104C

复位值: 0x0000 0000

| 位/域  | 名称        | R/W | 描述                                                                         |
|------|-----------|-----|----------------------------------------------------------------------------|
| 31:0 | HRXDADDRP | R   | 主机接收描述符地址指针 (Host Receive Descriptor Address Pointer)<br>在操作期间由 DMA 更新的指针。 |

### 27.11.13 当前主机发送缓冲区地址寄存器 (ETH\_DMAHTXBADDR)

偏移地址: 0x1050

复位值: 0x0000 0000

| 位/域  | 名称        | R/W | 描述                                                                      |
|------|-----------|-----|-------------------------------------------------------------------------|
| 31:0 | HTXBADDRP | R   | 主机发送缓冲区地址指针 (Host Transmit Buffer Address Pointer)<br>在操作期间由 DMA 更新的指针。 |

### 27.11.14 当前主机接收缓冲区地址寄存器 (ETH\_DMAHRXBADDR)

偏移地址: 0x1054

复位值: 0x0000 0000

| 位/域  | 名称        | R/W | 描述                                                                     |
|------|-----------|-----|------------------------------------------------------------------------|
| 31:0 | HRXBADDRP | R   | 主机接收缓冲区地址指针 (Host Receive Buffer Address Pointer)<br>在操作期间由 DMA 更新的指针。 |

## 28 模数转换器 (ADC)

### 28.1 术语全称、缩写描述

表格 145 ADC 术语全称、缩写描述

| 中文全称  | 英文全称            | 英文缩写   |
|-------|-----------------|--------|
| 模拟看门狗 | Analog watchdog | AWD    |
| 转换    | Conversion      | C      |
| 注入    | Injected        | INJ    |
| 规则    | Regular         | REG    |
| 开始    | Start           | S      |
| 扫描    | Scan            | SCAN   |
| 单个    | Single          | SINGLE |
| 自动    | Automatic       | A      |
| 组     | Group           | G      |
| 间断    | Discontinuous   | DISC   |
| 计数    | Count           | CNT    |
| 双数    | Dual            | DUAL   |
| 连续    | Continuous      | C      |
| 校准    | Calibration     | CAL    |
| 复位    | Reset           | RST    |
| 对齐    | Alignment       | ALIGN  |
| 外部    | External        | EXT    |
| 事件    | Event           | E      |
| 触发    | Trigger         | TRG    |
| 温度    | Temperature     | T      |
| 传感器   | Sensor          | S      |
| 时间    | Time            | TIM    |
| 采样    | Sample          | SMP    |
| 偏移    | Offset          | OF     |
| 高     | High            | H      |
| 低     | Low             | L      |
| 阈值    | Threshold       | T      |
| 序列    | Sequence        | SEQ    |

| 中文全称  | 英文全称                  | 英文缩写    |
|-------|-----------------------|---------|
| 长度    | Length                | LEN     |
| 规则通道  | Regular Channels      | REG     |
| 注入通道  | Injected Channel      | INJ     |
| 注入组   | Injected Group        | INJG    |
| 自动    | Automatic             | A       |
| 转换    | Conversion            | C       |
| 模拟看门狗 | Analog Watchdog       | AWD     |
| 间断模式  | Discontinuous Mode    | DISC    |
| 扫描模式  | Scan Mode             | SCAN    |
| 连续转换  | Continuous Conversion | CONTC   |
| 单次转换  | Single Conversion     | SINGLEC |
| 外部    | External              | EXT     |
| 外部触发  | External Trigger      | EXTTRG  |
| 采样时间  | Sample Time           | SMPTIM  |
| 序列    | Sequence              | SEQ     |
| 数目    | Number                | NUM     |

## 28.2简介

系列产品有3个ADC，精度为12位。每个ADC最多有16个外部通道和3个内部通道，各通道A/D转换模式有单次、连续、扫描或间断，ADC转换结果可以左对齐或右对齐存储在16位数据寄存器中。

## 28.3主要特征

- (1) ADC供电要求：全速运行为2.4V到3.6V，慢速运行为1.8V。
- (2) ADC输入范围： $V_{REF-} \leq V_{IN} \leq V_{REF+}$
- (3) 可配置12位、10位、8位或6位分辨率
- (4) ADC转换时间：
  - 公式：TCONV=采样时间+12个周期
  - 采样时间由SMPCYCCFGx[2:0]位控制，最小采样周期为3个，当ADCCLK=30MHz，采样时间为3周期：TCONV=3周期+12周期=15周期=0.5μs。
- (5) 模式输入通道类别：
  - 外部GPIO输入通道

- 1 个内部温度传感 ( $V_{SENSE}$ ) 输入通道
- 1 个内部参考电压 ( $V_{REFINT}$ ) 输入通道
- 1 个内部备份电压 ( $V_{BAT}$ ) 输入通道

(6) 通道转换模式

- 单个通道转换模式：单次转换模式、连续转换模式
- 输入通道分类：规则通道、注入通道
- 一组通道转换模式：扫描模式、间断模式、注入通道管理
- ADC 模式：独立 ADC 模式、双重/三重 ADC 模式

(7) 触发方式

- 片上定时器信号触发
- 外部引脚
- 软件触发

(8) 数据寄存器

- 规则数据寄存器
- 注入数据寄存器
- 通用规则数据寄存器

(9) 中断

- 转换结束中断
- 模拟看门狗中断
- 溢出中断

(10) 支持规则数据转换的 DMA 请求

(11) 数据对齐

- 数据寄存器 ADC\_CTRL2 的 DALIGNCFG 位可配置数据对齐方式为左对齐或右对齐。

## 28.4 功能描述

### 28.4.1 ADC 引脚

表格 146 ADC 引脚

| 名称               | 说明                                                                                                           | 信号类型       |
|------------------|--------------------------------------------------------------------------------------------------------------|------------|
| $V_{REF+}$       | ADC 使用的高端/正极参考电压, $1.8V \leq V_{REF+} \leq V_{DDA}$                                                          | 输入, 模拟参考正极 |
| $V_{DDA}$        | 等效于 $V_{DD}$ 的模拟电源且: 全速运行 $2.4V \leq V_{DDA} \leq V_{DD}(3.6V)$ , 慢速运行 $1.8V \leq V_{DDA} \leq V_{DD}(3.6V)$ | 输入, 模拟电源   |
| $V_{REF-}$       | ADC 使用的低端/负极参考电压, $V_{REF-} = V_{SSA}$                                                                       | 输入, 模拟参考负极 |
| $V_{SSA}$        | 等效于 $V_{SS}$ 的模拟电源地                                                                                          | 输入, 模拟电源地  |
| $ADCx\_IN[15:0]$ | 16 个模拟输入通道                                                                                                   | 模拟输入信号     |

## 28.4.2 ADC 转换模式

产品内置多个 ADC、多个通道（具体数量参考数据手册），可以组合出多种转换模式。

内置多个 ADC，依据 ADC 的数量，转换模式可以分为独立 ADC 模式、双重 ADC 模式；内置多个通道，可以将通道分为 2 类组别，即规则通道、注入通道，在每组内部转换模式分为扫描模式、间断模式；对于每个组内部的通道，转换模式分为单次转换模式、连续转换模式。

在应用中，依据实际应用需求，可结合 ADC 的数量、转换的通道数、每个通道的转换方式设计出满足需求的 ADC 转换方式。

### 28.4.2.1 单个 ADC 工作、单个通道的转换方式

#### 单次转换模式

该模式对单个通道而言之只对此通道进行一次转换，对多通道而言只对此组通道进行一次转换。

启动方式：

- 将 ADC\_CTRL2 寄存器中的 SWSTART 位置 1（仅适用于规则通道）
- 将 JSWSTART 位置 1（适用于注入通道）
- 外部触发（适用于规则通道或注入通道）

规则通道一次转换结束，转换数据将存储到 16 位 ADC\_REGDATA 寄存器，EOCFLG 位置 1，若配置 EOCIEN 位置 1，则产生中断。

注入通道一次转换结束，转换数据将存储到 16 位 ADC\_INJDATAx(x=1...4)寄存器，INJEOCFLG 位置 1，若配置 INJEOCIEN 位置 1，则产生中断。

图 114 单次转换模式时序图



#### 连续转换模式

该模式对单通道而言之对此通道进行连续转换。

该模式通过配置寄存器 ADC\_CTRL2 的 ADCEN 位启动或外部触发启动。

一个规则通道转换结束，转换数据将存储到 16 位 ADC\_REGDATA 寄存器，EOCFLG 位置 1，若配置 EOCIEN 位置 1，则产生中断。

一个注入通道转换结束，转换数据将存储到 16 位 `ADC_INJDATAx`( $x=1\dots4$ )寄存器，`INJEOCFLG` 位置 1，若配置 `INJEOCIEN` 位置 1，则产生中断。

图 115 连续转换模式时序图



#### 28.4.2.2 单个 ADC、一组通道转换方式

##### 模拟输入通道分类

###### 规则通道组

- 规则组由 16 个通道组成
- 规则通道转换顺序通过配置寄存器 `ADC_REGSEQx` 决定
- 规则组转换通道的总数通过配置寄存器 `ADC_REGSEQ1` 的 `REGSEQLEN` 位决定

###### 注入通道组

- 注入组由 4 个通道组成
- 注入通道转换顺序通过配置寄存器在 `ADC_INJSEQ` 决定
- 注入组转换通道的总数通过配置寄存器在 `ADC_INJSEQ` 的 `INJSEQLEN` 位决定

##### 内部输入通道

###### 温度传感器：

- 温度传感器用来测量芯片内部的温度
- 温度传感器选择 `ADC1_IN16` 输入通道
- 通过配置寄存器 `ADC_CCTRL` 的 `TSVREFEN` 位启动

###### 内部参考电压 $V_{REFINT}$ ：

- 内部参考电压用来提供一个稳定的电压输出给 ADC
- 内部参考电压  $V_{REFINT}$  选择 `ADC1_IN17` 输入通道

###### 内部备份电压 $V_{BAT}$ ：

- 内部备份电压  $V_{BAT}$  选择 `ADC1_IN18` 输入通道

## 通道转换顺序

### 规则序列寄存器配置:

- 配置寄存器 ADC\_REGSEQ3 的 REGSEQC1~REGSEQC6 位设置第 1~6 个转换通道
- 配置寄存器 ADC\_REGSEQ2 的 REGSEQC7~REGSEQC12 位设置第 7~12 个转换通道
- 配置寄存器 ADC\_REGSEQ1 的 REGSEQC13~REGSEQC16 位设置第 13~16 个转换通道
- 配置寄存器 ADC\_REGSEQ1 的 REGSEQLEN 设置需要转换的通道数目

### 注入序列寄存器配置:

- 配置寄存器 ADC\_INJSEQ 的 INJSEQC1~INJSEQC4 位设置第 1~4 个转换通道
- 配置寄存器 ADC\_INJSEQ 的 INJSEQLEN 设置需要转换的通道数目
- 若 INJSEQLEN 的值小于 4, 则转换顺序不同, 转换顺序从 (4-INJSEQLEN) 开始。

## 通道转换模式

### 扫描模式

该模式适用于一组通道, 相当于在一组通道的每个通道上进行单次转换。

该模式通过配置寄存器 ADC\_CTRL1 的 SCANEN 位启动, 启动后 ADC 扫描所有的按序列寄存器 ADC\_REGSEQ 或 ADC\_INJSEQ 排好顺序的通道, 每个通道转换完成后将自动转换该组下一个通道。

若配置 CONTCEN 位置 1, 当该组最后一个通道转换完成后将继续从该组第一个通道开始转换。

若配置 DMAEN 位置 1, 每次通道转换完成后, DMA 控制器将规则通道的转换数据传输到 SRAM。

图 116 扫描模式时序图



### 间断模式

该模式适用于一组通道，相当于对一组通道里的多个通道进行连续转换。

对于规则组，该模式通过配置寄存器 ADC\_CTRL1 的 REGDISCEN 位启动，启动后进行一次  $n$  个通道的短序列转换 ( $n \leq 8$ )， $n$  通过配置寄存器 ADC\_CTRL1 的 DISCNUMCFG[2:0]决定；通过软件控制或外部触发源可以启动下一轮  $n$  个通道的转换，直到该组通道全部转换完成，EOCFLG 位置 1。

对于注入组，该模式通过配置寄存器 ADC\_CTRL1 的 INJDISCEN 位启动，启动后按序列寄存器配置顺序进行一个通道的转换，通过软件控制或外部触发源可以按顺序启动下一个通道的转换，直到该组通道全部转换完成，EOCFLG 位和 INJEOCFLG 位置 1。

图 117 间断模式时序图



### 注入通道管理

触发注入：通过清除寄存器 ADC\_CTRL1 的 INJGACEN 位，在规则组通道转换期间若产生一个软件触发或外部触发将启动触发注入转换，此时规则通道转换停止，注入通道序列开始转换，在注入组通道转换完成后恢复规则组通道转换。

图 118 触发注入时序图



自动注入：需要配置寄存器 ADC\_CTRL1 的 INJGACEN 位启动，在规则组通道转换完成后，注入组通道自动开始转换，自动注入模式下，注入组通道的外部触发必须禁止；若还配置了寄存器 ADC\_CTRL2 的 CONTCEN 位，规则组和注入组的所有通道按序列进行连续转换。

图 119 自动注入时序图



### 28.4.2.3 双重或三重 ADC 模式、一组通道转换模式

两个或两个以上 ADC 模块的产品，使用双重或三重 ADC 模式，ADC1 默认为主 ADC，其他默认为从 ADC，通过配置 ADC\_CCTRL 寄存器中 ADCMSEL 位设置 ADC 模式。

当配置由外部事件触发时，需要设置为仅触发主 ADC，然后配置从 ADC 为软件触发。

双重或三重 ADC 有以下 6 种可能的模式：

#### (1) 同时规则模式

同时规则模式即多个 ADC 同时转换一个规则通道组。两个 ADC 不能同时转换一个通道。外部触发事件由寄存器 ADC1\_CTRL2 的 REGEXTTRGSEL 决定。

所有 ADC 规则通道转换完后，产生 EOCFLG 中断。双重 ADC 模式：转换结束

产生一个 DMA 传输请求，ADC1 转换数据放在寄存器 ADC1\_REGDATA 的低 16 位，ADC2 转换数据放在寄存器 ADC\_REGDATA 的高 16 位。三重 ADC 模式：转换结束后产生三个 DMA 请求，依此将 ADC1、ADC2、ADC3 转换数据传输到存储器。

#### （2）同时注入模式

同时注入模式即多个 ADC 同时转换一个注入通道组。两个 ADC 不能同时转换一个通道。外部触发事件由寄存器 ADC1\_CTRL2 的 INJGEXTTRGSEL 决定。

ADC 转换结束，转换数据存储在各个 ADC 接口的寄存器 ADC\_INJDATAx。

所有 ADC 注入通道转换完成后，产生 INJEOCFLG 中断。

#### （3）交替模式

交替模式即多个 ADC 交替转换一个规则通道组。外部触发事件由寄存器 ADC1\_CTRL2 的 REGEXTTRGSEL 决定。

双重 ADC 模式：出现触发后，ADC1 先启动，经过延迟后 ADC2 启动，延迟通过寄存器 ADC\_CCTRL 的 SMPDEL2 位配置。转换完成后生成 EOCFLG 中断，然后生成一个 DMA 请求，通过 DMA 模式 2 的方式进行数据传输。三重 ADC 模式：出现触发后，ADC1 先启动，经过延迟后 ADC2 启动，ADC2 转换经过延迟后 ADC3 启动，延迟通过寄存器 ADC\_CCTRL 的 SMPDEL2 位配置。每进行两次转换就生成一个 DMA 请求，通过 DMA 模式 2 的方式进行数据传输。

#### （4）交替触发模式

交替触发模式即多个 ADC 交替触发转换一个注入通道组。外部触发事件由寄存器 ADC1\_CTRL2 的 INJGEXTTRGSEL 决定。

双重 ADC 模式：产生第一次触发，转换 ADC1 中注入组所有通道，产生第二次触发，转换 ADC2 中注入组所有通道，每个 ADC 转换完成后都产生一个 INJEOCFLG 中断。三重 ADC 模式：产生第一次触发，转换 ADC1 中注入组所有通道，产生第二次触发，转换 ADC2 中注入组所有通道，产生第三次触发，转换 ADC3 中注入组所有通道，每个 ADC 转换完成后都产生一个 INJEOCFLG 中断。

#### （5）混合的同时规则/注入模式

混合同时规则/注入模式即同时规则模式被中断后启动同时注入模式。

该模式中，必须转换相同长度的序列或设置触发间隔时间能够转换完成较长序列。

#### （6）混合的同时规则+交替触发模式

混合的同时规则+交替触发模式即同时规则模式被中断后启动交替触发模式。

该模式中，必须转换相同长度的序列或设置触发间隔时间能够转换完成较长序列。

### 28.4.3 外部触发

外部触发的寄存器配置如下：

- 规则组通道的外部事件触发通过配置寄存器 ADC\_CTRL2 的 REGEXTTRGSEL 位启动
- 注入组通道的外部事件触发通过配置寄存器 ADC\_CTRL2 的 INJGEXTTRGSEL 位启动

表格 147 规则通道的外部触发

| 触发源       | REGEXTTRGSEL[3:0] | 触发类型         |
|-----------|-------------------|--------------|
| TMR1_CC1  | 0000              | 来自片上定时器的内部信号 |
| TMR1_CC2  | 0001              |              |
| TMR1_CC3  | 0010              |              |
| TMR2_CC2  | 0011              |              |
| TMR2_CC3  | 0100              |              |
| TMR2_CC4  | 0101              |              |
| TMR2_TRGO | 0110              |              |
| TMR3_CC1  | 0111              |              |
| TMR3_TRGO | 1000              |              |
| TMR4_CC4  | 1001              |              |
| TMR5_CC1  | 1010              |              |
| TMR5_CC2  | 1011              |              |
| TMR5_CC3  | 1100              |              |
| TMR8_CC1  | 1101              |              |
| TMR8_TRGO | 1110              |              |
| EINT 线 11 | 1111              | 外部引脚         |

表格 148 注入通道的外部触发

| 触发源       | INJGEXTTRGSEL[3:0] | 触发类型         |
|-----------|--------------------|--------------|
| TMR1_CC4  | 0000               | 来自片上定时器的内部信号 |
| TMR1_TRGO | 0001               |              |
| TMR2_CC1  | 0010               |              |
| TMR2_TRGO | 0011               |              |
| TMR3_CC2  | 0100               |              |
| TMR3_CC4  | 0101               |              |
| TMR4_CC1  | 0110               |              |
| TMR4_CC2  | 0111               |              |

| 触发源       | INJGEXTTRGSEL[3:0] | 触发类型 |
|-----------|--------------------|------|
| TMR4_CC3  | 1000               |      |
| TMR4_TRGO | 1001               |      |
| TMR5_CC4  | 1010               |      |
| TMR5_TRGO | 1011               |      |
| TMR8_CC2  | 1100               |      |
| TMR8_CC3  | 1101               |      |
| TMR8_CC4  | 1110               |      |
| EINT 线 15 | 1111               | 外部引脚 |

## 28.4.4 数据寄存器

### 28.4.4.1 规则数据寄存器

ADC\_REGDATA 是一个 32 位的 ADC 规则数据寄存器，其低 16 位有效，高 16 位保留，单 ADC 模式下只使用低 16 位存储转换数据，数据对齐方式为左对齐和右对齐。

通过配置寄存器 ADC\_CTRL2 的 DALIGNCFG 位决定是否使用 DMA 传输，其中规则通道最多有 16 个，但规则数据寄存器只有 1 个，所以在多通道转换时将产生数据覆盖问题，此时就需要使用 DMA 传输。

### 28.4.4.2 注入数据存储器

ADC\_INJDATAx (x=1,2,3,4) 是 ADC 注入数据寄存器，有四个 32 位的寄存器，其低 16 位有效，高 16 位保留。注入通道最多有 4 个，注入数据寄存器也有四个，在多通道转换时不会发生数据覆盖问题，数据对齐方式为左对齐和右对齐。

### 28.4.4.3 通用规则数据存储器

ADC\_CDATA 是 ADC 通用规则数据寄存器，仅适用于双重或三重模式，在双重或三重模式下一般需要 DMA 来配合传输数据。

## 28.4.5 中断

### 28.4.5.1 转换结束中断

#### 规则组通道转换结束中断

规则通道转换结束后产生中断，在中断函数中读取规则数据寄存器的值。

通过控制寄存器 ADC\_CTRL1 的 EOCIEN 位使能中断。

通过状态寄存器 ADC\_CSTS 的 EOCFLG 位查询事件标准。

#### 注入组通道转换结束中断

注入通道转换结束后产生中断，在中断函数中读取规则数据寄存器的值。

通过控制寄存器 **ADC\_CTRL1** 的 **INJEOCIEN** 位使能中断。

通过状态寄存器 **ADC\_CSTS** 的 **INJEOCFLG** 位查询事件标准。

#### 28.4.5.2 模拟看门狗中断

若输入的模拟电压不在阈值范围内将产生模拟看门狗中断。

通过控制寄存器 **ADC\_CTRL1** 的 **AWDIEN** 位使能中断。

通过状态寄存器 **ADC\_CSTS** 的 **AWDFLG** 位查询事件标准。

#### 28.4.5.3 溢出中断

当转换数据丢失（溢出）将产生一个溢出中断。

通过控制寄存器 **ADC\_CTRL1** 的 **OVRIEN** 位使能中断。

通过状态寄存器 **ADC\_CSTS** 的 **OVRFLLG** 位查询事件标准。

#### 28.4.6 DMA

规则通道转换结束后产生 **DMA** 请求，可以将转换的数据结果从 **ADC\_REGDATA** 寄存器传输到存储器中。

#### 28.4.7 片上硬件过采样

片上硬件过采样单元执行数据预处理以减轻 **CPU** 负担。它能够处理多个转换，并将多个转换的结果取平均，得出一个 16 位宽的数据。其结果值根据如下公式计算得出，其中 **N** 和 **M** 的值可以被调整，过采样单元可以通过设置 **ADC\_OSAMPCTRL** 寄存器的 **OSEN** 位来使能，它是以降低数据输出率为代价，换取较高的数据分辨率。 $D_{out}(n)$  是指 **ADC** 输出的第 **n** 个数字信号：

$$Result = \frac{1}{M} \times \sum_{n=0}^{N-1} (D_{out}(n))$$

片上硬件过采样单元执行两个功能：求和与位右移。

过采样率 **N** 是 **ADC\_OSAMPCTL** 寄存器的 **OSR[2:0]** 位定义，取值范围为 **2x** 到 **256x**。除法系数 **M** 定义一个多达 8 位的右移，它通过 **ADC\_OSAMPCTRL** 寄存器 **OSS[3:0]** 位进行配置。

求和单元能够生成一个多达 20 位（**256\*12** 位）的值。首先，将这个值进行右移，将移位后剩余的部分再通过取整转化一个近似值，最后将高位截断，仅保留最低 16 位有效位作为最终值传入对应的数据寄存器中。

#### 20 位到 16 位的结果截断

图 120 20 位到 16 位的结果截断



注意：

- (1) 如果移位后的中间结果仍超过 16 位，那么该结果的高位会被直接截掉。
- (2) 过采样功能不适用于 ADC 注入数据方式。

## 28.5 寄存器地址映射

表格 149 ADC 寄存器地址映射

| 寄存器名          | 描述                | 偏移地址      |
|---------------|-------------------|-----------|
| ADC_STS       | ADC 状态寄存器         | 0x00      |
| ADC_CTRL1     | ADC 控制寄存器 1       | 0x04      |
| ADC_CTRL2     | ADC 控制寄存器 2       | 0x08      |
| ADC_SMPTIM1   | ADC 采样时间寄存器 1     | 0x0C      |
| ADC_SMPTIM2   | ADC 采样时间寄存器 2     | 0x10      |
| ADC_INJDOFx   | ADC 注入通道数据偏移寄存器 x | 0x14-0x20 |
| ADC_AWDHT     | 模拟看门狗高阀值寄存器       | 0x24      |
| ADC_AWDLT     | 模拟看门狗低阀值寄存器       | 0x28      |
| ADC_REGSEQ1   | ADC 规则序列寄存器 1     | 0x2C      |
| ADC_REGSEQ2   | ADC 规则序列寄存器 2     | 0x30      |
| ADC_REGSEQ3   | ADC 规则序列寄存器 3     | 0x34      |
| ADC_INJSEQ    | ADC 注入序列寄存器       | 0x38      |
| ADC_INJDATAx  | ADC 注入数据寄存器 x     | 0x3C-0x48 |
| ADC_REGDATA   | ADC 规则数据寄存器       | 0x4C      |
| ADC_OSAMPCTRL | ADC 过采样控制寄存器      | 0x50      |

| 寄存器名      | 描述                        | 偏移地址 |
|-----------|---------------------------|------|
| ADC_CSTS  | ADC 通用状态寄存器               | 0x00 |
| ADC_CCTRL | ADC 通用控制寄存器               | 0x04 |
| ADC_CDATA | 适用于双重和三重模式的 ADC 通用规则数据寄存器 | 0x08 |

## 28.6 寄存器功能描述

### 28.6.1 ADC 状态寄存器 (ADC\_STS)

偏移地址: 0x00

复位值: 0x0000 0000

| 位/域  | 名称        | R/W   | 描述                                                                                               |
|------|-----------|-------|--------------------------------------------------------------------------------------------------|
| 0    | AWDFLG    | RC_W0 | 发生模拟看门狗事件标志位 (Analog Watchdog Occur Flag)<br>该位由硬件置 1, 软件清 0, 表示是否发生模拟看门狗事件。<br>0: 没有发生<br>1: 发生 |
| 1    | EOCFLG    | RC_W0 | 规则通道转换结束标志 (Regular Channel End Of Conversion Flag)<br>0: 未完成<br>1: 完成                           |
| 2    | INJEOCFLG | RC_W0 | 注入通道转换结束标志 (Injected Channel End Of Conversion Flag)<br>0: 未完成<br>1: 完成                          |
| 3    | INJCSFLG  | RC_W0 | 注入通道转换开始标志 (Injected Channel Conversion Start Flag)<br>0: 未开始<br>1: 开始                           |
| 4    | REGCSFLG  | RC_W0 | 规则通道转换开始标志 (Regular Channel Conversion Start Flag)<br>0: 未开始<br>1: 开始                            |
| 5    | OVRFLG    | RC_W0 | 溢出标志 (Overrun Flag)<br>0: 未发生<br>1: 发生                                                           |
| 31:6 |           |       | 保留                                                                                               |

### 28.6.2 ADC 控制寄存器 1 (ADC\_CTRL1)

偏移地址: 0x04

复位值: 0x0000 0000

| 位/域 | 名称       | R/W | 描述                                                                                                                                                |
|-----|----------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 4:0 | AWDCHSEL | R/W | 选择模拟看门狗通道 (Analog Watchdog Channel Select)<br>00000: ADC 模拟输入通道 0<br>00001: ADC 模拟输入通道 1<br>.....<br>01111: ADC 模拟输入通道 15<br>10000: ADC 模拟输入通道 16 |

| 位/域   | 名称         | R/W | 描述                                                                                                                                                                     |
|-------|------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |            |     | 10001: ADC 模拟输入通道 17<br>10010: ADC 模拟输入通道 18<br>其它值: 保留                                                                                                                |
| 5     | EOCIEN     | R/W | 使能 EOC 中断 (EOC Interrupt Enable)<br>用于使能转换结束后产生中断。<br>0: 禁用<br>1: 使能                                                                                                   |
| 6     | AWDIEN     | R/W | 使能模拟看门狗中断 (Analog Watchdog Interrupt Enable)<br>若该位被设置且处于扫描模式下, 当看门狗检测到数值超过阈值时, 产生中断并中止扫描。<br>0: 禁用<br>1: 使能                                                           |
| 7     | INJEOCIEN  | R/W | 使能注入通道转换结束中断 (Interrupt Enable for Injected Channels End of Conversion Flag)<br>0: 禁用<br>1: 使能                                                                         |
| 8     | SCANEN     | R/W | 使能扫描模式 (Scan Mode Enable)<br>在扫描模式中, 转换由 ADC_REGSEQX 或 ADC_INJSEQX 寄存器选中的通道。<br>0: 禁用<br>1: 使能<br>注意: 如果分别设置了 EOCIEN 或 INJEOCIEN 位, 只在最后一个通道转换完毕后才会产生 EOC 或 INJEOC 中断。 |
| 9     | AWDGLEN    | R/W | 扫描模式下, 在单一通道上使能看门狗 (Enable The Watchdog On A Single Channel In Scan Mode)<br>该通道由 AWDCHSEL[4:0]位指定。<br>0: 在所有的通道上使能<br>1: 在单一通道上使能                                     |
| 10    | INJGACEN   | R/W | 使能注入通道组自动转换 (Automatic Injected Group Conversion Enable)<br>用于使能规则通道组转换结束后注入通道组自动转换。<br>0: 禁用<br>1: 使能                                                                 |
| 11    | REGDISCEN  | R/W | 使能规则通道上的间断模式 (Discontinuous Mode On Regular Channels Enable)<br>0: 禁用<br>1: 使能                                                                                         |
| 12    | INJDISCEN  | R/W | 使能注入通道上的间断模式 (Discontinuous Mode On Injected Channels Enable)<br>0: 禁用<br>1: 使能                                                                                        |
| 15:13 | DISCNUMCFG | R/W | 配置间断模式通道计数 (Discontinuous Mode Channel Number Configure)<br>000: 1 个通道<br>001: 2 个通道<br>.....<br>111: 8 个通道                                                            |

| 位/域   | 名称       | R/W | 描述                                                                                              |
|-------|----------|-----|-------------------------------------------------------------------------------------------------|
| 21:16 | 保留       |     |                                                                                                 |
| 22    | INJAWDEN | R/W | 使能注入通道的模拟看门狗功能 (Enable the Analog Watchdog Function On the Injected Channels)<br>0: 禁用<br>1: 使能 |
| 23    | REGAWDEN | R/W | 使能规则通道上的模拟看门狗功能 (Enable the Analog Watchdog Function On the Regular Channels)<br>0: 禁用<br>1: 使能 |
| 25:24 | RESSEL   | R/W | 选择分辨率 (Resolution Selection)<br>00: 12 位<br>01: 10 位<br>10: 8 位<br>11: 6 位                      |
| 26    | OVRIEN   | R/W | 溢出中断使能 (Overrun Interrupt Enable)<br>0: 禁用<br>1: 使能                                             |
| 31:27 | 保留       |     |                                                                                                 |

### 28.6.3 ADC 控制寄存器 2 (ADC\_CTRL2)

偏移地址: 0x08

复位值: 0x0000 0000

| 位/域   | 名称        | R/W | 描述                                                                                        |
|-------|-----------|-----|-------------------------------------------------------------------------------------------|
| 0     | ADCEN     | R/W | 使能 ADC (ADC Enable)<br>0: 禁用进行 ADC 转换, 进入掉电模式<br>1: 启用 ADC 并且开始转换                         |
| 1     | CONTCEN   | R/W | 使能连续转换模式 (Continuous Conversion Mode Enable)<br>0: 单次转换模式<br>1: 连续转换模式                    |
| 7:2   | 保留        |     |                                                                                           |
| 8     | DMAEN     | R/W | 使能 DMA 模式 (DMA Mode Enable)<br>0: 禁用<br>1: 使能                                             |
| 9     | DMADISSEL | R/W | DMA 禁止选择 (DMA Disable Select)<br>0: 最后一次传输后不发出新的 DMA 请求<br>1: 只要发生数据转换且使能 DMA, 会发出 DMA 请求 |
| 10    | EOCSEL    | R/W | 结束转换选择 (End of Conversion Select)<br>0: 每个规则转换序列结束 EOCFLG 位置 1<br>1: 每个规则转换结束 EOCFLG 位置 1 |
| 11    | DALIGNCFG | R/W | 配置数据对齐方式 (Data Alignment Mode Configure)<br>0: 右对齐<br>1: 左对齐                              |
| 15:12 | 保留        |     |                                                                                           |

| 位/域   | 名称            | R/W | 描述                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------|---------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 19:16 | INJGEXTTRGSEL | R/W | <p>选择启动注入组转换的外部事件 (Select the External Trigger Event to Start the Injected Group Conversion)</p> <p>0000: 定时器 1 的 CC4 事件<br/>     0001: 定时器 1 的 TRGO 事件<br/>     0010: 定时器 2 的 CC1 事件<br/>     0011: 定时器 2 的 TRGO 事件<br/>     0100: 定时器 3 的 CC2 事件<br/>     0101: 定时器 3 的 CC4 事件<br/>     0110: 定时器 4 的 CC1 事件<br/>     0111: 定时器 4 的 CC2 事件<br/>     1000: 定时器 4 的 CC3 事件<br/>     1001: 定时器 4 的 TRGO 事件<br/>     1010: 定时器 5 的 CC4 事件<br/>     1011: 定时器 5 的 TRGO 事件<br/>     1100: 定时器 8 的 CC2 事件<br/>     1101: 定时器 8 的 CC3 事件<br/>     1110: 定时器 8 的 CC4 事件<br/>     1111: EINT 线 15</p> |
| 21:20 | INJEXTTRGEN   | R/W | <p>使能注入通道的外部触发 (Enable the External Trigger for Injected Channels)</p> <p>00: 禁用触发检测<br/>     01: 上升沿上的触发检测<br/>     10: 下降沿上的触发检测<br/>     11: 上升沿和下降沿上的触发检测</p>                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 22    | INJSWSC       | R/W | <p>软件启动转换注入通道 (Software Start Conversion Injected Channels)</p> <p>0: 复位状态<br/>     1: 开始转换注入通道</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 23    |               |     | 保留                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 27:24 | REGEXTTRGSEL  | R/W | <p>选择启动规则组转换的外部事件 (Select the External Trigger Event to Start the Regular Group Conversion)</p> <p>0000: 定时器 1 的 CC1 事件<br/>     0001: 定时器 1 的 CC2 事件<br/>     0010: 定时器 1 的 CC3 事件<br/>     0011: 定时器 2 的 CC2 事件<br/>     0100: 定时器 2 的 CC3 事件<br/>     0101: 定时器 2 的 CC4 事件<br/>     0110: 定时器 2 的 TRGO 事件<br/>     0111: 定时器 3 的 CC1 事件<br/>     1000: 定时器 3 的 TRGO 事件<br/>     1001: 定时器 4 的 CC4 事件<br/>     1010: 定时器 5 的 CC1 事件<br/>     1011: 定时器 5 的 CC2 事件<br/>     1100: 定时器 5 的 CC3 事件<br/>     1101: 定时器 8 的 CC1 事件<br/>     1110: 定时器 8 的 TRGO 事件<br/>     1111: EINT 线 11</p>   |
| 29:28 | REGEXTTRGEN   | R/W | <p>使能规则通道的外部触发 (Enable the External Trigger for Regular Channels)</p> <p>00: 禁用触发检测<br/>     01: 上升沿上的触发检测</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

| 位/域 | 名称      | R/W | 描述                                                                                |
|-----|---------|-----|-----------------------------------------------------------------------------------|
|     |         |     | 10: 下降沿上的触发检测<br>11: 上升沿和下降沿上的触发检测                                                |
| 30  | REGSWSC | R/W | 软件启动转换规则通道 (Software Start Conversion Regular Channels)<br>0: 复位状态<br>1: 开始转换规则通道 |
| 31  |         |     | 保留                                                                                |

#### 28.6.4 ADC 采样时间寄存器 1 (ADC\_SMPTIM1)

偏移地址: 0x0C

复位值: 0x0000 0000

| 位/域   | 名称              | R/W | 描述                                                                                                                                                                 |
|-------|-----------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 26:0  | SMPCYCCFGx[2:0] | R/W | 配置通道 x 的采样周期 (Channel x Sample Cycles Configure)<br>000: 3 周期<br>001: 15 周期<br>010: 28 周期<br>011: 56 周期<br>100: 84 周期<br>101: 112 周期<br>110: 144 周期<br>111: 480 周期 |
| 31:27 |                 |     | 保留                                                                                                                                                                 |

#### 28.6.5 ADC 采样时间寄存器 2 (ADC\_SMPTIM2)

偏移地址: 0x10

复位值: 0x0000 0000

| 位/域   | 名称              | R/W | 描述                                                                                                                                                                 |
|-------|-----------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29:0  | SMPCYCCFGx[2:0] | R/W | 配置通道 x 的采样周期 (Channel x Sample Cycles Configure)<br>000: 3 周期<br>001: 15 周期<br>010: 28 周期<br>011: 56 周期<br>100: 84 周期<br>101: 112 周期<br>110: 144 周期<br>111: 480 周期 |
| 31:30 |                 |     | 保留                                                                                                                                                                 |

#### 28.6.6 ADC 注入通道数据偏移寄存器 x (ADC\_INJDOFx) (x=1...4)

偏移地址: 0x14-0x20

复位值: 0x0000 0000

| 位/域   | 名称      | R/W | 描述                                                                                                                  |
|-------|---------|-----|---------------------------------------------------------------------------------------------------------------------|
| 11:0  | INJDOFx | R/W | 注入通道 x 的数据偏移 (Data Offset For Injected Channel x)<br>当转换注入通道时, 这些位定义了用于从原始转换数据中减去的数值, 转换的结果可以在 ADC_INJDATAx 寄存器中读出。 |
| 31:12 |         |     | 保留                                                                                                                  |

### 28.6.7 模拟看门狗高阀值寄存器 (ADC\_AWDHT)

偏移地址: 0x24

复位值: 0x0000 0FFF

| 位/域   | 名称          | R/W | 描述                                        |
|-------|-------------|-----|-------------------------------------------|
| 11:0  | AWDHT[11:0] | R/W | 模拟看门狗高阀值 (Analog Watchdog High Threshold) |
| 31:12 |             |     | 保留                                        |

### 28.6.8 模拟看门狗低阀值寄存器 (ADC\_AWDLT)

偏移地址: 0x28

复位值: 0x0000 0000

| 位/域   | 名称          | R/W | 描述                                       |
|-------|-------------|-----|------------------------------------------|
| 11:0  | AWDLT[11:0] | R/W | 模拟看门狗低阀值 (Analog Watchdog Low Threshold) |
| 31:12 |             |     | 保留                                       |

### 28.6.9 ADC 规则序列寄存器 1 (ADC\_REGSEQ1)

偏移地址: 0x2C

复位值: 0x0000 0000

| 位/域   | 名称        | R/W | 描述                                                                                                                            |
|-------|-----------|-----|-------------------------------------------------------------------------------------------------------------------------------|
| 4:0   | REGSEQC13 | R/W | 规则序列中的第 13 个转换 (13 <sup>th</sup> Conversion In Regular Sequence)<br>定义规则序列中第 13 个转换的通道编号 (0~17)                               |
| 9:5   | REGSEQC14 | R/W | 规则序列中的第 14 个转换 (14 <sup>th</sup> Conversion In Regular Sequence)<br>参考 REGSEQC13 的描述                                          |
| 14:10 | REGSEQC15 | R/W | 规则序列中的第 15 个转换 (15 <sup>th</sup> Conversion In Regular Sequence)<br>参考 REGSEQC13 的描述                                          |
| 19:15 | REGSEQC16 | R/W | 规则序列中的第 16 个转换 (16 <sup>th</sup> Conversion In Regular Sequence)<br>参考 REGSEQC13 的描述                                          |
| 23:20 | REGSEQLEN | R/W | 规则通道序列长度 (Regular Channel Sequence Length)<br>这些位由软件定义在规则通道转换序列中的通道数目。<br>0000: 1 个转换<br>0001: 2 个转换<br>.....<br>1111: 16 个转换 |
| 31:24 |           |     | 保留                                                                                                                            |

### 28.6.10 ADC 规则序列寄存器 2 (ADC\_REGSEQ2)

偏移地址: 0x30

复位值: 0x0000 000

| 位/域   | 名称        | R/W | 描述                                                                                   |
|-------|-----------|-----|--------------------------------------------------------------------------------------|
| 4:0   | REGSEQC7  | R/W | 规则序列中的第 7 个转换 (7 <sup>th</sup> Conversion In Regular Sequence)<br>参考 REGSEQC13 的描述   |
| 9:5   | REGSEQC8  | R/W | 规则序列中的第 8 个转换 (82 <sup>th</sup> Conversion In Regular Sequence)<br>参考 REGSEQC13 的描述  |
| 14:10 | REGSEQC9  | R/W | 规则序列中的第 9 个转换 (9 <sup>th</sup> Conversion In Regular Sequence)<br>参考 REGSEQC13 的描述   |
| 19:15 | REGSEQC10 | R/W | 规则序列中的第 10 个转换 (10 <sup>th</sup> Conversion In Regular Sequence)<br>参考 REGSEQC13 的描述 |
| 24:20 | REGSEQC11 | R/W | 规则序列中的第 11 个转换 (11 <sup>th</sup> Conversion In Regular Sequence)<br>参考 REGSEQC13 的描述 |
| 29:25 | REGSEQC12 | R/W | 规则序列中的第 12 个转换 (12 <sup>th</sup> Conversion In Regular Sequence)<br>参考 REGSEQC13 的描述 |
| 31:30 |           |     | 保留                                                                                   |

### 28.6.11 ADC 规则序列寄存器 3 (ADC\_REGSEQ3)

偏移地址: 0x34

复位值: 0x0000 0000

| 位/域   | 名称       | R/W | 描述                                                                                 |
|-------|----------|-----|------------------------------------------------------------------------------------|
| 4:0   | REGSEQC1 | R/W | 规则序列中的第 1 个转换 (1 <sup>st</sup> Conversion In Regular Sequence)<br>参考 REGSEQC13 的描述 |
| 9:5   | REGSEQC2 | R/W | 规则序列中的第 2 个转换 (2 <sup>nd</sup> Conversion In Regular Sequence)<br>参考 REGSEQC13 的描述 |
| 14:10 | REGSEQC3 | R/W | 规则序列中的第 3 个转换 (3 <sup>rd</sup> Conversion In Regular Sequence)<br>参考 REGSEQC13 的描述 |
| 19:15 | REGSEQC4 | R/W | 规则序列中的第 4 个转换 (4 <sup>th</sup> Conversion In Regular Sequence)<br>参考 REGSEQC13 的描述 |
| 24:20 | REGSEQC5 | R/W | 规则序列中的第 5 个转换 (5 <sup>th</sup> Conversion In Regular Sequence)<br>参考 REGSEQC13 的描述 |
| 29:25 | REGSEQC6 | R/W | 规则序列中的第 6 个转换 (6 <sup>th</sup> Conversion In Regular Sequence)<br>参考 REGSEQC13 的描述 |
| 31:30 |          |     | 保留                                                                                 |

### 28.6.12 ADC 注入序列寄存器 (ADC\_INJSEQ)

偏移地址: 0x38

复位值: 0x0000 0000

| 位/域   | 名称       | R/W | 描述                                                                                            |
|-------|----------|-----|-----------------------------------------------------------------------------------------------|
| 4:0   | INJSEQC1 | R/W | 注入序列中的第 1 个转换 (1 <sup>st</sup> Conversion In Injected Sequence)<br>定义注入序列中第 1 个转换的通道编号 (0~17) |
| 9:5   | INJSEQC2 | R/W | 注入序列中的第 2 个转换 (2 <sup>nd</sup> Conversion In Injected Sequence)                               |
| 14:10 | INJSEQC3 | R/W | 注入序列中的第 3 个转换 (3 <sup>rd</sup> Conversion In Injected Sequence)                               |
| 19:15 | INJSEQC4 | R/W | 注入序列中的第 4 个转换 (4 <sup>th</sup> Conversion In Injected Sequence)                               |

| 位/域   | 名称        | R/W | 描述                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|-----------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 21:20 | INJSEQLEN | R/W | <p>注入通道序列长度 (Injected Channel Sequence Length)<br/>           这些位由软件定义在注入通道转换序列中的通道数目, 其转换序列是:<br/> <math>\text{INJSEQC}_{(4-\text{INJSEQLEN})} \rightarrow \text{INJSEQ}_{(5-\text{INJSEQLEN})} \rightarrow \text{INJSEQC}_{(6-\text{INJSEQLEN})}</math><br/> <math>\rightarrow \text{INJSEQC}_{(7-\text{INJSEQLEN})}</math>, 具体情况如下:</p> <p>00: 1 个转换, 只转换 INJSEQC4<br/>           01: 2 个转换, 转换顺序是 INJSEQC3 → INJSEQC4<br/>           10: 3 个转换, 转换序列是 INJSEQC2 → INJSEQC3 → INJSEQC4<br/>           11: 4 个转换, 转换序列是<br/> <math>\text{INJSEQC1} \rightarrow \text{INJSEQC2} \rightarrow \text{INJSEQC3} \rightarrow \text{INJSEQC4}</math></p> |
| 31:22 |           |     | 保留                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

#### 28.6.13 ADC 注入数据寄存器 x (ADC\_INJDATAx) (x=1...4)

偏移地址: 0x3C–0x48

复位值: 0x0000 0000

| 位/域   | 名称      | R/W | 描述                                                                      |
|-------|---------|-----|-------------------------------------------------------------------------|
| 15:0  | INJDATA | R   | <p>注入转换的数据 (Injected Conversion Data)<br/>           注入通道的转换结果, 只读。</p> |
| 31:16 |         |     | 保留                                                                      |

#### 28.6.14 ADC 规则数据寄存器 (ADC\_REGDATA)

偏移地址: 0x4C

复位值: 0x0000 0000

| 位/域   | 名称      | R/W | 描述                                                                     |
|-------|---------|-----|------------------------------------------------------------------------|
| 15:0  | REGDATA | R   | <p>规则转换的数据 (Regular Conversion Data)<br/>           规则通道的转换结果, 只读。</p> |
| 31:16 |         |     | 保留                                                                     |

#### 28.6.15 ADC 过采样控制寄存器 (ADC\_OSAMPCTRL)

偏移地址: 0x50

复位值: 0x0000 0000

| 位/域 | 名称   | R/W | 描述                                                                                                                                                                                          |
|-----|------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | OSEN | R/W | <p>过采样使能 (Oversampling Enable)<br/>           该位通过软件置位和清除。<br/>           0: 禁用<br/>           1: 使能<br/>           注意: 只有在 <math>\text{ADCEN}=0</math> 时, 才允许通过软件对该位进行写 (需确保没有转换正在执行)。</p> |

| 位/域  | 名称  | R/W | 描述                                                                                                                                                                                                                                                                              |
|------|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:1  | OSR | R/W | <p>过采样率 (Oversampling Rate)<br/>定义了过采样率的大小。</p> <p>000: 2x<br/>001: 4x<br/>010: 8x<br/>011: 16x<br/>100: 32x<br/>101: 64x<br/>110: 128x<br/>111: 256x</p> <p>注意: 只有在 <b>ADCEN =0</b> 时, 才允许通过软件对该位进行写 (需确保没有转换正在执行)。</p>                                                        |
| 7:4  | OSS | R/W | <p>过采样移位 (Oversampling Shift)<br/>该位通过软件置位和清除。</p> <p>0000: 不移位<br/>0001: 移 1 位<br/>0010: 移 2 位<br/>0011: 移 3 位<br/>0100: 移 4 位<br/>0101: 移 5 位<br/>0110: 移 6 位<br/>0111: 移 7 位<br/>1000: 移 8 位<br/>其余值: 保留。</p> <p>注意: 只有在 <b>ADCEN =0</b> 时, 才允许通过软件对该位进行写 (需确保没有转换正在执行)。</p> |
| 8    | TOS | R/W | <p>过采样触发 (Oversampling Trigger)<br/>该位通过软件置位和清除。</p> <p>0: 在一次触发后连续执行过采样通道的所有转换<br/>1: 对于过采样通道的每次转换都需要一次触发, 触发次数由过采样率 (OSR) 决定。</p> <p>注意: 只有在 <b>ADCEN =0</b> 时, 才允许通过软件对该位进行写 (需确保没有转换正在执行)。</p>                                                                              |
| 31:9 | 保留  |     |                                                                                                                                                                                                                                                                                 |

### 28.6.16 ADC 通用状态寄存器 (ADC\_CSTS)

偏移地址: 0x00 (该偏移地址只与 ADC1 基地址+0x300 相关)

复位值: 0x0000 0000

| 位/域 | 名称      | R/W | 描述                                            |
|-----|---------|-----|-----------------------------------------------|
| 0   | AWDFLG1 | R   | ADC1 的模拟看门狗标志 (Analog Watchdog Flag of ADC1)  |
| 1   | EOCFLG1 | R   | ADC1 的转换结束标志 (End of Conversion Flag of ADC1) |

| 位/域   | 名称         | R/W | 描述                                                                 |
|-------|------------|-----|--------------------------------------------------------------------|
| 2     | INJEOCFLG1 | R   | ADC1 的注入通道转换结束标志 (Injected Channel End of Conversion Flag of ADC1) |
| 3     | INJCSFLG1  | R   | ADC1 的注入通道开始标志 (Injected Channel Start Flag of ADC1)               |
| 4     | REGCSFLG1  | R   | ADC1 的规则通道开始标志 (Regular Channel Start Flag of ADC1)                |
| 5     | OVRFLG1    | R   | ADC1 的溢出标志 (Overrun Flag of ADC1)                                  |
| 7:6   |            |     | 保留                                                                 |
| 8     | AWDFLG2    | R   | ADC2 的模拟看门狗标志 (Analog Watchdog Flag of ADC2)                       |
| 9     | EOCFLG2    | R   | ADC2 的转换结束标志 (End of Conversion Flag of ADC2)                      |
| 10    | INJEOCFLG2 | R   | ADC2 的注入通道转换结束标志 (Injected Channel End of Conversion Flag of ADC2) |
| 11    | INJCSFLG2  | R   | ADC2 的注入通道开始标志 (Injected Channel Start Flag of ADC2)               |
| 12    | REGCSFLG2  | R   | ADC2 的规则通道开始标志 (Regular Channel Start Flag of ADC2)                |
| 13    | OVRFLG2    | R   | ADC2 的溢出标志 (Overrun Flag of ADC2)                                  |
| 15:14 |            |     | 保留                                                                 |
| 16    | AWDFLG3    | R   | ADC3 的模拟看门狗标志 (Analog Watchdog Flag of ADC3)                       |
| 17    | EOCFLG3    | R   | ADC3 的转换结束标志 (End of Conversion Flag of ADC3)                      |
| 18    | INJEOCFLG3 | R   | ADC3 的注入通道转换结束标志 (Injected Channel End of Conversion Flag of ADC3) |
| 19    | INJCSFLG3  | R   | ADC3 的注入通道开始标志 (Injected Channel Start Flag of ADC3)               |
| 20    | REGCSFLG3  | R   | ADC3 的规则通道开始标志 (Regular Channel Start Flag of ADC3)                |
| 21    | OVRFLG3    | R   | ADC3 的溢出标志 (Overrun Flag of ADC3)                                  |
| 31:22 |            |     | 保留                                                                 |

### 28.6.17 ADC 通用控制寄存器 (ADC\_CCTRL)

偏移地址: 0x04 (该偏移地址只与 ADC1 基地址+0x300 相关)

复位值: 0x0000 0000

| 位/域   | 名称        | R/W | 描述                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------|-----------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4:0   | ADCMSEL   | R/W | <p>选择 ADC 模式 (ADC Mode Selection)<br/>所有 ADC 都独立。</p> <p>00000: 独立模式<br/>双重模式: ADC1 和 ADC2 一起工作, ADC3 独立</p> <p>00001: 规则同时+注入同时组合模式<br/>00010: 规则同时+交替触发组合模式<br/>00011: 保留<br/>00101: 仅注入同时模式<br/>00110: 仅规则同时模式<br/>00111: 仅交替模式<br/>01001: 仅交替触发模式</p> <p>三重模式: ADC1、ADC2 和 ADC3 一起工作</p> <p>10001: 规则同时+注入同时组合模式<br/>10010: 规则同时+交替触发组合模式<br/>10011: 保留<br/>10101: 仅注入同时模式<br/>10110: 仅规则同时模式<br/>10111: 仅交替模式<br/>11001: 仅交替触发模式</p> |
| 7:5   |           |     | 保留                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 11:8  | SMPDEL2   | R/W | <p>2 个采样阶段之间的延迟 (Delay Between 2 Sampling Phases)<br/>这些位在双重或三重交错模式下使用。</p> <p>0000: <math>5^*T_{ADCCLK}</math><br/>0001: <math>6^*T_{ADCCLK}</math><br/>0010: <math>7^*T_{ADCCLK}</math><br/>...<br/>1111: <math>20^*T_{ADCCLK}</math></p>                                                                                                                                                                                               |
| 12    |           |     | 保留                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 13    | DMADISSEL | R/W | <p>DMA 禁止选择 (DMA Disable Selection)</p> <p>0: 最后一次传输后不发出新的 DMA 请求<br/>1: 只要数据发生转换且 DMAMODE=01、10 或 11, 便会发出 DMA 请求</p>                                                                                                                                                                                                                                                                                                                    |
| 15:14 | DMAMODE   | R/W | <p>DMA 模式 (DMA Mode)</p> <p>00: 禁用 DMA 模式<br/>01: 使能 DMA 模式 1<br/>10: 使能 DMA 模式 2<br/>11: 使能 DMA 模式 3</p>                                                                                                                                                                                                                                                                                                                                 |
| 17:16 | ADCPRE    | R/W | <p>ADC 预分频器 (ADC Prescaler)</p> <p>00: PCLK2 2 分频<br/>01: PCLK2 4 分频<br/>10: PCLK2 6 分频<br/>11: PCLK2 8 分频</p>                                                                                                                                                                                                                                                                                                                            |
| 21:18 |           |     | 保留                                                                                                                                                                                                                                                                                                                                                                                                                                        |

| 位/域   | 名称       | R/W | 描述                                                                                   |
|-------|----------|-----|--------------------------------------------------------------------------------------|
| 22    | VBATEN   | R/W | 使能 $V_{BAT}$ ( $V_{BAT}$ Enable)<br>0: 禁用<br>1: 使能                                   |
| 23    | TSVREFEN | R/W | 使能温度传感器和 $V_{REFINT}$ (Temperature Sensor And $V_{REFINT}$ Enable)<br>0: 禁用<br>1: 使能 |
| 31:24 | 保留       |     |                                                                                      |

### 28.6.18 适用于双重和三重模式的 ADC 通用规则数据寄存器 (ADC\_CDATA)

偏移地址: 0x08 (该偏移地址只与 ADC1 基地址+0x300 相关)

复位值: 0x0000 0000

| 位/域   | 名称    | R/W | 描述                                                                                                                                    |
|-------|-------|-----|---------------------------------------------------------------------------------------------------------------------------------------|
| 15:0  | DATA1 | R   | 规则转换对中的第一个数据项 (1 <sup>st</sup> Data of Regular Conversion Pair)<br>在双重模式下, 这些位包含 ADC1 的规则数据。<br>在三重模式下, 这些位包含 ADC1、ADC3 和 ADC2 的规则数据。 |
| 31:16 | DATA2 | R   | 规则转换对中的第二个数据项 (2 <sup>nd</sup> Data of Regular Conversion Pair)<br>在双重模式下, 这些位包含 ADC2 的规则数据。<br>在三重模式下, 这些位包含 ADC1、ADC3 和 ADC2 的规则数据。 |

## 29 数模转换器 (DAC)

### 29.1 术语全称、缩写描述

表格 150 DAC 术语全称、缩写描述

| 中文全称      | 英文全称                           | 英文缩写 |
|-----------|--------------------------------|------|
| 线性反馈移位寄存器 | Linear Feedback Shift Register | LFSR |

### 29.2 简介

DAC 是一个可配置为输入 8 位或 12 位数据，输出电压的数字/模拟转换器，在输入 12 位数据时，可以将数据设置为左对齐或右对齐。具有两路 DAC 输出通道，两路通道互不影响；每路通道有多个触发源可触发转换，可单路触发转换输出，也可以两路同时触发转换输出。两路通道都可独立生成噪声波形和三角波形。

### 29.3 结构框图

图 121 DAC 结构框图



### 29.4 功能描述

#### 29.4.1 DAC 转换及触发源

DAC 的输出是通过对 `DAC_DATAOCHx` 寄存器中的数据进行计算得到相应电压值，但是无法对 `DAC_DATAOCHx` 寄存器直接写入数据，需要写入 `DAC_DHx` 寄存器之后通过相应的触发从而使 `DAC_DHx` 中的数据加载到 `DAC_DATAOCHx` 中。

当关闭通道触发时（寄存器 `DAC_CTRL` 中的 `TRGENCHx` 位置 0），写入 `DAC_DHx` 寄存器中的值会在一个 APB1 时钟周期后，自动传入

DAC\_DATAOCHx 中。

当打开通道触发时（寄存器 DAC\_CTRL 中的 TRGENCHx 位置 1），写入 DAC\_DHx 寄存器中的值会根据选择的触发源不同，而经过不同的时钟周期后传入 DAC\_DATAOCHx 中。可供选择的触发源有三类：

- 定时器的更新事件
- 外部中断触发
- 软件触发

当选择定时器的更新事件和外部中断作为触发源时，会经过三个 APB1 时钟周期后完成传输；当选择软件触发时，经过一个 APB1 时钟周期便完成传输。

当数据传输到 DAC\_DATAOCHx 寄存器中时，经过一段时间之后，数字量便被线性的转换成为模拟电压输出。中间的转换时间会根据电源电压和模拟输出负载的不同而不同。

#### 29.4.2 DAC 参考电压及输出

DAC 使用 V<sub>REF</sub> 作为参考电压，将 V<sub>SSA</sub> 接地，可得到 DAC 的输出电压范围为：0-V<sub>REF</sub>。

DAC 输出计算公式为：DAC 输出 = V<sub>REF</sub> \* (DATAOCHx/4095)。

#### 29.4.3 DAC 数据格式

##### 单通道 DAC

三种模式下对应写入的寄存器分别如下：

- 8 位数据右对齐：DAC\_DH8Rx[7:0]
- 12 位数据左对齐：DAC\_DH12Lx[15:4]
- 12 位数据右对齐：DAC\_DH12Rx[11:0]

##### 双通道 DAC

三种模式下对应写入的寄存器分别如下：

- 8 位数据右对齐：DAC\_DH8RD[15:0]
- 12 位数据左对齐：DAC\_DH12LDUAL[15:4]、  
DAC\_DH12LDUAL[31:20]
- 12 位数据右对齐：DAC\_DH12RDUAL[11:0]、  
DAC\_DH12RDUAL[27:16]

#### 29.4.4 DAC 波形生成

DAC 每个通道都可以单独生成噪声和三角波。

#### 29.4.5 DAC 双通道转换

当两路通道同时工作时，为了有效的利用总线带宽，写入的数据可以写入到共用寄存器：DH8RDUAL、DH12RDUAL 和 DH12LDUAL。

对于双通道转换，可以分为独立转换和同步转换两大类，具体配置及描述如下。

#### 29.4.5.1 独立触发

##### 禁用波形发生器

- (1) 使能两个通道的触发模式；
- (2) 配置两个通道使用不同的触发源。

##### 使用相同 LFSR

- (1) 使能两个通道的触发模式；
- (2) 配置两个通道使用不同的触发源；
- (3) 使能两个通道的噪声生成功能，设置相同的 LFSR 屏蔽值。

##### 使用不同 LFSR

- (1) 使能两个通道的触发模式；
- (2) 配置两个通道使用不同的触发源；
- (3) 使能两个通道的噪声生成功能，设置不同的 LFSR 屏蔽值。

##### 产生相同三角波

- (1) 使能两个通道的触发模式；
- (2) 配置两个通道使用不同的触发源；
- (3) 使能两个通道的三角波生成功能，设置相同的三角波幅值。

##### 产生不同三角波

- (1) 使能两个通道的触发模式；
- (2) 配置两个通道使用不同的触发源；
- (3) 使能两个通道的三角波生成功能，设置不同的三角波幅值。

#### 29.4.5.2 同步触发

##### 同步软件启动

使能两个通道的触发模式，写入数据后等待一个 APB1 时钟周期之后分别同时传入 DAC\_DATAOCH1 和 DAC\_DATAOCH2 寄存器。

##### 禁用波形发生器

- (1) 使能两个通道的触发模式；
- (2) 配置两个通道使用相同的触发源。

### 使用相同 LFSR

- (1) 使能两个通道的触发模式;
- (2) 配置两个通道使用相同的触发源;
- (3) 使能两个通道的噪声生成功能, 设置相同的 LFSR 屏蔽值。

### 使用不同 LFSR

- (1) 使能两个通道的触发模式;
- (2) 配置两个通道使用相同的触发源;
- (3) 使能两个通道的噪声生成功能, 设置不同的 LFSR 屏蔽值。

### 产生相同三角波

- (1) 使能两个通道的触发模式;
- (2) 配置两个通道使用相同的触发源;
- (3) 使能两个通道的三角波生成功能, 设置相同的三角波幅值。

### 使用不同三角波

- (1) 使能两个通道的触发模式;
- (2) 配置两个通道使用相同的触发源;
- (3) 使能两个通道的三角波生成功能, 设置不同的三角波幅值。

## 29.5 寄存器地址映射

表格 151 DAC 寄存器地址映射

| 寄存器名          | 描述                        | 偏移地址 |
|---------------|---------------------------|------|
| DAC_CTRL      | DAC 控制寄存器                 | 0x00 |
| DAC_SWTRG     | DAC 软件触发寄存器               | 0x04 |
| DAC_DH12R1    | DAC 通道 1 的 12 位右对齐数据保持寄存器 | 0x08 |
| DAC_DH12L1    | DAC 通道 1 的 12 位左对齐数据保持寄存器 | 0x0C |
| DAC_DH8R1     | DAC 通道 1 的 8 位右对齐数据保持寄存器  | 0x10 |
| DAC_DH12R2    | DAC 通道 2 的 12 位右对齐数据保持寄存器 | 0x14 |
| DAC_DH12L2    | DAC 通道 2 的 12 位左对齐数据保持寄存器 | 0x18 |
| DAC_DH8R2     | DAC 通道 2 的 8 位右对齐数据保持寄存器  | 0x1C |
| DAC_DH12RDUAL | 双 DAC 的 12 位右对齐数据保持寄存器    | 0x20 |
| DAC_DH12LDUAL | 双 DAC 的 12 位左对齐数据保持寄存器    | 0x24 |

| 寄存器名         | 描述                    | 偏移地址 |
|--------------|-----------------------|------|
| DAC_DH8RDUAL | 双 DAC 的 8 位右对齐数据保持寄存器 | 0x28 |
| DAC_DATAOCH1 | DAC 通道 1 数据输出寄存器      | 0x2C |
| DAC_DATAOCH2 | DAC 通道 2 数据输出寄存器      | 0x30 |
| DAC_STS      | DAC 状态寄存器             | 0x34 |

## 29.6 寄存器功能描述

### 29.6.1 DAC 控制寄存器 (DAC\_CTRL)

偏移地址: 0x00

复位值: 0x0000 0000

| 位/域  | 名称         | R/W | 描述                                                                                                                                                                                                                                                                                                                    |
|------|------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | ENCH1      | R/W | 使能 DAC 通道 1 (DAC Channel1 Enable)<br>0: 禁用<br>1: 使能                                                                                                                                                                                                                                                                   |
| 1    | BUFFDCH1   | R/W | 禁止 DAC 通道 1 输出缓存 (DAC Channel1 Output Buffer Disable)<br>0: 使能<br>1: 禁止                                                                                                                                                                                                                                               |
| 2    | TRGENCH1   | R/W | 使能 DAC 通道 1 触发 (DAC Channel1 Trigger Enable)<br>0: 禁用<br>1: 使能                                                                                                                                                                                                                                                        |
| 5:3  | TRGSELCH1  | R/W | 选择 DAC 通道 1 触发源 (DAC Channel1 Trigger Source Select)<br>在通道 1 触发使能 (TRGENCH1=1) 的情况下, 可通过该寄存器选择触发源。<br>000: TMR6 TRGO 事件<br>001: TMR8 TRGO 事件<br>010: TMR7 TRGO 事件<br>011: TMR5 TRGO 事件<br>100: TMR2TRGO 事件<br>101: TMR4 TRGO 事件<br>110: 外部中断线 9<br>111: 软件触发                                                         |
| 7:6  | WAVENCH1   | R/W | 使能 DAC 通道 1 产成噪声/三角波 (DAC Channel1 Noise/Triangle Wave Generation Enable)<br>00: 不产生波形<br>01: 产生噪声波形<br>1x: 产生三角波波形                                                                                                                                                                                                   |
| 11:8 | MAMPSELCH1 | R/W | 选择 DAC 通道 1 屏蔽的 LFSR 位/三角波幅值 (Select DAC Channel1 LFSR Bit Mask/Triangle Wave Amplitude Selector)<br>在“产生 LFSR 噪声”模式下, 通过该位选择屏蔽 LFSR 的位;<br>在“产生三角波”模式下通过该位选择三角波的幅值。<br>0000: 不屏蔽 LFSR 位 0/ 三角波幅值等于 1<br>0001: 不屏蔽 LFSR 位[1:0] / 三角波幅值等于 3<br>0010: 不屏蔽 LFSR 位[2:0] / 三角波幅值等于 7<br>0011: 不屏蔽 LFSR 位[3:0] / 三角波幅值等于 15 |

| 位/域   | 名称         | R/W | 描述                                                                                                                                                                                                                                                                                                                       |
|-------|------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |            |     | 0100: 不屏蔽 LFSR 位[4:0] / 三角波幅值等于 31<br>0101: 不屏蔽 LFSR 位[5:0] / 三角波幅值等于 63<br>0110: 不屏蔽 LFSR 位[6:0] / 三角波幅值等于 127<br>0111: 不屏蔽 LFSR 位[7:0] / 三角波幅值等于 255<br>1000: 不屏蔽 LFSR 位[8:0] / 三角波幅值等于 511<br>1001: 不屏蔽 LFSR 位[9:0] / 三角波幅值等于 1023<br>1010: 不屏蔽 LFSR 位[10:0] / 三角波幅值等于 2047<br>≥1011: 不屏蔽 LFSR 位[11:0] / 三角波幅值等于 4095 |
| 12    | DMAENCH1   | R/W | 使能 DAC 通道 1 DMA (DAC Channel1 DMA Enable)<br>0: 禁用<br>1: 使能                                                                                                                                                                                                                                                              |
| 13    | DMAUDIEN1  | R/W | 使能 DAC 通道 1 DMA 下溢中断 (DAC Channel1 DMA Underrun Interrupt Enable)<br>0: 禁用<br>1: 使能                                                                                                                                                                                                                                      |
| 15:14 |            |     | 保留                                                                                                                                                                                                                                                                                                                       |
| 16    | ENCH2      | R/W | 使能 DAC 通道 2 (DAC Channel2 Enable)<br>0: 禁用<br>1: 使能                                                                                                                                                                                                                                                                      |
| 17    | BUFFDCH2   | R/W | 禁止 DAC 通道 2 输出缓存 (DAC Channel2 Output Buffer Disable)<br>0: 使能<br>1: 禁止                                                                                                                                                                                                                                                  |
| 18    | TRGENCH2   | R/W | 使能 DAC 通道 2 触发 (DAC Channel2 Trigger Enable)<br>0: 禁用<br>1: 使能                                                                                                                                                                                                                                                           |
| 21:19 | TRGSELCH2  | R/W | 选择 DAC 通道 2 触发源 (DAC Channel2 Trigger Source Select)<br>在通道 2 触发使能 (TRGENCH2=1) 的情况下, 可通过该寄存器选择触发源。<br>000: TMR6 TRGO 事件<br>001: TMR8 TRGO 事件<br>010: TMR7 TRGO 事件<br>011: TMR5 TRGO 事件<br>100: TMR2TRGO 事件<br>101: TMR4 TRGO 事件<br>110: 外部中断线 9<br>111: 软件触发                                                            |
| 23:22 | WAVENCH2   | R/W | 使能 DAC 通道 2 噪声/三角波生成 (DAC Channel2 Noise/Triangle Wave Generation Enable)<br>00: 不产生波形<br>01: 产生噪声波形<br>1x: 产生三角波波形                                                                                                                                                                                                      |
| 27:24 | MAMPSELCH2 | R/W | 选择 DAC 通道 2 屏蔽的 LFSR 位/三角波幅值 (Select DAC Channel2 LFSR Bit Mask/Triangle Wave Amplitude Selector)<br>在“产生 LFSR 噪声”模式下, 通过该位选择屏蔽 LFSR 的位;<br>在“产生三角波”模式下通过该位选择三角波的幅值。<br>0000: 不屏蔽 LFSR 位 0/ 三角波幅值等于 1                                                                                                                    |

| 位/域   | 名称        | R/W | 描述                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------|-----------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |           |     | 0001: 不屏蔽 LFSR 位[1:0] / 三角波幅值等于 3<br>0010: 不屏蔽 LFSR 位[2:0] / 三角波幅值等于 7<br>0011: 不屏蔽 LFSR 位[3:0] / 三角波幅值等于 15<br>0100: 不屏蔽 LFSR 位[4:0] / 三角波幅值等于 31<br>0101: 不屏蔽 LFSR 位[5:0] / 三角波幅值等于 63<br>0110: 不屏蔽 LFSR 位[6:0] / 三角波幅值等于 127<br>0111: 不屏蔽 LFSR 位[7:0] / 三角波幅值等于 255<br>1000: 不屏蔽 LFSR 位[8:0] / 三角波幅值等于 511<br>1001: 不屏蔽 LFSR 位[9:0] / 三角波幅值等于 1023<br>1010: 不屏蔽 LFSR 位[10:0] / 三角波幅值等于 2047<br>≥1011: 不屏蔽 LFSR 位[11:0] / 三角波幅值等于 4095 |
| 28    | DMAENCH2  | R/W | 使能 DAC 通道 2 DMA (DAC Channel2 DMA Enable)<br>0: 禁用<br>1: 使能                                                                                                                                                                                                                                                                                                                                                                              |
| 29    | DMAUDIEN2 | R/W | 使能 DAC 通道 2 DMA 下溢中断 (DAC Channel2 DMA Underrun Interrupt Enable)<br>0: 禁用<br>1: 使能                                                                                                                                                                                                                                                                                                                                                      |
| 31:30 |           |     | 保留                                                                                                                                                                                                                                                                                                                                                                                                                                       |

### 29.6.2 DAC 软件触发寄存器 (DAC\_SWTRG)

偏移地址: 0x04

复位值: 0x0000 0000

| 位/域  | 名称     | R/W | 描述                                                                                                                                       |
|------|--------|-----|------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | SWTRG1 | W   | 使能 DAC 通道 1 软件触发 (DAC Channel1 Software Trigger Enable)<br>该位可由软件置 1、清 0；一旦寄存器 DAC_DH1 的数据传入寄存器 DAC_DATAOCH1，该位由硬件清 0。<br>0: 禁用<br>1: 使能 |
| 1    | SWTRG2 | W   | 使能 DAC 通道 2 软件触发 (DAC Channel2 Software Trigger Enable)<br>该位可由软件置 1、清 0；一旦寄存器 DAC_DH2 的数据传入寄存器 DAC_DATAOCH2，该位由硬件清 0。<br>0: 禁用<br>1: 使能 |
| 31:2 |        |     | 保留                                                                                                                                       |

### 29.6.3 DAC 通道 1 的 12 位右对齐数据保持寄存器 (DAC\_DH12R1)

偏移地址: 0x08

复位值: 0x0000 0000

| 位/域   | 名称   | R/W | 描述                                                                                             |
|-------|------|-----|------------------------------------------------------------------------------------------------|
| 11:0  | DATA | R/W | DAC 通道 1 的 12 位右对齐数据 (DAC Channel1 12-Bit Right-Aligned Data)<br>该位由软件写入，表示 12 位 DAC 通道 1 的数据。 |
| 31:12 |      |     | 保留                                                                                             |

#### 29.6.4 DAC 通道 1 的 12 位左对齐数据保持寄存器 (DAC\_DH12L1)

偏移地址: 0x0C

复位值: 0x0000 0000

| 位/域   | 名称   | R/W | 描述                                                           |
|-------|------|-----|--------------------------------------------------------------|
| 3:0   |      |     | 保留                                                           |
| 15:4  | DATA | R/W | DAC 通道 1 的 12 位左对齐数据 (DAC Channel1 12-Bit Left-Aligned Data) |
| 31:16 |      |     | 保留                                                           |

#### 29.6.5 DAC 通道 1 的 8 位右对齐数据保持寄存器 (DAC\_DH8R1)

偏移地址: 0x10

复位值: 0x0000 0000

| 位/域  | 名称   | R/W | 描述                                                          |
|------|------|-----|-------------------------------------------------------------|
| 7:0  | DATA | R/W | DAC 通道 1 的 8 位右对齐数据 (DAC Channel1 8-bit Right-Aligned Data) |
| 31:8 |      |     | 保留                                                          |

#### 29.6.6 DAC 通道 2 的 12 位右对齐数据保持寄存器 (DAC\_DH12R2)

偏移地址: 0x14

复位值: 0x0000 0000

| 位/域   | 名称   | R/W | 描述                                                            |
|-------|------|-----|---------------------------------------------------------------|
| 11:0  | DATA | R/W | DAC 通道 2 的 12 位右对齐数据 (DAC Channel2 12-bit Right-Aligned Data) |
| 31:12 |      |     | 保留                                                            |

#### 29.6.7 DAC 通道 2 的 12 位左对齐数据保持寄存器 (DAC\_DH12L2)

偏移地址: 0x18

复位值: 0x0000 0000

| 位/域   | 名称   | R/W | 描述                                                           |
|-------|------|-----|--------------------------------------------------------------|
| 3:0   |      |     | 保留                                                           |
| 15:4  | DATA | R/W | DAC 通道 2 的 12 位左对齐数据 (DAC Channel2 12-Bit Left-Aligned Data) |
| 31:16 |      |     | 保留                                                           |

#### 29.6.8 DAC 通道 2 的 8 位右对齐数据保持寄存器 (DAC\_DH8R2)

偏移地址: 0x1C

复位值: 0x0000 0000

| 位/域  | 名称   | R/W | 描述                                                          |
|------|------|-----|-------------------------------------------------------------|
| 7:0  | DATA | R/W | DAC 通道 2 的 8 位右对齐数据 (DAC Channel2 8-bit Right-Aligned Data) |
| 31:8 |      |     | 保留                                                          |

#### 29.6.9 双 DAC 的 12 位右对齐数据保持寄存器 (DAC\_DH12RDUAL)

偏移地址: 0x20

复位值: 0x0000 0000

| 位/域   | 名称      | R/W | 描述                                                            |
|-------|---------|-----|---------------------------------------------------------------|
| 11:0  | DATACH1 | R/W | DAC 通道 1 的 12 位右对齐数据 (DAC Channel1 12-Bit Right-Aligned Data) |
| 15:12 | 保留      |     |                                                               |
| 27:16 | DATACH2 | R/W | DAC 通道 2 的 12 位右对齐数据 (DAC Channel2 12-Bit Right-Aligned Data) |
| 31:28 | 保留      |     |                                                               |

#### 29.6.10 双 DAC 的 12 位左对齐数据保持寄存器 (DAC\_DH12LDUAL)

偏移地址: 0x24

复位值: 0x0000 0000

| 位/域   | 名称      | R/W | 描述                                                           |
|-------|---------|-----|--------------------------------------------------------------|
| 3:0   | 保留      |     |                                                              |
| 15:4  | DATACH1 | R/W | DAC 通道 1 的 12 位左对齐数据 (DAC Channel1 12-Bit Left-Aligned Data) |
| 19:16 | 保留      |     |                                                              |
| 31:20 | DATACH2 | R/W | DAC 通道 2 的 12 位左对齐数据 (DAC Channel2 12-Bit Left-Aligned Data) |

#### 29.6.11 双 DAC 的 8 位右对齐数据保持寄存器 (DAC\_DH8RDUAL)

偏移地址: 0x28

复位值: 0x0000 0000

| 位/域   | 名称      | R/W | 描述                                                          |
|-------|---------|-----|-------------------------------------------------------------|
| 7:0   | DATACH1 | R/W | DAC 通道 1 的 8 位右对齐数据 (DAC Channel1 8-Bit Right-Aligned Data) |
| 15:8  | DATACH2 | R/W | DAC 通道 2 的 8 位右对齐数据 (DAC Channel2 8-Bit Right-Aligned Data) |
| 31:16 | 保留      |     |                                                             |

#### 29.6.12 DAC 通道 1 数据输出寄存器 (DAC\_DATAOCH1)

偏移地址: 0x2C

复位值: 0x0000 0000

| 位/域   | 名称   | R/W | 描述                                       |
|-------|------|-----|------------------------------------------|
| 11:0  | DATA | R   | DAC 通道 1 输出数据 (DAC Channel1 Data Output) |
| 31:12 | 保留   |     |                                          |

#### 29.6.13 DAC 通道 2 数据输出寄存器 (DAC\_DATAOCH2)

偏移地址: 0x30

复位值: 0x0000 0000

| 位/域   | 名称   | R/W | 描述                                       |
|-------|------|-----|------------------------------------------|
| 11:0  | DATA | R   | DAC 通道 2 输出数据 (DAC Channel2 Data Output) |
| 31:12 | 保留   |     |                                          |

#### 29.6.14 DAC 状态寄存器 (DAC\_STS)

偏移地址: 0x34

复位值: 0x0000 0000

| 位/域   | 名称        | R/W   | 描述                                                                   |
|-------|-----------|-------|----------------------------------------------------------------------|
| 12:0  | 保留        |       |                                                                      |
| 13    | DMAUDFLG1 | RC_W1 | DAC 通道 1DMA 下溢标志 (DAC Channel1 DMA Underrun Flag)<br>0: 未发生<br>1: 发生 |
| 28:14 | 保留        |       |                                                                      |
| 29    | DMAUDFLG2 | RC_W1 | DAC 通道 2DMA 下溢标志 (DAC Channel2 DMA Underrun Flag)<br>0: 未发生<br>1: 发生 |
| 31:30 | 保留        |       |                                                                      |

## 30 随机数生成器 (RNG)

### 30.1 简介

RNG 是一个随机数发生器，以连续模拟噪声为基础，在主机读数为其提供一个 32 位的随机数。

### 30.2 主要特征

- (1) 提供由模拟发生器产生的 32 位随机数
- (2) 两个相连的随机数之间的间隔为 40 个 PLLCLK48 时钟信号周期
- (3) 监控 RNG 熵来标记异常行为
- (4) 禁止 RNG 可以降低功耗

### 30.3 功能描述

随机数发生器由模拟电路实现。这个电路为线性反馈移位寄存器生成 32 位随机数提供种子。

多个环形振荡器组成模拟电路，种子通过振荡器输出的频率进行异或运算而产生。PLLCLK48 为 RNG\_LFSR 的专用时钟，按恒定频率为其提供时钟信息，所以随机数的质量与 HCLK 的频率没有关系。当 RNG\_LFSR 引入大量种子后，其内容转移到 RNG\_DATA 寄存器。同时，系统会监视种子和 PLLCLK48。

RNG\_STS 寄存器中的状态位表明在种子上出现异常序列或 PLLCLK48 时钟频率过低的时间。检测到错误时生成中断。

#### 30.3.1 使能 RNG

使能 RNG 的设置顺序如下：

- (1) 使能中断，在随机数准备好或出现错误时产生中断。
- (2) 当 RNG\_CTRL[RNGEN]=1 时产生随机数。这时激活模拟部分、RNG\_LFSR 和错误检测器。
- (3) 每次中断时，当 RNG\_STS 寄存器的 CLKERINT 位和 FSINT 设置为 0 且 DATARDY=1 时，可以对 RNG\_DATA 寄存器进行读操作。

不使用设置 RNGEN 位后产生的第一个随机数，应保存起来与下一个随机数比较。每个随机数都需要与上一个随机数比较，如果任何一对相等，连续随机数发生器测试失败。

### 30.3.2 错误状态

#### 30.3.2.1 时钟错误

因为 PLLCLK48 时钟不正确而出现时钟错误时, RNG 无法再产生随机数。检查是否正确配置时钟控制器以提供 RNG 时钟和清除 CLKERINT 位。当 CLKERCSTS=0 时, RNG 正常工作。时钟错误不影响上一个随机数, 所以可以使用 RNG\_DATA 寄存器中的随机数。

#### 30.3.2.2 种子错误

出现种子错误时, 只要 FSCSTS=1 就会产生中断随机数。由于熵可能不够, 在 RNG\_DATA 寄存器中已有数据时不能使用产生的中断随机数。

应清除 FSINT 位并清除后设置 RNGEN 位, 以便重新初始化和重启 RNG。

## 30.4 寄存器地址映射

表格 152 RNG 寄存器地址映射

| 寄存器名     | 描述        | 偏移地址 |
|----------|-----------|------|
| RNG_CTRL | RNG 控制寄存器 | 0x00 |
| RNG_STS  | RNG 状态寄存器 | 0x04 |
| RNG_DATA | RNG 数据寄存器 | 0x08 |

## 30.5 寄存器功能描述

### 30.5.1 RNG 控制寄存器 (RNG\_CTRL)

偏移地址: 0x00

复位值: 0x0000 0000

| 位/域  | 名称    | R/W | 描述                                                                                                        |
|------|-------|-----|-----------------------------------------------------------------------------------------------------------|
| 1:0  |       |     | 保留                                                                                                        |
| 2    | RNGEN | R/W | 使能 RNG (RNG Enable)<br>0: 禁用<br>1: 使能                                                                     |
| 3    | INTEN | R/W | 使能中断 (Interrupt Enable)<br>0: 禁用<br>1: 使能, 当 RNG_STS 寄存器中的 DATARDY 位、CLKERINT 位和 FSINT 位中任意一位置 1 时, 中断挂起。 |
| 31:4 |       |     | 保留                                                                                                        |

### 30.5.2 RNG 状态寄存器 (RNG\_STS)

偏移地址: 0x04

复位值: 0x0000 0000

| 位/域  | 名称        | R/W   | 描述                                                                                                                                                                    |
|------|-----------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | DATARDY   | R     | <p>数据准备 (Data Ready)</p> <p>0: RNG_DATA 寄存器未准备就绪, 随机数据不可用</p> <p>1: RNG_DATA 寄存器已准备就绪, 随机数据可用</p> <p>当 INTEN=1 时, 中断挂起。对 RNG_DATA 寄存器进行读操作后此位清零, 直到算出新的有效值。</p>       |
| 1    | CLKERCSTS | R     | <p>RNG 时钟错误纠正状态 (RNGCLK Error Current Status)</p> <p>0: 检测到 PLLCLK48 时钟。如果 CLKERINT 位置 1, 表明检测到时钟错误并已恢复正常。</p> <p>1: 未检测到 PLLCLK48 时钟</p>                             |
| 2    | FSCSTS    | R     | <p>错误序列纠正状态 (Faulty Sequence Current Status)</p> <p>0: 未检测到序列错误。如果 FSINT 位置 1, 表明检测到错误序列并已恢复正常。</p> <p>1: 检测到 64 个以上的 0/1 或 32 个以上的交替的 0 和 1</p>                      |
| 4:3  | 保留        |       |                                                                                                                                                                       |
| 5    | CLKERINT  | RC_W0 | <p>RNG 时钟错误中断状态 (RNGCLK Error Interrupt Status)</p> <p>0: 检测到 PLLCLK48 时钟</p> <p>1: 未检测到 PLLCLK48 时钟</p> <p>此位与 CLKERCSTS 位同时设置, 写 0 清除。当 INTEN=1 时, 中断挂起。</p>        |
| 6    | FSINT     | RC_W0 | <p>错误序列中断状态 (Faulty Sequence Interrupt Status)</p> <p>0: 未检测到错误序列</p> <p>1: 检测到 64 个以上的 0/1 或 32 个以上的交替的 0 和 1</p> <p>此位与 FSCSTS 位同时设置, 写 0 清除。当 INTEN=1 时, 中断挂起。</p> |
| 31:7 | 保留        |       |                                                                                                                                                                       |

### 30.5.3 RNG 数据寄存器 (RNG\_DATA)

偏移地址: 0x08

复位值: 0x0000 0000

此寄存器为只读寄存器, 在读取时提供 32 位随机数值。DATARDY 位需置 1 才能对此寄存器进行读操作, 读取后此寄存器在 40 个 PLLCLK48 时钟周期之内提供新的随机数值。

| 位/域  | 名称   | R/W | 描述                                       |
|------|------|-----|------------------------------------------|
| 31:0 | DATA | R   | <p>随机数 (Random Data)</p> <p>32 位随机数。</p> |

# 31 循环冗余校验计算单元 (CRC)

## 31.1 简介

循环冗余校验 (CRC) 计算单元可将输入数据经过固定的生成多项式计算得到 32 位的 CRC 计算结果，主要用来检测或校验数据传输或者保存后的正确性与完整性。

## 31.2 功能描述

### 31.2.1 计算方式

使用 CRC-32 (以太网) 多项式: 0x4C11DB7

$$(X^{32}+X^{26}+X^{23}+X^{22}+X^{16}+X^{12}+X^{11}+X^{10}+X^8+X^7+X^5+X^4+X^2+X+1)$$

### 31.2.2 计算时间

其计算时间为 4 个 AHB 时钟周期。

每写入一次新数据，其结果是上一次的计算结果和新的计算结果的组合。(对整个字进行运算)。在计算期间，会暂停 CPU 的写操作，因此可以对寄存器 CRC\_DATA 进行“背靠背”写入或连续地“读-写”操作。

## 31.3 寄存器地址映射

表格 153 CRC 寄存器地址映射

| 寄存器名       | 描述      | 偏移地址 |
|------------|---------|------|
| CRC_DATA   | 数据寄存器   | 0x00 |
| CRC_INDATA | 独立数据寄存器 | 0x04 |
| CRC_CTRL   | 控制寄存器   | 0x08 |

## 31.4 寄存器功能描述

### 31.4.1 数据寄存器 (CRC\_DATA)

偏移地址: 0x00

复位值: 0xFFFF FFFF

| 位/域  | 名称   | R/W | 描述                                                                               |
|------|------|-----|----------------------------------------------------------------------------------|
| 31:0 | DATA | R/W | 32 位数据 (32-bit Data)<br>作为输入寄存器: 写入时存储 CRC 计算器的新数据。<br>作为输出寄存器: 读取时返回 CRC 计算的结果。 |

### 31.4.2 独立数据寄存器 (CRC\_INDATA)

偏移地址: 0x04

复位值: 0x0000 0000

| 位/域  | 名称     | R/W | 描述                                                                                                |
|------|--------|-----|---------------------------------------------------------------------------------------------------|
| 7:0  | INDATA | R/W | 独立 8 位数据 (Independent 8-bit Data)<br>可用于临时存放 1 字节的数据。<br>寄存器 CRC_CTRL 的 RST 位产生的 CRC 复位对本寄存器没有影响。 |
| 31:8 |        |     | 保留。                                                                                               |

注意：此寄存器不参与 CRC 计算，可以存放任何数据。

### 31.4.3 控制寄存器 (CRC\_CTRL)

偏移地址: 0x08

复位值: 0x0000 0000

| 位/域  | 名称  | R/W | 描述                                                                                          |
|------|-----|-----|---------------------------------------------------------------------------------------------|
| 0    | RST | W   | 复位 CRC 计算单元 (Reset CRC Calculation Unit)<br>设置 CRC_DATA 寄存器为 0xFFFF FFFF。只能对该位置位，它由硬件自动清 0。 |
| 31:1 |     |     | 保留                                                                                          |

## 32 芯片电子签名

### 32.1 简介

芯片电子签名用来匹配固件或外部设备。

### 32.2 寄存器功能描述

#### 32.2.1 唯一设备 96 位唯一芯片 ID

基地址: 0x1FFF 7A10

偏移地址: 0x00

| 位/域  | 名称         | R/W | 描述            |
|------|------------|-----|---------------|
| 31:0 | U_ID[31:0] | R   | 唯一身份标志 31:0 位 |

偏移地址: 0x04

只读, 其值在出厂时编写

| 位/域  | 名称          | R/W | 描述             |
|------|-------------|-----|----------------|
| 31:0 | U_ID[63:32] | R   | 唯一身份标志 63:32 位 |

偏移地址: 0x08

只读, 其值在出厂时编写

| 位/域  | 名称          | R/W | 描述             |
|------|-------------|-----|----------------|
| 31:0 | U_ID[95:64] | R   | 唯一身份标志 95:64 位 |

#### 32.2.2 闪存容量寄存器

基地址: 0x1FFF 7A22

偏移地址: 0x00

| 位/域  | 名称     | R/W | 描述                                                                               |
|------|--------|-----|----------------------------------------------------------------------------------|
| 15:0 | F_SIZE | R   | 闪存存储器容量 (Flash Memory Capacity)<br>表示产品的主存储区的容量 (以 K 字节为单位)。<br>例: 0x0400=1024KB |

## 33 版本历史

表格 154 版本历史记录

| 日期      | 版本  | 变更历史                         |
|---------|-----|------------------------------|
| 2025.7  | 1.0 | 新建                           |
| 2025.9  | 1.1 | 增加启动配置时, 高速外部时钟 HSECLK 的频率描述 |
| 2025.10 | 1.2 | 修改 TMR9/10/11/12/13/14 功能说明  |

# 声明

本手册由珠海极海半导体有限公司（以下简称“极海”）制订并发布，所列内容均受商标、著作权、软件著作权相关法律法规保护，极海保留随时更正、修改本手册的权利。使用极海产品前请仔细阅读本手册，一旦使用产品则表明您（以下简称“用户”）已知悉并接受本手册的所有内容。用户必须按照相关法律法规和本手册的要求使用极海产品。

## 1、权利所有

本手册仅应当被用于与极海所提供的对应型号的芯片产品、软件产品搭配使用，未经极海许可，任何单位或个人均不得以任何理由或方式对本手册的全部或部分内容进行复制、抄录、修改、编辑或传播。

本手册中所列带有“®”或“™”的“极海”或“Geehy”字样或图形均为极海的商标，其他在极海产品上显示的产品或服务名称均为其各自所有者的财产。

## 2、无知识产权许可

极海拥有本手册所涉及的全部权利、所有权及知识产权。

极海不应因销售、分发极海产品及本手册而被视为将任何知识产权的许可或权利明示或默示地授予用户。

如果本手册中涉及任何第三方的产品、服务或知识产权，不应被视为极海授权用户使用前述第三方产品、服务或知识产权，也不应被视为极海对第三方产品、服务或知识产权提供任何形式的保证，包括但不限于任何第三方知识产权的非侵权保证，除非极海在销售订单或销售合同中另有约定。

## 3、版本更新

用户在下单购买极海产品时可获取相应产品的最新版的手册。

如果本手册中所述的内容与极海产品不一致的，应以极海销售订单或销售合

同中的约定为准。

#### 4、信息可靠性

本手册相关数据经极海实验室或合作的第三方测试机构批量测试获得，但本手册相关数据难免会出现校正笔误或因测试环境差异所导致的误差，因此用户应当理解，极海对本手册中可能出现的该等错误无需承担任何责任。本手册相关数据仅用于指导用户作为性能参数参照，不构成极海对任何产品性能方面的保证。

用户应根据自身需求选择合适的极海产品，并对极海产品的应用适用性进行有效验证和测试，以确认极海产品满足用户自身的需求、相应标准、安全或其它可靠性要求；若因用户未充分对极海产品进行有效验证和测试而致使用户损失的，极海不承担任何责任。

#### 5、合规要求

用户在使用本手册及所搭配的极海产品时，应遵守当地所适用的所有法律法规。用户应了解产品可能受到产品供应商、极海、极海经销商及用户所在地等各有关出口、再出口或其它法律的限制，用户（代表其本身、子公司及关联企业）应同意并保证遵守所有关于取得极海产品及/或技术与直接产品的出口和再出口适用法律与法规。

#### 6、免责声明

本手册由极海“按原样”（*as is*）提供，在适用法律所允许的范围内，极海不提供任何形式的明示或暗示担保，包括但不限于对产品适销性和特定用途适用性的担保。

极海产品并非设计、授权或担保适合用于军事、生命保障系统、污染控制或有害物质管理系统中的关键部件，亦非设计、授权或担保适合用于在产品失效或故障时可导致人员受伤、死亡、财产或环境损害的应用。

如果产品未标明“汽车级”，则表示不适用于汽车应用。如果用户对产品的应用超出极海提供的规格、应用领域、规范，极海不承担任何责任。

用户应该确保对产品的应用符合相应标准以及功能安全、信息安全、环境标

准等要求。用户对极海产品的选择和使用负全部的责任。对于用户后续在针对极海产品进行设计、使用的过程中所引起的任何纠纷，极海概不承担责任。

## 7、责任限制

在任何情况下，除非适用法律要求或书面同意，否则极海和/或以“按原样”形式提供本手册及产品的任何第三方均不承担损害赔偿责任，包括任何一般、特殊因使用或无法使用本手册及产品而产生的直接、间接或附带损害（包括但不限于数据丢失或数据不准确，或用户或第三方遭受的损失），这涵盖了可能导致的人身安全、财产或环境损害等情况，对于这些损害极海概不承担责任。

## 8、适用范围

本手册的信息用以取代本手册所有早期版本所提供的信息。

©2025 珠海极海半导体有限公司 – 保留所有权利