# ESP32 技术参考手册



**Espressif Systems** 

2016年9月28日

# 关于本手册

《**ESP32 技术参考手册**》的目标读者群体是使用 ESP32 芯片的应用开发工程师。本手册提供了关于 ESP32 的具体信息,包括各个功能模块的内部架构、功能描述和寄存器配置等。

# 发布说明

| 日期      | 版本   | 发布说明          |
|---------|------|---------------|
| 2016.08 | V1.0 | 首次发布。         |
| 2016.09 | V1.1 | 増加章节 I2C 控制器。 |

# 免责申明和版权公告

本文中的信息,包括供参考的 URL 地址,如有变更,恕不另行通知。文档"按现状"提供,不负任何担保责任,包括对适销性、适用于特定用途或非侵权性的任何担保,和任何提案、规格或样品在他处提到的任何担保。本文档不负任何责任,包括使用本文档内信息产生的侵犯任何专利权行为的责任。本文档在此未以禁止反言或其他方式授予任何知识产权使用许可,不管是明示许可还是暗示许可。Wi-Fi 联盟成员标志归 Wi-Fi 联盟所有。蓝牙标志是 Bluetooth SIG 的注册商标。

文中提到的所有商标名称、商标和注册商标均属其各自所有者的财产,特此声明。

版权归 © 2016 乐鑫所有。保留所有权利。

# 目录

| 1.1 概述 1.2 主要特性 1.3 功能描述 1.3.1 地址映射 1.3.2 片上存储器 1.3.2.1 Internal ROM 0 1.3.2.2 Internal ROM 1 1.3.2.3 Internal SRAM 0 1.3.2.4 Internal SRAM 1 1.3.2.5 Internal SRAM 2 1.3.2.6 DMA 1.3.2.7 RTC FAST Memory 1.3.2.8 RTC SLOW Memory 1.3.3 片外存储器 1.3.4 外设 1.3.4.1 不对称 PID Controller 外设 1.3.4.2 不连续外设地址范围 1.3.4.3 存储器速度  2 中断矩阵 2.1 概述 2.3 功能描述 2.3.1 外部中断源 2.3.2 CPU 中断                          |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1.3. 功能描述 10 1.3.1 地址映射 10 1.3.2 片上存储器 10 1.3.2.1 Internal ROM 0 11 1.3.2.2 Internal ROM 1 11 1.3.2.3 Internal SRAM 0 11 1.3.2.4 Internal SRAM 1 12 1.3.2.5 Internal SRAM 2 12 1.3.2.6 DMA 12 1.3.2.7 RTC FAST Memory 13 1.3.2.8 RTC SLOW Memory 13 1.3.3 片外存储器 13 1.3.4 外设 13 1.3.4 外设 15 1.3.4.1 不对称 PID Controller 外设 15 1.3.4.2 不连续外设地址范围 15 1.3.4.3 存储器速度 15  2 中断矩阵                      |
| 1.3.1 地址映射 1.3.2 片上存储器 1.3.2.1 Internal ROM 0 1.3.2.2 Internal ROM 1 1.3.2.3 Internal SRAM 0 1.3.2.3 Internal SRAM 0 1.3.2.4 Internal SRAM 1 1.3.2.5 Internal SRAM 2 1.3.2.5 Internal SRAM 2 1.3.2.6 DMA 1.2 1.3.2.7 RTC FAST Memory 1.3.2.8 RTC SLOW Memory 1.3.3 片外存储器 1.3.4 外设 1.3.4.1 不对称 PID Controller 外设 1.3.4.2 不连续外设地址范围 1.3.4.3 存储器速度 15 2 中断矩阵 2.1 概述 2.2 主要特性 2.3 功能描述 2.3.1 外部中断源 |
| 1.3.2 片上存储器 10 1.3.2.1 Internal ROM 0 11 1.3.2.2 Internal ROM 1 11 1.3.2.3 Internal SRAM 0 11 1.3.2.4 Internal SRAM 1 12 1.3.2.5 Internal SRAM 2 12 1.3.2.6 DMA 12 1.3.2.7 RTC FAST Memory 13 1.3.2.8 RTC SLOW Memory 13 1.3.3 片外存储器 13 1.3.4 外设 13 1.3.4.1 不对称 PID Controller 外设 15 1.3.4.2 不连续外设地址范围 15 1.3.4.3 存储器速度 15  2 中断矩阵                                                             |
| 1.3.2.1 Internal ROM 0 1.3.2.2 Internal ROM 1 1.3.2.3 Internal SRAM 0 1.3.2.4 Internal SRAM 1 1.3.2.5 Internal SRAM 1 1.3.2.5 Internal SRAM 2 1.3.2.6 DMA 1.3.2.7 RTC FAST Memory 1.3.2.8 RTC SLOW Memory 1.3.3 片外存储器 1.3.4 外设 1.3.4.1 不对称 PID Controller 外设 1.3.4.2 不连续外设地址范围 1.3.4.3 存储器速度 15 2 中断矩阵 2.1 概述 2.2 主要特性 2.3 功能描述 2.3.1 外部中断源                                                    |
| 1.3.2.2 Internal ROM 1 11 1.3.2.3 Internal SRAM 0 11 1.3.2.4 Internal SRAM 1 12 1.3.2.5 Internal SRAM 2 12 1.3.2.6 DMA 12 1.3.2.7 RTC FAST Memory 13 1.3.2.8 RTC SLOW Memory 13 1.3.3 片外存储器 13.4.1 不对称 PID Controller 外设 15 1.3.4.2 不连续外设地址范围 15 1.3.4.3 存储器速度 15 1.3.4.3 存储器速度 16 2.2 主要特性 16 2.3 功能描述 16 2.3.1 外部中断源                                                                         |
| 1.3.2.3 Internal SRAM 0 11 1.3.2.4 Internal SRAM 1 12 1.3.2.5 Internal SRAM 2 12 1.3.2.6 DMA 12 1.3.2.7 RTC FAST Memory 13 1.3.2.8 RTC SLOW Memory 13 1.3.4 外设 13 1.3.4 外设 13 1.3.4.1 不对称 PID Controller 外设 15 1.3.4.2 不连续外设地址范围 15 1.3.4.3 存储器速度 15  2 中断矩阵 16 2.1 概述 16 2.2 主要特性 16 2.3 功能描述 16 2.3.1 外部中断源                                                                                  |
| 1.3.2.4 Internal SRAM 1 1.3.2.5 Internal SRAM 2 1.3.2.6 DMA 1.3.2.7 RTC FAST Memory 1.3.2.8 RTC SLOW Memory 1.3.3 片外存储器 1.3.4 外设 1.3.4.1 不对称 PID Controller 外设 1.3.4.2 不连续外设地址范围 1.3.4.3 存储器速度 15  2 中断矩阵 2.1 概述 2.2 主要特性 2.3 功能描述 2.3.1 外部中断源                                                                                                                                                 |
| 1.3.2.5 Internal SRAM 2 1.3.2.6 DMA 1.3.2.7 RTC FAST Memory 1.3.2.8 RTC SLOW Memory 1.3.3 片外存储器 1.3.4 外设 1.3.4.1 不对称 PID Controller 外设 1.3.4.2 不连续外设地址范围 1.3.4.3 存储器速度 15 2 中断矩阵 2.1 概述 2.2 主要特性 2.3 功能描述 2.3.1 外部中断源                                                                                                                                                                          |
| 1.3.2.6 DMA 1.3.2.7 RTC FAST Memory 1.3.2.8 RTC SLOW Memory 1.3.3 片外存储器 1.3.4 外设 1.3.4.1 不对称 PID Controller 外设 1.3.4.2 不连续外设地址范围 1.3.4.3 存储器速度 15 2 中断矩阵 2.1 概述 2.2 主要特性 2.3 功能描述 2.3.1 外部中断源                                                                                                                                                                                                  |
| 1.3.2.7 RTC FAST Memory 1.3.2.8 RTC SLOW Memory 1.3.3.1 片外存储器 1.3.4 外设 1.3.4.1 不对称 PID Controller 外设 1.3.4.2 不连续外设地址范围 1.3.4.3 存储器速度 15 2 中断矩阵 2.1 概述 2.2 主要特性 2.3 功能描述 2.3.1 外部中断源                                                                                                                                                                                                            |
| 1.3.2.8 RTC SLOW Memory 1.3.3 片外存储器 1.3.4 外设 1.3.4.1 不对称 PID Controller 外设 1.3.4.2 不连续外设地址范围 1.3.4.3 存储器速度 15 2 中断矩阵 2.1 概述 2.2 主要特性 2.3 功能描述 2.3.1 外部中断源                                                                                                                                                                                                                                      |
| 1.3.3 片外存储器       13         1.3.4 外设       13         1.3.4.1 不对称 PID Controller 外设       15         1.3.4.2 不连续外设地址范围       15         1.3.4.3 存储器速度       16         2 中断矩阵       16         2.1 概述       16         2.2 主要特性       16         2.3 功能描述       16         2.3.1 外部中断源       16                                                                                               |
| 1.3.4 外设       13         1.3.4.1 不对称 PID Controller 外设       15         1.3.4.2 不连续外设地址范围       15         1.3.4.3 存储器速度       16         2 中断矩阵       16         2.1 概述       16         2.2 主要特性       16         2.3 功能描述       16         2.3.1 外部中断源       16                                                                                                                            |
| 1.3.4.1 不对称 PID Controller 外设       15         1.3.4.2 不连续外设地址范围       15         1.3.4.3 存储器速度       16         2.1 概述       16         2.2 主要特性       16         2.3 功能描述       16         2.3.1 外部中断源       16                                                                                                                                                                              |
| 1.3.4.2 不连续外设地址范围       15         1.3.4.3 存储器速度       16         2.1 概述       16         2.2 主要特性       16         2.3 功能描述       16         2.3.1 外部中断源       16                                                                                                                                                                                                                             |
| 1.3.4.3 存储器速度       15         2 中断矩阵       16         2.1 概述       16         2.2 主要特性       16         2.3 功能描述       16         2.3.1 外部中断源       16                                                                                                                                                                                                                                        |
| 2 中断矩阵       16         2.1 概述       16         2.2 主要特性       16         2.3 功能描述       16         2.3.1 外部中断源       16                                                                                                                                                                                                                                                                       |
| 2.1 概述162.2 主要特性162.3 功能描述162.3.1 外部中断源16                                                                                                                                                                                                                                                                                                                                                      |
| 2.2 主要特性       16         2.3 功能描述       16         2.3.1 外部中断源       16                                                                                                                                                                                                                                                                                                                       |
| 2.3 功能描述       16         2.3.1 外部中断源       16                                                                                                                                                                                                                                                                                                                                                 |
| 2.3.1 外部中断源 16                                                                                                                                                                                                                                                                                                                                                                                 |
|                                                                                                                                                                                                                                                                                                                                                                                                |
| 232 CPI 由新                                                                                                                                                                                                                                                                                                                                                                                     |
| 2.3.2 010 个例                                                                                                                                                                                                                                                                                                                                                                                   |
| 2.3.3 分配外部中断源至 CPU 外部中断 19                                                                                                                                                                                                                                                                                                                                                                     |
| 2.3.4 屏蔽 CPU 的 NMI 类型中断 20                                                                                                                                                                                                                                                                                                                                                                     |
| 2.3.5 查询外部中断源当前的中断状态 20                                                                                                                                                                                                                                                                                                                                                                        |
| 3 复位和时钟                                                                                                                                                                                                                                                                                                                                                                                        |
| 3.1 System 复位 21                                                                                                                                                                                                                                                                                                                                                                               |
| 3.1.1 概述 21                                                                                                                                                                                                                                                                                                                                                                                    |
| 3.1.2 复位源 21                                                                                                                                                                                                                                                                                                                                                                                   |
| 3.2 系统时钟 22                                                                                                                                                                                                                                                                                                                                                                                    |
| 3.2.1 概述 22                                                                                                                                                                                                                                                                                                                                                                                    |
| 3.2.2 时钟源 23                                                                                                                                                                                                                                                                                                                                                                                   |
| 3.2.3 CPU 时钟 23                                                                                                                                                                                                                                                                                                                                                                                |
| 3.2.4 外设时钟 24                                                                                                                                                                                                                                                                                                                                                                                  |
| 3.2.4.1 APB_CLK 源           24                                                                                                                                                                                                                                                                                                                                                                 |
| 3.2.4.2 REF_TICK 源 25                                                                                                                                                                                                                                                                                                                                                                          |
| 3.2.4.3 LEDC_SCLK 源 25                                                                                                                                                                                                                                                                                                                                                                         |
| 3.2.4.4 APLL_SCLK 源 25                                                                                                                                                                                                                                                                                                                                                                         |
| 3.2.4.5 PLL_D2_CLK 源 25                                                                                                                                                                                                                                                                                                                                                                        |

| 3.2.4.6 时钟源注意事项               | 25 |
|-------------------------------|----|
| 3.2.5 Wi-Fi BT 时钟             | 26 |
| 3.2.6 RTC 时钟                  | 26 |
| 4 IO_MUX 和 GPIO 交换矩阵          | 27 |
| 4.1 概述                        | 27 |
| 4.2 通过 GPIO 交换矩阵的外设输入         | 28 |
| 4.2.1 概述                      | 28 |
| 4.2.2 功能描述                    | 28 |
| 4.2.3 简单 GPIO 输入              | 29 |
| 4.3 通过 GPIO 交换矩阵的外设输出         | 29 |
| 4.3.1 概述                      | 29 |
| 4.3.2 功能描述                    | 29 |
| 4.3.3 简单 GPIO 输出              | 30 |
| 4.4 IO_MUX 的直接 I/O 功能         | 30 |
| 4.4.1 概述                      | 30 |
| 4.4.2 功能描述                    | 30 |
| 4.5 RTC IO_MUX 的低功耗和模拟 I/O 功能 | 31 |
| 4.5.1 概述                      | 31 |
| 4.5.2 功能描述                    | 31 |
| 4.6 Light-sleep 模式管脚功能        | 31 |
| 4.7 Pad Hold 特性               | 31 |
| 4.8 I/O Pad 供电                | 32 |
| 4.8.1 VDD_SDIO 电源域            | 32 |
| 4.9 外设信号列表                    | 32 |
| 4.10 IO_MUX Pad 列表            | 37 |
| 4.11 RTC_MUX 管脚清单             | 38 |
| 4.12 寄存器列表                    | 39 |
| 4.13 寄存器                      | 44 |
| 5 I2C 控制器                     | 64 |
| 5.1 概述                        | 64 |
| 5.2 主要特性                      | 64 |
| 5.3 I2C 功能描述                  | 64 |
| 5.3.1 I2C 简介                  | 64 |
| 5.3.2 I2C 架构                  | 64 |
| 5.3.3 I2C 总线时序                | 66 |
| 5.3.4 I2C cmd 结构              | 66 |
| 5.3.5 I2C 主机写入从机              | 67 |
| 5.3.6 I2C 主机读取从机              | 69 |
| 5.3.7 中断                      | 71 |
| 5.4 寄存器列表                     | 71 |
| 5.5 寄存器                       | 73 |
| 6 LED_PWM                     | 84 |
| 6.1 概述                        | 84 |
| 6.2 功能描述                      | 84 |

| 6.2.1 架构           | 84  |
|--------------------|-----|
| 6.2.2 分频器          | 85  |
| 6.2.3 通道           | 85  |
| 6.2.4 中断           | 86  |
| 6.3 寄存器列表          | 86  |
| 6.4 寄存器            | 89  |
| 7 红外遥控             | 98  |
| 7.1 概述             | 98  |
| 7.2 功能描述           | 98  |
| 7.2.1 RMT 架构       | 98  |
| 7.2.2 RMT RAM      | 99  |
| 7.2.3 时钟           | 99  |
| 7.2.4 发射器          | 99  |
| 7.2.5 接收器          | 100 |
| 7.2.6 中断           | 100 |
| 7.3 寄存器列表          | 100 |
| 7.4 寄存器            | 102 |
| 8 PULSE_CNT        | 107 |
| 8.1 概述             | 107 |
| 8.2 功能描述           | 107 |
| 8.2.1 架构图          | 107 |
| 8.2.2 计数器通道输入信号    | 107 |
| 8.2.3 观察点          | 108 |
| 8.2.4 举例           | 108 |
| 8.2.5 溢出中断         | 109 |
| 8.3 寄存器列表          | 109 |
| 8.4 寄存器            | 111 |
| 9 64-bit 定时器       | 115 |
| 9.1 概述             | 115 |
| 9.2 功能描述           | 115 |
| 9.2.1 16-bit 预分频器  | 115 |
| 9.2.2 64-bit 时基计数器 | 115 |
| 9.2.3 报警产生         | 116 |
| 9.2.4 MWDT         | 116 |
| 9.2.5 中断           | 116 |
| 9.3 寄存器列表          | 116 |
| 9.4 寄存器            | 118 |
| 10 看门狗定时器          | 124 |
| 10.1 概述            | 124 |
| 10.2 主要特性          | 124 |
| 10.3 功能描述          | 124 |
| 10.3.1 时钟          | 124 |
| 10.3.1.1 运行过程      | 124 |

| 10.3.1.2 写保护        | 125 |
|---------------------|-----|
| 10.3.1.3 Flash 启动保护 | 125 |
| 10.3.1.4 寄存器        | 125 |
| 11 AES 加速器          | 126 |
| 11.1 概述             | 126 |
| 11.2 主要特性           | 126 |
| 11.3 功能描述           | 126 |
| 11.3.1 运算模式         | 126 |
| 11.3.2 密钥、明文、密文     | 126 |
| 11.3.3 字节序          | 127 |
| 11.3.4 加密与解密运算      | 129 |
| 11.3.5 运行效率         | 129 |
| 11.4 寄存器列表          | 129 |
| 11.5 寄存器            | 131 |
| 12 SHA 加速器          | 133 |
| 12.1 概述             | 133 |
| 12.2 特性             | 133 |
| 12.3 功能描述           | 133 |
| 12.3.1 填充解析信息       | 133 |
| 12.3.2 信息摘要         | 133 |
| 12.3.3 哈希运算         | 134 |
| 12.3.4 运行效率         | 134 |
| 12.4 寄存器列表          | 134 |
| 12.5 寄存器            | 136 |

# 表格

| 1  | 地址映射                                         | 10  |
|----|----------------------------------------------|-----|
| 2  | 片上寄存器地址映射                                    | 10  |
| 3  | 具有 DMA 功能的模块                                 | 13  |
| 4  | 片外存储器地址映射                                    | 13  |
| 5  | 外设地址映射                                       | 14  |
| 6  | PRO_CPU、APP_CPU 外部中断配置寄存器、外部中断源中断状态寄存器、外部中断源 | 17  |
| 7  | CPU 中断                                       | 19  |
| 8  | PRO_CPU 和 APP_CPU 复位源                        | 21  |
| 9  | CPU_CLK 源                                    | 23  |
| 10 | CPU_CLK 源                                    | 24  |
| 11 | 外设时钟用法                                       | 24  |
| 12 | APB_CLK 源                                    | 25  |
| 13 | REF_TICK 源                                   | 25  |
| 14 | LEDC_SCLK 源                                  | 25  |
| 15 | IO_MUX Light-sleep 管脚功能寄存器                   | 31  |
| 16 | GPIO 交换矩阵外设信号                                | 32  |
| 17 | IO_MUX Pad 列表                                | 37  |
| 18 | RTC_MUX 管脚清单                                 | 38  |
| 28 | 运算模式                                         | 126 |
| 29 | AES 文本字节序                                    | 127 |
| 30 | AES-128 密钥字节序                                | 128 |
| 31 | AES-192 密钥字节序                                | 128 |
| 32 | AES-256 密钥字节序                                | 128 |

# 插图

| 1  | 条统结构                                       | 9   |
|----|--------------------------------------------|-----|
| 2  | 地址映射结构                                     | 9   |
| 3  | 中断矩阵结构图                                    | 16  |
| 4  | 系统复位                                       | 21  |
| 5  | 系统时钟                                       | 22  |
| 6  | IO_MUX、RTC IO_MUX 和 GPIO 交换矩阵结构框图          | 27  |
| 7  | 通过 IO_MUX、GPIO 交换矩阵的外设输入                   | 28  |
| 8  | 通过 GPIO 交换矩阵输出信号                           | 29  |
| 9  | ESP32 I/O Pad 供电源                          | 32  |
| 10 | I2C Master 基本架构                            | 65  |
| 11 | I2C Slave 基本架构                             | 65  |
| 12 | I2C 时序图                                    | 66  |
| 13 | I2C 命令寄存器结构                                | 66  |
| 14 | I2C Master 写 7-bit 地址 Slave                | 67  |
| 15 | I2C Master 写 10-bit 地址 Slave               | 67  |
| 16 | I2C Master 写 7-bit 地址 Slave 的 M 地址 RAM     | 68  |
| 17 | I2C Master 分段写 7-bit 地址 Slave              | 68  |
| 18 | I2C Master 读 7-bit 地址 Slave                | 69  |
| 19 | I2C Master 读 10-bit 地址 Slave               | 69  |
| 20 | I2C Master 从 7-bit 地址 Slave 的 M 地址读取 N 个数据 | 70  |
| 21 | I2C Master 分段读 7-bit 地址 Slave              | 70  |
| 22 | LED_PWM 架构                                 | 84  |
| 23 | LED_PWM 高速通道框图                             | 84  |
| 24 | LED_PWM 输出信号图                              | 85  |
| 25 | 渐变占空比输出信号图                                 | 85  |
| 26 | RMT 架构                                     | 98  |
| 27 | 数据结构                                       | 99  |
| 28 | PULSE_CNT 单元基本架构图                          | 107 |
| 29 | PULSE_CNT 递增计数图                            | 109 |
| 30 | PULSE_CNT 递减计数图                            | 109 |
|    |                                            |     |

# 1. 系统和存储器

# 1.1 概述

ESP32 采用两个哈佛结构 Xtensa LX6 CPU 构成双核系统。所有的片上存储器、片外存储器以及外设都分布在两个 CPU 的数据总线和 / 或指令总线上。

除下文列出的个别情况外,两个 CPU 的地址映射呈对称结构,即使用相同的地址访问同一目标。系统中多个外设能够通过 DMA 访问片上存储器。

两个 CPU 的名称分别是 "PRO\_CPU" 和 "APP\_CPU"。PRO 代表 "protocol (协议)", APP 代表 "application (应用)"。在大多数情况下,两个 CPU 的功能是相同的。

# 1.2 主要特性

- 地址空间
  - 对称地址映射
  - 数据总线与指令总线分别有 4 GB (32-bit) 地址空间
  - 1296 KB 片上存储器地址空间
  - 19704 KB 片外存储器地址空间
  - 512 KB 外设地址空间
  - 部分片上存储器与片外存储器既能被数据总线也能被指令总线访问
  - 328 KB DMA 地址空间
- 片上存储器
  - 448 KB Internal ROM
  - 520 KB Internal SRAM
  - 8 KB RTC FAST Memory
  - 8 KB RTC SLOW Memory
- 片外存储器

片外 SPI 存储器可作为片外存储器被映射到可用的地址空间。部分片上存储器可用作片外存储器的 Cache。

- 最大支持 16 MB 片外 SPI Flash
- 最大支持 8 MB 片外 SPI SRAM
- 外设
  - 41 个外设模块
- DMA
  - 13 个具有 DMA 功能的模块

1.2 主要特性 1 系统和存储器

图 1 描述了系统结构。图 2 描述了地址映射结构。



图 1: 系统结构



图 2: 地址映射结构

1.3 功能描述 1 系统和存储器

# 1.3 功能描述

#### 1.3.1 地址映射

同构双核系统由两个哈佛结构 Xtensa LX6 CPU 构成,每个 CPU 都具有 4 GB (32-bit) 的地址空间。两个 CPU 的地址映射是对称的。

地址 0x4000\_0000 以下的部分属于数据总线的地址范围, 地址 0x4000\_0000 ~ 0x4FFF\_FFF 部分为指令总线的地址范围, 地址 0x5000\_0000 及以上的部分是数据总线与指令总线共用的地址范围。

CPU 的数据总线与指令总线都为小端序。即字节地址 0x0、0x1、0x2、0x3 访问的字节分别是 0x0 访问的 32-bit 字中的最低、次低、次高、最高字节。CPU 可以通过数据总线按照字节、半字、字进行对齐与非对齐的数据访问。CPU 可以通过指令总线进行数据访问,但必须是**字对齐方式**;非对齐数据访问会导致 CPU 工作异常。

两个 CPU 都能够使用数据总线与指令总线直接访问片上存储器、使用 Cache 和 MMU 直接访问映射到地址空间的片外存储器、使用指令总线直接访问外设。当两个 CPU 访问同一目标时,其使用相同的地址,整个系统的地址映射呈对称结构。表 1 描述了两个 CPU 的数据总线与指令总线中的各段地址所能访问的目标。

系统中部分片上存储器与部分片外存储器既可以被数据总线访问也可以被指令总线访问,这种情况下,两个CPU都可以用多个地址访问到同一目标。

| 古 <del>张 米 和</del> | 边界地址        |             | 宏县       | 目标    |  |
|--------------------|-------------|-------------|----------|-------|--|
| 总线类型               |             |             | 谷里<br>   |       |  |
|                    | 0x0000_0000 | 0x3F3F_FFFF |          | 保留    |  |
| 数据                 | 0x3F40_0000 | 0x3F7F_FFFF | 4 MB     | 片外存储器 |  |
| 数据                 | 0x3F80_0000 | 0x3FBF_FFFF | 4 MB     | 片外存储器 |  |
|                    | 0x3FC0_0000 | 0x3FEF_FFFF | 3 MB     | 保留    |  |
| 数据                 | 0x3FF0_0000 | 0x3FF7_FFFF | 512 KB   | 外设    |  |
| 数据                 | 0x3FF8_0000 | 0x3FFF_FFFF | 512 KB   | 片上存储器 |  |
| 指令                 | 0x4000_0000 | 0x400C_1FFF | 776 KB   | 片上存储器 |  |
| 指令                 | 0x400C_2000 | 0x40BF_FFFF | 11512 KB | 片外存储器 |  |
|                    | 0x40C0_0000 | 0x4FFF_FFFF | 244 MB   | 保留    |  |
| 数据 / 指令            | 0x5000_0000 | 0x5000_1FFF | 8 KB     | 片上存储器 |  |
|                    | 0x5000_2000 | 0xFFFF_FFFF |          | 保留    |  |

表 1: 地址映射

# 1.3.2 片上存储器

片上存储器分为 Internal ROM、Internal SRAM、RTC FAST Memory、RTC SLOW Memory 四个部分,其容量分别为 448 KB、520 KB、8 KB、8 KB。

其中 448 KB Internal ROM 分为 384 KB Internal ROM 0、64 KB Internal ROM 1 两部分,

520 KB Internal SRAM 分为 192 KB Internal SRAM 0、128 KB Internal SRAM 1、200 KB Internal SRAM 2 三部分。

RTC FAST Memory 与 RTC SLOW Memory 都为 SRAM。

表 2 列出了所有片上存储器以及片上存储器的数据总线与指令总线地址段。

#### 表 2: 片上寄存器地址映射

1.3 功能描述 1 系统和存储器

| 六 小 <del>八</del> 九 五川 | 边界地址        |             | 京具         | H 1-            | FT NO                                      |  |
|-----------------------|-------------|-------------|------------|-----------------|--------------------------------------------|--|
| 总线类型                  | 低位地址        | 高位地址        | 容量         | 目标              | 备注<br>———————————————————————————————————— |  |
| 数据                    | 0x3FF8_0000 | 0x3FF8_1FFF | 8 KB       | RTC FAST Memory | PRO_CPU Only                               |  |
|                       | 0x3FF8_2000 | 0x3FF8_FFFF | 56 KB      | 保留              |                                            |  |
| 数据                    | 0x3FF9_0000 | 0x3FF9_FFFF | 64 KB      | Internal ROM 1  |                                            |  |
|                       | 0x3FFA_0000 | 0x3FFA_DFFF | 56 KB      | 保留              |                                            |  |
| 数据                    | 0x3FFA_E000 | 0x3FFD_FFFF | 200 KB     | Internal SRAM 2 | DMA                                        |  |
| 数据                    | 0x3FFE_0000 | 0x3FFF_FFFF | 128 KB     | Internal SRAM 1 | DMA                                        |  |
| 总线类型                  | 边界          | 地址          | 容量         | <br>  目标        | 备注                                         |  |
| 心纹矢空                  | 低位地址        | 高位地址        | <b>分里</b>  |                 | <b>年</b> 在                                 |  |
| 指令                    | 0x4000_0000 | 0x4000_7FFF | 32 KB      | Internal ROM 0  | Remap                                      |  |
| 指令                    | 0x4000_8000 | 0x4005_FFFF | 352 KB     | Internal ROM 0  |                                            |  |
|                       | 0x4006_0000 | 0x4006_FFFF | 64 KB      | 保留              |                                            |  |
| 指令                    | 0x4007_0000 | 0x4007_FFFF | 64 KB      | Internal SRAM 0 | Cache                                      |  |
| 指令                    | 0x4008_0000 | 0x4009_FFFF | 128 KB     | Internal SRAM 0 |                                            |  |
| 指令                    | 0x400A_0000 | 0x400A_FFFF | 64 KB      | Internal SRAM 1 |                                            |  |
| 指令                    | 0x400B_0000 | 0x400B_7FFF | 32 KB      | Internal SRAM 1 | Remap                                      |  |
| 指令                    | 0x400B_8000 | 0x400B_FFFF | 32 KB      | Internal SRAM 1 |                                            |  |
| 指令                    | 0x400C_0000 | 0x400C_1FFF | 8 KB       | RTC FAST Memory | PRO_CPU Only                               |  |
| 总线类型                  | 边界地址        |             | <b>☆</b> 見 | 日長              | 备注                                         |  |
| 心纹矢尘                  | 低位地址        | 高位地址        | 容量         | 目标              | 1 年仁                                       |  |
| 数据指令                  | 0x5000_0000 | 0x5000_1FFF | 8 KB       | RTC SLOW Memory |                                            |  |

### 1.3.2.1 Internal ROM 0

Internal ROM 0 的容量为 384 KB, 可以被两个 CPU 通过指令总线 0x4000\_0000 ~ 0x4005\_FFFF 读取。

访问 ROM 0 的头 32 KB 的地址(0x4000\_0000 ~ 0x4000\_7FFF)可以被重新映射到 Internal SRAM 1 中的一部分,这部分原本被地址 0x400B\_0000 ~ 0x400B\_7FFF 访问。重映射时,这 32 KB SRAM 不能再被地址 0x400B\_0000 ~ 0x400B\_7FFF 访问,但是可以被数据总线 (0x3FFE\_8000 ~ 0x3FFE\_FFFF)访问。实现方式是分别为两个 CPU 配置一个寄存器,即为 PRO\_CPU 置位 DPORT\_PRO\_BOOT\_REMAP\_CTRL\_REG 寄存器的 bit 0 或者为 APP\_CPU 置位 DPORT\_APP\_BOOT\_REMAP\_CTRL\_REG 寄存器的 bit 0。

#### 1.3.2.2 Internal ROM 1

Internal ROM 1 的容量为 64 KB, 其可以被两个 CPU 通过数据总线 0x3FF9\_0000 ~ 0x3FF9\_FFFF 读取。

#### 1.3.2.3 Internal SRAM 0

Internal SRAM 0 的容量为 192 KB, 通过配置, 硬件的头 64 KB 可以作为 Cache 来缓存片外存储器。不作为 Cache 使用时, 头 64 KB 可以被两个 CPU 通过指令总线 0x4007\_0000 ~ 0x4007\_FFFF 读写, 其余 128 KB 可以被两个 CPU 通过指令总线 0x4008\_0000 ~ 0x4009\_FFFF 读写。

1.3 功能描述 1 系统和存储器

#### 1.3.2.4 Internal SRAM 1

Internal SRAM 1 的容量为 128 KB, 其既可以被两个 CPU 通过数据总线 0x3FFE\_0000 ~ 0x3FFF\_FFFF 读写, 也可以被两个 CPU 通过指令总线 0x400A\_0000 ~ 0x400B\_FFFF 读写。

指令总线地址和数据总线地址访问的 word 是逆序的。即地址:

0x3FFE\_0000 与 0x400B\_FFFC 访问到相同的 word

0x3FFE\_0004 与 0x400B\_FFF8 访问到相同的 word

0x3FFE\_0008 与 0x400B\_FFF4 访问到相同的 word

... ...

0x3FFF\_FFF4 与 0x400A\_0008 访问到相同的 word

0x3FFF\_FFF8 与 0x400A\_0004 访问到相同的 word

0x3FFF\_FFFC 与 0x400A\_0000 访问到相同的 word

CPU 的数据总线与指令总线都是小端序。因此地址空间访问每个 word 的字节顺序不是逆序的。即地址:

0x3FFE\_0000 访问的字节等同于 0x400B\_FFFC 访问的 word 中的最低字节

0x3FFE\_0001 访问的字节等同于 0x400B\_FFFC 访问的 word 中的次低字节

0x3FFE\_0002 访问的字节等同于 0x400B\_FFFC 访问的 word 中的次高字节

0x3FFE\_0003 访问的字节等同于 0x400B\_FFFC 访问的 word 中的最高字节

0x3FFE\_0004 访问的字节等同于 0x400B\_FFF8 访问的 word 中的最低字节

0x3FFE\_0005 访问的字节等同于 0x400B\_FFF8 访问的 word 中的次低字节

0x3FFE\_0006 访问的字节等同于 0x400B\_FFF8 访问的 word 中的次高字节

0x3FFE 0007 访问的字节等同于 0x400B FFF8 访问的 word 中的最高字节

.. ...

0x3FFF FFF8 访问的字节等同于 0x400A 0004 访问的 word 中的最低字节

0x3FFF\_FFF9 访问的字节等同于 0x400A\_0004 访问的 word 中的次低字节

0x3FFF FFFA 访问的字节等同于 0x400A 0004 访问的 word 中的次高字节

0x3FFF\_FFB 访问的字节等同于 0x400A\_0004 访问的 word 中的最高字节

0x3FFF\_FFFC 访问的字节等同于 0x400A\_0000 访问的 word 中的最低字节

0x3FFF FFFD 访问的字节等同于 0x400A 0000 访问的 word 中的次低字节

0x3FFF\_FFFE 访问的字节等同于 0x400A\_0000 访问的 word 中的次高字节

0x3FFF\_FFFF 访问的字节等同于 0x400A\_0000 访问的 word 中的最高字节

部分存储器可以被重新映射到 ROM 0 的地址空间。详细信息请参见 Internal Rom 0。

#### 1.3.2.5 Internal SRAM 2

Internal SRAM 2 的容量为 200 KB, 其可以被两个 CPU 通过数据总线 0x3FFA\_E000 ~ 0x3FFD\_FFFF 读写。

#### 1.3.2.6 DMA

DMA 使用与 CPU 数据总线完全相同的地址读写 Internal SRAM 1 与 Internal SRAM 2。即 DMA 使用地址 0x3FFE\_0000 ~ 0x3FFF\_FFFF 读写 Internal SRAM 1,使用地址 0x3FFA\_E000 ~ 0x3FFD\_FFFF 读写 Internal SRAM 2。

系统中具有 DMA 功能的模块总共有 13 个。表 3 列出了所有具有 DMA 功能的模块。

1.3 功能描述 1 系统和存储器

表 3: 具有 DMA 功能的模块

| UART0    | UART1 |       | UART2 |  |
|----------|-------|-------|-------|--|
| SPI1     | SPI2  |       | SPI3  |  |
| 1280     |       | 12S1  |       |  |
| SDIO Sla | ave   | SDMMC |       |  |
| EMAC     |       |       |       |  |
| BT       |       | WIFI  |       |  |

## 1.3.2.7 RTC FAST Memory

RTC FAST Memory 为 8 KB SRAM, 其只能被 PRO\_CPU 通过数据总线 0x3FF8\_0000 ~ 0x3FF8\_1FFF 读写,或 被 PRO\_CPU 通过指令总线 0x400C\_0000 ~ 0x400C\_1FFF 读写。与其他存储器不同,APP\_CPU 不能访问 RTC FAST Memory。

PRO\_CPU 的这两段地址同序访问 RTC FAST Memory。即地址 0x3FF8\_0000 与 0x400C\_0000 访问到相同的 word, 0x3FF8\_0004 与 0x400C\_0004 访问到相同的 word, 0x3FF8\_0008 与 0x400C\_0008 访问到 RTC FAST Memory, 也不能访问到其他任何目标。

## 1.3.2.8 RTC SLOW Memory

RTC SLOW Memory 为 8 KB SRAM, 其可以被两个 CPU 通过数据总线与指令总线共用地址段 0x5000\_0000 ~ 0x5000\_1FFF 读写。

# 1.3.3 片外存储器

ESP32 将 External Flash 与 External SRAM 作为片外存储器。表 4 列出了两个 CPU 的数据总线与指令总线中的各段地址通过 Cache 与 MMU 所能访问的片外存储器。两个 CPU 通过 Cache 与 MMU 对片外存储器进行访问时,Cache 将根据 MMU 中的设置把 CPU 的地址变换为 External Flash 与 External SRAM 的实地址。经过变换之后的实地址最大支持 16 MB 的 External Flash 与 8 MB 的 External SRAM。

表 4: 片外存储器地址映射

| 总线类型 | 边界地址        |             | 容量        | 目标             | 备注         |
|------|-------------|-------------|-----------|----------------|------------|
| 心纹矢空 | 低位地址        | 高位地址        | <b>分里</b> |                | <b>甘</b> 仁 |
| 数据   | 0x3F40_0000 | 0x3F7F_FFFF | 4 MB      | External Flash | 读          |
| 数据   | 0x3F80_0000 | 0x3FBF_FFFF | 4 MB      | External SRAM  | 读 / 写      |
| 总线类型 | 2.          |             | 容量        | 目标             | 备注         |
| 指令   | 0x400C_2000 | 0x40BF_FFFF | 11512 KB  | External Flash | 读          |

# 1.3.4 外设

ESP32 共有 41 个外设模块。表 5 详细描述了两个 CPU 的数据总线中的各段地址所能访问的各个外设模块。除了 PID Controller 以外,其余外设模块都可以被两个 CPU 用相同地址访问到。

表 5: 外设地址映射

| 总线类型 | 总线类型        |             |        | 日長               | 友许          |
|------|-------------|-------------|--------|------------------|-------------|
|      | 低位地址        | 高位地址        | ── 容量  | 目标               | 备注          |
| 数据   | 0x3FF0_0000 | 0x3FF0_0FFF | 4 KB   | DPort Register   |             |
| 数据   | 0x3FF0_1000 | 0x3FF0_1FFF | 4 KB   | AES Accelerator  |             |
| 数据   | 0x3FF0_2000 | 0x3FF0_2FFF | 4 KB   | RSA Accelerator  |             |
| 数据   | 0x3FF0_3000 | 0x3FF0_3FFF | 4 KB   | SHA Accelerator  |             |
| 数据   | 0x3FF0_4000 | 0x3FF0_4FFF | 4 KB   | Secure Boot      |             |
|      | 0x3FF0_5000 | 0x3FF0_FFFF | 44 KB  | 保留               |             |
| 数据   | 0x3FF1_0000 | 0x3FF1_3FFF | 16 KB  | Cache MMU Table  |             |
|      | 0x3FF1_4000 | 0x3FF1_EFFF | 44 KB  | 保留               |             |
| 数据   | 0x3FF1_F000 | 0x3FF1_FFFF | 4 KB   | PID Controller   | 每个 CPU 单独外设 |
|      | 0x3FF2_0000 | 0x3FF3_FFFF | 128 KB | 保留               |             |
| 数据   | 0x3FF4_0000 | 0x3FF4_0FFF | 4 KB   | UART0            |             |
|      | 0x3FF4_1000 | 0x3FF4_1FFF | 4 KB   | 保留               |             |
| 数据   | 0x3FF4_2000 | 0x3FF4_2FFF | 4 KB   | SPI1             |             |
| 数据   | 0x3FF4_3000 | 0x3FF4_3FFF | 4 KB   | SPI0             |             |
| 数据   | 0x3FF4_4000 | 0x3FF4_4FFF | 4 KB   | GPIO             |             |
|      | 0x3FF4_5000 | 0x3FF4_7FFF | 12 KB  | 保留               |             |
| 数据   | 0x3FF4_8000 | 0x3FF4_8FFF | 4 KB   | RTC              |             |
| 数据   | 0x3FF4_9000 | 0x3FF4_9FFF | 4 KB   | IO MUX           |             |
|      | 0x3FF4_A000 | 0x3FF4_AFFF | 4 KB   | 保留               |             |
| 数据   | 0x3FF4_B000 | 0x3FF4_BFFF | 4 KB   | SDIO Slave       | 三个部分之一      |
| 数据   | 0x3FF4_C000 | 0x3FF4_CFFF | 4 KB   | UDMA1            |             |
|      | 0x3FF4_D000 | 0x3FF4_EFFF | 8 KB   | 保留               |             |
| 数据   | 0x3FF4_F000 | 0x3FF4_FFFF | 4 KB   | 12S0             |             |
| 数据   | 0x3FF5_0000 | 0x3FF5_0FFF | 4 KB   | UART1            |             |
|      | 0x3FF5_1000 | 0x3FF5_2FFF | 8 KB   | 保留               |             |
| 数据   | 0x3FF5_3000 | 0x3FF5_3FFF | 4 KB   | I2C0             |             |
| 数据   | 0x3FF5_4000 | 0x3FF5_4FFF | 4 KB   | UDMA0            |             |
| 数据   | 0x3FF5_5000 | 0x3FF5_5FFF | 4 KB   | SDIO Slave       | 三个部分之一      |
| 数据   | 0x3FF5_6000 | 0x3FF5_6FFF | 4 KB   | RMT              |             |
| 数据   | 0x3FF5_7000 | 0x3FF5_7FFF | 4 KB   | PCNT             |             |
| 数据   | 0x3FF5_8000 | 0x3FF5_8FFF | 4 KB   | SDIO Slave       | 三个部分之一      |
| 数据   | 0x3FF5_9000 | 0x3FF5_9FFF | 4 KB   | LED PWM          |             |
| 数据   | 0x3FF5_A000 | 0x3FF5_AFFF | 4 KB   | Efuse Controller |             |
| 数据   | 0x3FF5_B000 | 0x3FF5_BFFF | 4 KB   | Flash Encryption |             |
|      | 0x3FF5_C000 | 0x3FF5_DFFF | 8 KB   | 保留               |             |
| 数据   | 0x3FF5_E000 | 0x3FF5_EFFF | 4 KB   | PWM0             |             |
| 数据   | 0x3FF5_F000 | 0x3FF5_FFFF | 4 KB   | TIMG0            |             |
| 数据   | 0x3FF6_0000 | 0x3FF6_0FFF | 4 KB   | TIMG1            |             |
|      | 0x3FF6_1000 | 0x3FF6_3FFF | 12 KB  | 保留               |             |
| 数据   | 0x3FF6_4000 | 0x3FF6_4FFF | 4 KB   | SPI2             |             |
| 数据   | 0x3FF6_5000 | 0x3FF6_5FFF | 4 KB   | SPI3             |             |
| 数据   | 0x3FF6_6000 | 0x3FF6_6FFF | 4 KB   | SYSCON           |             |

1.3 功能描述 1 系统和存储器

| 公 公 米 刊 | 总线          | 类型          | <b>☆</b> 目. | 日長    | <b>夕</b> 沙 |
|---------|-------------|-------------|-------------|-------|------------|
| 总线类型    | 低位地址        | 高位地址        | 容量          | 目标    | <b>备注</b>  |
| 数据      | 0x3FF6_7000 | 0x3FF6_7FFF | 4 KB        | I2C1  |            |
| 数据      | 0x3FF6_8000 | 0x3FF6_8FFF | 4 KB        | SDMMC |            |
| 数据      | 0x3FF6_9000 | 0x3FF6_AFFF | 8 KB        | EMAC  |            |
|         | 0x3FF6_B000 | 0x3FF6_BFFF | 4 KB        | 保留    |            |
| 数据      | 0x3FF6_C000 | 0x3FF6_CFFF | 4 KB        | PWM1  |            |
| 数据      | 0x3FF6_D000 | 0x3FF6_DFFF | 4 KB        | 12S1  |            |
| 数据      | 0x3FF6_E000 | 0x3FF6_EFFF | 4 KB        | UART2 |            |
| 数据      | 0x3FF6_F000 | 0x3FF6_FFFF | 4 KB        | PWM2  |            |
| 数据      | 0x3FF7_0000 | 0x3FF7_0FFF | 4 KB        | PWM3  |            |
|         | 0x3FF7_1000 | 0x3FF7_4FFF | 16 KB       | 保留    |            |
| 数据      | 0x3FF7_5000 | 0x3FF7_5FFF | 4 KB        | RNG   |            |
|         | 0x3FF7_6000 | 0x3FF7_FFFF | 40 KB       | 保留    |            |

## 1.3.4.1 不对称 PID Controller 外设

系统中有两个 PID Controller 分别服务于 PRO\_CPU 和 APP\_CPU **和 APP\_CPU 都只能访问自己的 PID Controller**,**不能访问对方的 PID Controller**。 两个 CPU 都使用数据总线 0x3FF1\_F000~3FF1\_FFFF 访问 自己的 PID Controller。

# 1.3.4.2 不连续外设地址范围

外设模块 SDIO Slave 被划分为三部分。两个 CPU 访问这三部分的地址是不连续的。这三部分分别被两个 CPU 的数据总线 0x3FF4\_B000~3FF4\_BFFF、0x3FF5\_5000~3FF5\_5FF、0x3FF5\_8000~3FF5\_8FFF 访问。和其他外设一样,SDIO Slave 能被两个 CPU 访问。

# 1.3.4.3 存储器速度

ROM 和 SRAM 的时钟源都是 CPU\_CLK, CPU 可在单个时钟周期内访问这两个存储器。由于 RTC FAST Memory 的时钟源是 APB\_CLOCK, RTC SLOW Memory 的时钟源是 FAST\_CLOCK, 所以 CPU 访问这两个存储器的速度稍慢。DMA 在 APB\_CLK 时钟下访问存储器。

SRAM 每 32K 为一个块。只要同时访问的是不同的块,那么 CPU 和 DMA 可以同时以最快速度访问 SRAM。

# 2. 中断矩阵

# 2.1 概述

ESP32 中断矩阵将任一外部中断源单独分配到每个 CPU 的任一外部中断上。这提供了强大的灵活性,能适应不同的应用需求。

# 2.2 主要特性

- 接受 71 个外部中断源作为输入
- 为两个 CPU 分别生成 26 个外部中断(总共 52 个)作为输出
- 屏蔽 CPU 的 NMI 类型中断
- 查询外部中断源当前的中断状态

中断矩阵的结构如图 3 所示。



图 3: 中断矩阵结构图

# 2.3 功能描述

### 2.3.1 外部中断源

ESP32 总共有 71 个外部中断源。表 6 列出了所有外部中断源。ESP32 中的 71 个外部中断源中有 67 个可以分配给两个 CPU。其余的 4 个外部中断源只能分配给特定的 CPU,每个 CPU 2 个。GPIO\_INTERRUPT\_PRO 和 GPIO\_INTERRUPT\_PRO\_NMI 只可以分配给 PRO\_CPU,GPIO\_INTERRUPT\_APP 和 GPIO\_INTERRUPT\_APP\_NMI 只可以分配给 APP\_CPU。因此,PRO\_CPU 与 APP\_CPU 各可以分配到 69 个外部中断源。

 $\sim$ 

中断矩阵

Espressif Systems

# 表 6: PRO\_CPU、APP\_CPU 外部中断配置寄存器、外部中断源中断状态寄存器、外部中断源

|                                                         |          | PRO_CPU               |          |                                                                                      |                    |          | APP_CPU               |     |                                                             |
|---------------------------------------------------------|----------|-----------------------|----------|--------------------------------------------------------------------------------------|--------------------|----------|-----------------------|-----|-------------------------------------------------------------|
| Peripheral Interrupt                                    |          |                       |          | Peripheral Intern                                                                    | upt Source         |          |                       |     | Peripheral Interrupt                                        |
| Configuration Register                                  |          | Status Register       | No.      | Name                                                                                 |                    | No.      | Status Register       |     | Configuration Register                                      |
| Corniguration negister                                  | Bit      | Name                  | INO.     | Name                                                                                 | <b>:</b>           | INO.     | Name                  | Bit | Corniguration Register                                      |
| PRO_MAC_INTR_MAP_REG                                    | 0        |                       | 0        | MAC_INTR                                                                             |                    | 0        |                       | 0   | APP_MAC_INTR_MAP_REG                                        |
| PRO_MAC_NMI_MAP_REG                                     | 1        |                       | 1        | MAC_N                                                                                | IMI                | 1        |                       | 1   | APP_MAC_NMI_MAP_REG                                         |
| PRO_BB_INT_MAP_REG                                      | 2        |                       | 2        | BB_IN                                                                                | Т                  | 2        |                       | 2   | APP_BB_INT_MAP_REG                                          |
| PRO_BT_MAC_INT_MAP_REG                                  | 3        |                       | 3        | BT_MAC_INT                                                                           |                    | 3        |                       | 3   | APP_BT_MAC_INT_MAP_REG                                      |
| PRO_BT_BB_INT_MAP_REG                                   | 4        |                       | 4        | BT_BB_INT                                                                            |                    | 4        |                       | 4   | APP_BT_BB_INT_MAP_REG                                       |
| PRO_BT_BB_NMI_MAP_REG                                   | 5        |                       | 5        | BT_BB_                                                                               |                    | 5        |                       | 5   | APP_BT_BB_NMI_MAP_REG                                       |
| PRO_RWBT_IRQ_MAP_REG                                    | 6        |                       | 6        | RWBT_I                                                                               |                    | 6        |                       | 6   | APP_RWBT_IRQ_MAP_REG                                        |
| PRO_BT_BB_NMI_MAP_REG                                   | 5        |                       | 5        | BT_BB_                                                                               |                    | 5        |                       | 5   | APP_BT_BB_NMI_MAP_REG                                       |
| PRO_RWBT_IRQ_MAP_REG                                    | 6        |                       | 6        | RWBT_I                                                                               |                    | 6        |                       | 6   | APP_RWBT_IRQ_MAP_REG                                        |
| PRO_RWBLE_IRQ_MAP_REG                                   | 7        |                       | 7        | RWBLE_                                                                               | •                  | 7        |                       | 7   | APP_RWBLE_IRQ_MAP_REG                                       |
| PRO_RWBT_NMI_MAP_REG                                    | 8        |                       | 8        | RWBT_1                                                                               |                    | 8        |                       | 8   | APP_RWBT_NMI_MAP_REG                                        |
| PRO_RWBLE_NMI_MAP_REG                                   | 9        |                       | 9        | RWBLE_                                                                               | •                  | 9        |                       | 9   | APP_RWBLE_NMI_MAP_REG                                       |
| PRO_SLCO_INTR_MAP_REG                                   | 10       |                       | 10       | SLCO_IN                                                                              |                    | 10       |                       | 10  | APP_SLC0_INTR_MAP_REG                                       |
| PRO_SLC1_INTR_MAP_REG                                   | 11       |                       | 11       | SLC1_IN                                                                              |                    | 11       |                       | 11  | APP_SLC1_INTR_MAP_REG                                       |
| PRO_UHCIO_INTR_MAP_REG PRO_UHCI1_INTR_MAP_REG           | 12       |                       | 12<br>13 | UHCIO_II UHCI1 II                                                                    |                    | 12<br>13 |                       | 12  | APP_UHCIO_INTR_MAP_REG  APP_UHCI1_INTR_MAP_REG              |
|                                                         | 13<br>14 | PRO_INTR_STATUS_REG_0 | 13       | TG TO LEV                                                                            |                    | 13       | APP_INTR_STATUS_REG_0 | 13  |                                                             |
| PRO_TG_TO_LEVEL_INT_MAP_REG PRO_TG_T1_LEVEL_INT_MAP_REG | 14       |                       | 14       | TG_T0_LEV                                                                            |                    | 14       |                       | 14  | APP_TG_T0_LEVEL_INT_MAP_REG  APP TG T1 LEVEL INT MAP REG    |
| PRO_TG_NT_LEVEL_INT_MAP_REG                             | 16       |                       | 16       | TG_WDT_LE                                                                            |                    | 16       |                       | 16  | APP_TG_NT_LEVEL_INT_MAP_REG  APP_TG_WDT_LEVEL_INT_MAP_REG   |
| PRO_TG_WDT_LEVEL_INT_WAP_REG                            | 17       |                       | 17       | TG_WDT_LE                                                                            |                    | 17       |                       | 17  | APP_IG_WDI_LEVEL_INT_MAP_REG  APP_TG_LACT_LEVEL_INT_MAP_REG |
| PRO TG1 TO LEVEL INT MAP REG                            | 18       |                       | 18       | TG1 T0 LEV                                                                           |                    | 18       |                       | 18  | APP TG1 TO LEVEL_INT_WAP_REG                                |
| PRO TG1 T1 LEVEL INT MAP REG                            | 19       |                       | 19       | TG1 T1 LEV                                                                           |                    | 19       |                       | 19  | APP TG1 T1 LEVEL INT MAP REG                                |
| PRO TG1 WDT LEVEL INT MAP REG                           | 20       |                       | 20       | TG1_VDT_LE                                                                           |                    | 20       |                       | 20  | APP TG1_VDT_LEVEL_INT_MAP_REG                               |
| PRO TG1 LACT LEVEL INT MAP REG                          | 21       |                       | 21       | TG1_LACT_LE                                                                          |                    | 21       |                       | 21  | APP TG1 LACT LEVEL INT MAP REG                              |
| PRO_GPIO_INTERRUPT_PRO_MAP_REG                          | 22       |                       | 22       | GPIO INTERRUPT PRO                                                                   | GPIO INTERRUPT APP | 22       |                       | 22  | APP_GPIO_INTERRUPT_APP_MAP_REG                              |
| PRO GPIO INTERRUPT PRO NMI MAP REG                      | 23       |                       | 23       | GPIO_INTERRUPT_PRO GPIO_INTERRUPT_APP  GPIO_INTERRUPT PRO_NMI GPIO_INTERRUPT APP NMI |                    | 23       |                       | 23  | APP GPIO INTERRUPT APP NMI MAP REG                          |
| PRO CPU INTR FROM CPU 0 MAP REG                         | 24       |                       | 24       | CPU INTR FRO                                                                         |                    | 24       |                       | 24  | APP CPU INTR FROM CPU 0 MAP REG                             |
| PRO CPU INTR FROM CPU 1 MAP REG                         | 25       |                       | 25       | CPU INTR FRO                                                                         |                    | 25       |                       | 25  | APP CPU INTR FROM CPU 1 MAP REG                             |
| PRO CPU INTR FROM CPU 2 MAP REG                         | 26       |                       | 26       | CPU INTR FRO                                                                         |                    | 26       |                       | 26  | APP CPU INTR FROM CPU 2 MAP REG                             |
| PRO CPU INTR FROM CPU 3 MAP REG                         | 27       |                       | 27       | CPU_INTR_FR0                                                                         |                    | 27       |                       | 27  | APP CPU INTR FROM CPU 3 MAP REG                             |
| PRO SPI INTR 0 MAP REG                                  | 28       |                       | 28       | SPI INTI                                                                             |                    | 28       |                       | 28  | APP SPI INTR 0 MAP REG                                      |
| PRO_SPI_INTR_1_MAP_REG                                  | 29       |                       | 29       | SPI INTI                                                                             |                    | 29       |                       | 29  | APP_SPI_INTR_1_MAP_REG                                      |
| PRO SPI INTR 2 MAP REG                                  | 30       |                       | 30       | SPI INTI                                                                             |                    | 30       |                       | 30  | APP SPI INTR 2 MAP REG                                      |
| PRO SPI INTR 3 MAP REG                                  | 31       |                       | 31       | SPI INTI                                                                             |                    | 31       |                       | 31  | APP SPI INTR 3 MAP REG                                      |
| PRO I2SO INT MAP REG                                    | 0        |                       | 32       | 1250 II                                                                              |                    | 32       |                       | 0   | APP I2SO INT MAP REG                                        |
| PRO I2S1 INT MAP REG                                    | 1        |                       | 33       | I2S1 II                                                                              |                    | 33       |                       | 1   | APP I2S1 INT MAP REG                                        |
| PRO_UART_INTR_MAP_REG                                   | 2        |                       | 34       | UART_IN                                                                              |                    | 34       |                       | 2   | APP_UART_INTR_MAP_REG                                       |
| PRO_UART1_INTR_MAP_REG                                  | 3        |                       | 35       | UART1_I                                                                              |                    | 35       |                       | 3   | APP_UART1_INTR_MAP_REG                                      |
| PRO_UART2_INTR_MAP_REG                                  | 4        |                       | 36       | UART2_I                                                                              |                    | 36       |                       | 4   | APP_UART2_INTR_MAP_REG                                      |
| PRO_SDIO_HOST_INTERRUPT_MAP_REG                         | 5        |                       | 37       | SDIO_HOST_IN                                                                         |                    | 37       |                       | 5   | APP_SDIO_HOST_INTERRUPT_MAP_REG                             |
| PRO_EMAC_INT_MAP_REG                                    | 6        |                       | 38       | EMAC_I                                                                               |                    | 38       |                       | 6   | APP_EMAC_INT_MAP_REG                                        |
| PRO_PWM0_INTR_MAP_REG                                   | 7        |                       | 39       | PWM0_II                                                                              | NTR                | 39       |                       | 7   | APP_PWM0_INTR_MAP_REG                                       |
| PRO_PWM1_INTR_MAP_REG                                   | 8        |                       | 40       | PWM1_II                                                                              | NTR                | 40       |                       | 8   | APP_PWM1_INTR_MAP_REG                                       |
| PRO_PWM2_INTR_MAP_REG                                   | 9        |                       | 41       | PWM2_INTR                                                                            |                    | 41       |                       | 9   | APP_PWM2_INTR_MAP_REG                                       |
| PRO_PWM3_INTR_MAP_REG                                   | 10       | PRO_INTR_STATUS_REG_1 | 42       | PWM3_INTR                                                                            |                    | 42       | APP_INTR_STATUS_REG_1 | 10  | APP_PWM3_INTR_MAP_REG                                       |
| PRO_LEDC_INT_MAP_REG                                    | 11       | 1                     | 43       | LEDC_INT                                                                             |                    | 43       | ]                     | 11  | APP_LEDC_INT_MAP_REG                                        |
| PRO_EFUSE_INT_MAP_REG                                   | 12       |                       | 44       | EFUSE_INT                                                                            |                    | 44       |                       | 12  | APP_EFUSE_INT_MAP_REG                                       |
| PRO_CAN_INT_MAP_REG                                     | 13       |                       | 45       | CAN_INT                                                                              |                    | 45       |                       | 13  | APP_CAN_INT_MAP_REG                                         |
| PRO_RTC_CORE_INTR_MAP_REG                               | 14       |                       | 46       | RTC_CORE_INTR                                                                        |                    | 46       |                       | 14  | APP_RTC_CORE_INTR_MAP_REG                                   |
| PRO_RMT_INTR_MAP_REG                                    | 15       |                       | 47       | RMT_INTR                                                                             |                    | 47       |                       | 15  | APP_RMT_INTR_MAP_REG                                        |
| PRO_PCNT_INTR_MAP_REG                                   | 16       |                       | 48       | PCNT_IN                                                                              |                    | 48       |                       | 16  | APP_PCNT_INTR_MAP_REG                                       |
| PRO_I2C_EXT0_INTR_MAP_REG                               | 17       |                       | 49       | I2C_EXT0_                                                                            |                    | 49       |                       | 17  | APP_I2C_EXT0_INTR_MAP_REG                                   |
| PRO_I2C_EXT1_INTR_MAP_REG                               | 18       |                       | 50       | I2C_EXT1_                                                                            | INTR               | 50       |                       | 18  | APP_I2C_EXT1_INTR_MAP_REG                                   |
| PRO_RSA_INTR_MAP_REG                                    | 19       |                       | 51       | RSA_IN                                                                               |                    | 51       |                       | 19  | APP_RSA_INTR_MAP_REG                                        |
| PRO SPI1 DMA INT MAP REG                                | 20       | l .                   | 52       | SPI1 DMA                                                                             | A INT              | 52       | I                     | 20  | APP SPI1 DMA INT MAP REG                                    |

|                               |     | PRO_CPU               |          |                                                  | APP_CPU  |      |                       |     |                               |
|-------------------------------|-----|-----------------------|----------|--------------------------------------------------|----------|------|-----------------------|-----|-------------------------------|
| Peripheral Interrupt          |     |                       |          | Peripheral Interrupt Source Peripheral Interrupt |          |      |                       |     |                               |
|                               |     | Status Register       | No.      | Nar                                              | ma       | No.  | Status Register       |     | Configuration Register        |
| Configuration Register        | Bit | Name                  | INO.     | Nati                                             | ne       | INO. | Name                  | Bit | Corniguration negister        |
| PRO_SPI2_DMA_INT_MAP_REG      | 21  |                       | 53       | SPI2_DN                                          | MA_INT   | 53   |                       | 21  | APP_SPI2_DMA_INT_MAP_REG      |
| PRO_SPI3_DMA_INT_MAP_REG      | 22  |                       | 54       | SPI3_DN                                          | MA_INT   | 54   |                       | 22  | APP_SPI3_DMA_INT_MAP_REG      |
| PRO_WDG_INT_MAP_REG           | 23  |                       | 55       | WDG.                                             | INT      | 55   |                       | 23  | APP_WDG_INT_MAP_REG           |
| PRO_TIMER_INT1_MAP_REG        | 24  |                       | 56       | TIMER                                            | _INT1    | 56   |                       | 24  | APP_TIMER_INT1_MAP_REG        |
| PRO_TIMER_INT2_MAP_REG        | 25  |                       | 57 TIMER |                                                  | _INT2    | 57   | ı                     | 25  | APP_TIMER_INT2_MAP_REG        |
| PRO_TG_T0_EDGE_INT_MAP_REG    | 26  | PRO_INTR_STATUS_REG_1 | 58       | TG_T0_EL                                         | DGE_INT  | 58   | APP_INTR_STATUS_REG_1 | 26  | APP_TG_T0_EDGE_INT_MAP_REG    |
| PRO_TG_T1_EDGE_INT_MAP_REG    | 27  |                       | 59       | TG_T1_E                                          | DGE_INT  | 59   |                       | 27  | APP_TG_T1_EDGE_INT_MAP_REG    |
| PRO_TG_WDT_EDGE_INT_MAP_REG   | 28  |                       | 60       | TG_WDT_E                                         | EDGE_INT | 60   |                       | 28  | APP_TG_WDT_EDGE_INT_MAP_REG   |
| PRO_TG_LACT_EDGE_INT_MAP_REG  | 29  |                       | 61       | TG_LACT_I                                        | EDGE_INT | 61   |                       | 29  | APP_TG_LACT_EDGE_INT_MAP_REG  |
| PRO_TG1_T0_EDGE_INT_MAP_REG   | 30  |                       | 62       | TG1_T0_E                                         | DGE_INT  | 62   |                       | 30  | APP_TG1_T0_EDGE_INT_MAP_REG   |
| PRO_TG1_T1_EDGE_INT_MAP_REG   | 31  |                       | 63       | TG1_T1_E                                         | DGE_INT  | 63   |                       | 31  | APP_TG1_T1_EDGE_INT_MAP_REG   |
| PRO_TG1_WDT_EDGE_INT_MAP_REG  | 0   |                       | 64       | TG1_WDT_                                         | EDGE_INT | 64   |                       | 0   | APP_TG1_WDT_EDGE_INT_MAP_REG  |
| PRO_TG1_LACT_EDGE_INT_MAP_REG | 1   |                       | 65       | TG1_LACT_                                        | EDGE_INT | 65   |                       | 1   | APP_TG1_LACT_EDGE_INT_MAP_REG |
| PRO_MMU_IA_INT_MAP_REG        | 2   | PRO_INTR_STATUS_REG_2 | 66       | MMU_I                                            | A_INT    | 66   | APP_INTR_STATUS_REG_2 | 2   | APP_MMU_IA_INT_MAP_REG        |
| PRO_MPU_IA_INT_MAP_REG        | 3   |                       | 67       | MPU_I.                                           | A_INT    | 67   |                       | 3   | APP_MPU_IA_INT_MAP_REG        |
| PRO_CACHE_IA_INT_MAP_REG      | 4   |                       | 68       | CACHE_                                           | IA_INT   | 68   |                       | 4   | APP_CACHE_IA_INT_MAP_REG      |

2.3 功能描述

2.3 功能描述 2 中断矩阵

# 2.3.2 CPU 中断

两个 CPU (PRO\_CPU 和 APP\_CPU) 各有 32 个中断,其中 26 个为外部中断。表 7 列出了每个 CPU 所有的中断。

表 7: CPU 中断

| 编号 | 类别   | 种类    | 优先级 |
|----|------|-------|-----|
| 0  | 外部中断 | 电平触发  | 1   |
| 1  | 外部中断 | 电平触发  | 1   |
| 2  | 外部中断 | 电平触发  | 1   |
| 3  | 外部中断 | 电平触发  | 1   |
| 4  | 外部中断 | 电平触发  | 1   |
| 5  | 外部中断 | 电平触发  | 1   |
| 6  | 内部中断 | 定时器 0 | 1   |
| 7  | 内部中断 | 软件    | 1   |
| 8  | 外部中断 | 电平触发  | 1   |
| 9  | 外部中断 | 电平触发  | 1   |
| 10 | 外部中断 | 边沿触发  | 1   |
| 11 | 内部中断 | 解析    | 3   |
| 12 | 外部中断 | 电平触发  | 1   |
| 13 | 外部中断 | 电平触发  | 1   |
| 14 | 外部中断 | NMI   | NMI |
| 15 | 内部中断 | 定时器 1 | 3   |
| 16 | 内部中断 | 定时器 2 | 5   |
| 17 | 外部中断 | 电平触发  | 1   |
| 18 | 外部中断 | 电平触发  | 1   |
| 19 | 外部中断 | 电平触发  | 2   |
| 20 | 外部中断 | 电平触发  | 2   |
| 21 | 外部中断 | 电平触发  | 2   |
| 22 | 外部中断 | 边沿触发  | 3   |
| 23 | 外部中断 | 电平触发  | 3   |
| 24 | 外部中断 | 电平触发  | 4   |
| 25 | 外部中断 | 电平触发  | 4   |
| 26 | 外部中断 | 电平触发  | 5   |
| 27 | 外部中断 | 电平触发  | 3   |
| 28 | 外部中断 | 边沿触发  | 4   |
| 29 | 内部中断 | 软件    | 3   |
| 30 | 外部中断 | 边沿触发  | 4   |
| 31 | 外部中断 | 电平触发  | 5   |

# 2.3.3 分配外部中断源至 CPU 外部中断

在本小节中:

- 记号 Source\_X 代表某个外部中断源。
- 记号 PRO\_X\_MAP\_REG (或 APP\_X\_MAP\_REG) 表示 PRO\_CPU (或 APP\_CPU) 的某个外部中断配置

2.3 功能描述 2 中断矩阵

寄存器,且此外部中断配置寄存器与外部中断源 Source\_X 相对应。即表 6 中 "PRO\_CPU (APP\_CPU) - Peripheral Interrupt Configuration Register"—列中与 "Peripheral Interrupt Source - Name"—列中的某个外部中断源处于同一行的寄存器。

- 记号 Interrupt\_P 表示 CPU 中断序号为 Num\_P 的外部中断, Num\_P 的取值范围为 0 ~ 5、8 ~ 10、12 ~ 14、17 ~ 28、30 ~ 31。
- 记号 Interrupt\_I 表示 CPU 中断序号为 Num\_I 的内部中断, Num\_I 的取值范围为 6、7、11、15、16、29。借助以上术语,可以这样描述中断矩阵控制器操作:
  - 将外部中断源 Source\_X 分配到 CPU (PRO\_CPU 或 APP\_CPU)
     将寄存器 PRO\_X\_MAP\_REG (APP\_X\_MAP\_REG) 配成 Num\_P。Num\_P 可以取任意 CPU 外部中断值。
     CPU 中断可以被多个外设共享(见下文)。
  - 关闭 CPU (PRO\_CPU 或 APP\_CPU) 外部中断源 Source\_X 将寄存器 PRO\_X\_MAP\_REG (APP\_X\_MAP\_REG) 配成任意 Num\_I。由于任何被配成 Num\_I 的中断都没 有连接到 2 个 CPU 上,选择特定内部中断值不会造成影响。
  - **将多个外部中断源 Source\_Xn ORed 分配到 PRO\_CPU (APP\_CPU) 的外部中断** 将各个寄存器 PRO\_Xn\_MAP\_REG (APP\_Xn\_MAP\_REG) 都配成同样的 Num\_P。这些外设中断都会触发 CPU Interrupt P。

# 2.3.4 屏蔽 CPU 的 NMI 类型中断

中断矩阵能够根据信号 PRO\_CPU NMI Interrupt Mask(或 APP\_CPU NMI Interrupt Mask)暂时屏蔽所有被分配到 PRO\_CPU(或 APP\_CPU)的外部中断源的 NMI 中断。信号 PRO\_CPU NMI Interrupt Mask 和 APP\_CPU NMI Interrupt Mask 分别来自外设 PID Controller。

# 2.3.5 查询外部中断源当前的中断状态

读寄存器 PRO\_INTR\_STATUS\_REG\_n (APP\_INTR\_STATUS\_REG\_n) 中的特定 Bit 值就可以获知外部中断源当前的中断状态。寄存器 PRO\_INTR\_STATUS\_REG\_n (APP\_INTR\_STATUS\_REG\_n) 与外部中断源的对应关系如表 6 所示。

# 3. 复位和时钟

# 3.1 System 复位

### 3.1.1 概述

系统提供三种级别的复位方式,分别是 CPU 复位,内核复位,系统复位。

所有的复位都不会影响 MEM 中的数据。图 4 展示了整个子系统的结构以及每种复位方式:



图 4: 系统复位

- CPU 复位: 只复位 CPU 的所有寄存器。
- 内核复位:除了 RTC,会把整个 digital 的寄存器全部复位,包括 CPU、所有外设和数字 GPIO。
- 系统复位: 会复位整个芯片所有的寄存器, 包括 RTC。

# 3.1.2 复位源

大多数情况下, APP\_CPU 和 PRO\_CPU 将被立刻复位, 有些复位源只能复位其中一个。APP\_CPU 和 PRO\_CPU 的复位原因也各自不同: 当系统复位起来之后, PRO CPU 可以通过读取寄存器; RTC\_CNTL\_RESET\_CAUSE\_PROCPU 来获取复位源, APP CPU 则可以通过读取寄存器; APP\_CNTL\_RESET\_CAUSE\_PROCPU 来获取复位源。

表 8: PRO CPU 和 APP CPU 复位源

表8列出了从这些寄存器中可能读出的复位源。

| 源 | 复位方式 | 注释 |  |
|---|------|----|--|

| PRO  | APP  | 源               | 复位方式 | 注释                         |
|------|------|-----------------|------|----------------------------|
| 0x01 | 0x01 | 芯片上电复位          | 系统复位 | -                          |
| 0x10 | 0x10 | RWDT 系统复位       | 系统复位 | 详见 WDT 章节                  |
| 0x0F | 0x0F | 欠压复位            | 系统复位 | 详见 Power Management 章节     |
| 0x03 | 0x03 | 软件系统复位          | 内核复位 | 配置 RTC_CNTL_SW_SYS_RST 寄存器 |
| 0x05 | 0x05 | Deep Sleep Rest | 内核复位 | 详见 Power Management 章节     |
| 0x07 | 0x07 | MWDT0 全局复位      | 内核复位 | 详见 WDT 章节                  |

| PRO  | APP  | 源            | 复位方式   | 注释                             |
|------|------|--------------|--------|--------------------------------|
| 0x08 | 0x08 | MWDT1 全局复位   | 内核复位   | 详见 WDT 章节                      |
| 0x09 | 0x09 | RWDT 内核复位    | 内核复位   | 详见 WDT 章节                      |
| 0x0B | -    | MWDT0 CPU 复位 | CPU 复位 | 详见 WDT 章节                      |
| 0x0C | -    | 软件 CPU 复位    | CPU 复位 | 配置 RTC_CNTL_SW_APPCPU_RST 寄存器  |
| -    | 0x0B | MWDT1 CPU 复位 | CPU 复位 | 详见 WDT 章节                      |
| -    | 0x0C | 软件 CPU 复位    | CPU 复位 | 配置 RTC_CNTL_SW_APPCPU_RST 寄存器  |
| 0x0D | 0x0D | RWDT CPU 复位  | CPU 复位 | 详见 WDT 章节                      |
|      |      |              |        | 表明 PRO CPU 能够通过配置              |
| _    | 0xE  | PRO CPU 复位   | CPU 复位 | DPORT_APPCPU_RESETTING 寄存器单独复位 |
|      |      |              |        | APP CPU                        |

# 3.2 系统时钟

# 3.2.1 概述

ESP32 提供了多种不同频率的时钟选择,可以灵活的配置 CPU,外设,以及 RTC 的工作频率,以满足不同功耗和性能需求。下图 5 为系统时钟结构。



图 5: 系统时钟

### 3.2.2 时钟源

ESP32 的时钟源分别来自外部晶振、内部 PLL 或震荡电路。具体地说,这些时钟源为:

- 快速时钟
  - PLL\_CLK, 320 MHz 内部 PLL 时钟
  - XTL CLK, 2~40 MHz 外部晶振时钟
- 低功耗慢速时钟
  - XTL32K\_CLK, 32 KHz 外部晶振时钟
  - RTC8M\_CLK, 8 MHz 内部时钟, 频率可调
  - RTC8M\_D256\_CLK 由 RTC8M\_CLK 256 分频所得, 频率为 (RTC8M\_CLK 256)。当 RTC8M\_CLK 的 初始频率为 8 MHz 时, 该时钟以 31.250 KHz 的频率运行。
  - RTC\_CLK, 150 KHz 内部低功耗时钟, 频率可调
- 音频时钟
  - APLL\_CLK, 16~128 MHz 内部 Audio PLL 时钟

### 3.2.3 CPU 时钟

如图5所示, CPU\_CLK 为 CPU 主时钟,它在高效工作模式下,主频可以达到 160 MHz。同时, CPU 能够在超低频下工作,以减少功耗。

CPU\_CLK由RTC\_CNTL\_SOC\_CLK\_SEL来选择时钟源,允许选择PLL\_CLK,APLL\_CLK,RTC8M\_CLK,XTL\_CLK作为CPU\_CLK的时钟源。具体请参考表 9 和表 10。

表 9: CPU\_CLK 源

| RTC_CNTL_SOC_CLK_SEL 值 | 时钟源       |
|------------------------|-----------|
| 0                      | XTL_CLK   |
| 1                      | PLL_CLK   |
| 2                      | RTC8M_CLK |
| 3                      | APLL_CLK  |

表 10: CPU\_CLK 源

| 时钟源            | SEL* | CPU 时钟                                         |
|----------------|------|------------------------------------------------|
| O / VTI OLIZ   |      | CPU_CLK = XTL_CLK / (APB_CTRL_PRE_DIV_CNT+1)   |
| 0/XTL_CLK      | -    | APB_CTL_PRE_DIV_CNT 默认值为 0,范围 0~1023。          |
| 1 / DLL CLK    | 0    | CPU_CLK = PLL_CLK / 4                          |
| 1 / PLL_CLK    | 0    | CPU_CLK 频率为 80 MHz。                            |
| 1 / DLL CLK    | 4    | CPU_CLK = PLL_CLK / 2                          |
| 1 / PLL_CLK    |      | CPU_CLK 频率为 160 MHz。                           |
| O / DTCOM CLIZ |      | CPU_CLK = RTC8M_CLK / (APB_CTRL_PRE_DIV_CNT+1) |
| 2 / RTC8M_CLK  | -    | APB_CTL_PRE_DIV_CNT 默认值为 0,范围 0~1023。          |
| 3 / APLL_CLK   | 0    | CPU_CLK = APLL_CLK / 4。                        |
| 3 / APLL_CLK   | 1    | CPU_CLK = APLL_CLK / 2。                        |

\*SEL: DPORT\_CPUPERIOD \_SEL 值

# 3.2.4 外设时钟

外设所需要的时钟包括 APB\_CLK, REF\_TICK, LEDC\_SCLK, APLL\_CLK 和 PLL\_D2\_CLK。下表 11 为接入各个外设的时钟。

表 11: 外设时钟用法

| 外设               | APB_CLK | REF_TICK | LEDC_SCLK | APLL_CLK | PLL_D2_CLK |
|------------------|---------|----------|-----------|----------|------------|
| EMAC             | Υ       | N        | N         | Υ        | N          |
| TIMG             | Υ       | N        | N         | N        | N          |
| I2S              | Υ       | N        | N         | Υ        | Υ          |
| UART             | Υ       | Υ        | N         | N        | N          |
| RMT              | Υ       | Υ        | N         | N        | N          |
| LED PWM          | Υ       | Υ        | Υ         | N        | N          |
| PWM              | Υ       | N        | N         | N        | N          |
| I2C              | Υ       | N        | N         | N        | N          |
| SPI              | Υ       | N        | N         | N        | N          |
| PCNT             | Υ       | N        | N         | N        | N          |
| Efuse Controller | Υ       | N        | N         | N        | N          |
| SDIO Slave       | Υ       | N        | N         | N        | N          |
| SDMMC            | Υ       | N        | N         | N        | N          |

# 3.2.4.1 APB\_CLK 源

如表 12 所示,APB\_CLK 由 CPU\_CLK 产生,分频系数由 CPU\_CLK 源决定:

3.2 系统时钟 3.2 系统时钟 3 复位和时钟

表 12: APB\_CLK 源

| CPU_CLK 源 | APB_CLK     |
|-----------|-------------|
| PLL_CLK   | CPU_CLK / 2 |
| APLL_CLK  | CPU_CLK / 2 |
| XTAL_CLK  | CPU_CLK     |
| RTC8M_CLK | CPU_CLK     |

# 3.2.4.2 REF\_TICK 源

REF\_TICK 由 APB\_CLK 分频产生,分频值由 APB\_CLK 源和 CPU\_CLK 源共同决定。用户通过配置合理的分频系数,可以保证 REF\_TICK 在 APB\_CLK 切换时维持频率不变。寄存器配置如表 13 所示:

表 13: REF\_TICK 源

| CPU_CLK & APB_CLK 源 | 时钟分频寄存器                |
|---------------------|------------------------|
| PLL_CLK             | APB_CTRL_PLL_TICK_NUM  |
| XTAL_CLK            | APB_CTRL_XTAL_TICK_NUM |
| APLL_CLK            | APB_CTRL_APLL_TICK_NUM |
| RTC8M_CLK           | APB_CTRL_CK8M_TICK_NUM |

## 3.2.4.3 LEDC\_SCLK 源

LEDC\_SCLK 时钟源由寄存器 LEDC\_APB\_CLK\_SEL 决定,如表 14 所示。

表 14: LEDC\_SCLK 源

| LEDC_APB_CLK_SEL 值 | LEDC_SCLK 源 |
|--------------------|-------------|
| 1                  | RTC8M_CLK   |
| 0                  | APB_CLK     |

### 3.2.4.4 APLL\_SCLK 源

APLL\_CLK 来自内部 PLL\_CLK, 其输出频率通过使用 APLL 配置寄存器来配置。

# 3.2.4.5 PLL\_D2\_CLK 源

PLL\_D2\_CLK 是 PLL\_CLK 的二分频时钟。

### 3.2.4.6 时钟源注意事项

大多数外设一般在选择 PLL\_CLK 时钟源的情况下工作。若频率发生变化,外设需要通过修改配置才能以同样的频率工作。接入 REF\_TICK 的外设允许在切换时钟源的情况下,不修改外设配置即可工作。详情请参考表 11。

LED PWM 模块能将 RTC8M\_CLK 作为时钟源使用,即在 APB\_CLK 关闭的时候,LED PWM 也可工作。换而言之,当系统处于低功耗模式时(参考 Power Management 模块),所有正常外设都将停止工作(APB\_CLK 关闭),但是 LED PWM 仍然可以通过 RTC8M\_CLK 来正常工作。

## 3.2.5 Wi-Fi BT 时钟

Wi-Fi 和 BT 必须在 APB\_CLK 时钟源选择 PLL\_CLK 下才能工作。只有当 Wi-Fi 和 BT 同时进入低功耗模式时,才能暂时关闭 PLL\_CLK。

LOW\_POWER\_CLK 允许选择 RTC\_CLK、SLOW\_CLK、RTC8M\_CLK 或 XTL\_CLK,用于 Wi-Fi 和 BT 的低功耗模式。

# 3.2.6 RTC 时钟

SLOW\_CLK 和 FAST\_CLK 的时钟源为低频时钟。RTC 模块能够在大多数时钟源关闭的状态下工作。

SLOW\_CLK 允许选择 RTC\_CLK, XTL32K\_CLK 或 RTC8M\_D256\_CLK, 用于驱动 Power Management 模块。

FAST\_CLK 允许选择 XTL\_CLK 的分频时钟或 RTC8M\_CLK, 用于驱动 On-chip Sensor 模块。

# 4. IO\_MUX 和 GPIO 交换矩阵

# 4.1 概述

ESP32 芯片有 40 个物理 GPIO pad,有部分 GPIO pad 不可用或者没有对应的芯片封装上的管脚。每个 pad 都可用作一个通用 IO,或连接一个内部的外设信号。IO\_MUX、RTC IO\_MUX 和 GPIO 交换矩阵用于将信号从外设传输至 GPIO pad。这些模块共同组成了芯片的 IO 控制。

此章内容描述了数字 pad(控制信号: FUNC\_SEL、IE、OE、WPU、WDU等)和 256 个外设输入 / 输出信号(控制信号: SIG\_IN\_SEL、SIG\_OUT\_SEL、IE、OE等)和快速外设输入 / 输出信号(控制信号: IE、OE等)以及 RTC IO\_MUX 之间的信号选择和连接关系。



图 6: IO MUX、RTC IO MUX 和 GPIO 交换矩阵结构框图

1. IO\_MUX 中每个 GPIO pad 有一组寄存器。每个 pad 可以配置成 GPIO 功能(连接 GPIO 交换矩阵)或者 直连功能(旁路 GPIO 交换矩阵,快速信号如以太网、SDIO、SPI、JTAG、UART 等会旁路 GPIO 交换矩 阵以实现更好的高频数字特性。所以高速信号会直接通过 IO\_MUX 输入和输出。)

章节 4.10 列出了所有 GPIO pad 的 IO\_MUX 功能。

- 2. GPIO 交换矩阵是外设输入和输出信号和 pad 之间的全交换矩阵。
  - 芯片输入方向: 256 个外设输入信号都可以选择任意一个 GPIO pad 的输入信号。
  - 芯片输出方向:每个 GPIO pad 的输出信号可来自 256 个外设输出信号中的任意一个。

章节 4.9 列出了 GPIO 交换矩阵的外设信号。

3. RTC IO\_MUX 用于控制 GPIO pad 的低功耗和模拟功能。只有部分 GPIO pad 具有这些功能。 章节 4.11 列出了 RTC IO\_MUX 功能。

# 4.2 通过 GPIO 交换矩阵的外设输入

## 4.2.1 概述

为实现通过 GPIO 交换矩阵接收外设输入信号,需要配置 GPIO 交换矩阵从 40 个 GPIO (0-39) 中获取外设输入信号的索引号 (0-255)。

输入信号通过 IO\_MUX 从 GPIO pad 中读取。IO\_MUX 必须设置相应 pad 为 GPIO 功能。这样 GPIO pad 的输入信号就可进入 GPIO 交换矩阵然后通过 GPIO 交换矩阵进入选择的外设输入。

## 4.2.2 功能描述

图 7 为通过 GPIO 交换矩阵的外设输入的示意图。



图 7: 通过 IO\_MUX、GPIO 交换矩阵的外设输入

把某个外设信号 Y 绑定到某个 GPIO pad X 的配置过程为:

- 1. 在 GPIO 交换矩阵中配置外设信号 Y 的 GPIO\_FUNCy\_IN\_SEL\_CFG 寄存器:
  - 设置 GPIO\_FUNCx\_IN\_SEL 字段为要读取的 GPIO pad X 的值。
- 2. 在 GPIO 交换矩阵中配置 GPIO pad X 的 GPIO\_FUNCx\_OUT\_SEL\_CFG 寄存器和 GPIO\_ENABLE\_DATA[x] 寄存器:
  - 若为纯单向数据输入,则可以关闭输出:将 GPIO\_FUNCx\_OEN\_SEL 位置为 1,并且将 GPIO\_ENABLE\_DATA[x] 寄存器置为 0。否则,不需要关闭输出。
- 3. 配置 GPIO pad X 的 IO\_MUX 寄存器:
  - 设置功能字段为 GPIO。
  - 置位 XX\_FUN\_IE 使能输入。
  - 设置 xx\_FUN\_WPU 和 xx\_FUN\_WPD 字段为需要的值,使能内部上拉 / 下拉电阻器。

#### 说明:

• 同一个输入 pad 上可以同时绑定多个内部 input\_signals。

- 置位 GPIO\_FUNCx\_IN\_INV\_SEL 可以把输入的信号取反。
- 无需将输入信号绑定到一个 pad 也可以使外设读取恒低或恒高电平的输入值。实现方式为选择特定的 GPIO\_FUNCy\_IN\_SEL 输入值而不是一个 GPIO 序号:
  - 当 GPIO\_FUNCx\_IN\_SEL 是 0x30 时, input\_signal\_x 始终为 0。
  - 当 GPIO\_FUNCx\_IN\_SEL 是 0x38 时, input\_signal\_x 始终为 1。

## 4.2.3 简单 GPIO 输入

GPIO\_IN\_DATA 寄存器存储着每一个 GPIO pad 的输入值。

任意 GPIO pin 的输入值都可以随时读取而无需为某一个外设信号配置 GPIO 交换矩阵。但是需要为 pad X 配置 XX\_FUN\_IE 寄存器,如章节 4.2.2 所述。

# 4.3 通过 GPIO 交换矩阵的外设输出

# 4.3.1 概述

为实现通过 GPIO 交换矩阵输出外设信号,需要配置 GPIO 交换矩阵将输出索引号(0-255)的外设信号输出到前 34 个(0-33)GPIO。GPIO pad 34-39 不能用于输出信号。

输出信号从外设输出到 GPIO 交换矩阵,然后到达 IO\_MUX。IO\_MUX 必须设置相应 pad 为 GPIO 功能。这样输出 GPIO 信号就能连接到相应 pad。

#### 4.3.2 功能描述

图 8 所示为 256 个输入信号中的某一个信号通过 GPIO 交换矩阵到达 IO\_MUX 然后连接到某个 pad。



图 8: 通过 GPIO 交换矩阵输出信号

输出外设信号 Y 到某一 GPIO pad X 的步骤为:

1. 在 GPIO 交换矩阵里配置 GPIO X 的 GPIO\_FUNCx\_OUT\_SEL\_CFG 寄存器和 GPIO\_ENABLE\_DATA[x] 寄存器:

- 设置 GPIO\_FUNCx\_OUT\_SEL 为外设输出信号 Y的索引号。
- 置位 GPIO\_FUNCx\_OEN\_SEL 和 GPIO\_ENABLE\_DATA[x], 此设置为强制使能输出模式;或者将 GPIO\_FUNCx\_OEN\_SEL 清零,此时输出使能信号由内部逻辑功能决定。
- 2. 可以通过设置 GPIO\_PINx 寄存器中的 GPIO\_PINx\_PAD\_DRIVER 位来选择是否以开漏方式输出。
- 3. 配置 GPIO pad X 的 I/O Mux 寄存器:
  - 设置功能字段为 GPIO。
  - 设置 xx\_FUN\_DRV 字段为特定的输出强度值,值越大,输出驱动能力越强。在开漏模式下,通过配置 xx\_FUNC\_WPU 和 xx\_FUNC\_WPD 寄存器上拉 / 下拉 pad。

#### 说明:

- 某一个外设的输出信号可以同时从多个 pad 输出。
- 只有前 34 个 GPIO (0-33) 可以用于输出信号。
- 置位 GPIO\_FUNCx\_OUT\_INV\_SEL 可以把输出的信号取反。

### 4.3.3 简单 GPIO 输出

GPIO 交换矩阵也可以用于简单 GPIO 输出。设置 GPIO\_OUT\_DATA 寄存器中某一位的值可以写入对应的 GPIO pad。

为实现某一 pad 的 GPIO 输出,设置 GPIO 交换矩阵 GPIO\_FUNCx\_OUT\_SEL 寄存器为特定的外设索引值 256 (0x100)。

# 4.4 IO\_MUX 的直接 I/O 功能

### 4.4.1 概述

快速信号如以太网、SDIO、SPI、JTAG、UART等会旁路 GPIO 交换矩阵以实现更好的高频数字特性。所以高速信号会直接通过 IO\_MUX 输入和输出。

这样比使用 GPIO 交换矩阵的灵活度要低,即每个 GPIO pad 的 IO\_MUX 寄存器只有较少的功能选择,但可以实现更好的高频数字特性。

### 4.4.2 功能描述

为实现外设 I/O 旁路 GPIO 交换矩阵必须配置两个寄存器:

- 1. GPIO pad 的 IO\_MUX 必须设置为相应的 pad 功能,章节 4.10 列出了 pad 功能。
- 2. 对于输入信号,必须置位 SIG\_IN\_SEL 寄存器,直接将输入信号输出到外设。

# 4.5 RTC IO\_MUX 的低功耗和模拟 I/O 功能

### 4.5.1 概述

18 个管脚具有低功耗(低功耗 RTC)性能和模拟功能,由 ESP32的 RTC 子系统控制。这些功能不使用 IO\_MUX和 GPIO 交换矩阵,而是使用 RTC\_MUX 将 I/O 指向 RTC 子系统。

当这些管脚被配置为 RTC GPIO 管脚,作为输出管脚时仍然能够在芯片处于 Deep-sleep 睡眠模式下保持输出电平值或者作为输入管脚使用时可以将芯片从 Deep-sleep 中唤醒。

章节 4.11 列出了 RTC\_MUX 管脚和功能。

# 4.5.2 功能描述

每个 pad 的模拟和 RTC 功能是由 RTC\_GPIO\_PINx 寄存器中的 RTC\_IO\_TOUCH\_PADx\_TO\_GPIO 位控制的。此位默认置为 1,通过 IO\_MUX 子系统输入输出信号,如前文所述。

如果清零 RTC\_IO\_TOUCH\_PADx\_TO\_GPIO 位,则输入输出信号会经过 RTC 子系统。在这种模式下,RTC\_GPIO\_PINx 寄存器用于数字 I/O,pad 的模拟功能也可以实现。章节 4.11 列出了 RTC 管脚的功能。

表 4.11 列出了 GPIO pad 与相应的 RTC 管脚和模拟功能的映射关系。请注意 RTC\_IO\_PINx 寄存器使用的是 RTC GPIO 管脚的序号,不是 GPIO pad 的序号。

# 4.6 Light-sleep 模式管脚功能

当 ESP32 处于 Light-sleep 模式时管脚可以有不同的功能。如果某一 GPIO pad 的 IO\_MUX 寄存器中 GPIOxx\_SLP\_SEL 位置为 1, 芯片处于 Light-sleep 模式下将由另一组不同的寄存器控制 pad。

正常工作模式 Light-sleep 模式 IO MUX 功能 或者 GPIOxx\_SLP\_SEL = 0 并且 GPIOxx\_SLP\_SEL = 1 Output Drive Strength GPIOXX FUNC DRV GPIOXX MCU DRV Pullup Resistor GPIOXX\_FUNC\_WPU GPIOXX\_MCU\_WPU GPIOXX MCU WPD Pulldown Resistor GPIOXX FUNC WPD Output Enable (From GPIO Matrix \_OEN field) GPIXX MCU OE

表 15: IO\_MUX Light-sleep 管脚功能寄存器

如果 GPIOxx\_SLP\_SEL 置为 0,则芯片在正常工作和 Light-sleep 模式下,管脚的功能一样。

# 4.7 Pad Hold 特性

每个 IO pad(包括 RTC pad)都有单独的 hold 功能,由 RTC 寄存器控制。pad 的 hold 功能被置上后,pad 在置上 hold 那一刻的状态被强制保持,无论内部信号如何变化,修改 IO\_MUX 配置或者 GPIO 配置,都不会改变 pad 的状态。应用如果希望在看门狗超时触发内核复位和系统复位时或者 Deep-sleep 时 pad 的状态不被改变,就需要提前把 hold 置上。

# 4.8 I/O Pad 供电

IO pad 供电如图 9 所示。



图 9: ESP32 I/O Pad 供电源

- 蓝色的 pad 为 RTC pad,它们都带有一种或几种模拟功能,也可以用作为正常数字 IO pad 使用,详见章节 4.11。
- 粉红色和绿色的 pad 只有数字 IO 的功能。
- 绿色的 pad 可以通过 VDD\_SDIO 由外部供电也可由芯片内部供电(详见下文)。

### 4.8.1 VDD\_SDIO 电源域

VDD\_SDIO 可以拉电流和灌电流,因此 VDD\_SDIO 电源域可由外部或内部供电。若使用外部供电,必须使用和 VDD3P3\_RTC 相同的电源。

如果外部不供电,则内部线性稳压器会给 VDD\_SDIO 供电。VDD\_SDIO 电压可以为 1.8V 或 3.3V(与 VRTC 相同),这取决于 MTDI pad 在复位时的状态——高电平时为 1.8V,低电平时为 3.3V。Efuse bit 置上后可强制决定 VDD\_SDIO 的默认电压。此外,软件启动后软件还可以配置寄存器来强制改变 VDD\_SDIO 的电压。

# 4.9 外设信号列表

表 16 列出了 GPIO 交换矩阵的外设输入 / 输出信号。

表 16: GPIO 交换矩阵外设信号

| Signal | Input Signal | Output Signal | Direct I/O in IO_MUX |
|--------|--------------|---------------|----------------------|
| 0      | SPICLK_in    | SPICLK_out    | YES                  |
| 1      | SPIQ_in      | SPIQ_out      | YES                  |

| Signal | Input Signal      | Output Signal       | Direct I/O in IO_MUX |
|--------|-------------------|---------------------|----------------------|
| 2      | SPID_in           | SPID_out            | YES                  |
| 3      | SPIHD_in          | SPIHD_out           | YES                  |
| 4      | SPIWP_in          | SPIWP_out           | YES                  |
| 5      | SPICS0_in         | SPICS0_out          | YES                  |
| 6      | SPICS1_in         | SPICS1_out          |                      |
| 7      | SPICS2_in         | SPICS2_out          |                      |
| 8      | HSPICLK_in        | HSPICLK_out         | YES                  |
| 9      | HSPIQ_in          | HSPIQ_out           | YES                  |
| 10     | HSPID_in          | HSPID_out           | YES                  |
| 11     | HSPICS0_in        | HSPICS0_out         | YES                  |
| 12     | HSPIHD_in         | HSPIHD_out          | YES                  |
| 13     | HSPIWP_in         | HSPIWP_out          | YES                  |
| 14     | U0RXD_in          | U0TXD_out           | YES                  |
| 15     | U0CTS_in          | U0RTS_out           | YES                  |
| 16     | U0DSR_in          | U0DTR_out           |                      |
| 17     | U1RXD_in          | U1TXD_out           | YES                  |
| 18     | U1CTS_in          | U1RTS_out           | YES                  |
| 23     | I2S0O_BCK_in      | I2S0O_BCK_out       |                      |
| 24     | I2S1O_BCK_in      | I2S1O_BCK_out       |                      |
| 25     | 12S0O_WS_in       | I2S0O_WS_out        |                      |
| 26     | I2S1O_WS_in       | I2S1O_WS_out        |                      |
| 27     | I2S0I_BCK_in      | I2S0I_BCK_out       |                      |
| 28     | 12S0I_WS_in       | I2S0I_WS_out        |                      |
| 29     | I2CEXT0_SCL_in    | I2CEXT0_SCL_out     |                      |
| 30     | I2CEXT0_SDA_in    | I2CEXT0_SDA_out     |                      |
| 31     | pwm0_sync0_in     | sdio_tohost_int_out |                      |
| 32     | pwm0_sync1_in     | pwm0_out0a          |                      |
| 33     | pwm0_sync2_in     | pwm0_out0b          |                      |
| 34     | pwm0_f0_in        | pwm0_out1a          |                      |
| 35     | pwm0_f1_in        | pwm0_out1b          |                      |
| 36     | pwm0_f2_in        | pwm0_out2a          |                      |
| 37     |                   | pwm0_out2b          |                      |
| 39     | pcnt_sig_ch0_in0  |                     |                      |
| 40     | pcnt_sig_ch1_in0  |                     |                      |
| 41     | pcnt_ctrl_ch0_in0 |                     |                      |
| 42     | pcnt_ctrl_ch1_in0 |                     |                      |
| 43     | pcnt_sig_ch0_in1  |                     |                      |
| 44     | pcnt_sig_ch1_in1  |                     |                      |
| 45     | pcnt_ctrl_ch0_in1 |                     |                      |
| 46     | pcnt_ctrl_ch1_in1 |                     |                      |
| 47     | pcnt_sig_ch0_in2  |                     |                      |
| 48     | pcnt_sig_ch1_in2  |                     |                      |
| 49     | pcnt_ctrl_ch0_in2 |                     |                      |
| 50     | pcnt_ctrl_ch1_in2 |                     |                      |

| Signal | Input Signal      | Output Signal    | Direct I/O in IO_MUX |
|--------|-------------------|------------------|----------------------|
| 51     | pcnt_sig_ch0_in3  |                  |                      |
| 52     | pcnt_sig_ch1_in3  |                  |                      |
| 53     | pcnt_ctrl_ch0_in3 |                  |                      |
| 54     | pcnt_ctrl_ch1_in3 |                  |                      |
| 55     | pcnt_sig_ch0_in4  |                  |                      |
| 56     | pcnt_sig_ch1_in4  |                  |                      |
| 57     | pcnt_ctrl_ch0_in4 |                  |                      |
| 58     | pcnt_ctrl_ch1_in4 |                  |                      |
| 61     | HSPICS1_in        | HSPICS1_out      |                      |
| 62     | HSPICS2_in        | HSPICS2_out      |                      |
| 63     | VSPICLK_in        | VSPICLK_out_mux  | YES                  |
| 64     | VSPIQ_in          | VSPIQ_out        | YES                  |
| 65     | VSPID_in          | VSPID_out        | YES                  |
| 66     | VSPIHD_in         | VSPIHD_out       | YES                  |
| 67     | VSPIWP_in         | VSPIWP_out       | YES                  |
| 68     | VSPICS0_in        | VSPICS0_out      | YES                  |
| 69     | VSPICS1_in        | VSPICS1_out      |                      |
| 70     | VSPICS2_in        | VSPICS2_out      |                      |
| 71     | pcnt_sig_ch0_in5  | ledc_hs_sig_out0 |                      |
| 72     | pcnt_sig_ch1_in5  | ledc_hs_sig_out1 |                      |
| 73     | pcnt_ctrl_ch0_in5 | ledc_hs_sig_out2 |                      |
| 74     | pcnt_ctrl_ch1_in5 | ledc_hs_sig_out3 |                      |
| 75     | pcnt_sig_ch0_in6  | ledc_hs_sig_out4 |                      |
| 76     | pcnt_sig_ch1_in6  | ledc_hs_sig_out5 |                      |
| 77     | pcnt_ctrl_ch0_in6 | ledc_hs_sig_out6 |                      |
| 78     | pcnt_ctrl_ch1_in6 | ledc_hs_sig_out7 |                      |
| 79     | pcnt_sig_ch0_in7  | ledc_ls_sig_out0 |                      |
| 80     | pcnt_sig_ch1_in7  | ledc_ls_sig_out1 |                      |
| 81     | pcnt_ctrl_ch0_in7 | ledc_ls_sig_out2 |                      |
| 82     | pcnt_ctrl_ch1_in7 | ledc_ls_sig_out3 |                      |
| 83     | rmt_sig_in0       | ledc_ls_sig_out4 |                      |
| 84     | rmt_sig_in1       | ledc_ls_sig_out5 |                      |
| 85     | rmt_sig_in2       | ledc_ls_sig_out6 |                      |
| 86     | rmt_sig_in3       | ledc_ls_sig_out7 |                      |
| 87     | rmt_sig_in4       | rmt_sig_out0     |                      |
| 88     | rmt_sig_in5       | rmt_sig_out1     |                      |
| 89     | rmt_sig_in6       | rmt_sig_out2     |                      |
| 90     | rmt_sig_in7       | rmt_sig_out3     |                      |
| 91     |                   | rmt_sig_out4     |                      |
| 92     |                   | rmt_sig_out5     |                      |
| 93     |                   | rmt_sig_out6     |                      |
| 94     |                   | rmt_sig_out7     |                      |
| 95     | I2CEXT1_SCL_in    | I2CEXT1_SCL_out  |                      |
| 96     | I2CEXT1_SDA_in    | I2CEXT1_SDA_out  |                      |

| Signal | Input Signal          | Output Signal            | Direct I/O in IO_MUX |
|--------|-----------------------|--------------------------|----------------------|
| 97     | host_card_detect_n_1  | host_ccmd_od_pullup_en_n |                      |
| 98     | host_card_detect_n_2  | host_rst_n_1             |                      |
| 99     | host_card_write_prt_1 | host_rst_n_2             |                      |
| 100    | host_card_write_prt_2 | gpio_sd0_out             |                      |
| 101    | host_card_int_n_1     | gpio_sd1_out             |                      |
| 102    | host_card_int_n_2     | gpio_sd2_out             |                      |
| 103    | pwm1_sync0_in         | gpio_sd3_out             |                      |
| 104    | pwm1_sync1_in         | gpio_sd4_out             |                      |
| 105    | pwm1_sync2_in         | gpio_sd5_out             |                      |
| 106    | pwm1_f0_in            | gpio_sd6_out             |                      |
| 107    | pwm1_f1_in            | gpio_sd7_out             |                      |
| 108    | pwm1_f2_in            | pwm1_out0a               |                      |
| 109    | pwm0_cap0_in          | pwm1_out0b               |                      |
| 110    | pwm0_cap1_in          | pwm1_out1a               |                      |
| 111    | pwm0_cap2_in          | pwm1_out1b               |                      |
| 112    | pwm1_cap0_in          | pwm1_out2a               |                      |
| 113    | pwm1_cap1_in          | pwm1_out2b               |                      |
| 114    | pwm1_cap2_in          | pwm2_out1h               |                      |
| 115    | pwm2_flta             | pwm2_out1l               |                      |
| 116    | pwm2_fltb             | pwm2_out2h               |                      |
| 117    | pwm2_cap1_in          | pwm2_out2l               |                      |
| 118    | pwm2_cap2_in          | pwm2_out3h               |                      |
| 119    | pwm2_cap3_in          | pwm2_out3l               |                      |
| 120    | pwm3_flta             | pwm2_out4h               |                      |
| 121    | pwm3_fltb             | pwm2_out4l               |                      |
| 122    | pwm3_cap1_in          |                          |                      |
| 123    | pwm3_cap2_in          |                          |                      |
| 124    | pwm3_cap3_in          |                          |                      |
| 140    | I2S0I_DATA_in0        | I2S0O_DATA_out0          |                      |
| 141    | I2S0I_DATA_in1        | I2S0O_DATA_out1          |                      |
| 142    | I2S0I_DATA_in2        | I2S0O_DATA_out2          |                      |
| 143    | I2S0I_DATA_in3        | I2S0O_DATA_out3          |                      |
| 144    | I2S0I_DATA_in4        | I2S0O_DATA_out4          |                      |
| 145    | I2S0I_DATA_in5        | I2S0O_DATA_out5          |                      |
| 146    | I2S0I_DATA_in6        | I2S0O_DATA_out6          |                      |
| 147    | I2S0I_DATA_in7        | I2S0O_DATA_out7          |                      |
| 148    | I2S0I_DATA_in8        | I2S0O_DATA_out8          |                      |
| 149    | I2S0I_DATA_in9        | I2S0O_DATA_out9          |                      |
| 150    | I2S0I_DATA_in10       | I2S0O_DATA_out10         |                      |
| 151    | I2S0I_DATA_in11       | I2S0O_DATA_out11         |                      |
| 152    | I2S0I_DATA_in12       | I2S0O_DATA_out12         |                      |
| 153    | I2S0I_DATA_in13       | I2S0O_DATA_out13         |                      |
| 154    | I2S0I_DATA_in14       | I2S0O_DATA_out14         |                      |
| 155    | I2S0I_DATA_in15       | I2S0O_DATA_out15         |                      |

| Signal | Input Signal    | Output Signal    | Direct I/O in IO_MUX |
|--------|-----------------|------------------|----------------------|
| 156    |                 | I2S0O_DATA_out16 |                      |
| 157    |                 | I2S0O_DATA_out17 |                      |
| 158    |                 | I2S0O_DATA_out18 |                      |
| 159    |                 | I2S0O_DATA_out19 |                      |
| 160    |                 | I2S0O_DATA_out20 |                      |
| 161    |                 | I2S0O_DATA_out21 |                      |
| 162    |                 | I2S0O_DATA_out22 |                      |
| 163    |                 | I2S0O_DATA_out23 |                      |
| 164    | I2S1I_BCK_in    | I2S1I_BCK_out    |                      |
| 165    | I2S1I_WS_in     | I2S1I_WS_out     |                      |
| 166    | I2S1I_DATA_in0  | I2S1O_DATA_out0  |                      |
| 167    | I2S1I_DATA_in1  | I2S1O_DATA_out1  |                      |
| 168    | I2S1I_DATA_in2  | I2S1O_DATA_out2  |                      |
| 169    | I2S1I_DATA_in3  | I2S1O_DATA_out3  |                      |
| 170    | I2S1I_DATA_in4  | I2S1O_DATA_out4  |                      |
| 171    | I2S1I_DATA_in5  | I2S1O_DATA_out5  |                      |
| 172    | I2S1I_DATA_in6  | I2S1O_DATA_out6  |                      |
| 173    | I2S1I_DATA_in7  | I2S1O_DATA_out7  |                      |
| 174    | I2S1I_DATA_in8  | I2S1O_DATA_out8  |                      |
| 175    | I2S1I_DATA_in9  | I2S1O_DATA_out9  |                      |
| 176    | I2S1I_DATA_in10 | I2S1O_DATA_out10 |                      |
| 177    | I2S1I_DATA_in11 | I2S1O_DATA_out11 |                      |
| 178    | I2S1I_DATA_in12 | I2S1O_DATA_out12 |                      |
| 179    | I2S1I_DATA_in13 | I2S1O_DATA_out13 |                      |
| 180    | I2S1I_DATA_in14 | I2S1O_DATA_out14 |                      |
| 181    | I2S1I_DATA_in15 | I2S1O_DATA_out15 |                      |
| 182    |                 | I2S1O_DATA_out16 |                      |
| 183    |                 | I2S1O_DATA_out17 |                      |
| 184    |                 | I2S1O_DATA_out18 |                      |
| 185    |                 | I2S1O_DATA_out19 |                      |
| 186    |                 | I2S1O_DATA_out20 |                      |
| 187    |                 | I2S1O_DATA_out21 |                      |
| 188    |                 | I2S1O_DATA_out22 |                      |
| 189    |                 | I2S1O_DATA_out23 |                      |
| 190    | I2S0I_H_SYNC    | pwm3_out1h       |                      |
| 191    | I2S0I_V_SYNC    | pwm3_out1l       |                      |
| 192    | I2S0I_H_ENABLE  | pwm3_out2h       |                      |
| 193    | I2S1I_H_SYNC    | pwm3_out2l       |                      |
| 194    | I2S1I_V_SYNC    | pwm3_out3h       |                      |
| 195    | I2S1I_H_ENABLE  | pwm3_out3l       |                      |
| 196    |                 | pwm3_out4h       |                      |
| 197    |                 | pwm3_out4l       |                      |
| 198    | U2RXD_in        | U2TXD_out        | YES                  |
| 199    | U2CTS_in        | U2RTS_out        | YES                  |

| Signal | Input Signal | Output Signal     | Direct I/O in IO_MUX |
|--------|--------------|-------------------|----------------------|
| 200    | emac_mdc_i   | emac_mdc_o        |                      |
| 201    | emac_mdi_i   | emac_mdo_o        |                      |
| 202    | emac_crs_i   | emac_crs_o        |                      |
| 203    | emac_col_i   | emac_col_o        |                      |
| 204    | pcmfsync_in  | bt_audio0_irq     |                      |
| 205    | pcmclk_in    | bt_audio1_irq     |                      |
| 206    | pcmdin       | bt_audio2_irq     |                      |
| 207    |              | ble_audio0_irq    |                      |
| 208    |              | ble_audio1_irq    |                      |
| 209    |              | ble_audio2_irq    |                      |
| 210    |              | pcmfsync_out      |                      |
| 211    |              | pcmclk_out        |                      |
| 212    |              | pcmdout           |                      |
| 213    |              | ble_audio_sync0_p |                      |
| 214    |              | ble_audio_sync1_p |                      |
| 215    |              | ble_audio_sync2_p |                      |
| 224    |              | sig_in_func224    |                      |
| 225    |              | sig_in_func225    |                      |
| 226    |              | sig_in_func226    |                      |
| 227    |              | sig_in_func227    |                      |
| 228    |              | sig_in_func228    |                      |

**Direct I/O in IO\_MUX "YES"** 指此信号也可以通过 IO\_MUX 直接连接 pad。如果这些信号要使用 GPIO 交换矩阵,则必须将相应的 SIG\_IN\_SEL 寄存器清零。

# 4.10 IO\_MUX Pad 列表

表 17 列出了每个 I/O pad 的 IO\_MUX 功能。

表 17: IO\_MUX Pad 列表

| GPIO | Pad Name  | Function 1 | Function 2 | Function 3 | Function 4 | Function 5 | Function 6   | Reset | Notes |
|------|-----------|------------|------------|------------|------------|------------|--------------|-------|-------|
| 0    | GPIO0     | GPIO0      | CLK_OUT1   | GPIO0      | -          | -          | EMAC_TX_CLK  | 3     | R     |
| 1    | U0TXD     | U0TXD      | CLK_OUT3   | GPIO1      | -          | -          | EMAC_RXD2    | 3     | -     |
| 2    | GPIO2     | GPIO2      | HSPIWP     | GPIO2      | HS2_DATA0  | SD_DATA0   | -            | 2     | R     |
| 3    | U0RXD     | U0RXD      | CLK_OUT2   | GPIO3      | -          | -          | -            | 3     | -     |
| 4    | GPIO4     | GPIO4      | HSPIHD     | GPIO4      | HS2_DATA1  | SD_DATA1   | EMAC_TX_ER   | 2     | R     |
| 5    | GPIO5     | GPIO5      | VSPICS0    | GPIO5      | HS1_DATA6  | -          | EMAC_RX_CLK  | 3     | -     |
| 6    | SD_CLK    | SD_CLK     | SPICLK     | GPIO6      | HS1_CLK    | U1CTS      | -            | 3     | -     |
| 7    | SD_DATA_0 | SD_DATA0   | SPIQ       | GPIO7      | HS1_DATA0  | U2RTS      | -            | 3     | -     |
| 8    | SD_DATA_1 | SD_DATA1   | SPID       | GPIO8      | HS1_DATA1  | U2CTS      | -            | 3     | -     |
| 9    | SD_DATA_2 | SD_DATA2   | SPIHD      | GPIO9      | HS1_DATA2  | U1RXD      | -            | 3     | -     |
| 10   | SD_DATA_3 | SD_DATA3   | SPIWP      | GPIO10     | HS1_DATA3  | U1TXD      | -            | 3     | -     |
| 11   | SD_CMD    | SD_CMD     | SPICS0     | GPIO11     | HS1_CMD    | U1RTS      | -            | 3     | -     |
| 12   | MTDI      | MTDI       | HSPIQ      | GPIO12     | HS2_DATA2  | SD_DATA2   | EMAC_TXD3    | 2     | R     |
| 13   | MTCK      | MTCK       | HSPID      | GPIO13     | HS2_DATA3  | SD_DATA3   | EMAC_RX_ER   | 1     | R     |
| 14   | MTMS      | MTMS       | HSPICLK    | GPIO14     | HS2_CLK    | SD_CLK     | EMAC_TXD2    | 1     | R     |
| 15   | MTDO      | MTDO       | HSPICS0    | GPIO15     | HS2_CMD    | SD_CMD     | EMAC_RXD3    | 3     | R     |
| 16   | GPIO16    | GPIO16     | -          | GPIO16     | HS1_DATA4  | U2RXD      | EMAC_CLK_OUT | 1     | -     |

| GPIO | Pad Name    | Function 1 | Function 2 | Function 3 | Function 4 | Function 5 | Function 6   | Reset | Notes |
|------|-------------|------------|------------|------------|------------|------------|--------------|-------|-------|
| 17   | GPIO17      | GPIO17     | -          | GPIO17     | HS1_DATA5  | U2TXD      | EMAC_CLK_180 | 1     | -     |
| 18   | GPIO18      | GPIO18     | VSPICLK    | GPIO18     | HS1_DATA7  | -          | -            | 1     | -     |
| 19   | GPIO19      | GPIO19     | VSPIQ      | GPIO19     | U0CTS      | -          | EMAC_TXD0    | 1     | -     |
| 20   | GPIO20      | GPIO20     | -          | GPIO20     | -          | -          | -            | 1     | -     |
| 21   | GPIO21      | GPIO21     | VSPIHD     | GPIO21     | -          | -          | EMAC_TX_EN   | 1     | -     |
| 22   | GPIO22      | GPIO22     | VSPIWP     | GPIO22     | U0RTS      | -          | EMAC_TXD1    | 1     | -     |
| 23   | GPIO23      | GPIO23     | VSPID      | GPIO23     | HS1_STROBE | -          | -            | 1     | -     |
| 25   | GPIO25      | GPIO25     | -          | GPIO25     | -          | -          | EMAC_RXD0    | 0     | R     |
| 26   | GPIO26      | GPIO26     | -          | GPIO26     | -          | -          | EMAC_RXD1    | 0     | R     |
| 27   | GPIO27      | GPIO27     | -          | GPIO27     | -          | -          | EMAC_RX_DV   | 1     | R     |
| 32   | 32K_XP      | GPIO32     | -          | GPIO32     | -          | -          | -            | 0     | R     |
| 33   | 32K_XN      | GPIO33     | -          | GPIO33     | -          | -          | -            | 0     | R     |
| 34   | VDET_1      | GPIO34     | -          | GPIO34     | -          | -          | -            | 0     | R, I  |
| 35   | VDET_2      | GPIO35     | -          | GPIO35     | -          | -          | -            | 0     | R, I  |
| 36   | SENSOR_VP   | GPIO36     | -          | GPIO36     | -          | -          | -            | 0     | R, I  |
| 37   | SENSOR_CAPP | GPIO37     | -          | GPIO37     | -          | -          | -            | 0     | R, I  |
| 38   | SENSOR_CAPN | GPIO38     | -          | GPIO38     | -          | -          | -            | 0     | R, I  |
| 39   | SENSOR_VN   | GPIO39     | -          | GPIO39     | -          | -          | -            | 0     | R, I  |

## 复位配置

"Reset"一栏是每个 pad 复位后的默认配置。

- 0 IE=0 (输入关闭)
- 1 IE=1 (输入使能)
- 2 IE=1, WPD=1 (输入使能,下拉电阻)
- 3 IE=1, WPU=1 (输入使能, 上拉电阻)

## 说明

- R Pad 通过 RTC\_MUX 具有 RTC / 模拟功能。
- I Pad 只能配置为输入 GPIO。

参考 ESP32 管脚清单 获取管脚功能的完整表格。

# 4.11 RTC\_MUX 管脚清单

表 18 列出了 RTC 管脚和对应 GPIO pad。

表 18: RTC\_MUX 管脚清单

| RTC GPIO Num   | GPIO Num | Pad Name    | Analog Function |          |   |
|----------------|----------|-------------|-----------------|----------|---|
| ATC GETO Nulli | GFIO Num | rau Mairie  | 1               | 2        | 3 |
| 0              | 36       | SENSOR_VP   | ADC_H           | ADC1_CH0 | - |
| 1              | 37       | SENSOR_CAPP | ADC_H           | ADC1_CH1 | - |
| 2              | 38       | SENSOR_CAPN | ADC_H           | ADC1_CH2 | - |
| 3              | 39       | SENSOR_VN   | ADC_H           | ADC1_CH3 | - |
| 4              | 34       | VDET_1      | -               | ADC1_CH6 | - |
| 5              | 35       | VDET_2      | -               | ADC1_CH7 | - |
| 6              | 25       | GPIO25      | DAC_1           | ADC2_CH8 | - |

| RTC GPIO Num | GPIO Num Pad Name | Analog Function |            |          |        |
|--------------|-------------------|-----------------|------------|----------|--------|
| RTC GPIO Num | GPIO Num          | Pad Name        | 1          | 2        | 3      |
| 7            | 26                | GPIO26          | DAC_2      | ADC2_CH9 | -      |
| 8            | 33                | 32K_XN          | XTAL_32K_N | ADC1_CH5 | TOUCH8 |
| 9            | 32                | 32K_XP          | XTAL_32K_P | ADC1_CH4 | TOUCH9 |
| 10           | 4                 | GPIO4           | -          | ADC2_CH0 | TOUCH0 |
| 11           | 0                 | GPIO0           | -          | ADC2_CH1 | TOUCH1 |
| 12           | 2                 | GPIO2           | -          | ADC2_CH2 | TOUCH2 |
| 13           | 15                | MTDO            | -          | ADC2_CH3 | TOUCH3 |
| 14           | 13                | MTCK            | -          | ADC2_CH4 | TOUCH4 |
| 15           | 12                | MTDI            | -          | ADC2_CH5 | TOUCH5 |
| 16           | 14                | MTMS            | -          | ADC2_CH6 | TOUCH6 |
| 17           | 27                | GPIO27          | -          | ADC2_CH7 | TOUCH7 |

# 4.12 寄存器列表

| 名称                    | 描述                                              | 地址         | 访问  |
|-----------------------|-------------------------------------------------|------------|-----|
| GPIO_OUT_REG          | GPIO 0-31 output register_REG                   | 0x3FF44004 | 读/写 |
| GPIO_OUT_W1TS_REG     | GPIO 0-31 output register_W1TS_REG              | 0x3FF44008 | 只读  |
| GPIO_OUT_W1TC_REG     | GPIO 0-31 output register_W1TC_REG              | 0x3FF4400C | 只读  |
| GPIO_OUT1_REG         | GPIO 0-31 output register1_REG                  | 0x3FF44010 | 读/写 |
| GPIO_OUT1_W1TS_REG    | GPIO 0-31 output register1_W1TS_REG             | 0x3FF44014 | 只读  |
| GPIO_OUT1_W1TC_REG    | GPIO 0-31 output register1_W1TC_REG             | 0x3FF44018 | 只读  |
| GPIO_OUT_W1TS_REG     | GPIO 0-31 output bit set register_REG           | 0x3FF44008 | 只读  |
| GPIO_OUT_W1TC_REG     | GPIO 0-31 output bit clear register_REG         | 0x3FF4400C | 只读  |
| GPIO_OUT1_REG         | GPIO 32-39 output register_REG                  | 0x3FF44010 | 读/写 |
| GPIO_OUT1_W1TS_REG    | GPIO 32-39 output register_W1TS_REG             | 0x3FF44014 | 只读  |
| GPIO_OUT1_W1TC_REG    | GPIO 32-39 output register_W1TC_REG             | 0x3FF44018 | 只读  |
| GPIO_OUT1_W1TS_REG    | GPIO 32-39 output bit set register_REG          | 0x3FF44014 | 只读  |
| GPIO_OUT1_W1TC_REG    | GPIO 32-39 output bit clear register_REG        | 0x3FF44018 | 只读  |
| GPIO_ENABLE_REG       | GPIO 0-31 output enable register_REG            | 0x3FF44020 | 读/写 |
| GPIO_ENABLE_W1TS_REG  | GPIO 0-31 output enable register_W1TS_REG       | 0x3FF44024 | 只读  |
| GPIO_ENABLE_W1TC_REG  | GPIO 0-31 output enable register_W1TC_REG       | 0x3FF44028 | 只读  |
| GPIO_ENABLE1_REG      | GPIO 0-31 output enable register1_REG           | 0x3FF4402C | 读/写 |
| GPIO_ENABLE1_W1TS_REG | GPIO 0-31 output enable register1_W1TS_REG      | 0x3FF44030 | 只读  |
| GPIO_ENABLE1_W1TC_REG | GPIO 0-31 output enable register1_W1TC_REG      | 0x3FF44034 | 只读  |
| GPIO_ENABLE_W1TS_REG  | GPIO 0-31 output enable bit set register_REG    | 0x3FF44024 | 只读  |
| GPIO_ENABLE_W1TC_REG  | GPIO 0-31 output enable bit clear register_REG  | 0x3FF44028 | 只读  |
| GPIO_ENABLE1_REG      | GPIO 32-39 output enable register_REG           | 0x3FF4402C | 读/写 |
| GPIO_ENABLE1_W1TS_REG | GPIO 32-39 output enable register_W1TS_REG      | 0x3FF44030 | 只读  |
| GPIO_ENABLE1_W1TC_REG | GPIO 32-39 output enable register_W1TC_REG      | 0x3FF44034 | 只读  |
| GPIO_ENABLE1_W1TS_REG | GPIO 32-39 output enable bit set register_REG   | 0x3FF44030 | 只读  |
| GPIO_ENABLE1_W1TC_REG | GPIO 32-39 output enable bit clear register_REG | 0x3FF44034 | 只读  |
| GPIO_STRAP_REG        | Bootstrap pin value register_REG                | 0x3FF44038 | 只读  |

| 名称                              | 描述                                                 | 地址                                                                                                       | 访问        |
|---------------------------------|----------------------------------------------------|----------------------------------------------------------------------------------------------------------|-----------|
| GPIO_IN_REG                     | GPIO 0-31 input register_REG                       | 0x3FF4403C                                                                                               | 只读        |
| GPIO_IN1_REG                    | GPIO 0-31 input register1_REG                      | 0x3FF44040                                                                                               | 只读        |
| GPIO_IN1_REG                    | GPIO 32-39 input register_REG                      | 0x3FF44040                                                                                               | 只读        |
| GPIO_STATUS_REG                 | GPIO 0-31 interrupt status register_REG            | 0x3FF44044                                                                                               | 读/写       |
| GPIO_STATUS_W1TS_REG            | GPIO 0-31 interrupt status register_W1TS_REG       | 0x3FF44048                                                                                               | 只读        |
| GPIO_STATUS_W1TC_REG            | GPIO 0-31 interrupt status register_W1TC_REG       | 0x3FF4404C                                                                                               | 只读        |
| GPIO_STATUS1_REG                | GPIO 0-31 interrupt status register1_REG           | 0x3FF44050                                                                                               | 读/写       |
| GPIO_STATUS1_W1TS_REG           | GPIO 0-31 interrupt status register1_W1TS_REG      | 0x3FF44054                                                                                               | 只读        |
| GPIO_STATUS1_W1TC_REG           | GPIO 0-31 interrupt status register1_W1TC_REG      | 0x3FF44058                                                                                               | 只读        |
| GPIO_STATUS_W1TS_REG            | GPIO 0-31 interrupt status bit set register_REG    | 0x3FF44048                                                                                               | 只读        |
| GPIO_STATUS_W1TC_REG            | GPIO 0-31 interrupt status bit clear register_REG  | 0x3FF4404C                                                                                               | 只读        |
| GPIO_STATUS1_REG                | GPIO 32-39 interrupt status register_REG           | 0x3FF44050                                                                                               | 读/写       |
| GPIO_STATUS1_W1TS_REG           | GPIO 32-39 interrupt status register_W1TS_REG      | 0x3FF44054                                                                                               | 只读        |
| GPIO_STATUS1_W1TC_REG           | GPIO 32-39 interrupt status register_W1TC_REG      | 0x3FF44058                                                                                               | 只读        |
| GPIO_STATUS1_W1TS_REG           | GPIO 32-39 interrupt status bit set register_REG   | 0x3FF44054                                                                                               | 只读        |
| GPIO_STATUS1_W1TC_REG           | GPIO 32-39 interrupt status bit clear register_REG | 0x3FF44058                                                                                               | 只读        |
| GPIO_ACPU_INT_REG               | GPIO 0-31 APP_CPU interrupt status_REG             | 0x3FF44060                                                                                               | 只读        |
| GPIO_ACPU_INT1_REG              | GPIO 0-31 APP_CPU interrupt status1_REG            | 0x3FF44074                                                                                               | 只读        |
| GPIO_ACPU_NMI_INT_REG           | GPIO 0-31 APP_CPU non-maskable interrupt sta-      | 0x2EE44064                                                                                               | 口净        |
| GPIO_ACPO_INIVII_INT_NEG        | tus_REG                                            | UX3FF44004                                                                                               | 只读        |
| GPIO_ACPU_NMI_INT1_REG          | GPIO 0-31 APP_CPU non-maskable interrupt sta-      | 0×3EE44078                                                                                               | 只读        |
| di lo_Aoi o_ivivii_iivi i_ii.ed | tus1_REG                                           | 0.01111070                                                                                               | 八氏        |
| GPIO_PCPU_INT_REG               | GPIO 0-31 PRO_CPU interrupt status_REG             | 0x3FF44068                                                                                               | 只读        |
| GPIO_PCPU_INT1_REG              | GPIO 0-31 PRO_CPU interrupt status1_REG            | 0x3FF4407C                                                                                               | 只读        |
| GPIO PCPU NMI INT REG           | GPIO 0-31 PRO_CPU non-maskable interrupt sta-      | 0x3FF4407C<br>a-<br>0x3FF4406C                                                                           | <br>  只读  |
| GI 10_I OI O_I VIVII_IIVI_I LEG | tus_REG                                            |                                                                                                          | 八庆        |
| GPIO_PCPU_NMI_INT1_REG          | GPIO 0-31 PRO_CPU non-maskable interrupt sta-      | 0x3FF44060 0x3FF44074 - 0x3FF44064 - 0x3FF44078 0x3FF44068 0x3FF4406C - 0x3FF44080 0x3FF44074 ox3FF44074 | <br>  只读  |
|                                 | tus1_REG                                           | 0.001111000                                                                                              |           |
| GPIO_ACPU_INT1_REG              | GPIO 32-39 APP_CPU interrupt status_REG            | 0x3FF44074                                                                                               | 只读        |
| GPIO_ACPU_NMI_INT1_REG          | GPIO 32-39 APP_CPU non-maskable interrupt          | 0x3FF44078                                                                                               | <br>  只读  |
|                                 | status_REG                                         |                                                                                                          |           |
| GPIO_PCPU_INT1_REG              | GPIO 32-39 PRO_CPU interrupt status_REG            | 0x3FF4407C                                                                                               | 只读        |
| GPIO PCPU NMI INT1 REG          | GPIO 32-39 PRO_CPU non-maskable interrupt          | 0x3FF44080                                                                                               | 」<br>只读   |
|                                 | status_REG                                         |                                                                                                          |           |
| GPIO_PINO_REG                   | Configuration for GPIO pin 0_REG                   | 0x3FF44088                                                                                               | 读/写       |
| GPIO_PIN1_REG                   | Configuration for GPIO pin 1_REG                   | 0x3FF4408C                                                                                               | 读/写       |
| GPIO_PIN2_REG                   | Configuration for GPIO pin 2_REG                   | 0x3FF44090                                                                                               | 读/写       |
|                                 |                                                    | 0.05544455                                                                                               | \_t_ (= : |
| GPIO_PIN38_REG                  | Configuration for GPIO pin 38_REG                  | 0x3FF44120                                                                                               | 读/写       |
| GPIO_PIN39_REG                  | Configuration for GPIO pin 39_REG                  | 0x3FF44124                                                                                               | 读/写       |
| GPIO_FUNCO_IN_SEL_CFG_REG       | Peripheral function 0 input selection register_REG | 0x3FF44130                                                                                               | 读/写       |
| GPIO_FUNC1_IN_SEL_CFG_REG       | Peripheral function 1 input selection register_REG | 0x3FF44134                                                                                               | 读/写       |
|                                 |                                                    |                                                                                                          |           |

| 名称                                | 描述                                             | 地址          | 访问    |
|-----------------------------------|------------------------------------------------|-------------|-------|
| GPIO_FUNC254_IN_SEL_CFG_REG       | Peripheral function 254 input selection regis- | 0x3FF44528  | 读/写   |
| di 10_1 0110234_111_3EE_01 d_11Ed | ter_REG                                        | 0.001144020 | ) 以一寸 |
| GPIO_FUNC255_IN_SEL_CFG_REG       | Peripheral function 255 input selection regis- | 0x3FF4452C  | 读/写   |
| di 10_1 0110233_111_3EE_01 d_11Ed | ter_REG                                        | 0.001144020 | ) 以一寸 |
| GPIO_FUNCO_OUT_SEL_CFG_REG        | Peripheral output selection for GPIO 0_REG     | 0x3FF44530  | 读/写   |
| GPIO_FUNC1_OUT_SEL_CFG_REG        | Peripheral output selection for GPIO 1_REG     | 0x3FF44534  | 读/写   |
|                                   |                                                |             |       |
| GPIO_FUNC38_OUT_SEL_CFG_REG       | Peripheral output selection for GPIO 38_REG    | 0x3FF445C8  | 读/写   |
| GPIO_FUNC39_OUT_SEL_CFG_REG       | Peripheral output selection for GPIO 39_REG    | 0x3FF445CC  | 读/写   |

| 名称                  | 描述                                      | 地址         | 访问  |
|---------------------|-----------------------------------------|------------|-----|
| IO_MUX_GPIO36_REG   | Configuration register for pad GPIO36   | 0x3FF53004 | 读/写 |
| IO_MUX_GPIO37_REG   | Configuration register for pad GPIO37   | 0x3FF53008 | 读/写 |
| IO_MUX_GPIO38_REG   | Configuration register for pad GPIO38   | 0x3FF5300C | 读/写 |
| IO_MUX_GPIO39_REG   | Configuration register for pad GPIO39   | 0x3FF53010 | 读/写 |
| IO_MUX_GPIO34_REG   | Configuration register for pad GPIO34   | 0x3FF53014 | 读/写 |
| IO_MUX_GPIO35_REG   | Configuration register for pad GPIO35   | 0x3FF53018 | 读/写 |
| IO_MUX_GPIO32_REG   | Configuration register for pad GPIO32   | 0x3FF5301C | 读/写 |
| IO_MUX_GPIO33_REG   | Configuration register for pad GPIO33   | 0x3FF53020 | 读/写 |
| IO_MUX_GPIO25_REG   | Configuration register for pad GPIO25   | 0x3FF53024 | 读/写 |
| IO_MUX_GPIO26_REG   | Configuration register for pad GPIO26   | 0x3FF53028 | 读/写 |
| IO_MUX_GPIO27_REG   | Configuration register for pad GPIO27   | 0x3FF5302C | 读/写 |
| IO_MUX_MTMS_REG     | Configuration register for pad MTMS     | 0x3FF53030 | 读/写 |
| IO_MUX_MTDI_REG     | Configuration register for pad MTDI     | 0x3FF53034 | 读/写 |
| IO_MUX_MTCK_REG     | Configuration register for pad MTCK     | 0x3FF53038 | 读/写 |
| IO_MUX_MTDO_REG     | Configuration register for pad MTDO     | 0x3FF5303C | 读/写 |
| IO_MUX_GPIO2_REG    | Configuration register for pad GPIO2    | 0x3FF53040 | 读/写 |
| IO_MUX_GPIO0_REG    | Configuration register for pad GPIO0    | 0x3FF53044 | 读/写 |
| IO_MUX_GPIO4_REG    | Configuration register for pad GPIO4    | 0x3FF53048 | 读/写 |
| IO_MUX_GPIO16_REG   | Configuration register for pad GPIO16   | 0x3FF5304C | 读/写 |
| IO_MUX_GPIO17_REG   | Configuration register for pad GPIO17   | 0x3FF53050 | 读/写 |
| IO_MUX_SD_DATA2_REG | Configuration register for pad SD_DATA2 | 0x3FF53054 | 读/写 |
| IO_MUX_SD_DATA3_REG | Configuration register for pad SD_DATA3 | 0x3FF53058 | 读/写 |
| IO_MUX_SD_CMD_REG   | Configuration register for pad SD_CMD   | 0x3FF5305C | 读/写 |
| IO_MUX_SD_CLK_REG   | Configuration register for pad SD_CLK   | 0x3FF53060 | 读/写 |
| IO_MUX_SD_DATA0_REG | Configuration register for pad SD_DATA0 | 0x3FF53064 | 读/写 |
| IO_MUX_SD_DATA1_REG | Configuration register for pad SD_DATA1 | 0x3FF53068 | 读/写 |
| IO_MUX_GPIO5_REG    | Configuration register for pad GPIO5    | 0x3FF5306C | 读/写 |
| IO_MUX_GPIO18_REG   | Configuration register for pad GPIO18   | 0x3FF53070 | R/W |
| IO_MUX_GPIO19_REG   | Configuration register for pad GPIO19   | 0x3FF53074 | 读/写 |
| IO_MUX_GPIO20_REG   | Configuration register for pad GPIO20   | 0x3FF53078 | 读/写 |
| IO_MUX_GPIO21_REG   | Configuration register for pad GPIO21   | 0x3FF5307C | 读/写 |
| IO_MUX_GPIO22_REG   | Configuration register for pad GPIO22   | 0x3FF53080 | 读/写 |
| IO_MUX_U0RXD_REG    | Configuration register for pad U0RXD    | 0x3FF53084 | 读/写 |

| 名称                | 描述                                    | 地址         | 访问  |
|-------------------|---------------------------------------|------------|-----|
| IO_MUX_U0TXD_REG  | Configuration register for pad U0TXD  | 0x3FF53088 | 读/写 |
| IO_MUX_GPIO23_REG | Configuration register for pad GPIO23 | 0x3FF5308C | 读/写 |
| IO_MUX_GPIO24_REG | Configuration register for pad GPIO24 | 0x3FF53090 | 读/写 |

| 名称                             | 描述                                               | 地址         | 访问  |
|--------------------------------|--------------------------------------------------|------------|-----|
| GPIO 配置 / 数据寄存器                |                                                  |            |     |
| RTCIO_RTC_GPIO_OUT_REG         | RTC GPIO output register_REG                     | 0x3FF48000 | 读/写 |
| RTCIO_RTC_GPIO_OUT_W1TS_REG    | RTC GPIO output register_W1TS_REG                | 0x3FF48001 | 只写  |
| RTCIO_RTC_GPIO_OUT_W1TC_REG    | RTC GPIO output register_W1TC_REG                | 0x3FF48002 | 只写  |
| RTCIO_RTC_GPIO_OUT_W1TS_REG    | RTC GPIO output bit set register_REG             | 0x3FF48001 | 只写  |
| RTCIO_RTC_GPIO_OUT_W1TC_REG    | RTC GPIO output bit clear register_REG           | 0x3FF48002 | 只写  |
| RTCIO_RTC_GPIO_ENABLE_REG      | RTC GPIO output enable register_REG              | 0x3FF48003 | 读/写 |
| RTCIO_RTC_GPIO_ENABLE_W1TS_REG | RTC GPIO output enable register_W1TS_REG         | 0x3FF48004 | 只写  |
| RTCIO_RTC_GPIO_ENABLE_W1TC_REG | RTC GPIO output enable register_W1TC_REG         | 0x3FF48005 | 只写  |
| RTCIO_RTC_GPIO_ENABLE_W1TS_REG | RTC GPIO output enable bit setregister_REG       | 0x3FF48004 | 只写  |
| RTCIO_RTC_GPIO_ENABLE_W1TC_REG | RTC GPIO output enable bit clear register_REG    | 0x3FF48005 | 只写  |
| RTCIO_RTC_GPIO_STATUS_REG      | RTC GPIO interrupt status register_REG           | 0x3FF48006 | 读/写 |
| RTCIO_RTC_GPIO_STATUS_W1TS_REG | RTC GPIO interrupt status register_W1TS_REG      | 0x3FF48007 | 只写  |
| RTCIO_RTC_GPIO_STATUS_W1TC_REG | RTC GPIO interrupt status register_W1TC_REG      | 0x3FF48008 | 只写  |
| RTCIO_RTC_GPIO_STATUS_W1TS_REG | RTC GPIO interrupt status bit set register_REG   | 0x3FF48007 | 只写  |
| RTCIO_RTC_GPIO_STATUS_W1TC_REG | RTC GPIO interrupt status bit clear register_REG | 0x3FF48008 | 只写  |
| RTCIO_RTC_GPIO_IN_REG          | RTC GPIO input register_REG                      | 0x3FF48009 | 只读  |
| RTCIO_RTC_GPIO_PIN0_REG        | RTC configuration for pin 0_REG                  | 0x3FF4800A | 读/写 |
| RTCIO_RTC_GPIO_PIN1_REG        | RTC configuration for pin 1_REG                  | 0x3FF4800B | 读/写 |
| RTCIO_RTC_GPIO_PIN2_REG        | RTC configuration for pin 2_REG                  | 0x3FF4800C | 读/写 |
| RTCIO_RTC_GPIO_PIN3_REG        | RTC configuration for pin 3_REG                  | 0x3FF4800D | 读/写 |
| RTCIO_RTC_GPIO_PIN4_REG        | RTC configuration for pin 4_REG                  | 0x3FF4800E | 读/写 |
| RTCIO_RTC_GPIO_PIN5_REG        | RTC configuration for pin 5_REG                  | 0x3FF4800F | 读/写 |
| RTCIO_RTC_GPIO_PIN6_REG        | RTC configuration for pin 6_REG                  | 0x3FF48010 | 读/写 |
| RTCIO_RTC_GPIO_PIN7_REG        | RTC configuration for pin 7_REG                  | 0x3FF48011 | 读/写 |
| RTCIO_RTC_GPIO_PIN8_REG        | RTC configuration for pin 8_REG                  | 0x3FF48012 | 读/写 |
| RTCIO_RTC_GPIO_PIN9_REG        | RTC configuration for pin 9_REG                  | 0x3FF48013 | 读/写 |
| RTCIO_RTC_GPIO_PIN10_REG       | RTC configuration for pin 10_REG                 | 0x3FF48014 | 读/写 |
| RTCIO_RTC_GPIO_PIN11_REG       | RTC configuration for pin 11_REG                 | 0x3FF48015 | 读/写 |
| RTCIO_RTC_GPIO_PIN12_REG       | RTC configuration for pin 12_REG                 | 0x3FF48016 | 读/写 |
| RTCIO_RTC_GPIO_PIN13_REG       | RTC configuration for pin 13_REG                 | 0x3FF48017 | 读/写 |
| RTCIO_RTC_GPIO_PIN14_REG       | RTC configuration for pin 14_REG                 | 0x3FF48018 | 读/写 |
| RTCIO_RTC_GPIO_PIN15_REG       | RTC configuration for pin 15_REG                 | 0x3FF48019 | 读/写 |
| RTCIO_RTC_GPIO_PIN16_REG       | RTC configuration for pin 16_REG                 | 0x3FF4801A | 读/写 |
| RTCIO_RTC_GPIO_PIN17_REG       | RTC configuration for pin 17_REG                 | 0x3FF4801B | 读/写 |
| RTCIO_DIG_PAD_HOLD_REG         | RTC GPIO hold register_REG                       | 0x3FF4801D | 读/写 |

| 名称                     | 描述                                            | 地址         | 访问  |
|------------------------|-----------------------------------------------|------------|-----|
| GPIO RTC 功能配置寄存器       |                                               |            |     |
| RTCIO_HALL_SENS_REG    | Hall sensor configuration_REG                 | 0x3FF4801E | 读/写 |
| RTCIO_SENSOR_PADS_REG  | Sensor pads configuration register_REG        | 0x3FF4801F | 读/写 |
| RTCIO_ADC_PAD_REG      | ADC configuration register_REG                | 0x3FF48020 | 读/写 |
| RTCIO_PAD_DAC1_REG     | DAC1 configuration register_REG               | 0x3FF48021 | 读/写 |
| RTCIO_PAD_DAC2_REG     | DAC2 configuration register_REG               | 0x3FF48022 | 读/写 |
| RTCIO_XTAL_32K_PAD_REG | 32KHz crystal pads configuration register_REG | 0x3FF48023 | 读/写 |
| RTCIO_TOUCH_CFG_REG    | Touch sensor configuration register_REG       | 0x3FF48024 | 读/写 |
| RTCIO_EXT_WAKEUP0_REG  | External wake up configuration register_REG   | 0x3FF4802F | 读/写 |
| RTCIO_XTL_EXT_CTR_REG  | Crystal power down enable gpio source_REG     | 0x3FF48030 | 读/写 |
| RTCIO_SAR_I2C_IO_REG   | RTC I2C pad selection_REG                     | 0x3FF48031 | 读/写 |

## 4.13 寄存器

Register 4.1: GPIO\_OUT\_REG (0x0004)



GPIO\_OUT\_REG GPIOO-31 输出值。(读/写)

Register 4.2: GPIO\_OUT\_W1TS\_REG (0x0008)



**GPIO\_OUT\_W1TS\_REG** GPIO0-31 输出置位寄存器。每一位置 1,则 GPIO\_OUT\_DATA 中的相应位也会置 1。(只读)

Register 4.3: GPIO\_OUT\_W1TC\_REG (0x000c)



**GPIO\_OUT\_W1TC\_REG** GPIO0-31 输出清零寄存器。每一位置 1,则 GPIO\_OUT\_DATA 中的相应位会清零。(只读)

Register 4.4: GPIO\_OUT1\_REG (0x0010)



GPIO\_OUT\_DATA GPIO32-39 输出值。(只读)

Register 4.5: GPIO\_OUT1\_W1TS\_REG (0x0014)



**GPIO\_OUT\_DATA** GPIO32-39 输出值置位寄存器。每一位置 1,则 GPIO\_OUT1\_DATA 中的相应位也会置 1。(只读)

Register 4.6: GPIO\_OUT1\_W1TC\_REG (0x0018)



**GPIO\_OUT\_DATA** GPIO32-39 输出值清零寄存器。每一位置 1,则 GPIO\_OUT1\_DATA 中的相应位 会清零。(只读)

Register 4.7: GPIO\_ENABLE\_REG (0x0020)



GPIO\_ENABLE\_REG GPIO0-31 输出使能。(读/写)

Register 4.8: GPIO\_ENABLE\_W1TS\_REG (0x0024)



**GPIO\_ENABLE\_W1TS\_REG** GPIO0-31 输出使能置位寄存器。每一位置 1,则 GPIO\_ENABLE 中的相应位也置 1。(只读)

Register 4.9: GPIO\_ENABLE\_W1TC\_REG (0x0028)



**GPIO\_ENABLE\_W1TC\_REG** GPIO0-31 输出使能清零寄存器。每一位置 1,则 GPIO\_ENABLE 中的相应位会清零。(只读)

Register 4.10: GPIO\_ENABLE1\_REG (0x002c)



GPIO\_ENABLE\_DATA GPIO32-39 输出使能。(读/写)

Register 4.11: GPIO\_ENABLE1\_W1TS\_REG (0x0030)



**GPIO\_ENABLE\_DATA** GPIO32-39 输出使能置位寄存器。每一位置 1,则 GPIO\_ENABLE1 中的相应位也置 1。(只读)

Register 4.12: GPIO\_ENABLE1\_W1TC\_REG (0x0034)



**GPIO\_ENABLE\_DATA** GPIO32-39 输出使能清零寄存器。每一位置 1,则 GPIO\_ENABLE1 中的相应位会清零。(只读)

Register 4.13: GPIO\_STRAP\_REG (0x0038)



GPIO\_STRAPPING GPIO strapping 结果: boot\_sel\_chip[5:0]: MTDI, GPIO0, GPIO2, GPIO4, MTDO, GPIO5

Register 4.14: GPIO\_IN\_REG (0x003c)



**GPIO\_IN\_REG** GPIO0-31 输入值。每个 bit 代表 pad 的片外输入值,比如片外引脚为高电平,此 bit 值应为 1,片外引脚为低电平,此 bit 值应为 0。(只读)

Register 4.15: GPIO\_IN1\_REG (0x0040)



**GPIO\_IN\_DATA\_NEXT** GPIO32-39 输入值。每个 bit 代表 pad 的片外输入值。(只读)

Register 4.16: GPIO\_STATUS\_REG (0x0044)



**GPIO\_STATUS\_REG** GPIO0-31 中断状态寄存器。每个 bit 都可以作为两个 CPU 的两种中断源,同时应该把 GPIO\_PINn\_REG 的 0-4 bit 相应的 GPIO\_STATUS\_INTERRUPT 的使能位置为 1。(读 / 写)

Register 4.17: GPIO\_STATUS\_W1TS\_REG (0x0048)



**GPIO\_STATUS\_W1TS\_REG** GPIO0-31 中断状态置位寄存器。每一位置 1,则 GPIO\_STATUS\_INTERRUPT中的相应位也置1。(只读)

Register 4.18: GPIO\_STATUS\_W1TC\_REG (0x004c)



**GPIO\_STATUS\_W1TC\_REG** GPIO0-31 中断状态清除寄存器。每一位置 1,则 GPIO\_STATUS\_INTERRUPT中的相应位会清零。(只读)

Register 4.19: GPIO\_STATUS1\_REG (0x0050)



GPIO\_STATUS\_INTERRUPT GPIO32-39 中断状态。(读/写)

Register 4.20: GPIO\_STATUS1\_W1TS\_REG (0x0054)



**GPIO\_STATUS\_INTERRUPT** GPIO32-39 中断状态置位寄存器。每一位置 1,则 GPIO\_STATUS\_INTERRUPT1中的相应位也置1。(只读)

Register 4.21: GPIO\_STATUS1\_W1TC\_REG (0x0058)



**GPIO\_STATUS\_INTERRUPT** GPIO32-39 中断状态清除寄存器。每一位置 1,则 GPIO\_STATUS\_INTERRUPT1中的相应位会清零。(只读)

Register 4.22: GPIO\_ACPU\_INT\_REG (0x0060)



GPIO\_ACPU\_INT\_REG GPIO0-31 APP CPU 中断状态寄存器。(只读)

Register 4.23: GPIO\_ACPU\_NMI\_INT\_REG (0x0064)



GPIO\_ACPU\_NMI\_INT\_REG GPIO0-31 APP CPU 非屏蔽中断状态寄存器。(只读)

Register 4.24: GPIO\_PCPU\_INT\_REG (0x0068)



GPIO\_PCPU\_INT\_REG GPIO0-31 PRO CPU 中断状态寄存器。(只读)

Register 4.25: GPIO\_PCPU\_NMI\_INT\_REG (0x006c)



GPIO\_PCPU\_NMI\_INT\_REG GPIO0-31 PRO CPU 非屏蔽中断状态寄存器。(只读)

Register 4.26: GPIO\_ACPU\_INT1\_REG (0x0074)



GPIO\_APPCPU\_INT GPIO32-39 APP CPU 中断状态寄存器。(只读)

Register 4.27: GPIO\_ACPU\_NMI\_INT1\_REG (0x0078)



GPIO\_APPCPU\_NMI\_INT GPIO32-39 APP CPU 非屏蔽中断状态寄存器。(只读)

Register 4.28: GPIO\_PCPU\_INT1\_REG (0x007c)



GPIO\_PROCPU\_INT GPIO32-39 PRO CPU 中断状态寄存器。(只读)

Register 4.29: GPIO\_PCPU\_NMI\_INT1\_REG (0x0080)



GPIO\_PROCPU\_NMI\_INT GPIO32-39 PRO CPU 非屏蔽中断状态寄存器。(只读)

Register 4.30: GPIO\_PINn\_REG (n: 0-39) (0x88+0x4\*n)

|    |   |   |   |   |   | 4 | No. Service Control of the Control o | (Ball |   |   |   |   |    |    |   | GP <sup>W</sup> | OBIN |    | ( Elm |    | <sub>Io</sub> d<br>St | (O) | EN MARK | JR S | FLAR | Koser<br>K | Bar | Ŕ | 10 P |   | Q JANKS |
|----|---|---|---|---|---|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---|---|---|---|----|----|---|-----------------|------|----|-------|----|-----------------------|-----|---------|------|------|------------|-----|---|------|---|---------|
| 31 |   |   |   |   |   |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |       |   |   |   |   | 18 | 17 |   |                 |      | 13 | 12    | 11 | 10                    |     | 7       | 7 6  |      |            | 3   | 2 | 3    | 2 |         |
| 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0     | 0 | 0 | 0 | 0 | 0  | Х  | Х | Х               | Х    | Х  | 0     | 0  | Х                     | х   | X >     | < C  | 0    | 0          | 0   | х | 0    | 0 | Reset   |

GPIO\_PIN∩\_INT\_ENA bit0: APP CPU 中断使能; (读/写)

bit1: APP CPU 非屏蔽中断使能;

bit3: PRO CPU 中断使能;

bit4: PRO CPU 非屏蔽中断使能。

GPIO\_PIN∩\_WAKEUP\_ENABLE GPIO 唤醒使能。只能将 CPU 从 Light-sleep 中唤醒。(读 / 写)

GPIO\_PINn\_INT\_TYPE 0: GPIO 中断类型; (读/写)

- 1: 上升沿触发;
- 2: 下降沿触发;
- 3: 任一沿触发;
- 4: 低电平触发;
- 5: 高电平触发。

GPIO\_PINn\_PAD\_DRIVER 0: 正常输出; 1: 开漏方式输出。(读/写)

Register 4.31: GPIO\_FUNCm\_IN\_SEL\_CFG\_REG (m: 0-255) (0x130+0x4\*m)



**GPIO\_SIG***m\_***IN\_SEL** 旁路 GPIO 交换矩阵。0:通过 GPIO 交换矩阵; 1:直接通过 IO\_MUX 连接信号与外设。(读 / 写)

GPIO\_FUNCm\_IN\_INV\_SEL 反转输入值。1: 反转; 0: 不反转。(读/写)

**GPIO\_FUNC***m\_***IN\_SEL** 外设输入 *m* 选择控制。此位选择 1 个 GPIO 交换矩阵输入管脚中与信号连接,或者选择 0x38 与恒高电平输入信号连接或者选择 0x30 与恒低电平输入信号连接。(读 / 写)

Register 4.32: GPIO\_FUNCn\_OUT\_SEL\_CFG\_REG (n: 0-39) (0x530+0x4\*n)

|    |   |   |   |   |   |   |   |   |   | iles et | (B <sub>B</sub> ) |   |   |   |   |   |   |   |    | GP <sup>1</sup> | 6 8<br>6 7 | 10°68 |   | IN THE PROPERTY OF THE PROPERT | \$\f\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\ | M | ĘĻ, | <sup>0</sup> È <sub>12</sub> | No. | ys s | <u></u> |       |
|----|---|---|---|---|---|---|---|---|---|---------|-------------------|---|---|---|---|---|---|---|----|-----------------|------------|-------|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|---|-----|------------------------------|-----|------|---------|-------|
| 31 |   |   |   |   |   |   |   |   |   |         |                   |   |   |   |   |   |   |   | 12 | 11              | 10         | 9     | 8 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                         |   |     |                              |     |      | 0       |       |
| 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0       | 0                 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0  | Х               | х          | Х     | х | Х                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Х                                       | Х | Х   | Х                            | Х   | Х    | х       | Reset |

GPIO\_FUNCn\_OEN\_INV\_SEL 1: 反转输出使能信号; 0: 不反转输出使能信号。(读/写)

**GPIO\_FUNC**<sub>n</sub>\_**OEN\_SEL** 1: 强制从 GPIO\_ENABLE\_REG bit n 中选取输出使能信号。0: 使用从外设选取的输出使能信号。(读 / 写)

GPIO\_FUNCn\_OUT\_INV\_SEL 1: 反转输出值; 0: 不反转输出值。(读/写)

**GPIO\_FUNC***n\_***OUT\_SEL** GPIO 输出 *n* 的选择控制。值为 *s*(0<=*s*<256) 连接外设输出 *s* 与 GPIO 输出 *n*。值为 256 选择 GPIO\_DATA\_REG 和 GPIO\_ENABLE\_REG 的 bit *n* 做为输出值和输出使能。(读 / 写)

Register 4.33: IO\_MUX\_ $\times$ \_REG ( $\times$ : GPIO0-GPIO39) (0x10+4 $\times$ )

|    |   |   |   |   |   |   |   | yo. | graet | ) |   |   |   |   |   |    |    | o <sup>t</sup> | N <sub>C</sub> | SSE OF |   | St. O. |   | THE A |   | O'W' | SA CO | O'N'CH'CO | 1000<br>1000<br>1000<br>1000<br>1000<br>1000<br>1000<br>100 | NO SE |
|----|---|---|---|---|---|---|---|-----|-------|---|---|---|---|---|---|----|----|----------------|----------------|--------|---|--------|---|-------|---|------|-------|-----------|-------------------------------------------------------------|-------|
| 31 |   |   |   |   |   |   |   |     |       |   |   |   |   |   |   | 15 | 14 |                | 12             | 11 10  | 9 | 8      | 7 | 6 5   | 4 | 3    | 2     | 1         | 0                                                           |       |
| 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0   | 0     | 0 | 0 | 0 | 0 | 0 | 0 | 0  |    | 0x0            |                | 0x2    | 0 | 0      | 0 | 0x0   | 0 | 0    | 0     | 0         | 0                                                           | Reset |

**IO\_x\_MCU\_SEL** 为信号选择 IO\_MUX 功能。0: 选择功能 1; 1: 选择功能 2; 以此类推。(读 / 写)

 $IO_x$ \_FUNC\_DRV 选择驱动强度,值越大,强大越大。(读 / 写)

**IO\_x\_FUNC\_IE** pad 的输入使能。1: 输入使能; 0: 输入关闭。(读 / 写)

**IO\_***x*\_**FUNC\_WPU** pad 的上拉使能。1: 内部上拉使能; 0: 内部上拉关闭。(读 / 写)

 $IO_x$ \_FUNC\_WPD pad 的下拉使能。1: 内部下拉使能;0: 内部下拉关闭。(读 / 写)

 $IO_x$ \_MCU\_DRV 睡眠模式下选择 pad 的驱动强度,值越大,强度越大。(读 / 写)

 $IO_x$ \_MCU\_IE 睡眠模式下 pad 的输入使能。1:输入使能;0:输入关闭。(读 / 写)

**IO\_x\_MCU\_WPU** 睡眠模式下 pad 的上拉使能。1: 内部上拉使能; 0: 内部上拉关闭。(读 / 写)

 $IO_{X}$ MCU\_WPD 睡眠模式下 pad 的下拉使能。1:内部下拉使能;0:内部下拉关闭。(读/写)

IO\_x\_SLP\_SEL pad 的睡眠模式选择。置 1 将使能睡眠模式。(读/写)

**IO\_x\_MCU\_OE** 睡眠模式下 pad 的输出使能。1: 输出使能; 2: 输出关闭。(读 / 写)

Register 4.34: RTCIO\_RTC\_GPIO\_OUT\_REG (0x0000)



RTCIO\_RTC\_GPIO\_OUT\_DATA GPIO0-17 输出寄存器。Bit14 是 GPIO[0], bit15 是 GPIO[1], 以此类推。(读/写)

Register 4.35: RTCIO\_RTC\_GPIO\_OUT\_W1TS\_REG (0x0001)



RTCIO\_RTC\_GPIO\_OUT\_DATA\_W1TS GPIO0-17 输出设置寄存器。每一位置 1,则 RT-CIO\_RTC\_GPIO\_OUT 中的相应位也会置 1。(只写)

Register 4.36: RTCIO\_RTC\_GPIO\_OUT\_W1TC\_REG (0x0002)



RTCIO\_RTC\_GPIO\_OUT\_DATA\_W1TC GPIO0-17 输出清除寄存器。每一位置 1,则 RT-CIO\_RTC\_GPIO\_OUT 中的相应位会清零。(只写)

Register 4.37: RTCIO\_RTC\_GPIO\_ENABLE\_REG (0x0003)



RTCIO\_RTC\_GPIO\_ENABLE GPIO0-17 输出使能。Bit14 是 GPIO[0], bit15 是 GPIO[1], 以此类推。 1 代表此 GPIO 为输出口。(读 / 写)

Register 4.38: RTCIO\_RTC\_GPIO\_ENABLE\_W1TS\_REG (0x0004)



RTCIO\_RTC\_GPIO\_ENABLE\_W1TS GPIO0-17 输出使能设置寄存器。每一位置 1,则 RT-CIO\_RTC\_GPIO\_ENABLE 中的相应位也会置 1。(只写)

Register 4.39: RTCIO\_RTC\_GPIO\_ENABLE\_W1TC\_REG (0x0005)



RTCIO\_RTC\_GPIO\_ENABLE\_W1TC GPIO0-17 输出使能清除寄存器。每一位置 1,则 RT-CIO\_RTC\_GPIO\_ENABLE 中的相应位会清零。(只写)

Register 4.40: RTCIO\_RTC\_GPIO\_STATUS\_REG (0x0006)



**RTCIO\_RTC\_GPIO\_STATUS\_INT** GPIO0-17 中断状态。Bit14 是 GPIO[0], bit15 是 GPIO[1], 以此类推。此寄存器应同时和 RTCIO\_RTC\_GPIO\_PINn\_REG 的 RTCIO\_RTC\_GPIO\_PINn\_INT\_TYPE中断类型配合使用,1 代表有相应中断,0 代表没有中断。(读/写)

Register 4.41: RTCIO\_RTC\_GPIO\_STATUS\_W1TS\_REG (0x0007)



RTCIO\_RTC\_GPIO\_STATUS\_INT\_W1TS GPIO0-17 中断设置寄存器。每一位置 1,则 RT-CIO\_RTC\_GPIO\_STATUS\_INT 中的相应位也会置 1。(只写)

Register 4.42: RTCIO\_RTC\_GPIO\_STATUS\_W1TC\_REG (0x0008)



RTCIO\_RTC\_GPIO\_STATUS\_INT\_W1TC GPIO0-17 中断清除寄存器。每一位置 1,则 RT-CIO\_RTC\_GPIO\_STATUS\_INT 中的相应位会清零。(只写)

Register 4.43: RTCIO\_RTC\_GPIO\_IN\_REG (0x0009)



**RTCIO\_RTC\_GPIO\_IN\_NEXT** GPIO0-17 输入值。Bit14 是 GPIO[0], bit15 是 GPIO[1], 以此类推。每个 bit 代表 pad 的片外输入值,比如片外引脚为高电平,此 bit 值应为 1,片外引脚为低电平,此 bit 值应为 0。(只读)

Register 4.44: RTCIO\_RTC\_GPIO\_PINn\_REG (n: 0-17) (0xA+1\*n)



RTCIO\_RTC\_GPIO\_PINn\_WAKEUP\_ENABLE GPIO 唤醒使能。只能将处于 Light-sleep 的 ESP32 唤醒。(读/写)

RTCIO\_RTC\_GPIO\_PINn\_INT\_TYPE GPIO 中断类型选择。(读/写)

- 0: GPIO 中断关闭;
- 1: 上升沿触发;
- 2: 下降沿触发;
- 3: 任一沿触发;
- 4: 低电平触发;
- 5: 高电平触发。

RTCIO\_RTC\_GPIO\_PINn\_PAD\_DRIVER Pad 驱动器选择。0: 正常输出; 1: 开漏模式。(读/写)

Register 4.45: RTCIO\_DIG\_PAD\_HOLD\_REG (0x001d)



RTCIO\_DIG\_PAD\_HOLD\_REG 选择哪一个数字 pad 置于 hold 状态。0: 允许正常操作; 1: 置于 hold 状态。(读 / 写)

Register 4.46: RTCIO HALL SENS REG (0x001e)



RTCIO\_HALL\_XPD\_HALL 给霍尔传感器上电,连接 VP 和 VN。(读 / 写)

RTCIO\_HALL\_PHASE 反转霍尔传感器的极性。(读/写)

Register 4.47: RTCIO\_SENSOR\_PADS\_REG (0x001f)



RTCIO\_SENSOR\_SENSE<sub>0</sub>\_HOLD 置 1 保持传感器 n 的输出值。0: 正常操作。(读 / 写)

RTCIO\_SENSOR\_SENSEn\_MUX\_SEL 1: 连接传感器 n 与 RTC 模块; 0: 连接传感器 n 与数字 IO\_MUX。(读 / 写)

RTCIO\_SENSOR\_SENSEn\_FUN\_SEL 选择 RTC IO\_MUX 功能。0:选择 Function 0;1:选择 Function 1。(读 / 写)

RTCIO\_SENSOR\_SENSEn\_SLP\_SEL pad 的睡眠模式选择信号。pad 进入睡眠模式时应将此 bit 置 1。(读 / 写)

RTCIO\_SENSOR\_SENSEn\_SLP\_IE 睡眠模式下 pad 的输入使能。1:使能;0: 关闭。(读 / 写)

RTCIO\_SENSOR\_SENSEn\_FUN\_IE pad 的输入使能。1: 使能; 0: 关闭。(读 / 写)

Register 4.48: RTCIO\_ADC\_PAD\_REG (0x0020)



RTCIO\_ADC\_ADCn\_HOLD 置 1 将保留 pad 的输出值, 0: 正常操作。(读 / 写)

RTCIO\_ADC\_ADCn\_MUX\_SEL 1: 连接 pad 与数字 IO\_MUX。(读 / 写) 0: 连接 pad 与 RTC 模块。

RTCIO\_ADC\_ADCn\_FUN\_SEL 选择 RTC 功能。0:选择 Function 0; 1:选择 Function 1。(读/写)

RTCIO\_ADC\_ADC\_SLP\_SEL pad 的睡眠模式选择信号。置 1 pad 将进入睡眠模式。(读 / 写)

RTCIO\_ADC\_ADC\_SLP\_IE 睡眠模式下 pad 的输入使能。1:使能;0:关闭。(读/写)

RTCIO\_ADC\_ADCn\_FUN\_IE pad 的输入使能。1: 使能; 0: 关闭。(读 / 写)



#### Register 4.49: RTCIO PAD DAC1 REG (0x0021)

RTCIO\_PAD\_PDAC1\_DRV 选择 pad 的驱动强度。(读/写)

RTCIO\_PAD\_PDAC1\_HOLD 置 1 将保留 pad 的输出值, 0: 正常操作。(读 / 写)

RTCIO\_PAD\_PDAC1\_RDE 1: 下拉使能; 0: 下拉关闭。(读/写)

RTCIO\_PAD\_PDAC1\_RUE 1: 上拉使能; 0: 上拉关闭。(读/写)

RTCIO\_PAD\_PDAC1\_DAC PAD DAC1 输出值。(读/写)

RTCIO\_PAD\_PDAC1\_XPD\_DAC 给 DAC1 上电。一般而言, DAC 上电时, PDAC1 应该置为三态, 即 IE=0、OE=0、RDE=0、RUE=0。(读 / 写)

RTCIO\_PAD\_PDAC1\_MUX\_SEL 1: 连接 pad 与数字 IO\_MUX。(读 / 写) 0: 连接传感器 4 与 RTC 模块。

RTCIO\_PAD\_PDAC1\_FUN\_SEL pad 的功能选择信号。(读 / 写)

RTCIO\_PAD\_PDAC1\_SLP\_SEL pad 的睡眠模式选择信号。置 1 则 pad 进入睡眠模式。(读 / 写)

RTCIO\_PAD\_PDAC1\_SLP\_IE 睡眠模式下 pad 的输入使能。1: 使能; 0: 关闭。(读/写)

RTCIO\_PAD\_PDAC1\_SLP\_OE pad 的输出使能。1: 使能; 0: 关闭。(读 / 写)

RTCIO\_PAD\_PDAC1\_FUN\_IE pad 的输入使能。1: 使能; 0: 关闭。(读 / 写)

RTCIO\_PAD\_PDAC1\_DAC\_XPD\_FORCE 给 DAC1 上电。一般而言, DAC 上电时, PDAC1 应该置为三态,即 IE=0、OE=0、RDE=0、RUE=0。(读/写)



#### Register 4.50: RTCIO PAD DAC2 REG (0x0022)

RTCIO\_PAD\_PDAC2\_DRV 选择 pad 的驱动强度。(读/写)

RTCIO\_PAD\_PDAC2\_HOLD 置 1 将保留 pad 的输出值, 0: 正常操作。(读 / 写)

RTCIO\_PAD\_PDAC2\_RDE 1: 下拉使能; 0: 下拉关闭。(读/写)

RTCIO\_PAD\_PDAC2\_RUE 1: 上拉使能; 0: 上拉关闭。(读/写)

RTCIO\_PAD\_PDAC2\_DAC PAD DAC2 输出值。(读/写)

RTCIO\_PAD\_PDAC2\_XPD\_DAC 给 DAC2 上电。一般而言, DAC 上电时, PDAC2 应该置为三态, 即 IE=0, OE=0, RDE=0, RUE=0。(读 / 写)

RTCIO\_PAD\_PDAC2\_MUX\_SEL 1: 连接 pad 与数字 IO\_MUX。(读 / 写) 0: 连接传感器 4 与 RTC 模块。

RTCIO\_PAD\_PDAC2\_FUN\_SEL 选择 pad 的 RTC 功能, 0: 选择 Function 0; 1: 选择 Function 1。(读 / 写)

RTCIO\_PAD\_PDAC2\_SLP\_SEL pad 的睡眠模式选择信号。置 1 则 pad 进入睡眠模式。(读/写)

RTCIO\_PAD\_PDAC2\_SLP\_IE 睡眠模式下 pad 的输入使能。1: 使能; 0: 关闭。(读 / 写)

RTCIO\_PAD\_PDAC2\_SLP\_OE pad 的输出使能。1: 使能; 0: 关闭。(读 / 写)

RTCIO\_PAD\_PDAC2\_FUN\_IE pad 的输入使能。1: 使能; 0: 关闭。(读/写)

RTCIO\_PAD\_PDAC2\_DAC\_XPD\_FORCE 给 DAC2 上电。一般而言, DAC 上电时, PDAC2 应该置为三态,即 IE=0, OE=0, RDE=0, RUE=0。(读 / 写)

Register 4.51: RTCIO XTAL 32K PAD REG (0x0023)

| Ŕ <sup>Ċ</sup> | 4k | 150 N | (b) | (b) | 1807 | The Tree | ~ <i>,</i><br>~, | (b) | log to | 38, | 大b<br>38 | , Y | کر<br>ا | into<br>soto | + 4. | W to | 10/1<br>10/ | 30,000 | Solver Control | , Tb | ~)<br>{ | (b) | 1807<br>1308 | NATO | × | 14 / J | 1. | in 30t sat |
|----------------|----|-------|-----|-----|------|----------|------------------|-----|--------|-----|----------|-----|---------|--------------|------|------|-------------|--------|----------------|------|---------|-----|--------------|------|---|--------|----|------------|
| 31 3           | 29 | 28    | 27  | 26  | 25   | 24       | 23               | 22  | 21     | 20  | 19       | 18  | 17      | 16 1         | 5 14 | 13   | 12          | 11     | 10 9           | 8    | 7       | 6   | 5            | 4    | 3 | 2 1    | 1  |            |
| 2              | 0  | 0     | 0   | 2   | 2    | 0        | 0                | 0   | 0      | 1   | 0        | 0   | 0       | 0            | 0    | 0    | 0           | 0      | 0              | 0    | 0       | 0   | 0            | 1    | 0 | 0 0    | 0  | Reset      |

RTCIO\_XTAL\_X32N\_DRV 选择 pad 的驱动强度。(读 / 写)

RTCIO\_XTAL\_X32N\_HOLD 置 1 将保留 pad 的输出值, 0: 正常操作。(读/写)

**RTCIO\_XTAL\_X32N\_RDE** 1: 下拉使能; 0: 下拉关闭。(读/写)

**RTCIO\_XTAL\_X32N\_RUE** 1: 上拉使能; 0: 上拉关闭。(读 / 写)

RTCIO\_XTAL\_X32P\_DRV 选择 pad 的驱动强度。(读/写)

RTCIO\_XTAL\_X32P\_HOLD 置 1 将保留 pad 的输出值, 0: 正常操作。(读/写)

**RTCIO\_XTAL\_X32P\_RDE** 1: 下拉使能; 0: 下拉关闭。(读/写)

**RTCIO\_XTAL\_X32P\_RUE** 1: 上拉使能; 0: 上拉关闭。(读/写)

RTCIO\_XTAL\_DAC\_XTAL\_32K 32K XTAL 偏置电流 DAC 值。(读/写)

RTCIO\_XTAL\_XPD\_XTAL\_32K 给 32 kHz 晶振通电。(读 / 写)

RTCIO\_XTAL\_X32N\_MUX\_SEL 1: 连接 X32N 与数字 IO\_MUX; 0: 连接 RTC 模块。(读/写)

RTCIO\_XTAL\_X32P\_MUX\_SEL 1: 连接 X32P pad 与数字 IO\_MUX; 0: 连接 RTC 模块。(读 / 写)

RTCIO\_XTAL\_X32N\_FUN\_SEL 选择 pad 的 RTC 功能, 0: 选择 Function 0; 1: 选择 Function 1。(读 / 写)

RTCIO\_XTAL\_X32N\_SLP\_SEL pad 的睡眠模式选择信号。置 1 则 pad 进入睡眠模式。(读/写)

RTCIO\_XTAL\_X32N\_SLP\_IE 睡眠模式下 pad 的输入使能。1: 使能; 0: 关闭。(读/写)

RTCIO\_XTAL\_X32N\_SLP\_OE pad 的输出使能。1: 使能; 0: 关闭。(读/写)

**RTCIO\_XTAL\_X32N\_FUN\_IE** pad 的输入使能。1: 使能; 0: 关闭。(读 / 写)

RTCIO\_XTAL\_X32P\_FUN\_SEL 选择 pad 的 RTC 功能, 0: 选择 Function 0; 1: 选择 Function 1。(读 / 写)

RTCIO\_XTAL\_X32P\_SLP\_SEL 睡眠模式选择,置1则 pad 进入睡眠模式。(读/写)

RTCIO\_XTAL\_X32P\_SLP\_IE 睡眠模式下 pad 的输入使能。1: 使能; 0: 关闭。(读/写)

RTCIO\_XTAL\_X32P\_SLP\_OE 睡眠模式下 pad 的输出使能。1: 使能; 0: 关闭。(读/写)

RTCIO\_XTAL\_X32P\_FUN\_IE pad 的输入使能。1: 使能; 0: 关闭。(读/写)

RTCIO XTAL DRES XTAL 32K 32K XTAL 电阻偏置控制。(读/写)

RTCIO\_XTAL\_DBIAS\_XTAL\_32K 32K XTAL 自偏置参考控制。(读/写)

Register 4.52: RTCIO\_TOUCH\_CFG\_REG (0x0024)



RTCIO\_TOUCH\_XPD\_BIAS 触摸传感器偏置上电位。1: 上电; 0: 断电。(读/写)

RTCIO\_TOUCH\_DREFH 触摸传感器波顶电压。(读/写)

RTCIO\_TOUCH\_DREFL 触摸传感器波底电压。(读/写)

RTCIO\_TOUCH\_DRANGE 触摸传感器电压变动范围。(读/写)

RTCIO\_TOUCH\_DCUR 触摸传感器偏置电流。当 BIAS\_SLEEP 使能时,可以进行设置。(读 / 写)

Register 4.53: RTCIO\_TOUCH\_PADn\_REG (n: 0-9) (0x25+1\*n)



RTCIO\_TOUCH\_PADn\_DAC 触摸传感器斜率控制。每个触摸 pad 为 3-bit, 默认为 100。(读 / 写)

RTCIO\_TOUCH\_PADn\_START 启动触摸传感器。(读/写)

**RTCIO\_TOUCH\_PAD***n\_***\_TIE\_OPT** 默认触摸传感器初始电压位。0: 0V; 1: VDD\_RTC 的电压。(读 / 写)

RTCIO\_TOUCH\_PADn\_XPD 触摸传感器上电。(读 / 写)

RTCIO\_TOUCH\_PADn\_TO\_GPIO 连接 RTC pad 输入与数字 pad 输入,可以置 0。(读 / 写)

Register 4.54: RTCIO EXT WAKEUP0 REG (0x002f)



RTCIO\_EXT\_WAKEUPO\_SEL GPIO[0-17] 可以用于将芯片从睡眠模式中唤醒。此寄存器选择 pad 源将芯片从 Deep/Light-sleep 模式中唤醒。0: 选择 GPIO0; 1: 选择 GPIO2, 以此类推。(读/写)

Register 4.55: RTCIO\_XTL\_EXT\_CTR\_REG (0x0030)



RTCIO\_XTL\_EXT\_CTR\_SEL 选择睡眠模式下外部晶振断电使能源。0: 选择 GPIO0; 1: 选择 GPIO2, 以此类推。被选择管脚的值异或 RTCIO\_RTC\_EXT\_XTAL\_CONF\_REG[30] 上的逻辑值是晶振断电使能信号。(读/写)

Register 4.56: RTCIO\_SAR\_I2C\_IO\_REG (0x0031)



RTCIO\_SAR\_I2C\_SDA\_SEL 选择另一个 pad 作为 RTC I2C SDA 信号。0: 选择 TOUCH\_PAD[1]; 1: 选择 TOUCH\_PAD[3]。(读 / 写)

RTCIO\_SAR\_I2C\_SCL\_SEL 选择另一个 pad 作为 RTC I2C SCL signal。0: 选择 TOUCH\_PAD[1]; 1: 选择 TOUCH\_PAD[3]。(读 / 写)

# 5. I2C 控制器

## 5.1 概述

I2C(Inter-integrated circuit)总线用于使 ESP32 和多个外部设备进行通信。多个外部设备可以共用一个 I2C 总线。

## 5.2 主要特性

I2C 具有以下几个特点。

- 支持主机模式以及从机模式
- 支持多主机多从机通信
- 支持标准模式 (100 kbit/s)
- 支持快速模式 (400 kbit/s)
- 支持 7-bit 以及 10-bit 寻址
- 支持关闭 SCL 时钟实现连续数据传输
- 支持可编程数字噪声滤波功能

## 5.3 I2C 功能描述

## 5.3.1 I2C 简介

I2C 是一个两线总线,由 SDA 线和 SCL 线构成。这些线设置为漏极开漏输出。因此,I2C 总线上可以挂载多个外设,通常是和一个或多个主机以及一个或多个从机。主机通过总线访问从机。

主机发出开始信号,则通讯开始:在 SCL 为高电平时拉低 SDA 线,主机将通过 SCL 线发出 9 个时钟脉冲。前 8 个脉冲用于按位传输,该字节包括 7-bit 地址和 1 个读写位。如果从机地址与该 7-bit 地址一致,那么从机可以通过在第 9 个脉冲上拉低 SDA 线来应答。接下来,根据读 / 写标志位,主机和从机可以发送 / 接收更多的数据。根据应答位的逻辑电平决定是否停止发送数据。在数据传输中,SDA 线仅在 SCL 线为低电平时才发生变化。当主机完成通讯,回发送一个停止标志:在 SCL 为高电平时,拉高 SDA 线。

ESP32 I2C 控制器可以处理 I2C 协议, 腾出处理器核用于其它任务。

## 5.3.2 I2C 架构

I2C 控制器可以工作于 Master 模式或者 Slave 模式, I2C\_MS\_MODE 寄存器用于模式选择。图 10 为 I2C Master 基本架构图,图 11 为 I2C Slave 基本架构图。从图中可知,I2C 控制器内部主要有以下几个单元。



图 10: I2C Master 基本架构



图 11: I2C Slave 基本架构

- RAM: 大小为 32 x 8 bit, 直接映射到 CPU 内核的地址上,首地址为 (REG\_I2C\_BASE+0x100), I2C 数据的每一个字节占据一个 word 的存储地址 (因此,首字节在 +0x100,第二字节在 +0x104,第三字节在 +0x108,以此类推)。
- 16 个命令寄存器(cmd0 ~ cmd15)以及一个 CMD\_Controller: 用于 I2C Master 控制数据传输过程。I2C 控制器每次执行一个命令。
- SCL\_FSM: 用于控制 SCL 时钟, I2C\_SCL\_HIGH\_PERIOD\_REG 以及 I2C\_SCL\_LOW\_PERIOD\_REG 寄存器用于配置 SCL 的频率和占空比。
- SDA\_FSM: 用于控制 SDA 数据线。
- DATA\_Shifter: 用于将字节数据转化成比特流或者将比特流转化成字节数据。I2C\_RX\_LSB\_FIRST 和 I2C\_TX\_LSB\_FIRST 用于配置最高有效位或最低有效位的优先储存或传输。
- SCL\_Filter 以及 SDA\_Filter: 用于 I2C\_Slave 滤除输入噪声。通过配置 I2C\_SCL\_FILTER\_EN 以及 I2C\_SDA\_FILTER\_EN 寄存器可以开启或关闭滤波器。滤波器可以滤除脉宽低于 I2C\_SCL\_FILTER\_THRES 以及 I2C\_SDA\_FILTER\_THRES 的毛刺。

## 5.3.3 I2C 总线时序



图 12: I2C 时序图

图 12 为 I2C 的时序图。当 I2C 控制器工作于 Master 模式, SCL 为输出信号。当 I2C 控制器工作于 Slave 模式, SCL 为输入信号。

根据 I2C 协议规定,一次数据传输始于 START 位结束于 STOP 位。数据按照每次一个字节进行传输,每个传输的字节后有一个 ACK 位。接收数据方通过回 ACK 的方式告知发送方继续传输数据。接收数据方也可以通过不回 ACK 的方式发送方停止传输数据。

I2C 控制器的 START 位、STOP 位、数据保持时间、数据采样时间均可以通过图 12 中所示的寄存器进行配置。

## 5.3.4 I2C cmd 结构



图 13: I2C 命令寄存器结构

命令寄存器只在 I2C Master 中有效, 其内部结构如图 13 所示。

CMD\_DONE: 软件可以通过读取每条命令的 CMD\_DONE 位来判断一条命令是否执行完毕。

op\_code: op\_code 用于命令编码, I2C 控制器支持 4 种命令。

- RSTART: op\_code 等于 0 时为 RSTART 命令,该命令用于控制 I2C 协议中 START 位以及 RESTART 位的发送。
- WRITE: op\_code 等于 1 时为 WRITE 命令,该命令表示当前 Master 将发送数据。
- READ: op\_code 等于 2 时为 READ 命令,该命令表示当前 Master 将要接收数据。
- STOP: op\_code 等于 3 时为 STOP 命令,该命令用于控制协议中 STOP 位的发送。
- END: op\_code 等于 4 时为 END 命令,该命令用于 master 模式下连续发送数据。主要实现方式为关闭 SCL 时钟,当数据准备完毕,继续上次传输。

一次完整的命令序列始于 RSTART 命令,结束于 STOP 命令。

ack\_value: 当接收数据时,在字节被接收后,该位用于表示接收方将发送一个 ACK 位。

ack\_exp:该位用于设置发送方期望的ACK值。

ack\_check\_en:该位用于控制发送方是否对 ACK 位进行检测。1:检测 ACK 值;0:不检测 ACK 值。

byte\_num:该寄存器用于说明读写数据的数据长度。RSTART、STOP、END 命令中 byte\_num 无意义。

#### 5.3.5 I2C 主机写入从机



图 14: I2C Master 写 7-bit 地址 Slave

图 14 为 I2C Master 写 N 个字节数据到 I2C Slave 的配置图,其中 Master 和 Slave 均为 ESP32 I2C 控制器。根据 I2C 协议,第一个字节为 I2C Slave 地址,如图中 RAM 所示,第一个数据为(Slave 7-bit 地址 +1-bit 读写标志位),其中读写标志位为 0 时表示写操作。接下来的连续空间存储着待发送的数据。cmd 框中包含了用于运行的一系列命令。

通过 RXFIFO\_ST\_REG 中的 TXFIFO\_START\_ADDR 读取 FIFO RAM 的起始地址。

当 cmd 以及数据都准备完毕,置位 I2C\_TRANS\_START 寄存器即开始一次数据传输。I2C Slave 启动 START 位来激活从机设备。随后,I2C Master 根据 WRITE 命令从 RAM 中取出 N+1 个字节并发送给从机。第一个字节为地址。I2C Slave 首先进行地址匹配,当 I2C Master 发送的 I2C Slave 地址不匹配时,I2C Slave 停止接收数据。当地址匹配后,I2C Slave 将数据按照顺序存储到 RAM 中。当 ack\_check\_en 配置为 1 时,I2C Master 会在每个字节之后进行 ACK 检测。



图 15: I2C Master 写 10-bit 地址 Slave

I2C 控制器默认使用 7-bit 地址,也可以使用 10-bit 地址。在主机中,在发送完第一个地址位之后发送第二个 I2C 地址位即可完成。在从机中,可以通过配置 I2C\_ADDR\_10BIT\_EN 寄存器开启 10-bit 地址。I2C\_SLAVE\_ADDR 用于配置 I2C Slave 地址。图 15 为 I2C Master 写 N 个字节到 10-bit 地址 I2C Slave 的配置图,由于 10-bit Slave 地址比 7-bit 地址多一个字节,所以 WRITE 命令对应的 byte\_num 以及 RAM 中数据数量都相应增加 1。



图 16: I2C Master 写 7-bit 地址 Slave 的 M 地址 RAM

许多 I2C Slave 具有特殊寄存器。I2C Master 通过向从机发送 1 个寄存器地址可以访问从机中指定的寄存器。 ESP32 I2C Slave 控制器拥有支持上述操作的硬件。

通过置位 I2C\_FIFO\_ADDR\_CFG\_EN 来开启控制 I2C Slave 数据存储位置的功能。如图 16 所示, I2C Slave 将接收到的数据 byte0 ~ byte(N-1) 从 Slave RAM 中的 addrM 开始依次存储。



图 17: I2C Master 分段写 7-bit 地址 Slave

当一次传输的数据较多,超出 RAM 32 个字节的存储空间,可以通过 END 命令进行分段传输。图 17 所示为 I2C Master 分成两段写 Slave。图中虚线以上为第一段数据命令配置, Master 在执行到 END 命令后会关闭 SCL 时钟,控制器产生 I2C\_END\_DETECT\_INT 中断。

在接收 I2C\_END\_DETECT\_INT(或者询问命令寄存器中 END 命令中 CMD\_DONE 位)时,此时软件可以更新 cmd 以及 RAM 中的内容,如图中虚线以下所示。之后,需要清除 I2C\_END\_DETECT\_INT 中断并通过在 CTR\_CTR\_REG 中置位 I2C\_TRANS\_START 来恢复运行。

## 5.3.6 I2C 主机读取从机



图 18: I2C Master 读 7-bit 地址 Slave

图 18 为 I2C Master 从 7-bit 地址 I2C Slave 读取 N 个字节数据的配置图。首先 I2C Master 需要将 I2C Slave 的地址发送出去,所以 cmd1 为 WRITE。该命令发送的字节是一个 I2C Slave 地址以及其读写标志位,其中,1 表示这是一个读操作。根据协议规定,对于最后一个读数据,I2C Master 不回 ACK,所以将 READ 分成两次。I2C Master 对 cmd2 中 N-1 个数据均回复 ACK,对 cmd3 中的数据即传输的最后一个数据不回复 ACK。在存储接收的数据时,I2C Master 从 RAM 的首地址开始存储,图中红色 byte0 会覆盖 (Slave 地址 +1-bit 读写位)。

在存储接收的数据时,默认 I2C Master 从 RAM 的首地址开始存储。ByteO (Slave 地址 +1-bit 读写标志位) 将被覆盖。通过 RXFIFO\_ST\_REG 对应的 RXFIFO\_START\_ADDR 和 TXFIFO\_START\_ADDR,可以配置用于读写数据的 FIFO RAM 的起始地址。



图 19: I2C Master 读 10-bit 地址 Slave

图 19 为 I2C Master 通过 10-bit 地址在从机中读取数据的配置图。在从机中,通过设置 I2C\_SLAVE\_ADDR\_10BIT\_EN,可以启动该模式。在主机中,RAM 的 2 个字节用于 10-bit 地址。



图 20: I2C Master 从 7-bit 地址 Slave 的 M 地址读取 N 个数据

图 20 说明了 I2C Master 在 I2C Slave 中选择一个寄存器地址,在该地址以及之后地址中读取数据。通过在从机中设置 I2C\_FIFO\_ADDR\_CFG\_EN 可以启动该模式。从机内置的寄存器地址 M 存储在 RAM 字节中。WRITE 命令要增加 2 个字节。



图 21: I2C Master 分段读 7-bit 地址 Slave

图 21 为 I2C Master 通过 END 命令分两段从 I2C Slave 读取 N+M 个数据的配置图。虚线以上为第一段数据传输的配置,当执行到 END 命令时,I2C Master 可以更新 cmd 如虚线以下所示。I2C Slave 在 RAM 数据空之前可以通过 APB 总线更新数据。

5.4 寄存器列表 5 /I2C 控制器

## 5.3.7 中断

- I2C\_TX\_SEND\_EMPTY\_INT: 当 I2C 发送的数据比 nonfifo\_tx\_thres 多时,即触发该中断。
- I2C\_RX\_REC\_FULL\_INT: 当 I2C 接收的数据比 nonfifo\_rx\_thres 多时,即触发该中断。
- I2C\_ACK\_ERR\_INT: 当 I2C 接收到一个错误的 ACK 位时,即触发该中断。
- I2C\_TRANS\_START\_INT: 当 I2C 发送一个 START 位时,即触发该中断。
- I2C\_TIME\_OUT\_INT: 当 I2C 在接收数据时耗时过长,即触发该中断。
- I2C\_TRANS\_COMPLETE\_INT: 当 I2C Master 完成 STOP 命令,即触发该中断。
- I2C\_MASTER\_TRAN\_COMP\_INT: 当 I2C Master 发送或接收一个字节,即触发该中断。
- I2C\_ARBITRATION\_LOST\_INT: 当 I2C Master 失去 I2C 总线使用权时,即触发该中断。
- I2C\_SLAVE\_TRAN\_COMP\_INT: 当 I2C Slave 探测到 STOP 位时,即触发该中断。
- I2C\_END\_DETECT\_INT: 当 I2C 处理 END 命令时,即触发该中断。

## 5.4 寄存器列表

| 名称                       | 描述                         | I2C0       | I2C1       | 访问    |
|--------------------------|----------------------------|------------|------------|-------|
| 配置寄存器                    |                            |            |            |       |
| I2C_SLAVE_ADDR_REG       | 配置 I2C slave 地址            | 0x3FF53010 | 0x3FF67010 | 读/写   |
| I2C_RXFIFO_ST_REG        | FIFO 状态寄存器                 | 0x3FF53014 | 0x3FF67014 | 只读    |
| I2C_FIFO_CONF_REG        | FIFO 配置寄存器                 | 0x3FF53018 | 0x3FF67018 | 读/写   |
| 时序寄存器                    |                            |            |            |       |
| I2C_SDA_HOLD_REG         | 配置在 SCL 下降沿后保持时间           | 0x3FF53030 | 0x3FF67030 | 读/写   |
| I2C_SDA_SAMPLE_REG       | 配置在 SCL 上升沿后采样时间           | 0x3FF53034 | 0x3FF67034 | 读/写   |
| I2C_SCL_LOW_PERIOD_REG   | 配置 SCL 时钟的低电平宽度            | 0x3FF53000 | 0x3FF67000 | 读/写   |
| I2C_SCL_HIGH_PERIOD_REG  | 配置 SCL 时钟的高电平宽度            | 0x3FF53038 | 0x3FF67038 | 读/写   |
| I2C_SCL_START_HOLD_REG   | 配置 SDA 和 SCL 下降沿之间的延迟,用于启动 | 0x3FF53040 | 0x3FF67040 | 读/写   |
| I2C_SCL_RSTART_SETUP_REG | 配置 SCL 上升沿和 SDA 下降沿之间的延迟   | 0x3FF53044 | 0x3FF67044 | 读/写   |
| I2C_SCL_STOP_HOLD_REG    | 配置 SCL 时钟边缘后的延迟, 用于<br>停止  | 0x3FF53048 | 0x3FF67048 | 读/写   |
| I2C_SCL_STOP_SETUP_REG   | 配置 SDA 和 SCL 上升沿之间的延迟,用于停止 | 0x3FF5304C | 0x3FF6704C | 读/写   |
| 滤波寄存器                    |                            |            |            |       |
| I2C_SCL_FILTER_CFG_REG   | SCL 滤波配置寄存器                | 0x3FF53050 | 0x3FF67050 | 读/写   |
| I2C_SDA_FILTER_CFG_REG   | SDA 滤波配置寄存器                | 0x3FF53054 | 0x3FF67054 | 读/写   |
| 中断寄存器                    |                            |            |            |       |
| I2C_INT_RAW_REG          | 原始中断状态                     | 0x3FF53020 | 0x3FF67020 | 只读    |
| I2C_INT_ENA_REG          | 中断使能位                      | 0x3FF53028 | 0x3FF67028 | 读 / 写 |
| I2C_INT_CLR_REG          | 中断清除位                      | 0x3FF53024 | 0x3FF67024 | 只写    |
| 命令寄存器                    |                            |            |            |       |

 5.4 寄存器列表

5 12C 控制器

| 名称             | 描述           | I2C0       | I2C1       | 访问  |
|----------------|--------------|------------|------------|-----|
| I2C_COMD0_REG  | I2C 命令寄存器 0  | 0x3FF53058 | 0x3FF67058 | 读/写 |
| I2C_COMD1_REG  | I2C 命令寄存器 1  | 0x3FF5305C | 0x3FF6705C | 读/写 |
| I2C_COMD2_REG  | I2C 命令寄存器 2  | 0x3FF53060 | 0x3FF67060 | 读/写 |
| I2C_COMD3_REG  | I2C 命令寄存器 3  | 0x3FF53064 | 0x3FF67064 | 读/写 |
| I2C_COMD4_REG  | I2C 命令寄存器 4  | 0x3FF53068 | 0x3FF67068 | 读/写 |
| I2C_COMD5_REG  | I2C 命令寄存器 5  | 0x3FF5306C | 0x3FF6706C | 读/写 |
| I2C_COMD6_REG  | I2C 命令寄存器 6  | 0x3FF53070 | 0x3FF67070 | 读/写 |
| I2C_COMD7_REG  | I2C 命令寄存器 7  | 0x3FF53074 | 0x3FF67074 | 读/写 |
| I2C_COMD8_REG  | I2C 命令寄存器 8  | 0x3FF53078 | 0x3FF67078 | 读/写 |
| I2C_COMD9_REG  | I2C 命令寄存器 9  | 0x3FF5307C | 0x3FF6707C | 读/写 |
| I2C_COMD10_REG | I2C 命令寄存器 10 | 0x3FF53080 | 0x3FF67080 | 读/写 |
| I2C_COMD11_REG | I2C 命令寄存器 11 | 0x3FF53084 | 0x3FF67084 | 读/写 |
| I2C_COMD12_REG | I2C 命令寄存器 12 | 0x3FF53088 | 0x3FF67088 | 读/写 |
| I2C_COMD13_REG | I2C 命令寄存器 13 | 0x3FF5308C | 0x3FF6708C | 读/写 |
| I2C_COMD14_REG | I2C 命令寄存器 14 | 0x3FF53090 | 0x3FF67090 | 读/写 |
| I2C_COMD15_REG | I2C 命令寄存器 15 | 0x3FF53094 | 0x3FF67094 | 读/写 |

# 5.5 寄存器

Register 5.1: I2C\_SCL\_LOW\_PERIOD\_REG (0x0000)



**I2C\_SCL\_LOW\_PERIOD** 该寄存器用于配置 SCL 时钟信号的低电平持续的 APB 时钟周期数。(读 / 写)

Register 5.2: I2C\_CTR\_REG (0x0004)



I2C\_RX\_LSB\_FIRST 该位用于控制接收数据的存储模式。(读/写)

- 1: 从最高有效位开始接收数据;
- 0: 从最低有效位开始接收数据。

 $I2C_TX_LSB_FIRST$  该位用于控制发送数据的发送模式。(读 / 写)

- 1: 从最低有效位开始发送数据;
- 0: 从最高有效位开始发送数据。

I2C\_TRANS\_START 置位该位,开始在txfifo中发送数据。(读/写)

**I2C\_MS\_MODE** 置位该位,配置该模块为 I2C Master。清除该位,配置该模块为 I2C Slave。(读 / 写)

**I2C\_SAMPLE\_SCL\_LEVEL** 1: SCL 为低电平时,采样 SDA 数据; 0: SCL 为高电平时,采样 SDA 数据。(读 / 写)

**I2C\_SCL\_FORCE\_OUT** 1: 直接输出; 0: 漏极开漏输出。(读/写)

**I2C\_SDA\_FORCE\_OUT** 1: 直接输出; 0: 漏极开漏输出。(读/写)

Register 5.3: I2C\_SR\_REG (0x0008)

| (4 <sup>©</sup> | g Not |     | STA | K Y |   | ζÇ\ | MATTA | STA | 4) |   | Stifo ? |    |    |   | le du | Be |    |   |   | 10 P | k <sup>K</sup> | , char | ,<br>No. |   | \$\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\ | 14/A | AND CONTRACTOR OF THE PROPERTY | SA S |   |   | S. R. R. C. S. R. R. C. S. R. R. C. S. R. R. C. S. R. R. C. S. R. |
|-----------------|-------|-----|-----|-----|---|-----|-------|-----|----|---|---------|----|----|---|-------|----|----|---|---|------|----------------|--------|----------|---|-----------------------------------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|---|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31              | 30    | 28  | 27  | 26  |   | 24  | 23    |     |    |   |         | 18 | 17 |   |       | 14 | 13 |   |   |      |                | 8      | 7        | 6 | 5                                       | 4    | 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 2                                        | 1 | 0 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 0               | 0     | 0 0 | 0   | 0   | 0 | 0   | 0     | 0   | 0  | 0 | 0       | 0  | 0  | 0 | 0     | 0  | 0  | 0 | 0 | 0    | 0              | 0      | 0        | 0 | 0                                       | 0    | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0                                        | 0 | 0 | Reset                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

I2C\_TXFIFO\_CNT 该字段存储了 RAM 中接收数据的字节数。(只读)

I2C\_RXFIFO\_CNT 该字段表示需发送数据的字节数。(只读)

I2C\_BYTE\_TRANS 当传输了一个字节时,该字段变为 1。(只读)

**I2C\_SLAVE\_ADDRESSED** 当配置成 I2C Slave, 主机发送的地址为从机地址时,该位翻转为高电平。(只读)

**I2C\_BUS\_BUSY** 1: I2C 总线处于传输数据状态; 0: I2C 总线处于空闲状态。(只读)

I2C\_ARB\_LOST 当 I2C 控制器不控制 SCL 线,该寄存器变为 1。(只读)

**I2C\_TIME\_OUT** 当 I2C 控制器接收一个 bit 的时间超时,该字段变为 1。(只读)

I2C\_SLAVE\_RW 在从机模式中, 1: 主机在从机中读取数据; 0: 主机向从机写入数据。(只读)

I2C\_ACK\_REC 该寄存器存储了接收到的 ACK 位的值。(只读)

Register 5.4: I2C\_TO\_REG (0x000c)



 $I2C_TIME_OUT$  当接收一个 bit 数据超过该值时,产生超时中断。(读 / 写)

Register 5.5: I2C\_SLAVE\_ADDR\_REG (0x0010)



I2C\_SLAVE\_ADDR\_10BIT\_EN 该字段用于开启从机的 10-bit 寻址模式。(读 / 写)
I2C\_SLAVE\_ADDR 当配置为 I2C Slave 时,该字段用于配置 Slave 地址。(读 / 写)

Register 5.6: I2C\_RXFIFO\_ST\_REG (0x0014)



I2C\_TXFIFO\_END\_ADDR 如 nonfifo\_tx\_thres 所述,该位是最后发送数据的偏移地址。(只读)
I2C\_TXFIFO\_START\_ADDR 如 nonfifo\_tx\_thres 所述,该位是最先发送数据的偏移地址。(只读)
I2C\_RXFIFO\_END\_ADDR 如 nonfifo\_rx\_thres 所述,该位是最先接收数据的偏移地址。(只读)
I2C\_RXFIFO\_START\_ADDR 如 nonfifo\_rx\_thres 所述,该位是最后接收数据的偏移地址。(只读)

Register 5.7: I2C\_FIFO\_CONF\_REG (0x0018)



**I2C\_NONFIFO\_TX\_THRES** 当 I2C 发送的数据多于 nonfifo\_tx\_thres 存储的字节,它将产生 tx\_send\_empty\_int\_raw 溢出中断,并更新发送数据的当前偏移地址。(读 / 写)

**I2C\_NONFIFO\_RX\_THRES** 当 I2C 接收的数据多于 nonfifo\_tx\_thres 存储的字节,它将产生 rx\_send\_full\_int\_raw 溢出中断,并更新接收数据的当前偏移地址。(读 / 写)

I2C\_FIFO\_ADDR\_CFG\_EN 当该位为 1 时,可以按寄存器地址访问 Slave。(读 / 写)

I2C\_NONFIFO\_EN 置位使能 APB nonfifo 访问方式。(读 / 写)

Register 5.8: I2C\_INT\_RAW\_REG (0x0020)



I2C\_RX\_REC\_FULL\_INT\_RAW I2C\_RX\_REC\_FULL\_INT 中断的原始中断状态位。(只读)

**I2C\_ACK\_ERR\_INT\_RAW** I2C\_ACK\_ERR\_INT 中断的原始中断状态位。(只读)

**I2C\_TRANS\_START\_INT\_RAW** I2C\_TRANS\_START\_INT 中断的原始中断状态位。(只读)

**I2C\_TIME\_OUT\_INT\_RAW** I2C\_TIME\_OUT\_INT 中断的原始中断状态位。(只读)

**I2C\_TRANS\_COMPLETE\_INT\_RAW** I2C\_TRANS\_COMPLETE\_INT 中断的原始中断状态位。(只读)

**I2C\_MASTER\_TRAN\_COMP\_INT\_RAW** I2C\_MASTER\_TRAN\_COMP\_INT 中断的原始中断状态位。(只读)

**I2C\_ARBITRATION\_LOST\_INT\_RAW** I2C\_ARBITRATION\_LOST\_INT 中断的原始中断状态位。(只读)

**I2C\_SLAVE\_TRAN\_COMP\_INT** 中断的原始中断状态位。(只读)

**I2C\_END\_DETECT\_INT\_RAW** I2C\_END\_DETECT\_INT 中断的原始中断状态位。(只读)

Register 5.9: I2C INT CLR REG (0x0024)



I2C\_TX\_SEND\_EMPTY\_INT\_CLR 置位该位用以清除 I2C\_TX\_SEND\_EMPTY\_INT 中断。(只写)

I2C\_RX\_REC\_FULL\_INT\_CLR 置位该位用以清除 I2C\_RX\_REC\_FULL\_INT 中断。(只写)

I2C\_ACK\_ERR\_INT\_CLR 置位该位用以清除 I2C\_ACK\_ERR\_INT 中断。(只写)

I2C\_TRANS\_START\_INT\_CLR 置位该位用以清除 I2C\_TRANS\_START\_INT 中断。(只写)

I2C\_TIME\_OUT\_INT\_CLR 置位该位用以清除 I2C\_TIME\_OUT\_INT 中断。(只写)

I2C\_TRANS\_COMPLETE\_INT\_CLR 置位该位用以清除 I2C\_TRANS\_COMPLETE\_INT 中断。(只写)

I2C\_MASTER\_TRAN\_COMP\_INT\_CLR 置位该位用以清除 I2C\_MASTER\_TRAN\_COMP\_INT 中断。(只写)

I2C\_ARBITRATION\_LOST\_INT\_CLR 置位该位用以清除 I2C\_ARBITRATION\_LOST\_INT 中断。(只写)

I2C\_SLAVE\_TRAN\_COMP\_INT\_CLR 置位该位用以清除 I2C\_SLAVE\_TRAN\_COMP\_INT 中断。(只写)

I2C\_END\_DETECT\_INT\_CLR 置位该位用以清除 I2C\_END\_DETECT\_INT 中断。(只写)

Register 5.10: I2C\_INT\_ENA\_REG (0x0028)



I2C\_TX\_SEND\_EMPTY\_INT\_ENA 中断使能位,用于 I2C\_TX\_SEND\_EMPTY\_INT 中断。(读 / 写)

I2C\_RX\_REC\_FULL\_INT\_ENA 中断使能位,用于 I2C\_RX\_REC\_FULL\_INT 中断。(读 / 写)

I2C\_ACK\_ERR\_INT\_ENA 中断使能位,用于 I2C\_ACK\_ERR\_INT 中断。(读/写)

I2C\_TRANS\_START\_INT\_ENA 中断使能位,用于 I2C\_TRANS\_START\_INT 中断。(读 / 写)

I2C\_TIME\_OUT\_INT\_ENA 中断使能位,用于 I2C\_TIME\_OUT\_INT 中断。(读 / 写)

**I2C\_TRANS\_COMPLETE\_INT\_ENA** 中断使能位,用于 I2C\_TRANS\_COMPLETE\_INT 中断。(读 / 写)

I2C\_MASTER\_TRAN\_COMP\_INT\_ENA 中断使能位,用于 I2C\_MASTER\_TRAN\_COMP\_INT 中断。(读 / 写)

I2C\_ARBITRATION\_LOST\_INT\_ENA 中断使能位,用于 I2C\_ARBITRATION\_LOST\_INT 中断。(读 / 写)

I2C\_SLAVE\_TRAN\_COMP\_INT\_ENA 中断使能位,用于 I2C\_SLAVE\_TRAN\_COMP\_INT 中断。(读 / 写)

I2C\_END\_DETECT\_INT\_ENA 中断使能位,用于 I2C\_END\_DETECT\_INT 中断。(读 / 写)

Register 5.11: I2C INT STATUS REG (0x002c)



I2C\_TX\_SEND\_EMPTY\_INT\_ST 隐蔽中断状态位,用于 I2C\_TX\_SEND\_EMPTY\_INT 中断。(只读)

I2C\_RX\_REC\_FULL\_INT\_ST 隐蔽中断状态位,用于I2C\_RX\_REC\_FULL\_INT中断。(只读)

I2C\_ACK\_ERR\_INT\_ST 隐蔽中断状态位,用于 I2C\_ACK\_ERR\_INT 中断。(只读)

I2C\_TRANS\_START\_INT\_ST 隐蔽中断状态位,用于 I2C\_TRANS\_START\_INT 中断。(只读)

I2C\_TIME\_OUT\_INT\_ST 隐蔽中断状态位,用于 I2C\_TIME\_OUT\_INT 中断。(只读)

I2C\_TRANS\_COMPLETE\_INT\_ST 隐蔽中断状态位,用于I2C\_TRANS\_COMPLETE\_INT 中断。(只读)

**I2C\_MASTER\_TRAN\_COMP\_INT\_ST** 隐蔽中断状态位,用于 I2C\_MASTER\_TRAN\_COMP\_INT 中断。(只读)

**I2C\_ARBITRATION\_LOST\_INT\_ST** 隐蔽中断状态位,用于 I2C\_ARBITRATION\_LOST\_INT 中断。(只读)

**I2C\_SLAVE\_TRAN\_COMP\_INT\_ST** 隐蔽中断状态位,用于 I2C\_SLAVE\_TRAN\_COMP\_INT 中断。(只读)

I2C\_END\_DETECT\_INT\_ST 隐蔽中断状态位,用于I2C\_END\_DETECT\_INT中断。(只读)

Register 5.12: I2C\_SDA\_HOLD\_REG (0x0030)



I2C\_SDA\_HOLD\_TIME 用于配置 SCL 下降沿后 SDA 保持不变的 APB 时钟周期数。(读/写)

Register 5.13: I2C\_SDA\_SAMPLE\_REG (0x0034)



**I2C\_SDA\_SAMPLE\_TIME** 用于配置在 SCL 上升沿和 I2C 控制器之间的延迟,基于 APB 时钟周期数。(读/写)

Register 5.14: I2C\_SCL\_HIGH\_PERIOD\_REG (0x0038)



I2C\_SCL\_HIGH\_PERIOD 用于配置使 SCL 维持在高电平的 APB 时钟周期数。(读/写)

Register 5.15: I2C\_SCL\_START\_HOLD\_REG (0x0040)



**I2C\_SCL\_START\_HOLD\_TIME** 用于配置 SDA 下降沿和 SCL 下降沿之间的时间,用于 START 状态,基于 APB 时钟周期数。(读 / 写)

Register 5.16: I2C\_SCL\_RSTART\_SETUP\_REG (0x0044)



**I2C\_SCL\_RSTART\_SETUP\_TIME** 用于配置 SCL 的上升沿和 SDA 的下降沿之间的时间,用于 RESTART 状态,基于 APB 时钟周期数。(读 / 写)

Register 5.17: I2C\_SCL\_STOP\_HOLD\_REG (0x0048)



I2C\_SCL\_STOP\_HOLD\_TIME 用于配置 STOP 状态后的延迟,基于 APB 时钟周期数。(读/写)

Register 5.18: I2C\_SCL\_STOP\_SETUP\_REG (0x004C)



**I2C\_SCL\_STOP\_SETUP\_TIME** 用于配置 SCL 上升沿和 SDA 上升沿之间的时间,基于 APB 时钟 周期数。(读 / 写)

Register 5.19: I2C\_SCL\_FILTER\_CFG\_REG (0x0050)

|    |   |   |   |   |   |   |   |   |   |   |   |   | , | le service de la constant de la cons | (pd) |   |   |   |   |   |   |   |   |   |   |   |   | \$2° |   | FILTE<br>RC | 30, | A THRES |
|----|---|---|---|---|---|---|---|---|---|---|---|---|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---|---|---|---|---|---|---|---|---|---|---|---|------|---|-------------|-----|---------|
| 31 |   |   |   |   |   |   |   |   |   |   |   |   |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |   |   |   |   |   |   |   |   |   |   |   | 4 | 3    | 2 |             | 0   |         |
| 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0    | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1    | 0 | 0           | 0   | Reset   |

**I2C\_SCL\_FILTER\_EN** 该位为 SCL 的滤波使能位。(读 / 写)

**I2C\_SCL\_FILTER\_THRES** 基于 APB 时钟周期数,当 SCL 输入信号上的脉冲宽度小于该寄存器的值时,I2C 控制器将过滤该脉冲。(读 / 写)

Register 5.20: I2C\_SDA\_FILTER\_CFG\_REG (0x0054)



I2C\_SDA\_FILTER\_EN 该位为 SDA 的滤波使能位。(读 / 写)

**I2C\_SDA\_FILTER\_THRES** 基于 APB 时钟周期数, 当 SDA 输入信号上的脉冲宽度小于此寄存器的值时, I2C 控制器将过滤该脉冲。(读 / 写)

Register 5.21: I2C\_COMD $^n$ \_REG ( $^n$ : 0-15) (0x58+4\* $^n$ )



**I2C\_COMMAND***n\_***DONE** 在 I2C 主机模式下完成 command *n* 时,该位翻转为高电平。(读 / 写)

**I2C\_COMMAND***n* command *n* 的内容。它包括三个部分:(读 / 写)

op\_code 是命令, 0: START; 1: WRITE; 2: READ; 3: STOP; 4: END。

Byte\_num 代表了需要被发送或接收的字节数。

ack\_check\_en, ack\_exp 和 ack 用于控制 ACK 位。详情请参考 I2C cmd 结构。

# 6. LED\_PWM

# 6.1 概述

LED\_PWM 用于控制 LED 的亮度和颜色,同时也可以因其它目的产生 PWM 信号。LED\_PWM 拥有 16 路通道,分别有 8 路高速通道和 8 路低速通道。在本文中,hschn 指高速通道,lschn 指低速通道,分别由 4 个命名为 h\_timerx 和 l\_timerx 的定时器驱动,能够产生独立的数字波形。高速通道和低速均能分别由各自的分频器控制。PWM 还能够自动调节占空比,在无须处理器干预的情况下实现亮度和颜色渐变。

# 6.2 功能描述

### 6.2.1 架构



图 22: LED\_PWM 架构

图 22 为 LED\_PWM 基本架构图。从图中可知, LED\_PWM 内部有 8 个高速通道以及 8 个低速通道。高速通道有 4 个高速时钟模块,可以从中任选一个 h\_timerx。低速通道有 4 个低速时钟模块,可以从中任选一个 l\_timerx。



图 23: LED\_PWM 高速通道框图

图 23 表示一个 PWM 通道和它选取的分频器;在该情况下,一个高速通道配有一个高速分频器。

6.2 功能描述 6 LED\_PWM

#### 6.2.2 分频器

一个高速时钟由选择器构成,选择器可以从 2 个时钟源中任选一个时钟源:REF\_TICK 和 APB\_CLK,请参考章节复位和时钟。输入时钟首先由分频器进行分频,分频系数为 LEDC\_DIV\_NUM\_HSTIMERx,该系数的固定位宽是 18 位: 其中高 10 位为整数部分,低 8 位为小数部分,计数范围由 LEDC\_HSTIMERx\_LIM 进行配置,每次计数达到最大值 ref\_pulse 时,产生溢出中断,并且计数值回归到 0。软件可以复位、暂停以及读取计数器的计数值。定时器的输出信号由计数器产生,位宽为 20 位。信号的循环周期决定了任何连接到该定时器的 PWM 通道的信号频率。分频器的分频系数以及计数器的计数范围共同决定了输出信号的频率:

$$f_{\text{sig\_out}} = \frac{f_{\text{REF\_TICK}} \cdot (\text{!LEDC\_TICK\_SEL\_HSTIMERx}) + f_{\text{APB\_CLK}} \cdot \text{LEDC\_TICK\_SEL\_HSTIMERx}}{\text{LEDC\_DIV\_NUM\_HSTIMERx} \cdot 2^{\text{LEDC\_HSTIMERx\_LIM}}}$$

低速通道的分频器 L\_timerx 相对于高速通道的分频器 h\_timerx 来说有以下 2 点区别:

- 1. 高速定位器的时钟源采用了 REF\_TICK 或 APB\_CLK, 低速定位器采用了 REF\_TICK 或 SLOW\_CLOCK。置位 LEDC\_APB\_CLK\_SEL 寄存器, SLOW\_CLOCK 的频率为 80 MHz, 否则为 8 MHz。
- 2. 当软件修改了高速通道计数器的最大值或分频系数的话,输出信号的更新将会在下一次溢出中断之后生效。而低速通道在置位 LEDC\_LSTIMERx\_PARA\_UP 之后,立刻更新计数器的计数范围参数和分频器的分频系数。

### 6.2.3 通道



图 24: LED PWM 输出信号图



图 25: 渐变占空比输出信号图

每个通道有两个比较器,即图 23 中的 high\_level\_comparator 以及 low\_level\_comparator。high\_level\_comparator 的比较值 hpoint 由 LEDC\_HPOINT\_HSCHn 配置。当计数器的值达到 hpoint 时,输出信号翻转为高电平。low\_level\_comparator 的比较值 lpoint 由 LEDC\_DUTY\_HSCHn, LEDC\_DUTY\_START\_HSCHn, LEDC\_DUTY\_INC\_HSCHn, LEDC\_DUTY\_NUM\_HSCHn 以及 LEDC\_DUTY\_SCALE\_HSCHn 共同决定。当计数器的值等于 lpoint 时,输出信号翻转为低电平。图 24 为 LED\_PWM 输出信号图。

LEDC\_DUTY\_HSCHn 是一个具有 4 位小数的浮点寄存器, 其中高 20 位用于 lpoint 的计算, 低 4 位用于抖动 lpoint 的值。当低 4 位非 0 时, 输出信号的脉冲宽度有 LEDC\_DUTY\_HSCHn [3:0]/16 的概率多一个计数周期。低 4 位小数有利于提高输出信号占空比的精度。置位 LEDC\_DUTY\_START\_HSCHn, 通道更新后的 LEDC\_DUTY\_HSCHn 寄存器值才会起作用,即通道可以实现一种占空比到另一种占空比的转换。

6.3 寄存器列表 6 LED\_PWM

LEDC\_DUTY\_INC\_HSCHn 决定了占空比的变化方向。渐变占空比的定义如下:每 LEDC\_DUTY\_CYCLE\_HSCHn 个脉冲, LEDC\_DUTY\_HSCHn的高 20 位就会递增或递减 LEDC\_DUTY\_SCALE\_HSCHn,渐变长度由 LEDC\_DUTY\_NUM\_HSCHn 控制,当渐变完成后,会产生渐变完成中断,且之后的输出信号将延续最后一次脉冲。图 25 为 LEDC\_DUTY\_INC\_HSCHn 为 1 时的渐变图,即每隔 LEDC\_DUTY\_CYCLE\_HSCHn 个脉冲,输出信号脉宽递增 LEDC\_DUTY\_SCALE\_HSCHn。

# 6.2.4 中断

- LEDC\_DUTY\_CHNG\_END\_LSCHn\_INT 低速通道上的占空比渐变结束触发中断。
- LEDC\_DUTY\_CHNG\_END\_HSCHn\_INT 高速通道上的占空比渐变结束触发中断。
- LEDC\_HS\_TIMERn\_OVF\_INT 高速时钟计数器达到最大计数值触发中断。
- LEDC\_LS\_TIMERn\_OVF\_INT 低速时钟计数器达到最大计数值触发中断。

# 6.3 寄存器列表

| 名称                   | 描述                                                | 地址         | 访问    |
|----------------------|---------------------------------------------------|------------|-------|
| 配置寄存器                |                                                   |            |       |
| LEDC_CONF_REG        | Global ledc configuration register                | 0x00000190 | 读/写   |
| LEDC_HSCH0_CONF0_REG | Configuration register 0 for high-speed channel 0 | 0x00000000 | 读 / 写 |
| LEDC_HSCH1_CONF0_REG | Configuration register 0 for high-speed channel 1 | 0x0000014  | 读/写   |
| LEDC_HSCH2_CONF0_REG | Configuration register 0 for high-speed channel 2 | 0x00000028 | 读 / 写 |
| LEDC_HSCH3_CONF0_REG | Configuration register 0 for high-speed channel 3 | 0x000003C  | 读 / 写 |
| LEDC_HSCH4_CONF0_REG | Configuration register 0 for high-speed channel 4 | 0x0000050  | 读/写   |
| LEDC_HSCH5_CONF0_REG | Configuration register 0 for high-speed channel 5 | 0x00000064 | 读 / 写 |
| LEDC_HSCH6_CONF0_REG | Configuration register 0 for high-speed channel 6 | 0x00000078 | 读 / 写 |
| LEDC_HSCH7_CONF0_REG | Configuration register 0 for high-speed channel 7 | 0x0000008C | 读/写   |
| LEDC_HSCH0_CONF1_REG | Configuration register 1 for high-speed channel 0 | 0x000000C  | 读/写   |
| LEDC_HSCH1_CONF1_REG | Configuration register 1 for high-speed channel 1 | 0x00000020 | 读/写   |
| LEDC_HSCH2_CONF1_REG | Configuration register 1 for high-speed channel 2 | 0x00000034 | 读/写   |
| LEDC_HSCH3_CONF1_REG | Configuration register 1 for high-speed channel 3 | 0x00000048 | 读 / 写 |
| LEDC_HSCH4_CONF1_REG | Configuration register 1 for high-speed channel 4 | 0x000005C  | 读 / 写 |
| LEDC_HSCH5_CONF1_REG | Configuration register 1 for high-speed channel 5 | 0x00000070 | 读 / 写 |
| LEDC_HSCH6_CONF1_REG | Configuration register 1 for high-speed channel 6 | 0x00000084 | 读 / 写 |
| LEDC_HSCH7_CONF1_REG | Configuration register 1 for high-speed channel 7 | 0x00000098 | 读 / 写 |
| LEDC_LSCH0_CONF0_REG | Configuration register 0 for low-speed channel 0  | 0x000000A0 | 读 / 写 |
| LEDC_LSCH1_CONF0_REG | Configuration register 0 for low-speed channel 1  | 0x000000B4 | 读 / 写 |
| LEDC_LSCH2_CONF0_REG | Configuration register 0 for low-speed channel 2  | 0x000000C8 | 读 / 写 |
| LEDC_LSCH3_CONF0_REG | Configuration register 0 for low-speed channel 3  | 0x00000DC  | 读 / 写 |
| LEDC_LSCH4_CONF0_REG | Configuration register 0 for low-speed channel 4  | 0x000000F0 | 读/写   |
| LEDC_LSCH5_CONF0_REG | Configuration register 0 for low-speed channel 5  | 0x00000104 | 读 / 写 |
| LEDC_LSCH6_CONF0_REG | Configuration register 0 for low-speed channel 6  | 0x00000118 | 读 / 写 |
| LEDC_LSCH7_CONF0_REG | Configuration register 0 for low-speed channel 7  | 0x0000012C | 读/写   |
| LEDC_LSCH0_CONF1_REG | Configuration register 1 for low-speed channel 0  | 0x000000AC | 读 / 写 |

6.3 寄存器列表 6 LED\_PWM

| 名称                     | 描述                                               | 地址         | 访问  |
|------------------------|--------------------------------------------------|------------|-----|
| LEDC_LSCH1_CONF1_REG   | Configuration register 1 for low-speed channel 1 | 0x000000C0 | 读/写 |
| LEDC_LSCH2_CONF1_REG   | Configuration register 1 for low-speed channel 2 | 0x00000D4  | 读/写 |
| LEDC_LSCH3_CONF1_REG   | Configuration register 1 for low-speed channel 3 | 0x000000E8 | 读/写 |
| LEDC_LSCH4_CONF1_REG   | Configuration register 1 for low-speed channel 4 | 0x000000FC | 读/写 |
| LEDC_LSCH5_CONF1_REG   | Configuration register 1 for low-speed channel 5 | 0x00000110 | 读/写 |
| LEDC_LSCH6_CONF1_REG   | Configuration register 1 for low-speed channel 6 | 0x00000124 | 读/写 |
| LEDC_LSCH7_CONF1_REG   | Configuration register 1 for low-speed channel 7 | 0x00000138 | 读/写 |
| 占空比寄存器                 |                                                  |            |     |
| LEDC_HSCH0_DUTY_REG    | Initial duty cycle for high-speed channel 0      | 0x00000008 | 读/写 |
| LEDC_HSCH1_DUTY_REG    | Initial duty cycle for high-speed channel 1      | 0x000001C  | 读/写 |
| LEDC_HSCH2_DUTY_REG    | Initial duty cycle for high-speed channel 2      | 0x00000030 | 读/写 |
| LEDC_HSCH3_DUTY_REG    | Initial duty cycle for high-speed channel 3      | 0x00000044 | 读/写 |
| LEDC_HSCH4_DUTY_REG    | Initial duty cycle for high-speed channel 4      | 0x00000058 | 读/写 |
| LEDC_HSCH5_DUTY_REG    | Initial duty cycle for high-speed channel 5      | 0x0000006C | 读/写 |
| LEDC_HSCH6_DUTY_REG    | Initial duty cycle for high-speed channel 6      | 0x00000080 | 读/写 |
| LEDC_HSCH7_DUTY_REG    | Initial duty cycle for high-speed channel 7      | 0x00000094 | 读/写 |
| LEDC_HSCH0_DUTY_R_REG  | Current duty cycle for high-speed channel 0      | 0x0000010  | 只读  |
| LEDC_HSCH1_DUTY_R_REG  | Current duty cycle for high-speed channel 1      | 0x00000024 | 只读  |
| LEDC_HSCH2_DUTY_R_REG  | Current duty cycle for high-speed channel 2      | 0x00000038 | 只读  |
| LEDC_HSCH3_DUTY_R_REG  | Current duty cycle for high-speed channel 3      | 0x0000004C | 只读  |
| LEDC_HSCH4_DUTY_R_REG  | Current duty cycle for high-speed channel 4      | 0x00000060 | 只读  |
| LEDC_HSCH5_DUTY_R_REG  | Current duty cycle for high-speed channel 5      | 0x00000074 | 只读  |
| LEDC_HSCH6_DUTY_R_REG  | Current duty cycle for high-speed channel 6      | 0x00000088 | 只读  |
| LEDC_HSCH7_DUTY_R_REG  | Current duty cycle for high-speed channel 7      | 0x0000009C | 只读  |
| LEDC_LSCH0_DUTY_REG    | Initial duty cycle for low-speed channel 0       | 0x000000A8 | 读/写 |
| LEDC_LSCH1_DUTY_REG    | Initial duty cycle for low-speed channel 1       | 0x000000BC | 读/写 |
| LEDC_LSCH2_DUTY_REG    | Initial duty cycle for low-speed channel 2       | 0x00000D0  | 读/写 |
| LEDC_LSCH3_DUTY_REG    | Initial duty cycle for low-speed channel 3       | 0x000000E4 | 读/写 |
| LEDC_LSCH4_DUTY_REG    | Initial duty cycle for low-speed channel 4       | 0x000000F8 | 读/写 |
| LEDC_LSCH5_DUTY_REG    | Initial duty cycle for low-speed channel 5       | 0x0000010C | 读/写 |
| LEDC_LSCH6_DUTY_REG    | Initial duty cycle for low-speed channel 6       | 0x00000120 | 读/写 |
| LEDC_LSCH7_DUTY_REG    | Initial duty cycle for low-speed channel 7       | 0x00000134 | 读/写 |
| LEDC_LSCH0_DUTY_R_REG  | Current duty cycle for low-speed channel 0       | 0x000000B0 | 只读  |
| LEDC_LSCH1_DUTY_R_REG  | Current duty cycle for low-speed channel 1       | 0x000000C4 | 只读  |
| LEDC_LSCH2_DUTY_R_REG  | Current duty cycle for low-speed channel 2       | 0x000000D8 | 只读  |
| LEDC_LSCH3_DUTY_R_REG  | Current duty cycle for low-speed channel 3       | 0x00000EC  | 只读  |
| LEDC_LSCH4_DUTY_R_REG  | Current duty cycle for low-speed channel 4       | 0x00000100 | 只读  |
| LEDC_LSCH5_DUTY_R_REG  | Current duty cycle for low-speed channel 5       | 0x00000114 | 只读  |
| LEDC_LSCH6_DUTY_R_REG  | Current duty cycle for low-speed channel 6       | 0x00000128 | 只读  |
| LEDC_LSCH7_DUTY_R_REG  | Current duty cycle for low-speed channel 7       | 0x0000013C | 只读  |
| 分频器寄存器                 |                                                  |            |     |
| LEDC_HSTIMERO_CONF_REG | High-speed timer 0 configuration                 | 0x00000140 | 读/写 |
| LEDC_HSTIMER1_CONF_REG | High-speed timer 1 configuration                 | 0x00000148 | 读/写 |
| LEDC_HSTIMER2_CONF_REG | High-speed timer 2 configuration                 | 0x00000150 | 读/写 |

6.3 寄存器列表 6 LED\_PWM

| 名称                      | 描述                                       | 地址         | 访问    |
|-------------------------|------------------------------------------|------------|-------|
| LEDC_HSTIMER3_CONF_REG  | High-speed timer 3 configuration         | 0x00000158 | 读/写   |
| LEDC_HSTIMERO_VALUE_REG | High-speed timer 0 current counter value | 0x00000144 | 只读    |
| LEDC_HSTIMER1_VALUE_REG | High-speed timer 1 current counter value | 0x0000014C | 只读    |
| LEDC_HSTIMER2_VALUE_REG | High-speed timer 2 current counter value | 0x00000154 | 只读    |
| LEDC_HSTIMER3_VALUE_REG | High-speed timer 3 current counter value | 0x0000015C | 只读    |
| LEDC_HSTIMERO_CONF_REG  | Low-speed timer 0 configuration          | 0x00000140 | 读 / 写 |
| LEDC_HSTIMER1_CONF_REG  | Low-speed timer 1 configuration          | 0x00000148 | 读/写   |
| LEDC_HSTIMER2_CONF_REG  | Low-speed timer 2 configuration          | 0x00000150 | 读/写   |
| LEDC_HSTIMER3_CONF_REG  | Low-speed timer 3 configuration          | 0x00000158 | 读/写   |
| LEDC_HSTIMERO_VALUE_REG | Low-speed timer 0 current counter value  | 0x00000144 | 只读    |
| LEDC_HSTIMER1_VALUE_REG | Low-speed timer 1 current counter value  | 0x0000014C | 只读    |
| LEDC_HSTIMER2_VALUE_REG | Low-speed timer 2 current counter value  | 0x00000154 | 只读    |
| LEDC_HSTIMER3_VALUE_REG | Low-speed timer 3 current counter value  | 0x0000015C | 只读    |
| 中断寄存器                   |                                          |            |       |
| LEDC_INT_RAW_REG        | Raw interrupt status                     | 0x00000180 | 只读    |
| LEDC_INT_ST_REG         | Masked interrupt status                  | 0x00000184 | 只读    |
| LEDC_INT_ENA_REG        | Interrupt enable bits                    | 0x00000188 | 读/写   |
| LEDC_INT_CLR_REG        | Interrupt clear bits                     | 0x0000018C | 只写    |

# 6.4 寄存器

Register 6.1: LEDC\_HSCHn\_CONF0\_REG (n: 0-7) (0x1C+0x10\*n)



LEDC\_IDLE\_LV\_HSCHn 高速通道 n 不工作时,用于控制输出值。(读/写)

**LEDC\_SIG\_OUT\_EN\_HSCH**<sup>n</sup> 高速通道 <sup>n</sup> 输出使能控制位。(读 / 写)

**LEDC\_TIMER\_SEL\_HSCH**n 用于从 4 种高速时钟计数器中为高速通道 n 选择一个时钟计数器。(读 /写)

- 0: 选择 hstimer0;
- 1: 选择 hstimer1;
- 2: 选择 hstimer2;
- 3: 选择 hstimer3。

Register 6.2: LEDC\_HSCHn\_HPOINT\_REG (n: 0-7) (0x20+0x10\*n)



LEDC\_HPOINT\_HSCHn 当高速通道 n 的 htimerx(x=[0,3]) 达到 reg\_hpoint\_hschn[19:0], 输出信号 翻转为高电平。(读/写)

Register 6.3: LEDC\_HSCHn\_DUTY\_REG (n: 0-7) (0x24+0x10\*n)



**LEDC\_DUTY\_HSCH**<sup>n</sup> 用于控制输出占空比。当通道<sup>n</sup> 的 hstimerx(x=[0,3]) 达到 reg\_lpoint\_hsch<sup>n</sup> 时,输出信号翻转为低电平。

reg\_lpoint\_hschn=(reg\_hpoint\_hschn[19:0]+reg\_duty\_hschn[24:4]) (1) reg\_lpoint\_hschn=(reg\_hpoint\_hschn[19:0]+reg\_duty\_hschn[24:4] +1) (2) 当寄存器选择 1, 2 时,请从功能描述中获取更多信息。

Register 6.4: LEDC\_HSCHn\_CONF1\_REG (n: 0-7) (0x28+0x10\*n)



**LEDC\_DUTY\_START\_HSCH***n* 当配置了 RREG\_DUTY\_NUM\_HSCH*n*, REG\_DUTY\_CYCLE\_HSCH*n* 以及 REG\_DUTY\_SCALE\_HSCH*n* 时,需要置位 REG\_DUTY\_START\_HSCH*n*,这些寄存器才会生效。硬件自动清零此位。(读 / 写)

LEDC\_DUTY\_INC\_HSCHn 用于递增或递减高速通道 n 的输出信号的占空比。(读/写)

**LEDC\_DUTY\_NUM\_HSCH**<sup>n</sup> 用于控制高速通道 <sup>n</sup> 占空比变化的次数。(读 / 写)

**LEDC\_DUTY\_CYCLE\_HSCH***n* 每 REG\_DUTY\_CYCLE\_HSCH*n* 个时钟周期递增或递减高速通道 *n* 的占空比。

LEDC\_DUTY\_SCALE\_HSCHn 用于递增或递减高速通道 n 的步长。(读/写)

Register 6.5: LEDC\_HSCHn\_DUTY\_R\_REG (n: 0-7) (0x2C+0x10\*n)



**LEDC\_DUTY\_HSCH** $n_R$  当下高速通道 n 的输出信号的占空比。(只读)

Register 6.6: LEDC\_LSCHn\_CONF0\_REG (n: 0-7) (0xBC+0x10\*n)



LEDC\_PARA\_UP\_LSCHn 用于更新低速通道 n 的 LEDC\_LSCHn\_HPOINT 和 LEDC\_LSCHn\_DUTY 寄存器。(读/写)

LEDC\_IDLE\_LV\_LSCHn 当低速通道 n 不工作时,用于控制输出值。(读 / 写)

**LEDC\_SIG\_OUT\_EN\_LSCH***n* 低速通道 *n* 的输出控制位。(读 / 写)

LEDC\_TIMER\_SEL\_LSCHn 用于从 4 种低速分频器中为低速通道 n 选择一个时钟计数器。(读 / 写)

- 0: 选择 lstimer0;
- 1: 选择 lstimer1;
- 2: 选择 lstimer2;
- 3: 选择 Istimer3。

Register 6.7: LEDC\_LSCHn\_HPOINT\_REG (n: 0-7) (0xC0+0x10\*n)



LEDC\_HPOINT\_LSCHn 当低速通道n的 lstimerx(x=[0,3]) 达到 reg\_hpoint\_lschn[19:0] 时,输出信号 翻转为高电平。(读/写)

Register 6.8: LEDC\_LSCHn\_DUTY\_REG (n: 0-7) (0xC4+0x10\*n)



LEDC\_DUTY\_LSCHn 用于控制输出占空比。当低速通道 n 的 lstimerx(x=[0,3]) 达到 reg\_lpoint\_lschn时,输出信号翻转为低电平。(读 / 写) reg\_lpoint\_lschn=(reg\_hpoint\_lschn[19:0]+reg\_duty\_lschn[24:4]) (1) reg\_lpoint\_lschn=(reg\_hpoint\_lschn[19:0]+reg\_duty\_lschn[24:4] +1) (2) 当寄存器选择 1, 2 时,请从功能描述中获取更多信息。

Register 6.9: LEDC\_LSCHn\_CONF1\_REG (n: 0-7) (0xC8+0x10\*n)



**LEDC\_DUTY\_START\_LSCH**<sup>n</sup> 当配置了 reg\_duty\_num\_hsch<sup>n</sup>、reg\_duty\_cycle\_hsch<sup>n</sup> 以及 reg\_duty\_scale\_hsch<sup>n</sup> 时,需要置位 reg\_duty\_start\_hsch<sup>n</sup>,这些寄存器才能生效。硬件自动清 零此位。(读 / 写)

**LEDC\_DUTY\_INC\_LSCH**n 用于递增或递减低速通道 n 的输出信号的占空比。(读 / 写)

**LEDC\_DUTY\_NUM\_LSCH**<sup>n</sup> 用于控制低速通道 <sup>n</sup> 的占空比变化的次数。(读 / 写)

**LEDC\_DUTY\_CYCLE\_LSCH***n* 用于每 reg\_duty\_cycle\_lsch*n* 个时钟周期递增或递减占空比。(读 / 写)

**LEDC\_DUTY\_SCALE\_LSCH**<sup>n</sup> 用递增或递减低速通道 <sup>n</sup> 的步长。(读 / 写)

Register 6.10: LEDC\_LSCHn\_DUTY\_R\_REG (n: 0-7) (0xCC+0x10\*n)



**LEDC\_DUTY\_R\_LSCH**<sub>n</sub>\_R 低速通道 n 的输出信号的当前占空比。(只读)

Register 6.11: LEDC\_HSTIMERx\_CONF\_REG (x: 0-3) (0x140+8\*x)



LEDC\_TICK\_SEL\_HSTIMER× 用于选择 APB\_CLK 或 REF\_TICK 作为高速时钟计数器。(读/写)

1: APB\_CLK;

0: REF\_TICK。

LEDC\_HSTIMERx\_RST 用于复位高速时钟计数器 x, 复位后计数器为 0。(读 / 写)

LEDC\_HSTIMERx\_PAUSE 用于暂停高速时钟计数器 x。(读 / 写)

LEDC\_DIV\_NUM\_HSTIMER× 用于配置高速时钟计数器 ×, 低 8 位为小数部分。(读 / 写)

LEDC\_HSTIMERx\_LIM 用于控制高速时钟计数器 x 的计数范围。计数范围为 [0,2\*\*reg\_hstimerx\_lim],最大位宽为 20 位。(读 / 写)

Register 6.12: LEDC\_HSTIMERx\_VALUE\_REG (x: 0-3) (0x144+8\*x)



LEDC\_HSTIMERx\_CNT 软件可以读取高速时钟计数器 x 的当前计数值。(只读)

Register 6.13: LEDC\_LSTIMERx\_CONF\_REG (x: 0-3) (0x160+8\*x)



LEDC\_LSTIMERx\_PARA\_UP 用于更新 REG\_DIV\_NUM\_LSTIMEx 和 REG\_LSTIMERx\_LIM。

**LEDC\_TICK\_SEL\_LSTIMER**× 用于为低速时钟计数器 × 选择 SLOW\_CLK 或 REF\_TICK 时钟。(读 / 写)

- 1: SLOW\_CLK;
- 0: REF\_TICK。

**LEDC\_LSTIMER**×**\_RST** 用于复位低速时钟计数器 ×, 复位后计数器为 0。(读 / 写)

LEDC\_LSTIMERx\_PAUSE 用于暂停低速时钟计数器 x。(读/写)

**LEDC\_DIV\_NUM\_LSTIMER** 用于配置低速时钟计数器 x, 低 8 位为小数部分。(读 / 写)

**LEDC\_LSTIMER**×**\_LIM** 用于控制低速时钟计数器 × 的计数范围。计数范围为 [0,2\*\*reg\_lstimerx\_lim], 最大位宽为 20 位。(读 / 写)

Register 6.14: LEDC\_LSTIMERx\_VALUE\_REG (x: 0-3) (0x164+8\*x)



LEDC\_LSTIMERx\_CNT 存储低速通道时钟计数器 x 的当前计数值。(只读)

Det out the transport of the transport o TO THE THE THE THE 2) January Miles 20 15 21 19 18 17 16 14 13 12 11 10 9 8 0 0

Register 6.15: LEDC INT RAW REG (0x0180)

**LEDC\_DUTY\_CHNG\_END\_LSCH***n\_***INT\_RAW** LEDC\_DUTY\_CHNG\_END\_LSCH*n\_*INT 中断的原始中断状态位。(只读)

**LEDC\_DUTY\_CHNG\_END\_HSCH***n\_***INT\_RAW** LEDC\_DUTY\_CHNG\_END\_HSCH*n\_*INT 中断的原始中断状态位。(只读)

LEDC\_LSTIMERx\_OVF\_INT\_RAW LEDC\_LSTIMERx\_OVF\_INT 中断的原始中断状态位。(只读)

LEDC\_HSTIMERx\_OVF\_INT\_RAW LEDC\_HSTIMERx\_OVF\_INT 中断的原始中断状态位。(只读)



Register 6.16: LEDC\_INT\_ST\_REG (0x0184)

**LEDC\_DUTY\_CHNG\_END\_LSCH***n\_***INT\_ST** LEDC\_DUTY\_CHNG\_END\_LSCH*n\_*INT 中断的隐蔽中断状态位。(只读)

**LEDC\_DUTY\_CHNG\_END\_HSCH***n\_***INT\_ST** LEDC\_DUTY\_CHNG\_END\_HSCH*n\_*INT 中断的隐蔽中断状态位。(只读)

LEDC\_LSTIMERx\_OVF\_INT\_ST LEDC\_LSTIMERx\_OVF\_INT 中断的隐蔽中断状态位。(只读)

**LEDC\_HSTIMERx\_OVF\_INT\_ST** LEDC\_HSTIMERx\_OVF\_INT 中断的隐蔽中断状态位。(只读)

Mandaland - July of the fact STONE SAME 12 July 1 WED HIT 0 0 Ω 

Register 6.17: LEDC INT ENA REG (0x0188)

LEDC\_DUTY\_CHNG\_END\_LSCHn\_INT\_ENA LEDC\_DUTY\_CHNG\_END\_LSCHn\_INT 中断的使能位。(读 / 写)

LEDC\_DUTY\_CHNG\_END\_HSCHn\_INT\_ENA LEDC\_DUTY\_CHNG\_END\_HSCHn\_INT 中断的使能位。(读 / 写)

LEDC\_LSTIMERx\_OVF\_INT\_ENA LEDC\_LSTIMERx\_OVF\_INT 中断的使能位。(读 / 写)

LEDC\_HSTIMERx\_OVF\_INT\_ENA LEDC\_HSTIMERx\_OVF\_INT 中断的使能位。(读/写)

MOR Migh January Miles 0 0 

Register 6.18: LEDC\_INT\_CLR\_REG (0x018C)

LEDC\_DUTY\_CHNG\_END\_LSCHn\_INT\_CLR 用于清除 LEDC\_DUTY\_CHNG\_END\_LSCHn\_INT 中断。(只写)

LEDC\_DUTY\_CHNG\_END\_HSCHn\_INT\_CLR 用于清除 LEDC\_DUTY\_CHNG\_END\_HSCHn\_INT 中断。(只写)

LEDC\_LSTIMERx\_OVF\_INT\_CLR 用于清除 LEDC\_LSTIMERx\_OVF\_INT 中断。(只写)

LEDC\_HSTIMERx\_OVF\_INT\_CLR 用于清除 LEDC\_HSTIMERx\_OVF\_INT 中断。(只写)

# Register 6.19: LEDC\_CONF\_REG (0x0190)



**LEDC\_APB\_CLK\_SEL** 用于设置 SLOW\_CLK 的频率。(读 / 写)

0: 8 MHz;1: 80 MHz。

# 7. 红外遥控

# 7.1 概述

RMT(红外遥控器)是一个红外发送 / 接收控制器, 其特殊设计支持生成各类信号。红外遥控发射器从内置的 RAM(随机存取存储器)区中读取连续的脉冲码, 并对输出信号进行载波调制。接收器检测输入信号, 并进行滤波, 然后将信号高低电平以及长度值存入 RAM 中。

RMT 有 8 个通道, 编码为 0~7, 每个通道有一组功能相同的寄存器。为了方便叙述, 以 n 表示各个通道。

# 7.2 功能描述

### 7.2.1 RMT 架构



图 26: RMT 架构

RMT 有 8 个独立通道,每个通道内部有一个发送器和一个接收器,发送和接收不可同时工作。8 个通道共享一块 512x32 bit 的 RAM。RAM 可由处理器内核通过 APB 总线进行读写。发射器可以对信号进行载波调制。软件可以通过配置 RMT\_REF\_ALWAYS\_ON\_CHn 选择每个通道的工作时钟: 80 MHz APB(外围总线)时钟或者 REF\_TICK。

7.2 功能描述 7 红外遥控

#### 7.2.2 RMT RAM



图 27: 数据结构

RAM 中数据结构如图 27 所示,由低 16 位和高 16 位组成。两个字段中 level 表示电平高低值, period 表示 level 持续的时钟周期数。period 为 0 表示结束标志,发射器停止发送数据。

RAM 可以通过 APB 总线进行访问,其起始地址为 RMT 基地址 + 0x800。每个通道可使用的 RAM 范围按照 64x32 bit 分成 8 个 block。默认情况下每个通道可使用的 block 数量为 1(通道 0 使用 block0,通道 1 使用 block1,以此类推)。当通道 n 发送的数据量大于可使用的 block 时,除了可以通过配置 RMT\_MEM\_SIZE\_CHn 寄存器扩展 block 还可以进行乒乓操作。将 RMT\_MEM\_SIZE\_CHn 寄存器配置为 >1,意味着此通道会占用下一个通道的 block。通道 n 使用的 RAM 地址范围为:

```
start_addr_ch^n = RMT base address + 0x800 + 64 * 4 * ^n, and end_addr_ch^n = RMT base address + 0x800 + 64 * 4 * ^n + 64 * 4 * RMT_MEM_SIZE_CH^n mod 512 * 4
```

为了防止数据覆盖,可以通过配置 RMT\_MEM\_OWNER\_CH $^n$  来表示发射器或者接收器对于信道  $^n$  的 RAM 使用权。当配置不正确时,则会产生 RMT\_CH $^n$ \_ERR 中断。

#### 7.2.3 时钟

软件可以通过配置 RMT\_REF\_ALWAYS\_ON\_CHn 选择每个通道的工作时钟: 80 MHz APB 时钟或者 REF\_TICK, 请参考章节复位和时钟。经过 8 位宽分频器分频之后的时钟供载波发生器以及计数器使用。分频器可以通过配置 RMT\_REF\_CNT\_RST\_CHn 进行复位。

#### 7.2.4 发射器

当 RMT\_TX\_START\_CHn 置为 1 时,通道 n 的发射器开始从 RAM 中读取数据。发射器每读取一次 RAM,可以 获得 32 位的数据, 低 16 位首先发送,高 16 位其次发送。

当发送的数据量大于可使用的 block 时,可以进行乒乓操作。在进行乒乓操作前配置 RMT\_TX\_LIM\_CHn,当发送的数据量大于等于 RMT\_TX\_LIM\_CHn 时,会产生 RMT\_CHn\_TX\_THR\_EVENT\_INT 中断,软件可以在检测到该中断之后更新已发送的数据。当发射器发送的数据量达到 block 的上限时,发射器会返回到 start\_addr\_chn 继续循环发送。

只有当数据中 period 等于 0 时,发射器将结束工作并产生 RMT\_CHn\_TX\_END\_INT 中断,然后返回空闲状态。此时可以通过配置 RMT\_IDLE\_OUT\_EN\_CHn 和 RMT\_IDLE\_OUT\_LV\_CHn 来控制发射器的输出。

输出信号可以通过配置 RMT\_CARRIER\_EN\_CHn 进行载波调制。载波的频率可以通过 RMT\_CARRIER\_HIGH\_CHn 和 RMT\_CARRIER\_HIGH\_CHn 进行设置。

7.3 寄存器列表 7 红外遥控

### 7.2.5 接收器

当 RMT\_RX\_EN\_CHn 置为 1 时, 计数器开始测量信号的长度并在下一次信号沿变化时将上次的信号高低电平以及长度值存入 RAM。当发射器长时间检测不到信号沿变化即计数器的值大于等于 RMT\_IDLE\_THRES\_CHn 时,接收器结束接收过程,产生 RMT\_CHn\_RX\_END\_INT 中断并返回空闲状态。

输入信号可以通过置位 RMT\_RX\_FILTER\_EN\_CHn 来进行滤波。滤波器可以滤除信号宽度小于 RMT RX FILTER THRES CHn 个 APB 时钟周期的脉冲。

当 RMT 模块不工作时,可以通过配置 RMT\_MEM\_PD 寄存器使 RAM 工作于低功耗模式。

#### 7.2.6 中断

- RMT\_CHn\_TX\_THR\_EVENT\_INT: 当发射器发送的数据量与 RMT\_CHn\_TX\_LIM\_REG 寄存器的内容一致时,即触发此中断。
- RMT\_CHn\_TX\_END\_INT: 当发射器停止发送信号时,即触发此中断。
- RMT\_CHn\_RX\_END\_INT: 当接收器停止接收信号时,即触发此中断。

# 7.3 寄存器列表

| 名称                      | 描述                                          | 地址         | 访问  |
|-------------------------|---------------------------------------------|------------|-----|
| 配置寄存器                   |                                             |            |     |
| RMT_CH0CONF0_REG        | Channel 0 config register 0                 | 0x3FF56020 | 读/写 |
| RMT_CH0CONF1_REG        | Channel 0 config register 1                 | 0x3FF56024 | 读/写 |
| RMT_CH1CONF0_REG        | Channel 1 config register 0                 | 0x3FF56028 | 读/写 |
| RMT_CH1CONF1_REG        | Channel 1 config register 1                 | 0x3FF5602C | 读/写 |
| RMT_CH2CONF0_REG        | Channel 2 config register 0                 | 0x3FF56030 | 读/写 |
| RMT_CH2CONF1_REG        | Channel 2 config register 1                 | 0x3FF56034 | 读/写 |
| RMT_CH3CONF0_REG        | Channel 3 config register 0                 | 0x3FF56038 | 读/写 |
| RMT_CH3CONF1_REG        | Channel 3 config register 1                 | 0x3FF5603C | 读/写 |
| RMT_CH4CONF0_REG        | Channel 4 config register 0                 | 0x3FF56040 | 读/写 |
| RMT_CH4CONF1_REG        | Channel 4 config register 1                 | 0x3FF56044 | 读/写 |
| RMT_CH5CONF0_REG        | Channel 5 config register 0                 | 0x3FF56048 | 读/写 |
| RMT_CH5CONF1_REG        | Channel 5 config register 1                 | 0x3FF5604C | 读/写 |
| RMT_CH6CONF0_REG        | Channel 6 config register 0                 | 0x3FF56050 | 读/写 |
| RMT_CH6CONF1_REG        | Channel 6 config register 1                 | 0x3FF56054 | 读/写 |
| RMT_CH7CONF0_REG        | Channel 7 config register 0                 | 0x3FF56058 | 读/写 |
| RMT_CH7CONF1_REG        | Channel 7 config register 1                 | 0x3FF5605C | 读/写 |
| 中断寄存器                   |                                             |            |     |
| RMT_INT_RAW_REG         | 原始中断状态                                      | 0x3FF560A0 | 只读  |
| RMT_INT_ST_REG          | 隐蔽中断状态                                      | 0x3FF560A4 | 只读  |
| RMT_INT_ENA_REG         | 中断使能位                                       | 0x3FF560A8 | 读/写 |
| RMT_INT_CLR_REG         | 中断清除位                                       | 0x3FF560AC | 只写  |
| 载波占空比寄存器                |                                             |            |     |
| RMT_CH0CARRIER_DUTY_REG | Channel 0 duty cycle configuration register | 0x3FF560B0 | 读/写 |

7.3 寄存器列表 7 红外遥控

| 名称                      | 描述                                          | 地址         | 访问    |
|-------------------------|---------------------------------------------|------------|-------|
| RMT_CH1CARRIER_DUTY_REG | Channel 1 duty cycle configuration register | 0x3FF560B4 | 读/写   |
| RMT_CH2CARRIER_DUTY_REG | Channel 2 duty cycle configuration register | 0x3FF560B8 | 读 / 写 |
| RMT_CH3CARRIER_DUTY_REG | Channel 3 duty cycle configuration register | 0x3FF560BC | 读/写   |
| RMT_CH4CARRIER_DUTY_REG | Channel 4 duty cycle configuration register | 0x3FF560C0 | 读/写   |
| RMT_CH5CARRIER_DUTY_REG | Channel 5 duty cycle configuration register | 0x3FF560C4 | 读/写   |
| RMT_CH6CARRIER_DUTY_REG | Channel 6 duty cycle configuration register | 0x3FF560C8 | 读/写   |
| RMT_CH7CARRIER_DUTY_REG | Channel 7 duty cycle configuration register | 0x3FF560CC | 读/写   |
| 发送事件配置寄存器               |                                             |            |       |
| RMT_CH0_TX_LIM_REG      | Channel 0 Tx event configuration register   | 0x3FF560D0 | 读/写   |
| RMT_CH1_TX_LIM_REG      | Channel 1 Tx event configuration register   | 0x3FF560D4 | 读 / 写 |
| RMT_CH2_TX_LIM_REG      | Channel 2 Tx event configuration register   | 0x3FF560D8 | 读 / 写 |
| RMT_CH3_TX_LIM_REG      | Channel 3 Tx event configuration register   | 0x3FF560DC | 读 / 写 |
| RMT_CH4_TX_LIM_REG      | Channel 4 Tx event configuration register   | 0x3FF560E0 | 读/写   |
| RMT_CH5_TX_LIM_REG      | Channel 5 Tx event configuration register   | 0x3FF560E4 | 读 / 写 |
| RMT_CH6_TX_LIM_REG      | Channel 6 Tx event configuration register   | 0x3FF560E8 | 读 / 写 |
| RMT_CH7_TX_LIM_REG      | Channel 7 Tx event configuration register   | 0x3FF560EC | 读/写   |
| 其它寄存器                   |                                             |            |       |
| RMT_APB_CONF_REG        | RMT-wide configuration register             | 0x3FF560F0 | 读/写   |

# 7.4 寄存器

Register 7.1: RMT\_CHnCONF0\_REG (n: 0-7) (0x0058+8\*n)



**RMT\_MEM\_PD** 用于降低 RMT RAM 的功耗(仅存在于 RMT\_CH0CONF0 寄存器)。1: RAM 处于低功耗状态;0: RAM 处于正常工作状态。(读 / 写)

RMT\_CARRIER\_OUT\_LV\_CHn 用于配置载波调制方式。1: 载波加载在低电平输出信号上;0: 载波加载在高电平输出信号上。(读 / 写)

**RMT\_CARRIER\_EN\_CH**n 通道 n 的载波调制使能位。1: 使能载波调制;0: 关闭载波调制。(读 / 写)

RMT\_MEM\_SIZE\_CHn 配置通道 n 的 block 大小。(读 / 写)

RMT\_IDLE\_THRES\_CHn 当接收器长时间检测不到信号沿变化即计数器的值大于等于 RMT\_IDLE\_THRES\_CHn 时,接收器结束接收过程。(读/写)

 $RMT_DIV_CNT_CH_n$  用于设置通道 n 的分频器的分频系数。(读 / 写)

Register 7.2: RMT CHnCONF1 REG (n: 0-7) (0x005c+8\*n)



**RMT\_IDLE\_OUT\_EN\_CH**n 通道 n 位于空闲状态下的输出使能控制位。(读 / 写)

RMT\_IDLE\_OUT\_LV\_CHn 配置通道 n 位于空闲状态下的输出信号电平。(读 / 写)

RMT\_REF\_ALWAYS\_ON\_CHn 用于选择通道的基础时钟。1: clk\_apb; 0: clk\_ref。(读 / 写)

**RMT\_REF\_CNT\_RST\_CH**<sup>n</sup> 复位通道 <sup>n</sup> 的时钟分频器。(读 / 写)

**RMT\_RX\_FILTER\_EN\_CH***n* 通道 *n* 的接收滤波使能位。(读 / 写)

RMT\_TX\_CONTI\_MODE\_CHn 发送结束时,发射器重启发送,不进入空闲状态,导致重复输出信号。(读/写)

**RMT\_MEM\_OWNER\_CH**n 标志通道 n 的 RAM 使用权。1: 接收器;0: 发射器。(读 / 写)

 $RMT_MEM_RD_RST_CH_n$  用于复位通道 n 的发射器的 RAM 读取地址。(读 / 写)

RMT\_MEM\_WR\_RST\_CHn 用于复位通道 n 的接收器的 RAM 写地址。(读/写)

 $RMT_RX_EN_CH_n$  用于使能通道 n 的接收器。(读 / 写)

**RMT\_TX\_START\_CH***n* 用于使能通道 *n* 的发射器。(读 / 写)

Register 7.3: RMT INT RAW REG (0x00a0)



**RMT\_CH***n\_***TX\_THR\_EVENT\_INT\_RAW** RMT\_CH*n\_*TX\_THR\_EVENT\_INT 中断的原始中断状态位。(只读)

RMT\_CHn\_ERR\_INT\_RAW RMT\_CHn\_ERR\_INT 中断的原始中断状态位。(只读)

RMT\_CHn\_RX\_END\_INT\_RAW RMT\_CHn\_RX\_END\_INT 中断的原始中断状态位。(只读)

**RMT\_CH**<sub>n\_</sub>**TX\_END\_INT\_RAW** RMT\_CH<sub>n\_</sub>TX\_END\_INT 中断的原始中断状态位。(只读)

Register 7.4: RMT\_INT\_ST\_REG (0x00a4)



RMT\_CHn\_TX\_THR\_EVENT\_INT\_ST RMT\_CHn\_TX\_THR\_EVENT\_INT 中断的隐蔽中断状态位。(只读)

RMT\_CHn\_ERR\_INT\_ST RMT\_CHn\_ERR\_INT 中断的隐蔽中断状态位。(只读)

RMT\_CHn\_RX\_END\_INT\_ST RMT\_CHn\_RX\_END\_INT 中断的隐蔽中断状态位。(只读)

RMT CHn TX END INT ST RMT CHn TX END INT 中断的隐蔽中断状态位。(只读)

Register 7.5: RMT INT ENA REG (0x00a8)



RMT\_CHn\_TX\_THR\_EVENT\_INT\_ENA RMT\_CHn\_TX\_THR\_EVENT\_INT 中断的使能位。(读 / 写)

RMT\_CHn\_ERR\_INT\_ENA RMT\_CHn\_ERROR\_INT 中断的使能位。(读 / 写)

RMT\_CHn\_RX\_END\_INT\_ENA RMT\_CHn\_RX\_END\_INT 中断的使能位。(读 / 写)

RMT\_CHn\_TX\_END\_INT\_ENA RMT\_CHn\_TX\_END\_INT 中断的使能位。(读/写)

Register 7.6: RMT\_INT\_CLR\_REG (0x00ac)



RMT\_CHn\_TX\_THR\_EVENT\_INT\_CLR 用于清除 RMT\_CHn\_TX\_THR\_EVENT\_INT 中断。(只写)

RMT\_CHn\_ERR\_INT\_CLR 用于清除 RMT\_CHn\_ERRINT 中断。(只写)

RMT\_CHn\_RX\_END\_INT\_CLR 用于清除 RMT\_CHn\_RX\_END\_INT 中断。(只写)

RMT\_CHn\_TX\_END\_INT\_CLR 用于清除 RMT\_CHn\_TX\_END\_INT 中断。(只写)

Register 7.7: RMT\_CHnCARRIER\_DUTY\_REG (n: 0-7) (0x00cc+4\*n)



**RMT\_CARRIER\_HIGH\_CH** $^n$  用于配置通道  $^n$  的载波的高电平时钟周期。(读 / 写)

**RMT\_CARRIER\_LOW\_CH** $^n$  用于配置通道  $^n$  的载波的低电平时钟周期。(读 / 写)

Register 7.8: RMT\_CHn\_TX\_LIM\_REG (n: 0-7) (0x00ec+4\*n)



RMT\_TX\_LIM\_CHn 当通道发送的数据量大于指定的 block 大小,则产生 TX\_THR\_EVENT 中断。(读 / 写)

Register 7.9: RMT\_APB\_CONF\_REG (0x00f0)



RMT\_MEM\_TX\_WRAP\_EN 乒乓操作使能位。当发射器发送的数据量大于 block 大小,发射器将继续从第一字节开始发送数据。(读 / 写)

# 8. PULSE CNT

## 8.1 概述

脉冲计数器模块用于对输入脉冲的上升沿或下降沿进行计数。每个脉冲计数器单元均有一个带符号的 16-bit 计数寄存器以及两个通道,通过配置可以加减计数器。每个通道均有一个脉冲输入信号以及一个能够用于控制输入信号的控制信号。输入信号可以打开或关闭滤波功能。

脉冲计数器有8组单元,各自独立工作,命名为PULSE\_CNT\_Un。

# 8.2 功能描述

### 8.2.1 架构图



图 28: PULSE\_CNT 单元基本架构图

图 28 为脉冲计数器的基本架构图。每个单元有两个通道: ch0 和 ch1。这两个通道的功能相似。每个通道均有一个输入信号和一个控制输入信号,都能连接到芯片引脚。上升沿和下降沿中的计数工作模式可以分别进行增加、不增不减或者减少计数值的配置行为。对控制信号而言,通过配置硬件可以更改上升沿和下降沿的工作模式,包括: 反转、禁止和保持。该计数器本身是一个带符号的 16-bit 加减计数器。它的值可以由软件直接读取,硬件通过将该值与一组比较仅进行比较,可以产生中断。

#### 8.2.2 计数器通道输入信号

如上文所述,一个通道里的两组输入信号能够以多种方式影响脉冲计数器: LCTRL\_MODE 和 HCTRL\_MODE 分别用于配置低控制信号和高控制信号; POS\_MODE 和 NEG\_MODE 分别用于配置输入信号的上升沿和下降沿。POS\_MODE 和 NEG\_MODE 配置为 1,计数器递增; 若将它们配置为 2 时,则计数器递减; 其它的值表示计数器保持元始纸,既不递增,也不递减。当 LCTRL\_MODE 或 HCTRL\_MODE 为 0,表示不修改 NEG\_MODE 和 POS\_MODE 的工作模式; 为 1 表示反转(即若原来计数器处于递增状态,当配置 POS\_MODE 或 NEG\_MODE 为 1 后,计数器将处于递减状态,反之亦然); 其它的值会禁止计数器计数作用。

下表列出了一些关于上升沿对计数器作用的例子,包括低/高电平控制信号以及各种配置选择。为了清晰可见,下表数值后面的括号内添加了一些描述,x代表了"无关项"。

8.2 功能描述 8 PULSE\_CNT

| POS_ MODE | LCTRL_ MODE | HCTRL_ MODE | sig I→h when ctrl=0 | sig l→h when ctrl=1 |
|-----------|-------------|-------------|---------------------|---------------------|
| 1 (inc)   | 0 (-)       | 0 (-)       | Inc ctr             | Inc ctr             |
| 2 (dec)   | 0 (-)       | O (-)       | Dec ctr             | Dec ctr             |
| 0 (-)     | Х           | Х           | No action           | No action           |
| 1 (inc)   | 0 (-)       | 1 (inv)     | Inc ctr             | Dec ctr             |
| 1 (inc)   | 1 (inv)     | O (-)       | Dec ctr             | Inc ctr             |
| 2 (dec)   | 0 (-)       | 1 (inv)     | Dec ctr             | Inc ctr             |
| 1 (inc)   | 0 (-)       | 2 (dis)     | Inc ctr             | No action           |
| 1 (inc)   | 2 (dis)     | O (-)       | No action           | Inc ctr             |

该表对下降沿 (sig h→l) 也同样适用,用 NEG\_MODE 来代替 POS\_MODE。

每个脉冲计数器单元在这 4 个输入中均有一个滤波器,可以滤除噪声。单元的 4 个输入信号可以通过置位 PCNT\_FILTER\_EN\_Un 来打开滤波功能。一旦滤波器被启动,任何宽度比 REG\_FILTER\_THRES\_Un 个时钟周期 窄的脉冲都会被过滤掉,这些被过滤掉的脉冲将不会对计数器起任何作用。

除了输入通道以外,软件也能对计数器进行一部分控制。比如通过置位 PCNT\_CNT\_PAUSE\_Un, 可以暂停计数器。通过置位 PCNT\_PULSE\_CNT\_RST\_Un 实现计数器清零功能。

#### 8.2.3 观察点

PULSE\_CNT 可以设置 5 个观察点, 5 个观察点共用一个中断,可以通过各自的中断使能信号开启或屏蔽中断。 这些观察点分别是:

- 最大计数值。当 PULSE\_CNT 大于等于 PCNT\_THR\_H\_LIM\_Un 时, 清空 pulse\_cnt。
- 最小计数值。当 PULSE\_CNT 小于等于 PCNT\_THR\_L\_LIM\_Un 时,清空 pulse\_cnt。其中 PCNT\_THR\_L\_LIM\_Un 应设为负数。
- 两个中间阈值。当 PULSE\_CNT 等于 PCNT\_THR\_THRESO\_Un 或者 PCNT\_THR\_THRES1\_Un 时,产生相 应的 thr\_event 信号。
- 零。当 PULSE\_CNT 等于 0 时,产生相应的 thr\_event 信号。

#### 8.2.4 举例

图 29 为仅仅使用通道 0 进行递增计数的示意图,通道 0 的配置如下所示。

- CNT\_CH0\_POS\_MODE\_Un=1,即在 sig\_ch0\_un 的上升沿进行递增计数。
- PCNT\_CH0\_NEG\_MODE\_Un=0,即在 sig\_ch0\_un 的下升沿不进行计数。
- PCNT\_CH0\_LCTRL\_MODE\_Un=0,即当 ctrl\_ch0\_un 为底电平时,对输入 sig\_ch0\_un 进行递增控制。
- PCNT\_CH0\_HCTRL\_MODE\_Un=2, 即当 ctrl\_ch0\_un 为高电平时, 对输入 sig\_ch0\_un 不进行控制。
- PCNT\_THR\_H\_LIM\_Un=5, 当 PULSE\_CNT 的值递增到 PCNT\_THR\_H\_LIM\_Un, PULSE\_CNT 返回到 0。

8.3 寄存器列表 8 PULSE\_CNT



图 29: PULSE\_CNT 递增计数图



图 30: PULSE\_CNT 递减计数图

图 30 为仅仅使用通道 0 进行递减计数的示意图,图 30 中通道 0 的配置与图 29 中的配置区别为:

- PCNT\_CH0\_LCTRL\_MODE\_Un=1, 即当 ctrl\_ch0\_un 为低电平时, 对输入 sig\_ch0\_un 进行递减控制。
- PCNT\_THR\_H\_LIM\_Un=-5, 当 PULSE\_CNT 的值递减到 PCNT\_THR\_H\_LIM\_Un, plus\_cnt 返回到 0。

## 8.2.5 溢出中断

PCNT\_CNT\_THR\_EVENT\_U $n_{i}$ \_IN:该中断有 5 个中断源,即一个最大计数值中断,一个最小计数值中断,两个中间阈值中断以及一个过零中断,它们可以通过各自的中断使能信号开启或屏蔽中断。

# 8.3 寄存器列表

| 名称                | 描述                                  | 地址         | 访问    |
|-------------------|-------------------------------------|------------|-------|
| 配置寄存器             |                                     |            |       |
| PCNT_U0_CONF0_REG | Configuration register 0 for unit 0 | 0x3FF57000 | 读/写   |
| PCNT_U1_CONF0_REG | Configuration register 0 for unit 1 | 0x3FF5700C | 读/写   |
| PCNT_U2_CONF0_REG | Configuration register 0 for unit 2 | 0x3FF57018 | 读 / 写 |
| PCNT_U3_CONF0_REG | Configuration register 0 for unit 3 | 0x3FF57024 | 读/写   |
| PCNT_U4_CONF0_REG | Configuration register 0 for unit 4 | 0x3FF57030 | 读 / 写 |
| PCNT_U5_CONF0_REG | Configuration register 0 for unit 5 | 0x3FF5703C | 读/写   |
| PCNT_U6_CONF0_REG | Configuration register 0 for unit 6 | 0x3FF57048 | 读/写   |
| PCNT_U7_CONF0_REG | Configuration register 0 for unit 7 | 0x3FF57054 | 读/写   |
| PCNT_U0_CONF1_REG | Configuration register 1 for unit 0 | 0x3FF57004 | 读/写   |
| PCNT_U1_CONF1_REG | Configuration register 1 for unit 1 | 0x3FF57010 | 读/写   |
| PCNT_U2_CONF1_REG | Configuration register 1 for unit 2 | 0x3FF5701C | 读 / 写 |
| PCNT_U3_CONF1_REG | Configuration register 1 for unit 3 | 0x3FF57028 | 读 / 写 |
| PCNT_U4_CONF1_REG | Configuration register 1 for unit 4 | 0x3FF57034 | 读/写   |

8.3 寄存器列表 8 PULSE\_CNT

| 名称                | 描述                                  | 地址         | 访问    |
|-------------------|-------------------------------------|------------|-------|
| PCNT_U5_CONF1_REG | Configuration register 1 for unit 5 | 0x3FF57040 | 读 / 写 |
| PCNT_U6_CONF1_REG | Configuration register 1 for unit 6 | 0x3FF5704C | 读 / 写 |
| PCNT_U7_CONF1_REG | Configuration register 1 for unit 7 | 0x3FF57058 | 读 / 写 |
| PCNT_U0_CONF2_REG | Configuration register 2 for unit 0 | 0x3FF57008 | 读 / 写 |
| PCNT_U1_CONF2_REG | Configuration register 2 for unit 1 | 0x3FF57014 | 读 / 写 |
| PCNT_U2_CONF2_REG | Configuration register 2 for unit 2 | 0x3FF57020 | 读/写   |
| PCNT_U3_CONF2_REG | Configuration register 2 for unit 3 | 0x3FF5702C | 读/写   |
| PCNT_U4_CONF2_REG | Configuration register 2 for unit 4 | 0x3FF57038 | 读/写   |
| PCNT_U5_CONF2_REG | Configuration register 2 for unit 5 | 0x3FF57044 | 读/写   |
| PCNT_U6_CONF2_REG | Configuration register 2 for unit 6 | 0x3FF57050 | 读 / 写 |
| PCNT_U7_CONF2_REG | Configuration register 2 for unit 7 | 0x3FF5705C | 读/写   |
| 计数器值              |                                     |            |       |
| PCNT_U0_CNT_REG   | Counter value for unit 0            | 0x3FF57060 | 只读    |
| PCNT_U1_CNT_REG   | Counter value for unit 1            | 0x3FF57064 | 只读    |
| PCNT_U2_CNT_REG   | Counter value for unit 2            | 0x3FF57068 | 只读    |
| PCNT_U3_CNT_REG   | Counter value for unit 3            | 0x3FF5706C | 只读    |
| PCNT_U4_CNT_REG   | Counter value for unit 4            | 0x3FF57070 | 只读    |
| PCNT_U5_CNT_REG   | Counter value for unit 5            | 0x3FF57074 | 只读    |
| PCNT_U6_CNT_REG   | Counter value for unit 6            | 0x3FF57078 | 只读    |
| PCNT_U7_CNT_REG   | Counter value for unit 7            | 0x3FF5707C | 只读    |
| 控制寄存器             |                                     |            |       |
| PCNT_CTRL_REG     | Control register for all counters   | 0x3FF570B0 | 读/写   |
| 中断寄存器             |                                     |            |       |
| PCNT_INT_RAW_REG  | Raw interrupt status                | 0x3FF57080 | 只读    |
| PCNT_INT_ST_REG   | Masked interrupt status             | 0x3FF57084 | 只读    |
| PCNT_INT_ENA_REG  | Interrupt enable bits               | 0x3FF57088 | 读 / 写 |
| PCNT_INT_CLR_REG  | Interrupt clear bits                | 0x3FF5708C | 只写    |

## 8.4 寄存器

Register 8.1: PCNT\_Un\_CONF0\_REG (n: 0-7) (0x0+0x0C\*n)



PCNT\_CH1\_LCTRL\_MODE\_Un 当 控 制 信 号 为 低 电 平 时, 用 于 改 变 CH1\_POS\_MODE/CH1\_NEG\_MODE 的设置。(读 / 写)

0:不做修改;1:反转(增加转为减少,减少转为增加);2,3:禁止计数器计数。

PCNT\_CH1\_HCTRL\_MODE\_Un 当 控 制 信 号 为 低 电 平 时, 用 于 改 变 CH1\_POS\_MODE/CH1\_NEG\_MODE 的设置。(读 / 写)

0:不做修改;1:反转(增加转为减少,减少转为增加);2,3:禁止计数器计数。

 $PCNT_CH1_POS_MODE_Un$  用于设置通道 1 检测输入信号上升沿的工作模式。(读 / 写)

1: 增加计数器; 2: 减少计数器; 0, 3: 对计数器无任何影响。

 $PCNT_CH1_NEG_MODE_Un$  用于设置通道 1 检测输入信号下降沿的工作模式。(读 / 写)

1: 增加计数器; 2: 减少计数器; 0, 3: 对计数器无任何影响。

PCNT\_CH0\_LCTRL\_MODE\_Un 当 控 制 信 号 为 低 电 平 时, 用 于 配 置 CH0\_POS\_MODE/CH0\_NEG\_MODE 的设置修改方式。(读 / 写)

0:不做修改;1:反转(增加转为减少,减少转为增加);2,3:禁止计数修改。

PCNT\_CH0\_HCTRL\_MODE\_Un 当 控 制 信 号 为 低 电 平 时, 用 于 配 置 CH0\_POS\_MODE/CH0\_NEG\_MODE 的设置修改方式。(读 / 写)

0:不做修改; 1: 反转(增加转为减少,减少转为增加); 2,3:禁止计数修改。

 $PCNT_CHO_POS_MODE_Un$  用于设置通道 1 检测输入信号上升沿的工作模式。(读 / 写)

1:增加计数器; 2:减少计数器; 0,3:对计数器无任何影响。

PCNT\_CH0\_NEG\_MODE\_Un T当通道 0 的输入信号探测到一个下降沿时,用于设置工作模式。(读/写) 1:增加计数器; 2:减少计数器; 0, 3:对计数器无任何影响。

**PCNT\_THR\_THRES1\_EN\_U**<sup>n</sup> 为单位 <sup>n</sup> 的阈值 1 比较器的使能位。(读 / 写)

**PCNT\_THR\_THRESO\_EN\_U**<sup>n</sup> 为单位 <sup>n</sup> 的阈值 0 比较器的使能位。(读 / 写)

**PCNT\_THR\_L\_LIM\_EN\_U**n 为单位 n 的阈值 1 比较器的使能位。(读 / 写)

**PCNT\_THR\_H\_LIM\_EN\_U**<sup>n</sup> 为单位 <sup>n</sup> 的 thr\_h\_lim 比较器的使能位。(读 / 写)

**PCNT\_THR\_ZERO\_EN\_U**n 为单位 n 的过零比较器的使能位。(读 / 写)

**PCNT\_FILTER\_EN\_U**<sup>n</sup> 为单位 <sup>n</sup> 的输入滤波器的使能位。(读 / 写)

PCNT\_FILTER\_THRES\_Un 在 APB\_CLK 个时钟周期内为滤波器设置最大阈值。在滤波器启动时, 任何比 APB\_CLK 个时钟周期窄的脉冲都将被过滤掉。(读 / 写)

Register 8.2: PCNT\_Un\_CONF1\_REG (n: 0-7) (0x4+0x0C\*n)



PCNT\_CNT\_THRES1\_Un 用于配置单位 n 的阈值 1 的值。(读 / 写)

**PCNT\_CNT\_THRES0\_U***n* 用于配置单位 *n* 的阈值 0 的值。(读 / 写)

Register 8.3: PCNT\_Un\_CONF2\_REG (n: 0-7) (0x8+0x0C\*n)



**PCNT\_CNT\_L\_LIM\_U**<sup>n</sup> 用于配置单位 n 的计数器的最小值。(读 / 写)

**PCNT\_CNT\_H\_LIM\_U**n 用于配置单位 n 的计数器的最大值。(读 / 写)

Register 8.4: PCNT\_Un\_CNT\_REG (n: 0-7) (0x28+0x0C\*n)



**PCNT\_PLUS\_CNT\_U**n 该寄存器存储着单位 n 的当前计数器的值,可供软件读取。(只读)

Register 8.5: PCNT\_INT\_RAW\_REG (0x0080)



**PCNT\_CNT\_THR\_EVENT\_U**n\_**INT\_RAW** PCNT\_CNT\_THR\_EVENT\_Un\_INT 中断的原始中断状态位。(只读)

Register 8.6: PCNT\_INT\_ST\_REG (0x0084)



**PCNT\_CNT\_THR\_EVENT\_U**n\_**INT\_ST** PCNT\_CNT\_THR\_EVENT\_Un\_INT 中断的屏蔽中断状态位。(只读)

Register 8.7: PCNT\_INT\_ENA\_REG (0x0088)



PCNT\_CNT\_THR\_EVENT\_Un\_INT\_ENA PCNT\_CNT\_THR\_EVENT\_Un\_INT 中断的使能位。(读 / 写)

Register 8.8: PCNT\_INT\_CLR\_REG (0x008c)



PCNT\_CNT\_THR\_EVENT\_Un\_INT\_CLR 用于清除 PCNT\_CNT\_THR\_EVENT\_Un\_INT 中断。(只写)

Register 8.9: PCNT\_CTRL\_REG (0x00b0)



**PCNT\_CNT\_PAUSE\_U** $_n$  用于暂停单位  $_n$  的计数器。(读 / 写)

**PCNT\_PLUS\_CNT\_RST\_U***n* 用于清零单位 *n* 的计数器。(读 / 写)

# 9. 64-bit 定时器

## 9.1 概述

ESP32 内置 4 个 64-bit 通用定时器。每个定时器包含一个 16-bit 预分频器和一个 64-bit 可自动重新加载向上 / 向下计数器。

ESP32 的定时器分为 2 组,每组 2 个。 $TIMG_n_Tx$  的 n 代表组别, x 代表定时器编号。

#### 定时器特性:

- 16-bit 时钟预分频器,分频系数为 2-65536
- 64-bit 时基计数器
- 可配置的向上 / 向下时基计数器: 增加或减少
- 暂停和恢复时基计数器
- 报警时自动重新加载
- 当报警值溢出/低于保护值时报警
- 软件控制的即时重新加载
- 电平触发中断和边沿触发中断

# 9.2 功能描述

### 9.2.1 16-bit 预分频器

每个定时器都以 APB 时钟 (缩写 APB\_CLK, 频率通常为 80 MHz) 作为基础时钟。16-bit 预分频器对 APB 时钟进行分频,产生时基计数器时钟 (TB\_clk)。TB\_clk 每过一个周期,时基计数器会向上数一或者向下数一。在使用寄存器 TIMG $n_Tx_DIVIDER$  配置分频器除数前,必须关闭定时器 (清零 TIMG $n_Tx_DIVIDER$ )。定时器使能时配置预分频器会导致不可预知的结果。预分频器可以对 APB 时钟进行 2 到 65536 的分频。具体来说,TIMG $n_Tx_DIVIDER$  为 1 或 2 时,时钟分频器是 2; TIMG $n_Tx_DIVIDER$  为 0 时,时钟分频器是 65536。如 TIMG $n_Tx_DIVIDER$  为 其他任意值,时钟会被相同数值分频。

### 9.2.2 64-bit 时基计数器

TIMG $n_Tx_I$ NCREASE 置 1 或清零可以将 64-bit 时基计数器分别配置为向上计数或向下计数。同时,64-bit 时基计数器支持自动重新加载和软件即时重新加载,计数器达到软件设定值时会触发报警事件。

 $TIMGn_Tx_EN$  置 1 或清零可以使能或关闭计数。清零后计数器暂停计数,并会在  $TIMGn_Tx_EN$  重新置 1 前保持其值不变。清零  $TIMGn_Tx_EN$  会重新加载计数器并改变计数器的值,但在设置  $TIMGn_Tx_EN$  前计数不会恢复。

软件可以通过寄存器  $TIMG_{n_{Tx_{LOAD_LO}}}$  和  $TIMG_{n_{Tx_{LOAD_HI}}}$  重置计数器的值。重新加载时,寄存器  $TIMG_{n_{Tx_{LOAD_LO}}}$  和  $TIMG_{n_{Tx_{LOAD_HI}}}$  的值才会被更新到 64-bit 时基计数器内。报警(报警时自动重新加载)或软件(软件即时重新加载)会触发重新加载。寄存器  $TIMG_{n_{Tx_{LOAD_HI}}}$  可以使能报警时自动重新加载。如果报警时自动重新加载未被使能,时基计数器会在报警后继续向上计数或向下计数。在寄存器

9.3 寄存器列表 9 64-BIT 定时器

 $TIMG_{n_{-}}Tx_{-}LOAD_{-}$ REG 上写任意值可以触发软件即时重新加载,写值时计数器值会立刻改变。软件也能通过改变  $TIMG_{n_{-}}Tx_{-}$ INCREASE 的值立刻改变时基计数器计数方向。

软件也能读取时基计数器。但由于计数器是 64-bit,CPU 只能以两个 32-bit 值的形式读值。计数器值首先需要被锁入  $TIMG_n_TxLO_REG$  和  $TIMG_n_TxHI_REG$ 。在  $TIMG_n_TxUPDATE_REG$  上写任意值可以马上将 64-bit 定时器值锁入两个寄存器。之后,软件可以在任何时间读取寄存器。这样可以防止读取计时器低字和高字时出现读值错误。

## 9.2.3 报警产生

定时器可以触发报警,报警则会引发重新加载和 / 或触发中断。如报警寄存器  $\mathsf{TIMGn\_Tx\_ALARMLO\_REG}$  和  $\mathsf{TIMGn\_Tx\_ALARMHI\_REG}$  的值等于当前定时器的值,则报警触发。为解决寄存器设置过晚,计数器值超过报警值的问题,当前定时器值高于(适用于向上定时器)或低于(适用于向下定时器)当前报警值也会触发报警。在这种情况下,使能报警功能会马上触发报警。

#### 9.2.4 MWDT

每个定时器模块另包含一个主系统看门狗定时器(缩写为 MWDT)和有关寄存器。本章列出了寄存器相关信息,功能描述请参阅看门狗定时器章节。

### 9.2.5 中断

- TIMGn\_Tx\_INT\_WDT\_INT 该中断在看门狗定时器中断阶段超时后产生。
- TIMGn\_Tx\_INT\_T1\_INT 该中断由定时器 1 上的报警事件产生。
- TIMGn\_Tx\_INT\_TO\_INT 该中断由定时器 0 上的报警事件产生。

# 9.3 寄存器列表

| 名称                  | 描述                                   | TIMG0       | TIMG1       | 访问  |
|---------------------|--------------------------------------|-------------|-------------|-----|
| 定时器 0 配置和控制寄存器      |                                      |             |             |     |
| TIMGn_TOCONFIG_REG  | Timer 0 configuration register       | 0x3FF5F000  | 0x3FF60000  | 读/写 |
| TIMGn_T0LO_REG      | Timer 0 current value, low 32 bits   | 0x3FF5F004  | 0x3FF60004  | 只读  |
| TIMGn_T0HI_REG      | Timer 0 current value, high 32 bits  | 0x3FF5F008  | 0x3FF60008  | 只读  |
| TIMGn TOUPDATE REG  | Write to copy current timer value to | 0x3FF5F00C  | 0x3FF6000C  | 只写  |
| TIMON_TOOL BATE_REG | TIMGn_T0_(LO/HI)_REG                 | 0.001101000 | 0.0000      | 八寸  |
| TIMGn_T0ALARMLO_REG | Timer 0 alarm value, low 32 bits     | 0x3FF5F010  | 0x3FF60010  | 读/写 |
| TIMGn_T0ALARMHI_REG | Timer 0 alarm value, high 32 bits    | 0x3FF5F014  | 0x3FF60014  | 读/写 |
| TIMGn_T0LOADLO_REG  | Timer 0 reload value, low 32 bits    | 0x3FF5F018  | 0x3FF60018  | 读/写 |
| TIMGn TOLOAD REG    | Write to reload timer from           | 0x3FF5F020  | 0x3FF60020  | 只写  |
| TIMON_TOLOAD_NEG    | TIMGn_T0_(LOADLOLOADHI)_REG          | 0.001101020 | 0.001100020 | 八勺  |
| 定时器 1 配置和控制寄存器      |                                      |             |             |     |
| TIMGn_T1CONFIG_REG  | Timer 1 configuration register       | 0x3FF5F024  | 0x3FF60024  | 读/写 |
| TIMGn_T1LO_REG      | Timer 1 current value, low 32 bits   | 0x3FF5F028  | 0x3FF60028  | 只读  |
| TIMGn_T1HI_REG      | Timer 1 current value, high 32 bits  | 0x3FF5F02C  | 0x3FF6002C  | 只读  |

9.3 寄存器列表 9 64-BIT 定时器

| 名称                       | 描述                                                        | TIMG0      | TIMG1      | 访问  |
|--------------------------|-----------------------------------------------------------|------------|------------|-----|
| TIMGn_T1UPDATE_REG       | Write to copy current timer value to TIMGn_T1_(LO/HI)_REG | 0x3FF5F030 | 0x3FF60030 | 只写  |
| TIMGn_T1ALARMLO_REG      | Timer 1 alarm value, low 32 bits                          | 0x3FF5F034 | 0x3FF60034 | 读/写 |
| TIMGn_T1ALARMHI_REG      | Timer 1 alarm value, high 32 bits                         | 0x3FF5F038 | 0x3FF60038 | 读/写 |
| TIMGn_T1LOADLO_REG       | Timer 1 reload value, low 32 bits                         | 0x3FF5F03C | 0x3FF6003C | 读/写 |
| TIMGn_T1LOAD_REG         | Write to reload timer from TIMGn_T1_(LOADLOLOADHI)_REG    | 0x3FF5F044 | 0x3FF60044 | 只写  |
| 系统看门狗定时器配置和控制寄存          | 架船                                                        |            |            |     |
| TIMGn_Tx_WDTCONFIG0_REG  | Watchdog timer configuration register                     | 0x3FF5F048 | 0x3FF60048 | 读/写 |
| TIMGn_Tx_WDTCONFIG1_REG  | Watchdog timer prescaler register                         | 0x3FF5F04C | 0x3FF6004C | 读/写 |
| TIMGn_Tx_WDTCONFIG2_REG  | Watchdog timer stage 0 timeout value                      | 0x3FF5F050 | 0x3FF60050 | 读/写 |
| TIMGn_Tx_WDTCONFIG3_REG  | Watchdog timer stage 1 timeout value                      | 0x3FF5F054 | 0x3FF60054 | 读/写 |
| TIMGn_Tx_WDTCONFIG4_REG  | Watchdog timer stage 2 timeout value                      | 0x3FF5F058 | 0x3FF60058 | 读/写 |
| TIMGn_Tx_WDTCONFIG5_REG  | Watchdog timer stage 3 timeout value                      | 0x3FF5F05C | 0x3FF6005C | 读/写 |
| TIMGn_Tx_WDTFEED_REG     | Write to feed the watchdog timer                          | 0x3FF5F060 | 0x3FF60060 | 只写  |
| TIMGn_Tx_WDTWPROTECT_REG | Watchdog write protect register                           | 0x3FF5F064 | 0x3FF60064 | 读/写 |
| 中断寄存器                    |                                                           |            |            |     |
| TIMGn_Tx_INT_RAW_REG     | Raw interrupt status                                      | 0x3FF5F09C | 0x3FF6009C | 只读  |
| TIMGn_Tx_INT_ST_REG      | Masked interrupt status                                   | 0x3FF5F0A0 | 0x3FF600A0 | 只读  |
| TIMGn_Tx_INT_ENA_REG     | Interrupt enable bits                                     | 0x3FF5F098 | 0x3FF60098 | 读/写 |
| TIMGn_Tx_INT_CLR_REG     | Interrupt clear bits                                      | 0x3FF5F0A4 | 0x3FF600A4 | 只写  |

## 9.4 寄存器

Register 9.1: TIMG $n_Tx$ CONFIG\_REG (x: 0-1) (0x0+0x24\*x)



 $TIMG_n_Tx_EN$  置 1 后,定时器 x 时基计数器使能。(读/写)

**TIMG** $n_Tx_I$ **INCREASE** 置 1 后,定时器 x 的时基计数器会在每个时钟周期后增加。清零后,定时器 x 时基计数器会在每个时钟周期后减少。(读/写)

TIMGn\_Tx\_AUTORELOAD 置 1 后,定时器 x 报警时自动重新加载使能。(读/写)

**TIMG**<sup>n</sup>\_**T**x\_**DIVIDER** 计时器 x 时钟 (Tx\_clk) 的预分频器值。(读/写)

TIMG/-\_Tx\_EDGE\_INT\_EN 置 1 后,报警会产生一个边沿触发中断。(读/写)

 $TIMG_{\cap}_{Tx}_{LEVEL\_INT\_EN}$  置 1 后, 报警会产生一个电平触发中断。(读/写)

TIMGn\_Tx\_ALARM\_EN 置 1 后, 报警使能。(读/写)

Register 9.2: TIMG $n_T \times LO_REG(x: 0-1) (0x4+0x24*x)$ 



**TIMG***n*\_**TxLO**\_**REG** 在 TIMG*n*\_TxUPDATE\_REG 上写值后,定时器 x 时基计数器的低 32 位可以被 读取。(只读)

Register 9.3: TIMG<sup>n</sup> T<sub>x</sub>HI REG (x: 0-1) (0x8+0x24\*x)



**TIMG**<sub>n</sub>\_**T**<sub>x</sub>**HI**\_**REG** 在 TIMG<sub>n</sub>\_TxUPDATE\_REG 上写值后,定时器 x 时基计数器的高 32 位可以被读取。(只读)





TIMGn\_TxUPDATE\_REG 写任何值触发定时器 x 时基计数器值更新(定时器 x 当前值会被存储到以上寄存器)。(只写)

Register 9.5: TIMG $\cap_T \times ALARMLO_REG(x: 0-1)$  (0x10+0x24\*x)



 $TIMG_{n_{-}}T_{x}ALARMLO_{-}REG$  定时器 x 时基计数器触发警报值的低 32 位。(读/写)

#### Register 9.6: TIMGn\_TxALARMHI\_REG (x: 0-1) (0x14+0x24\*x)



TIMGn\_TxALARMHI\_REG 定时器 x 时基计数器触发警报值的高 32 位。(读/写)

Register 9.7: TIMG $^{n}$ \_T $\times$ LOADLO\_REG ( $\times$ : 0-1) (0x18+0x24 $\times$ )



TIMGn\_TxLOADLO\_REG 定时器 x 时基计数器重新加载的低 32-bit 值。(读/写)

Register 9.8: TIMG $n_Tx$ LOADHI\_REG (x: 0-1) (0x1C+0x24\*x)



TIMGn\_TxLOADHI\_REG 定时器 x 时基计数器重新加载的高 32-bit 值。(读/写)

Register 9.9: TIMGn\_TxLOAD\_REG (x: 0-1) (0x20+0x24\*x)



 $TIMG_{n_{x}}TxLOAD_{x}$  写任何值触发定时器 x 时基计数器重新加载。(只写)

9 64-BIT 定时器 9.4 寄存器

THER THURT CRU THESE THE GIV THICK IT NOT SIS PLEST JENGTH THE THE TOTAL STATE OF THE STAT Inter it inti stes Thurstey and the state of the s

0x1

14

<sup>1</sup> Reset

15

0x1

Register 9.10: TIMGn Tx WDTCONFIGO REG (0x0048)

TIMGn\_Tx\_WDT\_EN 置 1 后, SWDT 使能。(读/写)

TIMGn\_TxS\_WDT\_STG0 阶段 0 配置。0: 关闭, 1: 中断, 2: 复位 CPU, 3: 复位系统。(读/写)

23

TIMGn\_Tx\_WDT\_STG1 阶段 1 配置。0: 关闭, 1: 中断, 2: 复位 CPU, 3: 复位系统。(读/写)

TIMGn\_Tx\_WDT\_STG2 阶段 2 配置。0: 关闭, 1: 中断, 2: 复位 CPU, 3: 复位系统。(读/写)

TIMGn\_Tx\_WDT\_STG3 阶段 3 配置。0: 关闭, 1: 中断, 2: 复位 CPU, 3: 复位系统。(读/写)

 $TIMG_{n}$ \_Tx\_WDT\_EDGE\_INT\_EN 置 1 后, 如超过定时器 x 的阶段中断产生时间, 会产生边沿触发中 断。(读/写)

 $TIMG_{n}$ \_Tx\_WDT\_LEVEL\_INT\_EN 置 1 后,如超过设置的阶段中断产生时间,会产生电平触发中 断。(读/写)

TIMGn\_Tx\_WDT\_CPU\_RESET\_LENGTH CPU 复位信号长度选择。0: 100 ns, 1: 200 ns, 2: 300 ns, 3: 400 ns, 4: 500 ns, 5: 800 ns, 6: 1.6 μs, 7: 3.2 μs。(读/写)

TIMGn\_Tx\_WDT\_SYS\_RESET\_LENGTH 系统复位信号长度选择。0: 100 ns, 1: 200 ns, 2: 300 ns, 3: 400 ns, 4: 500 ns, 5: 800 ns, 6: 1.6 μs, 7: 3.2 μs。(读/写)

TIMGn\_Tx\_WDT\_FLASHBOOT\_MOD\_EN 置 1 后, Flash 启动保护使能。(读/写)

Register 9.11: TIMGn\_Tx\_WDTCONFIG1\_REG (0x004c)



TIMGn\_Tx\_WDT\_CLK\_PRESCALE SWDT 时钟预分频器值,分辨率 12.5 ns TIMGn\_Tx\_WDT\_CLK\_PRESCALE。(读/写)





TIMGn\_Tx\_WDTCONFIG2\_REG SWDT 时钟周期中阶段 0 超时时间。(读/写)

Register 9.13: TIMGn\_Tx\_WDTCONFIG3\_REG (0x0054)



TIMGn\_Tx\_WDTCONFIG3\_REG SWDT 时钟周期中阶段 1 超时时间。(读/写)

Register 9.14: TIMGn\_Tx\_WDTCONFIG4\_REG (0x0058)



TIMGn\_Tx\_WDTCONFIG4\_REG SWDT 时钟周期中阶段 2 超时时间。(读/写)

Register 9.15: TIMGn\_Tx\_WDTCONFIG5\_REG (0x005c)



TIMGn\_Tx\_WDTCONFIG5\_REG SWDT 时钟周期中阶段 3 超时时间。(读/写)

Register 9.16: TIMGn\_Tx\_WDTFEED\_REG (0x0060)



TIMGn\_Tx\_WDTFEED\_REG 写任何值驱动 SWDT。(只写)

Register 9.17: TIMGn\_Tx\_WDTWPROTECT\_REG (0x0064)



TIMGn\_Tx\_WDTWPROTECT\_REG 如果寄存器中有和复位值不同的值,写保护使能。(读/写)

Register 9.18: TIMGn Tx INT ENA REG (0x0098)

31 0 0 0 |Reset 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

TIMGn\_Tx\_INT\_WDT\_INT\_ENA TIMGn\_Tx\_INT\_WDT\_INT 中断的中断使能位。(读/写)

TIMGn\_Tx\_INT\_T1\_INT\_ENA TIMGn\_Tx\_INT\_T1\_INT 中断的中断使能位。(读/写)

TIMGn\_Tx\_INT\_T0\_INT\_ENA TIMGn\_Tx\_INT\_T0\_INT 中断的中断使能位。(读/写)

Register 9.19: TIMGn Tx INT RAW REG (0x009c)



TIMGn\_Tx\_INT\_WDT\_INT\_RAW TIMGn\_Tx\_INT\_WDT\_INT 中断的原始中断状态位。(只读)

**TIMG**<sub>n</sub>\_**T**<sub>x</sub>\_**INT**\_**T1**\_**INT**\_**RAW** TIMG<sub>n</sub>\_Tx\_**INT**\_T1\_**INT** 中断的原始中断状态位。(只读)

TIMGn\_Tx\_INT\_T0\_INT\_RAW TIMGn\_Tx\_INT\_T0\_INT 中断的原始中断状态位。(只读)

Register 9.20: TIMGn\_Tx\_INT\_ST\_REG (0x00a0)



TIMGn\_Tx\_INT\_WDT\_INT\_ST TIMGn\_Tx\_INT\_WDT\_INT 中断的屏蔽中断状态位。(只读)

TIMGn\_Tx\_INT\_T1\_INT\_ST TIMGn\_Tx\_INT\_T1\_INT 中断的屏蔽中断状态位。(只读)

TIMGn\_Tx\_INT\_T0\_INT\_ST TIMGn\_Tx\_INT\_T0\_INT 中断的屏蔽中断状态位。(只读)

Register 9.21: TIMGn\_Tx\_INT\_CLR\_REG (0x00a4)



TIMGn\_Tx\_INT\_WDT\_INT\_CLR 置 1 该位以清除 TIMGn\_Tx\_INT\_WDT\_INT 中断。(只写)

TIMGn\_Tx\_INT\_T1\_INT\_CLR 置 1 该位以清除 TIMGn\_Tx\_INT\_T1\_INT 中断。(只写)

TIMGn\_Tx\_INT\_T0\_INT\_CLR 置 1 该位以清除 TIMGn\_Tx\_INT\_T0\_INT 中断。(只写)

# 10. 看门狗定时器

## 10.1 概述

ESP32 中有三个看门狗定时器:两个定时器模块中各一个(称作主系统看门狗定时器,缩写为 MWDT),RTC模块中一个(称作 RTC 看门狗定时器,缩写为 RWDT)。不可预知的软件或硬件问题会导致应用程序工作失常,看门狗定时器可以帮助系统从中恢复。看门狗定时器有四个阶段。如果当前阶段超过预定时间,但没有喂狗或关闭看门狗定时器,每个阶段可能被配成以下三或四种动作中的一种。这些动作是:中断、CPU 复位、内核复位和系统复位。其中,只有 RWDT 能够触发系统复位,将复位包括 RTC 和主系统在内的整个芯片。每个阶段的超时时间都可单独设置。

在 Flash 启动期间, RWDT 和第一个 MWDT 会自动开启以检测和修复启动问题。

# 10.2 主要特性

- 4个阶段,每阶段都可被单独配置或关闭
- 各阶段超时时间可配置
- 如阶段超时,会采取三到四种可能动作中的一种(中断、CPU 复位、内核复位和系统复位)
- 32-bit 超时计数器
- 写保护, 防止 RWDT 和 MWDT 配置被不小心改变
- Flash 启动保护 如果在预定时间内,SPI Flash 的启动过程没有完成,看门狗会重启整个主系统

# 10.3 功能描述

## 10.3.1 时钟

RWDT 的时钟源是 RTC 慢速时钟,频率通常为 32 KHz。MWDT 时钟源来自于 APB 时钟,经过可配置的 16-bit 预分频器输出给 MWDT。RWDT 和 MWDT 的时钟源用作驱动 32-bit 超时计数器。当计数器接近当前阶段的超时时间,将执行当前阶段配置的动作,超时计数器复位,下一阶段启动。

#### 10.3.1.1 运行过程

RWDT 和 MWDT 使能时会循环工作,从阶段 0 进行到阶段 3,再回到阶段 0 重新开始。每阶段超时动作和超时时间可以被单独配置。

如果超时计时器接近阶段超时时间,以下动作可以被配置到每个阶段:

- 触发中断 如阶段超时,中断被触发。
- 复位 CPU 内核
   如阶段超时,复位指定 CPU 内核。复位 MWDT0 CPU 只能复位 PRO CPU,复位 MWDT1 CPU 只能复位
   APP CPU。根据不同配置,复位 RWDT CPU 可以复位两个,一个或不复位 CPU 内核。

10.3 功能描述 10 看门狗定时器

● 复位主系统 如阶段超时,包括 MWDT 在内的主系统都会被复位。在本文中,主系统指的是 CPU 和所有外设。但 RTC 是一个例外,不会复位。

- 复位主系统和 RTC 如阶段超时,主系统和 RTC 同时复位。此动作仅可在 RWDT 中实现。
- 关闭 该阶段对系统不产生影响。

当软件喂狗时,看门狗定时器重新回到阶段 0,超时计数器从 0 重新开始。

### 10.3.1.2 写保护

两个 MWDT 和 RWDT 都可被保护不受误写影响。为实现该功能,两个看门狗都配有写密匙保护寄存器。MWDT 的寄存器为 TIMERS\_WDT\_WKEY, RWDT 的寄存器为 RTC\_CNTL\_WDT\_WKEY。复位时,这些寄存器的初始值为 0x50D83AA1。当寄存器的值被改变,写保护使能。此时,除了写密匙保护寄存器以外,在包括喂狗寄存器的其他任意 WDT 寄存器上写值操作会被忽略。推荐按以下步骤访问 WDT:

- 1. 关闭写保护
- 2. 根据需要修改寄存器或喂狗
- 3. 重新使能写保护

#### 10.3.1.3 Flash 启动保护

在 Flash 启动过程中,定时器组 0(TIMG0)中的 MWDT 和 RWDT 自动使能。两个看门狗定时器的阶段 0 默认为在超时后复位系统。启动后,应该清零寄存器 TIMERS\_WDT\_FLASHBOOT\_MOD\_EN 来关闭 MWDT Flash 启动保护程序。对于 RWDT,则应该清零 RTC\_CNTL\_WDT\_FLASHBOOT\_MOD\_EN。然后,软件可以配置 MWDT和 RWDT。

## 10.3.1.4 寄存器

MWDT 寄存器是定时器子模块的一部分,在定时器寄存器中有详细描述。RWDT 寄存器是 RTC 子模块的一部分,在 RTC 寄存器中有详细描述。

# 11. AES 加速器

## 11.1 概述

ESP32 内置 AES (高级加密标准) 加速器,相比于只用软件进行 AES 运算, AES 加速器能够极大地提高运算速度。AES 加速器支持 FIPS PUB 197 标准,能够实现 AES-128, AES-192, AES-256 加密与解密运算。

## 11.2 主要特性

- 支持 AES-128 加解密运算
- 支持 AES-192 加解密运算
- 支持 AES-256 加解密运算
- 支持 4 种密钥字节序和 4 种文本字节序

## 11.3 功能描述

## 11.3.1 运算模式

AES 加速器支持 AES-128/192/256 加解密 6 种运算。配置寄存器 AES\_MODE\_REG 以实现不同运算。寄存器 AES\_MODE\_REG 的值与各种运算的对应关系如表 28 所示。

| AES_MODE_REG[2:0] | 运算         |
|-------------------|------------|
| 0                 | AES-128 加密 |
| 1                 | AES-192 加密 |
| 2                 | AES-256 加密 |
| 4                 | AES-128 解密 |
| 5                 | AES-192 解密 |
| 6                 | AES-256 解密 |

表 28: 运算模式

#### 11.3.2 密钥、明文、密文

寄存器 AES\_KEY\_n\_REG 存放密钥。每个寄存器位宽都是 32 位,共有 8 个寄存器。如果为 AES-128 加解密运算,则 128 位密钥在寄存器 AES\_KEY\_0\_REG ~ AES\_KEY\_3\_REG 中。如果为 AES-192 加解密运算,则 192 位密钥在寄存器 AES\_KEY\_0\_REG ~ AES\_KEY\_5\_REG 中。如果为 AES-256 加解密运算,则 256 位密钥在寄存器 AES\_KEY\_0\_REG ~ AES\_KEY\_7\_REG 中。

寄存器 AES\_TEXT\_*m*\_REG 存放明文或密文。每个寄存器位宽都是 32 位,共有 4 个寄存器。如果为 AES-128/192/265 加密运算,则运算开始之前用明文初始化寄存器 AES\_TEXT\_*m*\_REG。运算完成之后,AES 加速器将把密文更新入寄存器 AES\_TEXT\_*m*\_REG。如果为 AES-128/192/256 解密运算,则运算开始之前用密文初始 化寄存器 AES\_TEXT\_*m*\_REG。运算完成之后,AES 加速器将把明文更新入寄存器 AES\_TEXT\_*m*\_REG。

## 11.3.3 字节序

### 密钥字节序

寄存器 AES\_ENDIAN\_REG 的 Bit 0、Bit 1 控制密钥的字节序,具体见表 30、表 31、表 32。表 30 中的 w[0] ~ w[3]、表 31 中的 w[0] ~ w[5]、表 32 中的 w[0] ~ w[7] 皆为标准 FIPS PUB 197 中 "5.2 Key Expansion" 所述 "the first Nk words of the expanded key"。Bit 一列指明 w[0] ~ w[7] 每个 word 中的各个字节。三张表表明了在四种不同字节序下,寄存器 AES\_KEY\_n\_REG 中的每个字节如何构成 "the first Nk words of the expanded key"。

#### 文本字节序

寄存器 AES\_ENDIAN\_REG 的 Bit 2、Bit 3 控制输入文本的字节序,Bit 4、Bit 5 控制输出文本的字节序。输入文本在 AES-128/192/256 加密运算时指的是明文,在 AES-128/192/256 解密运算时指的是密文。输出文本在 AES-128/192/256 加密运算时指的是密文,在 AES-128/192/256 解密运算时指的是明文。具体见表 29。表 29中的 State 为标准 FIPS PUB 197中 "3.4 The State"所述 "the AES algorithm's operations are performed on a tow-dimensional array of bytes called the State"。此表表明了在四种不同字节序下,寄存器 AES\_TEXT\_m\_REG中的每个字节所存放的明文或密文如何构成 State。

表 29: AES 文本字节序

| AES_ENDIAN_REG[3]/[5] | AES_ENDIAN_REG[2]/[4] |          |      |                       | Plaintext/Ciphertext  |                       |                       |  |
|-----------------------|-----------------------|----------|------|-----------------------|-----------------------|-----------------------|-----------------------|--|
|                       |                       |          | tate | С                     |                       |                       |                       |  |
|                       |                       | 5        | late | 0                     | 1                     | 2                     | 3                     |  |
|                       | 0                     |          | 0    | AES_TEXT_3_REG[31:24] | AES_TEXT_2_REG[31:24] | AES_TEXT_1_REG[31:24] | AES_TEXT_0_REG[31:24] |  |
| 0                     | 0                     |          | 1    | AES_TEXT_3_REG[23:16] | AES_TEXT_2_REG[23:16] | AES_TEXT_1_REG[23:16] | AES_TEXT_0_REG[23:16] |  |
|                       |                       | '        | 2    | AES_TEXT_3_REG[15:8]  | AES_TEXT_2_REG[15:8]  | AES_TEXT_1_REG[15:8]  | AES_TEXT_0_REG[15:8]  |  |
|                       |                       |          | 3    | AES_TEXT_3_REG[7:0]   | AES_TEXT_2_REG[7:0]   | AES_TEXT_1_REG[7:0]   | AES_TEXT_0_REG[7:0]   |  |
|                       |                       |          | tate |                       | (                     | 0                     |                       |  |
|                       |                       | 3        | late | 0                     | 1                     | 2                     | 3                     |  |
| 0                     | ,                     |          | 0    | AES_TEXT_3_REG[7:0]   | AES_TEXT_2_REG[7:0]   | AES_TEXT_1_REG[7:0]   | AES_TEXT_0_REG[7:0]   |  |
| 0                     | 1                     | ,        | 1    | AES_TEXT_3_REG[15:8]  | AES_TEXT_2_REG[15:8]  | AES_TEXT_1_REG[15:8]  | AES_TEXT_0_REG[15:8]  |  |
|                       |                       | <u>'</u> | 2    | AES_TEXT_3_REG[23:16] | AES_TEXT_2_REG[23:16] | AES_TEXT_1_REG[23:16] | AES_TEXT_0_REG[23:16] |  |
|                       |                       |          | 3    | AES_TEXT_3_REG[31:24] | AES_TEXT_2_REG[31:24] | AES_TEXT_1_REG[31:24] | AES_TEXT_0_REG[31:24] |  |
|                       |                       | State    |      |                       | (                     | 0                     |                       |  |
|                       |                       | 3        | late | 0                     | 1                     | 2                     | 3                     |  |
| 4                     | 0                     |          | 0    | AES_TEXT_0_REG[31:24] | AES_TEXT_1_REG[31:24] | AES_TEXT_2_REG[31:24] | AES_TEXT_3_REG[31:24] |  |
| !                     | "                     | _        | 1    | AES_TEXT_0_REG[23:16] | AES_TEXT_1_REG[23:16] | AES_TEXT_2_REG[23:16] | AES_TEXT_3_REG[23:16] |  |
|                       |                       | '        | 2    | AES_TEXT_0_REG[15:8]  | AES_TEXT_1_REG[15:8]  | AES_TEXT_2_REG[15:8]  | AES_TEXT_3_REG[15:8]  |  |
|                       |                       |          | 3    | AES_TEXT_0_REG[7:0]   | AES_TEXT_1_REG[7:0]   | AES_TEXT_2_REG[7:0]   | AES_TEXT_3_REG[7:0]   |  |
|                       |                       | 9        | tate |                       | (                     | 0                     |                       |  |
|                       |                       | "        | iaic | 0                     | 1                     | 2                     | 3                     |  |
| 1                     | 1                     |          | 0    | AES_TEXT_0_REG[7:0]   | AES_TEXT_1_REG[7:0]   | AES_TEXT_2_REG[7:0]   | AES_TEXT_3_REG[7:0]   |  |
| '                     | '                     | _        | 1    | AES_TEXT_0_REG[15:8]  | AES_TEXT_1_REG[15:8]  | AES_TEXT_2_REG[15:8]  | AES_TEXT_3_REG[15:8]  |  |
|                       |                       | '        | 2    | AES_TEXT_0_REG[23:16] | AES_TEXT_1_REG[23:16] | AES_TEXT_2_REG[23:16] | AES_TEXT_3_REG[23:16] |  |
|                       |                       |          | 3    | AES_TEXT_0_REG[31:24] | AES_TEXT_1_REG[31:24] | AES_TEXT_2_REG[31:24] | AES_TEXT_3_REG[31:24] |  |

## 表 30: AES-128 密钥字节序

11.3

功能描述

AES 加速器

| AES_ENDIAN_REG[1] | AES_ENDIAN_REG[0] | Bit     | w[0]                 | w[1]                 | w[2]                 | w[3]                 |
|-------------------|-------------------|---------|----------------------|----------------------|----------------------|----------------------|
|                   |                   | [31:24] | AES_KEY_3_REG[31:24] | AES_KEY_2_REG[31:24] | AES_KEY_1_REG[31:24] | AES_KEY_0_REG[31:24] |
| 0                 | 0                 | [23:16] | AES_KEY_3_REG[23:16] | AES_KEY_2_REG[23:16] | AES_KEY_1_REG[23:16] | AES_KEY_0_REG[23:16] |
| 0                 |                   | [15:8]  | AES_KEY_3_REG[15:8]  | AES_KEY_2_REG[15:8]  | AES_KEY_1_REG[15:8]  | AES_KEY_0_REG[15:8]  |
|                   |                   | [7:0]   | AES_KEY_3_REG[7:0]   | AES_KEY_2_REG[7:0]   | AES_KEY_1_REG[7:0]   | AES_KEY_0_REG[7:0]   |
|                   |                   | [31:24] | AES_KEY_3_REG[7:0]   | AES_KEY_2_REG[7:0]   | AES_KEY_1_REG[7:0]   | AES_KEY_0_REG[7:0]   |
| 0                 | ,                 | [23:16] | AES_KEY_3_REG[15:8]  | AES_KEY_2_REG[15:8]  | AES_KEY_1_REG[15:8]  | AES_KEY_0_REG[15:8]  |
| 0                 | '                 | [15:8]  | AES_KEY_3_REG[23:16] | AES_KEY_2_REG[23:16] | AES_KEY_1_REG[23:16] | AES_KEY_0_REG[23:16] |
|                   |                   | [7:0]   | AES_KEY_3_REG[31:24] | AES_KEY_2_REG[31:24] | AES_KEY_1_REG[31:24] | AES_KEY_0_REG[31:24] |
|                   |                   | [31:24] | AES_KEY_0_REG[31:24] | AES_KEY_1_REG[31:24] | AES_KEY_2_REG[31:24] | AES_KEY_3_REG[31:24] |
| 1                 | 0                 | [23:16] | AES_KEY_0_REG[23:16] | AES_KEY_1_REG[23:16] | AES_KEY_2_REG[23:16] | AES_KEY_3_REG[23:16] |
| i i               |                   | [15:8]  | AES_KEY_0_REG[15:8]  | AES_KEY_1_REG[15:8]  | AES_KEY_2_REG[15:8]  | AES_KEY_3_REG[15:8]  |
|                   |                   | [7:0]   | AES_KEY_0_REG[7:0]   | AES_KEY_1_REG[7:0]   | AES_KEY_2_REG[7:0]   | AES_KEY_3_REG[7:0]   |
|                   |                   | [31:24] | AES_KEY_0_REG[7:0]   | AES_KEY_1_REG[7:0]   | AES_KEY_2_REG[7:0]   | AES_KEY_3_REG[7:0]   |
| 1                 | ,                 | [23:16] | AES_KEY_0_REG[15:8]  | AES_KEY_1_REG[15:8]  | AES_KEY_2_REG[15:8]  | AES_KEY_3_REG[15:8]  |
| '                 | '                 | [15:8]  | AES_KEY_0_REG[23:16] | AES_KEY_1_REG[23:16] | AES_KEY_2_REG[23:16] | AES_KEY_3_REG[23:16] |
|                   |                   | [7:0]   | AES_KEY_0_REG[31:24] | AES_KEY_1_REG[31:24] | AES_KEY_2_REG[31:24] | AES_KEY_3_REG[31:24] |

# 表 31: AES-192 密钥字节序

| AES_ENDIAN_REG[1] | AES_ENDIAN_REG[0] | Bit     | w[0]                 | w[1]                 | w[2]                 | w[3]                 | w[4]                 | w[5]                 |
|-------------------|-------------------|---------|----------------------|----------------------|----------------------|----------------------|----------------------|----------------------|
|                   |                   | [31:24] | AES_KEY_5_REG[31:24] | AES_KEY_4_REG[31:24] | AES_KEY_3_REG[31:24] | AES_KEY_2_REG[31:24] | AES_KEY_1_REG[31:24] | AES_KEY_0_REG[31:24] |
| 0                 | 0                 | [23:16] | AES_KEY_5_REG[23:16] | AES_KEY_4_REG[23:16] | AES_KEY_3_REG[23:16] | AES_KEY_2_REG[23:16] | AES_KEY_1_REG[23:16] | AES_KEY_0_REG[23:16] |
| "                 | 0                 | [15:8]  | AES_KEY_5_REG[15:8]  | AES_KEY_4_REG[15:8]  | AES_KEY_3_REG[15:8]  | AES_KEY_2_REG[15:8]  | AES_KEY_1_REG[15:8]  | AES_KEY_0_REG[15:8]  |
|                   |                   | [7:0]   | AES_KEY_5_REG[7:0]   | AES_KEY_4_REG[7:0]   | AES_KEY_3_REG[7:0]   | AES_KEY_2_REG[7:0]   | AES_KEY_1_REG[7:0]   | AES_KEY_0_REG[7:0]   |
|                   |                   | [31:24] | AES_KEY_5_REG[7:0]   | AES_KEY_4_REG[7:0]   | AES_KEY_3_REG[7:0]   | AES_KEY_2_REG[7:0]   | AES_KEY_1_REG[7:0]   | AES_KEY_0_REG[7:0]   |
| 0                 |                   | [23:16] | AES_KEY_5_REG[15:8]  | AES_KEY_4_REG[15:8]  | AES_KEY_3_REG[15:8]  | AES_KEY_2_REG[15:8]  | AES_KEY_1_REG[15:8]  | AES_KEY_0_REG[15:8]  |
| "                 | '                 | [15:8]  | AES_KEY_5_REG[23:16] | AES_KEY_4_REG[23:16] | AES_KEY_3_REG[23:16] | AES_KEY_2_REG[23:16] | AES_KEY_1_REG[23:16] | AES_KEY_0_REG[23:16] |
|                   |                   | [7:0]   | AES_KEY_5_REG[31:24] | AES_KEY_4_REG[31:24] | AES_KEY_3_REG[31:24] | AES_KEY_2_REG[31:24] | AES_KEY_1_REG[31:24] | AES_KEY_0_REG[31:24] |
|                   |                   | [31:24] | AES_KEY_0_REG[31:24] | AES_KEY_1_REG[31:24] | AES_KEY_2_REG[31:24] | AES_KEY_3_REG[31:24] | AES_KEY_4_REG[31:24] | AES_KEY_5_REG[31:24] |
|                   | 0                 | [23:16] | AES_KEY_0_REG[23:16] | AES_KEY_1_REG[23:16] | AES_KEY_2_REG[23:16] | AES_KEY_3_REG[23:16] | AES_KEY_4_REG[23:16] | AES_KEY_5_REG[23:16] |
| '                 | 0                 | [15:8]  | AES_KEY_0_REG[15:8]  | AES_KEY_1_REG[15:8]  | AES_KEY_2_REG[15:8]  | AES_KEY_3_REG[15:8]  | AES_KEY_4_REG[15:8]  | AES_KEY_5_REG[15:8]  |
|                   |                   | [7:0]   | AES_KEY_0_REG[7:0]   | AES_KEY_1_REG[7:0]   | AES_KEY_2_REG[7:0]   | AES_KEY_3_REG[7:0]   | AES_KEY_4_REG[7:0]   | AES_KEY_5_REG[7:0]   |
|                   |                   | [31:24] | AES_KEY_0_REG[7:0]   | AES_KEY_1_REG[7:0]   | AES_KEY_2_REG[7:0]   | AES_KEY_3_REG[7:0]   | AES_KEY_4_REG[7:0]   | AES_KEY_5_REG[7:0]   |
|                   | 1                 | [23:16] | AES_KEY_0_REG[15:8]  | AES_KEY_1_REG[15:8]  | AES_KEY_2_REG[15:8]  | AES_KEY_3_REG[15:8]  | AES_KEY_4_REG[15:8]  | AES_KEY_5_REG[15:8]  |
| '                 | '                 | [15:8]  | AES_KEY_0_REG[23:16] | AES_KEY_1_REG[23:16] | AES_KEY_2_REG[23:16] | AES_KEY_3_REG[23:16] | AES_KEY_4_REG[23:16] | AES_KEY_5_REG[23:16] |
|                   |                   | [7:0]   | AES_KEY_0_REG[31:24] | AES_KEY_1_REG[31:24] | AES_KEY_2_REG[31:24] | AES_KEY_3_REG[31:24] | AES_KEY_4_REG[31:24] | AES_KEY_5_REG[31:24] |

## 表 32: AES-256 密钥字节序

| AES_ENDIAN_REG[1] | AES_ENDIAN_REG[0] | Bit     | w[0]                 | w[1]                 | w[2]                 | w[3]                 | w[4]                 | w[5]                 | w[6]                 | w[7]                 |
|-------------------|-------------------|---------|----------------------|----------------------|----------------------|----------------------|----------------------|----------------------|----------------------|----------------------|
|                   |                   | [31:24] | AES_KEY_7_REG[31:24] | AES_KEY_6_REG[31:24] | AES_KEY_5_REG[31:24] | AES_KEY_4_REG[31:24] | AES_KEY_3_REG[31:24] | AES_KEY_2_REG[31:24] | AES_KEY_1_REG[31:24] | AES_KEY_0_REG[31:24] |
| _                 |                   | [23:16] | AES_KEY_7_REG[23:16] | AES_KEY_6_REG[23:16] | AES_KEY_5_REG[23:16] | AES_KEY_4_REG[23:16] | AES_KEY_3_REG[23:16] | AES_KEY_2_REG[23:16] | AES_KEY_1_REG[23:16] | AES_KEY_0_REG[23:16] |
| 0                 |                   | [15:8]  | AES_KEY_7_REG[15:8]  | AES_KEY_6_REG[15:8]  | AES_KEY_5_REG[15:8]  | AES_KEY_4_REG[15:8]  | AES_KEY_3_REG[15:8]  | AES_KEY_2_REG[15:8]  | AES_KEY_1_REG[15:8]  | AES_KEY_0_REG[15:8]  |
|                   |                   | [7:0]   | AES_KEY_7_REG[7:0]   | AES_KEY_6_REG[7:0]   | AES_KEY_5_REG[7:0]   | AES_KEY_4_REG[7:0]   | AES_KEY_3_REG[7:0]   | AES_KEY_2_REG[7:0]   | AES_KEY_1_REG[7:0]   | AES_KEY_0_REG[7:0]   |
|                   |                   | [31:24] | AES_KEY_7_REG[7:0]   | AES_KEY_6_REG[7:0]   | AES_KEY_5_REG[7:0]   | AES_KEY_4_REG[7:0]   | AES_KEY_3_REG[7:0]   | AES_KEY_2_REG[7:0]   | AES_KEY_1_REG[7:0]   | AES_KEY_0_REG[7:0]   |
|                   | 1                 | [23:16] | AES_KEY_7_REG[15:8]  | AES_KEY_6_REG[15:8]  | AES_KEY_5_REG[15:8]  | AES_KEY_4_REG[15:8]  | AES_KEY_3_REG[15:8]  | AES_KEY_2_REG[15:8]  | AES_KEY_1_REG[15:8]  | AES_KEY_0_REG[15:8]  |
| 0                 | '                 | [15:8]  | AES_KEY_7_REG[23:16] | AES_KEY_6_REG[23:16] | AES_KEY_5_REG[23:16] | AES_KEY_4_REG[23:16] | AES_KEY_3_REG[23:16] | AES_KEY_2_REG[23:16] | AES_KEY_1_REG[23:16] | AES_KEY_0_REG[23:16] |
|                   |                   | [7:0]   | AES_KEY_7_REG[31:24] | AES_KEY_6_REG[31:24] | AES_KEY_5_REG[31:24] | AES_KEY_4_REG[31:24] | AES_KEY_3_REG[31:24] | AES_KEY_2_REG[31:24] | AES_KEY_1_REG[31:24] | AES_KEY_0_REG[31:24] |
|                   |                   | [31:24] | AES_KEY_0_REG[31:24] | AES_KEY_1_REG[31:24] | AES_KEY_2_REG[31:24] | AES_KEY_3_REG[31:24] | AES_KEY_4_REG[31:24] | AES_KEY_5_REG[31:24] | AES_KEY_6_REG[31:24] | AES_KEY_7_REG[31:24] |
| 4                 |                   | [23:16] | AES_KEY_0_REG[23:16] | AES_KEY_1_REG[23:16] | AES_KEY_2_REG[23:16] | AES_KEY_3_REG[23:16] | AES_KEY_4_REG[23:16] | AES_KEY_5_REG[23:16] | AES_KEY_6_REG[23:16] | AES_KEY_7_REG[23:16] |
| '                 |                   | [15:8]  | AES_KEY_0_REG[15:8]  | AES_KEY_1_REG[15:8]  | AES_KEY_2_REG[15:8]  | AES_KEY_3_REG[15:8]  | AES_KEY_4_REG[15:8]  | AES_KEY_5_REG[15:8]  | AES_KEY_6_REG[15:8]  | AES_KEY_7_REG[15:8]  |
|                   |                   | [7:0]   | AES_KEY_0_REG[7:0]   | AES_KEY_1_REG[7:0]   | AES_KEY_2_REG[7:0]   | AES_KEY_3_REG[7:0]   | AES_KEY_4_REG[7:0]   | AES_KEY_5_REG[7:0]   | AES_KEY_6_REG[7:0]   | AES_KEY_7_REG[7:0]   |
|                   |                   | [31:24] | AES_KEY_0_REG[7:0]   | AES_KEY_1_REG[7:0]   | AES_KEY_2_REG[7:0]   | AES_KEY_3_REG[7:0]   | AES_KEY_4_REG[7:0]   | AES_KEY_5_REG[7:0]   | AES_KEY_6_REG[7:0]   | AES_KEY_7_REG[7:0]   |
| 4                 | 1                 | [23:16] | AES_KEY_0_REG[15:8]  | AES_KEY_1_REG[15:8]  | AES_KEY_2_REG[15:8]  | AES_KEY_3_REG[15:8]  | AES_KEY_4_REG[15:8]  | AES_KEY_5_REG[15:8]  | AES_KEY_6_REG[15:8]  | AES_KEY_7_REG[15:8]  |
| !                 |                   | [15:8]  | AES_KEY_0_REG[23:16] | AES_KEY_1_REG[23:16] | AES_KEY_2_REG[23:16] | AES_KEY_3_REG[23:16] | AES_KEY_4_REG[23:16] | AES_KEY_5_REG[23:16] | AES_KEY_6_REG[23:16] | AES_KEY_7_REG[23:16] |
|                   |                   | [7:0]   | AES_KEY_0_REG[31:24] | AES_KEY_1_REG[31:24] | AES_KEY_2_REG[31:24] | AES_KEY_3_REG[31:24] | AES_KEY_4_REG[31:24] | AES_KEY_5_REG[31:24] | AES_KEY_6_REG[31:24] | AES_KEY_7_REG[31:24] |

11.4 寄存器列表 11 AES 加速器

# 11.3.4 加密与解密运算

#### 单次运算

- 1. 初始化寄存器 AES\_MODE\_REG、AES\_KEY\_n\_REG、AES\_TEXT\_m\_REG、AES\_ENDIAN\_REG。
- 2. 对寄存器 AES\_START\_REG 写入 1。
- 3. 轮询寄存器 AES\_IDLE\_REG, 直到从寄存器 AES\_IDLE\_REG 读出 1。
- 4. 从寄存器 AES\_TEXT\_m\_REG 读取结果。

#### 连续运算

每次运算完成之后,只有寄存器 AES\_TEXT\_m\_REG 会被 AES 加速器更新,即寄存器 AES\_MODE\_REG、AES\_KEY\_n\_REG、AES\_ENDIAN\_REG 中的内容不会变化。所以进行连续运算时可以简化初始化操作。

- 1. 更新寄存器 AES\_MODE\_REG、AES\_KEY\_n\_REG、AES\_ENDIAN\_REG 中需要更新的,其余不做变动。
- 2. 更新寄存器 AES\_TEXT\_m\_REG。
- 3. 对寄存器 AES\_START\_REG 写入 1。
- 4. 轮询寄存器 AES\_IDLE\_REG, 直到从寄存器 AES\_IDLE\_REG 读出 1。
- 5. 从寄存器 AES\_TEXT\_m\_REG 读取结果。

## 11.3.5 运行效率

AES 每加密一个信息块需要 11~15个时钟周期,每解密一个信息块需要 21 或 22个时钟周期。

# 11.4 寄存器列表

| 名称             | 描述                                      | 地址         | 访问    |
|----------------|-----------------------------------------|------------|-------|
| 配置寄存器          |                                         |            |       |
| AES_MODE_REG   | Operation mode of the AES Accelerator   | 0x3FF01008 | 读/写   |
| AES_ENDIAN_REG | Endian-ness configuration register      | 0x3FF01040 | 读/写   |
| 密钥寄存器          |                                         |            |       |
| AES_KEY_0_REG  | AES key material register 0             | 0x3FF01010 | 读/写   |
| AES_KEY_1_REG  | AES key material register 1             | 0x3FF01014 | 读/写   |
| AES_KEY_2_REG  | AES key material register 2             | 0x3FF01018 | 读/写   |
| AES_KEY_3_REG  | AES key material register 3             | 0x3FF0101C | 读/写   |
| AES_KEY_4_REG  | AES key material register 4             | 0x3FF01020 | 读/写   |
| AES_KEY_5_REG  | AES key material register 5             | 0x3FF01024 | 读 / 写 |
| AES_KEY_6_REG  | AES key material register 6             | 0x3FF01028 | 读 / 写 |
| AES_KEY_7_REG  | AES key material register 7             | 0x3FF0102C | 读/写   |
| 加密 / 解密数据寄存器   |                                         |            |       |
| AES_TEXT_0_REG | AES encrypted/decrypted data register 0 | 0x3FF01030 | 读/写   |
| AES_TEXT_1_REG | AES encrypted/decrypted data register 1 | 0x3FF01034 | 读 / 写 |
| AES_TEXT_2_REG | AES encrypted/decrypted data register 2 | 0x3FF01038 | 读 / 写 |
| AES_TEXT_3_REG | AES encrypted/decrypted data register 3 | 0x3FF0103C | 读 / 写 |

11.4 寄存器列表 11 AES 加速器

| 名称            | 描述                                   | 地址         | 访问 |
|---------------|--------------------------------------|------------|----|
| 控制 / 状态寄存器    |                                      |            |    |
| AES_START_REG | AES operation start control register | 0x3FF01000 | 只写 |
| AES_IDLE_REG  | AES idle status register             | 0x3FF01004 | 只读 |

11.5 寄存器 11 AES 加速器

## 11.5 寄存器

Register 11.1: AES\_START\_REG (0x000)



AES\_START 写入 1 使能 AES 运算。(只写)

Register 11.2: AES\_IDLE\_REG (0x004)



AES\_IDLE AES 空闲寄存器。AES 加速器运行时读出 0, 空闲时读出 1。(只读)

Register 11.3: AES\_MODE\_REG (0x008)



**AES\_MODE** 选择 AES 加速器运算模式。详情请见表 28。(读 / 写)

Register 11.4: AES\_KEY\_n\_REG (n: 0-7) (0x10+4\*n)



**AES\_KEY\_n\_REG (n: 0-7)** AES 密钥寄存器。(读 / 写)

Register 11.5: AES\_TEXT\_m\_REG (m: 0-3) (0x30+4\*m)



**AES\_TEXT\_m\_REG (m: 0-3)** 明文和密文寄存器。(读 / 写)

 11.5 寄存器
 11 AES 加速器

Register 11.6: AES\_ENDIAN\_REG (0x040)



AES\_ENDIAN 字节序选择寄存器。详情请见表 29。(读 / 写)

# 12. SHA 加速器

## 12.1 概述

相比于在软件中单独运行 SHA (安全哈希算法), SHA 加速器能够快速提升 SHA 的运行速度。SHA 加速器支持四种标准 FIPS PUB 180-4 运算: SHA-1、SHA-256、SHA-384 和 SHA-512。

## 12.2 特性

- 支持 SHA-1 运算
- 支持 SHA-256 运算
- 支持 SHA-384 运算
- 支持 SHA-512 运算

## 12.3 功能描述

## 12.3.1 填充解析信息

SHA 加速器每次只能接受一个信息块。软件将整个信息按照标准"FIPS PUB 180-4"中"5.2 Parsing the Message"的要求划分为一个一个的信息块,每次只将一个信息块写入寄存器 SHA\_TEXT\_n\_REG。如果是 SHA-1、SHA-256 运算,则软件每次将 512 bit 的块写入寄存器 SHA\_TEXT\_0\_REG ~ SHA\_TEXT\_15\_REG。如果是 SHA-384、SHA-512 运算,则软件每次将 1024 bit 的块写入寄存器 SHA\_TEXT\_0\_REG ~ SHA\_TEXT\_31\_REG。

SHA 加速器不能自动完成标准 "FIPS PUB 180-4"中 "5.1 Padding the Message"所要求的填充操作;在将信息输入到加速器之前,需由软件来完成填充操作。

标准 "FIPS PUB 180-4" 中 "2.2.1 Parameters" 描述 " $M_0^{(i)}$  is the left-most word of message block i",此 word 存放在寄存器 SHA\_TEXT\_0\_REG 中。以此类推寄存器 SHA\_TEXT\_1\_REG 中存放的是信息中某个块从左向右的第二个 word……

#### 12.3.2 信息摘要

哈希运算完成之后,信息摘要被 SHA 加速器更新入寄存器 SHA\_TEXT\_*n*\_REG。如果是 SHA-1 运算,则 160 bit 信息摘要存放在寄存器 SHA\_TEXT\_0\_REG ~ SHA\_TEXT\_4\_REG。如果是 SHA-256 运算,则 256 bit 信息摘要存放在寄存器 SHA\_TEXT\_0\_REG ~ SHA\_TEXT\_7\_REG。如果是 SHA-384 运算,则 384 bit 信息摘要存放在寄存器 SHA\_TEXT\_0\_REG ~ SHA\_TEXT\_11\_REG。如果是 SHA-512 运算,则 512 bit 信息摘要存放在寄存器 SHA\_TEXT\_0\_REG ~ SHA\_TEXT\_15\_REG。

标准 "FIPS PUB 180-4" 中 "2.2.1 Parameters" 描述 " $H^{(N)}$  is the final hash value and is used to determine the message digest"、" $H_0^{(i)}$  is the left-most word of hash value i"。则信息摘要中最左边 word  $H_0^{(N)}$  在寄存器 SHA\_TEXT\_0\_REG 中。以此类推信息摘要中从左至右的第二个 word  $H_1^{(N)}$  在寄存器 SHA\_TEXT\_1\_REG 中

12.4 寄存器列表 12 SHA 加速器

#### 12.3.3 哈希运算

运算 SHA-1、SHA-256、SHA-384 和 SHA-512 各有一组控制寄存器;不同的哈希运算使用不同的控制寄存器。运算 SHA-1 使用寄存器 SHA\_SHA1\_START\_REG、SHA\_SHA1\_CONTINUE\_REG、SHA\_SHA1\_LOAD\_REG 和 SHA\_SHA1\_BUSY\_REG。运算 SHA-256 使用寄存器 SHA\_SHA256\_START\_REG、SHA\_SHA256\_CONTINUE\_REG、SHA\_SHA256\_LOAD\_REG 和 SHA\_SHA256\_BUSY\_REG。运算 SHA-384 使用寄存器 SHA\_SHA384\_START\_REG、SHA\_SHA384\_CONTINUE\_REG、SHA\_SHA384\_LOAD\_REG 和 SHA\_SHA384\_BUSY\_REG。运算 SHA-512 使用寄存器 SHA\_SHA512\_START\_REG、SHA\_SHA512\_CONTINUE\_REG、SHA\_SHA512\_LOAD\_REG 和 SHA\_SHA512\_BUSY\_REG。具体操作流程如下。

#### 1. 操作第一个信息块

- (a) 用第一个信息块初始化寄存器 SHA\_TEXT\_n\_REG。
- (b) 对寄存器 SHA\_X\_START\_REG 写入 1。
- (c) 轮询寄存器 SHA\_X\_BUSY\_REG, 直到从寄存器 SHA\_X\_BUSY\_REG 读出 0。
- 2. 循环操作信息的后续每一个块
  - (a) 用后续的信息块初始化寄存器 SHA\_TEXT\_n\_REG。
  - (b) 对寄存器 SHA\_X\_CONTINUE\_REG 写入 1。
  - (c) 轮询寄存器 SHA\_X\_BUSY\_REG, 直到从寄存器 SHA\_X\_BUSY\_REG 读出 0。

#### 3. 获取信息摘要

- (a) 对寄存器 SHA\_X\_LOAD\_REG 写入 1。
- (b) 轮询寄存器 SHA\_X\_BUSY\_REG, 直到从寄存器 SHA\_X\_BUSY\_REG 读出 0。
- (c) 从寄存器 SHA\_TEXT\_n\_REG 取出信息摘要。

## 12.3.4 运行效率

SHA加速器需要60至100个时钟周期来处理一个信息块以及8至20个时钟周期来计算最后的信息摘要。

# 12.4 寄存器列表

| 名称             | 描述                                      | 地址         | 访问    |
|----------------|-----------------------------------------|------------|-------|
| 加密 / 解密数据寄存器   |                                         |            |       |
| SHA_TEXT_0_REG | SHA encrypted/decrypted data register 0 | 0x3FF03000 | 读/写   |
| SHA_TEXT_1_REG | SHA encrypted/decrypted data register 1 | 0x3FF03004 | 读 / 写 |
| SHA_TEXT_2_REG | SHA encrypted/decrypted data register 2 | 0x3FF03008 | 读/写   |
| SHA_TEXT_3_REG | SHA encrypted/decrypted data register 3 | 0x3FF0300C | 读 / 写 |
| SHA_TEXT_4_REG | SHA encrypted/decrypted data register 4 | 0x3FF03010 | 读/写   |
| SHA_TEXT_5_REG | SHA encrypted/decrypted data register 5 | 0x3FF03014 | 读 / 写 |
| SHA_TEXT_6_REG | SHA encrypted/decrypted data register 6 | 0x3FF03018 | 读/写   |
| SHA_TEXT_7_REG | SHA encrypted/decrypted data register 7 | 0x3FF0301C | 读 / 写 |
| SHA_TEXT_8_REG | SHA encrypted/decrypted data register 8 | 0x3FF03020 | 读/写   |

 12.4 寄存器列表
 12 SHA 加速器

| SHA_TEXT_10_REG SHA encrypted/decrypted data register 10 0x3FF03024 读/写 SHA_TEXT_10_REG SHA encrypted/decrypted data register 11 0x3FF03026 读/写 SHA_TEXT_112_REG SHA encrypted/decrypted data register 12 0x3FF03026 读/写 SHA_TEXT_112_REG SHA encrypted/decrypted data register 12 0x3FF03030 读/写 SHA_TEXT_113_REG SHA encrypted/decrypted data register 13 0x3FF03030 读/写 SHA_TEXT_114_REG SHA encrypted/decrypted data register 14 0x3FF03030 读/写 SHA_TEXT_115_REG SHA encrypted/decrypted data register 15 0x3FF03030 读/写 SHA_TEXT_16_REG SHA encrypted/decrypted data register 16 0x3FF03040 读/写 SHA_TEXT_16_REG SHA encrypted/decrypted data register 17 0x3FF03040 读/写 SHA_TEXT_16_REG SHA encrypted/decrypted data register 17 0x3FF03040 读/写 SHA_TEXT_17_REG SHA encrypted/decrypted data register 18 0x3FF03040 读/写 SHA_TEXT_19_REG SHA encrypted/decrypted data register 19 0x3FF03040 读/写 SHA_TEXT_19_REG SHA encrypted/decrypted data register 19 0x3FF03040 读/写 SHA_TEXT_20_REG SHA encrypted/decrypted data register 20 0x3FF03050 读/写 SHA_TEXT_21_REG SHA encrypted/decrypted data register 21 0x3FF03050 读/写 SHA_TEXT_21_REG SHA encrypted/decrypted data register 21 0x3FF03050 读/写 SHA_TEXT_23_REG SHA encrypted/decrypted data register 22 0x3FF03050 读/写 SHA_TEXT_24_REG SHA encrypted/decrypted data register 23 0x3FF03050 读/写 SHA_TEXT_25_REG SHA encrypted/decrypted data register 24 0x3FF03050 读/写 SHA_TEXT_25_REG SHA encrypted/decrypted data register 25 0x3FF03050 读/写 SHA_TEXT_26_REG SHA encrypted/decrypted data register 25 0x3FF03050 读/写 SHA_TEXT_26_REG SHA encrypted/decrypted data register 26 0x3FF03060 读/写 SHA_TEXT_27_REG SHA encrypted/decrypted data register 26 0x3FF03060 读/写 SHA_TEXT_29_REG SHA encrypted/decrypted data register 27 0x3FF03060 读/写 SHA_TEXT_29_REG SHA encrypted/decrypted data register 27 0x3FF03060 读/写 SHA_TEXT_29_REG SHA encrypted/decrypted data register 29 0x3FF03070 读/写 SHA_TEXT_29_REG SHA encrypted/decrypted data register 29 0x3FF03070 读/写 SHA_TEXT_29_REG SHA encrypted/decrypted data register 29 0x3FF03090 j/g/SHA_TEXT_29_REG SHA encr | 名称                      | 描述                                                | 地址         | 访问    |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|---------------------------------------------------|------------|-------|--|--|
| SHA_TEXT_12_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | SHA_TEXT_9_REG          | SHA encrypted/decrypted data register 9           | 0x3FF03024 | 读 / 写 |  |  |
| SHA_TEXT_12_REG SHA encrypted/decrypted data register 12 0x3FF03030 读/写 SHA_TEXT_13_REG SHA encrypted/decrypted data register 13 0x3FF03034 读/写 SHA_TEXT_14_REG SHA encrypted/decrypted data register 14 0x3FF03038 读/写 SHA_TEXT_14_REG SHA encrypted/decrypted data register 15 0x3FF03038 读/写 SHA_TEXT_15_REG SHA encrypted/decrypted data register 16 0x3FF03030 读/写 SHA_TEXT_17_REG SHA encrypted/decrypted data register 17 0x3FF03044 读/写 SHA_TEXT_18_REG SHA encrypted/decrypted data register 18 0x3FF03044 读/写 SHA_TEXT_19_REG SHA encrypted/decrypted data register 18 0x3FF03046 读/写 SHA_TEXT_19_REG SHA encrypted/decrypted data register 19 0x3FF03046 读/写 SHA_TEXT_29_REG SHA encrypted/decrypted data register 20 0x3FF03050 读/写 SHA_TEXT_29_REG SHA encrypted/decrypted data register 21 0x3FF03056 读/写 SHA_TEXT_29_REG SHA encrypted/decrypted data register 22 0x3FF03056 读/写 SHA_TEXT_29_REG SHA encrypted/decrypted data register 23 0x3FF03056 读/写 SHA_TEXT_28_REG SHA encrypted/decrypted data register 23 0x3FF03056 读/写 SHA_TEXT_28_REG SHA encrypted/decrypted data register 24 0x3FF03056 读/写 SHA_TEXT_28_REG SHA encrypted/decrypted data register 25 0x3FF03066 读/写 SHA_TEXT_25_REG SHA encrypted/decrypted data register 26 0x3FF03066 读/写 SHA_TEXT_25_REG SHA encrypted/decrypted data register 27 0x3FF03066 读/写 SHA_TEXT_28_REG SHA encrypted/decrypted data register 27 0x3FF03066 读/写 SHA_TEXT_28_REG SHA encrypted/decrypted data register 27 0x3FF03067 读/写 SHA_TEXT_28_REG SHA encrypted/decrypted data register 28 0x3FF03076 读/写 SHA_TEXT_28_REG SHA encrypted/decrypted data register 29 0x3FF03076 读/写 SHA_TEXT_28_REG SHA encrypted/decrypted data register 29 0x3FF03077 读/写 SHA_TEXT_28_REG SHA encrypted/decrypted data register 30 0x3FF03078 读/写 SHA_TEXT_30_REG SHA encrypted/decrypted data register 30 0x3FF03079 j/g/SHA_TEXT_31_REG SHA encrypted/decrypted data register 30 0x3FF03079 j/g/SHA_TEXT_31_REG SHA encrypted/decrypted data register 30 0x3FF03080 j/g/SHA_TEXT_31_REG SHA_SHA_SHA_SHA_SHA_SHA_SHA_SHA_SHA_SHA_                                              | SHA_TEXT_10_REG         | SHA encrypted/decrypted data register 10          | 0x3FF03028 | 读 / 写 |  |  |
| SHA_TEXT_13_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | SHA_TEXT_11_REG         | SHA encrypted/decrypted data register 11          | 0x3FF0302C | 读 / 写 |  |  |
| SHA_TEXT_14_REG SHA encrypted/decrypted data register 14 0x3FF03038 读/写 SHA_TEXT_15_REG SHA encrypted/decrypted data register 15 0x3FF0303C 读/写 SHA_TEXT_16_REG SHA encrypted/decrypted data register 16 0x3FF03040 读/写 SHA_TEXT_16_REG SHA encrypted/decrypted data register 16 0x3FF03040 读/写 SHA_TEXT_18_REG SHA encrypted/decrypted data register 18 0x3FF03048 读/写 SHA_TEXT_19_REG SHA encrypted/decrypted data register 19 0x3FF03040 读/写 SHA_TEXT_20_REG SHA encrypted/decrypted data register 20 0x3FF03050 读/写 SHA_TEXT_20_REG SHA encrypted/decrypted data register 20 0x3FF03050 读/写 SHA_TEXT_21_REG SHA encrypted/decrypted data register 21 0x3FF03050 读/写 SHA_TEXT_21_REG SHA encrypted/decrypted data register 22 0x3FF03056 读/写 SHA_TEXT_23_REG SHA encrypted/decrypted data register 23 0x3FF03056 读/写 SHA_TEXT_24_REG SHA encrypted/decrypted data register 23 0x3FF03050 读/写 SHA_TEXT_24_REG SHA encrypted/decrypted data register 24 0x3FF03060 读/写 SHA_TEXT_24_REG SHA encrypted/decrypted data register 25 0x3FF03060 读/写 SHA_TEXT_25_REG SHA encrypted/decrypted data register 26 0x3FF03060 读/写 SHA_TEXT_27_REG SHA encrypted/decrypted data register 27 0x3FF03060 读/写 SHA_TEXT_28_REG SHA encrypted/decrypted data register 29 0x3FF03070 读/写 SHA_TEXT_29_REG SHA encrypted/decrypted data register 29 0x3FF03070 读/写 SHA_TEXT_29_REG SHA encrypted/decrypted data register 29 0x3FF03070 读/写 SHA_TEXT_30_REG SHA encrypted/decrypted data register 29 0x3FF03070 读/写 SHA_TEXT_31_REG SHA encrypted/decrypted data register 30 0x3FF03070 读/写 SHA_TEXT_31_REG SHA encrypted/decrypted data register 30 0x3FF03070 读/写 SHA_SHA1_START_REG Control register to calculate the final SHA5 has 0x3FF03080 具写 SHA_SHA1_START_REG Control register to calculate the final SHA5 has 0x3FF03004 具写 SHA_SHA256_CONTINUE_REG Control register to calculate the final SHA256 operation 0x3FF03004 具写 SHA_SHA256_LOAD_REG SHA_SHA256_DOATHOUS_REG Control register to calculate the final SHA256 operation 0x3FF03004 具写 SHA_SHA384_LOAD_REG Control register to initiate SHA384 operation 0x3FF03004 具写 SHA_SHA | SHA_TEXT_12_REG         | SHA encrypted/decrypted data register 12          | 0x3FF03030 | 读/写   |  |  |
| SHA_TEXT_15_REG SHA encrypted/decrypted data register 15 0x3FF0303C 读/写 SHA_TEXT_17_REG SHA encrypted/decrypted data register 16 0x3FF03040 读/写 SHA_TEXT_17_REG SHA encrypted/decrypted data register 17 0x3FF03044 读/写 SHA_TEXT_17_REG SHA encrypted/decrypted data register 18 0x3FF03048 读/写 SHA_TEXT_19_REG SHA encrypted/decrypted data register 19 0x3FF03040 读/写 SHA_TEXT_19_REG SHA encrypted/decrypted data register 19 0x3FF03040 读/写 SHA_TEXT_20_REG SHA encrypted/decrypted data register 20 0x3FF03050 读/写 SHA_TEXT_21_REG SHA encrypted/decrypted data register 21 0x3FF03054 读/写 SHA_TEXT_21_REG SHA encrypted/decrypted data register 22 0x3FF03056 读/写 SHA_TEXT_22_REG SHA encrypted/decrypted data register 23 0x3FF03056 读/写 SHA_TEXT_24_REG SHA encrypted/decrypted data register 23 0x3FF03056 读/写 SHA_TEXT_24_REG SHA encrypted/decrypted data register 24 0x3FF03056 读/写 SHA_TEXT_25_REG SHA encrypted/decrypted data register 25 0x3FF03056 读/写 SHA_TEXT_26_REG SHA encrypted/decrypted data register 25 0x3FF03056 读/写 SHA_TEXT_26_REG SHA encrypted/decrypted data register 27 0x3FF03066 读/写 SHA_TEXT_29_REG SHA encrypted/decrypted data register 27 0x3FF03070 读/写 SHA_TEXT_29_REG SHA encrypted/decrypted data register 28 0x3FF03070 读/写 SHA_TEXT_29_REG SHA encrypted/decrypted data register 29 0x3FF03070 读/写 SHA_TEXT_29_REG SHA encrypted/decrypted data register 29 0x3FF03070 读/写 SHA_TEXT_31_REG SHA encrypted/decrypted data register 30 0x3FF03070 读/写 SHA_SHA1_START_REG SHA encrypted/decrypted data register 30 0x3FF03070 读/写 SHA_SHA1_START_REG SHA encrypted/decrypted data register 30 0x3FF03070 读/写 SHA_SHA1_START_REG SHA encrypted/decrypted data register 30 0x3FF03070 读/写 SHA_SHA1_LOAD_REG Control register to continue SHA1 operation 0x3FF03084 具写 SHA_SHA256_CONTINUE_REG Control register to continue SHA1 operation 0x3FF03080 具写 SHA_SHA256_LOAD_REG Control register to continue SHA256 operation 0x3FF03000 具写 SHA_SHA256_LOAD_REG Control register to continue SHA384 operation 0x3FF03000 具写 SHA_SHA384_LOAD_REG Control register to calculate the final SH | SHA_TEXT_13_REG         | SHA encrypted/decrypted data register 13          | 0x3FF03034 | 读 / 写 |  |  |
| SHA_TEXT_16_REG SHA encrypted/decrypted data register 16 0x3FF03040 读/写 SHA_TEXT_17_REG SHA encrypted/decrypted data register 17 0x3FF03044 读/写 SHA_TEXT_18_REG SHA encrypted/decrypted data register 18 0x3FF03046 读/写 SHA_TEXT_19_REG SHA encrypted/decrypted data register 19 0x3FF03046 读/写 SHA_TEXT_19_REG SHA encrypted/decrypted data register 19 0x3FF03046 读/写 SHA_TEXT_21_REG SHA encrypted/decrypted data register 20 0x3FF03056 读/写 SHA_TEXT_21_REG SHA encrypted/decrypted data register 21 0x3FF03056 读/写 SHA_TEXT_21_REG SHA encrypted/decrypted data register 22 0x3FF03058 读/写 SHA_TEXT_23_REG SHA encrypted/decrypted data register 23 0x3FF03056 读/写 SHA_TEXT_23_REG SHA encrypted/decrypted data register 23 0x3FF03066 读/写 SHA_TEXT_25_REG SHA encrypted/decrypted data register 24 0x3FF03066 读/写 SHA_TEXT_26_REG SHA encrypted/decrypted data register 25 0x3FF03066 读/写 SHA_TEXT_26_REG SHA encrypted/decrypted data register 26 0x3FF03066 读/写 SHA_TEXT_27_REG SHA encrypted/decrypted data register 27 0x3FF03066 读/写 SHA_TEXT_28_REG SHA encrypted/decrypted data register 27 0x3FF03066 读/写 SHA_TEXT_29_REG SHA encrypted/decrypted data register 29 0x3FF03074 读/写 SHA_TEXT_30_REG SHA encrypted/decrypted data register 29 0x3FF03076 读/写 SHA_TEXT_30_REG SHA encrypted/decrypted data register 30 0x3FF03076 读/写 SHA_TEXT_31_REG SHA encrypted/decrypted data register 30 0x3FF03076 读/写 SHA_SHA1_START_REG Control register to initiate SHA1 operation 0x3FF03080 具写 SHA_SHA1_LOAD_REG Control register to calculate the final SHA1 hash 0x3FF03080 具写 SHA_SHA1_LOAD_REG Control register to calculate the final SHA256 operation 0x3FF03080 具写 SHA_SHA256_BUSY_REG Status register for SHA256 operation 0x3FF03080 具写 SHA_SHA256_BUSY_REG Status register to initiate SHA384 operation 0x3FF03080 具写 SHA_SHA384_START_REG Control register to calculate the final SHA384 operation 0x3FF03080 具写 SHA_SHA384_CONTINUE_REG Control register to calculate the final SHA384 operation 0x3FF03080 具写 SHA_SHA384_DUSY_REG Status register for SHA256 operation 0x3FF03080 具写 SHA_SHA384_DUSY_REG S | SHA_TEXT_14_REG         | SHA encrypted/decrypted data register 14          | 0x3FF03038 | 读/写   |  |  |
| SHA_TEXT_17_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | SHA_TEXT_15_REG         | SHA encrypted/decrypted data register 15          | 0x3FF0303C | 读/写   |  |  |
| SHA_TEXT_18_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | SHA_TEXT_16_REG         | SHA encrypted/decrypted data register 16          | 0x3FF03040 | 读 / 写 |  |  |
| SHA_TEXT_19_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | SHA_TEXT_17_REG         | SHA encrypted/decrypted data register 17          | 0x3FF03044 | 读/写   |  |  |
| SHA_TEXT_20_REG SHA encrypted/decrypted data register 20 0x3FF03050 读/写 SHA_TEXT_21_REG SHA encrypted/decrypted data register 21 0x3FF03054 读/写 SHA_TEXT_22_REG SHA encrypted/decrypted data register 22 0x3FF03058 读/写 SHA_TEXT_23_REG SHA encrypted/decrypted data register 22 0x3FF0305C 读/写 SHA_TEXT_24_REG SHA encrypted/decrypted data register 23 0x3FF0306C 读/写 SHA_TEXT_24_REG SHA encrypted/decrypted data register 24 0x3FF0306C 读/写 SHA_TEXT_25_REG SHA encrypted/decrypted data register 25 0x3FF0306A 读/写 SHA_TEXT_26_REG SHA encrypted/decrypted data register 26 0x3FF0306A 读/写 SHA_TEXT_27_REG SHA encrypted/decrypted data register 27 0x3FF0306C 读/写 SHA_TEXT_28_REG SHA encrypted/decrypted data register 28 0x3FF03070 读/写 SHA_TEXT_29_REG SHA encrypted/decrypted data register 29 0x3FF03070 读/写 SHA_TEXT_29_REG SHA encrypted/decrypted data register 29 0x3FF03070 读/写 SHA_TEXT_30_REG SHA encrypted/decrypted data register 30 0x3FF03070 读/写 SHA_TEXT_31_REG SHA encrypted/decrypted data register 30 0x3FF03070 读/写 SHA_SHA1_START_REG SHA encrypted/decrypted data register 30 0x3FF03070 读/写 SHA_SHA1_CONTINUE_REG Control register to initiate SHA1 operation 0x3FF03080 只写 SHA_SHA1_START_REG Control register to continue SHA1 operation 0x3FF03080 只写 SHA_SHA1_BUSY_REG Status register for SHA1 operation 0x3FF03080 只写 SHA_SHA256_CONTINUE_REG Control register to calculate the final SHA1 hash 0x3FF03090 只写 SHA_SHA256_CONTINUE_REG Control register to continue SHA256 operation 0x3FF03090 只写 SHA_SHA256_BUSY_REG Status register for SHA256 operation 0x3FF03090 只写 SHA_SHA384_START_REG Control register to continue SHA384 operation 0x3FF03090 只写 SHA_SHA384_CONTINUE_REG Control register to continue SHA384 operation 0x3FF03090 只写 SHA_SHA384_LOAD_REG Control register to continue SHA384 operation 0x3FF03080 只写 SHA_SHA384_LOAD_REG Control register to continue SHA384 operation 0x3FF03080 只写 SHA_SHA384_LOAD_REG Control register to continue SHA512 operation 0x3FF030B0 只写 SHA_SHA384_LOAD_REG Control register to continue SHA512 operation 0x3FF030B0 只写 SHA_SHA512 | SHA_TEXT_18_REG         | SHA encrypted/decrypted data register 18          | 0x3FF03048 | 读 / 写 |  |  |
| SHA_TEXT_21_REG SHA encrypted/decrypted data register 21 0x3FF03054 读/写 SHA_TEXT_22_REG SHA encrypted/decrypted data register 22 0x3FF03058 读/写 SHA_TEXT_23_REG SHA encrypted/decrypted data register 23 0x3FF0305C 读/写 SHA_TEXT_24_REG SHA encrypted/decrypted data register 24 0x3FF03060 读/写 SHA_TEXT_25_REG SHA encrypted/decrypted data register 24 0x3FF03060 读/写 SHA_TEXT_25_REG SHA encrypted/decrypted data register 25 0x3FF03064 读/写 SHA_TEXT_26_REG SHA encrypted/decrypted data register 26 0x3FF03066 读/写 SHA_TEXT_27_REG SHA encrypted/decrypted data register 27 0x3FF0306C 读/写 SHA_TEXT_29_REG SHA encrypted/decrypted data register 28 0x3FF03070 读/写 SHA_TEXT_29_REG SHA encrypted/decrypted data register 29 0x3FF03070 读/写 SHA_TEXT_29_REG SHA encrypted/decrypted data register 29 0x3FF03070 读/写 SHA_TEXT_30_REG SHA encrypted/decrypted data register 30 0x3FF03070 读/写 SHA_TEXT_31_REG SHA encrypted/decrypted data register 30 0x3FF03070 读/写 SHA_SHA1_START_REG SHA encrypted/decrypted data register 30 0x3FF03070 读/写 SHA_SHA1_CONTINUE_REG Control register to initiate SHA1 operation 0x3FF03080 只写 SHA_SHA1_LOAD_REG Control register to calculate the final SHA1 hash 0x3FF03080 只写 SHA_SHA1_LOAD_REG Status register for SHA1 operation 0x3FF03080 只写 SHA_SHA256_START_REG Control register to calculate the final SHA256 operation 0x3FF03090 只写 SHA_SHA256_CONTINUE_REG Control register to calculate the final SHA256 operation 0x3FF03090 只写 SHA_SHA256_CONTINUE_REG Control register to calculate the final SHA256 operation 0x3FF03090 只写 SHA_SHA384_START_REG Control register to calculate the final SHA384 operation 0x3FF03000 只写 SHA_SHA384_START_REG Control register to calculate the final SHA384 operation 0x3FF03000 只写 SHA_SHA384_START_REG Control register to continue SHA384 operation 0x3FF03000 只写 SHA_SHA384_DAREG Status register for SHA384 operation 0x3FF03000 只写 SHA_SHA384_DAREG Control register to continue SHA384 operation 0x3FF03000 只写 SHA_SHA384_DAREG Status register for SHA384 operation 0x3FF03000 只写 SHA_SHA384_DAREG Control register to initiate | SHA_TEXT_19_REG         | SHA encrypted/decrypted data register 19          | 0x3FF0304C | 读/写   |  |  |
| SHA_TEXT_22_REG SHA encrypted/decrypted data register 22 0x3FF03058 读/写 SHA_TEXT_23_REG SHA encrypted/decrypted data register 23 0x3FF0305C 读/写 SHA_TEXT_24_REG SHA encrypted/decrypted data register 24 0x3FF03060 读/写 SHA_TEXT_25_REG SHA encrypted/decrypted data register 25 0x3FF03060 读/写 SHA_TEXT_25_REG SHA encrypted/decrypted data register 25 0x3FF03068 读/写 SHA_TEXT_26_REG SHA encrypted/decrypted data register 26 0x3FF03068 读/写 SHA_TEXT_27_REG SHA encrypted/decrypted data register 27 0x3FF0306C 读/写 SHA_TEXT_29_REG SHA encrypted/decrypted data register 28 0x3FF03070 读/写 SHA_TEXT_29_REG SHA encrypted/decrypted data register 29 0x3FF03070 读/写 SHA_TEXT_30_REG SHA encrypted/decrypted data register 30 0x3FF03070 读/写 SHA_TEXT_31_REG SHA encrypted/decrypted data register 30 0x3FF03070 读/写 SHA_TEXT_31_REG SHA encrypted/decrypted data register 30 0x3FF03070 读/写 SHA_TEXT_31_REG SHA encrypted/decrypted data register 30 0x3FF03070 读/写 SHA_SHA1_START_REG SHA encrypted/decrypted data register 31 0x3FF03080 只写 SHA_SHA1_START_REG SHA encrypted/decrypted data register 31 0x3FF03080 只写 SHA_SHA1_START_REG Control register to initiate SHA1 operation 0x3FF03080 只写 SHA_SHA1_LOAD_REG Control register to calculate the final SHA1 hash 0x3FF03080 只写 SHA_SHA1_BUSY_REG Status register for SHA1 operation 0x3FF03080 只写 SHA_SHA256_START_REG Control register to calculate the final SHA256 operation 0x3FF03090 只写 SHA_SHA256_CONTINUE_REG Control register to calculate the final SHA256 operation 0x3FF03090 只写 SHA_SHA384_START_REG Control register for SHA256 operation 0x3FF03000 只写 SHA_SHA384_CONTINUE_REG Control register to calculate the final SHA384 operation 0x3FF03000 只写 SHA_SHA384_LOAD_REG Status register for SHA256 operation 0x3FF03000 只写 SHA_SHA384_LOAD_REG Control register to continue SHA384 operation 0x3FF03000 只写 SHA_SHA384_LOAD_REG Status register for SHA384 operation 0x3FF03000 只写 SHA_SHA384_LOAD_REG Control register to continue SHA512 operation 0x3FF03000 只写 SHA_SHA384_LOAD_REG Status register for SHA384 operation 0x3FF03000 只写 SHA_SHA | SHA_TEXT_20_REG         | SHA encrypted/decrypted data register 20          | 0x3FF03050 | 读 / 写 |  |  |
| SHA_TEXT_23_REG SHA encrypted/decrypted data register 23 0x3FF0305C 读/写 SHA_TEXT_24_REG SHA encrypted/decrypted data register 24 0x3FF03060 读/写 SHA_TEXT_25_REG SHA encrypted/decrypted data register 25 0x3FF03064 读/写 SHA_TEXT_26_REG SHA encrypted/decrypted data register 26 0x3FF03068 读/写 SHA_TEXT_27_REG SHA encrypted/decrypted data register 27 0x3FF0306C 读/写 SHA_TEXT_28_REG SHA encrypted/decrypted data register 28 0x3FF03070 读/写 SHA_TEXT_29_REG SHA encrypted/decrypted data register 29 0x3FF03070 读/写 SHA_TEXT_29_REG SHA encrypted/decrypted data register 29 0x3FF03074 读/写 SHA_TEXT_30_REG SHA encrypted/decrypted data register 30 0x3FF03078 读/写 SHA_TEXT_31_REG SHA encrypted/decrypted data register 30 0x3FF03076 读/写 SHA_TEXT_31_REG SHA encrypted/decrypted data register 31 0x3FF0307C 读/写 SHA_SHA1_START_REG Control register to initiate SHA1 operation 0x3FF03080 具写 SHA_SHA1_CONTINUE_REG Control register to continue SHA1 operation 0x3FF03080 具写 SHA_SHA1_CONTINUE_REG Control register to calculate the final SHA1 hash 0x3FF03080 具写 SHA_SHA256_START_REG Control register to initiate SHA256 operation 0x3FF03080 具写 SHA_SHA256_CONTINUE_REG Control register to continue SHA256 operation 0x3FF03090 具写 SHA_SHA256_CONTINUE_REG Control register to continue SHA256 operation 0x3FF03090 具写 SHA_SHA256_BUSY_REG Status register for SHA256 operation 0x3FF03090 具写 SHA_SHA384_START_REG Control register to calculate the final SHA256 0x3FF03090 具写 SHA_SHA384_CONTINUE_REG Control register to calculate the final SHA384 operation 0x3FF03000 只写 SHA_SHA384_CONTINUE_REG Control register to calculate the final SHA384 operation 0x3FF03000 只写 SHA_SHA384_LOAD_REG Status register for SHA256 operation 0x3FF03000 只写 SHA_SHA384_LOAD_REG Control register to calculate the final SHA384 operation 0x3FF03000 只写 SHA_SHA384_LOAD_REG Status register for SHA384 operation 0x3FF03000 只写 SHA_SHA384_LOAD_REG Control register to calculate the final SHA384 operation 0x3FF03000 只写 SHA_SHA384_LOAD_REG Status register for SHA384 operation 0x3FF03000 只写 SHA_SHA_SHA512_CONTINUE | SHA_TEXT_21_REG         | SHA encrypted/decrypted data register 21          | 0x3FF03054 | 读/写   |  |  |
| SHA_TEXT_24_REG SHA encrypted/decrypted data register 24 0x3FF03060 读/写 SHA_TEXT_25_REG SHA encrypted/decrypted data register 25 0x3FF03064 读/写 SHA_TEXT_26_REG SHA encrypted/decrypted data register 26 0x3FF03068 读/写 SHA_TEXT_27_REG SHA encrypted/decrypted data register 27 0x3FF0306C 读/写 SHA_TEXT_27_REG SHA encrypted/decrypted data register 28 0x3FF03070 读/写 SHA_TEXT_29_REG SHA encrypted/decrypted data register 29 0x3FF03070 读/写 SHA_TEXT_29_REG SHA encrypted/decrypted data register 29 0x3FF03074 读/写 SHA_TEXT_30_REG SHA encrypted/decrypted data register 30 0x3FF03078 读/写 SHA_TEXT_31_REG SHA encrypted/decrypted data register 30 0x3FF0307C 读/写 SHA_TEXT_31_REG SHA encrypted/decrypted data register 31 0x3FF0307C 读/写 SHA_SHA1_START_REG Control register to initiate SHA1 operation 0x3FF03080 只写 SHA_SHA1_CONTINUE_REG Control register to calculate the final SHA1 hash 0x3FF03080 只写 SHA_SHA1_DAD_REG Status register for SHA1 operation 0x3FF03080 只写 SHA_SHA256_START_REG Control register to initiate SHA256 operation 0x3FF03080 只写 SHA_SHA256_CONTINUE_REG Control register to continue SHA256 operation 0x3FF03090 只写 SHA_SHA256_BUSY_REG Status register for SHA256 operation 0x3FF03090 只写 SHA_SHA256_BUSY_REG Control register to calculate the final SHA256 0x3FF03094 只写 SHA_SHA384_CONTINUE_REG Control register to calculate the final SHA256 0x3FF03094 只写 SHA_SHA384_CONTINUE_REG Control register to calculate the final SHA384 operation 0x3FF030A0 只写 SHA_SHA384_CONTINUE_REG Control register to continue SHA384 operation 0x3FF030A0 只写 SHA_SHA384_BUSY_REG Status register for SHA256 operation 0x3FF030A0 只写 SHA_SHA384_BUSY_REG Status register for SHA384 operation 0x3FF030A0 只写 SHA_SHA384_CONTINUE_REG Control register to continue SHA384 operation 0x3FF030A0 只写 SHA_SHA384_CONTINUE_REG Control register to continue SHA512 operation 0x3FF030B0 只写 SHA_SHA512_START_REG Control register to continue SHA512 operation 0x3FF030B0 只写 SHA_SHA512_CONTINUE_REG Control register to continue SHA512 operation 0x3FF030B4 只写 SHA_SHA512_LOAD_REG Control register to  | SHA_TEXT_22_REG         | SHA encrypted/decrypted data register 22          | 0x3FF03058 | 读 / 写 |  |  |
| SHA_TEXT_25_REG SHA encrypted/decrypted data register 25 0x3FF03064 读/写 SHA_TEXT_26_REG SHA encrypted/decrypted data register 26 0x3FF03068 读/写 SHA_TEXT_27_REG SHA encrypted/decrypted data register 27 0x3FF0306C 读/写 SHA_TEXT_28_REG SHA encrypted/decrypted data register 28 0x3FF03070 读/写 SHA_TEXT_29_REG SHA encrypted/decrypted data register 29 0x3FF03070 读/写 SHA_TEXT_29_REG SHA encrypted/decrypted data register 29 0x3FF03074 读/写 SHA_TEXT_30_REG SHA encrypted/decrypted data register 30 0x3FF03078 读/写 SHA_TEXT_31_REG SHA encrypted/decrypted data register 30 0x3FF03076 读/写 SHA_TEXT_31_REG SHA encrypted/decrypted data register 31 0x3FF0307C 读/写 Y钟/ 状态寄存器 SHA_SHA1_START_REG Control register to initiate SHA1 operation 0x3FF03080 只写 SHA_SHA1_CONTINUE_REG Control register to continue SHA1 operation 0x3FF03080 只写 SHA_SHA1_LOAD_REG Control register to calculate the final SHA1 hash 0x3FF03080 只写 SHA_SHA256_START_REG Control register to initiate SHA256 operation 0x3FF03080 只写 SHA_SHA256_CONTINUE_REG Control register to continue SHA256 operation 0x3FF03090 只写 SHA_SHA256_LOAD_REG Control register to calculate the final SHA256 0x3FF03090 只写 SHA_SHA384_START_REG Control register to calculate the final SHA256 0x3FF03090 只写 SHA_SHA384_CONTINUE_REG Control register to calculate the final SHA256 0x3FF03090 只写 SHA_SHA384_LOAD_REG Status register for SHA256 operation 0x3FF03090 只写 SHA_SHA384_LOAD_REG Control register to calculate the final SHA384 operation 0x3FF030A0 只写 SHA_SHA384_LOAD_REG Control register to calculate the final SHA384 operation 0x3FF030A0 只写 SHA_SHA384_BUSY_REG Status register for SHA384 operation 0x3FF030A0 只写 SHA_SHA384_BUSY_REG Status register for SHA384 operation 0x3FF030A0 只写 SHA_SHA384_BUSY_REG Status register to continue SHA512 operation 0x3FF030B0 只写 SHA_SHA512_START_REG Control register to calculate the final SHA512 operation 0x3FF030B0 只写 SHA_SHA512_CONTINUE_REG Control register to calculate the final SHA512 operation 0x3FF030B0 只写 SHA_SHA512_LOAD_REG Control register to calculate the final SHA512 operati | SHA_TEXT_23_REG         | SHA encrypted/decrypted data register 23          | 0x3FF0305C | 读/写   |  |  |
| SHA_TEXT_26_REG SHA encrypted/decrypted data register 26 0x3FF03068 读/写 SHA_TEXT_27_REG SHA encrypted/decrypted data register 27 0x3FF0306C 读/写 SHA_TEXT_28_REG SHA encrypted/decrypted data register 28 0x3FF03070 读/写 SHA_TEXT_29_REG SHA encrypted/decrypted data register 29 0x3FF03070 读/写 SHA_TEXT_30_REG SHA encrypted/decrypted data register 29 0x3FF03074 读/写 SHA_TEXT_30_REG SHA encrypted/decrypted data register 30 0x3FF03078 读/写 SHA_TEXT_31_REG SHA encrypted/decrypted data register 30 0x3FF03076 读/写 SHA_TEXT_31_REG SHA encrypted/decrypted data register 31 0x3FF0307C 读/写 Ptwl/ ************************************                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | SHA_TEXT_24_REG         | SHA encrypted/decrypted data register 24          | 0x3FF03060 | 读/写   |  |  |
| SHA_TEXT_27_REG SHA encrypted/decrypted data register 27 0x3FF0306C 读/写 SHA_TEXT_28_REG SHA encrypted/decrypted data register 28 0x3FF03070 读/写 SHA_TEXT_29_REG SHA encrypted/decrypted data register 29 0x3FF03074 读/写 SHA_TEXT_30_REG SHA encrypted/decrypted data register 30 0x3FF03078 读/写 SHA_TEXT_31_REG SHA encrypted/decrypted data register 31 0x3FF0307C 读/写 SHA_TEXT_31_REG SHA encrypted/decrypted data register 31 0x3FF0307C 读/写 SHA_SHA1_START_REG SHA encrypted/decrypted data register 31 0x3FF0307C 读/写 SHA_SHA1_START_REG Control register to initiate SHA1 operation 0x3FF03080 只写 SHA_SHA1_CONTINUE_REG Control register to calculate the final SHA1 hash 0x3FF03088 只写 SHA_SHA1_BUSY_REG Status register for SHA1 operation 0x3FF0308C 只写 SHA_SHA256_START_REG Control register to calculate the final SHA256 operation 0x3FF03090 只写 SHA_SHA256_CONTINUE_REG Control register to continue SHA256 operation 0x3FF03090 只写 SHA_SHA256_BUSY_REG Status register to calculate the final SHA256 nash 0x3FF03090 只写 SHA_SHA384_START_REG Control register to calculate the final SHA256 nash 0x3FF03090 只写 SHA_SHA384_CONTINUE_REG Control register to continue SHA384 operation 0x3FF030A0 只写 SHA_SHA384_CONTINUE_REG Control register to calculate the final SHA384 nash 0x3FF030A0 只写 SHA_SHA384_BUSY_REG Status register for SHA384 operation 0x3FF030A0 只写 SHA_SHA384_BUSY_REG Status register to calculate the final SHA384 nash 0x3FF030AC 只读 SHA_SHA384_BUSY_REG Status register to calculate the final SHA384 nash 0x3FF030AC 只读 SHA_SHA384_BUSY_REG Status register for SHA384 operation 0x3FF030AC 只读 SHA_SHA512_START_REG Control register to calculate the final SHA512 operation 0x3FF030BO 只写 SHA_SHA512_CONTINUE_REG Control register to continue SHA512 operation 0x3FF030BO 只写 SHA_SHA512_LOAD_REG Control register to continue SHA512 operation 0x3FF030BO 只写 SHA_SHA512_LOAD_REG Control register to calculate the final SHA512 operation 0x3FF030BO 只写 SHA_SHA512_LOAD_REG Control register to calculate the final SHA512 operation 0x3FF030BB 只写 SHA_SHA512_LOAD_REG Control register | SHA_TEXT_25_REG         | SHA encrypted/decrypted data register 25          | 0x3FF03064 | 读/写   |  |  |
| SHA_TEXT_28_REG SHA encrypted/decrypted data register 28 0x3FF03070 读/写 SHA_TEXT_29_REG SHA encrypted/decrypted data register 29 0x3FF03074 读/写 SHA_TEXT_30_REG SHA encrypted/decrypted data register 30 0x3FF03078 读/写 SHA_TEXT_31_REG SHA encrypted/decrypted data register 31 0x3FF0307C 读/写 控制/状态寄存器  SHA_SHA1_START_REG SHA encrypted/decrypted data register 31 0x3FF0307C 读/写 控制/状态寄存器  SHA_SHA1_START_REG Control register to initiate SHA1 operation 0x3FF03080 只写 SHA_SHA1_CONTINUE_REG Control register to colculate the final SHA1 hash 0x3FF03088 只写 SHA_SHA1_BUSY_REG Status register for SHA1 operation 0x3FF0308C 只写 SHA_SHA256_START_REG Control register to initiate SHA256 operation 0x3FF03090 只写 SHA_SHA256_CONTINUE_REG Control register to continue SHA256 operation 0x3FF03090 只写 SHA_SHA256_BUSY_REG Status register to calculate the final SHA256 0x3FF03090 只写 SHA_SHA256_BUSY_REG Status register for SHA256 operation 0x3FF03090 只写 SHA_SHA384_START_REG Control register to initiate SHA384 operation 0x3FF03090 只写 SHA_SHA384_CONTINUE_REG Control register to continue SHA384 operation 0x3FF030A0 只写 SHA_SHA384_CONTINUE_REG Control register to calculate the final SHA384 operation 0x3FF030A0 只写 SHA_SHA384_BUSY_REG Status register for SHA384 operation 0x3FF030A0 只写 SHA_SHA384_BUSY_REG Status register to calculate the final SHA384 operation 0x3FF030A0 只写 SHA_SHA384_BUSY_REG Status register for SHA384 operation 0x3FF030A0 只写 SHA_SHA384_BUSY_REG Status register for SHA384 operation 0x3FF030A0 只写 SHA_SHA512_START_REG Control register to initiate SHA512 operation 0x3FF030B0 只写 SHA_SHA512_CONTINUE_REG Control register to continue SHA512 operation 0x3FF030B4 只写 SHA_SHA512_CONTINUE_REG Control register to continue SHA512 operation 0x3FF030B4 只写 SHA_SHA512_LOAD_REG Control register to continue SHA512 operation 0x3FF030B4 只写 SHA_SHA512_LOAD_REG Control register to continue SHA512 operation 0x3FF030B4 只写 SHA_SHA512_LOAD_REG Control register to continue SHA512 operation 0x3FF030B4 只写 SHA_SHA512_LOAD_REG Control register to continue SHA512 operatio | SHA_TEXT_26_REG         | SHA encrypted/decrypted data register 26          | 0x3FF03068 | 读 / 写 |  |  |
| SHA_TEXT_29_REG SHA encrypted/decrypted data register 29 0x3FF03074 读/写 SHA_TEXT_30_REG SHA encrypted/decrypted data register 30 0x3FF03078 读/写 SHA_TEXT_31_REG SHA encrypted/decrypted data register 31 0x3FF0307C 读/写 控制/状态寄存器  SHA_SHA1_START_REG SHA encrypted/decrypted data register 31 0x3FF0307C 读/写 控制/状态寄存器  SHA_SHA1_START_REG Control register to initiate SHA1 operation 0x3FF03080 只写 SHA_SHA1_CONTINUE_REG Control register to continue SHA1 operation 0x3FF03084 只写 SHA_SHA1_LOAD_REG Control register to calculate the final SHA1 hash 0x3FF03088 只写 SHA_SHA1_BUSY_REG Status register for SHA1 operation 0x3FF0308C 只写 SHA_SHA256_START_REG Control register to initiate SHA256 operation 0x3FF0309C 只写 SHA_SHA256_CONTINUE_REG Control register to continue SHA256 operation 0x3FF0309A 只写 SHA_SHA256_BUSY_REG Status register for SHA256 operation 0x3FF0309A 只写 SHA_SHA384_START_REG Control register to calculate the final SHA256 0x3FF0309A 只写 SHA_SHA384_CONTINUE_REG Control register to continue SHA384 operation 0x3FF030A0 只写 SHA_SHA384_LOAD_REG Control register to calculate the final SHA384 operation 0x3FF030A0 只写 SHA_SHA384_BUSY_REG Status register to calculate the final SHA384 operation 0x3FF030A0 只写 SHA_SHA384_BUSY_REG Status register to calculate the final SHA384 0x3FF030A0 只写 SHA_SHA384_BUSY_REG Status register to continue SHA384 operation 0x3FF030A0 只写 SHA_SHA384_BUSY_REG Control register to calculate the final SHA384 0x3FF030A0 只写 SHA_SHA512_START_REG Control register to initiate SHA512 operation 0x3FF030B0 只写 SHA_SHA512_CONTINUE_REG Control register to continue SHA512 operation 0x3FF030B4 只写 SHA_SHA512_CONTINUE_REG Control register to calculate the final SHA512 poperation 0x3FF030B4 只写 SHA_SHA512_LOAD_REG SHA_SHA512_LOAD_REG Control register to calculate the final SHA512 poperation 0x3FF030B8 只写 SHA_SHA512_LOAD_REG SHA_SHA512_LOAD_REG Control register to calculate the final SHA512 poperation 0x3FF030B8 只写 SHA_SHA512_LOAD_REG SHA_SHA512_LOAD_REG SHA_SHA512_LOAD_REG SHA_SHA512_LOAD_REG SHA_SHA512_LOAD_REG SHA_SHA512_LOAD_REG  | SHA_TEXT_27_REG         | SHA encrypted/decrypted data register 27          | 0x3FF0306C | 读/写   |  |  |
| SHA_TEXT_30_REG SHA encrypted/decrypted data register 30 0x3FF03078 读/写 SHA_TEXT_31_REG SHA encrypted/decrypted data register 31 0x3FF0307C 读/写 控制 / 状态寄存器 SHA_SHA1_START_REG Control register to initiate SHA1 operation 0x3FF03080 只写 SHA_SHA1_CONTINUE_REG Control register to continue SHA1 operation 0x3FF03084 只写 SHA_SHA1_LOAD_REG Control register to calculate the final SHA1 hash 0x3FF03088 只写 SHA_SHA1_BUSY_REG Status register for SHA1 operation 0x3FF03086 只写 SHA_SHA256_START_REG Control register to initiate SHA256 operation 0x3FF03090 只写 SHA_SHA256_CONTINUE_REG Control register to continue SHA256 operation 0x3FF03094 只写 SHA_SHA256_BUSY_REG Status register for SHA256 operation 0x3FF03094 只写 SHA_SHA384_START_REG Control register to initiate SHA384 operation 0x3FF03096 只要 SHA_SHA384_CONTINUE_REG Control register to continue SHA384 operation 0x3FF030A0 只写 SHA_SHA384_LOAD_REG Control register to continue SHA384 operation 0x3FF030A0 只写 SHA_SHA384_BUSY_REG Status register for SHA384 operation 0x3FF030A0 只写 SHA_SHA384_BUSY_REG Status register for SHA384 operation 0x3FF030A0 只写 SHA_SHA384_BUSY_REG Control register to calculate the final SHA384 0x3FF030A8 只写 SHA_SHA384_BUSY_REG Status register for SHA384 operation 0x3FF030A0 只写 SHA_SHA384_BUSY_REG Control register to calculate the final SHA384 0x3FF030A0 只写 SHA_SHA384_BUSY_REG Control register to calculate the final SHA384 0x3FF030A0 只写 SHA_SHA512_START_REG Control register to initiate SHA512 operation 0x3FF030B0 只写 SHA_SHA512_CONTINUE_REG Control register to continue SHA512 operation 0x3FF030B4 只写 SHA_SHA512_LOAD_REG Control register to continue SHA512 operation 0x3FF030B4 只写 SHA_SHA512_LOAD_REG Control register to calculate the final SHA512 poperation 0x3FF030B8 只写 SHA_SHA512_LOAD_REG Control register to calculate the final SHA512 poperation 0x3FF030B8 只写 SHA_SHA512_LOAD_REG Control register to calculate the final SHA512 poperation 0x3FF030B8 只写 SHA_SHA512_LOAD_REG Control register to calculate the final SHA512 poperation 0x3FF030B8 只写 SHA_SHA512_LOAD_REG Control regist | SHA_TEXT_28_REG         | SHA encrypted/decrypted data register 28          | 0x3FF03070 | 读 / 写 |  |  |
| SHA_TEXT_31_REG SHA encrypted/decrypted data register 31 0x3FF0307C 读/写 控制/ 状态许存器 SHA_SHA1_START_REG Control register to initiate SHA1 operation 0x3FF03080 只写 SHA_SHA1_CONTINUE_REG Control register to continue SHA1 operation 0x3FF03084 只写 SHA_SHA1_LOAD_REG Control register to calculate the final SHA1 hash 0x3FF03088 只写 SHA_SHA1_BUSY_REG Status register for SHA1 operation 0x3FF03080 只写 SHA_SHA256_START_REG Control register to initiate SHA256 operation 0x3FF03090 只写 SHA_SHA256_CONTINUE_REG Control register to continue SHA256 operation 0x3FF03094 只写 SHA_SHA256_BUSY_REG Status register for SHA256 operation 0x3FF03098 只写 SHA_SHA256_BUSY_REG Status register to calculate the final SHA256 hash 0x3FF03098 只写 SHA_SHA384_START_REG Control register to initiate SHA384 operation 0x3FF030A0 只写 SHA_SHA384_CONTINUE_REG Control register to continue SHA384 operation 0x3FF030A4 只写 SHA_SHA384_LOAD_REG Control register to calculate the final SHA384 peration 0x3FF030A6 只写 SHA_SHA384_BUSY_REG Status register for SHA384 operation 0x3FF030A6 只写 SHA_SHA384_BUSY_REG Status register for SHA384 operation 0x3FF030A6 只写 SHA_SHA512_START_REG Control register to initiate SHA512 operation 0x3FF030B6 只写 SHA_SHA512_CONTINUE_REG Control register to initiate SHA512 operation 0x3FF030B8 只写 SHA_SHA512_LOAD_REG Control register to continue SHA512 operation 0x3FF030B8 只写 SHA_SHA512_LOAD_REG Control register to calculate the final SHA512 operation 0x3FF030B8 只写 SHA_SHA512_LOAD_REG Control register to calculate the final SHA512 operation 0x3FF030B8 只写 SHA_SHA512_LOAD_REG Control register to calculate the final SHA512 operation 0x3FF030B8 只写 SHA_SHA512_LOAD_REG Control register to calculate the final SHA512 operation 0x3FF030B8 只写 SHA_SHA512_LOAD_REG Control register to calculate the final SHA512 operation 0x3FF030B8 只写 SHA_SHA512_LOAD_REG Control register to calculate the final SHA512 operation 0x3FF030B8 只写 SHA_SHA512_LOAD_REG Control register to calculate the final SHA512 operation 0x3FF030B8 只有 SHA_SHA512_LOAD_REG Control register to calculate the fin | SHA_TEXT_29_REG         | SHA encrypted/decrypted data register 29          | 0x3FF03074 | 读/写   |  |  |
| 整備 / 秋志寄存器 SHA_SHA1_START_REG Control register to initiate SHA1 operation 0x3FF03080 只写 SHA_SHA1_CONTINUE_REG Control register to continue SHA1 operation 0x3FF03084 只写 SHA_SHA1_LOAD_REG Control register to calculate the final SHA1 hash 0x3FF03088 只写 SHA_SHA1_BUSY_REG Status register for SHA1 operation 0x3FF0308C 只写 SHA_SHA256_START_REG Control register to initiate SHA256 operation 0x3FF03090 只写 SHA_SHA256_CONTINUE_REG Control register to continue SHA256 operation 0x3FF03094 只写 SHA_SHA256_BUSY_REG Status register to calculate the final SHA256 hash 0x3FF03098 只写 SHA_SHA256_BUSY_REG Status register for SHA256 operation 0x3FF0309C 只读 SHA_SHA384_START_REG Control register to initiate SHA384 operation 0x3FF030A0 只写 SHA_SHA384_CONTINUE_REG Control register to continue SHA384 operation 0x3FF030A4 只写 SHA_SHA384_LOAD_REG Control register to calculate the final SHA384 hash 0x3FF030AC 只读 SHA_SHA384_BUSY_REG Status register for SHA384 operation 0x3FF030AC 只读 SHA_SHA384_BUSY_REG Control register to calculate the final SHA384 phash 0x3FF030AC 只读 SHA_SHA512_START_REG Control register to initiate SHA512 operation 0x3FF030Bd 只写 SHA_SHA512_CONTINUE_REG Control register to continue SHA512 operation 0x3FF030Bd 只写 SHA_SHA512_LOAD_REG Control register to calculate the final SHA512 operation 0x3FF030Bd 只写                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | SHA_TEXT_30_REG         | SHA encrypted/decrypted data register 30          | 0x3FF03078 | 读/写   |  |  |
| SHA_SHA1_START_REG Control register to initiate SHA1 operation 0x3FF03080 只写 SHA_SHA1_CONTINUE_REG Control register to continue SHA1 operation 0x3FF03084 只写 SHA_SHA1_LOAD_REG Control register to calculate the final SHA1 hash 0x3FF03088 只写 SHA_SHA1_BUSY_REG Status register for SHA1 operation 0x3FF0308C 只写 SHA_SHA256_START_REG Control register to initiate SHA256 operation 0x3FF03090 只写 SHA_SHA256_CONTINUE_REG Control register to continue SHA256 operation 0x3FF03090 只写 SHA_SHA256_LOAD_REG Control register to calculate the final SHA256 hash 0x3FF0309C 只读 SHA_SHA384_START_REG Control register to initiate SHA384 operation 0x3FF0309C 只读 SHA_SHA384_CONTINUE_REG Control register to continue SHA384 operation 0x3FF030A0 只写 SHA_SHA384_BUSY_REG Status register to calculate the final SHA384 hash 0x3FF030AC 只读 SHA_SHA384_BUSY_REG Status register for SHA384 operation 0x3FF030AC 只读 SHA_SHA384_BUSY_REG Status register for SHA384 operation 0x3FF030AC 只读 SHA_SHA512_START_REG Control register to initiate SHA512 operation 0x3FF030B0 只写 SHA_SHA512_START_REG Control register to initiate SHA512 operation 0x3FF030B4 只写 SHA_SHA512_LOAD_REG Control register to calculate the final SHA512 operation 0x3FF030B4 只写 SHA_SHA512_LOAD_REG Control register to calculate the final SHA512 operation 0x3FF030B4 只写 SHA_SHA512_LOAD_REG Control register to calculate the final SHA512 operation 0x3FF030B4 只写 SHA_SHA512_LOAD_REG Control register to calculate the final SHA512 operation 0x3FF030B4 只写 SHA_SHA512_LOAD_REG Control register to calculate the final SHA512 operation 0x3FF030B4 只写 SHA_SHA512_LOAD_REG Control register to calculate the final SHA512 operation 0x3FF030B4 只写 SHA_SHA512_LOAD_REG Control register to calculate the final SHA512 operation 0x3FF030B8 只写 SHA_SHA512_LOAD_REG Control register to calculate the final SHA512 operation 0x3FF030B8 只写 SHA_SHA512_LOAD_REG SHASHA512_LOAD_REG SHASHA512_LOAD_REG SHASHA512_LOAD_REG SHASHA512_LOAD_REG SHASHA512_LOAD_REG SHASHA512_LOAD_REG SHASHA512_LOAD_REG SHASHA512_LOAD_REG SHASHA512_LOAD_REG SHASHA512_LOAD_ | SHA_TEXT_31_REG         | SHA encrypted/decrypted data register 31          | 0x3FF0307C | 读/写   |  |  |
| SHA_SHA1_CONTINUE_REG Control register to continue SHA1 operation 0x3FF03084 只写 SHA_SHA1_LOAD_REG Control register to calculate the final SHA1 hash 0x3FF03088 只写 SHA_SHA1_BUSY_REG Status register for SHA1 operation 0x3FF0308C 只写 SHA_SHA256_START_REG Control register to initiate SHA256 operation 0x3FF03090 只写 SHA_SHA256_CONTINUE_REG Control register to continue SHA256 operation 0x3FF03094 只写 SHA_SHA256_LOAD_REG Control register to calculate the final SHA256 hash 0x3FF0309C 只读 SHA_SHA256_BUSY_REG Status register for SHA256 operation 0x3FF0309C 只读 SHA_SHA384_START_REG Control register to initiate SHA384 operation 0x3FF030A0 只写 SHA_SHA384_CONTINUE_REG Control register to continue SHA384 operation 0x3FF030A4 只写 SHA_SHA384_BUSY_REG Status register for SHA384 operation 0x3FF030A6 只写 SHA_SHA384_BUSY_REG Status register for SHA384 operation 0x3FF030AC 只读 SHA_SHA512_START_REG Control register to initiate SHA512 operation 0x3FF030B0 只写 SHA_SHA512_CONTINUE_REG Control register to continue SHA512 operation 0x3FF030B4 只写 SHA_SHA512_LOAD_REG Control register to continue SHA512 operation 0x3FF030B4 只写 SHA_SHA512_LOAD_REG Control register to calculate the final SHA512 operation 0x3FF030B4 只写 SHA_SHA512_LOAD_REG Control register to calculate the final SHA512 operation 0x3FF030B4 只写 SHA_SHA512_LOAD_REG Control register to calculate the final SHA512 operation 0x3FF030B4 只写 Control register to calculate the final SHA512 operation 0x3FF030B4 只写 Control register to calculate the final SHA512 operation 0x3FF030B4 只写 Control register to calculate the final SHA512 operation 0x3FF030B4 只写 Control register to calculate the final SHA512 operation 0x3FF030B4 只写 Control register to calculate the final SHA512 operation 0x3FF030B4 只写 Control register to calculate the final SHA512 operation 0x3FF030B4 只写 Control register to calculate the final SHA512 operation 0x3FF030B4 只写 Control register to calculate the final SHA512 operation 0x3FF030B4 只写 Control register to calculate the final SHA512 operation 0x3FF030B4 只写 Control register to calculate  | 控制 / 状态寄存器              |                                                   |            |       |  |  |
| SHA_SHA1_LOAD_REG Control register to calculate the final SHA1 hash 0x3FF03088 只写 SHA_SHA1_BUSY_REG Status register for SHA1 operation 0x3FF0308C 只写 SHA_SHA256_START_REG Control register to initiate SHA256 operation 0x3FF03090 只写 SHA_SHA256_CONTINUE_REG Control register to continue SHA256 operation 0x3FF03094 只写 SHA_SHA256_LOAD_REG Control register to calculate the final SHA256 hash 0x3FF03098 只写 SHA_SHA256_BUSY_REG Status register for SHA256 operation 0x3FF0309C 只读 SHA_SHA384_START_REG Control register to initiate SHA384 operation 0x3FF030A0 只写 SHA_SHA384_CONTINUE_REG Control register to continue SHA384 operation 0x3FF030A4 只写 SHA_SHA384_LOAD_REG Status register for SHA384 operation 0x3FF030A6 只写 SHA_SHA384_BUSY_REG Status register for SHA384 operation 0x3FF030AC 只读 SHA_SHA512_START_REG Control register to initiate SHA512 operation 0x3FF030B4 只写 SHA_SHA512_CONTINUE_REG Control register to continue SHA512 operation 0x3FF030B4 只写 SHA_SHA512_LOAD_REG Control register to continue SHA512 operation 0x3FF030B4 只写 SHA_SHA512_LOAD_REG Control register to continue SHA512 operation 0x3FF030B4 只写 SHA_SHA512_LOAD_REG Control register to calculate the final SHA512 operation 0x3FF030B8 只写 SHA_SHA512_LOAD_REG Control register to calculate the final SHA512 operation 0x3FF030B8 只写 SHA_SHA512_LOAD_REG Control register to calculate the final SHA512 operation 0x3FF030B8 只写 SHA_SHA512_LOAD_REG Control register to calculate the final SHA512 operation 0x3FF030B8 只写 SHA_SHA512_LOAD_REG Control register to calculate the final SHA512 operation 0x3FF030B8 只写 SHA_SHA512_LOAD_REG Control register to calculate the final SHA512 operation 0x3FF030B8 只写 SHA_SHA512_LOAD_REG Control register to calculate the final SHA512 operation 0x3FF030B8 只写 SHA_SHA512_LOAD_REG Control register to calculate the final SHA512 operation 0x3FF030B8 只写 SHA_SHA512_LOAD_REG Control register to calculate the final SHA512 operation 0x3FF030B8 只写 SHA_SHA512_LOAD_REG Control register for SHA512 operation 0x3FF030B8 publication operation 0x3FF030B8 publication operation | SHA_SHA1_START_REG      | Control register to initiate SHA1 operation       | 0x3FF03080 | 只写    |  |  |
| SHA_SHA1_BUSY_REG Status register for SHA1 operation 0x3FF0308C 只写 SHA_SHA256_START_REG Control register to initiate SHA256 operation 0x3FF03090 只写 SHA_SHA256_CONTINUE_REG Control register to continue SHA256 operation 0x3FF03094 只写 SHA_SHA256_LOAD_REG Control register to calculate the final SHA256 hash 0x3FF03098 只写 SHA_SHA256_BUSY_REG Status register for SHA256 operation 0x3FF0309C 只读 SHA_SHA384_START_REG Control register to initiate SHA384 operation 0x3FF030A0 只写 SHA_SHA384_CONTINUE_REG Control register to continue SHA384 operation 0x3FF030A4 只写 SHA_SHA384_BUSY_REG Status register for SHA384 operation 0x3FF030A6 只写 SHA_SHA384_BUSY_REG Status register for SHA384 operation 0x3FF030AC 只读 SHA_SHA512_START_REG Control register to initiate SHA512 operation 0x3FF030B0 只写 SHA_SHA512_CONTINUE_REG Control register to continue SHA512 operation 0x3FF030B4 只写 SHA_SHA512_LOAD_REG Control register to continue SHA512 operation 0x3FF030B8 只写 SHA_SHA512_LOAD_REG Control register to calculate the final SHA512 hash 0x3FF030B8 只写                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | SHA_SHA1_CONTINUE_REG   | Control register to continue SHA1 operation       | 0x3FF03084 | 只写    |  |  |
| SHA_SHA256_START_REG Control register to initiate SHA256 operation 0x3FF03090 只写 SHA_SHA256_CONTINUE_REG Control register to continue SHA256 operation 0x3FF03094 只写 SHA_SHA256_LOAD_REG Control register to calculate the final SHA256 hash 0x3FF03098 只写 SHA_SHA256_BUSY_REG Status register for SHA256 operation 0x3FF0309C 只读 SHA_SHA384_START_REG Control register to initiate SHA384 operation 0x3FF030A0 只写 SHA_SHA384_CONTINUE_REG Control register to continue SHA384 operation 0x3FF030A4 只写 SHA_SHA384_BUSY_REG Status register to calculate the final SHA384 hash 0x3FF030AC 只读 SHA_SHA512_START_REG Control register to initiate SHA512 operation 0x3FF030B0 只写 SHA_SHA512_CONTINUE_REG Control register to continue SHA512 operation 0x3FF030B4 只写 SHA_SHA512_LOAD_REG Control register to continue SHA512 operation 0x3FF030B4 只写 SHA_SHA512_LOAD_REG Control register to calculate the final SHA512 hash 0x3FF030B8 只写                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | SHA_SHA1_LOAD_REG       | Control register to calculate the final SHA1 hash | 0x3FF03088 | 只写    |  |  |
| SHA_SHA256_CONTINUE_REG Control register to continue SHA256 operation 0x3FF03094 只写 SHA_SHA256_LOAD_REG Control register to calculate the final SHA256 hash 0x3FF03098 只写 SHA_SHA256_BUSY_REG Status register for SHA256 operation 0x3FF0309C 只读 SHA_SHA384_START_REG Control register to initiate SHA384 operation 0x3FF030A0 只写 SHA_SHA384_CONTINUE_REG Control register to continue SHA384 operation 0x3FF030A4 只写 SHA_SHA384_BUSY_REG Status register for SHA384 operation 0x3FF030A8 只写 SHA_SHA384_BUSY_REG Status register for SHA384 operation 0x3FF030AC 只读 SHA_SHA512_START_REG Control register to initiate SHA512 operation 0x3FF030B0 只写 SHA_SHA512_CONTINUE_REG Control register to continue SHA512 operation 0x3FF030B4 只写 SHA_SHA512_LOAD_REG Control register to calculate the final SHA512 hash 0x3FF030B8 只写                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | SHA_SHA1_BUSY_REG       | Status register for SHA1 operation                | 0x3FF0308C | 只写    |  |  |
| SHA_SHA256_LOAD_REG  Control register to calculate the final SHA256 hash  SHA_SHA256_BUSY_REG  Status register for SHA256 operation  SHA_SHA384_START_REG  Control register to initiate SHA384 operation  SHA_SHA384_CONTINUE_REG  Control register to continue SHA384 operation  SHA_SHA384_LOAD_REG  SHA_SHA384_LOAD_REG  SHA_SHA384_BUSY_REG  Status register for SHA384 operation  Ox3FF030A4  只写  Control register to calculate the final SHA384 hash  SHA_SHA512_START_REG  Control register to initiate SHA512 operation  Ox3FF030B0  只写  SHA_SHA512_CONTINUE_REG  Control register to continue SHA512 operation  Ox3FF030B4  只写  SHA_SHA512_LOAD_REG  Control register to calculate the final SHA512 hash  Control register to calculate the final SHA512 phash                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | SHA_SHA256_START_REG    | Control register to initiate SHA256 operation     | 0x3FF03090 | 只写    |  |  |
| SHA_SHA256_LOAD_REG hash                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | SHA_SHA256_CONTINUE_REG | Control register to continue SHA256 operation     | 0x3FF03094 | 只写    |  |  |
| SHA_SHA384_START_REG Control register to initiate SHA384 operation 0x3FF030A0 只写 SHA_SHA384_CONTINUE_REG Control register to continue SHA384 operation 0x3FF030A4 只写 SHA_SHA384_LOAD_REG Control register to calculate the final SHA384 hash 0x3FF030A8 只写 SHA_SHA384_BUSY_REG Status register for SHA384 operation 0x3FF030AC 只读 SHA_SHA512_START_REG Control register to initiate SHA512 operation 0x3FF030B0 只写 SHA_SHA512_CONTINUE_REG Control register to continue SHA512 operation 0x3FF030B4 只写 SHA_SHA512_LOAD_REG Control register to calculate the final SHA512 hash 只写                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | SHA_SHA256_LOAD_REG     |                                                   | 0x3FF03098 | 只写    |  |  |
| SHA_SHA384_CONTINUE_REG Control register to continue SHA384 operation 0x3FF030A4 只写 SHA_SHA384_LOAD_REG Control register to calculate the final SHA384 hash 0x3FF030A8 只写 SHA_SHA384_BUSY_REG Status register for SHA384 operation 0x3FF030AC 只读 SHA_SHA512_START_REG Control register to initiate SHA512 operation 0x3FF030B0 只写 SHA_SHA512_CONTINUE_REG Control register to continue SHA512 operation 0x3FF030B4 只写 SHA_SHA512_LOAD_REG Control register to calculate the final SHA512 hash                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | SHA_SHA256_BUSY_REG     | Status register for SHA256 operation              | 0x3FF0309C | 只读    |  |  |
| SHA_SHA384_LOAD_REG Control register to calculate the final SHA384 hash SHA_SHA384_BUSY_REG Status register for SHA384 operation SHA_SHA512_START_REG Control register to initiate SHA512 operation SHA_SHA512_CONTINUE_REG Control register to continue SHA512 operation SHA_SHA512_LOAD_REG Control register to calculate the final SHA512 hash  Control register to calculate the final SHA512 ox3FF030B8 只写                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | SHA_SHA384_START_REG    | Control register to initiate SHA384 operation     | 0x3FF030A0 | 只写    |  |  |
| SHA_SHA384_LOAD_REG hash                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | SHA_SHA384_CONTINUE_REG | Control register to continue SHA384 operation     | 0x3FF030A4 | 只写    |  |  |
| SHA_SHA512_START_REG Control register to initiate SHA512 operation 0x3FF030B0 只写 SHA_SHA512_CONTINUE_REG Control register to continue SHA512 operation 0x3FF030B4 只写 SHA_SHA512_LOAD_REG Control register to calculate the final SHA512 0x3FF030B8 只写                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | SHA_SHA384_LOAD_REG     | _                                                 | 0x3FF030A8 | 只写    |  |  |
| SHA_SHA512_START_REG Control register to initiate SHA512 operation 0x3FF030B0 只写 SHA_SHA512_CONTINUE_REG Control register to continue SHA512 operation 0x3FF030B4 只写 SHA_SHA512_LOAD_REG Control register to calculate the final SHA512 0x3FF030B8 只写                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | SHA_SHA384_BUSY_REG     |                                                   | 0x3FF030AC | 只读    |  |  |
| SHA_SHA512_CONTINUE_REG Control register to continue SHA512 operation 0x3FF030B4 只写 SHA_SHA512_LOAD_REG Control register to calculate the final SHA512 0x3FF030B8 只写                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                         | <u> </u>                                          |            |       |  |  |
| SHA_SHA512_LOAD_REG Control register to calculate the final SHA512 0x3FF030B8 只写                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                         | <u> </u>                                          |            |       |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                         | Control register to calculate the final SHA512    |            |       |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | SHA_SHA512_BUSY_REG     |                                                   | 0x3FF030BC | 只读    |  |  |

12.5 寄存器 12 SHA 加速器

# 12.5 寄存器

Register 12.1: SHA\_TEXT\_n\_REG (n: 0-31) (0x0+4\*n)



**SHA\_TEXT\_n\_REG (n: 0-31)** SHA 信息块和哈希运算结果寄存器。(读 / 写)

Register 12.2: SHA\_SHA1\_START\_REG (0x080)



SHA\_SHA1\_START 写入 1 对第一个信息块进行 SHA-1 运算。(只写)

Register 12.3: SHA\_SHA1\_CONTINUE\_REG (0x084)



SHA\_SHA1\_CONTINUE 写入 1 对后续的信息块继续进行 SHA-1 运算。(只写)

Register 12.4: SHA\_SHA1\_LOAD\_REG (0x088)



SHA\_SHA1\_LOAD 写入 1 结束 SHA-1 运算, 计算最终的运算结果。(只写)

12.5 寄存器 12 SHA 加速器

Register 12.5: SHA\_SHA1\_BUSY\_REG (0x08C)



**SHA\_SHA1\_BUSY** SHA-1 运算状态寄存器: 1: SHA 加速器正在处理数据; 0: 空闲。(只读)

Register 12.6: SHA\_SHA256\_START\_REG (0x090)



**SHA\_SHA256\_START** 写人 1 对第一个信息块进行 SHA-256 运算。(只写)

Register 12.7: SHA\_SHA256\_CONTINUE\_REG (0x094)



SHA\_SHA256\_CONTINUE 写入 1 对后续的信息块继续进行 SHA-256 运算。(只写)

Register 12.8: SHA\_SHA256\_LOAD\_REG (0x098)



SHA\_SHA256\_LOAD 写入 1 结束 SHA-256 运算, 计算最终的运算结果。(只写)

12.5 寄存器 12 SHA 加速器

Register 12.9: SHA\_SHA256\_BUSY\_REG (0x09C)



SHA\_SHA256\_BUSY SHA-256 运算状态寄存器: 1: SHA 加速器正在处理数据; 0: 空闲。(只读)

Register 12.10: SHA\_SHA384\_START\_REG (0x0A0)



SHA\_SHA384\_START 写入 1 对第一个信息块进行 SHA-384 运算。(只写)

Register 12.11: SHA\_SHA384\_CONTINUE\_REG (0x0A4)



SHA\_SHA384\_CONTINUE 写入 1 对后续的信息块继续进行 SHA-384 运算。(只写)

Register 12.12: SHA\_SHA384\_LOAD\_REG (0x0A8)



**SHA\_SHA384\_LOAD** 写入 1 结束 SHA-384 运算, 计算最终的运算结果。(只写)

12.5 寄存器 12 SHA 加速器

Register 12.13: SHA\_SHA384\_BUSY\_REG (0x0AC)



SHA\_SHA384\_BUSY SHA-384 运算状态寄存器: 1: SHA 加速器正在处理数据; 0: 空闲。(只读)

Register 12.14: SHA\_SHA512\_START\_REG (0x0B0)



SHA\_SHA512\_START 写入 1 对第一个信息块进行 SHA-512 运算。(只写)

Register 12.15: SHA\_SHA512\_CONTINUE\_REG (0x0B4)



SHA\_SHA512\_CONTINUE 写入 1 对后续的信息块继续进行 SHA-512 运算。(只写)

Register 12.16: SHA\_SHA512\_LOAD\_REG (0x0B8)



**SHA\_SHA512\_LOAD** 写入 1 结束 SHA-512 运算, 计算最终的运算结果。(只写)

12.5 寄存器 12 SHA 加速器

Register 12.17: SHA\_SHA512\_BUSY\_REG (0x0BC)



SHA\_SHA512\_BUSY SHA-512 运算状态寄存器: 1: SHA 加速器正在处理数据; 0: 空闲。(只读)