

# **LOONGSON**

# 龙芯 2K2000 处理器

用户手册

V1.03

2025年08月

龙芯中科技术股份有限公司

自主决定命运,创新成就未来





# 阅读指南

《龙芯 2K2000 处理器用户手册》主要介绍龙芯 2K2000 架构与寄存器描述,对芯片系统架构、主要模块的功能与配置、寄存器列表及位域进行详细说明。



# 目录

| 目录                                                   |       |
|------------------------------------------------------|-------|
| 图目录                                                  | XI    |
| 表目录                                                  | . XII |
| 1 概述                                                 | 1     |
| 1.1 体系结构框图                                           | 2     |
| 1.2 芯片主要功能                                           | 2     |
| 1.2.1 处理器核                                           | 2     |
| 1.2.2 内存接口                                           | 2     |
| 1.2.3 PCIe 接口                                        | 3     |
| 1.2.4 RapidIO接口                                      | 3     |
| 1. 2. 5 GPU                                          |       |
| 1. 2. 6 显示接口                                         |       |
| 1. 2. 7 SATA 控制器                                     |       |
| 1. 2. 8 USB 控制器                                      |       |
| 1. 2. 9 GMAC 控制器                                     |       |
| 1. 2. 10 HDA 接口                                      |       |
| 1. 2. 11 128 接口                                      |       |
| 1. 2. 11 123 接口····································  |       |
| 1. 2. 12 3F1 控则备···································· |       |
| ~.                                                   |       |
| 1. 2. 14 UART                                        |       |
| 1. 2. 15 I2C 总线                                      |       |
| 1. 2. 16 PWM                                         |       |
| 1. 2. 17 HPET                                        |       |
| 1. 2. 18 RTC                                         |       |
| 1.2.19 ACPI 接口                                       |       |
| 1.2.20 Watchdog                                      |       |
| 1. 2. 21 AVS                                         |       |
| 1.2.22 中断控制器                                         |       |
| 1. 2. 23 CAN                                         |       |
| 1. 2. 24 GPIO                                        |       |
| 1.2.25 加解密模块                                         | 7     |
| 1.2.26 SDIO 控制器                                      | 7     |
| 1.2.27 eMMC 控制器                                      | 7     |
| 2 引脚定义                                               | 8     |
| 2.1 约定                                               | 8     |
| 2.2 DDR4接口                                           | 8     |
| 2.3 PCIe 接口                                          | 9     |
| 2.4 DVO 显示接口                                         | 9     |
| 2.5 HDMI 接口                                          | 11    |
| 2.6 GMAC 接口                                          | 11    |
| 2.7 SATA 接口                                          |       |
| 2. 8 USB 接口                                          |       |
| 2.9 HDA 接口                                           |       |
| 2. 10 SPI 接口                                         |       |
| 2. 11 12C 接口                                         |       |
| 2. 12 UART 接口                                        |       |
| 2. 13 CAN 接口                                         |       |
| 2. 14 LPC 接口                                         |       |
| 2.14 LPC 按口                                          |       |
| 4.10 の111 汝口                                         | 11    |



|   | 2.16 eMMC 接口          | 18 |
|---|-----------------------|----|
|   | 2.17 GPIO             | 18 |
|   | 2.18 PWM              |    |
|   | 2.19 ACPI 接口          | 19 |
|   | 2. 20 JTAG 接口         |    |
|   | 2.21 时钟信号             |    |
|   | 2. 22 RTC 相关信号        |    |
|   | 2.23 安全模块接口           |    |
|   | 2.24 系统相关信号           |    |
|   | 2.25 其他信号接口           |    |
|   | 2.26 外设功能复用表          |    |
| 2 | 时钟结构                  |    |
| J | 3.1 芯片时钟结构            |    |
|   | 3.2 系统参考时钟            |    |
|   | 3.3 内部网络时钟            |    |
|   | 3.4 RTC 时钟            |    |
|   | 3.5 PCIe PHY 参考时钟     |    |
|   | 3.6 USB PHY 参考时钟      |    |
|   | > <b>3 4</b> · · ·    |    |
|   | 3.7 SATA PHY 参考时钟     |    |
|   | 3.8 GMAC PHY 参考时钟     |    |
|   | 3.9 PHY 时钟之间关系        |    |
| 4 | 电源管理                  |    |
|   | 4.1 电源管理模块介绍          |    |
| _ | 4.2 电源级别              |    |
| 5 | 芯片配置寄存器               |    |
|   | 5.1 版本寄存器             |    |
|   | 5.2 芯片特性寄存器           |    |
|   | 5.3 厂商名称              |    |
|   | 5.4 芯片名称              |    |
|   | 5.5 功能设置寄存器           |    |
|   | 5.6 温度采样寄存器           |    |
|   | 5.7 处理器核分频设置寄存器       |    |
|   | 5.8 处理器核复位控制寄存器       |    |
|   | 5.9 路由设置寄存器           |    |
|   | 5.10 其它功能设置寄存器        |    |
|   | 5.11 FUSE0 观测寄存器      |    |
|   | 5. 12 FUSE1 观测寄存器     |    |
|   | 5.13 通用配置寄存器 0        |    |
|   | 5.14 通用配置寄存器 1        |    |
|   | 5.15 引脚复用配置寄存器        |    |
|   | 5.16 USB OC 选择配置      |    |
|   | 5.17 OTG 预取配置         |    |
|   | 5.18 固定地址配置           |    |
|   | 5.19 DMA 一致性配置寄存器     |    |
|   | 5. 20 PLL0 配置寄存器      |    |
|   | 5.21 PLL1 配置寄存器       |    |
|   | 5. 22 PLL2 配置寄存器      |    |
|   | 5.23 PLL_PIX_0 配置寄存器  |    |
|   | 5.24 PLL_PIX_1 配置寄存器  |    |
|   | 5.25 SSC PLL 配置寄存器 0  |    |
|   | 5, 26 SSC PLL 配置寄存器 1 | 52 |



|   | 5. 27 FREQSCALE 配置寄存器     | . 53 |
|---|---------------------------|------|
|   | 5.28 PCIe_F0 配置寄存器 0      | . 53 |
|   | 5.29 PCIe FO 配置寄存器 1      | . 54 |
|   | 5. 30 PCIe_FO PHY 配置控制寄存器 |      |
|   | 5.31 PCIe F1 配置寄存器 0      |      |
|   | 5. 32 PCIe F1 配置寄存器 1     |      |
|   | 5. 33 PCIe F1 PHY 配置控制寄存器 |      |
|   | 5. 34 PCIe GO 配置寄存器 0     |      |
|   | 5. 35 PCIe GO 配置寄存器 1     |      |
|   | 5. 36 PCIe GO PHY 配置控制寄存器 |      |
|   | 5. 37 PCIe 配置访问路由控制寄存器    |      |
|   | 5. 38 PRG 配置访问寄存器         |      |
|   | 5.39 PRG 模块配置寄存器 0        |      |
|   | 5.40 PRG 模块配置寄存器 1        |      |
|   | 5.41 RapidIO PHY 配置寄存器 0  |      |
|   | 5.42 RapidIO PHY 配置寄存器 1  |      |
|   | •                         |      |
|   | 5. 43 RapidIO PHY 配置寄存器 2 |      |
|   | 5. 44 RapidIO PHY 配置寄存器 3 |      |
|   | 5. 45 PAD 驱动配置寄存器         |      |
|   | 5.46 Compensation 状态寄存器   |      |
|   | 5. 47 SATA PHY 配置寄存器      |      |
|   | 5. 48 SATA PHY 配置访问寄存器    |      |
|   | 5. 49 SATA PHY PLL 配置寄存器  |      |
|   | 5.50 GMACO 配置寄存器          |      |
|   | 5.51 GMAC1 配置寄存器          |      |
|   | 5.52 USB3 PHY 配置寄存器 0     |      |
|   | 5.53 USB3 PHY 配置寄存器 1     |      |
|   | 5.54 USB3 PHY 配置寄存器 2     |      |
|   | 5.55 USB3 PHY 配置寄存器 3     |      |
|   | 5.56 USB3 PHY 配置寄存器 4     |      |
|   | 5.57 USB3 PHY 配置寄存器 5     |      |
|   | 5.58 USB3.0 控制器配置寄存器      |      |
|   | 5.59 USB2.0 PHY 配置寄存器 0   |      |
|   | 5.60 USB2.0 PHY 配置寄存器 1-9 |      |
|   | 5.61 USB2.0 配置寄存器         |      |
|   | 5.62 USB3.0 电源控制寄存器       |      |
|   | 5.63 USB2.0 电源控制寄存器       |      |
|   | 5.64 GPU 窗口 0 基址寄存器       |      |
|   | 5.65 GPU 窗口 0 大小寄存器       |      |
|   | 5.66 GPU 窗口 0 重映射寄存器      |      |
|   | 5.67 GPU 窗口 1 基址寄存器       | . 87 |
|   | 5.68 GPU 窗口 1 大小寄存器       |      |
|   | 5.69 GPU 窗口 1 重映射寄存器      | . 88 |
| 6 | 地址空间分配                    | . 89 |
|   | 6.1 一级交叉开关                | . 90 |
|   | 6.2 二级交叉开关                | . 90 |
|   | 6.3 交叉开关软件路由配置            | . 91 |
|   | 6.4 IO 互连网络               | . 95 |
|   | 6.4.1 PCI 设备的配置空间         | . 95 |
|   | 6.4.2 PCI 设备和功能           | . 96 |
|   | 6.4.3 设备地址空间分配示例          | 103  |



| 7   | 共享 Cache(SCache)                   | 105 |
|-----|------------------------------------|-----|
| 8   | 处理器核间中断与通信                         | 107 |
|     | 8.1 按地址访问模式                        |     |
|     | 8.2 配置寄存器指令访问                      | 108 |
|     | 8.3 配置寄存器指令调试支持                    | 109 |
| 9   | I/0 中断                             | 111 |
|     | 9.1 南北桥中断控制                        | 113 |
|     | 9.1.1 中断相关寄存器描述                    | 113 |
|     | 9.1.2 设备中断类型                       | 123 |
|     | 9.1.3 中断分发模式                       | 124 |
|     | 9.2 NODE 传统 I/O 中断                 | 124 |
|     | 9.2.1 按地址访问                        | 125 |
|     | 9.2.2 配置寄存器指令访问                    | 127 |
|     | 9.3 扩展 I/O 中断                      |     |
|     | 9.3.1 按地址访问                        | 127 |
|     | 9.3.2 配置寄存器指令访问                    | 129 |
|     | 9.3.3 扩展 IO 中断触发寄存器                | 129 |
|     | 温度传感器                              |     |
|     | 10.1 温度传感器配置寄存器                    |     |
|     | 10.2 温度传感器中断控制寄存器                  |     |
|     | 10.3 温度传感器中断状态/清除寄存器               |     |
|     | 10.4 高温自动降频设置                      |     |
| 11  | SPI 控制器                            |     |
|     | 11.1 访问地址                          |     |
|     | 11.2 SPI 控制器结构                     |     |
|     | 11.3 配置寄存器                         |     |
|     | 11.3.1 控制寄存器(SPCR)                 |     |
|     | 11.3.2 状态寄存器(SPSR)                 |     |
|     | 11.3.3 数据寄存器(TxFIFO/RxFIFO)        |     |
|     | 11.3.4 外部寄存器(SPER)                 |     |
|     | 11.3.5 参数控制寄存器(SFC_PARAM)          |     |
|     | 11.3.6 片选控制寄存器(SFC_SOFTCS)         |     |
|     | 11.3.7 时序控制寄存器(SFC_TIMING)         |     |
|     | 11.3.8 自定义控制寄存器 (CTRL)             |     |
|     | 11.3.9 自定义命令寄存器 (CMD)              |     |
|     | 11.3.10 自定义数据寄存器 0 (BUF0)          |     |
|     | 11.3.11 自定义数据寄存器 1 (BUF1)          |     |
|     | 11. 3. 12 自定义时序寄存器 0 (TIMERO)      |     |
|     | 11.3.13 自定义时序寄存器 1 (TIMER1)        |     |
|     | 11.3.14 自定义时序寄存器 2 (TIMER2)        |     |
|     | 11.4 接口时序                          |     |
|     | 11. 4. 1 SPI 主控制器接口时序              |     |
|     | 11. 4. 2 SPI Flash 访问时序            |     |
|     | 11.5 软件编程指南                        |     |
|     | 11. 5. 1 SPI 主控制器的读写操作             |     |
|     | 11. 5. 2 硬件 SPI Flash 读            |     |
| ٠.  | 11. 5. 3 混合访问 SPI Flash 和 SPI 主控制器 |     |
|     | LocalIO 控制器                        |     |
|     | 12.1 访问地址及引脚复用                     |     |
|     | 12.2 LocalIO 控制器功能概述               |     |
| 1.1 | DDR4 控制器                           | 145 |



| 13.1 DDR4 内存接口                 |     |
|--------------------------------|-----|
| 13.2 DDR4 SDRAM 控制器功能概述        | 145 |
| 13.3 DDR4 SDRAM 读操作协议          | 145 |
| 13.4 DDR4 SDRAM 写操作协议          | 146 |
| 13.5 DDR4 SDRAM 参数配置格式         | 146 |
| 13.6 软件编程指南                    | 157 |
| 13.6.1 初始化操作                   | 157 |
| 13.6.2 复位引脚的控制                 | 157 |
| 13.6.3 Leveling                | 159 |
| 13.6.4 Write Leveling          | 159 |
| 13.6.5 Gate Leveling           | 160 |
| 13.6.6 功耗控制配置流程                | 160 |
| 13.6.7 单独发起 MRS 命令             | 161 |
| 13.6.8 任意操作控制总线                | 161 |
| 13.6.9 自循环测试模式控制               | 162 |
| 13.7 ECC 功能使用控制                | 162 |
| 13.8 出错状态观测                    | 163 |
| 14 MISC 低速设备(D2:F0)            |     |
| 14.1 MISC低速设备配置寄存器(MISC-D2:F0) | 164 |
| 14.2 内部设备地址路由                  |     |
| 15 UART 控制器                    |     |
| 15.1 概述                        |     |
| 15.2 访问地址及引脚复用                 |     |
| 15.3 控制器结构                     |     |
| 15.4 寄存器描述                     |     |
| 15.4.1 数据寄存器 (DAT)             |     |
| 15. 4. 2 中断使能寄存器(IER)          |     |
| 15.4.3 中断标识寄存器(IIR)            |     |
| 15.4.4 FIFO 控制寄存器 (FCR)        |     |
| 15. 4. 5 线路控制寄存器 (LCR)         |     |
| 15.4.6 MODEM 控制寄存器 (MCR)       |     |
| 15. 4. 7 线路状态寄存器 (LSR)         |     |
| 15.4.8 MODEM 状态寄存器 (MSR)       |     |
| 15.4.9 分频锁存器                   |     |
| 15. 4. 10 新增寄存器的使用             |     |
| 16 CAN                         |     |
| 16.1 访问地址及引脚复用                 |     |
| 16.2 标准模式16.2.1 控制寄存器(CR)      |     |
| 16.2.1 控制奇仔碲 (CR)              |     |
| 16.2.3 状态寄存器(SR)               |     |
| 16.2.4 中断寄存器(IR)               |     |
| 16.2.5 验收代码寄存器(ACR)            |     |
| 16.2.6 验收屏蔽寄存器(AMR)            |     |
| 16.2.7 发送缓冲区列表                 |     |
| 16.2.8 接收缓冲区列表                 |     |
| 16.3 扩展模式                      |     |
| 16.3.1 模式寄存器(MOD)              |     |
| 16.3.2 命令寄存器(CMR)              |     |
| 16.3.3 状态寄存器 (SR)              |     |
| 16.3.4 中断寄存器(IR)               |     |
| ~~· ~· 1 E/  E/                | 100 |



|        | 16.3.5 中断使能寄存器(IER)           | 181 |
|--------|-------------------------------|-----|
|        | 16.3.6 仲裁丢失捕捉寄存器              | 181 |
|        | 16.3.7 错误警报限制寄存器(EMLR)        | 182 |
|        | 16.3.8 RX 错误计数寄存器(RXERR)      | 183 |
|        | 16.3.9 TX 错误计数寄存器(TXERR)      | 183 |
|        | 16.3.10 验收滤波器                 |     |
|        | 16.3.11 RX 信息计数寄存器(RMCR)      |     |
| 16. 4  | 公共寄存器                         |     |
| 1011   | 16.4.1 总线定时寄存器 0 (BTRO)       |     |
|        | 16. 4. 2 总线定时寄存器 1 (BTR1)     |     |
|        | 16. 4. 3 输出控制寄存器 (OCR)        |     |
| 17 I2C | 控制器                           |     |
|        | 概述                            |     |
|        | 访问地址及引脚复用                     |     |
|        | I2C 主控制器结构                    |     |
|        | I2C 主控制器寄存器说明                 |     |
| 11.1   | 17. 4. 1 分频锁存器低字节寄存器 (PRERIo) |     |
|        | 17. 4. 2 分频锁存器高字节寄存器 (PRERhi) |     |
|        | 17.4.3 控制寄存器 (CTR)            |     |
|        | 17.4.4 发送数据寄存器 (TXR)          |     |
|        | 17.4.5 接收数据寄存器 (RXR)          |     |
|        | 17.4.6 命令控制寄存器 (CR)           |     |
|        | 17.4.7 状态寄存器 (SR)             |     |
|        | 17.4.8 从模式控制寄存器(SLV_CTRL)     |     |
| 17 5   | I2C2 从模式地址空间                  |     |
|        | 控制器                           |     |
|        | 概述                            |     |
|        | 访问地址及引脚复用                     |     |
|        | 寄存器描述                         |     |
|        | 功能说明                          |     |
| 10.4   | 18. 4. 1 脉宽调制功能               |     |
|        | 18.4.2 脉冲测量功能                 |     |
|        | 18.4.3 防死区功能                  |     |
| 10 AVC | 控制器                           |     |
|        | 访问地址及引脚复用                     |     |
|        | 控制寄存器(CSR)                    |     |
|        |                               |     |
|        | 数据寄存器(Sreg)                   |     |
|        | 使用说明                          |     |
|        | [ 控制器                         |     |
|        | 概述                            |     |
|        | 访问地址                          |     |
|        | 寄存器描述                         |     |
|        | 可分价组处                         |     |
|        | NODE GPIO 控制                  |     |
| 41.1   | 21. 1. 1 输出使能寄存器 (0x0500)     |     |
|        | 21.1.2 输入输出寄存器(0x0508)        |     |
|        | 21.1.3 中断控制寄存器(0x0510)        |     |
|        | 21.1.3 中例控制司行备(0x0510)        |     |
| 91 9   | <b>南桥 GPIO 控制</b>             |     |
| 41.4   |                               | 201 |
|        |                               |     |



| 21.2.2 控制奇仔器              |     | )2 |
|---------------------------|-----|----|
| 22 电源管理模块                 |     |    |
| 22.1 访问地址                 |     |    |
| 22.2 电源级别                 |     |    |
| 22.3 ACPI 寄存器描述           |     |    |
| 22.4 DPM 寄存器描述            | 21  | 12 |
| 23 RTC                    |     |    |
| 23.1 概述                   |     |    |
| 23.2 访问地址                 |     |    |
| 23.3 寄存器描述                | 21  | 14 |
| 23.3.1 寄存器地址列表            |     |    |
| 23.3.2 SYS_TOYWRITEO      |     |    |
| 23. 3. 3 SYS_TOYWRITE1    |     |    |
| 23. 3. 4 SYS_TOYREADO     | 21  | 15 |
| 23. 3. 5 SYS_TOYREAD1     |     |    |
| 23.3.6 SYS_TOYMATCHO/1/2  |     |    |
| 23. 3. 7 SYS_RTCCTRL      |     |    |
| 23.3.8 SYS_RTCWRITE       |     |    |
| 23. 3. 9 SYS_RTCREAD      |     |    |
| 23.3.10 SYS_RTCMATCHO/1/2 |     |    |
| 24 LPC 控制器 (D23:F0)       |     |    |
| 24.1 LPC 配置寄存器(D23:F0)    |     |    |
| 24.2 LPC 地址空间             |     |    |
| 24.3 LPC 中断               |     |    |
| 24.4 LPC 控制寄存器            |     |    |
| 25 加解密                    |     |    |
| 25.1 DES (D29:F1)         |     |    |
| 25.1.1 DES 功能概述           |     |    |
| 25.1.2 DES 访问地址           |     |    |
| 25.1.3 DES 寄存器描述          |     |    |
| 25. 2 AES (D29:F0)        |     |    |
| 25.2.1 AES 功能概述           |     |    |
| 25. 2. 2 AES 访问地址         |     |    |
| 25.2.3 AES 寄存器描述          |     |    |
| 25. 3 RSA (D29:F2)        |     |    |
| 25.3.1 RSA 访问地址           |     |    |
| 25. 4 RNG (D29:F3)        |     |    |
| 25.4.1 RNG 访问地址           |     |    |
| 26 EMMC 控制器 (D28:F0)      |     |    |
| 26.1 功能特性                 |     |    |
| 26.2 寄存器描述                |     |    |
| 26.3 软件配置流程               |     |    |
| 26.3.1 EMMC 正常读写软件配置流程    |     |    |
| 26.3.2 EMMC 初始化流程         |     |    |
| 26.3.3 DDR 模式             |     |    |
| 27 SDIO 控制器 (D28:F1)      |     |    |
| 27.1 功能概述                 |     |    |
| 27.2 SDIO 协议概述            |     |    |
| 27.3 寄存器描述                |     |    |
| 27.4 软件编程指南               |     |    |
| 27.4.1 SD Memory 卡软件编程说明  | 2.4 | 16 |



| 27. 4. 2 SD10 卡软件编程说明     |     |
|---------------------------|-----|
| 27.4.3 DDR 模式设置           |     |
| 27.5 支持 SDIO 型号           |     |
| 28 GMAC 控制器(D3:F0/1/2)    |     |
| 28.1 GMAC配置寄存器            |     |
| 28.2 GMAC 软件编程指南          |     |
| 28.3 IEEE 1588 支持         |     |
| 28.4 GMAC PHY 初始化流程       |     |
| 29 OTG 控制器 (D5:F0)        |     |
| 29.1 概述                   |     |
| 29.2 访问地址                 |     |
| 30 USB 控制器(D4:F0, D25:F0) |     |
| 30.1总体概述                  |     |
| 30.2 XHCI 控制器             |     |
| 30.2.1 XHCI 配置寄存器         |     |
| 30.2.2 XHCI 基本操作寄存器       |     |
| 30.2.3 USB3.0 初始化序列       |     |
| 31 图形处理器 (D6:F0)          |     |
| 31.1 GPU 配置寄存器            |     |
| 32 显示控制器 (D6:F1)          |     |
| 32.1 概述                   |     |
| 32.2 DC 配置寄存器 (D6:F1)     |     |
| 32.3 DC 控制寄存器             |     |
| 32.3.1 帧缓冲配置寄存器           |     |
| 32.3.2 帧缓冲地址寄存器 0         |     |
| 32.3.3 帧缓冲地址寄存器 1         |     |
| 32.3.4 Meta0 低地址寄存器       |     |
| 32.3.5 MetaO 高地址寄存器       |     |
| 32.3.6 Metal 低地址寄存器       |     |
| 32.3.7 Metal 高地址寄存器       |     |
| 32.3.8 帧缓冲跨度寄存器           |     |
| 32.3.9 帧缓冲初始字节寄存器         |     |
| 32.3.10 颜色抖动配置寄存器         |     |
|                           |     |
| 32.3.12 颜色抖动查找表高位寄存器      | 260 |
| 32.3.13 颜色抖动说明            |     |
| 32.3.14 液晶面板配置寄存器         |     |
| 32.3.15 水平显示宽度寄存器         |     |
| 32.3.16 行同步配置寄存器          |     |
| 32.3.17 垂直显示高度寄存器         |     |
| 32.3.18 场同步配置寄存器          |     |
| 32.3.19 行场同步偏移配置寄存器       |     |
| 32.3.20 当前显示位置寄存器         | 262 |
| 32.3.21 伽马校正目录寄存器         | 262 |
| 32.3.22 伽马校正值寄存器          | 262 |
| 32.3.23 光标0配置寄存器          |     |
| 32.3.24 光标 0 存储地址寄存器      | 263 |
| 32.3.25 光标0显示位置寄存器        | 263 |
| 32.3.26 单色光标0背景色寄存器       |     |
| 32.3.27 单色光标 0 前景色寄存器     | 264 |
| 32.3.28 光标 1 配置寄存器        | 264 |



| 32.3.30                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 32.3.29 光标 1 存储地址寄存器           | 264 |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|-----|
| 32. 3. 32 単色光标 1 前景色寄存器 26 32. 3. 33 HDMI 区域配置寄存器 26 32. 3. 34 HDMI 皮刺寄存器 26 32. 3. 35 Audio BUF 配置寄存器 26 32. 3. 35 Audio N 配置寄存器 26 32. 3. 37 Audio CTS 配置寄存器 26 32. 3. 39 Audio InfoFrame 配置寄存器 26 32. 3. 39 Audio InfoFrame 配置寄存器 26 32. 3. 40 Audio Sample 配置寄存器 26 32. 3. 41 HDMI PHY PHZ 配置寄存器 26 32. 3. 41 HDMI PHY PEC 寄存器 26 32. 3. 42 HDMI PHY PEC 寄存器 26 32. 3. 43 HDMI PHY PEC 寄存器 26 32. 3. 44 HDMI PHY PEC 寄存器 26 32. 3. 45 HDMI PHY PEC 寄存器 26 32. 3. 47 AVI 内容寄存器 26 32. 3. 48 HDMI PHY PEC 寄存器 26 32. 3. 47 AVI 内容寄存器 16 32. 3. 48 AVI InfoFrame 内容寄存器 2 32. 3. 48 AVI InfoFrame 内容寄存器 2 32. 3. 50 AVI InfoFrame 内容寄存器 2 32. 3. 50 AVI InfoFrame 内容寄存器 2 32. 3. 51 Vendor Specific InfoFrame 配置寄存器 27 32. 3. 51 Vendor Specific InfoFrame 配置寄存器 27 32. 3. 53 PLL_PIX 配置寄存器 27 32. 3. 54 PLL_PIX 配置寄存器 27 32. 3. 55 HDMI 热桶拔状态寄存器 27 32. 3. 56 HDMI 左声道状态寄存器 27 32. 3. 58 HDMI 左声道状态寄存器 27 32. 3. 58 HDMI 左声道状态寄存器 27 32. 3. 58 HDMI 右声道对户数据寄存器 27 32. 3. 58 HDMI 在声道状态寄存器 27 32. 3. 58 HDMI 右声道球态寄存器 27 32. 3. 58 HDMI 表面扩充声道状态寄存器 27 32. 3. 58 HDMI 在声道球态寄存器 27 34. 1 DMA 控制寄存器 27 34. 1 DMA 控制寄存器 27 34. 1 DMA 控制器 (D7:FO) 27 33. 1 HDA 配置寄存器 27 34. 1 DMA 控制器 (D7:FO) 27 34. 1 HDA 配置寄存器 27 34. 1 DMA 控制器 28 34. 7. 2 DMA 描述符 28 34. 7. 1 DMA 控制器结构描述 28 34. 7. 2 DMA 描述符 28 35. SATA 控制器 (D8:FO) 28                                                                                               | 32.3.30 光标 1 显示位置寄存器           | 264 |
| 32. 3. 34 HDMI 区域配置寄存器 26 32. 3. 35 Audio BUF 配置寄存器 26 32. 3. 36 Audio N 配置寄存器 26 32. 3. 36 Audio N 配置寄存器 26 32. 3. 38 Audio CTS 配置寄存器 26 32. 3. 38 Audio CTS 配置寄存器 26 32. 3. 39 Audio InfoFrame 配置寄存器 26 32. 3. 40 Audio Sample 配置寄存器 26 32. 3. 40 Audio Sample 配置寄存器 26 32. 3. 41 HDMI PHY PLL 配置寄存器 26 32. 3. 42 HDMI PHY PLL 配置寄存器 26 32. 3. 42 HDMI PHY PEC 寄存器 26 32. 3. 43 HDMI PHY PEC 寄存器 26 32. 3. 44 HDMI PHY PEC 寄存器 26 32. 3. 45 HDMI PHY PEC 寄存器 26 32. 3. 46 AVI InfoFrame 内容寄存器 26 32. 3. 46 AVI InfoFrame 内容寄存器 26 32. 3. 47 AVI 内容寄存器 26 32. 3. 49 AVI InfoFrame 内容寄存器 27 32. 3. 50 AVI InfoFrame 内容寄存器 27 32. 3. 50 AVI InfoFrame 内容寄存器 27 32. 3. 51 Vendor Specific InfoFrame 配置寄存器 27 32. 3. 53 PLL_PIX 配置寄存器 27 32. 3. 53 PLL_PIX 配置寄存器 27 32. 3. 53 PLL_PIX 配置寄存器 27 32. 3. 54 PLL_PIX 配置寄存器 27 32. 3. 55 HDMI 先歧状态寄存器 27 32. 3. 56 HDMI 左声道讯产数据寄存器 27 32. 3. 56 HDMI 左声道讯产数据寄存器 27 32. 3. 57 HDMI 左声道讯产数据寄存器 27 32. 3. 58 HDMI 右声道状态寄存器 27 32. 3. 59 HDMI 右声道状态寄存器 27 32. 3. 59 HDMI 右声道球态寄存器 27 32. 3. 59 HDMI 右声道球态寄存器 27 32. 3. 50 HDMI 左声道用户数据寄存器 27 32. 3. 50 HDMI 左声道用户数据寄存器 27 32. 3. 50 HDMI 左声道用户数据寄存器 27 32. 3. 50 HDMI 左声道用产数据寄存器 27 33. 1 HDA 腔刺器(D7:FO) 27 33. 1 HDA 配置寄存器 27 34. 1 PCICMD-PCI 命令寄存器 27 34. 1 PCICMD-PCI 命令寄存器 27 34. 1 PCICMD-PCI 命令寄存器 27 34. 1 DMA 控刺器 28 34. 7. 1 DMA 控刺器结构描述 28 34. 7. 1 DMA 控刺器结构描述 28 34. 7. 2 DMA 描述符 28 35. SATA 控刺器内部寄存器描述 28                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 32.3.31 单色光标 1 背景色寄存器          | 264 |
| 32. 3. 34 HDMI 控制寄存器 26 32. 3. 35 Audio BUP 配置寄存器 26 32. 3. 36 Audio N 配置寄存器 26 32. 3. 37 Audio CTS 配置寄存器 26 32. 3. 38 Audio CTS 配置寄存器 26 32. 3. 39 Audio InfoFrame 配置寄存器 26 32. 3. 40 Audio Sample 配置寄存器 26 32. 3. 41 HDMI PHY PEU 配置寄存器 26 32. 3. 41 HDMI PHY PPL 配置寄存器 26 32. 3. 43 HDMI PHY PECO 寄存器 26 32. 3. 43 HDMI PHY PECO 寄存器 26 32. 3. 44 HDMI PHY PECO 寄存器 26 32. 3. 45 HDMI PHY PECO 寄存器 26 32. 3. 46 AVI InfoFrame 内容寄存器 26 32. 3. 47 AVI 内容寄存器 1 26 32. 3. 47 AVI 内容寄存器 1 26 32. 3. 47 AVI 内容寄存器 2 26 32. 3. 49 AVI InfoFrame 内容寄存器 3 27 32. 3. 50 AVI InfoFrame 内容寄存器 3 27 32. 3. 50 AVI InfoFrame 控制寄存器 27 32. 3. 50 AVI InfoFrame 控制寄存器 27 32. 3. 50 AVI InfoFrame 控制寄存器 27 32. 3. 51 Vendor Specific InfoFrame 配置寄存器 27 32. 3. 53 PLL_PIX 配置寄存器 27 32. 3. 54 PLL_PIX 配置寄存器 27 32. 3. 54 PLL_PIX 配置寄存器 27 32. 3. 56 HDMI 左声道讯产数据寄存器 27 32. 3. 57 HDMI 左声道用户数据寄存器 27 32. 3. 58 HDMI 右声道状态寄存器 27 32. 3. 59 HDMI 右声道对状态寄存器 27 32. 3. 59 HDMI 右声道对状态寄存器 27 32. 3. 50 HDMI 右声道用户数据寄存器 27 32. 3. 50 HDMI 右声道对状态寄存器 27 32. 3. 50 HDMI 右声道对状态寄存器 27 32. 3. 50 HDMI 右声道形常寄存器 27 33. 1 HDA 控制寄存器 (D7:FO) 27 33. 1 HDA 控制寄存器 (D7:FO) 27 34. 1 Rot 控制寄存器 27 34. 1 ZE 控制寄存器 27 34. 1 ZE 控制寄存器 27 34. 1 ZE 处制器寄存器 27 34. 1 DMA 控制器 (D8:FO) 27 35. 1 SATA 控制器 (D8:FO) 28 35 SATA 控制器 (D8:FO) 28 35 SATA 控制器内部寄存器器 28 35. 2 SATA 控制器内部寄存器器 28                                                                                                                                                                                                                                                                                                                                                                                       | 32.3.32 单色光标 1 前景色寄存器          | 265 |
| 32. 3. 35 Audio BUF 配置寄存器 26 32. 3. 36 Audio N 配置寄存器 26 32. 3. 37 Audio CTS 配置寄存器 26 32. 3. 38 Audio CTS 配置寄存器 26 32. 3. 39 Audio InfoFrame 配置寄存器 26 32. 3. 40 Audio Sample 配置寄存器 26 32. 3. 41 IDMI PIIY 控制寄存器 26 32. 3. 41 IDMI PIIY 控制寄存器 26 32. 3. 42 IIDMI PIIY PLL配置寄存器 26 32. 3. 43 IDMI PIIY PLL配置寄存器 26 32. 3. 44 IDMI PIIY PECO 寄存器 26 32. 3. 45 IDMI PIIY PECO 寄存器 26 32. 3. 45 IDMI PIIY PECO 寄存器 26 32. 3. 46 AVI InfoFrame 内容寄存器 26 32. 3. 48 AVI InfoFrame 内容寄存器 27 32. 3. 48 AVI InfoFrame 内容寄存器 37 32. 3. 48 AVI InfoFrame 内容寄存器 37 32. 3. 50 AVI InfoFrame 内容寄存器 37 32. 3. 50 AVI InfoFrame 控制寄存器 27 32. 3. 51 Vendor Specific InfoFrame 配置寄存器 27 32. 3. 52 场同步计数寄存器 27 32. 3. 53 PLL_PIX配置寄存器 27 32. 3. 54 IDMI 基市道状态寄存器 27 32. 3. 56 IDMI 基市道状态寄存器 27 32. 3. 56 IDMI 左声道状态寄存器 27 32. 3. 59 IDMI 右声道用户数据寄存器 27 34. 3 PCICMD-PCI 命令寄存器 37 34. 1 IDA 配置寄存器 (D7:FO) 27 34. 1 核述 27 34. 1 EX 控制器 (D7:FO) 27 34. 1 核述 27 34. 1 EX 控制器 (D7:FO) 27 34. 1 核述 27 34. 2 IZS 配置寄存器 27 34. 3 PCICMD-PCI 命令寄存器 27 34. 3 PCICMD-PCI 命令寄存器 27 34. 4 IZS 控制器 67年器 27 34. 7 DMA 控制器 67年器 27 34. 7 DMA 控制器 67年器 27 34. 7 DMA 控制器 67年器 28 34. 7. 1 DMA 控制器 67年器 28 35. 1 SATA 控制器 678器 28 35. 2 SATA 22  | 32.3.33 HDMI 区域配置寄存器           | 265 |
| 32. 3. 36 Audio N 配置寄存器 26 32. 3. 37 Audio CTS 配置寄存器 26 32. 3. 38 Audio CTS Cal 配置寄存器 26 32. 3. 39 Audio InfoFrame 配置寄存器 26 32. 3. 40 Audio Sample 配置寄存器 26 32. 3. 40 Audio Sample 配置寄存器 26 32. 3. 41 HDMI PHY PED RET PET PET PET PET PET PET PET PET PET P                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 32.3.34 HDMI 控制寄存器             | 265 |
| 32. 3. 37 Audio CTS 配置寄存器 26 32. 3. 38 Audio CTS Cal 配置寄存器 26 32. 3. 39 Audio InfoFrame 配置寄存器 26 32. 3. 40 Audio Sample 配置寄存器 26 32. 3. 41 HDMI PHY 控制寄存器 26 32. 3. 42 HDMI PHY PLL 配置寄存器 26 32. 3. 43 HDMI PHY PLL 配置寄存器 26 32. 3. 43 HDMI PHY PECO 寄存器 26 32. 3. 44 HDMI PHY PECO 寄存器 26 32. 3. 45 HDMI PHY PECO 寄存器 26 32. 3. 46 AVI InfoFrame 内容寄存器 0 26 32. 3. 47 AVI 内容寄存器 1 26 32. 3. 48 AVI InfoFrame 内容寄存器 2 26 32. 3. 49 AVI InfoFrame 内容寄存器 2 26 32. 3. 49 AVI InfoFrame 内容寄存器 3 27 32. 3. 51 Vendor Specific InfoFrame 配置寄存器 27 32. 3. 51 Vendor Specific InfoFrame 配置寄存器 27 32. 3. 52 均同步计数寄存器 27 32. 3. 53 PLL_PIX 配置寄存器 1 27 32. 3. 55 HDMI 热插技状态寄存器 27 32. 3. 56 HDMI 左声道用户数据寄存器 27 32. 3. 56 HDMI 左声道用户数据寄存器 27 32. 3. 58 HDMI 右声道用户数据寄存器 27 32. 3. 59 HDMI 右声道用冷数据寄存器 27 32. 3. 59 HDMI 右声道用冷数据寄存器 27 32. 3. 59 HDMI 右声道用冷数据寄存器 27 32. 3. 59 HDMI 右声道形 右声道形 57器 27 32 34 4 4 128 配置寄存器 27 34. 128 配置寄存器 27 34. 14 概述 27 34. 128 配置寄存器 27 34. 1 RW述 27 34. 1 RW 注册寄存器 27 34. 1 RW 注册寄存存器 27 34. 1 RW 注册寄存器 28 35. SATA 控制器 6D8 FO) 28                                                                                                                                                                                                                                                 | 32.3.35 Audio BUF 配置寄存器        | 266 |
| 32. 3. 37 Audio CTS 配置寄存器 26 32. 3. 38 Audio CTS Cal 配置寄存器 26 32. 3. 39 Audio InfoFrame 配置寄存器 26 32. 3. 40 Audio Sample 配置寄存器 26 32. 3. 41 HDMI PHY 控制寄存器 26 32. 3. 42 HDMI PHY PLL 配置寄存器 26 32. 3. 43 HDMI PHY PLL 配置寄存器 26 32. 3. 43 HDMI PHY PECO 寄存器 26 32. 3. 44 HDMI PHY PECO 寄存器 26 32. 3. 45 HDMI PHY PECO 寄存器 26 32. 3. 46 AVI InfoFrame 内容寄存器 0 26 32. 3. 47 AVI 内容寄存器 1 26 32. 3. 48 AVI InfoFrame 内容寄存器 2 26 32. 3. 49 AVI InfoFrame 内容寄存器 2 26 32. 3. 49 AVI InfoFrame 内容寄存器 3 27 32. 3. 51 Vendor Specific InfoFrame 配置寄存器 27 32. 3. 51 Vendor Specific InfoFrame 配置寄存器 27 32. 3. 52 均同步计数寄存器 27 32. 3. 53 PLL_PIX 配置寄存器 1 27 32. 3. 55 HDMI 热插技状态寄存器 27 32. 3. 56 HDMI 左声道用户数据寄存器 27 32. 3. 56 HDMI 左声道用户数据寄存器 27 32. 3. 58 HDMI 右声道用户数据寄存器 27 32. 3. 59 HDMI 右声道用冷数据寄存器 27 32. 3. 59 HDMI 右声道用冷数据寄存器 27 32. 3. 59 HDMI 右声道用冷数据寄存器 27 32. 3. 59 HDMI 右声道形 右声道形 57器 27 32 34 4 4 128 配置寄存器 27 34. 128 配置寄存器 27 34. 14 概述 27 34. 128 配置寄存器 27 34. 1 RW述 27 34. 1 RW 注册寄存器 27 34. 1 RW 注册寄存存器 27 34. 1 RW 注册寄存器 28 35. SATA 控制器 6D8 FO) 28                                                                                                                                                                                                                                                 | 32.3.36 Audio N 配置寄存器          | 266 |
| 32. 3. 38 Audio CTS Cal 配置寄存器 26 32. 3. 49 Audio InfoFrame 配置寄存器 26 32. 3. 40 Audio Sample 配置寄存器 26 32. 3. 41 HDMI PHY PED 常存器 26 32. 3. 42 HDMI PHY PLL配置寄存器 26 32. 3. 43 HDMI PHY PECO 寄存器 26 32. 3. 44 HDMI PHY PECO 寄存器 26 32. 3. 45 HDMI PHY PECI 寄存器 26 32. 3. 46 AVI InfoFrame 内容寄存器 26 32. 3. 47 AVI 内容寄存器 1 26 32. 3. 48 AVI InfoFrame 内容寄存器 2 26 32. 3. 49 AVI InfoFrame 内容寄存器 2 26 32. 3. 49 AVI InfoFrame 内容寄存器 2 26 32. 3. 50 AVI InfoFrame 控制寄存器 27 32. 3. 50 AVI InfoFrame 控制寄存器 27 32. 3. 51 Vendor Specific InfoFrame 配置寄存器 27 32. 3. 53 PLL_PIX 配置寄存器 27 32. 3. 54 PLL_PIX 配置寄存器 27 32. 3. 55 HDMI 热插技状态寄存器 27 32. 3. 56 HDMI 左声道状态寄存器 27 32. 3. 57 HDMI 左声道状态寄存器 27 32. 3. 58 HDMI 右声道状态寄存器 27 32. 3. 59 HDMI 右声道状态寄存器 27 32. 3. 59 HDMI 右声道状态寄存器 27 32. 3. 59 HDMI 右声道状态寄存器 27 32. 3. 50 HDMI 右声道状态寄存器 27 32. 3. 50 HDMI 右声道形户数据寄存器 27 32. 3. 50 HDMI 右声道形分寄存器 27 33. 4 HDA 控制寄存器描述 27 34. 12S 控制器 (D7:FO) 27 34. 1 R达 控制器 (D7:FO) 27 34. 1 R达 控制器 (D7:FO) 27 34. 1 R达 控制器 (D7:FO) 27 34. 1 PMA 控制器 (D7:FO) 27 34. 1 PMA 控制器 (D7:FO) 27 35. 1 HDA 控制 李存器 27 34. 3 PCICMD-PCI 命令 李器 27 34. 4 12S 控制器 (D7:FO) 27 34. 1 PMA 控制器 (D7:FO) 27 35. 1 HDA 控制器 (D7:FO) 27 36. 1 RMA 控制器 (D7:FO) 27 37 38. 1 HDA 控制 李存器 27 39. 3 FULM 控制 李存器 27 30. 3 FULM 控制 李存器 27 31. 3 FULM 控制 李存器 27 32. 3 FULM 控制 李存器 27 33. 3 FULM 控制 李存器 27 34. 4 12S 控制器 (D7:FO) 27 35. 3 HDA 控制 李存器 27 36. 4 12S 控制器 (D7:FO) 27 37 38. 4 12S 控制器 (D7:FO) 27 39. 5 DMA 控制器 李存器 27 30. 5 DMA 控制器 李存器 27 31. 5 DMA 命令 李存器 27 32. 5 DMA 控制器 李存器 27 33. 5 DMA 控制器 李存器 27 34. 5 DMA 控制器 李存器 27 35. 5 ATA 控制器 (D8:FO) 28                                                                                                         |                                |     |
| 32. 3. 39 Audio InfoFrame 配置寄存器 26 32. 3. 40 Audio Sample 配置寄存器 26 32. 3. 41 HDMI PHY 控制寄存器 26 32. 3. 42 HDMI PHY PLE 配置寄存器 26 32. 3. 43 HDMI PHY PECO 寄存器 26 32. 3. 44 HDMI PHY PECO 寄存器 26 32. 3. 44 HDMI PHY PECO 寄存器 26 32. 3. 45 HDMI PHY PECO 寄存器 26 32. 3. 46 AVI InfoFrame 内容寄存器 26 32. 3. 47 AVI 内容寄存器 1 26 32. 3. 48 AVI InfoFrame 内容寄存器 2 26 32. 3. 49 AVI InfoFrame 内容寄存器 3 27 32. 3. 50 AVI InfoFrame 营存器 27 32. 3. 51 Vendor Specific InfoFrame 配置寄存器 27 32. 3. 51 Vendor Specific InfoFrame 配置寄存器 27 32. 3. 52 场间步计数寄存器 27 32. 3. 53 PLL_PIX 配置寄存器 1 27 32. 3. 55 HDMI 热插拨状态寄存器 27 32. 3. 56 HDMI 左声道状态寄存器 27 32. 3. 56 HDMI 左声道状态寄存器 27 32. 3. 57 HDMI 左声道状态寄存器 27 32. 3. 58 HDMI 右声道状态寄存器 27 32. 3. 58 HDMI 右声道线态寄存器 27 32. 3. 58 HDMI 右声道状态寄存器 27 32. 3. 59 HDMI 右声道状态寄存器 27 32. 3. 59 HDMI 右声道状态寄存器 27 32. 3. 59 HDMI 右声道状态寄存器 27 32. 3. 50 HDMI 控制器 27 34. 1 HDA 配置寄存器 27 34. 1 HDA 配置寄存器 27 34. 2 IDS 配置寄存器 27 34. 3 PCICMD-PCI 命令寄存器 27 34. 3 PCICMD-PCI 命令寄存器 27 34. 3 PCICMD-PCI 命令寄存器 27 34. 4 IZS 控制器寄存器 27 34. 5 DMA 命令存器 27 34. 7 DMA 控制器寄存器 27 34. 7 DMA 控制器寄存器 28 34. 7. 1 DMA 控制器结构描述 28 34. 7. 1 DMA 控制器结构描述 28 34. 7. 1 DMA 控制器结构描述 28 35. 2 SATA 控制器内部等存器器描述 28 35. 2 SATA 控制器内部等存器描述 28 35. 2 SATA 控制器内部等存器 28 35. 2 SATA 控制器内部等存器描述 28 35. 2 SATA 控制器内部等存器描述 28 35. 2 SATA 控制器内部等存器描述 28 35. 2 SATA 控制器内部等存器 28 35. 2 SATA 控制器内部等存置 28 35. 2 SATA 控制器内部等存 |                                |     |
| 32. 3. 40 Audio Sample 配置寄存器 26 32. 3. 41 HDMI PHY Pk制寄存器 26 32. 3. 42 HDMI PHY PLL 配置寄存器 26 32. 3. 43 HDMI PHY PLL 配置寄存器 26 32. 3. 44 HDMI PHY PEC0 寄存器 26 32. 3. 45 HDMI PHY PEC1 寄存器 26 32. 3. 45 HDMI PHY PEC2 寄存器 26 32. 3. 46 AVI InfoFrame 内容寄存器 0. 26 32. 3. 47 AVI 内容寄存器 1 26 32. 3. 48 AVI InfoFrame 内容寄存器 2 26 32. 3. 49 AVI InfoFrame 内容寄存器 3 27 32. 3. 50 AVI InfoFrame 内容寄存器 27 32. 3. 51 Vendor Specific InfoFrame 置寄存器 27 32. 3. 51 Vendor Specific InfoFrame 置寄存器 27 32. 3. 52 场同步计数寄存器 27 32. 3. 53 PLL PIX 配置寄存器 1 27 32. 3. 55 HDMI 左声道状态寄存器 27 32. 3. 55 HDMI 左声道状态寄存器 27 32. 3. 56 HDMI 左声道状态寄存器 27 32. 3. 57 HDMI 左声道状态寄存器 27 32. 3. 58 HDMI 右声道状态寄存器 27 32. 3. 59 HDMI 右声道射户数据寄存器 27 32. 3. 60 中断寄存器 27 32. 3. 60 中断寄存器 27 32. 3. 60 中断寄存器 27 33. 1 HDA 控制器 (D7:FC) 27 33. 1 HDA 配置寄存器 (D7:FC) 27 34. 1 根述 27 34. 1 及种器 (D7:FC) 27 34. 1 根述 27 34. 2 I2S 配置寄存器 27 34. 3 PCICMD-PCI 命令寄存器 27 34. 3 PCICMD-PCI 命令寄存器 27 34. 4 I2S 控制器 67器 27 34. 5 DMA 命令寄存器 27 34. 7 DMA 控制器 48 控制器 48 控制器 28 34. 7. 1 DMA 控制器结构描述 28 34. 7. 1 DMA 控制器 28 34. 7. 1 DMA 控制器 28 34. 7. 1 DMA 控制器 28 35. SATA 控制器 (D8:FC) 28 35. SATA 控制器 67器 28 35. SATA 控制器 67器 28 35. SATA 控制器 67器 28 35. SATA 控制器 78 PMA 28 PM |                                |     |
| 32. 3. 41 HDMI PHY PLL 配置寄存器 26 32. 3. 42 HDMI PHY PLL 配置寄存器 26 32. 3. 43 HDMI PHY PECO 寄存器 26 32. 3. 44 HDMI PHY PECO 寄存器 26 32. 3. 45 HDMI PHY PECO 寄存器 26 32. 3. 45 HDMI PHY PECO 寄存器 26 32. 3. 46 AVI InfoFrame 内容寄存器 0 26 32. 3. 47 AVI 内容寄存器 1 26 32. 3. 48 AVI InfoFrame 内容寄存器 2 26 32. 3. 49 AVI InfoFrame 内容寄存器 3 27 32. 3. 50 AVI InfoFrame 控制寄存器 27 32. 3. 50 AVI InfoFrame 控制寄存器 27 32. 3. 51 Vendor Specific InfoFrame 配置寄存器 27 32. 3. 51 Vendor Specific InfoFrame 配置寄存器 27 32. 3. 53 PLL_PIX 配置寄存器 0 27 32. 3. 53 PLL_PIX 配置寄存器 0 27 32. 3. 55 HDMI 热插技状态寄存器 27 32. 3. 55 HDMI 左声道状态寄存器 27 32. 3. 55 HDMI 左声道用户数据寄存器 27 32. 3. 56 HDMI 左声道用户数据寄存器 27 32. 3. 58 HDMI 右声道状态寄存器 27 32. 3. 50 HDMI 右声道用产数据寄存器 27 32. 3. 50 HDMI 右声道状态寄存器 27 32. 3. 50 HDMI 右声道状态寄存器 27 32. 3. 50 HDMI 左声道用户数据寄存器 27 32. 3. 50 HDMI 右声道状态寄存器 27 32. 3. 50 HDMI 右声道水态寄存器 27 32. 3. 50 HDMI 左声道用户数据寄存器 27 34. 1 HDA 配置寄存器 (D7:FO) 27 33. 1 HDA 配置寄存器 27 34. 1 ZIS 配置寄存器 27 34. 2 IZS 配置寄存器 27 34. 3 PCICMD-PCI 命令寄存器 27 34. 4 IZS 控制器寄存器 27 34. 5 DMA 命令寄存器 27 34. 7 DMA 控制器寄存器 28 35. SATA 控制器内部寄存器描述 28                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                |     |
| 32. 3. 42 HDMI PHY PLL 配置寄存器 26 32. 3. 43 HDMI PHY PEC0 寄存器 26 32. 3. 44 HDMI PHY PEC1 寄存器 26 32. 3. 45 HDMI PHY PEC2 寄存器 26 32. 3. 46 AVI InfoFrame 内容寄存器 0. 26 32. 3. 47 AVI 内容寄存器 1. 26 32. 3. 48 AVI InfoFrame 内容寄存器 2. 26 32. 3. 49 AVI InfoFrame 内容寄存器 2. 26 32. 3. 49 AVI InfoFrame 内容寄存器 2. 27 32. 3. 50 AVI InfoFrame 控制寄存器 27 32. 3. 51 Vendor Specific InfoFrame配置寄存器 27 32. 3. 51 Vendor Specific InfoFrame配置寄存器 27 32. 3. 52 场同步计数寄存器 27 32. 3. 52 场同步计数寄存器 27 32. 3. 54 PLL_PIX配置寄存器 0. 27 32. 3. 55 HDMI 左声道状态寄存器 27 32. 3. 55 HDMI 左声道状态寄存器 27 32. 3. 56 HDMI 左声道用户数据寄存器 27 32. 3. 58 HDMI 右声道用户数据寄存器 27 32. 3. 59 HDMI 右声道用户数据寄存器 27 32. 3. 50 HDMI 右声道用户数据寄存器 27 32. 3. 50 HDMI 右声道用户数据寄存器 27 32. 3. 50 HDMI 右声道用户数据寄存器 27 32. 3. 60 中断寄存器 27 33. 1 HDA配置寄存器 27 34. 1 Mt基 27 34. 1 EX 控制器 (D7:FO) 27 34. 1 LDX 控制器 (D7:FI) 27 34. 1 LDX 控制器 (D7:FI) 27 34. 1 LDX 控制器 27 34. 1 LDX 控制器 27 34. 1 LDX 控制器 27 34. 2 LDX 控制器 27 34. 3 PCICMD-PCI 命令寄存器 27 34. 4 LDX 控制器 27 34. 5 DMA 命令寄存器 27 34. 5 DMA 命令寄存器 27 34. 7 DMA 控制器音存器 27 34. 7 DMA 控制器 28 34. 7 LDMA 控制器结构描述 28 34. 7 DMA 控制器 28 35. SATA 控制器 (D8:FO) 28 35. SATA 控制器 (D8:FO) 28 35. SATA 控制器 (D8:FO) 28 35. L SATA 控制器 (D8:FO) 28 35. SATA 控制器 (D8:FO) 28                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                |     |
| 32. 3. 43 HDMI PHY PECO 寄存器 26 32. 3. 44 HDMI PHY PECI 寄存器 26 32. 3. 45 HDMI PHY PECI 寄存器 26 32. 3. 46 AVI InfoFrame 内容寄存器 26 32. 3. 47 AVI 内容寄存器 1 26 32. 3. 48 AVI InfoFrame 内容寄存器 2 26 32. 3. 49 AVI InfoFrame 内容寄存器 2 26 32. 3. 49 AVI InfoFrame 内容寄存器 3 27 32. 3. 50 AVI InfoFrame 控制寄存器 27 32. 3. 51 Vendor Specific InfoFrame 配置寄存器 27 32. 3. 51 Vendor Specific InfoFrame 配置寄存器 27 32. 3. 55 HDMI 与进计数寄存器 27 32. 3. 55 HDMI 热插拔状态寄存器 27 32. 3. 55 HDMI 左声进状态寄存器 27 32. 3. 55 HDMI 左声进状态寄存器 27 32. 3. 57 HDMI 左声进时户数据寄存器 27 32. 3. 59 HDMI 右声道用户数据寄存器 27 34. 1 HDA 配置寄存器 (D7:FO) 27 33. 1 HDA 配置寄存器 (D7:FO) 27 34. 1 Kt  35 HDA 控制器 (D7:FI) 27 34. 1 Kt  36. 1 ESI 整制器 (D7:FI) 27 34. 1 Rt  37 36. 1 ESI 整制器 (D7:FI) 27 37 37 38. 1 DMA 检制器 (D7:FI) 27 38. 1 DMA 检制器 27 38. 1 DMA 检制器 27 38. 1 DMA 检制器 (D7:FI) 27 39 30. 1 DMA 控制器 (D7:FI) 27 31. 1 MM 整制器 (D7:FI) 27 31. 1 MM 整制器 (D7:FI) 27 32. 1 DMA 控制器 (D7:FI) 27 33. 1 DMA 检制器 (D7:FI) 27 34. 1 ESI 配置寄存器 27 35. 1 DMA 检制器 (D7:FI) 27 36. 1 ESI 配置寄存器 27 37 38. 2 DMA 控制器 (D8:FO) 28 35. 2 SATA 控制器 (D8:FO) 28                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                |     |
| 32. 3. 44 HDMI PHY PEC1 寄存器 26 32. 3. 45 HDMI PHY PEC2 寄存器 26 32. 3. 46 AVI InfoFrame 内容寄存器 0 26 32. 3. 47 AVI 内容寄存器 1 26 32. 3. 48 AVI InfoFrame 内容寄存器 2 26 32. 3. 49 AVI InfoFrame 内容寄存器 3 27 32. 3. 50 AVI InfoFrame 控制寄存器 27 32. 3. 51 Vendor Specific InfoFrame配置寄存器 27 32. 3. 52 场同步计数寄存器 27 32. 3. 53 PLL_PIX配置寄存器 27 32. 3. 54 PLL_PIX配置寄存器 0 27 32. 3. 55 HDMI 热插技状态寄存器 27 32. 3. 55 HDMI 左声道状态寄存器 27 32. 3. 56 HDMI 左声道用户数据寄存器 27 32. 3. 59 HDMI 右声道用户数据寄存器 27 32. 3. 59 HDMI 右声道用户数据寄存器 27 32. 3. 50 中断寄存器 27 32. 3. 50 中断寄存器 27 32. 3. 50 中断寄存器 27 32. 3. 60 中断寄存器 27 32. 3. 60 中断寄存器 27 33. 1 HDA 配置寄存器 (D7:FO) 27 33. 1 HDA 配置寄存器 (D7:FO) 27 34. 1 概述 27 34. 1 聚述 27 34. 1 区配置寄存器 27 34. 2 I2S配置寄存器 27 34. 3 PCICMD→PCI 命令寄存器 27 34. 4 I2S 控制器 (D7:F1) 27 34. 1 概述 27 34. 1 程达 27 34. 1 程达 27 34. 1 程达 27 34. 1 双达 27 34. 1 和达 27 34. 2 I2S 配置寄存器 27 34. 3 PCICMD→PCI 命令寄存器 27 34. 4 I2S 控制器 (D7:F1) 27 34. 1 和达 27 34. 1 和达 27 34. 1 和达 27 34. 2 I2S 配置寄存器 27 34. 5 DMA 命令寄存器 27 34. 7 DMA 控制器 28 34. 7 . 1 DMA 控制器 28 34. 7 . 2 DMA 描述符 28 35. SATA 控制器 (D8:FO) 28 35. SATA 控制器 (D8:FO) 28 35. 1 SATA 控制器 (D8:FO) 28 35. 2 SATA 控制器 (D8:FO) 28 35. 2 SATA 控制器 (D8:FO) 28 35. 2 SATA 控制器 (D8:FO) 28                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                |     |
| 32. 3. 45 HDMI PHY PEC2 寄存器 26 32. 3. 46 AVI InfoFrame 内容寄存器 0. 26 32. 3. 47 AVI 内容寄存器 1. 26 32. 3. 48 AVI InfoFrame 内容寄存器 2. 26 32. 3. 49 AVI InfoFrame 内容寄存器 2. 26 32. 3. 49 AVI InfoFrame 内容寄存器 3. 27 32. 3. 50 AVI InfoFrame 控制寄存器 2. 27 32. 3. 51 Vendor Specific InfoFrame 配置寄存器 2.7 32. 3. 52 场同步计数寄存器 2.7 32. 3. 53 PLL_PIX 配置寄存器 0. 27 32. 3. 54 PLL_PIX 配置寄存器 1. 27 32. 3. 55 HDMI 热捕拔状态寄存器 2.7 32. 3. 55 HDMI 左声道状态寄存器 2.7 32. 3. 55 HDMI 左声道状态寄存器 2.7 32. 3. 57 HDMI 左声道状态寄存器 2.7 32. 3. 59 HDMI 右声道用户数据寄存器 2.7 32. 3. 59 HDMI 右声道形态寄存器 2.7 32. 3. 60 中断寄存器 2.7 32. 3. 60 中断寄存器 2.7 32. 3. 60 中断寄存器 2.7 32. 3. 1 HDA 控制器 (D7:F0) 2.7 33. 1 HDA 枢型寄存器 (D7:F0) 2.7 33. 1 HDA 枢型寄存器 (D7:F0) 2.7 34. 1 概述 2.7 34. 1 聚达 2 IZS 配置寄存器 2.7 34. 2 IZS 配置寄存器 2.7 34. 3 PCICMD-PCI 命令寄存器 2.7 34. 4 IZS 控制器 6.7 34. 7 DMA 控制器 2.7 34. 7 DMA 控制器 2.8 34. 7. 2 DMA 描述符 2.8 34. 7. 1 DMA 控制器结构描述 2.8 34. 7. 2 DMA 描述符 2.8 35. 2 SATA 控制器 (D8:F0) 2.8 35. 1 SATA 控制器 (D8:F0) 2.8 35. 1 SATA 控制器 (D8:F0) 2.8 35. 2 SATA 控制器 (D8:F0) 2.8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                |     |
| 32. 3. 46 AVI InfoFrame 内容寄存器 0. 26 32. 3. 47 AVI 内容寄存器 1 26 32. 3. 48 AVI InfoFrame 内容寄存器 2 26 32. 3. 49 AVI InfoFrame 内容寄存器 3 27 32. 3. 50 AVI InfoFrame 内容寄存器 3 27 32. 3. 50 AVI InfoFrame 控制寄存器 27 32. 3. 51 Vendor Specific InfoFrame 配置寄存器 27 32. 3. 52 が同步计数寄存器 27 32. 3. 55 PLL_PIX 配置寄存器 0 27 32. 3. 53 PLL_PIX 配置寄存器 1 27 32. 3. 55 HDMI 热捕技状态寄存器 27 32. 3. 56 HDMI 左声道状态寄存器 27 32. 3. 57 HDMI 左声道用户数据寄存器 27 32. 3. 58 HDMI 右声道状态寄存器 27 32. 3. 59 HDMI 右声道形户数据寄存器 27 32. 3. 60 中断寄存器 27 33. 1 HDA 配置寄存器 (D7:F0) 27 33. 1 HDA 配置寄存器 (D7:F0) 27 34. 1 概述 27 34. 1 概述 27 34. 1 权法 27 34. 1 权法 27 34. 1 权法 27 34. 1 权法 27 34. 1 程序存器 27 34. 1 图                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                |     |
| 32. 3. 47 AVI 内容寄存器 1 26 32. 3. 48 AVI InfoFrame 内容寄存器 2 26 32. 3. 49 AVI InfoFrame 内容寄存器 3 27 32. 3. 50 AVI InfoFrame 内容寄存器 3 27 32. 3. 51 Vendor Specific InfoFrame 配置寄存器 27 32. 3. 51 Vendor Specific InfoFrame 配置寄存器 27 32. 3. 52 场同步计数寄存器 27 32. 3. 53 PLL_PIX配置寄存器 0 27 32. 3. 53 PLL_PIX配置寄存器 1 27 32. 3. 55 HDMI 热捕拔状态寄存器 27 32. 3. 56 HDMI 左声道状态寄存器 27 32. 3. 57 HDMI 左声道状态寄存器 27 32. 3. 58 HDMI 右声道状态寄存器 27 32. 3. 59 HDMI 右声道状态寄存器 27 32. 3. 59 HDMI 右声道状态寄存器 27 32. 3. 60 中断寄存器 27 32. 3. 60 中断寄存器 27 33. 1 HDA 腔間寄存器 (D7:FO) 27 33. 1 HDA 配置寄存器 (D7:FO) 27 34. 1 权法 27 34. 1 程序 27 34. 1 权法 27 34. 1 程序 27 34. 1 权法 27 34. 1 程序 27 34. 1 程序 27 34. 1 权法 27 34. 1 程序 27 34. 1 TOMA 控制器 28 34. 7 DMA 控制器 28 34. 7. 2 DMA 描述符 28 34. 7. 1 DMA 控制器结构描述 28 34. 7. 2 DMA 描述符 28 35. SATA 控制器 (D8:FO) 28 35. 1 SATA 控制器 (D8:FO) 28 35. 2 SATA 控制器 (D8:FO) 28                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                |     |
| 32.3.48 AVI InfoFrame 内容寄存器 2.       26         32.3.49 AVI InfoFrame 内容寄存器 3.       27         32.3.50 AVI InfoFrame 控制寄存器       27         32.3.51 Vendor Specific InfoFrame 配置寄存器       27         32.3.52 场同步计数寄存器       27         32.3.55 PLL_PIX 配置寄存器 0.       27         32.3.54 PLL_PIX 配置寄存器 1.       27         32.3.55 IDMI 热插技状态寄存器       27         32.3.56 HDMI 左声道状态寄存器       27         32.3.57 HDMI 左声道用户数据寄存器       27         32.3.59 HDMI 右声道状态寄存器       27         32.3.59 HDMI 右声道用户数据寄存器       27         33.1 HDA 控制器 (D7:F0)       27         33.2 HDA 控制器 (D7:F0)       27         33.2 HDA 控制寄存器描述       27         34.1 医控制器 (D7:F1)       27         34.2 I2S 配置寄存器       27         34.3 PCICMD-PCI 命令寄存器       27         34.4 I2S 控制器寄存器       27         34.5 DMA 命令寄存器       27         34.7 DMA 控制器       28         34.7 DMA 控制器       28         34.7 DMA 控制器       28         35.1 SATA 控制器内部寄存器描述       28         35.2 SATA 控制器内部寄存器描述       28         35.2 SATA 控制器内部寄存器描述       28                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                |     |
| 32. 3. 49 AVI InfoFrame 內容寄存器 3       27         32. 3. 50 AVI InfoFrame 控制寄存器       27         32. 3. 51 Vendor Specific InfoFrame 配置寄存器       27         32. 3. 52 场同步计数寄存器       27         32. 3. 53 PLL_PIX 配置寄存器 0       27         32. 3. 54 PLL_PIX 配置寄存器 1       27         32. 3. 55 HDMI 热插技状态寄存器       27         32. 3. 56 HDMI 左声道状态寄存器       27         32. 3. 57 HDMI 左声道用户数据寄存器       27         32. 3. 58 HDMI 右声道用户数据寄存器       27         32. 3. 59 HDMI 右声道用户数据寄存器       27         32. 3. 60 中断寄存器       27         33. 1 HDA 控制器 (D7:F0)       27         33. 2 HDA 控制寄存器描述       27         34 12S 控制器 (D7:F1)       27         34. 1 IX       27         34. 2 IX       28         34. 3 PCICMD-PCI 命令寄存器       27         34. 4 IX       28         34. 7 DMA 控制器       28         34. 7 DMA 控制器       28         34. 7 DMA 控制器       28         35. SATA 控制器       28                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                |     |
| 32.3.50 AVI InfoFrame 控制寄存器       27         32.3.51 Vendor Specific InfoFrame 配置寄存器       27         32.3.52 场同步计数寄存器       27         32.3.53 PLL_PIX 配置寄存器 0       27         32.3.54 PLL_PIX 配置寄存器 1       27         32.3.55 HDMI 热插拔状态寄存器       27         32.3.56 HDMI 左声道状态寄存器       27         32.3.57 HDMI 左声道用户数据寄存器       27         32.3.59 HDMI 右声道用户数据寄存器       27         32.3.59 HDMI 右声道用户数据寄存器       27         32.3.60 中断寄存器       27         33.1 HDA 控制器 (D7:F0)       27         33.2 HDA 控制寄存器描述       27         34.1 [2S 控制器 (D7:F1)       27         34.2 I2S 配置寄存器       27         34.3 PCICMD-PCI 命令寄存器       27         34.4 I2S 控制器寄存器       27         34.5 DMA 命令寄存器       27         34.7 DMA 控制器       28         34.7.1 DMA 控制器       28         34.7.2 DMA 描述符       28         35. SATA 控制器 (D8:F0)       28         35.1 SATA 控制器内部寄存器描述       28         35.2 SATA 控制器内部寄存器描述       28                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                |     |
| 32.3.51 Vendor Specific InfoFrame配置寄存器       27         32.3.52 场同步计数寄存器       27         32.3.53 PLL_PIX 配置寄存器 0       27         32.3.54 PLL_PIX 配置寄存器 1       27         32.3.55 HDMI 热插拔状态寄存器       27         32.3.56 HDMI 左声道状态寄存器       27         32.3.57 HDMI 左声道用户数据寄存器       27         32.3.59 HDMI 右声道用户数据寄存器       27         32.3.60 中断寄存器       27         33.1 HDA 控制器 (D7:F0)       27         33.2 HDA 控制器 (D7:F0)       27         33.2 HDA 控制寄存器描述       27         34.12 控制器 (D7:F1)       27         34.1 概述       27         34.2 I2S 配置寄存器       27         34.3 PCICMD-PCI 命令寄存器       27         34.4 I2S 控制器寄存器       27         34.5 DMA 命令寄存器       27         34.7 DMA 控制器       28         34.7.2 DMA 描述符       28         35. SATA 控制器 (D8:F0)       28         35.1 SATA 控制器内部寄存器描述       28         35.2 SATA 控制器内部寄存器描述       28         35.2 SATA 控制器内部寄存器描述       28                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                |     |
| 32. 3. 52 场同步计数寄存器       27         32. 3. 53 PLL_PIX 配置寄存器 0       27         32. 3. 54 PLL_PIX 配置寄存器 1       27         32. 3. 55 HDMI 热插拔状态寄存器       27         32. 3. 56 HDMI 左声道状态寄存器       27         32. 3. 57 HDMI 左声道用户数据寄存器       27         32. 3. 59 HDMI 右声道状态寄存器       27         32. 3. 60 中断寄存器       27         33. 1 HDA 腔間寄存器 (D7:FO)       27         33. 2 HDA 控制器 (D7:FO)       27         34. 12S 控制器 (D7:F1)       27         34. 1 概述       27         34. 2 I2S 配置寄存器       27         34. 3 PCICMD-PCI 命令寄存器       27         34. 4 12S 控制器寄存器       27         34. 5 DMA 命令寄存器       27         34. 6 配置操作       28         34. 7. 1 DMA 控制器       28         34. 7. 2 DMA 描述符       28         35. SATA 控制器 (D8:FO)       28         35. 1 SATA 控制器 (D8:FO)       28         35. 2 SATA 控制器内部寄存器描述       28         35. 2 SATA 控制器内部寄存器描述       28                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                |     |
| 32. 3. 53 PLL_PIX 配置寄存器 0       27         32. 3. 54 PLL_PIX 配置寄存器 1       27         32. 3. 55 HDMI 热插拔状态寄存器       27         32. 3. 56 HDMI 左声道状态寄存器       27         32. 3. 57 HDMI 左声道用户数据寄存器       27         32. 3. 59 HDMI 右声道状态寄存器       27         32. 3. 60 中断寄存器       27         33. 1 HDA 控制器 (D7:F0)       27         33. 2 HDA 控制器 (D7:F0)       27         33. 2 HDA 控制器 (D7:F1)       27         34. 1 經述       27         34. 2 I2S 配置寄存器       27         34. 3 PCICMD-PCI 命令寄存器       27         34. 4 I2S 控制器寄存器       27         34. 5 DMA 命令寄存器       27         34. 7 DMA 控制器       28         34. 7. 1 DMA 控制器       28         34. 7. 2 DMA 描述符       28         35. SATA 控制器 (D8:F0)       28         35. 1 SATA 控制器 (D8:F0)       28         35. 2 SATA 控制器内部寄存器描述       28                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                |     |
| 32.3.54 PLL_PIX 配置寄存器 1       27         32.3.55 HDMI 热插拔状态寄存器       27         32.3.56 HDMI 左声道状态寄存器       27         32.3.57 HDMI 左声道用户数据寄存器       27         32.3.58 HDMI 右声道状态寄存器       27         32.3.59 HDMI 右声道用户数据寄存器       27         32.3.60 中断寄存器       27         33.1 HDA 控制器 (D7:F0)       27         33.2 HDA 控制器 (D7:F0)       27         33.2 HDA 控制器 (D7:F1)       27         34.1 概述       27         34.2 I2S 配置寄存器       27         34.3 PCICMD-PCI 命令寄存器       27         34.4 I2S 控制器寄存器       27         34.5 DMA 命令寄存器       27         34.7 DMA 控制器       28         34.7.1 DMA 控制器       28         34.7.2 DMA 描述符       28         35 SATA 控制器 (D8:F0)       28         35.1 SATA 配置寄存器       28         35.2 SATA 控制器内部寄存器描述       28         35.2 SATA 控制器内部寄存器描述       28                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                |     |
| 32. 3. 55 HDMI 热插拔状态寄存器       27         32. 3. 56 HDMI 左声道状态寄存器       27         32. 3. 57 HDMI 左声道用户数据寄存器       27         32. 3. 59 HDMI 右声道状态寄存器       27         32. 3. 59 HDMI 右声道状态寄存器       27         32. 3. 60 中断寄存器       27         33 HDA 控制器 (D7:F0)       27         33. 1 HDA 配置寄存器 (D7:F0)       27         33. 2 HDA 控制寄存器描述       27         34 12S 控制器 (D7:F1)       27         34. 1 概述       27         34. 2 I2S 配置寄存器       27         34. 3 PCICMD-PCI 命令寄存器       27         34. 4 I2S 控制器寄存器       27         34. 5 DMA 命令寄存器       27         34. 6 配置操作       28         34. 7. 1 DMA 控制器       28         34. 7. 2 DMA 描述符       28         35. SATA 控制器 (D8:F0)       28         35. 1 SATA 配置寄存器       28         35. 2 SATA 控制器内部寄存器描述       28         35. 2 SATA 控制器内部寄存器描述       28                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | _                              |     |
| 32. 3. 56 HDMI 左声道状态寄存器       27         32. 3. 57 HDMI 左声道用户数据寄存器       27         32. 3. 58 HDMI 右声道状态寄存器       27         32. 3. 59 HDMI 右声道状态寄存器       27         32. 3. 60 中断寄存器       27         33 HDA 控制器 (D7:F0)       27         33. 1 HDA 配置寄存器 (D7:F0)       27         33. 2 HDA 控制寄存器描述       27         34 12S 控制器 (D7:F1)       27         34. 1 概述       27         34. 2 I2S 配置寄存器       27         34. 3 PCICMD-PCI 命令寄存器       27         34. 4 I2S 控制器寄存器       27         34. 5 DMA 命令寄存器       27         34. 7 DMA 控制器       28         34. 7. 1 DMA 控制器       28         34. 7. 2 DMA 描述符       28         35. SATA 控制器 (D8:F0)       28         35. 1 SATA 配置寄存器       28         35. 2 SATA 控制器内部寄存器描述       28         35. 2 SATA 控制器内部寄存器描述       28                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | _                              |     |
| 32. 3. 57 HDMI 左声道用户数据寄存器2732. 3. 58 HDMI 右声道状态寄存器2732. 3. 59 HDMI 右声道用户数据寄存器2732. 3. 60 中断寄存器2733 HDA 控制器 (D7:F0)2733. 1 HDA 配置寄存器 (D7:F0)2733. 2 HDA 控制寄存器描述2734 12S 控制器 (D7:F1)2734. 1 概述2734. 2 12S 配置寄存器2734. 3 PCICMD-PCI 命令寄存器2734. 4 12S 控制器寄存器2734. 5 DMA 命令寄存器2734. 6 配置操作2834. 7 DMA 控制器2834. 7. 2 DMA 描述符2835 SATA 控制器 (D8:F0)2835. 1 SATA 配置寄存器2835. 2 SATA 控制器内部寄存器描述28                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                |     |
| 32. 3. 58 HDMI 右声道状态寄存器2732. 3. 59 HDMI 右声道用户数据寄存器2732. 3. 60 中断寄存器2733 HDA 控制器(D7:F0)2733. 1 HDA 配置寄存器(D7:F0)2733. 2 HDA 控制寄存器描述2734 I2S 控制器(D7:F1)2734. 1 概述2734. 2 I2S 配置寄存器2734. 3 PCICMD-PCI 命令寄存器2734. 4 I2S 控制器寄存器2734. 5 DMA 命令寄存器2734. 6 配置操作2834. 7 DMA 控制器2834. 7. 2 DMA 描述符2835 SATA 控制器(D8:F0)2835. 1 SATA 配置寄存器2835. 2 SATA 控制器内部寄存器描述28                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                |     |
| 32. 3. 59 HDMI 右声道用户数据寄存器2732. 3. 60 中断寄存器2733 HDA 控制器(D7:F0)2733. 1 HDA 配置寄存器(D7:F0)2733. 2 HDA 控制寄存器描述2734 I2S 控制器(D7:F1)2734. 1 概述2734. 2 I2S 配置寄存器2734. 3 PCICMD-PCI 命令寄存器2734. 4 I2S 控制器寄存器2734. 5 DMA 命令寄存器2734. 6 配置操作2834. 7 DMA 控制器2834. 7. 1 DMA 控制器结构描述2835 SATA 控制器(D8:F0)2835. 1 SATA 配置寄存器2835. 2 SATA 控制器内部寄存器描述28                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                |     |
| 32. 3. 60 中断寄存器2733 HDA 控制器(D7:F0)2733. 1 HDA 配置寄存器(D7:F0)2733. 2 HDA 控制寄存器描述2734 I2S 控制器(D7:F1)2734. 1 概述2734. 2 I2S 配置寄存器2734. 3 PCICMD-PCI 命令寄存器2734. 4 I2S 控制器寄存器2734. 5 DMA 命令寄存器2734. 6 配置操作2834. 7 DMA 控制器2834. 7. 1 DMA 控制器结构描述2835. SATA 控制器(D8:F0)2835. 1 SATA 配置寄存器2835. 2 SATA 控制器内部寄存器描述28                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                |     |
| 33 HDA 控制器(D7:F0)2733.1 HDA 配置寄存器(D7:F0)2733.2 HDA 控制寄存器描述2734 I2S 控制器(D7:F1)2734.1 概述2734.2 I2S 配置寄存器2734.3 PCICMD-PCI 命令寄存器2734.4 I2S 控制器寄存器2734.5 DMA 命令寄存器2734.6 配置操作2834.7 DMA 控制器2834.7.1 DMA 控制器结构描述2835 SATA 控制器(D8:F0)2835.1 SATA 配置寄存器2835.2 SATA 控制器内部寄存器描述28                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 32.3.60 中断寄存器                  | 272 |
| 33. 1 HDA 配置寄存器(D7:F0)2733. 2 HDA 控制寄存器描述2734 I2S 控制器(D7:F1)2734. 1 概述2734. 2 I2S 配置寄存器2734. 3 PCICMD-PCI 命令寄存器2734. 4 I2S 控制器寄存器2734. 5 DMA 命令寄存器2734. 6 配置操作2834. 7 DMA 控制器2834. 7. 1 DMA 控制器结构描述2834. 7. 2 DMA 描述符2835 SATA 控制器(D8:F0)2835. 1 SATA 配置寄存器2835. 2 SATA 控制器内部寄存器描述28                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                |     |
| 33. 2 HDA 控制寄存器描述2734 I2S 控制器 (D7:F1)2734. 1 概述2734. 2 I2S 配置寄存器2734. 3 PCICMD-PCI 命令寄存器2734. 4 I2S 控制器寄存器2734. 5 DMA 命令寄存器2734. 6 配置操作2834. 7 DMA 控制器2834. 7. 1 DMA 控制器结构描述2834. 7. 2 DMA 描述符2835 SATA 控制器 (D8:F0)2835. 1 SATA 配置寄存器2835. 2 SATA 控制器内部寄存器描述28                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                |     |
| 34. 1 概述2734. 2 I2S 配置寄存器2734. 3 PCICMD-PCI 命令寄存器2734. 4 I2S 控制器寄存器2734. 5 DMA 命令寄存器2734. 6 配置操作2834. 7 DMA 控制器2834. 7. 1 DMA 控制器结构描述2834. 7. 2 DMA 描述符2835 SATA 控制器(D8:F0)2835. 1 SATA 配置寄存器2835. 2 SATA 控制器内部寄存器描述28                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                |     |
| 34. 2 I2S 配置寄存器2734. 3 PCICMD-PCI 命令寄存器2734. 4 I2S 控制器寄存器2734. 5 DMA 命令寄存器2734. 6 配置操作2834. 7 DMA 控制器2834. 7. 1 DMA 控制器结构描述2834. 7. 2 DMA 描述符2835 SATA 控制器(D8:F0)2835. 1 SATA 配置寄存器2835. 2 SATA 控制器内部寄存器描述28                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 34 I2S 控制器 (D7:F1)             | 277 |
| 34. 3 PCICMD-PCI 命令寄存器2734. 4 I2S 控制器寄存器2734. 5 DMA 命令寄存器2734. 6 配置操作2834. 7 DMA 控制器2834. 7. 1 DMA 控制器结构描述2834. 7. 2 DMA 描述符2835 SATA 控制器(D8:F0)2835. 1 SATA 配置寄存器2835. 2 SATA 控制器内部寄存器描述28                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 34.1 概述                        | 277 |
| 34. 4 I2S 控制器寄存器2734. 5 DMA 命令寄存器2734. 6 配置操作2834. 7 DMA 控制器2834. 7. 1 DMA 控制器结构描述2834. 7. 2 DMA 描述符2835 SATA 控制器(D8:F0)2835. 1 SATA 配置寄存器2835. 2 SATA 控制器内部寄存器描述28                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 34.2 I2S 配置寄存器                 | 277 |
| 34. 5 DMA 命令寄存器2734. 6 配置操作2834. 7 DMA 控制器2834. 7. 1 DMA 控制器结构描述2834. 7. 2 DMA 描述符2835 SATA 控制器(D8:F0)2835. 1 SATA 配置寄存器2835. 2 SATA 控制器内部寄存器描述28                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 34.3 PCICMD-PCI 命令寄存器          | 278 |
| 34.6 配置操作2834.7 DMA 控制器2834.7.1 DMA 控制器结构描述2834.7.2 DMA 描述符2835 SATA 控制器 (D8:F0)2835.1 SATA 配置寄存器2835.2 SATA 控制器内部寄存器描述28                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 34.4 I2S 控制器寄存器                | 278 |
| 34. 7 DMA 控制器2834. 7. 1 DMA 控制器结构描述2834. 7. 2 DMA 描述符2835 SATA 控制器 (D8:F0)2835. 1 SATA 配置寄存器2835. 2 SATA 控制器内部寄存器描述28                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 34.5 DMA 命令寄存器                 | 279 |
| 34. 7. 1 DMA 控制器结构描述       28         34. 7. 2 DMA 描述符       28         35 SATA 控制器 (D8:F0)       28         35. 1 SATA 配置寄存器       28         35. 2 SATA 控制器内部寄存器描述       28                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 34.6 配置操作                      | 280 |
| 34. 7. 2 DMA 描述符2835 SATA 控制器 (D8:F0)2835. 1 SATA 配置寄存器2835. 2 SATA 控制器内部寄存器描述28                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 34.7 DMA 控制器                   | 281 |
| 35 SATA 控制器 (D8:F0)       28         35.1 SATA 配置寄存器       28         35.2 SATA 控制器内部寄存器描述       28                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 34.7.1 DMA 控制器结构描述             | 281 |
| 35.1 SATA 配置寄存器       28         35.2 SATA 控制器内部寄存器描述       28                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                |     |
| 35.2 SATA 控制器内部寄存器描述28                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                |     |
| 35.2 SATA 控制器内部寄存器描述28                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 35.1 SATA 配置寄存器                | 285 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                |     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                |     |
| 36 PCIe 控制器 (Dev 9/A/B/C/D/E/F)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 36 PCIe 控制器(Dev 9/A/B/C/D/E/F) | 288 |
| 36.1 PCI 配置寄存器28                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 36.1 PCI 配置寄存器                 | 288 |



### 龙芯 2K2000 处理器用户手册目录

| 36.2 地址空间划分28         |    |
|-----------------------|----|
| 36.3 内部寄存器定义29        | 90 |
| 36.4 PCIe 配置头空间29     | 98 |
| 36.5 软件编程指南29         | 98 |
| 36.6 常用例程30           | 01 |
| 37 DMA 控制器 (D30:F0)30 | 05 |
| 37.1 DMA 控制器功能概述30    |    |
| 37.2 DMA 配置寄存器30      | 05 |
| 37.2.1 控制器配置寄存器30     | 05 |
| 37.2.2 通道配置寄存器30      |    |
| 37.3 DMA 描述符30        | 07 |
| 37.4 描述符配置约束和说明30     | 08 |
| 37.5 DMA 中断30         | 09 |
| 37.5.1 超时中断30         | 09 |
| 37.5.2 描述符中断30        |    |
| 修订记录                  | 10 |



# 图目录

| 图 1- ] | 1 7 | 龙芯 2K2000 结构图              | . 2 |
|--------|-----|----------------------------|-----|
| 图 3- ] | 1 7 | 芯片时钟结构图                    | 24  |
| 图 3- 2 | 2   | PLL 结构图                    | 25  |
| 图 6- ] | 1   | 64 位配置访问地址格式               | 95  |
| 图 6- 2 | 2   | 32 位配置访问地址格式               | 96  |
| 图 9- ] | 1   | 龙芯 2K2000 处理器南北桥中断路由示意图1   | 13  |
| 图 9- 2 | 2   | 龙芯 2K2000 处理器 NODE 中断路由示意图 | 13  |
| 图 11-  | 1   | SPI 主控制器接口时序1              | 39  |
| 图 11-  | 2   | SPI Flash 标准读时序1           | 40  |
| 图 11-  | 3   | SPI Flash 快速读时序1           | 40  |
| 图 11-  | 4   | SPI Flash 双向 I/0 读时序 1-    | 40  |
| 图 12-  | 1   | Local IO 读时序 1-            | 43  |
| 图 12-  | 2   | Local IO 写时序 1-            | 44  |
| 图 13-  | 1   | DDR4 SDRAM 读操作协议1          | 46  |
| 图 13-  | 2   | DDR4 SDRAM 写操作协议1          | 46  |
| 图 15-  | 1   | UART 控制器结构                 | 66  |
| 图 17-  | 1   | I2C 主控制器结构 15              | 86  |
| 图 18-  | 1   | 防死区功能1                     | 92  |
| 图 27-  | 1   | SD 卡多块写操作示意图               | 37  |
| 图 27-  | 2   | SD 卡多块读操作示意图2              | 38  |
| 图 27-  | 3   | SD Memory 卡初始化流程示意图2       | 46  |



# 表目录

| 表 2- | 1 1 | 信号类型代码                | . 8 |
|------|-----|-----------------------|-----|
| 表 2- | 2   | DDR4 SDRAM 控制器接口信号    | 8   |
| 表 2- | 3   | PCIe 总线信号             | 9   |
| 表 2- | 4   | DVO 接口信号              | 9   |
| 表 2- | 5   | DVO 接口 RGB 对应关系       | 10  |
| 表 2- | 6   | DVO、LIO 和 GPIO 复用关系   | 10  |
| 表 2- | 7   | HDMI 接口信号             | 11  |
| 表 2- | 8   | 网口信号                  | 11  |
| 表 2- | 9   | GMAC 接口信号             | 12  |
| 表 2- | 10  | GMAC 与 UART、GPIO 复用关系 | 12  |
| 表 2- | 11  | SATA 接口信号             | 12  |
| 表 2- | 12  | SATA 与 GPIO 复用关系      | 13  |
| 表 2- | 13  | USB2. 0 接口信号          | 13  |
| 表 2- | 14  | USB3. 0 接口信号          | 13  |
| 表 2- | 15  | USB 与 GPIO 复用关系       | 13  |
| 表 2- | 16  | HDA 接口信号              | 14  |
| 表 2- | 17  | HDA 与 I2S 复用关系        | 14  |
| 表 2- | 18  | HDA 与 GPIO 复用关系       | 14  |
| 表 2- | 19  | SPI 接口信号              | 14  |
| 表 2- | 20  | I2C 接口信号              | 15  |
| 表 2- | 21  | UART 接口信号             | 15  |
| 表 2- | 22  | UARTO 接口复用关系          | 15  |
| 表 2- | 23  | UARTO 与 AVS 复用关系      | 16  |
| 表 2- | 24  | CAN 接口信号              | 16  |
| 表 2- | 25  | LPC 接口信号              | 17  |
| 表 2- | 26  | SDIO 与 GPIO 复用关系      | 17  |
| 表 2- | 27  | SDIO 接口信号             | 17  |
| 表 2- | 28  | SDIO 与 SPI1、GPIO 复用关系 | 17  |
| 表 2- | 29  | eMMC 接口信号             | 18  |
| 表 2- | 30  | eMMC 与 GPIO 复用关系      | 18  |
| 表 2- | 31  | GPIO 信号               | 18  |
| 表 2- | 32  | PWM 信号                | 18  |
| 表 2- | 33  | PWM 与 CAN、GPIO 复用关系   | 18  |



| 表 2- | 34 | ACPI 信号19         |
|------|----|-------------------|
| 表 2- | 35 | JTAG 接口           |
| 表 2- | 36 | 时钟信号20            |
| 表 2- | 37 | 时钟信号20            |
| 表 2- | 38 | 安全模块接口20          |
| 表 2- | 39 | 系统相关信号21          |
| 表 2- | 40 | 其他信号接口22          |
| 表 2- | 41 | 外设功能复用表22         |
| 表 3- | 1  | PLL 相关配置信号说明表     |
| 表 3- | 2  | 参考时钟稳定标志及判断标准28   |
| 表 4- | 1  | ACPI 状态说明         |
| 表 5- | 1  | 版本寄存器30           |
| 表 5- | 2  | 芯片特性寄存器30         |
| 表 5- | 3  | 厂商名称寄存器31         |
| 表 5- | 4  | 芯片名称寄存器31         |
| 表 5- | 5  | 功能设置寄存器31         |
| 表 5- | 6  | 温度采样寄存器32         |
| 表 5- | 7  | 处理器核软件分频设置寄存器32   |
| 表 5- | 8  | 处理器核软件分频设置寄存器33   |
| 表 5- | 9  | 芯片路由设置寄存器33       |
| 表 5- | 10 | 其它功能设置寄存器34       |
| 表 5- | 11 | FUSE0 观测寄存器35     |
| 表 5- | 12 | FUSE1 观测寄存器35     |
| 表 5- | 13 | 通用配置寄存器 0         |
| 表 5- | 14 | 通用配置寄存器 1         |
| 表 5- | 15 | 引脚复用配置寄存器42       |
| 表 5- | 16 | USB OC 选择配置       |
| 表 5- | 17 | OTG 预取配置47        |
| 表 5- | 18 | 固定地址配置48          |
| 表 5- | 19 | DMA 一致性配置寄存器48    |
| 表 5- | 20 | PLL0 配置寄存器49      |
| 表 5- | 21 | PLL1 配置寄存器49      |
| 表 5- | 22 | PLL2 配置寄存器50      |
| 表 5- | 23 | PLL_PIX_0 配置寄存器50 |



| 表 5- 24 | 4 PLL_PIX_1 配置寄存器     | 51 |
|---------|-----------------------|----|
| 表 5- 25 | 5 SSC PLL 配置寄存器 0     | 51 |
| 表 5- 26 | 6 SSC PLL 配置寄存器 1     | 52 |
| 表 5- 27 | FRESCALE 配置寄存器        | 53 |
| 表 5- 28 | 3 PCIe_F0 配置寄存器 0     | 53 |
| 表 5- 29 | ) PCIe_F0 配置寄存器 1     | 54 |
| 表 5- 30 | ) PCIe_FO PHY 配置寄存器   | 56 |
| 表 5- 31 | PCIe_F1 配置寄存器 0       | 58 |
| 表 5- 32 | 2 PCIe_F1 配置寄存器 1     | 59 |
| 表 5- 33 | B PCIe_F1 PHY 配置寄存器   | 60 |
| 表 5- 34 | 4 PCIe_G0 配置寄存器 0     | 61 |
| 表 5- 35 | 5 PCIe_G0 配置寄存器 1     |    |
| 表 5- 36 | 5 PCIe_GO PHY 配置寄存器   | 63 |
| 表 5- 37 | 7 PCIe_F0 PHY 配置寄存器   | 64 |
| 表 5- 38 | B PRG 配置访问寄存器         | 64 |
| 表 5- 39 | PRG 模块配置寄存器 0         |    |
| 表 5- 40 | ) PRG 模块配置寄存器 1       |    |
| 表 5- 41 | RapidIO PHY 配置寄存器 0   |    |
| 表 5- 42 | 2 RapidIO PHY 配置寄存器 1 |    |
| 表 5- 43 | B RapidIO PHY 配置寄存器 2 |    |
| 表 5- 44 | 4 RapidIO PHY 配置寄存器 3 | 71 |
| 表 5- 45 | 5 PAD 驱动配置寄存器         |    |
| 表 5- 46 | 5 PAD 驱动配置寄存器         |    |
| 表 5- 47 | 7 SATA PHY 配置寄存器      |    |
| 表 5- 48 | SATA PHY 配置访问寄存器      |    |
| 表 5- 49 | SATA PHY PLL 配置寄存器    |    |
| 表 5- 50 | ) GMACO 配置寄存器         |    |
| 表 5- 51 | GMAC1 配置寄存器           |    |
| 表 5- 52 | USB3 PHY 配置寄存器 0 .    |    |
| 表 5- 53 | B USB3 PHY 配置寄存器 1 .  | 80 |
| 表 5- 54 | USB3 PHY 配置寄存器 2 .    | 80 |
| 表 5- 55 | 5 USB3 PHY 配置寄存器 3    | 80 |
| 表 5- 56 | USB3 PHY 配置寄存器 4      | 81 |
| 表 5- 57 | USB3 PHY 配置寄存器 5      | 81 |

### 龙芯 2K2000 处理器用户手册表目录

| 表 5- | 58  | USB3.0 控制器配置寄存器      | 82     |
|------|-----|----------------------|--------|
| 表 5- | 59  | USB2.0 PHY 配置寄存器 0   |        |
| 表 5- | 60  | USB2.0 PHY 配置寄存器 1-9 | 84     |
| 表 5- | 61  | USB2.0 配置寄存器         |        |
| 表 5- | 62  | USB3.0 电源控制寄存器       | 86     |
| 表 5- | 63  | USB2.0 电源控制寄存器       | 86     |
| 表 5- | 64  | GPU 窗口 0 基址寄存器       | 87     |
| 表 5- | 65  | GPU 窗口 0 大小寄存器       | 87     |
| 表 5- | 66  | GPU 窗口 0 重映射寄存器      | 87     |
| 表 5- | 67  | GPU 窗口 1 基址寄存器       | 87     |
| 表 5- | 68  | GPU 窗口 1 大小寄存器       | 88     |
| 表 5- | 69  | GPU 窗口 1 重映射寄存器      | 88     |
| 表 6- | 1 芯 | 芯片地址空间划分             | 89     |
| 表 6- | 2 - | 一级交叉开关路由规则           | 90     |
| 表 6- | 3 _ | 二级交叉开关路由规则           | 90     |
| 表 6- | 4 1 | MMAP 字段对应的该空间访问属性    | 91     |
| 表 6- | 5 地 | 也址窗口寄存器表             | 91     |
| 表 6- | 6 1 | MMAP 寄存器位域说明         |        |
| 表 6- | 7 - | 一级 xbar 从设备号与所述模块的对应 | 关系94   |
| 表 6- | 8 _ | 二级 xbar 从设备号与所述模块的对应 | 关系94   |
| 表 6- | 9 名 | 各个设备的配置头访问对应关系       | 96     |
| 表 6- | 10  | Type0 类型配置头          | 97     |
| 表 6- | 11  | TypeO 的配置头寄存器        |        |
| 表 6- | 12  | Type1 类型配置头          |        |
| 表 6- | 13  | Typel 的配置头寄存器        | 100    |
| 表 6- | 14  | 固定地址设备地址空间           |        |
| 表 6- | 15  | PCI 设备地址空间描述         |        |
| 表 7- | 1   | 共享 Cache 锁窗口寄存器配置    |        |
| 表 8- | 1 久 | 上理器核间中断相关的寄存器及其功能    | 指述107  |
| 表 8- | 2 ( | 0 号处理器核的核间中断与通信寄存器   | 器列表107 |
| 表 8- | 3   | 1号处理器核的核间中断与通信寄存器    | 器列表    |
| 表 8- | 4   | 当前处理器核核间中断与通信寄存器     | 列表108  |
| 表 8- | 5   | 处理器核核间通信寄存器          |        |
| 表 8- | 6   | 处理器核核间通信寄存器          |        |



| 表 9-1 其它功能设置寄存器.        |              |
|-------------------------|--------------|
| 表 9-2 中断相关寄存器描述         |              |
| 表 9-3 中断寄存器地址分布         |              |
| 表 9-4 中断控制寄存器           |              |
| 表 9-5 IO 控制寄存器地址        |              |
| 表 9-6 中断路由寄存器的说明        |              |
| 表 9-7 中断路由寄存器地址         |              |
| 表 9-8 处理器核私有中断状态        | 寄存器127       |
| 表 9-9 扩展 IO 中断使能寄存器     | <b>署</b> 127 |
| 表 9- 10 扩展 I0 中断自动轮转    | 使能寄存器127     |
| 表 9- 11 扩展 I0 中断状态寄存    | 器128         |
| 表 9- 12 各处理器核的扩展 10     | 中断状态寄存器128   |
| 表 9- 13 中断引脚路由寄存器的      | 说明128        |
| 表 9- 14 中断路由寄存器地址.      |              |
| 表 9- 15 中断目标处理器核路日      | 由寄存器的说明129   |
| 表 9- 16 中断目标处理器核路日      | 由寄存器地址129    |
| 表 9- 17 当前处理器核的扩展 I     | ) 中断状态寄存器129 |
| 表 9- 18 扩展 I0 中断触发寄存器   | 署13C         |
| 表 10-1 高低温中断寄存器说明       |              |
| 表 10-2 扩展 I0 中断触发寄存器    | 署133         |
| 表 10-3 高温降频控制寄存器说       | 明            |
| 表 11- 1 SPIO 控制器地址空间    | 分配135        |
| 表 11-2 SPI 配置寄存器列表.     |              |
| 表 11- 3 SPI 控制寄存器 (SPCR | )            |
| 表 11-4 SPI 状态寄存器 (SPSR  | )            |
| 表 11- 5 SPI 数据寄存器 (TxFI | FO/RXFIFO)   |
| 表 11-6 SPI 外部寄存器 (SPER  | )            |
| 表 11-7 SPI 分频系数         |              |
| 表 11-8 SPI 参数控制寄存器(     | SFC_PARAM)   |
| 表 11-9 SPI 片选控制寄存器(     | SFC_S0FTCS)  |
| 表 11- 10 SPI 时序控制寄存器    | (SFC_TIMING) |
| 表 11- 11 SPI Flash 自定义控 | 制寄存器138      |
| 表 11- 12 SPI Flash 自定义命 | 令寄存器138      |
| 表 11-13 SPI Flash 自定义数  | 据寄存器 0       |





| 表 11- | 14  | SPI Flash 自定义数据寄存器 1               | 138 |
|-------|-----|------------------------------------|-----|
| 表 11- | 15  | SPI Flash 自定义时序寄存器 0               | 139 |
| 表 11- | 16  | SPI Flash 自定义时序寄存器 1               | 139 |
| 表 11- | 17  | SPI Flash 自定义时序寄存器 2               | 139 |
| 表 12- | 1   | Local IO 地址空间分配                    | 143 |
| 表 13- | 1   | 内存控制器软件可见参数列表                      | 146 |
| 表 13- | 2   | 内存控制器出错状态观测寄存器                     | 163 |
| 表 14- | 1   | MISC 低速设备块的 PCI 配置寄存器 (MISC-D2:F0) | 164 |
| 表 14- | 2 1 | MISC 低速设备地址路由                      | 164 |
| 表 15- | 1   | UART 控制器物理地址构成                     | 165 |
| 表 15- | 2   | UART 数据寄存器                         | 166 |
| 表 15- | 3   | UART 中断使能寄存器                       | 167 |
| 表 15- | 4   | UART 中断标识寄存器                       | 167 |
| 表 15- | 5   | UART 中断控制功能表                       | 167 |
| 表 15- | 6   | UART 的 FIFO 控制寄存器                  | 168 |
| 表 15- | 7   | UART 线路控制寄存器                       | 168 |
| 表 15- | 8   | UART 的 MODEM 控制寄存器                 | 169 |
| 表 15- | 9   | UART 线路状态寄存器                       | 169 |
| 表 15- | 10  | UART 的 MODEM 状态寄存器                 | 170 |
| 表 15- | 11  | UART 分频锁存器 1                       | 170 |
| 表 15- | 12  | UART 分频锁存器 2                       | 171 |
| 表 15- | 13  | UART 分频锁存器 3                       | 171 |
| 表 16- | 1   | CAN 内部寄存器物理地址构成                    | 172 |
| 表 16- | 2   | CAN 控制器标准模式下寄存器定义                  | 173 |
| 表 16- | 3   | CAN 控制器标准模式下的控制寄存器格式               | 174 |
| 表 16- | 4   | CAN 控制器标准模式下命令寄存器格式                | 174 |
| 表 16- | 5   | CAN 控制器标准模式下状态寄存器格式                | 175 |
| 表 16- | 6   | CAN 控制器标准模式下中断寄存器格式                | 175 |
| 表 16- | 7   | CAN 验收代码寄存器                        | 175 |
| 表 16- | 8   | CAN 验收屏蔽寄存器                        | 176 |
| 表 16- | 9   | CAN 控制器标准模式下发送缓冲区格式                | 176 |
| 表 16- | 10  | 扩展模式下 CAN 控制器的地址列表                 | 177 |
| 表 16- | 11  | CAN 控制器扩展模式下的模式寄存器格式               | 179 |
| 表 16- | 12  | CAN 控制器扩展模式下命令寄存器格式                | 179 |





| 表 16 | <u>;</u> —   | 13 | CAN 控制器扩展模式下状态寄存器格式     | 180 |
|------|--------------|----|-------------------------|-----|
| 表 16 | <u>;</u> —   | 14 | CAN 控制器扩展模式下中断寄存器格式     | 180 |
| 表 16 | <u>;</u> —   | 15 | CAN 控制器扩展模式下中断使能寄存器格式   | 181 |
| 表 16 | <u>;</u> —   | 16 | CAN 控制器扩展模式下仲裁丢失捕捉寄存器格式 | 181 |
| 表 16 | <u>;</u> —   | 17 | CAN 错误劲爆限制寄存器           | 182 |
| 表 16 | <u>;</u> —   | 18 | CAN 的 RX 错误计数寄存器        | 183 |
| 表 16 | <u>;</u> —   | 19 | CAN 的 TX 错误计数寄存器        | 183 |
| 表 16 | <u>;</u> —   | 20 | CAN 的 RX 错信息计数寄存器       | 183 |
| 表 16 | <u>;</u> —   | 21 | CAN 总线定时寄存器 0           | 184 |
| 表 16 | <u>;</u> —   | 22 | CAN 总线定时寄存器 1           | 184 |
| 表 16 | <u>;</u> —   | 23 | CAN 输出控制寄存器             | 184 |
| 表 18 | }-           | 1  | PWM 寄存器列表               | 190 |
| 表 18 | 3-           | 2  | PWM 控制寄存器设置             | 190 |
| 表 21 | _            | 1  | 输出使能寄存器                 | 200 |
| 表 21 | _            | 2  | 输入输出寄存器                 | 200 |
| 表 21 | _            | 3  | 中断控制寄存器                 | 200 |
| 表 21 | _            | 4  | 中断控制寄存器                 | 201 |
| 表 21 | _            | 5  | GPIO 控制寄存器              | 201 |
| 表 21 | _            | 6  | 按位控制 GPIO 配置寄存器地址       | 202 |
| 表 21 | _            | 7  | 按字节控制 GPIO 配置寄存器地址      | 202 |
| 表 22 | ?—           | 1  | ACPI 状态说明               | 206 |
| 表 28 | <del> </del> | 1  | GMAC 控制器的配置寄存器          | 249 |
| 表 30 | )—           | 1  | USB-XHCI 控制器的配置寄存器      | 254 |
| 表 31 | _            | 1  | GPU 控制器的配置寄存器           | 256 |
| 表 32 | <u>}</u> —   | 1  | DC 控制器的配置寄存器            | 257 |
| 表 32 | <u>}</u> —   | 2  | 单色光标模式                  | 265 |
| 表 33 | ;—           | 1  | HDA 控制器的配置寄存器           | 274 |
| 表 34 | -            | 1  | I2S 控制器的配置寄存器           | 277 |
| 表 34 | -            | 2  | 寄存器定义                   | 278 |
| 表 34 | -            | 3  | 标识寄存器                   | 278 |
| 表 34 | -            | 4  | 配置寄存器 0                 | 278 |
| 表 34 | -            | 5  | 控制寄存器                   | 279 |
| 表 35 | <u>;</u> —   | 1  | SATA 控制器的配置寄存器          | 285 |
| 表 36 | <u>;</u> —   | 1  | PCIe 控制器的配置寄存器          | 288 |



### 龙芯 2K2000 处理器用户手册表目录

| 表 36- | 2 | PCIe 端口 DID 表 | 289 |
|-------|---|---------------|-----|
| 100   | _ |               | 200 |



### 1 概述

龙芯 2K2000 处理器 (简称龙芯 2K2000) 是一款集成处理器核的通用嵌入式芯片,可应用在网络安全、工业控制、电力、轨道交通、移动智能终端、信息教育等领域。片内集成 2个 LA364 处理器核,采用 LoongArch 指令系统(龙架构),主频约 1.4GHz,72 位 DDR4 控制器,并集成各种系统 IO 接口。其主要特征如下:

- 片内集成两个 64 位的三发射超标量 LA364 处理器核, 主频 1.4GHz
- 片内集成共享的 2MB 二级 Cache
- 片内集成 3D GPU
- 支持双路显示(HDMI和DVO)
- 片内集成 72 位 DDR4 控制器 (含 8 位 ECC)
- 1个 x4 PCIe 3.0 接口,可拆分为 4个独立 PCIe x1 接口,仅 RC 模式
- 1 个 x4 PCIe 3.0 接口,可拆分为 2 个独立 PCIe x1 接口或者 1 个 x4 的 RapidIO 2.2 接口,仅 RC 模式
- 1个x4 PCIe 3.0接口,可作为1个x4的RapidIO 2.2接口,有RC或者EP模式
- 1 个 4 通道 DMA
- 片内集成 2 个 SATA3. 0 接口
- 片内集成最多 4 个 USB 3.0, 最多 9 个 USB2.0, 其中 1 个为 OTG
- 片内集成 1 个 RGMII 千兆网 PHY 接口, 2 个千兆网口, 支持 TSN 和 MSI 中断
- 片内集成 HDA/I2S 接口
- 片内集成 RTC/HPET 模块
- 片内集成 3 个全功能 UART 接口和 1 个双线 UART 接口
- 片内集成 6 个 CAN 控制器
- 片内集成6个PWM控制器
- ▶ 片内集成 1 个 SDIO 控制器
- 片内集成 1 个 eMMC 控制器
- 片内集成 2 个 SPI 控制器,支持 QSPI
- 片内集成 4 个 I2C 控制器
- 片内集成1个LPC控制器
- 片内集成1个LI0控制器
- 片内集成 1 个 AVS 接口
- ACPI 规范
- 最多 96 个 GPIO 接口
- 安全可信模块



- 片内集成温度传感器
- 集成动态功耗控制模块
- 采用 FC-BGA 封装

### 1.1 体系结构框图

龙芯 2K2000 的结构如图 1-1 所示。一级交叉开关连接两个处理器核、两个二级 Cache 以及 IO 子网络(Cache 访问路径)。二级交叉开关连接两个二级 Cache、内存控制器、启动模块(SPI 或者 LIO)以及 IO 子网络(Uncache 访问路径)。IO 子网络采用南北桥结构,北桥包含 3 个 PCIe、显示、DMA 和安全模块,通过北桥网络连接一级交叉开关,以减少处理器访问延迟。南桥包括 GMAC、SATA、USB、HDA/I2S、SDIO、eMMC、加解密以及 MISC 模块,通过南桥网络与北桥相连。



图 1-1 龙芯 2K2000 结构图

### 1.2 芯片主要功能

#### 1.2.1 处理器核

- LA364
- 采用 LoongArch 指令系统(龙架构)
- 64KB 数据 Cache 和 64KB 的指令 Cache
- 2M 共享二级 Cache
- 通过目录协议维护 I/O DMA 访问的 Cache 一致性

#### 1.2.2 内存接口

- 72 位 DDR4 控制器(含 8 位 ECC),最高工作频率 1200MHz
- 支持 32 位模式下的 ECC
- 可配置为 64/32/16 位模式
- 支持命令调度



#### 1.2.3 PCIe 接口

- 兼容 PCIe 3.0
- 三个独立 X4 接口,均支持 X4/X2/X1 链路宽度自适应
- F0 接口可以配置为 4 个 X1 接口,各模式下支持最高速率为 PCIe 3.0 速率,仅 RC 模式
- F1 接口可以配置为 2 个 X1 或者 1 个 X4 的 RapidIO 2.2 接口, 2X1 模式下支持 最高速率为 PCIe 2.0 速率,仅 RC 模式
- GO 接口可以配置为 1 个 X4 的 RapidIO 2. 2 接口,可作为 RC 或者 EP (EP 内置 DMA)

#### 1.2.4 RapidIO 接口

- 兼容 RapidIO 2.2
- 使用串行接口,支持 1.25/2.5/3.125/5.0/6.25Gbps 速率
- 支持 RapidIO 协议 34/50 位地址的访问
- 支持 8/16 位 ID
- 支持 RapidIO 协议的 NREAD、NWRITE、 NWRITE\_R、SWRITE、 Maintenance Packet、Response Packet、Doorbell Packet、Message Packet
- x4/x2/x1链路宽度自适应
- 复用 PCIe 接口

#### 1. 2. 5 GPU

- 集成一路 DMA
- 集成 MMU
- 支持 4x MSAA
- 支持内存压缩
- 支持动态功耗管理

#### 1.2.6 显示接口

- 一路 HDMI 接口,一路 DVO 接口
- 两路独立硬件光标
- 伽玛校正
- 输出抖动
- 支持 1080p
- 支持线性显示缓冲
- 上电序列控制
- 低功耗管理



#### 1.2.7 SATA 控制器

- 2个 SATA 端口
- 支持 SATA 1.5Gbps、SATA2 代 3Gbps 和 SATA3 代 6Gbps 的传输
- 兼容串行 ATA 2.6、AHCI 1.1 和 AHCI 1.3.1 规范

#### 1.2.8 USB 控制器

- 采用 XHCI 协议
- 4 个独立的 USB3. 0 HOST 端口
- 最多 9 个 USB2. 0 HOST 端口,其中端口 6 固定为 OTG 工作模式
- 兼容 USB1.1、USB2.0 和 USB3.0
- 最高传输速度可达 5Gbps

#### 1.2.9 GMAC 控制器

- 三路 10/100/1000Mbps 自适应以太网 MAC
- 一路 RGMII 接口, 2 路千兆网口
- 均兼容 IEEE 802.3
- 半双工/全双工自适应
- Timestamp 功能
- 半双工时,支持碰撞检测与重发(CSMA/CD)协议
- 支持 CRC 校验码的自动生成与校验,支持前置符生成与删除
- RGMII接口的GMAC2支持网络唤醒
- 支持 TSN

#### 1.2.10 HDA 接口

- 支持 16、18 和 20 位采样精度,支持可变速率
- 最高采样频率 192KHz
- 7.1 频道环绕立体声输出
- 三路音频输入

#### 1.2.11 I2S 接口

- 支持 master/slave 模式下 I2S 输入
- 支持 master/slave 模式下 I2S 输出
- 支持8、16、18、20、24、32位宽
- 支持单声道和立体声道音频数据
- 支持(16、22.05、32、44.1、48)KHz 采样频率
- 支持 DMA 传输模式



#### 1.2.12 SPI 控制器

- 双缓冲接收器
- 极性和相位可编程的串行时钟
- 主模式支持
- 支持到4个的变长字节传输
- 支持系统启动
- 支持标准读、连续地址读、快速读、双路 I/0 等 SPI Flash 读模式
- SPI1 支持 QSPI

#### 1.2.13 LPC 接口

- 符合 LPC1.1 规范
- 扩展支持 TPM 协议
- 支持 Serialized IRQ 规范,提供 17 个中断源

#### 1. 2. 14 UART

- 1 个双线 UART、3 个全功能 UART 和流控 TXD, RXD, CTS, RTS, DSR, DTR, DCD, RI
- 最多 13 个 UART 接口
- 在寄存器与功能上兼容 NS16550A
- 两路全双工异步数据接收/发送
- 可编程的数据格式
- 16 位可编程时钟计数器
- 支持接收超时检测
- 带仲裁的多中断系统

#### 1.2.15 I2C 总线

- 兼容 SMBUS(100Kbps)
- 与 PHILIPS I2C 标准相兼容
- 履行双向同步串行协议
- 主从设备支持
- 能够支持多主设备的总线
- 总线的时钟频率可编程
- 可以产生开始/停止/应答等操作
- 能够对总线的状态进行探测
- 支持低速和快速模式
- 支持 7 位寻址和 10 位寻址
- 支持时钟延伸和等待状态



#### 1. 2. 16 PWM

- 6 路 32 位可配置 PWM 定时器
- 支持定时器功能
- 支持计数器功能
- 支持防死区发生控制

#### 1. 2. 17 HPET

- 64 位计数器
- 支持1个周期性中断
- 支持2个非周期性中断

#### 1. 2. 18 RTC

- 可产生3个计时中断
- 支持定时开关机功能

#### 1.2.19 ACPI接口

- USB/GMAC 可唤醒
- 来电可自动启动
- 支持 S0, S3, S4, S5 状态

#### 1. 2. 20 Watchdog

● 32 比特计数器及初始化寄存器

#### 1. 2. 21 AVS

● 通过 APB 设备进行访问

#### 1.2.22 中断控制器

- 支持软件设置中断
- 支持电平与边沿触发
- 支持中断屏蔽与使能
- 支持多种中断分发模式

#### 1. 2. 23 CAN

- 符合 CAN2. 0 规范
- 6路 CAN 接口
- 支持中断



#### 1. 2. 24 GPIO

- 4个专用 GPIO 引脚(不包含 ACPI 和 SE 专用 GPIO)
- 其余引脚与其他接口相复用,使用各个接口电压域
- 输入中断功能
- 申断极性、触发类型可设置

#### 1.2.25 加解密模块

- AES、DES 算法支持
- RSA 算法支持

#### 1.2.26 SDIO 控制器

- 1路独立 SDIO 控制器
- 兼容 SD Memory 4.0/MMC/SDIO 4.0协议

### 1.2.27 eMMC 控制器

- 1路独立 eMMC 控制器
- 兼容 eMMC 5.1 协议



# 2 引脚定义

龙芯 2K2000 的引脚进行了大量的功能复用。对于有复用关系的引脚,在介绍完其本身的功能之外会同时在下方给出其他复用功能的描述。

### 2.1 约定

本章对龙芯 2K2000 引脚定义的说明使用以下约定:

#### ● 信号名

信号名的选取以方便记忆和明确标识功能为原则。低有效信号以 n 结尾,高有效信号则不带 n。

#### ● 类型

信号的输入输出类型由一个代码表示,见表 2-1。

| 代码       | 描述   |
|----------|------|
| A        | 模拟   |
| DIFF I/O | 双向差分 |
| DIFF IN  | 差分输入 |
| DIFF OUT | 差分输出 |
| Ι        | 输入   |
| I/0      | 双向   |
| 0        | 输出   |
| OD       | 开漏输出 |
| Р        | 电源   |
| G        | 地    |

### 2.2 DDR4 接口

表 2-2 DDR4 SDRAM 控制器接口信号

| 信号名称                        | 类型       | 描述                      |
|-----------------------------|----------|-------------------------|
| DDR_DQ[63:0]                | I/0      | DDR4 SDRAM 数据总线信号       |
| DDR_CB[7:0]                 | I/0      | DDR4 ECC 校验位            |
| DDR_DQSp[8:0] DDR_DQSn[8:0] | DIFF I/O | DDR4 SDRAM 数据选通         |
| DDR_DM[8:0]n_DQSp[17:9]     | 0        | DDR4 SDRAM 数据屏蔽         |
| DDR_A[13:0]                 | 0        | DDR4 SDRAM 地址总线信号       |
| DDR_BA[1:0]                 | 0        | DDR4 SDRAM 逻辑 BANK 地址信号 |
| DDR_WEn                     | 0        | DDR4 SDRAM 写使能信号        |
| DDR_CASn                    | 0        | DDR4 SDRAM 列地址选择信号      |
| DDR_RASn                    | 0        | DDR4 SDRAM 行地址选择信号      |
| DDR_SCSn[1:0]               | 0        | DDR4 SDRAM 片选信号         |



| DDR_CKE[1:0] | 0        | DDR4 SDRAM 时钟使能信号         |
|--------------|----------|---------------------------|
| DDR_CKp[1:0] | DIEE OUT | DDD4 CDDAM 艺八叶研检山岸口       |
| DDR_CKn[1:0] | DIFF OUT | DDR4 SDRAM 差分时钟输出信号       |
| DDR_ODT[1:0] | 0        | DDR4 SDRAM ODT 信号         |
| DDR_BG[1:0]  | 0        | BankGroup 地址信号            |
| DDR_ACTn     | 0        | 行激活信号,低有效                 |
| DDR_PAR      | 0        | DDR4 地址奇偶校验输出             |
| DDR_ALERTn   | I        | DDR4 出错警告信号,低有效           |
| DDR_RESETn   | 0        | DDR4 SDRAM 复位控制信号         |
| DDR_REXT     | A        | DDR4 控制器参考电阻,通过 240ohm 接地 |

# 2.3 PCIe 接口

表 2- 3 PCIe 总线信号

| 信号名称                   | 类型       | 描述                               |  |
|------------------------|----------|----------------------------------|--|
| PCIe_REFCLKINp         | DIFF IN  | PRG 参考时钟输入                       |  |
| PCIe_REFCLKINn         | 2111 111 | TVO 2 241 61 allia 7             |  |
| RAPIDIO_CLKINp[1:0]    |          | RAPID IO 参考时钟输入,对应关系为:           |  |
| RAPIDIO_CLKINn[1:0]    | DIFF IN  | PCIe_F1: RAPIDIO_CLKINp/n[1]     |  |
| KAFIDIO_CLKINII[1.0]   |          | PCIe_GO: RAPIDIO_CLKINp/n[0]     |  |
| PCIe_REFCLKOUTp[3:0]   | DIFF OUT | ppg 45 # HLFL#A.II.              |  |
| PCIe_REFCLKOUTn[3:0]   |          | PRG 参考时钟输出                       |  |
| PCIe_PRG_REFRES        | A        | 通过 487ohm(+/-1%)电阻连至 PCIE_1VO 电源 |  |
| PCIe_F0/F1/G0_TXp[3:0] | DIED OUT | PCIe 差分数据输出                      |  |
| PCIe_F0/F1/G0_TXn[3:0] | DIFF OUT |                                  |  |
| PCIe_F0/F1/G0_RXp[3:0] | DIDE IN  | DOI + 1/1 W-14/4/                |  |
| PCIe_F0/F1/G0_RXn[3:0] | DIFF IN  | PCI e 差分数据输入<br>                 |  |
| PCIe_F0/F1/G0_RSTn     | 0        | PCIe 复位                          |  |

### 2.4 DVO 显示接口

表 2- 4 DVO 接口信号

| 信号名称          | 类型 | 描述                                      |  |
|---------------|----|-----------------------------------------|--|
| DVO_CLKp      | 0  | DVO 时钟输出                                |  |
| DVO_CLKn      | 0  | DVO 时钟输出,与 DVO*_CLKp 相差 180°, 非差<br>分关系 |  |
| DVO_HSYNC     | 0  | DVO 水平同步                                |  |
| DVO_VSYNC     | 0  | DVO 垂直同步                                |  |
| DVO_DE        | 0  | DVO 数据有效                                |  |
|               |    | DVO 显示数据                                |  |
| DVO_D[23:0] 0 |    | [23:16]为 R 数据                           |  |
|               |    | [15:08]为 G 数据                           |  |



|               |    | [07:00]为 B 数据       |  |
|---------------|----|---------------------|--|
| HDMI1_HOTPLUG | Ι  | DVO 通道热插拔检测(可选)     |  |
| HDMI1_I2C_SCL | OC | DVO 通道 I2C 串行时钟(可选) |  |
| HDMI1_I2C_SDA | OC | DVO 通道 I2C 串行数据(可选) |  |

DVO 接口数据信号与 RGB 对应关系如下:

表 2- 5 DVO 接口 RGB 对应关系

| DVO 接口信号 | 24 位模式 | 18 位模式 |
|----------|--------|--------|
| DVO_DO   | В0     |        |
| DVO_D1   | B1     |        |
| DVO_D2   | B2     | В0     |
| DVO_D3   | В3     | B1     |
| DVO_D4   | B4     | B2     |
| DVO_D5   | B5     | В3     |
| DVO_D6   | B6     | B4     |
| DVO_D7   | В7     | B5     |
| DVO_D8   | GO     |        |
| DVO_D9   | G1     |        |
| DVO_D10  | G2     | GO     |
| DVO_D11  | G3     | G1     |
| DVO_D12  | G4     | G2     |
| DVO_D13  | G5     | G3     |
| DVO_D14  | G6     | G4     |
| DVO_D15  | G7     | G5     |
| DVO_D16  | RO     |        |
| DVO_D17  | R1     |        |
| DVO_D18  | R2     | RO     |
| DVO_D19  | R3     | R1     |
| DVO_D20  | R4     | R2     |
| DVO_D21  | R5     | R3     |
| DVO_D22  | R6     | R4     |
| DVO_D23  | R7     | R5     |

DVO 接口与 LIO 以及 GPIO 有复用关系,如表 2-6 所示。

表 2- 6 DVO、LIO 和 GPIO 复用关系

| 信号名称      | 复用名称 1    | 复用名称 2  | 复用2类型 | 复用 2 信号描述             |
|-----------|-----------|---------|-------|-----------------------|
| DVO_CLKp  | ND_GPI004 | LIO_RDn | 0     | LIORDn 输出             |
| DVO_CLKn  | ND_GP1003 | LIO_WRn | 0     | LIOWRn 输出             |
| DVO_HSYNC | ND_GP1007 | LIO_DEN | 0     | LIO 数据使能              |
| DVO_VSYNC | ND_GP1006 | LIO_DIR | 0     | LIO 方向控制, 0 代表读, 1 代表 |



|              |                    |              |     | 写             |
|--------------|--------------------|--------------|-----|---------------|
| DVO_DE       | ND_GPI005          | LIO_ADLOCK   | 0   | LIO 地址/数据选择信号 |
| DVO_D[15:0]  | ND_GPI0[23:0<br>8] | LIO_AD[15:0] | I/0 | LIO 双向 AD 信号  |
| DVO_D[22:16] | ND_GPI0[30:2<br>4] | LIO_A[6:0]   | 0   | LIO 地址低位      |
| DVO_D23      | ND_GPI031          | LIO_CSn0     | 0   | LIO 片选信号 0    |
|              | ND_GPI0[02:0<br>0] | LIO_CSn[3:1] | 0   | LIO 片选信号 1-3  |
|              |                    | LIO_RDY      | I   | LIO 数据准备好     |

# 2.5 HDMI 接口

表 2- 7 HDMI 接口信号

| 信号名称           | 类型       | 信号描述             |
|----------------|----------|------------------|
| HDMIO_CKn      | DIFF OUT | HDMI 通道时钟负端输出    |
| HDMIO_CKp      | DIFF OUT | HDMI 通道时钟正端输出    |
| HDMIO_HOTPLUG  | Ι        | HDMI 通道热插拔检测     |
| HDMIO_I2C_SCL  | OC       | HDMI 通道 I2C 串行时钟 |
| HDMIO_I2C_SDA  | OC       | HDMI 通道 I2C 串行数据 |
| HDMIO_TXN[2:0] | DIFF OUT | HDMI 通道数据负端输出    |
| HDMIO_TXP[2:0] | DIFF OUT | HDMI 通道数据正端输出    |

# 2.6 GMAC 接口

表 2-8 网口信号

| 信号名称                | 类型      | 描述                              |
|---------------------|---------|---------------------------------|
| GMACPHYO/1_An       | DIFF IO | 千兆网双绞线 A 负端口                    |
| GMACPHYO/1_Ap       | DIFF IO | 千兆网双绞线 A 正端口                    |
| GMACPHYO/1_Bn       | DIFF IO | 千兆网双绞线 B 负端口                    |
| GMACPHYO/1_Bp       | DIFF IO | 千兆网双绞线 B 正端口                    |
| GMACPHYO/1_Cn       | DIFF IO | 千兆网双绞线 C 负端口                    |
| GMACPHYO/1_Cp       | DIFF IO | 千兆网双绞线 C 正端口                    |
| GMACPHYO/1_Dn       | DIFF IO | 千兆网双绞线 D 负端口                    |
| GMACPHYO/1_Dp       | DIFF IO | 千兆网双绞线 D 正端口                    |
| GMACPHYO/1_LED_100B | 0       | 十/百兆网工作状态指示灯,高有效                |
| GMACPHYO/1_LED_1KB  | 0       | 千兆网工作状态指示灯,高有效                  |
| GMACPHYO/1_LED_ACT  | 0       | 网络收发包状态指示,高有效                   |
| a anywe /- nnw      |         | GMACPHY 外部参考电阻输入,通过 4.99Kohm/1% |
| GMACPHYO/1_REXT     | I       | 电阻连至地                           |



表 2- 9 GMAC 接口信号

| 信号名称           | 类型  | 描述         |
|----------------|-----|------------|
| GMAC2_TXCK     | 0   | RGMII 发送时钟 |
| GMAC2_TCTL     | 0   | RGMII 发送控制 |
| GMAC2_TXD[3:0] | 0   | RGMII 发送数据 |
| GMAC2_RXCK     | Ι   | RGMII 接收时钟 |
| GMAC2_RCTL     | I   | RGMII 接收控制 |
| GMAC2_RXD[3:0] | I   | RGMII 接收数据 |
| GMAC2_MDCK     | 0   | SMA 接口时钟   |
| GMAC2_MDIO     | I/0 | SMA 接口数据   |

GMAC 接口与 UART 和 GPIO 有复用关系,如下表所示。

表 2- 10 GMAC 与 UART、GPIO 复用关系

| 信号名称              | 复用名称 1 | 复用名称 2    | 复用2类型 | 复用 2 信号描述        |
|-------------------|--------|-----------|-------|------------------|
| GMAC2_MDCK        | GPI051 |           | _     | _                |
| GMAC2_MDIO        | GPI050 |           |       |                  |
| GMAC2_RCTL        | GPI044 | UART1_CTS | I     | 设备接受数据就绪         |
| GMAC2_RXCK        | GPI053 |           |       |                  |
| GMAC2_RXD0        | GPI040 | UART1_DCD | I     | 外部 MODEM 探测到载波信号 |
| GMAC2_RXD1        | GPIO41 | UART1_RI  | I     | 外部 MODEM 探测到振铃信号 |
| GMAC2_RXD2        | GPI042 | UART1_DSR | I     | 设备初始化完成          |
| GMAC2_RXD3        | GPI043 | UART1_DTR | 0     | 串口初始化完成          |
| GMAC2_TCTL        | GPI049 |           |       |                  |
| GMAC2_TXCK        | GPI052 |           |       |                  |
| GMAC2_TXD0        | GPI045 | UART1_RTS | 0     | 串口数据传输请求         |
| GMAC2_TXD1        | GPI046 | UART1_RXD | I     | 串口数据输入           |
| GMAC2_TXD2        | GPIO47 | UART1_TXD | 0     | 串口数据输出           |
| GMAC2_TXD3        | GPI048 |           |       |                  |
| GMACPHY1_LED_100B | GPI061 |           |       |                  |
| GMACPHY1_LED_1KB  | GPI062 |           | -     | -                |
| GMACPHY1_LED_ACT  | GPI060 |           | _     | _                |

### 2.7 SATA 接口

表 2- 11 SATA 接口信号

| 信号名称          | 类型       | 描述                        |
|---------------|----------|---------------------------|
| SATA_REFCLKP1 | т.       | 差分 25MHz 参考时钟输入(内部有备份时钟,通 |
| SATA_REFCLKN2 | 1        | 过软件控制)                    |
| SATA_REFRES   | A        | 外部参考电阻                    |
| SATAO/1_TXp   | DIDD OUT | CAMA 25 A W. 12 FA da     |
| SATAO/1_TXn   | DIFF OUT | SATA 差分数据输出               |



| SATAO/1_RXp<br>SATAO/1_RXn | DIFF IN | SATA 差分数据输入        |
|----------------------------|---------|--------------------|
| SATA_LEDn                  | OD      | SATA 工作状态,低表示有数据传输 |

SATA接口的SATA\_LEDn与GPIO有复用关系,如下表所示。

表 2- 12 SATA 与 GPIO 复用关系

| 信号名称      | 复用名称   | 复用类型 | 复用信号描述    |
|-----------|--------|------|-----------|
| SATA_LEDn | GPI063 | I/0  | 通用输入输出 63 |

### 2.8 USB接口

表 2- 13 USB2.0 接口信号

| 信号名称              | 类型  | 描述                    |
|-------------------|-----|-----------------------|
| USB20_REFRES[2:0] | A   | 参考电阻                  |
| USB20_DP[8:0]     | I/0 | USB D+                |
| USB20_DM[8:0]     | I/0 | USB D-                |
| USB20_0C[3:0]     | Ι   | USB 过流检测输入,需注意该信号为高有效 |
| USB20_ID          | Ι   | OTG ID 输入             |
| USB20_VBUS        | A   | OTG VBUS 输入, 5V 供电    |

表 2- 14 USB3.0 接口信号

| 信号名称           | 类型       | 描述                          |
|----------------|----------|-----------------------------|
| HCD20 DEEDEC   | Δ.       | 外部参考电阻,通过 487ohm(+/-1%)电阻连至 |
| USB30_REFRES   | A        | RSM_1VOR 电源                 |
| USB30_RXp[3:0] | DIFF IN  | USB3 端口差分接收数据正端             |
| USB30_RXn[3:0] | DIFF IN  | USB3 端口差分接收数据负端             |
| USB30_TXp[3:0] | DIFF OUT | USB3 端口差分发送数据正端             |
| USB30_TXn[3:0] | DIFF OUT | USB3 端口差分发送数据负端             |
| USB30_REFCLKP1 | _        |                             |
| USB30_REFCLKN2 | 1        | 25MHz 参考时钟输入                |

USB接口与GPIO有复用关系,如下表所示。

表 2- 15 USB 与 GPIO 复用关系

| 信号名称      | 复用名称   | 复用类型 | 复用信号描述    |
|-----------|--------|------|-----------|
| USB20_0C0 | GPI028 | I/0  | 通用输入输出 28 |
| USB20_0C1 | GPI029 | I/0  | 通用输入输出 29 |
| USB20_0C2 | GPI030 | I/0  | 通用输入输出 30 |
| USB20_0C3 | GPI031 | I/0  | 通用输入输出 31 |



# 2.9 HDA 接口

表 2- 16 HDA 接口信号

| 信号名称       | 类型 | 描述                   |
|------------|----|----------------------|
| HDA_BITCLK | 0  | HDA BITCLK 输出        |
| HDA_SDIO   | Ι  | HDA 数据输入,连接第一个 codec |
| HDA_SDI1   | Ι  | HDA 数据输入,连接第二个 codec |
| HDA_SDI2   | Ι  | HDA 数据输入,连接第三个 codec |
| HDA_SDO    | 0  | HDA 数据输出             |
| HDA_SYNC   | 0  | HDA 同步               |
| HDA_RESETn | 0  | HDA 复位               |

HDA 接口与 I2S 以及 GPI0 复用,具体复用关系如下。复用配置请参考表 5- 14 通用配置寄存器 0。

表 2- 17 HDA 与 I2S 复用关系

| 信号名称       | 复用名称     | 复用类型 | 复用信号描述     |
|------------|----------|------|------------|
| HDA_BITCLK | I2S_BCLK | 0    | I2S bit 时钟 |
| HDA_SDIO   | I2S_DI   | I    | I2S 数据输入   |
| HDA_SDI1   | _        | _    | -          |
| HDA_SDI2   | _        | _    | -          |
| HDA_SDO    | I2S_D0   | 0    | I2S 数据输出   |
| HDA_SYNC   | I2S_MCLK | 0    | I2S MCLK   |
| HDA_RESETn | I2S_LR   | 0    | I2S 左右声道选择 |

表 2- 18 HDA 与 GPIO 复用关系

| 信号名称       | 复用名称   | 复用类型 | 复用信号描述    |
|------------|--------|------|-----------|
| HDA_BITCLK | GPI021 | I/0  | 通用输入输出 21 |
| HDA_SDIO   | GPI025 | I/0  | 通用输入输出 25 |
| HDA_SDI1   | GPI026 | I/0  | 通用输入输出 26 |
| HDA_SDI2   | GPI027 | I/0  | 通用输入输出 27 |
| HDA_SDO    | GPI024 | I/0  | 通用输入输出 24 |
| HDA_SYNC   | GPI022 | I/0  | 通用输入输出 22 |
| HDA_RESETn | GPI023 | I/0  | 通用输入输出 23 |

### 2.10 SPI 接口

表 2- 19 SPI 接口信号

| 信号名称      | 类型 | 描述       |
|-----------|----|----------|
| SPIO_SCK  | 0  | SPI 时钟输出 |
| SPIO_CSn0 | 0  | SPI 片选 0 |
| SPIO_CSn1 | 0  | SPI 片选 1 |



| SPI0_CSn2  | 0 | SPI 片选 2     |
|------------|---|--------------|
| SPIO_CSn3  | 0 | SPI 片选 3     |
| SPIO_SDO   | 0 | SPI 数据输出     |
| SPIO_SDI   | I | SPI 数据输入     |
| SPIO_HOLDn | 0 | SPI 地址保持输入输出 |
| SPIO_WPn   | 0 | SPI 写保护输出    |

SPI1与 SDI0和 GPI0 复用关系见 SDI0 小节介绍。

### 2.11 I2C接口

表 2- 20 I2C 接口信号

| 信号名称         | 类型 | 描述     |
|--------------|----|--------|
| I2C[3:0]_SCL | OD | I2C 时钟 |
| I2C[3:0]_SDA | OD | I2C 数据 |

I2C2 和 I2C3 复用关系见 LPC 小节介绍。

### 2.12 UART接口

表 2- 21 UART 接口信号

| 信号名称          | 类型 | 描述               |
|---------------|----|------------------|
| UART[2:0]_TXD | 0  | 串口数据输出           |
| UART[2:0]_RXD | Ι  | 串口数据输入           |
| UART[2:0]_RTS | 0  | 串口数据传输请求         |
| UART[2:0]_DTR | 0  | 串口初始化完成          |
| UART[2:0]_RI  | Ι  | 外部 MODEM 探测到振铃信号 |
| UART[2:0]_CTS | Ι  | 设备接受数据就绪         |
| UART[2:0]_DSR | Ι  | 设备初始化完成          |
| UART[2:0]_DCD | Ι  | 外部 MODEM 探测到载波信号 |
| ND_UART_TXD   | 0  | 串口数据输出           |
| ND_UART_RXD   | I  | 串口数据输入           |

2K2000有3个独立的全功能串口(UARTO/1/2)和1个双线UART接口(ND-UART),ND-UART 为 NODE 上的串口,其他串口通过设置可以工作在 2x4 和 4x2 模式,UARTO 各种模式的管脚 对应关系如下。

表 2- 22 UARTO 接口复用关系

| 1x8      | 2x4      | 4x2      |
|----------|----------|----------|
| TXD0 (0) | TXDO (O) | TXD0 (O) |
| RTS0 (0) | RTS0 (0) | TXD5 (O) |
| DTR0 (0) | TXD3 (0) | TXD3 (0) |



| RXDO(I) | RXDO(I)  | RXDO(I)  |
|---------|----------|----------|
| CTSO(I) | CTSO(I)  | RXD5(I)  |
| DSRO(I) | RXD3(I)  | RXD3(I)  |
| DCD0(I) | CTS3(I)  | RXD4(I)  |
| RIO(I)  | RTS3 (0) | TXD4 (0) |

UARTO 接口与 AVS 复用,具体复用关系如下。

表 2- 23 UARTO 与 AVS 复用关系

| 信号名称      | 复用名称      | 复用类型 | 复用信号描述 |
|-----------|-----------|------|--------|
| UARTO_TXD |           |      |        |
| UARTO_RXD |           |      |        |
| UARTO_RTS |           |      |        |
| UARTO_DTR |           |      |        |
| UARTO_RI  | AVS_MDATA | 0    | 输出数据   |
| UARTO_CTS |           |      |        |
| UARTO_DSR | AVS_CLOCK | 0    | 输出时钟   |
| UARTO_DCD | AVS_SDATA | I    | 输入数据   |

UART1 和 UART2 的复用关系分别见 GMAC 和 LPC 小节。

## 2.13 CAN 接口

表 2- 24 CAN 接口信号

| 信号名称    | 类型 | 描述            |
|---------|----|---------------|
| CANO_RX | I  | CAN 通道 0 数据接收 |
| CANO_TX | 0  | CAN 通道 0 数据发送 |
| CAN1_RX | I  | CAN 通道 1 数据接收 |
| CAN1_TX | 0  | CAN 通道 1 数据发送 |
| CAN2_RX | I  | CAN 通道 2 数据接收 |
| CAN2_TX | 0  | CAN 通道 2 数据发送 |
| CAN3_RX | I  | CAN 通道 3 数据接收 |
| CAN3_TX | 0  | CAN 通道 3 数据发送 |
| CAN4_RX | I  | CAN 通道 4 数据接收 |
| CAN4_TX | 0  | CAN 通道 4 数据发送 |
| CAN5_RX | I  | CAN 通道 5 数据接收 |
| CAN5_TX | 0  | CAN 通道 5 数据发送 |

CANO-3接口与LPC接口有复用,CAN4-5接口与PWM有复用,具体复用参见各自小节。



## 2.14 LPC 接口

表 2- 25 LPC 接口信号

| 信号名称       | 类型  | 描述                              |  |
|------------|-----|---------------------------------|--|
| LPC_ADO    | I/0 | LPC 复用的命令、地址、数据信号线 0            |  |
| LPC_AD1    | I/0 | LPC 复用的命令、地址、数据信号线 1            |  |
| LPC_AD2    | I/0 | LPC 复用的命令、地址、数据信号线 2            |  |
| LPC_AD3    | I/0 | LPC 复用的命令、地址、数据信号线 3            |  |
| LPC_CLK    | 0   | LPC 33MHz 时钟输出                  |  |
| LPC_FRAMEn | I/0 | LPC 总线帧起始、结束信号                  |  |
| LPC_RESETn | 0   | LPC 总线复位信号                      |  |
| LPC_SERIRQ | I/0 | LPC 总线 serial IRQ 信号,用于传输串行中断信号 |  |

LPC与UART、CAN、I2C、GPIO有复用,复用关系见下表。

表 2- 26 SDIO 与 GPIO 复用关系

| 信号名称       | 复用名称 1                           | 复用名称 2  | 复用名称3    | 复用名称 4 |
|------------|----------------------------------|---------|----------|--------|
| LPC_ADO    | UART2_DCD (UART9_CTS/UART10_RXD) | CAN3_RX | I2C2_SCL | GPI032 |
| LPC_AD1    | UART2_RI (UART9_RTS/UART10_TXD)  | CAN3_TX | I2C2_SDA | GPI033 |
| LPC_AD2    | UART2_DSR (UART9_RXD)            | CAN2_RX | I2C3_SCL | GPI034 |
| LPC_AD3    | UART2_DTR (UART9_TXD)            | CAN2_TX | I2C3_SDA | GPI035 |
| LPC_CLK    | UART2_TXD                        | CANO_TX |          | GPI039 |
| LPC_FRAMEn | UART2_RTS (UART11_TXD)           | CAN1_TX |          | GPIO37 |
| LPC_RESETn | UART2_RXD                        | CANO_RX |          | GPI038 |
| LPC_SERIRQ | UART2_CTS (UART11_RXD)           | CAN1_RX |          | GPI036 |

## 2.15 SDIO接口

表 2- 27 SDIO 接口信号

| 信号名称           | 类型  | 描述          |  |
|----------------|-----|-------------|--|
| SDIO_CLK       | 0   | SDIO 时钟输出   |  |
| SDIO_CMD       | I/0 | SDIO 命令输入输出 |  |
| SDIO_DATA[3:0] | I/0 | SDIO 数据信号   |  |

SDIO与SPI1、GPIO有复用,复用关系见下表。

表 2- 28 SDIO与 SPI1、GPIO 复用关系

| 信号名称       | 复用名称1  | 复用名称 2    | 复用2类型 | 复用 2 信号描述 |
|------------|--------|-----------|-------|-----------|
| SDIO_CLK   | GPI059 | SPI1_SCK  | 0     | SPI 时钟输出  |
| SDIO_CMD   | GPI058 | SPI1_SD0  | 0     | SPI 数据输出  |
| SDIO_DATAO | GPI054 | SPI1_CSn0 | 0     | SPI 片选 0  |
| SDIO_DATA1 | GPI055 | SPI1_CSn2 | 0     | SPI 片选 2  |
| SDIO_DATA2 | GPI056 | SPI1_CSn3 | 0     | SPI 片选 3  |
| SDIO_DATA3 | GPI057 | SPI1_SDI  | Ι     | SPI 数据输入  |



# 2.16 eMMC 接口

表 2- 29 eMMC 接口信号

| 信号名称           | 类型  | 描述           |
|----------------|-----|--------------|
| EMMC_CLK       | 0   | EMMC 时钟输出    |
| EMMC_CMD       | I/0 | EMMC 命令输入输出  |
| EMMC_DATA[7:0] | I/0 | EMMC 数据输入输出位 |
| EMMC_DS        | I   | EMMC 数据选通信号  |

eMMC与GPIO有复用,复用关系见下表。

表 2- 30 eMMC 与 GPIO 复用关系

| 信号名称           | 复用名称        | 复用类型 | 复用信号描述 |
|----------------|-------------|------|--------|
| EMMC_CLK       | GPI020      | I/0  | 通用输入输出 |
| EMMC_CMD       | GPI019      | I/0  | 通用输入输出 |
| EMMC_DATA[7:0] | GPIO[17:10] | I/0  | 通用输入输出 |
| EMMC_DS        | GPI018      | I/0  | 通用输入输出 |

#### 2.17 GPIO

下表仅列出专用的 4 个 GPI0 引脚信号(不包含 ACPI 和 SE 专用 GPI0),其他 GPI0 为 复用信号,可参考其他信号定义。

表 2- 31 GPIO 信号

| 信号名称   | 类型  | 描述     |
|--------|-----|--------|
| GPI000 | I/0 | 通用输入输出 |
| GPI001 | I/0 | 通用输入输出 |
| GPI002 | I/0 | 通用输入输出 |
| GPI003 | I/0 | 通用输入输出 |

### 2.18 PWM

表 2- 32 PWM 信号

| 信号名称     | 类型 | 描述     |
|----------|----|--------|
| PWM[5:0] | 0  | PWM 输出 |

PWM 与 CAN、GPIO 有复用,复用关系如下。

表 2-33 PWM 与 CAN、GPIO 复用关系

| 信号名称 | 复用名称 1 | 复用名称 2  | 复用2类型 | 复用 2 信号描述     |
|------|--------|---------|-------|---------------|
| PWMO | GPI004 |         |       |               |
| PWM1 | GPI005 |         |       |               |
| PWM2 | GPI006 | CAN4_TX | 0     | CAN 通道 4 数据接收 |



| PWM3 | GPI007 | CAN4_RX | I | CAN 通道 4 数据发送 |
|------|--------|---------|---|---------------|
| PWM4 | GPI008 | CAN5_TX | 0 | CAN 通道 5 数据接收 |
| PWM5 | GPI009 | CAN5_RX | Ι | CAN 通道 5 数据发送 |

# 2.19 ACPI接口

表 2- 34 ACPI 信号

| 信号名称            | 类型  | 描述                                      |  |  |  |
|-----------------|-----|-----------------------------------------|--|--|--|
|                 |     | ACPI 使能                                 |  |  |  |
|                 |     | 0: 不使能 ACPI 功能,此时除了复位信号(ACPI_SYSRSTn)外, |  |  |  |
| ACPI_EN         | I   | 其他电源管理信号无效;                             |  |  |  |
|                 |     | 1: 使能 ACPI 功能;                          |  |  |  |
|                 |     | (板级必须控制,可根据需要设置为0或者1)                   |  |  |  |
| ACPI_SYSRSTn    | I   | 系统复位,低有效。                               |  |  |  |
| ACF1_313K31II   | 1   | (必须按照时序要求进行控制)                          |  |  |  |
| ACDI WAKEN      | I   | PCIe 唤醒,低有效。                            |  |  |  |
| ACPI_WAKEN      | 1   | (不使用时上拉处理)                              |  |  |  |
| ACDI CUCCTATE   | 0   | 低功耗状态,低有效                               |  |  |  |
| ACPI_SUSSTATn   | 0   | (不使用时可不接)                               |  |  |  |
| ACDI San        | 0   | S3 状态, 低有效。                             |  |  |  |
| ACPI_S3n        | 0   | (不使用时可不接)                               |  |  |  |
| ACPI_S4n        | 0   | S4 状态, 低有效。                             |  |  |  |
| ACF1_54II       | 0   | (不使用时可不接)                               |  |  |  |
| ACPI_S5n        | 0   | S5 状态, 低有效。                             |  |  |  |
| ACF1_SSII       | 0   | (不使用时可不接)                               |  |  |  |
|                 |     | 平台复位,低有效。                               |  |  |  |
| ACPI_PLTRSTn    | 0   | (建议板级使用该复位信号,ACPI_EN 为 0 时该信号仅受         |  |  |  |
|                 |     | ACPI_SYSRSTn 控制)                        |  |  |  |
| ACPI_PWRBTNn    | I   | 电源开关,低有效。                               |  |  |  |
| ACF 1_F WIDTNII | 1   | (不使用时上拉处理)                              |  |  |  |
| ACPI PWROK      | I   | 电源有效,指示最后一级电源上电成功,高有效。                  |  |  |  |
| ACF 1_F WROK    | 1   | (不使用时上拉处理)                              |  |  |  |
| ACPI_VSBGATE    | 0   | 主电源和 standby 电源切换控制信号                   |  |  |  |
| ACFI_VSDGATE    | 0   | (不使用时可不接)                               |  |  |  |
|                 |     | ACPI 域 GPIO 端口,用作 GPE 功能,具有唤醒和中断功能,中断   |  |  |  |
| ACPI_GPIO[7:0]  | I/0 | 类型包括电平/边沿/双沿,极性可设置                      |  |  |  |
|                 |     | (不使用时可不接)                               |  |  |  |
| ACPI_RSMRSTn    | I   | ACPI 域复位信号,低有效                          |  |  |  |
| VOLT_VOWNOTTI   | 1   | (必须按照时序要求进行控制)                          |  |  |  |
|                 |     | 测试模式控制(ACPI 电压域)                        |  |  |  |
| ACPI_DOTESTn    | I   | 0: 测试模式                                 |  |  |  |
|                 |     | 1: 功能模式                                 |  |  |  |



# 2.20 JTAG 接口

表 2- 35 JTAG 接口

| 信号名称          | 类型 | 描述             |
|---------------|----|----------------|
|               |    | JTAG 选择        |
|               |    | 00: CPU_JTAG   |
| JTAG_SEL[1:0] | I  | 01: SE_JTAG    |
|               |    | 10: LA132_JTAG |
|               |    | 11: GPU_JTAG   |
| JTAG_TCK      | Ι  | JTAG 时钟        |
| JTAG_TDI      | Ι  | JTAG 数据输入      |
| JTAG_TMS      | Ι  | JTAG 模式        |
| JTAG_TRST     | Ι  | JTAG 复位        |
| JTAG_TDO      | 0  | JTAG 数据输出      |

### 2.21 时钟信号

表 2- 36 时钟信号

| 信号名称        | 类型 | 描述                     |  |
|-------------|----|------------------------|--|
| SYS_SYSCLK  | Ι  | 100MHz 参考时钟            |  |
| CVC TROTOLV | Т  | 测试时钟输入, 功能模式下板级必须将该引脚下 |  |
| SYS_TESTCLK | 1  | 拉至 GND                 |  |

# 2.22 RTC 相关信号

表 2- 37 时钟信号

| 信号名称   | 类型  | 描述                |
|--------|-----|-------------------|
| RTC_XI | I/0 | 32. 768KHz 晶体输入接口 |
| RTC_XO | I/0 | 32. 768KHz 晶体输出接口 |

## 2.23 安全模块接口

表 2-38 安全模块接口

| 信号名称       | 类型 | 描述                           |
|------------|----|------------------------------|
| PIN_SE_EN  | Ι  | SE 模块使能输入,1=enable,0=disable |
|            |    | 安全模块时钟选择输入                   |
| SE_CLK_SEL | I  | 0: 使用内部晶振产生的 10M 时钟          |
|            |    | 1: 使用外部 100M 参考时钟            |
| SE_GPI000  | 10 | 安全模块通用输入输出 0                 |
| SE_GPI001  | 10 | 安全模块通用输入输出1                  |
| SE_GPI002  | 10 | 安全模块通用输入输出 2                 |
| SE_GPI003  | 10 | 安全模块通用输入输出3                  |
| SE_GPI004  | 10 | 安全模块通用输入输出 4                 |
| SE_GPI005  | 10 | 安全模块通用输入输出 5                 |



| SE_GPI006         | 10 | 安全模块通用输入输出 6          |
|-------------------|----|-----------------------|
| SE_GPI007         | 10 | 安全模块通用输入输出 7          |
| SE_GPI008         | 10 | 安全模块通用输入输出 8          |
| SE_GPI009         | 10 | 安全模块通用输入输出 9          |
| SE_I2C_SCL        | 10 | 安全模块 I2C 总线数据         |
| SE_I2C_SDA        | 10 | 安全模块 I2C 总线时钟         |
| SE_QSPI_FLASH_CLK | 0  | 安全模块 QSPI1 Flash 时钟输入 |
| SE_QSPI_FLASH_CSn | 0  | 安全模块 QSPI1 Flash 片选输出 |
| SE_QSPI_FLASH_IO0 | 10 | 安全模块 QSPI1 Flash 数据 0 |
| SE_QSPI_FLASH_I01 | 10 | 安全模块 QSPI1 Flash 数据 1 |
| SE_QSPI_FLASH_I02 | 10 | 安全模块 QSPI1 Flash 数据 2 |
| SE_QSPI_FLASH_I03 | 10 | 安全模块 QSPI1 Flash 数据 3 |
| SE_RNGO_CLK       | 0  | 安全模块 RNGO 时钟输出        |
| SE_RNGO_DATA      | 10 | 安全模块 RNGO 数据          |
| SE_RNGO_OEn       | 0  | 安全模块 RNGO 数据输出允许      |
| SE_RNGO_PE        | 0  | 安全模块 RNGO 端口输出允许      |
| SE_RNG1_CLK       | 0  | 安全模块 RNG1 时钟输出        |
| SE_RNG1_DATA      | 10 | 安全模块 RNG1 数据          |
| SE_RNG1_OEn       | 0  | 安全模块 RNG1 数据输出允许      |
| SE_RNG1_PE        | 0  | 安全模块 RNG1 端口输出允许      |
| SE_SPI_CLK        | 0  | 安全模块 SPI 时钟           |
| SE_SPI_CSn        | 0  | 安全模块 SPI 片选输出         |
| SE_SPI_MISO       | I  | 安全模块 SPI 数据输入         |
| SE_SPI_MOSI       | 0  | 安全模块 SPI 数据输出         |
| SE_UARTO_RX       | I  | 安全模块串口0数据接收           |
| SE_UARTO_TX       | 0  | 安全模块串口0数据发送           |

# 2.24 系统相关信号

表 2- 39 系统相关信号

| 信号名称             | 类型 | 描述                                   |
|------------------|----|--------------------------------------|
|                  |    | eMMC 引脚电压检测结果选择 (VDD 大于 0.85V 时推荐 0) |
| SYS_CLKSEL       | Ι  | 0: 硬件检测结果                            |
|                  |    | 1: 软件配置                              |
|                  |    | PRG 参考时钟选择                           |
| PRG_CLKSEL       | I  | 0: 选择 USB3 输出的 25MHz 参考时钟            |
|                  |    | 1:选择PCIe_REFCLKp/n作为参考时钟             |
|                  |    | USB 参考时钟选择                           |
| USB_CLKSEL       | Ι  | 0: USB 参考时钟为 25MHz 晶体                |
|                  |    | 1: USB 参考时钟为 25MHz 差分输入              |
| CHID CONFIC[1.0] | т  | PLL 时钟配置输入                           |
| CHIP_CONFIG[1:0] | Ι  | 00=低频模式                              |



|                  |   | 01=高频模式                           |
|------------------|---|-----------------------------------|
|                  |   | 10=软件模式(DFT)                      |
|                  |   | 11=bypass 模式                      |
|                  |   | 启动选择。                             |
|                  |   | 0: LIO                            |
| CHIP_CONFIG[3:2] | Ι | 1: SPI                            |
|                  |   | 2: SDIO                           |
|                  |   | 3: eMMC                           |
|                  |   | LIO 模式                            |
| CHIP_CONFIG6     | I | 0: 8bit                           |
|                  |   | 1: 16bit                          |
|                  |   | PCI e_F1/G0 端口模式 (为 0 时可通过软件更改模式) |
| CHIP_CONFIG7     | Ι | 0: PCIe                           |
|                  |   | 1: Rapid IO                       |
|                  |   | PCIe_ GO 工作模式                     |
| CHIP_CONFIG8     | Ι | 0: RC 模式                          |
|                  |   | 1: EP 模式                          |

## 2.25 其他信号接口

表 2-40 其他信号接口

| 信号名称          | 类型  | 描述                          |
|---------------|-----|-----------------------------|
| NMIN          | I   | 不可屏蔽中断输入                    |
| VDDG_CPU0     | I/0 | NC, 需浮空                     |
| VDDG_CPU1     | I/0 | NC, 需浮空                     |
| VDDG_GPUTOP   | I/0 | NC, 需浮空                     |
| VDDG_GPUVUSPC | I/0 | NC, 需浮空                     |
| VDDG_SE       | I/0 | NC, 需浮空                     |
| BBG_GNDSIN    | I   | BBGEN 模块-1.1~1.1V 偏置 GND 输入 |
| BBG_GNDSOUT   | 0   | BBGEN 模块-1.1~1.1V 偏置 GND 输出 |
| BBG_VDDSIN    | I   | BBGEN 模块-1.1~1.1V 偏置 VDD 输入 |
| BBG_VDDSOUT   | 0   | BBGEN 模块-1.1~1.1V 偏置 VDD 输出 |
| BBG_VNEG      | I   | 通过 1uF/4.7V 电容接地            |

# 2.26 外设功能复用表

模块层次的功能复用关系如下表所示:

表 2- 41 外设功能复用表

| 功能 0   | 功能1      | 功能 2   | 功能3 | 功能 4 | 功能 5 | 功能 6 |
|--------|----------|--------|-----|------|------|------|
| DDR4   |          |        |     |      |      |      |
| SE     |          |        |     |      |      |      |
| PCIex4 | 4*PCIex1 |        |     |      |      |      |
| PCIex4 | 2*PCIex1 | SRI0x4 |     |      |      |      |
| PCIex4 |          | SRI0x4 |     |      |      |      |
| SATA   | GPIO(1)  |        |     |      |      |      |





| USB            | GPIO(4)  |           |             |              |           |         |
|----------------|----------|-----------|-------------|--------------|-----------|---------|
| GMACO/1(w/PHY) | GPIO(3)  |           |             |              |           |         |
| HDMI           |          |           |             |              |           |         |
| DVO            | GPIO(32) | Local Bus |             |              |           |         |
|                |          |           |             | UART1 (4)    | UART1 (2) |         |
|                |          |           |             |              | UART8 (2) |         |
| GMAC2 (RGMII)  | GPIO(14) |           | UART1 (8)   | ( )          | UART6 (2) |         |
|                |          |           |             | UART6 (4)    | UART7 (2) |         |
| HDA            | GPIO(7)  |           |             | I2S          |           |         |
| SPI0           |          |           |             |              |           |         |
| RTC            |          |           |             |              |           |         |
| I2C0           |          |           |             |              |           |         |
| I2C1           |          |           |             |              |           |         |
|                | GPIO(2)  | CANO      |             | WADWO (4)    | UART2 (2) |         |
|                | GPIO(2)  | CAN1      | UART2(8)    | UART2 (4)    | UART11(2) |         |
| LPC            | GPIO(2)  | CAN2      |             | UART9 (4)    | UART9 (2) | I2C2    |
|                | GPIO(2)  | CAN3      |             |              | UART10(2) | I2C3    |
|                |          |           |             | WADWO (4)    | UARTO(2)  |         |
|                |          |           | 114 DWO (O) | UARTO (4)    | UART5 (2) |         |
|                |          |           | UARTO (8)   | HADWO (4)    | UART3 (2) | AVG (0) |
|                |          |           |             | UART3 (4)    | UART4(2)  | AVS (3) |
|                |          |           | UART (2)    |              |           |         |
| JTAG (LA364)   |          | JTAG      | JTAG (GPU)  | JTAG (LA132) | JTAG (SE) |         |
|                | GPIO(4)  |           |             |              |           |         |
| PWMO-1         | GPIO(2)  |           |             |              |           |         |
| PWM2-3         | GPIO(2)  | CAN4      | GPU_UART    |              |           |         |
| PWM4-5         | GPIO(2)  | CAN5      |             |              |           |         |
| eMMC           | GPIO(11) |           |             |              |           |         |
| SDIO           | GPIO(6)  |           | SPI1        |              |           |         |
| ACPI           | GPIO(8)  |           |             |              |           |         |



## 3 时钟结构

#### 3.1 芯片时钟结构

龙芯 2K2000 由一个 100MHz 单端时钟作为参考时钟,内部共有 6 个独立的 PLL,其中每个 PLL 最多可以提供 3 组频率上相互依赖的时钟输出。这 6 个 PLL 的用途分别为:

- ✓ 一个 PLL 用于产生 HDA、node 和 eMMC 时钟, node 时钟经过各自分频供 CPU 核、二级 Cache、一二级交叉开关、IO 子网络、I2S、加解密模块以及 LA132 使用;
- ✓ 一个 PLL 产生 GMAC 控制器、RapidIO、SATA 以及 USB 的时钟;
- ✓ 一个 PLL 产生 GPU、DC、VPU、DDR 时钟;
- ✓ 一个 PLL 产生 PIXO 和 HDMI PHY 时钟
- ✓ 一个 PLL 产生 PIX1 时钟
- ✓ 一个展频 PLL 产生 GPU、DDR 和 IO 子网络时钟

还有一个 MISC 时钟,直接使用 100MHz 参考时钟通过分频得到。

芯片时钟结构图如图 3-1 所示,



图 3-1 芯片时钟结构图



#### 3.2 系统参考时钟

芯片的系统参考时钟为单端输入时钟 SYS SYSCLK, 频率为 100MHz。

#### 3.3 内部网络时钟

芯片内部包含了 5 个主要 PLL, 这 5 个 PLL 以系统参考时钟作为输入, 用于产生芯片内部网络需要的各个时钟。每个 PLL 最多可以提供 3 个时钟输出。

这 5 个 PLL 的用途分别为:

- 一个 PLL 用于产生 HDA、node 和 eMMC 时钟, node 时钟经过各自分频供 CPU 核、二级 Cache、一二级交叉开关、IO 子网络、I2S、加解密模块以及 LA132 使用:
- 一个 PLL 产生 GMAC 控制器、RapidIO、SATA 以及 USB 的时钟;
- 一个 PLL 产生 GPU、DC、VPU、DDR 时钟;
- 一个 PLL 产生 PIXO 和 HDMI PHY 时钟;
- 一个 PLL 产生 PIX1 时钟;

PLL 的结构图如图 3-2 所示,



图 3- 2PLL 结构图

输出时钟频率的计算方式如下:

clock out = refclk / div ref \* loopc / divoutN;

其中,需要保证输入分频器的输出(refclk / div\_ref) 在 20  $^{\sim}$  40MHz 的范围内,倍 频模块倍频后的频率(refclk / div ref \* 100pc)在 1. 2GHz  $^{\sim}$  3. 2GHz 的范围内。

PLL相关的配置及说明见表 3-1。这些配置通过 PLL0-4 配置寄存器 (参见 5.21-5.25 章 节) 进行控制。



| 信号            | 位数 | 方向  | 说明             |
|---------------|----|-----|----------------|
| pll_div_out0  | 7  | R/W | PLL 输出时钟 0 分频数 |
| pll_div_out1  | 7  | R/W | PLL 输出时钟 1 分频数 |
| pll_div_out2  | 7  | R/W | PLL 输出时钟 2 分频数 |
| pll_loopc     | 9  | R/W | PLL 倍频乘数       |
| pll_div_ref   | 7  | R/W | PLL 输入分频数      |
| pll_locked    | 1  | RO  | PLL 锁定         |
| sel_pll_out0  | 1  | R/W | 选择 PLL 输出时钟 0  |
| sel_pll_out1  | 1  | R/W | 选择 PLL 输出时钟 1  |
| sel_pll_out2  | 1  | R/W | 选择 PLL 输出时钟 2  |
| set_pll_param | 1  | R/W | 设置 PLL 配置参数    |
| pll_bypass    | 1  | R/W | PLL 内部 bypass  |
| pll_pd        | 1  | R/W | PLL powerdown  |

表 3-1 PLL 相关配置信号说明表

当 CHIP\_CONFIG[1:0]为 10b 时表示可通过软件更改 PLL 的输出频率。这种配置下,芯片启动时默认的时钟频率为外部参考时钟频率,需要在启动过程中对芯片时钟进行软件配置。通过软件修改时钟配置的过程如下:

- 1. 将 sel\_pll\_out\*设置为 0;
- 2. 将 pl1 pd 信号设置为 1;
- 3. 将 set\_pll\_param 设置为 0,
- 4. 设置 pll\_div\_ref/pll\_loopc/pll\_div\_out\*的值;
- 5. 将 set pll param 设置为 1;
- 6. 将 pl1 pd 信号设置为 0;
- 7. 等待 PLL 锁定信号 pl1\_locked 变为 1;
- 8. 设置 sel\_pll\_out\*为 1。

根据小数环路分频使能的设置,环路分频系数计算公式有所不同。

当小数环路分频未使能时,环路分频系数为:

DIV LOOPC = 4\*loopc

当小数环路分频使能时,环路分频系数为:

DIV\_LOOPC = 4\*(loopc+frac\_input/(2^16)+!(dither\_disable[1])

第 n 路输出时钟频率计算公式如下:

f outn = fref/ref div\*DIV LOOPC/(2\*div outn)

在参数配置时要求 VCO 的振荡频率 (fref/ref div\*DIV LOOPC) 在 1.6-3.2GHz 之间.

#### 3.4 RTC 时钟

RTC 时钟频率要求为 32.768KHz。可选择外接晶体或者晶振,芯片内部 RTC 模块可以自适应这两种时钟输入,无需特别控制。



#### 3.5 PCIe PHY 参考时钟

2K2000 的 PCIe 有 3 个 PHY, 它们共用内部参考时钟。可以从下面三个时钟源对参考时钟进行选择:

- 1、外部 100MHz 单端参考时钟 SYS SYSCLK
- 2、外部 100MHz 差分输入 (PCIe REFCLKp/n)
- 3、USB PHY 的 25MHz 参考时钟 (USB CLKINp/n)

另外, PCIe F1 作为 RapidIO 使用时由外部提供 156. 25MHz 的差分参考时钟。这种情况下, 其他 PCIe 仍可从以上两种参考时钟进行选择。

#### 3.6 USB PHY 参考时钟

USB3 PHY 的参考时钟有以下两种选择方式,通过芯片引脚 USB CLKSEL 进行选择:

- 1、外接 25MHz 晶体;
- 2、外接 25MHz 差分输入;

USB2 PHY 的参考时钟可以从下面两个时钟源进行选择:

- 1、系统参考时钟经过4分频后得到的25M单端时钟;
- 2、USB3 PHY的 25M 参考时钟。

#### 3.7 SATA PHY 参考时钟

SATA PHY 的参考时钟可以从下面三个时钟源进行选择:

- 1、外部 25MHz 差分输入(SATA REFCLKp/n)
- 2、USB3 PHY的 25M 参考时钟
- 3、内部系统参考时钟经过 4 分频后得到的 25M 差分时钟

### 3.8 GMAC PHY 参考时钟

GMAC PHY 参考时钟有以下两个来源,通过配置寄存器 CFG. 0770[22]进行选择。

- 1、使用 USB3 PHY 的 25MHz 参考时钟 (USB CLKINp/n)
- 2、使用内部 PLL 生成的 GMAC 控制器时钟

#### 3.9 PHY 时钟之间关系

对于 USB3/2、PCIe、SATA 和 GMAC PHY, 在初始化之前需要保证其参考时钟已处于稳定状态,下表列出各参考时钟稳定的标志以及判断标准。



表 3-2 参考时钟稳定标志及判断标准

| 模块       | 参考时钟来源      | 参考时钟稳定标志                              |
|----------|-------------|---------------------------------------|
|          | 95.001- 目体  | USB3 osc 时钟稳定(USB3 PHY 配置寄存器 3bit24 置 |
| USB3 PHY | 25MHz 晶体    | 为 1)                                  |
|          | 25MHz 差分输入  | 输入时钟稳定                                |
| USB2 PHY | USB3 PHY    | 参考 USB3 PHY                           |
| CMAC DIN | USB3 PHY    | 参考 USB3 PHY                           |
| GMAC PHY | 内部 PLL0     | PLL0 lock (PLL0 配置寄存器 bit39 变为 1)     |
| CATA DIW | USB3 PHY    | 参考 USB3 PHY                           |
| SATA PHY | 25MHz 差分输入  | 输入时钟稳定                                |
| DDC      | USB3 PHY    | 参考 USB3 PHY                           |
| PRG      | 100MHz 差分输入 | 输入时钟稳定                                |
| DCI .    | DDC         | PRG 模块输出时钟稳定(PRG 模块配置寄存器 0 bit 48     |
| PCIe     | PRG         | 变为1)                                  |



## 4 电源管理

本章对电源管理进行简单介绍,具体寄存器及使用方法请参考第22章。

### 4.1 电源管理模块介绍

- 龙芯 2K2000 电源管理模块提供系统功耗管理实现机制。
- 支持 Advanced Configuration and Power Interface, Version 4.0a(ACPI), 提供相应的功耗管理功能。
- 系统休眠与唤醒,支持 ACPI S3 (待机到内存), ACPI S4 (待机到硬盘), ACPI S5 (软关机),并且支持电源失效检测和自动系统恢复。支持多种唤醒方式(USB,GMAC,电源开关等)。
- 动态性能功耗控制,支持处理器核 DVFS 控制。
- 系统时钟控制,模块时钟门控,多种方式调节频率。
- 提供温度管理控制功能。支持3级报警机制。

### 4.2 电源级别

表 4-1显示了系统支持的 ACPI 状态及其相关说明。

表 4- 1 ACPI 状态说明

| 状态    | 描述                                         |  |
|-------|--------------------------------------------|--|
| 00/00 | 全部工作,该模式下系统全部工作,处理器子状态可由 Cx 或 Px 决定,媒体处理器由 |  |
| G0/S0 | 状态 Dx 决定。                                  |  |
| G1/S1 | 暂不支持                                       |  |
| G1/S3 | Suspend to RAM(STR),上下文保存到内存               |  |
| G1/S4 | Suspend to Disk(STD), 保存到硬盘, 除唤醒电路全部掉电     |  |
| G2/S5 | Soft off, 只有唤醒电路上电                         |  |
| G3    | Mechanical off,所有供电失效                      |  |



## 5 芯片配置寄存器

龙芯 2K2000 有大量的配置寄存器,多数分布于各个功能模块中,本章介绍芯片级的配置寄存器。其中 5.1 至 5.13 节配置寄存器的基地址为 0x1fe00000 或 0x3ff00000,5.14 至 5.71 节配置寄存器的基地址为 0x5ff00000。

关于二级交叉开关以及 DMA 访问窗口相关的配置寄存器将在第 6 章介绍,中断相关寄存器将在第 8 章和第 9 章介绍,这里不再赘述。下面详细介绍其他的配置寄存器。

### 5.1 版本寄存器

版本寄存器。

地址偏移: 0000h

默认值: 012h

表 5-1 版本寄存器

|     |         |    | * ****   |
|-----|---------|----|----------|
| 位域  | 字段名     | 访问 | 描述       |
| 7:0 | Version | R  | 配置寄存器版本号 |

#### 5.2 芯片特性寄存器

该寄存器标识了一些软件相关的处理器特性,供软件在使能特定功能前查看。

地址偏移: 0008h

默认值: 37fh

表 5-2 芯片特性寄存器

| 位域 | 字段名          | 访问 | 描述                           |
|----|--------------|----|------------------------------|
| 0  | Centigrade   | R  | 为1时,表示CSR[0x428]有效           |
| 1  | Node counter | R  | 为1时,表示CSR[0x408]有效           |
| 2  | MSI          | R  | 为1时,表示MSI可用                  |
| 3  | EXT_IOI      | R  | 为 1 时,表示 EXT_IOI 可用          |
| 4  | IPI_percore  | R  | 为1时,表示通过CSR私有地址进<br>行 IPI 发送 |
| 5  | Freq_percore | R  | 为1时,表示通过CSR私有地址调整频率          |
| 6  | Freq_scale   | R  | 为1时,表示动态分频功能可用               |
| 7  | DVFS_v1      | R  | 为 1 时,表示动态调频 v1 可用           |
| 8  | Tsensor      | R  | 为1时,表示温度传感器可用                |
| 9  | 中断译码         | R  | 中断引脚译码模式可用                   |



#### 5.3 厂商名称

该寄存器用于标识厂商名称。

地址偏移: 0010h

默认值: 6e6f\_7367\_6e6f\_6f4ch

表 5-3 厂商名称寄存器

|      |        | • • • | / 1.4 ⊟ 144 14 BB |
|------|--------|-------|-------------------|
| 位域   | 字段名    | 访问    | 描述                |
| 63:0 | Vendor | R     | 字符串"Loongson"     |

### 5.4 芯片名称

该寄存器用于标识芯片名称。

地址偏移: 0020h

默认值: 0000\_3030\_3032\_4b32h

表 5-4 芯片名称寄存器

| 位域   | 字段名 | 访问 | 描述           |
|------|-----|----|--------------|
| 63:0 | ID  | R  | 字符串 "2K2000" |

## 5.5 功能设置寄存器

地址偏移: 0180h

默认值: 3D00\_FFBB\_BB00\_3DE0h

表 5- 5 功能设置寄存器

| 位域   | 字段名                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 访问 | 描述                |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|-------------------|
| 3:0  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | RW | 保留                |
| 4    | MCO_disable_confspace                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | RW | 是否禁用 MCO DDR 配置空间 |
| 5    | MCO_defult_confspace                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | RW | 将所有内存访问路由至配置空间    |
| 6    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | RW | 保留                |
| 7    | MCO_resetn                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | RW | MCO 软件复位(低有效)     |
| 8    | MCO_clken                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | RW | 是否使能 MCO          |
| 43:9 | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | RW | 保留                |
| 63:5 | Course in the co | D  | CDII 15 +         |
| 6    | Cpu_version                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | R  | CPU 版本            |

## 5.6 温度采样寄存器

地址偏移: 0198h

默认值: 0000\_0000\_0000\_0000h



| 位域    | 字段名               | 访问 | 描述               |
|-------|-------------------|----|------------------|
| 15:0  |                   | R  | 保留               |
| 19:16 |                   | R  | 保留               |
| 20    | dotest            | R  | Dotest 引脚状态      |
| 21    |                   | R  |                  |
| 31:22 |                   | R  | 保留               |
| 45:32 | thsens_data       | R  | 传感器的原始数据         |
| 46    | thsens_overflow   | R  | 传感器监测值溢出标志       |
| 47    | reserved          | R  | 保留               |
| 48    | thsens outmode    | R  | 传感器配置的监测模式       |
|       |                   |    | 0: 温度模式; 1: 电压模式 |
| 51:49 | reserved          | R  | 保留               |
| 54:52 | thsens_outcluster | R  | 传感器配置的监测点        |
| 55    | reserved          | R  | 保留               |
| 63:56 | temperature       | R  | 摄氏温度值            |

表 5-6 温度采样寄存器

#### 5.7 处理器核分频设置寄存器

以下寄存器用于处理器核动态分频使用,使用该寄存器对处理器核进行调频设置,可以在 100ns 内完成变频操作,没有其它额外开销。

地址偏移: 01d0h

默认值: FFFF FFFF FFFFh

位域 字段名 访问 描述 核 0 分频控制值 2:0 core0\_freqctrl 3 core0 en RW 核 0 时钟使能 6:4 RW 核 1 分频控制值 corel\_freqctrl 7 核1时钟使能 corel en RW 软件分频后的时钟频率值等于原 来的(分频控制值+1)/8

表 5-7 处理器核软件分频设置寄存器

### 5.8 处理器核复位控制寄存器

以下寄存器用于处理器核软件控制复位使用。需要复位时,先将对应核的 resetn 置 0,再将 resetn\_pre 置 0,等待 500 微秒后,将 resetn\_pre 置 1,再将 resetn 置 1 即可完成整个复位过程。

地址偏移: 01d8h

默认值: FFFF\_FFFF\_FFFFh



| 表 5- | 8 | 处理器核软件分频设置寄存器 |
|------|---|---------------|
| 100  | 0 |               |

| 位域 | 字段名              | 访问 | 描述         |
|----|------------------|----|------------|
| 0  | CoreO_resetn_pre | RW | 核 0 复位辅助控制 |
| 1  | CoreO_resetn     | RW | 核 0 复位     |
| 2  | Corel_resetn_pre | RW | 核 1 复位辅助控制 |
| 3  | Corel_resetn     | RW | 核 1 复位     |

## 5.9 路由设置寄存器

以下寄存器用于控制芯片内的部分路由设置。

地址偏移: 0400h

默认值: 0044\_BF7C\_C000\_00F0h

| 位域 字段名   方向 描述   共享缓存散列位控制   表止通过基地址 0x3ff0_0000 对配置寄存器空间的路由                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 表 5- 9 芯片路由设置寄存器 |                     |    |                               |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|---------------------|----|-------------------------------|
| 9       disable_0x3ff0       RW       禁止通过基地址 0x3ff0_0000 对配置寄存器空间的路由内部等待计数器步长设置:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 位域               | 字段名                 | 访问 | 描述                            |
| Second State                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 3:0              | scid_sel            | RW | 共享缓存散列位控制                     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                  | 1: 11 0 0000        | DW | 禁止通过基地址 0x3ff0_0000 对配置寄存     |
| 0: 歩长为1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 9                | disable_0x3ff0      | KW | 器空间的路由                        |
| Sign                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                  |                     |    | 内部等待计数器步长设置:                  |
| 2: 步长为 2 3: 步长为 1  38:34 LIO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                  |                     |    | 0: 步长为1                       |
| 3: 步长为 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 33:32            | LIO clock_period_i  | RW | 1: 步长为4                       |
| RW   ROM 数据读取延迟(boot 时钟周期数)   Rom 数据位宽:   Rom 数据位宽:   0:8位   1:16位   16位   1:16位   10数据位宽:   10数据位宽:   10数据位宽:   10数据位宽:   10数据位宽:   10数据位宽:   1:16位   1:16 |                  |                     |    | 2: 步长为 2                      |
| RW   ROM 数据读取延迟(boot 时钟周期数)   Rom 数据位宽:   0:8位   1:16位     10 数据读取延迟(boot 时钟周期数)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                  |                     |    | 3: 步长为1                       |
| Rom 数据位宽:   Rom 数据位宽:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 20.24            | LIO                 | DW |                               |
| RW   0:8位   1:16位   1:16位   44:40   LIO io_count_init_i   RW   IO数据读取延迟 (boot 时钟周期数)   IO数据位宽:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 38:34            | rom_count_init_i    | KW | KUM 数据读取延迟(boot 时钟周期数)        |
| 1: 16 位  44:40 LIO io_count_init_i RW IO 数据读取延迟(boot 时钟周期数)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                  |                     |    | Rom 数据位宽:                     |
| 44:40   LIO io_count_init_i   RW   IO 数据读取延迟(boot 时钟周期数)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 39               | LIO rom_width16     | RW | 0:8位                          |
| LIO io_width_16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                  |                     |    | 1: 16位                        |
| LIO io_width_16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 44:40            | LIO io_count_init_i | RW | I0 数据读取延迟(boot 时钟周期数)         |
| 1: 16 位  1: 16 位  46                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                  |                     |    | IO 数据位宽:                      |
| RW   RW   RW   RW   LIO big_mem 模式控制                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 45               | LIO io_width_16     | RW | 0:8位                          |
| A7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                  |                     |    | 1: 16 位                       |
| 51:48       LIO adlock_cfg       RW       ADLOCK 时间软件配置         LIO cs 地址选择       0: 只使用 CSO, 地址空间为[31:0];         1:CS 使用地址[23:22],地址空间为[21:0];         55:52       LIO cs cfg         RW       2:CS 使用地址[24:23],地址空间为[22:0];         3:CS 使用地址[25:24],地址空间为[23:0];                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 46               | LIO iopf_en         | RW | 保留                            |
| LIO cs 地址选择 0: 只使用 CSO,地址空间为[31:0]; 1:CS 使用地址[23:22],地址空间为[21:0]; 2:CS 使用地址[24:23],地址空间为[22:0]; 3:CS 使用地址[25:24],地址空间为[23:0];                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 47               | LIO big_mem         | RW | LIO big_mem 模式控制              |
| 0: 只使用 CSO, 地址空间为[31:0];<br>1: CS 使用地址[23:22],地址空间为[21:0];<br>55:52 LIO cs cfg RW 2: CS 使用地址[24:23],地址空间为[22:0];<br>3: CS 使用地址[25:24],地址空间为[23:0];                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 51:48            | LIO adlock_cfg      | RW | ADLOCK 时间软件配置                 |
| 55:52       LIO cs cfg       RW       1:CS 使用地址[23:22],地址空间为[21:0];         2:CS 使用地址[24:23],地址空间为[22:0];         3:CS 使用地址[25:24],地址空间为[23:0];                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                  |                     |    | LIO cs 地址选择                   |
| 55:52       LIO cs cfg       RW       2:CS 使用地址[24:23],地址空间为[22:0];         3:CS 使用地址[25:24],地址空间为[23:0];                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                  |                     |    | 0: 只使用 CSO, 地址空间为[31:0];      |
| 3:CS 使用地址[25:24],地址空间为[23:0];                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                  | LIO cs cfg          |    | 1:CS 使用地址[23:22],地址空间为[21:0]; |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 55:52            |                     | RW | 2:CS 使用地址[24:23],地址空间为[22:0]; |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                  |                     |    | 3:CS 使用地址[25:24],地址空间为[23:0]; |
| 4:CS 使用地址[26:25],地址空间为[24:0];                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                  |                     |    | 4:CS 使用地址[26:25],地址空间为[24:0]; |
| 5:CS 使用地址[27:26],地址空间为[25:0];                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                  |                     |    | 5:CS 使用地址[27:26],地址空间为[25:0]; |



|    |               |    | 6:CS 使用地址[28:27],地址空间为[26:0]; |
|----|---------------|----|-------------------------------|
|    |               |    | 7:CS 使用地址[29:28],地址空间为[27:0]; |
|    |               |    | 8:CS 使用地址[30:29],地址空间为[28:0]; |
|    |               |    | 其他: CS 使用地址[31:30],地址空间为      |
|    |               |    | [29:0];                       |
| 61 | enable_gather | RW | boot 读响应聚合使能                  |

# 5.10 其它功能设置寄存器

以下寄存器用于控制芯片内部分功能使能。

地址偏移: 0420h

默认值: 0000\_0000\_0000\_0000h

| 表 5- 10 其它功能设置寄存器 |                     |    |                      |  |
|-------------------|---------------------|----|----------------------|--|
| 位域                | 字段名                 | 访问 | 描述                   |  |
| 0                 | disable_jtag        | RW | 完全禁用 JTAG 接口         |  |
| 1                 | disable_cpujtag     | RW | 完全禁用 CPU_JTAG 调试接口   |  |
| 2                 | disable_LA132       | RW | 完全禁用 LA132           |  |
| 3                 | disable_jtag132     | RW | 完全禁用 LA132 JTAG 调试接口 |  |
| 4                 | Disable_antifuse0   | RW | 禁用 fuse              |  |
| 5                 | Disable_antifuse1   | RW | 禁用 fuse              |  |
| 6                 | Disable_ID          | RW | 禁用 ID 修改             |  |
| 7                 |                     |    | 保留                   |  |
| 8                 | resetn_LA132        | RW | LA132 复位控制           |  |
| 9                 | sleeping_LA132      | R  | LA132 进入睡眠状态         |  |
| 10                | soft_int_LA132      | RW | LA132 核间中断寄存器        |  |
| 15:12             | core_int_en_LA132   | RW | LA132 对应每个核的 IO 中断使能 |  |
| 18:16             | freqscale_LA132     | RW | LA132 分频控制           |  |
| 19                | clken_LA132         | RW | LA132 时钟使能           |  |
| 20                |                     |    |                      |  |
| 21                | stable_resetn       | RW | 稳定时钟复位控制             |  |
| 22                | freqscale_percore   | RW | 使能每个核私有的调频寄存器        |  |
| 23                | clken_percore       | RW | 使能每个核私有的时钟使能         |  |
| 07.04             | Claration and       | DW | 配置总线超时时间设置,实际时       |  |
| 27:24             | confbus_timeout     | RW | 间为2的幂次方              |  |
| 29:28             |                     |    |                      |  |
|                   |                     |    | 每个核的调频模式选择           |  |
| 35:32             | freqscale_mode_core | RW | 0: (n+1)/8           |  |
|                   |                     |    | 1: 1/(n+1)           |  |
|                   |                     |    | 结点的调频模式选择            |  |
| 36                | freqscale_mode_node | RW | 0: (n+1)/8           |  |
|                   |                     |    | 1: 1/(n+1)           |  |



| 37    | freqscale_mode_LA132  | RW | LA132 的调频模式选择<br>0: (n+1)/8<br>1: 1/(n+1)        |
|-------|-----------------------|----|--------------------------------------------------|
| 39:38 |                       |    | 1. 1/ (11-1)                                     |
| 40    | freqscale_mode_stable | RW | Stable clock 的调频模式选择<br>0: (n+1)/8<br>1: 1/(n+1) |
| 43:41 |                       |    | 保留                                               |
| 46:44 | freqscale_stable      | RW | Stable clock 调频寄存器                               |
| 47    | clken_stable          | RW | Stable clock 时钟使能                                |
| 48    | BRIDGE_INT_en         | RW | 南北桥 IO 中断使能                                      |
| 49    | INT_encode            | RW | 使能中断引脚编码模式                                       |
| 53:52 |                       |    |                                                  |
| 54    |                       |    |                                                  |
| 57:56 | thsensor_sel          | RW | 温度传感器选择,只能为0                                     |
| 62:60 | Auto_scale            | R  | 自动调频当前值                                          |
| 63    | Auto_scale_doing      | R  | 自动调频正在生效标志                                       |

## 5.11 FUSE0 观测寄存器

以下寄存器用于观测部分软件可见的 Fuse0 数值。

地址偏移: 0460h

表 5- 11 FUSEO 观测寄存器

| 位域    | 字段名    | 访问 | 描述 |
|-------|--------|----|----|
| 127:0 | Fuse_0 | RW |    |

### 5.12 FUSE1 观测寄存器

以下寄存器用于观测部分软件可见的 Fusel 数值。

地址偏移: 0470h

表 5- 12 FUSE1 观测寄存器

| 位域    | 字段名    | 访问 | 描述 |
|-------|--------|----|----|
| 127:0 | Fuse_1 | RW |    |

## 5.13 通用配置寄存器 0

通用配置寄存器 0,对北桥设备进行配置。

地址偏移: 0420h

默认值: 0400\_0000\_CCCC\_3CE0h

表 5- 13 通用配置寄存器 0



| 位域    | 名称                 | 访问  | 描述                                             |
|-------|--------------------|-----|------------------------------------------------|
| 63:60 | Reserved           | R/W | 保留                                             |
| 59    | vpu_soft_reset     | R/W | vpu 的软件复位,高有效                                  |
| 58    | vpu_clken          | R/W | 使能 vpu 的时钟<br>0: 关闭时钟<br>1: 打开时钟               |
| 57:49 | Reserved           | R/W | 保留                                             |
| 48    | pcie_g0_p0_clk_ok  | RO  | pcie_g0 端口 0 时钟 ready<br>0: 没有时钟<br>1: 时钟正常    |
| 47:46 | Reserved           | R/W | 保留                                             |
| 45    | pcie_fl_pl_clk_ok  | RO  | pcie_fl 端口 1 时钟 ready<br>0:没有时钟<br>1:时钟正常      |
| 44    | pcie_f1_p0_c1k_ok  | RO  | pcie_f1 端口 0 时钟 ready<br>0:没有时钟<br>1:时钟正常      |
| 43    | pcie_f0_p3_c1k_ok  | RO  | pcie_f0 端口 3 时钟 ready<br>0:没有时钟<br>1:时钟正常      |
| 42    | pcie_f0_p2_c1k_ok  | RO  | pcie_f0 端口 2 时钟 ready<br>0:没有时钟<br>1:时钟正常      |
| 41    | pcie_f0_p1_c1k_ok  | RO  | pcie_f0 端口 1 时钟 ready<br>0:没有时钟<br>1:时钟正常      |
| 40    | pcie_f0_p0_c1k_ok  | RO  | pcie_f0 端口 0 时钟 ready<br>0: 没有时钟<br>1: 时钟正常    |
| 39:37 | Reserved           | R/W | 保留                                             |
| 36    | pcie_g0_uca_en     | R/W | pcie_g0 uncache 访问加速使能<br>0:关闭访问加速<br>1:打开访问加速 |
| 35    | Reserved           | R/W | 保留                                             |
| 34    | pcie_f1_uca_en     | R/W | pcie_f1 uncache 访问加速使能 0:关闭访问加速 1:打开访问加速       |
| 33    | pcie_f0_uca_en     | R/W | pcie_f0 uncache 访问加速使能 0:关闭访问加速 1:打开访问加速       |
| 32    | graphic_uca_en     | R/W | GPU/DC uncache 访问加速时能 0: 关闭访问加速 1: 打开访问加速      |
| 31:27 | Reserved           | R/W | 保留                                             |
| 26    | pcie_g0_p0_c1ken   | R/W | 使能 pcie_g0 的 port0 时钟<br>0: 关闭时钟<br>1: 打开时钟    |
| 25    | pcie_g0_enable     | R/W | 使能 pcie_g0 控制器<br>0: 禁止访问<br>1: 允许访问           |
| 24    | pcie_g0_soft_reset | R/W | pcie_g0 的软件复位<br>0: 解除复位<br>1: 保持复位            |
| 23:20 | Reserved           | R/W | 保留                                             |



|                    |                                                                                                                                                                                                                                                                   | HAR COLLEGE COLLEGE                                                                                                                                                                                                                                                                                                                                    |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| pcie_fl_pl_clken   | R/W                                                                                                                                                                                                                                                               | 使能 pcie_f1 的 port1 时钟<br>0:关闭时钟<br>1:打开时钟                                                                                                                                                                                                                                                                                                              |
| pcie f1 p0 clken   | R/W                                                                                                                                                                                                                                                               | ### (1) ### (1) ### (2) ### (2) ### (3) #### (4) #### (4) ####################                                                                                                                                                                                                                                                                         |
|                    | ,                                                                                                                                                                                                                                                                 | 1: 打开时钟                                                                                                                                                                                                                                                                                                                                                |
| pcie_f1_enable     | R/W                                                                                                                                                                                                                                                               | 使能 pcie_f1 控制器<br>0:禁止访问<br>1:允许访问                                                                                                                                                                                                                                                                                                                     |
| pcie_fl_soft_reset | R/W                                                                                                                                                                                                                                                               | pcie_f1 的软件复位<br>0: 解除复位<br>1: 保持复位                                                                                                                                                                                                                                                                                                                    |
| pcie_g0_refclk_sel | R/W                                                                                                                                                                                                                                                               | PCIe GO 参考时钟源选择: 1: 选择从 PAD 输入参考时钟; 0: 选择内部参考时钟; 如果 fix_pcie_clksel 为 1, 那么该信号恒为 1。                                                                                                                                                                                                                                                                    |
| pcie_g0_rio_mode   | R/W                                                                                                                                                                                                                                                               | RapidIO 设备使能模式。<br>0: 不使用 RapidIO 设备,使用 pcie_g0 设备<br>1: 使用 RapidIO 设备<br>如果 fix_pcie_mode 为 1, 那么该信号恒为 0。                                                                                                                                                                                                                                             |
| pcie_f0_p3_clken   | R/W                                                                                                                                                                                                                                                               | 使能 pcie_f0 的 port3 时钟<br>0:关闭时钟<br>1:打开时钟                                                                                                                                                                                                                                                                                                              |
| pcie_f0_p2_clken   | R/W                                                                                                                                                                                                                                                               | 使能 pcie_f0 的 port2 时钟<br>0: 关闭时钟<br>1: 打开时钟                                                                                                                                                                                                                                                                                                            |
| pcie_f0_p1_clken   | R/W                                                                                                                                                                                                                                                               | 使能 pcie_f0 的 port1 时钟<br>0: 关闭时钟<br>1: 打开时钟                                                                                                                                                                                                                                                                                                            |
| pcie_f0_p0_clken   | R/W                                                                                                                                                                                                                                                               | 使能 pcie_f0 的 port0 时钟<br>0: 关闭时钟<br>1: 打开时钟                                                                                                                                                                                                                                                                                                            |
| pcie_f0_enable     | R/W                                                                                                                                                                                                                                                               | 使能 pcie_f0 控制器<br>0:禁止访问<br>1:允许访问                                                                                                                                                                                                                                                                                                                     |
| pcie_f0_soft_reset | R/W                                                                                                                                                                                                                                                               | pcie_f0 的软件复位<br>0: 解除复位<br>1: 保持复位                                                                                                                                                                                                                                                                                                                    |
| dc_clken           | R/W                                                                                                                                                                                                                                                               | 使能 dc 的时钟<br>0: 关闭时钟<br>1: 打开时钟                                                                                                                                                                                                                                                                                                                        |
| gpu_clken          | R/W                                                                                                                                                                                                                                                               | 使能 gpu 的时钟<br>0: 关闭时钟<br>1: 打开时钟                                                                                                                                                                                                                                                                                                                       |
| Reserved           | R/W                                                                                                                                                                                                                                                               | 保留                                                                                                                                                                                                                                                                                                                                                     |
| gpu_soft_reset     | R/W                                                                                                                                                                                                                                                               | gpu 的软件复位,高有效                                                                                                                                                                                                                                                                                                                                          |
| Reserved           | R/W                                                                                                                                                                                                                                                               | 保留                                                                                                                                                                                                                                                                                                                                                     |
| pcie_fl_refclk_sel | R/W                                                                                                                                                                                                                                                               | pcie f1 的时钟选择。 1: 选择 PAD 输入时钟 0: 选择内部参考时钟 如果 fix_pcie_clksel 为 1,那么该信号恒为 1。                                                                                                                                                                                                                                                                            |
| pcie_fl_rio_mode   | R/W                                                                                                                                                                                                                                                               | RapidIO 设备使能模式。 0: 不使用 RapidIO 设备,使用 pcie_f1 设备 1: 使用 RapidIO 设备 如果 fix_pcie_mode 为 1, 那么该信号恒为 0。                                                                                                                                                                                                                                                      |
|                    | pcie_f1_p0_clken  pcie_f1_enable  pcie_f1_soft_reset  pcie_g0_refclk_sel  pcie_g0_rio_mode  pcie_f0_p3_clken  pcie_f0_p1_clken  pcie_f0_p0_clken  pcie_f0_enable  pcie_f0_soft_reset  dc_clken  gpu_clken  Reserved  gpu_soft_reset  Reserved  pcie_f1_refclk_sel | pcie_f1_p0_clken R/W  pcie_f1_enable R/W  pcie_f1_soft_reset R/W  pcie_g0_refclk_sel R/W  pcie_g0_rio_mode R/W  pcie_f0_p3_clken R/W  pcie_f0_p2_clken R/W  pcie_f0_p1_clken R/W  pcie_f0_p0_clken R/W  pcie_f0_enable R/W  pcie_f0_enable R/W  pcie_f0_soft_reset R/W  dc_clken R/W  Reserved R/W  Reserved R/W  Reserved R/W  pcie_f1_refclk_sel R/W |



| 0 | default_route_cfg0 | R/W | 使用固定地址访问 PCIe、图形设备。 0:使用 PCI 配置头对设备地址进行配置 1:使用固定地址访问设备 如果 fix_default_route 为 1,那么该信号恒为 1。 该位必须设置为 0。 |
|---|--------------------|-----|-------------------------------------------------------------------------------------------------------|
|---|--------------------|-----|-------------------------------------------------------------------------------------------------------|

# 5.14 通用配置寄存器 1

本寄存器包含 USB、SATA、GMAC、HDA/I2S、LPC、SPI 相关的配置信息。 地址偏移: 0430h

默认值: 1000\_0900\_0009\_99F2h

表 5- 14 通用配置寄存器 1

| 次 5 14 旭用癿且可行奋 I |                  |     |                        |
|------------------|------------------|-----|------------------------|
| 位域               | 名称               | 访问  | 描述                     |
|                  |                  |     | HDA1 中断引脚控制            |
| 63               | hdal_int_route   | R/W | 0: 使用 hdal_int         |
|                  |                  |     | 1: 使用 hda0_int         |
| 62               | lpc_ioaddr_new   | R/W | 需要设置成 1                |
|                  |                  |     | RTC 访问通路控制             |
| 61               | rtc_access_speed | R/W | 0: 低速访问通路,读取 RTC 时间延迟长 |
|                  |                  |     | 1: 高速访问通路,读取 RTC 时间延迟短 |
|                  |                  |     | 使能 HDA64 位 DMA 地址模式    |
| 60               | hda_dma_64       | R/W | 0: 使用 32 位 DMA 地址模式    |
|                  |                  |     | 1: 使用 64 位 DMA 地址模式    |
|                  |                  |     | PWM 控制器软件复位            |
| 59               | pwm_soft_reset   | R/W | 0: 解除复位                |
|                  |                  |     | 1: 保持复位                |
|                  |                  |     | I2C 控制器软件复位            |
| 58               | i2c_soft_reset   | R/W | 0: 解除复位                |
|                  |                  |     | 1: 保持复位                |
|                  |                  |     | UART 控制器软件复位           |
| 57               | uart_soft_reset  | R/W | 0: 解除复位                |
|                  |                  |     | 1: 保持复位                |
|                  |                  |     | CAN 控制器软件复位            |
| 56               | can_soft_reset   | R/W | 0: 解除复位                |
|                  |                  |     | 1: 保持复位                |
|                  |                  |     | LPC 控制器软件复位            |
| 55               | lpc_soft_reset   | R/W | 0: 解除复位                |
|                  |                  |     | 1: 保持复位                |
|                  |                  |     | SPI 控制器软件复位            |
| 54               | spi_soft_reset   | R/W | 0: 解除复位                |
|                  |                  |     | 1: 保持复位                |
| 53               | Reserved         | R/W | 保留                     |



|       | T                         |        |                                 |
|-------|---------------------------|--------|---------------------------------|
|       | otp_access                |        | 芯片内 antifuse 读写控制               |
| 52    |                           | R/W    | 0: 禁止访问 antifuse                |
|       |                           |        | 1: 允许访问 antifuse                |
|       | anament aaft maa          |        | ENCRYPT 控制器软件复位                 |
| 51:48 | encrypt_soft_res          | R/W    | 0: 解除复位                         |
|       | et                        |        | 1: 保持复位                         |
|       |                           |        | SDIO 控制器软件复位                    |
| 47    | sdio_soft_reset           | R/W    | 0: 解除复位                         |
|       |                           |        | 1: 保持复位                         |
|       |                           |        | EMMC 控制器软件复位                    |
| 46    | emmc_soft_reset           | R/W    | 0: 解除复位                         |
|       |                           |        | 1: 保持复位                         |
|       |                           |        | HDA1 控制器软件复位                    |
| 45    | hdal_soft_reset           | R/W    | 0: 解除复位                         |
|       |                           |        | 1: 保持复位                         |
| 44    |                           |        | HDAO 控制器软件复位                    |
|       | hda0_soft_reset           | R/W    | 0: 解除复位                         |
|       | 11440_5011_10501          |        | 1: 保持复位                         |
|       | sata0_clken               |        | SATAO 时钟使能                      |
| 43    |                           | R/W    | 0: 没有时钟                         |
| 10    |                           |        | 1: 时钟正常                         |
|       |                           |        | SATAO 访问使能                      |
| 42    | sata0_en                  | R/W    | 0: 禁止访问                         |
|       | _                         |        | 1: 允许访问                         |
| 41    | Reserved                  | R/W    | 保留                              |
|       |                           | IV/ W  | SATAO 控制器软件复位                   |
| 40    | sata0_cnt1_soft_<br>reset | R/W    | 0: 解除复位                         |
|       |                           |        | 1: 保持复位                         |
|       |                           |        | GPI050 引脚中断重映射                  |
| 39    | gpio50_int_remap          | R/W    | 0: 默认映射方式                       |
|       | GP                        |        | 1:将 GPI050 中断映射到 GPI03 对应的中断引脚  |
|       |                           |        | GPI015 引脚中断重映射                  |
| 38    | gpio15_int_remap          | R/W    | 0: 默认映射方式                       |
|       | Spiolo_inv_remap          | N/W    | 1: 将 GPI015 中断映射到 GPI02 对应的中断引脚 |
|       |                           |        | GPI014 引脚中断重映射                  |
| 37    | gpio14_int_remap          | R/W    | 0: 默认映射方式                       |
|       | Sprorr_int_remap          | 11/ "  | 1: 将 GPI014 中断映射到 GPI01 对应的中断引脚 |
|       |                           |        | GPI013 引脚中断重映射                  |
| 36    | gpio13_int_remap          | R/W    | 0: 默认映射方式                       |
|       | gp1013_int_remap          | 11/ 11 | 1: 将 GPI013 中断映射到 GPI00 对应的中断引脚 |
| 35    | Reserved                  | R/W    | 保留                              |
| 30    | Veset And                 | IV/ W  |                                 |
| 34    | se_int_en                 | R/W    | SE 中断使能                         |
|       |                           |        | 0: 禁止 SE 中断                     |



|     |                  |        | 1. 债於 55 由縣                    |
|-----|------------------|--------|--------------------------------|
|     |                  |        | 1: 使能 SE 中断                    |
| 22  | hand interest    | D/W    | hpet 中断分离控制                    |
| 33  | hpet_int_ctrl    | R/W    | 0: HPET 的中断全部分配到 hpet0_int     |
|     |                  |        | 1: HPET 的中断分别分配到 hpet0/1/2_int |
| 0.0 |                  | D /W   | LPC 控制器使能                      |
| 32  | lpc_en           | R/W    | 0: 禁止访问                        |
|     |                  |        | 1: 允许访问                        |
| 0.1 |                  | D /W   | LPC uncache 加速使能               |
| 31  | lpc_uca_en       | R/W    | 0: 关闭访问加速                      |
|     |                  |        | 1: 打开访问加速                      |
| 20  |                  | D /W   | SPI uncache 加速使能               |
| 30  | spi_uca_en       | R/W    | 0: 关闭访问加速                      |
|     |                  |        | 1: 打开访问加速                      |
|     |                  | D /*** | 配置寄存器 uncache 加速使能             |
| 29  | conf_uca_en      | R/W    | 0: 关闭访问加速                      |
|     |                  |        | 1: 打开访问加速                      |
|     |                  | D /    | 低速 misc 设备 uncache 加速使能        |
| 28  | misc_uca_en      | R/W    | 0: 关闭访问加速                      |
|     |                  |        | 1: 打开访问加速                      |
|     |                  |        | HDAO/HDA1/I2S uncache 加速使能     |
| 27  | aud_uca_en       | R/W    | 0: 关闭访问加速                      |
|     |                  |        | 1: 打开访问加速                      |
|     |                  |        | gmac uncache 加速使能              |
| 26  | gmac_uca_en      | R/W    | 0: 关闭访问加速                      |
|     |                  |        | 1: 打开访问加速                      |
|     |                  |        | sata uncache 加速使能              |
| 25  | sata_uca_en      | R/W    | 0: 关闭访问加速                      |
|     |                  |        | 1: 打开访问加速                      |
|     |                  |        | usb uncache 加速使能               |
| 24  | usb_uca_en       | R/W    | 0: 关闭访问加速                      |
|     |                  |        | 1: 打开访问加速                      |
|     |                  |        | gmac2 时钟使能                     |
| 23  | gmac2_clken      | R/W    | 0: 没有时钟                        |
|     |                  |        | 1: 时钟正常                        |
|     | gmac2_sdb_flowct |        | gmac2 流控使能                     |
| 22  | rl               | R/W    | 0: 流控关闭                        |
|     | 1.1              |        | 1: 流控打开                        |
|     |                  |        | HDA1 控制器访问使能                   |
| 21  | hda1_en          | R/W    | 0: 禁止访问                        |
|     |                  |        | 1: 允许访问                        |
|     |                  |        | HDAO/I2S 控制器使能                 |
| 20  | hda0_i2s_en      | R/W    | 0: 使能 I2S 控制器                  |
|     |                  |        | 1: 使能 HDA0 控制器                 |



|          |                  |       | usb3 时钟使能     |
|----------|------------------|-------|---------------|
| 19       | usb3_c1ken       | R/W   | 0:没有时钟        |
|          |                  |       | 1: 时钟正常       |
|          |                  |       | usb3 访问使能     |
| 18       | usb3_en          | R/W   | 0: 禁止访问       |
|          |                  |       | 1: 允许访问       |
|          |                  |       | usb3 PHY 软件复位 |
| 17       | usb3_phy_soft_re | R/W   | 0: 解除复位       |
|          | set              |       | 1: 保持复位       |
|          | 10 11 0          |       | usb3 控制器软件复位  |
| 16       | usb3_cntl_soft_r | R/W   | 0: 解除复位       |
|          | eset             |       | 1: 保持复位       |
|          |                  |       | otg 时钟使能      |
| 15       | otg_clken        | R/W   | 0: 没有时钟       |
|          |                  |       | 1: 时钟正常       |
|          |                  |       | otg 访问使能      |
| 14       | otg_en           | R/W   | 0: 禁止访问       |
|          |                  |       | 1: 允许访问       |
| 13       | Reserved         | R/W   | 保留            |
| 10       |                  |       | otg 控制器软件复位   |
| 12       | otg_cntl_soft_re | R/W   | 0: 解除复位       |
|          | set              | 11,   | 1: 保持复位       |
|          |                  | R/W   | usb2 时钟使能     |
| 11       | usb2_clken       |       | 0: 没有时钟       |
|          | dob2_cikon       |       | 1: 时钟正常       |
|          |                  |       | usb2 访问使能     |
| 10       | usb2_en          | R/W   | 0: 禁止访问       |
|          |                  |       | 1: 允许访问       |
|          |                  |       | usb2 PHY 软件复位 |
| 9        | usb2_phy_soft_re | R/W   | 0: 解除复位       |
|          | set              |       | 1: 保持复位       |
|          |                  | R/W   | usb2 控制器软件复位  |
| 8        | usb2_cntl_soft_r |       | 0: 解除复位       |
|          | eset             |       | 1: 保持复位       |
|          |                  |       | gmac1 时钟使能    |
| 7        | gmac1_clken      | R/W   | 0: 没有时钟       |
| <b>'</b> | Succer_CINCH     | 11/ " | 1: 时钟正常       |
|          |                  |       | gmac1 流控使能    |
| 6        | gmac1_sdb_flowct | R/W   | 0: 流控关闭       |
| σ        | rl               | K/W   |               |
|          |                  |       | 1: 流控打开       |
| _        | ama o0 - 11      | D/W   | gmac0 时钟使能    |
| 5        | gmac0_clken      | R/W   | 0: 没有时钟       |
|          |                  |       | 1: 时钟正常       |



| 4   | gmac0_sdb_flowct | R/W | gmac0 流控使能<br>0: 流控关闭<br>1: 流控打开                                                                                 |
|-----|------------------|-----|------------------------------------------------------------------------------------------------------------------|
| 3:1 | Reserved         | R/W | 保留                                                                                                               |
| 0   | default_route_cf | R/W | 使用固定地址访问 USB、SATA、GMAC 等设备。 0: 使用 PCI 配置头对设备地址进行配置 1: 使用固定地址访问设备 如果 fix_default_route 为 1, 那么该信号恒为 1。 该位必须设置为 0。 |

## 5.15 引脚复用配置寄存器

地址偏移: 0440h

默认值: 0000\_0000\_FFFF\_FFFFh

本寄存器包含引脚复用的相关配置信息,注意当开启某个功能时,需要关闭与之复用的其他所有功能。

表 5- 15 引脚复用配置寄存器

| 位域     | 名称             | 访问   | 描述                                                |  |
|--------|----------------|------|---------------------------------------------------|--|
|        |                |      | GPU 串口选择                                          |  |
| 59     | gpu_uart_sel   | R/W  | 1b: 工作在 GPU 串口模式                                  |  |
|        |                |      | Ob: 工作在非 GPU 串口模式<br>UART8 控制器使能,引脚 UART1 RTS/CTS |  |
| 58     | uart8_enable   | R/W  | 对应的两线串口                                           |  |
| 57     | uant7 analala  | R/W  | UART7 控制器使能,引脚引脚                                  |  |
| 97     | uart7_enable   | R/W  | UART1_RI/DCD 对应的两线串口                              |  |
| 56     | uart6 enable   | R/W  | UART6 控制器使能,引脚 UART1_DTR/DSR                      |  |
|        | _              |      | (RI/DCD) 对应的两线(四线)串口                              |  |
| 55     | Reserved       | R/W  | 保留                                                |  |
| 54     | uart5_enable   | R/W  | UART5 控制器使能,引脚 UARTO_RTS/CTS                      |  |
|        |                | ,    | 对应的两线串口<br>UART4 控制器使能,引脚引脚                       |  |
| 53     | uart4_enable   | R/W  | UARTO_RI/DCD 对应的两线串口                              |  |
|        |                |      | UART3 控制器使能,引脚 UARTO_DTR/DSR                      |  |
| 52     | uart3_enable   | R/W  | (RI/DCD) 对应的两线(四线) 串口                             |  |
| 51     | Reserved       | R/W  | 保留                                                |  |
|        |                |      | 分别对应 LIO CS3/2/1 引脚工作模式选择                         |  |
| 50:48  | lio_cs_sel     | R/W  | 1b: 工作在 LIO CS 模式                                 |  |
|        |                |      | 0b: 工作在 GPIO 模式                                   |  |
|        |                |      | DVO 引脚的工作模式选择                                     |  |
| 47. 40 |                | D /W | 01b: 工作在 LIO 模式                                   |  |
| 47:46  | dvo_sel        | R/W  | 10b: 工作在 DVO 模式                                   |  |
|        |                |      | 其他: 工作在 GPIO 模式                                   |  |
| 45.40  |                | D /W | GMAC2 引脚的工作模式选择(与 bit10 共                         |  |
| 45:42  | uart_sel_uart1 | R/W  | 同决定)                                              |  |



|       | <u> </u>         |       | (1. 10. 1. 5.7. 107)                             |
|-------|------------------|-------|--------------------------------------------------|
|       |                  |       | {bit10, bit[45:42]}:                             |
|       |                  |       | 1xxxxb: 工作在 GMAC 模式                              |
|       |                  |       | 00000b: 工作在 GPIO 模式                              |
|       |                  |       | 其他: 工作在 UART 模式 (与 bit [58:55]                   |
|       |                  |       | 配合决定是否工作在全功能模式)                                  |
| 41:40 | Reserved         | R/W   | 保留                                               |
|       |                  |       | 引脚 UARTO_DSR/RI/DCD 的工作模式选择                      |
|       |                  |       | (与 bit23 共同决定)                                   |
| 39:38 | uart_sel_uart0   | R/W   | [bit39, bit38, bit23]:                           |
| 00.00 | dar v_ser_dar ve | 11, " | 001b: 工作在 AVS 模式                                 |
|       |                  |       | xx0b: 工作在 UART 模式 (由 bit[54:52]                  |
|       |                  |       | 决定是否工作在全功能模式)                                    |
|       |                  |       | PWM4/5 引脚的工作模式选择, 当未使能                           |
| 37    | can5_sel         | R/W   | PWM4/5 时                                         |
| 31    | cans_ser         | IV/W  | 1b: 工作在 CAN 模式                                   |
|       |                  |       | 0b: 工作在非 CAN 模式                                  |
|       |                  |       | PWM2/3 引脚的工作模式选择, 当未使能                           |
| 26    | 41               | R/W   | PWM2/3 时                                         |
| 36    | can4_sel         | K/W   | 1b: 工作在 CAN 模式                                   |
|       |                  |       | 0b: 工作在非 CAN 模式                                  |
|       |                  |       | 引脚 UART2_RI/DCD 的工作模式选择                          |
| 35    | can3_sel         | R/W   | 1b: 工作在 CAN 模式                                   |
|       |                  |       | 0b: 工作在非 CAN 模式                                  |
|       |                  |       | 引脚 UART2_DTR/DSR 的工作模式选择                         |
| 34    | can2_sel         | R/W   | 1b: 工作在 CAN 模式                                   |
|       |                  |       | 0b: 工作在非 CAN 模式                                  |
|       |                  |       | 引脚 UART2_RTS/CTS 的工作模式选择                         |
| 33    | can1_sel         | R/W   | 1b: 工作在 CAN 模式                                   |
|       |                  |       | 0b: 工作在非 CAN 模式                                  |
|       |                  |       | 引脚 UART2_TXD/RXD 的工作模式选择                         |
| 32    | can0_sel         | R/W   | 1b: 工作在 CAN 模式                                   |
|       |                  |       | 0b: 工作在非 CAN 模式                                  |
| 31    | uartll_enable    | R/W   | UART11 控制器使能,引脚 UART2_RTS/CTS                    |
|       |                  |       | 対应的两线串口<br>UART10 控制器使能,引脚引脚                     |
| 30    | uart10_enable    | R/W   | UART2_RI/DCD 对应的两线串口                             |
| 29    | uart9_enable     | R/W   | UART9 控制器使能,引脚 UART2_DTR/DSR (RI/DCD)对应的两线(四线)串口 |
| 28    | Reserved         | R/W   | 保留                                               |
|       |                  |       | SPI 引脚(复用 SDIO)的工作模式选择(与                         |
|       |                  | R/W   | bit[25]共同决定)                                     |
| 27    | spi sel          |       | [bit25, bit27]:                                  |
|       | 2h1_261          |       | 00b: 工作在 GPIO 模式                                 |
|       |                  |       | 1xb: 工作在 SDIO 模式                                 |
|       |                  |       | TVn: 丁LLT 20110                                  |



|    |                     |        | 01b: 工作在 SPI 模式                  |
|----|---------------------|--------|----------------------------------|
| 26 | Reserved            | R/W    | 保留                               |
|    |                     |        | SDIO 引脚的工作模式选择                   |
| 25 | sdio_sel            | R/W    | 0: 工作在非 SDIO 模式                  |
| 20 | 5410_561            | 10, "  | 1: 工作在 SDIO 模式                   |
|    |                     |        | eMMC 引脚的工作模式选择                   |
| 24 | emmc_sel            | R/W    | 0: 工作在 GPIO 模式                   |
| 21 | emmc_ser            | 11/ 11 | 1: 工作在 eMMC 模式                   |
|    |                     |        | AVS 引脚(复用 UART_DSR/RI/DCD)的工     |
|    |                     |        | 作模式选择(与bit[39:38]共同决定)           |
|    |                     |        | [bit39, bit38, bit23]:           |
| 23 | avs_sel             | R/W    |                                  |
|    |                     |        | 001b: 工作在 AVS 模式                 |
|    |                     |        | xx0b: 工作在 UART 模式 (由 bit [41:38] |
|    |                     |        | 决定是否工作在全功能模式)                    |
|    |                     |        | 引脚 UART2_TXD/RXD(复用              |
| 00 | uart_txd_rxd_sel_ua | D /W   | LPC_CLK/RESET)的工作模式选择            |
| 22 | rt2                 | R/W    | 0: 工作在非 UART 模式                  |
|    |                     |        | 1: 工作在 UART 模式 (由 bit [31:28] 决定 |
|    |                     |        | 是否工作在全功能模式)                      |
|    |                     |        | 引脚 UART2_RTS/CTS(复用              |
|    | uart_rts_cts_sel_ua |        | LPC_LFRAME/SERIRQ)的工作模式选择        |
| 21 | rt2                 | R/W    | 0: 工作在非 UART 模式                  |
|    |                     |        | 1: 工作在 UART 模式 (由 bit[31:28] 决定  |
|    |                     |        | 是否工作在全功能模式)                      |
|    |                     |        | 引脚 UART2_DTR/DSR(复用 LPC_LAD3/2)  |
|    |                     |        | 的工作模式选择(与 bit7 共同决定)             |
|    | uart_dtr_dsr_sel_ua |        | [bit7, bit20]:                   |
| 20 | rt2                 | R/W    | 00b: 工作在 GPIO 模式                 |
|    |                     |        | x1b: 工作在 UART 模式 (由 bit[31:28]   |
|    |                     |        | 决定是否工作在全功能模式)                    |
|    |                     |        | 10b: 工作在 I2C 模式                  |
|    |                     |        | 引脚 UART2_RI/DCD(复用 LPC_LADO/1)   |
|    |                     |        | 的工作模式选择(与 bit6 共同决定)             |
|    | uart_ri_dcd_sel_uar |        | [bit6, bit19]:                   |
| 19 | t2                  | R/W    | 00b: 工作在 GPI0 模式                 |
|    | \                   |        | x1b: 工作在 UART 模式 (由 bit [31:28]  |
|    |                     |        | 决定是否工作在全功能模式)                    |
|    |                     |        | 10b: 工作在 I2C 模式                  |
|    |                     |        | 引脚 USB_0C3 的工作模式选择               |
| 18 | usb_oc3_sel         | R/W    | 0: 工作在 GPIO 模式                   |
|    |                     |        | 1: 工作在 USB_OC 模式                 |
| 17 | usb_oc2_se1         | R/W    | 引脚 USB_0C2 的工作模式选择               |
| 17 | usu_002_861         | K/W    | 0: 工作在 GPIO 模式                   |



|       |               | I      |                                   |
|-------|---------------|--------|-----------------------------------|
|       |               |        | 1: 工作在 USB_0C 模式                  |
|       |               |        | 引脚 USB_0C1 的工作模式选择                |
| 16    | usb_oc1_sel   | R/W    | 0: 工作在 GPIO 模式                    |
|       |               |        | 1: 工作在 USB_OC 模式                  |
|       |               |        | 引脚 USB_0C0 的工作模式选择                |
| 15    | usb_oc0_sel   | R/W    | 0: 工作在 GPIO 模式                    |
|       |               |        | 1: 工作在 USB_OC 模式                  |
|       |               |        | 引脚 LPC                            |
|       |               |        | (LPC_ADO~3/LPC_SERIRQ/LPC_FRAMEn) |
| 14    | lpc_sel       | R/W    | 的工作模式选择                           |
|       |               |        | 0: 工作在非 LPC 模式                    |
|       |               |        | 1: 工作在 LPC 模式                     |
|       |               |        | 引脚 SATA_LEDn 的工作模式选择              |
| 13    | sata_ledn_sel | R/W    | 0: 工作在 GPIO 模式                    |
|       |               |        | 1: 工作在 SATA 模式                    |
|       |               |        | HDA 引脚的工作模式选择。                    |
|       |               |        | 00b: GPIO 模式                      |
| 12:11 | hda_i2s_sel   | R/W    | 01b: HDAO 模式                      |
|       |               |        | 10b: I2S 模式                       |
|       |               |        | 11b: HDA1 模式                      |
|       |               |        | GMAC2 引脚的工作模式选择                   |
| 10    | gmac2_sel     | R/W    | 0: 工作在非 GMAC 模式                   |
|       | @maceser      | 14,    | 1: 工作在 GMAC 模式                    |
|       |               |        | 引脚 GMAC1_LED 的工作模式选择              |
| 9     | gmac1_led_sel | R/W    | 0: 工作在 GPIO 模式                    |
|       | 0             | ,      | 1: 工作在 GMAC 模式                    |
| 8     | Reserved      | R/W    | 保留                                |
|       | Treserves .   | 14,    | 引脚 I2C3 的工作模式选择                   |
| 7     | i2c3_sel      | R/W    | 0: 工作在非 I2C 模式                    |
| '     | 1200_501      | 11/ "  | 1: 工作在 I2C 模式                     |
|       |               |        | 引脚 I2C2 的工作模式选择                   |
| 6     | i2c2_sel      | R/W    | 0: 工作在非 I2C 模式                    |
|       | 1202_301      | 11/ 11 | 1: 工作在 I2C 模式                     |
|       |               |        | 1: 工作在 120 侯式                     |
| 5     | pumb col      | D/W    | 5                                 |
| 5     | pwm5_sel      | R/W    | U: 工作在 PWM 模式<br>  1: 工作在 PWM 模式  |
|       |               |        |                                   |
| 4     |               | D /W   | 引脚 PWM4 的工作模式选择                   |
| 4     | pwm4_sel      | R/W    | 0: 工作在非 PWM 模式                    |
|       |               |        | 1: 工作在 PWM 模式                     |
|       |               | D /*** | 引脚 PWM3 的工作模式选择                   |
| 3     | pwm3_sel      | R/W    | 0: 工作在非 PWM 模式                    |
|       |               |        | 1: 工作在 PWM 模式                     |
| 2     | pwm2_sel      | R/W    | 引脚 PWM2 的工作模式选择                   |



|   |          |     | 0: 工作在非 PWM 模式<br>1: 工作在 PWM 模式 |
|---|----------|-----|---------------------------------|
|   |          |     |                                 |
|   |          | - ( | 引脚 PWM1 的工作模式选择                 |
| 1 | pwm1_sel | R/W | 0: 工作在非 PWM 模式                  |
|   |          |     | 1: 工作在 PWM 模式                   |
|   |          |     | 引脚 PWMO 的工作模式选择                 |
| 0 | pwm0_sel | R/W | 0: 工作在非 PWM 模式                  |
|   |          |     | 1: 工作在 PWM 模式                   |

## 5.16 USB OC 选择配置

本寄存器用来选择 USB 控制器所对应的 overcurrent 检测引脚。每两位作为一组,共有 4 种配置,00 代表选择 USB\_0C0 信号,01 代表选择 USB\_0C1 信号,10 代表选择 USB\_0C2 信号,11 代表选择 USB\_0C3 信号。每组对应一个 USB 端口。

地址偏移: 0448h

表 5- 16 USB OC 选择配置

| 位域    | 名称              | 访问    | 描述                                  |
|-------|-----------------|-------|-------------------------------------|
|       |                 |       | USB_0C0 引脚复用配置                      |
| 31    | 31 usb_oc0_mode | R/W   | 0: OTG DRVVBUS 输出                   |
|       |                 |       | 1: USB OC 输入                        |
| 23:22 | usb2p3_ocse1    | R/W   | USB2 控制器 PORT3 端口对应 OC 信号选择         |
| 21:20 | usb2p2_ocse1    | R/W   | USB2 控制器 PORT2 端口对应 OC 信号选择         |
| 19:18 | usb2p1_ocse1    | R/W   | USB2 控制器 PORT1 端口对应 OC 信号选择         |
| 17:16 | usb2p0_ocsel    | R/W   | USB2 控制器 PORTO 端口对应 OC 信号选择         |
| 15:14 | uch2n2 occol    | R/W   | XHCI-USB3.0 控制器中 PORT3 端口对应 OC 信号   |
| 15:14 | usb3p3_ocse1    | K/W   | 选择                                  |
| 12.19 |                 | D/W   | XHCI-USB3.0 控制器中 PORT2 端口对应 OC 信号   |
| 13:12 | usb3p2_ocse1    | R/W   | 选择                                  |
| 11:10 | uch2n1 occol    | R/W   | XHCI-USB3.0 控制器中 PORT1 端口对应 OC 信号   |
| 11.10 | usb3p1_ocse1    | N/W   | 选择                                  |
| 9:8   | usb3p0_ocse1    | R/W   | XHCI-USB3.0 控制器中 PORTO 端口对应 OC 信号   |
| 9.0   | usbapo_ocse1    | N/W   | 选择                                  |
| 7:6   | usb3u2p3_ocse1  | R/W   | XHCI-USB3.0 控制器中 USB2 PORT3 端口对应 OC |
| 7.0   | usbauzpa_ocsei  | N/W   | 信号选择                                |
| 5:4   | uch3u2n2 oogo1  | R/W   | XHCI-USB3.0 控制器中 USB2 PORT2 端口对应 OC |
| 0.4   | usb3u2p2_ocse1  | I\/ W | 信号选择                                |
| 3:2   | usb3u2p1_ocse1  | R/W   | XHCI-USB3.0 控制器中 USB2 PORT1 端口对应 OC |
| J.4   | usbouzpi_ocsei  | 1\/ W | 信号选择                                |
| 1:0   | usb3u2p0_ocse1  | R/W   | XHCI-USB3.0 控制器中 USB2 PORTO 端口对应 OC |
| 1:0   | uspouzpo_ocse1  | K/W   | 信号选择                                |



#### 5.17 OTG 预取配置

本寄存器包含 OTG 内部预取模块的相关配置信息。

地址偏移: 0450h

默认值: C708\_8834h

表 5- 17 OTG 预取配置

| 位域    | 名称               | 访问    | 描述                         |  |  |
|-------|------------------|-------|----------------------------|--|--|
| 0.1   | stop_cpu_rd_for_ | D /W  | 当存在未响应的 DMA 写请求时,使能对处理器读   |  |  |
| 31    | dma_wr           | R/W   | 访问的阻塞                      |  |  |
| 0.0   | invld_pref_on_cp | D /W  | 当处理器写控制器内部寄存器时,无效掉预取的      |  |  |
| 30    | u_wr             | R/W   | 读数据                        |  |  |
| 29    | stop_cpu_wr_for_ | R/W   | 当存在未响应的 DMA 写请求时,使能对处理器写   |  |  |
| 29    | dma_wr           | K/W   | 访问的阻塞(当 bit31 有效时才生效)      |  |  |
|       |                  |       | 使能对 4/16/32 字节访问的预取        |  |  |
| 26:24 | £                | R/W   | bit26: 4字节访问               |  |  |
| 20:24 | pref_cond        | K/W   | bit25: 16 字节访问             |  |  |
|       |                  |       | bit24: 32 字节访问             |  |  |
|       |                  |       | 当处理器需要读取控制器内部寄存器时,会阻止      |  |  |
| 21:16 |                  | R/W   | 控制器进行 DMA 写操作。此参数配置的是允许处   |  |  |
| 21.10 |                  | K/W   | 理器访问被阻塞的周期数(该值乘以4),当阻      |  |  |
|       |                  |       | 塞时间到达后,停止后续的 DMA 写操作。      |  |  |
| 15:12 | pref_limit       | R/W   | 预取请求地址边界配置。地址边界等于 4K*2 N。  |  |  |
| 11:8  | pref_max_num     | R/W   | 预取的最大个数                    |  |  |
| 7:4   | pref_num_on_stat | R/W   | 静态预取策略下,一次预取的个数            |  |  |
|       | ic               |       | III JANUARIA I A MARKATI A |  |  |
| 3     | pref_static_en   | R/W   | 使能静态预取策略                   |  |  |
| 2     | invld_pref_on_dm | R/W   | <br>  写请求无效所有的读预取数据        |  |  |
|       | a_wr             | 10, " |                            |  |  |
| 1     | pref_disable     | R/W   | 关闭预取                       |  |  |
|       |                  |       | 读请求必须等待所有的写请求完成(写响应到       |  |  |
| 0     | rd_wait_wr       | R/W   | 达),即使读写地址不冲突。当读写地址冲突时,     |  |  |
|       |                  |       | 读请求会被强制等待写请求完成。            |  |  |

## 5.18 固定地址配置

本寄存器用来配置中断控制器和 HPET 模块的固定访问地址(可由 BIOS 更改)。如果不使用该固定地址,操作系统可以通过配置访问获取配置寄存器或者低速 MISC 设备块的基地址,然后加上固定偏移来获得中断控制器和 HPET 模块的访问地址。使用固定地址来访问中断控制器和 HPET 模块可以加快操作系统的中断处理过程。该固定地址由操作系统决定。如果操作系统使用了与本芯片默认设置的固定地址不同的地址,BIOS 需修改本寄存器来与操作系统保持一致。



地址偏移: 0460h

默认值: 5FFF\_E004\_5FFF\_F004h

表 5- 18 固定地址配置

| 位域    | 名称               | 访问  | 描述              |
|-------|------------------|-----|-----------------|
| 63:44 | hpet_fix_addr    | R/W | 固定地址的 31 到 12 位 |
| 43:35 | Reserved         | R/W | 保留              |
| 34    | hpet_fix_addr_en | R/W | 使能该固定地址配置       |
| 33:32 | Reserved         | R/W | 保留              |
| 31:12 | apic_fix_addr    | R/W | 固定地址的 31 到 12 位 |
| 11:3  | Reserved         | R/W | 保留              |
| 2     | apic_fix_addr_en | R/W | 使能该固定地址配置       |
| 1:0   | Reserved         | R/W | 保留              |

#### 5.19 DMA 一致性配置寄存器

本寄存器用来配置 DMA 设备访存是否维护 cache 一致性

地址偏移: 0470h

默认值: 0000\_0000\_FFFF\_FFFFh

表 5- 19 DMA 一致性配置寄存器

| 位域           | 名称         | 访问  | 描述                |  |
|--------------|------------|-----|-------------------|--|
| 31:30        | encrypt_cc | R/W | 加解密模块一致性控制        |  |
| 29:28        | emmc_cc    | R/W | EMMC 一致性控制        |  |
| 26: 25       | hda_cc     | R/W | HDA 一致性控制         |  |
| 24           | sata_cc    | R/W | SATA 一致性控制        |  |
| 22: 20       | gmac_cc    | R/W | GMAC 一致性控制        |  |
| 18:16        | usb_cc     | R/W | USB 一致性控制         |  |
| 14           | vpu_cc     | R/W | VPU 一致性控制         |  |
| 13           | dc_cc      | R/W | DC 一致性控制          |  |
| 12           | gpu_cc     | R/W | GPU 一致性控制         |  |
| 9: 8         | rio_cc     | R/W | RIO 两个端口一致性控制     |  |
| 6            | pcie_g0_cc | R/W | PCIe GO 端口一致性控制   |  |
| 5 <b>:</b> 4 | pcie_fl_cc | R/W | PCIe F1 两个端口一致性控制 |  |
| 3: 0         | pcie_f0_cc | R/W | PCIe F0 四个端口一致性控制 |  |

### 5.20 PLL0 配置寄存器

该寄存器用来设置 PLL0, 其中输出时钟 0 用来控制 SATA/USB2/SATA3 的控制器时钟,输出时钟 1 用来产生 GMAC 需要的 125MHz 时钟,输出时钟 2 用来产生 RIO 控制器的时钟。

地址偏移: 0x0480



表 5- 20 PLL0 配置寄存器

| 位域    | 名称            | 访问  | 描述             |
|-------|---------------|-----|----------------|
| 63:46 | Reserved      | R/W | 保留             |
| 45    | pl1_pd        | R/W | PLL powerdown  |
| 44    | pll_bypass    | R/W | PLL 内部 bypass  |
| 43    | set_pll_param | R/W | 设置 PLL 配置参数    |
| 42    | sel_pll_out2  | R/W | 选择 PLL 输出时钟 2  |
| 41    | sel_pll_out1  | R/W | 选择 PLL 输出时钟 1  |
| 40    | sel_pll_out0  | R/W | 选择 PLL 输出时钟 0  |
| 39    | pll_locked    | RO  | PLL 锁定         |
| 38:32 | pll_div_ref   | R/W | PLL 输入分频数      |
| 31:30 | Reserved      | R/W | 保留             |
| 29:21 | pll_loopc     | R/W | PLL 倍频乘数       |
| 20:14 | pll_div_out2  | R/W | PLL 输出时钟 2 分频数 |
| 13:7  | pll_div_out1  | R/W | PLL 输出时钟 1 分频数 |
| 6:0   | pll_div_out0  | R/W | PLL 输出时钟 0 分频数 |

### 5.21 PLL1 配置寄存器

该寄存器用来设置 PLL1,其中输出时钟 0 用来产生 DC/VPU 需要的时钟,输出时钟 1 用来产生 DDR 需要的时钟,输出时钟 2 用来产生 GPU 需要的时钟。

地址偏移: 0x0490

表 5- 21 PLL1 配置寄存器

| 位域    | 名称               | 访问  | 描述            |
|-------|------------------|-----|---------------|
| 63:52 | Reserved         | R/W | 保留            |
| 51:50 | soft_memdiv_mode | R/W |               |
| 49    | soft_mc_resetn   | R/W |               |
| 48    | memdiv_resetn    | R/W |               |
| 47:46 | Reserved         | R/W | 保留            |
| 45    | pll_pd           | R/W | PLL powerdown |
| 44    | pll_bypass       | R/W | PLL 内部 bypass |
| 43    | set_pll_param    | R/W | 设置 PLL 配置参数   |
| 42    | sel_pll_out2     | R/W | 选择 PLL 输出时钟 2 |
| 41    | sel_pll_out1     | R/W | 选择 PLL 输出时钟 1 |
| 40    | sel_pll_out0     | R/W | 选择 PLL 输出时钟 0 |
| 39    | pll_locked       | RO  | PLL 锁定        |
| 38:32 | pll_div_ref      | R/W | PLL 输入分频数     |
| 31:30 | Reserved         | R/W | 保留            |
| 29:21 | pll_loopc        | R/W | PLL 倍频乘数      |



| 20:14 | pll_div_out2 | R/W | PLL 输出时钟 2 分频数 |
|-------|--------------|-----|----------------|
| 13:7  | pll_div_out1 | R/W | PLL 输出时钟 1 分频数 |
| 6:0   | pll_div_out0 | R/W | PLL 输出时钟 0 分频数 |

#### 5.22 PLL2 配置寄存器

该寄存器用来设置 PLL2, 其中输出时钟 0 用来作为 HDA 的 24MHz 时钟,输出时钟 1 用来作为内部网络的时钟,输出时钟 2 用来作为 eMMC 的时钟。

地址偏移: 0x04a0 默认值: 0000\_0000h

表 5- 22 PLL2 配置寄存器

| 位域    | 名称            | 访问  | 描述             |
|-------|---------------|-----|----------------|
| 63:46 | Reserved      | R/W | 保留             |
| 45    | pll_pd        | R/W | PLL powerdown  |
| 44    | pll_bypass    | R/W | PLL 内部 bypass  |
| 43    | set_pll_param | R/W | 设置 PLL 配置参数    |
| 42    | sel_pll_out2  | R/W | 选择 PLL 输出时钟 2  |
| 41    | sel_pll_out1  | R/W | 选择 PLL 输出时钟 1  |
| 40    | sel_pll_out0  | R/W | 选择 PLL 输出时钟 0  |
| 39    | pll_locked    | RO  | PLL 锁定         |
| 38:32 | pll_div_ref   | R/W | PLL 输入分频数      |
| 31:30 | Reserved      | R/W | 保留             |
| 29:21 | pll_loopc     | R/W | PLL 倍频乘数       |
| 20:14 | pll_div_out2  | R/W | PLL 输出时钟 2 分频数 |
| 13:7  | pll_div_out1  | R/W | PLL 输出时钟 1 分频数 |
| 6:0   | pll_div_out0  | R/W | PLL 输出时钟 0 分频数 |

# 5.23 PLL\_PIX\_0 配置寄存器

该寄存器用来设置 PLL\_PIX\_0, 其中输出时钟 0 用来产生 PIX0 和 HDMI PHY 的时钟。

地址偏移: 0x04b0

表 5- 23 PLL\_PIX\_0 配置寄存器

| 位域    | 名称            | 访问  | 描述            |
|-------|---------------|-----|---------------|
| 63:46 | Reserved      | R/W | 保留            |
| 45    | pll_pd        | R/W | PLL powerdown |
| 44    | pll_bypass    | R/W | PLL 内部 bypass |
| 43    | set_pll_param | R/W | 设置 PLL 配置参数   |
| 42:41 | Reserved      | R/W | 保留            |
| 40    | sel_pll_out0  | R/W | 选择 PLL 输出时钟 0 |



| 39    | pll_locked   | RO  | PLL 锁定         |
|-------|--------------|-----|----------------|
| 38:32 | pll_div_ref  | R/W | PLL 输入分频数      |
| 31:30 | Reserved     | R/W | 保留             |
| 29:21 | pll_loopc    | R/W | PLL 倍频乘数       |
| 20:7  | Reserved     | R/W | 保留             |
| 6:0   | pll_div_out0 | R/W | PLL 输出时钟 0 分频数 |

### 5.24 PLL\_PIX\_1 配置寄存器

该寄存器用来设置 PLL\_PIX\_1, 其中输出时钟 0 用来产生 PIX1 的时钟。

地址偏移: 0x04c0

默认值: 0000\_0000h

表 5- 24 PLL\_PIX\_1 配置寄存器

| 位域    | 名称            | 访问  | 描述             |
|-------|---------------|-----|----------------|
| 63:46 | Reserved      | R/W | 保留             |
| 45    | pll_pd        | R/W | PLL powerdown  |
| 44    | pll_bypass    | R/W | PLL 内部 bypass  |
| 43    | set_pll_param | R/W | 设置 PLL 配置参数    |
| 42:41 | Reserved      | R/W | 保留             |
| 40    | sel_pll_out0  | R/W | 选择 PLL 输出时钟 0  |
| 39    | pll_locked    | RO  | PLL 锁定         |
| 38:32 | pll_div_ref   | R/W | PLL 输入分频数      |
| 31:30 | Reserved      | R/W | 保留             |
| 29:21 | pll_loopc     | R/W | PLL 倍频乘数       |
| 20:7  | Reserved      | R/W | 保留             |
| 6:0   | pll_div_out0  | R/W | PLL 输出时钟 0 分频数 |

### 5.25 SSC PLL 配置寄存器 0

该寄存器用来设置 SSC PLL, 其中输出时钟 0 用来产生 IO 网络需要的时钟, 输出时钟 1 用来产生 DDR 需要的时钟, 输出时钟 2 用来产生 GPU 需要的时钟。

地址偏移: 0x04e0

表 5- 25 SSC PLL 配置寄存器 0

| 位域    | 名称       | 访问  | 描述       |
|-------|----------|-----|----------|
| 61:56 | Reserved | R/W | 保留       |
| 53:48 | div_out2 | R/W | 输出分频系数 2 |
| 45:40 | div_out1 | R/W | 输出分频系数 1 |
| 37:32 | div_out0 | R/W | 输出分频系数 0 |



| 31:24 | loopc          | R/W | 环路分频系数,可配值范围为8-200(包含)                                                                                                                                                                                      |
|-------|----------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 18:16 | ref_div        | R/W | 参考时钟分频设置                                                                                                                                                                                                    |
| 10:8  | odf_disable    | R/W | 输出分频器禁止,每位对应一个输出分频<br>器,高有效                                                                                                                                                                                 |
| 7:6   | dither_disable | R/W | bit7:为高时禁止长方形 PDF dither<br>bit6:为高时禁止三角形 PDF dither                                                                                                                                                        |
| 5     | strb_bypass    | R/W | 选通信号 bypass, 具体描述参见 strb.                                                                                                                                                                                   |
| 4     | strb           | R/W | 展频或小数分频配置(包括 spread_sel, frac_en, frac_input, mode_pe riod, inc_step)的选通信号. 该位配置的要求如下:  1. 只有 strb_bypass 为 0 时才起作用;  2. 先置高再置低后以上配置信号才生效  3. 只有在 lock 生效后才起作用. 当 strb_bypass 设置为 1 时,以上配置参数只可以在低功耗模式下进行修改. |
| 3     | spread_sel     | R/W | 展频方式选择,0-中心展频,1-下展频                                                                                                                                                                                         |
| 2     | frac_en        | R/W | 小数环路分频使能, 高有效                                                                                                                                                                                               |
| 1     | sscg_en        | R/W | 展频使能, 高有效                                                                                                                                                                                                   |
| 0     | pd             | R/W | 低功耗模式, 高有效                                                                                                                                                                                                  |

## 5.26 SSC PLL 配置寄存器 1

该寄存器用来设置 SSC PLL。

地址偏移: 0x04e8

默认值: 0000\_0000h

表 5- 26 SSC PLL 配置寄存器 1

| 位域    | 名称               | 访问 | 描述                            |
|-------|------------------|----|-------------------------------|
| 60    | lock             |    | PLL 锁定信号, 高有效                 |
| 50    | 11 1             |    | GPU 网络时钟选择设置, 0-选择 PLL1 的输    |
| 58    | gpu_clk_sel      |    | 出,1-选择 SSC PLL 的输出            |
| F.7   |                  |    | DDR 时钟选择设置, 0-选择 PLL1 的输出, 1- |
| 57    | 57   ddr_clk_sel |    | 选择 SSC PLL 的输出                |
| F.C.  |                  |    | I0 网络时钟选择设置, 0-选择 PLL2 的输     |
| 56    | io_clk_sel       |    | 出, 1-选择 SSC PLL 的输出           |
| 50.40 |                  |    | 电荷泵设置,loopc 设置越大,该寄存器设        |
| 52:48 | 52:48 cp         |    | 置越大                           |
| 47:32 | frac_input       |    | 小数环路分频设置                      |
| 30:16 | inc_step         |    | 展频深度设置                        |
| 12:0  | mod_period       |    | 展频调制周期设置                      |



#### 5.27 FREQSCALE 配置寄存器

该寄存器用于配置时钟的分频系数以及 CPU 核的时钟使能。

地址偏移: 0x04d0

默认值: FFFF\_FF99\_FFFF\_FFB7h

表 5- 27 FRESCALE 配置寄存器

| 位域    | 名称                  | 访问  | 描述                 |
|-------|---------------------|-----|--------------------|
| 63:48 | Reserved            | R/W | 保留                 |
| 47    | i2s_clk_en          | R/W | I2S 模块时钟使能         |
| 46:44 | i2s_freqscale       | R/W | I2S 模块时钟分频数        |
| 43    | encrypt_clk_en      | R/W | 加解密模块时钟使能          |
| 42:40 | encrypt_freqscale   | R/W | 加解密模块时钟分频数(分频模式为1) |
| 35    | io_clk_en           | R/W | IO 桥网络时钟使能         |
| 34:32 | io_network_freqscal | R/W | IO桥网络时钟分频数         |
| 25:23 | boot_freqscale      | R/W | boot时钟分频数          |
| 22:20 | apb_freqscale       | R/W | apb时钟分频数           |
| 18:16 | usb_freqscale       | R/W | USB3 控制器时钟分频数      |
| 14:12 | sata_freqscale      | R/W | SATA控制器时钟分频数       |
| 11:4  | Reserved            | R/W | 保留                 |
| 3     | node_freqscale_mode | R/W | node 网络时钟分频模式      |
| 2:0   | node_freqscale      | R/W | node 网络时钟分频数       |

Freqscale 分频计算公式为:

mode 为 0 时: fout= fin \* (freqscale + 1)/8

mode 为 1 时: fout= fin \* 1/(freqscale + 1)

对于分频模式没有指明或无配置位的时钟分频数,其分频模式固定为0.

## 5.28 PCIe\_F0 配置寄存器 0

本组寄存器包含对 PCIe\_FO 的控制信号和状态采集信息。

地址偏移: 0x0580

默认值: 0000\_0191h

表 5-28 PCIe\_F0 配置寄存器 0

| 位域     | 名称            | 访问  | 描述                                                                                               |
|--------|---------------|-----|--------------------------------------------------------------------------------------------------|
| 63:48  | Reserved      | R/W | 保留                                                                                               |
| 47: 44 | port_rst_soft | R/W | F0 的 4 个 pcie port 每个 port 对应 1 位,<br>从低位到高位分别对应 port0 ~ port3<br>0:撤销 port 的复位<br>1:对 port 进行复位 |



|        |                    |      | 复位对应 port 时,需要向对应位先写入 1,           |
|--------|--------------------|------|------------------------------------|
|        |                    |      | 再写入 0                              |
|        |                    |      | F0 的 4 个 pcie port 每个 port 对应 1 位, |
|        |                    |      | │<br>│ 从低位到高位分别对应 port0 ~ port3    |
| 43: 40 | link_down_reset_en | R/W  | 0:链路断开时不产生复位                       |
|        |                    |      | 1:链路断开后产生复位                        |
|        |                    |      | <br>  需要软件将此位域的值配置为 0xf            |
| 39: 36 | Reserved           | R/W  | 保留                                 |
|        |                    |      | 每一位控制 X4 PHY 的一个 lane 的工作状态。       |
|        |                    |      | │<br>│ 从低位到高位分别控制 1ane0 ~ 1ane3    |
| 35: 32 | lane_shut          | R/W  | 0: 正常工作模式                          |
|        |                    |      | 1: 关闭 PHY 的对应 lane                 |
| 31: 28 | Reserved           | R/W  | 保留                                 |
|        |                    | - /w | 0: port3 的 RAM 处在正常工作模式            |
| 27     | p3_ram_stdby       | R/W  | 1: port3的 RAM 处在 standby 模式        |
| 0.0    | p2_ram_stdby       | D /W | 0: port2的 RAM 处在正常工作模式             |
| 26     |                    | R/W  | 1: port2的 RAM 处在 standby 模式        |
| 0.5    | . 11               | ,    | 0: port1 的 RAM 处在正常工作模式            |
| 25     | pl_ram_stdby       | R/W  | 1: port1 的 RAM 处在 standby 模式       |
| 0.4    | pO_ram_stdby       | R/W  | 0: port0 的 RAM 处在正常工作模式            |
| 24     |                    |      | 1: port0 的 RAM 处在 standby 模式       |
| 23:17  | Reserved           | R/W  | 保留                                 |
| 1.0    | . h C C L          | D /W | 0: PHY 未完成软件配置;                    |
| 16     | phy_soft_cfg_done  | R/W  | 1: PHY 己完成软件配置                     |
| 15:13  | Reserved           | R/W  | 保留                                 |
| 10     | ma f. ma at an     | D/W  | 0: 与 PRG 共用参考电阻;                   |
| 12     | ref_master         | R/W  | 1: 使用 PHY 的 PAD 上的参考电阻             |
| 11:4   | Reserved           | R/W  | 保留                                 |
| 3      | app_req_retry_en   | R/W  | 保留                                 |
| 2      | do_sleep           | R/W  | 保留                                 |
| 1      | power_fault        | R/W  | 保留                                 |
| 0      | slot_wake_n        | R/W  | 保留                                 |

## 5.29 PCIe\_F0 配置寄存器 1

本组寄存器包含对 PCIe\_FO 的控制信号和状态采集信息。

地址偏移: 0x0588 默认值: 0006\_0000h

表 5- 29 PCIe\_F0 配置寄存器 1

| 位域    | 名称       | 访问  | 描述 |
|-------|----------|-----|----|
| 63:40 | Reserved | R/W | 保留 |



| 39 | phy_hfc_ready_p3 | RO  | 此位为 1 表示 port3 使用的 PHY 中 PLL 完成<br>时钟锁定                                                                        |
|----|------------------|-----|----------------------------------------------------------------------------------------------------------------|
| 38 | phy_hfc_ready_p2 | RO  | 此位为 1 表示 port2 使用的 PHY 中 PLL 完成<br>时钟锁定                                                                        |
| 37 | phy_hfc_ready_p1 | RO  | 此位为1表示 port1 使用的 PHY 中 PLL 完成时钟锁定                                                                              |
| 36 | phy_hfc_ready_p0 | RO  | 此位为 1 表示 port0 使用的 PHY 中 PLL 完成时钟锁定                                                                            |
| 35 | phy_ready_p3     | RO  | 此位为 1 表示 PHY 的 1ane3 准备好                                                                                       |
| 34 | phy_ready_p2     | RO  | 此位为 1 表示 PHY 的 1ane2 准备好                                                                                       |
| 33 | phy_ready_p1     | RO  | 此位为 1 表示 PHY 的 lanel 准备好                                                                                       |
| 32 | phy_ready_p0     | RO  | 此位为 1 表示 PHY 的 1ane0 准备好                                                                                       |
| 31 | pipe_rst_p3      | R/W | 向此位写入 1 将置 port3 的 PIPE 接口复位信号有效,再写入 0 则结束 port3 的 PIPE 接口的复位                                                  |
| 30 | pipe_rst_p2      | R/W | 向此位写入 1 将置 port2 的 PIPE 接口复位信号有效,再写入 0 则结束 port2 的 PIPE 接口的复位                                                  |
| 29 | pipe_rst_pl      | R/W | 向此位写入1将置 port1的 PIPE 接口复位信号有效,再写入0则结束 port1的 PIPE 接口的复位                                                        |
| 28 | pipe_rst_p0      | R/W | 向此位写入1将置 port0的 PIPE 接口复位信号有效,再写入0则结束 port0的 PIPE 接口的复位                                                        |
| 27 | x4_mode_soft     | R/W | 当 x4_mode_soft 为 1 时,使用 x4_mode_val<br>的值来设置 PHY 是工作在 1X4 还是 4X1 模式<br>当 x4_mode_soft 为 0 时,PHY 工作在 1X4 模<br>式 |
| 26 | x4_mode_val      | R/W | 当 x4_mode_soft 为 1 时,此位为 1 表示 PHY<br>工作在 1X4 模式;此位为 0 表示 PHY 工作在<br>4X1 模式                                     |
| 25 | Reserved         | R/W | 保留                                                                                                             |
| 24 | phy_rst_soft     | R/W | 向此位写入 1 将置 PHY 的复位信号有效,再写入 0 则结束 PHY 的复位用于让软件对 F0 模块的 PCIe PHY 进行总复位                                           |
| 23 | Reserved         | RW  | 保留                                                                                                             |
| 22 | warm_wait_bypass | R/W | 0: 热复位时需要等待 PHY 的 PLL 工作正常 1: 热复位时不等待 PHY 的 PLL 的状态                                                            |
| 21 | phy_state_bypass | R/W | 此位为1时PCIe 控制器的复位控制跳过对PHY_READY的状态观测;否则在等待PHY_READY为1时PCIe 控制器的复位才能继                                            |



|       |                    |      | 续并结束                                 |
|-------|--------------------|------|--------------------------------------|
|       |                    |      | 此位为1时,PHY与PCIe控制器的复位控制               |
| 00    |                    | D/W  | 跳过对 prg_hfc_ready 状态的观察;否则要          |
| 20    | prg_state_bypass   | R/W  | 等待 prg_hfc_ready 为 1 后 PHY 与 PCIe 控制 |
|       |                    |      | 器复位才能继续并结束                           |
| 19:15 | Reserved           | R/W  | 保留                                   |
| 14    | phy_status_p2      | RO   | F0 控制器中 port2 的 PIPE 接口看到的           |
| 14    | phy_status_pz      | KO . | phystatus                            |
| 13    | phy status p2      | RO   | F0 控制器中 port2 的 PIPE 接口看到的           |
| 13    | phy_status_pz      | RO   | phystatus                            |
| 12    | phy status pl      | RO   | F0 控制器中 port1 的 PIPE 接口看到的           |
| 12    | phy_status_pr      | KO   | phystatus                            |
| 11    | phy_status_p0      | RO   | F0 控制器中 port0 的 PIPE 接口 lane0 看到的    |
| 11    | phy_status_po      | KO   | phystatus                            |
| 10    | phy_rstn           | RO   | 此位为 0 表示 PHY 处在复位状态                  |
| 9     | prg_hfc_ready      | RO   | 此位为1表示为PHY产生内部参考时钟的PRG               |
| 9     | prg_nrc_ready      | KO   | 的 PLL 完成时钟锁定                         |
| 8     | phy_hfc_ready_p0   | RO   | 此位为 1 表示 port0 使用的 PHY 中 PLL 完成      |
| 0     | pny_nic_ready_pu   | KO . | 时钟锁定                                 |
| 7     | phy_init_cfg_stop  | RO   | 此位为 1 表示 PHY 的复位后预置初始化配置             |
| ,     |                    | KO . | 过程中出现错误                              |
| 6     | nhy init of a hugy | RO   | 此为 1 表示 PHY 正在进行其复位后的预置初             |
| 0     | phy_init_cfg_busy  | KO . | 始化配置                                 |
| 5:2   | Reserved           | RO   | 保留                                   |
| 1     | nhy init of actor  | RO   | 此位为1表示 PHY 的复位后预置初始化配置               |
| 1     | phy_init_cfg_stop  | KU . | 过程被停止                                |
|       |                    |      | 此为1表示PHY 在其复位后完成了预置的初                |
| 0     | nhy init of done   | RO   | 始化配置                                 |
| 0     | phy_init_cfg_done  | NO.  | 此位为1后才允许对软件对 PHY 进行配置访               |
|       |                    |      | 问                                    |

## 5.30 PCIe\_FO PHY 配置控制寄存器

本组寄存器用来控制产生 PCIe\_FO PHY 内部控制寄存器的配置访问操作。

地址偏移: 0x0590 默认值: 0000\_0000h

表 5- 30 PCIe\_FO PHY 配置寄存器

| 位域    | 名称              | 访问  | 描述                     |
|-------|-----------------|-----|------------------------|
| 63:61 | Reserved        | R/W | 保留                     |
| 00    | 60 phy_cfg_done | RO  | 此位为1表示对的 PHY 一次配置访问完成。 |
| 60    |                 |     | 写完成表示写的数据已经写入 PHY 内部寄存 |



|       |                  |      | 器,读完成表示读的数据已经返回到       |
|-------|------------------|------|------------------------|
|       |                  |      | phy_cfg_data 寄存器       |
| 50    |                  | D /W | 向此位先写入1再写入0,启动一次对PHY的  |
| 59    | phy_cfg_trigger  | R/W  | 配置访问                   |
| 50    |                  | D /W | 0: 对 PHY 进行的是配置读访问     |
| 58    | phy_cfg_write    | R/W  | 1: 对 PHY 进行的是配置写访问     |
|       | 57 phy_cfg_clken | D /W | 0: 关闭 PHY 的配置访问端口时钟    |
| 57    |                  | R/W  | 1: 开启 PHY 的配置访问端口时钟    |
|       |                  | - /w | 0: PHY 的配置访问端口处在复位状态   |
| 56    | phy_cfg_resetn   | R/W  | 1: PHY 的配置访问端口退出复位状态   |
| 55:52 | Reserved         | R/W  | 保留                     |
| 51:32 | phy_cfg_addr     | R/W  | PHY 进行配置访问的地址          |
|       |                  |      | PHY 配置读写数据。在写操作时,将数据先写 |
| 31:0  | phy_cfg_data     | R/W  | 入该寄存,然后再执行写操作;在读操作时,   |
|       |                  |      | 从 PHY 返回的读数据存储到该寄存器。   |

PCIe/SATA/USB3 PHY 以及 PRG 的内部寄存器均通过以上软件接口(接口定义相同,但是每个 PHY 和 PRG 对应的访问寄存器的地址不同)进行读写配置。具体的配置流程如下:

#### 对于写操作

- 1. 将 phy\_cfg\_write 置为 1, 要写的数据写入 phy\_cfg\_data 寄存器, 要写的地址写入 phy\_cfg\_adr 寄存器
  - 2. 将 phy\_cfg\_trigger 先置 1 再置 0
  - 3. 等待 phy\_cfg\_done 变为 1

#### 对于读操作

- 1. 将 phy\_cfg\_write 置为 0, 要读的地址写入 phy\_cfg\_adr 寄存器
- 2. 将 phy cfg trigger 先置 1 再置 0
- 3. 等待 phy\_cfg\_done 变为 1
- 4. phy\_cfg\_data 寄存器中即为从 PHY 中读出的数据

需注意,在配置之前先将 apb\_clken 置为 1,且 apb\_resetn 置为 0,同时需保证在 APB 配置过程中这两位不变。配置完成后可将 apb\_clken 置为 0。

## 5.31PCIe\_F1 配置寄存器 0

本组寄存器包含对 PCIe F1 的控制信号和状态采集信息。

地址偏移: 0x05a0

默认值: 0000\_0191h



#### 表 5- 31 PCIe\_F1 配置寄存器 0

| 位域     | 名称                 | 访问  | 描述                                                                                                                                      |
|--------|--------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------|
| 63: 46 | Reserved           | R/W | 保留                                                                                                                                      |
| 45: 44 | port_rst_soft      | R/W | F1 的 2 个 pcie port 每个 port 对应 1 位,<br>从低位到高位分别对应 port0 ~ port1<br>0: 撤销 port 的复位<br>1: 对 port 进行复位<br>复位对应 port 时,需要向对应位先写入 1,<br>再写入 0 |
| 43: 42 | Reserved           | R/W | 保留                                                                                                                                      |
| 41: 40 | link_down_reset_en | R/W | F1 的 2 个 pcie port 每个 port 对应 1 位,<br>从低位到高位分别对应 port0 ~ port1<br>0: 链路断开时不产生复位<br>1: 链路断开后产生复位<br>需要软件将此位域的值配置为 0x3                    |
| 39: 36 | Reserved           | R/W | 保留                                                                                                                                      |
| 35: 32 | lane_shut          | R/W | 每一位控制 X4 PHY 的一个 lane 的工作状态。<br>从低位到高位分别控制 lane0 ~ lane3<br>0:正常工作模式<br>1:关闭 PHY 的对应 lane                                               |
| 31: 26 | Reserved           | R/W | 保留                                                                                                                                      |
| 25     | pl_ram_stdby       | R/W | 0: port1的 RAM 处在正常工作模式<br>1: port1的 RAM 处在 standby 模式                                                                                   |
| 24     | pO_ram_stdby       | R/W | 0: port0 的 RAM 处在正常工作模式<br>1: port0 的 RAM 处在 standby 模式                                                                                 |
| 23: 17 | Reserved           | R/W | 保留                                                                                                                                      |
| 16     | phy_soft_cfg_done  | R/W | 0: PHY 未完成软件配置;<br>1: PHY 已完成软件配置                                                                                                       |
| 15:13  | Reserved           | R/W | 保留                                                                                                                                      |
| 12     | ref_master         | R/W | 0: 与 PRG 共用参考电阻;<br>1: 使用 PHY 的 PAD 上的参考电阻                                                                                              |
| 11:4   | phy_pll_mult       | R/W | PHY 的 PLL 的初始倍频系数<br>当使用 PCIe 功能时不修改此位域的值,由<br>PHY 自行完成不同速率下的倍频系数的修改<br>Pll_clk_freq =<br>(phy_pll_mult*2)*ref_clk_freq                 |
| 3      | app_req_retry_en   | R/W | 保留                                                                                                                                      |
| 2      | do_sleep           | R/W | 保留                                                                                                                                      |
| 1      | power_fault        | R/W | 保留                                                                                                                                      |
| 0      | slot_wake_n        | R/W | 保留                                                                                                                                      |



## 5.32 PCIe\_F1 配置寄存器 1

本组寄存器包含对 PCIe\_F1 的控制信号和状态采集信息。

地址偏移: 0x05a8 默认值: 0006\_0000h

表 5- 32 PCIe\_F1 配置寄存器 1

| 位域    | 名称               | 访问  | 描述                                                                                                  |
|-------|------------------|-----|-----------------------------------------------------------------------------------------------------|
| 63:36 | Reserved         | R/W | 保留                                                                                                  |
| 35    | phy_ready_p3     | RO  | 此位为 1 表示 PHY 的 lane3 准备好                                                                            |
| 34    | phy_ready_p2     | RO  | 此位为1表示PHY的lane2准备好                                                                                  |
| 33    | phy_ready_p1     | RO  | 此位为1表示PHY的lanel准备好                                                                                  |
| 32    | phy_ready_p0     | RO  | 此位为 1 表示 PHY 的 lane0 准备好                                                                            |
| 31    | Reserved         | R/W | 保留                                                                                                  |
| 30    | Reserved         | R/W | 保留                                                                                                  |
| 29    | pipe_rst_pl      | R/W | 向此位写入 1 将置 port1 的 PIPE 接口复位信号有效,再写入 0 则结束 port1 的 PIPE 接口的复位                                       |
| 28    | pipe_rst_p0      | R/W | 向此位写入 1 将置 port0 的 PIPE 接口复位信号有效,再写入 0 则结束 port0 的 PIPE 接口的复位                                       |
| 27    | x4_mode_soft     | R/W | 当 x4_mode_soft 为 1 时,使用 x4_mode_val 的值来设置 PHY 是工作在 1X4 还是 4X1 模式当 x4_mode_soft 为 0 时,PHY 工作在 1X4 模式 |
| 26    | x4_mode_val      | R/W | 当 x4_mode_soft 为 1 时,此位为 1 表示 PHY 工作在 1X4 模式;此位为 0 表示 PHY 工作在 4X1 模式                                |
| 25    | rio_phy_pll_rstn | R/W | 0: RIO 模式下置 PHY 的 PLL 的复位<br>1: RIO 模式下撤销 PHY 的 PLL 的复位                                             |
| 24    | phy_rst_soft     | R/W | 向此位写入 1 将置 PHY 的复位信号有效,再写入 0则结束 PHY 的复位<br>用于让软件对 F1 模块的 PCIe PHY 进行总复位                             |
| 23    | Reserved         | R/W | 保留                                                                                                  |
| 22    | warm_wait_bypass | R/W | 0: 热复位时需要等待 PHY 的 PLL 工作正常 1: 热复位时不等待 PHY 的 PLL 的状态                                                 |
| 21    | phy_state_bypass | R/W | 此位为 1 时 PCIe 控制器的复位控制跳过对<br>PHY_READY 的状态观测;否则在等待 PHY_READY 为<br>1 时 PCIe 控制器的复位才能继续并结束             |
| 20    | prg_state_bypass | R/W | 此位为1时,PHY与PCIe控制器的复位控制跳过对prg_hfc_ready状态的观察;否则要等待prg_hfc_ready为1后PHY与PCIe控制器复位才能继续并结束               |
| 19:13 | Reserved         | R/W | 保留                                                                                                  |
| 12    | phy_status_pl    | RO  | FO 控制器中 port1 的 PIPE 接口看到的 phystatus                                                                |
| 11    | phy_status_p0    | RO  | F0 控制器中 port0 的 PIPE 接口 lane0 看到的 phystatus                                                         |



| 10  | phy_rstn          | RO | 此位为 0 表示 PHY 处在复位状态                                    |
|-----|-------------------|----|--------------------------------------------------------|
| 9   | prg_hfc_ready     | RO | 此位为 1 表示为 PHY 产生内部参考时钟的 PRG 的 PLL 完成时钟锁定               |
| 8   | phy_hfc_ready     | RO | 此位为 1 表示 PHY 的 PLL 完成时钟锁定                              |
| 7   | phy_init_cfg_stop | RO | 此位为1表示PHY的复位后预置初始化配置过程中<br>出现错误                        |
| 6   | phy_init_cfg_busy | RO | 此为1表示PHY正在进行其复位后的预置初始化配置                               |
| 5:2 | Reserved          | RO | 保留                                                     |
| 1   | phy_init_cfg_stop | RO | 此位为1表示PHY的复位后预置初始化配置过程被停止                              |
| 0   | phy_init_cfg_done | RO | 此为1表示PHY在其复位后完成了预置的初始化配置<br>置<br>此位为1后才允许对软件对PHY进行配置访问 |

## 5.33 PCIe\_F1 PHY 配置控制寄存器

本组寄存器用来控制产生 PCIe\_F1 PHY 内部控制寄存器的配置访问操作。

地址偏移: 0x05b0

默认值: 0000\_0000h

表 5- 33 PCIe\_F1 PHY 配置寄存器

| 位域    | 名称              | 访问  | 描述                                                                                         |
|-------|-----------------|-----|--------------------------------------------------------------------------------------------|
| 63:61 | Reserved        | R/W | 保留                                                                                         |
| 60    | phy_cfg_done    | RO  | 此位为 1 表示对的 PHY 一次配置访问完成。<br>写完成表示写的数据已经写入 PHY 内部寄存<br>器,读完成表示读的数据已经返回到<br>phy_cfg_data 寄存器 |
| 59    | phy_cfg_trigger | R/W | 向此位先写入 1 再写入 0,启动一次对 PHY 的<br>配置访问                                                         |
| 58    | phy_cfg_write   | R/W | 0: 对 PHY 进行的是配置读访问 1: 对 PHY 进行的是配置写访问                                                      |
| 57    | phy_cfg_clken   | R/W | 0: 关闭 PHY 的配置访问端口时钟 1: 开启 PHY 的配置访问端口时钟                                                    |
| 56    | phy_cfg_resetn  | R/W | 0: PHY 的配置访问端口处在复位状态<br>1: PHY 的配置访问端口退出复位状态                                               |
| 55:52 | Reserved        | R/W | 保留                                                                                         |
| 51:32 | phy_cfg_addr    | R/W | PHY 进行配置访问的地址                                                                              |
| 31:0  | phy_cfg_data    | R/W | PHY 配置读写数据。在写操作时,将数据先写<br>入该寄存,然后再执行写操作;在读操作时,<br>从 PHY 返回的读数据存储到该寄存器。                     |



## 5.34 PCIe\_GO 配置寄存器 0

本组寄存器包含对 PCIe\_GO 的控制信号和状态采集信息。

地址偏移: 0x05e0 默认值: 0000\_0191h

表 5- 34 PCIe\_GO 配置寄存器 0

| 位域             | 名称                 | 访问     | 描述                                    |
|----------------|--------------------|--------|---------------------------------------|
| 63:45          | Reserved           | R/W    | 保留                                    |
| 00.10          | Reserved           | 10/ 11 | 0: 撤销 port 的复位                        |
|                |                    |        | 1: 对 port 进行复位                        |
| 44             | port_rst_soft      | R/W    | 复位对应 port 时,需要向对应位先写入 1,              |
|                |                    |        | 再写入0                                  |
| 43: 41         | Reserved           | R/W    | 保留                                    |
| 10, 11         | 110501100          | 147 11 | 0: 链路断开时不产生复位                         |
| 40             | link_down_reset_en | R/W    | 1: 链路断开后产生复位                          |
| 10             |                    | 11, 11 | 需要软件将此位域的值配置为 0x1                     |
| 39: 36         | Reserved           | R/W    | 保留                                    |
|                |                    | === :1 | 每一位控制 X4 PHY 的一个 lane 的工作状            |
|                |                    |        | 态。从低位到高位分别控制 lane0 ~ lane3            |
| 35 <b>:</b> 32 | lane_shut          | R/W    | 0: 正常工作模式                             |
|                |                    |        | 1: 关闭 PHY 的对应 lane                    |
| 31: 25         | Reserved           | R/W    | 保留                                    |
|                |                    |        | 0: port0的RAM处在正常工作模式                  |
| 24             | pO_ram_stdby       | R/W    | 1: port0的RAM处在standby模式               |
| 23: 18         | Reserved           | R/W    | 保留                                    |
| -              |                    | ,      | 0: 在 EP 模式下 PCIe 主机从控制器内部对            |
|                |                    |        | Bar0 寄存器进行访问;                         |
| 17             | bar0_acc_sel       | RW     | <br>  1: 在 EP 模式下 PCIe 主机通过 2K2000 的内 |
|                |                    |        | <br>  部网络访问控制器的 Bar0 寄存器;             |
|                |                    |        | 0: PHY 未完成软件配置;                       |
| 16             | phy_soft_cfg_done  | R/W    | 1: PHY 已完成软件配置                        |
| 15:13          | Reserved           | R/W    | 保留                                    |
|                |                    |        | 0: 与 PRG 共用参考电阻;                      |
| 12             | ref_master         | R/W    | 1:使用 PHY 的 PAD 上的参考电阻                 |
|                |                    |        | PHY 的 PLL 的初始倍频系数                     |
|                |                    |        | <br>  当使用 PCIe 功能时不修改此位域的值,由          |
|                |                    |        | PHY 自行完成不同速率下的倍频系数的修                  |
| 11:4           | phy_pll_mult       | R/W    | 改                                     |
|                |                    |        | P11_c1k_freq =                        |
|                |                    |        | (phy_p11_mult*2)*ref_c1k_freq         |
| 3              | app_req_retry_en   | R/W    | 保留                                    |
| 2              | do_sleep           | R/W    | 保留                                    |



| 1 | power_fault | R/W | 保留 |
|---|-------------|-----|----|
| 0 | slot_wake_n | R/W | 保留 |

## 5.35 PCIe\_GO 配置寄存器 1

本组寄存器包含对 PCIe\_GO 的控制信号和状态采集信息。

地址偏移: 0x05e8

默认值: 0006\_0000h

表 5- 35 PCIe\_GO 配置寄存器 1

| 位域    | 名称               | 访问  | 描述                                                                                                             |
|-------|------------------|-----|----------------------------------------------------------------------------------------------------------------|
| 63:36 | Reserved         | R/W | 保留                                                                                                             |
| 35    | phy_ready_p3     | RO  | 此位为 1 表示 PHY 的 1ane3 准备好                                                                                       |
| 34    | phy_ready_p2     | RO  | 此位为 1 表示 PHY 的 1 ane 2 准备好                                                                                     |
| 33    | phy_ready_p1     | RO  | 此位为 1 表示 PHY 的 lanel 准备好                                                                                       |
| 32    | phy_ready_p0     | RO  | 此位为 1 表示 PHY 的 lane0 准备好                                                                                       |
| 31    | Reserved         | R/W | 保留                                                                                                             |
| 30    | Reserved         | R/W | 保留                                                                                                             |
| 29    | Reserved         | R/W | 保留                                                                                                             |
| 28    | pipe_rst_p0      | R/W | 向此位写入 1 将置 port0 的 PIPE 接口复位信号有效,再写入 0 则结束 port0 的 PIPE接口的复位                                                   |
| 27    | x4_mode_soft     | R/W | 当 x4_mode_soft 为 1 时,使用 x4_mode_val<br>的值来设置 PHY 是工作在 1X4 还是 4X1 模式<br>当 x4_mode_soft 为 0 时, PHY 工作在 1X4<br>模式 |
| 26    | x4_mode_val      | R/W | 当 x4_mode_soft 为 1 时,此位为 1 表示 PHY<br>工作在 1X4 模式;此位为 0 表示 PHY 工作在<br>4X1 模式                                     |
| 25    | rio_phy_pll_rstn | R/W | 0: RIO 模式下置 PHY 的 PLL 的复位<br>1: RIO 模式下撤销 PHY 的 PLL 的复位                                                        |
| 24    | phy_rst_soft     | R/W | 向此位写入 1 将置 PHY 的复位信号有效,再写入 0 则结束 PHY 的复位用于让软件对 FO 模块的 PCIe PHY 进行总复位                                           |
| 23    | ep_phy_cfg_soft  | R/W | 0: EP 模式时不需要对 PHY 进行配置 1: EP 模式时需要对 PHY 进行配置                                                                   |
| 22    | warm_wait_bypass | R/W | 0: 热复位时需要等待 PHY 的 PLL 工作正常 1: 热复位时不等待 PHY 的 PLL 的状态                                                            |
| 21    | phy_state_bypass | R/W | 此位为1时 PCIe 控制器的复位控制跳过对PHY_READY 的状态观测;否则在等待PHY_READY 为1时 PCIe 控制器的复位才能                                         |



|       |                   |       | W. C. V. C                         |
|-------|-------------------|-------|------------------------------------|
|       |                   |       | 继续并结束<br>                          |
|       |                   |       | 此位为1时,PHY与PCIe控制器的复位控              |
| 20    | prg state bypass  | R/W   | 制跳过对 prg_hfc_ready 状态的观察; 否则       |
| 20    | prg_state_bypass  | IV/ W | 要等待 prg_hfc_ready 为 1 后 PHY 与 PCIe |
|       |                   |       | 控制器复位才能继续并结束                       |
| 19:15 | Reserved          | R/W   | 保留                                 |
| 1.4   | 1 10              | DO.   | GO 控制器中 lane3 的 PIPE 接口看到的         |
| 14    | phy_status_13     | RO    | phystatus                          |
| 10    | 1 10              | DO.   | GO 控制器中 lane2 的 PIPE 接口看到的         |
| 13    | phy_status_12     | RO    | phystatus                          |
|       |                   |       | GO 控制器中 lanel 的 PIPE 接口看到的         |
| 12    | phy_status_11     | RO    | phystatus                          |
|       | phy_status_10     |       | GO 控制器中 laneO 的 PIPE 接口 laneO 看到   |
| 11    |                   | RO    | 的 phystatus                        |
| 10    | phy_rstn          | RO    | 此位为 0 表示 PHY 处在复位状态                |
| 9     | prg_hfc_ready     | RO    | 保留                                 |
| 8     | phy_hfc_ready     | RO    | 此位为 1 表示 PHY 的 PLL 完成时钟锁定          |
| _     |                   |       | 此位为1表示PHY的复位后预置初始化配置               |
| 7     | phy_init_cfg_stop | RO    | 过程中出现错误                            |
|       |                   | P.0   | 此为1表示PHY正在进行其复位后的预置初               |
| 6     | phy_init_cfg_busy | RO    | 始化配置                               |
| 5:2   | Reserved          | RO    | 保留                                 |
|       |                   | P.0   | 此位为1表示PHY的复位后预置初始化配置               |
| 1     | phy_init_cfg_stop | RO    | 过程被停止                              |
|       |                   |       | 此为1表示PHY在其复位后完成了预置的初               |
|       | phy_init_cfg_done |       | 始化配置                               |
| 0     |                   | RO    | 此位为1后才允许对软件对PHY进行配置访               |
|       |                   |       | 问                                  |

## 5.36 PCIe\_GO PHY 配置控制寄存器

本组寄存器用来控制产生 PCIe\_GO PHY 内部控制寄存器的配置访问操作。

地址偏移: 0x05f0

默认值: 0000\_0000h

表 5- 36 PCIe\_GO PHY 配置寄存器

| 位域    | 名称           | 访问  | 描述                       |
|-------|--------------|-----|--------------------------|
| 63:61 | Reserved     | R/W | 保留                       |
| 60    | phy_cfg_done | RO  | 此位为 1 表示对的 PHY 一次配置访问完成。 |
|       |              |     | 写完成表示写的数据已经写入 PHY 内部寄存   |
|       |              |     | 器,读完成表示读的数据已经返回到         |
|       |              |     | phy_cfg_data 寄存器         |



| 59    | phy_cfg_trigger | R/W | 向此位先写入 1 再写入 0,启动一次对 PHY 的<br>配置访问                                     |
|-------|-----------------|-----|------------------------------------------------------------------------|
| 58    | phy_cfg_write   | R/W | 0:对 PHY 进行的是配置读访问 1:对 PHY 进行的是配置写访问                                    |
| 57    | phy_cfg_clken   | R/W | 0: 关闭 PHY 的配置访问端口时钟 1: 开启 PHY 的配置访问端口时钟                                |
| 56    | phy_cfg_resetn  | R/W | 0: PHY 的配置访问端口处在复位状态 1: PHY 的配置访问端口退出复位状态                              |
| 55:52 | Reserved        | R/W | 保留                                                                     |
| 51:32 | phy_cfg_addr    | R/W | PHY 进行配置访问的地址                                                          |
| 31:0  | phy_cfg_data    | R/W | PHY 配置读写数据。在写操作时,将数据先写<br>入该寄存,然后再执行写操作;在读操作时,<br>从 PHY 返回的读数据存储到该寄存器。 |

#### 5.37 PCIe 配置访问路由控制寄存器

本寄存器用来控制 PCIe 配置访问的路由。当配置访问命中在 PCIe 控制器二级总线 (secondary bus)上,但设备号非 0 时,可通过配置该寄存器禁止该配置访问被转发到二级总线上。每个 PCIe 端口分别有一个配置位,配置为 0 代表禁止。

地址偏移: 0x0638

默认值: 0000\_0000h

表 5-37 PCIe\_FO PHY 配置寄存器

| 位域     | 名称         | 访问  | 描述                         |
|--------|------------|-----|----------------------------|
| 31: 14 | _          | R/W | 保留                         |
|        |            |     | 每个 PCIe 控制器有一个控制位,对应关系如下:  |
|        |            |     | 03:00 对应 PCIe_F0 的 port3-0 |
| 13:0   | pcie_route | R/W | 05:04 对应 PCIe_F1 的 port1-0 |
|        |            |     | 12 对应 PCIe_GO 的 portO      |
|        |            |     | 其他位,保留                     |

## 5.38 PRG 配置访问寄存器

本组寄存器用来控制产生 PRG 内部控制寄存器的配置访问操作。

地址偏移: 0x0640

默认值: 0000\_0000h

表 5-38 PRG 配置访问寄存器

| 位域    | 名称                | 访问  | 描述                       |
|-------|-------------------|-----|--------------------------|
| 63:61 | Reserved          | R/W | 保留                       |
| CO    | O phy_cfg_done RC | DO. | 此位为 1 表示对的 PHY 一次配置访问完成。 |
| 60    |                   | KU  | 写完成表示写的数据已经写入 PHY 内部寄存器, |



|       |                 |     | 读完成表示读的数据已经返回到 phy_cfg_data<br>寄存器                                    |
|-------|-----------------|-----|-----------------------------------------------------------------------|
| 59    | phy_cfg_trigger | R/W | 向此位先写入 1 再写入 0,启动一次对 PHY 的配置访问                                        |
| 58    | phy_cfg_write   | R/W | 0:对 PHY 进行的是配置读访问 1:对 PHY 进行的是配置写访问                                   |
| 57    | phy_cfg_clken   | R/W | 0: 关闭 PHY 的配置访问端口时钟 1: 开启 PHY 的配置访问端口时钟                               |
| 56    | phy_cfg_resetn  | R/W | 0: PHY 的配置访问端口处在复位状态 1: PHY 的配置访问端口退出复位状态                             |
| 55:52 | Reserved        | R/W | 保留                                                                    |
| 51:32 | phy_cfg_addr    | R/W | PHY 进行配置访问的地址                                                         |
| 31:0  | phy_cfg_data    | R/W | PHY 配置读写数据。在写操作时,将数据先写入<br>该寄存,然后再执行写操作;在读操作时,从<br>PHY 返回的读数据存储到该寄存器。 |

## 5.39 PRG 模块配置寄存器 0

本寄存器用来对 PRG 模块进行配置。

地址偏移: 0x0648

默认值: 6500\_0754h

表 5- 39 PRG 模块配置寄存器 0

| 位域    | 名称              | 访问  | 描述                         |
|-------|-----------------|-----|----------------------------|
| 63:56 | prg_version     | RO  | PRG 版本                     |
| 55:50 | Reserved        | R/W | 保留                         |
| 49    | prg_pwr_reach   | RO  | PRG 模块供电指示                 |
| 48    | hfc_ready       | RO  | PRG 模块输出时钟稳定               |
| 47:40 | prg_sts         | RO  | PRG 模块状态                   |
| 39:35 | Reserved        | R/W | 保留                         |
| 34:32 | prg_pwr_mode    | R/W | PRG power 模式设置             |
| 31    | Reserved        | R/W | 保留                         |
| 30    | prg_plldiv_pup  | R/W | PRG PLLDIV 模块使能            |
| 29    | prg_sin2sqr_pup | R/W | PRG SIN2SQR 模块使能           |
| 28    | prg_xo_pup      | R/W | PRG XO 模块使能                |
| 27    | prg_s2d_pup     | R/W | PRG S2D 模块使能               |
| 26    | prg_ibias_pup   | R/W | PRG IBIAS 模块使能             |
| 25    | prg_d2s_pup1    | R/W | PRG D2S 模块 1 使能            |
| 24    | prg_d2s_pup0    | R/W | PRG D2S 模块 0 使能            |
| 23:16 | prg_pci_pup     | R/W | PRG 输出时钟使能                 |
| 15:11 | Reserved        | R/W | 保留                         |
| 10    | prg_hard_cfg_en | R/W | PRG 硬件配置使能,仅在 pcie 桥和双桥模式下 |



|   |                    |      | 起作用                                |
|---|--------------------|------|------------------------------------|
|   |                    |      | 1: PRG 的 DS 复位和全局复位由硬件控制           |
|   |                    |      | 0: PRG 的 DS 复位和全局复位由软件控制           |
|   |                    |      | (cfg_prg_ds_rstn和cfg_prg_rstn)     |
|   | 1. 7               | D /W | 是否使能 PRG 的输出时钟 1-7, 与              |
| 9 | prg_1to7_pup       | R/W  | cfg_prg_pci_pup 作用类似。              |
|   |                    |      | RPG_CLKSEL 设置为 1 时,可由软件控制 PRG 参    |
|   |                    |      | 考时钟选择                              |
| 8 | prg_clkref_ext_sel | R/W  | 0: 选择 USB3 的 25MHz 参考时钟            |
|   |                    |      | 1:选择外部引脚 PCIe_REFCLKp/n 输入的 100MHz |
|   |                    |      | 参考时钟                               |
| 7 | prg_ssc_en         | R/W  | PRG 模块展频使能                         |
| 6 | prg_en             | R/W  | PRG 模块使能                           |
| 5 | prg_ref_int_en     | R/W  | PRG 内部参考时钟使能                       |
| 4 | prg_clkref_en      | R/W  | PRG 参考时钟使能                         |
| 3 | prg_clkosc_en      | R/W  | PRG OSC 使能                         |
| 2 | prg_xo_byp         | R/W  | PRG OSC bypass                     |
| 1 | prg_ds_rstn        | R/W  | PRG DS 复位信号,低有效                    |
| 0 | prg_rstn           | R/W  | PRG 全局复位信号,低有效                     |

#### 5.40 PRG 模块配置寄存器 1

本寄存器用来对 PRG 模块进行配置。

地址偏移: 0x0650 默认值: 0000\_0000h

表 5- 40 PRG 模块配置寄存器 1

| 位域    | 名称                | 访问    | 描述                          |
|-------|-------------------|-------|-----------------------------|
| 63:48 | cfg_prg_vreg_ctrl | R/W   | PRG voltage regulator配置     |
| 38:36 | cfg_prg_plldiv    | R/W   | PRG PLL 分频设置                |
| 33:32 | cfg_prg_refdiv    | R/W   | PRG 参考时钟分频设置                |
| 31:0  | cfg prg pll ratio | R/W   | 参考时钟 25MHz: 配置为 0x64000000  |
| 31.0  | crg_prg_pri_ratio | IX/ W | 参考时钟 100MHz: 配置为 0x19000000 |

#### 5.41 RapidIO PHY 配置寄存器 0

本组寄存器包含对 PCIe\_F1、PCIe\_G0 在作为 RIO 使用时配置 PHY 的控制信号。

地址偏移: 0x0680 (F1) 、0x600 (G0)

默认值: 0000\_0FF0h

表 5- 41 RapidIO PHY 配置寄存器 0

| 位域    |       | 访问    | 描述     |
|-------|-------|-------|--------|
| 17.54 | D.1/3 | 221.2 | 100.00 |



| 63:62  | Reserved             | R/W   | 保留                                            |
|--------|----------------------|-------|-----------------------------------------------|
| 61     | rx_force_valid       | R/W   | 1: 无条件的从 PHY 接收数据                             |
|        |                      |       | 0: PHY 给出 symbolllock 标志后开始接收来自 PHY 的数        |
| 60     | rx_symbollock_bypass | R/W   | 据                                             |
|        |                      |       | 1: 只要 PHY 达到 bitlock 就开始接收来自 PHY 的数据          |
| 59: 58 | Reserved             | R/W   | 保留                                            |
| 57     | nio abut             | R/W   | 0: RIO 功能时钟保持正常工作状态                           |
| 57     | rio_shut             | K/W   | 1: RIO 关闭内部时钟                                 |
| 56     | rio_ram_standby      | R/W   | 0: RIO 使用的 RAM 保持正常工作状态                       |
| 30     | 110_1am_standby      | IX/ W | 1: RIO 使用的 RAM 进入 standby 状态                  |
| 55: 52 | Reserved             | R/W   | 保留                                            |
| 51     | tx_detectrx_pol_p3   | R/W   | 0: lane3 在检测 RX 存在时将 TX 端设置为 0                |
| 31     | tx_detect1x_po1_p3   | IX/ W | 1: lane3 在检测 RX 存在时将 TX 端设置为 Vdd              |
| 50     | ty dotoetry nol no   | R/W   | 0: lane2 在检测 RX 存在时将 TX 端设置为 0                |
| 30     | tx_detectrx_pol_p2   | IX/ W | 1: lane2 在检测 RX 存在时将 TX 端设置为 Vdd              |
| 49     | tx_detectrx_pol_p1   | R/W   | 0: lanel 在检测 RX 存在时将 TX 端设置为 0                |
| 43     | tx_detect1x_po1_p1   | IX/ W | 1: lanel 在检测 RX 存在时将 TX 端设置为 Vdd              |
| 48     | tx_detectrx_pol_p0   | R/W   | 0: lane0 在检测 RX 存在时将 TX 端设置为 0                |
| 40     | tx_detect1x_po1_po   | IX/ W | 1: lane0 在检测 RX 存在时将 TX 端设置为 Vdd              |
|        | tx_detectrx_in_p3    |       | 0: lane3 在检测 RX 存在时 TX_P = TX_M = Vdd/2       |
|        |                      |       | 1: lane3 在检测 RX 存在时,根据 tx_detectrx_pol_p3     |
| 47     |                      | R/W   | 进行设置 TX 端;如果 tx_detectrx_pol_p3 为 1 则 TX_P =  |
|        |                      |       | TX_M = Vdd;如果tx_detectrx_pol_p3为0则TX_P = TX_M |
|        |                      |       | =0                                            |
|        |                      |       | 0: lane2 在检测 RX 存在时 TX_P = TX_M = Vdd/2       |
|        |                      |       | 1: lane2 在检测 RX 存在时,根据 tx_detectrx_pol_p2     |
| 46     | tx_detectrx_in_p2    | R/W   | 进行设置 TX 端; 如果 tx_detectrx_pol_p2 为 1 则 TX_P = |
|        |                      |       | TX_M = Vdd;如果tx_detectrx_pol_p2为0则TX_P = TX_M |
|        |                      |       | =0                                            |
|        |                      |       | 0: lane1 在检测 RX 存在时 TX_P = TX_M = Vdd/2       |
|        |                      |       | 1: lanel 在检测 RX 存在时,根据 tx_detectrx_pol_p1     |
| 45     | tx_detectrx_in_p1    | R/W   | 进行设置 TX 端; 如果 tx_detectrx_pol_p1 为 1 则 TX_P = |
|        |                      |       | TX_M = Vdd;如果tx_detectrx_pol_p1为0则TX_P = TX_M |
|        |                      |       | =0                                            |
|        |                      |       | 0: lane0 在检测 RX 存在时 TX_P = TX_M = Vdd/2       |
| 44     |                      | D /W  | 1: lane0 在检测 RX 存在时,根据 tx_detectrx_pol_p0     |
|        | tx_detectrx_in_p0    | R/W   | 进行设置 TX 端; 如果 tx_detectrx_pol_p0 为 1 则 TX_P = |
|        |                      |       | TX_M = Vdd;如果tx_detectrx_pol_p0为0则TX_P = TX_M |
|        |                      |       |                                               |
| 43     | tx_detectrx_p3       | R/W   | 0: lane3 检测 RX 存在的电路关闭                        |
|        |                      |       | 1: lane3 检测 RX 存在的电路开启                        |
| 42     | tx_detectrx_p2       | R/W   | 0: lane2 检测 RX 存在的电路关闭                        |
|        |                      |       | 1: lane2 检测 RX 存在的电路开启                        |



| 41    | tx_detectrx_pl | R/W | 0: lanel 检测 RX 存在的电路关闭                     |
|-------|----------------|-----|--------------------------------------------|
|       |                |     | 1: lanel 检测 RX 存在的电路开启                     |
| 40    | tx_detectrx_p0 | R/W | 0: 1ane0 检测 RX 存在的电路关闭                     |
|       |                |     | 1: lane0 检测 RX 存在的电路开启                     |
| 39    | send_beacon_p3 | R/W | 此位为 1 表示在 lane3 发送 beacon                  |
| 38    | send_beacon_p2 | R/W | 此位为 1 表示在 1ane2 发送 beacon                  |
| 37    | send_beacon_p1 | R/W | 此位为 1 表示在 lanel 发送 beacon                  |
| 36    | send_beacon_p0 | R/W | 此位为 1 表示在 lane0 发送 beacon                  |
|       |                |     | 0: 1ane3 尚未完成 power_mode_p3 设置的工作状态的进      |
| 35    | power_reach_p3 | RO  | λ                                          |
|       |                |     | 1: lane3 完成了 power_mode_p3 设置的工作状态的进入      |
|       |                |     | lane3 的工作状态                                |
|       |                |     | 0h: 正常工作模式                                 |
|       |                |     | 1h: TX 闲置, RX 正常工作                         |
|       |                |     | 2h: TX、RX 均闲置                              |
| 34:32 | power_mode_p3  | R/W | 3h: TX 正常工作, RX 闲置                         |
|       |                |     | 4h, 5h: TX、RX 均闲置, DLL 和 PLL 闲置但不关电        |
|       |                |     | 6h: TX、RX 均闲置,DLL 和 PLL 闲置且关电              |
|       |                |     | 7h: 关电状态                                   |
|       |                |     | 0: lane2 尚未完成 power_mode_p2 设置的工作状态的进      |
| 31    | power_reach_p2 | RO  | λ                                          |
|       |                |     | 1: lane2 完成了 power_mode_p2 设置的工作状态的进入      |
|       |                |     | lane2 的工作状态                                |
|       |                |     | 0h: 正常工作模式                                 |
|       |                |     | 1h: TX 闲置, RX 正常工作                         |
|       |                |     | 2h: TX、RX 均闲置                              |
| 30:28 | power_mode_p2  | R/W | 3h: TX 正常工作, RX 闲置                         |
|       |                |     | 4h, 5h: TX、RX 均闲置, DLL 和 PLL 闲置但不关电        |
|       |                |     | 6h: TX、RX 均闲置,DLL 和 PLL 闲置且关电              |
|       |                |     | 7h: 关电状态                                   |
|       |                |     | 0: lanel 尚未完成 power_mode_pl 设置的工作状态的进      |
| 27    | power_reach_p1 | RO  | λ                                          |
|       |                |     | 1: lanel 完成了 power_mode_pl 设置的工作状态的进入      |
|       |                |     | lanel 的工作状态                                |
|       |                |     | 0h: 正常工作模式                                 |
|       |                |     | 1h: TX 闲置, RX 正常工作                         |
| 26:24 |                |     | 2h: TX、RX 均闲置                              |
|       | power_mode_p1  | R/W | 3h: TX 正常工作, RX 闲置                         |
|       |                |     | 4h, 5h: TX、RX 均闲置, DLL 和 PLL 闲置但不关电        |
|       |                |     | 6h: TX、RX 均闲置,DLL 和 PLL 闲置且关电              |
|       |                |     | 7h: 关电状态                                   |
|       |                |     | 0: lane0 尚未完成 power mode p0 设置的工作状态的进      |
| 23    | power_reach_p0 | RO  | ): Taneo 向水光波 power_mode_po 改直的工作状态的近<br>入 |
|       | _              |     |                                            |



|       |                  |      | 1: lane0 完成了 power_mode_p0 设置的工作状态的进入 |
|-------|------------------|------|---------------------------------------|
|       |                  |      | lane0 的工作状态                           |
|       |                  |      | Oh: 正常工作模式                            |
|       |                  |      | 1h: TX 闲置, RX 正常工作                    |
|       |                  | - /w | 2h: TX、RX 均闲置                         |
| 22:20 | power_mode_p0    | R/W  | 3h: TX 正常工作, RX 闲置                    |
|       |                  |      | 4h, 5h: TX、RX 均闲置, DLL 和 PLL 闲置但不关电   |
|       |                  |      | 6h: TX、RX 均闲置,DLL 和 PLL 闲置且关电         |
|       |                  |      | 7h: 关电状态                              |
|       |                  |      | 0: lane3 的 TX 的极性不变                   |
| 19    | tx_polarity_p3   | R/W  | 1: lane3 的 TX 的极性反转                   |
|       |                  |      | 0: lane2的TX的极性不变                      |
| 18    | tx_polarity_p2   | R/W  | 1: lane2 的 TX 的极性反转                   |
|       |                  |      | 0: lane1 的 TX 的极性不变                   |
| 17    | tx_polarity_pl   | R/W  | 1: lane1 的 TX 的极性反转                   |
|       |                  |      | 0: lane0 的 TX 的极性不变                   |
| 16    | tx_polarity_p0   | R/W  | 1: lane0 的 TX 的极性反转                   |
|       |                  |      | 0: lane3 的 RX 的极性不变                   |
| 15    | rx_polarity_p3   | R/W  | 1: lane3 的 RX 的极性反转                   |
|       |                  |      | 0: lane2的RX的极性不变                      |
| 14    | rx_polarity_p2   | R/W  | 1: lane2 的 RX 的极性反转                   |
|       |                  | ,    | 0: lane1 的 RX 的极性不变                   |
| 13    | rx_polarity_pl   | R/W  | 1: lanel 的 RX 的极性反转                   |
|       |                  | ,    | 0: lane0 的 RX 的极性不变                   |
| 12    | rx_polarity_p0   | R/W  | 1: lane0 的 RX 的极性反转                   |
|       |                  | ,    | 0: lane3 在 RX 端的校准功能关闭                |
| 11    | rx_cal_en_p3     | R/W  | 1: lane3 在 RX 端的校准功能开启                |
|       |                  | ,    | 0: lane2 在 RX 端的校准功能关闭                |
| 10    | rx_cal_en_p2     | R/W  | 1: lane2 在 RX 端的校准功能开启                |
|       |                  | ,    | 0: lanel 在 RX 端的校准功能关闭                |
| 9     | rx_cal_en_p1     | R/W  | 1: lanel 在 RX 端的校准功能开启                |
|       |                  |      | 0: lane0 在 RX 端的校准功能关闭                |
| 8     | rx_cal_en_p0     | R/W  | 1: lane0 在 RX 端的校准功能开启                |
|       |                  |      | 0: lane3 检测同步字符的功能关闭                  |
| 7     | sync_det_en_p3   | R/W  | 1: lane3 检测同步字符的功能开启                  |
|       |                  | D (W | 0: lane2 检测同步字符的功能关闭                  |
| 6     | sync_det_en_p2   | R/W  | 1: lane2 检测同步字符的功能开启                  |
| _     | _                | _ (  | 0: lanel 检测同步字符的功能关闭                  |
| 5     | sync_det_en_p1   | R/W  | 1: lanel 检测同步字符的功能开启                  |
|       |                  | P (  | 0: lane0 检测同步字符的功能关闭                  |
| 4     | 4 sync_det_en_p0 | R/W  | 1: lane0 检测同步字符的功能开启                  |
| 3     | tx_en_by_soft    | R/W  | 0: PHY 的 TX 输出使能在 PHY 准备好时自动开启        |



|     |           |     | 1: PHY 的 TX 输出使能由 tx_en_val 控制         |
|-----|-----------|-----|----------------------------------------|
|     |           |     | 在 tx_en_by_soft 为 1 时,控制 PHY 的 TX 输出使能 |
| 2   | tx_en_val | R/W | 0: TX 输出使能关闭                           |
|     |           |     | 1: TX 输出使能开启                           |
|     |           |     | 设置收发时钟的分频                              |
|     |           |     | Oh: PHY PLL 输出时钟频率除以 4                 |
| 1:0 | gen_sel   | R/W | 1h: PHY PLL 输出时钟频率除以 2                 |
|     |           |     | 2h: PHY PLL 输出时钟频率除以 1                 |
|     |           |     | 3h: 保留                                 |

#### 5.42 RapidIO PHY 配置寄存器 1

本组寄存器包含对 PCIe\_F1、PCIe\_G0 在作为 RIO 使用时配置 PHY 的控制信号。

地址偏移: 0x0688 (F1)、0x0608 (G0)

默认值: 0000\_0000h

表 5- 42 RapidIO PHY 配置寄存器 1

| 位域    | 名称        | 访问  | 描述                                  |
|-------|-----------|-----|-------------------------------------|
| 63:62 | Reserved  | R/W | 保留                                  |
| 61:56 | tx_c0_p3  | R/W | Lane3 的 TX 端 FIR 滤波器的 cursor 系数     |
| 55:54 | Reserved  | R/W | 保留                                  |
| 53:48 | tx_c0_p2  | R/W | Lane2 的 TX 端 FIR 滤波器的 cursor 系数     |
| 47:46 | Reserved  | R/W | 保留                                  |
| 45:40 | tx_c0_p1  | R/W | Lanel 的 TX 端 FIR 滤波器的 cursor 系数     |
| 39:38 | Reserved  | R/W | 保留                                  |
| 37:32 | tx_c0_p0  | R/W | lane0 的 TX 端 FIR 滤波器的 cursor 系数     |
| 31:30 | Reserved  | R/W | 保留                                  |
| 29:24 | tx_cm1_p3 | R/W | Lane3 的 TX 端 FIR 滤波器的 pre-cursor 系数 |
| 23:22 | Reserved  | R/W | 保留                                  |
| 21:16 | tx_cm1_p2 | R/W | Lane2 的 TX 端 FIR 滤波器的 pre-cursor 系数 |
| 15:14 | Reserved  | R/W | 保留                                  |
| 13:8  | tx_cm1_p1 | R/W | Lane1 的 TX 端 FIR 滤波器的 pre-cursor 系数 |
| 7:6   | Reserved  | R/W | 保留                                  |
| 5:0   | tx_cm1_p0 | R/W | laneO 的 TX 端 FIR 滤波器的 pre-cursor 系数 |

## 5.43 RapidIO PHY 配置寄存器 2

本组寄存器包含对 PCIe\_F1、PCIe\_GO 在作为 RIO 使用时配置 PHY 的控制信号。

地址偏移: 0x0690 (F1) 、0x0610 (G0)

默认值: 0000\_0000h

表 5- 43 RapidIO PHY 配置寄存器 2



| 位域    | 名称         | 访问  | 描述                                        |
|-------|------------|-----|-------------------------------------------|
| 63:62 | Reserved   | R/W | 保留                                        |
| 61:56 | tx_diff_p3 | R/W | Lane3 TX number of half branches up to 21 |
| 55:54 | Reserved   | R/W | 保留                                        |
| 53:48 | tx_diff_p2 | R/W | Lane2 TX number of half branches up to 21 |
| 47:46 | Reserved   | R/W | 保留                                        |
| 45:40 | tx_diff_p1 | R/W | Lanel TX number of half branches up to 21 |
| 39:38 | Reserved   | R/W | 保留                                        |
| 37:32 | tx_diff_p0 | R/W | laneO TX number of half branches up to 21 |
| 31:30 | Reserved   | R/W | 保留                                        |
| 29:24 | tx_c1_p3   | R/W | Lane3 的 TX 端 FIR 滤波器的 post-cursor 系数      |
| 23:22 | Reserved   | R/W | 保留                                        |
| 21:16 | tx_c1_p2   | R/W | Lane2 的 TX 端 FIR 滤波器的 post-cursor 系数      |
| 15:14 | Reserved   | R/W | 保留                                        |
| 13:8  | tx_c1_p1   | R/W | Lanel 的 TX 端 FIR 滤波器的 post-cursor 系数      |
| 7:6   | Reserved   | R/W | 保留                                        |
| 5:0   | tx_c1_p0   | R/W | lane0 的 TX 端 FIR 滤波器的 post-cursor 系数      |

## 5.44 RapidIO PHY 配置寄存器 3

本组寄存器包含对 PCIe\_F1、PCIe\_G0 在作为 RIO 使用时配置 PHY 的控制信号。

地址偏移: 0x0698 (F1) 、0x0618 (G0)

默认值: 0000\_3C1Ch

表 5- 44 RapidIO PHY 配置寄存器 3

| 位域    | 名称                    | 访问  | 描述                                     |
|-------|-----------------------|-----|----------------------------------------|
| 63:62 | rx_boundary_en_p3     | R/W | lane3的RX boundary 使能控制                 |
| 61:60 | rx_boundary_en_p2     | R/W | lane2的RX boundary 使能控制                 |
| 59:58 | rx_boundary_en_p1     | R/W | lanel 的 RX boundary 使能控制               |
| 57:56 | rx_boundary_en_p0     | R/W | laneO的RX boundary 使能控制                 |
| 55:52 | rx_cal_dwcnt          | R/W | RX calibration 使用的计数值                  |
| 51    | rx_cal_compete_clr_p3 | R/W | 此位置1将清除 lane3 的 RX calibration 完成状态位   |
| 50    | rx_cal_compete_clr_p2 | R/W | 此位置 1 将清除 lane2 的 RX calibration 完成状态位 |
| 49    | rx_cal_compete_clr_p1 | R/W | 此位置1将清除 lanel 的 RX calibration 完成状态位   |
| 48    | rx_cal_compete_clr_p0 | R/W | 此位置1将清除 laneO 的 RX calibration 完成状态位   |
|       |                       |     | 当 rio_prioirty 为 1 时,lane3 的使能控制       |
| 47    | lane_en_p3            | R/W | 0: 不使能                                 |
|       |                       |     | 1: 使能                                  |
|       |                       |     | 当 rio_prioirty 为 1 时,lane2 的使能控制       |
| 46    | lane_en_p2            | R/W | 0: 不使能                                 |
|       |                       |     | 1: 使能                                  |
| 45    | lane_en_p1            | R/W | 当 rio_prioirty 为 1 时,lanel 的使能控制       |



|       |                     |       | 0: 不使能                                    |
|-------|---------------------|-------|-------------------------------------------|
|       |                     |       | 1: 使能                                     |
|       |                     |       | 当 rio prioirty 为 1 时, lane0 的使能控制         |
| 44    | lane_en_p0          | R/W   | 0: 不使能                                    |
|       |                     | ,     | 1: 使能                                     |
| 43:33 | Reserved            | R/W   | 保留                                        |
| 32    | tx_align_done       | RO    | 此位为 1 表示多个 lane 的 TX 时钟完成相位对齐的操作          |
| 0.1   | 1.1                 | DO.   | 此位为 1,表示 lane3 完成 RX 端的检测到错误的同步字          |
| 31    | bad_syncdet_p3      | RO    | 符(comma)                                  |
| 30    | bad_syncdet_p2      | RO    | 此位为 1,表示 lane2 完成 RX 端的检测到错误的同步字          |
|       | bau_syncuet_pz      | KO    | 符(comma)                                  |
| 29    | bad_syncdet_p1      | RO    | 此位为 1,表示 lanel 完成 RX 端的检测到错误的同步字          |
|       |                     |       | 符(comma)                                  |
| 28    | bad_syncdet_p0      | RO    | 此位为 1,表示 lane0 完成 RX 端的检测到错误的同步字          |
|       |                     |       | 符(comma)                                  |
| 27    | syncdet_p3          | RO    | 此位为 1,表示 1ane3 完成 RX 端的检测到同步字符            |
|       | _                   |       | (comma)                                   |
| 26    | syncdet_p2          | RO    | 此位为 1,表示 1ane2 完成 RX 端的检测到同步字符            |
|       |                     |       | (comma)                                   |
| 25    | syncdet_p1          | RO    | 此位为 1,表示 lanel 完成 RX 端的检测到同步字符            |
|       |                     |       | (comma)<br>此位为 1,表示 lane0 完成 RX 端的检测到同步字符 |
| 24    | syncdet_p0          | RO    | 此位为1,农外Taneo元成KA编的短例到问少于的(comma)          |
| 23    | rx_symbol_locked_p3 | RO    | 此位为 1,表示 1ane3 完成 RX 端的字符锁定               |
| 22    | rx_symbol_locked_p2 | RO    | 此位为 1,表示 1ane2 完成 RX 端的字符锁定               |
| 21    | rx_symbol_locked_p1 | RO    | 此位为 1,表示 lanel 完成 RX 端的字符锁定               |
| 20    | rx_symbol_locked_p0 | RO    | 此位为 1,表示 lane0 完成 RX 端的字符锁定               |
| 19    | rx_bit_locked_p3    | RO    | 此位为 1,表示 lane3 完成 RX 端的 bit 锁定            |
| 18    | rx_bit_locked_p2    | RO    | 此位为 1,表示 lane2 完成 RX 端的 bit 锁定            |
| 17    | rx_bit_locked_p1    | RO    | 此位为 1,表示 lanel 完成 RX 端的 bit 锁定            |
| 16    | rx_bit_locked_p0    | RO    | 此位为 1,表示 lane0 完成 RX 端的 bit 锁定            |
| 15    | Reserved            | R/W   | 保留                                        |
|       |                     |       | 0: PLL 的 VCO 分频电路的上电由 phy_ready_pN 控制 (当  |
| 14    | vcodiv_pup_by_soft  | R/W   | phy_ready_p0~3 均为 1 后自动上电)                |
|       |                     |       | 1: PLL 的 VCO 分频电路的上电由 vcodiv_pup_val 控制   |
| 1.0   | woodiy pup yol      | R/W   | 0: PLL 的 VCO 分频电路关闭                       |
| 13    | vcodiv_pup_val      | IV/ W | 1: PLL 的 VCO 分频电路开启                       |
|       |                     |       | PHY 的 PLL VCO 的分频系数                       |
|       |                     |       | 0h: 4                                     |
| 12:10 | vcodiv_ratio        | R/W   | 1h: 8                                     |
|       |                     |       | 2h、3h: 16                                 |
|       |                     |       | 4h、5h: 10                                 |



|      |                       |      | 6h、7h: 20                                       |
|------|-----------------------|------|-------------------------------------------------|
|      |                       | D /W | 0: PHY 的复位和线路使能使用 PCIe 的控制                      |
| 9    | rio_prioirty          | R/W  | 1: PHY 的复位和线路使能使用 RIO 的控制                       |
|      |                       |      | 当 rio_prioirty 为 1 时用于控制 PHY 的复位                |
| 8    | rio_phy_rstn          | R/W  | 0: PHY 的复位信号有效                                  |
|      |                       |      | 1: PHY 的复位信号撤销                                  |
| 7    | 1:                    | D /W | 0: TX 时钟对齐电路复位由 rio_phy_pll_rstn 控制             |
| 7    | tx_align_rstn_by_soft | R/W  | 1: TX 时钟对齐电路复位由 tx_align_rstn_val 控制            |
|      |                       |      | 软件控制 TX 时钟对齐电路复位时                               |
| C    | 1 1: - 1: - 1         | D /W | (tx_align_rstn_by_soft 为 1) 的复位信号值              |
| 6    | tx_align_rstn_val     | R/W  | 0: TX 时钟对齐电路复位有效                                |
|      |                       |      | 1: TX 时钟对齐电路复位撤销                                |
|      |                       | R/W  | RIO的设备类型和初始的 Host Base Device ID                |
| F. 4 | 1                     |      | 2'b00: host with dev ID as 8'h00 (16'h0000)     |
| 5:4  | device_type           |      | 2'b01: host with dev ID as 8'h01 (16'h0001)     |
|      |                       |      | 2'blx: endpoint with dev ID as 8'hFF (16'hFFFF) |
| 3:2  | Reserved              | R/W  | 保留                                              |
| 1    | lance than            | D/W  | 0: Small Transport Size (8-bit ID)              |
| 1    | large_tran            | R/W  | 1: Large Transport Size (16-bit ID)             |
|      |                       | D /W | 0: RIO 复位信号置位                                   |
| 0    | rab_soft_rstn         | R/W  | 1: RIO 复位信号撤销                                   |

## 5.45 PAD 驱动配置寄存器

本寄存器用来对 PAD 的驱动能力进行配置。

地址偏移: 0x06e0

默认值: 0000\_0000\_3c8d\_d001h

表 5- 45 PAD 驱动配置寄存器

| 位域      | 名称          | 访问   | 描述              |  |
|---------|-------------|------|-----------------|--|
|         |             |      | 3.3V pad 驱动能力控制 |  |
|         |             |      | 0:COMPEN        |  |
|         |             |      | 1:COMPTQ        |  |
| C2 . 40 | 10 0 1      | D /W | 2:FASTFRZ       |  |
| 63:48   | pad3v3_ctrl | R/W  | 3:FREEZE        |  |
|         |             |      | 7:4 RASRCN      |  |
|         |             |      | 11:8 RASRCP     |  |
|         |             |      | 12: SLEEP       |  |
|         | pad1v8_ctrl | R/W  | 1.8V pad 驱动能力控制 |  |
|         |             |      | 0:COMPEN        |  |
| 47:32   |             |      | 1:COMPTQ        |  |
|         |             |      | 2:FASTFRZ       |  |
|         |             |      | 3:FREEZE        |  |



|       |                | 7:4 RASRCN |                                      |
|-------|----------------|------------|--------------------------------------|
|       |                |            | 11:8 RASRCP                          |
|       |                |            | 12:SLEEP                             |
|       |                |            | eMMC PAD 电压软件配置 (SYS_CLKSEL 为 1 时有效) |
| 31    | emmc_psw_soft  | R/W        | 0: 1.8V 供电                           |
|       |                |            | 1: 3.3V 供电                           |
| 30    | pad_ctrl_emmc  | R/W        | eMMC PAD 驱动能力控制                      |
| 29:28 | pad_ctrl_gmac  | R/W        | GMAC PAD 驱动能力控制                      |
| 27:26 | pad_ctrl_acpi  | R/W        | ACPI PAD 驱动能力控制                      |
| 25:24 | pad_ctrl_miphy | R/W        | miphy PAD 驱动能力控制                     |
| 23:22 | pad_ctrl_pcie  | R/W        | PCIe PAD 驱动能力控制                      |
| 21:20 | pad_ctrl_sata  | R/W        | SATA PAD 驱动能力控制                      |
| 19:18 | pad_ctrl_hda   | R/W        | HDA PAD 驱动能力控制                       |
| 17:16 | pad_ctrl_lio   | R/W        | LIO PAD 驱动能力控制                       |
| 15:14 | pad_ctrl_lpc   | R/W        | LPC PAD 驱动能力控制                       |
| 13:12 | pad_ctrl_spi   | R/W        | SPI PAD 驱动能力控制                       |
| 11:10 | pad_ctrl_jtag  | R/W        | JTAG PAD 驱动能力控制                      |
| 9:8   | pad_ctrl_uart  | R/W        | UART PAD 驱动能力控制                      |
| 7:6   | pad_ctrl_pwm   | R/W        | PWM PAD 驱动能力控制                       |
| 5:4   | pad_ctrl_i2c   | R/W        | I2C PAD 驱动能力控制                       |
| 3:2   | pad_ctrl_gpio  | R/W        | GPIO PAD 驱动能力控制                      |
| 1:0   | pad_ctrl_sdio  | R/W        | SDIO PAD 驱动能力控制                      |

# 5.46 Compensation 状态寄存器

本寄存器用来读取补偿状态。

地址偏移: 0x06e8

默认值: 0000\_0000h

表 5-46 PAD 驱动配置寄存器

| 位域    | 名称                  | 访问  | 描述                       |
|-------|---------------------|-----|--------------------------|
|       |                     |     | 53:compok_3v3_1eft       |
|       |                     |     | 52:compok_3v3_top        |
| F2.40 | C                   | DO. | 51:compok_3v3_right      |
| 53:48 | Compensation 模块状态指示 | RO  | 50:compok_3v3_rsm        |
|       |                     |     | 49:compok_3v3_rsmacpi    |
|       |                     |     | 48:compok_1v8            |
|       | Compensation 模块锁定码  | RO  | [47:44]:nasrcp_3v3_left  |
|       |                     |     | [43:40]:nasrcn_3v3_1eft  |
| 47:0  |                     |     | [39:36]:nasrcp_3v3_top   |
|       |                     |     | [35:32]:nasrcn_3v3_top   |
|       |                     |     | [31:28]:nasrcp_3v3_right |



|  | [27:24]:nasrcn_3v3_right   |
|--|----------------------------|
|  | [23:20]:nasrcp_3v3_rsm     |
|  | [19:16]:nasrcn_3v3_rsm     |
|  | [15:12]:nasrcp_3v3_rsmacpi |
|  | [11:08]:nasrcn_3v3_rsmacpi |
|  | [07:04]:nasrcp_1v8 ,       |
|  | [03:00]:nasrcn_1v8         |

## 5.47 SATA PHY 配置寄存器

本寄存器用来配置 SATA PHY 的一些控制参数。

地址偏移: 0x0740

默认值: 0000\_0000\_0000\_f412h

表 5- 47 SATA PHY 配置寄存器

|       | 1                            |     |                                                                                          |
|-------|------------------------------|-----|------------------------------------------------------------------------------------------|
| 位域    | 名称                           | 访问  | 描述                                                                                       |
| 63:62 | phy_osc_mode                 | R/W | PHY OSC 模式                                                                               |
| 61    | phy_hfc_ready                | RO  | _                                                                                        |
| 60    | phy_pl_osc_rdy               | RO  | _                                                                                        |
| 59:40 | phy_sata_bert_eb_fill        | RO  | -                                                                                        |
| 39:36 | phy_sigdet                   | RO  | _                                                                                        |
| 35:32 | phy_syncchardet              | RO  | -                                                                                        |
| 31:28 | phy_rx_symbol_lock           | RO  | _                                                                                        |
| 27:24 | phy_rx_bit_lock              | RO  | _                                                                                        |
| 23:20 | phy_ready                    | RO  | _                                                                                        |
| 19:16 | phy_cfg_soft_phy_rstn        | R/W | PHY 软复位控制,每一位对应一个 PORT                                                                   |
| 15:12 | phy_cfg_sel_soft_phy_rstn    | R/W | PHY 软复位控制选择,每一位对应一个PORT  0: 由硬件控制 PHY 的复位信号;  1: 由寄存器 phy_cfg_soft_phy_rstn 控制 PHY 的复位信号 |
| 11    | phy_pl_osc_force_on          | R/W | 强制晶振启动信号                                                                                 |
| 10    | phy_p1_osc_bypass            | R/W | OSC bypass                                                                               |
| 9:8   | phy_osc_ref_div              | R/W | OSC 参考时钟分频控制                                                                             |
| 7     | phy_p1_rst_osc_n             | R/W | OSC 复位信号                                                                                 |
| 6     | clksel                       | R/W | 参考时钟选择 0:选择外部 25MHz 差分时钟 1:选择内部差分时钟                                                      |
| 5     | phy_p1_ssc_en                | R/W | SSC 使能                                                                                   |
| 4     | phy_ref_diff                 | R/W | 差分参考时钟选择,必须设置为1                                                                          |
| 3     | phy_ sel _sigdet_sync_logic  | R/W | -                                                                                        |
| 2     | phy_ bypass_rx_data_gating_n | R/W | -                                                                                        |



| 1 | phy_soft_rst_n_sata | R/W | SATA 控制器软件复位控制,低有效  |
|---|---------------------|-----|---------------------|
| 0 | phy_cfg_reset_n     | R/W | SATA PHY 全局复位控制,低有效 |

#### 5.48 SATA PHY 配置访问寄存器

本组寄存器用来控制产生 SATA PHY 内部控制寄存器的配置访问操作。

地址偏移: 0x0748

默认值: 0000\_0000h

表 5-48 SATA PHY 配置访问寄存器

| 位域    | 名称              | 访问    | 描述                     |
|-------|-----------------|-------|------------------------|
| 63:61 | Reserved        | R/W   | 保留                     |
|       |                 |       | 此位为 1 表示对的 PHY 一次配置访问完 |
|       |                 |       | 成。                     |
| 60    | phy_cfg_done    | RO    | 写完成表示写的数据已经写入 PHY 内部寄  |
|       |                 |       | 存器,读完成表示读的数据已经返回到      |
|       |                 |       | phy_cfg_data 寄存器       |
| 59    | nhy of trigger  | R/W   | 向此位先写入1再写入0,启动一次对PHY   |
| 39    | phy_cfg_trigger | IV/ W | 的配置访问                  |
| 58    | phy_cfg_write   | R/W   | 0: 对 PHY 进行的是配置读访问     |
| 36    |                 | K/W   | 1: 对 PHY 进行的是配置写访问     |
| 57    | phy_cfg_clken   | R/W   | 0: 关闭 PHY 的配置访问端口时钟    |
| 31    |                 |       | 1: 开启 PHY 的配置访问端口时钟    |
| 56    | phy_cfg_resetn  | R/W   | 0: PHY 的配置访问端口处在复位状态   |
| 30    |                 |       | 1: PHY 的配置访问端口退出复位状态   |
| 55:52 | Reserved        | R/W   | 保留                     |
| 51:32 | phy_cfg_addr    | R/W   | PHY 进行配置访问的地址          |
|       | phy_cfg_data    |       | PHY 配置读写数据。在写操作时,将数据   |
| 21.0  |                 | R/W   | 先写入该寄存,然后再执行写操作; 在读    |
| 31:0  |                 |       | 操作时,从 PHY 返回的读数据存储到该寄  |
|       |                 |       | 存器。                    |

#### 5.49 SATA PHY PLL 配置寄存器

本寄存器用来对 SATA PHY 内部 PLL 进行配置。

地址偏移: 0x0750

默认值: 00f0\_0000h

表 5- 49 SATA PHY PLL 配置寄存器

| 位域   | 名称           | 访问  | 描述              |
|------|--------------|-----|-----------------|
| 23:0 | pl_pll_ratio | R/W | SATA PHY PLL 配置 |



## 5.50 GMAC0 配置寄存器

本组寄存器用来操作 gmac0 以及对应 PHY 的相关配置。

地址偏移: 0770h

默认值: 01c2\_0e0fh

表 5- 50 GMACO 配置寄存器

| 位域    | 名称                  | 访问   | 描述                                        |
|-------|---------------------|------|-------------------------------------------|
| 63:33 | Reserved            | R/W  | 保留                                        |
| 32    | gmac_reset          | R/W  | gmac 控制器复位信号,高有效                          |
| 31    | phy_pll_lock        | RO   | PHY PLL 锁定信号                              |
| 30:25 | Reserved            | R/W  | 保留                                        |
| 24    | phy_resetn          | R/W  | PHY 复位控制信号,低有效                            |
|       |                     |      | 参考时钟模式                                    |
| 23    | ref_clk_mode        | R/W  | 0: 单端时钟                                   |
|       |                     |      | 1: 差分时钟                                   |
|       |                     |      | PHY 参考时钟频率选择                              |
| 22    | p11_25_125          | R/W  | 0: 125M(必须将 ref_clk_mode 设置为 0)           |
|       |                     |      | 1: 25M(必须将 ref_clk_mode 设置为 1)            |
|       |                     |      | led_100b 显示模式                             |
| 21    | led_100b_mode       | R/W  | 0: 10/100 BASE-T 模式                       |
|       |                     |      | 1: 10/100/1000 BASE-T 模式                  |
| 00.10 | phy_addr            | R/W  | PHY 地址, 当配置 PHY 内部寄存器时 gmac 寄存器内的 PHY 地址应 |
| 20:16 |                     |      | 与该地址相同,该地址不能为全0                           |
| 15    | BR_en               | R/W  | BroadR-Reach enable                       |
| 1.4   | wire_speed_downgrad | D /W | 只有在自协商模式下有效                               |
| 14    | е                   | R/W  |                                           |
|       |                     |      | PHY 主从模式,使能 manual_ms_en 时有效              |
| 1.9   |                     | D/W  | 0: PHY 为 slave 模式                         |
| 13    | manual_ms_value     | R/W  | 1: PHY 为 master 模式                        |
|       |                     |      | 10/100 BASE-T 模式下无效                       |
|       |                     |      | PHY 主从模式手动配置使能                            |
| 12    |                     | D/W  | 0: 禁止手动配置主从模式,通过自协商解决                     |
| 12    | manual_ms_en        | R/W  | 1: 使能手动配置主从模式                             |
|       |                     |      | 10/100 BASE-T 模式下无效                       |
|       |                     |      | PHY 自协商使能(复位后默认值,可通过 PHY 内部寄存器重新配置)       |
| 11    | auto_neg_en         | R/W  | 0: 禁用自协商                                  |
|       |                     |      | 1: 使能自协商                                  |
|       |                     |      | PHY 工作模式选择(bit7 为 0 时有效)                  |
| 10    | full_duplex_en      | R/W  | 0: 半双工                                    |
|       |                     |      | 1: 全双工                                    |
| 0.0   | anand and           | D/W  | PHY 工作速率选择(bit7 为 0 时有效)                  |
| 9:8   | speed_sel           | R/W  | 00: 10 BASE-T                             |



|     |               |     | 01: 100 BASE-T                             |
|-----|---------------|-----|--------------------------------------------|
|     |               |     | 10: 1000 BASE-T                            |
|     |               |     | 11: Reserved                               |
|     |               |     | PHY 复位后工作模式和速率配置选择(推荐为 0)                  |
| 7   | init_mode_sel | R/W | 0: 手动配置                                    |
|     |               |     | 1: 使用 GMAC 输出结果                            |
| 6:4 | Reserved      | R/W | 保留                                         |
| 3   | mdc_one_cycle | R/W | 当通过 mdc 和 mdio 写 PHY 内部寄存器时,写数据完成后再发一个时钟周期 |
| 2   | gmii_col_en   | R/W | PHY 输出的 col 信号标志使能位,半双工模式必须为 1             |
| 1   | Reserved      | R/W | 保留                                         |
| 0   | gmii_crs_en   | R/W | PHY 输出的 crs 信号标志使能位,半双工模式必须为 1             |

## 5.51 GMAC1 配置寄存器

本组寄存器用来操作 gmac1 以及对应 PHY 的相关配置。

地址偏移: 0778h

默认值: 01c3\_0e0fh

表 5- 51 GMAC1 配置寄存器

| 位域    | 名称                  | 访问  | 描述                                       |
|-------|---------------------|-----|------------------------------------------|
| 63:33 | Reserved            | R/W | 保留                                       |
| 32    | gmac_reset          | R/W | gmac 控制器复位信号,高有效                         |
| 31    | phy_pll_lock        | RO  | PHY PLL 锁定信号                             |
| 30:25 | Reserved            | R/W | 保留                                       |
| 24    | phy_resetn          | R/W | PHY 复位控制信号,低有效                           |
|       |                     |     | 参考时钟模式                                   |
| 23    | ref_clk_mode        | R/W | 0: 单端时钟                                  |
|       |                     |     | 1: 差分时钟                                  |
|       |                     |     | PHY 参考时钟频率选择                             |
| 22    | pl1_25_125          | R/W | 0: 125M(必须将 ref_clk_mode 设置为 0)          |
|       |                     |     | 1: 25M(必须将 ref_clk_mode 设置为 1)           |
|       |                     |     | led_100b 显示模式                            |
| 21    | led_100b_mode       | R/W | 0: 10/100 BASE-T 模式                      |
|       |                     |     | 1: 10/100/1000 BASE-T 模式                 |
| 00.10 | phy_addr            | R/W | PHY 地址,当配置 PHY 内部寄存器时 gmac 寄存器内的 PHY 地址应 |
| 20:16 |                     |     | 与该地址相同,该地址不能为全 0                         |
| 15    | BR_en               | R/W | BroadR-Reach enable                      |
| 14    | wire_speed_downgrad | R/W | 只有在自协商模式下有效                              |
| 13    | manual ma valua     | R/W | PHY 主从模式,使能 manual_ms_en 时有效             |
| 13    | manual_ms_value     | K/W | 0: PHY 为 slave 模式                        |



|     |                  | 1     |                                        |  |  |
|-----|------------------|-------|----------------------------------------|--|--|
|     |                  |       | 1: PHY 为 master 模式                     |  |  |
|     |                  |       | 10/100 BASE-T 模式下无效                    |  |  |
|     |                  |       | PHY 主从模式手动配置使能                         |  |  |
| 10  | 1                | D/W   | 0: 禁止手动配置主从模式,通过自协商解决                  |  |  |
| 12  | manual_ms_en     | R/W   | 1: 使能手动配置主从模式                          |  |  |
|     |                  |       | 10/100 BASE-T 模式下无效                    |  |  |
|     |                  |       | PHY 自协商使能(复位后默认值,可通过 PHY 内部寄存器重新配置)    |  |  |
| 11  | auto_neg_en      | R/W   | 0:禁用自协商                                |  |  |
|     |                  |       | <br>  1: 使能自协商                         |  |  |
|     |                  |       | PHY 工作模式选择(bit7 为 0 时有效)               |  |  |
| 10  | full_duplex_en   | R/W   | 0: 半双工                                 |  |  |
|     |                  |       | 1: 全双工                                 |  |  |
|     |                  |       | PHY 工作速率选择(bit7 为 0 时有效)               |  |  |
|     |                  |       | 00: 10 BASE-T                          |  |  |
| 9:8 | speed_sel        | R/W   | 01: 100 BASE-T                         |  |  |
|     |                  |       | 10: 1000 BASE-T                        |  |  |
|     |                  |       | 11: Reserved                           |  |  |
|     |                  |       | PHY 复位后工作模式和速率配置选择(推荐为 0)              |  |  |
| 7   | init_mode_sel    | R/W   | <br>  0: 手动配置                          |  |  |
|     | 11110_110000_001 |       | <br>  1: 使用 GMAC 输出结果                  |  |  |
| 6:4 | Reserved         | R/W   | 保留                                     |  |  |
|     |                  |       | 当通过 mdc 和 mdio 写 PHY 内部寄存器时,写数据完成后再发一个 |  |  |
| 3   | mdc_one_cycle    | R/W   | 时钟周期                                   |  |  |
| 2   | gmii_col_en      | R/W   | PHY 输出的 col 信号标志使能位,半双工模式必须为 1         |  |  |
| 1   | Reserved         | R/W   | 保留                                     |  |  |
| 0   | gmii_crs_en      | R/W   | PHY 输出的 crs 信号标志使能位,半双工模式必须为 1         |  |  |
|     | 8m11_C12_C11     | 11/ " | 11111111111111111111111111111111111111 |  |  |

#### 5.52 USB3 PHY 配置寄存器 0

芯片集成了 12 个 USB 端口,其中 USB3.0 有 4 个端口,USB2.0 有 8 个端口,由两个控制器 (一个 USB3.0 xhci 控制器和一个 USB2.0 xhci 控制器)控制。USB3.0 控制器对应 4 个 USB3.0 端口和 4 个 USB2.0 端口,USB2.0 控制器对应 4 个 USB2.0 端口。

本组寄存器用来配置 USB PHY 接口相关的电气特性,每个端口由一个 DW 控制。

地址偏移: 0800h

默认值: 0000\_0000\_0000\_0000h

表 5- 52 USB3 PHY 配置寄存器 0

| 位域 | 名称         | 访问  | 描述                                               |  |
|----|------------|-----|--------------------------------------------------|--|
| 59 | apb_access | R/W | USB3. 0PHY 的 apb 配置接口的读写访问使能<br>1: 访问开始<br>0: 还原 |  |
| 58 | apb_pwrite | R/W | USB3. 0PHY 的 apb 配置接口的读写控制                       |  |



|      |                |      | 1: 写有效                                     |  |
|------|----------------|------|--------------------------------------------|--|
|      |                |      | 0: 读有效                                     |  |
|      |                |      | USB3. OPHY 的 apb 配置接口的时钟时能                 |  |
| 57   | cfg_apb_clken  | R/W  | 1: 使能                                      |  |
|      |                |      | 0: 关闭                                      |  |
|      |                |      | USB3. OPHY 的 apb 配置接口的复位                   |  |
| 56   | cfg_apb_resetn | R/W  | 1: 解复位                                     |  |
|      |                |      | 0: 复位                                      |  |
| 51:3 | 1 11           | D /W | HICDO ODIN 44 1 FI EI EI 45 EI 45 LI 45 LI |  |
| 2    | apb_paddr      | R/W  | USB3. 0PHY 的 apb 配置接口的地址                   |  |
| 31:0 | apb_pwdata     | R/W  | USB3. OPHY 的 apb 配置接口的写数据                  |  |

#### 5.53 USB3 PHY 配置寄存器 1

地址偏移: 0808h

默认值: 0000\_0000\_0000\_0000h

表 5- 53 USB3 PHY 配置寄存器 1

| 位域   | 名称                | 访问  | 描述                                                                                                                          |
|------|-------------------|-----|-----------------------------------------------------------------------------------------------------------------------------|
| 63:0 | micro_fuse_settin | R/W | USB3. 0PHY 的配置接口的第[63:0]位 [17] 写使能,为高时可写入 [16:8] PHY 配置地址,bit16 为 1 时,路由到 pipe_wrapper; bit16 为 0 时,路由到 miphy [7:0] PHY 配置值 |

#### 5.54 USB3 PHY 配置寄存器 2

地址偏移: 0810h

默认值: 0000\_0000\_0000\_0000h

表 5- 54 USB3 PHY 配置寄存器 2

| 位域   | 名称                | 访问  | 描述                          |  |
|------|-------------------|-----|-----------------------------|--|
| 63:0 | micro_fuse_settin | R/W | USB3. 0PHY 的配置接口的第[127:64]位 |  |

## 5.55 USB3 PHY 配置寄存器 3

地址偏移: 0818h

默认值: c800\_0081\_0f00\_0000h

表 5- 55 USB3 PHY 配置寄存器 3

| 位域 | 名称             | 访问  | 描述                         |
|----|----------------|-----|----------------------------|
| 31 | refclk_25m_sel | R/W | usb2 和 gnet phy 25M 参考时钟选择 |



|      |                   |     | 0 万体分类时分 4 八阵                |  |  |
|------|-------------------|-----|------------------------------|--|--|
|      |                   |     | 0: 系统参考时钟 4 分频               |  |  |
|      |                   |     | 1: usb3 phy 输出的 25M 时钟       |  |  |
| 28   | ssc_en            | R/W | 使能 pll 的 ssc 模块              |  |  |
| 27   | miphycfg_lane3_en | R/W | lane3_en 端口 3 使能             |  |  |
| 26   | miphycfg_lane2_en | R/W | lane2_en 端口 2 使能             |  |  |
| 25   | miphycfg_lanel_en | R/W | lanel_en 端口 1 使能             |  |  |
| 24   | osc_ready         | RO  | osc 时钟稳定                     |  |  |
|      | micro_setting_sta | RO  | USB3. OPHY 的配置接口状态           |  |  |
|      |                   |     | [7] 写错误                      |  |  |
| 23:1 |                   |     | [6] 写忙                       |  |  |
| 6    | tus               |     | [5:2] -0000                  |  |  |
|      |                   |     | [1] 写停止                      |  |  |
|      |                   |     | [0] 写完成                      |  |  |
| 15.0 | micro_fuse_settin | D/W | UCD2 ADIIV 协配界校口协签[142.190]  |  |  |
| 15:0 | g                 | R/W | USB3. 0PHY 的配置接口的第[143:128]位 |  |  |

#### 5.56 USB3 PHY 配置寄存器 4

地址偏移: 0820h

默认值: 0000\_0000\_0000\_0000h

表 5- 56 USB3 PHY 配置寄存器 4

|  | 位域             | 名称        | 访问 | 描述                             |  |
|--|----------------|-----------|----|--------------------------------|--|
|  |                |           |    | USB3. 0PHY 的 apb 配置接口的读写访问完成指示 |  |
|  | 60 apb_done RO |           | RO | 1: 完成访问操作                      |  |
|  |                |           |    | 0: 未完成访问                       |  |
|  | 31:0           | apb_rdata | RO | USB3. OPHY 的 apb 配置接口的读数据      |  |

## 5.57 USB3 PHY 配置寄存器 5

地址偏移: 0828h

默认值: 0000\_0000\_0000\_0000h

表 5- 57 USB3 PHY 配置寄存器 5

| 位域   | 名称               | 访问 描述         |                                                                                                             |
|------|------------------|---------------|-------------------------------------------------------------------------------------------------------------|
| 31:0 | 名称 Tst_obser_bus | ·<br>访问<br>RO | 描述 Phy 调试总线从高位到低位的信号如下(全部是 1 位信号): p0_clk_tx p0_clk_rx p0_rx_bit_locked p0_rx_symbol_locked p0_syncchardet: |
|      |                  |               | p0_sigdet<br>p0_sigdet_raw                                                                                  |



p0\_txdetectrx\_out p1\_c1k\_tx  $p1_clk_rx$ p1\_rx\_bit\_locked  ${\tt pl\_rx\_symbol\_locked}$ pl\_syncchardet:  $pl\_sigdet$ pl\_sigdet\_raw pl\_txdetectrx\_out p2\_c1k\_tx p2\_c1k\_rx p2\_rx\_bit\_locked p2\_rx\_symbol\_locked p2\_syncchardet: p2\_sigdet p2\_sigdet\_raw p2\_txdetectrx\_out  $p3_c1k_tx$ p3\_c1k\_rx p3\_rx\_bit\_locked p3\_rx\_symbol\_locked p3\_syncchardet: p3\_sigdet p3\_sigdet\_raw p3\_txdetectrx\_out p0~p3 代表 4 个对应端口: tx 的 word 时钟  $clk_tx$ rx 的 word 时钟  $clk_rx$ 置位时 1:deserializer 被锁住 rx\_bit\_locked rx\_symbol\_locked 置位时 deserializer 被 symbol 锁 接受端检测到同步字 syncchardet rxbuffer 检测激活 sigdet rxbuffer 检测激活  ${\tt sigdet\_raw}$ 置位时 TXP/TXN 正常模式电压高于 2/3VDD txdetectrx\_out

#### 5.58 USB3.0 控制器配置寄存器

地址偏移: 0840h

默认值: 0000\_0000\_0100\_4400h

表 5- 58 USB3.0 控制器配置寄存器



| 位域        | 名称                             | 访问   | 描述                             |
|-----------|--------------------------------|------|--------------------------------|
| 53:4<br>9 | usb3_debug                     | RO   | usb3_debug 的[4:0]位,具体含义需查阅相关资料 |
| 48:4<br>5 | disU3rxdetect_ack              | RO   | disU3rxdetect 的确认信号,与端口数量对应    |
| 44        | host_system_err                | RO   | 系统报错,反映在 USBSTS. HSE 域         |
| 43:3<br>2 | host_current_belt              | RO   | 指示所有接收到的 BELT 的最小值             |
| 26        | disU3rxdetect                  | R/W  | 这个信号用来停止控制器发送命令,且释放 pipe 总线    |
| 25        | U3rxdetect                     | R/W  | 当信号被设置时,开始做 rx detect          |
|           |                                | R/W  | 指示端口是否有功耗切换                    |
| 24        | port_power_control_pres<br>ent |      | 1:有功耗切换                        |
|           |                                |      | 0:没有功耗切换                       |
| 00.0      | host_u3_port_disable           | R/W  | USB3.0 端口关闭                    |
| 23:2      |                                |      | 1:端口关闭                         |
| 0         |                                |      | 0:端口使能                         |
| 10 1      |                                | R/W  | USB2.0 端口关闭                    |
| 19:1      | host_u2_port_disable           |      | 1:端口关闭                         |
| 6         |                                |      | 0:端口使能                         |
| 15:1      | h                              | D /W | 法体的 JiCD2 O 的地口粉具              |
| 2         | host_num_u3_port               | R/W  | 使能的 USB3. 0 的端口数量              |
| 11:7      | host_num_u2_port               | R/W  | 使能的 USB2. 0 的端口数量              |
|           |                                |      | 指示设备是否永久在连接状态,对应接口数量的高4位是      |
| 7.0       | hub most most to the           | R/W  | USB3.0的端口,对应接口数量的低4位是USB2.0的端口 |
| 7:0       | hub_port_perm_attach           |      | 1:永久连接                         |
|           |                                |      | 0:非永久连接                        |

## 5.59 USB2.0 PHY 配置寄存器 0

地址偏移: 0868h

默认值: 0000\_0000\_0000\_0000h

表 5- 59 USB2. 0 PHY 配置寄存器 0

| 位域        | 名称              | 访问  | 描述                          |
|-----------|-----------------|-----|-----------------------------|
| 1:0       | mode_p0         | R/W | Code 校正模式选择                 |
| 6:2       | code_ext_p0     | R/W | 使用外部校正码,当 calib_bypass 置位时  |
| 7         | calib_bypass_p0 | R/W | 绕过校正码,保持偏压活动状态,高有效          |
| 8         | bgbypass_p0     | R/W | 绕过内部 Bandgap 输出而改用 BGEXT 引脚 |
| 9         | tck_cal_p0      | R/W | 配置为0                        |
| 10        | tq_cal_p0       | R/W | IDDQ 模式使能,高有效               |
| 12:1<br>1 | calib_tuning_p0 | R/W | 调整内部的 bandgap(具体功能见下图)      |



|           | 1               |     |                             |
|-----------|-----------------|-----|-----------------------------|
| 17:1<br>6 | mode_p1         | R/W | Code 校正模式选择                 |
| 22:1      | code_ext_p1     | R/W | 使用外部校正码,当 calib_bypass 置位时  |
| 23        | calib_bypass_pl | R/W | 绕过校正码,保持偏压活动状态,高有效          |
| 24        | bgbypass_p1     | R/W | 绕过内部 Bandgap 输出而改用 BGEXT 引脚 |
| 25        | tck_cal_p1      | R/W | 配置为0                        |
| 26        | tq_cal_pl       | R/W | IDDQ 模式使能,高有效               |
| 28:2      | calib_tuning_p1 | R/W | 调整内部的 bandgap               |
| 33:3      | mode_p2         | R/W | Code 校正模式选择                 |
| 38:3<br>4 | code_ext_p2     | R/W | 使用外部校正码,当 calib_bypass 置位时  |
| 39        | calib_bypass_p2 | R/W | 绕过校正码,保持偏压活动状态,高有效          |
| 40        | bgbypass_p2     | R/W | 绕过内部 Bandgap 输出而改用 BGEXT 引脚 |
| 41        | tck_cal_p2      | R/W | 配置为0                        |
| 42        | tq_cal_p2       | R/W | IDDQ 模式使能,高有效               |
| 44:4<br>3 | calib_tuning_p2 | R/W | 调整内部的 bandgap               |
| 49:4<br>8 | mode_p3         | R/W | Code 校正模式选择                 |
| 54:5<br>0 | code_ext_p3     | R/W | 使用外部校正码,当 calib_bypass 置位时  |
| 55        | calib_bypass_p3 | R/W | 绕过校正码,保持偏压活动状态,高有效          |
| 56        | bgbypass_p3     | R/W | 绕过内部 Bandgap 输出而改用 BGEXT 引脚 |
| 57        | tck_cal_p3      | R/W | 配置为0                        |
| 58        | tq_cal_p3       | R/W | IDDQ 模式使能,高有效               |
| 60:5<br>9 | calib_tuning_p3 | R/W | 调整内部的 bandgap               |

注: 以上后缀 p0~p3 代表四个 USB2. 0 PHY 的编号

#### 5.60 USB2.0 PHY 配置寄存器 1-9

以上表(0870h 偏移的寄存器)为基准,以下为功能重复定义的配置表,所以统一以变量形式自行对照相应的寄存器域,N 代表第 N 个端口,本芯片 USB2. 0 端口有 9 个(含 1 个 OTG),编号从 0 开始,所以 N 的取值从  $0^{\sim}8$ 。

地址偏移: 0870h + (N\*8) h

默认值: 0000\_0000\_0000\_0000h

表 5- 60 USB2. 0 PHY 配置寄存器 1-9



| 位域    | 名称               | 访问  | 描述                          |
|-------|------------------|-----|-----------------------------|
| 63:60 | usb2_debug_ob_N  | RO  | Debug 观测引脚引脚                |
| 48:44 | usb2_debug_sel_N | R/W | Debug 观测引脚选择                |
| 43    | Dppulldown_N     | R/W | Dp 下拉电阻使能,低有效               |
| 42    | Dmpulldown_N     | R/W | Dm 下拉电阻使能,低有效               |
|       |                  |     | 当 dp 或 dm 短接 5V 的 VBUS 时指示  |
| 41    | Det5v_N          | RO  | 1:短接                        |
|       |                  |     | 0:没短接                       |
|       | Dpdn_short_lfs_N | RO  | 当 dp 或 dm 互相短接,或者 5V 或者地时指示 |
| 40    |                  |     | 1:短接                        |
|       |                  |     | 0:没短接                       |
| 39    | Codeminus_N      | R/W | 减少内部阻抗校正码 00010             |
| 38    | Codeplus_N       | R/W | 增加内部阻抗校正码 00010             |
| 37:36 | Zhsdrv_N         | R/W |                             |
|       |                  | R/W | HS 驱动电流调整引脚                 |
| 25.20 | The M            |     | 0000-defaultVOH             |
| 35:32 | Ihstx_N          |     | 0001- defaultVOH+5mv        |
|       |                  |     | 0010- defaultVOH+2*5mv      |
| 31:0  | Afetrim_N        | R/W |                             |

## 5.61 USB2.0 配置寄存器

地址偏移: 08b8h

默认值: 0000\_0000\_0000\_1040h

表 5- 61 USB2.0 配置寄存器

| 位域    | 名称                          | 访问  | 描述                             |
|-------|-----------------------------|-----|--------------------------------|
|       |                             |     | USB2.0 PHY PLL 禁用              |
| 52:50 | u2_phy_pll_disable          | R/W | 1: 禁用                          |
|       |                             |     | 0: 使能                          |
| 49:41 | u2_port_tq                  | R/W | 测试用                            |
|       |                             |     | USB2.0端口复位(分别对应端口0~8)          |
| 40:32 | u2_port_reset               | R/W | 1: 复位                          |
|       |                             |     | 0: 解复位                         |
|       | port_power_control_pre sent |     | 指示端口是否有功耗切换                    |
| 12    |                             | R/W | 1:有功耗切换                        |
|       |                             |     | 0:没有功耗切换                       |
|       |                             |     | USB2. 0 端口关闭                   |
| 11:8  | host_u2_port_disable        | R/W | 1:端口关闭                         |
|       |                             |     | 0:端口使能                         |
| 7:4   | host_num_u2_port            | R/W | 使能的 USB2. 0 的端口数量              |
| 2.0   | hub_port_perm_attach        | R/W | 指示设备是否永久在连接状态,对应接口数量是 USB2.0 的 |
| 3:0   |                             |     | 端口                             |



|  | 1:永久连接  |
|--|---------|
|  | 0:非永久连接 |

# 5.62 USB3.0 电源控制寄存器

地址偏移: 08d8h

默认值: 0000\_0000\_0000\_0000h

表 5- 62 USB3.0 电源控制寄存器

| 位域    | 名称                  | 访问  | 描述               |
|-------|---------------------|-----|------------------|
| 63:13 | Reserved            | R/W | 保留               |
|       |                     |     | 禁用 usb 休眠唤醒功能    |
| 12    | pmu_disable         | R/W | 0: 使能            |
|       |                     |     | 1: 禁用            |
|       |                     |     | 电源状态请求           |
| 9:8   | power_state_request | R/W | 00: U0 或 L0 模式   |
|       |                     |     | 11: U3 或 L2 模式   |
| 7:6   | power_state_u2pmu   | RO  | USB2 端口功耗状态      |
| 5     | pme_gen_u2pmu       | RO  | USB2 产生唤醒事件      |
| 4     | connect_state_u2pmu | RO  | USB2 任一端口低功耗状态指示 |
| 3:2   | power_state_u3pmu   | RO  | USB3 端口功耗状态      |
| 1     | pme_gen_u3pmu       | RO  | USB3 产生唤醒事件      |
| 0     | connect_state_u3pmu | RO  | USB3 任一端口低功耗状态指示 |

## 5.63 USB2.0 电源控制寄存器

地址偏移: 08e0h

默认值: 0000\_0000\_0000\_000ch

表 5- 63 USB2.0 电源控制寄存器

| 位域    | 名称                  | 访问  | 描述               |
|-------|---------------------|-----|------------------|
| 63:13 | Reserved            | R/W | 保留               |
|       |                     |     | 禁用 usb 休眠唤醒功能    |
| 12    | pmu_disable         | R/W | 0: 使能            |
|       |                     |     | 1: 禁用            |
|       |                     |     | 电源状态请求           |
| 9:8   | power_state_request | R/W | 00: L0 模式        |
|       |                     |     | 11: L2 模式        |
| 7:6   | power_state_u2pmu   | RO  | USB2 端口功耗状态      |
| 5     | pme_gen_u2pmu       | RO  | USB2 产生唤醒事件      |
| 4     | connect_state_u2pmu | RO  | USB2 任一端口低功耗状态指示 |
| 3:0   | Reserved            | RO  | 保留               |



#### 5.64 GPU 窗口 0 基址寄存器

地址偏移: 0900h

默认值: 0000\_0000\_0000\_0000h

表 5-64 GPU 窗口 0 基址寄存器

| 位域    | 名称            | 访问  | 描述          |
|-------|---------------|-----|-------------|
| 63:48 | Reserved      | R/W | 保留          |
| 47:0  | gpu_win0_base | R/W | GPU 窗口 0 基址 |

## 5.65 GPU 窗口 0 大小寄存器

地址偏移: 0908h

默认值: 0000\_0000\_0000\_0000h

表 5-65 GPU 窗口 0 大小寄存器

| 位域                 | 名称            | 访问                                    | 描述  |
|--------------------|---------------|---------------------------------------|-----|
| 63:48              | Reserved      | R/W                                   | 保留  |
| 47:0 gpu_winO_mask | D/W           | GPU 窗口 0 大小。将高位设置为 0, 低位连续 1 的个数代表有效地 |     |
|                    | gpu_wino_mask | R/W                                   | 址宽度 |

## 5.66 GPU 窗口 0 重映射寄存器

地址偏移: 0910h

默认值: 0000\_0000\_0000\_0000h

表 5-66 GPU 窗口 0 重映射寄存器

| 位域    | 名称              | 访问  | 描述             |
|-------|-----------------|-----|----------------|
| 63:48 | Reserved        | R/W | 保留             |
| 47:1  | gpu_win0_mmap   | R/W | GPU 窗口 0 重映射设置 |
| 0     | gpu_win0_enable | R/W | 窗口使能控制,高有效     |

#### 5.67 GPU 窗口 1 基址寄存器

地址偏移: 0920h

默认值: 0000\_0000\_0000\_0000h

表 5-67 GPU 窗口 1 基址寄存器

| 位域    | 名称            | 访问  | 描述          |
|-------|---------------|-----|-------------|
| 63:48 | Reserved      | R/W | 保留          |
| 47:0  | gpu_win1_base | R/W | GPU 窗口 1 基址 |



# 5.68 GPU 窗口 1 大小寄存器

地址偏移: 0928h

默认值: 0000\_0000\_0000\_0000h

表 5- 68 GPU 窗口 1 大小寄存器

| 位域    | 名称           | 访问  | 描述                                   |
|-------|--------------|-----|--------------------------------------|
| 63:48 | Reserved     | R/W | 保留                                   |
| 47:0  | any win1 mol | R/W | GPU 窗口 1 大小。将高位设置为 0,低位连续 1 的个数代表有效地 |
| 47.0  | gpu_winl_mak | K/W | 址宽度                                  |

# 5.69 GPU 窗口 1 重映射寄存器

地址偏移: 0930h

默认值: 0000\_0000\_0000\_0000h

表 5- 69 GPU 窗口 1 重映射寄存器

| 位域    | 名称              | 访问  | 描述             |
|-------|-----------------|-----|----------------|
| 63:48 | Reserved        | R/W | 保留             |
| 47:1  | gpu_win1_mmap   | R/W | GPU 窗口 1 重映射设置 |
| 0     | gpu_winl_enable | R/W | 窗口使能控制,高有效     |



# 6 地址空间分配

龙芯 2K2000 内部地址位宽为 40 位,路由主要通过系统的两级交叉开关以及 I0 子网络组成。交叉开关可以对每个 Master 端口接收到的请求进行路由配置; I0 子网络采用 PCI 总线的拓扑结构,通过对软件扫描设备并配置寄存器基地址的方式来访问,因此每个设备都有一个标准的 PCI 配置头。

龙芯 2K2000 的地址空间与 PCI 定义的地址空间形式相同,主要分为三类:

- 1. 配置空间: 该地址空间用于访问各个 IO 设备的 PCI 配置头, 其地址组成符合 PCI 配置访问的地址组织形式;
- 2. I0 空间:该地址空间用于访问 PCI 协议定义的 I0 地址空间。在 2K2000 中只有 PCIe 有这段地址空间,用于通过 I0 类型的请求访问 PCIe 控制器的下游设备。
- 3. MEM 空间:除了以上两种地址空间之外的所有地址空间为 MEM 空间。

全芯片的地址空间划分如下表所示:

表 6-1 芯片地址空间划分

| NAME             | BASE              | MASK                     | SIZE | 备注                             |
|------------------|-------------------|--------------------------|------|--------------------------------|
| Memory           | 64' h0000_0000    | 64' hFFFF_FFFF_F000_0000 | 256M | 内存空间                           |
| Memory mapped IO | 64' h1000_0000    | 64' hFFFF_FFFF_F800_0000 | 128M | 用于映射内部所使用<br>的设备空间(BAR)        |
| PCIe IO          | 64' h1800_0000    | 64' hFFFF_FFFF_FE00_0000 | 32M  | 用于映射 PCIe 控制<br>器对外的 IO 空间     |
| Type0            | 64' h1A00_0000    | 64' hFFFF_FFFF_FF00_0000 | 16M  | Type0 配置空间                     |
| Type1            | 64' h1B00_0000    | 64' hFFFF_FFFF_FF00_0000 | 16M  | Type1 配置空间                     |
| BOOT             | 64' h1C00_0000    | 64' hFFFF_FFFF_FFC0_0000 | 16M  | 启动空间,可映射至<br>SPI和LIO上          |
| LIO Memory       | 64' h1D00_0000    | 64' hFFFF_FFFF_FF00_0000 | 16M  |                                |
| Flash            | 64' h1FC0_0000    | 64' hFFFF_FFFF_FFF0_0000 | 1M   | 可映射至 SPI、<br>NAND、SDIO 和 LIO 上 |
| CONFIG           | 64' h1FE0_0000    | 64' hFFFF_FFFF_FFF0_0000 | 1M   | 芯片配置寄存器空间                      |
| SPI              | 64' h1FFF_0000    | 64' hFFFF_FFFF_FFFF_0000 | 64K  | SPI 配置空间                       |
| Memory mapped IO | 64' h4000_0000    | 64' hFFFF_FFFF_C000_0000 | 1G   | PCIe MEM 空间                    |
| Memory           | 64' h8000_0000    | 64' hFFFF_FFFF_8000_0000 | 2G   | 内存空间                           |
| Memory           | 64' h1_0000_0000  | 64' hFFFF_FFFF_0000_0000 | 4G   | 内存空间                           |
| Memory           | 64' h2_0000_0000  | 64' hFFFF_FFFE_0000_0000 | 8G   | 内存空间                           |
| Memory mapped IO | 64' h40_0000_0000 | 64' hFFFF_FFC0_0000_0000 | 256G | PCIe MEM 空间                    |
| Type0            | 64' hFE_0000_0000 | 64' hFFFF_FFFF_FF00_0000 | 256M | Type0 配置空间                     |
| Type1            | 64' hFE_1000_0000 | 64' hFFFF_FFFF_FF00_0000 | 256M | Typel 配置空间                     |
| Type0            | 64' hFE_2000_0000 | 64' hFFFF_FFFF_FF00_0000 | 256M | Type0 配置空间                     |
| Type1            | 64' hFE_3000_0000 | 64' hFFFF_FFFF_FF00_0000 | 256M | Typel 配置空间                     |



## 6.1 一级交叉开关

- 一级交叉开关一共有3个主端口,分别连接COREO、CORE1和IO桥。
- 一级开关的路由可以软件配置,也可以采用硬件路由,默认的地址空间分配如下表所 示。其中包含了32位和64位地址空间访问模式。

| 地址空间                            | 大小   | 设备/路由目的空间                   | 备注                                               |
|---------------------------------|------|-----------------------------|--------------------------------------------------|
| 0x1000_0000 - 0x17FF_FFFF       | 128M | I/0 设备的配置寄存器空间              | 需注意该段地址空间为 MEM<br>类型。各个 IO 设备的 BAR 地<br>址在该地址空间。 |
| 0x1800_0000 - 0x19FF_FFFF       | 32M  | PCIe 的 I/O 空间               | 32 位模式                                           |
| 0x1A00_0000 - 0x1BFF_FFFF       | 32M  | 各个 I/O 设备的配置头空间             | 32 位模式                                           |
| 0x1C00_0000 - 0x1CFF_FFFF       | 16M  | 启动空间                        | ВООТ                                             |
| 0x1FC0_0000 - 0x1FCF_FFFF       | 1M   | 启动空间                        | BOOT                                             |
| 0x1FE0_0000 - 0x1FE0_FFFF       | 64K  | Confbus                     | 芯片配置空间                                           |
| 0x4000_0000 - 0x7FFF_FFFF       | 1G   | 32 位访问模式下 I/0 设备的<br>MEM 空间 | 32 位模式                                           |
| 0xFE_0000_0000 - 0xFE_FFFF_FFFF | 4G   | 各个 I/0 设备的配置头空间             | 64 位模式                                           |
| 0xFD_FC00_0000 - 0xFD_FFFF_FFFF | 64M  | PCIe 的 I/0 空间               | 64 位模式                                           |
| 0xF0_0000_0000 - 0xFF_FFFF_FFFF | 64G  | I/0 设备的配置空间                 | 64 位模式                                           |
| 其他地址或上述空间若为 CACHED              |      | Bit6为0,路由到scache0;          | 由地址的第6位决定路由目                                     |

表 6-2 一级交叉开关路由规则

# 6.2 二级交叉开关

龙芯 2K2000 的二级交叉开关连接两个二级 Cache、内存控制器、启动模块 (SPI 或者 LIO)、confbus 模块、UART 和 I2C。

Bit6为1,路由到 scachel

地址窗口是供SCACHEO、SCACHE1两个具有主功能的IP进行路由选择和地址转换而设置 的,路由可以软件配置,也可以采用硬件路由,默认的地址空间分配如下表所示。

| 地址空间                      | 大小  | 设备/路由目的空间 | 备注     |
|---------------------------|-----|-----------|--------|
| 0x1C00_0000 - 0x1CFF_FFFF | 16M | 启动空间      | воот   |
| 0x1FC0_0000 - 0x1FCF_FFFF | 1M  | 启动空间      | BOOT   |
| 0x1FE0_01F0 - 0x1FE0_01FF | 16B | SPI 配置空间  |        |
| 0x1D00_0000 - 0x1DFF_FFFF | 16M | LIO 空间    |        |
| 0x1FE0_0000 - 0x1FE0_FFFF | 64K | Confbus   | 芯片配置空间 |

表 6-3 二级交叉开关路由规则



| 0x3FF0_0000 - 0x3FF0_FFFF | 64K  | Confbus | 芯片配置空间 |
|---------------------------|------|---------|--------|
| 0x1FE0_01E0 - 0x1FE0_01EF | 16B  | APB     |        |
| 0x1FE0_0100 - 0x1FE0_017F | 128B | APB     |        |

## 6.3 交叉开关软件路由配置

龙芯 2K2000 交叉开关的路由可以通过软件实现。软件可以对每个 Master 端口接收到的请求进行路由配置,每个 Master 端口都拥有 8 个地址窗口,可以完成 8 个地址窗口的目标路由选择。每个地址窗口由 BASE、MASK 和 MMAP 三个 64 位寄存器组成,BASE 以 K 字节对齐; MASK 采用类似网络掩码高位为 1 的格式; MMAP 的低四位表示对应目标 Slave 端口的编号,MMAP[4]表示允许取指,MMAP[5]表示允许块读,MMAP[6]表示允许交错访问使能,MMAP[7]表示窗口使能。

表 6-4 MMAP 字段对应的该空间访问属性

| [7]  | [6]                 | [5]  | [4]  |
|------|---------------------|------|------|
| 窗口使能 | 允许对 SCACHE/内存进行交错访问 | 允许块读 | 允许取指 |

窗口命中公式: (IN\_ADDR & MASK) == BASE

由于龙芯 2K2000 缺省采用固定路由,在上电启动时,配置窗口都处于关闭状态,使用时需要系统软件对其进行使能配置。

地址窗口转换寄存器如下表所示。

表 6-5 地址窗口寄存器表

| 地址          | 寄存器             | 地址          | 寄存器             |
|-------------|-----------------|-------------|-----------------|
| 0x3ff0_2000 | COREO_WINO_BASE | 0x3ff0_2100 | CORE1_WINO_BASE |
| 0x3ff0_2008 | COREO_WIN1_BASE | 0x3ff0_2108 | CORE1_WIN1_BASE |
| 0x3ff0_2010 | COREO_WIN2_BASE | 0x3ff0_2110 | CORE1_WIN2_BASE |
| 0x3ff0_2018 | COREO_WIN3_BASE | 0x3ff0_2118 | CORE1_WIN3_BASE |
| 0x3ff0_2020 | COREO_WIN4_BASE | 0x3ff0_2120 | CORE1_WIN4_BASE |
| 0x3ff0_2028 | COREO_WIN5_BASE | 0x3ff0_2128 | CORE1_WIN5_BASE |
| 0x3ff0_2030 | COREO_WIN6_BASE | 0x3ff0_2130 | CORE1_WIN6_BASE |
| 0x3ff0_2038 | COREO_WIN7_BASE | 0x3ff0_2138 | CORE1_WIN7_BASE |
| 0x3ff0_2040 | COREO_WINO_MASK | 0x3ff0_2140 | CORE1_WINO_MASK |
| 0x3ff0_2048 | COREO_WIN1_MASK | 0x3ff0_2148 | CORE1_WIN1_MASK |
| 0x3ff0_2050 | COREO_WIN2_MASK | 0x3ff0_2150 | CORE1_WIN2_MASK |
| 0x3ff0_2058 | COREO_WIN3_MASK | 0x3ff0_2158 | CORE1_WIN3_MASK |
| 0x3ff0_2060 | COREO_WIN4_MASK | 0x3ff0_2160 | CORE1_WIN4_MASK |
| 0x3ff0_2068 | COREO_WIN5_MASK | 0x3ff0_2168 | CORE1_WIN5_MASK |
| 0x3ff0_2070 | COREO_WIN6_MASK | 0x3ff0_2170 | CORE1_WIN6_MASK |
| 0x3ff0_2078 | COREO_WIN7_MASK | 0x3ff0_2178 | CORE1_WIN7_MASK |



| 0x3ff0_2080 | COREO_WINO_MMAP   | 0x3ff0_2180 | CORE1_WINO_MMAP   |
|-------------|-------------------|-------------|-------------------|
| 0x3ff0_2088 | COREO_WIN1_MMAP   | 0x3ff0_2188 | CORE1_WIN1_MMAP   |
| 0x3ff0_2090 | COREO_WIN2_MMAP   | 0x3ff0_2190 | CORE1_WIN2_MMAP   |
| 0x3ff0_2098 | COREO_WIN3_MMAP   | 0x3ff0_2198 | CORE1_WIN3_MMAP   |
| 0x3ff0_20a0 | COREO_WIN4_MMAP   | 0x3ff0_21a0 | CORE1_WIN4_MMAP   |
| 0x3ff0_20a8 | COREO_WIN5_MMAP   | 0x3ff0_21a8 | CORE1_WIN5_MMAP   |
| 0x3ff0_20b0 | COREO_WIN6_MMAP   | 0x3ff0_21b0 | CORE1_WIN6_MMAP   |
| 0x3ff0_20b8 | COREO_WIN7_MMAP   | 0x3ff0_21b8 | CORE1_WIN7_MMAP   |
|             |                   |             |                   |
| 0x3ff0_2200 | IO_L1X_WINO_BASE  |             |                   |
| 0x3ff0_2208 | IO_L1X_WIN1_BASE  |             |                   |
| 0x3ff0_2210 | IO_L1X_WIN2_BASE  |             |                   |
| 0x3ff0_2218 | IO_L1X_WIN3_BASE  |             |                   |
| 0x3ff0_2220 | IO_L1X_WIN4_BASE  |             |                   |
| 0x3ff0_2228 | IO_L1X_WIN5_BASE  |             |                   |
| 0x3ff0_2230 | IO_L1X_WIN6_BASE  |             |                   |
| 0x3ff0_2238 | IO_L1X_WIN7_BASE  |             |                   |
| 0x3ff0_2240 | IO_L1X_WINO_MASK  |             |                   |
| 0x3ff0_2248 | IO_L1X_WIN1_MASK  |             |                   |
| 0x3ff0_2250 | IO_L1X_WIN2_MASK  |             |                   |
| 0x3ff0_2258 | IO_L1X_WIN3_MASK  |             |                   |
| 0x3ff0_2260 | IO_L1X_WIN4_MASK  |             |                   |
| 0x3ff0_2268 | IO_L1X_WIN5_MASK  |             |                   |
| 0x3ff0_2270 | IO_L1X_WIN6_MASK  |             |                   |
| 0x3ff0_2278 | IO_L1X_WIN7_MASK  |             |                   |
| 0x3ff0_2280 | IO_L1X_WINO_MMAP  |             |                   |
| 0x3ff0_2288 | IO_L1X_WIN1_MMAP  |             |                   |
| 0x3ff0_2290 | IO_L1X_WIN2_MMAP  |             |                   |
| 0x3ff0_2298 | IO_L1X_WIN3_MMAP  |             |                   |
| 0x3ff0_22a0 | IO_L1X_WIN4_MMAP  |             |                   |
| 0x3ff0_22a8 | IO_L1X_WIN5_MMAP  |             |                   |
| 0x3ff0_22b0 | IO_L1X_WIN6_MMAP  |             |                   |
| 0x3ff0_22b8 | IO_L1X_WIN7_MMAP  |             |                   |
|             |                   |             |                   |
| 0x3ff0_2400 | SCACHEO_WINO_BASE | 0x3ff0_2500 | SCACHE1_WINO_BASE |
| 0x3ff0_2408 | SCACHEO_WIN1_BASE | 0x3ff0_2508 | SCACHE1_WIN1_BASE |
| 0x3ff0_2410 | SCACHEO_WIN2_BASE | 0x3ff0_2510 | SCACHE1_WIN2_BASE |
| 0x3ff0_2418 | SCACHEO_WIN3_BASE | 0x3ff0_2518 | SCACHE1_WIN3_BASE |
| 0x3ff0_2420 | SCACHEO_WIN4_BASE | 0x3ff0_2520 | SCACHE1_WIN4_BASE |
| 0x3ff0_2428 | SCACHEO_WIN5_BASE | 0x3ff0_2528 | SCACHE1_WIN5_BASE |
| 0x3ff0_2430 | SCACHEO_WIN6_BASE | 0x3ff0_2530 | SCACHE1_WIN6_BASE |
| 0x3ff0_2438 | SCACHEO_WIN7_BASE | 0x3ff0_2538 | SCACHE1_WIN7_BASE |



| 0-2550 2440 | CCACUEO WINO MACV | 0-2550 2540 | CCACUE1 WINO MACK |
|-------------|-------------------|-------------|-------------------|
| 0x3ff0_2440 | SCACHEO_WINO_MASK | 0x3ff0_2540 | SCACHEL WIND MASK |
| 0x3ff0_2448 | SCACHEO_WIN1_MASK | 0x3ff0_2548 | SCACHEL WINL MASK |
| 0x3ff0_2450 | SCACHEO_WIN2_MASK | 0x3ff0_2550 | SCACHEL WIN2 MASK |
| 0x3ff0_2458 | SCACHEO_WIN3_MASK | 0x3ff0_2558 | SCACHE1_WIN3_MASK |
| 0x3ff0_2460 | SCACHEO_WIN4_MASK | 0x3ff0_2560 | SCACHE1_WIN4_MASK |
| 0x3ff0_2468 | SCACHEO_WIN5_MASK | 0x3ff0_2568 | SCACHE1_WIN5_MASK |
| 0x3ff0_2470 | SCACHEO_WIN6_MASK | 0x3ff0_2570 | SCACHE1_WIN6_MASK |
| 0x3ff0_2478 | SCACHEO_WIN7_MASK | 0x3ff0_2578 | SCACHE1_WIN7_MASK |
| 0x3ff0_2480 | SCACHEO_WINO_MMAP | 0x3ff0_2580 | SCACHE1_WINO_MMAP |
| 0x3ff0_2488 | SCACHEO_WIN1_MMAP | 0x3ff0_2588 | SCACHE1_WIN1_MMAP |
| 0x3ff0_2490 | SCACHEO_WIN2_MMAP | 0x3ff0_2590 | SCACHE1_WIN2_MMAP |
| 0x3ff0_2498 | SCACHEO_WIN3_MMAP | 0x3ff0_2598 | SCACHE1_WIN3_MMAP |
| 0x3ff0_24a0 | SCACHEO_WIN4_MMAP | 0x3ff0_25a0 | SCACHE1_WIN4_MMAP |
| 0x3ff0_24a8 | SCACHEO_WIN5_MMAP | 0x3ff0_25a8 | SCACHE1_WIN5_MMAP |
| 0x3ff0_24b0 | SCACHEO_WIN6_MMAP | 0x3ff0_25b0 | SCACHE1_WIN6_MMAP |
| 0x3ff0_24b8 | SCACHEO_WIN7_MMAP | 0x3ff0_25b8 | SCACHE1_WIN7_MMAP |
|             | 1                 |             |                   |
| _           | -                 | 0x3ff0_2600 | IO_L2X_WINO_BASE  |
| _           | -                 | 0x3ff0_2608 | IO_L2X_WIN1_BASE  |
| _           | _                 | 0x3ff0_2610 | IO_L2X_WIN2_BASE  |
| _           | _                 | 0x3ff0_2618 | IO_L2X_WIN3_BASE  |
| _           | -                 | 0x3ff0_2620 | IO_L2X_WIN4_BASE  |
| _           | -                 | 0x3ff0_2628 | IO_L2X_WIN5_BASE  |
| _           | _                 | 0x3ff0_2630 | IO_L2X_WIN6_BASE  |
| _           | _                 | 0x3ff0_2638 | IO_L2X_WIN7_BASE  |
| _           | -                 | 0x3ff0_2640 | IO_L2X_WINO_MASK  |
| _           | -                 | 0x3ff0_2648 | IO_L2X_WIN1_MASK  |
| -           | -                 | 0x3ff0_2650 | IO_L2X_WIN2_MASK  |
| _           | -                 | 0x3ff0_2658 | IO_L2X_WIN3_MASK  |
| -           | -                 | 0x3ff0_2660 | IO_L2X_WIN4_MASK  |
| _           | _                 | 0x3ff0_2668 | IO_L2X_WIN5_MASK  |
| _           | -                 | 0x3ff0_2670 | IO_L2X_WIN6_MASK  |
| _           | -                 | 0x3ff0_2678 | IO_L2X_WIN7_MASK  |
| _           | -                 | 0x3ff0_2680 | IO_L2X_WINO_MMAP  |
| _           | -                 | 0x3ff0_2688 | IO_L2X_WIN1_MMAP  |
| -           | _                 | 0x3ff0_2690 | IO_L2X_WIN2_MMAP  |
| _           | -                 | 0x3ff0_2698 | IO_L2X_WIN3_MMAP  |
| _           | -                 | 0x3ff0_26a0 | IO_L2X_WIN4_MMAP  |
| _           | _                 | 0x3ff0_26a8 | IO_L2X_WIN5_MMAP  |
| _           | _                 | 0x3ff0_26b0 | IO_L2X_WIN6_MMAP  |
|             |                   |             |                   |

一级 xbar 连接 2 个 Scache 和 IO 桥作为从设备,由 2 个 core 和 IO 桥作为主设备进行



窗口映射。二级 xbar 主要连接内存控制器和 MISC 作为从设备,由 2 个 Scache 和 uncache dma 通路作为主设备进行窗口映射。

每个地址窗口由 BASE、MASK 和 MMAP 三个 64 位寄存器组成,BASE 以 K 字节对齐,MASK 采用类似网络掩码高位为 1 的格式,MMAP 中包含转换后地址、路由选择及使能控制等位,如下表所示:

表 6-6 MMAP 寄存器位域说明

| [63:40] | [39:10] | [7:4] | [3:0] |
|---------|---------|-------|-------|
| 保留      | 转换后地址   | 窗口使能  | 从设备号  |

其中,一级 xbar 从设备号对应的设备如下表所示:

表 6-7 一级 xbar 从设备号与所述模块的对应关系

| 从设备号 | 目的设备    |
|------|---------|
| 0    | Scache0 |
| 1    | Scache1 |
| 2    | 10 桥    |

二级 xbar 从设备号对应的设备如下表所示:

表 6-8 二级 xbar 从设备号与所述模块的对应关系

| 从设备号 | 目的设备   |
|------|--------|
| 0    | MC     |
| 4    | SPI    |
| 5    | LIO    |
| 6    | APB    |
| 7    | CONFIG |

需要注意的是,窗口配置不能对 Cache 一致性的请求进行地址转换,否则在 SCache 处的地址会与处理器一级 Cache 处的地址不一致,导致 Cache 一致性的维护错误。

窗口命中公式: (IN\_ADDR & MASK) == BASE

新地址换算公式: OUT\_ADDR = (IN\_ADDR & ~MASK) | {MMAP[63:10], 10', ho} 根据缺省的寄存器配置,芯片启动后,CPU的 0x000000000 - 0x0ffffffff 的地址区间 (256M) 映射到 DDR 的 0x000000000 - 0x0ffffffff 的地址区间,0x10000000-0x17fffffff 映射到芯片的 PCI\_MEM 空间,0x18000000-0x19fffffff 映射到芯片的 PCI\_IO 空间,0x1a000000-0x1afffffff 映射到芯片的 PCI 配置空间(Type0),0x1b000000-0x1bffffff 映射到芯片的 PCI 配置空间(Type1),0x40000000-0x7fffffff 映射到芯片的 PCI\_MEM 空间。软件可以通过修改相应的配置寄存器实现新的地址空间路由和转换。

此外,当出现8个地址窗口都不命中时,由内存控制器模块返回数据。



### 6.4 IO 互连网络

2K2000 中的 IO 互连网络采用南北桥结构。为了便于说明,这里把 IO 设备分成 PCIe 设备(包括 PCIe0 与 PCIe1) 和其他 IO 设备(除 PCIe 之外的所有其他设备)两部分。

10 互连网络主要由以下两部分通路组成:

- 1. CPU 访问 IO 设备的通路, 其地址路由形式主要包括:
  - ●配置访问: CPU 通过配置请求访问 IO 设备的配置头;
  - ●IO 访问: IO 访问用于访问 PCIe 控制器下游设备的 IO 地址空间,根据 PCIe 配置头的 IO Base 和 IO Limit 配置决定地址路由方式;
  - ●内部寄存器访问: 通过各个 IO 设备配置头的 BAR 地址访问 IO 设备的内部配置寄存器,MEM 访问类型。
  - ●PCIe 下游设备 MEM 访问: 根据 PCIe 配置头的 Memory Base 和 Memory Limit、Prefetchable Memory Base 和 Prefetchable Memory Limit 进行地址路由,用于访问 PCIe 下游设备的 MEM 空间。
- 2. IO DMA 访问内存的通路,包括 CACHE 和 UNCACHE 访问类型。

#### 6.4.1 PCI 设备的配置空间

这里需要先区分配置头空间和设备寄存器空间两个概念。配置头空间指的是每个 I0 设备的配置头所在的地址空间,而设备寄存器空间指的是配置头中的 BAR 所指定的设备配置寄存器的地址空间。访问 I/0 设备的设备寄存器空间需要先读取其配置头空间中的 BAR 地址作为其配置空间的起始地址,然后再对相应设备寄存器进行读写。

首先介绍 64 位模式下访问配置头空间的地址格式,龙芯 2K2000 中定义地址段 0xFE\_0000\_0000 - 0xFE\_1FFF\_FFFF 是 CPU 的 64 位配置地址空间,CPU 通过这段地址访问各个设备的 PCI 配置头。由地址的[63:28]决定配置头类型(0xFE0 是 Type0,0xFE1 是 Type1,其他保留);[23:16]在 Type1 类型配置头访问时表示总线号(Bus Number),Type0 时保留;[15:11]表示设备号(Device Number);[10:8]表示功能号(Function Number);[27:24]和[7:0]组合起来表示偏移(offset),大小为 4K。下图是 CPU 访问 PCI 配置头空间的 64 位地址格式。



图 6-1 64 位配置访问地址格式

为了保证系统的兼容性,还提供了32位地址模式下的配置地址格式,如下图所示。该模式下,地址偏移只有8位(即256B)。其中,地址的[31:24]决定配置头类型(0x1A 是



Type0, 0x1B是 Type1); [23:16]在 Type1 类型配置头访问时表示总线号(Bus Number), Type0 时保留; [15:11]表示设备号(Device Number); [10:8]表示功能号(Function Number); [7:0]表示偏移(offset), 大小为 256B。



图 6-2 32 位配置访问地址格式

#### 6.4.2 PCI 设备和功能

CONFBUS

21, 0

龙芯 2K2000 芯片中,具备配置头空间的设备包括: APB 总线控制器、GMACO/1 控制器、USB 控制器、SATA 控制器、PCIeO/1 控制器和 DMA 控制器。其中所有 APB 设备都作为一个整体挂在 APB 总线控制器上,由地址的[15:12]位进行译码,下文中将会做详细说明。各个设备的设备号、功能号以及配置头访问首地址如下表所示(该表只包括各个控制器本身的配置空间,不关注 PCIe 控制器的 Type1 访问等)。除了 PCIe 控制器之外,其他设备的配置头空间大小都只有 256B。

| Device          | Device<br>Number,<br>Function<br>Number | Vendor ID | Device ID                  | Size                           |
|-----------------|-----------------------------------------|-----------|----------------------------|--------------------------------|
| APB             | 2, 0                                    | 0x0014    | 0x7A22                     | 512K                           |
| GMACO           | 3, 0                                    | 0x0014    | 0x7A13                     | 32K                            |
| GMAC1           | 3, 1                                    | 0x0014    | 0x7A13                     | 32K                            |
| GMAC2           | 3, 2                                    | 0x0014    | 0x7A03                     | 32K                            |
| USB2-XHCI       | 4,0                                     | 0x0014    | 0x7A44                     | 1M                             |
| USB2-OTG        | 5, 0                                    | 0X0014    | 0x7A54                     | 256K                           |
| DC-GPU          | 6, 0                                    | 0x0014    | 0x7A25                     | 256 (REG)<br>256M (GMEM)       |
| DC-DC           | 6, 1                                    | 0x0014    | 0x7A36                     | 64K                            |
| DC-HDA          | 6, 2                                    | 0x0014    | 0x7A37                     | 64K                            |
| DC-VPU          | 6, 3                                    | 0x0014    | 0x7A16                     | 512                            |
| HDA             | 7, 0                                    | 0x0014    | 0x7A07                     | 64K                            |
| I2S             | 7, 1(二选一)                               | 0x0014    | 0x7A27                     | 64K                            |
| SATA            | 8, 0                                    | 0x0014    | 0x7A18                     | 1K                             |
| PCIeO-PortO     | 9, 0                                    | 0x0014    | 0x7A49                     | 8K                             |
| PCIeO-Port1     | 10, 0                                   | 0x0014    | 0x7A39                     | 8K                             |
| PCIeO-Port2     | 11, 0                                   | 0x0014    | 0x7A39                     | 8K                             |
| PCIeO-Port3     | 12, 0                                   | 0x0014    | 0x7A39                     | 8K                             |
| PCIe1-Port0     | 13, 0                                   | 0x0014    | 0x7A49                     | 8K                             |
| PCIe1-Port1     | 14, 0                                   | 0x0014    | 0x7A39                     | 8K                             |
| PCIe2-Port0(RC) | 15, 0                                   | 0x0014    | 0x7A79(DMA<br>会带来设备<br>更新) | 8K                             |
| PCIe2-Port0(EP) | 15, 0                                   | 0x0014    | 0x7AF9                     | 4K(BARO), 8K(BAR1), 256M(BAR2) |

表 6-9 各个设备的配置头访问对应关系

0x7a1a

64K

0x0014



| SPI1      | 22, 0 | 0x0014 | 0x7a1b | 4K (REG)              |
|-----------|-------|--------|--------|-----------------------|
|           |       |        |        | 16M (MEM)<br>4K (REG) |
| LPC       | 23, 0 | 0x0014 | 0x7a0c | 32M (MEM)             |
|           |       |        |        | 128K(IO)              |
| RapidIOO  | 24, 0 | 0x0014 | 0x7a1d | 8K (REG)              |
| Kapiuioo  | 24, 0 | 0x0014 | Oxiala | 1G (MEM)              |
| USB3-XHCI | 25, 0 | 0x0014 | 0x7A34 | 1M                    |
| PanidIO1  | 27, 0 | 0x0014 | 0x7a1d | 8K (REG)              |
| RapidIO1  | 21, 0 | 0x0014 | Oxiala | 1G (MEM)              |
| eMMC      | 28, 0 | 0x0014 | 0x7A88 | 4K                    |
| SD        | 28, 1 | 0x0014 | 0x7A48 | 4K                    |
| AES       | 29, 0 | 0x0014 | 0x7A0e | 4K                    |
| DES       | 29, 1 | 0x0014 | 0x7A1e | 4K                    |
| RSA       | 29, 2 | 0x0014 | 0x7A2e | 4K                    |
| RNG       | 29, 3 | 0x0014 | 0x7A3e | 4K                    |
| DMA       | 30, 0 | 0x0014 | 0x7A2F | 4K                    |
| SE        | 31,0  | 0x0014 | 0x7A8e | 64K                   |

除 PCIe 外,所有的配置头空间都遵循 PCI Type0 类型的格式,如下表所示,但是每个设备的缺省值不尽相同,后文中将展开介绍。

表 6- 10 Type0 类型配置头

| 31                               | 24                  | 23        | 16  | 15                      | 8     | 7        | 0        | ADDR |
|----------------------------------|---------------------|-----------|-----|-------------------------|-------|----------|----------|------|
| Device II                        | Device ID Vendor ID |           |     |                         |       |          | 00h      |      |
| Status                           |                     |           |     | Command                 |       |          |          | 04h  |
| Class Cod                        | le                  |           |     |                         |       | Revison  | ID       | 08h  |
| BIST                             |                     | Header Ty | уре | Lantency                | Timer | Cache Li | ine Size | OCh  |
| Base Addr                        | ess 0               |           |     |                         |       |          |          | 10h  |
| Base Addr                        | Base Address 1      |           |     |                         |       |          | 14h      |      |
| Base Address 2                   |                     |           |     |                         |       | 18h      |          |      |
| Base Address 3                   |                     |           |     |                         |       |          | 1Ch      |      |
| Base Address 4                   |                     |           |     |                         |       | 20h      |          |      |
| Base Addr                        | Base Address 5      |           |     |                         |       |          |          | 24h  |
| CardBus CIS Pointer              |                     |           |     |                         |       |          | 28h      |      |
| Subsystem ID Subsystem Vendor ID |                     |           |     |                         |       | 2Ch      |          |      |
| Expension ROM Base Address       |                     |           |     |                         |       | 30h      |          |      |
| Reserved                         |                     |           |     | Capabilities<br>Pointer |       | ities    | 34h      |      |
| Reserved                         |                     |           |     |                         |       |          |          | 38h  |



|--|

### 表 6- 11 Type0 的配置头寄存器

| 寄存器名称                    | 偏移地址 | 读/写   | 功能描述                                                                                                                                                                                                               | 说明<br>(除 PCIe 控制器)       |
|--------------------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|
| Vendor ID<br>制造商 ID 号    | 0x0  | RO    | 制造商 ID 号                                                                                                                                                                                                           | 缺省值都为 0x0014             |
| Device ID<br>设备 ID 号     | 0x2  | RO    | 设备 ID 号                                                                                                                                                                                                            |                          |
| Command<br>命令寄存器         | 0x4  | RW    | Bit0: I/O 访问使能 Bit1: 存储器访问使能 Bit2: 主设备使能 Bit3: 专用周期监视 Bit4: 存储器写与使失效使能 Bit5: VGA 画板侦测 Bit6: 奇偶校验错响应 Bit7: 等待周期控制 Bit8: SERR#使能 Bit9: 快速背靠背使能 其它: 保留                                                                | 扫描配置地址后,需要使能相应设备的存储器访问使能 |
| Status<br>状态寄存器          | 0x6  | RO/RW | Bit3-0: RO, 保留 Bit4: RO, 能力列表 Bit5: RO, 66MHz 能力 Bit6: 保留 Bit7: RO, 快速背靠背能力 Bit8: RW, 主设备数据奇偶校验错 Bit10-9: RO, 设备选择定时 Bit11: RW, 发出目标失败信号 Bit12: RW, 收到目标失败 Bit13: RW, 收到主设备失败 Bit14: RW, 发出系统错信号 Bit15: RW, 检测到奇偶错 |                          |
| Revision ID<br>版本索引      | 0x8  | RO    | 设备版本号                                                                                                                                                                                                              | 缺省值都为 0x0                |
| Class Code<br>类代码        | 0x9  | RO    | Bit7-0: Prog. I/F 编程接口<br>Bit15-8: Subclass code,子<br>类码<br>Bit23-16: Class code 类别<br>码                                                                                                                           |                          |
| Cache Line Size<br>缓存行大小 | 0xC  | RO    | 龙芯 2K2000 的缓存行大小为<br>64Byte                                                                                                                                                                                        | 缺省值都为 0x10               |
| Latency Timer<br>等待计时器   | 0xD  | RW    |                                                                                                                                                                                                                    | 保留                       |
| Header Type<br>配置头类型     | 0xE  | RO    | 除 PCIe 控制器外,都是<br>Type0。<br>另外 bit7 表示多功能属性:<br>1-多功能设备<br>0-单功能设备                                                                                                                                                 |                          |



| BIST<br>内自建测试                            | 0xF  | RW    | Bit3-0: 完成代码,0-成功完成,非0-设备指定的错误<br>Bit5-4: 保留<br>Bit6: 起动 BIST<br>Bit7: BIST能力,1-提供<br>BIST功能,0-不提供 | 保留             |
|------------------------------------------|------|-------|----------------------------------------------------------------------------------------------------|----------------|
| Base Address Register 0<br>0 号基址寄存器      | 0x10 | RW/RO | 基地址寄存器 0-Bit0: RO, 1-I/0 基地址寄存器, 0-MEM 基地址寄存器:                                                     | 只支持 64 位模式     |
| Base Address Register 1<br>1 号基址寄存器      | 0x18 | RW    | 基址寄存器 1                                                                                            | 只支持 64 位模式     |
| Base Address Register 2<br>2号基址寄存器       | 0x20 | RW    | 基址寄存器 2                                                                                            | 只支持 64 位模式     |
| Cardbus CIS Pointer<br>CIS 卡总线指针         | 0x28 | RW    | CIS 卡总线指针                                                                                          | 保留             |
| Subsystem Vendor ID<br>子系统版本号            | 0x2C | RO    | 子系统供应商 ID 号                                                                                        | 保留             |
| Subsystem ID<br>子系统版本号                   | 0x2D | RO    | 子系统版本 ID 号                                                                                         | 保留             |
| Expansion ROM Base Address<br>扩展 ROM 基地址 | 0x30 | RW    | 扩展 ROM 基地址寄存器<br>Bit0: 地址译码使能<br>Bit10-1: 保留<br>Bit31-11: 用于指定 ROM 的起<br>始地址                       | 保留             |
| Capabilities Pointer<br>扩展能力指针           | 0x34 | RW    | 扩展指针                                                                                               | 保留             |
| Reserved                                 | 0x35 |       |                                                                                                    | 保留             |
| Reserved                                 | 0x38 |       |                                                                                                    | 保留             |
| Interrupt Line<br>中断线寄存器                 | 0x3C | RW    | 中断线寄存器                                                                                             |                |
| Interrupt Pin<br>中断引脚寄存器                 | 0x3D | RO    | 中断引脚寄存器                                                                                            | 保留(除 PCIe 控制器) |
| Min Gnt<br>最小突发期时间                       | 0x3E | RW    |                                                                                                    | 保留(除 PCIe 控制器) |
| Max Lat<br>获取 PCI 总线最大时间                 | 0x3F | RW    |                                                                                                    | 保留(除 PCIe 控制器) |

PCIe 控制器的配置头为 Type1 类型,具体如下:



### 表 6- 12 Type1 类型配置头

| 31                                      | 24                                      | 23        | 16  | 15                      | 8     | 7                   | 0        | ADDR |
|-----------------------------------------|-----------------------------------------|-----------|-----|-------------------------|-------|---------------------|----------|------|
| Device ID                               | Vendor II                               | Vendor ID |     |                         |       |                     |          |      |
| Status                                  |                                         |           |     | Command                 |       |                     |          | 04h  |
| Class Code                              |                                         |           |     |                         |       | Revison             | ID       | 08h  |
| BIST                                    |                                         | Header T  | уре | Lantency                | Timer | Cache Li            | ine Size | 0Ch  |
| Base Address 0                          |                                         |           |     |                         |       | 10h                 |          |      |
| Base Address 1                          |                                         |           |     |                         |       |                     |          | 14h  |
| Secondary Lant                          | dary Lantency Timer   Subordinate Bus # |           |     | Secondary               | Bus # | Primary             | Bus #    | 18h  |
| Secondary Status                        |                                         |           |     | IO Limit                |       | IO Base             |          | 1Ch  |
| (Non-Prefetcha                          | (Non-Prefetchable) Memory Base          |           |     |                         | 20h   |                     |          |      |
| PrefetchableMe                          | mory Limit                              |           |     | PrefetchableMemory Base |       |                     |          | 24h  |
| Prefetchable M<br>Upper 32 Bits         |                                         |           | 28h |                         |       |                     |          |      |
| Prefetchable Memory Limit Upper 32 Bits |                                         |           |     |                         |       |                     |          | 2Ch  |
| IO Limit<br>Upper 16 Bits               | IO Base<br>Upper 16 Bits                |           |     |                         | 30h   |                     |          |      |
| Reserved                                |                                         |           |     |                         |       | Capabili<br>Pointer | ities    | 34h  |
| Expansion ROM                           | Expansion ROM Base Address              |           |     |                         |       |                     |          | 38h  |
| Bridge Control                          |                                         |           |     | Interrupt               | Pin   | Interrup            | ot Line  | 3Ch  |

## 表 6- 13 Type1 的配置头寄存器

| 寄存器名称                 | 偏移地址 | 读/写 | 功能描述                                                                                                                                                | 说明<br>(PCIe 控制器)                 |
|-----------------------|------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|
| Vendor ID<br>制造商 ID 号 | 0x0  | RO  | 制造商 ID 号                                                                                                                                            | 缺省值都为 0x0014                     |
| Device ID<br>设备 ID 号  | 0x2  | RO  | 设备 ID 号                                                                                                                                             |                                  |
| Command<br>命令寄存器      | 0x4  | RW  | Bit0: I/O 访问使能 Bit1: 存储器访问使能 Bit2: 主设备使能 Bit3: 专用周期监视 Bit4: 存储器写与使失效使能 Bit5: VGA 画板侦测 Bit6: 奇偶校验错响应 Bit7: 等待周期控制 Bit8: SERR#使能 Bit9: 快速背靠背使能 其它: 保留 | 扫描配置地址后,需<br>要使能相应设备的存<br>储器访问使能 |



| Status<br>状态寄存器          | 0x6  | RO/RW | Bit3-0: RO, 保留 Bit4: RO, 能力列表 Bit5: RO, 66MHz 能力 Bit6: 保留 Bit7: RO, 快速背靠背能力 Bit8: RW, 主设备数据奇偶校验错 Bit10-9: RO, 设备选择定时 Bit11: RW, 发出目标失败信号 Bit12: RW, 收到目标失败 Bit13: RW, 收到主设备失败 Bit14: RW, 发出系统错信号 Bit15: RW, 检测到奇偶错 |               |
|--------------------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| Revision ID<br>版本索引      | 0x8  | RO    | 设备版本号                                                                                                                                                                                                              | 缺省值都为 0x0     |
| Class Code<br>类代码        | 0x9  | RO    | Bit7-0: Prog. I/F 编程接口<br>Bit15-8: Subclass code,子<br>类码<br>Bit23-16: Class code 类别<br>码                                                                                                                           | 缺省值为 0x0b3000 |
| Cache Line Size<br>缓存行大小 | 0xC  | RO    | 缓存行大小                                                                                                                                                                                                              | 缺省值都为 0x00    |
| Latency Timer<br>等待计时器   | 0xD  | RW    |                                                                                                                                                                                                                    | 保留            |
| Header Type<br>配置头类型     | 0xE  | RO    | PCIe 控制器都是 Type1                                                                                                                                                                                                   | 缺省值为 0x01     |
| BIST<br>内自建测试            | 0xF  | RW    | Bit3-0: 完成代码,0-成功完成,非0-设备指定的错误<br>Bit5-4: 保留<br>Bit6: 起动BIST<br>Bit7: BIST能力,1-提供<br>BIST功能,0-不提供                                                                                                                  | 保留            |
| Base Address Register O  | 0x10 | RW/RO | 基地址寄存器 0-Bit0: R0, 1-I/0 基地址寄存器, 0-MEM 基地址寄存器  I/0 基地址寄存器: Bit1: 保留 Bit31-2: R0, 基地址单元  Bit63-32: 保留  MEM 基地址存储器: Bit2-1: R0, MEM 基地址寄存器-译码器宽度单元, 00-32 位, 10-64 位 Bit3: R0, 预提取属性Bit64-4: 基地址单元                   | 64 位 MEM 空间   |
| Primary Bus #            | 0x18 | RW    | Primary Bus 编号                                                                                                                                                                                                     | 默认为0          |
| Secondary Bus #          | 0x19 | RW    | Secondary Bus 编号                                                                                                                                                                                                   | 默认为0          |
| Subordinate Bus #        | 0x1A | RW    | Subordinate Bus 编号                                                                                                                                                                                                 | 默认为0          |



| IO Base                                   | 0x1C | RW/RO | [3:0] RO,<br>Oh-16bit,1h-32bit<br>[7:4] RW                                                                                                                                                                                                                                                                                                      | 默认为 0x1  |
|-------------------------------------------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|
| IO Limit                                  | OX1D | RW/RO | [3:0] RO,<br>Oh-16bit,1h-32bit<br>[7:4] RW                                                                                                                                                                                                                                                                                                      | 默认为 0x1  |
| Secondary Lantency Timer                  | 0x1E | RO    | Secondary Bus 状态寄存器                                                                                                                                                                                                                                                                                                                             | 默认为0     |
| (Non-Prefetchable) Memory<br>Base         | 0x20 | RW/RO | [3:0] RO, must be 0<br>[15:4] RW                                                                                                                                                                                                                                                                                                                | 默认为 0x0  |
| (Non-Prefetchable) Memory<br>Limit        | 0x22 | RW/RO | [3:0] RO, must be 0<br>[15:4] RW                                                                                                                                                                                                                                                                                                                | 默认为 0x0  |
| Prefetchable Memory Base                  | 0x24 | RW/RO | [3:0] RO, Oh-32bit,<br>1h-64bit<br>[15:4] RW                                                                                                                                                                                                                                                                                                    | 默认为 0x1  |
| Prefetchable Memory Limit                 | 0x26 | RW/RO | [3:0] RO, Oh-32bit,<br>1h-64bit<br>[15:4] RW                                                                                                                                                                                                                                                                                                    | 默认为 0x1  |
| Prefetchable Memory Base<br>Upper 32bits  | 0x28 | RW    | 可预取 MEM 地址空间高 32 位                                                                                                                                                                                                                                                                                                                              | 默认为0     |
| Prefetchable Memory Limit<br>Upper 32bits | 0x2C | RW    | 可预取 MEM 地址空间高 32 位                                                                                                                                                                                                                                                                                                                              | 默认为0     |
| IO Base Upper 16 Bits                     | 0x30 | RW    | I0 地址 Base 高 16 位                                                                                                                                                                                                                                                                                                                               | 默认为0     |
| IO Limit Upper 16 Bits                    | 0x32 | RW    | IO 地址 Limit 高 16 位                                                                                                                                                                                                                                                                                                                              | 默认为0     |
| Capabilities Pointer<br>扩展能力指针            | 0x34 | RW    | 扩展指针                                                                                                                                                                                                                                                                                                                                            | 默认为 0x40 |
| Expansion ROM Base Address<br>扩展 ROM 基地址  | 0x38 | RW    | 扩展 ROM 基地址寄存器<br>Bit0: 地址译码使能<br>Bit10-1: 保留<br>Bit31-11: 用于指定 ROM 的起<br>始地址                                                                                                                                                                                                                                                                    | 保留       |
| Interrupt Line<br>中断线寄存器                  | 0x3C | RW    | 中断线寄存器                                                                                                                                                                                                                                                                                                                                          | 默认为 0xFF |
| Interrupt Pin<br>中断引脚寄存器                  | 0x3D | RO    | 中断引脚寄存器                                                                                                                                                                                                                                                                                                                                         | 默认为 0x0  |
| Bridge Control                            | 0x3E | RW/RO | O(RW): Parity Error Response Enable 1(RW): SERR# Enable 2(RW): ISA Enable 3(RW): VGA Enable 4(RW): VGA 16bit Decode 5(RW): Master-Abort Mode 6(RW) Secondary Bus Reset 7(RW): Fast Back-to-Back Enable 8(RO): Primary Discard Timer 9: Secondary Discard Timer 10(RW1C): Discard Timer Status 11(RW): Discard Timer SERR# Enable 15:12 Reserved | 默认为 0    |



#### 6.4.3 设备地址空间分配示例

对 PCI 设备的访问主要通过 PCI MEM 空间来完成。软件可以在该地址段内任意分配各个设备的访问地址。内部 PCI 设备包括: GPU、DC、GMEM、PCIe、RapidIO、USB、SATA、GMAC、HDA、I2S、LPC、SPI。这些设备(除 LPC 外)的访问地址可以由软件动态分配。一种分配方式如下:通过扫描 PCI 总线,读取各个设备(PCI 方式方位)的配置空间,获取各个设备使用的 MEM 空间和 I/0 空间大小,系统软件从 0x40000,  $0000^{\circ}0x7fff$ , ffff 这个地址内分配合适大小的 MEM 空间,从 0x1800,  $0000^{\circ}0x19ff$ , ffff 这个地址内分配合适大小的 I/0 空间(PCIe 设备)。

除了这些 PCI 类型的设备外,还包含一些使用固定地址访问的设备,比如:中断控制器、HPET 控制器、confbus 配置寄存器、MISC 低速设备块。

表 6- 14 和表 6- 15 给出了固定地址设备和 PCI 设备的一种地址分配示例,以及它们的地址空间大小和支持的访问类型。访问类型中,B 表示字节访问(1byte),H 表示半字访问(2byte),W 表示字访问(4byte),D 表示双字访问(8byte),Q 表示 4 字访问(16byte),C 表示 cacheline 访问。

| 模块       | 地址空间                      | 地址空间大小 | 访问类型   |
|----------|---------------------------|--------|--------|
| INT      | 0x1000, 0000~0x1000, 0fff | 4K     | BHW    |
| HPET     | 0x1000, 1000~0x1000, 1fff | 4K     | BW     |
| CONF REG | 0x1001,0000~0x1001,ffff   | 64K    | BHW    |
| MISC     | 0x1008,0000~0x100f,ffff   | 512K   | BW     |
| LPC REG  | 0x1000, 2000~0x1000, 2fff | 4K     | W      |
| LPC MEM  | 0x1200,0000~0x13ff,ffff   | 32M    | BHWDQC |
| LPC I/O  | 0x1800, 0000~0x1800, ffff | 64K    | В      |
| LPC TPM  | 0x1801,0000~0x1801,ffff   | 64K    | В      |

表 6-14 固定地址设备地址空间

表 6- 15 PCI 设备地址空间描述

| 模块                | 地址空间大小 | 访问类型   |
|-------------------|--------|--------|
| GPU               | 256    | W      |
| Graphic Memory (共 | 可配置    | BHWDQC |
| 享显存)              | V.,    | ·      |
| DC                | 64K    | W      |
| PCIe I/O          | 可配置    | BHW    |
| PCIe MEM          | 可配置    | ВНЖ    |
| SPI MEM           | 16M    | BHWDQC |
| USB-XHCI          | 1MB    | W      |
| SATA              | 1K     | W      |
| GMACO             | 32K    | W      |



| GMAC1   | 32K | W   |
|---------|-----|-----|
| GMAC2   | 32K | W   |
| HDA     | 64K | BHW |
| HDA1    | 64K | BHW |
| 12S     | 64K | W   |
| SPI REG | 4K  | В   |

上述设备中,除了 PCIe IO/MEM、RapidIO MEM 和 Graphic Memory 外,其它设备的地址空间大小是固定不变的,软件可以改变地址空间的起始地址。PCIe IO/MEM 地址空间的大小需要根据所接设备来决定。

Graphic Memory 的大小根据所接内存的容量来决定。BIOS 需要通过访问桥片通用配置 寄存器来修改 GPU 配置头的 BAR 寄存器 2/3 的 MASK 值来配置 Graphic Memory 的大小,然后软件再通过 PCI 扫描的方式来获得显存的大小。

在使用 PCIe 外接独立显卡的情况下,独立显卡自带的独立显存空间位于 PCIe MEM 地址空间内,作为 PCIe 设备统一管理。



# 7 共享 Cache (SCache)

SCache 模块是龙芯 2K2000 处理器内部所有处理器核所共享的三级 Cache。SCache 模块的主要特征包括:

- 16 项 Cache 访问队列。
- 关键字优先。
- 通过目录支持 Cache 一致性协议。
- 可用于片上多核结构,也可直接和单处理器 IP 对接。
- 采用 16 路组相联结构。
- 支持 ECC 校验。
- 支持 DMA 一致性读写和预取读。
- 支持 16 种共享 Cache 散列方式。
- 支持按窗口锁共享 Cache。
- 保证读数据返回原子性。

共享 Cache 模块包括共享 Cache 管理模块 scachemanage 及共享 Cache 访问模块 scacheaccess。Scachemanage 模块负责处理器来自处理器和 DMA 的访问请求,而共享 Cache 的 TAG、目录和数据等信息存放在 scacheaccess 模块中。为降低功耗,共享 Cache 的 TAG、目录和数据可以分开访问,共享 Cache 状态位、w 位与 TAG 一起存储,TAG 存放在 TAG RAM中,目录存放在 DIR RAM中,数据存放在 DATA RAM中。失效请求访问共享 Cache,同时读出所有路的 TAG、目录,并根据 TAG 来选出目录,并根据命中情况读取数据。替换请求、重填请求和写回请求只操作一路的 TAG、目录和数据。

为提高一些特定计算任务的性能,共享 Cache 增加了锁机制。落在被锁区域中的共享 Cache 块会被锁住,因而不会被替换出共享 Cache(除非 16 路共享 Cache 中都是被锁住的块)。通过芯片配置寄存器空间可以对共享 Cache 模块内部的四组锁窗口寄存器进行动态配置,但必须保证 16 路共享 Cache 中有一路不被锁住。此外当共享 Cache 收到 DMA 写请求时,如果被写的区域在共享 Cache 中命中且被锁住,那么 DMA 写将直接写入到共享 Cache 而不是内存。

| 名称           | 地址         | 位域      | 描述        |
|--------------|------------|---------|-----------|
| Slock0_valid | 0x3ff00200 | [63:63] | 0 号锁窗口有效位 |
| Slock0_addr  | 0x3ff00200 | [47:0]  | 0 号锁窗口锁地址 |
| SlockO_mask  | 0x3ff00240 | [47:0]  | 0 号锁窗口掩码  |
| Slock1_valid | 0x3ff00208 | [63:63] | 1号锁窗口有效位  |
| Slock1_addr  | 0x3ff00208 | [47:0]  | 1号锁窗口锁地址  |

表 7-1 共享 Cache 锁窗口寄存器配置



| Slock1_mask  | 0x3ff00248 | [47:0]  | 1号锁窗口掩码   |
|--------------|------------|---------|-----------|
| Slock2_valid | 0x3ff00210 | [63:63] | 2号锁窗口有效位  |
| Slock2_addr  | 0x3ff00210 | [47:0]  | 2 号锁窗口锁地址 |
| Slock2_mask  | 0x3ff00250 | [47:0]  | 2 号锁窗口掩码  |
| Slock3_valid | 0x3ff00218 | [63:63] | 3 号锁窗口有效位 |
| Slock3_addr  | 0x3ff00218 | [47:0]  | 3 号锁窗口锁地址 |
| Slock3_mask  | 0x3ff00258 | [47:0]  | 3 号锁窗口掩码  |

举例来说,当一个地址 addr 使得 slock0\_valid && ((addr & slock0\_mask) == (slock0\_addr & slock0\_mask) )为1时,这个地址就被锁窗口0锁住了。

2个 scache 使用同一个配置寄存器,基地址为 0x1fe00000,偏移地址 0x0280。

表 7-2 共享 Cache 配置寄存器 (SC\_CONFIG)

| 位域    | 字段名                 | 访问 | 复位值   | 描述                                                                                                                                               |
|-------|---------------------|----|-------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | LRU en              | RW | 1' b1 | Scache LRU 替换算法使能                                                                                                                                |
| 16    | Prefetch En         | RW | 1' b1 | Scache 预取功能使能                                                                                                                                    |
| 22:20 | Prefetch config     | RW | 3' h1 | 当 scache 预取越过配置大小的地址范围时,停止预取<br>0 - 4KB<br>1 - 16KB<br>2 - 64KB<br>3 - 1MB                                                                       |
|       |                     |    |       | 7 - 不受限<br>(注: SCID_SEL==0 时有效)                                                                                                                  |
| 26:24 | Prefetch lookahead  | RW | 3' h2 | scache 预取步长 0 - 保留 1 - 0x100 2 - 0x200 3 - 0x300 4 - 0x400 5 - 0x500 6 - 0x600 7 - 0x700 (注: SCID_SEL==0 时有效)                                    |
| 30:28 | Sc stall dirq cycle | RW | 3' h2 | SC 指令堵住 dirq 的时钟周期数 0 - 1 cycle (nonstall) 1 - 16-31 cycle random 2 - 32-63 cycle random 3-64-127 cycle random 4 - 128-255 cycle random 其他 - 无效值 |



# 8 处理器核间中断与通信

龙芯 2K2000 为每个处理器核都实现了 8 个核间中断寄存器(IPI)以支持多核 BIOS 启动和操作系统运行时在处理器核之间进行中断和通信。

龙芯 2K2000 中支持两种不同的访问方式,一种是与 3A3000 等处理器兼容的地址访问模式,另一种是为了支持处理器寄存器空间的直接私有访问。后面章节进行分别说明。

### 8.1 按地址访问模式

对于龙芯 2K2000,下列寄存器可以使用基地址  $0x3ff0_0000$  或者  $0x1fe0_0000$  进行访问。其中,基地址  $0x3ff0_0000$  可以通过路由设置寄存器中的  $disable_0x3ff0$  控制位进行关闭。具体寄存器说明和地址见表 8-1 到表 8-3。

| 衣 0 <sup>-</sup> 1 处连备核问中例相大的可行备及共功能抽处 |      |                                                    |  |  |
|----------------------------------------|------|----------------------------------------------------|--|--|
| 名称                                     | 读写权限 | 描述                                                 |  |  |
| IPI_Status                             | R    | 32 位状态寄存器,任何一位有被置 1 且对应位使能情况下,处理器核<br>INT4 中断线被置位。 |  |  |
| IPI_Enable                             | RW   | 32 位使能寄存器,控制对应中断位是否有效                              |  |  |
| IPI_Set                                | W    | 32 位置位寄存器,往对应的位写 1,则对应的 STATUS 寄存器位被置 1            |  |  |
| IPI_Clear                              | W    | 32 位清除寄存器,往对应的位写 1,则对应的 STATUS 寄存器位被清 0            |  |  |
| MailBox0                               | RW   | 缓存寄存器,供启动时传递参数使用,按 64 或者 32 位的 uncache 方式进行访问。     |  |  |
| MailBox01                              | RW   | 缓存寄存器,供启动时传递参数使用,按 64 或者 32 位的 uncache 方式进行访问。     |  |  |
| MailBox02                              | RW   | 缓存寄存器,供启动时传递参数使用,按 64 或者 32 位的 uncache 方式<br>进行访问。 |  |  |
| MailBox03                              | RW   | 缓存寄存器,供启动时传递参数使用,按 64 或者 32 位的 uncache 方式进行访问。     |  |  |

表 8-1 处理器核间中断相关的寄存器及其功能描述

在龙芯 2K2000 与处理器核间中断相关的寄存器及其功能描述如下:

表 8-20号处理器核的核间中断与通信寄存器列表

| 名称               | 偏移地址   | 权限 | 描述                       |
|------------------|--------|----|--------------------------|
| CoreO_IPI_Status | 0x1000 | R  | 0号处理器核的 IPI_Status 寄存器   |
| CoreO_IPI_Enalbe | 0x1004 | RW | 0号处理器核的 IPI_Enalbe 寄存器   |
| CoreO_IPI_Set    | 0x1008 | W  | 0 号处理器核的 IPI_Set 寄存器     |
| CoreO_IPI_Clear  | 0x100c | W  | 0号处理器核的 IPI_Clear 寄存器    |
| CoreO_MailBoxO   | 0x1020 | RW | 0号处理器核的 IPI_MailBox0 寄存器 |
| CoreO_ MailBox1  | 0x1028 | RW | 0号处理器核的 IPI_MailBox1 寄存器 |
| CoreO_ MailBox2  | 0x1030 | RW | 0号处理器核的 IPI_MailBox2 寄存器 |
| CoreO_ MailBox3  | 0x1038 | RW | 0号处理器核的 IPI_MailBox3 寄存器 |



| 名称               | 偏移地址   | 权限 | 描述                       |
|------------------|--------|----|--------------------------|
| Core1_IPI_Status | 0x1100 | R  | 1号处理器核的 IPI_Status 寄存器   |
| Core1_IPI_Enalbe | 0x1104 | RW | 1号处理器核的 IPI_Enalbe 寄存器   |
| Core1_IPI_Set    | 0x1108 | W  | 1号处理器核的 IPI_Set 寄存器      |
| Core1_IPI_Clear  | 0x110c | W  | 1号处理器核的 IPI_Clear 寄存器    |
| Core1_MailBox0   | 0x1120 | R  | 1号处理器核的 IPI_MailBox0 寄存器 |
| Corel_ MailBox1  | 0x1128 | RW | 1号处理器核的 IPI_MailBox1 寄存器 |
| Corel_ MailBox2  | 0x1130 | W  | 1号处理器核的 IPI_MailBox2 寄存器 |
| Corel_ MailBox3  | 0x1138 | W  | 1号处理器核的 IPI_MailBox3 寄存器 |

表 8-31号处理器核的核间中断与通信寄存器列表

# 8.2 配置寄存器指令访问

在龙芯 2K2000 中,新增了处理器核直接的寄存器访问指令,可以通过私有空间对配置 寄存器进行访问。为了更方便地使用核间中断寄存器,在这个模式下,对核间中断寄存器 定义进行一些调整。

| 表 6 · 自由是基础依依的中断与起目的存储为农 |        |    |                          |
|--------------------------|--------|----|--------------------------|
| 名称                       | 偏移地址   | 权限 | 描述                       |
| perCore_IPI_Status       | 0x1000 | R  | 当前处理器核的 IPI_Status 寄存器   |
| perCore_IPI_Enalbe       | 0x1004 | RW | 当前处理器核的 IPI_Enalbe 寄存器   |
| perCore_IPI_Set          | 0x1008 | W  | 当前处理器核的 IPI_Set 寄存器      |
| perCore_IPI_Clear        | 0x100c | W  | 当前处理器核的 IPI_Clear 寄存器    |
| perCore_MailBox0         | 0x1020 | RW | 当前处理器核的 IPI_MailBox0 寄存器 |
| perCore_ MailBox1        | 0x1028 | RW | 当前处理器核的 IPI_MailBoxl 寄存器 |
| perCore_ MailBox2        | 0x1030 | RW | 当前处理器核的 IPI_MailBox2 寄存器 |
| perCore_ MailBox3        | 0x1038 | RW | 当前处理器核的 IPI_MailBox3 寄存器 |

表 8-4 当前处理器核核间中断与通信寄存器列表

为了向其它核发送核间中断请求及 MailBox 通信,通过以下寄存器进行访问。

| X 0 5 处埋名 |        |    | 6′核核的週后奇什益                                                                                                               |
|-----------|--------|----|--------------------------------------------------------------------------------------------------------------------------|
| 名称        | 偏移地址   | 权限 | 描述                                                                                                                       |
| IPI_Send  | 0x1040 | WO | 32 位中断分发寄存器 [31] 等待完成标志,置 1 时会等待中断生效 [30:26] 保留 [25:16] 处理器核号 [15:5] 保留 [4:0] 中断向量号,对应 IPI_Status 中的向量                   |
| Mail_Send | 0x1048 | WO | 64 位 MailBox 缓存寄存器 [63:32] MailBox 数据 [31] 等待完成标志,置 1 时会等待写入生效 [30:27] 写入数据的 mask,每一位表示 32 位写数据对应的字节不会真正写入目标地址,如 1000b 表 |

表 8-5 处理器核核间通信寄存器



|           |                  |               | 示写入第 0-2 字节,0000b 则 0-3 字节全部写入  |
|-----------|------------------|---------------|---------------------------------|
|           |                  |               | [26] 保留                         |
|           |                  |               | [25:16] 处理器核号                   |
|           |                  |               | [15:5] 保留                       |
|           |                  |               | [4:2] MailBox 号                 |
|           |                  |               | 0 - MailBox0低32位                |
|           |                  |               | 1 - MailBox0 高 32 位             |
|           |                  |               | 2 - MailBox1低32位                |
|           |                  |               | 3 - MailBox1 高 32 位             |
|           |                  |               | 4 - MailBox2低32位                |
|           |                  |               | 5 - MailBox2 高 32 位             |
|           |                  |               | 6 - MailBox3 低 32 位             |
|           |                  |               | 7 - MailBox4 高 32 位             |
|           |                  |               | [1:0] 保留                        |
|           |                  |               | 32 位频率使能寄存器                     |
|           |                  |               | [31] 等待完成标志,置1时会等待设置生效          |
|           |                  |               | [30:27] 写入数据的 mask,每一位表示 32 位写数 |
|           |                  |               | 据对应的字节不会真正写入目标地址,如 1000b 表      |
| EDEO C 1  | FREQ_Send 0x1058 | WO            | 示写入第 0-2 字节,0000b 则 0-3 字节全部写入  |
| rkeQ_Sena |                  | WO            | [26] 保留                         |
|           |                  | [25:16] 处理器核号 |                                 |
|           |                  |               | [15:5] 保留                       |
|           |                  |               | [4:0] 写入对应的处理器核私有频率配置寄存         |
|           |                  |               | 器。CSR[0x1050]                   |

需要注意的是,由于 Mail\_Send 寄存器一次只可以发送 32 位的数据,当发送 64 位数据 时必须拆分为两次发送。因此,目标核在等待 Mail\_Box 内容时,需要通过其它的软件手段 来确保传输的完整性。例如,发送完 Mail\_Box 数据之后,通过核间中断来表示已经发送完成。

# 8.3 配置寄存器指令调试支持

配置寄存器指令原则上在使用时不跨片访问,但为了满足对调试等的需求,在此使用 多个寄存器地址对跨片访问进行支持。值得注意的是,这类寄存器只能写,不能读。

出了前一节提到的 IPI\_Send、Mail Send、Freq Send,还有一个 Any Send 寄存器可供使用,其地址如下。

表 8- 6 处理器核核间通信寄存器

| 名称       | 偏移地址   | 权限 | 描述                     |
|----------|--------|----|------------------------|
| ANW C. I | 0.1150 | WO | 64 位寄存器访问寄存器           |
| ANY_Send | 0x1158 | WO | [63:32] 写入数据           |
|          |        |    | [31] 等待完成标志,置1时会等待中断生效 |



| [30:27] 写入数据的 mask,每一位表示 32 位写数 |
|---------------------------------|
| 据对应的字节不会真正写入目标地址,如 1000b 表      |
| 示写入第 0-2 字节,0000b 则 0-3 字节全部写入  |
| [26] 保留                         |
| [25:16] 目标处理器核号                 |
| [15:0] 写入的寄存器偏移地址               |



# 9 I/0 中断

龙芯 2K2000 芯片支持两种不同的中断方式。第一种为传统中断方式; 第二种为扩展 I0 中断方式。

龙芯 2K2000 芯片中断源分为两部分,一部分来自南北桥上的设备,另一部分来自 NODE 节点的模块,两部分中断采用层次化管理,其中南北桥上的中断通过 INTO/1 路由到 NODE 上,作为两个中断源与 NODE 上的其他中断源进行统一管理,如下图所示。任意一个 IO 中断源可以被配置为是否使能、触发的方式、以及被路由的目标处理器核中断脚。

南北桥上的中断通过 INTO/1 路由到 NODE 上,需要使能"其他功能设置寄存器"中的对应位。该寄存器基地址为 0x1fe00000,偏移地址 0x0420。

表 9-1 其它功能设置寄存器

| 位域 | 字段名           | 访问 | 复位值 | 描述          |
|----|---------------|----|-----|-------------|
| 48 | BRIDGE_INT_en | RW | 0x0 | 南北桥 IO 中断使能 |







图 9-1 龙芯 2K2000 处理器南北桥中断路由示意图



图 9-2 龙芯 2K2000 处理器 NODE 中断路由示意图

# 9.1 南北桥中断控制

#### 9.1.1 中断相关寄存器描述

南北桥的中断控制器针对每一个中断源,有一套控制和状态寄存器。

表 9-2 中断相关寄存器描述

| 寄存器名       | 位宽 | 访问类型 | 说明                                                                                         | 默认值 |
|------------|----|------|--------------------------------------------------------------------------------------------|-----|
| INT_MASK   | 1  | R/W  | 中断屏蔽寄存器。<br>0: 使能该中断;<br>1: 屏蔽该中断。                                                         | 1   |
| MSI_EN     | 1  | R/W  | 消息包中断使能寄存器。<br>0:关闭消息包方式;<br>1:使能消息包方式。                                                    | 0   |
| INTEDGE    | 1  | R/W  | 触发方式设置寄存器。<br>0: 电平触发中断;<br>1: 边沿触发中断。                                                     | 0   |
| INTCLR     | 1  | WO   | 脉冲触发中断清除寄存器。<br>写1清除该中断,写0无效。                                                              | N/A |
| SOFT_INT   | 1  | R/W  | 软件触发中断寄存器。<br>使用软件来模拟设备中断,等价于设备的中断输<br>出。                                                  | 0   |
| AUTO_CTRLO | 1  | R/W  | 中断分发模式控制寄存器(与 AUTO_CTRL1 合用)。<br>{AUTO_CTRL1, AUTO_CTRL0}:<br>00b: 固定分发模式;<br>01b: 轮转分发模式; | 0   |



|              |   |     | 10b: 空闲分发模式;                                                                                                               |     |
|--------------|---|-----|----------------------------------------------------------------------------------------------------------------------------|-----|
|              |   |     | 11b: 忙碌分发模式。                                                                                                               |     |
| AUTO_CTRL1   | 1 | R/W | 中断分发模式控制寄存器(与 AUTO_CTRL0 合用)。<br>{AUTO_CTRL1, AUTO_CTRL0}:<br>00b: 固定分发模式;<br>01b: 轮转分发模式;<br>10b: 空闲分发模式;<br>11b: 忙碌分发模式。 | 0   |
|              |   |     | 中断路由寄存器。                                                                                                                   |     |
| ROUTE_ENTRY  | 8 | R/W | 用来配置将该中断路由给哪个处理器,该寄存器按照位图的形式组织。bit0:路由给INTn0;bit1:路由给INTn1。bit7:2:保留。                                                      | 0   |
|              |   |     |                                                                                                                            |     |
| MSI_VECTOR   | 8 | R/W | 消息包中断向量寄存器。                                                                                                                | 见下文 |
| INTISR_CHIPO | 1 | RO  | 路由到 INTn0 的中断状态(在服务)寄存器。<br>0: 无中断;<br>1: 有中断。                                                                             | 0   |
| INTISR_CHIP1 | 1 | RO  | 路由到 INTn1 的中断状态(在服务)寄存器。<br>0: 无中断;<br>1: 有中断。                                                                             | 0   |
| INTIRR       | 1 | RO  | 中断请求寄存器。<br>0:没有中断请求;<br>1:有中断请求。                                                                                          | 0   |
| INTISR       | 1 | RO  | 中断状态(在服务)寄存器。<br>0:没有中断被接收;<br>1:有中断被接收。                                                                                   | 0   |
| INT_POLARITY | 1 | R/W | 中断电平触发极性选择寄存器。<br>对于电平触发类型:<br>0: 高电平触发;<br>1: 低电平触发。                                                                      | 0   |

南北桥中断控制器的访问地址是固定的,访问基地址为 0x5fff, f000, 地址空间大小为 4KB。中断控制器相关寄存器的地址分布见表 9-2。

表 9-3 中断寄存器地址分布

| 寄存器名           | 地址偏移  | 访问  | 说明             |
|----------------|-------|-----|----------------|
| INT_APIC_ID    | 0x000 | RO  | 中断控制器标识寄存器     |
| INT_MASK       | 0x020 | R/W | 中断屏蔽寄存器        |
| MSI_EN         | 0x040 | R/W | 消息包中断使能寄存器     |
| INTEDGE        | 0x060 | R/W | 触发方式设置寄存器      |
| INTCLR         | 0x080 | WO  | 脉冲触发中断清除寄存器    |
| SOFT_INT       | 0x0a0 | R/W | 软件触发中断寄存器      |
| AUTO_CTRL0     | 0x0c0 | R/W | 中断分发模式控制寄存器 0  |
| AUTO_CTRL1     | 0x0e0 | R/W | 中断分发模式控制寄存器 1  |
|                |       |     |                |
| ROUTE_ENTRY_O  | 0x100 | R/W | 中断路由寄存器[7-0]   |
| ROUTE_ENTRY_8  | 0x108 | R/W | 中断路由寄存器[15-8]  |
| ROUTE_ENTRY_16 | 0x110 | R/W | 中断路由寄存器[23-16] |
| ROUTE_ENTRY_24 | 0x118 | R/W | 中断路由寄存器[31-24] |
| ROUTE_ENTRY_32 | 0x120 | R/W | 中断路由寄存器[39-32] |
| ROUTE_ENTRY_40 | 0x128 | R/W | 中断路由寄存器[47-40] |
| ROUTE_ENTRY_48 | 0x130 | R/W | 中断路由寄存器[55-48] |
| ROUTE_ENTRY_56 | 0x138 | R/W | 中断路由寄存器[63-56] |
|                |       |     |                |



| MSI_VECTORO  | 0x200 | R/W | MSI 中断向量寄存器[ 7- 0]      |
|--------------|-------|-----|-------------------------|
| MSI_VECTOR8  | 0x208 | R/W | MSI 中断向量寄存器[15-8]       |
| MSI_VECTOR16 | 0x210 | R/W | MSI 中断向量寄存器[23-16]      |
| MSI_VECTOR24 | 0x218 | R/W | MSI 中断向量寄存器[31-24]      |
| MSI_VECTOR32 | 0x220 | R/W | MSI 中断向量寄存器[39-32]      |
| MSI_VECTOR40 | 0x228 | R/W | MSI 中断向量寄存器[47-40]      |
| MSI_VECTOR48 | 0x230 | R/W | MSI 中断向量寄存器[55-48]      |
| MSI_VECTOR56 | 0x238 | R/W | MSI 中断向量寄存器[63-56]      |
|              |       |     |                         |
| INTISR_0     | 0x300 | RO  | 路由到 INTn0 的中断状态(在服务)寄存器 |
| INTISR_1     | 0x320 | RO  | 路由到 INTn1 的中断状态(在服务)寄存器 |
| INTIRR       | 0x380 | RO  | 中断请求寄存器                 |
| INTISR       | 0x3a0 | RO  | 中断状态(在服务)寄存器            |
| INT_POLARITY | 0x3e0 | R/W | 中断触发电平选择寄存器             |
|              |       |     |                         |

### 中断控制器标识寄存器

地址偏移: 000-003h属性: RO默认值: 07000000h大小: 32 位

| 位域    | 名称       | 访问 | 描述       |
|-------|----------|----|----------|
| 31:24 | apic_id  | RO | 中断控制器 ID |
| 23:0  | Reserved | RO | 保留       |

地址偏移: 004-007h属性: RO默认值: 003F0001h大小: 32 位

| 位域    | 名称           | 访问 | 描述                        |
|-------|--------------|----|---------------------------|
| 31:24 | Reserved     | RO | 保留                        |
| 23:16 | int_num      | RO | 支持的中断源个数。实际中断个数等于该字段的值加1。 |
| 15:8  | Reserved     | RO | 保留                        |
| 7:0   | apic_version | RO | 中断控制器版本号                  |

#### 中断掩码寄存器

 地址偏移: 020-023h
 属性: R/W

 默认值: FFFFFFFFh
 大小: 32 位

| 位域   | 名称       | 访问  | 描述                         |
|------|----------|-----|----------------------------|
| 31:0 | int_mask | R/W | 中断掩码寄存器的低 32 位 (bit[31:0]) |

 地址偏移: 024-027h
 属性: R/W

 默认值: FFFFFFFFh
 大小: 32 位

| 位域   | 名称       | 访问  | 描述                           |
|------|----------|-----|------------------------------|
| 31:0 | int mask | R/W | 中断掩码寄存器的高 32 位 (bit [63:32]) |

#### 中断消息包使能寄存器

地址偏移: 040-043h属性: R/W默认值: 00000000h大小: 32 位

| 位域   | 名称     | 访问  | 描述                            |
|------|--------|-----|-------------------------------|
| 31:0 | msi_en | R/W | 中断消息包使能寄存器的低 32 位 (bit[31:0]) |



地址偏移: 044-047h属性: R/W默认值: 00000000h大小: 32 位

| 位域   | 名称     | 访问  | 描述                             |
|------|--------|-----|--------------------------------|
| 31:0 | msi_en | R/W | 中断消息包使能寄存器的高 32 位 (bit[63:32]) |

#### 中断触发控制寄存器

 地址偏移: 060-063h
 属性: R/W

 默认值: 00000000h
 大小: 32 位

| 位域   | 名称       | 访问  | 描述                           |
|------|----------|-----|------------------------------|
| 31:0 | int_edge | R/W | 中断触发控制寄存器的低 32 位 (bit[31:0]) |

地址偏移: 064-067h属性: R/W默认值: 00000000h大小: 32 位

| 位域   | 名称       | 访问  | 描述                           |
|------|----------|-----|------------------------------|
| 31:0 | int edge | R/W | 中断触发控制寄存器的高 32 位(bit[63:32]) |

#### 中断清除寄存器

地址偏移: 080-083h属性: WO默认值: N/A大小: 32 位

| 位域   | 名称        | 访问 | 描述                         |
|------|-----------|----|----------------------------|
| 31:0 | int clear | WO | 中断清除寄存器的低 32 位 (bit[31:0]) |

地址偏移: 084-087h属性: WO默认值: 000000000h大小: 32 位

| 位域   | 名称        | 访问 | 描述                          |
|------|-----------|----|-----------------------------|
| 31:0 | int_clear | WO | 中断清除寄存器的高 32 位 (bit[63:32]) |

#### 软中断寄存器

地址偏移: 0A0-0A3h属性: R/W默认值: 00000000h大小: 32 位

| 位域   | 名称       | 访问  | 描述                        |
|------|----------|-----|---------------------------|
| 31:0 | soft_int | R/W | 软中断寄存器的低 32 位 (bit[31:0]) |

地址偏移: 0A4-0A7h属性: R/W默认值: 000000000h大小: 32 位

| 位域   | 名称       | 访问  | 描述                         |
|------|----------|-----|----------------------------|
| 31:0 | soft_int | R/W | 软中断寄存器的高 32 位 (bit[63:32]) |

### INT\_AUTO\_CTRLO 寄存器

地址偏移: 0C0-0C3h属性: R/W默认值: 00000000h大小: 32 位

| I | 位域   | 名称             | 访问  | 描述                                |
|---|------|----------------|-----|-----------------------------------|
|   | 31:0 | int auto ctrl0 | R/W | 中断智能分发控制寄存器 0 的低 32 位 (bit[31:0]) |

地址偏移: 0C4-0C7h属性: R/W默认值: 000000000h大小: 32 位



| 位域   | 名称             | 访问  | 描述                                 |
|------|----------------|-----|------------------------------------|
| 31:0 | int_auto_ctrl0 | R/W | 中断智能分发控制寄存器 0 的高 32 位 (bit[63:32]) |

### INT\_AUTO\_CTRL1 寄存器

地址偏移: 0C0-0C3h属性: R/W默认值: 000000000h大小: 32 位

| 位域   | 名称             | 访问  | 描述                               |
|------|----------------|-----|----------------------------------|
| 31:0 | int_auto_ctrl1 | R/W | 中断智能分发控制寄存器 1 的低 32 位(bit[31:0]) |

地址偏移: 0C4-0C7h属性: R/W默认值: 00000000h大小: 32 位

| 位域   | 名称             | 访问  | 描述                                 |
|------|----------------|-----|------------------------------------|
| 31:0 | int_auto_ctrl1 | R/W | 中断智能分发控制寄存器 1 的高 32 位 (bit[63:32]) |

#### 中断路由配置寄存器

地址偏移: 100-103h属性: R/W默认值: 00000000h大小: 32 位

| 位域    | 名称       | 访问  | 描述                 |
|-------|----------|-----|--------------------|
| 25:24 | RI00     | R/W | RIOO 中断路由配置寄存器     |
| 17:16 | RIO1     | R/W | RIO1 中断路由配置寄存器     |
| 9:8   | SDIO_DMA | R/W | SDIO_DMA 中断路由配置寄存器 |
| 1:0   | eMMC_DMA | R/W | eMMC_DMA 中断路由配置寄存器 |

地址偏移: 104-107h属性: R/W默认值: 00000000h大小: 32 位

| 位域    | 名称        | 访问  | 描述                  |
|-------|-----------|-----|---------------------|
| 25:24 | gmac0_phy | R/W | GMACO PHY 中断路由配置寄存器 |
| 17:16 | gmac1_phy | R/W | GMAC1 PHY 中断路由配置寄存器 |
| 9:8   | sataphy   | R/W | SATAPHY 中断路由配置寄存器   |
| 1:0   | NB_DMA    | R/W | NB_DMA 中断路由配置寄存器    |

地址偏移: 108-10Bh属性: R/W默认值: 00000000h大小: 32 位

| 位域    | 名称                         | 访问  | 描述             |
|-------|----------------------------|-----|----------------|
| 25:24 | can_int_route              | R/W | CAN 中断路由配置寄存器  |
| 17:16 | vpu_int_route              | R/W | VPU 中断路由配置寄存器  |
| 9:8   | i2c_int/se_int4_ro<br>ute  | R/W | I2C 中断路由配置寄存器  |
| 1:0   | uart_int/se_int5_r<br>oute | R/W | UART 中断路由配置寄存器 |

地址偏移: 10C-10Fh属性: R/W默认值: 00000000h大小: 32 位

| 位域    | 名称                             | 访问  | 描述                  |
|-------|--------------------------------|-----|---------------------|
| 25:24 | <pre>gmacl_pmt_int_route</pre> | R/W | GMAC1_PMT 中断路由配置寄存器 |
| 17:16 | gmacl_sbd_int_route            | R/W | GMAC1_SBD 中断路由配置寄存器 |
| 9:8   | gmac0_pmt_int_route            | R/W | GMACO_PMT 中断路由配置寄存器 |
| 1:0   | gmac0_sbd_int_route            | R/W | GMACO_SBD 中断路由配置寄存器 |



 地址偏移: 110-113h
 属性: R/W

 默认值: 00000000h
 大小: 32 位

| 位域    | 名称                  | 访问  | 描述                  |
|-------|---------------------|-----|---------------------|
| 25:24 | lpc_int_route       | R/W | LPC 中断路由配置寄存器       |
| 17:16 | gmac2_pmt_int_route | R/W | GMAC2_PMT 中断路由配置寄存器 |
| 9:8   | gmac2_sbd_int_route | R/W | GMAC2_SBD 中断路由配置寄存器 |
| 1:0   | SATA_int_route      | R/W | SATA 中断路由配置寄存器      |

地址偏移: 114-117h属性: R/W默认值: 00000000h大小: 32 位

| 位域    | 名称              | 访问  | 描述              |
|-------|-----------------|-----|-----------------|
| 25:24 | hdal_int_route  | R/W | HDA1 中断路由配置寄存器  |
| 17:16 | usb3_int_route  | R/W | USB3 中断路由配置寄存器  |
| 9:8   | hpet2_int_route | R/W | HPET2 中断路由配置寄存器 |
| 1:0   | hpet1_int_route | R/W | HPET1 中断路由配置寄存器 |

地址偏移: 118-11Bh属性: R/W默认值: 00000000h大小: 32 位

| 位域    | 名称             | 访问  | 描述             |
|-------|----------------|-----|----------------|
| 25:24 | pwm3_int_route | R/W | PWM3 中断路由配置寄存器 |
| 17:16 | pwm2_int_route | R/W | PWM2 中断路由配置寄存器 |
| 9:8   | pwml_int_route | R/W | PWM1 中断路由配置寄存器 |
| 1:0   | pwm0_int_route | R/W | PWMO 中断路由配置寄存器 |

地址偏移: 11C-11Fh属性: R/W默认值: 00000000h大小: 32 位

| 位域    | 名称                           | 访问  | 描述                 |
|-------|------------------------------|-----|--------------------|
| 25:24 | thsens_int/se_int3_rou<br>te | R/W | THSENSOR 中断路由配置寄存器 |
| 17:16 | avs_int_route                | R/W | AVS 中断路由配置寄存器      |
| 9:8   | gpu_int_route                | R/W | GPU 中断路由配置寄存器      |
| 1:0   | dc_int/se_int7_route         | R/W | DC 中断路由配置寄存器       |

地址偏移: 120-123h属性: R/W默认值: 00000000h大小: 32 位

| 位域    | 名称                   | 访问  | 描述                      |
|-------|----------------------|-----|-------------------------|
| 25:24 | pcie_f0_p3_int_route | R/W | PCIe_FO 控制器 3 中断路由配置寄存器 |
| 17:16 | pcie_f0_p2_int_route | R/W | PCIe_F0 控制器 2 中断路由配置寄存器 |
| 9:8   | pcie_f0_p1_int_route | R/W | PCIe_F0 控制器 1 中断路由配置寄存器 |
| 1:0   | pcie_f0_p0_int_route | R/W | PCIe_FO 控制器 0 中断路由配置寄存器 |

地址偏移: 124-127h属性: R/W默认值: 00000000h大小: 32 位

| 位域    | 名称                     | 访问  | 描述                      |
|-------|------------------------|-----|-------------------------|
| 25:24 | pwm5_int_route         | R/W | PWM5 中断路由配置寄存器          |
| 17:16 | pwm4_int/se_int6_route | R/W | PWM4 中断路由配置寄存器          |
| 9:8   | pcie_f1_p1_int_route   | R/W | PCIe_F1 控制器 1 中断路由配置寄存器 |
| 1:0   | pcie_f1_p0_int_route   | R/W | PCIe_F1 控制器 0 中断路由配置寄存器 |

地址偏移: 128-12Bh属性: R/W默认值: 00000000h大小: 32 位



| 位域    | 名称                   | 访问  | 描述                      |
|-------|----------------------|-----|-------------------------|
| 25:24 | rsa_int_route        | R/W | RSA 中断路由配置寄存器           |
| 17:16 | des_int_route        | R/W | DES 中断路由配置寄存器           |
| 9:8   | aes_int_route        | R/W | AES 中断路由配置寄存器           |
| 1:0   | pcie g0 p0 int route | R/W | PCIe_GO 控制器 0 中断路由配置寄存器 |

地址偏移: 12C-12Fh属性: R/W默认值: 00000000h大小: 32 位

| 位域    | 名称             | 访问  | 描述             |
|-------|----------------|-----|----------------|
| 25:24 | acpi_int_route | R/W | ACPI 中断路由配置寄存器 |
| 17:16 | toy2_int_route | R/W | TOY2 中断路由配置寄存器 |
| 9:8   | toy1_int_route | R/W | TOY1 中断路由配置寄存器 |
| 1:0   | toy0 int route | R/W | TOYO 中断路由配置寄存器 |

地址偏移: 130-133h 属性: R/W 默认值: 00000000h 大小: 32 位

| 位域    | 名称             | 访问  | 描述                |
|-------|----------------|-----|-------------------|
| 25:24 | emmc_int_route | R/W | eMMC 控制器中断路由配置寄存器 |
| 17:16 | sdio_int_route | R/W | SDIO 控制器中断路由配置寄存器 |
| 9:8   | otg_int_route  | R/W | OTG 控制器中断路由配置寄存器  |
| 1:0   | usb2_int_route | R/W | USB2 控制器中断路由配置寄存器 |

地址偏移: 134-137h属性: R/W默认值: 00000000h大小: 32 位

| 位域    | 名称 名称          | 访问  | 描述             |
|-------|----------------|-----|----------------|
| 25:24 | hpet_int_route | R/W | HPET 中断路由配置寄存器 |
| 17:16 | rtc2_int_route | R/W | RTC2 中断路由配置寄存器 |
| 9:8   | rtcl_int_route | R/W | RTC1 中断路由配置寄存器 |
| 1:0   | rtc0_int_route | R/W | RTCO 中断路由配置寄存器 |

地址偏移: 138-13Bh属性: R/W默认值: 00000000h大小: 32 位

| 位域    | 名称                 | 访问  | 描述                          |
|-------|--------------------|-----|-----------------------------|
| 25:24 | gpio_hi_int_route  | R/W | GPIO 高位(bit[56:4])中断路由配置寄存器 |
| 17:16 | i2s/hda0_int_route | R/W | I2S/HDAO 中断路由配置寄存器          |
| 9:8   | i2s_dma1_int_route | R/W | I2S DMA 1 中断路由配置寄存器         |
| 1:0   | i2s_dma0_int_route | R/W | I2S DMAO 中断路由配置寄存器          |

地址偏移: 13C-13Fh属性: R/W默认值: 00000000h大小: 32 位

| 位域    | 名称                                          | 访问  | 描述                 |
|-------|---------------------------------------------|-----|--------------------|
| 25:24 | gpio3_int_route/gpio50_int_route            | R/W | GPI03/50 中断路由配置寄存器 |
| 17:16 | <pre>gpio2_int_route/gpio15_int_route</pre> | R/W | GPI02/15 中断路由配置寄存器 |
| 9:8   | <pre>gpiol_int_route/gpiol4_int_route</pre> | R/W | GPI01/14 中断路由配置寄存器 |
| 1:0   | <pre>gpio0_int_route/gpio13_int_route</pre> | R/W | GPI00/13 中断路由配置寄存器 |

#### 消息包中断向量配置寄存器

地址偏移: 200-203h属性: R/W默认值: 03020100h大小: 32 位



| 位域    | 名称                  | 访问  | 描述                     |
|-------|---------------------|-----|------------------------|
| 31:24 | rio0_int_vector     | R/W | RIOO MSI 中断向量配置寄存器     |
| 23:16 | riol_int_vector     | R/W | RIO1 MSI 中断向量配置寄存器     |
| 15:8  | SDIO_DMA_int_vector | R/W | SDIO_DMA MSI 中断向量配置寄存器 |
| 7: 0  | eMMC DMA int vector | R/W | eMMC_DMA MSI 中断向量配置寄存器 |

地址偏移: 204-207h属性: R/W默认值: 070605040h大小: 32 位

| 位域    | 名称                 | 访问  | 描述                    |
|-------|--------------------|-----|-----------------------|
| 31:24 | gmac0_int_vector   | R/W | GMACO MSI 中断向量配置寄存器   |
| 23:16 | gmac1_int_vector   | R/W | GMAC1 MSI 中断向量配置寄存器   |
| 15:8  | sataphy_int_vector | R/W | SATAPHY MSI 中断向量配置寄存器 |
| 7:0   | NB DMA int vector  | R/W | NB_DMA_MSI 中断向量配置寄存器  |

地址偏移: 208-20Bh属性: R/W默认值: 0B0A0908h大小: 32 位

| 位域    | 名称                      | 访问  | 描述                 |
|-------|-------------------------|-----|--------------------|
| 31:24 | can_int_vector          | R/W | CAN MSI 中断向量配置寄存器  |
| 23:16 | vpu_int_vector          | R/W | VPU MSI 中断向量配置寄存器  |
| 15:8  | i2c_int/se_int4_vector  | R/W | I2C MSI 中断向量配置寄存器  |
| 7:0   | uart_int/se_int5_vector | R/W | UART MSI 中断向量配置寄存器 |

地址偏移: 20C-20Fh属性: R/W默认值: 0E0F0D0Ch大小: 32 位

| 位域    | 名称 名称                | 访问  | 描述                      |
|-------|----------------------|-----|-------------------------|
| 31:24 | gmacl_pmt_int_vector | R/W | GMAC1_PMT MSI 中断向量配置寄存器 |
| 23:16 | gmac1_sbd_int_vector | R/W | GMAC1_SBD MSI 中断向量配置寄存器 |
| 15:8  | gmac0_pmt_int_vector | R/W | GMACO_PMT MSI 中断向量配置寄存器 |
| 7:0   | gmac0_sbd_int_vector | R/W | GMACO_SBD MSI 中断向量配置寄存器 |

地址偏移: 210-213h属性: R/W默认值: 13121110h大小: 32 位

| 位域    | 名称                              | 访问  | 描述                      |
|-------|---------------------------------|-----|-------------------------|
| 31:24 | lpc_int_vector                  | R/W | LPC MSI 中断向量配置寄存器       |
| 23:16 | <pre>gmac2_pmt_int_vector</pre> | R/W | GMAC2_PMT MSI 中断向量配置寄存器 |
| 15:8  | gmac2_sbd_int_vector            | R/W | GMAC2_SBD MSI 中断向量配置寄存器 |
| 7:0   | SATA_int_vector                 | R/W | SATA MSI 中断向量配置寄存器      |

地址偏移: 214-217h属性: R/W默认值: 17161514h大小: 32 位

| 位域    | 名称              | 访问  | 描述                  |
|-------|-----------------|-----|---------------------|
| 31:24 | can_int_vector  | R/W | CAN MSI 中断向量配置寄存器   |
| 31:16 | usb3_int_route  | R/W | USB3 MSI 中断向量配置寄存器  |
| 15:8  | hpet2_int_route | R/W | HPET2 MSI 中断向量配置寄存器 |
| 7:0   | hpet1_int_route | R/W | HPET1 MSI 中断向量配置寄存器 |

地址偏移: 218-21Bh属性: R/W默认值: 1B1A1918h大小: 32 位

| 位域    | 名称              | 访问  | 描述                 |
|-------|-----------------|-----|--------------------|
| 31:24 | pwm3_int_vector | R/W | PWM3 MSI 中断向量配置寄存器 |
| 23:16 | pwm2_int_vector | R/W | PWM2 MSI 中断向量配置寄存器 |



| 15:8 | pwm1_int_vector | R/W | PWM1 MSI 中断向量配置寄存器 |
|------|-----------------|-----|--------------------|
| 7:0  | pwm0_int_vector | R/W | PWMO MSI 中断向量配置寄存器 |

地址偏移: 21C-21Fh属性: R/W默认值: 1E1F1D1Ch大小: 32 位

| 位域    | 名称                            | 访问  | 描述                     |
|-------|-------------------------------|-----|------------------------|
| 31:24 | thsens_int/se_int<br>3_vector | R/W | Thsensor MSI 中断向量配置寄存器 |
| 23:16 | avs_int_vector                | R/W | AVS MSI 中断向量配置寄存器      |
| 15:8  | gpu_int_vector                | R/W | GPU MSI 中断向量配置寄存器      |
| 7:0   | dc_int/se_int7_vector         | R/W | DC MSI 中断向量配置寄存器       |

地址偏移: 220-223h属性: R/W默认值: 43424140h大小: 32 位

| 位域    | 名称                    | 访问  | 描述                          |
|-------|-----------------------|-----|-----------------------------|
| 31:24 | pcie_f0_p3_int_vector | R/W | PCIe_FO 控制器 3 MSI 中断向量配置寄存器 |
| 23:16 | pcie_f0_p2_int_vector | R/W | PCIe_FO 控制器 2 MSI 中断向量配置寄存器 |
| 15:8  | pcie_f0_p1_int_vector | R/W | PCIe_FO 控制器 1 MSI 中断向量配置寄存器 |
| 7:0   | pcie_f0_p0_int_vector | R/W | PCIe_FO 控制器 O MSI 中断向量配置寄存器 |

地址偏移: 224-227h属性: R/W默认值: 47464544h大小: 32 位

| 位域    | 名称                                  | 访问  | 描述                          |
|-------|-------------------------------------|-----|-----------------------------|
| 31:24 | pwm5_int_vector                     | R/W | PWM5 MSI 中断向量配置寄存器          |
| 23:16 | <pre>pwm4_int/se_int6_vecto r</pre> | R/W | PWM4 MSI 中断向量配置寄存器          |
| 15:8  | pcie_f1_p1_int_vector               | R/W | PCIe_F1 控制器 1 MSI 中断向量配置寄存器 |
| 7:0   | pcie_f1_p0_int_vector               | R/W | PCIe_F1 控制器 0 MSI 中断向量配置寄存器 |

地址偏移: 228-22Bh属性: R/W默认值: 4B4A4948h大小: 32 位

| 位域    | 名称                    | 访问  | 描述                          |
|-------|-----------------------|-----|-----------------------------|
| 31:24 | rsa_int_vector        | R/W | RSA MSI 中断向量配置寄存器           |
| 23:16 | des_int_vector        | R/W | DES MSI 中断向量配置寄存器           |
| 15:8  | aes_int_vector        | R/W | AES MSI 中断向量配置寄存器           |
| 7:0   | pcie_g0_p0_int_vector | R/W | PCIe_GO 控制器 O MSI 中断向量配置寄存器 |

地址偏移: 22C-22Fh属性: R/W默认值: 4F4E4D4Ch大小: 32 位

| 位域    | 名称              | 访问  | 描述                 |
|-------|-----------------|-----|--------------------|
| 31:24 | acpi_int_vector | R/W | ACPI MSI 中断向量配置寄存器 |
| 23:16 | toy2_int_vector | R/W | TOY2 MSI 中断向量配置寄存器 |
| 15:8  | toy1_int_vector | R/W | TOY1 MSI 中断向量配置寄存器 |
| 7:0   | toy0_int_vector | R/W | TOYO MSI 中断向量配置寄存器 |

地址偏移: 230-233h属性: R/W默认值: 53525150h大小: 32 位

| 位域    | 名称              | 访问  | 描述                     |
|-------|-----------------|-----|------------------------|
| 31:24 | emmc_int_vector | R/W | eMMC 控制器 MSI 中断向量配置寄存器 |
| 23:16 | sdio_int_vector | R/W | SDIO 控制器 MSI 中断向量配置寄存器 |
| 15:8  | otg_int_vector  | R/W | OTG 控制器 MSI 中断向量配置寄存器  |



| 7:0 | usb2_int_vector | R/W | USB2 控制器 MSI 中断向量配置寄存器 |
|-----|-----------------|-----|------------------------|

地址偏移: 234-237h属性: R/W默认值: 57565554h大小: 32 位

| 位域    | 名称              | 访问  | 描述                 |
|-------|-----------------|-----|--------------------|
| 31:24 | hpet_int_vector | R/W | HPET MSI 中断向量配置寄存器 |
| 23:16 | rtc2_int_vector | R/W | RTC2 MSI 中断向量配置寄存器 |
| 15:8  | rtcl_int_vector | R/W | RTC1 MSI 中断向量配置寄存器 |
| 7:0   | rtc0_int_vector | R/W | RTCO MSI 中断向量配置寄存器 |

地址偏移: 238-23Bh属性: R/W默认值: 5B5A5958h大小: 32 位

| 位域    | 名称                  | 访问  | 描述                               |
|-------|---------------------|-----|----------------------------------|
| 31:24 | gpio_hi_int_vector  | R/W | GPIO 高位(bit[56:4]) MSI 中断向量配置寄存器 |
| 23:16 | i2s/hda0_int_vector | R/W | I2S MSI 中断向量配置寄存器                |
| 15:8  | i2s_dma1_int_vector | R/W | I2S DMA1 MSI 中断向量配置寄存器           |
| 7:0   | i2s_dma0_int_vector | R/W | I2S DMAO MSI 中断向量配置寄存器           |

地址偏移: 23C-23Fh 属性: R/W 默认值: 5F5E5D5Ch 大小: 32 位

| 位域    | 名称                                 | 访问  | 描述                     |
|-------|------------------------------------|-----|------------------------|
| 31:24 | gpio3_int_vector/gpio50_int_vector | R/W | GPI03/50 MSI 中断向量配置寄存器 |
| 23:16 | gpio2_int_vector/gpio15_int_vector | R/W | GPIO2/15 MSI 中断向量配置寄存器 |
| 15:8  | gpio1_int_vector/gpio14_int_vector | R/W | GPIO1/14 MSI 中断向量配置寄存器 |
| 7:0   | gpio0_int_vector/gpio13_int_vector | R/W | GPIOO/13 MSI 中断向量配置寄存器 |

#### 路由到 INTn0 的中断在服务状态寄存器

地址偏移: 300-303h属性: R/W默认值: 00000000h大小: 32 位

| 位域   | 名称        | 访问  | 描述                                          |
|------|-----------|-----|---------------------------------------------|
| 31:0 | int_isr_0 | R/W | 路由到 INTn0 的中断在服务状态寄存器的低 32 位<br>(bit[31:0]) |

| 位域   | 名称        | 访问  | 描述                                           |
|------|-----------|-----|----------------------------------------------|
| 31:0 | int_isr_0 | R/W | 路由到 INTn0 的中断在服务状态寄存器的高 32 位<br>(bit[63:32]) |

#### 路由到 INTn1 的中断在服务状态寄存器

地址偏移: 320-323h 属性: R/W 默认值: 00000000h 大小: 32 位

| 位域   | 名称        | 访问  | 描述                                          |
|------|-----------|-----|---------------------------------------------|
| 31:0 | int_isr_1 | R/W | 路由到 INTn1 的中断在服务状态寄存器的低 32 位<br>(bit[31:0]) |

地址偏移: 324-327h 属性: R/W



默认值: 00000000h 大小: 32 位

| 位域   | 名称        | 访问  | 描述                                           |
|------|-----------|-----|----------------------------------------------|
| 31:0 | int_isr_1 | R/W | 路由到 INTn1 的中断在服务状态寄存器的高 32 位<br>(bit[63:32]) |

#### 中断请求寄存器

| 位域   | 名称      | 访问  | 描述                         |
|------|---------|-----|----------------------------|
| 31:0 | int_irr | R/W | 中断请求寄存器的低 32 位 (bit[31:0]) |

地址偏移: 384-387h属性: R/W默认值: 00000000h大小: 32 位

| 位域   | 名称      | 访问  | 描述                          |
|------|---------|-----|-----------------------------|
| 31:0 | int irr | R/W | 中断请求寄存器的高 32 位 (bit[63:32]) |

#### 中断在服务状态寄存器

地址偏移: 3A0-3A3h属性: R/W默认值: 000000000h大小: 32 位

| 位域   | 名称      | 访问  | 描述                            |
|------|---------|-----|-------------------------------|
| 31:0 | int_isr | R/W | 中断在服务状态寄存器的低 32 位 (bit[31:0]) |

地址偏移: 3A4-3A7h属性: R/W默认值: 00000000h大小: 32 位

| 位域   | 名称      | 访问  | 描述                             |
|------|---------|-----|--------------------------------|
| 31:0 | int isr | R/W | 中断在服务状态寄存器的高 32 位 (bit[63:32]) |

#### 中断电平触发极性寄存器

地址偏移: 3E0-3E3h属性: R/W默认值: 00000000h大小: 32 位

| 位域   | 名称           | 访问  | 描述                             |
|------|--------------|-----|--------------------------------|
| 31:0 | int_polarity | R/W | 中断电平触发极性寄存器的低 32 位 (bit[31:0]) |

地址偏移: 3E4-3E7h属性: R/W默认值: 00000000h大小: 32 位

| 位域   | 名称           | 访问  | 描述                              |
|------|--------------|-----|---------------------------------|
| 31:0 | int_polarity | R/W | 中断电平触发极性寄存器的高 32 位 (bit[63:32]) |

#### 9.1.2 设备中断类型

南北桥内部设备中断都连接到了南北桥的中断控制器上。对于南北桥来说,I2S DMA 中断为脉冲触发类型,gpio 中断根据需要可以配置成电平触发或者脉冲触发,其余中断均为电平触发,且高电平有效。



对于 PCIe 设备,一种方式是通过中断线的方式将 PCIe 控制器的中断送给南北桥的中断控制器;另一种方式是直接使用 PCIe 设备的 MSI 中断。

在 PCIe MSI 中断方式下,南北桥内部的 PCIe 控制器接收到 MSI 中断时,会将它直接转换成中断消息包发给 NODE 中断控制器。

#### 9.1.3 中断分发模式

南北桥支持双路中断输出,因此可以将不同的中断源或者同一个中断源的多次中断在这 两路中断输出之间进行分发。南北桥支持中断硬件负载均衡功能,使得中断可以在软件预设 的两路输出之间进行分发,分为四种模式:

- 1. 固定分发模式——按照中断路由配置寄存器配置的路由方式进行分发。在此种模式下,路由配置寄存器必须为 one-hot 编码,也就是说一个中断只能路由给一路中断输出。
- 2. 轮转分发模式——这种模式下每个新中断产生时,会按照 Route\_Entry 寄存器中路由向量的配置,路由到下一个中断输出上。
- 3. 空闲分发模式——跳转到空闲的中断输出。这种模式下,每个新中断产生时,会按照 Entry 寄存器中路由向量的配置,首先检测下一个中断输出上是否已有未被处理的中断,如果没有,则路由到该中断输出;如果下一个中断输出上已经存在未被处理的中断,则继续检测下一个处理器核。
- 4. 忙碌分发模式——当前中断输出忙碌则跳转到其左边(0->1->2->3)的候选中断输出上。这种模式下每个新中断产生时,会首先检测上次中断的中断输出上是否已有未被处理的中断,如果没有,则继续中断该中断输出,如果存在未被处理的中断,则按照 Entry 寄存器的配置,路由到下一个中断输出上。

需要注意到的是,一旦配置完 AUTO CTRLO/1 后不应该在运行中途修改。

建议软件使用固定分发模式。

# 9.2 NODE 传统 I/O 中断

龙芯 2K2000 芯片的传统中断支持 32 个中断源,以统一方式进行管理。任意一个 I0 中断源可以被配置为是否使能、触发的方式、以及被路由的目标处理器核中断脚。

中断相关配置寄存器都是以位的形式对相应的中断线进行控制,中断控制位连接及属性配置见下表。

中断使能(Enable)的配置有三个寄存器: Intenset、Intenclr 和 Inten。Intenset 设置中断使能,Intenset 寄存器写 1 的位对应的中断被使能。Intenclr 清除中断使能,Intenclr 寄存器写 1 的位对应的中断被清除。Inten 寄存器读取当前各中断使能的情况。

边沿触发的中断信号由 Intedge 配置寄存器来选择,写 1表示边沿触发,写 0表示电



平触发。中断处理程序可以通过 Intenclr 的相应位来清除中断记录,清除中断的同时也会清除中断使能。

|         | 访问属性/缺省值 |       |          |          |                            |  |  |
|---------|----------|-------|----------|----------|----------------------------|--|--|
| 位域      | Intedge  | Inten | Intenset | Intenclr | 中断源                        |  |  |
| 0       | RW / O   | R / O | RW / O   | RW / O   | GPI024/16/8/0/SC0/<br>INT0 |  |  |
| 1       | RW / O   | R / O | RW / O   | RW / 0   | GPI025/17/9/1/SC1/<br>INT1 |  |  |
| 2       | RW / O   | R / 0 | RW / O   | RW / 0   | GPI026/18/10/2/SC2         |  |  |
| 3       | RW / O   | R / 0 | RW / O   | RW / 0   | GPI027/19/11/3/SC3         |  |  |
| 4       | RW / O   | R / 0 | RW / O   | RW / 0   | GPI028/20/12/4             |  |  |
| 5       | RW / O   | R / 0 | RW / O   | RW / O   | GPI029/21/13/5             |  |  |
| 6       | RW / O   | R / 0 | RW / O   | RW / O   | GPI030/22/14/6             |  |  |
| 7       | RW / O   | R / 0 | RW / O   | RW / 0   | GPI031/23/15/7             |  |  |
| 8       | RW / O   | R / 0 | RW / O   | RW / 0   | 12C0                       |  |  |
| 9       | RW / O   | R / 0 | RW / O   | RW / 0   | I2C1                       |  |  |
| 10      | RW / 0   | R / O | RW / O   | RW / 0   | UARTO                      |  |  |
| 11      | RW / O   | R / O | RW / O   | RW / 0   | MCO                        |  |  |
| 12      | RW / O   | R / O | RW / O   | RW / 0   |                            |  |  |
| 13      | RW / 0   | R / O | RW / O   | RW / 0   | SPI                        |  |  |
| 14      | RW / 0   | R / 0 | RW / O   | RW / 0   | Thsens                     |  |  |
| 15      | RW / 0   | R / O | RW / O   | RW / 0   |                            |  |  |
| 23 : 16 | RW / 0   | R / O | RW / O   | RW / 0   |                            |  |  |
| 31 : 24 | RW / 0   | R / 0 | RW / O   | RW / 0   |                            |  |  |

表 9- 4 中断控制寄存器

与核间中断类似,I0 中断的基地址同样可以使用 0x1fe00000 或 0x3ff00000 进行访问,也可以通过处理器核的专用寄存器配置指令进行访问。

#### 9.2.1 按地址访问

这种访问方式基地址可以使用 0x1fe00000 或 0x3ff00000。 0x3ff00000 的基地址可以通过路由配置寄存器中的  $disable_0x3ff0$  控制位进行禁用。

 名称
 偏移地址
 描述

 Intisr
 0x1420
 32 位中断状态寄存器

 Inten
 0x1424
 32 位中断使能状态寄存器

表 9-5 IO 控制寄存器地址



3:0

7:4

| Intenset     | 0x1428 | 32 位设置使能寄存器          |
|--------------|--------|----------------------|
| Intenclr     | 0x142c | 32 位清除使能寄存器          |
| Intedge      | 0x1434 | 32 位触发方式寄存器          |
| COREO_INTISR | 0x1440 | 路由给 COREO 的 32 位中断状态 |
| CORE1_INTISR | 0x1448 | 路由给 CORE1 的 32 位中断状态 |

龙芯 2K2000 中集成了 2 个处理器核,上述的 32 位中断源可以通过软件配置选择期望 中断的目标处理器核。进一步,中断源可以选择路由到处理器核中断 INTO 到 INT3 中的任意 一个,即对应 CPO Status 的 IP2 到 IP5。32 个 I/O 中断源中每一个都对应一个 8 位的路由 控制器, 其格式和地址如表 9-5 和表 9-6 所示。路由寄存器采用向量的方式进行路由选择, 如 0x42 表示路由到 1 号处理器的 INT2 上。

龙芯 2K2000 中断引脚路由位增加了编码方式,由 CSR[0x420][49]位控制使能。当该 位使能时,下表的[7:4]由位图表示法变为数值编码法。可配置的数值 0-7 表示中断引脚 0-7。例如,在该模式下,0x22表示路由到1号处理器的INT2上。

位域 说明 路由的处理器核向量号

表 9- 6 中断路由寄存器的说明

| 丰  | 9- | 7   | 山 | 断路       | 山 | 客 | 左 | 哭-    | 栅    | +1 |  |
|----|----|-----|---|----------|---|---|---|-------|------|----|--|
| 1X | ., | - 1 |   | 1171 ILT | т |   | _ | THE . | LIM. | иι |  |

路由的处理器核中断引脚向量号

| 名称      | 偏移地址   | 描述             | 名称      | 偏移地址   | 描述 |
|---------|--------|----------------|---------|--------|----|
| Entry0  | 0x1400 | GPI024/16/8/0  | Entry16 | 0x1410 |    |
| Entry1  | 0x1401 | GPI025/17/9/1  | Entry17 | 0x1411 |    |
| Entry2  | 0x1402 | GPI026/18/10/2 | Entry18 | 0x1412 |    |
| Entry3  | 0x1403 | GPI027/19/11/3 | Entry19 | 0x1413 |    |
| Entry4  | 0x1404 | GPI028/20/12/4 | Entry20 | 0x1414 |    |
| Entry5  | 0x1405 | GPI029/21/13/5 | Entry21 | 0x1415 |    |
| Entry6  | 0x1406 | GPI030/22/14/6 | Entry22 | 0x1416 |    |
| Entry7  | 0x1407 | GPI031/23/15/7 | Entry23 | 0x1417 |    |
| Entry8  | 0x1408 | I2C0           | Entry24 | 0x1418 |    |
| Entry9  | 0x1409 | I2C1           | Entry25 | 0x1419 |    |
| Entry10 | 0x140a | UARTO          | Entry26 | 0x141a |    |
| Entry11 | 0x140b | MCO            | Entry27 | 0x141b |    |
| Entry12 | 0x140c |                | Entry28 | 0x141c |    |



| Entry13 | 0x140d | SPI    | Entry29 | 0x141d |  |
|---------|--------|--------|---------|--------|--|
| Entry14 | 0x140e | Thsens | Entry30 | 0x141e |  |
| Entry15 | 0x140f |        | Entry31 | 0x141f |  |

#### 9.2.2 配置寄存器指令访问

在龙芯 2K2000 中,同样可以通过配置寄存器指令的访问方法,通过私有空间对配置寄存器进行访问。指令所使用的偏移地址与通过地址访问的方式相同。此外,为了方便用户的使用,对每个核不同的当前中断状态设置了专用的私有中断状态寄存器,如下表所示。

表 9-8 处理器核私有中断状态寄存器

| 名称             | 偏移地址   | 描述                  |
|----------------|--------|---------------------|
| perCore_INTISR | 0x1010 | 路由给当前处理器核的 32 位中断状态 |

### 9.3 扩展 I/0 中断

除了兼容原有的传统 I0 中断方式,2K2000 支持扩展 I/0 中断,用于将中断直接分发给各个处理器核,而不再通过中断线进行转发,提升 I0 中断使用的灵活性。

在扩展 I0 中断模式下,中断可以直接进行轮转分发操作。当前版本,最多可以支持 256 个扩展中断向量。

### 9.3.1 按地址访问

以下是相关的扩展 IO 中断寄存器。与其它的配置寄存器一样,基地址可以使用 0x1fe00000 或 0x3ff00000, 也可以通过处理器核的专用寄存器配置指令进行访问。

表 9-9 扩展 IO 中断使能寄存器

| 名称                 | 偏移地址   | 描述                       |
|--------------------|--------|--------------------------|
| EXT_I0Ien[63:0]    | 0x1600 | 扩展 IO 中断[63:0]的中断使能配置    |
| EXT_IOIen[127:64]  | 0x1608 | 扩展 IO 中断[127:64]的中断使能配置  |
| EXT_IOIen[191:128] | 0x1610 | 扩展 I0 中断[191:128]的中断使能配置 |
| EXT_IOIen[255:192] | 0x1618 | 扩展 I0 中断[255:192]的中断使能配置 |

表 9-10 扩展 I0 中断自动轮转使能寄存器

| 名称                     | 偏移地址   | 描述                         |
|------------------------|--------|----------------------------|
| EXT_IOIbounce[63:0]    | 0x1680 | 扩展 I0 中断[63:0]的自动轮转使能配置    |
| EXT_IOIbounce[127:64]  | 0x1688 | 扩展 IO 中断[127:64]的自动轮转使能配置  |
| EXT_I0Ibounce[191:128] | 0x1690 | 扩展 I0 中断[191:128]的自动轮转使能配置 |
| EXT_IOIbounce[255:192] | 0x1698 | 扩展 I0 中断[255:192]的自动轮转使能配置 |



|                    | 10 II J/K |                        |
|--------------------|-----------|------------------------|
| 名称                 | 偏移地址      | 描述                     |
| EXT_I0Isr[63:0]    | 0x1700    | 扩展 I0 中断[63:0]的中断状态    |
| EXT_IOIsr[127:64]  | 0x1708    | 扩展 I0 中断[127:64]的中断状态  |
| EXT_I0Isr[191:128] | 0x1710    | 扩展 I0 中断[191:128]的中断状态 |
| EXT_I0Isr[255:192] | 0x1718    | 扩展 I0 中断[255:192]的中断状态 |

表 9- 11 扩展 IO 中断状态寄存器

表 9-12 各处理器核的扩展 10 中断状态寄存器

|                          | H/C·±H/ | /H11) /K T0   B)   M/M H1   H1   |
|--------------------------|---------|----------------------------------|
| 名称                       | 偏移地址    | 描述                               |
| COREO_EXT_IOIsr[63:0]    | 0x1800  | 路由至处理器核 0 的扩展 10 中断[63:0]的中断状态   |
| COREO_EXT_IOIsr[127:64]  | 0x1808  | 路由至处理器核 0 的扩展 10 中断[127:64]的中断状态 |
| COREO_EXT_IOIsr[191:128] | 0x1810  | 路由至处理器核0的扩展10中断[191:128]的中断状态    |
| COREO_EXT_IOIsr[255:192] | 0x1818  | 路由至处理器核0的扩展10中断[255:192]的中断状态    |
| CORE1_EXT_IOIsr[63:0]    | 0x1900  | 路由至处理器核 1 的扩展 10 中断[63:0]的中断状态   |
| CORE1_EXT_IOIsr[127:64]  | 0x1908  | 路由至处理器核 1 的扩展 10 中断[127:64]的中断状态 |
| CORE1_EXT_IOIsr[191:128] | 0x1910  | 路由至处理器核1的扩展10中断[191:128]的中断状态    |
| CORE1_EXT_IOIsr[255:192] | 0x1918  | 路由至处理器核1的扩展10中断[255:192]的中断状态    |

与传统 I0 中断类似,扩展 I0 中断的 256 位中断源也可以通过软件配置选择期望中断的目标处理器核。

但中断源并不可以单独选择路由到处理器核中断 INTO 到 INT3 中的任意一个,而是以组为单位进行 INT 中断的路由,以中断对应 CPO\_Status 的 IP2 到 IP5。下面是按组进行配置的中断引脚路由寄存器。

龙芯 2K2000 中断引脚路由位增加了编码方式,由 CSR[0x420][49]位控制使能。当该位使能时,下表的[3:0]由位图表示法变为数值编码法。可配置的数值 0-7 表示中断引脚 0-7。例如,在该模式下,0x2表示路由到 INT2 上。

表 9-13 中断引脚路由寄存器的说明

| 位域  | 说明             |
|-----|----------------|
| 3:0 | 路由的处理器核中断引脚向量号 |
| 7:4 | 保留             |

表 9- 14 中断路由寄存器地址

| 名称          | 偏移地址   | 描述                     |
|-------------|--------|------------------------|
| EXT_IOImapO | 0x14C0 | EXT_IOI[31:0]的引脚路由方式   |
| EXT_IOImap1 | 0x14C1 | EXT_IOI[63:32]的引脚路由方式  |
| EXT_IOImap2 | 0x14C2 | EXT_IOI[95:64]的引脚路由方式  |
| EXT_IOImap3 | 0x14C3 | EXT_IOI[127:96]的引脚路由方式 |



| EXT_IOImap4 | 0x14C4 | EXT_IOI[159:128]的引脚路由方式 |
|-------------|--------|-------------------------|
| EXT_IOImap5 | 0x14C5 | EXT_IOI[191:160]的引脚路由方式 |
| EXT_IOImap6 | 0x14C6 | EXT_IOI[223:192]的引脚路由方式 |
| EXT_IOImap7 | 0x14C7 | EXT_IOI[255:224]的引脚路由方式 |

每个中断源都另外对应一个8位的路由控制器,其格式和地址如下表9-14和表9-15 所示。路由寄存器采用向量的方式进行路由选择,如0x2表示路由到1号处理器核。

表 9- 15 中断目标处理器核路由寄存器的说明

| 位域  | 说明         |
|-----|------------|
| 3:0 | 路由的处理器核向量号 |
| 7:4 | 保留         |

表 9- 16 中断目标处理器核路由寄存器地址

| 名称                 | 偏移地址   | 描述                    |
|--------------------|--------|-----------------------|
| EXT_IOImap_CoreO   | 0x1C00 | EXT_IOI[0]的处理器核路由方式   |
| EXT_IOImap_Core1   | 0x1C01 | EXT_IOI[1]的处理器核路由方式   |
| EXT_IOImap_Core2   | 0x1C02 | EXT_IOI[2]的处理器核路由方式   |
|                    |        |                       |
| EXT_IOImap_Core254 | 0x1CFE | EXT_IOI[254]的处理器核路由方式 |
| EXT_IOImap_Core255 | 0x1CFF | EXT_IOI[255]的处理器核路由方式 |

#### 9.3.2 配置寄存器指令访问

使用处理器核的配置寄存器指令进行访问时,最大的不同在于对处理器核的中断状态 寄存器的访问成为私有的访问,每个核都只需要向同一个地址发出查询请求就可以得到当 前核的中断状态。

表 9-17 当前处理器核的扩展 10 中断状态寄存器

| 名称                         | 偏移地址   | 描述                               |
|----------------------------|--------|----------------------------------|
| perCore_EXT_IOIsr[63:0]    | 0x1800 | 路由至当前处理器核的扩展 I0 中断[63:0]的中断状态    |
| perCore_EXT_IOIsr[127:64]  | 0x1808 | 路由至当前处理器核的扩展 10 中断[127:64]的中断状态  |
| perCore_EXT_IOIsr[191:128] | 0x1810 | 路由至当前处理器核的扩展 I0 中断[191:128]的中断状态 |
| perCore_EXT_IOIsr[255:192] | 0x1818 | 路由至当前处理器核的扩展 10 中断[255:192]的中断状态 |

### 9.3.3 扩展 IO 中断触发寄存器

为了支持扩展 I0 中断的动态分发,在配置寄存器中增加了一个扩展 I0 中断触发寄存器,用于将对应的 I0 中断置位。平时可以利用这个寄存器对中断进行调试或测试。



这个寄存器的说明如下:

表 9- 18 扩展 10 中断触发寄存器

| 名称               | 偏移地址   | 权限 | 描述              |
|------------------|--------|----|-----------------|
| EXT_IOI_send 0x1 | 0x1140 | WO | 扩展 I0 中断设置寄存器   |
|                  |        |    | [7:0]为期望设置的中断向量 |



# 10 温度传感器

龙芯 2K2000 内部集成温度传感器,可以通过采样寄存器进行观测,同时内部实现了灵活的高低温中断报警机制。

下面列出温度传感器相关的寄存器以及说明,这些寄存器的基地址与中断控制器一致。

### 10.1 温度传感器配置寄存器

本寄存器用来配置温度传感器的一些控制参数。

地址偏移: 0400h

默认值: 0000\_0000\_0000\_0001h

| 位域   | 名称          | 访问  | 描述                                                                      |
|------|-------------|-----|-------------------------------------------------------------------------|
| 63:7 | reserved    | R/W | 保留                                                                      |
| 6:4  | cluster_sel | R/W | 采样点选择: 0 为本地监测点,对于电压检测可选值有 1-7,对于温度检测可选值有 1-7。                          |
| 3:2  | mode        | R/W | 工作模式控制:<br>00-温度采样<br>10-电压采样<br>其他-保留                                  |
| 1    | rate        | R/W | 检测速率控制:<br>0-低速模式(10 <sup>2</sup> 0Hz)<br>1-高速模式(325 <sup>6</sup> 50Hz) |
| 0    | powerdown   | R/W | 低功耗控制,为1代表进入低功耗模式                                                       |

传感器监测点如下:

| 采样点编号 | 电压监测点   | 温度监测点 |
|-------|---------|-------|
| 1     | COREO   | COREO |
| 2     | Scache0 | -     |
| 3     | GPU     | GPU   |
| 4     | PCIe_F1 | PRG   |
| 5     | PCIe_GO | _     |
| 6     | RESUME  | _     |
| 7     | GMAC2   | _     |

## 10.2 温度传感器中断控制寄存器

本寄存器用来对温度传感器中断进行控制。

地址偏移: 0408h

默认值: 0000\_0000\_0000\_0001h

| 位域    | 名称         | 访问  | 描述                                                    |
|-------|------------|-----|-------------------------------------------------------|
| 63:41 | reserved   | R/W | 保留                                                    |
| 40    | low_int_en | R/W | 低温中断使能                                                |
| 39:32 | temp_low   | R/W | 低温中断触发温度设置:<br>[7]-温度正负指示,0代表正值,1代表负值;<br>[6:0]-摄氏温度值 |



| 31:9 | reserved    | R/W | 保留                                                    |
|------|-------------|-----|-------------------------------------------------------|
| 8    | high_int_en | R/W | 高温中断使能                                                |
| 7:0  | temp_high   | R/W | 高温中断触发温度设置:<br>[7]-温度正负指示,0代表正值,1代表负值;<br>[6:0]-摄氏温度值 |

对于高低温中断报警功能,分别有4组控制寄存器对其阈值进行设置。每组寄存器包含以下三个控制位:

GATE: 设置高温或低温的阈值。当输入温度高于高温阈值或低于低温阈值时,将会产生中断。需要注意的是,Gate值的设置应该是与0x428寄存器相对应的16位数值,而不是摄氏温度;

EN: 中断使能控制。置1之后该组寄存器的设置才有效;

SEL:输入温度选择。当前 2K2000 内部集成 1 个温度传感器,该寄存器用于配置选择哪个传感器的温度作为输入,因此只能选择 0。

高温中断控制寄存器中包含 4 组用于控制高温中断触发的设置位,低温中断控制寄存器中包含 4 组用于控制低温中断触发的设置位。另外还有一组寄存器用于显示中断状态,分别对应于高温中断和低温中断,对该寄存器进行任意写操作将清除中断状态。

这几个寄存器的具体描述如下, 其基地址为 0x1fe00000 或 0x3ff00000:

表 10-1 高低温中断寄存器说明

| 寄存器                             | 地址     | 控制    | 说明                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------------------------------|--------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 高温中断控制寄存器 Thsens_int_ctrl_Hi    | 0x1460 | RW RW | [7:0]: Hi_gate0: 高温阈值 0,超过这个温度将产生中断 [8:8]: Hi_en0: 高温中断使能 0 [11:10]: Hi_Se10: 选择高温中断 0 的温度传感器输入源 [23:16]: Hi_gate1: 高温阈值 1,超过这个温度将产生中断 [24:24]: Hi_en1: 高温中断使能 1 [27:26]: Hi_Se11: 选择高温中断 1 的温度传感器输入源 [39:32]: Hi_gate2: 高温阈值 2,超过这个温度将产生中断 [40:40]: Hi_en2: 高温中断使能 2 [43:42]: Hi_Se12: 选择高温中断 2 的温度传感器输入源 [55:48]: Hi_gate3: 高温阈值 3,超过这个温度将产生中断 [56:56]: Hi_en3: 高温问断 3 的温度传感器输入源 [59:58]: Hi_Se13: 选择高温中断 3 的温度传感器输入源 |
| 低温中断控制寄存器<br>Thsens_int_ctrl_Lo | 0x1468 | RW    | [7:0]: Lo_gate0: 低温阈值 0, 低于这个温度将产生中断 [8:8]: Lo_en0: 低温中断使能 0 [11:10]: Lo_Se10: 选择低温中断 0 的温度传感器输入源 [23:16]: Lo_gate1: 低温阈值 1, 低于这个温度将产生中断 [24:24]: Lo_en1: 低温中断使能 1 [27:26]: Lo_Se11: 选择低温中断 1 的温度传感器输入源 [39:32]: Lo_gate2: 低温阈值 2, 低于这个温度将产生中断 [40:40]: Lo_en2: 低温中断使能 2 [43:42]: Lo_Se12: 选择低温中断 2 的温度传感器输入源 [55:48]: Lo_gate3: 低温阈值 3, 低于这个温度将产生中断 [56:56]: Lo_en3: 低温阈值 3, 低于这个温度将产生中断 [56:56]: Lo_en3: 低温中断使能 3     |



| 中断状态寄存器<br>Thsens_int_status/clr | 0x1470 | RW | 中断状态寄存器,写 1 清除中断<br>[0]: 高温中断触发<br>[1]: 低温中断触发                                                                                                                                                            |
|----------------------------------|--------|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 高低温中断控制高位<br>Thsens_int_up       | 0x1478 | RW | [7:0] Hi_gate0 高 8 位<br>[15:8] Hi_gate1 高 8 位<br>[23:16] Hi_gate2 高 8 位<br>[31:24] Hi_gate3 高 8 位<br>[39:32] Lo_gate0 高 8 位<br>[47:40] Lo_gate1 高 8 位<br>[55:48] Lo_gate2 高 8 位<br>[63:56] Lo_gate3 高 8 位 |

## 10.3 温度传感器中断状态/清除寄存器

本寄存器用来对温度传感器中断进行控制。

地址偏移: 0410h

默认值: 0000\_0000\_0000\_0000h

| 位域    | 名称                | 访问  | 描述                             |
|-------|-------------------|-----|--------------------------------|
| 63:56 | temperature       | RO  | 摄氏温度值                          |
| 55    | reserved          | R/W | 保留                             |
| 54:52 | thsens_outcluster | RO  | 传感器配置的监测点                      |
| 51:49 | reserved          | R/W | 保留                             |
| 48    | thsens_outmode    | RO  | 传感器配置的监测模式<br>0: 温度模式; 1: 电压模式 |
| 47    | reserved          | R/W | 保留                             |
| 46    | thsens_overflow   | R/W | 传感器监测值溢出标志                     |
| 45:32 | thsens_data       | R/W | 传感器的原始数据                       |
| 31:2  | reserved          | R/W | 保留                             |
| 1     | int_high          | R/W | 中断状态指示,读取时获取高温中断状态,写1清零        |
| 0     | int_low           | R/W | 中断状态指示,读取时获取低温中断状态,写1清零        |

此外,还可以使用新增的摄氏温度寄存器直接读取当前的摄氏温度。这个寄存器可以使用 0x1FE00000 或者 0x3FF00000 为基地址的读操作进行访问,也可以使用配置寄存器指令进行直接访问,偏移地址为 0x0428。该寄存器描述如下:

表 10-2 扩展 I0 中断触发寄存器

| 名称                 | 偏移地址   | 权限 | 描述        |
|--------------------|--------|----|-----------|
| Thsens_Temperature | 0x0428 | R  | 温度传感器摄氏温度 |

# 10.4 高温自动降频设置

为了在高温环境中保证芯片的运行,可以设置令高温自动降频,使得芯片在超过预设范围时主动进行时钟分频,达到降低芯片翻转率的效果。

对于高温降频功能,有4组控制寄存器对其行为进行设置。每组寄存器包含以下四个控制位:

GATE: 设置高温或低温的阈值。当输入温度高于高温阈值或低于低温阈值时,将触发分频操作;

EN: 使能控制。置1之后该组寄存器的设置才有效;



SEL:输入温度选择。当前 2K2000 内部集成 1 个温度传感器,该寄存器用于配置选择哪个传感器的温度作为输入,因此只能选择 0。

FREQ: 分频数。当触发分频操作时,使用预设的 FREQ 对时钟进行分频,分频的模式受freqscale\_mode\_node 的控制。

其基地址为 0x1fe00000 或 0x3ff00000。

表 10-3 高温降频控制寄存器说明

|                                | 衣 10   | り回仰 | 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |
|--------------------------------|--------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 寄存器                            | 地址     | 控制  | 说明                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
| 高温降频控制寄存器<br>Thsens_freq_scale | 0x1480 | RW  | 四组设置优先级由高到低 [7:0]: Scale_gate0: 高温阈值 0,超过这个温度将降频 [8:8]: Scale_en0: 高温降频使能 0 [11:10]: Scale_Se10: 选择高温降频 0 的温度传感器输入源 [14:12]: Scale_freq0: 降频时的分频值 [23:16]: Scale_gate1: 高温阈值 1,超过这个温度将降频 [24:24]: Scale_en1: 高温降频使能 1 [27:26]: Scale_Se11: 选择高温降频 1 的温度传感器输入源 [30:28]: Scale_Se11: 选择高温降频 1 的温度传感器输入源 [30:32]: Scale_freq1: 降频时的分频值 [39:32]: Scale_gate2: 高温阈值 2,超过这个温度将降频 [40:40]: Scale_en2: 高温降频使能 2 [43:42]: Scale_Se12: 选择高温降频 2 的温度传感器输入源 [46:44]: Scale_freq2: 降频时的分频值 [55:48]: Scale_gate3: 高温阈值 3,超过这个温度将降频 [56:56]: Scale_en3: 高温降频使能 3 [59:58]: Scale_Se13: 选择高温降频 3 的温度传感器输入源 [62:60]: Scale_freq3: 降频时的分频值 |  |  |  |
| Thsens_freq_scale_up           | 0x1490 | RW  | 温度传感器控制寄存器高位 [7:0] Scale_Hi_gate0 高 8 位 [15:8] Scale_Hi_gate1 高 8 位 [23:16] Scale_Hi_gate2 高 8 位 [31:24] Scale_Hi_gate3 高 8 位 [39:32] Scale_Lo_gate0 高 8 位 [47:40] Scale_Lo_gate1 高 8 位 [55:48] Scale_Lo_gate2 高 8 位 [63:56] Scale_Lo_gate3 高 8 位                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |



# 11 SPI 控制器

串行外围设备接口 SPI 总线技术是多种微处理器、微控制器以及外围设备之间的一种 全双工、同步、串行数据接口标准。

### 11.1 访问地址

龙芯 2K2000 处理器集成了 2 个 SPI 控制器,其中 SPI1 可以配置为 4 线模式,SPI0 控制器的地址空间分配如表 11-1 所示,SPI1 通过 PCI 设备的方式访问。SPI0 控制器包括两个地址空间,分别如下:

 地址名称
 地址范围
 大小

 SPI Memory0
 0X1FC0\_0000-0X1FD0\_0000
 1MByte

 SPI Memory1
 0X1C00\_0000-0X1E00\_0000
 32MByte

 SPI Register
 0X1FE0\_01F0-0X1FE0\_01FF
 16Byte

表 11-1 SPIO 控制器地址空间分配

SPI 控制器寄存器物理地址基址为 0x1FE001F0。

SPI Memory 地址空间是系统启动时处理器最先访问的地址空间, 0x1C000000 的地址被自动路由至 SPI。

SPI Memory 空间可以通过 CPU 的读请求直接访问,需要注意的是 SPI Memory1 的最低 1M 字节与 SPI Memory0 空间重叠,仅仅是采用了不同的映射方式。

当需要对 SPI 进行其它操作时,比如发送命令,擦除 SPI Flash 等时,就要使用 SPI Register 空间对控制寄存器进行直接操作。

## 11.2 SPI 控制器结构

本系统集成的 SPI 控制器仅可作为主控端,所连接的是从设备。对于软件而言,SPI 控制器除了有若干 IO 寄存器外还有一段映射到 SPI Flash 的只读 memory 空间。如果将这段 memory 空间分配在 0x1c000000,复位后不需要软件干预就可以直接访问,从而支持处理器从 SPI Flash 启动。

## 11.3 配置寄存器

表 11-2 SPI 配置寄存器列表

| 偏移 | 名称            | 描述    |
|----|---------------|-------|
| 0  | SPCR          | 控制寄存器 |
| 1  | SPSR          | 状态寄存器 |
| 2  | TxFIFO/RxFIFO | 数据寄存器 |
| 3  | SPER          | 外部寄存器 |



| 4 | SFC_PARAM  | 参数控制寄存器 |
|---|------------|---------|
| 5 | SFC_SOFTCS | 片选控制寄存器 |
| 6 | SFC_TIMING | 时序控制寄存器 |

### 11.3.1 控制寄存器(SPCR)

偏移地址: 0x0

表 11-3 SPI 控制寄存器 (SPCR)

| 位域  | 名称   | 访问  | 初值 | 描述                               |
|-----|------|-----|----|----------------------------------|
| 7   | spie | R/W | 0  | 中断输出使能信号高有效                      |
| 6   | spe  | R/W | 0  | 系统工作使能信号高有效                      |
| 5   | -    | -   | 0  | 保留                               |
| 4   | mstr | -   | 1  | master 模式选择位,此位一直保持 1            |
| 3   | cpol | R/W | 0  | 时钟极性位                            |
| 2   | cpha | R/W | 0  | 时钟相位位1则相位相反,为0则相同                |
| 1:0 | spr  | R/W | 0  | sclk_o 分频设定,需要与 sper 的 spre 一起使用 |

### 11.3.2 状态寄存器(SPSR)

偏移地址: 0x1

表 11-4 SPI 状态寄存器(SPSR)

| 位域  | 名称      | 访问  | 初值 | 描述                          |
|-----|---------|-----|----|-----------------------------|
| 7   | spif    | R/W | 0  | 中断标志位1表示有中断申请,写1则清零         |
| 6   | wcol    | R/W | 0  | 写寄存器溢出标志位为1表示已经溢出,写1则<br>清零 |
| 5:4 | _       | _   | 0  | 保留                          |
| 3   | wffull  | R   | 0  | 写寄存器满标志 1 表示已经满             |
| 2   | wfempty | R   | 1  | 写寄存器空标志 1 表示空               |
| 1   | rffull  | R   | 0  | 读寄存器满标志 1 表示已经满             |
| 0   | rfempty | R   | 1  | 读寄存器空标志 1 表示空               |

### 11.3.3 数据寄存器(TxFIFO/RxFIFO)

偏移地址: 0x2

表 11-5 SPI 数据寄存器 (TxFIFO/RXFIFO)

| 位域  | 名称               | 访问     | 初值 | 描述               |
|-----|------------------|--------|----|------------------|
| 7:0 | TxFIF0<br>RxFIF0 | W<br>R | -  | 数据发送端口<br>数据接收端口 |

### 11.3.4 外部寄存器(SPER)

偏移地址: 0x3



| 位域  | 名称   | 访问  | 初值 | 描述                                            |
|-----|------|-----|----|-----------------------------------------------|
| 7:6 | icnt | R/W | 0  | 传输完多少个字节后发中断<br>00:1<br>01:2<br>10:3<br>11:4  |
| 5:3 | _    | -   | -  | 保留                                            |
| 2   | mode | R/W | 0  | spi 接口模式控制<br>0: 采样与发送时机同时<br>1: 采样与发送时机错开半周期 |
| 1:0 | spre | R/W | 0  | 与 spr 一起设定分频的比率                               |

表 11-7 SPI 分频系数

| spre | 00 | 00 | 00 | 00 | 01 | 01 | 01  | 01  | 10  | 10   | 10   | 10   |
|------|----|----|----|----|----|----|-----|-----|-----|------|------|------|
| spr  | 00 | 01 | 10 | 11 | 00 | 01 | 10  | 11  | 00  | 01   | 10   | 11   |
| 分频系数 | 2  | 4  | 16 | 32 | 8  | 64 | 128 | 256 | 512 | 1024 | 2048 | 4096 |

## 11.3.5 参数控制寄存器 (SFC\_PARAM)

偏移地址: 0x4

表 11-8 SPI 参数控制寄存器 (SFC\_PARAM)

| 位域  | 名称        | 访问  | 初值 | 描述                              |
|-----|-----------|-----|----|---------------------------------|
| 7:4 | clk_div   | R/W | 2  | 时钟分频数选择<br>分频系数与{spre, spr}组合相同 |
| 3   | dual_io   | R/W | 0  | 双 I/0 模式,优先级高于快速读               |
| 2   | fast_read | R/W | 0  | 快速读模式                           |
| 1   | burst_en  | R/W | 0  | SPI flash 支持连续地址读模式             |
| 0   | memory_en | R/W | 1  | SPI flash 读使能,无效时 csn[0]可由软件控制。 |

### 11.3.6 片选控制寄存器(SFC\_SOFTCS)

偏移地址: 0x5

表 11-9 SPI 片选控制寄存器 (SFC\_SOFTCS)

| 位域  | 名称   | 访问  | 初值 | 描述                       |
|-----|------|-----|----|--------------------------|
| 7:4 | csn  | R/W | 0  | csn 引脚输出值                |
| 3:0 | csen | R/W | 0  | 为 1 时对应位的 csn 线由 7:4 位控制 |

# 11.3.7 时序控制寄存器 (SFC\_TIMING)

偏移地址: 0x6

表 11- 10 SPI 时序控制寄存器(SFC\_TIMING)

| 位域  | 名称       | 访问 | 初值 | 描述              |
|-----|----------|----|----|-----------------|
|     |          |    |    | 采样延迟,用于调整读的时序。  |
| 7:4 | samp_dly | RW | 0  | 1,表示延迟一个单位;     |
|     |          |    |    | 2,表示延迟两个单位,以此类推 |



| 3   | quad_io | RW  | 0 | 4线模式使能,1有效                                                              |
|-----|---------|-----|---|-------------------------------------------------------------------------|
| 2   | tFAST   | R/W | 0 | SPI flash 读采样模式         0: 上沿采样,间隔半个 SPI 周期         1: 上沿采样,间隔一个 SPI 周期 |
| 1:0 | tCSH    | R/W | 3 | SPI Flash 的片选信号最短无效时间,以分频后时钟周期 T 计算00: 1T 01: 2T 10: 4T 11: 8T          |

### 11.3.8 自定义控制寄存器 (CTRL)

偏移地址: 0x8

表 11- 11 SPI Flash 自定义控制寄存器

| 位域  | 名称      | 访问 | 初值 | 描述              |
|-----|---------|----|----|-----------------|
| 7:4 | nbyte   | RW | 0  | 一次传输的字节数        |
| 3:2 | reserve | RW | 0  | 保留              |
| 1   | nbmode  | RW | 0  | 多字节传输模式         |
| 0   | start   | RW | 0  | 开始多字节传输,完成后自动清零 |

### 11.3.9 自定义命令寄存器 (CMD)

偏移地址: 0x9

表 11- 12 SPI Flash 自定义命令寄存器

| 位域  | 名称  | 访问 | 初值 | 描述                  |
|-----|-----|----|----|---------------------|
| 7:0 | cmd | RW | 0  | 设置发送给 spi flash 的命令 |

### 11.3.10 自定义数据寄存器 0 (BUF0)

偏移地址: 0xa

表 11-13 SPI Flash 自定义数据寄存器 0

| 位域  | 名称   | 访问 | 初值 | 描述                                                           |
|-----|------|----|----|--------------------------------------------------------------|
| 7:0 | buf0 | RW | 0  | 向 SPI 发送写命令时,该寄存器配置发送的第一个字节的数据;向 SPI 发送读命令时,该寄存器存储第一个读回来的数据。 |

### 11.3.11 自定义数据寄存器 1 (BUF1)

偏移地址: 0xb

表 11- 14 SPI Flash 自定义数据寄存器 1

| 位域  | 名称   | 访问 | 初值 | 描述                          |
|-----|------|----|----|-----------------------------|
| 7:0 | buf1 | RW | 0  | 向 SPI 发送写命令时,该寄存器配置发送的第二个字节 |



|  |  | 的数据; | 向   | SPI | 发送读句 | 命令时, | 该寄存器存储第二个读 |
|--|--|------|-----|-----|------|------|------------|
|  |  | 回来的数 | 女据。 | 0   |      |      |            |

### 11.3.12 自定义时序寄存器 0 (TIMERO)

偏移地址: 0xc

表 11- 15 SPI Flash 自定义时序寄存器 0

| 位域  | 名称    | 访问 | 初值 | 描述               |
|-----|-------|----|----|------------------|
| 7:0 | time0 | RW | 0  | 自定义命令所需时间值的低 8 位 |

### 11.3.13 自定义时序寄存器 1 (TIMER1)

偏移地址: 0xd

表 11- 16 SPI Flash 自定义时序寄存器 1

| 位域  | 名称    | 访问 | 初值 | 描述              |
|-----|-------|----|----|-----------------|
| 7:0 | Time1 | RW | 0  | 自定义命令所需时间值的中间8位 |

### 11.3.14 自定义时序寄存器 2 (TIMER2)

偏移地址: 0xe

表 11- 17 SPI Flash 自定义时序寄存器 2

| 位域  | 名称    | 访问 | 初值 | 描述             |
|-----|-------|----|----|----------------|
| 7:0 | Time2 | RW | 0  | 自定义命令所需时间值的高8位 |

# 11.4 接口时序

### 11.4.1 SPI 主控制器接口时序



图 11-1 SPI 主控制器接口时序



### 11.4.2 SPI Flash 访问时序



图 11-2 SPI Flash 标准读时序



图 11-3 SPI Flash 快速读时序



图 11- 4 SPI Flash 双向 I/O 读时序



### 11.5 软件编程指南

### 11.5.1 SPI 主控制器的读写操作

### ● 模块初始化.

- 停止 SPI 控制器工作,对控制寄存器 spcr 的 spe 位写 0
- 重置状态寄存器 spsr,对寄存器写入 8'b1100 0000
- 设置外部寄存器 sper,包括中断申请条件 sper[7:6]和分频系数 sper[1:0], 具体参考寄存器说明
- 配置 SPI 时序,包括 spcr 的 cpol、cpha 和 sper 的 mode 位。mode 为 1 时是标准 SPI 实现,为 0 时为兼容模式。
- 配置中断使能, spcr 的 spie 位
- 启动 SPI 控制器,对控制寄存器 spcr 的 spe 位写 1

### ● 模块的发送/传输操作

- 往数据传输寄存器写入数据
- 传输完成后从数据传输寄存器读出数据。由于发送和接收同时进行,即使 SPI 从设备没有发送有效数据也必须进行读出操作。

### ● 中断处理

- 接收到中断申请
- 读状态寄存器 spsr 的值,若 spsr[2]为1则表示数据发送完成,若 spsr[0] 为1则表示已经接收数据
- 读或写数据传输寄存器
- 往状态寄存器 spsr 的 spif 位写 1,清除控制器的中断申请

#### 11.5.2 硬件 SPI Flash 读

#### 初始化

- 将 SFC\_PARAM 的 memory\_en 位写 1。当 SPI 被选为启动设备时此位复位为 1。
- 设置读参数(时钟分频、连续地址读、快速读、双 I/0、tCSH等)。这些参数 复位值均为最保守的值。

#### ● 更改参数

如果所使用的 SPI Flash 支持更高的频率或者提供增强功能,修改相应参数可以大大加快 Flash 的访问速度。参数的修改不需要关闭 SPI Flash 读使能 (memory\_en)。具体参考寄存器说明。



### 11.5.3 混合访问 SPI Flash 和 SPI 主控制器

### ● 对 SPI Flash 进行读以外的访问

将 SPI Flash 读使能关闭后,软件就可直接控制 csn[0],并通过 SPI 主控制器访问 SPI 总线。这意味着在进行此操作时,不能从 SPI Flash 中取指。

除了读以外, SPI Flash 还实现了很多命令(如擦除、写入), 具体参见相关 Flash 的文档。



# 12 Local IO 控制器

## 12.1 访问地址及引脚复用

表 12-1 Local IO 地址空间分配

| 起始地址        | 结束名称        | 名称   | 说明                              |
|-------------|-------------|------|---------------------------------|
| 0x1C00_0000 | 0x1CFF_FFFF | 启动空间 | 当引脚设置为 LIO 启动时可访问,其它情况下<br>不可访问 |
| 0x1D00_0000 | 0x1DFF_FFFF | 存储空间 |                                 |

对于 Local IO 模块,使用时要注意将对应的引脚设置为相应的功能。

与LocalIO相关的引脚设置寄存器为5.1节中的lio\_sel。

### 12.2 Local IO 控制器功能概述

LocalIO 控制器提供了简单外设访问接口,主要用于连接系统启动 ROM。它对外提供一个片选,具有可配置的数据位宽和访问延迟。其中 wait 参数指 liord 或 liowr 信号为低的周期数减一,读写时序可参考图 10-1,图 10-2。当数据位宽为 16 时,送出的地址由 CPU 物理地址右移一位得到。



图 12- 1Local IO 读时序





图 12- 2Local IO 写时序

#### 说明:

- 图中 clock 信号实际并不存在,只是为了方便时序描述
- A H 代表地址 bit23-bit29(8 位模式)/bit24-bit30(16 位模式)
- A M 代表地址 bit7-bit22(8 位模式)/bit8-bit23(16 位模式)
- A L 代表低 7 位地址
- 在 big\_mem 设置为 0 时,第 4 拍波形不存在,第 4 拍之后的波形向前推一拍
- LIO\_WRN 和 LIO\_RDN 低有效时间与 LIO clock\_period\_i 设置有关:
  - LIO clock\_period\_i 设置为1时-低电平持续8拍;
  - LIO clock period i 设置为2时-低电平持续16拍;
  - LIO clock\_period\_i 设置为 3/0 时-低电平持续 32 拍;
- 一次 CS 有效期间可能出现多次读写操作,以上时序图仅作为一种示例。



# 13 DDR4 控制器

## 13.1 DDR4 内存接口

芯片集成的内存接口遵守 DDR4 SDRAM 行业标准 (JESD79-4)。

#### 访问地址

DDR4 内存控制器包括两个地址空间:内存控制器的寄存器配置空间和内存的存储空间。 当配置参数 mc\_disable\_reg = 0 时,发给内存的访问都为寄存器配置访问;当配置参数 mc\_disable\_reg = 1 时,发给内存的访问都为内存的读写访问。

### 13.2 DDR4 SDRAM 控制器功能概述

内存支持的片选个数为 2, 一共含有 21 位的地址总线 (即: 17 位的行列地址总线、2 位逻辑 Bank 总线和 2 位逻辑 Bank Group 总线, 其中行列地址总线与 RASn、CASn 和 Wen 复用)。在具体选择使用不同内存芯片类型时,可以调整 DDR4 控制器参数设置进行支持。其中,行地址(ROW)数为 17, 列地址(COL)数为 12。

芯片集成的内存内存控制器具有如下特征:

- 接口上命令、读写数据全流水操作;
- 内存命令合并、排序提高整体带宽;
- 配置寄存器读写端口,可以修改内存设备的基本参数;
- 内建动态延迟补偿电路(DCC),用于数据的可靠发送和接收;
- 支持 DDR4 SDRAM, 且参数配置支持 x8、x16 颗粒;
- 控制器与 PHY 频率比 1/2;
- 支持数据传输速率范围为 800Mbps-2400Mbps。

## 13.3 DDR4 SDRAM 读操作协议

DDR4 SDRAM 读操作的协议如图 13-1 所示。在图中命令(Command,简称 CMD)由 ACT\_n、RAS\_n、CAS\_n 和 WE\_n 共 4 个信号组成。对于读操作,ACT\_n=1,RAS\_n=1, CAS\_n=0, WE\_n=1。





图 13-1 DDR4 SDRAM 读操作协议

### 13.4 DDR4 SDRAM 写操作协议

DDR4 SDRAM 写操作的协议如图 13-2 示。在图中命令 CMD 由 ACT\_n、RAS\_n、CAS\_n 和 WE\_n 共 4 个信号组成。对于写操作,ACT\_n=1,RAS\_n=1,CAS\_n=0,WE\_n=0。另外,与读操作不同,写操作可以通过 DQM 来标识写操作的数据掩码,即需要写入的字节数,DQM 与图中 DQS 信号同步。



图 13-2 DDR4 SDRAM 写操作协议

# 13.5 DDR4 SDRAM 参数配置格式

内存控制器的参数列表

表 13-1 内存控制器软件可见参数列表

| Offset | 63:56 | 55:48             | 47:40                 | 39:32             | 31:24      | 23:16        | 15:8              | 7:0                 |
|--------|-------|-------------------|-----------------------|-------------------|------------|--------------|-------------------|---------------------|
| PHY    |       |                   |                       |                   |            |              |                   |                     |
| 0x0000 |       |                   |                       |                   |            |              | version(RD)       |                     |
| 0x0008 |       | switch_by<br>te48 | x4_mode               | ddr3_mode         |            |              | capability        | (RD)                |
| 0x0010 |       |                   |                       |                   |            |              | dram_init<br>(RD) | init_start          |
| 0x0018 |       |                   |                       |                   |            |              |                   |                     |
| 0x0020 |       |                   |                       |                   |            |              | preamble2         | rdfifo_vali<br>d    |
| 0x0028 |       | rdfifo_empt       | y (RD)                |                   |            | Overflow(RD) |                   |                     |
| 0x0030 |       | dll_value<br>(RD) | dll_init_<br>done(RD) | dll_lock_mod<br>e | dll_bypass | dll_adj_cnt  | dll_incre<br>ment | dll_start_p<br>oint |



|                  |                         |                                       |                                        | T                         |                         |                           | dll_close             |                         |
|------------------|-------------------------|---------------------------------------|----------------------------------------|---------------------------|-------------------------|---------------------------|-----------------------|-------------------------|
| 0x0038           |                         |                                       |                                        | dll_dbl_fix               |                         |                           | _disable              | dll_ck                  |
| 0x0040           |                         |                                       |                                        |                           |                         |                           | clken_ckc             |                         |
| 0x0048           |                         |                                       |                                        |                           |                         |                           | a a                   |                         |
| 0x0050           |                         |                                       |                                        |                           |                         |                           | alkan da              |                         |
| 0x0058           |                         |                                       |                                        |                           |                         |                           | clken_ds_<br>0        |                         |
| 0x0060           |                         |                                       |                                        |                           |                         |                           | 11 1                  |                         |
| 0x0068           |                         |                                       |                                        |                           |                         |                           | clken_ds_<br>1        |                         |
| 0x0070           |                         |                                       |                                        |                           |                         |                           |                       |                         |
| 0x0078           |                         |                                       |                                        |                           |                         |                           | clken_ds_<br>2        |                         |
| 0x0080           |                         |                                       |                                        |                           |                         |                           |                       |                         |
| 0x0088           |                         |                                       |                                        |                           |                         |                           | clken_ds_<br>3        |                         |
| 0x0090           |                         |                                       |                                        |                           |                         |                           |                       |                         |
| 0x0098           |                         |                                       |                                        |                           |                         |                           | clken_ds_<br>4        | ds4_en                  |
| 0x00a0           |                         |                                       |                                        |                           |                         |                           |                       |                         |
| 0x00a8           |                         |                                       |                                        |                           |                         |                           | clken_ds_<br>5        |                         |
| 0x00b0           |                         |                                       |                                        |                           |                         |                           |                       |                         |
| 0x00b8           |                         |                                       |                                        |                           |                         |                           | clken_ds_<br>6        |                         |
| 0x00c0           |                         |                                       |                                        |                           |                         |                           |                       |                         |
| 0x00c8           |                         |                                       |                                        |                           |                         |                           | clken_ds_<br>7        |                         |
| 0x00d0           |                         |                                       |                                        |                           |                         |                           |                       |                         |
| 0x00d8           |                         |                                       |                                        |                           |                         |                           | clken_ds_<br>8        | ecc_ds_en               |
| 0x00e0           |                         |                                       |                                        |                           |                         |                           |                       | vref_slice_<br>enable   |
|                  |                         |                                       |                                        |                           |                         |                           |                       |                         |
| 0x0100           |                         |                                       |                                        |                           | dll_1xdly_0             | dll_1xgen_0               | dll_wrdqs<br>_0       | dll_wrdq_0              |
| 0x0108           |                         | vref_samp<br>le 0                     | vrefclk_i<br>nv 0                      | dll_vref_0                | vref_dly_0              | dll_gate_0                | dll_rddqs<br>1 0      | dll_rddqs0_<br>0        |
| 0x0110           | rdodt_ctrl_<br>0        | rdgate_le<br>n 0                      | rdgate_mo<br>de 0                      | rdgate_ctrl_<br>0         |                         |                           | dqs_oe_ct<br>rl 0     | dq_oe_ctrl_<br>0        |
| 0x0118           |                         |                                       |                                        |                           | dly_2x_0                |                           | redge_sel             | rddqs_phase<br>0(RD)    |
| 0x0120           | w_bdly0_0[3<br>1:28]    | w_bdly0_0<br>[27:24]                  | w_bdly0_0<br>[23:20]                   | w_bdly0_0[19<br>:16]      | w_bdly0_0[1<br>5:12]    | w_bdly0_0[1<br>1:8]       | w_bdly0_0<br>[7:4]    | w_bdly0_0[3<br>:0]      |
| 0x0128           | 1120]                   | w_bdly0_0<br>[59:56]                  | w_bdly0_0<br>[55:52]                   | w_bdly0_0[51<br>:48]      | w_bdly0_0[4<br>7:44]    | w_bdly0_0[4<br>3:40]      | w_bdly0_0<br>[39:36]  | w_bdly0_0[3<br>5:32]    |
| 0x0130           | w_bdly1_0[2<br>4:21]    | w_bdly1_0<br>[20:18]                  | w_bdly1_0<br>[17:15]                   | w_bdly1_0[14<br>:12]      | w_bdly1_0[1<br>1:9]     | w_bdly1_0[8<br>:6]        | w_bdly1_0<br>[5:3]    | w_bdly1_0[2<br>:0]      |
| 0x0138           | 7.21                    | [20.10]                               | [11.10]                                | .12]                      | 1.0]                    | .0]                       | [0.0]                 | w_bdly1_0[2<br>7:26]    |
| 0x0140           |                         |                                       |                                        |                           |                         |                           | rg_bdly_0<br>[7:4]    | rg_bdly_0[3<br>:0]      |
| 0x0148           |                         |                                       |                                        |                           |                         |                           | [1.4]                 | .0]                     |
| 0x0150           | rdqsp_bdly_<br>0[31:28] | rdqsp_bdl<br>y_0[27:24                | rdqsp_bdl<br>y_0[23:20                 | rdqsp_bdly_0<br>[19:16]   | rdqsp_bdly_<br>0[15:12] | rdqsp_bdly_<br>0[11:8]    | rdqsp_bdl<br>y_0[7:4] | rdqsp_bdly_<br>0[3:0]   |
| 0x0158           |                         | J                                     |                                        |                           |                         |                           |                       | rdqsp_bdly_<br>0[35:32] |
| 0x0160           | rdqsn_bdly_<br>0[31:28] | rdqsn_bdl<br>y_0[27:24                | rdqsn_bdl<br>y_0[23:20                 | rdqsn_bdly_0<br>[19:16]   | rdqsn_bdly_<br>0[15:12] | rdqsn_bdly_<br>0[11:8]    | rdqsn_bdl<br>y_0[7:4] | rdqsn_bdly_<br>0[3:0]   |
| 0x0168           |                         | 1                                     | 1                                      |                           |                         |                           |                       | rdqsn_bdly_<br>0[35:32] |
| 0x0170           | rdq_bdly_0[<br>24:21]   | rdq_bdly_<br>0[20:18]                 | rdq_bdly_<br>0[17:15]                  | rdq_bdly_0[1<br>4:12]     | rdq_bdly_0[<br>11:9]    | rdq_bdly_0[<br>8:6]       | rdq_bdly_<br>0[5:3]   | rdq_bdly_0[<br>2:0]     |
| 0x0178           | u 1.u1]                 | 0[20.10]                              | 0[11.10]                               | 1.14                      | 11.0]                   | 3.01                      | 0[0.0]                | rdq_bdly_0[<br>27:26]   |
|                  |                         |                                       | 1                                      | 1                         | -                       |                           | dll wrdgs             | 21.20]                  |
| 0x0180           |                         |                                       |                                        |                           | dll_1xdly_1             | dll_1xgen_1               |                       | dll_wrdq_1              |
| 0x0180<br>0x0188 |                         | vref_samp                             | vrefclk_i                              | dll_vref_1                | dll_1xdly_1 vref_dly_1  | dll_1xgen_1<br>dll_gate_1 | _1<br>dll_rddqs       | dll_wrdq_1 dll_rddqs0_  |
|                  | rdodt_ctrl_             | vref_samp<br>le_1<br>rdgate_le<br>n 1 | vrefclk_i<br>nv_1<br>rdgate_mo<br>de 1 | dll_vref_1 rdgate_ctrl_ 1 |                         |                           | 1                     |                         |



| 0x01a0 | w_bdly0_1[3<br>1:28]    | w_bdly0_1<br>[27:24]   | w_bdly0_1<br>[23:20]   | w_bdly0_1[19<br>:16]             | w_bdly0_1[1<br>5:12]            | w_bdly0_1[1<br>1:8]    | w_bdly0_1<br>[7:4]      | w_bd1y0_1[3                  |
|--------|-------------------------|------------------------|------------------------|----------------------------------|---------------------------------|------------------------|-------------------------|------------------------------|
| 0x01a8 | 1.20]                   | w_bdly0_1<br>[59:56]   | w_bdly0_1<br>[55:52]   | w_bdly0_1[51                     | w_bdly0_1[4                     | w_bdly0_1[4<br>3:40]   | w_bdly0_1<br>[39:36]    | w_bdly0_1[3<br>5:32]         |
| 0x01b0 | w_bdly1_1[2<br>4:21]    | w_bdly1_1<br>[20:18]   | w_bdly1_1<br>[17:15]   | :48]<br>  w_bdly1_1[14<br>  :12] | 7:44<br>  w_bdly1_1[1<br>  1:9] | w_bdly1_1[8<br>:6]     | w_bdly1_1<br>[5:3]      | w_bdly1_1[2<br>:0]           |
| 0x01b8 |                         | 2211213                |                        |                                  |                                 |                        |                         | w_bdly1_1[2<br>7:26]         |
| 0x01c0 |                         |                        |                        |                                  |                                 |                        | rg_bdly_1<br>[7:4]      | rg_bdly_1[3<br>:0]           |
| 0x01c8 |                         |                        |                        |                                  |                                 |                        |                         |                              |
| 0x01d0 | rdqsp_bd1y_<br>1[31:28] | rdqsp_bdl<br>y_1[27:24 | rdqsp_bdl<br>y_1[23:20 | rdqsp_bdly_1<br>[19:16]          | rdqsp_bdly_<br>1[15:12]         | rdqsp_bdly_<br>1[11:8] | rdqsp_bdl<br>y_1[7:4]   | rdqsp_bdly_<br>1[3:0]        |
| 0x01d8 |                         |                        | -                      |                                  |                                 |                        |                         | rdqsp_bdly_<br>1[35:32]      |
| 0x01e0 | rdqsn_bdly_<br>1[31:28] | rdqsn_bdl<br>y_1[27:24 | rdqsn_bdl<br>y_1[23:20 | rdqsn_bdly_1<br>[19:16]          | rdqsn_bdly_<br>1[15:12]         | rdqsn_bdly_<br>1[11:8] | rdqsn_bdl<br>y_1[7:4]   | rdqsn_bdly_<br>1[3:0]        |
| 0x01e8 |                         |                        |                        |                                  |                                 |                        |                         | rdqsn_bdly_<br>1[35:32]      |
| 0x01f0 | rdq_bdly_1[<br>24:21]   | rdq_bdly_<br>1[20:18]  | rdq_bdly_<br>1[17:15]  | rdq_bdly_1[1<br>4:12]            | rdq_bdly_1[<br>11:9]            | rdq_bdly_1[<br>8:6]    | rdq_bdly_<br>1[5:3]     | rdq_bdly_1[<br>2:0]          |
| 0x01f8 | 21.21]                  | 1[20.10]               | 1[11.10]               | 1.12]                            | 11.0]                           | 0.0]                   | 1[0.0]                  | rdq_bdly_1[<br>27:26]        |
| 0x0200 |                         |                        |                        |                                  | dll_1xdly_2                     | dll_1xgen_2            | dll_wrdqs               | dll_wrdq_2                   |
| 0x0208 |                         | vref_samp<br>le 2      | vrefclk_i<br>nv 2      | dll_vref_2                       | vref_dly_2                      | dll_gate_2             | dll_rddqs<br>1 2        | dll_rddqs0_<br>2             |
| 0x0210 | rdodt_ctrl_<br>2        | rdgate_le<br>n 2       | rdgate_mo<br>de 2      | rdgate_ctrl_<br>2                |                                 |                        | dqs_oe_ct               | dq_oe_ctrl_                  |
| 0x0218 | 2                       | 11_2                   | de_z                   | 2                                | dly_2x_2                        |                        | redge_sel               | rddqs_phase                  |
| 0x0220 | w_bdly0_2[3<br>1:28]    | w_bdly0_2<br>[27:24]   | w_bdly0_2<br>[23:20]   | w_bdly0_2[19<br>:16]             | w_bdly0_2[1<br>5:12]            | w_bdly0_2[1<br>1:8]    | 2<br>w_bdly0_2<br>[7:4] | _2(RD)<br>w_bd1y0_2[3<br>:0] |
| 0x0228 | 1.20]                   | w_bdly0_2<br>[59:56]   | w_bdly0_2<br>[55:52]   | w_bdly0_2[51<br>:48]             | w_bdly0_2[4<br>7:44]            | w_bdly0_2[4<br>3:40]   | w_bdly0_2<br>[39:36]    | w_bdly0_2[3<br>5:32]         |
| 0x0230 | w_bdly1_2[2<br>4:21]    | w_bdly1_2<br>[20:18]   | w_bdly1_2<br>[17:15]   | w_bdly1_2[14<br>:12]             | w_bdly1_2[1<br>1:9]             | w_bdly1_2[8<br>:6]     | w_bdly1_2<br>[5:3]      | w_bdly1_2[2<br>:0]           |
| 0x0238 | 1101)                   | [20110]                | [11110]                | ,,,,                             | 1103                            |                        | [0.0]                   | w_bdly1_2[2<br>7:26]         |
| 0x0240 |                         |                        |                        |                                  |                                 |                        | rg_bdly_2<br>[7:4]      | rg_bdly_2[3                  |
| 0x0248 |                         |                        |                        |                                  |                                 |                        | [1.1]                   | .0]                          |
| 0x0250 | rdqsp_bdly_<br>2[31:28] | rdqsp_bdl<br>y_2[27:24 | rdqsp_bdl<br>y_2[23:20 | rdqsp_bdly_2<br>[19:16]          | rdqsp_bdly_<br>2[15:12]         | rdqsp_bdly_<br>2[11:8] | rdqsp_bdl<br>y_2[7:4]   | rdqsp_bdly_<br>2[3:0]        |
| 0x0258 |                         | -                      | -                      |                                  |                                 |                        |                         | rdqsp_bdly_<br>2[35:32]      |
| 0x0260 | rdqsn_bdly_<br>2[31:28] | rdqsn_bdl<br>y_2[27:24 | rdqsn_bdl<br>y_2[23:20 | rdqsn_bdly_2<br>[19:16]          | rdqsn_bdly_<br>2[15:12]         | rdqsn_bdly_<br>2[11:8] | rdqsn_bdl<br>y_2[7:4]   | rdqsn_bdly_<br>2[3:0]        |
| 0x0268 |                         |                        |                        |                                  |                                 |                        |                         | rdqsn_bdly_<br>2[35:32]      |
| 0x0270 | rdq_bdly_2[<br>24:21]   | rdq_bdly_<br>2[20:18]  | rdq_bdly_<br>2[17:15]  | rdq_bdly_2[1<br>4:12]            | rdq_bdly_2[<br>11:9]            | rdq_bdly_2[<br>8:6]    | rdq_bdly_<br>2[5:3]     | rdq_bdly_2[<br>2:0]          |
| 0x0278 | 21,21,                  | 2[20710]               | 2[11110]               | 1112]                            | 1110]                           | 0,0]                   | 2[0,0]                  | rdq_bdly_2[<br>27:26]        |
| 0x0280 |                         |                        |                        |                                  | dll_1xdly_3                     | dll_1xgen_3            | dll_wrdqs               | dll_wrdq_3                   |
| 0x0288 |                         | vref_samp<br>le 3      | vrefclk_i<br>nv 3      | dll_vref_3                       | vref_dly_3                      | dll_gate_3             | dll_rddqs<br>1 3        | dll_rddqs0_<br>3             |
| 0x0290 | rdodt_ctrl_<br>3        | rdgate_le<br>n 3       | rdgate_mo<br>de 3      | rdgate_ctrl_                     |                                 |                        | dqs_oe_ct               | dq_oe_ctrl_                  |
| 0x0298 | , ,                     | 1_0                    | 40_0                   |                                  | dly_2x_3                        | I                      | redge_sel               | rddqs_phase<br>3(RD)         |
| 0x02a0 | w_bdly0_3[3<br>1:28]    | w_bdly0_3<br>[27:24]   | w_bdly0_3<br>[23:20]   | w_bd1y0_3[19<br>:16]             | w_bdly0_3[1<br>5:12]            | w_bdly0_3[1<br>1:8]    | w_bdly0_3<br>[7:4]      | w_bdly0_3[3<br>:0]           |
| 0x02a8 |                         | w_bdly0_3<br>[59:56]   | w_bdly0_3<br>[55:52]   | w_bd1y0_3[51<br>:48]             | w_bdly0_3[4<br>7:44]            | w_bdly0_3[4<br>3:40]   | w_bdly0_3<br>[39:36]    | w_bdly0_3[3<br>5:32]         |
| 0x02b0 | w_bdly1_3[2<br>4:21]    | w_bdly1_3<br>[20:18]   | w_bdly1_3<br>[17:15]   | w_bdly1_3[14<br>:12]             | w_bdly1_3[1<br>1:9]             | w_bdly1_3[8<br>:6]     | w_bdly1_3<br>[5:3]      | w_bdly1_3[2<br>:0]           |
| 0x02b8 |                         |                        | [220]                  | ,                                |                                 | 3                      |                         | w_bdly1_3[2<br>7:26]         |
| 0x02c0 |                         |                        |                        |                                  |                                 |                        | rg_bdly_3<br>[7:4]      | rg_bdly_3[3                  |
| 0x02c8 |                         |                        |                        |                                  |                                 |                        |                         |                              |
| 0x02d0 | rdqsp_bdly_<br>3[31:28] | rdqsp_bdl<br>y_3[27:24 | rdqsp_bdl<br>y_3[23:20 | rdqsp_bdly_3<br>[19:16]          | rdqsp_bdly_<br>3[15:12]         | rdqsp_bdly_<br>3[11:8] | rdqsp_bdl<br>y_3[7:4]   | rdqsp_bdly_<br>3[3:0]        |
| 0x02d8 |                         |                        | -                      |                                  |                                 |                        |                         | rdqsp_bdly_<br>3[35:32]      |



| 0x02e0 | rdqsn_bdly_<br>3[31:28] | rdqsn_bdl<br>y_3[27:24<br>] | rdqsn_bdl<br>y_3[23:20<br>] | rdqsn_bdly_3<br>[19:16] | rdqsn_bdly_<br>3[15:12] | rdqsn_bdly_<br>3[11:8] | rdqsn_bdl<br>y_3[7:4] | rdqsn_bdly_<br>3[3:0]   |
|--------|-------------------------|-----------------------------|-----------------------------|-------------------------|-------------------------|------------------------|-----------------------|-------------------------|
| 0x02e8 |                         |                             | -                           |                         |                         |                        |                       | rdqsn_bdly_<br>3[35:32] |
| 0x02f0 | rdq_bdly_3[<br>24:21]   | rdq_bdly_<br>3[20:18]       | rdq_bdly_<br>3[17:15]       | rdq_bdly_3[1<br>4:12]   | rdq_bdly_3[<br>11:9]    | rdq_bdly_3[<br>8:6]    | rdq_bdly_<br>3[5:3]   | rdq_bdly_3[<br>2:0]     |
| 0x02f8 |                         |                             |                             |                         |                         |                        |                       | rdq_bdly_3[<br>27:26]   |
| 0x0300 |                         |                             |                             |                         | dll_1xdly_4             | dll_1xgen_4            | dll_wrdqs<br>_4       | dll_wrdq_4              |
| 0x0308 |                         | vref_samp<br>le_4           | vrefclk_i<br>nv_4           | dll_vref_4              | vref_dly_4              | dll_gate_4             | dll_rddqs<br>1_4      | dll_rddqs0_<br>4        |
| 0x0310 | rdodt_ctrl_<br>4        | rdgate_le<br>n_4            | rdgate_mo<br>de_4           | rdgate_ctrl_<br>4       |                         |                        | dqs_oe_ct<br>rl_4     | dq_oe_ctrl_<br>4        |
| 0x0318 |                         |                             |                             |                         | dly_2x_4                |                        | redge_sel<br>_4       | rddqs_phase<br>_4(RD)   |
| 0x0320 | w_bdly0_4[3<br>1:28]    | w_bdly0_4<br>[27:24]        | w_bdly0_4<br>[23:20]        | w_bdly0_4[19<br>:16]    | w_bdly0_4[1<br>5:12]    | w_bdly0_4[1<br>1:8]    | w_bdly0_4<br>[7:4]    | w_bdly0_4[3<br>:0]      |
| 0x0328 |                         | w_bdly0_4<br>[59:56]        | w_bdly0_4<br>[55:52]        | w_bdly0_4[51<br>:48]    | w_bdly0_4[4<br>7:44]    | w_bdly0_4[4<br>3:40]   | w_bdly0_4<br>[39:36]  | w_bdly0_4[3<br>5:32]    |
| 0x0330 | w_bdly1_4[2<br>4:21]    | w_bdly1_4<br>[20:18]        | w_bdly1_4<br>[17:15]        | w_bdly1_4[14<br>:12]    | w_bdly1_4[1<br>1:9]     | w_bdly1_4[8<br>:6]     | w_bdly1_4<br>[5:3]    | w_bdly1_4[2<br>:0]      |
| 0x0338 |                         |                             |                             |                         |                         |                        |                       | w_bdly1_4[2<br>7:26]    |
| 0x0340 |                         |                             |                             |                         |                         |                        | rg_bdly_4<br>[7:4]    | rg_bdly_4[3<br>:0]      |
| 0x0348 |                         | 1 11                        | 1 11                        |                         |                         |                        |                       |                         |
| 0x0350 | rdqsp_bdly_<br>4[31:28] | rdqsp_bdl<br>y_4[27:24<br>] | rdqsp_bdl<br>y_4[23:20<br>] | rdqsp_bdly_4<br>[19:16] | rdqsp_bdly_<br>4[15:12] | rdqsp_bdly_<br>4[11:8] | rdqsp_bdl<br>y_4[7:4] | rdqsp_bdly_<br>4[3:0]   |
| 0x0358 |                         |                             |                             |                         |                         |                        |                       | rdqsp_bdly_<br>4[35:32] |
| 0x0360 | rdqsn_bdly_<br>4[31:28] | rdqsn_bdl<br>y_4[27:24<br>] | rdqsn_bdl<br>y_4[23:20<br>] | rdqsn_bdly_4<br>[19:16] | rdqsn_bdly_<br>4[15:12] | rdqsn_bdly_<br>4[11:8] | rdqsn_bdl<br>y_4[7:4] | rdqsn_bdly_<br>4[3:0]   |
| 0x0368 |                         |                             |                             |                         |                         |                        |                       | rdqsn_bdly_<br>4[35:32] |
| 0x0370 | rdq_bdly_4[<br>24:21]   | rdq_bdly_<br>4[20:18]       | rdq_bdly_<br>4[17:15]       | rdq_bdly_4[1<br>4:12]   | rdq_bdly_4[<br>11:9]    | rdq_bdly_4[<br>8:6]    | rdq_bdly_<br>4[5:3]   | rdq_bdly_4[<br>2:0]     |
| 0x0378 |                         |                             |                             |                         |                         |                        |                       | rdq_bdly_4[<br>27:26]   |
| 0x0380 |                         |                             |                             |                         | dll_1xdly_5             | dll_1xgen_5            | dll_wrdqs<br>_5       | dll_wrdq_5              |
| 0x0388 |                         | vref_samp<br>le 5           | vrefclk_i<br>nv 5           | dll_vref_5              | vref_dly_5              | dll_gate_5             | dll_rddqs<br>1 5      | dll_rddqs0_<br>5        |
| 0x0390 | rdodt_ctrl_<br>5        | rdgate_le<br>n 5            | rdgate_mo<br>de 5           | rdgate_ctrl_<br>5       |                         |                        | dqs_oe_ct             | dq_oe_ctrl_<br>5        |
| 0x0398 |                         |                             |                             | -                       | dly_2x_5                |                        | redge_sel             | rddqs_phase<br>5(RD)    |
| 0x03a0 | w_bdly0_5[3<br>1:28]    | w_bdly0_5<br>[27:24]        | w_bdly0_5<br>[23:20]        | w_bdly0_5[19<br>:16]    | w_bdly0_5[1<br>5:12]    | w_bdly0_5[1<br>1:8]    | w_bdly0_5<br>[7:4]    | w_bdly0_5[3<br>:0]      |
| 0x03a8 |                         | w_bdly0_5<br>[59:56]        | w_bd1y0_5<br>[55:52]        | w_bdly0_5[51<br>:48]    | w_bdly0_5[4<br>7:44]    | w_bdly0_5[4<br>3:40]   | w_bdly0_5<br>[39:36]  | w_bdly0_5[3<br>5:32]    |
| 0x03b0 | w_bdly1_5[2<br>4:21]    | w_bdly1_5<br>[20:18]        | w_bdly1_5<br>[17:15]        | w_bdly1_5[14<br>:12]    | w_bdly1_5[1<br>1:9]     | w_bdly1_5[8<br>:6]     | w_bdly1_5<br>[5:3]    | w_bdly1_5[2<br>:0]      |
| 0x03b8 |                         |                             |                             |                         |                         |                        |                       | w_bdly1_5[2<br>7:26]    |
| 0x03c0 |                         |                             |                             |                         |                         |                        | rg_bdly_5<br>[7:4]    | rg_bdly_5[3<br>:0]      |
| 0x03c8 |                         |                             |                             |                         |                         |                        |                       |                         |
| 0x03d0 | rdqsp_bdly_<br>5[31:28] | rdqsp_bdl<br>y_5[27:24<br>] | rdqsp_bdl<br>y_5[23:20<br>] | rdqsp_bdly_5<br>[19:16] | rdqsp_bdly_<br>5[15:12] | rdqsp_bdly_<br>5[11:8] | rdqsp_bdl<br>y_5[7:4] | rdqsp_bdly_<br>5[3:0]   |
| 0x03d8 |                         |                             |                             |                         |                         |                        |                       | rdqsp_bdly_<br>5[35:32] |
| 0x03e0 | rdqsn_bdly_<br>5[31:28] | rdqsn_bdl<br>y_5[27:24<br>] | rdqsn_bdl<br>y_5[23:20<br>] | rdqsn_bdly_5<br>[19:16] | rdqsn_bdly_<br>5[15:12] | rdqsn_bdly_<br>5[11:8] | rdqsn_bdl<br>y_5[7:4] | rdqsn_bdly_<br>5[3:0]   |
| 0x03e8 |                         |                             |                             |                         |                         |                        |                       | rdqsn_bdly_<br>5[35:32] |
| 0x03f0 | rdq_bdly_5[<br>24:21]   | rdq_bdly_<br>5[20:18]       | rdq_bdly_<br>5[17:15]       | rdq_bdly_5[1<br>4:12]   | rdq_bdly_5[<br>11:9]    | rdq_bdly_5[<br>8:6]    | rdq_bdly_<br>5[5:3]   | rdq_bdly_5[<br>2:0]     |
| 0x03f8 |                         |                             |                             |                         |                         |                        |                       | rdq_bdly_5[<br>27:26]   |
| 0x0400 |                         |                             |                             |                         | dll_1xdly_6             | dll_1xgen_6            | dll_wrdqs<br>6        | dll_wrdq_6              |
| 0x0408 |                         | vref_samp<br>le_6           | vrefclk_i<br>nv_6           | dll_vref_6              | vref_dly_6              | dll_gate_6             | dll_rddqs<br>1_6      | dll_rddqs0_<br>6        |
| 0x0410 | rdodt_ctrl_<br>6        | rdgate_le<br>n_6            | rdgate_mo<br>de_6           | rdgate_ctrl_<br>6       |                         |                        | dqs_oe_ct<br>rl_6     | dq_oe_ctrl_<br>6        |
| 0x0418 |                         |                             |                             |                         | dly_2x_6                |                        | redge_sel<br>6        | rddqs_phase<br>6(RD)    |



| 0x0420 | w_bdly0_6[3<br>1:28]    | w_bdly0_6<br>[27:24]        | w_bdly0_6<br>[23:20]        | w_bd1y0_6[19<br>:16]    | w_bdly0_6[1<br>5:12]    | w_bdly0_6[1<br>1:8]    | w_bdly0_6<br>[7:4]    | w_bdly0_6[3<br>:0]      |
|--------|-------------------------|-----------------------------|-----------------------------|-------------------------|-------------------------|------------------------|-----------------------|-------------------------|
| 0x0428 |                         | w_bdly0_6<br>[59:56]        | w_bdly0_6<br>[55:52]        | w_bdly0_6[51<br>:48]    | w_bdly0_6[4<br>7:44]    | w_bdly0_6[4<br>3:40]   | w_bdly0_6<br>[39:36]  | w_bdly0_6[3<br>5:32]    |
| 0x0430 | w_bdly1_6[2<br>4:21]    | w_bdly1_6<br>[20:18]        | w_bdly1_6<br>[17:15]        | w_bdly1_6[14<br>:12]    | w_bdly1_6[1<br>1:9]     | w_bdly1_6[8<br>:6]     | w_bdly1_6<br>[5:3]    | w_bdly1_6[2<br>:0]      |
| 0x0438 | 1.21                    | [20.10]                     | [11.10]                     | .12]                    | 1.0]                    | .0]                    | [0.0]                 | w_bdly1_6[2<br>7:26]    |
| 0x0440 |                         |                             |                             |                         |                         |                        | rg_bdly_6<br>[7:4]    | rg_bdly_6[3             |
| 0x0448 |                         |                             |                             |                         |                         |                        | [,,,]                 | .0,                     |
| 0x0450 | rdqsp_bdly_<br>6[31:28] | rdqsp_bdl<br>y_6[27:24<br>] | rdqsp_bdl<br>y_6[23:20<br>] | rdqsp_bdly_6<br>[19:16] | rdqsp_bdly_<br>6[15:12] | rdqsp_bdly_<br>6[11:8] | rdqsp_bdl<br>y_6[7:4] | rdqsp_bdly_<br>6[3:0]   |
| 0x0458 |                         |                             |                             |                         |                         |                        |                       | rdqsp_bdly_<br>6[35:32] |
| 0x0460 | rdqsn_bdly_<br>6[31:28] | rdqsn_bdl<br>y_6[27:24<br>] | rdqsn_bdl<br>y_6[23:20<br>] | rdqsn_bdly_6<br>[19:16] | rdqsn_bdly_<br>6[15:12] | rdqsn_bdly_<br>6[11:8] | rdqsn_bdl<br>y_6[7:4] | rdqsn_bdly_<br>6[3:0]   |
| 0x0468 |                         |                             |                             |                         |                         |                        |                       | rdqsn_bdly_<br>6[35:32] |
| 0x0470 | rdq_bdly_6[<br>24:21]   | rdq_bdly_<br>6[20:18]       | rdq_bdly_<br>6[17:15]       | rdq_bdly_6[1<br>4:12]   | rdq_bdly_6[<br>11:9]    | rdq_bdly_6[<br>8:6]    | rdq_bdly_<br>6[5:3]   | rdq_bdly_6[<br>2:0]     |
| 0x0478 |                         |                             |                             |                         |                         |                        |                       | rdq_bdly_6[<br>27:26]   |
| 0x0480 |                         |                             |                             |                         | dll_1xdly_7             | dll_1xgen_7            | dll_wrdqs<br>7        | dll_wrdq_7              |
| 0x0488 |                         | vref_samp<br>le 7           | vrefclk_i<br>nv 7           | dll_vref_7              | vref_dly_7              | dll_gate_7             | dll_rddqs<br>1_7      | dll_rddqs0_<br>7        |
| 0x0490 | rdodt_ctrl_<br>7        | rdgate_le<br>n 7            | rdgate_mo<br>de 7           | rdgate_ctrl_<br>7       |                         |                        | dqs_oe_ct<br>rl 7     | dq_oe_ctrl_             |
| 0x0498 |                         |                             |                             |                         | dly_2x_7                | <u> </u>               | redge_sel             | rddqs_phase<br>7(RD)    |
| 0x04a0 | w_bdly0_7[3<br>1:28]    | w_bd1y0_7<br>[27:24]        | w_bdly0_7<br>[23:20]        | w_bdly0_7[19<br>:16]    | w_bdly0_7[1<br>5:12]    | w_bdly0_7[1<br>1:8]    | w_bdly0_7<br>[7:4]    | w_bdly0_7[3             |
| 0x04a8 | 1.20                    | w_bdly0_7<br>[59:56]        | w_bdly0_7<br>[55:52]        | w_bdly0_7[51<br>:48]    | w_bdly0_7[4<br>7:44]    | w_bdly0_7[4<br>3:40]   | w_bdly0_7<br>[39:36]  | w_bdly0_7[3<br>5:32]    |
| 0x04b0 | w_bdly1_7[2<br>4:21]    | w_bdly1_7<br>[20:18]        | w_bdly1_7<br>[17:15]        | w_bdly1_7[14<br>:12]    | w_bdly1_7[1<br>1:9]     | w_bdly1_7[8<br>:6]     | w_bdly1_7<br>[5:3]    | w_bdly1_7[2<br>:0]      |
| 0x04b8 |                         | 2                           | Carrag                      |                         |                         |                        |                       | w_bdly1_7[2<br>7:26]    |
| 0x04c0 |                         |                             |                             |                         |                         |                        | rg_bdly_7<br>[7:4]    | rg_bdly_7[3             |
| 0x04c8 |                         |                             |                             |                         |                         |                        |                       |                         |
| 0x04d0 | rdqsp_bdly_<br>7[31:28] | rdqsp_bd1<br>y_7[27:24<br>] | rdqsp_bdl<br>y_7[23:20<br>] | rdqsp_bdly_7<br>[19:16] | rdqsp_bdly_<br>7[15:12] | rdqsp_bdly_<br>7[11:8] | rdqsp_bdl<br>y_7[7:4] | rdqsp_bdly_<br>7[3:0]   |
| 0x04d8 |                         |                             |                             |                         |                         |                        |                       | rdqsp_bdly_<br>7[35:32] |
| 0x04e0 | rdqsn_bdly_<br>7[31:28] | rdqsn_bdl<br>y_7[27:24<br>] | rdqsn_bdl<br>y_7[23:20<br>] | rdqsn_bdly_7<br>[19:16] | rdqsn_bdly_<br>7[15:12] | rdqsn_bdly_<br>7[11:8] | rdqsn_bdl<br>y_7[7:4] | rdqsn_bdly_<br>7[3:0]   |
| 0x04e8 |                         |                             |                             |                         |                         |                        |                       | rdqsn_bdly_<br>7[35:32] |
| 0x04f0 | rdq_bdly_7[<br>24:21]   | rdq_bdly_<br>7[20:18]       | rdq_bdly_<br>7[17:15]       | rdq_bdly_7[1<br>4:12]   | rdq_bdly_7[<br>11:9]    | rdq_bdly_7[<br>8:6]    | rdq_bdly_<br>7[5:3]   | rdq_bdly_7[<br>2:0]     |
| 0x04f8 |                         |                             |                             |                         |                         |                        |                       | rdq_bdly_7[<br>27:26]   |
| 0x0500 |                         |                             |                             |                         | dll_1xdly_8             | dll_1xgen_8            | dll_wrdqs<br>_8       | dll_wrdq_8              |
| 0x0508 |                         | vref_samp<br>le 8           | vrefclk_i<br>nv 8           | dll_vref_8              | vref_dly_8              | dll_gate_8             | dll_rddqs<br>1 8      | dll_rddqs0_<br>8        |
| 0x0510 | rdodt_ctrl_<br>8        | rdgate_le<br>n_8            | rdgate_mo<br>de 8           | rdgate_ctrl_<br>8       |                         |                        | dqs_oe_ct             | dq_oe_ctrl_             |
| 0x0518 | -                       |                             |                             | -                       | dly_2x_8                | 1                      | redge_sel             | rddqs_phase<br>8(RD)    |
| 0x0520 | w_bdly0_8[3<br>1:28]    | w_bd1y0_8<br>[27:24]        | w_bd1y0_8<br>[23:20]        | w_bdly0_8[19<br>:16]    | w_bdly0_8[1<br>5:12]    | w_bdly0_8[1<br>1:8]    | w_bdly0_8<br>[7:4]    | w_bdly0_8[3<br>:0]      |
| 0x0528 |                         | w_bdly0_8<br>[59:56]        | w_bdly0_8<br>[55:52]        | w_bdly0_8[51<br>:48]    | w_bdly0_8[4<br>7:44]    | w_bdly0_8[4<br>3:40]   | w_bdly0_8<br>[39:36]  | w_bdly0_8[3<br>5:32]    |
| 0x0530 | w_bdly1_8[2<br>4:21]    | w_bdly1_8<br>[20:18]        | w_bdly1_8<br>[17:15]        | w_bdly1_8[14<br>:12]    | w_bdly1_8[1<br>1:9]     | w_bdly1_8[8<br>:6]     | w_bdly1_8<br>[5:3]    | w_bdly1_8[2<br>:0]      |
| 0x0538 | -                       |                             |                             |                         |                         | ad .                   |                       | w_bdly1_8[2<br>7:26]    |
| 0x0540 |                         |                             |                             |                         |                         |                        | rg_bdly_8<br>[7:4]    | rg_bdly_8[3<br>:0]      |
| 0x0548 |                         |                             |                             |                         |                         |                        |                       |                         |
| 0x0550 | rdqsp_bdly_<br>8[31:28] | rdqsp_bdl<br>y_8[27:24<br>] | rdqsp_bdl<br>y_8[23:20<br>] | rdqsp_bdly_8<br>[19:16] | rdqsp_bdly_<br>8[15:12] | rdqsp_bdly_<br>8[11:8] | rdqsp_bdl<br>y_8[7:4] | rdqsp_bdly_<br>8[3:0]   |
| 0x0558 |                         |                             |                             |                         |                         |                        |                       | rdqsp_bdly_<br>8[35:32] |



| 0x0560           | rdqsn_bdly_<br>8[31:28] | rdqsn_bdl<br>y_8[27:24   | rdqsn_bdl<br>y_8[23:20 | rdqsn_bdly_8<br>[19:16] | rdqsn_bdly_<br>8[15:12] | rdqsn_bdly_<br>8[11:8] | rdqsn_bdl<br>y_8[7:4] | rdqsn_bdly_<br>8[3:0]   |
|------------------|-------------------------|--------------------------|------------------------|-------------------------|-------------------------|------------------------|-----------------------|-------------------------|
| 0x0568           |                         |                          |                        |                         |                         |                        |                       | rdqsn_bdly_<br>8[35:32] |
| 0x0570           | rdq_bdly_8[<br>24:21]   | rdq_bdly_<br>8[20:18]    | rdq_bdly_<br>8[17:15]  | rdq_bdly_8[1<br>4:12]   | rdq_bdly_8[<br>11:9]    | rdq_bdly_8[<br>8:6]    | rdq_bdly_<br>8[5:3]   | rdq_bdly_8[<br>2:0]     |
| 0x0578           | 24.21]                  | 8[20.18]                 | 0[17.15]               | 4.12]                   | 11.9]                   | 0.0]                   | 0[0.3]                | rdq_bdly_8[             |
|                  |                         |                          |                        |                         |                         |                        |                       | 27:26]                  |
| 0x0700           | ca_train_ma             | wrdqs_dis                | ca invert              | ca_training_            | leveling cs             | tLVL DELAY             | leveling_             | leveling_mo             |
| 0x0708           | р                       | able                     |                        | mode                    |                         | mpr loc                | req(WR)<br>leveling_  | de<br>leveling_re       |
| 0x0710           | leveling_re             | leveling_                | leveling_              | leveling_res            | leveling_re             | leveling_re            | done(RD)              | ady(RD)<br>leveling_re  |
|                  | sp_7                    | resp_6                   | resp_5                 | p_4                     | sp_3                    | sp_2                   | resp_1                | sp_0<br>leveling re     |
| 0x0718           |                         |                          |                        |                         |                         |                        |                       | sp_8                    |
| 0x0720           |                         |                          |                        |                         |                         |                        |                       |                         |
|                  | Jfo otal Jo             |                          |                        |                         |                         |                        |                       |                         |
| 0x0800           | dfe_ctrl_ds             | pad_ctrl_ds<br>pad_reset | pad oplen              | 1 11                    |                         | pad_ctrl_ck            |                       |                         |
| 0x0808           |                         | _po                      | _ca                    | pad_opdly_ca            | 0 1 1                   | pad_ctrl_ca            |                       |                         |
| 0x0810           | vref_ctrl_ds_           |                          | vref_ctrl_d            |                         | vref_ctrl_ds_           |                        | vref_ctrl_d           |                         |
| 0x0818           | vref_ctrl_ds_           | _7                       | vref_ctrl_d            | s_6                     | vref_ctrl_ds_           | _5                     | vref_ctrl_d           |                         |
| 0x0820           |                         |                          |                        |                         |                         |                        | vref_ctrl_d           | ls_8                    |
| 0x0828           |                         |                          | 1 /                    | (70)                    |                         |                        | 1 .                   |                         |
| 0x0830           |                         |                          | pad_comp_o(            | RD)                     |                         |                        | pad_comp_i            |                         |
| 0x0838           | 1 . 1 1 .               |                          | 1 . 1 1                | 0                       | 1 ( 1 1 )               |                        | 1 . 1 1               |                         |
| 0x0840           | pad_ctrl_ds_3           |                          | pad_ctrl_ds            |                         | pad_ctrl_ds_            |                        | pad_ctrl_ds           |                         |
| 0x0848           | pad_ctrl_ds_7           | <i>i</i>                 | pad_ctrl_ds            | 0                       | pad_ctrl_ds_            |                        | pad_ctrl_ds           |                         |
| 0x0850           |                         |                          |                        |                         |                         |                        | pad_ctrl_ds           | _8                      |
| 0x0900           |                         |                          |                        | and anhana (DD)         |                         |                        | all. in               |                         |
| 0x0900           |                         | rdedge_soft              | i<br>                  | rd_phase(RD)            |                         |                        | clk_inv<br>rdedge inv |                         |
| CTL              |                         |                          |                        |                         |                         |                        | Tueuge_IIIV           |                         |
| 0x1000           | tMRD                    | tRP                      | tWLDQSEN               | tMOD                    | tXPR                    |                        | tCKE                  | tRESET                  |
| 0x1000           | CMIND                   | CIG                      | CWEDQUEN               | CMOD                    | tai k                   |                        | TORE                  | tODTL                   |
| 0x1010           | tREFretention           | n .                      |                        |                         | tRFC                    |                        | tREF                  | TODIE                   |
| 0x1018           | tCKESR                  | tXSRD                    | tXS                    |                         | tRFC dlr                |                        | CILLI                 | tREF_IDLE               |
| 0x1020           | CORLOR                  | CAGILD                   | tho                    |                         | tRDPDEN                 | tCPDED                 | tXPDLL                | tXP                     |
| 0x1028           |                         |                          |                        |                         | tZQperiod               | tZQCL                  | tZQCS                 | tZQ_CMD                 |
|                  |                         |                          |                        |                         | -,,                     |                        |                       |                         |
| 0x1040           | tRCD                    | tRRD_S_s1                | tRRD_L_s1              | tRRD dlr                |                         |                        |                       | tRAS_min                |
| 0x1048           |                         | r                        | r                      | tRTP                    | tWR_CRC_DM              | tWR                    | tFAW_slr              | tFAW                    |
| 0x1050           | tWTR_S_CRC_             | tWTR_L_CR                | tWTR_S                 | tWTR                    |                         | tCCD_dlr               | tCCD_S_s1             | tCCD_L_slr              |
| 0x1058           | DM                      | C_DM                     |                        |                         |                         |                        | r                     |                         |
| 0x1060           |                         |                          | tPHY_WRLA              | tWL                     |                         | tRDDATA                | tPHY_RDLA             | tRL                     |
| 0x1068           |                         |                          | T                      | tCAL                    |                         |                        | T                     | tPL                     |
| 0x1070           |                         |                          | tW2P_same              | tW2W_sameba             | tW2R sameba             | tR2P_sameba            | tR2W_same             | tR2R_sameba             |
| 0x1078           |                         |                          | ba<br>tW2P_same        | tW2W_samebg             | tW2R_samebg             | tR2P_samebg            | ba<br>tR2W_same       | tR2R_samebg             |
| 0x1078           |                         |                          | bg<br>tW2P_same        |                         |                         |                        | bg<br>tR2W_same       |                         |
|                  |                         |                          | c -                    | tW2W_samec              | tW2R_samec              | tR2P_samec             | c –                   | tR2R_samec              |
| 0x1088           |                         |                          | tW2P_same              | , WOW                   | , WOD                   | 4 DOD                  | tR2W_same             | 4 DOD                   |
| 0x1090<br>0x1098 |                         |                          | cs                     | tW2W_samecs             | tW2R_samecs             | tR2P_samecs            | cs<br>tR2W_diff       | tR2R_samecs             |
| 01000            | I                       |                          |                        | tW2W_diffcs             | tW2R_diffcs             |                        | cs ckzw_diff          | tR2R_diffcs             |



|                  | mirror dimm c          |           | f              |                   | 1                 |                       |                | cs enable    |
|------------------|------------------------|-----------|----------------|-------------------|-------------------|-----------------------|----------------|--------------|
| 0x1100<br>0x1108 |                        | s_map     | cs_ref         | cs_resync         |                   |                       |                | cs_enable    |
|                  | cke_map<br>mirror_cs_e | mirror_cs | mirro_dim      | 0.11              | cs_map            |                       |                | .,           |
| 0x1110           | nable                  | _sta(RO)  | m_ctrl         | cs2cid            |                   |                       |                | cid_map      |
| 0x1118           | mrs done(RD            | mrs req(W | pre all d      | pre_all_req(      |                   | status cmd(           | cmd req(W      | command mod  |
| 0x1120           | )                      | R)        | one (RD)       | WR)               | cmd_cmd           | RD)                   | R)             | e e          |
| 0x1128           | cmd_cke                | cmd_a     |                |                   | cmd_ba            | cmd_bg                | cmd_c          | cmd_cs       |
| 0x1130           | cs_mrs_sequen          | ce        |                |                   |                   | mpr_rd_done<br>(RO)   | cmd_mpr_r<br>d | cmd_pda      |
| 0x1138           |                        |           |                |                   |                   | cmd_dq0               |                |              |
| 0x1140           | mr_3_cs_0              |           | mr_2_cs_0      |                   | mr_1_cs_0         |                       | mr_0_cs_0      |              |
| 0x1148           | mr_3_cs_1              |           | mr_2_cs_1      |                   | mr_1_cs_1         |                       | mr_0_cs_1      |              |
| 0x1150           | mr_3_cs_2              |           | mr_2_cs_2      |                   | mr_1_cs_2         |                       | mr_0_cs_2      |              |
| 0x1158           | mr_3_cs_3              |           | mr_2_cs_3      |                   | mr_1_cs_3         |                       | mr_0_cs_3      |              |
| 0x1160           | mr_3_cs_4              |           | mr_2_cs_4      |                   | mr_1_cs_4         |                       | mr_0_cs_4      |              |
| 0x1168           | mr_3_cs_5              |           | mr_2_cs_5      |                   | mr_1_cs_5         |                       | mr_0_cs_5      |              |
| 0x1170           | mr_3_cs_6              |           | mr_2_cs_6      |                   | mr_1_cs_6         |                       | mr_0_cs_6      |              |
| 0x1178           | mr_3_cs_7              |           | mr_2_cs_7      |                   | mr_1_cs_7         |                       | mr_0_cs_7      |              |
| 0x1180           | mr_3_cs_0_ddr          | 4         | mr_2_cs_0_d    | dr4               | mr_1_cs_0_ddr4    |                       | mr_0_cs_0_d    | dr4          |
| 0x1188           |                        |           | mr_6_cs_0_ddr4 |                   | mr_5_cs_0_ddr4    |                       | mr_4_cs_0_ddr4 |              |
| 0x1190           | mr_3_cs_1_ddr          | 4         | mr_2_cs_1_d    | dr4               | mr_1_cs_1_dd      | r4                    | mr_0_cs_1_ddr4 |              |
| 0x1198           |                        |           | mr_6_cs_1_ddr4 |                   | mr_5_cs_1_ddr4    |                       | mr_4_cs_1_ddr4 |              |
| 0x11a0           | mr_3_cs_2_ddr          | 4         | mr_2_cs_2_ddr4 |                   | mr_1_cs_2_ddr4    |                       | mr_0_cs_2_ddr4 |              |
| 0x11a8           |                        |           | mr_6_cs_2_d    | dr4               | mr_5_cs_2_ddr4    |                       | mr_4_cs_2_ddr4 |              |
| 0x11b0           | mr_3_cs_3_ddr          | 4         | mr_2_cs_3_d    | dr4               | mr_1_cs_3_ddr4    |                       | mr_0_cs_3_ddr4 |              |
| 0x11b8           |                        |           | mr_6_cs_3_ddr4 |                   | mr_5_cs_3_ddr4    |                       | mr_4_cs_3_ddr4 |              |
| 0x11c0           | mr_3_cs_4_ddr          | 4         | mr_2_cs_4_d    | dr4               | mr_1_cs_4_dd      | r4                    | mr_0_cs_4_d    | dr4          |
| 0x11c8           |                        |           | mr_6_cs_4_d    | dr4               | mr_5_cs_4_dd      | r4                    | mr_4_cs_4_d    | dr4          |
| 0x11d0           | mr_3_cs_5_ddr          | 4         | mr_2_cs_5_d    | dr4               | mr_1_cs_5_dd      | r4                    | mr_0_cs_5_d    | dr4          |
| 0x11d8           |                        |           | mr_6_cs_5_d    | dr4               | mr_5_cs_5_ddi     | r4                    | mr_4_cs_5_d    | dr4          |
| 0x11e0           | mr_3_cs_6_ddr          | 4         | mr_2_cs_6_d    | dr4               | mr_1_cs_6_dd      | r4                    | mr_0_cs_6_d    | dr4          |
| 0x11e8           |                        |           | mr_6_cs_6_d    | dr4               | mr_5_cs_6_dd      | r4                    | mr_4_cs_6_d    | dr4          |
| 0x11f0           | mr_3_cs_7_ddr          | 4         | mr_2_cs_7_d    | dr4               | mr_1_cs_7_dd      | r4                    | mr_0_cs_7_d    | dr4          |
| 0x11f8           |                        |           | mr_6_cs_7_d    | dr4               | mr_5_cs_7_ddr4    |                       | mr_4_cs_7_d    | dr4          |
| 0x1200           |                        |           | nc16_map       | nc                | channel_wid<br>th | ba_xor_row_<br>offset | addr_new       | cs_place     |
| 0x1208           |                        |           |                |                   |                   | bg_xor_row_<br>offset |                | addr_mirror  |
| 0x1210           | addr_base_1            | <u> </u>  | <u>I</u>       | <u> </u>          | addr_base_0       | 011361                | 1              | 1            |
| 0x1218           |                        |           |                |                   |                   |                       |                |              |
| 0x1220           | addr_mask_1            | <u> </u>  | <u>I</u>       | <u> </u>          | addr_mask_0       | 1                     | <u>I</u>       | <u> </u>     |
| 0x1228           |                        |           |                |                   | _                 |                       |                |              |
| 0x1230           |                        |           | cs_diff        | c_diff            | bg_diff           | ba_diff               | row_diff       | col_diff     |
| 0x1238           |                        |           | _              | CF_confbus_t      |                   | =                     | _              | _            |
| 0x1240           | WRQthreshol            | tRDQidle  | wr_pkc_nu      | imeout<br>rwq arb | retry             | no_dead_ino           | placement      | stb en/pbuf  |
| 0x1240           | d                      |           | m              | 14_410            | 1001              | rder                  | _en            | tRWGNTidle   |
| 0x1248           |                        |           |                |                   |                   |                       | rfifo age      | rivacin11016 |
| 0x1250           | prior age3             |           | prior age2     |                   | prior_age1        |                       | prior age0     |              |
|                  |                        |           | prior_age2     |                   | prior_age1        | rbuffer_max           | rdfifo_de      | atat :::     |
| 0x1260           | retry_cnt(RD)          |           |                |                   |                   | (RD)                  | pth            | stat_en      |



|        |                      | 1                    | I                    |                     | 1                    |                       | I                    |                      |
|--------|----------------------|----------------------|----------------------|---------------------|----------------------|-----------------------|----------------------|----------------------|
| 0x1268 |                      |                      |                      |                     |                      |                       |                      |                      |
|        | 510 11               |                      |                      |                     |                      |                       |                      |                      |
| 0x1280 | aw_512_alig<br>n     |                      | rd_before<br>_wr     | ecc_enable          |                      | int_vector(<br>RD)    | int_trigg<br>er(RD)  | int_enable           |
| 0x1288 |                      |                      |                      |                     |                      |                       |                      |                      |
| 0x1290 |                      |                      |                      |                     |                      | int_cnt_fat<br>al(RD) | int_cnt_e<br>rr(RD)  | int_cnt              |
| 0x1298 | ecc_cnt_cs_<br>7(RD) | ecc_cnt_c<br>s_6(RD) | ecc_cnt_c<br>s_5(RD) | ecc_cnt_cs_4 (RD)   | ecc_cnt_cs_<br>3(RD) | ecc_cnt_cs_<br>2(RD)  | ecc_cnt_c<br>s_1(RD) | ecc_cnt_cs_<br>0(RD) |
| 0x12a0 | ecc_data_di<br>r(RD) | ecc_code_<br>dir(RD) | ecc_code_25          | 6 (RD)              |                      |                       |                      | ecc_code_64<br>(RD)  |
| 0x12a8 | ecc_addr(RD)         |                      | •                    |                     | •                    |                       | '                    | 1 .                  |
| 0x12b0 | ecc_data[63:0        | ] (RD)               |                      |                     |                      |                       |                      |                      |
| 0x12b8 | ecc_data[127:        | 64] (RD)             |                      |                     |                      |                       |                      |                      |
| 0x12c0 | ecc_data[191:        | 128] (RD)            |                      |                     |                      |                       |                      |                      |
| 0x12c8 | ecc_data[255:        | 192] (RD)            |                      |                     |                      |                       |                      |                      |
|        |                      |                      |                      |                     |                      |                       |                      |                      |
| 0x1300 |                      |                      |                      |                     |                      |                       | ref_num              | ref_sch_en           |
| 0x1308 |                      |                      |                      |                     |                      |                       | Status_sr<br>ef(RD)  | srefresh_re          |
|        |                      |                      |                      |                     |                      |                       | ,/                   |                      |
| 0x1340 | hardware_pd<br>7     | hardware_<br>pd 6    | hardware_<br>pd 5    | hardware_pd_<br>4   | hardware_pd<br>3     | hardware_pd<br>2      | hardware_<br>pd 1    | hardware_pd          |
| 0x1348 | power_sta_7<br>(RD)  | power_sta<br>6(RD)   | power_sta<br>5(RD)   | power_sta_4(<br>RD) | power_sta_3<br>(RD)  | power_sta_2<br>(RD)   | power_sta<br>1(RD)   | power_sta_0<br>(RD)  |
| 0x1350 | selfref_age          | _0 (RD)              | slowpd_age           | I(D)                | fastpd_age           | (ND)                  | active_age           | (ID)                 |
| 0x1358 |                      |                      |                      | power_up            |                      |                       |                      | Age_step             |
| 0x1360 | tCONF_IDLE           |                      |                      |                     | tLPMC_IDLE           |                       | I                    |                      |
|        |                      |                      |                      |                     |                      |                       |                      |                      |
| 0x1380 |                      |                      |                      |                     |                      |                       |                      | zq_overlap           |
| 0x1388 |                      |                      |                      |                     |                      |                       |                      | zq_stat_en           |
| 0x1390 | zq_cnt_1 (RD)        |                      | I                    |                     | zq_cnt_0(RD)         |                       |                      | 1                    |
| 0x1398 | zq_cnt_3(RD)         |                      |                      |                     | zq_cnt_2(RD)         |                       |                      |                      |
| 0x13a0 | zq_cnt_5(RD)         |                      |                      |                     | zq_cnt_4(RD)         |                       |                      |                      |
| 0x13a8 | zq_cnt_6(RD)         |                      |                      |                     | zq_cnt_6(RD)         |                       |                      |                      |
|        |                      |                      |                      |                     |                      |                       |                      |                      |
| 0x13c0 |                      |                      |                      |                     | odt_wr_cs_map        | )                     |                      |                      |
| 0x13c8 |                      |                      |                      |                     |                      |                       | odt_wr_le            | odt_wr_dela          |
| 0x13d0 |                      |                      |                      |                     | odt_rd_cs_map        | )                     |                      |                      |
| 0x13d8 |                      |                      |                      |                     |                      |                       | odt_rd_le<br>ngth    | odt_rd_dela          |
|        |                      |                      |                      |                     |                      |                       |                      |                      |
| 0x1400 |                      |                      |                      | tRESYNC_leng        | tRESYNC_del          | tRESYNC_shi<br>ft     | tRESYNC_m<br>ax      | tRESYNC_min          |
|        |                      |                      |                      |                     |                      |                       |                      |                      |
| 0x1440 |                      |                      |                      |                     | pre_predict          | 1                     | tm_cmdq_n<br>um      | burst_lengt          |
| 0x1448 |                      |                      |                      |                     |                      |                       |                      | ca_timing            |
| 0x1450 |                      |                      |                      |                     |                      | wr/rd_dbi_e           | ca_par_en            | crc_en               |
| 0x1458 |                      |                      |                      |                     |                      | 11                    | tCA_PAR              | tWR_CRC              |
| 0x1460 | bit_map_7            | bit_map_6            | bit_map_5            | bit_map_6           | bit_map_3            | bit_map_2             | bit_map_1            | bit_map_0            |
| 0x1468 | bit_map_15           | bit_map_1 4          | bit_map_1            | bit_map_12          | bit_map_11           | bit_map_10            | bit_map_9            | bit_map_8            |
| 0x1470 |                      | 1                    |                      |                     |                      |                       | bit_map_1            | bit_map_16           |
| 0x1478 |                      |                      |                      |                     |                      |                       | 7                    | bitmap_mirr          |
| 0x1480 |                      |                      |                      | alertn_misc(        |                      |                       | alertn_cn            | or<br>alertn_clr     |
| 081400 |                      |                      |                      | RD)                 |                      |                       | t                    | arer til_cir         |



| 0x1488 | alertn_addr(RD)            |
|--------|----------------------------|
|        | ater til_adur (ND)         |
| 0x14b8 | mpr_train_ecc              |
| 0x14c0 | mpr_train_data_0           |
| 0x14c8 | mpr_train_data_1           |
| 0x14d0 | mpr_train_data_2           |
| 0x14d8 | mpr_train_data_3           |
| 0x14e0 | mpr_train_data_4           |
| 0x14e8 | mpr_train_data_5           |
| 0x14f0 | mpr_train_data_6           |
| 0x14f8 | mpr_train_data_7           |
| 0x1500 | win0_base                  |
| 0x1508 | winl_base                  |
| 0x1510 | win2_base                  |
| 0x1518 | win3_base                  |
| 0x1520 | win4_base                  |
| 0x1528 | win5_base                  |
| 0x1530 | win6_base                  |
| 0x1538 | win7_base                  |
| •••••  |                            |
| 0x1580 | winO_mask                  |
| 0x1588 | win1_mask                  |
| 0x1590 | win2_mask                  |
| 0x1598 | win3_mask                  |
| 0x15a0 | win4_mask                  |
| 0x15a8 | win5_mask                  |
| 0x15b0 | win6_mask                  |
| 0x15b8 | win7_mask                  |
| 0x1600 | win0_mmap                  |
| 0x1608 | win1_mmap                  |
| 0x1610 | win2_mmap                  |
| 0x1618 | win3_mmap                  |
| 0x1620 | win4_mmap                  |
| 0x1628 | win5_mmap                  |
| 0x1630 | win6_mmap                  |
| 0x1638 | win7_mmap                  |
|        |                            |
| 0x1680 | write_train_data[63:0]     |
| 0x1688 | write_train_data[127:64]   |
| 0x1690 | write_train_data[191:128]  |
| 0x1698 | write_train_data[255:192]  |
| 0x16a0 | write_train_data[319:256]  |
| 0x16a8 | write_train_data[383:320]  |
| 0x16b0 | write_train_data[447:384]  |
| 0x16b8 | write_train_data[511:448]  |
| 0x16c0 | Write_train_ecc_data[64:0] |



### 龙芯 2K2000 处理器用户手册

| 0x16c8 |               | train_wri      | obj_addr |            | train_ecc_c<br>md len |             | rw_train_<br>req | rw_train_mo<br>de/start |
|--------|---------------|----------------|----------|------------|-----------------------|-------------|------------------|-------------------------|
|        |               | te_n           |          |            | mu_ren                |             | Teq              | ue/start                |
| 0x1700 |               |                |          |            |                       |             | acc_hp           | acc_en                  |
| 0x1708 | acc_fake_b    |                |          |            | acc_fake_a            |             |                  |                         |
| 0x1710 |               |                |          |            |                       |             |                  |                         |
| 0x1718 |               |                |          |            |                       |             |                  |                         |
| 0x1720 | addr_base_acc | 1              |          |            | addr_base_acc         | c 0         | 1                |                         |
| 0x1728 |               |                |          |            |                       |             |                  |                         |
| 0x1730 | addr_mask_acc | :_1            |          |            | addr_mask_acc         | L<br>c_0    |                  |                         |
| 0x1738 |               |                |          |            |                       |             |                  |                         |
| MON    |               |                |          |            |                       |             | I                |                         |
| 0x2000 |               |                |          |            |                       |             |                  | cmd_monitor             |
| 0x2008 |               |                |          |            |                       |             |                  |                         |
| 0x2010 | cmd_fbck[63:0 | [ (RD)         |          | l          |                       |             | 1                |                         |
| 0x2018 | cmd_fbck[127: | 64] (RD)       |          |            |                       |             |                  |                         |
| 0x2020 |               |                |          |            | rw_switch_cn          | t (RD)      |                  |                         |
| •••••  |               |                |          |            |                       |             |                  |                         |
| 0x2100 |               |                |          |            |                       |             |                  | scheduler_m<br>on       |
| 0x2108 |               |                |          |            |                       |             |                  | Oli                     |
| 0x2110 | sch_cmd_num(F | rD)            |          |            |                       |             | 1                |                         |
| 0x2118 | ba_conflict_a | 11 (RD)        |          |            |                       |             |                  |                         |
| 0x2120 | ba_conflict_l | ast1(RD)       |          |            |                       |             |                  |                         |
| 0x2128 | ba_conflict_l | ast2(RD)       |          |            |                       |             |                  |                         |
| 0x2130 | ba_conflict_l | ast3(RD)       |          |            |                       |             |                  |                         |
| 0x2138 | ba_conflict_l | ast4(RD)       |          |            |                       |             |                  |                         |
| 0x2140 | ba_conflict_l | ast5(RD)       |          |            |                       |             |                  |                         |
| 0x2148 | ba_conflict_l | ast6(RD)       |          |            |                       |             |                  |                         |
| 0x2150 | ba_conflict_l | ast7(RD)       |          |            |                       |             |                  |                         |
| 0x2158 | ba_conflict_l | ast8(RD)       |          |            |                       |             |                  |                         |
| 0x2160 | rd_conflict(F | rD)            |          |            |                       |             |                  |                         |
| 0x2168 | wr_conflict(F | rD)            |          |            |                       |             |                  |                         |
| 0x2170 | rtw_conflict( | (RD)           |          |            |                       |             |                  |                         |
| 0x2178 | wtr_conflict  | (RD)           |          |            |                       |             |                  |                         |
| 0x2180 | rd_conflict_l | ast1(RD)       |          |            |                       |             |                  |                         |
| 0x2188 | wr_conflict_l | ast1(RD)       |          |            |                       |             |                  |                         |
| 0x2190 | rtw_conflict_ | last1(RD)      |          | <u> </u>   |                       |             |                  |                         |
| 0x2198 | wtr_conflict_ | last1(RD)      |          |            |                       |             |                  |                         |
| 0x21a0 | wr_rd_turnard | ound (RD)      |          |            |                       |             |                  |                         |
| 0x21a8 | cs_turnaround | (RD)           |          |            |                       |             |                  |                         |
| 0x21b0 | bg_conflict(F | D)             |          |            |                       |             |                  |                         |
|        |               |                |          |            |                       |             |                  |                         |
| 0x2300 |               |                |          |            |                       | sm_leveling |                  | sm_init                 |
| 0x2308 |               |                |          |            |                       |             |                  |                         |
| 0x2310 |               | sm_rank_0<br>3 |          | sm_rank_02 |                       | sm_rank_01  |                  | sm_rank_00              |
| 0x2318 |               | sm_rank_0<br>7 |          | sm_rank_06 |                       | sm_rank_05  |                  | sm_rank_04              |
| 0x2320 |               | sm_rank_1      |          | sm_rank_10 |                       | sm_rank_09  |                  | sm_rank_08              |



### 龙芯 2K2000 处理器用户手册

| 0x2328                                                                                                                         |                                                                                                                                       | sm_rank_1<br>5                           |                 | sm_rank_14 |                            | sm_rank_13  |                  | sm_rank_12              |
|--------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|-----------------|------------|----------------------------|-------------|------------------|-------------------------|
| 0x2330                                                                                                                         |                                                                                                                                       | sm_rank_1<br>9                           |                 | sm_rank_18 |                            | sm_rank_17  |                  | sm_rank_16              |
| 0x2338                                                                                                                         |                                                                                                                                       | sm_rank_2<br>3                           |                 | sm_rank_22 |                            | sm_rank_21  |                  | sm_rank_20              |
| 0x2340                                                                                                                         |                                                                                                                                       | sm_rank_2<br>7                           |                 | sm_rank_26 |                            | sm_rank_25  |                  | sm_rank_24              |
| 0x2348                                                                                                                         |                                                                                                                                       | sm_rank_3                                |                 | sm_rank_30 |                            | sm_rank_29  |                  | sm_rank_28              |
|                                                                                                                                |                                                                                                                                       |                                          |                 |            |                            |             |                  |                         |
| TST                                                                                                                            |                                                                                                                                       |                                          | 1               | •          | -1                         |             |                  | 1                       |
| 0x3000                                                                                                                         |                                                                                                                                       |                                          |                 |            |                            | lpbk_mode   | lpbk_star<br>t   | lpbk_en                 |
| 0x3008                                                                                                                         | lpbk_correct(                                                                                                                         | RD)                                      |                 |            | lpbk_counter               | (RD)        |                  | lpbk_error<br>RD)       |
| 0x3010                                                                                                                         | lpbk_data_en[6                                                                                                                        | 63:0]                                    |                 |            |                            |             | I                | 1.07                    |
| 0x3018                                                                                                                         |                                                                                                                                       |                                          |                 |            |                            |             |                  | lpbk_data_o<br>n[71:64] |
| 0x3020                                                                                                                         |                                                                                                                                       |                                          |                 |            |                            |             | lpbk_data_m      |                         |
| 0x3028                                                                                                                         |                                                                                                                                       |                                          |                 |            |                            |             |                  |                         |
| 0x3030                                                                                                                         | Lpbk_dat_w0[63                                                                                                                        | 3:0]                                     |                 | I.         |                            |             | 1                | 1                       |
| 0x3038                                                                                                                         | Lpbk_dat_w0[12                                                                                                                        |                                          |                 |            |                            |             |                  |                         |
| 0x3040                                                                                                                         | Lpbk_dat_w1[65                                                                                                                        | 3:0]                                     |                 |            |                            |             |                  |                         |
| 0x3048                                                                                                                         | Lpbk_dat_w1[12                                                                                                                        | 27:64]                                   |                 |            |                            |             |                  |                         |
| 0x3050                                                                                                                         |                                                                                                                                       | lpbk_ecc_<br>mask_w0                     | lpbk_dat_ma     | sk_w0      |                            |             | lpbk_ecc_w0      | )                       |
| 0x3058                                                                                                                         |                                                                                                                                       | lpbk_ecc_<br>mask wl                     | lpbk_dat_ma     | sk_w1      |                            |             | lpbk_ecc_w1      |                         |
| 0x3060                                                                                                                         |                                                                                                                                       |                                          |                 |            |                            |             |                  | prbs_23                 |
| 0x3068                                                                                                                         |                                                                                                                                       |                                          |                 |            |                            | prbs_init   |                  | 1                       |
| •••••                                                                                                                          |                                                                                                                                       |                                          |                 |            |                            |             |                  |                         |
| 0x3100                                                                                                                         |                                                                                                                                       |                                          |                 |            | fix_data_pa<br>ttern index | bus_width   | page_size        | test_engin<br>en        |
| 0x3108                                                                                                                         |                                                                                                                                       |                                          | cs_diff_t<br>st | c_diff_tst | bg_diff_tst                | ba_diff_tst | row_diff_<br>tst | col_diff_t              |
| 0x3120                                                                                                                         | addr_base_tst                                                                                                                         |                                          |                 |            | - I                        |             |                  | 1 -                     |
| 0x3128                                                                                                                         |                                                                                                                                       |                                          |                 |            |                            |             |                  |                         |
| 0x3130                                                                                                                         | user_data_pat                                                                                                                         | tern                                     |                 |            |                            | •           |                  |                         |
| 0x3138                                                                                                                         |                                                                                                                                       |                                          |                 |            |                            |             |                  |                         |
| 0x3140                                                                                                                         | valid_bits[63                                                                                                                         | :0]                                      |                 |            |                            |             |                  |                         |
|                                                                                                                                |                                                                                                                                       |                                          |                 |            |                            |             |                  | .1:11:4                 |
| 0x3148                                                                                                                         |                                                                                                                                       |                                          |                 |            |                            |             |                  | valid_bits<br>71:64]    |
| 0x3148<br>0x3150                                                                                                               | ctr1[63:0]                                                                                                                            |                                          |                 |            |                            |             |                  | 71:64]                  |
|                                                                                                                                | ctrl[63:0]<br>ctrl[127:64]                                                                                                            |                                          |                 |            |                            |             |                  | valid_bits<br>71:64]    |
| 0x3150                                                                                                                         |                                                                                                                                       | )                                        |                 |            |                            |             |                  | 71:64]                  |
| 0x3150<br>0x3158                                                                                                               | ctrl[127:64]                                                                                                                          |                                          |                 |            |                            |             |                  | valid_fits<br>71:64]    |
| 0x3150<br>0x3158<br>0x3160<br>0x3168<br>0x3170                                                                                 | ctr1[127:64] obs[63:0] (RD) obs[127:64] (I obs[191:128]                                                                               | RD)                                      |                 |            |                            |             |                  | valid_oits<br>71:64]    |
| 0x3150<br>0x3158<br>0x3160<br>0x3168<br>0x3170<br>0x3178                                                                       | ctr1[127:64] obs[63:0] (RD) obs[127:64] (I obs[191:128] obs[255:192]                                                                  | RD) (RD) (RD)                            |                 |            |                            |             |                  | valid_oits<br>71:64]    |
| 0x3150<br>0x3158<br>0x3160<br>0x3168<br>0x3170<br>0x3178<br>0x3180                                                             | ctr1[127:64] obs[63:0] (RD) obs[127:64] (I obs[191:128] obs[255:192] obs[319:256]                                                     | RD) (RD) (RD) (RD)                       |                 |            |                            |             |                  | valid_oits<br>71:64]    |
| 0x3150<br>0x3158<br>0x3160<br>0x3168<br>0x3170<br>0x3178<br>0x3180<br>0x3188                                                   | ctr1[127:64] obs[63:0] (RD) obs[127:64] (I obs[191:128] obs[255:192] obs[319:256] obs[383:320]                                        | RD) (RD) (RD) (RD) (RD)                  |                 |            |                            |             |                  | valid_oits<br>71:64]    |
| 0x3150<br>0x3158<br>0x3160<br>0x3168<br>0x3170<br>0x3178<br>0x3180<br>0x3188<br>0x3190                                         | ctr1[127:64] obs[63:0] (RD) obs[127:64] (I obs[191:128] obs[255:192] obs[319:256] obs[383:320] obs[447:384]                           | (RD) (RD) (RD) (RD) (RD) (RD)            |                 |            |                            |             |                  | valid_fits<br>71:64]    |
| 0x3150<br>0x3158<br>0x3160<br>0x3168<br>0x3170<br>0x3178<br>0x3180<br>0x3188<br>0x3190<br>0x3198                               | ctr1[127:64] obs[63:0] (RD) obs[127:64] (I obs[191:128] obs[255:192] obs[319:256] obs[383:320] obs[447:384] obs[511:448]              | (RD) (RD) (RD) (RD) (RD) (RD) (RD)       |                 |            |                            |             |                  | valid_fits<br>71:64]    |
| 0x3150<br>0x3158<br>0x3160<br>0x3168<br>0x3170<br>0x3178<br>0x3180<br>0x3188<br>0x3190<br>0x3198<br>0x31a0                     | ctr1[127:64] obs[63:0] (RD) obs[127:64] (I obs[191:128] obs[255:192] obs[319:256] obs[383:320] obs[447:384] obs[511:448] obs[575:512] | RD) (RD) (RD) (RD) (RD) (RD) (RD) (RD) ( |                 |            |                            |             |                  | valid_fits<br>71:64]    |
| 0x3150<br>0x3158<br>0x3160<br>0x3168<br>0x3170<br>0x3178<br>0x3180<br>0x3188<br>0x3190<br>0x3198<br>0x31a0<br>0x31a8           | ctr1[127:64] obs[63:0] (RD) obs[127:64] (I obs[191:128] obs[255:192] obs[319:256] obs[383:320] obs[447:384] obs[511:448]              | RD) (RD) (RD) (RD) (RD) (RD) (RD) (RD) ( |                 |            |                            | (nn)        |                  | valid_fits<br>71:64]    |
| 0x3150<br>0x3158<br>0x3160<br>0x3168<br>0x3170<br>0x3178<br>0x3180<br>0x3180<br>0x3190<br>0x3198<br>0x3190<br>0x31a0<br>0x31a8 | ctr1[127:64] obs[63:0] (RD) obs[127:64] (I obs[191:128] obs[255:192] obs[319:256] obs[383:320] obs[447:384] obs[511:448] obs[575:512] | RD) (RD) (RD) (RD) (RD) (RD) (RD) (RD) ( |                 |            | obs[671:640]               | (RD)        |                  | Valid_fits<br>71:64]    |
| 0x3150<br>0x3158<br>0x3160<br>0x3168<br>0x3170<br>0x3178<br>0x3180<br>0x3188<br>0x3190<br>0x3198<br>0x31a0<br>0x31a8           | ctr1[127:64] obs[63:0] (RD) obs[127:64] (I obs[191:128] obs[255:192] obs[319:256] obs[383:320] obs[447:384] obs[511:448] obs[575:512] | RD) (RD) (RD) (RD) (RD) (RD) (RD) (RD) ( |                 |            | obs[671:640]               | (RD)        |                  | valid_oits<br>71:64]    |



| 0x3220 | tud_i0     |
|--------|------------|
| 0x3228 | tud_i1     |
| 0x3230 | tud_o (RD) |
| •••••  |            |
| 0x3300 | tst_300    |
| 0x3308 | tst_308    |
| 0x3310 | tst_310    |
| 0x3318 | tst_318    |
| 0x3320 | tst_320    |
| 0x3328 | tst_328    |
| 0x3330 | tst_330    |
| 0x3338 | tst_338    |
| 0x3340 | tst_340    |
| 0x3348 | tst_348    |
| 0x3350 | tst_350    |
| 0x3358 | tst_358    |
| 0x3360 | tst_360    |
| 0x3368 | tst_368    |
| 0x3370 | tst_370    |
| 0x3378 | tst_378    |

### 13.6 软件编程指南

#### 13.6.1 初始化操作

初始化操作由软件向寄存器 Init\_start (0x010) 写入 0x2 时开始,在设置 Init\_start 信号之前,必须将其它所有寄存器设置为正确的值。

软硬件协同的 DRAM 初始化过程如下:

- (1) 设置 pm\_clk\_sel\_ckca 和 pm\_clk\_sel\_ds
- (2) 设置 pm\_phy\_init\_start 为 1, 开始初始化 PHY
- (3) 等待 DLL 主控模块锁定,即 pm\_dl1\_init\_done 为 1
- (4) 等待所有时钟产生模块的 pm\_dll\_lock\_\*或者 pm\_pll\_lock\_\*变为 1
- (5) 使能所有的 pm clken \*
- (6) 将 pm init start 设置为 1,内存控制器开始初始化
- (7) 等待内存控制器初始化完成,即 pm\_dram\_init 的值与 pm\_cs\_enable 相同。

#### 13.6.2 复位引脚的控制

为了在 STR 等状态下更加简单地控制复位引脚,可以通过 pad\_reset\_po(0x808)寄存器进行特别的复位引脚(DDR RESETn)控制,主要的控制模式有两种:

(1) 一般模式, reset\_ctrl[1:0] == 2' b00。这种模式下, 复位信号引脚的行为与一般的控制模式相兼容。主板上直接将 DDR RESETn 与内存槽上的对应引脚相连。引



脚的行为是:

- 未上电时:引脚状态为低;
- 上电时:引脚状态为低;
- 控制器开始初始化时,引脚状态为高;
- 正常工作时,引脚状态为高。

时序如下图所示:



- (2) 反向模式, reset\_ctrl[1:0] == 2' b10。这种模式下,复位信号引脚在进行内存实际控制的时候, 有效电平与一般的控制模式相反。所以主板上需要将 DDR\_RESETn 通过反向器与内存槽上的对应引脚相连。引脚的行为是:
- 未上电时:引脚状态为低;
- 上电时:引脚状态为低;
- 控制器开始配置时: 引脚状态为高;
- 控制器开始初始化时:引脚状态为低;
- 正常工作时: 引脚状态为低。

时序如下图所示:



- (3) 复位禁止模式,pm\_pad\_reset\_o[1:0] == 2' b01。这种模式下,复位信号引脚在整个内存工作期间,保持低电平。所以主板上需要将 DDR\_RESETn 通过反向器与内存槽上的对应引脚相连。引脚的行为是:
- 始终为低;



时序如下图所示:



由后两种复位模式相配合,就可以直接在使用内存控制器的复位信号的情况下实现 STR 控制。当整个系统从关闭状态下启动时,使用(2)中的方法来使用内存条正常复位并 开始工作。当系统从 STR 中恢复的时候,使用(3)中的方法来重新配置内存条,使得在不破坏内存条原有状态的条件上使其重新开始正常工作。

#### **13.6.3** Leveling

Leveling 操作是在 DDR4 中,用于智能配置内存控制器读写操作中各种信号间相位关系的操作。通常它包括了 Write Leveling、Read Leveling 和 Gate Leveling。在本控制器中,只实现了 Write Leveling 与 Gate Leveling,Read Leveling 没有实现,软件需要通过判断读写的正确性来实现 Read Leveling 所完成的功能。除了在 Leveling 过程中操作的 DQS 相位、GATE 相位之外,还可以根据这些最后确认的相位来计算出写 DQ 相位、读 DQ 相位的配置方法。此外,本设计还支持 bit-deskew 功能,用于补偿一个 dataslice 内不同 bit 之间的延时差。

#### 13.6.4 Write Leveling

Write Leveling 用于配置写 DQS 与时钟之间的相位关系,软件编程需要参照如下步骤。

- (1) 完成控制器初始化,参见上一小节内容;
- (2) 将 D11 wrdqs x (x = 0···8) 设置为 0x20;
- (3) 将 D11\_wrdq\_x (x = 0···8) 设置为 0x0;
- (4) 设置 Lv1 mode 为 2' b01;
- (5) 采样 Lvl ready 寄存器,如果为1,表示可以开始 Write Leveling 请求;
- (6) 设置 Lvl\_req 为 1;
- (7) 采样 Lvl done 寄存器,如果为 1,表示一次 Write Leveling 请求完成;
- (8) 采样 Lvl\_resp\_x 寄存器,如果为0,则将对应的Dll\_wrdq\_x[6:0]和dll\_1xdly[6:0]增加1,并重复执行5-7直至Lvl\_resp\_x为1,然后转向9;如果为1,则将对应的Dll\_wrdq\_x[6:0]和dll\_1xdly[6:0]增加1,并重复执行5-7直



至Lvl\_resp\_x为0, 然后继续将对应的Dll\_wrdq\_x[6:0]和dll\_lxdly[6:0]增加1, 并重复执行5-7直至Lvl\_resp\_x为1, 然后转向9。

- (9) 将 D11\_wrdq\_x 和 d11\_1xd1y 的值减 0x40, 此时 D11\_wrdq\_x 和 d11\_1xd1y 的值就 应该是正确的设置值。
- (10) 根据 DIMM 类型设置 pm\_dly\_2x, 对于 0x0 边界右边的颗粒对应的 pm\_dly\_2x 值增加 0x010101。
- (11)将Lvl\_mode (0x700)设置为2'b00,退出Write Leveling模式。

#### 13.6.5 Gate Leveling

Gate Leveling 用于配置控制器内使能采样读 DQS 窗口的时机,软件编程参照如下步骤。

- (1) 完成控制器初始化,参见上一小节内容;
- (2) 完成 Write Leveling,参见上一小节内容;
- (3) 将 D11 gate x (x = 0···8) 设置为 0;
- (4) 设置 Lv1 mode 为 2' b10;
- (5) 采样 Lvl\_ready 寄存器,如果为1,表示可以开始 Gate Leveling 请求;
- (6) 设置 Lv1\_req 为 1;
- (7) 采样 Lvl done 寄存器,如果为1,表示一次 Gate Leveling 请求完成;
- (8) 采样 Lv1\_resp\_x[0] 寄存器。如果第一次采样发现 Lv1\_resp\_x[0] 为 1,则将对应的 D11 gate x[6:0] 增加 1,并重复执行 6-8,直至采样结果为 0,否则进行下一步;
- (9) 如果采样结果为 0,则将对应的 D11\_gate\_x[6:0]增加 1,并重复执行 6-9;如果为 1,则表示 Gate Leveling 操作已经成功;
- (10) 根据 pm rddqs phase 的值设置 pm rdedge sel
- (11)将D11\_gate\_x (x = 0…8)减0x20;
- (12)调整完毕后,再分别进行两次 Lvl\_req操作,观察 Lvl\_resp\_x[7:5]与 Lvl\_resp\_x[4:2]的值变化,如果各增加为 Burst\_length/2,则继续进行第 13 步操作;如果不为 4,可能需要对 Rd\_oe\_begin\_x进行加一或减一操作,如果大于 Burst\_length/2,很可能需要对 Dll\_gate\_x的值进行一些微调;
- (13) 将 Lv1 mode (0x700) 设置为 2' b00, 退出 Gate Leveling 模式;
- (14) 至此 Gate Leveling 操作结束。

#### 13.6.6 功耗控制配置流程

首先需要设置 pm\_pad\_ctrl\_ca[0] 为 1, 等待内存初始化完成之后, 再设置 pm\_pad\_ctrl\_ca[0]为 0。该功能只有使能了 CAL Mode 才可以使用。



#### 13.6.7 单独发起 MRS 命令

对于 DDR4 模式时,内存控制器向内存发出的 MRS 命令次序分别为:

MR3\_CS0、MR3\_CS1、MR3\_CS2、MR3\_CS3、MR3\_CS4、MR3\_CS5、MR3\_CS6、MR3\_CS7、

MR6 CSO, MR6 CS1, MR6 CS2, MR6 CS3, MR6 CS4, MR6 CS5, MR6 CS6, MR6 CS7,

MR5 CSO、MR5 CS1、MR5 CS2、MR5 CS3、MR5 CS4、MR5 CS5、MR5 CS6、MR5 CS7、

MR4\_CS0、MR1\_CS1、MR1\_CS2、MR1\_CS3、MR4\_CS4、MR4\_CS5、MR4\_CS6、MR4\_CS7、

MR2 CS0、MR2 CS1、MR2 CS2、MR2 CS3、MR2 CS4、MR2 CS5、MR2 CS6、MR2 CS7、

MR1 CSO、MR1 CS1、MR1 CS2、MR1 CS3、MR1 CS4、MR1 CS5、MR1 CS6、MR1 CS7、

MRO\_CSO、MR1\_CS1、MR1\_CS2、MR1\_CS3、MRO\_CS4、MRO\_CS5、MRO\_CS6、MRO\_CS7。

其中,对应 CS 的 MRS 命令是否有效,是由 Cs\_mrs 决定,只有 Cs\_mrs 上对应每个片选的位有效,才会真正向 DRAM 发出这个 MRS 命令。对应的每个 MR 的值由寄存器 Mr\*\_cs\*决定。这些值同时也用于初始化内存时的 MRS 命令。

#### 具体操作如下:

- (1) 将寄存器 Cs mrs (0x1101)、Mr\* cs\* (0x1140 0x11f8)设置为正确的值;
- (2) 设置 Command mode (0x0x1120) 为 1, 使控制器进入命令发送模式;
- (3) 采样 Status\_cmd (0x1122),如果为 1,则表示控制器已进入命令发送模式,可以进行下一步操作,如果为 0,则需要继续等待;
- (4) 写 Mrs req (0x1126) 为 1, 向 DRAM 发送 MRS 命令;
- (5) 采样 Mrs\_done (0x1127), 如果为 1,则表示 MRS 命令已经发送完毕,可以退出,如果为 0,则需要继续等待;
- (6) 设置 Command mode (0x1120) 为 0, 使控制器退出命令发送模式。

#### 13.6.8 任意操作控制总线

内存控制器可以通过命令发送模式向 DRAM 发出任意的命令组合,软件可以设置 Cmd\_cs、Cmd cmd、Cmd ba、Cmd a (0x1128),在命令发送模式下向 DRAM 发出。

#### 具体操作如下:

- (1) 将寄存器 Cmd cs、Cmd cmd、Cmd ba、Cmd a (0x1128) 设置为正确的值;
- (2) 设置 Command mode (0x1120) 为 1, 使控制器进入命令发送模式;
- (3) 采样 Status\_cmd (0x1122),如果为 1,则表示控制器已进入命令发送模式,可以进行下一步操作,如果为 0,则需要继续等待;
- (4) 写 Cmd\_req (0x1121) 为 1, 向 DRAM 发送命令;
- (5) 设置 Command\_mode (0x1120) 为 0, 使控制器退出命令发送模式。



#### 13.6.9 自循环测试模式控制

自循环测试模式可以分别在测试模式下或者正常功能模式下使用,为此,本内存控制器分别实现了两套独立的控制接口,一套用于在测试模式下由测试端口直接控制,另一套用于在正常功能模式下由寄存器配置模块进行配置使能测试。

这两套接口的复用使用端口 test\_phy 进行控制,当 test\_phy 有效时,使用控制器的 test\_\*端口进行控制,此时的自测试完全由硬件控制;当 test\_phy 无效时,使用软件编程的 pm\_\*的参数进行控制。使用测试端口的具体信号含义可以参考寄存器参数中的同名部分。

这两套接口从控制的参数来说基本一致,仅仅是接入点不同,在此介绍软件编程时的控制方法。具体操作如下:

- (1) 将内存控制器所有的参数全部正确设置;
- (2) 按照初始化流程等待时钟复位稳定;
- (3) 将寄存器 Lpbk en 设为 1;
- (4) 将寄存器 Lpbk start 设为 1; 此时自循环测试正式开始。
- (5) 到此为止自循环测试已经开始,软件需要经常检测是否有错误发生,具体操作如下:

采样寄存器 Lpbk\_error,如果这个值为 1,表示有错误发生,此时可以通过 Lpbk\_\*等观测用寄存器来观测第一个出错时的错误数据和正确数据;如果这个值为 0,表示还没有出现过数据错误。

## 13.7 ECC 功能使用控制

ECC 功能只有在 32 位或 64 位模式下可以使用。

Ecc\_enable (0x1280) 包括以下 2 个控制位:

Ecc enable[0]控制是否使能 ECC 功能,只有设置了这个有效位,才会使能 ECC 功能。

Ecc\_enable[1]控制是否通过处理器内部的读响应通路进行报错,以使得出现 ECC 两位错的读访问能立即导致处理器核的异常发生。

除此之外,ECC 出错还可以通过中断方式通知处理器核。这个中断通过 Int\_enable 进行控制。中断包括两个向量,Int\_vector[0]表示出现 ECC 错误(包括 1 位错与 2 位错),Int vector[1]表示出现 ECC 两位错。Int vector 的清除通过向对应位写 1 实现。



## 13.8 出错状态观测

内存控制器出错后,可通过访问相应的系统配置寄存器来获取相应的出错信息,并进行简单的调试操作。寄存器基地址为 0x1fe00000 或 0x3ff00000,同样也可以使用配置寄存器指令进行访问,寄存器及其对应位如下。

表 13-2 内存控制器出错状态观测寄存器

| 寄存器                                  | 偏移地址   | 控制 | 说明                                                                                                                                                                            |
|--------------------------------------|--------|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 内存控制器 ECC 设置寄存器mc_ecc_set            | 0x0600 | RW | 内存控制器 ECC 设置寄存器 [5:0]: mc int_enable, 中断使能 [8]: mc int_trigger, 中断触发配置 [21:16]: mc int_vector(RO), 中断向量(只读) [33:32]: mc ecc_enable, ECC 相关功能使能 [40]: mc rd_before_wr, 读后写功能使能 |
|                                      | 0x0608 | RW | 保留                                                                                                                                                                            |
| 内存控制器 ECC 计数寄存器<br>mc_ecc_cnt        | 0x0610 | RW | 内存控制器 ECC 计数寄存器 [7:0]: mc int_cnt, 配置 ECC 校验触发中断次数阈值 [15:8]: mc int_cnt_err(RO), ECC 校验一位出错次数统计(只读) [23:16]: mc int_cnt_fatal(RO), ECC 校验两位出错次数统计(只读)                         |
| 内存控制器 ECC 出错次数统计寄存器<br>mc_ecc_cs_cnt | 0x0618 | RO | 内存控制器 ECC 出错次数统计寄存器<br>[7:0]: mc ecc_cnt_cs_0, CSO 出现 ECC 校验<br>错次数统计<br>[15:8]: mc ecc_cnt_cs_1, CS1 出现 ECC 校验<br>错次数统计                                                      |
| 内存控制器 ECC 校验码寄存器mc_ecc_code          | 0x0620 | RO | 内存控制器 ECC 校验码寄存器<br>[7:0]: mc ecc_code_64, 64 位 ECC 校验时的<br>ECC 校验码,使能内存目录功能时无效                                                                                               |
| 内存控制器 ECC 出错地址寄存器<br>mc_ecc_addr     | 0x0628 | RO | 内存控制器 ECC 出错地址寄存器<br>[63:0]: mc ecc_addr, ECC 校验出错的地址信息                                                                                                                       |
| 内存控制器 ECC 出错数据寄存器 0<br>mc_ecc_data0  | 0x0630 | RO | 内存控制器 ECC 出错数据寄存器 0<br>[63:0]:mc_ecc_data0, ECC 校验出错时数据<br>的[63:0]位                                                                                                           |
| 内存控制器 ECC 出错数据寄存器 1<br>mc_ecc_data1  | 0x0638 | RO | 内存控制器 ECC 出错数据寄存器 1<br>[63:0]:mc_ecc_data1, ECC 校验出错时数据<br>的[127:64]位                                                                                                         |
| 内存控制器 ECC 出错数据寄存器 2<br>mc_ecc_data2  | 0x0640 | RO | 内存控制器 ECC 出错数据寄存器 2<br>[63:0]:mc_ecc_data2, ECC 校验出错时数据<br>的[191:128]位                                                                                                        |
| 内存控制器 ECC 出错数据寄存器 3<br>mc_ecc_data3  | 0x0648 | RO | 内存控制器 ECC 出错数据寄存器 3<br>[63:0]:mc_ecc_data3, ECC 校验出错时数据<br>的[255:192]位                                                                                                        |



# 14 MISC 低速设备 (D2:F0)

### 14.1 MISC低速设备配置寄存器 (MISC-D2:F0)

MISC 低速设备块包含多个低速设备。该总线控制器作为一个设备具有相应的配置头空间。配置头的默认值见表 14-1.

| 地址偏移    | 简称      | 描述                                  | 默认值                | 访问类型    |
|---------|---------|-------------------------------------|--------------------|---------|
| 00h-01h | VID     | Vendor ID                           | 0014h              | RO      |
| 02h-03h | DID     | Device ID                           | 7A22h              | RO      |
| 04h-05h | PCICMD  | PCI Command                         | 0000h              | R/W, RO |
| 08h     | RID     | Revision ID                         | 00h                | RO      |
| 09h     | PI      | Programming Interface               | 00h                | RO      |
| OAh     | SCC     | Sub Class Code                      | 80h                | RO      |
| 0Bh     | BCC     | Base Class Code                     | 08h                | RO      |
| 0Ch     | CLS     | Cache Line Size                     | 10h                | RO      |
| 0Eh     | HEADTYP | Header Type                         | 00h                | RO      |
| 10h-17h | CNL_BAR | Control Block Base Address Register | 00000000000000004h | R/W, RO |
| 2Ch-2Dh | SVID    | Subsystem Vendor ID                 | 0000h              | RO      |
| 2Eh-2Fh | SID     | Subsystem Identification            | 0000h              | RO      |
| 3Ch     | INT_LN  | Interrupt Line                      | FFh                | R/W     |
| 3Dh     | INT_PN  | Interrupt Pin                       | 00h                | RO      |

表 14-1 MISC 低速设备块的 PCI 配置寄存器 (MISC-D2:F0)

注: 表中未列出的地址空间表示保留。

下面列出与 PCI 配置头规范稍有不同的寄存器及其描述。

### PCICMD-PCI 命令寄存器

地址偏移: 04-05h 属性: R/W, RO 默认值: 0000h 大小: 16 位

| 位域   | 名称                     | 访问  | 描述                                                                                                    |
|------|------------------------|-----|-------------------------------------------------------------------------------------------------------|
| 15:2 | Reserved               | RO  | 保留                                                                                                    |
| 1    | Memory Space<br>Enable | R/W | 该位用来控制是否使能对 MISC 低速设备块内部设备的访问。<br>0:禁止访问;<br>1:使能对 MISC 低速设备块内部设备的访问。在将该位配置为 1 之前,必须先配置 PCNL_BAR 寄存器。 |
| 0    | Reserved               | RO  | 保留                                                                                                    |

## 14.2 内部设备地址路由

MISC 低速设备块下挂载了多个低速设备,包括: UART/CAN、I2C/AVS、PWM、HPET、ACPI、RTC、DPM 和 GPIO。这些低速设备根据地址位的 bit[18:16]进行区分,对应关系为:

表 14-2MISC 低速设备地址路由

|            |          |     |     | ,,,,, |      |              |      |    |
|------------|----------|-----|-----|-------|------|--------------|------|----|
| bit[18:16] | 0        | 1   | 2   | 3     | 4    | 5            | 6    | 7  |
| 设备         | UART/CAN | I2C | PWM | AVS   | HPET | ACPI/RTC/DPM | GPI0 | _  |
| 访问类型       | В        | В   | W   | W     | W    | W            | В    | 保留 |

对于 UART、I2C、PWM、ACPI/RTC来说,由于包含多个控制器,它们需要进一步的路由。 这些设备块的内部路由见表 14-2。不同的设备块需要的路由地址位数是不同的。

后续章节将分别对这些低速设备进行介绍。



## 15 UART 控制器

### 15.1 概述

UART 控制器提供与 MODEM 或其他外部设备串行通信的功能,例如与另外一台计算机,以 RS232 为标准使用串行线路进行通信。该控制器在设计上能很好地兼容国际工业标准半导体设备 16550A。2K2000 的 UART 支持的最高波特率为 921600。

2K2000 集成了 13 个 UART 接口和 13 个 UART 控制器, 其中, UARTO、UART3、UART4、UART5 复用 UART0 接口; UART1、UART6、UART7、UART8 复用 UART1 接口; UART2、UART9、UART10、UART11 复用 UART2 接口; ND UART 为 node 上的控制器接口。

## 15.2 访问地址及引脚复用

ND\_UART 控制器寄存器物理地址基址为 0x1FE001E0, 此外通过物理地址 0x1FE00100 可访问新增的两个寄存器 RFC 和 TFC。

其余 UART 控制器的访问基地址为 MISC 低速设备块的基地址加偏移 0x0。

注意: UART 模块仅支持按字节访问。

各个 UART 控制器内部寄存器的物理地址构成如下:

表 15-1 UART 控制器物理地址构成

| 地址位     | 构成     | 备注                       |
|---------|--------|--------------------------|
| [15:13] | 0      | 保留                       |
| [12:08] | UART 号 | 0x0 - 0xB, 分别表示各个 UART 号 |
| [07:00] | REG    | 内部寄存器地址                  |

对于各个 UART, 使用时要注意将对应的引脚设置为相应的功能。

与 UART 相关的引脚设置寄存器为 5.15 节中的 uart1\_sel、uart2\_sel、uart0\_enable、uart1 enable 及 uart2 enable。

## 15.3 控制器结构

UART 控制器有发送和接收模块(Transmitter and Receiver)、MODEM 模块、中断仲裁模块(Interrupt Arbitrator)、和访问寄存器模块(Register Access Control),这些模块之间的关系见下图所示。主要模块功能及特征描述如下:

1) 发送和接收模块:负责处理数据帧的发送和接收。发送模块是将 FIFO 发送队列中的数据按照设定的格式把并行数据转换为串行数据帧,并通过发送端口送出去。接收模块则监视接收端信号,一旦出现有效开始位,就进行接收,并实现将接收到的异步串行数据帧转换为并行数据,存入 FIFO 接收队列中,同时检查数据帧格式是否有错。UART 的帧结构是通过行控制寄存器(LCR)设置的,发送和接收器的状态被保存在行状态寄存器(LSR)中



- 2) MODEM 模块: MODEM 控制寄存器 (MCR) 控制输出信号 DTR 和 RTS 的状态。MODEM 控制模块监视输入信号 DCD, CTS, DSR 和 RI 的线路状态,并将这些信号的状态记录在 MODEM 状态寄存器 (MSR) 的相对应位中。
- 3) 中断仲裁模块: 当任何一种中断条件被满足,并且在中断使能寄存器(IER)中相应位置1,那么UART的中断请求信号UAT\_INT被置为有效状态。为了减少和外部软件的交互,UART把中断分为四个级别,并且在中断标识寄存器(IIR)中标识这些中断。四个级别的中断按优先级级别由高到低的排列顺序为,接收线路状态中断;接收数据准备好中断;传送拥有寄存器为空中断;MODEM状态中断。
- 4) 访问寄存器模块:当 UART 模块被选中时,CPU 可通过读或写操作访问被地址线选中的寄存器。



图 15-1 UART 控制器结构

## 15.4 寄存器描述

#### 15.4.1 数据寄存器 (DAT)

中文名:数据传输寄存器

寄存器位宽: [7:0]

偏移量: 0x00

表 15-2 UART 数据寄存器

| 位域  | 位域名称    | 位宽 | 访问 | 描述      |
|-----|---------|----|----|---------|
| 7:0 | Tx FIFO | 8  | RW | 数据传输寄存器 |



### 15.4.2 中断使能寄存器 (IER)

中文名: 中断使能寄存器

寄存器位宽: [7:0]

偏移量: 0x01

复位值: 0x00

表 15-3 UART 中断使能寄存器

| 位域  | 位域名称     | 位宽 | 访问 | 描述                             |
|-----|----------|----|----|--------------------------------|
| 7:4 | Reserved | 4  | RW | 保留                             |
| 3   | IME      | 1  | RW | Modem 状态中断使能 '0'-关闭 '1'-打<br>开 |
| 2   | ILE      | 1  | RW | 接收器线路状态中断使能'0'-关闭'1'-打开        |
| 1   | ITxE     | 1  | RW | 传输保存寄存器为空中断使能'0'-关闭'1'<br>-打开  |
| 0   | IRxE     | 1  | RW | 接收有效数据中断使能'0'-关闭 '1'-打         |

#### 15.4.3 中断标识寄存器(IIR)

中文名: 中断源寄存器

寄存器位宽: [7:0]

偏移量: 0x02

复位值: 0xc1

表 15-4 UART 中断标识寄存器

| 位域  | 位域名称     | 位宽 | 访问 | 描述          |
|-----|----------|----|----|-------------|
| 7:4 | Reserved | 4  | R  | 保留          |
| 3:1 | II       | 3  | R  | 中断源表示位,详见下表 |
| 0   | INTp     | 1  | R  | 中断表示位       |

#### 中断控制功能表:

表 15-5 UART 中断控制功能表

| Bit 3 | Bit 2 | Bit 1 | 优先级                  | 中断类型          | 中断源                                      | 中断复位控制                     |
|-------|-------|-------|----------------------|---------------|------------------------------------------|----------------------------|
| 0     | 1     | 1     | 1 <sup>st</sup>      | 接收线路状态        | 奇偶、溢出或帧错误,<br>或打断中断                      | 读 LSR                      |
| 0     | 1     | 0     | $2^{^{\mathrm{nd}}}$ | 接收到有效数 据      | FIFO 的字符个数达到<br>trigger 的水平              | FIFO 的字符个数低于<br>trigger 的值 |
| 1     | 1     | 0     | 2 <sup>nd</sup>      | 接收超时          | 在 FIF0 至少有一个字符,但在 4 个字符时间内没有任何操作,包括读和写操作 | 读接收 FIF0                   |
| 0     | 0     | 1     | 3 <sup>rd</sup>      | 传输保存寄存<br>器为空 | 传输保存寄存器为空                                | 写数据到 THR 或者多<br>IIR        |
| 0     | 0     | 0     | 4 <sup>th</sup>      | Modem 状态      | CTS, DSR, RI or DCD.                     | 读 MSR                      |



#### **15.4.4** FIFO 控制寄存器(FCR)

中文名: FIFO 控制寄存器

寄存器位宽: [7:0]

偏移量: 0x02

复位值: 0xc0

表 15-6 UART 的 FIFO 控制寄存器

| 位域  | 位域名称     | 位宽 | 访问 | 描述                                                                            |
|-----|----------|----|----|-------------------------------------------------------------------------------|
| 7:6 | TL       | 2  | W  | 接收 FIFO 提出中断申请的 trigger 值 '00' - 1 字节 '01' - 4 字节<br>'10' - 8 字节 '11' - 14 字节 |
| 5:3 | Reserved | 3  | W  | 保留                                                                            |
| 2   | Txset    | 1  | W  | '1'清除发送 FIFO 的内容,复位其逻辑                                                        |
| 1   | Rxset    | 1  | W  | '1'清除接收 FIF0 的内容,复位其逻辑                                                        |
| 0   | Reserved | 1  | W  | 保留                                                                            |

## 15.4.5 线路控制寄存器 (LCR)

中文名:线路控制寄存器

寄存器位宽: [7:0]

偏移量: 0x03

表 15-7 UART 线路控制寄存器

| 位域  | 位域名称 | 位宽 | 访问 | 描述                                                                                            |
|-----|------|----|----|-----------------------------------------------------------------------------------------------|
| 7   | dlab | 1  | RW | 分频锁存器访问位<br>'1' - 访问操作分频锁存器<br>'0' - 访问操作正常寄存器                                                |
| 6   | bcb  | 1  | RW | 打断控制位<br>'1'-此时串口的输出被置为 0 (打断状态).<br>'0'-正常操作                                                 |
| 5   | spb  | 1  | RW | 指定奇偶校验位<br>'0'-不用指定奇偶校验位<br>'1'-如果 LCR[4]位是 1 则传输和检查奇偶校验位为 0。如果<br>LCR[4]位是 0 则传输和检查奇偶校验位为 1。 |
| 4   | eps  | 1  | RW | 奇偶校验位选择<br>'0'-在每个字符中有奇数个1)包括数据和奇偶校验位(<br>'1'-在每个字符中有偶数个1                                     |
| 3   | pe   | 1  | RW | 奇偶校验位使能<br>'0'-没有奇偶校验位<br>'1'-在输出时生成奇偶校验位,输入则判断奇偶校验位                                          |
| 2   | sb   | 1  | RW | 定义生成停止位的位数<br>'0'-1个停止位<br>'1'-在5位字符长度时是1.5个停止位,其他长度是2个停止位                                    |
| 1:0 | bec  | 2  | RW | 设定每个字符的位数<br>'00' - 5 位 '01' - 6 位<br>'10' - 7 位 '11' - 8 位                                   |



#### 15.4.6 MODEM 控制寄存器 (MCR)

中文名: Modem 控制寄存器

寄存器位宽: [7:0]

偏移量: 0x04

复位值: 0x00

表 15-8 UART 的 MODEM 控制寄存器

| 位域  | 位域名称     | 位宽 | 访问 | 描述                                                                                                                                       |
|-----|----------|----|----|------------------------------------------------------------------------------------------------------------------------------------------|
| 7:5 | Reserved | 3  | W  | 保留                                                                                                                                       |
| 4   | Loop     | 1  | W  | 回环模式控制位<br>'0' - 正常操作<br>'1' - 回环模式。在在回环模式中,TXD 输出<br>一直为 1,输出移位寄存器直接连到输入移位<br>寄存器中。其他连接如下。<br>DTR DSR<br>RTS CTS<br>Out1 RI<br>Out2 DCD |
| 3   | OUT2     | 1  | W  | 在回环模式中连到 DCD 输入                                                                                                                          |
| 2   | OUT1     | 1  | W  | 在回环模式中连到 RI 输入                                                                                                                           |
| 1   | RTSC     | 1  | W  | RTS 信号控制位                                                                                                                                |
| 0   | DTRC     | 1  | W  | DTR 信号控制位                                                                                                                                |

### 15.4.7 线路状态寄存器 (LSR)

中文名:线路状态寄存器

寄存器位宽: [7:0]

偏移量: 0x05

表 15-9 UART 线路状态寄存器

| 位域 | 位域名称  | 位宽 | 访问 | 描述                                                                   |
|----|-------|----|----|----------------------------------------------------------------------|
| 7  | ERROR | 1  | R  | 错误表示位<br>'1'-至少有奇偶校验位错误,帧错误或打断中断的一个。<br>'0'-没有错误                     |
| 6  | TE    | 1  | R  | 传输为空表示位<br>'1' - 传输 FIFO 和传输移位寄存器都为空。给传输 FIFO<br>写数据时清零<br>'0' - 有数据 |
| 5  | TFE   | 1  | R  | 传输 FIFO 位空表示位<br>'1' - 当前传输 FIFO 为空,给传输 FIFO 写数据时清零<br>'0' - 有数据     |
| 4  | BI    | 1  | R  | 打断中断表示位<br>'1' - 接收到起始位+数据+奇偶位+停止位都是0,即<br>有打断中断<br>'0' - 没有打断       |
| 3  | FE    | 1  | R  | 帧错误表示位<br>'1' - 接收的数据没有停止位<br>'0' - 没有错误                             |
| 2  | PE    | 1  | R  | 奇偶校验位错误表示位                                                           |



|   |    |   |   | '1'- 当前接收数据有奇偶错误<br>'0'- 没有奇偶错误                     |
|---|----|---|---|-----------------------------------------------------|
| 1 | OE | 1 | R | 数据溢出表示位<br>'1' - 有数据溢出<br>'0' - 无溢出                 |
| 0 | DR | 1 | R | 接收数据有效表示位<br>'0' - 在 FIFO 中无数据<br>'1' - 在 FIFO 中有数据 |

对这个寄存器进行读操作时,LSR[4:1]和LSR[7]被清零,LSR[6:5]在给传输FIF0写数据时清零,LSR[0]则对接收FIF0进行判断。

#### 15.4.8 MODEM 状态寄存器 (MSR)

中文名: Modem 状态寄存器

寄存器位宽: [7: 0]偏移量: 0x06复位值: 0x00

表 15- 10 UART 的 MODEM 状态寄存器

| 位域 | 位域名称 | 位宽 | 访问 | 描述                        |
|----|------|----|----|---------------------------|
| 7  | CDCD | 1  | R  | DCD 输入值的反,或者在回环模式中连到 Out2 |
| 6  | CRI  | 1  | R  | RI 输入值的反,或者在回环模式中连到 OUT1  |
| 5  | CDSR | 1  | R  | DSR 输入值的反,或者在回环模式中连到 DTR  |
| 4  | CCTS | 1  | R  | CTS 输入值的反,或者在回环模式中连到 RTS  |
| 3  | DDCD | 1  | R  | DDCD 指示位                  |
| 2  | TERI | 1  | R  | RI 边沿检测。RI 状态从低到高变化       |
| 1  | DDSR | 1  | R  | DDSR 指示位                  |
| 0  | DCTS | 1  | R  | DCTS 指示位                  |

#### 15.4.9 分频锁存器

中文名:分频锁存器1

寄存器位宽: [7:0]

偏移量: 0x00

复位值: 0x00

表 15- 11 UART 分频锁存器 1

| 位域  | 位域名称 | 位宽 | 访问 | 描述          |
|-----|------|----|----|-------------|
| 7:0 | LSB  | 8  | RW | 存放分频锁存器的低8位 |

中文名:分频锁存器 2

寄存器位宽: [7:0]

偏移量: 0x01



#### 表 15- 12 UART 分频锁存器 2

| 位域  | 位域名称 | 位宽 | 访问 | 描述          |
|-----|------|----|----|-------------|
| 7:0 | MSB  | 8  | RW | 存放分频锁存器的高8位 |

中文名:分频锁存器3

寄存器位宽: [7:0]

偏移量: 0x02

复位值: 0x00

表 15-13 UART 分频锁存器 3

| 位域  | 位域名称  | 位宽 | 访问 | 描述            |
|-----|-------|----|----|---------------|
| 7:0 | D_DIV | 8  | RW | 存放分频锁存器的小数分频值 |

#### 15.4.10 新增寄存器的使用

新增的接收 FIFO 计数器(RFC)可供 CPU 检测接收 FIFO 中有效数据的个数,据此 CPU 可在收到一次中断后连续读取多个数据,提高 CPU 处理 UART 接收数据的能力;

发送 FIFO 计数器(TFC)可供 CPU 检测发送 FIFO 中有效数据的个数,据此 CPU 可在保证发送 FIFO 不溢出的前提下连续发送多个数据,提高 CPU 处理 UART 发送数据的能力;

分频锁存器 3 (即小数分频寄存器) 用于解决仅用整数除法无法精确得到所需波特率的问题。以参考时钟 100MHz 除以 16,再除以波特率,所得商整数部分赋值给由分频器锁存器 MSB 和 LSB,小数部分乘以 256 赋值给分频锁存器 D\_DIV。



## 16 CAN

龙芯 2K2000 集成了 6 路 CAN 接口控制器。CAN 总线是由发送数据线 TX 和接收数据线 RX 构成的串行总线,可发送和接收数据。器件与器件之间进行双向传送,最高传送速率 1Mbps。

### 16.1 访问地址及引脚复用

6个 CAN 控制器访问基址参考第 14章,内部寄存器的物理地址构成如下:

 地址位
 构成
 备注

 [15:13]
 0
 保留

 [12:08]
 CAN 编号
 分别为 0x10-0x15

 [07:00]
 REG
 内部寄存器地址

表 16-1 CAN 内部寄存器物理地址构成

对于 CAN 模块,使用时要注意将对应的引脚设置为相应的功能。

与 CAN 相关的引脚设置寄存器为 5.16 节中的 can sel。

### 16.2 标准模式

地址区包括控制段和信息缓冲区,控制段在初始化载入是可被编程来配置通讯参数的,应发送的信息会被写入发送缓冲器,成功接收信息后,微控制器从接收缓冲器中读取接收的信息,然后释放空间以做下一步应用。

初始载入后,寄存器的验收代码,验收屏蔽,总线定时寄存器 0 和 1 以及输出控制就不能改变了。只有控制寄存器的复位位被置高时,才可以访问这些寄存器。在复位模式和工作模式两种不同的模式中,访问寄存器是不同的。当硬件复位或控制器掉线,状态寄存器的总线状态位时会自动进入复位模式。工作模式是通过置位控制寄存器的复位请求位激活的。

在标准模式下, CAN 控制器将 ID[10:3]的值和验收代码的值相同的消息包存入接收缓冲区。如果验收屏蔽码的某位为 1,则验收码对应的位不参与对 ID 的检查。



表 16-2 CAN 控制器标准模式下寄存器定义

| CAN 4th 4th | FIL         | 工作模式                 |                      | 复位模式   |               |
|-------------|-------------|----------------------|----------------------|--------|---------------|
| CAN 地址      | 段           | 读                    | 写                    | 读      | 写             |
| 0           |             | 控制                   | 控制                   | 控制     | 控制            |
| 1           |             | FF                   | 命令                   | FF     | 命令            |
| 2           |             | 状态                   | _                    | 状态     | _             |
| 3           |             | FF                   | _                    | 中断     | _             |
| 4           |             | FF                   | _                    | 验收代码   | 验收代码          |
| 5           | 控制          | FF                   | _                    | 验收屏蔽   | 验收屏蔽          |
| 6           |             | FF                   | _                    | 总线定时 0 | 总线定时 0        |
| 7           |             | FF                   | _                    | 总线定时1  | 总线定时 1        |
| 8           |             | 保留                   | 保留                   | 保留     | 保留            |
| 9           |             | _                    | FIFO 预警深度            | _      | FIFO 预警深<br>度 |
| 10          |             | ID(10-3)             | ID(10-3)             | FF     | _             |
| 11          |             | ID(2-0),<br>RTR, DLC | ID(2-0),<br>RTR, DLC | FF     | _             |
| 12          |             | 数据字节1                | 数据字节1                | FF     | _             |
| 13          |             | 数据字节2                | 数据字节2                | FF     | _             |
| 14          | <br>  发送缓冲器 | 数据字节3                | 数据字节3                | FF     | _             |
| 15          |             | 数据字节 4               | 数据字节4                | FF     | _             |
| 16          | 数据字节 5      |                      | 数据字节5                | FF     | _             |
| 17          |             | 数据字节6                | 数据字节6                | FF     | _             |
| 18          |             | 数据字节7                | 数据字节7                | FF     | _             |
| 19          |             | 数据字节8                | 数据字节8                | FF     | _             |
| 20          |             | ID(10-3)             | ID(10-3)             | FF     | _             |
| 21          |             | ID(2-0),<br>RTR, DLC | ID(2-0),<br>RTR, DLC | FF     | _             |
| 22          |             | 数据字节1                | 数据字节1                | FF     | _             |
| 23          |             | 数据字节 2               | 数据字节2                | FF     | _             |
| 24          | 接收缓冲器       | 数据字节3                | 数据字节3                | FF     | _             |
| 25          |             | 数据字节 4               | 数据字节4                | FF     | _             |
| 26          | 数据字节5       |                      | 数据字节5                | FF     | _             |
| 27          | 数据字节 6      |                      | 数据字节6                | FF     | _             |
| 28          |             | 数据字节7                | 数据字节7                | FF     | _             |
| 29          |             | 数据字节8                | 数据字节8                | FF     | _             |
| 30          |             | 系数小数部分               | 系数小数部分               | 系数小数部分 | 系数小数部分        |
| 31          | _<br>小数分频控制 | 系数整数低位               | 系数整数低位               | 系数整数低位 | 系数整数低位        |
| 32          |             | 系数整数高位               | 系数整数高位               | 系数整数高位 | 系数整数高位        |

### 16.2.1 控制寄存器 (CR)

中文名:控制寄存器

寄存器位宽: [7:0]

偏移量: 0x00

复位值: 0x01

读此位的值总是逻辑 1。在硬启动或总线状态位设置为 1(总线关闭)时,复位请求位



被置为 1。如果这些位被软件访问,其值将发生变化而且会影响内部时钟的下一个上升沿,在外部复位期间微控制器不能把复位请求位置为 0。如果把复位请求位设为 0,微控制器就必须检查这一位以保证外部复位引脚不保持为低。复位请求位的变化是同内部分频时钟同步的。读复位请求位能够反映出这种同步状态。

复位请求位被设为0后控制器将会等待

- a) 一个总线空闲信号(11个弱势位),如果前一次复位请求是硬件复位或CPU 初始复位。
- b) 128 个总线空闲,如果前一次复位请求是 CAN 控制器在重新进入总线开启模式前初始化总线造成的。

| 位域   | 位域名称    | 位宽 | 访问 | 描述         |
|------|---------|----|----|------------|
| 7: 4 | Reserve | 2  | _  | 保留         |
| 5    | FAIE    | 1  | RW | 接收缓冲将满中断使能 |
| 4    | OIE     | 1  | RW | 溢出中断使能     |
| 3    | EIE     | 1  | RW | 错误中断使能     |
| 2    | TIE     | 1  | RW | 发送中断使能     |
| 1    | RIE     | 1  | RW | 接收中断使能     |
| 0    | RR      | 1  | RW | 复位请求       |

表 16-3 CAN 控制器标准模式下的控制寄存器格式

#### 16.2.2 命令寄存器 (CMR)

中文名:命令寄存器

寄存器位宽: [7:0]

偏移量: 0x01

复位值: 0x00

命令寄存器对微控制器来说是只写存储器如果去读这个地址返回值是 0xff

表 16-4 CAN 控制器标准模式下命令寄存器格式

| 位域           | 位域名称    | 位宽 | 访问 | 描述      |
|--------------|---------|----|----|---------|
| 7            | EFF     | 1  | W  | 扩展模式    |
| 6 <b>:</b> 5 | Reserve | 2  | _  | 保留      |
| 4            | GTS     | 1  | W  | 睡眠      |
| 3            | CDO     | 1  | W  | 清除数据溢出  |
| 2            | RRB     | 1  | W  | 释放接收缓冲器 |
| 1            | AT      | 1  | W  | 中止发送    |
| 0            | TR      | 1  | W  | 发送请求    |

#### 16.2.3 状态寄存器 (SR)

中文名: 状态寄存器

寄存器位宽: [7:0]



偏移量: 0x02 复位值: 0x00

表 16-5 CAN 控制器标准模式下状态寄存器格式

| 位域 | 位域名称 | 位宽 | 访问 | 描述      |
|----|------|----|----|---------|
| 7  | BS   | 1  | R  | 总线状态    |
| 6  | ES   | 1  | R  | 出错状态    |
| 5  | TS   | 1  | R  | 发送状态    |
| 4  | RS   | 1  | R  | 接收状态    |
| 3  | TCS  | 1  | R  | 发送完毕状态  |
| 2  | TBS  | 1  | R  | 发送缓存器状态 |
| 1  | DOS  | 1  | R  | 数据溢出状态  |
| 0  | RBS  | 1  | R  | 接收缓存器状态 |

#### 16.2.4 中断寄存器 (IR)

中文名:中断寄存器

寄存器位宽: [7:0]

偏移量: 0x03

复位值: 0x00

表 16-6 CAN 控制器标准模式下中断寄存器格式

| 位域   | 位域名称     | 位宽 | 访问 | 描述       |
|------|----------|----|----|----------|
| 7: 5 | Reserved | 1  | R  | 保留       |
| 4    | FAI      | 1  | R  | 接收缓冲将满中断 |
| 3    | DOI      | 1  | R  | 数据溢出中断   |
| 2    | EI       | 1  | R  | 错误中断     |
| 1    | TI       | 1  | R  | 发送中断     |
| 0    | RI       | 1  | R  | 接收中断     |

#### 16.2.5 验收代码寄存器 (ACR)

中文名:验收代码寄存器

寄存器位宽: [7:0]

偏移量: 0x04

复位值: 0x00

在复位情况下,该寄存器是可以读写的。

表 16-7 CAN 验收代码寄存器

| 位域  | 位域名称 | 位宽 | 访问 | 描述      |
|-----|------|----|----|---------|
| 7:0 | AC   | 8  | RW | ID 验收代码 |



#### 16.2.6 验收屏蔽寄存器 (AMR)

中文名:验收屏蔽寄存器

寄存器位宽: [7:0]

偏移量: 0x05

复位值: 0x00

验收代码位 AC 和信息识别码的高 8 位 ID. 10-ID. 3 相等且与验收屏蔽位 AM 的相应位相或为 1 时数据可以接收。在复位情况下,该寄存器是可以读写的。

表 16-8 CAN 验收屏蔽寄存器

| 1 | 位域  | 位域名称 | 位宽 | 访问 | 描述     |
|---|-----|------|----|----|--------|
| 7 | 7:0 | AM   | 8  | RW | ID 屏蔽位 |

#### 16.2.7 发送缓冲区列表

缓冲器是用来存储微控制器要 CAN 控制器发送的信息,它被分为描述符区和数据区。 发送缓冲器的读/写只能由微控制器在工作模式下完成,在复位模式下读出的值总是 0xff。

地址 X 数据位 名称 10 识别码字节1 ID(10-3) ID(2-0), RTR, DLC 11 识别码字节 2 TX 数据 1 12 TX 数据 1 13 TX 数据 2 TX 数据 2 14 发送缓冲器 TX 数据 3 TX 数据 3 15 TX 数据 4 TX 数据 4 16 TX 数据 5 TX 数据 5 17 TX 数据 6 TX 数据 6 18 TX 数据 7 TX 数据 7 19 TX 数据 8 TX 数据 8

表 16-9 CAN 控制器标准模式下发送缓冲区格式

### 16.2.8 接收缓冲区列表

接收缓冲区的配置和发送缓冲区的一样,只是地址变为20-29。

## 16.3 扩展模式

在扩展模式下,允许使用 11 位 ID 的标准帧和 29 位 ID 的扩展帧(是标准帧还是扩展 帧由 TX 帧信息的最高位 IDE 位确定)。

在扩展模式下, CAN 控制器可以接收 11 位 ID 的标准帧也可以接收 29 位 ID 的扩展帧。



在接收不同格式的帧的时候,验收代码  $0\sim$ 验收代码  $3\pmod{2}$   $\pmod{2}$  所检查的内容有所不同。验收屏蔽码  $0^\sim$ 验收屏蔽码  $3\pmod{2}$   $\pmod{2}$   $\pmod{3}$   $\pmod{4}$   $\pmod{4}$ 

在扩展模式下,CAN 控制器可以对接收到的消息包进行单滤波也可以进行双滤波。在进行单滤波时,验收代码 0~验收代码 3 仅对单一 ID 进行过滤。在进行双滤波时,验收代码 0~验收代码 3 可以对两个不同的 ID 进行。CAN 控制器只将 ID 符合滤波条件的消息包存入接收缓冲区。

对 11 位 ID 包的单滤波:

允许将 rdata0 和 rdata1 用来扩展对 ID 的验收长度

$$(rx_id[10:3] == code0) \& (rtr == code1[4]) \& (rx_id[2:0] == code1[7:5]) \& (rx_data0 == code2) \& (rx_data1 == code3)$$

对 11 位 ID 包的双滤波:

$$(rx_id[10:3] == code0)&&(rtr == code1[4])&&(rx_id[2:0] == code1[7:5])&&(rx_data0 == {code1[3:0], code3[3:0]})$$

或者

$$(rx_id[10:3] == code2) \&\& (rtr == code3[4]) \&\& (rx_id[2:0] == code3[7:5])$$

对 29 位 ID 包的单滤波:

$$(rx_id[28:21] == code0) \&\& (rx_id[20:13] == code1)\&\& (rx_id[12:5] == code2)\&\& (rtr == code3[2])\&\& (rx id[4:0] == code3[7:3])$$

对 29 位 ID 的双滤波:

$$(rx_id[28:21] == code0) \&\& (rx_id[20:13] == code1)$$

或者

$$(rx id[28:21] == code2) \&\& (rx id[20:13] == code3)$$

表 16-10 扩展模式下 CAN 控制器的地址列表

| CAN 地址    | 工作模式   |           | 复位模式   |           |
|-----------|--------|-----------|--------|-----------|
| CAN JEJIL | 读      | 写         | 读      | 写         |
| 0         | 控制     | 控制        | 控制     | 控制        |
| 1         | 0      | 命令        | 0      | 命令        |
| 2         | 状态     | _         | 状态     | _         |
| 3         | 中断     | _         | 中断     | _         |
| 4         | 中断使能   | 中断使能      | 中断使能   | 中断使能      |
| 5         | _      | _         | 验收屏蔽   | 验收屏蔽      |
| 6         | 总线定时 0 | _         | 总线定时 0 | 总线定时 0    |
| 7         | 总线定时 1 | _         | 总线定时 1 | 总线定时 1    |
| 8         | 保留     | 保留        | 保留     | 保留        |
| 9         | _      | FIFO 预警深度 | _      | FIFO 预警深度 |
| 10        | 保留     | 保留        | 保留     | 保留        |



| 11 | 仲裁丢失捕捉                                               | _                                                    | 仲裁丢失捕捉                                                                                                                                            | _      |
|----|------------------------------------------------------|------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|--------|
| 12 | 错误代码捕捉                                               | _                                                    | 错误代码捕捉                                                                                                                                            | _      |
| 13 | 错误警报限制                                               | _                                                    | 错误警报限制                                                                                                                                            | _      |
| 14 | RX 错误计数器                                             | _                                                    | RX 错误计数器                                                                                                                                          | _      |
| 15 | TX 错误计数器                                             | _                                                    | TX 错误计数器                                                                                                                                          | _      |
| 16 | RX 帧信息<br>{IDE, RTR, 2'h0, DLC[<br>3:0]}             | TX 帧信息<br>{IDE, RTR, 2'h0, DL<br>C[3:0]}             | 验收代码 0<br>Id[28:21] (扩展帧)<br>Id[10:3](非扩展帧)                                                                                                       | 验收代码 0 |
| 17 | RX_Id[28:21] (扩展<br>帧)<br>RX_Id[10:3] (非扩<br>展帧)     | TX_Id[28:21] (扩<br>展帧)<br>TX_Id[10:3] (非扩<br>展帧)     | 验收代码 1<br>Id[20:13] (扩展帧)<br>{Id[2:0],RTR,4'h0<br>} (非扩展帧,单滤波)<br>{Id[2:0],RTR,data0<br>[7:4]}(非扩展帧,<br>双滤波)<br>{Id[2:0],RTR,4'h0<br>]}(非扩展帧,单滤波) | 验收代码 1 |
| 18 | RX_Id[20:13](扩展<br>帧)<br>{RX_Id[2:0],5'h0}(<br>非扩展帧) | TX_Id[20:13](扩展<br>帧)<br>{TX_Id[2:0],5'h0<br>}(非扩展帧) | 验收代码 2<br>Id2[28:21](扩展帧,<br>双滤波)<br>Id[12:5](扩展帧,<br>单滤波)<br>Id2[10:3](非扩展<br>帧, 双滤波)<br>Data0(非扩展帧,单<br>滤波)                                     | 验收代码 2 |
| 19 | RX Id[12:5] (扩展帧)<br>RX dataO(非扩展帧)                  | TX Id[12:5](扩展<br>帧)<br>TX dataO(非扩展帧)               | 验收代码 3<br>Id2[20:13](扩展帧,<br>双滤波)<br>{id[4:0],RTR,2'h0<br>}(扩展帧,单滤波)<br>{id2[2:0],RTR,data<br>0[3:0]}(非扩展帧,<br>双滤波)<br>Data1(非扩展帧,单<br>滤波)        | 验收代码 3 |
| 20 | {RX_id[4:0],3' h0}<br>(扩展帧)<br>RX datal(非扩展帧)        | {TX_id[4:0],3'h0<br>}(扩展帧)<br>TX datal(非扩展帧)         | 验收屏蔽 0<br>(不判断为 1 的那位<br>的 id 值)                                                                                                                  | 验收屏蔽 0 |
| 21 | RX dataO(扩展帧)<br>RX data2(非扩展帧)                      | TX data2(非扩展帧)<br>TX data2(非扩展帧)                     | 验收屏蔽 1                                                                                                                                            | 验收屏蔽 1 |
| 22 | RX data1(扩展帧)<br>RX data3(非扩展帧)                      | TX data1(扩展帧)<br>TX data3(非扩展帧)                      | 验收屏蔽 2                                                                                                                                            | 验收屏蔽 2 |
| 23 | RX data2(扩展帧)<br>RX Data4(非扩展帧)                      | TX data2(扩展帧)<br>TX Data4(非扩展帧)                      | 验收屏蔽 3                                                                                                                                            | 验收屏蔽 3 |
| 24 | RX data3(扩展帧)<br>RX data5(非扩展帧)                      | TX data3(扩展帧)<br>TX data5(非扩展帧)                      | _                                                                                                                                                 | _      |
| 25 | RX data4(扩展帧)<br>RX data6(非扩展帧)                      | TX data4(扩展帧)<br>TX data6(非扩展帧)                      | _                                                                                                                                                 | _      |
| 26 | RX data5(扩展帧)<br>RX data7(非扩展帧)                      | TX data5(扩展帧)<br>TX data7(非扩展帧)                      | _                                                                                                                                                 | _      |
| 27 | RX data6(扩展帧)                                        | TX data6(扩展帧)                                        | _                                                                                                                                                 | _      |
| 28 | RX data7(扩展帧)                                        | TX data7(扩展帧)                                        | _                                                                                                                                                 | _      |
| 29 | RX 信息计数器                                             |                                                      | RX 信息计数器                                                                                                                                          | _      |
|    |                                                      |                                                      | 系数小数部分                                                                                                                                            |        |



| 31 | 系数整数低位 | 系数整数低位 | 系数整数低位 | 系数整数低位 |
|----|--------|--------|--------|--------|
| 32 | 系数整数高位 | 系数整数高位 | 系数整数高位 | 系数整数高位 |

#### 16.3.1 模式寄存器 (MOD)

中文名:模式寄存器

寄存器位宽: [7:0]

偏移量: 0x00

复位值: 0x01

读此位的值总是逻辑 1。在硬启动或总线状态位设置为 1 (总线关闭)时,复位请求位被置为 1。如果这些位被软件访问,其值将发生变化而且会影响内部时钟的下一个上升沿,在外部复位期间微控制器不能把复位请求位置为 0。如果把复位请求位设为 0,微控制器就必须检查这一位以保证外部复位引脚不保持为低。复位请求位的变化是同内部分频时钟同步的。读复位请求位能够反映出这种同步状态。

复位请求位被设为0后控制器将会等待

- a) 一个总线空闲信号(11个弱势位),如果前一次复位请求是硬件复位或CPU 初始复位。
- b) 128 个总线空闲,如果前一次复位请求是 CAN 控制器在重新进入总线开启模式前初始化总线造成的。

表 16- 11 CAN 控制器扩展模式下的模式寄存器格式

| 位域 | 位域名称    | 位宽 | 访问 | 描述                      |
|----|---------|----|----|-------------------------|
| 7  | DM      | 1  | RW | 接收缓冲的 DMA 模式            |
| 6  | FDE     | 1  | RW | 小数分频使能                  |
| 5  | Reserve | 1  | _  |                         |
| 4  | SM      | 1  | RW | 睡眠模式                    |
| 3  | AFM     | 1  | RW | 单/双滤波模式(0 为双滤波,仅复位模式可写) |
| 2  | STM     | 1  | RW | 正常工作模式(1为自测试模式,仅复位模式可写) |
| 1  | LOM     | 1  | RW | 只听模式(仅复位模式可写)           |
| 0  | RM      | 1  | RW | 复位模式                    |

#### 16.3.2 命令寄存器 (CMR)

中文名:命令寄存器

寄存器位宽: [7:0]

偏移量: 0x01

复位值: 0x00

命令寄存器对微控制器来说是只写存储器如果去读这个地址返回值是 0xff

表 16- 12 CAN 控制器扩展模式下命令寄存器格式



| 位域   | 位域名称    | 位宽 | 访问 | 描述                   |
|------|---------|----|----|----------------------|
| 7    | EFF     | 1  | W  | 扩展模式(仅在复位模式下可写)      |
| 6: 5 | Reserve | 2  | _  | 保留                   |
| 4    | SRR     | 1  | W  | 自接收请求(和 TR 不能同时为 1)  |
| 3    | CDO     | 1  | W  | 清除数据溢出               |
| 2    | RRB     | 1  | W  | 释放接收缓冲器              |
| 1    | AT      | 1  | W  | 中止发送                 |
| 0    | TR      | 1  | W  | 发送请求 (和 SRR 不能同时为 1) |

### 16.3.3 状态寄存器 (SR)

中文名: 状态寄存器

寄存器位宽: [7:0]

偏移量: 0x02

复位值: 0x00

表 16-13 CAN 控制器扩展模式下状态寄存器格式

| 位域 | 位域名称 | 位宽 | 访问 | 描述      |
|----|------|----|----|---------|
| 7  | BS   | 1  | R  | 总线状态    |
| 6  | ES   | 1  | R  | 出错状态    |
| 5  | TS   | 1  | R  | 发送状态    |
| 4  | RS   | 1  | R  | 接收状态    |
| 3  | TCS  | 1  | R  | 发送完毕状态  |
| 2  | TBS  | 1  | R  | 发送缓存器状态 |
| 1  | DOS  | 1  | R  | 数据溢出状态  |
| 0  | RBS  | 1  | R  | 接收缓存器状态 |

#### 16.3.4 中断寄存器 (IR)

中文名:中断寄存器

寄存器位宽: [7:0]

偏移量: 0x03

表 16- 14 CAN 控制器扩展模式下中断寄存器格式

| 位域 | 位域名称 | 位宽 | 访问 | 描述       |
|----|------|----|----|----------|
| 7  | BEI  | 1  | R  | 总线错误中断   |
| 6  | ALI  | 1  | R  | 仲裁丢失中断   |
| 5  | EPI  | 1  | R  | 错误消极中断   |
| 4  | FAI  | 1  | R  | 接收缓冲将满中断 |
| 3  | DOI  | 1  | R  | 数据溢出中断   |
| 2  | EI   | 1  | R  | 错误中断     |
| 1  | TI   | 1  | R  | 发送中断     |
| 0  | RI   | 1  | R  | 接收中断     |



#### 16.3.5 中断使能寄存器 (IER)

中文名: 中断使能寄存器

寄存器位宽: [7:0]

偏移量: 0x04

复位值: 0x00

表 16- 15 CAN 控制器扩展模式下中断使能寄存器格式

| 位域 | 位域名称 | 位宽 | 访问 | 描述         |
|----|------|----|----|------------|
| 7  | BEIE | 1  | RW | 总线错误中断使能   |
| 6  | ALIE | 1  | RW | 仲裁丢失中断使能   |
| 5  | EPIE | 1  | RW | 错误消极中断使能   |
| 4  | FAIE | 1  | RW | 接收缓冲将满中断使能 |
| 3  | DOIE | 1  | RW | 数据溢出中断使能   |
| 2  | EIE  | 1  | RW | 错误中断使能     |
| 1  | TIE  | 1  | RW | 发送中断使能     |
| 0  | RIE  | 1  | RW | 接收中断使能     |

### 16.3.6 仲裁丢失捕捉寄存器

中文名: 仲裁丢失捕捉寄存器

寄存器位宽: [7:0]

偏移量: 0xB

表 16- 16 CAN 控制器扩展模式下仲裁丢失捕捉寄存器格式

| 位域           | 位域名称   | 位宽 | 访问 | 描述  |
|--------------|--------|----|----|-----|
| 7 <b>:</b> 5 | _      | 3  | R  | 保留  |
| 4            | BITNO4 | 1  | R  | 第四位 |
| 3            | BITNO3 | 1  | R  | 第三位 |
| 2            | BITNO2 | 1  | R  | 第二位 |
| 1            | BITNO1 | 1  | R  | 第一位 |
| 0            | BITNO0 | 1  | R  | 第零位 |



| 位      |        |        |        |        | 十进制值功能 |                 |
|--------|--------|--------|--------|--------|--------|-----------------|
| ALC. 4 | ALC. 3 | ALC. 2 | ALC. 1 | ALC. 0 | 一一一一一  | 功能              |
| 0      | 0      | 0      | 0      | 0      | 0      | 仲裁丢失在识别码的bit1   |
| 0      | 0      | 0      | 0      | 1      | 1      | 仲裁丢失在识别码的bit2   |
| 0      | 0      | 0      | 1      | 0      | 2      | 仲裁丢失在识别码的bit3   |
| 0      | 0      | 0      | 1      | 1      | 3      | 仲裁丢失在识别码的bit4   |
| 0      | 0      | 1      | 0      | 0      | 4      | 仲裁丢失在识别码的bit5   |
| 0      | 0      | 1      | 0      | 1      | 5      | 仲裁丢失在识别码的bit6   |
| 0      | 0      | 1      | 1      | 0      | 6      | 仲裁丢失在识别码的bit7   |
| 0      | 0      | 1      | 1      | 1      | 7      | 仲裁丢失在识别码的bit8   |
| 0      | 1      | 0      | 0      | 0      | 8      | 仲裁丢失在识别码的bit9   |
| 0      | 1      | 0      | 0      | 1      | 9      | 仲裁丢失在识别码的bit10  |
| 0      | 1      | 0      | 1      | 0      | 10     | 仲裁丢失在识别码的bit11  |
| 0      | 1      | 0      | 1      | 1      | 11     | 仲裁丢失在SRTR位.     |
| 0      | 1      | 1      | 0      | 0      | 12     | 仲裁丢失在IDE位       |
| 0      | 1      | 1      | 0      | 1      | 13     | 仲裁丢失在识别码的bit12  |
| 0      | 1      | 1      | 1      | 0      | 14     | 仲裁丢失在识别码的bit13  |
| 0      | 1      | 1      | 1      | 1      | 15     | 仲裁丢失在识别码的bit14  |
| 1      | 0      | 0      | 0      | 0      | 16     | 仲裁丢失在识别码的bit15  |
| 1      | 0      | 0      | 0      | 1      | 17     | 仲裁丢失在识别码的bit16  |
| 1      | 0      | 0      | 1      | 0      | 18     | 仲裁丢失在识别码的bit17  |
| 1      | 0      | 0      | 1      | 1      | 19     | 仲裁丢失在识别码的bit18  |
| 1      | 0      | 1      | 0      | 0      | 20     | 仲裁丢失在识别码的bit19  |
| 1      | 0      | 1      | 0      | 1      | 21     | 仲裁丢失在识别码的bit20  |
| 1      | 0      | 1      | 1      | 0      | 22     | 仲裁丢失在识别码的bit21  |
| 1      | 0      | 1      | 1      | 1      | 23     | 仲裁丢失在识别码的bit22  |
| 1      | 1      | 0      | 0      | 0      | 24     | 仲裁丢失在识别码的bit23  |
| 1      | 1      | 0      | 0      | 1      | 25     | 仲裁丢失在识别码的bit24; |
| 1      | 1      | 0      | 1      | 0      | 26     | 仲裁丢失在识别码的bit25; |
| 1      | 1      | 0      | 1      | 1      | 27     | 仲裁丢失在识别码的bit26; |
| 1      | 1      | 1      | 0      | 0      | 28     | 仲裁丢失在识别码的bit27  |
| 1      | 1      | 1      | 0      | 1      | 29     | 仲裁丢失在识别码的bit28  |
| 1      | 1      | 1      | 1      | 0      | 30     | 仲裁丢失在识别码的bit29  |
| 1      | 1      | 1      | 1      | 1      | 31     | 仲裁丢失在RTR位       |

### 16.3.7 错误警报限制寄存器 (EMLR)

中文名: 错误警报限制寄存器

寄存器位宽: [7:0]

偏移量: 0xD

表 16-17 CAN 错误劲爆限制寄存器

| 位域   | 位域名称 | 位宽 | 访问 | 描述     |
|------|------|----|----|--------|
| 7: 0 | EML  | 8  | RW | 错误警报阀值 |



### 16.3.8 RX 错误计数寄存器 (RXERR)

中文名: RX 错误计数寄存器

寄存器位宽: [7:0]偏移量: 0xE复位值: 0x60

表 16- 18 CAN 的 RX 错误计数寄存器

| 位域   | 位域名称  | 位宽 | 访问 | 描述     |
|------|-------|----|----|--------|
| 7: 0 | RXERR | 8  | R  | 接收错误计数 |

#### 16.3.9 TX 错误计数寄存器 (TXERR)

中文名: TX 错误计数寄存器

寄存器位宽: [7:0]

偏移量: 0xF

复位值: 0x60

表 16- 19 CAN 的 TX 错误计数寄存器

| 位域   | 位域名称  | 位宽 | 访问 | 描述     |
|------|-------|----|----|--------|
| 7: 0 | TXERR | 8  | R  | 发送错误计数 |

#### 16.3.10 验收滤波器

在验收滤波器的帮助下,只有当接收信息中的识别位和验收滤波器预定义的值相等时, CAN 控制器才允许将已接收信息存入 RXFIFO。验收滤波器由验收代码寄存器和验收屏蔽寄存器定义。在模式寄存器中选择单滤波器模式或者双滤波器模式。具体的配置可以参考 SJA1000 的数据手册。

#### **16.3.11** RX 信息计数寄存器(RMCR)

中文名: RX 信息计数寄存器

寄存器位宽: [7:0]

偏移量: 0x1D

复位值: 0x00

表 16-20 CAN的 RX 错信息计数寄存器

| 位域   | 位域名称 | 位宽 | 访问 | 描述        |
|------|------|----|----|-----------|
| 7: 0 | RMCR | 8  | R  | 接收的数据帧计数器 |

## 16.4 公共寄存器

lbit time = internal\_clock\_time \* ( (BRP + 1) \* 2) \*(1+ (TESG2 + 1) + (TESG1 + 1))



### 16.4.1 总线定时寄存器 0 (BTRO)

中文名: 总线定时寄存器

寄存器位宽: [7:0]

偏移量: 0x06

复位值: 0x00

注: 在复位模式是可以读写的,工作模式是只读的。

表 16-21 CAN 总线定时寄存器 0

| 位域   | 位域名称 | 位宽 | 访问 | 描述      |
|------|------|----|----|---------|
| 7: 6 | SJW  | 8  | RW | 同步跳转宽度  |
| 5: 0 | BRP  | 8  | RW | 波特率分频系数 |

### 16.4.2 总线定时寄存器 1 (BTR1)

中文名: 总线定时寄存器 1

寄存器位宽: [7:0]

偏移量: 0x07

复位值: 0x00

表 16-22 CAN 总线定时寄存器 1

| 位域   | 位域名称  | 位宽 | 访问 | 描述                  |
|------|-------|----|----|---------------------|
| 7    | SAM   | 1  | RW | 为1时三次采样,否则是一次采用     |
| 6: 4 | TESG2 | 3  | RW | 一个 bit 中的时间段 2 的计数值 |
| 3: 0 | TSEG1 | 4  | RW | 一个 bit 中的时间段 1 的计数值 |

### 16.4.3 输出控制寄存器 (OCR)

中文名: 输出控制寄存器

寄存器位宽: [7:0]

偏移量: 0x08

复位值: 0x00

表 16-23 CAN 输出控制寄存器

| 位域   | 位域名称 | 位宽 | 访问 | 描述      |
|------|------|----|----|---------|
| 7: 0 | OCR  | 8  | RW | 保留(未使用) |



# 17 I2C 控制器

### 17.1 概述

本章给出 I2C 的详细描述和配置使用。I2C 总线是由数据线 SDA 和时钟 SCL 构成的串行总线,可发送和接收数据。器件与器件之间进行双向传送,最高传送速率 400kbps。

本系统芯片集成了 4 个 I2C 接口(I2C0<sup>~</sup>I2C3)及控制器, 4 个 I2C 控制器均可以做主设备(master),可通过引脚与其他 I2C 设备进行数据的交换。其中 I2C2 还可以作为从设备,包含 6 个 8bit 数据寄存器可用于 LA132 的通信接口,主设备还可以访问温度传感器、RTC 计数值,并通过中断寄存器产生中断请求。

### 17.2 访问地址及引脚复用

I2C0 和 I2C1 内部寄存器的物理地址构成如下:

| 地址位     | 构成      | 备注                                       |
|---------|---------|------------------------------------------|
| [31:04] | I2C 基地址 | 0x1fe00120 代表 I2C0;0x1fe00130 代表<br>I2C1 |
| [03]    | 保留      |                                          |
| [02:00] | REG     | 内部寄存器地址                                  |

I2C2 和 I2C3 通过 APB 设备进行访问,两个 I2C 控制器内部寄存器的物理地址构成如下:

| 地址位     | 构成        | 备注                       |
|---------|-----------|--------------------------|
| [18:16] | APB 模块内路由 | 3'b001代表 I2C 模块          |
| [15:09] | 保留        |                          |
| [08]    | I2C 编号    | 0x0 代表 I2C2; 0x1 代表 I2C3 |
| [07:03] | 保留        |                          |
| [02:00] | REG       | 内部寄存器地址                  |

对于 I2C 模块, 使用时要注意将对应的引脚设置为相应的功能。

与 I2C 相关的引脚设置寄存器为 5.1 节中的 i2c\_sel。

## 17.3 I2C 主控制器结构

I2C 主控制器的结构,主要模块有,时钟发生器(Clock Generator)、字节命令控制器(Byte Command Controller)、位命令控制器(Bit Command controller)、数据移位寄存器(Data Shift Register)。其余为APB总线接口和一些寄存器。

- 1) 时钟发生器模块:产生分频时钟,同步位命令的工作。
- 2) 字节命令控制器模块:将一个命令解释为按字节操作的时序,即把字节操作分解为位操作。
  - 3) 位命令控制器模块:进行实际数据的传输,以及位命令信号产生。
  - 4) 数据移位寄存器模块:串行数据移位。





图 17-1 I2C 主控制器结构

### 17.4 I2C 主控制器寄存器说明

#### 17.4.1 分频锁存器低字节寄存器 (PRER1o)

中文名: 分频锁存器低字节寄存器

寄存器位宽: [7:0]

偏移量: 0x00

复位值: 0xff

| 位域  | 位域名称   | 位宽 | 访问 | 描述          |
|-----|--------|----|----|-------------|
| 7:0 | PRER1o | 8  | RW | 存放分频锁存器的低8位 |

#### 17.4.2 分频锁存器高字节寄存器 (PRERhi)

中文名:分频锁存器高字节寄存器

寄存器位宽: [7:0]

偏移量: 0x01

复位值: 0xff

| 位域  | 位域名称   | 位宽 | 访问 | 描述          |
|-----|--------|----|----|-------------|
| 7:0 | PRERhi | 8  | RW | 存放分频锁存器的高8位 |

假设分频锁存器的值为 prescale 从 LPB 总线 PCLK 时钟输入的频率为 clock\_a SCL 总 线的输出频率为 clock\_s 则应满足如下关系

Prcescale =  $\operatorname{clock\_a/(4*clock\_s)-1}$ 

#### 17.4.3 控制寄存器 (CTR)

中文名:控制寄存器

寄存器位宽: [7:0]



 偏移量:
 0x02

 复位值:
 0x00

| 位域  | 位域名称       | 位宽 | 访问 | 描述                                    |
|-----|------------|----|----|---------------------------------------|
| 7   | EN         | 1  | RW | 模块工作使能位<br>为1正常工作模式,<br>0对分频寄存器进行操作   |
| 6   | IEN        | 1  | RW | 中断使能位为1则打开中断                          |
| 5   | Slave_mode | 1  | RW | 从模式设置(仅对 I2C2 有效)<br>0: 主模式<br>1: 从模式 |
| 4:0 | Reserved   | 6  | RW | 保留                                    |

### 17.4.4 发送数据寄存器 (TXR)

中文名: 发送寄存器

寄存器位宽: [7:0]

偏移量: 0x03

复位值: 0x00

| 位域  | 位域名称 | 位宽 | 访问 | 描述                                      |
|-----|------|----|----|-----------------------------------------|
| 7:1 | DATA | 7  | W  | 存放下个将要发送的字节                             |
| 0   | DRW  | 1  | W  | 当数据传送时,该位保存的是数据的最低位;<br>当地址传送时,该位指示读写状态 |

### 17.4.5 接收数据寄存器 (RXR)

中文名:接收寄存器

寄存器位宽: [7:0]

偏移量: 0x03

复位值: 0x00

| 位域  | 位域名称 | 位宽 | 访问 | 描述           |
|-----|------|----|----|--------------|
| 7:0 | RXR  | 8  | R  | 存放最后一个接收到的字节 |

#### 17.4.6 命令控制寄存器 (CR)

中文名:命令寄存器

寄存器位宽: [7:0]

偏移量: 0x04

| 位域 | 位域名称 | 位宽 | 访问 | 描述          |
|----|------|----|----|-------------|
| 7  | STA  | 1  | W  | 产生 START 信号 |
| 6  | ST0  | 1  | W  | 产生 STOP 信号  |
| 5  | RD   | 1  | W  | 产生读信号       |
| 4  | WR   | 1  | W  | 产生写信号       |



| 3   | ACK      | 1 | W | 产生应答信号   |
|-----|----------|---|---|----------|
| 2:1 | Reserved | 2 | W | 保留       |
| 0   | IACK     | 1 | W | 产生中断应答信号 |

都是在 I2C 发送数据后硬件自动清零。对这些位读操作时候总是读回'0'。bit 3 为 1 时表示此次传输结束时控制器不发送 ack, 反之结束时发送 ack。

#### 17.4.7 状态寄存器 (SR)

中文名: 状态寄存器

寄存器位宽: [7:0]

偏移量: 0x04

复位值: 0x00

| - 21 | <u>н.</u> Окоо |    | T  |                                      |
|------|----------------|----|----|--------------------------------------|
| 位域   | 位域名称           | 位宽 | 访问 | 描述                                   |
| 7    | RxACK          | 1  | R  | 收到应答位<br>1 没收到应答位<br>0 收到应答位         |
| 6    | Busy           | 1  | R  | I2c 总线忙标志位<br>1 总线在忙<br>0 总线空闲       |
| 5    | AL             | 1  | R  | 当 I2C 核失去 I2C 总线控制权时,该位置 1           |
| 4:2  | Reserved       | 3  | R  | 保留                                   |
| 1    | TIP            | 1  | R  | 指示传输的过程<br>1 表示正在传输数据<br>0 表示数据传输完毕  |
| 0    | IF             | 1  | R  | 中断标志位,一个数据传输完,或另外一个器件<br>发起数据传输,该位置1 |

#### 17.4.8 从模式控制寄存器 (SLV CTRL)

中文名: 从模式控制寄存器

寄存器位宽: [7:0]

偏移量: 0x07

复位值: 0x00

|   | 位域  | 位域名称     | 位宽 | 访问 | 描述             |
|---|-----|----------|----|----|----------------|
|   | 7   | slv_en   | 1  | RW | I2C2 从模式使能,高有效 |
| Ī | 6:0 | slv_addr | 7  | RW | I2C2 从模式地址     |

<sup>\*</sup>该寄存器仅用于 I2C2

## 17.5 I2C2 从模式地址空间

当 I2C2 设备配置为从模式时(将主控制器寄存器的 0x7 使能从模式,并配置从模式地址), I2C2 作为从设备,额外的寄存器空间被使能,该部分额外的寄存器空间即可被 cpu 访问,也可以通过外部 I2C 主设备访问。

I2C 主设备可访问  $0x0^{\sim}0x16$  的 I2C 总线地址空间, 其中前 16 字节为只读空间, 为芯片



内部设备的数据,这部分寄存器无法通过 cpu 访问。I2C 地址 0x10~0x16 为可读写的中断寄存器和 6 个数据寄存器。从 cpu 的地址空间上看,这部分寄存器被映射到了在主模式下原本为 I2C 主控制器的控制寄存器的地址空间,实现主设备和 cpu 访问的通信接口。值得注意的是从模式下 cpu 仍然可以访问 0x7 从模式控制寄存器以实现从模式的使能控制。

从模式下的寄存器空间如下表所示。

| 地址   | I2C 总线访问            | CPU 访问        |
|------|---------------------|---------------|
| 0x0  | 摄氏温度值 (R)           | Slave 中断(R/W) |
|      | [7:2]-固定 0;         |               |
| 0x1  | [1]- 温度值可用;         | 数据寄存器 1 (R/W) |
|      | [0]-温度溢出 (R)        |               |
| 0x2  | 固定 0 (R)            | 数据寄存器 2 (R/W) |
| 0x3  | 固定 0 (R)            | 数据寄存器 3 (R/W) |
| 0x4  | 固定 0 (R)            | 数据寄存器 4 (R/W) |
| 0x5  | 固定 0 (R)            | 数据寄存器 5 (R/W) |
| 0x6  | 固定 0 (R)            | 数据寄存器 6 (R/W) |
| 0x7  | 固定 0 (R)            | 从模式控制寄存器(R/W) |
| 0x8  | [31:26]-月,范围 1~12   |               |
| 0x9  | [25:21]-日,范围 1~31   |               |
|      | [20:16]-小时,范围 0~23  |               |
| 0xa  | [15:10]-分,范围 0~59   |               |
| 0xb  | [9:4]-秒,范围 0~59     |               |
|      | [3:0]-0.1 秒,范围 0~9  |               |
| 0xc  |                     |               |
| 0xd  | 「31:0]-年,范围 0∼16383 |               |
| 0xe  | to the second       |               |
| 0xf  |                     |               |
| 0x10 | Slave 中断(R/W)       |               |
| 0x11 | 数据寄存器 1 (R/W)       |               |
| 0x12 | 数据寄存器 2 (R/W)       |               |
| 0x13 | 数据寄存器 3 (R/W)       |               |
| 0x14 | 数据寄存器 4 (R/W)       |               |
| 0x15 | 数据寄存器 5 (R/W)       |               |
| 0x16 | 数据寄存器 6 (R/W)       |               |



# 18 PWM 控制器

## 18.1 概述

2K2000 芯片里实现了 6 路脉冲宽度调节/计数控制器,以下简称 PWM。每一路 PWM 工作和控制方式完全相同。每路 PWM 有一路脉冲宽度输出信号和一路待测脉冲输入信号。时钟频率为 50MHz, 计数寄存器和参考寄存器均 32 位数据宽度。

## 18.2 访问地址及引脚复用

PWM 控制器访问基址参考第 14 章,内部寄存器的物理地址构成如下:

| 地址位     | 构成     | 备注                        |
|---------|--------|---------------------------|
| [15:11] | 0      | 保留                        |
| [10:8]  | PWM 编号 | 取值 0x0-0x5 分别代表 PWM0-PWM5 |
| [7:4]   | 0      | 保留                        |
| [03:00] | REG    | 内部寄存器地址                   |

对于 PWM 模块, 使用时要注意将对应的引脚设置为相应的功能。

## 18.3 寄存器描述

每路控制器共有五个寄存器,具体描述如下:

表 18-1 PWM 寄存器列表

| 名称          | 地址         | 宽度 | 访问  | 说明        |
|-------------|------------|----|-----|-----------|
| Low_buffer  | Base + 0x4 | 32 | R/W | 低脉冲缓冲寄存器  |
| Full_buffer | Base + 0x8 | 32 | R/W | 脉冲周期缓冲寄存器 |
| CTRL        | Base + OxC | 11 | R/W | 控制寄存器     |

表 18-2 PWM 控制寄存器设置

| 位域   | 名称     | 访问       | 复位值   | 说明                                                    |
|------|--------|----------|-------|-------------------------------------------------------|
| 0    | EN     | R/W      | 0     | 计数器使能位<br>置 1 时: CNTR 用来计数<br>置 0 时: CNTR 停止计数 (输出保持) |
| 2: 1 |        | Reserved | 2' b0 | 预留                                                    |
| 3    | OE     | R/W      | 0     | 脉冲输出使能控制位,低有效<br>置 0 时:脉冲输出使能<br>置 1 时:脉冲输出屏蔽         |
| 4    | SINGLE | R/W      | 0     | 单脉冲控制位<br>置 1 时:脉冲仅产生一次<br>置 0 时:脉冲持续产生               |
| 5    | INTE   | R/W      | 0     | 中断使能位<br>置 1 时: 当 full_pulse 到 1 时送中断<br>置 0 时: 不产生中断 |
| 6    | INT    | R/W      | 0     | 中断位<br>读操作: 1表示有中断产生,0表示没有中断<br>写入 1: 清中断             |



| 7  | RST    | R/W | 0 | 使得 Low_level 和 full_pluse 计数器重置<br>置 1 时: 计数器重置 (从 buffer 读,输出低电平)<br>置 0 时: 计数器正常工作 |
|----|--------|-----|---|--------------------------------------------------------------------------------------|
| 8  | САРТЕ  | R/W | 0 | 测量脉冲使能<br>置1时:测量脉冲模式<br>置0时:非测量脉冲模式(一般而言则是脉冲输出<br>模式)                                |
| 9  | INVERT | R/W | 0 | 输出翻转使能<br>置1时:使脉冲在输出去发生信号翻转(周期以高<br>电平开始)<br>置0时:使脉冲保持原始输出(周期以低电平开始)                 |
| 10 | DZONE  | R/W | 0 | 防死区功能使能<br>置1时:该计数模块需要启用防死区功能<br>置0时:该模块无需防死区功能                                      |

## 18.4 功能说明

#### 18.4.1 脉宽调制功能

Low\_buffer 和 Full\_buffer 寄存器可以由系统编程写入获得初始值。系统编程写入完毕后,模块内部的 low\_level 和 full\_pulse 寄存器分别从 Low\_buffer 和 Full\_buffer 缓冲寄存器中读取初值,之后在系统时钟驱动下不断自减(初始输出低电平)。当 low\_level 寄存器到达 l 之后,输出变为高电平,此时 full\_pulse 仍在自减。当 full\_pulse 寄存器到达 l 之后,输出变为低电平,low\_level 和 full\_pulse 又分别从 Low\_buffer 和 Full\_buffer 缓冲寄存器中读取初值,然后重新开始不断自减,控制器就产生连续不断的脉冲宽度输出。当 full pulse 寄存器的值等于 l 的时候,可以配置产生一个中断,从而作为定时器使用。

例:如果要产生宽度为系统时钟周期 50 倍的高脉宽和 90 倍的低脉宽,在 low\_buffer 中应该配置初始值 90,在 full\_buffer 寄存器中配置初始值 (50+90)=140.

值得说明的是,由于两个缓冲寄存器的写入有先后之分,在某些特殊的情况下(比如写入时刻刚好是旧脉冲结束时)会使得输出脉冲有异于预期。推荐的做法是在向缓冲寄存器写入新数前,将控制寄存器 EN 位写 0,在写入新数之后再将 EN 位写 1。值得说明的是,即使没有重写 EN 位,紊乱的脉冲输出最多只会维持一个周期。

如果对两个缓冲寄存器都写 0,则输出为低电平;如果对 low\_buffer 写 0,对 full\_buffer 写 1,则输出高电平;如果写入 Low\_buffer 的值不小于 full\_buffer,则输出低电平。但这三类数值都是不推荐的。

此外,缓冲寄存器的数值写入应当先于CTRL控制寄存器。

#### 18.4.2 脉冲测量功能

待测脉冲信号连在 PWM 输入信号接口上,在设置完 CTRL 控制寄存器后,在系统时钟的驱动下,Low\_level 和 full\_pulse 寄存器开始不断自增。当检测到输入脉冲信号上跳变时,将 Low\_level 寄存器的值传送到 low\_buffer 寄存器中;当检测到输入脉冲信号下跳变时,



将 full\_pulse 寄存器的值传送到 full\_buffer 寄存器中,并将 Low\_level 和 full\_pulse 寄存器置 1,重新开始计数。

例:如果要输入脉冲为系统时钟 50 倍的高脉宽和 90 倍的低脉宽,在 low\_buffer 中最终读出的值为 90,在 full\_buffer 寄存器中读出的值为(50+90)=140.

待测脉冲应当是周期信号,且脉冲周期不应超出32位计数器能计量的范围。

每次测量均是从下跳变开始,到下一个下跳变结束。由于测量及缓冲的需要,在连续测量两个脉冲周期后,low buffer 和 full buffer 寄存器中存储的才是正确的脉冲参数。

若出现持续的周期超过 0xFFFF\_FFF9 的脉冲,控制寄存器 INT 位会被置 1,表示待测脉冲超出了计量范围。

#### 18.4.3 防死区功能

四路 PWM 都配备了防死区功能,可以防止四路脉冲输出同时发生跳变。

将四路模块分别标记为 PWM\_0、PWM\_1、PWM\_2、PWM\_3, 它们的优先级为 0>1>2>3, 即若要同时产生跳变,在 PWM\_0 跳变之后 PWM\_1 才能跳变(低优先级的信号被"抹去"一个或多个系统时钟),依此类推。该优先级是固化的,不可配置。

一个典型的防死区示例如下(PWM\_\*为未开防死区的输出,PWM\_\*'为打开防死区后的输出):



图 18-1 防死区功能



# 19 AVS 控制器

# 19.1 访问地址及引脚复用

AVS 通过 APB 设备进行访问,内部寄存器的物理地址构成如下:

| 地址位     | 构成        | 备注                |
|---------|-----------|-------------------|
| [18:16] | APB 模块内路由 | 3' b011 代表 AVS 模块 |
| [15:04] | 保留        |                   |
| [03:00] | REG       | 内部寄存器地址           |

对于 AVS 模块,使用时要注意将对应的引脚设置为相应的功能。

## 19.2 控制寄存器 (CSR)

中文名: 控制寄存器 寄存器位宽: [31: 0]

 偏移量:
 0x0

 复位值:
 0x0

| 位域    | 位域名称     | 位宽 | 访问 | 描述                                                                             |
|-------|----------|----|----|--------------------------------------------------------------------------------|
| 31    | resyn    | 1  | RW | 1表示在对设备进行通信前,先对设备进行重同步;0则不进行重同步;默认为0                                           |
| 30:29 | mask_ack | 19 | RW | 全写1表示 mask alert_ack                                                           |
| 28    | mask_i   | 1  | RW | 1表示 mask alert_i                                                               |
| 27    | mask_s   | 1  | RW | 1表示 mask alert_s                                                               |
| 26    | mask_c   | 1  | RW | 1表示 mask alert_c                                                               |
| 25    | mask_a   | 1  | RW | 1表示 mask alert_a                                                               |
| 24    | rx_ctrl  | 1  | RW | 控制器采样数据的方式,1表示在AVS 时钟的上沿开始采样数据,0表示在AVS 时钟的下沿开始采样数据;默认为0                        |
| 23:20 | rx_delay | 4  | RW | 延迟采样,1表示延迟一个单位后采样数据;<br>2表示延迟两个单位后采样数据,以此类推;默<br>认为0                           |
| 19:17 | clk_div  | 3  | RW | 时钟分频系数: 0x0, 二分频; 0x1, 四分频; 0x2, 八分频; 0x3, 十六分频; 0x4, 三十二分频; 0x5, 六十四分频; 默认二分频 |
| 16    | Dmux     | 1  | RW | 1表示接受设备返回的数据,0反之。默认为0                                                          |
| 15:0  | reserved | 16 | _  | _                                                                              |

# 19.3 参数控制寄存器 (Mreg)

中文名: 参数控制寄存器



寄存器位宽: [31: 0]偏移量: 0x4复位值: 0x0

| , j   |          |    |    |                                      |
|-------|----------|----|----|--------------------------------------|
| 位域    | 位域名称     | 位宽 | 访问 | 描述                                   |
| 31    | TX_EN    | 1  | RW | 写 1 表示开始一次 AVS 通信                    |
| 30:29 | cmd      | 2  | RW | 0x0表示写入设备并且生效; 0x1表示写入并保持,且          |
|       |          |    |    | 不立即生效; 0x2 保留; 0x3 表示读。对于写, 建议使      |
|       |          |    |    | cmd 为 0                              |
| 28    | group    | 1  | RW | 0为AVS协议指定的指令类别;1表示制造厂商自定义的           |
|       |          |    |    | 指令类别                                 |
| 27:24 | cmd_type | 4  | RW | 0x0 为电压调节命令(1LSB=1mv); 0x1 为压摆率命令,   |
|       |          |    |    | cmd_data 的高八位为上摆率,低八位为下摆率; 0x2 为     |
|       |          |    |    | 读电流命令(只读); 0x3 为读温度命令(只读); 0x4       |
|       |          |    |    | 为复位电压至默认值命令(只写); 0x5 为功率设置命          |
|       |          |    |    | 令; 0x6~0xd, 保留; 0xe 为设备状态清除命令; 0xf 为 |
|       |          |    |    | 读设备版本命令                              |
| 23:20 | rail_sel | 4  | RW | 轨道选择,如电压轨。如果该值为0xf,则表示选择全            |
|       |          |    |    | 部的轨道                                 |
| 19:4  | cmd_data | 16 | RW | 写命令需要设置的值,如设置电压值大小;读命令,该             |
|       |          |    |    | 值可设置为 0; 状态清除命令需要将该值全部置为 1           |
| 3:0   | reserved | 4  | _  | _                                    |
|       |          |    | 1  |                                      |

# 19.4 数据寄存器 (Sreg)

中文名: 返回数据寄存器

寄存器位宽: [31: 0]偏移量: 0x8复位值: 0x00

| 位域    | 位域名称      | 位宽 | 访问 | 描述                                                                                                                                |
|-------|-----------|----|----|-----------------------------------------------------------------------------------------------------------------------------------|
| 31    | busy      | 1  | R  | 1表示正在进行通信或控制器正在处理数据                                                                                                               |
| 30:29 | slave_ack | 2  | RW | 0x0 表示 CRC 校验 0K, 并且读或写有效; 0x1 表示 CRC 校验 0K, 数据都 0K, 但是设备资源不可用(busy 等)。 如,超出电压范围的电压设置; 0x2 表示 CRC 校验错误; 0x3 表示 CRC 校验 0K, 但是命令无效等 |
| 28    | alert_i   | 1  | RW | 1表示出现设备中断                                                                                                                         |
| 27    | alert_s   | 1  | RW | 1表示出现设备状态响应                                                                                                                       |
| 26    | alert_c   | 1  | RW | 1表示 CRC 校验错误                                                                                                                      |
| 25    | alert_a   | 1  | RW | 1表示出现设备状态响应,包含设备自定义的状态响应                                                                                                          |
| 24:16 | reserved  | 9  | _  | _                                                                                                                                 |



| 15:0 sdata 16 R | 设备返回的数据。如,读电压命令,该值为设备返回的电压值 |
|-----------------|-----------------------------|
|-----------------|-----------------------------|

# 19.5 使用说明

以设置电压 1.8V 为例,CSR 寄存器设为 0x70000(下沿采样数据,16 分频);然后将 Mreg 设为 0x80007080;等待 busy 为 0,最后读取 salve\_ack 寄存器,若为 0,则表示设置 成功。读电压需要设置 CSR 寄存器设为 0x70000;然后将 Mreg 设为 0xe00000000;等待 busy 为 0,最后读取 salve\_ack 寄存器,若为 0,则表示读取成功,sdata 为设备返回的电压值。假如在一次通信中设备未发送 status frame,会出现 alert\_s,alert\_c, alert\_a 一直被 拉高的情况。



# 20 HPET 控制器

### 20.1 概述

HPET (High Precision Event Timer, 高精度事件定时器)定义了一组新的定时器, 这组定时器被操作系统使用, 用来给线程调度, 内核以及多媒体定时器服务器等产生中断。操作系统可以将不同的定时器分配给不同的应用程序使用。通过配置, 每个定时器都能独立产生中断。

这组定时器由一个向上累加的主计时器(up-counter)以及一组比较器构成。这个计时器以固定的频率(50MHz)向上累加,因此当软件两次读取计时器的值时,除非遇到计时器溢出,否则第二次读取的值总是比第一次读取的值大。而每个定时器都包含一个 match 寄存器以及一个比较器。当 match 寄存器的值与主计时器相等时,那么定时器产生中断。部分定时器可产生周期性中断。

内部包括一个 64 位的主计数器 (main count) 以及三个 32 位的比较器 (comparator)。在这三个比较器中,比较器 0 支持周期性中断 (periodic-capable) 和非周期性中断,其他两个比较器支持非周期性中断。

### 20.2 访问地址

HPET 模块的访问基地址为 MISC 低速设备块的基地址加偏移 0x40000。HPET 控制器内部 寄存器的物理地址构成如下:

| 地址位     | 构成  | 备注      |
|---------|-----|---------|
| [15:08] | 0   | 保留      |
| [07:00] | REG | 内部寄存器地址 |

# 20.3 寄存器描述

下表列出了 HPET 的寄存器:

| 寄存器偏移地址                                                | 寄存器                                  | 类型  |  |
|--------------------------------------------------------|--------------------------------------|-----|--|
| 000-007h                                               | General Capabilities and ID Register | 只读  |  |
| 008-00Fh                                               | Reserved                             |     |  |
| 010-017h                                               | 读/写                                  |     |  |
| 018-01Fh Reserved                                      |                                      |     |  |
| 020-027h General Interrupt Status Register             |                                      | R/W |  |
| 028-0EFh Reserved                                      |                                      |     |  |
| 0F0-0F7h Main Counter Value Register                   |                                      | R/W |  |
| 100-107h Timer O Configuration and Capability Register |                                      | R/W |  |
| 108-10Fh Timer O Comparator Value Register             |                                      |     |  |



| 110-11Fh | Reserved                                      |     |
|----------|-----------------------------------------------|-----|
| 120-127h | Timer 1 Configuration and Capability Register | R/W |
| 128-12Fh | Timer 1 Comparator Value Register             | R/W |
| 130-13Fh | Reserved                                      |     |
| 140-147h | Timer 2 Configuration and Capability Register | R/W |
| 148-14Fh | Timer 2 Comparator Value Register             | R/W |
| 150-15Fh | Reserved                                      |     |

若系统在状态转换过程中需要保存这些寄存器的的值以便随后恢复,那么操作系统负责保存这些寄存器的值,硬件无需保存这些寄存器的值。因此当系统处于 S3, S4, S5 状态时,这些寄存器无需维持。

### General Capabilities and ID Register

| 位      | 名称                 | 描述                                    | 读写特性 |
|--------|--------------------|---------------------------------------|------|
|        |                    | Main Counter Tick Period: 这个域标示了主计时器的 |      |
| 63: 32 | COUNTER_CLK_PERIOD | 计时频率,以 fs(10^-15s)为单位。这个值必须大于         | RO   |
|        |                    | 0, 且小于或等于 0x05F5E100(100ns, 即 10MHz)  |      |
| 31: 16 | VENDOR_ID          |                                       | RO   |
| 15: 14 | Reserved           |                                       |      |
|        |                    | Counter Size:主计时器的宽度;                 |      |
| 13     | COUNT_SIZE_CAP     | 0: 32 bits                            | RO   |
|        |                    | 1: 64 bits                            |      |
|        |                    | Num of Timer: 定时器的个数; 这个域的值指示最后一      |      |
| 12:8   | NUM_TIM_CAP        | 个定时器的编号,2K2000 中有三个定时器,因此这个           | RO   |
|        |                    | 域的值是 2。                               |      |
| 7:0    | REV_ID             | 版本号;不可为0                              | RO   |

### General Configuaration Register

| 位     | 名称         | 描述                              | 读写特性 |
|-------|------------|---------------------------------|------|
| 63: 1 | Reserved   |                                 |      |
|       |            | Overal Enable; 用来使能所有定时器产生中断。如果 |      |
|       |            | 为 0, 主计时器停止计时且所有的定时器都不再产生中      |      |
| 0     | ENABLE_CNF | 断。                              | R/W  |
|       |            | 0: 主计时器停止计时且所有的定时器都不再产生中        | K/W  |
|       |            | 断;                              |      |
|       |            | 1: 主计时器计时且允许定时器产生中断;            |      |

### General Interrupt Status Register

| 位     | 名称         | 描述                                     | 读写特性 |
|-------|------------|----------------------------------------|------|
| 63: 3 | Reserved   |                                        |      |
| 2     | T2_INT_STS | Timer 2 Interrupt Active:功能同TO_INT_STS | R/WC |



| Timer 0 Interrupt Active:功能依赖于这个定时器的中断触发模式是电平触发还是边沿触发:如果是电平触发模式:这位默认是 0。当对应的定时器发生中断,那么有硬件将其置 1. 一旦被置位,软件往这位写 1 将会清空这位。 | 1 | T1_INT_STS | Timer 1 Interrupt Active:功能同TO_INT_STS                                                                                  | R/WC |
|------------------------------------------------------------------------------------------------------------------------|---|------------|-------------------------------------------------------------------------------------------------------------------------|------|
| 如果边沿触发模式: 软件将忽略这位。软件通常往这位写 0.                                                                                          | 0 | TO_INT_STS | 中断触发模式是电平触发还是边沿触发:<br>如果是电平触发模式:<br>这位默认是 0。当对应的定时器发生中断,那么有硬件<br>将其置1.一旦被置位,软件往这位写1将会清空这位。<br>往这位写 0,则无意义。<br>如果边沿触发模式: | R/WC |

各个定时器的中断触发模式由各自 Configuartion and Capability 寄存器的 Tn\_TYPE\_CNF 位确定。

### Main Counter Value Register

| 位      | 名称               | 描述                        | 读写特性  |
|--------|------------------|---------------------------|-------|
| 63: 32 | Reserved         |                           |       |
| 31: 0  | Main Counter Val | 主计时器的值; 只有当主计时器停止计时时, 才允许 | R/W   |
| 31: 0  | main_counter_var | 修改这个寄存器的值。                | IX/ W |

### Timer N Configuration and Capabilities Register

| 位     | 名称             | 描述                                          | 读写特性 |
|-------|----------------|---------------------------------------------|------|
| 63: 9 | Reserved       |                                             |      |
| 8     | Tn 32MODE CNF  | Timer n 32-bit 模式 (N 为 0-2)。当定时器为 32 位      | RO   |
|       |                | 时,这位为0,且只读                                  |      |
| 7     | Reserved       |                                             | RO   |
|       |                | Timer N Value Set (N 为 0-2):只有能产生周期性中       |      |
|       |                | 断的定时器才会使用这个域。通过对这位写1,软件                     |      |
|       |                | 能直接修改周期性定时期的累加器。软件无需对这位                     |      |
| 6     | Tn_VAL_SET_CNF | 清 0                                         | R/W  |
|       |                | 只有 Timer 0 能产生周期性中断,因此对 Timer0 来            |      |
|       |                | 讲,这位是可读可写。而对于 Timer1, Timer2,这              |      |
|       |                | 位默认为0,且为只读。                                 |      |
| 5     | Tn SIZE CAP    | Timer N Size; Timer N 的宽度(N 为 0-2)。         | RO   |
| J     | III_STZL_CM    | 0: 32 位宽。                                   | I NO |
|       |                | Timer N Periodic Interrupt Capable (N为0-2): |      |
| 4     | Tn_PER_INT_CAP | 1: 定时器能产生周期性中断;                             | RO   |
|       |                | 0: 定时器不能产生周期性中断;                            |      |
|       |                | Timer N type (N为 0-2):                      |      |
| 3     | Tn_TYPE_CNF    | 如果对应的 Tn_PER_INT_CAP 位为 0,那么这位为只            | R/W  |
|       |                | 读,且默认为 0.                                   |      |



|   |                 | 若对应的 Tn_PER_INT_CAP 位为 1, 那么这位可读可      |     |
|---|-----------------|----------------------------------------|-----|
|   |                 | 写。用作使能相应的定时器产生周期性中断。                   |     |
|   |                 | 1: 使能定时器产生周期性中断                        |     |
|   |                 | 0: 使能定时器产生非周期性中断                       |     |
| 2 | Tn INT ENB CNF  | Timer N interrupt Enable (N为0-2):使能定时器 | R/W |
| 2 | III_INI_END_CNI | 产生中断                                   | K/W |
|   |                 | Timer N Interrupt Type (N为0-2):        |     |
|   | Tn_INT_TYPE_CNF | 0: 定时器的中断触发模式为边沿触发; 这意位着对应             |     |
|   |                 | 的定时器将产生边沿触发中断。若另外的的中断产                 |     |
| 1 |                 | 生,那么将产生另外的边沿。                          |     |
|   |                 | 1: 定时器的中断触发模式为电平触发; 这意味着对应             |     |
|   |                 | 的定时器将产生电平触发中断。这个中断将一直有效                |     |
|   |                 | 直到被软件清掉(General Interrupt Status       |     |
|   |                 | Register).                             |     |
| 0 | Reserved        |                                        |     |

### Timer N Comparator Value Register

| 位      | 名称         | 描述                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 读写特性 |
|--------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| 63: 32 | Reserved   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |      |
| 31: 0  | Tn_Com_VAL | Tn_Comparator value (N为 0-2): 定时器比较器的值; 当对应的定时器配置为非周期性模式时:     ◆ 这个寄存器的值将与主计时器寄存器的值做比较;     ◆ 若主计时器的值与比较器的值相等时,则产生定时中断(如果; 对应的中断使能打开)。     ◆ 比较器的值不会因为中断的产生而发生变化若对应的定时器配置为周期性模式时:     ◆ 当主计时器的值域比较器的值相等时,产生中断(如果对应的中断使能被打开);     ◆ 如果产生中断,那么比较器的值将累加最后一次软件写入比较器的值。比如当比较器的值被写入 0x0123h, 那么当主计时器的值为 0x123h 时,产生中断; 比较器的值被硬件修改为 0x246h;     ◆ 当主计时器的值达到 0x246h 时,产生另外一个中断; 比较器的值被硬件修改为 0x369h。     ◆ 只要产生中断,那么比较器的值都会累加; 直到比较器的值达到最大(0xffffffff),那么累加器的值将会继续累加。比如当比较器的值是 FFFF0000h,而最后一次由软件写入比较器的值是 20000。当中断发生后,比较器的值变为00010000h。 | R/W  |



# 21 GPI0

龙芯 2K2000 共有 96 个 GPIO 引脚(不包含 ACPI 和 SE 专用 GPIO),4 个为专用 GPIO, 其余 92 个与其他功能复用。96 个 GPIO 中 32 个为 node 上的 GPIO, 其余 64 个为南桥上的 GPIO,两种 GPIO 的访问地址有所不同,下面分别介绍。

### 21.1 NODE GPIO 控制

node 提供最多 32 个 GPIO 供系统使用,绝大部分都与其它功能复用。通过寄存器设置,还可以将 GPIO 配置为中断输入功能,并可以设置其中断电平。

本节各个配置寄存器的基地址为 0x1fe00000。

#### 21.1.1 输出使能寄存器 (0x0500)

基地址为 0x1fe00000, 偏移地址 0x0500。

表 21-1 输出使能寄存器

| 位域    | 字段名          | 访问 | 复位值           | 描述             |
|-------|--------------|----|---------------|----------------|
| 31:0  | GPIO_OEn     | RW | 32' hffffffff | GPIO 输出使能(低有效) |
| 63:32 | GPIO_FUNC_En | RW | 32' hffff0000 | GPIO 功能使能(低有效) |

#### 21.1.2 输入输出寄存器(0x0508)

基地址为 0x1fe00000, 偏移地址 0x0508。

表 21-2 输入输出寄存器

| 位域    | 字段名    | 访问 | 复位值    | 描述        |
|-------|--------|----|--------|-----------|
| 31:0  | GPIO_0 | RW | 32' h0 | GPIO 输出设置 |
| 63:32 | GPIO_I | RO | 32' h0 | GPIO 输入状态 |

#### 21.1.3 中断控制寄存器(0x0510)

基地址为 0x1fe00000, 偏移地址 0x0510。

表 21-3 中断控制寄存器

|       |              |    | 1 - 2 1 4 4 1 | * ****          |
|-------|--------------|----|---------------|-----------------|
| 位域    | 字段名          | 访问 | 复位值           | 描述              |
|       |              |    |               | GPIO 中断有效电平设置   |
| 31:0  | GPIO_INT_Po1 | RW | 32' h0        | 0 - 低电平有效       |
|       |              |    |               | 1 - 高电平有效       |
| 63:32 | GPIO_INT_en  | RW | 32' h0        | GPIO 中断使能控制,高有效 |



#### 21.1.4 GPIO 中断控制

node 中 GPIO 引脚都可以作为中断输入使用。

GPI000、GPI008、GPI016、GPI024 共享中断控制器的 0 号中断线。

GPI001、GPI009、GPI017、GPI025 共享中断控制器的 1 号中断线。

GPI002、GPI010、GPI018、GPI026共享中断控制器的2号中断线。

GPI003、GPI011、GPI019、GPI027共享中断控制器的3号中断线。

GPI004、GPI012、GPI020、GPI028 共享中断控制器的 4 号中断线。

GPI005、GPI013、GPI021、GPI029 共享中断控制器的 5 号中断线。

GPI006、GPI014、GPI022、GPI030 共享中断控制器的 6 号中断线。

GPI007、GPI015、GPI023、GPI031 共享中断控制器的 7 号中断线。

每个 GPIO 的中断使能由配置寄存器 GPIO\_INT\_en 控制,中断电平由 GPIO\_INT\_POL 控制,寄存器如下:

基地址为 0x1fe00000, 偏移地址 0x0510。

位域 字段名 访问 复位值 描述 GPIO 中断有效电平设置 31:0 GPIO\_INT\_Pol RW 32' h0 0 - 低电平有效 1 - 高电平有效 63:32 GPIO\_INT\_en RW 32' h0 GPIO 中断使能控制,高有效

表 21-4 中断控制寄存器

当中断控制器上的每个中断线只使能其中一位 GPIO 时,可以使用边沿触发方式,固定在某个沿 (POL 设为 0 时下降沿,为 1 时上升沿) 触发中断并在中断控制器中记录。

# 21.2 南桥 GPIO 控制

南桥提供最多 64 个 GPIO 供系统使用,绝大部分都与其它功能复用。GPIO引脚由一组寄存器控制,包括: GPIO 方向控制 (GPIO\_OEN)、GPIO 输出值 (GPIO\_O)、GPIO 输入值 (GPIO\_I)、GPIO 输入中断使能控制 (GPIO\_INT\_EN)、GPIO 输入中断极性控制 (GPIO\_INT\_POL)、GPIO 输入中断边沿性控制 (GPIO\_INT\_EDGE)、GPIO 输入中断清除 (GPIO\_INT\_CLR)、GPIO 输入中断状态 (GPIO\_INT\_STS)。

表 21-5 GPIO 控制寄存器

| 寄存器           | 大小(位) | 描述                                       |
|---------------|-------|------------------------------------------|
| GPIO_OEN      | 1     | GPIO 输出使能,低有效。                           |
| GPIO_O        | 1     | GPIO 输出值。                                |
| GPIO_I        | 1     | GPIO 输入值。                                |
| GPIO_INT_EN   | 1     | GPIO 中断使能。                               |
| GPIO_INT_POL  | 1     | GPIO 中断极性。                               |
| GPIO_INT_EDGE | 1     | GPIO 中断边沿性。与 GPIO 中断极性配合控制 GPIO 中断状态的产生。 |



|              |   | POL       | EDGE | 描述      |  |
|--------------|---|-----------|------|---------|--|
|              |   | 0         | 0    | 低电平触发中断 |  |
|              |   | 1         | 0    | 高电平触发中断 |  |
|              |   | 0         | 1    | 下降沿触发中断 |  |
|              |   | 1         | 1    | 上升沿触发中断 |  |
| GPIO_INT_CLR | 1 | GPIO 中断   | 状态清除 |         |  |
| GPIO_INT_STS | 1 | GPIO 中断状态 |      |         |  |

#### 21.2.1 访问地址

GPIO 的访问基地址等于 MISC 低速设备块的基地址加偏移 0x60000。

南桥提供了两种方式来控制 GPIO 引脚。一种是按位控制每个 GPIO 引脚,一种是按字节控制每个 GPIO 引脚。南桥是通过提供两个地址空间来映射 GPIO 控制寄存器实现该功能的。一种是按位映射,一种是按字节来索引控制寄存器的每个比特位。对应的,GPIO 内部的地址空间也分为两部分。

推荐使用后一种方式来控制器 GPIO 引脚。

GPIO 模块的内部寄存器物理地址构成如下:

| 地址空间        | 说明         |  |
|-------------|------------|--|
| 0x800-0xF00 | 按字节控制寄存器地址 |  |
| 0x0 - 0x70  | 按位控制寄存器地址  |  |

表 21-6 按位控制 GPIO 配置寄存器地址

|      |               | 4211- |                                |
|------|---------------|-------|--------------------------------|
| 地址偏移 | 寄存器           | 大小(位) | 描述                             |
| 0x00 | GPIO_OEN      | 64    | GPIO 输出使能,低有效。每位控制一个 GP IO 引脚。 |
| 0x10 | GPIO_O        | 64    | GPIO 输出值。每位控制一个 GPIO 引脚。       |
| 0x20 | GPIO_I        | 64    | GPIO 输入值。每位控制一个 GPIO 引脚。       |
| 0x30 | GPIO_INT_EN   | 64    | GPIO 中断使能。每位控制一个 GPIO 引脚。      |
| 0x40 | GPIO_INT_POL  | 64    | GPIO 中断极性。每位控制一个 GPIO 引脚。      |
| 0x50 | GPIO_INT_EDGE | 64    | GPIO 中断边沿性。每位控制一个 GPIO 引脚。     |
| 0x60 | GPIO_INT_CLR  | 64    | GPIO 中断清除。每位控制一个 GPIO 引脚。      |
| 0x70 | GPIO_INT_STS  | 64    | GPIO 中断状态。每位控制一个 GPIO 引脚。      |

表 21-7 按字节控制 GPIO 配置寄存器地址

| 地址偏移  | 寄存器           | 大小<br>(字节) | 描述                              |
|-------|---------------|------------|---------------------------------|
| 0x800 | GPIO_OEN      | 64         | GPIO 输出使能,低有效。每个字节控制一个 GPIO 引脚。 |
| 0x900 | GPIO_O        | 64         | GPIO 输出值。每个字节控制一个 GPIO 引脚。      |
| 0xA00 | GPIO_I        | 64         | GPIO 输入值。每个字节控制一个 GPIO 引脚。      |
| 0xB00 | GPIO_INT_EN   | 64         | GPIO 中断使能。每个字节控制一个 GPIO 引脚。     |
| 0xC00 | GPIO_INT_POL  | 64         | GPIO 中断极性。每个字节控制一个 GPIO 引脚。     |
| 0xD00 | GPIO_INT_EDGE | 64         | GPIO 中断边沿性。每个字节控制一个 GPIO 引脚。    |
| 0xE00 | GPIO_INT_CLR  | 64         | GPIO 中断清除。每个字节控制一个 GPIO 引脚。     |
| 0xF00 | GPIO_INT_STS  | 64         | GPIO 中断状态。每个字节控制一个 GPIO 引脚。     |

#### 21.2.2 控制寄存器

#### GPIO 方向控制

 地址偏移: 00-03h
 属性: R/W

 默认值: FFFFFFF0h
 大小: 4



| 位域   | 名称       | 访问  | 描述                               |
|------|----------|-----|----------------------------------|
| 31:0 | GPIO_OEN | R/W | 对应于 GPI0[31:0]的方向控制。 0: 输出 1: 输入 |

地址偏移: 04-07h 属性: R/W 默认值: FFFFFFFFh 大小: 4

| 位域   | 名称       | 访问  | 描述                                |
|------|----------|-----|-----------------------------------|
| 31:0 | GPIO_OEN | R/W | 对应于 GPI0[63:32]的方向控制。 0: 输出 1: 输入 |

#### GPIO 输出值

地址偏移: 10-13h 属性: R/W 默认值: 0000000Fh 大小: 4

| 位域   | 名称     | 访问  | 描述                  |
|------|--------|-----|---------------------|
| 31:0 | GPIO_O | R/W | 对应于 GPI0[31:0]的输出值。 |

地址偏移: 14-17h 属性: R/W 默认值: 00000000h 大小: 4

| 位域   | 名称     | 访问  | 描述                   |
|------|--------|-----|----------------------|
| 31:0 | GPIO_O | R/W | 对应于 GPIO[63:32]的输出值。 |

### GPIO 输入值

地址偏移: 20-23h 属性: RO 默认值: N/A 大小: 4

| 位域   | 名称     | 访问 | 描述                  |
|------|--------|----|---------------------|
| 31:0 | GPIO I | RO | 对应于 GPIO[31:0]的输入值。 |

地址偏移: 24-27h 属性: RO

默认值: 00000000h 大小: 4

| 位域   | 名称     | 访问 | 描述                   |
|------|--------|----|----------------------|
| 31:0 | GPIO_I | RO | 对应于 GPI0[63:32]的输入值。 |

### GPIO 中断使能

地址偏移: 30-33h 属性: R/W 默认值: 00000000h 大小: 4

| 位域   | 名称          | 访问  | 描述                                     |
|------|-------------|-----|----------------------------------------|
| 31:0 | GPIO_INT_EN | R/W | 对应于 GPI0[31:0]的输入中断使能。 0: 关闭中断 1: 使能中断 |

 地址偏移: 34-37h
 属性: R/W

 默认值: 00000000h
 大小: 4



| 位域   | 名称          | 访问  | 描述                                            |
|------|-------------|-----|-----------------------------------------------|
| 31:0 | GPIO_INT_EN | R/W | 对应于 GPI0[63:32]的输入中断使能。<br>0: 关闭中断<br>1: 使能中断 |

### GPIO 中断极性

地址偏移: 40-43h 属性: R/W 默认值: 00000000h 大小: 4

| 位域   | 名称           | 访问  | 描述                                                             |
|------|--------------|-----|----------------------------------------------------------------|
| 31:0 | GPIO_INT_POL | R/W | 对应于 GPI0[31:0]的中断极性。<br>与中断边沿性配合,组成四种中断触发方式,见下文 GPI0 中<br>断边沿。 |

地址偏移: 44-47h 属性: R/W 默认值: 00000000h 大小: 4

| 位域   | 名称           | 访问  | 描述                                                             |
|------|--------------|-----|----------------------------------------------------------------|
| 31:0 | GPIO_INT_POL | R/W | 对应于 GPI0[63:32]的中断极性。<br>与中断边沿性配合,组成四种中断触发方式,见下文 GPI0<br>中断边沿。 |

### GPIO 中断边沿

地址偏移: 50-53h 属性: R/W 默认值: 00000000h 大小: 4

| 位域   | 名称            | 访问  | 描述     |                                                                       |  |
|------|---------------|-----|--------|-----------------------------------------------------------------------|--|
| 31:0 | GPIO_INT_EDGE | R/W | 对应于 GP | 中断边沿。<br>成四种中断触发方式。<br>描述<br>低电平触发中断<br>高电平触发中断<br>下降沿触发中断<br>上升沿触发中断 |  |

地址偏移: 54-57h 属性: R/W 默认值: 00000000h 大小: 4

| 位域   | 名称            | 访问  | 描述  |      |                      |  |
|------|---------------|-----|-----|------|----------------------|--|
|      |               |     |     |      | 的中断边沿。<br>成四种中断触发方式。 |  |
|      |               |     | POL | EDGE | 描述                   |  |
| 31:0 | GPIO_INT_EDGE | R/W | 0   | 0    | 低电平触发中断              |  |
|      |               |     | 1   | 0    | 高电平触发中断              |  |
|      |               |     | 0   | 1    | 下降沿触发中断              |  |
|      |               |     | 1   | 1    | 上升沿触发中断              |  |



### GPIO 中断清除

地址偏移: 60-63h 属性: R/W 默认值: 00000000h 大小: 4

| 位域   | 名称           | 访问  | 描述                                                                              |
|------|--------------|-----|---------------------------------------------------------------------------------|
| 31:0 | GPIO_INT_CLR | R/W | 对应于 GPI0[31:0]的中断清除。<br>写 1 清除相应 GPI0 位上的中断,随后硬件会自动置 0 中断清<br>除寄存器相应位,不需软件再作处理。 |

地址偏移: 64-67h 属性: R/W 默认值: 00000000h 大小: 4

| 位域   | 名称           | 访问  | 描述                                                                               |
|------|--------------|-----|----------------------------------------------------------------------------------|
| 31:0 | GPIO_INT_CLR | R/W | 对应于 GPIO[63:32]的中断极性。<br>写 1 清除相应 GPIO 位上的中断,随后硬件会自动置 0 中断<br>清除寄存器相应位,不需软件再作处理。 |

### GPIO 中断状态

地址偏移: 70-73h 属性: R/W 默认值: 00000000h 大小: 4

| 位域   | 名称           | 访问  | 描述                                       |
|------|--------------|-----|------------------------------------------|
| 31:0 | GPIO_INT_STS | R/W | 对应于 GPI0[31:0]的中断状态。<br>1: 有中断<br>0: 无中断 |

地址偏移: 74-77h 属性: R/W 默认值: 00000000h 大小: 4

| 位域   | 名称           | 访问  | 描述                                        |
|------|--------------|-----|-------------------------------------------|
| 31:0 | GPIO_INT_STS | R/W | 对应于 GPI0[63:32]的中断状态。<br>1: 有中断<br>0: 无中断 |



# 22 电源管理模块

桥片电源管理模块提供系统功耗管理功能。支持 Advanced Configuration and Power Interface, Version 4.0a(ACPI),提供相应的功耗管理功能。

- 系统休眠与唤醒,支持ACPI S3 (待机到内存),ACPI S4 (待机到硬盘),ACPI S5 (软 关机),并且支持电源失效检测和自动系统恢复。支持多种唤醒方式(USB,GMAC,电 源开关等)。
- 系统时钟控制,模块时钟门控,多种方式调节频率。
- 集成一个看门狗。最大定时时间约82 s。
- 集成了时钟开关和电源开关模块,可以根据需求将部分模块的时钟/电源关闭。可独立 关闭时钟/电源的包括处理器核0、处理器核1、GPU、RapidIO0、RapidIO1、PCIe2。

### 22.1 访问地址

电源管理模块的访问基地址为 MISC 低速设备块的基地址加偏移 0x50000。

注意: 电源管理模块支持按 4/1 字节访问。

电源管理模块的内部寄存器物理地址构成如下:

| 地址位     | 构成           | 备注      |
|---------|--------------|---------|
| [15:13] | 0            | 保留      |
| [12]    | 内部路由         | 0: ACPI |
| [12]    | LJ thrift ET | 1: DPM  |
| [11:8]  | 0            | 保留      |
| [7:0]   | REG          | 内部寄存器地址 |

## 22.2 电源级别

表 22- 1ACPI 状态说明

|       | * - * - * - * - * - * - * - * - * - * - |
|-------|-----------------------------------------|
| 状态    | 描述                                      |
| G0/S0 | 全部工作,该模式下系统全部工作。                        |
| G1/S1 | 暂不支持                                    |
| G1/S3 | Suspend to RAM(STR),上下文保存到内存            |
| G1/S4 | Suspend to Disk(STD),保存到硬盘,除唤醒电路全部掉电    |
| G2/S5 | Soft off, 只有唤醒电路上电                      |
| G3    | Mechanical off,所有供电失效                   |

# 22.3 ACPI 寄存器描述

本节介绍电源管理相关寄存器。寄存器电压域表示寄存器的该位所属电压域。

PMCON SOC: SOC General PM Configuration Register

| 地址偏移 |                                         | 电压域 | 属性      |
|------|-----------------------------------------|-----|---------|
| 0x00 |                                         | SOC | R/W, RO |
| 位域   | 描述                                      |     |         |
| 25   | PWRBTN_LVL - RO<br>该位指示当前 PWRBTNn 信号状态。 |     |         |
| 24:0 | 保留                                      |     |         |

PMCON RESUME: RESUME General PM Configuration Register



| 地址偏移  |                                                       | 电压域                                    | 属性                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------|-------------------------------------------------------|----------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x04  |                                                       | ACPI                                   | R/W, RO, R/WC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 位域    | 描述                                                    | ,                                      | ,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 31:14 | 保留                                                    |                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|       | VSB_GATEn_EN - R/W                                    |                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 10    | 是否使能 VSB_GATEn 功                                      | b能。0:关闭; 1:使能。                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 13    | 如果 RSMRSTn 有效过,该位为 1。重新上电后由系统配置该位。如果主板使用 VSB_GATEn 引脚 |                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|       | 作为电源管理控制信号                                            | l,系统软件必须将该位写 1。                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|       | VSB_GATEn_SLEEP_DLY                                   | - R/W                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|       | 用来控制 S0 到 S3 时,                                       | VSB_GATEn 信号下降沿相对 S3n 下降               | 经沿的提前时间                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|       | 2' b00: 休眠时提前3                                        | 1.25ms;                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 12:11 | 2' b01: 休眠时提前6                                        | 2.5ms;                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|       | 2' b10: 休眠时提前1                                        | 25ms;                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|       | 2' b11: 休眠时提前 2                                       |                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|       |                                                       | 该字段为 2'b0。重新上电后由系统                     | 配置该字段。                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|       | VSB_GATEn_WAKE_DLY                                    |                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|       |                                                       | VSB_GATEn 信号上升沿相对 S3n 上升               | 沿的延后时间                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|       | 2' b00: 唤醒时延后1                                        |                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 10:9  | 2'b01:唤醒时延后 250ms;                                    |                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|       | 2' b10: 唤醒时延后 5                                       |                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|       | 2' b11: 唤醒时延后 1                                       |                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|       |                                                       | 该字段为2'b0。重新上电后由系统                      | 配置该字段。                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 8     | 保留                                                    |                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|       | USB_GMAC_OK - R/W                                     | N// N/                                 | Alexandra - Al |
| 7     |                                                       | 该位为0,表示USB和GMAC没有配置                    | 1、个能唤醒系统。重新上电后由系                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|       | 统配置该位。                                                |                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| C     | CTT_STS - R/WC                                        | <b>五位出)</b> (20/05                     | 北大 法产生毛护士中已经体协测                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 6     | 系统在 50 状态时 反生   记录事件状态                                | temperature trip, 系统进入 G2/S5           | <b></b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|       | TT EN - R/W                                           |                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 5     | 使能 temperature tri                                    | 5. 伊拉扣40                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 4:3   | 保留                                                    | D 体护机制                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 4.0   | SRS(System Reset St                                   | tatus) - P/WC                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 2     | 0: SYS_RESETn 没有被                                     |                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|       |                                                       | カー<br>过,系统重新复位后需检查此位并作                 | 出相应清除操作。                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|       | PWROK FLR (PWROK Fat                                  |                                        | - 四4月/四4日                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 1     |                                                       | PWROK 信号变无效该位置 1,软件通过                  | 寸写 1 将该位清除。                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|       | DRAM INIT - R/W                                       | """""""""""""""""""""""""""""""""""""" | テコ + JA W l示1日 lか。                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 0     | _                                                     | PMON 在进行 DRAM 初始化前将该位置                 | 71. 结束 DRAM 初始化后络该位写                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|       |                                                       | 查 DRAM 初始化是否被打断过。                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|       |                                                       | 中 nurur NVH LPVE 日 1次11 611 1分。        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

# ${\tt PMCON\_RTC} \ : \ {\tt RTC} \ {\tt General} \ {\tt PM} \ {\tt Configuration} \ {\tt Register}$

| 地址偏移  |                                                                 | 电压域                                                   | 属性        |  |
|-------|-----------------------------------------------------------------|-------------------------------------------------------|-----------|--|
| 0x08  |                                                                 | RTC                                                   | R/W, R/WC |  |
| 位域    | 描述                                                              |                                                       |           |  |
| 31:13 | 保留                                                              |                                                       |           |  |
| 12    |                                                                 | RTC_DLY_BYPASS - R/W<br>是否将 RTC 域输入的关键信号进行延迟控制,默认值为 1 |           |  |
| 11    | RESUME_2POWER - R/W<br>RESUME 域与 ACPI 域是否为单独电压域,默认值为 1          |                                                       |           |  |
| 10    | RTC_REG_LP - R/W<br>控制 RTC 模块中寄存器是否进入低功耗模式<br>0: 非低功耗<br>1: 低功耗 |                                                       |           |  |
| 9     | CMOS_CLKDISABLE - R/W<br>控制 CMOS 模块的时钟是否关闭<br>0: 打开             |                                                       |           |  |



|     | 1: 关闭                                              |
|-----|----------------------------------------------------|
| 8:7 | 保留                                                 |
|     | S3_ASSERTION_WIDTH - R/W                           |
|     | 这 2 bit 值代表 S3n 信号从有效到重新无效的最小时间间隔。                 |
| 6:5 | 11: 1s                                             |
| 0.5 | 10: 125ms                                          |
|     | 01: 1ms                                            |
|     | 00: 60us                                           |
|     | S4_ASSERTION_WIDTH - R/W                           |
|     | 这 2 bit 值代表 S4n 信号从有效到重新无效的最小时间间隔。                 |
| 4:3 | 11: 4 s                                            |
| 4.5 | 10: 2 s                                            |
|     | 01: 1 s                                            |
|     | 00: 125 us                                         |
|     | S4_ASSERTION_EN - R/W                              |
| 2   | 0: S4n 信号从有效到重新无效的间隔为几个 RTC 周期。                    |
|     | 1: S4n 信号从有效到重新无效的间隔为 S4_ASSERTION_WIDTH 决定。       |
|     | PWR_FLR (Power Failure) - R/WC.                    |
| 1   | 该位在 RTC 域,只能被 RTC_RSTn 复位。                         |
| 1   | 如果置1表示系统发生过电源失效(进入G3状态),即除RTC以外所有供电失效过(RSMRSTn     |
|     | 有效过),软件通过写1将该位清除。                                  |
|     | AFTERG3_EN - R/W                                   |
|     | 该位决定系统进入 G3 状态后重新供电后的动作。                           |
| 0   | 0: 系统在供电恢复后将自动回复到 SO 状态。                           |
|     | 1: 系统将恢复到 S5 状态,如果发生电源失效时系统在 S4 状态,重新供电后系统恢复到 S4 状 |
|     | 态。                                                 |
|     | 该位会被 power button override 和 thermal trip 事件置 1。   |

### $PM1\_STS$ : Power Management 1 Status Register

| 地址偏移  |                                                                                                                                                                                                             | 电压域                                            | 属性         |      |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|------------|------|
| 0x0C  |                                                                                                                                                                                                             | ACPI/RTC/SOC                                   | R/WC       |      |
| 位域    | 描述                                                                                                                                                                                                          |                                                |            | 电压域  |
| 31:16 | Reserved                                                                                                                                                                                                    |                                                |            |      |
| 15    | WAK_STS (Wake Status)<br>0: 软件写 1 将该位清除<br>1: 如果系统从任何一个                                                                                                                                                     | ,                                              | 5位置 1。     | ACPI |
| 14    | PCIeXP_WAKE_STS - R/V<br>1: PCIe 唤醒事件发生<br>0: 软件写 1 将该位清除                                                                                                                                                   | VC.                                            |            | ACPI |
| 13:12 | Reserved                                                                                                                                                                                                    |                                                |            |      |
| 11    | PRBTNOR_STS (Power Button Override Status) - R/WC 0: 软件写 1 将该位清除 1: 当 power button override 发生时,该位置 1,系统无条件进入 G2/S5 状态,同时将 AFTERG3 EN 位置 1。                                                                 |                                                | RTC        |      |
| 10    | RTC_STS (RTC Status) - R/WC<br>0: 软件写 1 将该位清除<br>1: 当 RTC 产生 alarm 时该位置 1。此外当 RTC_EN 有效时,该位产生唤醒事件。                                                                                                          |                                                | ACPI       |      |
| 9     | Reserved                                                                                                                                                                                                    |                                                |            |      |
| 8     | PWRBTN_STS (Power Button Status) - R/WC 0: 软件写 1 将该位清除。Thermal trip 会清除该位。 1: 当按下 PWRBTNn 保持 16ms 以上(4s 以下)时,该位会置 1。 在 SO 状态时,当 PWRBTN_EN 和 PWRBTN_STS 同时有效时,将产生中断。 在 S3-S5 任何休眠状态时,如果 PWRBTN_STS 置位,系统将恢复。 |                                                | ACPI       |      |
| 7:1   | 保留                                                                                                                                                                                                          |                                                |            |      |
| 0     | 0: 软件写 1 将该位清除                                                                                                                                                                                              | verflow Status) - R/WC<br>>时钟周期 20ns) 的最高位翻转时, | 该位置 1。记时功能 | SOC  |



推荐使用 HPET 完成。

### PM1\_EN: Power Management 1 Enable Register

| 地址偏移  | ;                                                                           | 电压域                     | 属性             |      |
|-------|-----------------------------------------------------------------------------|-------------------------|----------------|------|
| 0x10  |                                                                             | ACPI/RTC/SOC            | R/W            |      |
| 位域    | 描述                                                                          |                         |                | 电压域  |
| 31:15 | 保留                                                                          |                         |                |      |
| 14    | PCIeXP_WAKE_DIS - R/V<br>当置位时,不产生PCIe呼                                      | V<br>换醒事件,但是该位的值不影响PCIe | XP_WAKE_STS的值。 | ACPI |
| 13:11 | 保留                                                                          |                         |                |      |
| 10    | RTC_EN (RTC Event Enable) - R/W<br>RTC 唤醒和中断使能                              |                         |                | rtc  |
| 9     | 保留                                                                          |                         |                |      |
| 8     | PWRBTN_EN (Power Button Enable) - R/W. PWRBTN 中断事件产生使能,该位不影响 PWRBTN 唤醒事件产生。 |                         |                | ACPI |
| 7:1   | 保留                                                                          |                         |                |      |
| 0     | TMROF_EN (PM Timer Ove<br>如果该位置位,TMROF_S                                    |                         |                | SOC  |

### PM1\_CNT : Power Management 1 Control Register

| 地址偏移  | <b>也</b> 址偏移 电压域 属性                                                                                                                                                                                                                                                               |                |          |      |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|----------|------|
| 0x14  |                                                                                                                                                                                                                                                                                   | ACPI/RTC/SOC   | R/W      |      |
| 位域    | 描述                                                                                                                                                                                                                                                                                |                |          | 电压域  |
| 31:14 | 保留                                                                                                                                                                                                                                                                                |                |          |      |
| 13    | SLP_EN(S1eep Enable) - R/W.<br>该位写 1 将会使系统进入 SLP_TYP 声明的休眠状态,进入相关休眠状态后该位<br>自动恢复为 0。                                                                                                                                                                                              |                | 关休眠状态后该位 | ACPI |
| 12:10 | 自动恢复为 0。  SLP_TYP(Sleep Type) - R/W. 该 3bit 表示系统的休眠状态。 000:表示 SO 状态。 001: Reserved. 010: Reserved. 101: Reserved. 100: Reserved. 100: Reserved. 111: Suspend-to-RAM. S3n 信号有效,进入 S3 状态。 110: Suspend-to-Disk. S3n, S4n 信号有效,进入 S4 状态。 111: Soft Off. S3n, S4n, S5n 信号有效,进入 S5 状态。 |                | rtc      |      |
| 9:1   | Reserved                                                                                                                                                                                                                                                                          |                |          |      |
| 0     | INT_EN - R/W<br>中断使能开关,使能电                                                                                                                                                                                                                                                        | 源管理控制器中断信号的产生。 |          | SOC  |

### PM1\_TMR : Power Management 1 Timer

| 地址偏移  |                                                   | 电压域                                   | 属性  |
|-------|---------------------------------------------------|---------------------------------------|-----|
| 0x18  |                                                   | SOC                                   | RO  |
| 位域    | 描述                                                |                                       |     |
| 31:24 | 保留                                                |                                       |     |
| 23:0  | TMR_VAL(Timer Value<br>计数器计数,周期 8ns<br>推荐使用 HPET。 | e) - RO.<br>。当 23 位翻转时,置位 TNROF_STS ( | Ŭ.∘ |

### GPEO\_STS : General Purpose EventO Status Register

| 地址偏移 |    | 电压域  | 属性   |
|------|----|------|------|
| 0x28 |    | ACPI | R/WC |
| 位域   | 描述 |      |      |



|       | GPI_STS - R/WC                                          |
|-------|---------------------------------------------------------|
| 31:16 | 0: 软件写 1 将该位清除。                                         |
|       | 1: 当 ACPI_GPIO 发生中断事件时这些位被置位,当 GPI_EN 位有效时,产生唤醒事件或中断。   |
|       | USB[5:0]_STS - R/WC.                                    |
| 15 10 | 只有第 10 位有意义,15:11 位暂无意义。                                |
| 15:10 | 0: 软件写 1 将该位清除。                                         |
|       | 1: 当 USB 发生 wake 事件时这些位被置位,当 USBx_EN 位有效时,产生唤醒事件或中断。    |
| 9:6   | 保留                                                      |
|       | GMAC2_STS - R/WC.                                       |
| 5     | 0: 软件写 1 将该位清除。                                         |
|       | 1: 当 GMAC2 发生 wake 事件时这些位被置位,当 GMAC2_EN 位有效时,产生唤醒事件或中断。 |
| 4     | 保留                                                      |
| 3     | CTW_STS - R/WC.                                         |
| 3     | thermal warning 发生                                      |
| 2     | CTA_STS - R/WC.                                         |
| 2     | thermal alert 发生                                        |
| 1:0   | 保留                                                      |

# ${\tt GPE0\_EN} \ : \ {\tt General} \ {\tt Purpose} \ {\tt Event0} \ {\tt Status} \ {\tt Register}$

| 地址偏移  |                                                                        | 电压域              | 属性  |     |
|-------|------------------------------------------------------------------------|------------------|-----|-----|
| 0x2C  |                                                                        | ACPI/RTC         | R/W |     |
| 位域    | 描述                                                                     |                  |     | 电压域 |
| 31:16 |                                                                        | l事件,GPIO 中断类型可配置 |     |     |
| 15:10 | USB[5 :0]_EN - R/W.<br>0: 无效<br>1: 使能 USBx_STS 产生唤醒事件, 当回到 SO 将产生中断信号。 |                  |     | RTC |
| 9:6   | 保留                                                                     |                  |     |     |
| 5     | GMAC2_EN - R/W.<br>0: 无效<br>1: 使能 GMAC2_STS 产生唤醒事件, 当回到 SO 将产生中断信号。    |                  | RTC |     |
| 4     | 保留                                                                     |                  |     |     |
| 3     | CTW_EN - R/W<br>使能 THERMAL WARNING产生中断。                                |                  |     |     |
| 2     | CTA_EN - R/W<br>使能 THERMAL ALERT产                                      | 生中断。             |     |     |
| 1:0   | 保留                                                                     |                  |     |     |

### RST\_CNT : Reset Control Register

| 地址偏移 |                | 电压域 | 属性  |
|------|----------------|-----|-----|
| 0x30 |                | SOC | R/W |
| 位域   | 描述             |     |     |
| 31:2 | 保留             |     |     |
| 1    | WD_EN - R/W    |     |     |
| 1    | Watch dog 功能使能 |     |     |
| 0    | OS_RST - R/W   |     |     |
|      | 软件写该位使系统复位。    |     |     |

### WD\_SET : Watch Dog Set Register

| 地址偏移 |    | 电压域 | 属性 |
|------|----|-----|----|
| 0x34 |    | SOC | WO |
| 位域   | 描述 |     |    |
| 31:1 | 保留 |     |    |



当 WD\_EN 为 1 时,写该位将重填内部 watch dog 计数器,充填的值为 WD\_Timer. 注意, watch dog 计数器的工作频率为 50MHz。

### WD\_Timer: Watch Dog Timer Register

| 地址偏移 |                                  | 电压域 | 属性  |
|------|----------------------------------|-----|-----|
| 0x38 |                                  | SOC | R/W |
| 位域   | 描述                               |     |     |
| 31:0 | 该寄存器的值为 watch dog 重填的值,复位值为全 1 。 |     |     |

### GEN\_RTC\_1 : General RTC Register 1

| 地址偏移 |           | 电压域 | 属性  |
|------|-----------|-----|-----|
| 0x50 |           | RTC | R/W |
| 位域   | 描述        |     |     |
| 31:0 | RTC 通用寄存器 |     |     |

### GEN\_RTC\_2 : General RTC Register 2

| 地址偏移 |           | 电压域 | 属性  |
|------|-----------|-----|-----|
| 0x54 |           | RTC | R/W |
| 位域   | 描述        |     |     |
| 31:0 | RTC 通用寄存器 |     |     |

### ACPI\_GPIO\_0: ACPI 域 GPIO 输出

| 地址偏移  |                 | 电压域  | 属性  |
|-------|-----------------|------|-----|
| 0x80  |                 | ACPI | R/W |
| 位域    | 描述              |      |     |
| 31:16 | 保留              |      |     |
| 15:0  | ACPI 域 GPIO 输出值 |      |     |

### ACPI\_GPIO\_OEN: ACPI 域 GPIO 输出使能

| 地址偏移  |                        | 电压域  | 属性  |
|-------|------------------------|------|-----|
| 0x84  |                        | ACPI | R/W |
| 位域    | 描述                     |      |     |
| 31:16 | 保留                     |      |     |
| 15:0  | ACPI 域 GPIO 输出使能控制,低有效 |      |     |

### ACPI\_GPIO\_I : ACPI 域 GPIO 输入

| 地址偏移  |                 | 电压域  | 属性  |
|-------|-----------------|------|-----|
| 0x88  |                 | ACPI | R/W |
| 位域    | 描述              |      |     |
| 31:16 | 保留              |      |     |
| 15:0  | ACPI 域 GPIO 输入值 |      |     |

### ACPI\_GPIO\_POL: ACPI 域 GPIO 中断极性

| 地址偏移  |                                              | 电压域  | 属性  |
|-------|----------------------------------------------|------|-----|
| 0x90  |                                              | ACPI | R/W |
| 位域    | 描述                                           |      |     |
| 31:16 | 保留                                           |      |     |
| 15:0  | ACPI 域 GPIO 中断极性控制, 1 代表高电平/上升沿, 0 代表低电平/下降沿 |      |     |

ACPI\_GPIO\_EDGE : ACPI 域 GPIO 中断边沿设置



| 地址偏移  |                                          | 电压域  | 属性  |  |
|-------|------------------------------------------|------|-----|--|
| 0x94  |                                          | ACPI | R/W |  |
| 位域    | 描述                                       | 描述   |     |  |
| 31:16 | 保留                                       |      |     |  |
| 15:0  | ACPI 域 GPI0 中断边沿设置,1 代表边沿类型中断,0 代表电平类型中断 |      |     |  |

# ACPI\_GPIO\_DUALEDGE: ACPI 域 GPIO 中断双沿设置

| 地址偏移  |                                         | 电压域  | 属性  |
|-------|-----------------------------------------|------|-----|
| 0x98  |                                         | ACPI | R/W |
| 位域    | 描述                                      |      |     |
| 31:16 | 保留                                      |      |     |
| 15:0  | ACPI 域 GPIO 中断是否为双沿触发,1 代表双沿触发,0 代表单沿触发 |      |     |

# 22.4 DPM 寄存器描述

| 名称         | 偏移地址 | 访问 | 描述                                                                                                      |
|------------|------|----|---------------------------------------------------------------------------------------------------------|
| dpm_en     | 0x0  | RW | DPM 使能,每个设备 1 位。<br>0: 禁用 DPM 控制<br>1: 使能 DPM 控制                                                        |
| pwrup_sel  | 0x4  | RW | powerup 控制,每个设备 1 位。<br>1:使用开关器件的反馈信号<br>0:使用内部计时(wait_time[7:4])                                       |
| dpm_tgt    | 0x8  | RW | DPM 目标设置,每个设备 2 位。 2' b00: 时钟和电源正常 2' b01: 关闭时钟 2' b10: 保留 2' b11: 关闭时钟和电源                              |
| dpm_sts    | 0xc  | R  | DPM 状态,每个设备 2 位。 2'b00:时钟和电源正常 2'b01:关闭时钟 2'b10:保留 2'b11:关闭时钟和电源                                        |
| wait_time0 | 0x10 | RW |                                                                                                         |
| wait_time1 | 0x14 | RW | 等待时间设置,每个设备8位。<br>[3:0]:设置复位等待周期数                                                                       |
| wait_time2 | 0x18 | RW | [7:4]:设置上电等待周期数(pwrup_sel 为 0 时),<br>bit7=0, 单位时间为 2us, 单位数量由[6:4]设置<br>bit7=1, 单位时间为 4us, 单位数量由[6:4]设置 |
| wait_time3 | 0x1c | RW |                                                                                                         |

### 设备编号:

0:core0

1:core1

2:gpu

3:rio0

4:rio1



5:pcie2

设置流程(每个设备的设置流程一致,下面以 GPU 为例):

- 1. 设置 dpm\_en[2]为 1
- 2. 设置 pwrup\_sel[2]为 1
- 3. 设置 wait\_time0[23:16]为 0x33
- 4. 设置 dpm\_tgt[5:4]为 2'b01(仅关闭时钟)或者 2'b11(关闭时钟和电源)
- 5. 读取 dpm\_sts[5:4],与 dpm\_tgt[5:4]设置一致则代表设置成功。



# **23 RTC**

## 23.1 概述

实时时钟(RTC)单元可以在主板上电后进行配置,当主板断电后,该单元仍然运作,可以仅靠板上的电池供电就正常运行。RTC单元运行时电流仅几个微安。

RTC 包含振荡器,结合外部 32.768KHZ 晶体产生工作时钟。该时钟用于时间信息的维护以及产生各种定时和计数中断。

RTC 模块中包含两个计数器,分别为 TOY (Time of Year) 计数器和 RTC 计数器。其中 TOY 计数器按年月日时分秒计数,精度为以 0.1 秒;RTC 计数器以 32.768KHz 时钟计数,宽度为 32 位。

### 23.2 访问地址

RTC 模块的访问基地址为 MISC 低速设备块的基地址加偏移 0x50100。RTC 模块的内部寄存器物理地址构成如下:

| 地址位    | 构成  | 备注      |
|--------|-----|---------|
| [15:9] | 0   | 保留      |
| [8]    | 1   | 保留      |
| [7:0]  | REG | 内部寄存器地址 |

## 23.3 寄存器描述

#### 23.3.1 寄存器地址列表

| 名称            | 偏移地址 | 位宽 | RW  | 描述              |
|---------------|------|----|-----|-----------------|
| sys_toytrim   | 0x20 | 32 | RW  | 软件必须初始化为0       |
| sys_toywrite0 | 0x24 | 32 | W   | TOY 低 32 位数值写入  |
| sys_toywrite1 | 0x28 | 32 | W   | TOY 高 32 位数值写入  |
| sys_toyread0  | 0x2C | 32 | R   | TOY 低 32 位数值读出  |
| sys_toyread1  | 0x30 | 32 | R   | TOY 高 32 位数值读出  |
| sys_toymatch0 | 0x34 | 32 | RW  | TOY 定时中断 0      |
| sys_toymatch1 | 0x38 | 32 | RW  | TOY 定时中断 1      |
| sys_toymatch2 | 0x3C | 32 | RW  | TOY 定时中断 2      |
| ava mtaatml   | 0x40 | 32 | RW  | TOY 和 RTC 控制寄存器 |
| sys_rtcctrl   | 0.00 | 32 | I.W | 软件必须初始化         |
| sys_rtctrim   | 0x60 | 32 | RW  | 软件必须初始化为0       |
| sys_rtcwrite0 | 0x64 | 32 | W   | RTC 定时计数写入      |
| sys_rtcread0  | 0x68 | 32 | R   | RTC 定时计数读出      |
| sys_rtcmatch0 | 0x6C | 32 | RW  | RTC 时钟定时中断 0    |
| sys_rtcmatch1 | 0x70 | 32 | RW  | RTC 时钟定时中断 1    |
| sys_rtcmatch2 | 0x74 | 32 | RW  | RTC 时钟定时中断 2    |

#### 23.3.2 SYS TOYWRITEO

中文名: TOY 计数器低 32 位数值



寄存器位宽: [31:0]

偏移量: 0x24

复位值: 0x00000000

| 位域    | 位域名称         | 访问 | 缺省 | 描述                     |
|-------|--------------|----|----|------------------------|
| 31:26 | TOY_MONTH    | W  |    | 月,范围 1 <sup>~</sup> 12 |
| 25:21 | TOY_DAY      | W  |    | 日,范围 1 <sup>~</sup> 31 |
| 20:16 | TOY_HOUR     | W  |    | 小时,范围 0~23             |
| 15:10 | TOY_MIN      | W  |    | 分,范围 0 <sup>~</sup> 59 |
| 9:4   | TOY_SEC      | W  |    | 秒,范围 0~59              |
| 3:0   | TOY_MILLISEC | W  |    | 0.1 秒, 范围 0~9          |

### **23.3.3** SYS\_TOYWRITE1

中文名: TOY 计数器高 32 位数值

寄存器位宽: [31:0]

偏移量: 0x28

复位值: 0x00000000

| 位域   | 位域名称     | 访问 | 缺省 | 描述           |
|------|----------|----|----|--------------|
| 31:0 | TOY_YEAR | W  |    | 年,范围 0~16383 |

#### **23. 3. 4** SYS\_TOYREADO

中文名: TOY 计数器低 32 位数值

寄存器位宽: [31: 0] 偏移量: 0x2C

复位值: 0x00000000

| 位域    | 位域名称         | 访问 | 缺省 | 描述                     |
|-------|--------------|----|----|------------------------|
| 31:26 | TOY_MONTH    | R  |    | 月,范围 1~12              |
| 25:21 | TOY_DAY      | R  |    | 日,范围 1 <sup>~</sup> 31 |
| 20:16 | TOY_HOUR     | R  |    | 小时,范围 0~23             |
| 15:10 | TOY_MIN      | R  |    | 分,范围 0~59              |
| 9:4   | TOY_SEC      | R  |    | 秒,范围 0~59              |
| 3:0   | TOY_MILLISEC | R  |    | 0.1秒,范围0~9             |

#### **23. 3. 5** SYS\_TOYREAD1

中文名: TOY 计数器高 32 位数值

寄存器位宽: [31:0]

偏移量: 0x30

复位值: 0x00000000

| 位域   | 位域名称     | 访问 | 缺省 | 描述           |
|------|----------|----|----|--------------|
| 31:0 | TOY_YEAR | R  |    | 年,范围 0~16383 |



### **23.3.6** SYS\_TOYMATCHO/1/2

中文名: TOY 计数器中断寄存器 0/1/2

寄存器位宽: [31:0]

偏移量: 0x34/38/3C

复位值: 0x00000000

| 位域    | 位域名称  | 访问 | 缺省 | 描述                     |
|-------|-------|----|----|------------------------|
| 31:26 | YEAR  | RW |    | 年,范围 0~16383           |
| 25:22 | MONTH | RW |    | 月,范围 1 <sup>~</sup> 12 |
| 21:17 | DAY   | RW |    | 日,范围 1 <sup>~</sup> 31 |
| 16:12 | HOUR  | RW |    | 小时,范围 0~23             |
| 11:6  | MIN   | RW |    | 分,范围 0~59              |
| 5:0   | SEC   | RW |    | 秒,范围0~59               |

### **23. 3. 7** SYS\_RTCCTRL

中文名: RTC 定时器中断寄存器 0/1/2

寄存器位宽: [31:0]

偏移量: 0x40

复位值:无

| 位域    | 位域名称 | 访问  | 缺省 | 描述                                      |
|-------|------|-----|----|-----------------------------------------|
| 31:24 | 保留   | R   | 0  | 保留,置0                                   |
| 23    | ERS  | R   | 0  | REN(bit13)写状态                           |
| 22:21 | 保留   | R   | 0  | 保留,置0                                   |
| 20    | RTS  | R   | 0  | Sys_rtctrim 写状态                         |
| 19    | RM2  | R   | 0  | Sys_rtcmatch2 写状态                       |
| 18    | RM2  | R   | 0  | Sys_rtcmatch2 写状态                       |
| 17    | RMO  | R   | 0  | Sys_rtcmatch0 写状态                       |
| 16    | RS   | R   | 0  | Sys_rtcwrite 写状态                        |
| 15    | 保留   | R   | 0  | 保留,置0                                   |
| 14    | 保留   | R   | 0  | 保留,置0                                   |
| 13    | REN  | R/W | 0  | RTC 使能, 高有效。需要初始化为 1                    |
| 12    | 保留   | R   | 0  | 保留,置0                                   |
| 11    | TEN  | R/W | 0  | TOY 使能,高有效。需要初始化为1                      |
| 10    | 保留   | R   | 0  | 保留,置0                                   |
| 9     | 保留   | R   | 0  | 保留,置0                                   |
| 8     | ЕО   | R/W | 0  | 0: 32.768k 晶振禁止;<br>1: 32.768k 晶振使能     |
| 7     | 保留   | R   | 0  | 保留,置0                                   |
| 6     | 保留   | R   | 0  | 保留,置0                                   |
| 5     | 32S  | R   | 0  | 0: 32.768k 晶振不工作;<br>1: 32.768k 晶振正常工作。 |
| 4     | 保留   | R   | 0  | 保留,置0                                   |
| 3     | TM2  | R   | 0  | Sys_toymatch2 写状态                       |
| 2     | TM1  | R   | 0  | Sys_toymatch1 写状态                       |
| 1     | TMO  | R   | 0  | Sys_toymatch0 写状态                       |



| 0 | TS | R  | 0 | Sys toywrite 写状态 |
|---|----|----|---|------------------|
| O | 10 | 11 | • | Sys_toywrite 与状态 |

### 23.3.8 SYS\_RTCWRITE

中文名: RTC 计数器写入端口

寄存器位宽: [31:0]

偏移量: 0x64

复位值: 0x00000000

| 位域   | 位域名称 | 访问 | 缺省 | 描述 |
|------|------|----|----|----|
| 31:0 | RTC  | W  |    |    |

### **23. 3. 9** SYS\_RTCREAD

中文名: RTC 计数器读出端口

寄存器位宽: [31:0]

偏移量: 0x68

复位值: 0x00000000

| 位域   | 位域名称 | 访问 | 缺省 | 描述 |
|------|------|----|----|----|
| 31:0 | RTC  | R  |    |    |

#### **23. 3. 10** SYS\_RTCMATCHO/1/2

中文名: RTC 定时器中断寄存器 0/1/2

寄存器位宽: [31:0]

偏移量: 0x6C/70/74

复位值: 0x00000000

| , - · | i i i i i i i i i i i i i i i i i i i |    |    |    |
|-------|---------------------------------------|----|----|----|
| 位域    | 位域名称                                  | 访问 | 缺省 | 描述 |
| 31:26 | RTC                                   | RW |    |    |



# 24 LPC 控制器 (D23:F0)

LPC 控制器具有以下特性:

- 符合LPC1.1规范
- 支持LPC访问超时计数器
- 支持Memory Read/write访问类型
- 支持Firmware Memory Read/Write访问类型(单字节)
- 支持I/0 read/write访问类型
- 支持TPM I/O read/write访问类型
- 支持Memory访问类型地址转换
- 支持Serial IRQ规范,支持17个中断源

### 24.1 LPC 配置寄存器 (D23:F0)

表 24-1. LPC 控制器的配置寄存器

| 地址偏移    | 简称       | 描述                       | 默认值               | 访问类型    |
|---------|----------|--------------------------|-------------------|---------|
| 00h-01h | VID      | Vendor ID                | 0014h             | RO      |
| 02h-03h | DID      | Device ID                | 7A0Ch             | RO      |
| 04h-05h | PCICMD   | PCI Command              | 0001h             | R/W, RO |
| 08h     | RID      | Revision ID              | 00h               | RO      |
| 09h     | PI       | Programming Interface    | 00h               | RO      |
| 0Ah     | SCC      | Sub Class Code           | 01h               | RO      |
| 0Bh     | BCC      | Base Class Code          | 06h               | RO      |
| 0Ch     | CLS      | Cache Line Size          | 00h               | RO      |
| 0Eh     | HEADTYP  | Header Type              | 00h               | RO      |
| 10h-17h | FIXCREG  | Fixed ControlRegister    | 0000000010002004h | RO      |
| 18h-1Fh | FIXMREG  | Fixed MemoryRegister     | 0000000012000004h | RO      |
| 20h-27h | FIXIOREG | Fixed I/ORegister        | 000000FDFC000001h | RO      |
| 2Ch-2Dh | SVID     | Subsystem Vendor ID      | 0000h             | RO      |
| 2Eh-2Fh | SID      | Subsystem Identification | 0000h             | RO      |
| 3Ch     | INT_LN   | Interrupt Line           | 00h               | R/W     |
| 3Dh     | INT_PN   | Interrupt Pin            | 01h               | RO      |

注: 表中未列出的地址空间表示保留。

下面列出与 PCI 配置头规范稍有不同的寄存器及其描述。

#### PCICMD-PCI 命令寄存器 (LPC-D23:F0)

地址偏移: 04-05h 属性: R/W, RO 默认值: 0000h 大小: 16 位

| 位域   | 名称                     | 访问  | 描述                                                                      |
|------|------------------------|-----|-------------------------------------------------------------------------|
| 15:2 | Reserved               | RO  | 保留                                                                      |
| 1    | Memory Space<br>Enable | R/W | 该位用来控制是否使能对 LPC 控制寄存器和 MEM 空间的访问。 0: 禁止访问; 1: 使能对 LPC 控制寄存器和 MEM 空间的访问。 |
| 0    | I/O Space Enable       | R/W | 该位用来控制是否使能对 LPC I/0 空间的访问。LPC I/0 空间的地址固定从 I/0 空间的地址 0 开始。              |



|  | 0:禁止访问;              |
|--|----------------------|
|  | 1: 使能对 LPCI/0 空间的访问。 |

#### FIXCREG-Fixed 控制寄存器

该寄存器不作为 LPC 配置头的 BAR 使用。

地址偏移: 10-17h 属性: RO 默认值: 0000000010002004h 大小: 64 位

| 位域   | 名称       | 访问 | 描述  |
|------|----------|----|-----|
| 63:0 | Reserved | RO | 保留。 |

#### FIXMREG-Fixed MEM 寄存器

该寄存器不作为 LPC 配置头的 BAR 使用。

地址偏移: 18-1Fh 属性: RO 默认值: 0000000012000004h 大小: 64 位

| 位域   | 名称       | 访问 | 描述  |
|------|----------|----|-----|
| 63:0 | Reserved | RO | 保留。 |

#### FIXIOREG-Fixed I/O寄存器

该寄存器不作为 LPC 配置头的 BAR 使用。

地址偏移: 20-27h 属性: RO 默认值: 000000FDFC000001h 大小: 64 位

| 位域   | 名称       | 访问 | 描述  |
|------|----------|----|-----|
| 63:0 | Reserved | RO | 保留。 |

FIXCREG、FIXMREG、FIXIOREG 的地址和 PCI 配置头的 BAR 寄存器相同,但这几个寄存器不作为 LPC 配置头的 BAR 寄存器使用。软件可以通过修改 PCI 配置读函数的方法来绕过该硬件bug,使得上层软件不受影响。

# 24.2 LPC 地址空间

LPC 控制器包括三个地址空间:控制寄存器空间、MEM 空间、I/O 空间。

LPC 控制寄存器空间用来配置 LPC 控制器。LPC 控制寄存器空间位于桥片的固定设备地址空间内,起始地址为 0x1000, 2000, 大小为 4KB。

LPC MEM 空间用来访问 LPC 总线上挂载的 Memory/Firmware Memory 设备。LPC MEM 空间位于桥片的固定设备地址空间内,起始地址为 0x1200,0000,大小为 32MB。处理器发往 LPC MEM 空间的访问会被转换成 LPC 协议的 Memory 访问发往 LPC 总线。LPC 控制器发出哪种类型的 Memory 访问,由 LPC 控制器的控制寄存器决定。处理器发往这个地址空间的地址可以进行地址转换。转换后的地址由 LPC 控制器的配置寄存器 LPC\_MEM\_TRANS 设置。

LPC I/0 空间用来访问 LPC 总线上挂载的 I/0 设备,LPC I/0 空间的地址从 PCI I/0 空间的 0 地址开始,大小为 128KB。处理器发往该空间的访问会被转换成 LPC 协议的 I/0 访问



发到 LPC 总线。其中 LPCI/0 空间的低 64KB 空间用来访问 LPCI/0 设备,高 64KB 空间用来访问 TPM 设备。

### 24.3 LPC 中断

LPC 控制器内部包括两类中断: SIRQ 中断和访问超时中断。LPC 控制器共支持 17 个 SIRQ 中断,对应中断相关寄存器的比特位[16:0]。访问超时中断对应中断相关寄存器的比特位[17]。

SIRQ 中断为电平触发中断,触发电平的值可由寄存器配置。软件应先配置好 SIRQ 中断的触发电平,然后再使能 LPC 控制器的 SIRQ 中断。SIRQ 中断不需要软件清除。

访问超时中断为边沿触发中断,因此,如果发生 LPC 访问超时中断,则软件需要写中断清除寄存器的 bit [17]来清除该中断。

### 24.4 LPC 控制寄存器

#### 控制寄存器 0

地址偏移: 00-03h 属性: R/W 默认值: 0000FFFFh 大小: 4

| 位域    | 名称               | 访问  | 描述                                    |
|-------|------------------|-----|---------------------------------------|
| 31    | SIRQ_EN          | R/W | SIRQ 中断使能控制                           |
| 23    | LPC_MEM_TRANS_EN | R/W | LPC Memory 空间地址转换使能                   |
| 22:16 | LPC_MEM_TRANS    | R/W | LPC Memory 空间地址转换后的高7位地址(bit[31:25]). |
| 15:0  | LPC_SYNC_TIMEOUT | R/W | LPC 访问超时的阈值(最小为 64)                   |

#### 控制寄存器1

地址偏移: 04-07h 属性: R/W 默认值: 00000000h 大小: 4

| 位域   | 名称            | 访问  | 描述                                                     |  |
|------|---------------|-----|--------------------------------------------------------|--|
| 31   | FIRMWARE_TYPE | R/W | LPC Memory 空间 Firmware Memory 访问类型设置                   |  |
| 17:0 | LPC_INT_EN    | R/W | LPC 中断使能,每个比特位对应一个中断源。对于每个中断源,<br>0: 关闭中断;<br>1: 使能中断。 |  |

#### LPC 中断状态寄存器

地址偏移: 08-0Bh 属性: RO 默认值: 00000000h 大小: 4

| 位域   | 名称          | 访问 | 描述                                                           |
|------|-------------|----|--------------------------------------------------------------|
| 17:0 | LPC_INT_SRC | RO | LPC 中断源指示,每个比特位对应一个中断源。对于每个中断源,<br>源,<br>0: 没有中断;<br>1: 有中断。 |



### LPC 中断清除寄存器

地址偏移: 0C-0Fh 属性: WO 默认值: 00000000h 大小: 4

| 位域 | 名称                    | 访问 | 描述                                                      |
|----|-----------------------|----|---------------------------------------------------------|
| 17 | LPC_TIMEOUT_INT_CLEAR | WO | LPC 访问超时中断清除(写 1 清除)。比特 17 对应 LPC 访问超时中断,写 1 清除,写 0 无效。 |

### LPC SIRQ 中断极性寄存器

地址偏移: 10-13h 属性: R/W 默认值: 0000FFFBh 大小: 4

| 位域   | 名称                | 访问  | 描述                                                     |
|------|-------------------|-----|--------------------------------------------------------|
| 16:0 | SIRQ_INT_POLARITY | R/W | LPC SIRQ 中断极性寄存器,每个比特位对应一个中断源。对于每个中断源,0:低电平触发;1:高电平触发。 |



# 25 加解密

### 25.1 DES (D29:F1)

#### 25.1.1 DES 功能概述

DES 控制器采用 32 位的 APB 接口,支持使用 DES/TDEA 算法进行加/解密,并支持使用 APB 接口进行 DMA 操作。DES 控制器采用了 OpenCore 的面积节约方案的 DES3 加/解密单元作为实现加/解密的运算单元。这个运算单元每 16 个时钟周期完成一次 DES 加/解密,每 48 个时钟周期完成一次 TDEA 加/解密。为了减少加/解密的等待时间,DES 控制器使用 2 个时钟域分别处理 APB 接口的操作和进行 DES 加/解密计算(DES 加解密使用的时钟的频率更高)。两个不同的时钟域通过 2 个 4 项的 64bit 位宽异步 FIFO 交换加/解密运算前后的数据。

DES 控制器在使用前需要先配置密钥以及 Command 寄存器。控制器有 3 个使用 64bit 格式存储的密钥: Key0、Key1、Key2。其中,Key1、Key2 仅在 TDEA 算法是需要进行配置。控制器不检查密钥中的校验位。待运算(加密还是解密由 Command [1] 的值确定)的数据通过Data\_low 和 Data\_high 写入运算数据 FIFO。DES 运算模块从运算数据 FIFO 读取数据后进行加/解密运算迭代,迭代的结果被送入运算结果 FIFO。通过 APB 接口查询 Command [4] 可以获知运算结果是否就绪。当 Command [4] 的值为0时,可以从 APB接口通过 Data\_low 和 Data\_high读取运算结果 FIFO 中的运算结果。

#### 25. 1. 2 DES 访问地址

DES 的 PCI 设备编号为 (dev29, func1),可以通过配置总线设置 DES 寄存器的基地址。物理地址的低 6 位作为偏移访问配置寄存器。

#### 25.1.3 DES 寄存器描述

DES 的寄存器列表及寄存器说明如下:

| 地址偏移 | 名称             | 说明                                                 |  |
|------|----------------|----------------------------------------------------|--|
| 0x0  | Key0_low       | DES 密钥的低 32 位/TDEA 密钥 0 的低 32 位                    |  |
| 0x4  | Key0_high      | DES 密钥的高 32 位/TDEA 密钥 0 的高 32 位                    |  |
| 0x8  | Key1_low       | TDEA 密钥 1 的低 32 位                                  |  |
| 0xc  | Key1_high      | TDEA 密钥 1 的高 32 位                                  |  |
| 0x10 | Key2_low       | TDEA 密钥 2 的低 32 位                                  |  |
| 0x14 | Key2_high      | TDEA 密钥 2 的高 32 位                                  |  |
|      |                | 非 DMA 模式 (Command[2] = 1' b0): 待加/解密数据低 32 位的      |  |
| 0x18 | <br>  Data low | 写入端口;加/解密后数据低32位的读出端口。                             |  |
| OXIO | Data_10w       | DMA 模式(Command[2] = 1'bl): Data_low 和 Data_high 不做 |  |
|      |                | 区分。先写入/读取的是数据的低32位,后写入/读取的是数据的                     |  |



|      |           | 高 32 位。                                            |
|------|-----------|----------------------------------------------------|
|      |           | 非 DMA 模式 (Command[2] = 1' b0): 待加/解密数据高 32 位的      |
|      |           | 写入端口;加/解密后数据高32位的读出端口。                             |
| 0x1c | Data_high | DMA 模式(Command[2] = 1'bl): Data_low 和 Data_high 不做 |
|      |           | 区分。先写入/读取的是数据的低32位,后写入/读取的是数据的                     |
|      |           | 高 32 位。                                            |
| 0x20 | Command   | 命令和状态控制寄存器                                         |
| 0x24 |           |                                                    |
| 0x28 | Rev       | 保留                                                 |
| 0x2c |           |                                                    |

#### Comand 寄存器位域说明:

| 位域   | 复位值 | 名称         | 属性   | 说明                                                          |
|------|-----|------------|------|-------------------------------------------------------------|
| 0    | 0   | des3       | RW   | 0: 使用 DES 算法<br>1: 使用 TDEA 算法                               |
| 1    | 0   | decrypt    | RW   | 0: 加密操作       1: 解密操作                                       |
| 2    | 0   | dma_start  | RW   | 写入 1 启动 DMA 操作,写入 0 无影响在 DMA 操作完成前此位保持为 1 当 DMA 操作完成时此位自动清零 |
| 3    | 0   | dma_done   | RW1C | 当 DMA 操作完成时,此位置 1<br>向此位写入 1,则清零                            |
| 4    | 1   | dout_empty | RO   | 0: 数据读 FIF0 非空<br>1: 数据读 FIF0 为空                            |
| 5    | 0   | din_full   | RO   | 0: 数据写 FIF0 未满<br>1: 数据写 FIF0 已满                            |
| 7:6  | 0   | Rev        | RO   | 保留                                                          |
| 31:8 | 0   | dma_count  | RW   | 需要进行 DMA 加/解密的 64 位数的个数                                     |

### 25. 2 AES (D29:F0)

#### 25. 2. 1 AES 功能概述

AES 控制器采用 32 位的 APB 接口,支持使用 128-bit KEY、192-bit KEY、256-bit KEY 进行 AES 算法加/解密,并支持使用 APB 接口进行 DMA 操作。在使用 DMA 功能时,支持 CTR 模式进行加/解密。AES 控制器有 3 个主要模块: KEY 扩展模块、加密模块、解密模块。加/解密运算模块每 11 个时钟周期完成一次 128-bit KEY 的 AES 加/解密,每 13 个时钟周期完成一次 192-bit KEY 的 AES 加/解密,每 15 个时钟周期完成一次 256-bit KEY 的 AES 加/解



密。为了减少加/解密的等待时间,AES 控制器使用 2 个时钟域分别处理 APB 接口的操作和进行 AES 加/解密计算(AES 加解密使用的时钟的频率更高)。KEY 扩展模块工作在速度较慢的 APB 时钟域。两个不同的时钟域通过 2 个 4 项的 128bit 位宽异步 FIFO 交换加/解密运算前后的数据。

AES 控制器在使用前需要先配置密钥以及 Command 寄存器。AES 的密钥、明文和密文均以小尾端的格式进行存储。控制器使用 8 个 32bit 寄存器以小尾端的格式存储密钥: Key0、Key1、Key2、key3、key4、key5、key6、key7。其中,Key4、Key5 仅在 192-bit KEY 和 256-bit KEY 时需要进行配置; Key6、Key7 仅在 256-bit KEY 时需要进行配置。待运算(加密还是解密由 Command[1]的值确定)的数据通过 4 个 32 位寄存器地址(Data0、Data1、Data2、Data3)写入运算数据 FIF0。AES 运算模块从运算数据 FIF0 读取数据后进行加/解密运算迭代,迭代的结果被送入运算结果 FIF0。通过 APB 接口查询 Command[4]可以获知运算结果是否就绪。当 Command[4]的值为 0 时,可以从 APB 接口通过 Data0、Data1、Data2、Data3 读取运算结果 FIF0 中的运算结果。

#### 25. 2. 2 AES 访问地址

AES 的 PCI 设备编号为 (dev29, func0),可以通过配置总线设置 AES 寄存器的基地址。物理地址的低 6 位作为偏移访问配置寄存器。

### 25.2.3 AES 寄存器描述

AES 的寄存器列表及寄存器说明如下:

| 地址偏移 | 名称    | 说明                                                                                                                                   |
|------|-------|--------------------------------------------------------------------------------------------------------------------------------------|
| 0x0  | Key0  | AES 密钥的 Key[31:0],以小尾端形式存储的 AES 密钥的最低 32 位                                                                                           |
| 0x4  | Key1  | AES 密钥的 Key[63:32]                                                                                                                   |
| 0x8  | Key2  | AES 密钥的 Key[95:64]                                                                                                                   |
| 0xc  | Key3  | AES 密钥的 Key [127:96],在使用 128-bit Key 时为以小尾端形式存储的 AES 密钥的最高 32 位                                                                      |
| 0x10 | Key4  | AES 密钥的 Key[159:128],仅在使用 192/256-bit 的 Key 时使用                                                                                      |
| 0x14 | Key5  | AES 密钥的 Key [191:160] ,仅在使用 192/256-bit 的 Key 时使用,在使用 192-bit Key 时为以小尾端形式存储的 AES 密钥的最高 32 位                                         |
| 0x18 | Key6  | AES 密钥的 Key[223:192] ,仅在使用 256-bit 的 Key 时使用                                                                                         |
| 0x1c | Key7  | AES 密钥的 Key [255:224] ,仅在使用 256-bit 的 Key 时使用,在使用 256-bit Key 时为以小尾端形式存储的 AES 密钥的最高 32 位                                             |
| 0x20 | DataO | 非 DMA 模式 (Command [2]=1'b0): 待加/解密数据最低 32 位的写入端口和加/解密后数据最低 32 位的读出端口 DMA 模式 (Command [2]=1'b1): Data0-Data3 不做区分,数据按照从低到高的小尾端顺序写入或读出 |



|      |              | 非 DMA 模式(Command[2]=1'b0):待加/解密数据 63~32 位的写入端口和加  |
|------|--------------|---------------------------------------------------|
| 0x24 | Data1        | /解密后数据高 63~32 位的读出端口                              |
| 0x24 | Datai        | DMA 模式(Command[2]=1'b1):Data0-Data3 不做区分,数据按照从低到高 |
|      |              | 的小尾端顺序写入或读出                                       |
|      |              | 非 DMA 模式(Command[2]=1'b0):待加/解密数据 95~64 位的写入端口和加  |
| 0x28 | Data2        | /解密后数据高 95~64 位的读出端口                              |
| UX28 | Dataz        | DMA 模式(Command[2]=1'b1):DataO-Data3 不做区分,数据按照从低到高 |
|      |              | 的小尾端顺序写入或读出                                       |
|      |              | 非 DMA 模式(Command[2]=1'b0):待加/解密数据的最高 32 位(127~96) |
| 0x2c | Data3        | 的写入端口和加/解密后数据最高 32 位(127~96)的读出端口                 |
| UXZC | ратаз        | DMA 模式(Command[2]=1'b1):DataO-Data3 不做区分,数据按照从低到高 |
|      |              | 的小尾端顺序写入或读出                                       |
| 0x30 | Ctm init and | 使用 CTR 模式时 CTR 计数器的初始值。要使此寄存器的值发生作用需要先            |
| 000  | Ctr_init_val | 配置此寄存器的值,再向 cammand[0]写入 0。                       |
| 0x34 | Command      | 命令和状态控制寄存器                                        |
| 0x38 | D.           | /u ka                                             |
| 0x3c | _ Rev        | 保留<br>                                            |
|      |              |                                                   |

### Comand 寄存器位域说明:

| 位域   | 复位值 | 名称         | 属性   | 说明                                                          |
|------|-----|------------|------|-------------------------------------------------------------|
| 0    | 0   | Ctr_mode   | RW   | 0: 使用普通的 AES 算法进行加/解密 1: 使用 CTR 模式进行 AES 算法的加/解密            |
| 1    | 0   | decrypt    | RW   | 0: 加密操作         1: 解密操作                                     |
| 2    | 0   | dma_start  | RW   | 写入 1 启动 DMA 操作,写入 0 无影响在 DMA 操作完成前此位保持为 1 当 DMA 操作完成时此位自动清零 |
| 3    | 0   | dma_done   | RW1C | 当 DMA 操作完成时,此位置 1,中断输出信号变为高电平<br>向此位写入 1,则清零,中断输出信号变为低电平    |
| 4    | 1   | dout_empty | RO   | 0: 数据读 FIF0 非空<br>1: 数据读 FIF0 为空                            |
| 5    | 0   | din_full   | RO   | 0: 数据写 FIF0 未满<br>1: 数据写 FIF0 已满                            |
| 7:6  | 0   | Kr_mode    | RW   | 0: 128-bit KEY<br>1: 192-bit KEY<br>2: 256-bit KEY<br>3: 保留 |
| 31:8 | 0   | dma_count  | RW   | 需要进行 DMA 加/解密的 128 位数的个数                                    |



### 25.3 RSA (D29:F2)

#### 25.3.1 RSA 访问地址

RSA 的 PCI 设备编号为(dev29, func2),可以通过配置总线设置 RSA 寄存器的基地址。物理地址的低 11 位作为偏移访问内部空间。

### 25.4 RNG (D29:F3)

### 25.4.1 RNG 访问地址

RNG 的 PCI 设备编号为(dev29, func33),可以通过配置总线设置 RNG 的基地址。直接通过以上地址访问 RNG 会返回一个 32 位随机数。



# 26 EMMC 控制器 (D28:F0)

# 26.1 功能特性

- 兼容eMMC5.1版本
- 支持eMMC启动
- 8位预分频逻辑 (频率=系统时钟/(p+1))
- DMA数据传输模式
- 专用独立DMA通道
- 1位/4位/8位的总线模式

# 26.2 寄存器描述

EMMC 控制器的寄存器详细说明如下:

| 寄存器名称    | 偏移地址 | 读/写(R/W) | 功能描述       | 复位值 |
|----------|------|----------|------------|-----|
| EMMC_CON | 0x00 | R/W      | EMMC 控制寄存器 | 0x0 |

| EMMC_CON | 位    | 缺省值 | 描述                      |
|----------|------|-----|-------------------------|
| •        | 31:9 | 0x0 |                         |
| soft_rst | 8    | 0x0 | 软件复位,整个模块复位。复位完成后硬件自动清零 |
| Reserved | 7:1  | 0x0 |                         |
| enclk    | 0    | 0x0 | SD 时钟输出使能               |

| 寄存器名称    | 地址   | 读/写(R/W) | 功能描述        | 复位值 |
|----------|------|----------|-------------|-----|
| EMMC_PRE | 0x04 | R/W      | EMMC 预分频寄存器 | 0x1 |

| EMMC_PRE        | 位     | 缺省值 | 描述                                                                                                 |
|-----------------|-------|-----|----------------------------------------------------------------------------------------------------|
| emmc_clk_rev_en | 31    | 0x1 | SDR 模式时,该位为 1,表示控制器输出的 emmc 数据与 emmc 时钟下降沿对齐;该位为 0,表示控制器输出的 emmc 数据与 emmc 时钟上升沿对齐。DDR 模式,该位必须置为 1。 |
| Reserved        | 30:10 | 0x0 |                                                                                                    |
| emmc_pre        | 9:0   | 0x1 | EMMC 时钟预分频值,输出频率=PCLK/预分频值                                                                         |

| 寄存器名称        | 偏移地址 | 读/写(R/W) | 功能描述         | 复位值 |
|--------------|------|----------|--------------|-----|
| EMMC_CMD_ARG | 0x08 | R/W      | EMMC 命令参数寄存器 | 0x0 |



| EMMC_CMD_ARG | 位    | 缺省值 | 描述   |
|--------------|------|-----|------|
| sdi_cmd_arg  | 31:0 | 0x0 | 命令参数 |

| 寄存器名称        | 偏移地址 | 读/写(R/W) | 功能描述         | 复位值 |
|--------------|------|----------|--------------|-----|
| EMMC_CMD_CON | 0x0c | R/W      | EMMC 命令控制寄存器 | 0x0 |

| EMMC_CMD_CON   | 位     | 缺省值 | 描述                                                                          |
|----------------|-------|-----|-----------------------------------------------------------------------------|
| Reserved       | 31:18 | 0x0 |                                                                             |
| func_num_abort | 17:15 | 0x0 | EMMC 卡时中断的功能号,用于多块读写时,硬件自动<br>发送停止命令。如果 auto_stop_en 为 0,则此位无效              |
| emmc_en        | 14    | 0x0 | EMMC 使能信号。用于多块读写时,硬件自动发送停止命令,为1时发送 CMD52,为0是发送 CMD12。如果auto_stop_en为0,则此位无效 |
| check_on       | 13    | 0x0 | 是否检查 CRC, 为 1 时有效                                                           |
| Auto_stop_en   | 12    | 0x0 | 硬件自动发送停止命令,多块读写时,是否硬件自动<br>发送停止命令,为1时有效                                     |
| Reserved       | 11    | 0x0 |                                                                             |
| long_rsp       | 10    | 0x0 | 是否为136位长响应,为1时表示长消息回复                                                       |
| Wait_rsp       | 9     | 0x0 | 决定是否主机等待相应,为1是表示等待消息回复                                                      |
| CMST           | 8     | 0x0 | 命令开始,置1时开始,命令结束后硬件自动清零                                                      |
| cmd_index      | 7:0   | 0x0 | 带开始 2 位的命令索引 (共 8 位)                                                        |

| 寄存器名称        | 偏移地址 | 读/写(R/W) | 功能描述         | 复位值 |
|--------------|------|----------|--------------|-----|
| EMMC_CMD_STA | 0x10 | RO       | EMMC 命令状态寄存器 | 0x0 |

| EMMC_CMD_STA | 位     | 缺省值 | 描述                                                              |
|--------------|-------|-----|-----------------------------------------------------------------|
| Reserved     | 31:13 | 0x0 |                                                                 |
| cmd_sent_fin | 14    | 0x0 | 命令发送完成(包含响应)标志位,为1表示命令发送完成及响应完成                                 |
| auto_stop    | 13    | 0x0 | 硬件自动发送停止命令标志位,为1表示硬件自动发送停止命令,为0则没有                              |
| rsp_crc_err  | 12    | 0x0 | 响应 CRC 错误,接收到的响应 CRC 错误。为 1 时表示响应 CRC 错误,为 0 时未发现               |
| cmd_end      | 11    | 0x0 | 命令发送完成(不关心响应)。为1时表示命令发送<br>完成,为0时未完成。                           |
| cmd_tout     | 10    | 0x0 | 命令超时。命令响应超时(64个时钟周期),或者<br>R1b类型的命令,忙等待超时,为1时表示响应超时,<br>为0时未超时。 |



| 6:        | 0   | 00  | 响应结束,接收完成从设备的返回信息。为1时表示    |
|-----------|-----|-----|----------------------------|
| rsp_fin   | 9   | 0x0 | 响应结束,为0时未完成。               |
| cmd_on    | 8   | 0x0 | 命令传输标志位。为1时表示传输进行中,为0表示结束。 |
| rsp_index | 7:0 | 0x0 | 从设备返回的带开始2位的响应索引(共8位)      |

| 寄存器名称     | 偏移地址 | 读/写(R/W) | 功能描述           | 复位值 |
|-----------|------|----------|----------------|-----|
| EMMC_RSP0 | 0x14 | RO       | EMMC 命令响应寄存器 0 | 0x0 |

| EMMC_RESPO | 位    | 缺省值 | 描述                                                       |
|------------|------|-----|----------------------------------------------------------|
| sdi_resp0  | 31:0 | 0x0 | 卡状态[31:0] (短),卡状态[127:96] (长)长响应<br>的配置间 sdi_cmd_con[10] |

| 寄存器名称     | 偏移地址 | 读/写(R/W) | 功能描述           | 复位值 |
|-----------|------|----------|----------------|-----|
| EMMC_RSP1 | 0x18 | RO       | EMMC 命令响应寄存器 1 | 0x0 |

| EMMC_RESP1 | 位    | 缺省值 | 描述                                             |
|------------|------|-----|------------------------------------------------|
| sdi_respl  | 31:0 | 0x0 | 未使用 (短), 卡状态[95:64] (长)长响应的配置间 sdi_cmd_con[10] |

|   | 寄存器名称     | 偏移地址 | 读/写(R/W) | 功能描述           | 复位值 |
|---|-----------|------|----------|----------------|-----|
| Ī | EMMC_RSP2 | 0x1c | RO       | EMMC 命令响应寄存器 2 | 0x0 |

| EMMC_RESP2 | 位    | 缺省值 | 描述                        |
|------------|------|-----|---------------------------|
| sdi resp2  | 31:0 | 0x0 | 未使用(短),卡状态[63:32](长)长响应的配 |
| Sul_lesp2  | 31.0 |     | 置间 sdi_cmd_con[10]        |

| 寄存器名称     | 偏移地址 | 读/写(R/W) | 功能描述           | 复位值 |
|-----------|------|----------|----------------|-----|
| EMMC_RSP3 | 0x20 | RO       | EMMC 命令响应寄存器 3 | 0x0 |

| EMMC_RESP3 | 位    | 缺省值 | 描述                                             |
|------------|------|-----|------------------------------------------------|
| sdi_resp3  | 31:0 | 0x0 | 未使用(短),卡状态[31:0](长)长响应的配置<br>间 sdi_cmd_con[10] |

| 寄存器名称       | 偏移地址 | 读/写(R/W) | 功能描述           | 复位值 |
|-------------|------|----------|----------------|-----|
| EMMC_DTIMER | 0x24 | R/W      | EMMC 命令数据超时寄存器 | 0x0 |



| EMMC_DTIMER | 位     | 缺省值 | 描述                             |
|-------------|-------|-----|--------------------------------|
| Reserved    | 31:28 | 0x0 |                                |
| ext_dtimer  | 27:24 | 0x0 | 数据超时计数值,sdi_dtimer 设置为最大值时方可使用 |
| sdi_dtimer  | 23:0  | 0x0 | 数据超时计数值,用分频后的时钟计数              |

| 寄存器名称      | 偏移地址 | 读/写(R/W) | 功能描述        | 复位值 |
|------------|------|----------|-------------|-----|
| EMMC_BSIZE | 0x28 | R/W      | EMMC 块大小寄存器 | 0x0 |

| EMMC_BSIZE | 位     | 缺省值 | 描述           |
|------------|-------|-----|--------------|
| Reserved   | 31:12 | 0x0 |              |
| sdi_bsize  | 11:0  | 0x0 | 块大小值(0~4095) |

| 寄存器名称        | 偏移地址 | 读/写(R/W) | 功能描述         | 复位值 |
|--------------|------|----------|--------------|-----|
| EMMC_DAT_CON | 0x2c | R/W      | EMMC 数据控制寄存器 | 0x0 |

| EMMC_DAT_CON | 位                   | 缺省值 | 描述                                            |
|--------------|---------------------|-----|-----------------------------------------------|
| Reserved     | 31:21               | 0x0 |                                               |
| wide mode 8b | wide_mode_8b 26 0x0 |     | wide_mode_8b 为 1, wide_mode 为 0, 表示八线模式 (emmc |
|              |                     |     | 模式有效)                                         |
| resume rw    | 20                  | 0x0 | EMMC 挂起回复读写标志位。为 1 时,EMMC 挂起后恢复之前             |
| _            |                     |     | 的写操作;为0时,恢复之前的读操作                             |
| IO resume    | 19                  | 0x0 | EMMC 恢复请求。在 EMMC 设备进入挂起状态后,将此位写 1,            |
|              |                     |     | 并且 IO_suspend 位写 0 后,EMMC 设备恢复之前的操作。          |
|              |                     |     | EMMC 挂起请求。写 1 后控制器会在合适的时机发送 CMD52             |
| IO_suspend   | 18                  | 0x0 | 命令,通知 EMMC 设备进入挂起状态。恢复操作时需要将此                 |
|              |                     |     | 位写 0.                                         |
| RwaitReg     | 17                  | 0x0 | 读等待请求。写 1 后控制器会在合适的时机将 DAT2 拉低,               |
| 1            |                     |     | 通知 EMMC 设备进入读等待状态。写 0 后恢复之前的读操作。              |
| wide_mode    | 16                  | 0x0 | 位宽选择位。为1表示4线模式,为0表示单线模式。                      |
| DMA_en       | 15                  | 0x0 | DMA 使能。为 1 时表示使能 DMA, 为 0 表示禁止 DMA            |
| DTST         | 14                  | 0x0 | 数据传输开始,写1时数据传输开始,数据传输结束后硬件                    |
|              |                     |     | 清零。                                           |
| Reserved     | 13:12               | 0x0 |                                               |
| B1k_num      | 11:0                | 0x0 | 读写操作的块数。                                      |

| 寄存器名称        | 偏移地址 | 读/写(R/W) | 功能描述         | 复位值 |
|--------------|------|----------|--------------|-----|
| EMMC_DAT_CNT | 0x30 | R/W      | EMMC 数据计数寄存器 | 0x0 |



| EMMC_DAT_CNT | 位     | 缺省值 | 描述        |
|--------------|-------|-----|-----------|
| Reserved     | 31:24 | 0x0 |           |
| blk_num_cnt  | 23:12 | 0x0 | 当前传输块的字节数 |
| blk_cnt      | 11:0  | 0x0 | 当前传输的块数   |

| 寄存器名称        | 偏移地址 | 读/写(R/W) | 功能描述         | 复位值 |
|--------------|------|----------|--------------|-----|
| EMMC_DAT_STA | 0x34 | RO       | EMMC 数据状态寄存器 | 0x0 |

| EMMC_DAT_STA | 位     | 缺省值 | 描述                                                         |
|--------------|-------|-----|------------------------------------------------------------|
| Reserved     | 31:17 | 0x0 |                                                            |
| suspend_on   | 16    | 0x0 | 为1时表示正在挂起状态                                                |
| rst_suspend  | 15    | 0x0 | 为1表示正在挂起复位。用于EMMC设备挂起后,<br>控制器复位 FIFO 和 DMA 请求             |
| R1b_tout     | 14    | 0x0 | 为 1 表示 R1b 类型命令超时                                          |
| data_start   | 13    | 0x0 | 为1表示数据传输开始                                                 |
| R1b_fin      | 12    | 0x0 | 检测到带 busy 状态的命令完成。当发送带 busy 状态的命令时,此位为 0; 当 busy 状态结束时变成 1 |
| auto_stop    | 11    | 0x0 | 为1时表示硬件正在自动发送停止命令                                          |
| Reserved     | 10    | 0x0 |                                                            |
| r_wait_req   | 9     | 0x0 | 读等待发生。发送读等待请求信号到 EMMC 卡                                    |
| EMMC_int     | 8     | 0x0 | EMMC 中断标志位。为 1 表示检测到中断                                     |
| crc_sta      | 7     | 0x0 | 数据发送后,从设备返回 CRC 错误                                         |
| dat_crc      | 6     | 0x0 | 数据接收 CRC 错误                                                |
| dat_tout     | 5     | 0x0 | 数据传输超时。为1时表示数据超时。                                          |
| dat_fin      | 4     | 0x0 | 数据传输结束标志位(比如编程时)。为1时标志<br>忙结束                              |
| busy_fin     | 3     | 0x0 | 编程错误标志位(比如编程时)。为1时标志忙结<br>束                                |
| prog_err     | 2     | 0x0 | 编程错误标志位,为1时表示编程错误                                          |
| tx_dat_on    | 1     | 0x0 | Tx 数据发送中,为1时表示正在发送,为0时发送完成                                 |
| rx_dat_on    | 0     | 0x0 | Rx 数据接收中,为1时表示正在接收,为0时发送完成。                                |

| 寄存器名称         | 偏移地址 | 读/写(R/W) | 功能描述            | 复位值 |
|---------------|------|----------|-----------------|-----|
| EMMC_FIFO_STA | 0x38 | RO       | EMMC FIFO 状态寄存器 | 0x0 |



| EMMC_FIFO_STA | 位     | 缺省值 | 描述           |
|---------------|-------|-----|--------------|
| Reserved      | 31:12 | 0x0 |              |
| tx_full       | 11    | 0x0 | Tx FIFO 满标志位 |
| tx_empty      | 10    | 0x0 | Tx FIFO 空标志位 |
| Reserved      | 9     | 0x0 |              |
| rx_full       | 8     | 0x0 | Rx FIFO 满标志  |
| rx_empty      | 7     | 0x0 | Rx FIFO 空标志位 |
| Reserved      | 6:0   | 0x0 |              |

| 寄存器名称         | 偏移地址 | 读/写(R/W) | 功能描述       | 复位值 |
|---------------|------|----------|------------|-----|
| EMMC_INT_MASK | 0x3c | R/W      | EMMC 中断寄存器 | 0x0 |

| EMMC_INT_MASK | 位     | 缺省值 | 描述                         |
|---------------|-------|-----|----------------------------|
| Reserved      | 31:10 | 0x0 |                            |
| R1b_fin_int   | 9     | 0x0 | 检测到 busy 结束中断,写 1 清零       |
| rsp_crc_int   | 8     | 0x0 | 命令响应 CRC 错误中断,写 1 清零       |
| cmd_tout_int  | 7     | 0x0 | 命令超时中断,写 1 清零              |
| cmd_fin_int   | 6     | 0x0 | 发送完成中断,硬件清零                |
| EMMC_int      | 5     | 0x0 | 检测到 EMMC 中断,写 1 清零         |
| prog_err_int  | 4     | 0x0 | 编程错误中断,写 1 清零              |
| crc_sta_int   | 3     | 0x0 | 数据发送后从设备返回 CRC 错误中断,写 1 清零 |
| dat_crc_int   | 2     | 0x0 | 数据接收 CRC 错误中断,写 1 清零       |
| dat_tout_int  | 1     | 0x0 | 数据超时中断,写1清零                |
| dat_fin_int   | 0     | 0x0 | 数据完成中断,硬件清零                |

| 寄存器名称    | 偏移地址 | 读/写(R/W) | 功能描述         | 复位值 |
|----------|------|----------|--------------|-----|
| EMMC_DAT | 0x40 | RO       | EMMC 命令数据寄存器 | 0x0 |

| EMMC_DAT | 位    | 缺省值 | 描述                           |
|----------|------|-----|------------------------------|
| emmc_dat | 31:0 | 0x0 | EMMC 控制器发送或者接收的数据(用于 DMA 操作) |

| 寄存器名称       | 偏移地址 | 读/写(R/W) | 功能描述         | 复位值 |
|-------------|------|----------|--------------|-----|
| EMMC_INT_EN | 0x64 | R/W      | EMMC 中断寄使能存器 | 0x0 |

| EMMC_INT_EN    | 位     | 缺省值 | 描述                |
|----------------|-------|-----|-------------------|
| Reserved       | 31:10 | 0x0 |                   |
| R1b_fin_int_en | 9     | 0x0 | Busy 结束中断使能,为1时有效 |



| rsp_crc_int_en  | 8   | 0x0 | 命令响应 CRC 错误中断使能,为1时有效    |  |
|-----------------|-----|-----|--------------------------|--|
| cmd_tout_int_en | 7   | 0x0 | 命令超时中断使能,为1时有效           |  |
| cmd_fin_int_en  | 6   | 0x0 | 命令发送完成中断使能,为1时有效         |  |
| EMMC_int_en     | 5   | 0x0 | EMMC 中断使能,为1时有效          |  |
| prog_err_int_en | 4   | 0x0 | SD 卡编程错误中断使能,为1时有效       |  |
| crc sta int en  | 3   | 0x0 | 数据发送后从设备返回 CRC 错误中断使能,为1 |  |
| cre_sta_int_en  | o o | ONO | 时有效                      |  |
| dat_cec_int_en  | 2   | 0x0 | 数据接收 CRC 错误中断使能,为1时有效    |  |
| dat_tout_int_en | 1   | 0x0 | 数据超时中断使能,为1时有效           |  |
| dat_fin_int_en  | 0   | 0x0 | 数据完成中断使能,为1时有效           |  |

| 寄存器名称          | 地址   | 读/写(R/W) | 功能描述           | 复位值 |
|----------------|------|----------|----------------|-----|
| dll_master_val | 0xf0 | r        | DLL master 锁定值 | 0x0 |

| dll_master_val | 位    | 缺省值 | 描述                 |
|----------------|------|-----|--------------------|
| reserved       | 31:4 | 0x0 |                    |
| dll_init_done  | 8    | 0x0 | DLL master 锁定完成标志位 |
| pm_dll_value   | 7:0  | 0x0 | DLL master 锁定值     |

| 寄存器名称   | 地址   | 读/写(R/W) | 功能描述      | 复位值 |
|---------|------|----------|-----------|-----|
| dll_con | 0xf4 | r/w      | DLL 控制寄存器 | 0x0 |

| dll_con                | 位     | 缺省值 | 描述                                                 |
|------------------------|-------|-----|----------------------------------------------------|
| reserved               | 31:30 | 0x0 |                                                    |
| resync_dll_rd          | 29    | 0x0 | 内部采样时钟 DLL 重同步使能位                                  |
| dll_bypass_rd          | 28    | 0x0 | 采样时钟 DLL bypass。该位置 1, DLL 控制器将不对 DLL 参数值进行微调。     |
| resync_dll_pad         | 27    | 0x0 | pad 时钟 DLL 重同步使能位                                  |
| dll_bypass_pad         | 26    | 0x0 | pad 时钟 DLL bypass。该位置 1,DLL 控制器将不对 DLL<br>参数值进行微调。 |
| pm_init_start          | 25    | 0x0 | DLL master 初始化开始位                                  |
| pm_dll_lock_mode       | 24    | 0x0 | DLL master 锁定模式。0,锁定一个周期; 1,锁定半个周期                 |
| pm_dll_start_poi<br>nt | 23:16 | 0x0 | DLL master 初始化的起点值。该值应该低于一个周期的<br>延迟值              |
| pm_dll_increment       | 15:8  | 0x0 | DLL master 初始化的步进值                                 |
| pm_dll_adj_cnt         | 7:0   | 0x0 | 刷新锁定值的时间间隔                                         |



| 寄存器名称       | 地址   | 读/写(R/W) | 功能描述                                           | 复位值 |
|-------------|------|----------|------------------------------------------------|-----|
| param_delay | 0xf8 | r/w      | DLL 延迟参数寄存器。理想情况下,<br>DLL 一级延迟为 100ps, 共 256 级 | 0x0 |

| param_delay   | 位     | 缺省值 | 描述                                                                                                   |
|---------------|-------|-----|------------------------------------------------------------------------------------------------------|
| reserved      | 31:16 | 0x0 |                                                                                                      |
| clk_rd_delay  | 15:8  | 0x0 | 内部采样时钟延迟参数,用于调整控制器采样数据的采样<br>点。DDR 模式下,该值一般比 clk_pad_delay 大。                                        |
| clk_pad_delay | 7:0   | 0x0 | 时钟延迟参数。DDR 模式下,此时的时钟与内部参考时钟的相位关系应该为 90°。例如,内部参考时钟为 50MHz(20ns),此时的 clk_pad_delay 值 应该为 50(50*100ps)。 |

| 寄存器名称         | 地址   | 读/写(R/W) | 功能描述   | 复位值 |
|---------------|------|----------|--------|-----|
| sdio_emmc_sel | 0xfc | r/w      | 总线模式选择 | 0x0 |

| sdio_emmc_sel | 位    | 缺省值 | 描述                                          |
|---------------|------|-----|---------------------------------------------|
| reserved      | 31:4 | 0x0 |                                             |
| bus_sel       | 1    | 0x0 | SDIO与EMMC总线模式选择。0表示EMMC总线模式;1<br>表示SDIO总线模式 |
| data_mode     | 0    | 0x0 | 数据模式选择。0,表示 SDR 数据模式;<br>1,表示 DDR 数据模式      |

## 26.3 软件配置流程

#### 26.3.1 EMMC 正常读写软件配置流程

- 1. 配置 emmc\_con, 使能时钟
- 2. 配置 emmc pre, 输出预设频率的时钟
- 3. 配置 emmc bsize,设置一块数据的大小,单位为字节
- 4. 配置 emmc\_dtimer,设置超时计数,最大为 100ms
- 5. 配置 emmc\_int\_en,设置中断使能,设置读写完成及错误中断使能
- 6. 配置 emmc\_ dat\_con,设置线宽数据模式
- 7. 配置 bus\_sel,设置 DDR 或 SDR 模式
- 8. EMMC 设备初始化:初始化流程需要对命令通道进行操作,先配置 emmc\_cmd\_arg,填写命令参数,再 emmc\_cmd\_con,开始发送命令,通过检测 emmc\_int\_msk 检查命令发送完成中断;命令完成后读 emmc rsp0~3,读 EMMC 发回来的回复
- 9. 初始化完成后,可发送数据相关命令进行数据操作。配置 DMA(注: EMMC 控制器基



址加上 0x800 为 DMA 读,基址加上 0x400 为 DMA 写;其余配置及使用方式参考第 34.7 章节 DMA 控制器)与 EMMC 控制器。命令发送同样时通过配置 emmc\_cmd\_arg 和 emmc\_cmd\_con 来完成。数据收发是否完成,通过检测 emmc\_int\_msk 来判断。

#### 26.3.2 EMMC 初始化流程



#### 26.3.3 DDR 模式

在开启 DDR 模式前,需要先初始化 EMMC 设备,同时设置 EMMC 设备为 DDR 模式; 然后初始化 DLL,设置延迟值,最后将控制器设置为 DDR 模式。流程如下:

- 1. DLL 设置:pm\_dll\_lock\_mode 置 1 锁定半个周期时钟;pm\_dll\_start\_point 置为 0x10 (该值应该大于 0 小于半周期); pm\_dll\_adj\_cnt 置为 0xff; pm\_dll\_increment, pm\_dll\_bypass, pm\_dll\_resync 都置为 1; 最后 pm\_init\_start 置 1 开始 DLL 初始化;
- 2. DLL 锁定: DLL 设置完成后,检测 dll\_init\_done 寄存器,该值为 l 表示 DLL 完成锁定
- 3. 配置延迟值:将 DLL 锁定值 pm\_dll\_value 除以 2 后的值写入 clk\_pad\_delay;



clk\_rd\_delay 应该比 pm\_dll\_value/2 大,具体值视不同芯片和环境条件(PCB 走线,工作温度等)而定,软件需要根据实际情况对 clk\_rd\_delay 进行调整

4. data\_mode 置 1, 开启 DDR 模式



# 27 SDIO 控制器 (D28:F1)

## 27.1 功能概述

龙芯 2K2000 集成了一个 SDIO 控制器,用于 SD Memory 和 SDIO 卡的读写。SDIO 控制器特性如下:

- 兼容SD 存储卡规格(4.0版本)
- 兼容SDI0卡规格(4.0版本)
- 8字(32字节)数据发送/接收FIF0
- 扩展的256位SD卡状态寄存器
- 8位预分频逻辑(频率=系统时钟/(p+1))
- DMA数据传输模式
- 专用独立DMA通道
- 1位/4位(宽总线)的SD模式

## 27.2 SDIO 协议概述

SDIO 是一个串行通信方式,主设备和从设备通过消息传递来实现数据和状态的传输。如下图是一个写多块数据的示意框图,过程如下:

- 1. 主设备通过命令线发送写命令消息给从设备
- 2. 从设备接收完消息之后通过命令线发送应答消息给主设备
- 3. 主设备接收到正确的应答消息后,通过数据线发送一块数据(512K Byte 或者更多)给从设备,并且检测数据线忙状态
- 4. 从设备接收到正确的数据后会进入编程状态,此时将数据线置为忙状态,不再响应 主设备的数据请求
  - 5. 主设备检测到从设备编程完成,继续发送下一块数据。
- 6. 主设备发送完最后一块数据时,通过命令线发送停止命令给从设备,收到正确应答之后完成这次多块写操作。



图 27-1 SD 卡多块写操作示意图



多块读操作的过程和多块写操作的过程类似(等补充说明)。



图 27-2 SD 卡多块读操作示意图

不同的命令都有统一的格式。一般命令的格式如下表,1bit 起始位,1bit 传输方向位,6bit 命令序号,32bit 命令参数,7bit CRC 检验位再加上 1bit 结束位。

| Bit position | 47        | 46               | [45:40]       | [39:8]   | [7:1] | 0       |
|--------------|-----------|------------------|---------------|----------|-------|---------|
| Width (bits) | 1         | 1                | 6             | 32       | 7     | 1       |
| Value        | '0'       | '1'              | x             | х        | x     | '1'     |
| Description  | start bit | transmission bit | command index | argument | CRC7  | end bit |

其中 command index 对应命令的序号,比如命令 0, cmdindex 为 0, 命令 55, cmdindex 为 37。不同命令的参数可能不同,具体参考 SD 协议规范。

## 27.3 寄存器描述

SDIO 控制器的寄存器详细说明如下:

| 寄存器名称   | 偏移地址 | 读/写(R/W) | 功能描述       | 复位值 |
|---------|------|----------|------------|-----|
| SDI_CON | 0x00 | R/W      | SDI0 控制寄存器 | 0x0 |

| SDI_CON  | 位    | 缺省值 | 描述                      |
|----------|------|-----|-------------------------|
| •        | 31:9 | 0x0 |                         |
| soft_rst | 8    | 0x0 | 软件复位,整个模块复位。复位完成后硬件自动清零 |
| Reserved | 7:1  | 0x0 |                         |
| enclk    | 0    | 0x0 | SD 时钟输出使能               |

| 寄存器名称   | 地址   | 读/写(R/W) | 功能描述        | 复位值 |
|---------|------|----------|-------------|-----|
| SDI_PRE | 0x04 | R/W      | SDIO 预分频寄存器 | 0x1 |

| SDI_PRE         | 位  | 缺省值 | 描述                                                         |
|-----------------|----|-----|------------------------------------------------------------|
| sdio_clk_rev_en | 31 | 0x1 | SDR 模式时,该位为 1,表示控制器输出的 sdio 数据与 sdio 时钟下降沿对齐;该位为 0,表示控制器输出 |



|          |       |     | 的 sdio 数据与 sdio 时钟上升沿对齐。DDR 模式,该<br>位必须置为 1。 |
|----------|-------|-----|----------------------------------------------|
| Reserved | 30:10 | 0x0 |                                              |
| Sdi_pre  | 9:0   | 0x1 | SDIO 时钟预分频值,输出频率=PCLK/预分频值                   |

| 寄存器名称       | 偏移地址 | 读/写(R/W) | 功能描述         | 复位值 |
|-------------|------|----------|--------------|-----|
| SDI_CMD_ARG | 0x08 | R/W      | SDIO 命令参数寄存器 | 0x0 |

| SI | DI_CMD_ARG | 位    | 缺省值 | 描述   |
|----|------------|------|-----|------|
| sc | li_cmd_arg | 31:0 | 0x0 | 命令参数 |

| 寄存器名称       | 偏移地址 | 读/写(R/W) | 功能描述         | 复位值 |
|-------------|------|----------|--------------|-----|
| SDI_CMD_CON | 0x0c | R/W      | SDIO 命令控制寄存器 | 0x0 |

| SDI_CMD_CON     | 位     | 缺省值 | 描述                               |
|-----------------|-------|-----|----------------------------------|
| Reserved        | 31:19 | 0x0 |                                  |
| cmd6_data_en    | 18    | 0x0 | 写 1 使能 cmd6 数据传输                 |
| func num abort  | 17:15 | 0x0 | SDIO 卡时中断的功能号,用于多块读写时,硬件自动       |
| Tune_num_abor t | 11.15 | OXO | 发送停止命令。如果 auto_stop_en 为 0,则此位无效 |
|                 |       |     | SDIO 使能信号。用于多块读写时,硬件自动发送停止       |
| sdio_en         | 14    | 0x0 | 命令,为1时发送 CMD52,为0是发送 CMD12。如果    |
|                 |       |     | auto_stop_en 为 0,则此位无效           |
| check_on        | 13    | 0x0 | 是否检查 CRC, 为 1 时有效                |
| Auto stop en    | 12    | 0x0 | 硬件自动发送停止命令,多块读写时,是否硬件自动          |
| Auto_stop_en    | 12    | OXO | 发送停止命令,为1时有效                     |
| Reserved        | 11    | 0x0 |                                  |
| long_rsp        | 10    | 0x0 | 是否为136位长响应,为1时表示长消息回复            |
| Wait_rsp        | 9     | 0x0 | 决定是否主机等待相应,为1是表示等待消息回复           |
| CMST            | 8     | 0x0 | 命令开始,置1时开始,命令结束后硬件自动清零           |
| cmd_index       | 7:0   | 0x0 | 带开始 2 位的命令索引 (共 8 位)             |

| 寄存器名称       | 偏移地址 | 读/写(R/W) | 功能描述         | 复位值 |
|-------------|------|----------|--------------|-----|
| SDI_CMD_STA | 0x10 | RO       | SDIO 命令状态寄存器 | 0x0 |

| SDI_CMD_STA  | 位     | 缺省值 | 描述                      |
|--------------|-------|-----|-------------------------|
| Reserved     | 31:13 | 0x0 |                         |
| cmd_sent_fin | 14    | 0x0 | 命令发送完成(包含响应)标志位,为1表示命令发 |



|             |             |     | 送完成及响应完成                                          |
|-------------|-------------|-----|---------------------------------------------------|
| auto_stop   | 13          | 0x0 | 硬件自动发送停止命令标志位,为1表示硬件自动发                           |
|             |             |     | 送停止命令,为 0 则没有                                     |
| rsp_crc_err | 12          | 0x0 | 响应 CRC 错误,接收到的响应 CRC 错误。为 1 时表示响应 CRC 错误,为 0 时未发现 |
|             |             |     | 10-                                               |
| cmd_end     | 11          | 0x0 | 命令发送完成(不关心响应)。为1时表示命令发送                           |
|             |             |     | 完成,为0时未完成。                                        |
|             |             |     | 命令超时。命令响应超时(64个时钟周期),或者 R1b                       |
| cmd_tout    | 10          | 0x0 | 类型的命令,忙等待超时,为1时表示响应超时,为                           |
|             |             |     | 0 时未超时。                                           |
| c.          | 0           | 0.0 | 响应结束,接收完成从设备的返回信息。为1时表示                           |
| rsp_fin     | 9           | 0x0 | 响应结束,为0时未完成。                                      |
|             | 0           | 0x0 | 命令传输标志位。为1时表示传输进行中,为0表示                           |
| CIIIQ_ON    | cmd_on 8 02 |     | 结束。                                               |
| rsp_index   | 7:0         | 0x0 | 从设备返回的带开始2位的响应索引(共8位)                             |

| 寄存器名称    | 偏移地址 | 读/写(R/W) | 功能描述           | 复位值 |
|----------|------|----------|----------------|-----|
| SDI_RSP0 | 0x14 | RO       | SDIO 命令响应寄存器 0 | 0x0 |

| SDI_RESP0 | 位    | 缺省值 | 描述                                                        |
|-----------|------|-----|-----------------------------------------------------------|
| sdi_resp0 | 31:0 | 0x0 | 卡状态[31:0] (短), 卡状态[127:96] (长)长响应<br>的配置间 sdi_cmd_con[10] |

| 寄存器名称    | 偏移地址 | 读/写(R/W) | 功能描述           | 复位值 |
|----------|------|----------|----------------|-----|
| SDI_RSP1 | 0x18 | RO       | SDIO 命令响应寄存器 1 | 0x0 |

| SDI_RESP1 | 位    | 缺省值 | 描述                                                 |
|-----------|------|-----|----------------------------------------------------|
| sdi_respl | 31:0 | 0x0 | 未使用 (短), 卡状态[95:64] (长) 长响应的配置间<br>sdi_cmd_con[10] |

| 寄存器名称    | 偏移地址 | 读/写(R/W) | 功能描述           | 复位值 |
|----------|------|----------|----------------|-----|
| SDI_RSP2 | 0x1c | RO       | SDIO 命令响应寄存器 2 | 0x0 |

| SDI_RESP2 | 位    | 缺省值 | 描述                                          |
|-----------|------|-----|---------------------------------------------|
| sdi_resp2 | 31:0 | 0x0 | 未使用(短),卡状态[63:32](长)长响应的配置间 sdi_cmd_con[10] |



| 寄存器    | 名称 | 偏移地址 | 读/写(R/W) | 功能描述           | 复位值 |
|--------|----|------|----------|----------------|-----|
| SDI_RS | Р3 | 0x20 | RO       | SDIO 命令响应寄存器 3 | 0x0 |

| SDI_RESP3 | 位    | 缺省值 | 描述                                               |
|-----------|------|-----|--------------------------------------------------|
| sdi_resp3 | 31:0 | 0x0 | 未使用 (短), 卡状态[31:0] (长)长响应的配置间<br>sdi_cmd_con[10] |

| 寄存器名称      | 偏移地址 | 读/写(R/W) | 功能描述           | 复位值 |
|------------|------|----------|----------------|-----|
| SDI_DTIMER | 0x24 | R/W      | SDIO 命令数据超时寄存器 | 0x0 |

| SDI_DTIMER | 位     | 缺省值 | 描述                            |
|------------|-------|-----|-------------------------------|
| Reserved   | 31:28 | 0x0 |                               |
| ext_dtimer | 27:24 | 0x0 | 数据超时计数值,sdi_dtimer设置为最大值时方可使用 |
| sdi_dtimer | 23:0  | 0x0 | 数据超时计数值,用分频后的时钟计数             |

| 寄存器名称     | 偏移地址 | 读/写(R/W) | 功能描述        | 复位值 |
|-----------|------|----------|-------------|-----|
| SDI_BSIZE | 0x28 | R/W      | SDIO 块大小寄存器 | 0x0 |

| SDI_BSIZE | 位     | 缺省值 | 描述            |
|-----------|-------|-----|---------------|
| Reserved  | 31:12 | 0x0 |               |
| sdi_bsize | 11:0  | 0x0 | 块大小值 (0~4095) |

| 寄存器名称       | 偏移地址 | 读/写(R/W) | 功能描述         | 复位值 |
|-------------|------|----------|--------------|-----|
| SDI_DAT_CON | 0x2c | R/W      | SDIO 数据控制寄存器 | 0x0 |

| SDI_DAT_CON   | 位     | 缺省值 | 描述                                   |
|---------------|-------|-----|--------------------------------------|
| Reserved      | 31:21 | 0x0 |                                      |
|               |       |     | 写 1 表示对 SDIO 设备发送 CMD53 进行写操作时,并且    |
| sdio_esp_rdy  | 25    | 0x0 | 写数据发送完成后,该设备不会拉低数据线 0 进入             |
|               |       |     | busy 状态                              |
| sdio_esp_card | 24    | 0x0 | 写 1 表示 SDIO 特殊设备,与 sdio_esp_rdy 配合使用 |
| resume rw     | 20    | 0x0 | SDIO 挂起回复读写标志位。为1时,SDIO 挂起后恢复        |
| resume_1 w    | 20    | OAO | 之前的写操作;为0时,恢复之前的读操作                  |
|               |       |     | SDIO 恢复请求。在 SDIO 设备进入挂起状态后,将此位       |
| IO_resume     | 19    | 0x0 | 写 1,并且 IO_suspend 位写 0 后,SDIO 设备恢复之前 |
|               |       |     | 的操作。                                 |



|            |       |     | SDIO 挂起请求。写 1 后控制器会在合适的时机发送    |
|------------|-------|-----|--------------------------------|
| IO_suspend | 18    | 0x0 | CMD52 命令,通知 SDIO 设备进入挂起状态。恢复操作 |
|            |       |     | 时需要将此位写 0.                     |
|            |       |     | 读等待请求。写 1 后控制器会在合适的时机将 DAT2 拉  |
| RwaitReq   | 17    | 0x0 | 低,通知 SDIO 设备进入读等待状态。写 0 后恢复之前  |
|            |       |     | 的读操作。                          |
| wide_mode  | 16    | 0x0 | 位宽选择位。为1表示4线模式,为0表示单线模式。       |
| DMA_en     | 15    | 0x0 | DMA 使能。为1时表示使能 DMA,为0表示禁止 DMA  |
| DTST       | 14    | 0x0 | 数据传输开始,写1时数据传输开始,数据传输结束        |
| 0131       | 14    | UXU | 后硬件清零。                         |
| Reserved   | 13:12 | 0x0 |                                |
| B1k_num    | 11:0  | 0x0 | 读写操作的块数。                       |

| 寄存器名称       | 偏移地址 | 读/写(R/W) | 功能描述         | 复位值 |
|-------------|------|----------|--------------|-----|
| SDI_DAT_CNT | 0x30 | R/W      | SDIO 数据计数寄存器 | 0x0 |

| SDI_DAT_CNT | 位     | 缺省值 | 描述        |
|-------------|-------|-----|-----------|
| Reserved    | 31:24 | 0x0 |           |
| blk_num_cnt | 23:12 | 0x0 | 当前传输块的字节数 |
| blk_cnt     | 11:0  | 0x0 | 当前传输的块数   |

| 寄存器名称       | 偏移地址 | 读/写(R/W) | 功能描述         | 复位值 |
|-------------|------|----------|--------------|-----|
| SDI_DAT_STA | 0x34 | RO       | SDIO 数据状态寄存器 | 0x0 |

| SDI_DAT_STA | 位     | 缺省值 | 描述                                                         |
|-------------|-------|-----|------------------------------------------------------------|
| Reserved    | 31:17 | 0x0 |                                                            |
| suspend_on  | 16    | 0x0 | 为1时表示正在挂起状态                                                |
| rst_suspend | 15    | 0x0 | 为1表示正在挂起复位。用于SDIO设备挂起后,控制器复位FIFO和DMA请求                     |
| R1b_tout    | 14    | 0x0 | 为1表示Rlb类型命令超时                                              |
| data_start  | 13    | 0x0 | 为1表示数据传输开始                                                 |
| R1b_fin     | 12    | 0x0 | 检测到带 busy 状态的命令完成。当发送带 busy 状态的命令时,此位为 0; 当 busy 状态结束时变成 1 |
| auto_stop   | 11    | 0x0 | 为1时表示硬件正在自动发送停止命令                                          |
| Reserved    | 10    | 0x0 |                                                            |
| r_wait_req  | 9     | 0x0 | 读等待发生。发送读等待请求信号到 SDI0 卡                                    |
| SDIO_int    | 8     | 0x0 | SDIO 中断标志位。为 1 表示检测到中断                                     |
| crc_sta     | 7     | 0x0 | 数据发送后,从设备返回 CRC 错误                                         |



| dat_crc   | 6 | 0x0 | 数据接收 CRC 错误                   |
|-----------|---|-----|-------------------------------|
| dat_tout  | 5 | 0x0 | 数据传输超时。为1时表示数据超时。             |
| dat_fin   | 4 | 0x0 | 数据传输结束标志位(比如编程时)。为1时标志忙结<br>束 |
| busy_fin  | 3 | 0x0 | 编程错误标志位(比如编程时)。为1时标志忙结束       |
| prog_err  | 2 | 0x0 | 编程错误标志位,为1时表示编程错误             |
| tx_dat_on | 1 | 0x0 | Tx 数据发送中,为1时表示正在发送,为0时发送完成    |
| rx_dat_on | 0 | 0x0 | Rx 数据接收中,为1时表示正在接收,为0时发送完成。   |

| 寄存器名称        | 偏移地址 | 读/写(R/W) | 功能描述            | 复位值 |
|--------------|------|----------|-----------------|-----|
| SDI_FIFO_STA | 0x38 | RO       | SDIO FIFO 状态寄存器 | 0x0 |

| SDI_FIFO_STA | 位     | 缺省值 | 描述           |
|--------------|-------|-----|--------------|
| Reserved     | 31:12 | 0x0 |              |
| tx_full      | 11    | 0x0 | Tx FIFO 满标志位 |
| tx_empty     | 10    | 0x0 | Tx FIFO 空标志位 |
| Reserved     | 9     | 0x0 |              |
| rx_full      | 8     | 0x0 | Rx FIFO 满标志  |
| rx_empty     | 7     | 0x0 | Rx FIFO 空标志位 |
| Reserved     | 6:0   | 0x0 |              |

| 寄存器名称        | 偏移地址 | 读/写(R/W) | 功能描述       | 复位值 |
|--------------|------|----------|------------|-----|
| SDI_INT_MASK | 0x3c | R/W      | SDIO 中断寄存器 | 0x0 |

| SDI_INT_MASK | 位     | 缺省值 | 描述                         |
|--------------|-------|-----|----------------------------|
| Reserved     | 31:10 | 0x0 |                            |
| R1b_fin_int  | 9     | 0x0 | 检测到 busy 结束中断,写 1 清零       |
| rsp_crc_int  | 8     | 0x0 | 命令响应 CRC 错误中断,写 1 清零       |
| cmd_tout_int | 7     | 0x0 | 命令超时中断,写 1 清零              |
| cmd_fin_int  | 6     | 0x0 | 发送完成中断,硬件清零                |
| SDIO_int     | 5     | 0x0 | 检测到 SDIO 中断,写 1 清零         |
| prog_err_int | 4     | 0x0 | SD 卡编程错误中断,写 1 清零          |
| crc_sta_int  | 3     | 0x0 | 数据发送后从设备返回 CRC 错误中断,写 1 清零 |
| dat_crc_int  | 2     | 0x0 | 数据接收 CRC 错误中断,写 1 清零       |
| dat_tout_int | 1     | 0x0 | 数据超时中断,写1清零                |
| dat_fin_int  | 0     | 0x0 | 数据完成中断,硬件清零                |



| 寄存器名称   | 偏移地址 | 读/写(R/W) | 功能描述         | 复位值 |
|---------|------|----------|--------------|-----|
| SDI_DAT | 0x40 | RO       | SDIO 命令数据寄存器 | 0x0 |

| SDI_DAT | 位    | 缺省值 | 描述                           |
|---------|------|-----|------------------------------|
| sdi_dat | 31:0 | 0x0 | SDIO 控制器发送或者接收的数据(用于 DMA 操作) |

| 寄存器名称      | 偏移地址 | 读/写(R/W) | 功能描述         | 复位值 |
|------------|------|----------|--------------|-----|
| SDI_INT_EN | 0x64 | R/W      | SDIO 中断寄使能存器 | 0x0 |

| SDI_INT_EN      | 位     | 缺省值 | 描述                          |
|-----------------|-------|-----|-----------------------------|
| Reserved        | 31:10 | 0x0 |                             |
| R1b_fin_int_en  | 9     | 0x0 | Busy 结束中断使能,为1时有效           |
| rsp_crc_int_en  | 8     | 0x0 | 命令响应 CRC 错误中断使能,为1时有效       |
| cmd_tout_int_en | 7     | 0x0 | 命令超时中断使能,为1时有效              |
| cmd_fin_int_en  | 6     | 0x0 | 命令发送完成中断使能,为1时有效            |
| SDIO_int_en     | 5     | 0x0 | SDIO 中断使能,为1时有效             |
| prog_err_int_en | 4     | 0x0 | SD 卡编程错误中断使能,为1时有效          |
| crc_sta_int_en  | 3     | 0x0 | 数据发送后从设备返回 CRC 错误中断使能,为1时有效 |
| dat_cec_int_en  | 2     | 0x0 | 数据接收 CRC 错误中断使能,为1时有效       |
| dat_tout_int_en | 1     | 0x0 | 数据超时中断使能,为1时有效              |
| dat_fin_int_en  | 0     | 0x0 | 数据完成中断使能,为1时有效              |

| 寄存器名称          | 地址   | 读/写(R/W) | 功能描述           | 复位值 |
|----------------|------|----------|----------------|-----|
| dll_master_val | 0xf0 | r        | DLL master 锁定值 | 0x0 |

| dll_master_val | 位    | 缺省值 | 描述                 |
|----------------|------|-----|--------------------|
| reserved       | 31:4 | 0x0 |                    |
| dll_init_done  | 8    | 0x0 | DLL master 锁定完成标志位 |
| pm_dll_value   | 7: 0 | 0x0 | DLL master 锁定值     |

| 寄存器名称   | 地址   | 读/写(R/W) | 功能描述      | 复位值 |
|---------|------|----------|-----------|-----|
| dll_con | 0xf4 | r/w      | DLL 控制寄存器 | 0x0 |

| dll_con       | 位     | 缺省值 | 描述                |
|---------------|-------|-----|-------------------|
| reserved      | 31:30 | 0x0 |                   |
| resync_dll_rd | 29    | 0x0 | 内部采样时钟 DLL 重同步使能位 |



| dll_bypass_rd          | 28    | 0x0                                            | 采样时钟 DLL bypass。该位置 1, DLL 控制器将不对 DLL 参数值进行微调。 |
|------------------------|-------|------------------------------------------------|------------------------------------------------|
| resync_dll_pad         | 27    | 0x0                                            | pad 时钟 DLL 重同步使能位                              |
| dll_bypass_pad         | 26    | pad 时钟 DLL bypass。该位置 1,DLL 控制器将不对<br>参数值进行微调。 |                                                |
| pm_init_start          | 25    | 0x0                                            | DLL master 初始化开始位                              |
| pm_dll_lock_mode       | 24    | 0x0                                            | DLL master 锁定模式。0,锁定一个周期; 1,锁定半个周期             |
| pm_dll_start_poi<br>nt | 23:16 | 0x0                                            | DLL master 初始化的起点值。该值应该低于一个周期的延迟值              |
| pm_dll_increment       | 15:8  | 0x0                                            | DLL master 初始化的步进值                             |
| pm_dll_adj_cnt         | 7:0   | 0x0                                            | 刷新锁定值的时间间隔                                     |

| 寄存器名称       | 地址   | 读/写(R/W) | 功能描述                                           | 复位值 |
|-------------|------|----------|------------------------------------------------|-----|
| param_delay | 0xf8 | r/w      | DLL 延迟参数寄存器。理想情况下,<br>DLL 一级延迟为 100ps, 共 256 级 | 0x0 |

| param_delay   | 位     | 缺省值 | 描述                                |
|---------------|-------|-----|-----------------------------------|
| reserved      | 31:16 | 0x0 |                                   |
| .111 1.1.     | 15.0  | 0x0 | 内部采样时钟延迟参数,用于调整控制器采样数据的采样         |
| clk_rd_delay  | 15:8  |     | 点。DDR 模式下,该值一般比 clk_pad_delay 大。  |
|               | 7:0   | 0x0 | 时钟延迟参数。DDR 模式下,此时的时钟与内部参考时钟       |
| clk_pad_delay |       |     | 的相位关系应该为 90°。例如, 内部参考时钟为 50MHz    |
|               |       |     | (20ns),此时的 clk_pad_delay 值 应该为 50 |
|               |       |     | (50*100ps) 。                      |

| 寄存器名称         | 地址   | 读/写(R/W) | 功能描述   | 复位值 |
|---------------|------|----------|--------|-----|
| sdio_emmc_sel | 0xfc | r/w      | 总线模式选择 | 0x0 |

| sdio_emmc_sel | 位    | 缺省值 | 描述                                     |
|---------------|------|-----|----------------------------------------|
| reserved      | 31:4 | 0x0 |                                        |
|               |      |     | SDIO 与 EMMC 总线模式选择。0 表示 SDIO 总线模式; 1 表 |
| bus_sel       | 1    | 0x0 | 示 EMMC 总线模式。切换至 EMMC 模式时,EMMC 最多只能支    |
|               |      |     | 持四线模式。                                 |
| data mode     | 0    | 0x0 | 数据模式选择。0,表示 SDR 数据模式;                  |
| data_mode     |      | OAO | 1,表示 DDR 数据模式                          |



## 27.4 软件编程指南

#### **27.4.1** SD Memory 卡软件编程说明

SD Memory 卡要想正常工作,必须要先初始化。初始化的过程需要发送不同的命令序列来配置从设备。初始化的流程示意图如下:



图 27-3 SD Memory 卡初始化流程示意图

初始化完成之后就可以正常工作了。

配置寄存器的流程如下:

- 1. 配置 sdi con, 使能输出时钟
- 2. 配置 sdi\_pre,设置一个分频系数,如果时序不满足,可以设置输出反向时钟来调整时序。
  - 3. 配置 sdi int en, 使能命令、数据完成及其他中断。
  - 4. 按照上图初始化流程初始化控制器

发送命令的配置寄存器过程如下:

- ▶ 根据发送的命令,配置 cmd arg 寄存器
- ▶ 配置 cmd con 寄存器,发送命令
- ▶ 读 sdi int msk 寄存器,检查是否传输完成,是否有错误
- ▶ 如果需要,读 sdi\_rsp 寄存器

初始化的流程如下:

 $CMDO \rightarrow CMD8 \rightarrow ACMD41 (EU CMD55 \rightarrow CMD41) \rightarrow CMD2 \rightarrow CMD3$ 



- → CMD7 → ACMD6 (用于配置是否用 4bit 数据线传输)
- 5. 进行数据操作之前需要配置 Bsize 寄存器, Dtimer 寄存器
- 6. 数据的操作必须要配置 DMA, 配置 dat\_con 寄存器并配置 DMA (注: SDIO 控制器基址加上 0x800 为 DMA 读, 基址加上 0x400 为 DMA 写; 其余配置及使用方式参考第 34.7 章节 DMA 控制器)
  - 7. 读 sdi int msk 寄存器, 检测是否传输完成, 是否有错误。
  - 8. 没有错误则完成一次数据传输,不需要软件发送停止命令

#### 27.4.2 SDIO 卡软件编程说明

SDIO 卡的初始化流程和 SD memory 卡不同, 其初始化流程如下:

- 1. 配置 sdi con, 使能输出时钟。
- 2. 配置 sdi pre,设置一个分频系数,如果时序不满足,可以设置输出反向
- 3. 时钟来调整时序。
- 4. 配置 sdi int en, 使能命令、数据完成及其他中断。
- 5. 初始化流程如下:

发送命令的配置寄存器过程如下:

- ▶ 根据发送的命令,配置 cmd\_arg 寄存器
- ▶ 配置 cmd con 寄存器,发送命令
- ▶ 读 sdi int msk 寄存器,检查是否传输完成,是否有错误
- ▶ 如果需要,读 sdi rsp 寄存器

初始化的流程如下(对 CCCR 的操作):

- 6. CMD52 (复位) CMD5 (等待上电完成) CMD3 (获取 RCA) CMD7 (选择相应 RCA 的 卡) CMD52 (配置是否用 4bit 数据线传输) CMD52 (配置读写数据的块大小) CMD52 (打开 IO 中断使能) 进行数据操作之前需要配置 Bsize 寄存器, Dtimer 寄存器
- 7. 数据的操作必须要配置 DMA, 配置 dat\_con 寄存器并配置 DMA(注: 读操作时先配置 DMA, 写操作时先配置 dat con)
- 8. 发送读写数据的命令时,如果需要硬件自动发送停止命令,需要配置 auto\_stop 和 sdio\_en。读写数据时需要先读写支持的 Function,配置相应的 FBR 的指针寄存器,再发送 多块读写 (CMD53) 或者单块读写 (CMD52) 命令进行读写。
  - 9. 读 sdi int msk 寄存器, 检测是否传输完成, 是否有错误。
  - 10. 没有错误则完成一次数据传输,不需要软件发送停止命令
  - 11. 如果检测到 IO 中断,控制器会置起响应的中断,但是不会停止当前的操作。
- 12. 对于读等待,控制器会在合适的时机将 DAT2 拉低,通知 SDI0 卡停止发送数据。所以如果当前正在传输数据过程中,控制器可能会在当前一块数据传输结束后,发出读等待信



- 号,这时才不会接收下一块数据。
- 13. 对于挂起和恢复操作。有可能出现挂起嵌套情况,比如说操作 1 被操作 2 中断而挂起,然后操作 2 被操作 3 中断而挂起。挂起时中断的现场需要软件保存(如当前的读写标志位,当前传输的块数,地址等),进行入栈操作。恢复时需要软件再按相应的顺序出栈。

#### 27.4.3 DDR 模式设置

在开启 DDR 模式前,需要先初始化 sdio 设备,同时设置 sdio 设备为 DDR 模式;然后初始化 DLL,设置延迟值,最后将控制器设置为 DDR 模式。流程如下:

- 1. DLL 设置: pm\_dll\_lock\_mode 置 1 锁定半个周期时钟; pm\_dll\_start\_point 置为 0x10 (该值应该大于 0 小于半周期); pm\_dll\_adj\_cnt 置为 0xff; pm\_dll\_increment, pm\_dll\_bypass, pm\_dll\_resync 都置为 1; 最后 pm\_init\_start 置 1 开始 DLL 初始化; 2. DLL 锁定: DLL 设置完成后,检测 dll\_init\_done 寄存器,该值为 1 表示 DLL 完成锁定
- 3. 配置延迟值:将 DLL 锁定值 pm\_dll\_value 除以 2 后的值写入 clk\_pad\_delay; clk\_rd\_delay 应该比 pm\_dll\_value/2 大,具体值视不同芯片和环境条件(PCB 走线,工作温度等)而定,软件需要根据实际情况对 clk\_rd\_delay 进行调整
- 4. data\_mode 置 1, 开启 DDR 模式

## 27.5 支持 SDIO 型号

本节列出经过验证的可支持的 SDI0 卡型号, 其它类型的 SDI0 卡未经验证, 不保证与本控制器兼容。

- Mem 卡: Kingston SD-CO2G SDC/2GB
- I0卡(wifi): maxwell sd8686



# 28 GMAC 控制器 (D3:F0/1/2)

桥片集成了 3 个 GMAC 控制器,即 GMACO/1/2,其中 GMACO/1 内部集成 PHY (GMII 接口), GMAC2 通过 RGMII 接口连接外置 PHY,分别为 Device 3 的功能 0/1/2。

## 28.1 GMAC配置寄存器

表 28-1GMAC 控制器的配置寄存器

|         |         | V 20 10™10 1T \\ 1 \\ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | . A 14 HH          |         |
|---------|---------|---------------------------------------------------|--------------------|---------|
| 地址偏移    | 简称      | 描述                                                | 默认值                | 访问类型    |
| 00h-01h | VID     | Vendor ID                                         | 0014h              | RO      |
| 02h-03h | DID     | Device ID                                         | 7A13h              | RO      |
| 04h-05h | PCICMD  | PCI Command                                       | 0000h              | R/W, RO |
| 08h     | RID     | Revision ID                                       | 00h                | RO      |
| 09h     | PI      | Programming Interface                             | 00h                | RO      |
| OAh     | SCC     | Sub Class Code                                    | 00h                | RO      |
| 0Bh     | BCC     | Base Class Code                                   | 02h                | RO      |
| 0Ch     | CLS     | Cache Line Size                                   | 10h                | RO      |
| 0Eh     | HEADTYP | Header Type                                       | 00h                | RO      |
| 10h-17h | CNL_BAR | Control Block Base Address<br>Register            | 00000000000000004h | R/W, RO |
| 2Ch-2Dh | SVID    | Subsystem Vendor ID                               | 0000h              | RO      |
| 2Eh-2Fh | SID     | Subsystem Identification                          | 0000h              | RO      |
| 3Ch     | INT_LN  | Interrupt Line                                    | FFh                | R/W     |
| 3Dh     | INT_PN  | Interrupt Pin                                     | 00h                | RO      |

注:表中未列出的地址空间表示保留。

下面列出与 PCI 配置头规范稍有不同的寄存器及其描述。

#### PCICMD-PCI 命令寄存器 (GMAC-D3:F0, D3:F1)

地址偏移: 04-05h 属性: R/W, RO 默认值: 0000h 大小: 16 位

| 位域   | 名称                     | 访问  | 描述                                                                                            |
|------|------------------------|-----|-----------------------------------------------------------------------------------------------|
| 15:2 | Reserved               | RO  | 保留                                                                                            |
| 1    | Memory Space<br>Enable | R/W | 该位用来控制是否使能对 GMAC 控制寄存器的访问。<br>0:禁止访问;<br>1:使能对 GMAC 控制寄存器的访问。在将该位配置为 1 之前,必须先配置 PCNL_BAR 寄存器。 |
| 0    | Reserved               | RO  | 保留                                                                                            |

## 28.2 GMAC 软件编程指南

#### DMA 初始化

- 1. 软件重置(reset)GMAC
- 2. 等待重置完成(查询 DMA reg0[0])
- 3. 对 DMA reg0 的以下域进行编程
  - ➤ MIX-BURST和 AAL(DMA reg0[26]、[25])



- ➤ Fixed-burst 或者 undefined-burst (DMA reg0[16])
- ➤ Burst-length 和 Burst-mode
- > Descriptor Length(只有当环形格式时有效)
- ➤ Tx 和 Rx 仲裁调度
- 4. 对 Bus Mode Reg 进行编程。如果选择了 Fixed-burst,则需要在该寄存器内设置最大 burst length
- 5. 分别创建发送、接收描述符链,可以分别选择环形模式或者链型模式进行连接,并将接收描述符的 OWN 位设为 1 (DMA 拥有)
- 6. 在软件启用 DMA 描述符之前,必须保证至少发送/接收描述符链中有三个描述符
- 7. 将发送、接收描述符链表的首地址写入 DMA reg3、4
- 8. 对 DMA reg6(DMA mode operation)中的以下位进行配置
  - ➤ 接收/发送的 Store and FoR/Ward
  - ➤ 接收/发送的阈值因子(Threshold Control)
  - ▶ 启用流控制(hardware flow control enable)
  - ▶ 错误帧和未识别的正确帧略过(foR/Warding enable)
  - ➤ OSF 模式
- 9. 向 DMA reg6(Status reg)写 1,清除所有中断请求
- 10. 向 DMA reg7(interrupt enable reg)相应位写 1, 启用对应类型中断
- 11. 向 DMA reg6[1]、[13]中写 1, 启用发送和接收 DMA

#### MAC 初始化

- 1. 正确配置配套 PHY 芯片
- 2. 对 GMAC reg4(GMII Address Register)进行正确配置,使其能够正常访问 PHY 相关寄存器
- 3. 读取 GMAC reg5(GMII Data Register)获取当前 PHY 的链接(link)、速度(speed)、模式(双工)等信息
- 4. 配置 MAC 地址
- 5. 如果启用了 hash filtering,则需要对 hash filtering 进行配置
- 6. 对 GMAC reg1 (Mac Frame filter)以下域进行配置,来进行帧过滤
- ▶ 接收所有
- ▶ 混杂模式(promiscuous mode)
- ▶ 哈希或完美过滤(hash or perfect filter)
- ▶ 组播、多播过滤设置等等
- 7. 对 GMAC reg6 (Flow control register) 以下域进行配置



- ▶ 暂停时间和其他暂停控制位
- ▶ 接收和发送流控制位
- ▶ 流控制忙/后压力启用
- 8. 对中断掩码寄存器(Mac reg15)进行配置
- 9. 基于之前得到的线路信息(link, speed, mode)对 GMAC reg0进行正确的配置
- 10. 设置 GMAC reg0[2]、[3]来启用 GMAC 中的发送、接收模块

#### 发送和接收的一般过程

- 1. 检测到发送或接收中断后,查寻相应描述符来判断其是否属于主机,并读取描述符中的 数据
- 2. 完成对描述符中数据的读取后,将描述符各位清 0 并设置其 OWN 位,使其继续发送/接收数据
- 3. 如果当前发送或接收描述符不属于 DMA (OWN=0),则 DMA 模块会进入挂起状态。当有数据需要被发送或接收时,向 DMA Tx/Rx POLL 寄存器写 1 重新使能 DMA 模块。需要注意的是接收描述符在空闲时应该总是属于 DMA (OWN=1)
- 4. 发送和接收描述符及对应 buffer 地址的实时信息可以通过查寻 DMA reg18、19、20、21 获得

## 28.3 IEEE 1588 支持

支持 IEEE1588-2019, 以下描述软件编程指南。

启用 IEEE1588 时间戳功能只需将时间戳控制寄存器 (Register 448 Time Stamp Control Register) bit0 设为 1。但是要正常使用该功能必须在 GMAC 初始化阶段完成以下相关初始 化工作:

#### IEEE1588 初始化

- 1. 将寄存器 15 的 bit9 设为 1, 关掉由时钟戳触发的系统中断。
- 2. 将时间戳控制寄存器 (reg 448)的 bit0 设为 1, 启用时间戳功能。
- 3. 根据 ptp 时钟频率来设置亚秒增量寄存器 (Register 449 Sub-Second Increment Register)。
- 4. 如果你使用了 Fine Correction approach, 设置 (Register 454 Time Stamp Addend register) 寄存器并将时间戳控制寄存器 (reg 448) 的 bit 5 设为 1 (addend reg update).
- 5. 轮询时间戳控制寄存器的 bit5, 至该位为 0。
- 6. 通过设置时间戳控制寄存器的 bit1 为 1,来启用 Fine Update method (如果有必要)。



- 7. 将时间戳高位更新寄存器(Time Stamp High Update)和时间戳低位寄存器(Time Stamp Low Update)设置为相应的值。
- 8. 将时间戳控制寄存器 bit2 设为 1(时间戳初始化)。
- 9. 当向时间戳更新寄存器 (registers 452 and 453 Time Stamp Update register)中写入 初始值后,时间戳计数器开始工作。
- 10. 启用 GMAC 的发送和接收模块来正确运行时间戳功能。 注意: 当 IEEE1588 功能中途关闭后,重新启用时必须重复执行以上过程

#### 系统时钟校正

在一个进程当中同步或更新系统时间(coarse correction method),进行以下步骤:

- 1. 将偏移(offset 正或负)写入时间戳更新寄存器(registers 452 and 453 Time Stamp Update registers)。
- 2. 将时间戳控制寄存器 (reg 448) 的 bit3 (TSUPDT) 设为 1。
- 3. 当 TSUPDT 位 (reg448 bit3) 变为 0 时,系统时钟加或者减去了步骤 1 中时间戳更新寄存器中的偏移值。

## 28.4 GMAC PHY 初始化流程

- 1. 通过读写 confbus 偏移 770 寄存器对 PHY 进行配置,可配选项包括参考时钟选择、PHY 地址、工作频率、双工模式、自协商等,检测 PHY PLL 是否锁定,通过读 confbus 偏移 770 寄存器 31 位来确定,为 1 表示锁定,否则等待。
- 2. 通过配置 PHY 的 0 号寄存器第 11 位为 1 使得 PHY power down, 然后配置 PHY 的 0 号寄存器第 11 位为 0 使得 PHY power up。

通过配置 PHY 的 0 号寄存器第 8 位设置双工模式 (1—全双工; 0—半双工), 第 6 位和 13 位组合决定工作频率 (00—10Mb/s; 01—100Mb/s; 10—1000Mb/s)。



# 29 OTG 控制器 (D5:F0)

## 29.1 概述

2K2000 的 OTG 对应 USB2 PHY 的 PORT6, 支持特性如下:

- 支持 HNP 与 SRP 协议;
- 内嵌 DMA, 无需占用处理器带宽即可在 OTG 与外部存储之间移动数据;
- 在 device 模式下,为高速设备(480Mbps);
- 在 host 模式下, 支持高速设备(480Mbps);
- 在 device 模式下,支持 6 个双向的 endpoint, 其中仅有默认的 endpoint0 支持控制传输;
- 在 device 模式下,最多同时支持 4 个 IN 方向的传输;
- 在 host 模式下,支持 12 个 channel, 且软件可配置每个 channel 的方向;
- 在 host 模式下, 支持 periodic OUT 传输;

## 29.2 访问地址

OTG 控制器内部寄存器的物理地址构成如下:

| 地址位     | 构成       | 备注                      |
|---------|----------|-------------------------|
| [63:18] | BAR_BASE | Device 5、FUNC 0的基地址寄存器值 |
| [17:00] | REG      | 内部寄存器地址                 |



# 30 USB 控制器 (D4:F0, D25:F0)

## 30.1 总体概述

2K2000 的 USB 端口特性如下:

- USB 3.0 协议
- 兼容 USB 1.1 、USB 2.0 协议
- 兼容 XHCI 1.1 协议
- 支持 4 个 USB3. 0 端口,每个端口都可挂 SS、LS、FS 或 HS 设备
- 支持8个USB2.0端口,每个端口都可挂LS、FS或HS设备
- USB 2.0 为 XHCI 控制器 (D4:F0), 对应 USB2 PHY 的 PORT4/5/7/8
- USB 3.0 为 XHCI 控制器 (D25:F0), 对应 USB2 PHY 的 PORTO/1/2/3 和 USB3 PHY 的 PORTO/1/2/3

## 30.2 XHCI 控制器

#### 30.2.1 XHCI 配置寄存器

表 30- 1USB-XHCI 控制器的配置寄存器

| 地址偏移    | 简称      | 描述                                     | 默认值                | 访问类型    |
|---------|---------|----------------------------------------|--------------------|---------|
| 00h-01h | VID     | Vendor ID                              | 0014h              | RO      |
| 02h-03h | DID     | Device ID                              | 7A34h              | RO      |
| 04h-05h | PCICMD  | PCI Command                            | 0000h              | R/W, RO |
| 08h     | RID     | Revision ID                            | 00h                | RO      |
| 09h     | PI      | Programming Interface                  | 30h                | RO      |
| 0Ah     | SCC     | Sub Class Code                         | 03h                | RO      |
| 0Bh     | BCC     | Base Class Code                        | 0Ch                | RO      |
| 0Ch     | CLS     | Cache Line Size                        | 10h                | RO      |
| 0Eh     | HEADTYP | Header Type                            | 00h                | RO      |
| 10h-17h | CNL_BAR | Control Block Base Address<br>Register | 00000000000000004h | R/W, RO |
| 2Ch-2Dh | SVID    | Subsystem Vendor ID                    | 0000h              | RO      |
| 2Eh-2Fh | SID     | Subsystem Identification               | 0000h              | RO      |
| 3Ch     | INT_LN  | Interrupt Line                         | FFh                | R/W     |
| 3Dh     | INT_PN  | Interrupt Pin                          | 00h                | RO      |

注: 表中未列出的地址空间表示保留。

下面列出与 PCI 配置头规范稍有不同的寄存器及其描述。

#### PCICMD-PCI 命令寄存器 (USB XHCI-D25:F0)

地址偏移: 04-05h 属性: R/W, RO 默认值: 0000h 大小: 16 位

| 位域   | 名称                     | 访问  | 描述                                        |
|------|------------------------|-----|-------------------------------------------|
| 15:2 | Reserved               | RO  | 保留                                        |
| 1    | Memory Space<br>Enable | R/W | 该位用来控制是否使能对 USB XHCI 控制寄存器的访问。<br>0:禁止访问; |



|   |          |    | 1: 使能对 USB XHCI 控制寄存器的访问。在将该位配置为 1 之前,<br>必须先配置 PCNL_BAR 寄存器。 |
|---|----------|----|---------------------------------------------------------------|
| 0 | Reserved | RO | 保留                                                            |

#### 30.2.2 XHCI 基本操作寄存器

本节不具体列出协议里的寄存器的描述,可以在 XHCI Rev1.1 协议中查找,下表列出了相关域和在协议中的章节。

| 地址偏移                                      | 简称                    | 默认值                  | 描述                                            |
|-------------------------------------------|-----------------------|----------------------|-----------------------------------------------|
| O to CAPLENGTH                            | Capability Registers  | Up to 256<br>Bytes   | Refer to xhci<br>specification<br>Section5.3  |
| CAPLENGTH to CAPLENGTH+BFFh               | Operational Registers | Up to 3K<br>Bytes    | Refer to xhci<br>specification<br>Section5.4  |
| Pointed to by the Capability<br>Registers | RUN-time Registers    | Up to 32800<br>Bytes | Refer to xhci<br>specification<br>Section5.5  |
| Pointed to by the Capability<br>Registers | Doorbell Array        | Up to 1K<br>Bytes    | Refer to xhci<br>specification<br>Section 5.6 |

#### 30.2.3 USB3.0 初始化序列

USB3.0的 xhci 控制器的初始化复位时序参考如下:

- 1. 配置 PAD 复用寄存器,使引脚工作在 USB\_OC 模式
- 2. 配置通用配置寄存器 1, 开启 USB 的控制器的访问时能, 并配置 USB 时钟的输入模式
- 3. 读 USB 配置寄存器的 osc\_ready 信号,直到为'h1(只有在接外部晶体模式下需要此步骤)
- 4. 解复位 USB 配置寄存器的 apb reset n
- 5. 读 USB 配置寄存器的 micro\_setting\_status[0], 直到为'h1
- 6. 软件通过 USB 配置寄存器配置 USB3. OPHY 的初值,在 PHY 的偏移地址 0x4AA, 0x5AA, 0x6AA, 0x7AA 上,分别都写入值 0x32
- 7. 解复位控制器的复位信号



# 31图形处理器 (D6:F0)

## 31.1 GPU 配置寄存器

表 31- 1GPU 控制器的配置寄存器

| 地址偏移    | 简称       | 描述                                      | 默认值                 | 访问类型    |
|---------|----------|-----------------------------------------|---------------------|---------|
| 00h-01h | VID      | Vendor ID                               | 0014h               | RO      |
| 02h-03h | DID      | Device ID                               | 7A25h               | RO      |
| 04h-05h | PCICMD   | PCI Command                             | 0000h               | R/W, RO |
| 08h     | RID      | Revision ID                             | 00h                 | RO      |
| 09h     | PI       | Programming Interface                   | 00h                 | RO      |
| OAh     | SCC      | Sub Class Code                          | 02h                 | RO      |
| 0Bh     | BCC      | Base Class Code                         | 03h                 | RO      |
| 0Ch     | CLS      | Cache Line Size                         | 10h                 | RO      |
| 0Eh     | HEADTYP  | Header Type                             | 00h                 | RO      |
| 10h-17h | CNL_BAR  | Control Block Base Address<br>Register  | 000000000000000004h | R/W, RO |
| 18h-1Fh | GMEM_BAR | Graphic Memory Base Address<br>Register | 00000000000000004h  | R/W, RO |
| 2Ch-2Dh | SVID     | Subsystem Vendor ID                     | 0000h               | RO      |
| 2Eh-2Fh | SID      | Subsystem Identification                | 0000h               | RO      |
| 3Ch     | INT_LN   | Interrupt Line                          | FFh                 | R/W     |
| 3Dh     | INT_PN   | Interrupt Pin                           | 00h                 | RO      |

注:表中未列出的地址空间表示保留。

下面列出与 PCI 配置头规范稍有不同的寄存器及其描述。

#### PCICMD-PCI 命令寄存器 (GPU-D6:F0)

地址偏移: 04-05h 属性: R/W, RO

默认值: 0000h 大小: 16 位

| 位域   | 名称                     | 访问  | 描述                                                                                          |
|------|------------------------|-----|---------------------------------------------------------------------------------------------|
| 15:2 | Reserved               | RO  | 保留                                                                                          |
| 1    | Memory Space<br>Enable | R/W | 该位用来控制是否使能对 GPU 控制寄存器的访问。<br>0:禁止访问;<br>1:使能对 GPU 控制寄存器的访问。在将该位配置为 1 之前,必须先配置 PCNL_BAR 寄存器。 |
| 0    | Reserved               | RO  | 保留                                                                                          |



# 32显示控制器(D6:F1)

## 32.1 概述

显示控制器从内存中取帧缓冲和光标信息输出到外部显示接口上。 龙芯 2K2000 的显示控制器支持的特性包括:

- 1路 HDMI (显示通道 0)和 1路 DVO (显示通道 1)
- HDMI 最大支持至 4K @30Hz
- DVO 最大支持至 1080p@60Hz
- 横向分辨率必须为8的整数倍(比如不支持1366分辨率)
- Tile 模式只支持 1080p 及以下和 4K 分辨率
- Tile4 不支持压缩模式
- Monochrome、ARGB8888 两种模式硬件光标
- 两路硬件光标, 光标像素为 64 x 64 或 32 x 32 可选
- RGB444, RGB555, RGB565, RGB888 四种色深
- 输出抖动和伽马校正
- 可切换的双路线性帧缓冲
- 中断和软复位

## 32.2 DC 配置寄存器 (D6:F1)

表 32- 1DC 控制器的配置寄存器

|         |         | · · · · · · · · · · · · · · · · · · ·  |                    |         |
|---------|---------|----------------------------------------|--------------------|---------|
| 地址偏移    | 简称      | 描述                                     | 默认值                | 访问类型    |
| 00h-01h | VID     | Vendor ID                              | 0014h              | RO      |
| 02h-03h | DID     | Device ID                              | 7A06h              | RO      |
| 04h-05h | PCICMD  | PCI Command                            | 0000h              | R/W, RO |
| 08h     | RID     | Revision ID                            | 00h                | RO      |
| 09h     | PI      | Programming Interface                  | 00h                | RO      |
| 0Ah     | SCC     | Sub Class Code                         | 03h                | RO      |
| 0Bh     | BCC     | Base Class Code                        | 0Ch                | RO      |
| 0Ch     | CLS     | Cache Line Size                        | 10h                | RO      |
| 0Eh     | HEADTYP | Header Type                            | 00h                | RO      |
| 10h-17h | CNL_BAR | Control Block Base Address<br>Register | 00000000000000004h | R/W, RO |
| 2Ch-2Dh | SVID    | Subsystem Vendor ID                    | 0000h              | RO      |
| 2Eh-2Fh | SID     | Subsystem Identification               | 0000h              | RO      |
| 3Ch     | INT_LN  | Interrupt Line                         | FFh                | R/W     |
| 3Dh     | INT_PN  | Interrupt Pin                          | 00h                | RO      |

注: 表中未列出的地址空间表示保留。

下面列出与 PCI 配置头规范稍有不同的寄存器及其描述。

#### PCICMD-PCI 命令寄存器 (DC-D6:F1)

地址偏移: 04-05h 属性: R/W, RO



#### 默认值: 0000h

大小: 16 位

| 位域   | 名称                     | 访问  | 描述                                                                                        |
|------|------------------------|-----|-------------------------------------------------------------------------------------------|
| 15:2 | Reserved               | RO  | 保留                                                                                        |
| 1    | Memory Space<br>Enable | R/W | 该位用来控制是否使能对 DC 控制寄存器的访问。<br>0:禁止访问;<br>1:使能对 DC 控制寄存器的访问。在将该位配置为 1 之前,必须先配置 PCNL_BAR 寄存器。 |
| 0    | Reserved               | RO  | 保留                                                                                        |

# 32.3 DC 控制寄存器

## 32.3.1 帧缓冲配置寄存器

| 寄存器名              | 偏移地址             |                                             | R/W                         | 描述        | 复位值 |
|-------------------|------------------|---------------------------------------------|-----------------------------|-----------|-----|
| frameBufferConfig | 0x1240<br>0x1250 | 帧缓冲配置寄存器<br>R/W 0x1240: HDMI<br>0x1250: DV0 |                             | 00000000h |     |
| frameBufferConfig | bit              | 描述                                          |                             |           | 初始值 |
| Reset             | 20               | 从值                                          | 1 变为 0 时                    | 软复位       | 0   |
| DC_DMA            | 17:16            | DMA 耳<br>0: 25<br>1: 12<br>2: 64<br>3: 32   | 28<br>1                     | 0         |     |
| Gamma             | 12               | 写14                                         | 更能伽马校.                      | E         | 0   |
| FB number         | 11               | 指示                                          | 当前正在使                       | 用的缓冲区号,只读 | 0   |
| Switch Panel      | 9                |                                             | 表示使用另一示交换、拷                 | 0         |     |
| Output Enable     | 8                | 写14                                         | 吏能显示输!                      | 出         | 0   |
| FB switch         | 7                | 写14                                         | 吏能缓冲区                       | 0         |     |
| Meta En           | 6                |                                             | 7规模式<br>1能压缩模式              | 0         |     |
| TileMode          | 5:4              | 1: Ti                                       | near 模式<br>le 4模式<br>le 8模式 | 0         |     |
| Format            | 2:0              |                                             | one<br>GB444<br>GB555       | 0         |     |

## 32.3.2 帧缓冲地址寄存器 0

| 寄存器名             | 偏移地址             |    | R/W      | 描述                                         | 复位值       |
|------------------|------------------|----|----------|--------------------------------------------|-----------|
| frameBufferAddr0 | 0x1260<br>0x1270 |    | R/W      | 帧缓冲地址寄存器 0。<br>0x1260: HDMI<br>0x1270: DV0 | 00000000h |
| frameBufferAddr0 | bit              | 描述 |          |                                            | 初始值       |
| Address          | 31:0             | 缓冲 | 区 0 在内存品 | 中的物理地址                                     | 0         |

## 32.3.3 帧缓冲地址寄存器 1



| 寄存器名             | 偏移地址             |     | R/W    | 描述                                         | 复位值       |
|------------------|------------------|-----|--------|--------------------------------------------|-----------|
| frameBufferAddr1 | 0x1580<br>0x1590 |     | R/W    | 帧缓冲地址寄存器 1。<br>0x1580: HDMI<br>0x1590: DV0 | 00000000h |
| frameBufferAddr1 | bit              | 描述  |        |                                            | 初始值       |
| Address          | 31:0             | 缓冲[ | 区1在内存。 | 0                                          |           |

## 32.3.4 Meta0 低地址寄存器

| 寄存器名               | 偏移地址             |       | R/W   | 描述                                          | 复位值       |
|--------------------|------------------|-------|-------|---------------------------------------------|-----------|
| MetaOBufferAddrLow | 0x1b00<br>0x1b10 |       | R/W   | MetaO 低地址寄存器<br>Ox1bOO: HDMI<br>Ox1b1O: DVO | 00000000h |
| MetaOBufferAddrLow | bit              | 描述    |       |                                             | 初始值       |
| Address            | 31:0             | MetaC | 缓冲区在内 | 0                                           |           |

## 32.3.5 Meta0 高地址寄存器

| 寄存器名                    | 偏移地址             |       | R/W   | 描述                                          | 复位值       |
|-------------------------|------------------|-------|-------|---------------------------------------------|-----------|
| MetaOBufferAddrHig<br>h | 0x1b20<br>0x1b30 |       | R/W   | MetaO 高地址寄存器<br>Ox1b2O: HDMI<br>Ox1b3O: DVO | 00000000h |
| MetaOBufferAddrHig<br>h | bit              | 描述    |       | 初始值                                         |           |
| Address                 | 31:0             | MetaC | 缓冲区在内 | 0                                           |           |

## 32.3.6 Metal 低地址寄存器

| 寄存器名               | 偏移地址             |       | R/W   | 描述                                          | 复位值       |
|--------------------|------------------|-------|-------|---------------------------------------------|-----------|
| MetalBufferAddrLow | 0x1b40<br>0x1b50 |       | R/W   | Meta1 低地址寄存器<br>Ox1b40: HDMI<br>Ox1b50: DVO | 00000000h |
| MetalBufferAddrLow | bit              | 描述    |       |                                             | 初始值       |
| Address            | 31:0             | Meta1 | 缓冲区在内 | 0                                           |           |

## 32.3.7 Metal 高地址寄存器

| 寄存器名                    | 偏移地址             |       | R/W   | 描述                                          | 复位值       |
|-------------------------|------------------|-------|-------|---------------------------------------------|-----------|
| MetalBufferAddrHig<br>h | 0x1b60<br>0x1b70 |       | R/W   | Metal 高地址寄存器<br>Ox1b60: HDMI<br>Ox1b70: DVO | 00000000h |
| MetalBufferAddrHig<br>h | bit              | 描述    |       | 初始值                                         |           |
| Address                 | 31:0             | Metal | 缓冲区在内 | 0                                           |           |

## 32.3.8 帧缓冲跨度寄存器

| 寄存器名              | 偏移地址             |     | R/W                                  | 描述                                       | 复位值       |
|-------------------|------------------|-----|--------------------------------------|------------------------------------------|-----------|
| frameBufferStride | 0x1280<br>0x1290 |     | R/W                                  | 帧缓冲跨度寄存器:<br>0x1280: HDMI<br>0x1290: DV0 | 00000000h |
| frameBufferStride | bit              | 描述  |                                      | 初始值                                      |           |
| Stride            | 31:0             | 需要注 | 屏一行的字 <sup>=</sup><br>主意的是根<br>节数向上取 | 0                                        |           |



#### 32.3.9 帧缓冲初始字节寄存器

| 寄存器名              | 偏移地址             |     | R/W    | 描述                                        | 复位值       |
|-------------------|------------------|-----|--------|-------------------------------------------|-----------|
| frameBufferOrigin | 0x1300<br>0x1310 |     | R/W    | 帧缓冲初始字节寄存器<br>0x1300: HDMI<br>0x1310: DV0 | 00000000h |
| frameBufferOrigin | bit              | 描述  |        |                                           | 初始值       |
| Origin            | 31:0             | 显示原 | 异左侧原有5 | 0                                         |           |

#### 32. 3. 10 颜色抖动配置寄存器

| 寄存器名         | 偏移地址             |     | R/W    | 描述                                       | 复位值       |
|--------------|------------------|-----|--------|------------------------------------------|-----------|
| ditherConfig | 0x1360<br>0x1370 |     | R/W    | 颜色抖动配置寄存器<br>0x1360: HDMI<br>0x1370: DV0 | 00000000h |
| ditherConfig | bit              | 描述  |        |                                          | 初始值       |
| Enable       | 31               | 写16 | 更能颜色抖表 | 0                                        |           |
| RedSize      | 19:16            | 红色均 | 或宽度    |                                          | 0         |
| GreenSize    | 11:8             | 绿色块 | 或宽度    | 0                                        |           |
| BlueSize     | 3:0              | 蓝色均 | 或宽度    |                                          | 0         |

#### 32.3.11 颜色抖动查找表低位寄存器

| 寄存器名           | 偏移地址             |    | R/W      | 描述                                          | 复位值       |
|----------------|------------------|----|----------|---------------------------------------------|-----------|
| ditherTableLow | 0x1380<br>0x1390 |    | R/W      | 颜色抖动查找表低位寄存器<br>0x1380: HDMI<br>0x1390: DV0 | 00000000h |
| ditherTableLow | bit              | 描述 |          |                                             | 初始值       |
| Y1_X3          | 31:28            | 坐标 | (3,1) 处的 | 比较值。                                        | 0         |
| Y1_X2          | 27:24            | 坐标 | (2,1) 处的 | 比较值。                                        | 0         |
| Y1_X1          | 23:20            | 坐标 | (1,1) 处的 | 比较值。                                        | 0         |
| Y1_X0          | 19:16            | 坐标 | (0,1) 处的 | 比较值。                                        | 0         |
| Y0_X3          | 15:12            | 坐标 | (3,0) 处的 | 比较值。                                        | 0         |
| Y0_X2          | 11:8             | 坐标 | (2,0) 处的 | 比较值。                                        | 0         |
| Y0_X1          | 7:4              | 坐标 | (1,0) 处的 | 比较值。                                        | 0         |
| Y0_X0          | 3:0              | 坐标 | (0,0) 处的 | 比较值。                                        | 0         |

## 32.3.12 颜色抖动查找表高位寄存器

| 寄存器名            | 偏移地址             |    | R/W      | 描述                                          | 复位值       |
|-----------------|------------------|----|----------|---------------------------------------------|-----------|
| ditherTableHigh | 0x13a0<br>0x13b0 |    | R/W      | 颜色抖动查找表高位寄存器<br>0x13a0: HDMI<br>0x13b0: DV0 | 00000000h |
| ditherTableLow  | bit              | 描述 |          |                                             | 初始值       |
| Y3_X3           | 31:28            | 坐标 | (3,3) 处的 | 比较值。                                        | 0         |
| Y3_X2           | 27:24            | 坐标 | (2,3) 处的 | 比较值。                                        | 0         |
| Y3_X1           | 23:20            | 坐标 | (1,3) 处的 | 比较值。                                        | 0         |
| Y3_X0           | 19:16            | 坐标 | (0,3) 处的 | 比较值。                                        | 0         |
| Y2_X3           | 15:12            | 坐标 | (3,2) 处的 | 比较值。                                        | 0         |
| Y2_X2           | 11:8             | 坐标 | (2,2) 处的 | 比较值。                                        | 0         |
| Y2_X1           | 7:4              | 坐标 | (1,2) 处的 | 比较值。                                        | 0         |
| Y2_X0           | 3:0              | 坐标 | (0,2) 处的 | 比较值。                                        | 0         |

## 32.3.13 颜色抖动说明

颜色抖动功能用于根据一定规则来增强像素值。

在下面的这个例子中,将解释颜色抖动功能的实现步骤。



首先,确定是对哪一数据位进行增强(即该数据位加1),为此需要配置寄存器 Display Dither Configuration。比如配置 RedSize 为6(1到8之间,包含1和8),则表明对从 MSB位数起第6位进行增强,即 RedColor[7:0]的 RedColor[2]位增强。GreenSize 和 BlueSize 同理。

其次,需要建立查找表,即配置寄存器 Display Dither Table。

查找表包含16个条目,即16个阈值,每个条目4位宽。

查找表通过屏幕像素计数器的横坐标 x 的最低两位 x[1:0] 和纵坐标 y 的最低两位 y[1:0] 进行索引,得到一个阈值 U[3:0]。

对应屏幕(x,y)位置的像素值的最低四位被拿来跟查到的这个阈值比较。

如果 RedColor[3:0] > U[3:0], 并且 RedColor[7:2]不是 1111111b, 则 RedColor[2]位 加 1, 实现颜色增强。

#### 32.3.14 液晶面板配置寄存器

| 寄存器名        | 偏移地址   |             | R/W         | 描述                        | 复位值  |
|-------------|--------|-------------|-------------|---------------------------|------|
| panelConfig | 0x13c0 |             | R/W         | 液晶面板配置寄存器<br>0x13c0: HDMI | 101h |
|             | 0x13d0 | ,           | 0x13d0: DV0 |                           |      |
| panelConfig | bit    | 描述          |             |                           | 初始值  |
| ClockPol    | 9      | 时钟村         | 汲性,写 1 耳    | 权反                        | 0    |
| ClockEn     | 8      | 时钟位         | 吏能,写1位      | 吏能                        | 1    |
| DEPo1       | 1      | 数据使能极性,写1取反 |             |                           | 0    |
| DE          | 0      | 数据值         | 吏能,写1位      | 更能                        | 1    |

#### 32.3.15 水平显示宽度寄存器

| 寄存器名     | 偏移地址             | R/W     | 描述                                      | 复位值       |  |
|----------|------------------|---------|-----------------------------------------|-----------|--|
| HDisplay | 0x1400<br>0x1410 | R/W     | 行水平显示宽度寄存器<br>0x1400:HDMI<br>0x1410:DV0 | 00000000h |  |
| HDisplay | Bit              | 描述      |                                         | 初始值       |  |
| Total    | 28:16            | 显示屏一行的总 | 0                                       |           |  |
| Display  | 12:0             | 显示屏一行中显 | 显示屏一行中显示区的像素数                           |           |  |

#### 32. 3. 16 行同步配置寄存器

| 寄存器名  | 偏移地址             | R/W   | 描述                                    | 复位值       |
|-------|------------------|-------|---------------------------------------|-----------|
| Hsync | 0x1420<br>0x1430 | R/W   | 行同步配置寄存器<br>0x1420:HDMI<br>0x1430:DV0 | 40000000h |
| Hsync | Bit              | 描述    |                                       | 初始值       |
| Pol   | 31               | 行同步极性 | , 写 1 取反                              | 0         |
| Pulse | 30               | 行同步使能 | , 写 1 使能                              | 1         |
| End   | 28:16            | 行同步结束 | 时的像素数                                 | 0         |
| Start | 12:0             | 行同步开始 | 时的像素数                                 | 0         |

#### 32. 3. 17 垂直显示高度寄存器

| 寄存器名     | 偏移地址   | R/W | 描述        | 复位值       |
|----------|--------|-----|-----------|-----------|
| VDisplay | 0x1480 | R/W | 垂直显示高度寄存器 | 00000000h |



| 1 |          |        |       |               |     |
|---|----------|--------|-------|---------------|-----|
|   |          | 0x1490 |       | 0x1480:HDMI   |     |
|   |          |        |       | 0x1490:DV0    |     |
|   | VDisplay | Bit    | 描述    |               | 初始值 |
|   | Total    | 27:16  | 显示屏一列 | 的总像素数(包括非显示区) | 0   |
|   | Display  | 11:0   | 显示屏一列 | 中显示区的像素数      | 0   |

## 32.3.18 场同步配置寄存器

| 寄存器 名 | 偏移地址             | R/W | 描述                                    | 复位值       |
|-------|------------------|-----|---------------------------------------|-----------|
| VSync | 0x14a0<br>0x14b0 | R/W | 场同步配置寄存器<br>0x14a0:HDMI<br>0x14b0:DV0 | 40000000h |
| VSync | Bit              | 描述  |                                       | 初始值       |
| Pol   | 31               | 场同步 | 极性,写1取反                               | 0         |
| Pulse | 30               | 场同步 | 使能,写1使能                               | 1         |
| End   | 27:16            | 场同步 | 结束时的像素数                               | 0         |
| Start | 11:0             | 场同步 | 开始时的像素数                               | 0         |

## 32.3.19 行场同步偏移配置寄存器

| 寄存器名                 | 偏移地址             | R/W        | 描述                                    | 复位值       |
|----------------------|------------------|------------|---------------------------------------|-----------|
| SyncDeviation        | 0x1b80<br>0x1b90 | R/W        | 场同步配置寄存器<br>0x1b80:HDMI<br>0x1b90:DV0 | 00000000h |
| SyncDeviation        | Bit              | 描述         |                                       | 初始值       |
| SyncDeviation<br>En  | 31               | 行场同<br>行起落 | 引步偏移使能,不使能则场同步信号按像素<br>\$             | 0         |
| SyncDeviationNu<br>m | 12:0             | ı          | 引步偏移值,单位为像素点,数值为行同步<br>注置减场同步起始位置     | 0         |

#### 32.3.20 当前显示位置寄存器

| 寄存器名                   | 偏移地<br>址         | R/W    | 描述                                     | 复位值       |
|------------------------|------------------|--------|----------------------------------------|-----------|
| DisplayCurrentLocation | 0x14c0<br>0x14d0 | R      | 当前显示位置寄存器<br>0x14c0:HDMI<br>0x14d0:DV0 | 00000000h |
| DisplayCurrentLocation | Bit              | 描述     |                                        | 初始值       |
| Current Location X     | 31:16            | 当前 X 的 | 位置                                     | 0         |
| Current Location Y     | 15:0             | 当前Y的   | 位置                                     | 0         |

## 32.3.21 伽马校正目录寄存器

| 寄存器名       | 偏移地址             | 偏移地址 |                       | 描述                                       | 复位值       |
|------------|------------------|------|-----------------------|------------------------------------------|-----------|
| GammaIndex | 0x14e0<br>0x14f0 |      | R/W                   | 伽马校正目录寄存器<br>0x14e0: HDMI<br>0x14f0: DV0 | 00000000h |
| GammaIndex | bit              | 描述   |                       |                                          | 初始值       |
| Index      | 7:0              |      | 从 0−255 颜f<br>一般设 0。戶 | 0                                        |           |

## 32.3.22 伽马校正值寄存器

| 寄存器名      | 偏移地址             | R/W | 描述                                      | 复位值       |
|-----------|------------------|-----|-----------------------------------------|-----------|
| GammaData | 0x1500<br>0x1510 | R/W | 伽马校正值寄存器<br>0x1500: HDMI<br>0x1510: DV0 | 00000000h |



| GammaIndex | bit   | 描述                                          | 初始值 |
|------------|-------|---------------------------------------------|-----|
| Red        | 23:16 | Gamma 调整的红色域,将 Gamma Index 指示的值调整<br>为当前域的值 | 0   |
| Green      | 15:8  | Gamma 调整的绿色域,将 Gamma Index 指示的值调整<br>为当前域的值 | 0   |
| Blue       | 7:0   | Gamma 调整的蓝色域,将 Gamma Index 指示的值调整<br>为当前域的值 | 0   |

Gamma 调整模块包含三个查找表,一个负责红色,一个负责绿色,一个负责蓝色。 查找表可以通过寄存器改写。查找表只可写。

考虑一个 Gamma 调整如下: (原色,调整色)。当设置 Gamma 颜色查找表时,我们应该按照颜色值大小顺序配置寄存器.。

如果我们想要一个调整为 (0, 0) (1, 2) (2, 5) (3, 6) ······, 先对寄存器 Gamma Index 配置 0,表示 gamma 调整从 0 开始,然后对 Gamma Data 寄存器配置 256 次完成整个配置过程: 0, 2, 5, 6······

#### 32.3.23 光标 0 配置寄存器

| 寄存器名          | 偏移地址   | R/W                                  | 描述                               | 复位值       |
|---------------|--------|--------------------------------------|----------------------------------|-----------|
| Cursor0Config | 0x1520 | R/W                                  | 光标配置寄存器                          | 00000000h |
| Cursor0Config | Bit    | 描述                                   |                                  | 初始值       |
| HotSpotX      | 21:16  | 光标作用点<br>图案中的横                       | 的横坐标(在光标 32*32 或者 64*64<br>坐标)   | 0         |
| HotSpotY      | 13:8   | 光标作用点<br>图案中的横                       | 的纵坐标(在光标 32*32 或者 64*64<br>坐标)   | 0         |
| Display       | 4      |                                      | 在于哪个显示单元中,0表示在0号<br>,1表示在1号显示单元中 | 0         |
| Mode          | 2      | 1: 64*64 为 0: 32*32 为                | -11 21 1                         | 0         |
| Format        | 1:0    | 0:disabled<br>1:masked<br>2:ARGB8888 |                                  | 0         |

#### 32.3.24 光标 0 存储地址寄存器

| 寄存器名           | 偏移地址   |     | R/W     | 描述        | 复位值       |
|----------------|--------|-----|---------|-----------|-----------|
| CursorOAddress | 0x1530 |     | R/W     | 光标存储地址寄存器 | 00000000h |
| CursorOAddress | bit    | 描述  |         |           | 初始值       |
| Address        | 31:0   | 光标数 | 女据在内存中的 | 的物理地址     | 0         |

#### 32.3.25 光标 0 显示位置寄存器

| 寄存器名            | 偏移地址   | R/W   | 描述         | 复位值       |
|-----------------|--------|-------|------------|-----------|
| Cursor0Location | 0x1540 | R/W   | 光标显示位置寄存器  | 00000000h |
| Cursor0Location | Bit    | 描述    |            | 初始值       |
| Y               | 27:16  | 光标作用, | 点在整个屏幕的纵坐标 | 0         |
| X               | 11:0   | 光标作用, | 点在整个屏幕的横坐标 | 0         |

#### 32.3.26 单色光标 0 背景色寄存器

| 寄存器名              | 偏移地址   | R/W | 描述         | 复位值       |
|-------------------|--------|-----|------------|-----------|
| CursorOBackground | 0x1550 | R/W | 单色光标背景色寄存器 | 00000000h |



| CursorOBackground | bit   | 描述             | 初始值 |
|-------------------|-------|----------------|-----|
| Red               | 23:16 | 光标单色模式下背景色的红色域 | 0   |
| Green             | 15:8  | 光标单色模式下背景色的绿色域 | 0   |
| Blue              | 7:0   | 光标单色模式下背景色的蓝色域 | 0   |

# 32.3.27 单色光标 0 前景色寄存器

| 寄存器名              | 偏移地址   |                | R/W    | 描述         | 复位值       |
|-------------------|--------|----------------|--------|------------|-----------|
| CursorOForeground | 0x1560 |                | R/W    | 单色光标前景色寄存器 | 00000000h |
| CursorOForeground | bit    | bit 描述         |        |            | 初始值       |
| Red               | 23:16  | 光标单            | 单色模式下  | 0          |           |
| Green             | 15:8   | 光标单色模式下前景色的绿色域 |        |            | 0         |
| Blue              | 7:0    | 光标卓            | 单色模式下向 | 前景色的蓝色域    | 0         |

## 32.3.28 光标1配置寄存器

| 寄存器名          | 偏移地址   | R/W                                  | 描述                                        | 复位值       |  |  |
|---------------|--------|--------------------------------------|-------------------------------------------|-----------|--|--|
| CursorlConfig | 0x1670 | R/W                                  | 光标1配置寄存器                                  | 00000000h |  |  |
| Cursor1Config | Bit    | 描述                                   |                                           | 初始值       |  |  |
| HotSpotX      | 21:16  | 光标作用点<br>横坐标)                        | 光标作用点的横坐标(在光标 32*32 或者 64*64 图案中的<br>横坐标) |           |  |  |
| HotSpotY      | 13:8   | 光标作用点<br>横坐标)                        | 光标作用点的纵坐标(在光标 32*32 或者 64*64 图案中的<br>横坐标) |           |  |  |
| Display       | 4      |                                      | 指示光标存在于哪个显示单元中,0表示在0号显示单元中,1表示在1号显示单元中    |           |  |  |
| Mode          | 2      | '                                    | 1: 64*64 光标模式<br>0: 32*32 光标模式            |           |  |  |
| Format        | 1:0    | 0:disabled<br>1:masked<br>2:ARGB8888 | 0                                         |           |  |  |

## 32.3.29 光标 1 存储地址寄存器

| 寄存器名           | 偏移地址   | R/W   | 描述           | 复位值       |
|----------------|--------|-------|--------------|-----------|
| Cursor1Address | 0x1680 | R/W   | 光标 1 存储地址寄存器 | 00000000h |
| Cursor1Address | Bit    | 描述    |              | 初始值       |
| Address        | 31:0   | 光标数据在 | 内存中的物理地址     | 0         |

## 32.3.30 光标 1 显示位置寄存器

| 寄存器名            | 偏移地址   | R/W   | 描述           | 复位值       |
|-----------------|--------|-------|--------------|-----------|
| Cursor1Location | 0x1690 | R/W   | 光标 1 显示位置寄存器 | 00000000h |
| CursorlLocation | Bit    | 描述    |              | 初始值       |
| Y               | 27:16  | 光标作用。 | 点在整个屏幕的纵坐标   | 0         |
| X               | 11:0   | 光标作用。 | 点在整个屏幕的横坐标   | 0         |

## 32.3.31 单色光标 1 背景色寄存器

| 寄存器名              | 偏移地址   | R/W  | 描述            | 复位值       |
|-------------------|--------|------|---------------|-----------|
| Cursor1Background | 0x16a0 | R/W  | 光标1单色光标背景色寄存器 | 00000000h |
| Cursor1Background | Bit    | 描述   |               | 初始值       |
| Red               | 23:16  | 单色光标 | 模式下背景色的红色域    | 0         |
| Green             | 15:8   | 单色光标 | 模式下背景色的绿色域    | 0         |
| Blue              | 7:0    | 单色光标 | 模式下背景色的蓝色域    | 0         |



#### 32.3.32 单色光标 1 前景色寄存器

| 寄存器名              | 偏移地址   | R/W | 描述            | 复位值       |
|-------------------|--------|-----|---------------|-----------|
| Cursor1Foreground | 0x16b0 | R/W | 光标1单色光标前景色寄存器 | 00000000h |
| Cursor1Foreground | Bit    | 描述  |               | 初始值       |
| Red               | 23:16  | 单色光 | 标模式下前景色的红色域   | 0         |
| Green             | 15:8   | 单色光 | 际模式下前景色的绿色域   | 0         |
| Blue              | 7:0    | 单色光 | 标模式下前景色的蓝色域   | 0         |

Display Controller 支持硬件光标。当开启硬件光标时,可以下面两种格式:

- 1. XOR cursor
- 2. Full color RGB

在 XOR 光标格式情况下,每个像素点使用 2 位。一位为 mask,一位为 XOR。Mask 位产 生指针的形状。XOR 位决定该像素显示。

表 32-2 单色光标模式

| AND(mask_bit) | XOR(xor_bit) | CURSOR_COLOR |
|---------------|--------------|--------------|
| 0             | 0            | 背景色          |
| 0             | 1            | 前景色          |
| 1             | 0            | 透明           |
| 1             | 1            | 屏幕反色         |

在 RGB 指针格式下,每个像素包含 8 位 R,8 位 G和 8 位 B。

Alpha 部分表示插值系数。

指针有两个重要的点: 左上点(top-left point)和作用点(hot spot)。

左上点用来作为指针地址的参考点。

作用点用来将鼠标按下动作确定到一个像素上。

#### 32.3.33 HDMI 区域配置寄存器

| 寄存器名         | 偏移地址     |             | R/W                 | 描述                           | 复位值       |
|--------------|----------|-------------|---------------------|------------------------------|-----------|
| HdmiZoneIdle | 0x1700   |             | R/W                 | HDMI 区域配置寄存器<br>0x1700: HDMI | 00000000h |
| HdmiZoneIdle | bit      | bit 描述      |                     |                              | 初始值       |
| HzoneIdle    | 1 7 • () |             | 中预留给可<br>小于 48 则 hl | 0                            |           |
| Hwait        | 15:8     | 在 hb<br>配 0 | lank 区域等            | 0                            |           |
| VzoneIdle    | 23:16    |             | 中预留给可<br>小于 48 则可   | 0                            |           |
| Vwait        | 31:24    | 在 vb<br>配 0 | lank 区域等            | 待 Vwait 周期数再允许发包,一般          |           |

#### 32.3.34 HDMI 控制寄存器

| 寄存器名              | 偏移地址   |      | R/W | 描述                         | 复位值       |
|-------------------|--------|------|-----|----------------------------|-----------|
| HdmiInterfaceCtrl | 0x1720 |      | R/W | HDMI 控制寄存器<br>0x1720: HDMI | 00000000h |
| HdmiInterfaceCtrl | bit    | 描述   |     |                            | 初始值       |
| InterfaceEnable   | 0      | HDMI | 使能  |                            | 0         |
| PacketEnable      | 1      | 包使的  | Ě   | 0                          |           |



| AudioEnable         | 2   | 音频使能                                                                                                              | 0     |
|---------------------|-----|-------------------------------------------------------------------------------------------------------------------|-------|
| VideoLGBDisable     | 3   | 视频 Leading Guard Band 禁止使能                                                                                        | 0     |
| VideoPreambleLength | 7:4 | Video Preamble 长度                                                                                                 | 4' d8 |
| I2CPadSe1           | 8   | 0: 使用 GPIO 通过软件模拟 I2C 功能<br>1: 使用内置 I2 模块                                                                         | 0     |
| CtlPeriodMode       | 9   | HBlank 和 Vblank 区域的 control 周期发送的值<br>0: CTL0 - CTL3 都为 0<br>1: CTL0 为 1, CTL1 - CTL3 为 0, 即等同于 Video<br>Preamble | 0     |

#### **32.3.35** Audio BUF 配置寄存器

| 寄存器名         | 偏移地址   |                   | R/W                                     | 描述                                                        | 复位值       |
|--------------|--------|-------------------|-----------------------------------------|-----------------------------------------------------------|-----------|
| AudioBuf     | 0x1740 |                   | R/W                                     | HDMI 模块缓存 HDA 发送的音频数据,推迟 ASP 包的发送,用于音视频同步<br>0x1740: HDMI | 00000000h |
| AudioBuf     | bit    | 描述                |                                         |                                                           | 初始值       |
| AudioBufEn   | 31     | 写1                | 更能推迟 AS                                 | P包的发送功能                                                   | 0         |
| AudioBufClr  | 30     | 写1%               | 青除 Aduio ]                              | 0                                                         |           |
| AudioBufSize | 9:0    | 位有多<br>Base<br>ms | 爰存的音频数,最多缓存<br>Freq 44.1K<br>Freq 48KHz | 10' h0                                                    |           |

## **32.3.36** Audio N 配置寄存器

| 寄存器名         | 偏移地址   |     | R/W | 描述                      | 复位值       |
|--------------|--------|-----|-----|-------------------------|-----------|
| audioNConfig | 0x1760 |     | R/W | N 配置寄存器<br>0x1760: HDMI | 00000000h |
| audioNConfig | bit    | 描述  |     |                         | 初始值       |
| NValue       | 19:0   | 配置] | N的值 |                         | 20' h0    |

## 32.3.37 Audio CTS 配置寄存器

| 寄存器名           | 偏移地址   | 偏移地址   |                                | 描述                        | 复位值       |
|----------------|--------|--------|--------------------------------|---------------------------|-----------|
| audioCTSConfig | 0x1780 | 0x1780 |                                | CTS 配置寄存器<br>0x1780: HDMI | 00000000h |
| audioCTSConfig | bit    | 描述     |                                |                           | 初始值       |
| CTSValue       | 19:0   | 配置制    | 静态 CTS 的(                      | 直                         | 20' h0    |
| CTSCntStop     | 28     | 0: 使   | か态测量模式<br>能 CTS 动态<br>止 CTS 动态 | 0                         |           |
| CTSFix         | 29     | 0: 动   | E成模式: 」态测量 ・态配置                | 0                         |           |
| NCTSUpdate     | 30     | 静态四    | 配置模式下:                         | 0                         |           |
| ACREn          | 31     | 使能     | ACR 包                          |                           | 0         |

## **32.3.38** Audio CTS Cal 配置寄存器

| 寄存器名              | 偏移地址   |    | R/W | 描述                            | 复位值       |
|-------------------|--------|----|-----|-------------------------------|-----------|
| audioCTSCalConfig | 0x17a0 |    | R   | CTS Cal 配置寄存器<br>Ox17aO: HDMI | 00000000h |
| audioCTSCalConfig | bit    | 描述 |     |                               | 初始值       |



| CTSCalValue | 19:0 | 保存动态生成的 CTS 值 | 0 |
|-------------|------|---------------|---|

## 32.3.39 Audio InfoFrame 配置寄存器

| 寄存器名                 | 偏移地址                                                             |                                 | R/W                                | 描述                          | 复位值       |
|----------------------|------------------------------------------------------------------|---------------------------------|------------------------------------|-----------------------------|-----------|
| audioInfoFrameConfig | 0x17c0                                                           |                                 | R/W                                | 音频信息帧包配置寄存器<br>0x17c0: HDMI | 00000000h |
| audioInfoFrameConfig | bit 描述                                                           |                                 |                                    | 初始值                         |           |
| Enable               | 0                                                                | 写 1 使能发送 Audio InfoFrame Packet |                                    |                             | 0         |
| Frequency            | Audio InfoFrame Packet 发送频率:  1 0: 每 1 个视频域发送一次  1: 每 2 个视频域发送一次 |                                 |                                    |                             | 0         |
| Update               | 2                                                                | 写15                             | 更新 Audio                           | 0                           |           |
| ChannelCount         | 6:4                                                              | 音频                              | 通道计数                               | 0                           |           |
| ChannelAllocation    | 15:8                                                             | 音频注                             | 通道/播放器                             | 0                           |           |
| DownMix              | 16                                                               | 0: 禁                            | DVD 音频应序<br>止 down-mi<br>许 down-mi | 0                           |           |
| LevelShift alue      | 23:20                                                            | 水平和                             | 多位值(仅在                             | 0                           |           |
| LFEPBL               | 25:24                                                            | LFE ‡                           | 番放等级信息                             | 0                           |           |

## **32.3.40** Audio Sample 配置寄存器

| 寄存器名               | 偏移地址   |                                  | R/W                           | 描述                         | 复位值       |
|--------------------|--------|----------------------------------|-------------------------------|----------------------------|-----------|
| audioSampleConfig  | 0x17e0 |                                  | R/W                           | 音频数据包配置寄存器<br>0x17e0: HDMI | 00000000h |
| audioSampleConfig  | bit    | 描述                               |                               |                            | 初始值       |
| ASPEn              | 0      | 写 1 使能发送 Audio Sample Packet 的功能 |                               |                            | 0         |
| SampleLayout       | 1      | 配置 Audio Sample layout           |                               |                            | 0         |
| ChannelStatusFiexd | 2      | 0: HI                            | 音频数据报<br>DA Digital<br>C音频通道状 | 0                          |           |
| LeftChnlValid      | 3      | 写15                              | 强制设置 AS                       | 0                          |           |
| RightChnlValid     | 4      | 写15                              | 强制设置 AS                       | 0                          |           |

## **32.3.41** HDMI PHY 控制寄存器

| 寄存器名          | 偏移地址   |                              | R/W                                  | 描述                             | 复位值       |
|---------------|--------|------------------------------|--------------------------------------|--------------------------------|-----------|
| HDMIPhyCtrl   | 0x1800 |                              | R/W                                  | HDMI PHY 控制寄存器<br>0x1800: HDMI | 00000000h |
| HDMIPhyCtrl   | bit    | 描述                           |                                      |                                | 初始值       |
| PhyEn         | 0      | IDDQ                         | nk 的终止检<br>模式,PhyEi<br>吏能脉冲(F        | 0                              |           |
| PhyResetn     | 1      | 全局是                          | 异步 reset,                            | 0                              |           |
| PhyRextEn     | 2      | 高有效的偏压电阻检测。独立于 PhyEn         |                                      |                                | 0         |
| PhyBiasSel    | 3      | "HDM                         | 1.8V的24<br>IIBIAS"引<br>iuA±2%的对<br>上 | 0                              |           |
| PhyBiasStatus | 4      |                              | 电阻检测状a<br>asStatus =                 | 0                              |           |
| PhyTermEn     | 9:8    | 对<=<br>对> 1                  | 效的 Source<br>1.65Gbps :<br>.65Gbps : |                                |           |
| PhyTermDetEn  | 10     | 高有效的 Sink 终止检测使能。与 Phy En 独立 |                                      |                                |           |



| PhyTermStatus | 11    | 接受者终止检测状态位。<br>PhyTermStatus = 'H' 表示存在 Sink 终止。                                                                                                                                                    |  |
|---------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| PhySkewChk    | 13:12 | 2Bit 的 Inter Pair Skew 的检测控制位<br>00:不检测<br>01: Inter Pair Skew >= 2*T <sub>BIT</sub> 设错误标识位<br>10: Inter Pair Skew >= 4*T <sub>BIT</sub> 设错误标识位<br>11: Inter Pair Skew >= 6*T <sub>BIT</sub> 设错误标识位 |  |
| PhySkewErr    | 14    | 当 Inter Pair Skew 的值大于所设定值时的错误标识位                                                                                                                                                                   |  |

## **32.3.42** HDMI PHY PLL 配置寄存器

| 寄存器名             | 偏移地址   |             | R/W                                                          | 描述                             | 复位值       |
|------------------|--------|-------------|--------------------------------------------------------------|--------------------------------|-----------|
| HDMIPhyPLLConfig | 0x1820 |             | R/W                                                          | HDMI PHY 控制寄存器<br>0x1820: HDMI | 00000000h |
| HDMIPhyPLLConfig | bit    | 描述          |                                                              |                                | 初始值       |
| HDMIPLL          | 15:0   | 5:1<br>12:6 | : PLL_ENAB<br>使能脉冲<br>: PLL_IDF<<br>: PLL_NDIV<br>: PLL_ODF< | 0                              |           |
| HDMIPLLLocked    | 16     | PHY F       | LL 锁定指示                                                      | 0                              |           |
| HDMIPLLBypass    | 17     | HDMI        | PHY内PLL I                                                    | bypass 设置,高有效,仅用于调试            | 0         |

### 32.3.43 HDMI PHY PECO 寄存器

| 寄存器名                  | 偏移地址   |     | R/W       | 描述                  | 复位值       |
|-----------------------|--------|-----|-----------|---------------------|-----------|
| HDMIPhyPEC0           | 0x1840 |     | R/W       | 0x1840: HDMI        | 00000000h |
| HDMIPhyPECO           | bit    | 描过  |           |                     | 初始值       |
| TST_PE1CO_ENABLE      | 0      | Тар | 号为 1, Cha | annel 号为 0 的预加重控制使能 | 0         |
| TST_PE2CO_ENABLE      | 1      | Тар | 号为 2, Cha | annel 号为 0 的预加重控制使能 | 0         |
| TST_PE3CO_ENABLE      | 2      | Тар | 号为 3, Cha | annel 号为 0 的预加重控制使能 | 0         |
| TST_PE1CO_STR         | 7:4    | Тар | 号为 1, Cha | annel 号为 0 的系数值     | 0         |
| TST_PE2CO_STR         | 11:8   | Тар | 号为 2, Cha | annel 号为 0 的系数值     | 0         |
| TST_PE3CO_STR         | 15:12  | Тар | 号为 3, Cha | 0                   |           |
| TST_PECO_FLOAT_SEL    | 19:16  | Cha | nnel 号为 0 | 的内部扭斜对调整的可编程边沿控制    | 0         |
| TST_PEBYPASS_ENABLE_N | 31     | 低电  | 2平有效的预    | 顶加重旁路电流使能<br>       | 0         |

## **32.3.44** HDMI PHY PEC1 寄存器

| 寄存器名               | 偏移地    | 止   | R/W       | 描述                  | 复位值       |
|--------------------|--------|-----|-----------|---------------------|-----------|
| HDMIPhyPEC1        | 0x1860 |     | R/W       | 0x1860: HDMI        | 00000000h |
| HDMIPhyPEC1        | bit    | 描过  | È         |                     | 初始值       |
| TST_PE1C1_ENABLE   | 0      | Тар | 号为 1, Cha | annel 号为 1 的预加重控制使能 | 0         |
| TST_PE2C1_ENABLE   | 1      | Тар | 号为 2, Cha | annel 号为 1 的预加重控制使能 | 0         |
| TST_PE3C1_ENABLE   | 2      | Тар | 号为 3, Cha | annel 号为 1 的预加重控制使能 | 0         |
| TST_PE1C1_STR      | 7:4    | Тар | 号为 1, Cha | annel 号为 1 的系数值     | 0         |
| TST_PE2C1_STR      | 11:8   | Тар | 号为 2, Cha | 0                   |           |
| TST_PE3C1_STR      | 15:12  | Тар | 号为 3, Cha | annel 号为 1 的系数值     | 0         |
| TST_PEC1_FLOAT_SEL | 19:16  | Cha | nnel 号为 1 | 的内部扭斜对调整的可编程边沿控制    | 0         |

# **32.3.45** HDMI PHY PEC2 寄存器

| 寄存器名             | 偏移地址   | 止   | R/W      | 描述                  | 复位值       |
|------------------|--------|-----|----------|---------------------|-----------|
| HDMIPhyPEC2      | 0x1880 |     | R/W      | 0x1880: HDMI        | 00000000h |
| HDMIPhyPEC2      | bit    | 描过  | Š        |                     | 初始值       |
| TST_PE1C2_ENABLE | 0      | Тар | 号为 1, Ch | annel 号为 2 的预加重控制使能 | 0         |



| TST_PE2C2_ENABLE   | 1     | Tap 号为 2, Channel 号为 2 的预加重控制使能 | 0 |
|--------------------|-------|---------------------------------|---|
| TST_PE3C2_ENABLE   | 2     | Tap 号为 3,Channe1 号为 2 的预加重控制使能  | 0 |
| TST_PE1C2_STR      | 7:4   | Tap 号为 1,Channel 号为 2 的系数值      | 0 |
| TST_PE2C2_STR      | 11:8  | Tap 号为 2,Channel 号为 2 的系数值      | 0 |
| TST_PE3C2_STR      | 15:12 | Tap 号为 3,Channel 号为 2 的系数值      | 0 |
| TST_PEC2_FLOAT_SEL | 19:16 | Channel 号为 2 的内部扭斜对调整的可编程边沿控制   | 0 |

## **32.3.46** AVI InfoFrame 内容寄存器 0

| 寄存器名                                 | 偏移地址   | R/W    | 描述                                                        | 复位值       |
|--------------------------------------|--------|--------|-----------------------------------------------------------|-----------|
| AVI ContentO                         | 0x18e0 | R/W    | AVI InfoFrame 内容配置寄存器 0<br>0x18e0:HDMI                    | 00000800h |
| AVI ContentO                         | Bit    | 描述     |                                                           | 初始值       |
| Scan Information                     | 1:0    |        |                                                           | 0         |
| Bar Info                             | 3:2    |        |                                                           | 0         |
| Active Format<br>Information Present | 4      |        |                                                           | 0         |
| RGB or YCbCr                         | 6:5    |        |                                                           | 0         |
| Active Format Aspect<br>Ratio        | 11:8   |        |                                                           | 4' b1000  |
| Picture Aspect Ratio                 | 13:12  |        |                                                           | 0         |
| Colorimetry                          | 15:14  |        |                                                           | 0         |
| NonUniform Picture<br>Scaling        | 17:16  |        | 条目详细定义见 HDMI 1.4b, 8.2.1.<br>.iary Video information(AVI) | 0         |
| RGB Quantization Range               | 19:18  | InfoF  | •                                                         | 0         |
| Extended Colorimetry                 | 22:20  | 111101 | 1 ame                                                     | 0         |
| IT content                           | 23     |        |                                                           | 0         |
| Video Format<br>Identification Code  | 30:24  |        |                                                           | 0         |

### 32. 3. 47 AVI 内容寄存器 1

| 寄存器名                   | 偏移地址   | R/W                         | 描述                                     | 复位值       |
|------------------------|--------|-----------------------------|----------------------------------------|-----------|
| AVI Content1           | 0x1900 | R/W                         | AVI InfoFrame 内容配置寄存器 1<br>0x1900:HDMI | 00000000h |
| AVI Content1           | Bit    | 描述                          |                                        | 初始值       |
| Pixel Repetition       | 3:0    |                             |                                        | 0         |
| Content Type           | 5:4    | 相关条目详细定义见 HDMI 1.4b, 8.2.1. |                                        | 0         |
| YCC Quantization Range | 7:6    | Auxilia                     | ary Video information (AVI) InfoFrame  | 0         |

### **32.3.48** AVI InfoFrame 内容寄存器 2

| 寄存器名                                                   | 偏移地址   | R/W     | 描述                                                     | 复位值       |
|--------------------------------------------------------|--------|---------|--------------------------------------------------------|-----------|
| AVI Content2                                           | 0x1920 | R/W     | AVI InfoFrame 内容配置寄存器 2<br>0x1920:HDMI                 | 00000000h |
| AVI Content2                                           | Bit    | 描述      |                                                        | 初始值       |
| Line Number of End of<br>Top Bar(lower 8 bits)         | 7:0    |         |                                                        | 0         |
| Line Number of End of<br>Top Bar(upper 8 bits)         | 15:8   |         |                                                        | 0         |
| Line Number of Start of<br>Bottom Bar(lower 8<br>bits) | 23:16  |         | 目详细定义见 HDMI 1.4b, 8.2.1.<br>ary Video information(AVI) | 0         |
| Line Number of Start of<br>Bottom Bar(upper 8<br>bits) | 31:24  | InfoFra | ame                                                    | 0         |



## **32.3.49** AVI InfoFrame 内容寄存器 3

| 寄存器名                                                | 偏移地址   | R/W    | 描述                                                    | 复位值       |
|-----------------------------------------------------|--------|--------|-------------------------------------------------------|-----------|
| AVI Content3                                        | 0x1940 | R/W    | AVI InfoFrame 内容配置寄存器 3<br>0x1940:HDMI                | 00000000h |
| AVI Content3                                        | Bit    | 描述     |                                                       | 初始值       |
| Pixel Number of End of<br>Left Bar(lower 8 bits)    | 7:0    |        |                                                       | 0         |
| Pixel Number of End of<br>Left Bar(upper 8 bits)    | 15:8   |        |                                                       | 0         |
| Pixel Number of Start of<br>Right Bar(lower 8 bits) | 23:16  |        | :目详细定义见HDMI 1.4b,8.2.1.<br>ary Video information(AVI) | 0         |
| Pixel Number of Start of<br>Right Bar(upper 8 bits) | 31:24  | InfoFr | rame                                                  | 0         |

## **32.3.50** AVI InfoFrame 控制寄存器

| 寄存器名          | 偏移地址   | R/W     | 描述                                                 | 复位值       |
|---------------|--------|---------|----------------------------------------------------|-----------|
| AVI Control   | 0x1960 | R/W     | AVI InfoFrame 控制寄存器<br>0x1960:HDMI                 | 00000000h |
| AVI Control   | Bit    | 描述      |                                                    | 初始值       |
| AVI Enable    | 0      | AVI In: | foFrame Packet 使能                                  | 0         |
| AVI Frequency | 1      | 1: 每两   | foFrame Packet 发送频率<br>5帧一个<br>-帧一个                | 0         |
| AVI Update    | 2      |         | 新 AVI Content0 - AVI Content3 的内<br>要发送的包内,硬件自动清 0 | 0         |

## 32.3.51 Vendor Specific InfoFrame 配置寄存器

| 寄存器名                                  | 偏移地址   | R/W   | 描述                                                      | 复位值       |
|---------------------------------------|--------|-------|---------------------------------------------------------|-----------|
| VendorSpecific<br>InfoFrame Config    | 0x1980 | R/W   | HDMI Vendor Specific InfoFrame 配置<br>寄存器<br>0x1980:HDMI | 00000000h |
| Vendor Specific<br>InfoFrame Config   | Bit    | 描述    |                                                         | 初始值       |
| VSI Enable                            | 0      | Vendo | r Specific InfoFrame Packet使能                           | 0         |
| VSI Frequency                         | 1      | 1: 每  | r Specific InfoFrame Packet 发送频率<br>两帧一个<br>一帧一个        | 0         |
| VSI Update                            | 2      |       | 豆新该寄存器后续的内容至将要发送的包<br>更件自动清 0                           | 0         |
| HDMI Video Format                     | 6:4    |       |                                                         | 0         |
| HDMI Video Format Identification Code | 15:8   |       |                                                         | 0         |
| 3D Video Format<br>Structure          | 19:16  |       | 各目详细定义见 HDMI 1.4b, 8.2.3. HDMI<br>r Specific InfoFrame  | 0         |
| 3D Ext Data                           | 23:20  |       |                                                         | 0         |

## 32.3.52 场同步计数寄存器

| 寄存器名          | 偏移地址   | R/W   | 描述          | 复位值       |
|---------------|--------|-------|-------------|-----------|
| Vsync Counter | 0x1a10 | R     | Vsync 计数寄存器 | 00000000h |
| Vsync Counter | Bit    | 描述    |             | 初始值       |
| Vsync Counter | 31: 0  | Vsync | 计数          | 0         |



## **32.3.53** PLL\_PIX 配置寄存器 0

| 寄存器名               | 偏移地址   |       | R/W      | 描述                           | 复位值       |
|--------------------|--------|-------|----------|------------------------------|-----------|
| audioPIXPLLConfig0 | 0x1a20 |       | R/W      | 像素 PLL 配置寄存器<br>Ox1a20: HDMI | 00000000h |
| audioPIXPLLConfig0 | bit    | 描述    |          | 初始值                          |           |
| PLLDivOut          | 6:0    | PLL 辑 | 前出时钟 0 分 | 0                            |           |
| PLLDivLoop         | 29:21  | PLL 信 | 音频乘数     | 0                            |           |

# **32.3.54** PLL\_PIX 配置寄存器 1

| 寄存器名               | 偏移地址   |               | R/W                               | 描述                             | 复位值       |
|--------------------|--------|---------------|-----------------------------------|--------------------------------|-----------|
| audioPIXPLLConfig1 | 0x1a40 |               | R/W                               | 像素 PLL 配置寄存器 1<br>0x1a40: HDMI | 00000000h |
| audioPIXPLLConfig1 | bit    | bit 描述        |                                   |                                | 初始值       |
| PLLDivRef          | 6:0    | PLL 辑         | <b>俞</b> 入分频数                     |                                | 0         |
| PLLLocked          | 7      | 7 PLL 锁定      |                                   |                                | 0         |
| PLLOut             | 8      | 8 选择 PLL 车    |                                   | 钟 0                            | 0         |
| PLLSoftSet         | 11     | 11 使能软件       |                                   | L                              | 0         |
| PLLBypass          | 12     | PLL 内部 bypass |                                   |                                | 0         |
| PLLPd              | 13     | PLL powerdown |                                   |                                | 0         |
| PLLConfigSelect    | 14     | 1: DC         | 已置源选择:<br>C Pixel PLI<br>L3/4 配置等 | 0                              |           |

## **32.3.55** HDMI 热插拔状态寄存器

| 寄存器名                  | 偏移地址   | 止    | RO                | 描述            | 复位值       |
|-----------------------|--------|------|-------------------|---------------|-----------|
| HDMI HPSR             | 0x1ba0 |      | RO                | HDMI 热插拔状态寄存器 | 00000000h |
| HDMI HotPlugStatusReg | bit    | 描述   |                   |               | 初始值       |
| HDMI HotPlug Status   | 0      | 1: 有 | 热插拔状态<br>插入<br>插入 |               | 0         |

## 32. 3. 56 HDMI 左声道状态寄存器

| 寄存器名                    | 偏移地址   | R/W   | 描述           | 复位值       |
|-------------------------|--------|-------|--------------|-----------|
| LeftChannelStatus0      | 0x2000 | R/W   | 左声道状态寄存器 0   | 00000000h |
| Lei tollallilei Statuso | 0.2000 | IV/ W | 0x2000: HDMI | 000000001 |
| LeftChannelStatus1      | 0x2020 | R/W   | 左声道状态寄存器 1   | 00000000h |
| Ler tollamiers tatus i  | 0x2020 | IV/ W | 0x2020: HDMI | 000000011 |
| LeftChannelStatus2      | 0x2040 | R/W   | 左声道状态寄存器 2   | 00000000h |
| Lei tollallilei Statusz | 0.0040 | IV/W  | 0x2040: HDMI | 000000011 |
| LeftChannelStatus3      | 0x2060 | R/W   | 左声道状态寄存器 3   | 00000000h |
| Ler tollamiers tatus    | 0x2000 | IV/ W | 0x2060: HDMI | 000000011 |
| LeftChannelStatus4      | 0x2080 | R/W   | 左声道状态寄存器 4   | 00000000h |
| Let tollallile15 tatus4 | 0x2000 | IV/ W | 0x2080: HDMI | 000000011 |
| LeftChannelStatus5      | 0x20a0 | R/W   | 左声道状态寄存器 5   | 00000000h |
| Lei (Chaimeistatus)     | UXZUdU | IV/W  | 0x20a0: HDMI | UUUUUUUII |

## 32.3.57 HDMI 左声道用户数据寄存器

| 寄存器名           | 偏移地址   | R/W | 描述           | 复位值       |
|----------------|--------|-----|--------------|-----------|
| LeftUserData0  | 0x20c0 | R/W | 左声道用户数据寄存器 0 | 00000000h |
| Lei teserbatao |        |     | 0x20c0: HDMI |           |
|                |        |     | 左声道用户数据寄存器1  |           |
| LeftUserDatal  | 0x20e0 | R/W | 0x20e0: HDMI | 00000000h |
|                |        |     |              |           |



| LeftUserData2 | 0x2100 | R/W | 左声道用户数据寄存器 2<br>0x2100: HDMI | 00000000h |
|---------------|--------|-----|------------------------------|-----------|
| LeftUserData3 | 0x2120 | R/W | 左声道用户数据寄存器 3<br>0x2120: HDMI | 00000000h |
| LeftUserData4 | 0x2140 | R/W | 左声道用户数据寄存器 4<br>0x2140: HDMI | 00000000h |
| LeftUserData5 | 0x2160 | R/W | 左声道用户数据寄存器 5<br>0x2160: HDMI | 00000000h |

## 32.3.58 HDMI 右声道状态寄存器

| 寄存器名               | 偏移地址   | R/W   | 描述           | 复位值        |
|--------------------|--------|-------|--------------|------------|
| RightChannelStatus | 0x2180 | R/W   | 右声道状态寄存器 0   | 00000000h  |
| 0                  | 0.000  | IV/ W | 0x2000: HDMI | 000000001  |
| RightChannelStatus | 0x21a0 | R/W   | 右声道状态寄存器 1   | 00000000h  |
| 1                  | 0x21a0 | K/W   | 0x2020: HDMI | 0000000011 |
| RightChannelStatus | 0x21c0 | R/W   | 右声道状态寄存器 2   | 00000000h  |
| 2                  | 0x2100 | K/W   | 0x2040: HDMI |            |
| RightChannelStatus | 0x21e0 | R/W   | 右声道状态寄存器3    | 00000000h  |
| 3                  | 0x21e0 | K/W   | 0x2060: HDMI | 0000000011 |
| RightChannelStatus | 0x2200 | R/W   | 右声道状态寄存器 4   | 00000000h  |
| 4                  | 0x2200 | K/W   | 0x2080: HDMI | 0000000011 |
| RightChannelStatus | 0x2220 | R/W   | 右声道状态寄存器 5   | 00000000h  |
| 5                  | UXZZZU | IX/ W | 0x20a0: HDMI |            |

# 32.3.59 HDMI 右声道用户数据寄存器

| 寄存器名           | 偏移地址   | R/W | 描述                           | 复位值       |
|----------------|--------|-----|------------------------------|-----------|
| RightUserData0 | 0x2240 | R/W | 右声道用户数据寄存器 0<br>0x2240: HDMI | 00000000h |
| RightUserData1 | 0x2260 | R/W | 右声道用户数据寄存器 1<br>0x2260: HDMI | 00000000h |
| RightUserData2 | 0x2280 | R/W | 右声道用户数据寄存器 2<br>0x2280: HDMI | 00000000h |
| RightUserData3 | 0x22a0 | R/W | 右声道用户数据寄存器 3<br>0x22a0: HDMI | 00000000h |
| RightUserData4 | 0x22c0 | R/W | 右声道用户数据寄存器 4<br>0x22c0: HDMI | 00000000h |
| RightUserData5 | 0x22e0 | R/W | 右声道用户数据寄存器 5<br>0x22e0: HDMI | 00000000h |

## 32.3.60 中断寄存器

| 寄存器名           | 偏移地址   | 偏移地址               |        | 描述          | 复位值       |
|----------------|--------|--------------------|--------|-------------|-----------|
| Interrupt      | 0x1570 |                    | R/W    | 中断寄存器       | 00000000h |
| Interrupt      | bit    | 描述                 |        |             | 初始值       |
| Display1_Vsync | 0      | 1 号』               | 显示单元产生 | 0           |           |
| Dispaly1_Hsync | 1      | 1 号』               | 显示单元产生 | 0           |           |
| DisplayO_Vsync | 2      | 0 号토               | 显示单元产生 | 0           |           |
| DisplayO_Hysnc | 3      | 0 号토               | 显示单元产生 | 0           |           |
| CursorReadEnd  | 4      | 光标数                | 数据读取结页 | 0           |           |
| FB1ReadEnd     | 5      | 1 号』               | 显示单元帧级 | 0           |           |
| FB0ReadEnd     | 6      | 0号显示单元帧缓冲读取结束;写1清0 |        |             | 0         |
| DB1Underflow   | 7      | 1 号显               | 显示单元数据 | 居缓冲区下溢;写1清0 | 0         |





| DB0Underflow  | 8     | 0号显示单元数据缓冲区下溢;写1清0   | 0 |
|---------------|-------|----------------------|---|
|               | _     |                      | - |
| DB1FUnderflow | 9     | 1号显示单元数据缓冲区致命下溢;写1清0 | 0 |
| DB0FUnderflow | 10    | 0号显示单元数据缓冲区致命下溢;写1清0 | 0 |
| i2c_int       | 12:11 | I2C 中断; 写 1 清 0      | 0 |
| HDMI_hotplug  | 13    | HDMI 热插拔; 写 1 清 0    | 0 |
| -             | 14    | 保留                   | 0 |
| _             | 15    | 保留                   | 0 |
| En0           | 16    | 第0位中断使能;写1使能,写0屏蔽    | 0 |
| En1           | 17    | 第1位中断使能;写1使能,写0屏蔽    | 0 |
| En2           | 18    | 第2位中断使能;写1使能,写0屏蔽    | 0 |
| En3           | 19    | 第3位中断使能;写1使能,写0屏蔽    | 0 |
| En4           | 20    | 第4位中断使能;写1使能,写0屏蔽    | 0 |
| En5           | 21    | 第5位中断使能;写1使能,写0屏蔽    | 0 |
| En6           | 22    | 第6位中断使能;写1使能,写0屏蔽    | 0 |
| En7           | 23    | 第7位中断使能;写1使能,写0屏蔽    | 0 |
| En8           | 24    | 第8位中断使能;写1使能,写0屏蔽    | 0 |
| En9           | 25    | 第9位中断使能;写1使能,写0屏蔽    | 0 |
| En10          | 26    | 第10位中断使能;写1使能,写0屏蔽   | 0 |
| En11          | 27    | 第11位中断使能;写1使能,写0屏蔽   | 0 |
| En12          | 28    | 第12位中断使能;写1使能,写0屏蔽   | 0 |
| En13          | 29    | 第13位中断使能;写1使能,写0屏蔽   | 0 |
| En14          | 30    | 第14位中断使能;写1使能,写0屏蔽   | 0 |
| En15          | 31    | 第15位中断使能;写1使能,写0屏蔽   | 0 |



# 33 HDA 控制器 (D7:F0)

HDA 控制器兼容 High Definition Audio Specification Revision 1.0a。 HDA 相关的引脚设置寄存器见 4.6 节。

## 33.1 HDA 配置寄存器 (D7:F0)

表 33- 1HDA 控制器的配置寄存器

| 地址偏移    | 简称      | 描述                                     | 默认值                | 访问类型    |
|---------|---------|----------------------------------------|--------------------|---------|
| 00h-01h | VID     | Vendor ID                              | 0014h              | RO      |
| 02h-03h | DID     | Device ID                              | 7A07h              | RO      |
| 04h-05h | PCICMD  | PCI Command                            | 0000h              | R/W, RO |
| 08h     | RID     | Revision ID                            | 00h                | RO      |
| 09h     | PI      | Programming Interface                  | 00h                | RO      |
| OAh     | SCC     | Sub Class Code                         | 03h                | RO      |
| 0Bh     | BCC     | Base Class Code                        | 04h                | RO      |
| 0Ch     | CLS     | Cache Line Size                        | 10h                | RO      |
| 0Eh     | HEADTYP | Header Type                            | 00h                | RO      |
| 10h-17h | CNL_BAR | Control Block Base Address<br>Register | 00000000000000004h | R/W, RO |
| 2Ch-2Dh | SVID    | Subsystem Vendor ID                    | 0000h              | RO      |
| 2Eh-2Fh | SID     | Subsystem Identification               | 0000h              | RO      |
| 3Ch     | INT_LN  | Interrupt Line                         | FFh                | R/W     |
| 3Dh     | INT_PN  | Interrupt Pin                          | 00h                | RO      |

### 注:

- 1. HDA 配置头只在相关引脚配置为 HDA 模式下可见。
- 2. 表中未列出的地址空间表示保留。

下面列出与 PCI 配置头规范稍有不同的寄存器及其描述。

### PCICMD-PCI 命令寄存器 (HDA-D7:F0)

地址偏移: 04-05h 属性: R/W, RO 默认值: 0000h 大小: 16 位

| 位域   | 名称                     | 访问  | 描述                                                                                          |  |  |
|------|------------------------|-----|---------------------------------------------------------------------------------------------|--|--|
| 15:2 | Reserved               | RO  | 保留                                                                                          |  |  |
| 1    | Memory Space<br>Enable | R/W | 该位用来控制是否使能对 HDA 控制寄存器的访问。<br>0:禁止访问;<br>1:使能对 HDA 控制寄存器的访问。在将该位配置为 1 之前,必须先配置 PCNL BAR 寄存器。 |  |  |
| 0    | Reserved               | RO  | 保留                                                                                          |  |  |

# 33.2 HDA 控制寄存器描述

HDA 控制寄存器的设计完全按照 HD audio Rev 1.0 规范进行设计的,下表列举了主要的寄存器的参数信息,具体的参考 HD audio Rev 1.0 手册,下表仅列举了与虚拟声卡相关的寄存器参数信息。



### ELD 0 MEM 寄存器 (虚拟声卡 0)

地址偏移: 0x2200-0x2253 属性: R/W, R0 默认值: 0 大小: 84 字节

| 位域  | 名称  | 访问  | 描述             |
|-----|-----|-----|----------------|
| XXX | XXX | XXX | 详见 HDA1. 0a 协议 |

### ELDO MEM 有效寄存器 (虚拟声卡 0)

| 位域  | 名称             | 访问  | 描述                                                                  |
|-----|----------------|-----|---------------------------------------------------------------------|
| 7:1 | Reserved       | RO  | 保留                                                                  |
| 0   | ELDO Mem Valid | R/W | 该位用来控制 ELDO MEM 寄存器中的内容是否有效<br>0: ELDO Mem 内容无效<br>1: ELDO Mem 内容有效 |

### ELD1 MEM 寄存器(虚拟声卡1)

地址偏移: 0x2300-0x2353 属性: R/W, R0 默认值: 0 大小: 84 字节

| 位域  | 名称  | 访问  | 描述             |
|-----|-----|-----|----------------|
| XXX | XXX | XXX | 详见 HDA1. 0a 协议 |

### ELD1 MEM 有效寄存器 (虚拟声卡1)

| 位域  | 名称             | 访问  | 描述                                                                  |
|-----|----------------|-----|---------------------------------------------------------------------|
| 7:1 | Reserved       | RO  | 保留                                                                  |
| 0   | ELD1 Mem Valid | R/W | 该位用来控制 ELD1 MEM 寄存器中的内容是否有效<br>0: ELD1 Mem 内容无效<br>1: ELD1 Mem 内容有效 |

### Codec Unsupported Response 内容寄存器

地址偏移: 0x2400-0x2403 属性: R/W, R0 默认值: 0x000000000 大小: 32 位

| 位域   | 名称                         | 访问  | 描述                 |
|------|----------------------------|-----|--------------------|
| 31:0 | Codec Unsupported Response | R/W | 虚拟声卡不支持的命令所返回的响应内容 |

### Codec Unsupported Response 有效寄存器

地址偏移: 0x 2404-0x2404 属性: R/W, R0 默认值: 0 大小: 8 位

| 位域  | 名称                                  | 访问  | 描述                                                     |
|-----|-------------------------------------|-----|--------------------------------------------------------|
| 7:1 | Reserved                            | RO  | 保留                                                     |
| 0   | Codec Unsupported<br>Response Valid | R/W | 该位用来控制虚拟声卡对于不支持的命令所返回的响应<br>内容是否有效<br>0: Response 内容无效 |



|  | 1 Pagnanga 山家方海  |
|--|------------------|
|  | 1: Response 内容有效 |

## Codec IID 初始值寄存器

地址偏移: 0x2408 -0x23b 属性: R/W 默认值: 0 大小: 32 位

| 位域   | 名称                   | 访问  | 描述                           |
|------|----------------------|-----|------------------------------|
| 31:0 | Codec IID Init Value | R/W | 虚拟声卡 IID 寄存器的初始值,由 BIOS 进行设置 |



# 34 I2S 控制器 (D7:F1)

## 34.1 概述

龙芯 2K2000 中 I2S 控制器,数据宽度是 32 位,支持 DMA 传输,支持多家公司的 codec 芯片。I2S 控制器支持主或从模式。主模式时由 I2S 控制器产生位时钟信号、左右声道选择时钟信号和数据信号,从模式时 I2S 控制器接收位时钟信号、左右声道选择时钟信号和数据信号。主模式时,codec 系统时钟由控制器提供,从模式时,系统时钟可由控制器或晶振提供。I2S 的功能特性包括:

- 1. 支持8、16、18、20、24、32位的音频数据采样位宽。
- 2. 支持8、16、32位的左右声道处理字宽。
- 3. 包含两个缓存 FIFO, FIFO 的缓存容量为 8bytes。
- 4. I2S 的中断处理模式可配,在 I2S 的发送和接收中断功能都使能后,当两个通道的缓存 fifo 为满仍要写以及为空仍要读时,则向 CPU 发出中断信号。
- 5. I2S 可以为 codec 芯片提供系统时钟,时钟频率可配。

## 34.2 I2S 配置寄存器

地址偏移 简称 描述 默认值 访问类型 Vendor ID 00h-01h VID 0014h RO 02h-03h DID Device ID 7A27h RO 04h-05h PCICMD PCI Command 0000h R/W, RO 08h RID Revision ID 00h RO 09h PΙ Programming Interface 00h RO 0Ah SCC Sub Class Code 01h RO BCC 0Bh Base Class Code 04h RO 0Ch CLS Cache Line Size 10h RO 0Eh HEADTYP Header Type 00h RO Control Block Base Address 10h-17h CNL\_BAR 00000000000000004h R/W, RO Register 2Ch-2Dh SVID Subsystem Vendor ID 0000h RO SID 2Eh-2FhSubsystem Identification 0000h RO 3Ch INT LN Interrupt Line FFh R/W 3DhINT\_PN Interrupt Pin 00h RO

表 34- 1I2S 控制器的配置寄存器

#### 注:

- 1. I2S 配置头只在 hda i2s sel 配置为 0 时可见。
- 2. 表中未列出的地址空间表示保留。

下面列出与 PCI 配置头规范稍有不同的寄存器及其描述。



## 34.3 PCICMD-PCI 命令寄存器

地址偏移: 04-05h 属性: R/W, RO 默认值: 0000h 大小: 16 位

| 位域   | 名称                     | 访问  | 描述                                                                                          |  |  |  |
|------|------------------------|-----|---------------------------------------------------------------------------------------------|--|--|--|
| 15:2 | Reserved               | RO  | 保留                                                                                          |  |  |  |
| 1    | Memory Space<br>Enable | R/W | 该位用来控制是否使能对 I2S 控制寄存器的访问。<br>0:禁止访问;<br>1:使能对 I2S 控制寄存器的访问。在将该位配置为 1 之前,必须先配置 PCNL_BAR 寄存器。 |  |  |  |
| 0    | Reserved               | RO  | 保留                                                                                          |  |  |  |

## 34.4 I2S 控制器寄存器

I2S 包含 5 个寄存器, 定义如下表所示。

寄存器名称 偏移地址 读/写(R/W) 功能描述 复位值 32' h0 IIS Version0x0000R/W I2S 标识寄存器 R/W 32' h0 IISConfig 0x0004 I2S 配置寄存器 IISControl 0x0008 R/WI2S 控制寄存器 32' h0 R/W I2S 接收数据寄存器 (用于 DMA 接收数据) 32' h0 IISRxData 0x000c I2S 发送数据寄存器 (用于 DMA 发送数据) R/W 32' h0  ${\tt IISTxData}$ 0x0010 IISConfig1 0xd014 R/W I2S 配置寄存器 1 32' h0

表 34-2 寄存器定义

I2S 标识寄存器允许主控机读取接收器的相关工作信息。它标识了 IIS 的地址位宽,数据位宽以及版本号等信息。

| 寄存器名称      | 偏移地址 | 读/写(R/W) | 功能描述          |
|------------|------|----------|---------------|
| IISVersion | 位    | 缺省值      | 描述            |
|            |      |          | 地址总线宽度:       |
|            |      |          | 00: 地址宽度 8 位  |
| ADRW       | 9:8  | 2' h0    | 01: 地址宽度 16 位 |
|            |      |          | 10: 地址宽度 32 位 |
|            |      |          | 11: 地址宽度 64 位 |
|            |      |          | 数据宽度:         |
|            |      |          | 00: 地址宽度 8 位  |
| DATW       | 5:4  | 2' h0    | 01: 地址宽度 16 位 |
|            |      |          | 10: 地址宽度 32 位 |
|            |      |          | 11: 地址宽度 64 位 |
| VER        | 3:0  | 4' h0    | I2S 版本号       |

表 34-3 标识寄存器

配置寄存器 0 是配置 I2S 的声道字长,发送和接收音频数据的采样深度以及位时钟的分频系数。

表 34-4 配置寄存器 0

| 寄存器名称        | 偏移地址  | 读/写(R/W) | 功能描述       |
|--------------|-------|----------|------------|
| IISConfig0   | 位     | 缺省值      | 描述         |
| LR_LEN       | 31:24 | 'h0      | 左右声道处理的字长。 |
| TX_RES_DEPTH | 23:16 | 'h0      | TX 采样深度设置: |



|              |      |     | IIS 采样数据长度,有效范围为 8-32, 如果发送的数据 宽度小于采样数据长度,则低位补 0; 如果发送的数据 宽度大于采样数据长度,则低位忽略。             |
|--------------|------|-----|-----------------------------------------------------------------------------------------|
| BCLK_RATIO   | 15:8 | 'h0 | 位时钟(BCLK)分频系数:<br>位时钟分频系数,分频数为 MCLK 时钟频率除以<br>2x(RATIO+1)                               |
| RX_RES_DEPTH | 7:0  | 'h0 | RX 采样深度设置:<br>IIS 采样数据长度,有效范围为 8-32,如果接收到的数据宽度小于采样数据长度,则低位补 0;如果接收到的数据宽度大于采样数据长度,则低位忽略。 |

控制寄存器用于配置 IIS 的工作使能信号,缓存 FIFO 的存储状态以及中断相关信息状态。

表 34- 5 控制寄存器

| 寄存器名称         | 偏移地址  | 读/写(R/W) | 功能描述                      |
|---------------|-------|----------|---------------------------|
| IISControl    | 位     | 缺省值      | 描述                        |
|               |       |          | 系统时钟(MCLK)输出稳定标志,为1时时钟稳定输 |
| MCLK_READY 16 |       | R        | 出,为0时输出时钟不可用              |
| MASTER        | 15    | 'h0      | 1: IIS 工作于主模式             |
| MASTER        | 10    | 110      | 0: IIS 工作于从模式             |
| MSB/LSB       | 14    | 'h0      | 1: 高位在左端 0: 高位在右端         |
| RX_EN         | 13    | 'h0      | 控制器接收使能,为1时有效,开始接收数据      |
| TX_EN         | 12    | 'h0      | 控制器发送使能,为1时有效,开始发送数据      |
| RX_DMA_EN     | 11    | 'h0      | DMA 接收使能,为1时有效            |
| Reserved      | 10: 9 | 'h0      |                           |
| CLK READY     | 8     | R        | 位时钟和声道选择时钟输出稳定标志,为1时时钟稳定  |
| CLK_KEADI     | 0     | N.       | 输出,为0时输出时钟不可用             |
| TX_DMA_EN     | 7     | 'h0      | DMA 发送使能,为1时有效            |
| Reserved      | 6:5   | 'h0      |                           |
| RESETn        | 4     | 'h0      | IIS 控制器软复位                |
| MCLK_EN       | 3     | 'h0      | 使能时钟输出                    |
| RX_INT_EN     | 1     | 'h0      | RX 中断使能,为1时使能中断,为0时禁止     |
| TX_INT_EN     | 0     | 'h0      | TX 中断使能,为1时使能中断,为0时禁止     |

配置寄存器 1 是配置系统时钟(MCLK)的分频系数。

表 34-5 配置寄存器 1

| 寄存器名称          | 偏移地址  | 读/写(R/W) | 功能描述                                                                    |
|----------------|-------|----------|-------------------------------------------------------------------------|
| IISConfig1     | 位     | 缺省值      | 描述                                                                      |
| MCLK_RATIO     | 15:0  | 'h0      | 系统时钟(MCLK)分频系数整数部分:<br>分频数为总线时钟频率除以系统时钟向下取整的值,<br>系统时钟作为 Codec 的 sysclk |
| MCLK_RATIO_FRA | 32:16 | 'h0      | 系统时钟(MCLK)分频系数小数部分:<br>分频数为总线时钟频率除以系统时钟得小数部分乘<br>以2 <sup>1</sup> 6      |

# 34.5 DMA 命令寄存器

该寄存器用来控制 I2S 内部的 DMA 控制器  $(共 2 \uparrow)$ ,其中 DMA0 用于放音,DMA1 用于录音。 DMA 控制器的详细描述见下节。

偏移量: 0x100/0x110 (DMA0/DMA1)

复位值: 00000000h



| 位域   | 名称        | 访问  | 描述                                       |
|------|-----------|-----|------------------------------------------|
| 63:5 | ask_addr  | R/W | DMA 描述符地址的 bit[63:5], 低 5 位为 0           |
| 5    | Reserved  | R/W | 保留                                       |
| 4    | dma_stop  | R/W | 停止 DMA 操作。DMA 控制器完成当前数据读写后停止。            |
| 3    | dma_start | R/W | 开始 DMA 操作。DMA 控制器读取描述符地址(ask_addr)后将些位清零 |
| 2    | ask_valid | R/W | DMA 工作寄存器写回到(ask_addr)所指向的内存,完成后清零。      |
| 1    | Reserved  | R/W | 保留                                       |
| 0    | dma_64bit | R/W | DMA 控制器 64 位地址支持                         |

## 34.6 配置操作

I2S 正常工作,需要先配置好 CODEC 芯片,然后配置 I2S 控制器的的配置寄存器和控制寄存器。

2K2000 芯片通过 I2S 接口和 CODEC 芯片通信,CODEC 芯片作为 I2S 总线上的从设备,详细地址、寄存器和配置方法请参考具体 CODEC 芯片的数据手册。配置完 CODEC 之后,需要对 I2S 控制器进行配置。可以将一些配置信息写入标志寄存器 (I2SVersion),以供查询。先配置好 I2SConfig0 和 I2SConfig1 寄存器,再配置 I2SControl 寄存器。

I2SConfig 寄存器建议 LR\_LEN 和 RES\_DEPTH 配成一样,不至于在传输过程中丢数据或者空数据。MCLK 时钟是从内部时钟 I2S\_CLOCK 分频得到,根据配置 CODEC 的采样频率、采样深度和倍频系数来计算,计算公式如下:

MCLK=256xfs(或者 512xfs)或者(768xfs);(详细见 CODEC 手册推荐配置)

 $MCLK_RATIO = [Freq_I2S / (256xfs)];$ 

MCLK RATIO FRAC = (Freq I2S / (256xfs) - [Freq I2S / (256xfs)]) x 2<sup>16</sup>;

BCLK 时钟根据配置 CODEC 的采样深度来计算, 计算公式如下:

BCLK = MASTER RES DEPTH x 2 xfs;

BCLK RATIO= Freq MCLK / (RES DEPTH x 2 x fs) /2 - 1;

其中 fs 为配置的采样频率(即音频文件的码率)。。

- 1. I2S 控制器配置流程如下: 先配置 I2SConfig0、I2SConfig1 寄存器、MSB/LSB 寄存器:
- 2. 如果是主模式或从模式采用控制器 MCLK 时,使能 MCLK\_EN 寄存器,等待 MCLK\_READY 为1进行下一步,否则跳过该步骤;
- 3. 如果是主模式,配置 MASTER 为 1,等待 CLK\_READY 为 1 进行下一步,否则跳过该步骤;

先配置 DMA, DMA 复用的配置方法见第 5.4 节, 然后配置 CODEC 芯片, 使能 I2SControl 相关寄存器。



## 34.7 DMA 控制器

### 34.7.1 DMA 控制器结构描述

芯片中包含 2 个 DMA 控制器,用来实现内存与 I2S 之间数据搬移,可以节省资源提高系统数据传输的效率。

DMA 的传送数据的过程由三个阶段组成:

- 1. 传送前的预处理:由 CPU 配置 DMA 描述符相关的寄存器。
- 2. 数据传送: 在 DMA 控制器的控制下自动完成。
- 3. 传送结束处理:发送中断请求。

本 DMA 控制器限定为以字(4Byte)为单位的数据搬运。

DMA 控制器支持 64 位地址空间,这主要通过 dma\_64bit 来控制,当该位设置为 1 时表示 DMA 控制器工作在 64 位地址空间,反之为 32 位地址空间。在 64 位地址模式下,需要扩展 DMA\_ORDER\_ADDR 和 DMA\_SADDR 为 64 位寄存器。

#### **34.7.2** DMA 描述符

### DMA ORDER ADDR LOW

偏移地址: 0x0 复位值: 0x000000000

| 位域   | 位域名称           | 位宽 | 访问  | 描述                      |
|------|----------------|----|-----|-------------------------|
| 31:1 | dma_order_addr | 31 | R/W | 存储器内部下一描述符地址寄存器(低 32 位) |
| 0    | Dma_order_en   | 1  | R/W | 描述符是否有效信号               |

说明:存储下一个DMA 描述符的地址,dma\_order\_en 是下个DMA 描述符的使能位,如果该位为1表示下个描述符有效,该位为0表示下个描述符无效,不执行操作,地址16字节对齐。在配置DMA 描述符时,该寄存器存放的是下个描述符的地址,执行完该次DMA 操作后,通过判断 dma\_order\_en 信号确定是否开始下次DMA 操作。在64位地址模式下,该寄存器存储低32位地址。

#### DMA SADDR

偏移地址: 0x4

复位值: 0x00000000

| 位域   | 位域名称      | 位宽 | 访问  | 描述                    |
|------|-----------|----|-----|-----------------------|
| 31:0 | dma_saddr | 32 | R/W | DMA 操作的系统内存地址(低 32 位) |

说明: DMA 操作分为: 内存读: 从内存中读数据,保存在 DMA 控制器的缓存中,然后写入 I2S 设备,该寄存器指定了读内存的地址;内存写: 从 I2S 设备读数据保存在 DMA 缓存中,



当 DMA 缓存中的数据超过一定数目,就往内存中写,该寄存器指定了写内存的地址。在 64 位地址模式下,该寄存器存储低 32 位地址。

### DMA DADDR

偏移地址: 0x8

复位值: 0x00000000

| 位域   | 位域名称      | 位宽 | 访问  | 描述               |
|------|-----------|----|-----|------------------|
| 27:0 | dma_daddr | 28 | R/W | DMA 操作的 I2S 设备地址 |

### DMA\_LENGTH

偏移地址: 0xc

复位值: 0x00000000

| 位域   | 位域名称       | 位宽 | 访问  | 描述        |
|------|------------|----|-----|-----------|
| 31:0 | dma_length | 32 | R/W | 传输数据长度寄存器 |

说明:代表一块被搬运内容的长度,单位是字。当搬运完 length 长度的字之后,开始下个 step 即下一个循环。开始新的循环,则再次搬运 length 长度的数据。当 step 变为 1,单个 DMA 描述符操作结束,开始读下个描述符。

### DMA STEP LENGTH

偏移地址: 0x10

复位值: 0x00000000

| 位域   | 位域名称            | 位宽 | 访问  | 描述          |
|------|-----------------|----|-----|-------------|
| 31:0 | dma step length | 32 | R/W | 数据传输间隔长度寄存器 |

说明: 间隔长度说明两块被搬运内存数据块之间的长度,前一个 step 的结束地址与后一个 step 的开始地址之间的间隔。

#### DMA STEP TIMES

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

 位域
 位域名称
 位宽
 访问
 描述

 31:0
 dma\_step\_times
 32
 R/W
 数据传输循环次数寄存器

说明:循环次数说明在一次 DMA 操作中需要搬运的块的数目。如果只想搬运一个连续的数据块,循环次数寄存器的值可以赋值为 1。

#### DMA CMD

偏移地址: 0x18

复位值: 0x00000000

| 位域    | 位域名称    | 位宽 | 访问  | 描述                                        |
|-------|---------|----|-----|-------------------------------------------|
| 14:13 | Dma_cmd | 2  | R/W | 源、目的地址生成方式                                |
| 12    | dma_r_w | 1  | R/W | DMA 操作类型,"1"为读 ddr2 写设备,"0"<br>为读设备写 ddr2 |



| 11:8 | dma_write_state       | 4 | R/W | DMA 写数据状态          |
|------|-----------------------|---|-----|--------------------|
| 7:4  | dma_read_state        | 4 | R/W | DMA 读数据状态          |
| 3    | dma_trans_over        | 1 | R/W | DMA 执行完被配置的所有描述符操作 |
| 2    | dma_single_trans_over | 1 | R/W | DMA 执行完一次描述符操作     |
| 1    | dma_int               | 1 | R/W | DMA 中断信号           |
| 0    | dma_int_mask          | 1 | R/W | DMA 中断是否被屏蔽掉       |

说明: dma\_single\_trans\_over=1 指一次 DMA 操作执行结束,此时 length=0 且 step\_times=1,开始取下个 DMA 操作的描述符。下个 DMA 操作的描述符地址保存在 DMA\_ORDER\_ADDR 寄存器中,如果 DMA\_ORDER\_ADDR 寄存器中 dma\_order\_en=0,则 dma\_trans\_over=1,整个 dma 操作结束,没有新的描述符要读;如果 dma\_order\_en=1,则 dma\_trans\_over 置为 0,开始读下个 dma 描述符。dma\_int 为 DMA 的中断,如果没有中断屏蔽,在一次配置的 DMA 操作结束后发生中断。CPU 处理完中断后可以直接将其置低,也可以等到 DMA 进行下次传输时自动置低。 dma\_int\_mask 为对应 dma\_int 的中断屏蔽。 dma\_read\_state 说明了 DMA 当前的读状态。 dma\_write\_state 说明了 DMA 当前的写状态。

DMA 写状态(WRITE\_STATE[3:0])描述, DMA 包括以下几个写状态:

| Write_state    | [3:0] | 描述                                                              |
|----------------|-------|-----------------------------------------------------------------|
| Write_idle     | 4' h0 | 写状态正处于空闲状态                                                      |
| W_ddr_wait     | 4' h1 | Dma 判断需要执行读设备写内存操作,并发起写内存请求,但是内存还<br>没准备好响应请求,因此 dma 一直在等待内存的响应 |
| Write_ddr      | 4' h2 | 内存接收了 dma 写请求,但是还没有执行完写操作                                       |
| Write_ddr_end  | 4' h3 | 内存接收了 dma 写请求,并完成写操作,此时 dma 处于写内存操作完成<br>状态                     |
| Write_dma_wait | 4' h4 | Dma 发出将 dma 状态寄存器写回内存的请求,等待内存接收请求                               |
| Write_dma      | 4' h5 | 内存接收写 dma 状态请求,但是操作还未完成                                         |
| Write_dma_end  | 4' h6 | 内存完成写 dma 状态操作                                                  |
| Write_step_end | 4' h7 | Dma 完成一次 length 长度的操作(也就是说完成一个 step)                            |

### DMA 读状态(READ\_STATE[3:0])描述,DMA 包括以下几个读状态:

| Read_state       | [3:0] | 描述                                         |
|------------------|-------|--------------------------------------------|
| Read_idle        | 4' h0 | 读状态正处于空闲状态                                 |
| Read_ready       | 4' h1 | 接收到开始 dma 操作的 start 信号后,进入准备好状态,开始读描述<br>符 |
| Get_order        | 4' h2 | 向内存发出读描述符请求,等待内存应答                         |
| Read_order       | 4' h3 | 内存接收读描述符请求,正在执行读操作                         |
| Finish_order_end | 4' h4 | 内存读完 dma 描述符                               |
| R_ddr_wait       | 4' h5 | Dma 向内存发出读数据请求,等待内存应答                      |
| Read_ddr         | 4' h6 | 内存接收 dma 读数据请求,正在执行读数据操作                   |
| Read_ddr_end     | 4' h7 | 内存完成 dma 的一次读数据请求                          |
| Read_dev         | 4' h8 | Dma 进入读设备状态                                |



| Read_dev_end  | 4' h9 | 设备返回读数据,结束此次读设备请求            |
|---------------|-------|------------------------------|
| Read_step_end | 4' ha | 结束一次 step 操作, step times 减 1 |

## $DMA\_ORDER\_ADDR\_HIGH$

偏移地址: 0x20 复位值: 0x00000000

| 位域   | 位域名称           | 位宽 | 访问  | 描述                       |
|------|----------------|----|-----|--------------------------|
| 31:0 | dma_order_addr | 32 | R/W | 存储器内部下一个描述符地址寄存器(高 32 位) |

### DMA\_SADDR\_HIGH

偏移地址: 0x24 复位值: 0x000000000

| 位域   | 位域名称      | 位宽 | 访问  | 描述                  |
|------|-----------|----|-----|---------------------|
| 31:0 | dma_saddr | 32 | R/W | DMA 操作的内存地址(高 32 位) |



# 35 SATA 控制器 (D8:F0)

SATA 的特性包括:

- 支持SATA 1代1.5Gbps、SATA2代3Gbps和SATA3代6Gbps的传输
- 兼容串行ATA 3.3规范和AHCI 1.3.1规范

## 35.1 SATA 配置寄存器

表 35-1 SATA 控制器的配置寄存器

| 地址偏移    | 简称      | 描述                       | 默认值       | 访问类型    |
|---------|---------|--------------------------|-----------|---------|
| 00h-01h | VID     | Vendor ID                | 0014h     | RO      |
| 02h-03h | DID     | Device ID                | 7A18h     | RO      |
| 04h-05h | PCICMD  | PCI Command              | 0000h     | R/W, RO |
| 08h     | RID     | Revision ID              | 00h       | RO      |
| 09h     | PI      | Programming Interface    | 01h       | RO      |
| OAh     | SCC     | Sub Class Code           | 06h       | RO      |
| 0Bh     | BCC     | Base Class Code          | 01h       | RO      |
| 0Ch     | CLS     | Cache Line Size          | 10h       | RO      |
| 0Eh     | HEADTYP | Header Type              | 00h       | RO      |
| 24h-27h | ABAR    | AHCI Base Address        | 00000000h | R/W, RO |
| 2Ch-2Dh | SVID    | Subsystem Vendor ID      | 0000h     | RO      |
| 2Eh-2Fh | SID     | Subsystem Identification | 0000h     | RO      |
| 3Ch     | INT_LN  | Interrupt Line           | FFh       | R/W     |
| 3Dh     | INT_PN  | Interrupt Pin            | 00h       | RO      |

注: 表中未列出的地址空间表示保留。

下面列出与 PCI 配置头规范稍有不同的寄存器及其描述。

### PCICMD-PCI 命令寄存器 (SATA-D8:F0)

地址偏移: 04-05h 属性: R/W, RO 默认值: 0000h 大小: 16 位

| 位域       | 名称                     | 访问  | 描述                                                                                            |
|----------|------------------------|-----|-----------------------------------------------------------------------------------------------|
| 15:<br>2 | Reserved               | RO  | 保留                                                                                            |
| 1        | Memory Space<br>Enable | R/W | 该位用来控制是否使能对 SATA 控制寄存器的访问。<br>0:禁止访问;<br>1:使能对 SATA 控制寄存器的访问。在将该位配置为 1 之前,必须先配置 PCNL_BAR 寄存器。 |
| 0        | Reserved               | RO  | 保留                                                                                            |

# 35.2 SATA 控制器内部寄存器描述

SATA 的基地址是由 SATA 的 BARO 给定,寄存器的定义和协议标准定义完全一致。

| 偏移地址  | 位宽 | 名称  | 描述           |
|-------|----|-----|--------------|
| 0x000 | 32 | CAP | HBA 特性寄存器    |
| 0x004 | 32 | GHC | 全局 HBA 控制寄存器 |



| 0x008 | 32 | IS        | 中断状态寄存器        |
|-------|----|-----------|----------------|
| 0х00с | 32 | PI        | 端口寄存器          |
| 0x010 | 32 | VS        | AHCI 版本寄存器     |
| 0x014 | 32 | CCC_CTL   | 命令完成合并控制寄存器    |
| 0x018 | 32 | CCC_PORTS | 命令完成合并端口寄存器    |
| 0x024 | 32 | CAP2      | HBA 特性扩展寄存器    |
| 0x0A0 | 32 | BISTAFR   | BIST 激活 FIS    |
| 0x0A4 | 32 | BISTCR    | BIST 控制寄存器     |
| 0x0A8 | 32 | BISTCTR   | BIST FIS 计数寄存器 |
| 0x0AC | 32 | BISTSR    | BIST 状态寄存器     |
| 0x0B0 | 32 | BISTDECR  | BIST 双字错计数寄存器  |
| 0x0BC | 32 | OOBR      | 00B 寄存器        |
| 0x0E0 | 32 | TIMER1MS  | 1ms 计数寄存器      |
| 0x0E8 | 32 | GPARAM1R  | 全局参数寄存器 1      |
| 0x0EC | 32 | GPARAM2R  | 全局参数寄存器 2      |
| 0x0F0 | 32 | PPARAMR   | 端口参数寄存器        |
| 0x0F4 | 32 | TESTR     | 测试寄存器          |
| 0x0F8 | 32 | VERIONR   | 版本寄存器          |
| 0x0FC | 32 | IDR       | ID寄存器          |
| 0x100 | 32 | PO_CLB    | 命令列表基地址低 32 位  |
| 0x104 | 32 | PO_CLBU   | 命令列表基地址高 32 位  |
| 0x108 | 32 | PO_FB     | FIS 基地址低 32 位  |
| 0x10c | 32 | PO_FBU    | FIS 基地址高 32 位  |
| 0x110 | 32 | PO_IS     | 中断状态寄存器        |
| 0x114 | 32 | PO_IE     | 中断使能寄存器        |
| 0x118 | 32 | PO_CMD    | 命令寄存器          |
| 0x120 | 32 | PO_TFD    | 任务文件数据寄存器      |
| 0x124 | 32 | PO_SIG    | 签名寄存器          |
| 0x128 | 32 | P0_SSTS   | SATA 状态寄存器     |
| 0x12C | 32 | PO_SCTL   | SATA 控制寄存器     |
| 0x130 | 32 | PO_SERR   | SATA 错误寄存器     |
| 0x134 | 32 | PO_SACT   | SATA 激活寄存器     |
| 0x138 | 32 | PO_CI     | 命令发送寄存器        |
| 0x13C | 32 | PO_SNTF   | SATA 命令通知寄存器   |
| 0x170 | 32 | PO_DMACR  | DMA 控制寄存器      |
| 0x178 | 32 | PO_PHYCR  | PHY 控制寄存器      |
| 0x17C | 32 | PO_PHYSR  | PHY 状态寄存器      |
| 0x180 | 32 | P1_CLB    | 命令列表基地址低 32 位  |
| 0x184 | 32 | P1_CLBU   | 命令列表基地址高 32 位  |
| 0x188 | 32 | P1_FB     | FIS 基地址低 32 位  |
| 0x18c | 32 | P1_FBU    | FIS 基地址高 32 位  |
| 0x190 | 32 | P1_IS     | 中断状态寄存器        |



| 0x194 | 32 | P1_IE     | 中断使能寄存器      |
|-------|----|-----------|--------------|
| 0x108 | 32 | P1_CMD    | 命令寄存器        |
| 0x1a0 | 32 | P1_TFD    | 任务文件数据寄存器    |
| 0x1a4 | 32 | P1_SIG    | 签名寄存器        |
| 0x1a8 | 32 | P1_SSTS   | SATA 状态寄存器   |
| 0x1aC | 32 | P1_SCTL   | SATA 控制寄存器   |
| 0x1b0 | 32 | P1_SERR   | SATA 错误寄存器   |
| 0x1b4 | 32 | P1_SACT   | SATA 激活寄存器   |
| 0x1b8 | 32 | P1_CI     | 命令发送寄存器      |
| 0x1bC | 32 | P1_SNTF   | SATA 命令通知寄存器 |
| 0x1f0 | 32 | P1_DMACR  | DMA 控制寄存器    |
| 0x1f8 | 32 | P1_PHYCR  | PHY 控制寄存器    |
| 0x1fC | 32 | P1s_PHYSR | PHY 状态寄存器    |

# 35.3 SATA PHY 初始化流程

SATA PHY 初始化

- 1. 如果使用片内生成的 25MHz 时钟,则将寄存器 sata\_phy\_p1\_osc\_force\_ext 设置为 1
- 2. 撤销 SATA PHY 的复位信号 sata\_phy\_cfg\_reset\_n
- 3. 对 SATA PHY 的内部寄存器进行配置
- 4. 撤销 SATA PHY 的复位信号 sata\_phy\_cfg\_soft\_phy\_rstn
- 5. 等待 sata\_phy\_ready 变为 0xf
- 6. 撤销 SATA 控制器的软复位(默认情况下 SATA 控制器处于复位状态)



# 36 PCIe 控制器 (Dev 9/A/B/C/D/E/F)

龙芯 2K2000 有 3 个 PCIe 模块: F0、F1、G0。F0 模块既可以作为一个 X4/X2/X1 的 PCIe 端口也可以作为 4 个独立的 X1 PCIe 端口; F1 模块既可以作为一个 X4/X2/X1 的 PCIe 端口也可以作为 2 个独立的 X1 PCIe 端口,作为 X1 端口时,仅 LANEO 和 LANE1 可用,LANE2 和 LANE3 不可用; G0 模块只能作为一个 X4/X2/X1 的 PCIe 端口。

F0 模块包含  $0\sim3$  号,共 4 个 PCIe 端口。0 号端口可以以 X4/X2/X1 的方式工作, $1\sim3$  号端口仅能以 X1 的方式工作。F0 的所有 PCIe 端口最高工作速率为 GEN3(8Gbps),只能工作在 RC 模式。

F1 模块包含 0 和 1 号 PCIe 端口。0 号端口可以以 X4/X2/X1 的方式工作,1 号端口仅能以 X1 的方式工作。2X1 模式时,F1 的所有 PCIe 端口最高工作速率为 GEN2(5Gbps)。F1 只能工作在 RC 模式。

G0 模块包含 0 号 PCIe 端口。0 号端口可以以 X4/X2/X1 的方式工作,最高工作速率为 GEN3 (8Gbps)。G0 允许工作在 RC 或 EP 模式。

GO 有内置的 DMA 控制器,可以在内部总线与 PCIe 总线间进行数据搬运。

## 36.1 PCI 配置寄存器

下表列出 PCIe 端口的配置头缺省值,不同端口的 Device ID 可能不同,其他字段都相同。

| 地址偏移    | 简称      | 描述                                     | 默认值                | 访问类 型   |
|---------|---------|----------------------------------------|--------------------|---------|
| 00h-01h | VID     | Vendor ID                              | 0014h              | RO      |
| 02h-03h | DID     | Device ID                              | 见寄存器描述             | RO      |
| 04h-05h | PCICMD  | PCI Command                            | 0000h              | R/W, RO |
| 06h-07h | PCISTS  | PCI Status                             | 0010h              | RO      |
| 08h     | RID     | Revision ID                            | 01h                | RO      |
| 09h     | PI      | Programming Interface                  | 00h                | RO      |
| OAh     | SCC     | Sub Class Code                         | 04h                | RO      |
| 0Bh     | BCC     | Base Class Code                        | 06h                | RO      |
| 0Ch     | CLS     | Cache Line Size                        | 00h                | RO      |
| ODh     | PLT     | Primary Latency Timer                  | 00h                | RO      |
| 0Eh     | HEADTYP | Header Type                            | 01h                | RO      |
| 10h-17h | CNL_BAR | Control Block Base Address<br>Register | 00000000000000004h | R/W, RO |
| 18h     | PBNUM   | Primary Bus Number                     | 00h                | R/W     |
| 19h     | SBNUM   | Secondary Bus Number                   | 00h                | R/W     |
| 1Ah     | SuBNUM  | Subordinate Bus Number                 | 00h                | R/W     |
| 1Bh     | SLT     | Secondary Latency Timer                | 00h                | RO      |
| 1Ch     | IOBASE  | I/O Base                               | 01h                | R/W     |
| 1Dh     | IOLMT   | I/O Limit                              | 01h                | R/W     |
| 1Eh-1Fh | SSTS    | Secondary Status                       | 0000h              | RO      |
| 20h-21h | MBASE   | Memory Base                            | 0000h              | R/W     |

表 36-1 PCIe 控制器的配置寄存器



| 22h-23h | MLMT   | Memory Limit                              | 0000h     | R/W |
|---------|--------|-------------------------------------------|-----------|-----|
| 25h-24h | PMBASE | Prefetchable Memory Base                  | 0000h     | R/W |
| 27h-26h | PMLMT  | Prefetchable Memory Limit                 | 0000h     | R/W |
| 28h-2Bh | PMBU32 | Prefetchable Memory Base Upper<br>32 Bits | 00000000h | R/W |
| 2Ch-2Fh | PMLU32 | Prefetchable Memory Limit Upper 32 Bits   | 00000000h | R/W |
| 30h-31h | IOBU   | I/O Base Upper 16 Bits                    | 0000h     | R/W |
| 32h-33h | IOLMTU | I/O Limit Upper 16 Bits                   | 0000h     | R/W |
| 34h     | CAPP   | Capabilities Pointer                      | 40h       | RO  |
| 3Ch     | INT_LN | Interrupt Line                            | FFh       | R/W |
| 3Dh     | INT_PN | Interrupt Pin                             | 01h       | RO  |
| 3Eh-3Fh | BCTRL  | Bridge Control Register                   | 0000h     | R/W |

注: 表中未列出的地址空间表示保留。

下面列出与 PCI 配置头规范稍有不同的寄存器及其描述。

### DID-设备标识寄存器 (PCIe)

 地址偏移: 02-03h
 属性: R0

 默认值: 见描述
 大小: 16 位

| 位域   | 名称  | 访问 | 描述                                     |
|------|-----|----|----------------------------------------|
| 15:0 | DID | RO | PCIe 设备标识寄存器。各个 PCIe 端口对应的 DID 见表 36-2 |

| PCI 设备号  | 描述               | 设备标识寄存器 |  |  |  |  |
|----------|------------------|---------|--|--|--|--|
| D9:F0    | PCIe_F0 端口 0     | 7A49h   |  |  |  |  |
| D10:F0   | PCIe_F0 端口 1     | 7A39h   |  |  |  |  |
| D11:F0   | PCIe_F0 端口 2     | 7A39h   |  |  |  |  |
| D12:F0   | PCIe_F0 端口 3     | 7A39h   |  |  |  |  |
| D13:F0   | PCIe_F1 端口 0     | 7A49h   |  |  |  |  |
| D14:F0   | PCIe_F1 端口 1     | 7A39h   |  |  |  |  |
| D15:F0   | PCIe_GO端口 O (RC) | 7A79h   |  |  |  |  |
| D15 · F0 | PCIe GO端口O(EP)   | 7AF9h   |  |  |  |  |

表 36-2 PCIe 端口 DID 表

# 36.2 地址空间划分

芯片中的 PCIe 控制器内有标准的 PCIe 配置头,因此 PCIe 控制器的内部寄存器以及其下游设备的地址空间都通过其配置头的信息来管理。配置头中地址相关的寄存器在 PCI 设备扫描时确定。

每个 PCIe 端口作为 SOC 中的独立设备,每个端口都包含一个 PCIe 配置头。当 FO、GO 中的 PCIe 工作在 X4 模式时,其他 X1 的端口软件不可见,只有当 PCIe 工作在 X1 模式时才可以访问其他 X1 端口。

对于每一个 PCIe 端口,其地址空间可以分为以下几部分:

配置头地址空间:该部分空间对应 PCIe 的配置头,通过配置请求来访问,最大 8KB。 其中低 4KB 通过将配置请求的 func 设为 0 来访问,用于访问标准配置头;高 4KB 通过将配置请求的 func 设为 1 来访问,用于改写标准配置头中的一些只读寄存器。当控制器作为 EP使用时,来自外部 PCIe 总线的所有设备号为 0 的 TYPEO 访问被用于该 EP端口的 PCIe header。



配置访问地址空间:该部分地址空间用于通过配置请求访问 PCIe 控制器的下游设备配置头信息。根据下游设备的 Bus 号,由 PCIe 控制器决定发送 TYPE0 类型还是 TYPE1 类型的配置访问。当控制器作为 EP 使用时,来自外部 PCIe 总线的所有设备号非 0 的 TYPE0 访问被用于通过芯片内部的互连网络访问芯片内部的各功能接口的 PCI header;所有来自外部 PCIe 总线的 TYPE1 访问则依据其总线号通过内部互连来访问芯片的其它作为 RC 的 PCIe 端口。

以上两个地址空间的地址由配置地址空间基地址、BUS 号、设备号、功能号以及寄存器偏移地址计算得出,访问以字为单位。

PCIe 控制器内部寄存器空间:该部分地址空间用于访问 PCIe 控制器的内部寄存器。这些寄存器用于控制 PCIe 控制器的行为和特性,与 PCIe 配置头空间属于两个地址空间。该地址空间为 MEM 类型,64 位地址空间,大小为 4KB,基地址等于 64 位 BARO 的值,该值在初始化时由 PCI 扫描软件分配。

MEM 地址空间: 该部分地址空间包含了 PCIe 控制器下游设备的所有 MEM 地址空间。对于 32 位地址空间,由 PCIe 配置头的 memory base 和 memory limit 决定;对于 64 位地址空间,由 PCIe 配置头的 prefetchable memory base(组合 upper 32bits)和 prefetchable memory limit(组合 upper 32bits)决定。该段地址空间由 PCIe 配置头的 command 寄存器bit1 位来使能控制。当控制器作为 EP 使用时,来自外部 PCIe 总线的所有 MEM 访问将通过芯片内部的互连网络直接访问芯片内部的资源。

IO 地址空间:该部分地址空间包含了 PCIe 控制器下游设备的所有 IO 地址空间。由 PCIe 配置头的 io base(组合 upper 16bits)和 io limit(组合 upper 16bits)决定。该段地址空间由 PCIe 配置头的 command 寄存器 bit0 位来使能控制。当控制器作为 EP 使用时,来自外部 PCIe 总线的所有 IO 访问将通过芯片内部的互连网络直接访问芯片内部的资源。

对于 MEM 地址空间和 IO 地址空间来说,如果在 X1 工作模式下,某个 X1 端口下游没有连接设备,通过设置 command 寄存器的 bit0 和 bit1 为 0 即可禁用其 MEM 和 IO 地址空间。

# 36.3 内部寄存器定义

芯片的每个 PCIe 端口都有自己的端口控制寄存器。如上文所述,每个端口的控制寄存器的基址由配置头的 BARO 决定。

### PCIe 端口控制寄存器 0

偏移地址: 0x0 默认值: 0xc8ff0044

| Bits | 复位值    | 属性  | 名字               | 描述             |
|------|--------|-----|------------------|----------------|
| 0    | 0      | R/W | Rx_lane_flip_en  | PCIe 接收线反转     |
| 1    | 0      | R/W | Tx_lane_flip_en  | PCIe 发送线反转     |
| 2    | 1      | R/W | Sys_aux_pwr_det  | 指示拥有辅助电源(Vaux) |
| 3    | 0 (RC) | R/W | App_ltssm_enable | PCIe 端口链路建立使能  |



|       | 1 (EP) |     |                     |                                                                                                 |
|-------|--------|-----|---------------------|-------------------------------------------------------------------------------------------------|
| 11:4  | 0x4    | R/W | Reserved            | 复位后需要设置为0                                                                                       |
| 12    | 0      | R/W | App_req_enter_L1    | 要求 PCIe 链路进入 L1                                                                                 |
| 13    | 0      | R/W | App_ready_enter_L23 | 已经准备好让 PCIe 链路进入 L23                                                                            |
| 14    | 0      | R/W | App_req_exit_L1     | 要求 PCIe 端口退出 L1                                                                                 |
| 15    | 0      | R/W | Soft_reset_en       | 软复位使能                                                                                           |
| 23:16 | 0xff   | R/W | Reserved            | 保留                                                                                              |
| 24    | 0      | R/W | at_en               | PCIe 端口入站(PCIe 到内部总线)地址转<br>换使能.                                                                |
| 25    | 0      | R/W | bus_error_en        | PCIe 读返回总线错误的处理方式<br>0:读数据返回全 1,不产生总线错例外<br>1:产生总线错例外<br>当 PCIe 控制器完成总线扫描和初始化后,<br>此位可以修改为 1    |
| 26    | 0      | R/W | read_pass_write_en  | 内部总线读写顺序控制<br>0: PCIe 控制器在内部总线上发起的请求<br>中,读请求不允许越过写请求<br>1: PCIe 控制器在内部总线上发起的请求<br>中,读请求允许越过写请求 |
| 27    | 1      | RO  | Reserved            | 此位的值禁止软件进行改写                                                                                    |
| 31:28 | 0x0    | RO  | Reserved            | 保留                                                                                              |

### PCIe 端口控制寄存器 1

通过对相应位写入 1 产生一个时钟周期的脉冲,控制 PCIe 接口进行相应的操作。写写此寄存器时,一次仅能有 1 位被置 1。

偏移地址: 0x4 默认值: 0x0

| Bits | 复位值 | 属性    | 名字                      | 描述                                               |
|------|-----|-------|-------------------------|--------------------------------------------------|
| 0    | 0   | R/W1P | App_unlock_msg          | 在 PCIe 端口上发送解锁消息                                 |
| 1    | 0   | R/W1P | Apps_pm_xmt_tur<br>noff | 在 PCIe 端口上发送 PM_Turn_Off 消息                      |
| 2    | 0   | R/W1P | App_init_rst            | 在 PCIe 端口上发送热复位消息                                |
| 3    | 0   | R/W1P | Soft_reset              | 对 PCIe 端口进行软复位                                   |
| 4    | 0   | R/W1P | Apps_pm_xmt_pme         | 将 PCIe 端口从 D1 或者 D2 或者 D3 状态中唤醒,并发送<br>PM_PME 消息 |
| 31:5 | 0x0 | RO .  | Reserved                | 保留                                               |

## PCIe 端口状态寄存器 0

偏移地址: 0x8 默认值: 0x20f

| Bits | 名字            | 描述               |
|------|---------------|------------------|
|      |               | 系统电源状态指示         |
|      |               | 00b: Reserved    |
| 1:0  | Cfg_pwr_ind   | 01b: On          |
|      |               | 10b: Blink       |
|      |               | 11b: Off         |
|      |               | Attention 按钮状态指示 |
|      |               | 00b: Reserved    |
| 3:2  | Cfg_atten_ind | 01b: On          |
|      |               | 10b: Blink       |
|      |               | 11b: 0ff         |
| 4    | CC            | 系统电源控制器状态        |
| 4    | Cfg_pwr_ctrl  | 0: Power On      |



|       |                          | 1: Power Off                       |
|-------|--------------------------|------------------------------------|
| 5     | Pm_xtlh_block_tlp        | 禁止发出请求指示                           |
|       |                          | PCI 主设备使能                          |
| 6     | Cfg_bus_master_en        | 1: enabled                         |
|       |                          | 0: disabled                        |
|       |                          | 内存映射访问使能                           |
| 7     | Cfg_mem_space_en         | 1: enabled                         |
|       |                          | 0: disabled                        |
| 10:8  | Cfg_max_rd_req_size      | 最大读请求大小                            |
| 13:11 | Cfg_max_payload_size     | 最大数据负载                             |
| 14    | Cfg_rcb                  | RCB 位                              |
|       |                          | 数据链路层状态                            |
| 15    | Rdlh_link_up             | 1: Link is up                      |
|       |                          | 0: Link is down                    |
| 18:16 | Pm_curnt_state           | 当前电源状态                             |
| 23:19 | Cfg_aer_int_msg_num      | 根错误状态寄存器的 31:21 位                  |
| 28:24 | Cfg_pcie_cap_int_msg_num | PCIe 能力寄存器 13:9 位                  |
| 29    | rfa undata0              | 此位为1表示 rfc_data0 有更新的流控令牌包的内容。     |
|       | rfc_update0              | rfc_update0、rfc_data0被用作观察流控令牌的发放  |
| 30    | nfo undotal              | 此位为1表示rfc_datal有更新的流控令牌包的内容。       |
| 30    | rfc_update1              | rfc_updatel、rfc_datal 被用作观察流控令牌的发放 |
| 31    | Reserved                 | 保留                                 |

## PCIe 端口状态寄存器 1

偏移地址: 0xc

默认值: 0x01000000

| Bits  | 名字                   | 描述                           |
|-------|----------------------|------------------------------|
| 5:0   | Xmlh_ltssm_state     | LTSSM 状态机的当前状态               |
|       |                      | 物理链路状态指示                     |
| 6     | Xmlh_link_up         | 1: Up                        |
|       |                      | 0: Down                      |
| 7     | Rtlh_rfc_upd         | 数据链路层收到流控包指示                 |
| 8     | Cfg_eml_control      |                              |
| 16:9  | Cfg_pbus_num         | 设备所属总线号                      |
| 21:17 | Cfg_pbus_dev_num     | 设备号                          |
|       |                      | 电源管理状态指示                     |
|       |                      | 000b: D0                     |
|       |                      | 001b: D1                     |
| 24:22 | Pm_dstate            | 010b: D2                     |
|       |                      | 011b: D3                     |
|       |                      | 100b: Uninitialized          |
|       |                      | Other values: Not applicable |
| 25    | Pm_status            | 电源管理状态位                      |
| 26    | Pm_pme_en            | PME 使能指示                     |
| 27    | Aux_pm_en            | 辅助电源使能指示                     |
| 28    | Cfg_link_auto_bw_int | 链路自治带宽状态寄存器更新指示              |
| 29    | Cfg_bw_mgt_int       | 链路带宽管理状态寄存器更新指示              |
| 30    | Reserved             | 保留                           |
| 31    | Cfg_link_eq_req_int  | 此位为1表示收到链路重新进行均衡的请求          |

# 用户定义消息 ID 寄存器

偏移地址: 0x10

| MATO SCIENCE ON TO |                 |    |                                              |
|--------------------|-----------------|----|----------------------------------------------|
| Bits               | 名字              | 属性 | 描述                                           |
| 15:0               | radm_msg_req_id | RO | 访问 radm_msg_index 指定的接收用户定义消息组所存储的用户定义消息的 ID |



| 17:16 | radm_msg_index | RW | 访问的接收用户定义消息组的编号<br>X1、X4 控制器只允许使用 0h<br>X8 控制器允许使用 0h、1h<br>X16 控制器允许使用 0h~ 3h |
|-------|----------------|----|--------------------------------------------------------------------------------|
| 31:18 | Reserved       | RO | 保留                                                                             |

## 流控观察寄存器 0

偏移地址: 0x14

| Bits | 名字        | 属性 | 描述                                |
|------|-----------|----|-----------------------------------|
| 31:0 | rfc_datal | RO | 记录最近一次同一个符号时间里收到2个流控包时的第二个 流控包的内容 |

# PCIe 端口中断状态寄存器

偏移地址: 0x18

| <b>層移地</b> 耳 | 上: 0x18            |                                              |
|--------------|--------------------|----------------------------------------------|
| Bits         | 名字                 | 描述                                           |
| 0            | aer_rc_err_int     | 当 RC 产生或收到错误消息并且 Root Error Command 寄存器中对应的  |
| 0            | der_rc_err_int     | 错误报告使能被打开时置位。此位仅在 RC 工作模式下使用。                |
|              |                    | 当 RC 产生或收到错误消息并且 MSI 被使能且 Root Error Command |
| 1            | aer_rc_err_msi     | 寄存器中对应的错误报告使能被打开时置位。此位仅在 RC 工作模式             |
|              |                    | 下使用。                                         |
|              |                    | 此位报告检测到系统错误。当 Root Control 寄存器的对应位使能被        |
| 2            | sys_err_rc         | 打开并且 PCIe 总线上如何设备产生:可修复错误、致命错误、非致            |
|              |                    | 命错误时,或者 RC 产生内部错误时置位。                        |
|              |                    | 收到 PME 中断。当下列条件满足时,此位置位:                     |
| 3            | pme_int            | 1. Command 寄存器中 INTx 未被禁止;                   |
|              | pmc_rrt            | 2. Root Control 寄存器中 PME 中断使能位被打开;           |
|              |                    | 3. 收到 PME 消息(Root Status 寄存器中 PME 状态位被置位)。   |
|              |                    | 收到 PME 中断。当下列条件满足时,此位置位:                     |
| 4            | pme_msi            | 1. Command 寄存器中 INTx 被禁止, MSI 被使能;           |
| 1            | pme_msi            | 2. Root Control 寄存器中 PME 中断使能位被打开;           |
|              |                    | 3. 收到 PME 消息(Root Status 寄存器中 PME 状态位被置位)。   |
| 5            | vendor_msg0        | 用户定义消息组0收到用户定义消息                             |
| 6            | rc_core_wake       | 从电源管理中唤醒                                     |
| 7            | INTA               | INTA 中断                                      |
| 8            | INTB               | INTB 中断                                      |
| 9            | INTC               | INTC 中断                                      |
| 10           | INTD               | INTD 中断                                      |
| 11           | radm_correctable_e | 此 PCIe 端口收到可修复错误消息                           |
| 11           | rr                 |                                              |
| 12           | radm_nonfatal_err  | 此 PCIe 端口收到非致命错误消息                           |
| 13           | radm_fatal_err     | 此 PCIe 端口收到致命错误消息                            |
| 14           | pm_pme             | 收到 PM_PME 消息                                 |
| 15           | pm_to_ack          | 收到 PM_TO_Ack 消息                              |
|              |                    | 当下列条件满足时,此位置位:                               |
| 16           | hp_pme             | 1. PCI 电源管理控制和状态寄存器中 PME 使能被打开;              |
| 10           | пр_рше             | 2. Slot Status 寄存器中的任意 1 位由 0 变 1 并且对应位的通知使  |
|              |                    | 能被打开。                                        |
|              |                    | 当下列条件满足时,此位置位:                               |
|              | hp_int             | 1. Command 寄存器中 INTx 未被禁止;                   |
| 17           |                    | 2. Slot Control 寄存器中热插拔中断使能被打开;              |
|              |                    | 3. Slot Status 寄存器中的任意 1 位为 1,并且对应位的通知使能被    |
|              |                    | 打开。                                          |
|              |                    | [1] 丌。                                       |



| 18     | hp_msi                        | 当下列条件满足时,此位置位: 1. MSI 使能被打开; 2. Slot Control 寄存器中热插拔中断使能被打开; 3. Slot Status 寄存器中的任意 1 位从 0 变 1,并且对应位的通知使能被打开。 |
|--------|-------------------------------|---------------------------------------------------------------------------------------------------------------|
| 19     | link_auto_bw_int              | 当链路的自治带宽状态寄存器被更新并且链路的自治带宽中断被使<br>能时置位仅在 RC 模式下使用。                                                             |
| 20     | bw_mgt_int                    | 当链路的带宽状态寄存器被更新并且链路的带宽中断被使能时置<br>位。仅在 RC 模式下使用。                                                                |
| 21     | gm_composer_lookup<br>_err    | 此位被置位表示此 PCIe 端口在向外发送数据响应时溢出。这通常表示此 PCIe 端口接收端收到的 Non-Posted 请求的数量超出了端口流控限制。                                  |
| 22     | radmx_composer_loo<br>kup_err | 此位被置位表示此 PCIe 端口接收送数据响应时溢出。这通常表示此<br>PCIe 端口发送端发送的 Non-Posted 请求的数量超出了端口流控限<br>制。                             |
| 23     | phy_int                       | PHY 中断                                                                                                        |
| 24     |                               | Reserved                                                                                                      |
| 25     | ltssm_12_to_detect            | LTSSM 状态从 L2 状态退出到设备检测状态                                                                                      |
| 26     | pm_turn_off                   | 收到 PM_Turn_Off 消息                                                                                             |
| 27     | Link_req_rst_not_f all        | PCIe 端口物理链路断裂                                                                                                 |
| 28     | Link_eq_req_int               | 此位被置位表面链路重新进行了 gen3 的 equalization 参数训练                                                                       |
| 29     | edma_int                      | 内置 DMA 控制器中断<br>仅端口 0(X4 控制器)使用                                                                               |
| 31: 30 |                               | Reserved                                                                                                      |

### PCIe 端口中断状态清除寄存器

偏移地址: 0x1c

R/W1C

在某一位写入1则清除PCIe端口中断状态寄存器的对应位。

## PCIe 端口中断掩码寄存器

偏移地址: 0x20

R/W

默认值: 0x2bfffffff

PCIe 端口中断状态寄存器对应的中断掩码。哪 1 位置 1 并且中断状态寄存器的相应位也为 1 时,此 PCIe 端口产生中断。

### PCIe 端口控制寄存器 2



偏移地址: 0x24 默认值: 0x12

| 714 D . O. M |                     |     |                                  |
|--------------|---------------------|-----|----------------------------------|
| Bits         | 名字                  | 属性  | 描述                               |
| 31:5         | Reserved            | RO  | 保留                               |
| 4            | Il ontor protect    | RW  | 此位为1表示开启L1状态的进入保护                |
| 4            | L1_enter_protect    | IVW | 软件不要修改此位寄存器的值                    |
| 3            | Ep otrans en        | RW  | 此位为1表示在EP模式下开启PCIe地址到内部总线地址的转    |
| J            | Ep_otrans_en        |     | 换功能                              |
| 2            | Header_ro_wen       | RW  | 此位为 1,将是 header 中的只读位变为可写        |
| 1            | cfg0 busnum is zero | RW  | 此位为1将发送的TYPEO的配置访问中的BUS NUM强制设置为 |
| 1            | cigo_bushum_is_zero | IVW | 0                                |
| 0            | Reserved            | RW  | 保留                               |

### PCIe 端口控制和状态寄存器

偏移地址: 0x28

| Bits  | 复位值 | 属性  | 名字            | 描述                                    |
|-------|-----|-----|---------------|---------------------------------------|
| 0     | 0   | R/W | func_bypass   | 置1时,取消内部接口请求间的先后顺序限制(读可能会越过写,写也可能越过读) |
| 7:1   |     |     |               | Reserved                              |
| 8     | 0   | R/W |               | Reserved                              |
| 15:9  |     |     |               | Reserved                              |
| 16    | 0   | R/W | aux_clk_en    | 让 PHY 进入 SSC 模式 PCIe 端口辅助时钟使能         |
| 25:17 |     |     |               | Reserved                              |
| 26    |     | RO  | max_lane_mode | PCIe 端口在最大链路宽度模式工作                    |
| 27    |     | RO  | Is_rc         | PCIe 端口在 RC 模式工作                      |
| 28    |     | RO  | L0s           | PCIe 端口处于 LOs 功耗状态                    |
| 29    |     | RO  | L1            | PCIe 端口处于 L1 功耗状态                     |
| 30    |     | RO  | L2            | PCIe 端口处于 L2 功耗状态                     |
| 31    |     | RO  | L2_exit       | PCIe 端口退出 L2 功耗状态                     |

### 用户定制消息发送寄存器 0

偏移地址: 0x38

此寄存器用于在发送用户定制 PCIe 消息前存储 PCIe 传输层协议消息包头的头 4 个字节的信息。

| Bits  | 名字           | 描述                         |
|-------|--------------|----------------------------|
| 1:0   | ven_msg_fmt  | PCIe 协议中传输层协议包头中的 Fmt 域    |
| 6:2   | ven_msg_type | PCIe 协议中传输层协议包头中的 Type 域   |
| 9:7   | ven_msg_tc   | PCIe 协议中传输层协议包头中的 TC 域     |
| 10    | ven_msg_td   | PCIe 协议中传输层协议包头中的 TD 域     |
| 11    | ven_msg_ep   | PCIe 协议中传输层协议包头中的 EP 域     |
| 13:12 | ven_msg_attr | PCIe 协议中传输层协议包头中的 Attr 域   |
| 23:14 | ven_msg_len  | PCIe 协议中传输层协议包头中的 Length 域 |
| 31:24 | Reserved     | 保留                         |

### 用户定制消息发送寄存器1

此寄存器用于在发送用户定制 PCIe 消息前存储 PCIe 传输层协议消息包头的第 4 到第 7 字节的消息。

偏移地址: 0x3c

| Bits | 名字              | 描述                                  |
|------|-----------------|-------------------------------------|
| 2:0  | ven_msg_fun_num | PCIe 协议中传输层协议包头中的 Function Number 域 |



| 10:3  | ven_msg_tag       | PCIe 协议中传输层协议包头中的 Tag 域                                              |  |  |
|-------|-------------------|----------------------------------------------------------------------|--|--|
| 18:11 | ven_msg_code      | PCIe 协议中传输层协议包头中的 Message Code 域                                     |  |  |
| 22:19 |                   | Reserved                                                             |  |  |
| 23    | ven_msg_req_valid | 此位置 1 表示当前用户定制消息的所有参数均已经配置完毕,要求<br>PCIe 端口发送此用户定制消息。消息发送完毕后,此位自动清 0。 |  |  |
| 31:24 | Reserved          | 保留                                                                   |  |  |

### 用户定制消息发送寄存器 2

偏移地址: 0x40

用于存储待发送用户定制消息所携带数据的低32位。

### 用户定制消息发送寄存器3

偏移地址: 0x44

用于存储待发送用户定制消息所携带数据的高32位。

### 流控观察寄存器1

偏移地址: 0x48

| Bits | 名字        | 属性 | 描述                         |
|------|-----------|----|----------------------------|
| 31:0 | rfc_data0 | RO | 记录最近一次同一个符号时间里收到的第一个流控包的内容 |

### MSI 消息发送寄存器

偏移地址: 0x5c

用于存储要发送的 MSI 消息的包头参数和触发 MSI 消息的发送。仅在 EP 模式下使用。在发送 MSI 消息前,需要系统软件按照 PCIe 协议为控制器配置 MSI 消息使用的地址并将 EP 的中断方式设置为 MSI 方式。

| Bits  | 名字               | 属性 | 描述                                                             |
|-------|------------------|----|----------------------------------------------------------------|
| 4:0   | ven_msi_vector   | RW | PCI 协议 MSI 包中的 Vector 域                                        |
| 7:5   | ven_msg_tc       | RW | PCIe 协议中传输层协议包头中的 TC 域                                         |
| 10:8  | ven_msg_func_num | RW | PCIe 协议中传输层协议包头中的 Function Number 域                            |
| 11    | ven_msi_valid    | RW | 此位置1表示当前MSI消息的所有参数均已经配置完毕,要求<br>PCIe端口发送此MSI消息。消息发送完毕后,此位自动清0。 |
| 12    | msi_en           | RO | MSI 使能观测位                                                      |
| 31:13 |                  |    | Reserved                                                       |

### 地址译码掩码寄存器 0

偏移地址: 0x68

用于存储此 PCIe 端口作为 RC 时入站地址转换的地址掩码的低 32 位。

### 地址译码掩码寄存器1

偏移地址: 0x6c

R/W

用于存储此 PCIe 端口作为 RC 时入站地址转换的地址掩码的高 32 位。

### 地址译码转换地址寄存器 0



偏移地址: 0x70

R/W

用于存储此 PCIe 端口作为 PCIe 入站(PCIe 到内部总线)地址转换的转换地址的低 32 位。

### 地址译码转换地址寄存器1

偏移地址: 0x74

R/W

用于存储此 PCIe 端口作为 PCIe 入站(PCIe 到内部总线)地址转换的转换地址的高 32 位。

### 接收用户定义消息数据负载读取端口0

偏移地址: 0x78

R/W

用于读取 radm\_msg\_index 所指定的接收组所存储的用户定义消息数据的低 32 位。

### 接收用户定义消息数据负载读取端口1

偏移地址: 0x7c

R/W

用于读取 radm msg index 所指定的接收组存储的用户定义消息数据的高 32 位。

### EP 模式地址译码掩码寄存器 0

偏移地址: 0x80

用于存储此 PCIe 端口作为 EP 时从内部总线地址到 PCIe 地址转换的地址掩码的低 32 位。

### EP 模式地址译码掩码寄存器 1

偏移地址: 0x84

R/W

用于存储此 PCIe 端口作为 EP 时从内部总线地址到 PCIe 地址转换的地址掩码的高 32 位。

### EP 模式地址译码转换地址寄存器 0

偏移地址: 0x88

R/W

用于存储此 PCIe 端口作为 EP 时从内部总线地址到 PCIe 地址转换的地址的低 32 位。

### EP 模式下为 PCIe 总线开放窗口 mask 寄存器 0

偏移地址: 0x90



R/W

EP 模式下为 PCIe 总线开放的 memory 访问窗口 mask 的低 32 位。

### EP 模式下为 PCIe 总线开放窗口 mask 寄存器 1

偏移地址: 0x94

R/W

EP模式下为 PCIe 总线开放的 memory 访问窗口 mask 的高 32 位。

## 36.4 PCIe 配置头空间

芯片的每个 PCIe 端口都有自己的 PCIe 配置头空间。每个端口的 PCIe 配置头空间都有自己的基址,该基址通过芯片配置空间基址、BUS 号(内部总线 BUS 号为 0)以及设备号来确定。

## 36.5 软件编程指南

PCIe 控制器在作为 RC 使用时,在使用前需要经过以下几个步骤的初始化过程:

- 1. 参考时钟准备
- 2. 控制器使能
- 3. PHY 参数初始化
- 4. 链路建立初始化

### 参考时钟准备

芯片的 PCIe 控制器使用了由芯片内部系统时钟为芯片内部 PCIe 控制器以及外部的 PCIe 设备提供同源参考时钟的参考时钟方案。在使用 PCIe 控制器前,需要首先确保参考时钟的选择与所用的板卡环境一致。F0 的参考时钟源由 5.1 小节的通用配置寄存器 0 的 bit2 控制; G0 的参考时钟源由 5.1 小节的通用配置寄存器 0 的 bit15 控制。

#### PCIe 控制器使能

使能 PCIe 控制器的的操作包含下列步骤:

- 1. 设置 PCIe 控制器所属模块的工作模式
- 2. 操作芯片配置寄存器 0,对 PCIe 控制器模块进行复位和使能

下面的伪代码给出了完成上述2个步骤的操作过程

 $void\ pcie\_enable (unsigned\ int\ port\_num,\ unsigned\ int\ cfg\_regl\_offset,\ unsigned\ int\ soft\_reset\_offset,\ unsigned\ int\ enable\_offset)$ 

volatile unsigned int read\_data;

read\_data = \*((volatile unsigned long \*)(CONFBUS\_BASE\_ADDR + cfg\_regl\_offset));



```
if (port num == 1) {//set to max lane num mode
           *((volatile unsigned long *) (CONFBUS BASE ADDR + cfg reg1 offset)) = read data | (0x3
<< 26):
        } else {
           *((volatile unsigned long *) (CONFBUS_BASE_ADDR + cfg_reg1_offset)) = read_data | (0x1
<< 27);
        printf("set soft reset\n");
        read data = *((volatile unsigned int *)(CONFBUS BASE ADDR + 0x420));
        *((volatile unsigned int *)(CONFBUS_BASE_ADDR + 0x420)) = read_data | (0x1 <<
soft_reset_offset);
        printf("release soft reset\n");
        read_data = *((volatile unsigned int *)(CONFBUS_BASE_ADDR + 0x420));
        *((volatile unsigned int *)(CONFBUS BASE ADDR + 0x420)) = read data & (^{\sim}(0x1 <<
soft reset offset));
        printf("set pcie enable\n");
        read data = *((volatile unsigned int *)(CONFBUS BASE ADDR + 0x420));
        *((volatile unsigned int *)(CONFBUS_BASE_ADDR + 0x420)) = read_data | (0x1 <<
enable offset);
```

上面伪代码中函数包含 4 个参数。参数 port\_num 为 1,表示这个 PCIe 模块只使用 port0,且 port0 工作在最大 lane 宽度上;否则这个 PCIe 模块工作在多个 port 同时使用的模式下 (F0 为 4X1、G0 为 2X1)。参数 cfg\_regl\_offset 为这个 PCIe 模块的配置寄存器 1 在芯片配置寄存器中的地址偏移。参数 soft\_reset\_offset 为这个 PCIe 模块的软件复位控制位在桥芯片的通用配置寄存器 0 中的位偏移。参数 enable\_offset 为这个 PCIe 模块的使能控制位在桥芯片的通用配置寄存器 0 中的位偏移。

### PHY 参数初始化

在 RC 模式下, PCIe 控制器在使用前需要完成对 PHY 的参数配置。完成对 PHY 进行参数 配置后才能释放对 PHY 的 PLL 的复位信号,让 PCIe 控制器的复位能够完成。PHY 的参数初始化流程如下:

- 1. 等待 PHY 的内建初始化配置过程结束。
- 2. 配置 PHY 的内部寄存器,按照需要,修订 PHY 和 PIPE 接口的工作参数。
- 3. 将控制器所属的 PHY 控制寄存器中的 phy\_soft\_cfg\_done 置 1,释放 PHY 的 PLL 的复位信号。
- 4. 查询芯片配置寄存器中的通用配置寄存器 0 中控制器对应的时钟就绪状态,直到对应时钟就绪。
- 5. PHY 的初始化配置结束。



### PCIe 配置头访问

基于前文对配置请求的介绍,对 PCIe 配置头的访问为 Type0 的访问,其格式为:

|        | 39 |      | 28 | 27 24        | 1 23 | 16       | 15 11            | 10 | ;              | 8 | 7           | 0 |
|--------|----|------|----|--------------|------|----------|------------------|----|----------------|---|-------------|---|
| Type 0 |    | FE0h |    | Offset[11:8] |      | Reserved | Device<br>Number |    | nction<br>mber |   | Offset[7:0] |   |

PCIe 各个 Port 的设备号(device number)分别为 0x9, 0xa, 0xb, 0xc, 0xf, 0x10。根据设备号及所要访问的寄存器偏移地址(offset)即可得到对应寄存器的物理地址。功能号Function Number 为 0 时访问配置头内寄存器,功能号 Function Number 为 1 时可以访问配置头空间内影子寄存器,用于改写配置头内的只读寄存器。

### PCIe 链路建立(Linkup)

链路建立流程如下:

- 1. 设置链路目标速度。
- 2. 依据是否要进行 gen3 的链路均衡参数训练,设置是否关闭 gen3 的参数训练。
- 3. 配置访问设置 Gen2 Control Register 寄存器中(0x80c)Directed Speed Change 为 1, PHY Tx Swing 为 0。注意配置地址格式,因为 offset 大于 8 位地址,需将高 4 位填到地址的 bit24-bit27。
- 4. 如果使用 gen3 速率,在 SPCIe 寄存器中为每个 lane 设置初始的 PRESET 值(这些 PRESET 值从 header 的地址偏移 0x14c 开始存储)。
- 5. 根据 BARO 中配的地址通过 MEM 访问设置 PCIe 控制器内部寄存器 app\_ltssm\_enable (0x0) 为 1, 开始 link training 过程。
- 6. 等待链路速率达到设定的速率。
- 7. 等待内部寄存器 Xmlh ltssm state(0xc)为 0x11。
- 8. Linkup 成功。

上述步骤中。步骤1~4之间没有顺序要求。

### TYPE1 类型配置访问

TYPE1 类型配置请求地址格式如下:



发送 TYPE1 类型配置访问之前需要设置配置头的 Primary Bus Number、Secondary Bus Numer 和 Subordinate Bus Number。然后直接按照 TYPE1 地址格式发送读写请求即可,PCIe 控制器根据地址中的 Bus Number 与所配置的 Secondary Bus Numer 和 Subordinate Bus Number 决定发出 TYPE0 类型还是 TYPE1 类型的配置请求。

如果 Bus Number==Secondary Bus Numer,则发出 TYPE0 类型的配置请求。



如果 Bus Number> Secondary Bus Numer 并且 Bus Number <= Subordinate Bus Number, 则发出 TYPE1 类型的配置请求。

#### 常用例程 36.6

本节给出龙芯 2K2000 的 PCIe 控制器的常用例程。需要先执行下面示例中的 pcie\_link\_init,再执行下面示例中的 pcie\_header\_init。随后,芯片可以通过 cfg\_device\_read 和 cfg\_device\_write 这两个函数对下游设备的 PCI Header 进行初始化。

miphy read reg、miphy write reg是用于对 PHY 内部的寄存器进行读、写操作的函 数。其第一个参数 base 是要访问的 PHY 的内部访问端口在芯片配置寄存器中的地址偏移; 其第二个参数是要访问的 PHY 内部寄存器在 PHY 内部的地址偏移。

```
#define FUNC_OFFSET 8
   #define DEV_OFFSET 11
   #define BUS OFFSET 16
   #define REG_HBIT_OFFSET 24
   #define PBUS_NUM 0
   #define HT_BASE
                                    0x90000000000000000
   #define CONFBUS_BASE_ADDR 0x90000fdfe010800
   #define TYPEO CFGBASE Oxfe00000000
   #define TYPE1_CFGBASE Oxfe10000000
   #define IO_BASE
                            0xfdfc000000
   #define REG_HEADER(BASE, BUS_NUM, DEV_NUM, FUNC_NUM, REG_HBIT, REG_LBIT) \
            *((volatile\ unsigned\ int\ *)(HT_BASE\ +\ BASE\ +\ \setminus
                                         (BUS_NUM << BUS_OFFSET) + \
                                         (DEV_NUM << DEV_OFFSET) + \
                                         (FUNC_NUM << FUNC_OFFSET) + \
                                         (REG_HBIT << REG_HBIT_OFFSET) + \
                                          REG LBIT))
   void miphy_write_reg(unsigned int base, unsigned int offset, unsigned int data)
        *((volatile unsigned int *)(CONFBUS BASE ADDR + base)) = data;
        *((volatile unsigned int *)(CONFBUS_BASE_ADDR + base + 0x4)) = (offset&0xfffff)
(0x1 << 25) \mid (0x1 << 24) \mid (0x1 << 26) \mid (0x1 << 27);
        *((volatile unsigned int *)(CONFBUS BASE ADDR + base + 0x4)) = (offset&0xfffff) |
(0x1 << 25) \mid (0x1 << 24) \mid (0x1 << 26) \mid (0x0 << 27);
        unsigned int cfg_read_data;
        do {
            cfg_read_data = *((volatile unsigned int *)(CONFBUS_BASE_ADDR + base + 0x4));
        }while(!((cfg read data>>28)&0x1));
```



```
}
   unsigned int miphy_read_reg(unsigned int base, unsigned int offset)
       *((volatile unsigned int *)(CONFBUS_BASE_ADDR + base + 0x4)) = (offset&Oxfffff) |
(0x1 << 25) \mid (0x1 << 24) \mid (0x0 << 26) \mid (0x1 << 27);
       *((volatile unsigned int *)(CONFBUS BASE ADDR + base + 0x4)) = (offset&0xfffff) |
(0x1 << 25) \mid (0x1 << 24) \mid (0x0 << 26) \mid (0x0 << 27);
       unsigned int cfg_read_data;
       do\,\{
           cfg_read_data = *((volatile unsigned int *)(CONFBUS_BASE_ADDR + base + 0x4));
       }while(!((cfg_read_data>>28)&0x1));
       cfg_read_data = *((volatile unsigned int *)(CONFBUS_BASE_ADDR + base));
       return cfg read data;
   }
void wait speedchange (unsigned int dev num, unsigned int tgt spd) {
    volatile unsigned int read_data;
    unsigned int spd val;
    if(tgt\_spd == 0x1)//gen1 speed
        spd_val = 0x10000;
    else if (tgt\_spd == 0x2)//gen2 speed
        spd val = 0x20000;
    else if (tgt spd == 0x3)//gen3 speed
        spd_va1 = 0x30000;
    else
        spd_val = 0x0;
    //linkstatus register
    read data = REG HEADER (TYPEO CFGBASE, PBUS NUM, dev num, 0, 0, 0x80);
    while((read data&0xf0000)!=spd val)
    {//link status register
        read_data = REG_HEADER(TYPEO_CFGBASE, PBUS_NUM, dev_num, 0, 0, 0x80);
    }
}
void wait linkup(unsigned int bar0base) {
    volatile unsigned int read data;
    read data
                =
                     *((volatile
                                                       *) (HT_BASE
                                                                         bar0base
                                   unsigned
                                                int
0xc));//xmlh ltssm state
    while((read_data&0x1f)!=0x11)
        read_data = *((volatile unsigned int *)(HT_BASE + bar0base + 0xc));
}
void pcie_link_init(unsigned long barObase, unsigned int dev_num, unsigned int
tgt spd, unsigned int start preset, unsigned int do eq23, unsigned int lane cnt)
```



```
volatile unsigned int read data;
    //set target speed
    read data = REG HEADER (TYPEO CFGBASE, PBUS NUM, dev num, 0, 0, 0xa0);
    REG HEADER (TYPEO CFGBASE,
                                 PBUS NUM,
                                               dev num,
                                                           0,
                                                                 0,
                                                                       0xa0
(read_data&~0xf|tgt_spd);
    if(do_eq23 == 0x0) {//disable EQ23}
      read data = REG HEADER (TYPEO CFGBASE, PBUS NUM, dev num, 0, 8, 0x90);
      REG HEADER (TYPEO CFGBASE, PBUS NUM, dev num, 0, 8, 0x90) = (read data |
0x200);
   read_data = (start_preset << 16) | start_preset;</pre>
    for (i = 0; i < lane_cnt/2; i = i+1) {//set start PRESET
      REG_HEADER(TYPEO_CFGBASE, PBUS_NUM, dev_num, 0, 1, (0x4c + i*4)) = read_data;
    //direct speed change and config PHY Tx swing to full swing
    read data = REG HEADER (TYPEO CFGBASE, PBUS NUM, dev num, 0, 8, 0xc);
   REG_HEADER(TYPEO_CFGBASE, PBUS_NUM, dev_num, 0, 8, 0xc) = (read_data|0x20000);
    //start link
   read_data = *((volatile unsigned int *)(HT_BASE + barObase));
    *((volatile unsigned int *)(HT BASE + barObase)) = read data | 0x8;
    wait_speedchange(dev_num, tgt_spd);
    printf("pcie link speed is change to target speed %d\n", tgt spd);
    wait linkup(bar0base);
    printf("pcie link is up\n");
}
void pcie hot reset(unsigned int bar0base)
    unsigned long pcie_reg_base = HT_BASE + bar0base;
    tmp var = *(volatile unsigned int *) ( pcie reg base);
    //enable soft reset
    *(volatile unsigned int *) ( pcie reg base) = tmp var | 0x8000;
    //triger hot reset
   *(volatile unsigned int *) ( pcie reg base +0x4) = 0x4;
void local_header_init(unsigned int io_base,
                   unsigned int mem base,
                   unsigned long long pref mem base,
                   unsigned int dev num,
                   unsigned int func_num,
                   unsigned int sub_busnum,
                   unsigned int second busnum) {
    //enable io/mem space, bus master, parity error response and SErr
    REG_HEADER(TYPEO_CFGBASE, 0, dev_num, func_num, 0, 0x4) = 0x147;
    REG HEADER (TYPEO_CFGBASE, 0, dev num, func num, 0, 0x1c) = 0xf1000000
(((io_base >> 12) & 0xf) << 12) | (((io_base >> 12) & 0xf) << 4);//io space
    REG HEADER (TYPEO CFGBASE, 0, dev num, func num, 0, 0x30) = ((io base >> 16) <<
16) | (io base >> 16);//io limit/base upper 16bit
    REG_HEADER(TYPEO_CFGBASE, 0, dev_num, func_num, 0, 0x20) = ((mem_base >> 16) <<
```



```
16) | (mem_base >> 16);//mem limit/base
    //mem limit/base
    REG HEADER (TYPEO_CFGBASE, 0, dev num, func num, 0, 0x24) = ((pref mem base >> 16)
<< 16) | (pref mem base >> 16);
    /pref mem base upper 32bit
    REG_HEADER(TYPEO_CFGBASE, 0, dev_num, func_num, 0, 0x28) = 0x000000000;/
    //pref mem limit upper 32bit
    REG HEADER (TYPEO_CFGBASE, 0, dev num, func num, 0, 0x2c) = 0x000000000;
    //bridge control
    REG HEADER (TYPEO_CFGBASE, 0, dev num, func num, 0, 0x3c) = 0x20000;
    //pme int en, sys err f err en, sys err nf err en, sys err cor err en
    REG_HEADER(TYPEO_CFGBASE, 0, dev_num, func_num, 0, 0x8c) = 0xf;
    REG_HEADER (TYPEO_CFGBASE, 0, dev_num, func_num, 1, 0x2c) = 0x7;
    //set primary_busnum, 2nd_busnum and sub_busnum
    REG HEADER (TYPEO_CFGBASE, 0, dev num, func num, 0, 0x18) = (sub busnum << 16)
                                                       (second busnum \langle\langle 8\rangle \mid 0x0;
}
void cfg device read(
unsigned int bus_num,
unsigned int dev_num, unsigned int func_num,
unsigned int reg_id, unsigned int * read_data
)
{
    unsigned int reg_addrh, reg_addrl, reg_addr;
    reg_addr = reg_id << 2;
    reg_addrh = (reg_addr&0xf00) >> 8;
    reg addrl = reg addr&0xff;
    *(read data) = REG HEADER(TYPE1 CFGBASE, bus num, dev num, func num,
                              reg_addrh, reg_addrl);
void cfg_device_write(
unsigned int bus num,
unsigned int dev_num, unsigned int func_num,
unsigned int reg id, unsigned int write data
)
{
    unsigned int reg_addrh, reg_addrl, reg_addr;
    reg addr = reg id << 2;
    reg addrh = (reg addr&0xf00) >> 8;
    reg_addrl = reg_addr&0xff;
    REG_HEADER (TYPE1_CFGBASE, bus_num, dev_num,
                func_num, reg_addrh, reg_addrl) = write_data;
    }
```



# 37 DMA 控制器 (D30:F0)

## 37.1 DMA 控制器功能概述

2K2000 的 DMA 控制器实现数据访问格式可配置的多通道全地址空间的直接内存访问功能,目前可支持同时四通道数据搬运。控制器内部包括版本寄存器、中断使能、中断状态以及复位控制寄存器,可配置控制器的运行频率。各通道还拥有一组配置寄存器,用于配置描述符的地址信息、通道状态控制、停止模式、发送控制等。

描述符存在内存中,用于 DMA 控制器通道和 CPU 的控制交互,每个通道可配置地址连续的多个描述符,以 ring 的形式首尾相接。描述符分别定义源端和目的端的数据访问格式,包括基地址、访问跨步距离(stride)、数据宽度(size)、访问长度(length)、最大并发访问数量(outstanding)、访问总字节数(count)以及是否地址固定(fixed)、是否缓存(Cached)。

DMA 的传送数据的过程由三个阶段组成:

- a) 传送前的预处理:将描述符存在内存的指定位置,由 CPU 配置 DMA 描述符相关的寄存器。
  - b) 数据传送:将数据从读缓冲区搬运到写缓冲区,在DMA控制器的控制下自动完成。
  - c) 传送结束处理: 发送中断请求。

## 37.2 DMA 配置寄存器

DMA 控制器的 PCI 设备编号为(dev30, func0),可以通过配置总线设置 DMA 控制器寄存器的基地址。物理地址的低 12 位作为偏移访问配置寄存器。

### 37.2.1 控制器配置寄存器

#### (1) 版本寄存器(0x0000)

| 位域    | 字段名      | 访问 | 复位值    | 描述               |
|-------|----------|----|--------|------------------|
| 7:0   | Version  | R  | 8' h10 | 配置寄存器版本号         |
| 19:16 | Channels | R  | 4' h4  | DMA 通道数,最多 16 通道 |
| 47:32 | Reserved | RW | 16' b0 | 保留位              |

#### (2) 中断使能控制寄存器 (0x0010)

| 位域   | 字段名        | 访问 | 复位值    | 描述                   |
|------|------------|----|--------|----------------------|
| 31:0 | Int onable | RW | 32' b0 | 中断使能寄存器,每两位对应一个通道;   |
| 31:0 | Int_enable | KW | 32' b0 | 两位中的低位为超时中断,高位为描述符中断 |

### (3) 中断状态寄存器(0x0014)

| 位域   | 字段名        | 访问  | 复位值    | 描述                |
|------|------------|-----|--------|-------------------|
| 31:0 | Int_status | R/C | 32' b0 | 中断状态寄存器,每两位对应一个通道 |



| _   |  |  |          |
|-----|--|--|----------|
| - 1 |  |  |          |
| - 1 |  |  | F + )+ 0 |
|     |  |  |          |
|     |  |  |          |
| - 1 |  |  | 4 114    |

### (4) 复位控制寄存器(0x0018)

| 位 | 立域  | 字段名            | 访问 | 复位值    | 描述                                        |
|---|-----|----------------|----|--------|-------------------------------------------|
| 1 | 5:0 | Channel_res et | RW | 32' b0 | 复位控制,每1位对应一个通道<br>写1将各个通道的 this_ptr 复位为 0 |

### 37.2.2 通道配置寄存器

每个通道拥有一组配置寄存器,用于表示描述符信息。基地址从 0x100 开始,每个通道偏移增加 0x20,寄存器描述如下:

### (1) 基地址寄存器(偏移: 0x0000)

| 位域   | 字段名       | 访问 | 复位值    | 描述                |
|------|-----------|----|--------|-------------------|
| 63:0 | Ring_base | RW | 64' h0 | 描述符基地址,必须 16 字节对齐 |

#### (2) 指针寄存器(偏移: 0x0008)

| 位域    | 字段名      | 访问 | 复位值    | 描述                               |
|-------|----------|----|--------|----------------------------------|
| 15:0  | Last_ptr | RW | 16' b0 | 描述符最大指针,表示了描述符个数<br>(Last_ptr+1) |
| 31:16 | This_ptr | R  | 16' b0 | 当前描述符指针                          |

### (3) 超时中断设置寄存器(偏移: 0x000C)

| 位域    | 字段名              | 访问 | 复位值    | 描述                                       |
|-------|------------------|----|--------|------------------------------------------|
| 0     | Overtimer_<br>en | RW | 1' b0  | 使能超时中断                                   |
| 31:16 | Overtimer        | RW | 16' b0 | 超时时间设置,以16拍为单位。在取回一个无效描述符后开始计数,一旦超时就触发中断 |

### (4) 控制寄存器 (偏移: 0x0010)

| 位域 | 字段名         | 访问 | 复位值   | 描述                          |
|----|-------------|----|-------|-----------------------------|
|    |             |    |       | 启动/状态                       |
|    | D-11/       | DW | 1, 10 | 写1开始读取描述符;                  |
| 0  | Poll/status | RW | 1' b0 | 读到1表示本通道正在工作,读到0表示已经停       |
|    |             |    |       | 止                           |
|    |             |    |       | 停止模式控制                      |
| 1  | Stop_mode   | RW | 1' b0 | 0: 根据描述符状态自动停止              |
|    |             |    |       | 1: 根据停止指针停止                 |
| 2  | Dma_uncache | RW | 1' b0 | 使用 uncache 方式进行描述符读写        |
|    |             |    | 1' b0 | 等待响应控制                      |
| 3  | Wait man    | DW |       | 0: 描述符操作完成后直接读取下一个描述符       |
| 3  | Wait_resp   | RW |       | 1: 等待描述符 owner 写的响应后再读取下一个描 |
|    |             |    |       | 述符(建议当描述符数量较少且成 ring 时配置 1) |
| 4  | T1          | RW | 1, 10 | 要求发送端提供 req 信号              |
| 4  | Tx_ask_req* |    | 1' b0 | 0: 不需要发送端提供 req 信号          |



|       |             |    |        | 1: 需要发送端提供 req 信号             |
|-------|-------------|----|--------|-------------------------------|
|       |             |    |        | 要求接收端提供 req 信号                |
| 5     | Rx_ask_req* | RW | 1' b0  | 0: 不需要接收端提供 req 信号            |
|       |             |    |        | 1: 需要接收端提供 req 信号             |
| 21 10 | Stop_ptr    | RW | 16' b0 | 停止指针,当 Stop_mode 为 1 时,能够执行的最 |
| 31:16 |             |    |        | 后一个指针                         |

<sup>\*</sup>仅 CAN 控制器支持此功能

# 37.3 DMA 描述符

描述符存在内存中,用于 DMA 控制器通道和 CPU 的控制交互,可以配置为链式,也可配置为 ring 的形式首尾相接。每个通道开始运行时,从描述符基址读取描述符,当描述符运行结束后获取下一个描述符。通道指针寄存器的 last\_ptr,或者描述符内的 last\_des标记都规定了描述符链(环)的最后一个描述符,当该描述符执行完毕后,通道重新获取第0个描述符,this\_ptr 清零。停止模式为 0 时,通道一直运行直到取回一个无效的描述符(owner 位为 0)时停止操作,停止模式为 1 时,通道运行至 stop\_ptr 指定的位置停下。

每次 DMA 完成一个描述符对应的数据搬运操作后,会向描述符的 Owner 位写 0 表示该描述符已经完成。当通道获取到一个无效描述符时,重新启动 DMA 需要重新对通道控制寄存器执行 poll 操作,直到获取到一个有效的描述符。

每个描述符占32个字节,描述符信息表示如下。

#### (1) DESO (0x0000)

| (I) DD | DO (ONOCOO) |    |        |                                                                          |
|--------|-------------|----|--------|--------------------------------------------------------------------------|
| 位域     | 字段名         | 访问 | 复位值    | 描述                                                                       |
| 15:0   | Wait_time   | RW | 16' b0 | 每次从读缓冲区请求数据的间隔时间,以 16 拍为<br>单位                                           |
| 16     | Int_trigger | RW | 1' b0  | 描述符完成时触发中断使能                                                             |
| 17     | Last_des    | RW | 1' b0  | 表示 ring 的结尾,下一个描述符直接将 ptr 修改为 0 Last_des/Last_ptr 都可以表示 ring 的结束位置,以小的为准 |
| 31     | Owner       | RW | 1' b0  | 描述符状态 0: CPU 未填充 1: DMA 未完成                                              |

#### (2) DES1 (0x0004)

| 位域    | 字段名       | 访问 | 复位值    | 描述                                               |
|-------|-----------|----|--------|--------------------------------------------------|
| 15:0  | TX.stride | RW | 16' b0 | 每次写访问之间的跨步距离-1<br>(例:配置为 0xffff 代表跨步距离为 0x10000, |
|       |           |    |        | 下同)                                              |
| 31:16 | RX.stride | RW | 16' b0 | 每次读访问之间的跨步距离-1                                   |

#### (3) DES2 (0x0008)



| 位域    | 字段名         | 访问 | 复位值    | 描述                                                                            |
|-------|-------------|----|--------|-------------------------------------------------------------------------------|
| 0     | TX. fixed   | RW | 1' b0  | 写地址固定,不进行累加                                                                   |
| 1     | TX. cached  | RW | 1' b0  | 写地址为 Cached,维护一致性<br>当设置为 Cached 时,会自动合并处理                                    |
| 7:4   | TX. size    | RW | 4' b0  | 每次写时的 size (应该与地址对齐)<br>0: 1字节; 1: 2字节; 2: 4字节; 3: 8字节;<br>4: 16字节; 其他: 保留    |
| 11:8  | TX.length   | RW | 4' b0  | 每次读时的 length, 当 size 为 4 时有效, 其他情况均为 0 0: 1 拍; 1: 2 拍; 2: 3 拍; 3: 4 拍; 其他: 保留 |
| 15:12 | TX.outstand | RW | 4' h0  | 最大并发访问数量<br>0:1个;1:2个;2:3个;3:4个;其他:保<br>留                                     |
| 31:16 | TX. count   | RW | 16' b0 | 以 size 和 length 为单位的访问总字节数-1                                                  |

### (4) DES3 (0x000C)

| 位域    | 字段名          | 访问 | 复位值    | 描述                                                                            |
|-------|--------------|----|--------|-------------------------------------------------------------------------------|
| 0     | RX. fixed    | RW | 1' b0  | 读地址固定,不进行累加                                                                   |
| 1     | RX. cached   | RW | 1' b0  | 读地址为 Cached,维护一致性<br>当设置为 Cached 时,会自动合并处理                                    |
| 7:4   | RX. size     | RW | 4' b0  | 每次读时的 size (应该与地址对齐) 0: 1字节; 1: 2字节; 2: 4字节; 3: 8字节; 4: 16字节; 其他: 保留          |
| 11:8  | RX. length   | RW | 4' b0  | 每次读时的 length, 当 size 为 4 时有效, 其他情况均为 0 0: 1 拍; 1: 2 拍; 2: 3 拍; 3: 4 拍; 其他: 保留 |
| 15:12 | RX. outstand | RW | 4' h0  | 最大并发访问数量<br>0:1个;1:2个;2:3个;3:4个;其他:保<br>留                                     |
| 31:16 | RX. count    | RW | 16' b0 | 以 size 和 length 为单位的访问总字节数-1                                                  |

### (5) DES4 (0x0010)

| 位域   | 字段名      | 访问 | 复位值    | 描述      |
|------|----------|----|--------|---------|
| 63:0 | TX. addr | RW | 64' b0 | 写缓冲区基地址 |

### (6) DES6 (0x0018)

| 位域   | 字段名      | 访问 | 复位值    | 描述      |
|------|----------|----|--------|---------|
| 63:0 | RX. addr | RW | 64' b0 | 读缓冲区基地址 |

# 37.4 描述符配置约束和说明

(1)缓冲区基地址根据 size 向下对齐。如当 size 为 4 时,一次访问 16 个字节,基地



址后四位强制为0;

- (2)一次访问请求是指由描述符内 length 和 size 指定规格的数据读或者数据写访问, 单次访问请求字节数为 length</size;
- (3)总访问字节数(count+1)根据 length << size 进行对齐,向下取整倍数。即以单次访问请求的字节数作为单位,如 length2,size 为 4,则字节总数强制向下取整为 12的倍数;
  - (4) 跨步距离(stride+1) 同总访问字节数根据 length << size 向下取整倍数对齐;
- (5) 对于一个描述符所对应的 dma 传输,当发送了 tx. count+1 个字节数后视为 dma 完成。如果发送总访问字节数大于接收总访问字节数,那么以接收的总访问字节数作为发送的总访问字节数。

## 37.5 DMA 中断

DMA 控制器有两种中断:超时中断和描述符中断,每个通道均可通过使能位对中断进行 屏蔽或使能。响应中断后,可通过中断状态寄存器查询到中断源通道,并需要对中断状态寄 存器进行写清零操作。

### 37.5.1 超时中断

当通道取回一个无效的描述符后,通道超时计数器被激活。当计数值达到超时时间预设值的时,触发超时中断,提示软件控制器空闲,需要重新装填描述符。此时可以通过通道指针寄存器读取到当前描述符链行进的位置。在装填完描述符后,需要重新通过通道控制寄存器 poll 位获取新的描述符。在取回一个有效的描述符后,通道重新开始工作。

### 37.5.2 描述符中断

使能描述符中断不仅需要使能该通道的描述符中断,还需要再描述符的中断触发位配置为1。当描述符执行完成后,立即产生描述符中断。



## 修订记录

| 版本号    | 更新内容 |
|--------|------|
| V1. 03 | 发布版本 |

### 技术支持

可通过邮箱向我司提交芯片手册和产品使用的问题,并获取技术支持。

服务邮箱: service@loongson.cn

#### 串明

本文档版权归龙芯中科技术股份有限公司所有,未经许可不得擅自实施传播等侵害版权人合法权益的行为。

本文档仅提供阶段性信息,可根据实际情况进行更新,恕不另行通知。如因文档使用不当造成的直接或间接损失,本公司不承担任何责任。

#### 龙芯中科技术股份有限公司

 ${\tt Loongson}\ {\tt Technology}\ {\tt Corporation}\ {\tt Limited}$ 

地址:北京市海淀区中关村环保科技示范园龙芯产业园2号楼

Building No. 2, Loongson Industrial Park,

Zhongguancun Environmental Protection Park, Haidian District, Beijing

电话(Tel): 010-62546668 传真(Fax): 010-62600826