

# **LOONGSON**

# 龙芯 1C300 处理器用户手册

1.5版

2021年7月

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

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





# 阅读指南

《龙芯 1C300 处理器用户手册》主要介绍龙芯 1C300 的架构与寄存器描述。关于龙芯 1C300 处理器所集成的 GS232 高性能处理器核的相关资料,请参阅《龙芯 GS232 处理器用户手册》。龙芯 1C300 在本文档中简称龙芯 1C。



# 修订历史

| 日期         | 编辑    | 版本    | 变化                                                    |
|------------|-------|-------|-------------------------------------------------------|
| 2013-3-14  | 研发中心  | 0.0.1 | 初稿                                                    |
| 2013-3-16  | 研发中心  | 0.0.2 |                                                       |
| 2013-3-29  | 研发中心  | 0.0.3 | 补充 DWT、中断配置寄存器描述; CAMIF、<br>UART、OTG 等模块的描述修订         |
| 2013-4-15  | 研发中心  | 0.1   | 地址空间修订                                                |
| 2013-4-26  | 研发中心  | 0.2   |                                                       |
| 2014-2-12  | 研发中心  | 0.3   | 修改排版                                                  |
| 2014-2-28  | 研发中心  | 0.9   | 修改 1C2 改版之后的变动                                        |
| 2014-4-21  | 研发中心  | 1.0   | 增加引脚的上下拉说明<br>增加 SRAM 引脚描述以及修正部分错误<br>芯片名称更新为龙芯 1C300 |
| 2014-6-9   | 研发中心  | 1.1   | 修改手册 GPIO、DMA 等寄存器描述 bug                              |
| 2014-12-12 | 研发中心  | 1.2   | 修正中断位域、CPU 频率配置等寄存器描述<br>bug,修正看门狗基址                  |
| 2015-2-10  | 研发中心  | 1.3   | 修改手册 CAMERA 寄存器描述<br>去除 MAC 1588 支持的描述                |
| 2015-8-4   | 研发中心  | 1.4   | 修正 I2C 复用描述<br>修正 3.1 节中断寄存器部分地址                      |
| 2021-7-7   | 芯片研发部 | 1.5   | 修正表 2-1 中 PLL 配置和 NAND 大小的描述<br>修正部分文字错误,公司信息         |
|            |       |       |                                                       |

手册信息反馈: service@loongson.cn

# 目录

| 1 | 概述    | <u>)</u> |                                       | .10  |
|---|-------|----------|---------------------------------------|------|
|   | 1.1   | 体系结构     | 7框图                                   | .10  |
|   | 1.2   | 芯片主要     | 長功能                                   | . 11 |
|   |       | 1. 2. 1  | 处理器核                                  | 11   |
|   |       | 1. 2. 2  | SDRAM 控制器                             | 11   |
|   |       | 1. 2. 3  | SRAM/NOR FLASH 控制器                    | 11   |
|   |       | 1. 2. 4  | NAND 控制器                              |      |
|   |       | 1. 2. 5  | 时钟发生器                                 |      |
|   |       | 1. 2. 6  | I <sup>2</sup> S 控制器                  |      |
|   |       | 1. 2. 7  | AC97 控制器                              |      |
|   |       | 1. 2. 8  | LCD 控制器                               |      |
|   |       | 1. 2. 9  | Camera 接口                             |      |
|   |       | 1. 2. 10 | MAC 控制器                               |      |
|   |       | 1. 2. 11 | USB2. 0 控制器                           |      |
|   |       | 1. 2. 12 | SPI 控制器                               |      |
|   |       | 1. 2. 13 | 120 控制器                               |      |
|   |       | 1. 2. 14 | UART 控制器                              |      |
|   |       | 1. 2. 15 | GP10.                                 |      |
|   |       | 1. 2. 16 | PWM 控制器                               |      |
|   |       | 1. 2. 17 | RTC.                                  |      |
|   |       | 1. 2. 18 | CAN 控制器                               |      |
|   |       | 1. 2. 19 | SDIO 控制器                              |      |
|   |       | 1. 2. 20 | ADC 控制器                               |      |
| 2 | 引脚    |          | 1T:k3.HH                              |      |
| _ | 2.1   |          |                                       |      |
|   | 2.2   |          |                                       |      |
|   | 2.3   |          | -<br>接口                               |      |
|   | 2.4   |          | IOR FLASH接口                           |      |
|   | 2.5   |          | OKI BEN D                             |      |
|   | 2.6   |          |                                       |      |
|   | 2.7   | 1        | <del>[</del> П                        |      |
|   | 2.8   |          | 口                                     |      |
|   | 2.9   |          |                                       |      |
|   | 2.10  |          |                                       |      |
|   | 2.11  |          | ····································· |      |
|   | 2.12  |          | x 日A 接口                               |      |
|   | 2.13  |          | <b>安</b> 口                            |      |
|   | 2.14  |          | Д                                     |      |
|   | 2.15  |          |                                       |      |
|   | 2.16  |          |                                       |      |
|   | 2.17  |          | ]                                     |      |
|   | 2.17  |          |                                       |      |
|   | 2.19  |          | L F  7                                |      |
|   | 2.19  |          | 号                                     |      |
| 2 |       |          | 1 J                                   |      |
| J | 可付3.1 |          | ·                                     |      |
|   | 3.2   |          | F 存器定义                                |      |
| 1 |       |          | 「什价化义                                 |      |
|   | 4.1   |          |                                       |      |
|   | 4.1   | 町坪朱色     | J                                     | 33   |

|    | 4.2  | 时钟信号     | 说明                           | .33 |
|----|------|----------|------------------------------|-----|
| 5  | 芯片   | 配置与控     | 制                            | .34 |
|    | 5.1  | 地址空间     | 分配                           | .34 |
|    | 5.2  | 芯片配置     | 寄存器(CONFREG)                 | .35 |
|    |      |          | PLL/SDRAM 频率配置寄存器            |     |
|    |      |          | CPU/CAMERA/DC 频率配置寄存器        |     |
|    |      |          | SDRAM 参数寄存器                  |     |
|    |      |          | SHUT_CTRL 寄存器                |     |
|    |      |          | MISC_CTRL 寄存器                |     |
|    |      |          | cpu throt 寄存器                |     |
|    |      |          | UART 复用配置寄存器                 |     |
|    |      |          | GPI00 配置寄存器(对应 GPI0[31:0])   |     |
|    |      |          | GPI01 配置寄存器(对应 GPI0[63:32])  |     |
|    |      |          | GPI02 配置寄存器(对应 GPI0[95:64])  |     |
|    |      |          | GPI03 配置寄存器(对应 GPI0[127:96]) |     |
|    |      |          | PAD[31:0]引脚复用关系配置寄存器         |     |
|    |      |          | PAD[63:32]引脚复用关系配置寄存器        |     |
|    |      |          | PAD[95:64] 引脚复用关系配置寄存器       |     |
|    |      |          | PAD[127:96]引脚复用关系配置寄存器       |     |
|    | 5.3  |          | 寄存器                          |     |
|    |      |          |                              |     |
| Ŭ  | 6.1  |          | н                            |     |
|    | 6.2  |          | 述                            |     |
|    | 6.3  |          | 说明                           |     |
| 7  |      |          | . 90 /4                      |     |
| •  | 7.1  |          |                              |     |
|    | 7.2  |          | 哭<br>俗                       |     |
| 8  |      |          | н                            |     |
| Ū  | 8.1  |          |                              |     |
|    | 8.2  |          |                              |     |
|    | 8.3  |          | i述                           |     |
|    | 8.4  |          |                              |     |
|    | 0    |          | 访存方式                         |     |
|    |      |          | 配置顺序                         |     |
| 9  | I2S  |          | NO.E./W.                     |     |
| _  | 9.1  |          |                              |     |
|    | 9.2  | —        |                              |     |
|    | 9.3  |          | 哭                            |     |
|    | 9.4  |          |                              |     |
| 1( |      |          | 器(DC)                        |     |
| -  | 10.1 |          | , nn ( = - )                 |     |
|    | 10.2 |          | 义和说明                         |     |
|    |      | 10. 2. 1 | 帧缓冲配置寄存器                     |     |
|    |      |          | 帧缓冲地址寄存器 0                   |     |
|    |      |          | 帧缓冲地址寄存器 1                   |     |
|    |      | 10. 2. 4 | 帧缓冲跨度寄存器                     |     |
|    |      | 10. 2. 5 | 颜色抖动配置寄存器                    |     |
|    |      |          | 颜色抖动查找表低位寄存器                 |     |
|    |      |          | 颜色抖动查找表高位寄存器                 |     |
|    |      |          | 颜色抖动说明                       |     |
|    |      |          |                              | 74  |

|      |           | 水平显示宽度寄存器                                                                                                              |      |
|------|-----------|------------------------------------------------------------------------------------------------------------------------|------|
|      | 10. 2. 11 | 行同步配置寄存器                                                                                                               | . 74 |
|      | 10. 2. 12 | 垂直显示高度寄存器                                                                                                              | . 74 |
|      | 10. 2. 13 | 场同步配置寄存器                                                                                                               | . 75 |
|      |           | 输出定序说明                                                                                                                 |      |
|      |           | 伽马校正目录寄存器                                                                                                              |      |
|      |           | 伽马校正值寄存器                                                                                                               |      |
|      |           | 伽马校正说明                                                                                                                 |      |
| 11   | •         | 制器                                                                                                                     |      |
| 11.1 | •         | 存器描述                                                                                                                   |      |
|      | 11. 1. 1  | RegisterO (Bus Mode Register)                                                                                          |      |
|      | 11. 1. 2  | Register1 (Transmit Poll Demand Register)                                                                              |      |
|      | 11. 1. 3  | Register2 (Receive Poll Demand Register)                                                                               |      |
|      | 11. 1. 4  | Register3 (Receive Descriptor List Address Register)                                                                   |      |
|      | 11. 1. 5  | Register4 (Transmit Descriptor List Address Register)                                                                  |      |
|      | 11. 1. 6  | Register5 (Status Register)                                                                                            |      |
|      | 11. 1. 7  | Register6 (Operation Mode Register)                                                                                    |      |
|      | 11. 1. 8  | Register7 (Interrupt Enable Register)                                                                                  |      |
|      | 11. 1. 9  | Register8 (Missed Frame and Buffer Overflow Counter Register                                                           |      |
|      |           | Register9 (Receive Interrupt Watchdog Timer Register)                                                                  |      |
|      |           | Register10 (AXI Bus Mode Register)                                                                                     |      |
|      |           | Register11 (AXI Status Register)                                                                                       |      |
|      |           | Register18 (Current Host Transmit Descriptor Register)                                                                 |      |
|      |           | Register19 (Current Host Receive Descriptor Register)<br>Register20 (Current Host Transmit Buffer Address Register).   |      |
|      |           | Register20 (Current Host Transmit Buffer Address Register).  Register21 (Current Host Receive Buffer Address Register) |      |
| 11.2 |           | Registerzi (Gurrent nost Receive builer Address Register)<br>  制器寄存器描述                                                 |      |
| 11.4 | 11. 2. 1  | RegisterO (MAC Configuration Register)                                                                                 |      |
|      | 11. 2. 2  | Register1 (MAC Frame Filter)                                                                                           |      |
|      | 11. 2. 3  | Register2 (Hash Table High Register)                                                                                   |      |
|      | 11. 2. 4  | Register3 (Hash Table Low Register)                                                                                    |      |
|      | 11. 2. 1  | Register4 (GMII Address Register)                                                                                      |      |
|      | 11. 2. 2  | Register5 (GMII Data Register)                                                                                         |      |
|      | 11. 2. 3  | Register6 (Flow Control Register)                                                                                      |      |
|      | 11. 2. 4  | Register7 (VLAN Tag Register)                                                                                          |      |
|      | 11. 2. 5  | Register8 (Version Register)                                                                                           | . 96 |
|      | 11. 2. 6  | Register14 (Interrupt Status Register)                                                                                 | . 97 |
|      | 11. 2. 7  | Register15 (Interrupt Mask Register)                                                                                   | . 98 |
|      | 11. 2. 8  | Register16 (MAC AddressO High Register)                                                                                |      |
|      | 11. 2. 9  | Register17 (MAC AddressO Low Register)                                                                                 |      |
|      |           | Register18 (MAC Address1 High Register)                                                                                |      |
|      |           | Register19 (MAC Address1 Low Register)                                                                                 |      |
|      |           | Register48 (AN Control Register)                                                                                       |      |
|      |           | Register49 (AN Status Register)                                                                                        |      |
|      |           |                                                                                                                        |      |
|      |           | Register51 (Auto-Negotiation Link Partner Ability Register)                                                            |      |
|      |           | Register52 (Auto-Negotiation Expansion Register)                                                                       |      |
|      |           | Register54 (SGMII/RGMII Status Register)                                                                               |      |
|      |           | Register448 (Time Stamp Control Register)                                                                              |      |
|      |           | Register449 (Sub-Second Increment Register)                                                                            |      |
|      | 11 7 70   | Register 450 (System Time - Seconds Register)                                                                          | 106  |



|      | 11.2.21 Register 451 (System Time - Nanoseconds Register)                   | 106   |
|------|-----------------------------------------------------------------------------|-------|
|      | 11.2.22 Register 452 (System Time - Seconds Update Register)                | 107   |
|      | 11.2.23 Register 453 (System Time - Nanoseconds Update Register)            | 107   |
|      | 11.2.24 Register 454 (Time Stamp Addend Register)                           | 107   |
|      | 11.2.25 Register 455 (Target Time Seconds Register)                         | 107   |
|      | 11.2.26 Register 456 (Target Time Nanoseconds Register)                     | 107   |
|      | 11.2.27 Register 457 (System Time - Higher Word Seconds Register)           | 108   |
|      | 11.2.28 Register 458 (Time Stamp Status Register)                           | 108   |
|      | 11.2.29 Register 459 (PPS Control Register)                                 | 109   |
|      | 11. 2. 30 Register 460 (PPS Auxiliary Time Stamp - Nanoseconds Regis<br>109 | ter)  |
|      | 11.2.31 Register 461 (PPS Auxiliary Time Stamp - Seconds Register).         | 109   |
| 11.3 | DMA 描述符                                                                     |       |
|      | 11.3.1 DMA 描述符的基本格式                                                         | 110   |
|      | <b>11.3.2</b> DMA 接收描述符                                                     | 110   |
|      | 11.3.2.1 RDES0                                                              | . 111 |
|      | 11.3.2.2 RDES1                                                              | . 113 |
|      | 11.3.2.3 RDES2                                                              | . 113 |
|      | 11.3.2.4 RDES3                                                              | . 114 |
|      | 11.3.3 DMA 发送描述符                                                            | 114   |
|      | 11.3.3.1 TDES0                                                              | . 114 |
|      | 11.3.3.2 TDES1                                                              | . 116 |
|      | 11.3.3.3 TDES2                                                              | . 117 |
|      | 11.3.3.4 TDES3                                                              | . 117 |
| 11.4 | 软件编程向导                                                                      | 118   |
| 12   | USB 控制器                                                                     | .120  |
| 12.1 | 总体概述                                                                        | 120   |
| 12.2 | USB 主机控制器寄存器                                                                | 120   |
|      | <b>12.2.1</b> EHCI 相关寄存器                                                    | 120   |
|      | <b>12.2.2</b> Capability 寄存器                                                | 121   |
|      | <b>12.2.3</b> Operational 寄存器                                               | 121   |
|      | <b>12.2.4</b> EHCI 实现相关寄存器                                                  | 122   |
| 12.3 | OHCI 相关寄存器                                                                  | 124   |
|      | <b>12.3.1</b> Operational 寄存器                                               | 124   |
|      | 12.3.2 OHCI 实现相关寄存器                                                         | 125   |
| 13   | OTG 控制器                                                                     | .127  |
| 13.1 | 概述                                                                          | 127   |
| 13.2 | 寄存器描述                                                                       | 127   |
|      | <b>13.2.1</b> 全局控制与状态寄存器(Global CSR Map)                                    | 128   |
|      | <b>13.2.2</b> Host 模式控制与状态寄存器(Host Mode CSR)                                | 129   |
|      | <b>13.2.3</b> Device 模式控制与状态寄存器(Device Mode CSR)                            | 129   |
|      | 13.2.4 数据 FIFO 访问寄存器组(DFIFO Access Register MAP)                            | 130   |
|      | 13.2.5 功耗控制与门控时钟寄存器组(Power and Clock Gating CSR Map)                        | 131   |
| 13.3 | 寄存器描述                                                                       | 131   |
|      | <b>13.3.1</b> 寄存器访问特性                                                       | 131   |
|      | 13.3.2 全局寄存器                                                                | 131   |
|      | <b>13.3.3</b> Host 模式寄存器                                                    | 156   |
|      | <b>13.3.4</b> Device 模式寄存器                                                  | 167   |
|      | <b>13.3.5</b> 功耗与门控时钟寄存器                                                    | 182   |
| 14   | 通用 DMA                                                                      | .183  |
| 1/11 | DMA 控制哭结构描述                                                                 | 183   |



| 14.2 | DMA 寄     | 存器                                    | 184  |
|------|-----------|---------------------------------------|------|
|      | 14. 2. 1  | ORDER_ADDR_IN                         | 184  |
|      | 14. 2. 2  | DMA ORDER ADDR                        |      |
|      | 14. 2. 3  | DMA_SADDR                             | 185  |
|      | 14. 2. 4  | DMA_DADDR                             |      |
|      | 14. 2. 5  | DMA LENGTH                            |      |
|      | 14. 2. 6  | DMA_STEP_LENGTH                       |      |
|      | 14. 2. 7  | DMA_STEP_TIMES                        |      |
|      | 14. 2. 8  | <br>DMA_CMD                           |      |
| 14.3 | 多个模块      | 央使用 DMA 配置说明                          |      |
| 15   |           | 制器                                    |      |
| 15.1 |           | 器结构                                   |      |
| 15.2 |           | 子器                                    |      |
|      | 15. 2. 1  | ·····<br>控制寄存器(SPCR)                  |      |
|      | 15. 2. 2  | 状态寄存器 (SPSR)                          |      |
|      | 15. 2. 3  | 数据寄存器(TxFIF0/RxFIF0)                  |      |
|      | 15. 2. 4  | 外部寄存器 (SPER)                          |      |
|      | 15. 2. 5  | 参数控制寄存器 (SFC_PARAM)                   |      |
|      | 15. 2. 6  | 片选控制寄存器(SFC_SOFTCS)                   |      |
|      | 15. 2. 7  | 时序控制寄存器(SFC_TIMING)                   |      |
| 15.3 | 接口时序      | · · · · · · · · · · · · · · · · · · · |      |
|      |           | SPI 主控制器接口时序                          |      |
|      |           | SPI Flash 访问时序                        |      |
| 15.4 |           | 到                                     |      |
|      | 15. 4. 1  |                                       |      |
|      | 15. 4. 2  | 硬件 SPI Flash 读                        |      |
|      | 15. 4. 3  | 混合访问 SPI Flash 和 SPI 主控制器             |      |
| 16   | SPI1 控    | 制器                                    |      |
| 16.1 | SPI 主控    | 制器结构                                  | 194  |
| 17   | AC97 控    | 制器                                    | .195 |
| 17.1 | 概述(1C     | 2 无该模块)                               | 195  |
| 17.2 | AC97 控    | 制器寄存器                                 | 195  |
|      | 17. 2. 1  | CSR 寄存器                               | 196  |
|      | 17. 2. 2  | <b>0CC</b> 寄存器                        | 196  |
|      | 17. 2. 3  | ICC 寄存器                               | 197  |
|      | 17. 2. 4  | Codec 寄存器访问命令                         | 197  |
|      | 17. 2. 5  | 中断状态寄存器/中断掩膜寄存器                       | 198  |
|      | 17. 2. 6  | 中断状态/清除寄存器                            | 198  |
|      | 17. 2. 7  | <b>0C</b> 中断清除寄存器                     | 198  |
|      | 17. 2. 8  | IC 中断清除寄存器                            | 199  |
|      | 17. 2. 9  | CODEC WRITE 中断清除寄存器                   | 199  |
|      | 17. 2. 10 | CODEC READ 中断清除寄存器                    | 199  |
| 18   | I2C 控制    | 器                                     | .200 |
| 18.1 | 概述        |                                       | 200  |
| 18.2 | I2C 控制    | 器结构                                   | 200  |
| 18.3 | I2C 控制    | 器寄存器说明                                | 200  |
|      | 18. 3. 1  | 分频锁存器低字节寄存器(PRERIo)                   | 201  |
|      | 18. 3. 2  | 分频锁存器高字节寄存器(PRERhi)                   | 201  |
|      | 18. 3. 3  | 控制寄存器 (CTR)                           | 201  |
|      | 18. 3. 4  | 发送数据寄存器 (TXR)                         | 201  |
|      | 18. 3. 5  | 接受数据寄存器(RXR)                          | 202  |



|      | 18. 3. 6               | 命令控制寄存器 (CR)                          | 202        |
|------|------------------------|---------------------------------------|------------|
|      | 18. 3. 7               | 状态寄存器 (SR)                            | 202        |
| 19   | UART 挖                 | 2制器                                   | 204        |
| 19.1 | 概述                     |                                       | 204        |
| 19.2 | 控制器组                   | 告构                                    | 204        |
| 19.3 | UARTO S                | SPLIT 配置说明                            | 205        |
| 19.4 | 寄存器指                   | 错述                                    | 206        |
|      | 19. 4. 1               | 数据寄存器(DAT)                            | 206        |
|      | 19. 4. 2               | 中断使能寄存器(IER)                          | 206        |
|      | 19. 4. 3               | 中断标识寄存器(IIR)                          | 207        |
|      | 19. 4. 4               | FIFO 控制寄存器 (FCR)                      | 207        |
|      | 19. 4. 5               | 线路控制寄存器 (LCR)                         | 208        |
|      | 19. 4. 6               | MODEM 控制寄存器(MCR)                      | . 208      |
|      | 19. 4. 7               | 线路状态寄存器 (LSR)                         | 209        |
|      | 19. 4. 8               | MODEM 状态寄存器 (MSR)                     | . 210      |
|      | 19. 4. 9               | 分频锁存器                                 | 210        |
| 19.5 | USART                  | 寄存器描述                                 | 210        |
|      | 19. 5. 1               | 控制寄存器 (CR)                            | . 210      |
|      | 19. 5. 2               | 模式寄存器 (MR)                            | 211        |
|      | 19. 5. 3               | FI/DI 参数寄存器(FIDIR)                    | . 211      |
| 20   | NAND <b></b> 担         | 空制器                                   | 212        |
| 20.1 |                        | 空制器结构描述                               |            |
| 20.2 | NAND ‡                 | 空制器寄存器配置描述                            | 212        |
|      | 20. 2. 1               | 命令寄存器(NAND_CMD)                       |            |
|      | 20. 2. 2               | 页内偏移地址寄存器(ADDR_C)                     |            |
|      | 20. 2. 3               | 页地址寄存器(ADDR_R)                        |            |
|      | 20. 2. 4               | 时序寄存器 (NAND_TIMING)                   |            |
|      | 20. 2. 5               | ID 寄存器(ID_L)                          |            |
|      | 20. 2. 6               | ID 和状态寄存器(STATUS & ID_H)              |            |
|      | 20. 2. 7               | 参数配置寄存器(NAND_PARAMETER)               |            |
|      | 20. 2. 8               | 操作数量寄存器(NAND_OP_NUM)                  |            |
|      | 20. 2. 9               | 映射寄存器 (CS_RDY_MAP)                    |            |
|      |                        | DMA 读写数据寄存器 (DMA_ADDRESS)             |            |
| 20.3 |                        | ADDR 说明                               |            |
| 20.4 |                        | ASH 读写操作举例                            |            |
| 20.5 |                        | CC 说明                                 |            |
| 20.6 |                        | SOOT 说明                               |            |
| 21.1 |                        |                                       |            |
| 21.1 |                        | 描述                                    |            |
| 21.2 | 可行命<br><b>21. 2. 1</b> | ************************************* |            |
|      |                        | SYS_TOYWRITEO.                        |            |
|      |                        | SYS_TOYWRITE1                         |            |
|      | 21. 2. 3               | SYS_TOYREADO                          |            |
|      | 21. 2. 4               | SYS_TOYREAD0 SYS_TOYREAD1             |            |
| 22   |                        | 制器                                    |            |
| 22.1 | 功能概划                   |                                       |            |
| 22.1 |                        | ····································· |            |
| 22.2 |                        |                                       |            |
| 22.4 |                        | z说明                                   |            |
| 22.7 |                        | SD Memory 卡软件编程说明                     | 232<br>232 |

|      | <b>22.4.2</b> SDIO 卡软件编程说明       | 234 |
|------|----------------------------------|-----|
| 23   | CAN 控制器                          | 236 |
| 23.1 | 概述                               | 236 |
| 23.2 | CAN 控制器结构                        | 236 |
| 23.3 | 标准模式                             | 237 |
|      | 23.3.1 标准模式地址表                   | 237 |
|      | 23.3.2 控制寄存器 (CR)                | 238 |
|      | <b>23.3.3</b> 命令寄存器(CMR)         | 239 |
|      | 23.3.4 状态寄存器 (SR)                | 239 |
|      | 23.3.5 中断寄存器(IR)                 | 239 |
|      | 23.3.6 验收代码寄存器(ACR)              | 240 |
|      | <b>23.3.7</b> 验收屏蔽寄存器(AMR)       | 240 |
|      | 23.3.8 发送缓冲区列表                   | 240 |
|      | 23.3.9 接收缓冲区列表                   | 241 |
| 23.4 | 扩展模式                             | 241 |
|      | 23.4.1 扩展模式地址表                   | 241 |
|      | 23.4.2 模式寄存器(MOD)                | 241 |
|      | 23.4.3 命令寄存器 (CMR)               | 242 |
|      | <b>23.4.4</b> 状态寄存器(SR)          | 242 |
|      | <b>23.4.5</b> 中断寄存器(IR)          | 243 |
|      | <b>23.4.6</b> 中断使能寄存器(IER)       | 243 |
|      | <b>23.4.7</b> 仲裁丢失捕捉寄存器(IER)     | 243 |
|      | <b>23.4.8</b> 错误警报限制寄存器(EMLR)    | 244 |
|      | <b>23.4.9</b> RX 错误计数寄存器(RXERR)  | 245 |
|      | <b>23.4.10</b> TX 错误计数寄存器(TXERR) | 245 |
|      | 23.4.11 验收滤波器                    | 245 |
|      | <b>23.4.12</b> RX 信息计数寄存器(RMCR)  | 245 |
| 23.5 | 公共寄存器                            | 245 |
|      | 23.5.1 总线定时寄存器 0 (BTR0)          | 245 |
|      | 23.5.2 总线定时寄存器 1(BTR1)           | 245 |
|      | 23.5.3 输出控制寄存器(0CR)              | 246 |
| 24   | ADC 控制器                          | 247 |
| 24.1 | 概述                               | 247 |
| 24.2 | 寄存器描述                            | 247 |
| 24.3 | 配置操作                             | 252 |
| 25   | PWM 控制器                          | 255 |
| 25.1 | 概述                               |     |
| 25.2 | PWM 寄存器说明                        | 255 |
| 26   | 看门狗(WDT)                         | 258 |
| 26.1 | 概述                               | 258 |
| 26.2 | WATCH DOG 寄存器描述                  | 258 |
|      | <b>26.2.1</b> 看门狗使能寄存器(WDT_EN)   | 258 |
|      | <b>26.2.2</b> 看门狗设置寄存器(WDT_SET)  |     |
|      | <b>26.2.3</b> 看门狗计数器(WDT_timer)  |     |
| 27   | 高精度定时器(HCNTR)                    | 260 |
| 27.1 | 概述                               | 260 |
| 27.2 | 安方思世决                            | 260 |



# 图目录

| 图 1-1 力 | 龙芯 1C 结构图                  | 10  |
|---------|----------------------------|-----|
| 图 4-1 差 | 系统时钟结构                     | 33  |
| 图 8-1 ( | Camera 接口(CAMIF)功能框图       | 59  |
| 图 8-2   | ITU-R BT.601 输入时序          | 60  |
| 图 8-3   | ITU-R BT.656 输入时序          | 60  |
| 图 8-4   | 存储方式                       | 65  |
| 图 9-1   | I2S 接口框图                   | 68  |
| 图 9-2   | I2S 传输协议                   | 68  |
| 图 10-1  | 显示控制器输出定序                  | 75  |
| 图 11-1  | DMA 描述符的基本格式 (小尾端 32 位总线)  | 110 |
| 图 11-2  | DMA 描述符的基本格式 (小尾端 64 位总线)  | 110 |
| 图 11-3  | DMA 接收描述符的基本格式(小尾端 32 位总线) | 111 |
| 图 11-4  | DMA 发送描述符的基本格式(小尾端 32 位总线) | 114 |
| 图 12-1  | USB 主机控制器模块图               | 120 |
| 图 13-1  | OTG CSRs 地址映射              | 128 |
| 图 15-1  | SPI 控制器结构                  | 188 |
| 图 15-2  | SPI 主控制器接口时序               | 190 |
| 图 15-3  | SPI Flash 标准读时序            | 191 |
| 图 15-4  | SPI Flash 快速读时序            | 191 |
| 图 15-5  | SPI Flash 双向 I/0 读时序       | 191 |
| 图 17-1  | AC97 应用系统                  | 195 |
| 图 18-1  | I2C 主控制器结构                 | 200 |
| 图 19-1  | UART 控制器结构                 | 205 |
| 图 21-1  | RTC 结构框图                   | 220 |
| 图 22-1  | SD 卡多块写操作示意图               | 224 |
| 图 22-2  | SD 卡多块读操作示意图               | 224 |
| 图 22-3  | SD Memory 卡初始化流程示意图        | 233 |
| 图 23-1  | CAN 主控制器结构                 | 237 |
| 图 24-1  | ADC 单次转换/连续转换示意图           | 254 |
| 图 26-1  | 看门狗结构图                     | 258 |



# 表目录

| 表 2-1 信号类型代码              | 16  |
|---------------------------|-----|
| 表 4-1 龙芯 1C 时钟信号          |     |
| 表 8-1 ITU-R BT. 656 基准码   | 60  |
| 表 8-2 第四个字节 XY 值          | 61  |
| 表 15-6 SPI 分频系数           | 189 |
| 表 19-1 UART split 配置及功能复用 | 205 |
| 表 20-1 NAND 地址空间示意图       | 216 |
| 表 22-1 SD 模式下命令格式         | 224 |



# 1 概述

龙芯 1C300(以下简称 1C)芯片是基于 GS232 处理器核的高性价比单芯片系统,可应用于指纹生物识别、物联传感等领域。

1C 包含浮点处理单元,可以有效增强系统浮点数据处理能力。1C 的内存接口,支持多种类型的内存,允许灵活的系统设计。支持 8-bit SLC NAND 或 MLC NAND FLASH,提供高容量的存储扩展接口。

1C 为开发者提供了丰富的外设接口及片上模块,包括 Camera 控制器,USB OTG 2.0 及 USB HOST 2.0 接口,AC97/I2S 控制器,LCD 控制器,ADC 控制器,高速 SPI 接口,全功能 UART 接口等,提供足够的计算能力和多应用的连接能力。片上集成 RTC 功能,可用于实时显示时间。

## 1.1 体系结构框图

龙芯 IC 内部采用多级总线结构。处理器核、内存控制器、图形显示控制器、CAMERA 接口模块和 AXI\_MUX 使用交叉开关互连。OTG、MAC、USB、DMA 控制器、SPI 通过 AXI\_MUX 连接至交叉开关。低速外设(I2C、I2S、PWM、UART等)通过 AXI2APB 连接至交叉开关。



图 1-1 龙芯 1C 结构图

## 1.2 芯片主要功能

### 1.2.1 处理器核

- 单核心 GS232, MIPS32 指令集兼容, 主频 300MHZ
- 支持高效双发射(一个时钟节拍执行两条指令)技术
- 支持寄存器重命名、动态调度、转移预测等乱序发射、乱序执行技术
- 五级流水线(取指、译码、发射、执行并写回、提交)微体系结构
- 16KB 数据 cache 和 16KB 指令 cache
- 集成 64 位浮点处理部件,支持全流水的 64 位浮点加法和浮点乘法运算,硬件实现浮点除法运算

### 1.2.2 SDRAM 控制器

- SDRAM 接口,工作频率 45~133MHz
- 支持 8/16 位并行数据总线宽度
- 支持自动刷新和自刷新功能,支持页面模式

## 1.2.3 SRAM/NOR FLASH 控制器

- SRAM 以及 NOR Flash 直连接口,工作频率 66~133MHz
- 支持静态存储器片选引脚,可以单独配置
- 支持 8bit/16bit 并行数据总线宽度

## 1.2.4 NAND 控制器

- 最大支持单颗容量为 4GB NAND FLASH
- 支持 512 字节、2K 字节页、4K 字节页和 8K 字节页类型 FLASH
- 硬件 ECC 生成、检测和指示(软件纠错)
- 支持 FLASH 数据读取速度 8~10MB/S,写入速度 5MB/s
- 支持从 NAND Flash 启动
- 支持小尾端模式

#### 1.2.5 时钟发生器

- 1 个标准 PLL 输入接口,支持外部无源晶体作为芯片时钟输入
- 支持片内输出可配置时钟一路,供片外外设使用
- PLL 频率软件可配置

#### 1.2.6 I<sup>2</sup>S 控制器

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

#### 1.2.7 AC97 控制器

- 可变采样率 AC97 编解码器接口(48KHz 及以下)
- 支持立体声 PCM 和单声道 MIC 输入
- 支持 2 通道立体声 PCM 输出
- 支持 DMA 和中断操作
- 支持 16、18 和 20 位采样精度,支持可变速率
- 支持 16 位、16 个入口 FIFO 每通道

#### **1.2.8** LCD 控制器

- 支持 16/24 位像素模式
- 支持 RGB444/555/565/888 显示输出
- 支持 1024x768、800x600、640×480、320×240 分辨率
- 支持 DMA 传输模式

#### **1.2.9** Camera 接口

- 支持 ITU-R BT.601/656 8 位输入
- 支持 RAW RGB、RGB565 及 YUV4:2:2 数据输入
- 支持 YUV、RGB888、RGB0888、RGB565 输出

- 支持 320x240 和 640x480 分辨率缩放
- 支持最大 2Kx2K 分辨率输入,分辨率可配置
- 支持 DMA 传输模式

## 1.2.10 MAC 控制器

- 支持 10/100Mbps PHY 器件,包括 10 Base-T、100 Base-TX、100 Base-FX 和 100 Base-T4;
- 完全兼容 IEEE 标准 802.3
- 完全兼容 802.3x 全双工流控和半双工背压流控
- 支持 VLAN 帧
- 支持 DMA 传输模式
- 支持标准的媒体独立接口(MII)
- 支持标准的简化 MII 接口(RMII)可连接外部 PHY 芯片

#### 1.2.11 USB2.0 控制器

- 1 个 USB OTG 2.0 控制器
- 1 个 USB HOST 2.0 控制器
- 支持高速和全速模式
- 支持 DMA 传输模式
- 兼容 USB Rev 1.1 、USB Rev 2.0 协议

#### 1.2.12 SPI 控制器

- 支持两路独立 SPI 接口,每路 SPI 接口均支持 4 个片选
- 遵循串行外设接口(SPI)规范
- 支持同步、串行、全双工通信
- 支持 SPI 主模式
- 每次传输8位
- 支持查询、中断传输模式
- 支持 SPI nor flash 启动
- 支持 SPI 接口双向输入输出,最高数据传输速度 24~96 Mbps
- 支持最低速率通讯要求,速率达 25KB 以下,方便匹配特殊设备。

#### **1.2.13** I<sup>2</sup>C 控制器

- 三路标准 I2C 总线接口
- 支持主、从、或主/从模式配置
- 总线的时钟频率可编程

#### 1.2.14 UART 控制器

- 支持两个全功能串口,其中全功能串口0可复用为4个两线串口或2 个4线串口,支持智能卡协议
- 基于中断操作的 RxD0, TxD0, RxD1, TxD1, RxD2 和 TxD2;
- UART 通道 0, 1 和 2 带 IrDA 1.0
- UART 通道 0 和 1 带 RTS0, CTS0, RTS1 和 CTS1

#### **1.2.15** GPIO

- 最多支持 105 个 GPIO
- 所有 GPIO (启动和系统配置除外) 在复位后默认为输入
- 所有 GPIO 支持中断功能
- 每个 GPIO 管脚均支持电平触发、边沿触发模式,可独立配置
- GPIO 管脚速率可达 4MHz

## 1.2.16 PWM 控制器

- 4路32位可配置PWM定时器
- 支持定时器功能
- 支持计数器功能

### 1.2.17 RTC

- 计时精确到 0.1 秒
- 支持外部无源晶体作为 RTC 时钟输入
- 支持外部电池供电运行,断电后由电池供电
- 专门的电源管脚,可以与电池或者 3.3V 主电源相连
- 提供秒、分、时、日、月、年



## 1.2.18 CAN 控制器

- 2路独立 CAN 控制器
- 兼容 CAN2.0A 和 CAN2.0B 协议(PCA82C200 兼容模式中的无源 扩展帧)
- 支持 CAN 协议扩展
- 位速率可达 1Mbits/s

## 1.2.19 SDIO 控制器

- 1路独立 SDIO 控制器
- 兼容 SD Memory 2.0/MMC/SDIO 2.0 协议
- 支持 SDIO 启动

## **1.2.20** ADC 控制器

- 采样率最高 1MHz
- 4 路 ADC 输入
- 支持 4 线和 5 线触摸屏
- 支持连续采样和单次采样
- 支持模拟看门狗



# 2 引脚定义

## 2.1 约定

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

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

表 2-1 信号类型代码

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

## 2.2 LCD 接口

| 信号名称          | 类型 | 上下拉 | 描述         |
|---------------|----|-----|------------|
| LCD_CLK       | О  | PU  | LCD 时钟信号   |
| LCD_HSYNC     | О  | PU  | LCD 水平同步信号 |
| LCD_VSYNC     | О  | PU  | LCD 垂直同步信号 |
| LCD_EN        | О  | PU  | LCD 使能信号   |
| LCD_DAT[15:0] | О  | PU  | LCD 数据信号   |

【注】在 QFP100 封装下,LCD 接口不能用。在 QFP176 封装下,LCD 可以用 16 位和 24 位模式。16 位模式下引脚不需要复用;在 24 位模式下,低位需要复用 CAM\_DAT[7:0]或者 MAC 信号。

# 2.3 SDRAM 接口

| 信号名称    | 类型 | 上下拉 | 描述                 |
|---------|----|-----|--------------------|
| SD_CLK  | 0  | -   | SDRAM 时钟信号         |
| SD_CKE  | О  | -   | SDRAM 时钟使能信号       |
| SD_CSn  | О  | -   | SDRAM 片选信号,低电平有效   |
| SD_RASn | О  | -   | SDRAM 行选通信号, 低电平有效 |
| SD_CASn | О  | -   | SDRAM 列选通信号, 低电平有效 |



| SD_WE         | О   | - | SDRAM 读写信号, 低电平为写              |
|---------------|-----|---|--------------------------------|
| SD_BA[1:0]    | О   | - | SDRAM 的 Bank 信号,一共 4 个<br>Bank |
| SD_ADDR[12:0] | О   | - | SDRAM 地址信号                     |
| SD_DATA[15:0] | I/O | - | SDRAM 数据信号                     |
| SD_DQM[1:0]   | О   |   | SDRAM 数据屏蔽信号                   |

# 2.4 SRAM/NOR Flash 接口

| 信号名称            | 类型  | 上下拉 | 描述                 |
|-----------------|-----|-----|--------------------|
| SRAM_CSn        | О   | -   | SRAM 片选信号,低点平有效    |
| SRAM_WEn        | О   | -   | SRAM 写使能信号,低电平有效   |
| SRAM_OEn        | О   | -   | SRAM 读使能信号,低电平有效   |
| SRAM_OEn        | О   | -   | SRAM 读使能信号,低电平有效   |
| SRAM_DATA[15:0] | I/O | -   | SRAM 数据信号          |
| SRAM_BHE        | О   |     | SRAM 高 Byte 数据有效信号 |
| SRAM_BLE        | О   |     | SRAM 低 Byte 数据有效信号 |

## 2.5 I2S 接口

| 信号名称     | 类型 | 上下拉 | 描述           |
|----------|----|-----|--------------|
| I2S_MCLK | О  | PU  | I2S 时钟信号     |
| I2S_BCLK | О  | PU  | I2S 比特位时钟信号  |
| I2S_LRCK | О  | PU  | I2S 通道选择信号   |
| I2S_DI   | I  | PU  | I2S 数据串行输入信号 |
| I2S_DO   | О  | PU  | I2S 数据串行输出信号 |

【注】在 QFP100 封装下, I2S 接口没有引出来, 需要和 MAC 引脚复用。在 QFP176 封装下, I2S 接口引出来了,可以直接使用。

# 2.6 I2C 接口

| 信号名称         | 类型  | 上下拉 | 描述                    |
|--------------|-----|-----|-----------------------|
| I2C[2:0]_SCL | О   | PU  | I²C 串行时钟              |
| I2C[2:0]_SDA | I/O | PU  | I <sup>2</sup> C 串行数据 |

【注】在 QFP100 封装下, I2C 接口都没有引出来; QFP176A 封装下引出了 I2C0, 其它的需要通过复用引出。



## 2.7 UART接口

| 信号名称      | 类型 | 上下拉 | 描述            |
|-----------|----|-----|---------------|
| UART0_TX  | О  | PU  | UART0 数据发送    |
| UART0_RX  | I  | PU  | UART0 数据接收    |
| UART0_RTS | I  | PU  | UART0 请求接收    |
| UART0_CTS | I  | PU  | UART0 允许接收    |
| UART0_DSR | I  | PU  | UARTO 设备准备好   |
| UART0_DTR | О  | PU  | UART0 数据终端准备好 |
| UART0_DCD | I  | PU  | UART0 载波检测    |
| UART0_RI  | I  | PU  | UART0 振铃提示    |

【注】在 QFP100 封装下,无全功能串口,只有两线式。在 QFP176D 封装下,全功能串口可直接使用。

## 2.8 PWM 接口

| 信号名称 | 类型 | 上下拉 | 描述        |
|------|----|-----|-----------|
| PWM0 | О  | PU  | PWM0 脉冲输出 |
| PWM1 | О  | PU  | PWM1 脉冲输出 |
| PWM2 | О  | 未引出 | PWM2 脉冲输出 |
| PWM3 | О  | 未引出 | PWM3 脉冲输出 |

【注】在 QFP100 封装下,PWM 没有引出来,需要和其它复用。在 QFP176 封装下,PWM0 和 PWM1 可直接使用,PWM2 和 PWM3 需要和其它复用。

# 2.9 ADC 接口

| 信号名称     | 类型 | 上下拉 | 描述                  |
|----------|----|-----|---------------------|
| ADC_REXT | I  | -   | ADC 参考电阻            |
| ADC_VREF | I  | -   | ADC 参考电压            |
| ADC_VDDA | I  | -   | ADC 模拟电源            |
| ADC_VSSA | I  | -   | ADC 模拟地             |
| ADC_D0   | I  | -   | ADC 第 0 通道采样输入      |
| ADC_D1   | I  | -   | ADC 第 1 通道采样输入      |
| ADC_XP   | I  | _   | 触摸屏 X+/ADC 第2通道采样输入 |
| ADC_YP   | I  | _   | 触摸屏Y+/ADC第3通道采样输入   |

【注】AD接口仅在QFP176A封装下可用。



## 2.10 SPI 接口

| 信号名称         | 类型 | 上下拉 | 描述         |
|--------------|----|-----|------------|
| SPI_SCK      | О  | PU  | SPI 时钟输出   |
| SPI[3:0]_CSn | О  | PU  | SPI 片选 0~3 |
| SPI_MOSI     | О  | PD  | SPI 数据输出   |
| SPI_MISO     | I  | PD  | SPI 数据输入   |

# 2.11 EJTAG 接口

| 信号名称       | 类型 | 上下拉 | 描述                         |
|------------|----|-----|----------------------------|
| EJTAG_SEL  | I  | PU  | JTAG 选择(0: JTAG, 1: EJTAG) |
| JTAG_SEL   | I  | PU  | JTAG 引脚功能复用(为1选择复用<br>功能)  |
| EJTAG_TCK  | I  | PU  | JTAG 时钟                    |
| EJTAG_TDI  | I  | PU  | JTAG 数据输入                  |
| EJTAG_TMS  | I  | PU  | JTAG 模式                    |
| EJTAG_TRST | I  | PU  | JTAG 复位,需下拉                |
| EJTAG_TDO  | О  | PU  | JTAG 数据输出                  |

【注】EJTAG\_SEL 是选择 JTAG 还是 EJTAG, JTAG\_SEL 是用来选择 JTAG 复用功能,不要混淆。

## 2.12 CAMERA 接口

| 信号名称         | 类型 | 上下拉 | 描述        |
|--------------|----|-----|-----------|
| CAM_CLKOUT   | 0  | PU  | 摄像头参考时钟输出 |
| CAM_PCLK_I   | I  | PU  | 摄像头像素时钟输入 |
| CAM_HSYNC    | I  | PU  | 摄像头水平同步信号 |
| CAM_VSYNC    | I  | PU  | 摄像头垂直同步信号 |
| CAMDATA[7:0] | I  | PU  | 摄像头数据输入   |

【注】在QFP100 封装下,CAM 没有引出来,需要和NAND、MAC 复用。 在QFP176 封装下,CAM 可直接使用。

# 2.13 NAND 接口

| 信号名称     | 类型 | 上下拉 | 描述        |
|----------|----|-----|-----------|
| NAND_CLE | О  | PD  | NAND 命令锁存 |



| NAND_ALE    | О   | PD NAND 地址锁存  |             |
|-------------|-----|---------------|-------------|
| NAND_RD     | О   | PD            | NAND 读信号    |
| NAND_WR     | О   | PD NAND 写信号   |             |
| NAND_CE     | О   | PD NAND 片选 0  |             |
| NAND_RDY    | I   | PD NAND 准备好 0 |             |
| NAND_D[7:0] | I/O | PD            | NAND 地址/数据线 |

# 2.14 MAC 接口

| 信号名称         | 类型  | 上下拉         | 描述       |
|--------------|-----|-------------|----------|
| MAC_TXCK     | О   | PU MII 发送时钟 |          |
| MAC_TXEN     | О   | PU          | MII 发送控制 |
| MAC_TXD[3:0] | О   | PU          | MII 发送数据 |
| MAC_RXCK     | I   | PU          | MII 接收时钟 |
| MAC_RXDV     | I   | PU          | MII 接收控制 |
| MAC_RXER     | I   | PU          | MII 接收错误 |
| MAC_RXD[3:0] | I   | PU          | MII 接收数据 |
| MAC_MDCK     | О   | PU          | SMA 接口时钟 |
| MAC_MDIO     | I/O | PU          | SMA 接口数据 |
| MAC_COL      | I   | PU          | MAC 冲突检测 |
| MAC_CRS      | I   | PU          | MAC 载波侦测 |

【注】在 QFP100 封装下,MAC 只能使用 RMII 模式。在 QFP176 封装下,可使用 MII 和 RMII 模式。

# 2.15 OTG 接口

| 信号名称      | 类型       | 上下拉描述          |              |
|-----------|----------|----------------|--------------|
| OTG_DVDD  |          | OTG 数字电源       |              |
| OTG_DVSS  |          | OTG 数字地        |              |
| OTG_VDD33 |          | OTG 模拟电源       |              |
| OTG_VSS33 |          | OTG 模拟地        |              |
| OTG_REXT  |          | OTG 参考电阻       |              |
| OTG_DP    | DIFF I/O | -              | OTG 差分信号线 D+ |
| OTG_DM    | DIFF I/O | - OTG 差分信号线 D- |              |
| OTG_VBUS  |          |                | OTG_VBUS     |



| OTG_ID |  | OTG_ID |
|--------|--|--------|
|--------|--|--------|

# 2.16 USB 接口

| 信号名称      | 类型       | 上下拉描述    |              |
|-----------|----------|----------|--------------|
| USB_DVDD  |          | USB 数字电源 |              |
| USB_DVSS  |          | USB 数字地  |              |
| USB_VDD33 |          | USB 模拟电源 |              |
| USB_VSS33 |          | USB 模拟地  |              |
| USB_REXT  |          | USB 参考电阻 |              |
| USB_DP    | DIFF I/O | -        | USB 差分信号线 D+ |
| USB_DM    | DIFF I/O | -        | USB 差分信号线 D- |

【注】在 QFP100 封装下, USB HOST 不能使用。在 QFP176 封装下,可以使用。

# 2.17 RTC 接口

| 信号名称      | 类型 | 上下拉 | 描述                    |
|-----------|----|-----|-----------------------|
| RTC_CLK_I | I  | -   | RTC 晶振输入,接 32.768K 晶振 |
| RTC_CLK_O | О  | -   | RTC 晶振输出              |
| VR_VDDA   |    |     | RTC 电源                |

# 2.18 时钟配置信号

| 信号名称  | 类型 | 上下拉 | 描述             |
|-------|----|-----|----------------|
| XTALI | I  | -   | 系统时钟晶振输入,接 24M |
| XTAL0 | О  | -   | 系统时钟晶振输出       |

# 2.19 电源地

| 信号名称      | 类型 | 上下拉 | 描述            |
|-----------|----|-----|---------------|
| PLL_VDD33 | P  |     | Core PLL 模拟电源 |
| PLL_VSS33 | G  |     | Core PLL 模拟地  |
| PLL_VDD12 | P  |     | Core PLL 数字电源 |
| PLL_VSS12 | G  |     | Core PLL 数字地  |



| CORE_VDD | P | 核电压电源 |
|----------|---|-------|
| CORE_VSS | G | 核电压地  |
| IO_VDD   | P | IO 电源 |

## 2.20 初始化信号

龙芯 1C 有四种启动方式,OTG、SPI FLASH、NAND FLASH、SDIO。复用功能引脚,通过在系统复位期间采样外部上下拉的值得到配置信息,供软件判定上电状态。

表 2-1 配置信号

| 表 2-1 配置信号  |            |                                                                                                                                                                                                                                                                                                                             |  |
|-------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 引脚名称        | 信号名称       | 描述                                                                                                                                                                                                                                                                                                                          |  |
| NAND_D[3:0] | start_freq | 上电启动时 PLL 倍频配置,频率计算公式为: Freq = 6*(4*NAND_D[3:0] + 40); 当 NAND_D[3:0]=0 时为 bypass 模式, PLL 输出参考时钟 当 NAND_D[3:0]!=0 时, PLL 输出倍频后的时钟 PLL 输出到 CPU 时钟有分频器, 默认二分频 CPU 到 SDRAM 有分频器, 默认二分频                                                                                                                                          |  |
| NAND_D[5:4] | boot_sel   | 启动选择,在 QFP100 和 QFP176 封装下不同 (在 QFP100<br>封装下,NAND 的控制信号没有封装成引脚)<br>在 QFP100 封装下,boot_sel 为<br>00: Reserved<br>01: 表示从 SPI flash 启动<br>10: 表示从 NAND flash 启动(复用 SDRAM 引脚)<br>11: 表示从 NAND flash 启动(复用 MAC 引脚)<br>在 QFP176 封装下,boot_sel 为<br>00: Reserved<br>01: 表示从 SPI flash 启动<br>10: 表示从 SPI flash 启动<br>11: 表示从 SDIO 启动 |  |
| NAND_D[7:6] | nand_type  | NAND boot 时配置 NAND flash 颗粒容量大小<br>11:表示容量大于等于 2Gb(2KB 页/4KB 页/8KB 页)<br>10:表示容量为 1Gb(2KB 页)<br>01:表示容量为 512Mb(512 Bytes 页)<br>00:表示容量为小于等于 256Mb(512 Bytes 页)                                                                                                                                                              |  |
| NAND_CLE    | rs_rd_cfg  | NAND boot 时是否采用 ECC,仅在 boot_sel 选择 NAND flash 启动时有效<br>为 0 时,表示 NAND 非 ECC 启动<br>为 1 时,表示 NAND ECC 启动                                                                                                                                                                                                                       |  |



|          |               | USB_HOST 和 USB_OTG 的时钟选择信号。 |
|----------|---------------|-----------------------------|
| SPI0_CLK | usb_refclksel | 为 1 时,表示由内部的 PLL 提供时钟。      |
|          |               | 为 0 时,表示由外部的晶振提供时钟。         |



# 3 寄存器定义

# 3.1 基本寄存器定义

| 寄存器名称            | 地址          | 读/写<br>(R/W) | 功能描述                    | 复位值        |
|------------------|-------------|--------------|-------------------------|------------|
| 基本寄存器            |             |              |                         |            |
| START_FREQ       | 0xbfe7_8030 | R/W          | PLL 频率配置及<br>SDRAM 分频系数 | 上电状态       |
| CLK_DIV_PARAM    | 0xbfe7_8034 | R/W          | CPU/CAMERA/DC<br>分频系数   | 0x0        |
| CBUS_CONFSIGNALS | 0xbfd0_0400 | R/W          |                         | 0x0        |
| CBUS_SD_CTRL0    | 0xbfd0_0410 | R/W          | SDRAM 参数配置<br>寄存器       | 0x001438a3 |
| CBUS_SD_CTRL1    | 0xbfd0_0414 | R/W          | SDRAM 参数配置<br>寄存器       | 0x80000080 |
| SHUT_CTRL        | 0xbfd0_0420 | R/W          | 各模块开关寄存器                | 0x0        |
| MISC_CTRL        | 0xbfd0_0424 | R/W          | 功能复用寄存器 0               | 0x4        |
| cpu_throt        | 0xbfe7_c010 | R/W          | CPU 动态降频寄存器             | 0x0        |
| 中断寄存器            |             |              |                         |            |
| INTISR0          | 0xbfd0_1040 | R            | 中断状态寄存器 0               | 0x0        |
| INTEN0           | 0xbfd0_1044 | R/W          | 中断使能寄存器 0               | 0x0        |
| INTSET0          | 0xbfd0_1048 | R/W          | 中断置位寄存器 0               | 0x0        |
| INTCLR0          | 0xbfd0_104c | R/W          | 中断清零寄存器 0               | 0x0        |
| INTPOL0          | 0xbfd0_1050 | R/W          | 中断触发电平标志寄存器 0           | 0x0        |
| INTEDGE0         | 0xbfd0_1054 | R/W          | 中断触发边沿标志寄存器 0           | 0x0        |
| INTISR1          | 0xbfd0_1058 | R            | 中断状态寄存器 1               | 0x0        |
| INTEN1           | 0xbfd0_105c | R/W          | 中断使能寄存器 1               | 0x0        |
| INTSET1          | 0xbfd0_1060 | R/W          | 中断置位寄存器 1               | 0x0        |



| INTCLR1   | 0xbfd0_1064                                       | R/W   | 中断清零寄存器 1         | 0x0         |
|-----------|---------------------------------------------------|-------|-------------------|-------------|
| INTOLIXT  | 0XDIUU_1004                                       | IX/VV |                   | UXU         |
| INTPOL1   | 0xbfd0_1068                                       | R/W   | 中断触发电平标志寄存器 1     | 0x0         |
| INTEDGE1  | 0xbfd0_106c                                       | R/W   | 中断触发边沿标志寄存器1      | 0x0         |
| INTISR2   | 0xbfd0_1070                                       | R     | 中断状态寄存器 2         | 0x0         |
| INTEN2    | 0xbfd0_1074                                       | R/W   | 中断使能寄存器 2         | 0x0         |
| INTSET2   | 0xbfd0_1078                                       | R/W   | 中断置位寄存器 2         | 0x0         |
| INTCLR2   | 0xbfd0_107c                                       | R/W   | 中断清零寄存器 2         | 0x0         |
| INTPOL2   | 0xbfd0_1080                                       | R/W   | 中断触发电平标志寄存器 2     | 0x0         |
| INTEDGE2  | 0xbfd0 1084   R/W                                 |       | 中断触发边沿标志<br>寄存器 2 | 0x0         |
| INTISR3   | 0xbfd0_1088 R 中断状态寄存器 3                           |       | 中断状态寄存器 3         | 0x0         |
| INTEN3    | 0xbfd0_108c R/W 中断使能寄存器 3                         |       | 0x0               |             |
| INTSET3   | Oxbfd0_1090 R/W 中断置位寄存器 3                         |       | 0x0               |             |
| INTCLR3   | 0xbfd0_1094 R/W 中断清零寄存器 3                         |       | 0x0               |             |
| INTPOL3   | 0xbfd0_1098                                       | R/W   | 中断触发电平标志<br>寄存器 3 | 0x0         |
| INTEDGE3  | 0xbfd0_109c                                       | 中断触发过 |                   | 0x0         |
| INTISR4   | 0xbfd0_10 <sup>a</sup> 0                          | R     | 中断状态寄存器 4         | 0x0         |
| INTEN4    | 0xbfd0_10 <sup>a</sup> 4                          | R/W   | 中断使能寄存器 4         | 0x0         |
| INTSET4   | 0xbfd0_10 <sup>a</sup> 8                          | R/W   | 中断置位寄存器 4         | 0x0         |
| INTCLR4   | 0xbfd0_10ac                                       | R/W   | 中断清零寄存器 4         | 0x0         |
| INTPOL4   | 0xbfd0_10b0         R/W         中断触发电平标志<br>寄存器 4 |       | 0x0               |             |
| INTEDGE4  | 0xbfd0_10b4 R/W 中断触发<br>寄存器 4                     |       | 中断触发边沿标志寄存器 4     | 0x0         |
| GPIO 寄存器  |                                                   |       |                   |             |
| GPIO_CFG0 | 0xbfd0_10c0                                       | R/W   | GPIO 配置寄存器 0      | 0xffe00040  |
| GPIO_CFG1 | 0xbfd0_10c4                                       | R/W   | GPIO 配置寄存器 1      | 0xfc00_3f3f |
|           | 0xbfd0_10c8                                       | R/W   | GPIO 配置寄存器 2      | 0x1ff0_3fff |



| CDIO CEGS    | 0vbfd0 1000 | R/W   | GPIO 配置寄存器 3   | 0x0         |
|--------------|-------------|-------|----------------|-------------|
| GPIO_CFG3    | 0xbfd0_10cc | TX/VV |                | UXU         |
| GPIO_OE0     | 0xbfd0_10d0 | R/W   | GPIO 输出使能寄存器 0 |             |
| GPIO_OE1     | 0xbfd0_10d4 | R/W   | GPIO 输出使能寄存器 1 | 0xfc00_3f3f |
| GPIO_OE2     | 0xbfd0_10d8 | R/W   | GPIO 输出使能寄存器 2 | 0x1ff0_3fff |
| GPIO_OE3     | 0xbfd0_10dc | R/W   | GPIO 输出使能寄存器 3 | 0x0         |
| GPIO_IN0     | 0xbfd0_10e0 | R/W   | GPIO 输入寄存器 0   | 0x0         |
| GPIO_IN1     | 0xbfd0_10e4 | R/W   | GPIO 输入寄存器 1   | 0x0         |
| GPIO_IN2     | 0xbfd0_10e8 | R/W   | GPIO 输入寄存器 2   | 0x0         |
| GPIO_IN3     | 0xbfd0_10ec | R/W   | GPIO 输入寄存器 3   | 0x0         |
| GPIO_OUT0    | 0xbfd0_10f0 | R/W   | GPIO 输出寄存器 0   | 0x0         |
| GPIO_OUT1    | 0xbfd0_10f4 | R/W   | GPIO 输出寄存器 1   | 0x0         |
| GPIO_OUT2    | 0xbfd0_10f8 | R/W   | GPIO 输出寄存器 2   | 0x0         |
| GPIO_OUT3    | 0xbfd0_10fc | R/W   | GPIO 输出寄存器 3   | 0x0         |
| 复用关系寄存器      |             |       |                |             |
| CBUS_FIRST0  | 0xbfd0_11c0 | R/W   | 第一复用寄存器 0      | 0x0         |
| CBUS_FIRST1  | 0xbfd0_11c4 | R/W   | 第一复用寄存器 1      | 0x0         |
| CBUS_FIRST2  | 0xbfd0_11c8 | R/W   | 第一复用寄存器 2      | 0x0         |
| CBUS_FIRST3  | 0xbfd0_11cc | R/W   | 第一复用寄存器 3      | 0x0         |
| CBUS_SECOND0 | 0xbfd0_11d0 | R/W   | 第二复用寄存器 0      | 0x0         |
| CBUS_SECOND1 | 0xbfd0_11d4 | R/W   | 第二复用寄存器 1      | 0x0         |
| CBUS_SECOND2 | 0xbfd0_11d8 | R/W   | 第二复用寄存器 2      | 0x0         |
| CBUS_SECOND3 | 0xbfd0_11dc | R/W   | 第二复用寄存器 3      | 0x0         |
| CBUS_THIRD0  | 0xbfd0_11e0 | R/W   | 第三复用寄存器 0      | 0x0         |
| CBUS_THIRD1  | 0xbfd0_11e4 | R/W   | 第三复用寄存器 1      | 0x0         |
| CBUS_THIRD2  | 0xbfd0_11e8 | R/W   | 第三复用寄存器 2      | 0x0         |
| CBUS_THIRD3  | 0xbfd0_11ec | R/W   | 第三复用寄存器 3      | 0x0         |
| CBUS_FOURTH0 | 0xbfd0_11f0 | R/W   | 第四复用寄存器 0      | 0x0         |
| CBUS_FOURTH1 | 0xbfd0_11f4 | R/W   | 第四复用寄存器 1      | 0x0         |
|              |             |       |                |             |



| CBUS_FOURTH2  | 0xbfd0_11f8 | R/W | 第四复用寄存器 2 | 0x0 |  |
|---------------|-------------|-----|-----------|-----|--|
| CBUS_FOURTH3  | 0xbfd0_11fc | R/W | 第四复用寄存器 3 | 0x0 |  |
| DMA 配置寄存器     |             |     |           |     |  |
| ORDER_ADDR_IN | 0xbfd0_1160 | R/W | DMA 配置寄存器 |     |  |

# 3.2 各模块寄存器定义

| 寄存器名称            | 地址          | 读/写<br>(R/W) | 功能描述              | 复位值        |  |  |
|------------------|-------------|--------------|-------------------|------------|--|--|
| SDRAM 接口         |             |              |                   |            |  |  |
| SD_CONFIG[31:0]  | 0xbfd0_0410 | R/W          | SDRAM 参数配置<br>寄存器 | 0x30d0db5a |  |  |
| SD_CONFIG[63:32] | 0xbfd0_0414 | R/W          | SDRAM 参数配置<br>寄存器 | 0x50       |  |  |
| PWM0             |             |              |                   |            |  |  |
| CNTR             | 0xbfe5_c000 | R/W          | 主计数器              | 0x0        |  |  |
| HRC              | 0xbfe5_c004 | R/W          | 高脉冲定时参考寄<br>存器    | 0x0        |  |  |
| LRC              | 0xbfe5_c008 | R/W          | 低脉冲定时参考寄<br>存器    | 0x0        |  |  |
| CTRL             | 0xbfe5_c00c | R/W          | 控制寄存器             | 0x0        |  |  |
| PWM1             |             |              |                   |            |  |  |
| CNTR             | 0xbfe5_c010 | R/W          | 主计数器              | 0x0        |  |  |
| HRC              | 0xbfe5_c014 | R/W          | 高脉冲定时参考寄<br>存器    | 0x0        |  |  |
| LRC              | 0xbfe5_c018 | R/W          | 低脉冲定时参考寄<br>存器    | 0x0        |  |  |
| CTRL             | 0xbfe5_c01c | R/W          | 控制寄存器             | 0x0        |  |  |
| PWM2             |             |              |                   |            |  |  |
| CNTR             | 0xbfe5_c020 | R/W          | 主计数器              | 0x0        |  |  |
| HRC              | 0xbfe5_c024 | R/W          | 高脉冲定时参考寄<br>存器    | 0x0        |  |  |
| LRC              | 0xbfe5_c028 | R/W          | 低脉冲定时参考寄<br>存器    | 0x0        |  |  |



| CTRL       | 0xbfe5_c02c | 0xbfe5_c02c R/W 控制        |                | 0x0      |
|------------|-------------|---------------------------|----------------|----------|
| PWM3       | 1           |                           |                |          |
| CNTR       | 0xbfe5_c030 | 0xbfe5_c030 R/W           |                | 0x0      |
| HRC        | 0xbfe5_c034 | R/W                       | 高脉冲定时参考寄<br>存器 | 0x0      |
| LRC        | 0xbfe5_c038 | 0xbfe5_c038 R/W 2         |                | 0x0      |
| CTRL       | 0xbfe5_c03c | R/W                       | 控制寄存器          | 0x0      |
| I2S 接口     |             |                           |                |          |
| IISVersion | 0xbfe6_0000 | R/W                       | I2S 标识寄存器      | 0x0      |
| IISConfig  | 0xbfe6_0001 | R/W                       | I2S 配置寄存器      | 0x0      |
| IISState   | 0xbfe6_0002 | R/W                       | I2S 状态寄存器      | 0x0      |
| IISRxData  | 0xbfe6_0003 | R/W                       | I2S 接收数据寄存器    | 0x0      |
| IISTxData  | 0xbfe6_0004 | R/W                       | I2S 发送数据寄存器    | 0x0      |
| AC97       |             |                           |                |          |
| CSR        | 0xbfe6_0000 | R/W                       | 配置状态寄存器        | 0x0      |
| OCC0       | 0xbfe6_0004 | R/W                       | 输出通道配置寄存器 0    | 0x4141   |
| OCC1       | 0xbfe6_0008 |                           | 保留             |          |
| OCC2       | 0xbfe6_000c |                           | 保留             |          |
| ICC        | 0xbfe6_0010 | Oxbfe6_0010 R/W 输入通道配置寄存器 |                | 0x410000 |
| CODEC_ID   | 0xbfe6_0014 |                           | Codec ID 寄存器   |          |
| CRAC       | 0xbfe6_0018 | Codec 寄存器访问           命令  |                | 0x0      |
| OC0        | 0xbfe6_0020 |                           | 输出声道 0         |          |
| OC1        | 0xbfe6_0024 |                           | 输出声道 1         |          |
| OC2        | 0xbfe6_0028 |                           | 保留             |          |
| OC3        | 0xbfe6_002c |                           | 保留             |          |
| OC4        | 0xbfe6_0030 |                           | 保留             |          |
|            |             | <u></u>                   |                |          |



| 0xbfe6_0034 |                                                                                                                                                                                                                                      | 保留                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |             |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| 0xbfe6_0038 |                                                                                                                                                                                                                                      | 保留                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |             |
| 0xbfe6_003c |                                                                                                                                                                                                                                      | 保留                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |             |
| 0xbfe6_0040 |                                                                                                                                                                                                                                      | 保留                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |             |
| 0xbfe6_0044 |                                                                                                                                                                                                                                      | 保留                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |             |
| 0xbfe6_0048 |                                                                                                                                                                                                                                      | 保留                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |             |
| 0xbfe6_004c |                                                                                                                                                                                                                                      | 输入声道 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |             |
| 0xbfe6_0054 | R/W                                                                                                                                                                                                                                  | 中断状态寄存器                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |             |
| 0xbfe6_0058 | R/W                                                                                                                                                                                                                                  | 中断掩膜                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0x0         |
| 0xbfe6_005c | R                                                                                                                                                                                                                                    | 中断状态/清除寄存器                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0x0         |
| 0xbfe6_0060 | R                                                                                                                                                                                                                                    | OC 中断清除寄存器                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0x0         |
| 0xbfe6_0064 | R                                                                                                                                                                                                                                    | IC 中断清除寄存器                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0x0         |
| 0xbfe6_0610 | R                                                                                                                                                                                                                                    | CODEC 写中断清<br>除寄存器                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 0x0         |
| 0xbfe6_006c | R                                                                                                                                                                                                                                    | CODEC 读中断清<br>除寄存器                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 0x0         |
|             |                                                                                                                                                                                                                                      | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |             |
| 0xbfe6_4024 | W                                                                                                                                                                                                                                    | TOY 低 32 位数值<br>写入                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |             |
| 0xbfe6_4028 | W                                                                                                                                                                                                                                    | TOY 高 32 位数值<br>写入                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |             |
| 0xbfe6_402C | R                                                                                                                                                                                                                                    | TOY 低 32 位数值<br>读出                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |             |
| 0xbfe6_4030 | R                                                                                                                                                                                                                                    | <b>TOY</b> 高 <b>32</b> 位数值<br>读出                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |             |
|             |                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |             |
| 0xbfe6_c000 | R/W                                                                                                                                                                                                                                  | SDIO 控制寄存器                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0x0         |
| 0xbfe6_c004 | R/W                                                                                                                                                                                                                                  | SDIO 预分频寄存器                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0x1         |
| 0xbfe6_c008 | R/W                                                                                                                                                                                                                                  | SDIO 命令参数寄                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0x0         |
|             | Oxbfe6_0038 Oxbfe6_003c Oxbfe6_0040 Oxbfe6_0044 Oxbfe6_004c Oxbfe6_0054 Oxbfe6_0058 Oxbfe6_005c Oxbfe6_0060 Oxbfe6_0064 Oxbfe6_006c  Oxbfe6_4024 Oxbfe6_4024 Oxbfe6_4028 Oxbfe6_4020 Oxbfe6_4020 Oxbfe6_4030 Oxbfe6_c000 Oxbfe6_c004 | Oxbfe6_0038           Oxbfe6_003c           Oxbfe6_0040           Oxbfe6_0044           Oxbfe6_004c           Oxbfe6_0054         R/W           Oxbfe6_0058         R/W           Oxbfe6_005c         R           Oxbfe6_0060         R           Oxbfe6_0061         R           Oxbfe6_006c         R           Oxbfe6_006c         R           Oxbfe6_4024         W           Oxbfe6_4028         W           Oxbfe6_4020         R           Oxbfe6_4030         R           Oxbfe6_c000         R/W           Oxbfe6_c0004         R/W | Oxbfe6_0038 |



|              |             | 1   | 1            | 1        |
|--------------|-------------|-----|--------------|----------|
|              |             |     | 存器           |          |
| sdi_cmd_con  | 0xbfe6_c00c | R/W | SDIO 命令控制寄   | 0x0      |
|              |             |     | 存器           |          |
| sdi_cmd_sta  | 0xbfe6_c010 | R   | SDIO 命令状态寄   | 0x0      |
|              |             |     | 存器           |          |
| sdi_rsp0     | 0xbfe6_c014 | R/W | SDIO 响应寄存器   | 0x0      |
|              |             |     | 0            |          |
| sdi_rsp1     | 0xbfe6_c018 | R/W | SDIO 响应寄存器   | 0x0      |
|              |             |     | 1            |          |
| sdi_rsp2     | 0xbfe6_c01c | R/W | SDIO 响应寄存器   | 0x0      |
|              |             |     | 2            |          |
| sdi_rsp3     | 0xbfe6_c020 | R/W | SDIO 响应寄存器   | 0x0      |
|              |             |     | 3            |          |
| sdi_dtimer   | 0xbfe6_c024 | R/W | SDIO 定时寄存器   | 0x1388   |
| sdi_bsize    | 0xbfe6_c028 | R/W | SDIO 块大小寄存   | 0x0      |
|              |             |     | 器            |          |
| sdi_dat_con  | 0xbfe6_c02c | R/W | SDIO 数据控制寄   | 0x0      |
|              |             |     | 存器           |          |
| sdi_dat_cnt  | 0xbfe6_c030 | R/W | SDIO 数据计数器   | 0x0      |
| sdi_dat_sta  | 0xbfe6_c034 | R   | SDIO 数据状态寄   | 0x0      |
|              |             |     | 存器           |          |
| sdi_fsta     | 0xbfe6_c038 | R   | SDIO FIFO 状态 | 0x0      |
|              |             |     | 寄存器          |          |
| sdi_int_mask | 0xbfe6_c03c | R/W | SDIO 中断屏蔽寄   | 0x0      |
|              |             |     | 存器           |          |
| sdi_wdat     | 0xbfe6_c040 | R/W | SDIO 数据寄存器   | 0x0      |
| sdi_int_en   | 0xbfe6_c064 | RW  | SDIO 中断使能寄   | 0x0      |
|              |             |     | 存器           |          |
| ADC 接口       |             |     |              |          |
| adc_cnt      | 0xbfe7_4000 | R/W | 分频和采样间隔      | 0x400010 |
|              |             |     | 寄存器          |          |
| adc_s_ctrl   | 0xbfe7_4004 | R/W | 单次采样控制寄      | 0x0      |
|              |             |     | 存器           |          |
| adc_c_ctrl   | 0xbfe7_4008 | R/W | 连续采样控制寄      | 0x0      |
|              | •           | •   | •            |          |



|                    |             | 1   |              |           |
|--------------------|-------------|-----|--------------|-----------|
|                    |             |     | 存器           |           |
| x_range            | 0xbfe7_4010 | R/W | 触摸屏X方向阈值     | 0x3ff0000 |
| y_range            | 0xbfe7_4014 | R/W | 触摸屏Y方向阈值     | 0x3ff0000 |
| awatchdog_range    | 0xbfe7_4018 | R/W | 模拟看门狗阈值      | 0x3f0000f |
| axis               | 0xbfe7_401c | R/W | 触摸屏坐标        | 0x0       |
| adc_s_dout0        | 0xbfe7_4020 | R/W | 通道0和通道1单     | 0x0       |
|                    |             |     | 次采样的结果       |           |
| adc_s_dout1        | 0xbfe7_4024 | R/W | 通道2和通道3单     | 0x0       |
|                    |             |     | 次采样的结果       |           |
| adc_c_dout         | 0xbfe7_4028 | R/W | 连续采样的结果      | 0x0       |
| adc_debounce_cnt   | 0xbfe7_402c | R/W | 触摸屏去抖动时      | 0x640     |
|                    |             |     | 间            |           |
| adc_int            | 0xbfe7_4030 | R/W | ADC 中断标志和    | 0x0       |
|                    |             |     | 控制           |           |
| NAND               |             |     |              |           |
| NAND_CMD           | 0Xbfe7_8000 | R/W | NAND 命令寄存器   | 0x0       |
| ADDR_C             | 0Xbfe7_8004 | R/W | NAND 页内偏移地   | 0x0       |
|                    |             |     | 址寄存器         |           |
| ADDR_R             | 0Xbfe7_8008 | R/W | NAND 页地址寄存   | 0x0       |
|                    |             |     | 器            |           |
| NAND_TIMING        | 0Xbfe7_800C | R/W | NAND 时序寄存器   | 0x0412    |
| ID_L               | 0Xbfe7_8010 | R   | NAND 低位 ID 寄 | 0x0       |
|                    |             |     | 存器           |           |
| STATUS & ID_H      | 0Xbfe7_8014 | R   | NAND 高位 ID 寄 | 0x0       |
|                    |             |     | 存器           |           |
| NAND_PARAMETER     | 0Xbfe7_8018 | R/W | NAND 颗粒参数寄   | 0x        |
|                    |             |     | 存器           |           |
| NAND_OP_NUM        | 0Xbfe7_801C | R/W | NAND 读写数量寄   | 0x800     |
|                    |             |     | 存器           |           |
| CS_RDY_MAP         | 0Xbfe7_8020 | R/W | NAND 颗粒 RDY  | 0x0       |
|                    |             |     | 信号           |           |
| DMA access address | 0Xbfe7_8040 | R/W | NAND 读写数据寄   | 0x0       |
|                    |             |     | 存器           |           |
|                    |             |     |              |           |



| CAMERA 接口            |             |     |           |     |  |
|----------------------|-------------|-----|-----------|-----|--|
| DMA_ADDR0_CONFIG     | 0xbc28_0000 | R/W | 帧缓冲区基地址 0 | 0x0 |  |
| DMA_ADDR1_CONFIG     | 0xbc28_0008 | R/W | 帧缓冲区基地址 1 | 0x0 |  |
| DMA_ADDR2_CONFIG     | 0xbc28_0010 | R/W | 帧缓冲区基地址 2 | 0x0 |  |
| DMA_ADDR3_CONFIG     | 0xbc28_0018 | R/W | 帧缓冲区基地址 3 | 0x0 |  |
| Camif_config_pix     | 0xbc28_0020 | R/W | 浮动分辨率像素   | 0x0 |  |
| Camif_config_uoffset | 0xbc28_0028 | R/W | U基地址      | 0x0 |  |
| Camif_config_voffset | 0xbc28_0030 | R/W | V 基地址     | 0x0 |  |
| Camif_config         | 0xbc28_0038 | R/W | 状态寄存器     | 0x0 |  |
| HCNTR 接口             |             |     |           |     |  |
| hcntr_ctrl           | 0xbfe7_c000 | R/W | 定时器控制寄存器  | 0x0 |  |



# 4 时钟结构

## 4.1 时钟架构

龙芯 1C 的时钟结构如下图所示,来自 XTALI/O 的时钟送到 2 个 USBPHY 和 1 个 PLL。PLL 经过分频产生 CPU、SDRAM、MAC、USB 等主要模块的工作时钟; USB、MAC、OTG 等模块在接口处使用各自的时钟(或参考时钟)。



图 4-1 系统时钟结构

## 4.2 时钟信号说明

表 4-1 统一介绍了龙芯 1C 的所有时钟引脚。

| 秋 I I 龙心 IO 时 时 目 了 |         |     |                      |  |  |
|---------------------|---------|-----|----------------------|--|--|
| 信号名称                | 频率(MHz) | 类型  | 描述                   |  |  |
| XTALI               |         | I/O | PLL 和 USBPHY 参考时钟,连接 |  |  |
| XTALO               |         | I/O | 24MHz 晶体。            |  |  |
| MACTXCLK            |         | I   | MAC 发送参考时钟           |  |  |
| MACRXCLK            |         | I   | MAC 接收参考时钟           |  |  |
| CAM_PCLK            |         | I   | Camera 像素时钟          |  |  |

表 4-1 龙芯 1C 时钟信号



# 5 芯片配置与控制

## 5.1 地址空间分配

龙芯 1C 的地址空间分为三级,包括一级 AXI 交叉开关上模块的地址空间、AXI\_MUX 下各模块的地址空间、以及 APB 上各模块的地址空间。

表 5-1 AXI 各模块地址分配

| 地址空间                      | 设备        | 说明    |
|---------------------------|-----------|-------|
| 0x0000_0000 - 0x0fff_ffff | SDRAM     | 256MB |
| 0xbc28_0000 - 0xbc2f_ffff | CAMERA_IF | 512K  |
| 0xbc30_0000 - 0xbc3f_ffff | DC        | 1MB   |
| 0xbf00_0000 - 0xbfff_ffff | AXI MUX   | 16MB  |

#### 表 5-2 AXI-MUX 各模块地址分配

| 地址空间                      | 设备          | 说明          |
|---------------------------|-------------|-------------|
| 0xbd00,0000 - 0xbd7f,ffff | SPI0-memory | 8MB         |
| 0xbe00,0000 - 0xbe3f,ffff | SPI1-memory | 4MB         |
| 0xbfc0_0000 - 0xbfcf_ffff | Boot        | 1MB,根据系统启动  |
|                           |             | 方式映射到 SPI 或 |
|                           |             | NAND        |
| 0xbfd0_0000 - 0xbfdf_ffff | CONFREG     | 1MB         |
| 0xbfe0_0000 - 0xbfe0_ffff | OTG         | 64KB        |
| 0xbfe1_0000 - 0xbfe1_ffff | MAC         | 64KB        |
| 0xbfe2_0000 - 0xbfe2_ffff | USB         | 64KB        |
| 0xbfe4_0000 - 0xbfe7_ffff | APB-devices | 256KB       |
| 0xbfe8,0000 - 0xbfeb,ffff | SPI0-IO     | 256KB       |
| 0xbfec,0000 - 0xbfef,ffff | SPI1-IO     | 256KB       |

#### 表 5-3 APB 各模块地址分配

| 地址空间                    | 模块    | 说明   |
|-------------------------|-------|------|
| 0xbfe4_0000-0xbfe4_3fff | UART0 | 16KB |
| 0xbfe4_4000-0xbfe4_7fff | UART1 | 16KB |



| 16KB<br>16KB<br>256B<br>256B |
|------------------------------|
| 256B<br>256B                 |
| 256B                         |
|                              |
|                              |
| 256B                         |
| 16KB                         |
|                              |

# 5.2 芯片配置寄存器(CONFREG)

龙芯 1C 芯片内部专门有一个配置寄存器模块(CONFREG),用于芯片的一些基本配置及复用关系等。以下是寄存器列表及说明。

#### **5.2.1** PLL/SDRAM 频率配置寄存器

| 寄存器名称      | 地址          | 读/写(R/W) | 功能描述      | 复位值 |
|------------|-------------|----------|-----------|-----|
| START_FREQ | 0xbfe7_8030 | R/W      | PLL 配置频率及 |     |



|  |  |  | SDRAM 分频系数 |  |
|--|--|--|------------|--|
|--|--|--|------------|--|

| START_FREQ | 位     | 缺省值 | 描述                                                                                         |
|------------|-------|-----|--------------------------------------------------------------------------------------------|
| PLL_VALID  | 31    | 0   | PLL 倍频系数有效位                                                                                |
| Reserved   | 30:24 | 0   |                                                                                            |
| FRAC_N     | 23:16 | 0   | PLL 倍频系数的小数部分                                                                              |
| M_PLL      | 15:8  |     | PLL 倍频系数的整数部分<br>(理论可以达到 255,建议不要超过<br>100)                                                |
| Reserved   | 7:4   | 0   |                                                                                            |
| RST_TIME   | 3:2   |     | 配置完 PLL 频率后复位时间<br>00:表示 no reset<br>01:表示 0x100 CLK<br>10:表示 0x400 CLK<br>11:表示 0xff0 CLK |
| SDRAM_DIV  | 1:0   |     | CPU 到 SDRAM 的分频系数<br>00:表示 2 分频<br>01:表示 4 分频<br>10 或 11:表示 3 分频                           |

注: PLL 的分频系数 N 固定为 4, PLL 的频率计算公式如下:

 $Freq_PLL = XIN *(M_PLL + FRAC_N)/4$ 

#### 5.2.2 CPU/CAMERA/DC 频率配置寄存器

| 寄存器名称         | 地址          | 读/写(R/W) | 功能描述          | 复位值 |
|---------------|-------------|----------|---------------|-----|
| CLK_DIV_PARAM | 0xbfe7_8034 | R/W      | CPU/CAMERA/DC |     |
|               |             |          | 分频系数          |     |

| CLK_DIV_PARAM | 位     | 缺省值  | 描述                                                                                |
|---------------|-------|------|-----------------------------------------------------------------------------------|
| PIX_DIV       | 31:24 | 0x24 | DC 像素时钟分频系数<br>PIX_DIV[7]为配置参数有效位<br>PIX_DIV[6:0]为分频系数,为0时不分<br>频,其它范围为1~127      |
| CAM_DIV       | 23:16 | 0x24 | CAMERA 时钟分频系数<br>CAM_DIV[7]为配置参数有效位<br>CAM_DIV[6:0]为分频系数,为 0 时不<br>分频,其它范围为 1~127 |
| CPU_DIV       | 15:8  | 0x2  | CPU 时钟分频系数<br>CPU_DIV[7]为配置参数有效位<br>CPU_DIV[6:0]为分频系数,为 0 时不                      |



|               |     |   | 分频,其它范围为 1~127                                           |
|---------------|-----|---|----------------------------------------------------------|
| Reserved      | 7:6 | 0 |                                                          |
| PIX_DIV_VALID | 5   | 0 | DC 像素时钟分频系数有效                                            |
| PIX_SEL       | 4   | 0 | DC 像素时钟选择信号<br>为 1 时选择分频时钟<br>为 0 时选择晶振输入时钟(bypass 模式)   |
| CAM_DIV_VALID | 3   | 0 | CAMERA 时钟分频系数有效                                          |
| CAM_SEL       | 2   | 0 | CAMERA 时钟选择信号<br>为 1 时选择分频时钟<br>为 0 时选择晶振输入时钟(bypass 模式) |
| CPU_DIV_VALID | 1   | 0 | CPU 时钟分频系数有效                                             |
| CPU_SEL       | 0   | 0 | CPU 时钟选择信号<br>为 1 时选择分频时钟<br>为 0 时选择晶振输入时钟(bypass 模式)    |

Freq\_PIX = Freq\_PLL/PIX\_DIV;

Freq\_CAM = Freq\_PLL/CAM\_DIV;

Freq\_CPU = Freq\_PLL/CPU\_DIV;

Freq\_SDRAM = Freq\_CPU/SDRAM\_DIV;

#### **5.2.3** SDRAM 参数寄存器

| 寄存器名称            | 地址          | 读/写(R/W) | 功能描述    | 复位值        |
|------------------|-------------|----------|---------|------------|
| SD_CONFIG[31:0]  | 0xbfd0_0410 | R/W      | SDRAM参数 | 0x001438a3 |
|                  |             |          | 配置寄存器   |            |
| SD_CONFIG[63:32] | 0xbfd0_0414 | R/W      | SDRAM参数 | 0x80000080 |
|                  |             |          | 配置寄存器   |            |

SDRAM 参数寄存器的详细说明和配置见第七章。

#### **5.2.4** SHUT\_CTRL 寄存器

| 寄存器名称     | 地址          | 读/写(R/W) | 功能描述  | 复位值 |
|-----------|-------------|----------|-------|-----|
| shut_ctrl | 0xbfd0_0420 | R/W      | 各模块开关 | 0x0 |
|           |             |          | 寄存器   |     |



| SHUT_CTRL    | 位     | 缺省值 | 描述                                                                                                                        |
|--------------|-------|-----|---------------------------------------------------------------------------------------------------------------------------|
| UART_split   | 31:30 | 0   | 全功能串口 uart0 分割配置<br>00: 作为全功能串口使用<br>01: 作为 2 个四线串口使用                                                                     |
| OUTPUT_CLK   | 29:26 | 0   | 时钟输出配置。每一位表示一个时钟的输出第0位为1时表示 DC 的 PIX_CLK 输出;第1位为1时表示 CAMERA 时钟从 SPI0_CS 引脚输出;第2位为1时表示 CAMERA 时钟从 PWM0 引脚输出;第3位为1时表示晶振时钟输出 |
| ADC_shut     | 25    | 0   | ADC 模块关闭,为 1 时有效                                                                                                          |
| SDIO_shut    | 24    | 0   | SDIO 模块关闭,为 1 时有效                                                                                                         |
| DMA2_shut    | 23    | 0   | DMA2 模块关闭,为 1 时有效                                                                                                         |
| DMA1_shut    | 22    | 0   | DMA1 模块关闭,为 1 时有效                                                                                                         |
| DMA0_shut    | 21    | 0   | DMA0 模块关闭,为 1 时有效                                                                                                         |
| SPI1_shut    | 20    | 0   | SPI1 模块关闭,为 1 时有效                                                                                                         |
| SPI0_shut    | 19    | 0   | SPIO 模块关闭,为 1 时有效                                                                                                         |
| I2C2_shut    | 18    | 0   | I2C2 模块关闭,为1时有效<br>另外作 UARTO 全功能复用配置位,详<br>细见 5.2.6 UART 复用配置寄存器                                                          |
| I2C1_shut    | 17    | 0   | I2C1 模块关闭,为 1 时有效                                                                                                         |
| I2C0_shut    | 16    | 0   | I2C0 模块关闭,为 1 时有效                                                                                                         |
| AC97_shut    | 15    | 0   | AC97 模块关闭,为 1 时有效                                                                                                         |
| I2S_shut     | 14    | 0   | I2S 模块关闭,为 1 时有效                                                                                                          |
| UART3_shut   | 13    | 0   | UART3 模块关闭,为 1 时有效                                                                                                        |
| UART2_shut   | 12    | 0   | UART2 模块关闭,为 1 时有效                                                                                                        |
| UART1_shut   | 11    | 0   | UART1 模块关闭,为 1 时有效                                                                                                        |
| UART0_shut   | 10    | 0   | UARTO 模块关闭,为 1 时有效                                                                                                        |
| CAN1_shut    | 9     | 0   | CAN1 模块关闭,为1时有效                                                                                                           |
| CAN0_shut    | 8     | 0   | CAN0 模块关闭,为1时有效                                                                                                           |
| ECC_shut     | 7     | 0   | NAND ECC 功能关闭,为 1 时有效                                                                                                     |
| MAC_shut     | 6     | 0   | MAC 模块关闭,为 1 时有效                                                                                                          |
| USBHOST_shut | 5     | 0   | USBHOST 模块关闭,为1时有效                                                                                                        |
| USBOTG_shut  | 4     | 0   | USBOTG 模块关闭,为1时有效                                                                                                         |



| SDRAM_shut | 3 | 0 | SDRAM 模块关闭,为 1 时有效  |
|------------|---|---|---------------------|
| SRAM_shut  | 2 | 0 | SRAM 模块关闭,为 1 时有效   |
| CAM_shut   | 1 | 0 | CAMERA 模块关闭,为 1 时有效 |
| LCD_shut   | 0 | 0 | LCD 模块关闭,为 1 时有效    |

# **5.2.5** MISC\_CTRL 寄存器

| 寄存器名称     | 地址          | 读/写(R/W) | 功能描述  | 复位值 |
|-----------|-------------|----------|-------|-----|
| misc_ctrl | 0xbfd0_0424 | R/W      | 功能复用寄 |     |
|           |             |          | 存器    |     |

| MISC_CTRL      | 位     | 缺省值 | 描述                                                                     |
|----------------|-------|-----|------------------------------------------------------------------------|
| USBHOST_RSTn   | 31    | 0   | USBHOST 模块软件复位                                                         |
| PHY_INTF_SEL_i | 30:28 | 0   | MAC 模块 MII 接口配置信号<br>000:MII 模式<br>100:RMII 模式                         |
| Reserved       | 27:26 | 0   |                                                                        |
| AC97_EN        | 25    | 0   | AC97 和 I2S 复用选择,为 1 时使用<br>AC97,为 0 时使用 I2S                            |
| SDIO_DMA_EN    | 24:23 | 0   | SDIO 使用 DMA,为 0 时不使用 DMA,<br>为 1 时使用 DMA0,为 2 时使用<br>DMA1,为 3 时使用 DMA2 |
| ADC_DMA_EN     | 22    | 0   | ADC 使用 DMA,为 1 时有效                                                     |
| Reserved       | 21:18 | 0   |                                                                        |
| SDIO_USE_SPI1  | 17    | 0   | SDIO 使用 SPI1 引脚,为 1 时有效                                                |
| SDIO_USE_SPI0  | 16    | 0   | SDIO 使用 SPIO 引脚,为 1 时有效                                                |
| SRAM_CTRL      | 15:0  | 0   | SRAM 配置参数,详细见 SRAM                                                     |

# **5.2.6** cpu\_throt 寄存器

| 寄存器名称     | 地址          | 读/写(R/W) | 功能描述    | 复位值 |
|-----------|-------------|----------|---------|-----|
| cpu_throt | 0xbfe7_c010 | R/W      | CPU 动态降 | 0x0 |
|           |             |          | 频控制寄存   |     |
|           |             |          | 器       |     |

| cpu_throt 位 | 缺省值 | 描述 |
|-------------|-----|----|
|-------------|-----|----|



| Reserved  | 31:4 | 0   |                                                                                                                                                                                                                                                                                                                                    |
|-----------|------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| cpu_throt | 3:0  | Oxf | CPU 降频系数。该配置只对 CPU 的频率有效,而对总线时钟、SDRAM 时钟没有影响。 cpu_throt 说明如下: 0xf: 保持 CPU 频率不变。 0xe: 降为原频率的 15/16 0xd: 降为原频率的 14/16 0xc: 降为原频率的 13/16 0xb: 降为原频率的 12/16 0xa: 降为原频率的 10/16 0x8: 降为原频率的 9/16 0x7: 降为原频率的 8/16 0x6: 降为原频率的 8/16 0x6: 降为原频率的 6/16 0x4: 降为原频率的 5/16 0x3: 降为原频率的 5/16 0x3: 降为原频率的 3/16 0x1: 降为原频率的 2/16 0x0: 降为原频率的 1/16 |

## **5.2.7** UART 复用配置寄存器

| 寄存器名称           | 地址          | 读/写(R/W) | 功能描述         | 复位值 |
|-----------------|-------------|----------|--------------|-----|
| uart0_full_func | 0xbfd0_0420 | R/W      | uart4~uart6  | 0x0 |
|                 |             |          | 是复用成         |     |
|                 |             |          | uart0 的全功    |     |
|                 |             |          | 能还是本身        |     |
|                 |             |          | 的功能          |     |
| uart8_full_func | 0xbfe4_c904 | R/W      | uart9~uart11 | 0x0 |
|                 |             |          | 是复用成         |     |
|                 |             |          | uart8 的全功    |     |
|                 |             |          | 能还是本身        |     |
|                 |             |          | 的功能          |     |

| UARTO_FULL_FUNC | 位     | 缺省值 | 描述                                                                                                   |
|-----------------|-------|-----|------------------------------------------------------------------------------------------------------|
|                 | 31:19 | 0   | 同 misc_ctrl[31:19]                                                                                   |
| uart0_full_func | 18    | 0   | 为 0 时,uart4~uart6 当作 uart4~6 本身信号使用,此时 I2C2 模块打开;<br>为 1 时,uart4~uart6 当作 uart0 全功能信号使用,此时 I2C2 模块关闭 |
|                 | 17:0  | 0   | 同 misc_ctrl[17:0]                                                                                    |



| UART8_FULL_FUNC | 位   | 缺省值 | 描述                                                                                             |
|-----------------|-----|-----|------------------------------------------------------------------------------------------------|
|                 | 7:1 | 0   | 同 MSR[7:1]                                                                                     |
| uart8_full_func | 0   | 0   | 为 0 时,uart9~uart11 当作 uart8~11 本身信号使用;<br>为 1 时,uart9~uart11 当作 uart8 全功<br>能信号使用,此时 I2C2 模块关闭 |

#### **5.2.8** GPIO0 配置寄存器(对应 GPIO[31:0])

| 寄存器名称     | 地址          | 读/写(R/W) | 功能描述     | 复位值         |
|-----------|-------------|----------|----------|-------------|
| GPIO_CFG0 | 0xbfd0_10c0 | R/W      | GPIO0 配置 | 0xfc00_3f3f |
|           |             |          | 寄存器      |             |
|           |             |          | 1表示配置为   |             |
|           |             |          | GPIO,0 表 |             |
|           |             |          | 示无效      |             |
| GPIO_EN0  | 0xbfd0_10d0 | R/W      | GPIO0 方向 | 0xfc00_3f3f |
|           |             |          | 寄存器      |             |
|           |             |          | 0表示配置为   |             |
|           |             |          | 输出,1表示   |             |
|           |             |          | 配置为输入    |             |
| GPIO_IN0  | 0xbfd0_10e0 | R        | GPIO0 输入 | 0x0         |
|           |             |          | 寄存器      |             |
| GPIO_OUT0 | 0xbfd0_10f0 | R/W      | GPIO0 输出 | 0x0         |
|           |             |          | 寄存器      |             |
|           |             |          | 为1输出高    |             |
|           |             |          | 为0输出低    |             |

如果要配置 GPIO[16]输出 1,则需要先配置 GPIO\_CFG[16]为 1,然后配置 GPIO\_EN[16]为 0,然后配置 GPIO\_OUT[16]为 1。同理可配置 GPIO0~GPIO127 输入或者输出。

#### **5.2.9** GPIO1 配置寄存器(对应 GPIO[63:32])

| 寄存器名称     | 地址          | 读/写(R/W) | 功能描述     | 复位值 |
|-----------|-------------|----------|----------|-----|
| GPIO_CFG1 | 0xbfd0_10c4 | R/W      | GPIO1 配置 | 0x0 |



|           |             |     | 寄存器<br>1 表示配置为<br>GPIO, 0 表<br>示无效                                 |     |
|-----------|-------------|-----|--------------------------------------------------------------------|-----|
| GPIO_EN1  | 0xbfd0_10d4 | R/W | GPIO1 方向<br>寄存器<br>0表示配置为<br>输出,1表示<br>配置为输入                       | 0x0 |
| GPIO_IN1  | 0xbfd0_10e4 | R   | GPIO1 输入<br>寄存器                                                    | 0x0 |
| GPIO_OUT1 | 0xbfd0_10f4 | R/W | <ul><li>GPIO1 输出<br/>寄存器</li><li>为 1 输出高</li><li>为 0 输出低</li></ul> | 0x0 |

## **5.2.10** GPIO2 配置寄存器(对应 GPIO[95:64])

| 寄存器名称     | 地址          | 读/写(R/W) | 功能描述     | 复位值 |
|-----------|-------------|----------|----------|-----|
| GPIO_CFG2 | 0xbfd0_10c8 | R/W      | GPIO2 配置 | 0x0 |
|           |             |          | 寄存器      |     |
|           |             |          | 1表示配置为   |     |
|           |             |          | GPIO,0 表 |     |
|           |             |          | 示无效      |     |
| GPIO_EN2  | 0xbfd0_10d8 | R/W      | GPIO2 方向 | 0x0 |
|           |             |          | 寄存器      |     |
|           |             |          | 0表示配置为   |     |
|           |             |          | 输出,1表示   |     |
|           |             |          | 配置为输入    |     |
| GPIO_IN2  | 0xbfd0_10e8 | R        | GPIO2 输入 | 0x0 |
|           |             |          | 寄存器      |     |
| GPIO_OUT2 | 0xbfd0_10f8 | R/W      | GPIO2 输出 | 0x0 |
|           |             |          | 寄存器      |     |
|           |             |          | 为1输出高    |     |
|           |             |          | 为0输出低    |     |



# **5.2.11** GPIO3 配置寄存器(对应 GPIO[127:96])

| 寄存器名称     | 地址          | 读/写(R/W) | 功能描述     | 复位值 |
|-----------|-------------|----------|----------|-----|
| GPIO_CFG3 | 0xbfd0_10cc | R/W      | GPIO3 配置 | 0x0 |
|           |             |          | 寄存器      |     |
|           |             |          | 1表示配置为   |     |
|           |             |          | GPIO,0 表 |     |
|           |             |          | 示无效      |     |
| GPIO_EN3  | 0xbfd0_10dc | R/W      | GPIO3 方向 | 0x0 |
|           |             |          | 寄存器      |     |
|           |             |          | 0表示配置为   |     |
|           |             |          | 输出,1表示   |     |
|           |             |          | 配置为输入    |     |
| GPIO_IN3  | 0xbfd0_10ec | R        | GPIO3 输入 | 0x0 |
|           |             |          | 寄存器      |     |
| GPIO_OUT3 | 0xbfd0_10fc | R/W      | GPIO3 输出 | 0x0 |
|           |             |          | 寄存器      |     |
|           |             |          | 为1输出高    |     |
|           |             |          | 为0输出低    |     |

# **5.2.12** PAD[31:0]引脚复用关系配置寄存器

| 寄存器名称        | 地址          | 读/写(R/W) | 功能描述        | 复位值 |
|--------------|-------------|----------|-------------|-----|
| CBUS_FIRST0  | 0xbfd0_11c0 | R/W      | PAD[31:0] 第 | 0x0 |
|              |             |          | 一复用寄存       |     |
|              |             |          | 器, bit 位为 1 |     |
|              |             |          | 时表示对应       |     |
|              |             |          | 的 PAD 配置    |     |
|              |             |          | 为第一复用,      |     |
|              |             |          | 为 0 时表示     |     |
|              |             |          | 无效          |     |
| CBUS_SECOND0 | 0xbfd0_11d0 | R/W      | PAD[31:0] 第 | 0x0 |
|              |             |          | 二复用寄存       |     |
|              |             |          | 器,bit 位为 1  |     |
|              |             |          | 时表示对应       |     |
| 42           |             |          | 的 PAD 配置    |     |



|               |             |     | 为第二复用,             |     |
|---------------|-------------|-----|--------------------|-----|
|               |             |     | 为 0 时表示            |     |
|               |             |     | 无效                 |     |
| CBUS_THIRD0   | 0xbfd0_11e0 | R/W | PAD[31:0] 第        | 0x0 |
|               |             |     | 三复用寄存              |     |
|               |             |     | 器, bit 位为 <b>1</b> |     |
|               |             |     | 时表示对应              |     |
|               |             |     | 的 PAD 配置           |     |
|               |             |     | 为第三复用,             |     |
|               |             |     | 为 0 时表示            |     |
|               |             |     | 无效                 |     |
| CBUS_FOURTHT0 | 0xbfd0_11f0 | R/W | PAD[31:0] 第        | 0x0 |
|               |             |     | 四复用寄存              |     |
|               |             |     | 器, bit 位为 <b>1</b> |     |
|               |             |     | 时表示对应              |     |
|               |             |     | 的 PAD 配置           |     |
|               |             |     | 为第四复用,             |     |
|               |             |     | 为 0 时表示            |     |
|               |             |     | 无效                 |     |
| CBUS_FIFTHT0  | 0xbfd0_1200 | R/W | PAD[31:0] 第        | 0x0 |
|               |             |     | 五复用寄存              |     |
|               |             |     | 器, bit 位为 1        |     |
|               |             |     | 时表示对应              |     |
|               |             |     | 的 PAD 配置           |     |
|               |             |     | 为第五复用,             |     |
|               |             |     | 为 0 时表示            |     |
|               |             |     | 无效                 |     |

1C 芯片的引脚有多种复用关系,最多有六种功能和一种 GPIO 复用关系,具体见数据手册第七章复用关系表格。每个引脚的复用关系优先级如下:

第一复用>第三复用>第三复用>第四复用>第五复用>GPIO 复用>默认功能 比如要使用 PAD[21]的第四复用功能,则需要将 CBUS\_FIRST0[21]~ CBUS\_THIRD0[21]都置为 0,将 CBUS\_FOURTH0[21]置为 1。如果要使用默认功能,则需要将 CBUS\_FIRST0[21]~ CBUS\_FOURTH0[21]和 GPIO[21]都置为 0。



# **5.2.13** PAD[63:32]引脚复用关系配置寄存器

| 寄存器名称         | 地址          | 读/写(R/W) | 功能描述                                                          | 复位值 |
|---------------|-------------|----------|---------------------------------------------------------------|-----|
| CBUS_FIRST1   | 0xbfd0_11c4 | R/W      | PAD[63:32]<br>第一复用寄<br>存器, bit 位<br>为 1 时表示                   | 0x0 |
|               |             |          | 对应的 PAD<br>配置为第一<br>复用,为 0 时<br>表示无效                          |     |
| CBUS_SECOND1  | 0xbfd0_11d4 | R/W      | PAD[63:32]<br>第二复用寄存器, bit 位为 1 时表示对应的 PAD配置为第二复用,为 0 时表示无效   | 0x0 |
| CBUS_THIRD1   | 0xbfd0_11e4 | R/W      | PAD[63:32]<br>第三复用寄存器, bit 位为 1 时表示对应的 PAD配置为第三复用,为 0 时表示无效   | 0x0 |
| CBUS_FOURTHT1 | 0xbfd0_11f4 | R/W      | PAD[63:32]<br>第四复用寄存器, bit 位为 1 时表示对应的 PAD<br>配置为第四复用,为0时表示无效 | 0x0 |
| CBUS_FIFTHT1  | 0xbfd0_1204 | R/W      | PAD[63:32]<br>第五复用寄                                           | 0x0 |



|  | 存器,bit 位 |  |
|--|----------|--|
|  | 为 1 时表示  |  |
|  | 对应的 PAD  |  |
|  | 配置为第五    |  |
|  | 复用,为0时   |  |
|  | 表示无效     |  |

# **5.2.14** PAD[95:64]引脚复用关系配置寄存器

| 寄存器名称         | 地址          | 读/写(R/W) | 功能描述       | 复位值 |
|---------------|-------------|----------|------------|-----|
| CBUS_FIRST2   | 0xbfd0_11c8 | R/W      | PAD[95:64] | 0x0 |
|               |             |          | 第一复用寄      |     |
|               |             |          | 存器,bit 位   |     |
|               |             |          | 为 1 时表示    |     |
|               |             |          | 对应的 PAD    |     |
|               |             |          | 配置为第一      |     |
|               |             |          | 复用,为0时     |     |
|               |             |          | 表示无效       |     |
| CBUS_SECOND2  | 0xbfd0_11d8 | R/W      | PAD[95:64] | 0x0 |
|               |             |          | 第二复用寄      |     |
|               |             |          | 存器,bit 位   |     |
|               |             |          | 为 1 时表示    |     |
|               |             |          | 对应的 PAD    |     |
|               |             |          | 配置为第二      |     |
|               |             |          | 复用,为0时     |     |
|               |             |          | 表示无效       |     |
| CBUS_THIRD2   | 0xbfd0_11e8 | R/W      | PAD[95:64] | 0x0 |
|               |             |          | 第三复用寄      |     |
|               |             |          | 存器,bit 位   |     |
|               |             |          | 为 1 时表示    |     |
|               |             |          | 对应的 PAD    |     |
|               |             |          | 配置为第三      |     |
|               |             |          | 复用,为0时     |     |
|               |             |          | 表示无效       |     |
| CBUS_FOURTHT2 | 0xbfd0_11f8 | R/W      | PAD[95:64] | 0x0 |
|               |             |          | 第四复用寄      |     |
|               |             |          | 存器,bit 位   |     |



|              |             |     | 为 1 时表示<br>对应的 PAD<br>配置为第四<br>复用,为 0 时<br>表示无效                     |     |
|--------------|-------------|-----|---------------------------------------------------------------------|-----|
| CBUS_FIFTHT2 | 0xbfd0_1208 | R/W | PAD[95:64]<br>第五复用寄存器, bit 位为 1 时表示对应的 PAD<br>配置为第五<br>复用,为 0 时表示无效 | 0x0 |

# **5.2.15** PAD[127:96]引脚复用关系配置寄存器

| 寄存器名称         | 地址          | 读/写(R/W) | 功能描述        | 复位值 |
|---------------|-------------|----------|-------------|-----|
| CBUS_FIRST3   | 0xbfd0_11cc | R/W      | PAD[127:96] | 0x0 |
|               |             |          | 第一复用寄       |     |
|               |             |          | 存器          |     |
| CBUS_SECOND3  | 0xbfd0_11dc | R/W      | PAD[127:96] | 0x0 |
|               |             |          | 第二复用寄       |     |
|               |             |          | 存器          |     |
| CBUS_THIRD3   | 0xbfd0_11ec | R/W      | PAD[127:96] | 0x0 |
|               |             |          | 第三复用寄       |     |
|               |             |          | 存器          |     |
| CBUS_FOURTHT3 | 0xbfd0_11fc | R/W      | PAD[127:96] | 0x0 |
|               |             |          | 第四复用寄       |     |
|               |             |          | 存器          |     |
| CBUS_FIFTHT3  | 0xbfd0_120c | R/W      | PAD[127:96] | 0x0 |
|               |             |          | 第五复用寄       |     |
|               |             |          | 存器, bit 位   |     |
|               |             |          | 为 1 时表示     |     |
|               |             |          | 对应的 PAD     |     |
|               |             |          | 配置为第五       |     |
|               |             |          | 复用,为0时      |     |



# 5.3 中断配置寄存器

中断寄存器一共有五组,对应 CPU 的 CAUSE 寄存器里的五位中断位。每一组都有状态寄存器、使能寄存器、置位寄存器、清零寄存器、电平选择寄存器和边沿选择寄存器六个寄存器。这六个寄存器每一位都一一对应。所有的 GPIO 都可以当作中断输入,特殊中断寄存器分布在 INTO\_SR 和 INT1\_SR。

第一组中断寄存器

| 寄存器名称    | 地址          | 读/写(R/W) | 功能描述           | 复位值 |
|----------|-------------|----------|----------------|-----|
| INT0_SR  | 0xbfd0_1040 | R        | 中断状态寄存器 0      | 0x0 |
|          |             |          | 为 1 表示对应的      |     |
|          |             |          | bit 位产生中断,为    |     |
|          |             |          | 0表示无中断         |     |
| INTO_EN  | 0xbfd0_1044 | R/W      | 中断使能寄存器 0      | 0x0 |
|          |             |          | 为1表示使能对应       |     |
|          |             |          | 的 bit 位产生中断,   |     |
|          |             |          | 为0表示禁止         |     |
| INT0_SET | 0xbfd0_1048 | R/W      | 中断置位寄存器 0      | 0x0 |
|          |             |          | 为 1 表示中断置      |     |
|          |             |          | 位,为0无效         |     |
| INT0_CLR | 0xbfd0_104C | R/W      | 中断清 0 寄存器 0    | 0x0 |
|          |             |          | 为 1 表示清除中      |     |
|          |             |          | 断,为0无效         |     |
| INT0_POL | 0xbfd0_1050 | R/W      | 中断极性选择寄        | 0x0 |
|          |             |          | 存器 0           |     |
|          |             |          | 当 int0_edge 配置 |     |
|          |             |          | 成电平触发时,为       |     |
|          |             |          | 1 表示高电平触发      |     |
|          |             |          | 中断,为0表示低       |     |
|          |             |          | 电平触发;          |     |
|          |             |          | 当 int0_edge 配置 |     |
|          |             |          | 成边沿触发时,为       |     |
|          |             |          | 1 表示上升沿触发      |     |
|          |             |          | 中断,为0表示下       |     |



|           |             |     | 降沿触发     |     |
|-----------|-------------|-----|----------|-----|
| INT0_EDGE | 0xbfd0_1054 | R/W | 中断边沿选择寄  | 0x0 |
|           |             |     | 存器 0     |     |
|           |             |     | 为1表示边沿触发 |     |
|           |             |     | 中断,为0表示电 |     |
|           |             |     | 平触发      |     |

| 寄存器名称   | 地址          | 读/写(R/W) | 功能描述  | 复位值 |
|---------|-------------|----------|-------|-----|
| INT0_SR | 0xbfd0_1040 | R        | 中断状态寄 | 0x0 |
|         |             |          | 存器 0  |     |

| INT0_SR      | 位     | 缺省值 | 描述                                                                   |
|--------------|-------|-----|----------------------------------------------------------------------|
| SDIO_int     | 31    | 0   | SDIO 中断状态位                                                           |
| ADC_int      | 30    | 0   | ADC 中断状态位                                                            |
| UART3_int    | 29    | 0   | UART3 中断状态位                                                          |
| Reserved     | 28:24 | 0   |                                                                      |
| RTC_int      | 23:21 | 0   | RTC 中断状态位                                                            |
| PWM_int      | 20:17 | 0   | 对应四路 PWM 中断状态位                                                       |
| NAND_int     | 16    | 0   | NAND 中断状态位                                                           |
| DMA2_int     | 15    | 0   | DMA2 中断状态位                                                           |
| DMA1_int     | 14    | 0   | DMA1 中断状态位                                                           |
| DMA0_int     | 13    | 0   | DMA0 中断状态位                                                           |
| Reversed     | 12:11 | 0   |                                                                      |
| I2S_AC97_int | 10    | 0   | I2S 或者 AC97 中断状态位, ac97_en<br>为 1 时此位为 AC97 中断状态位,反之<br>则为 I2S 中断状态位 |
| SPI1_int     | 9     | 0   | SPI1 中断状态位                                                           |
| SPI0_int     | 8     | 0   | SPIO 中断状态位                                                           |
| CAN1_int     | 7     | 0   | CAN1 中断状态位                                                           |
| CAN0_int     | 6     | 0   | CAN0 中断状态位                                                           |
| UART2_int    | 5     | 0   | UART2 中断状态位                                                          |
| UART1_int    | 4     | 0   | UART1 中断状态位                                                          |
| UART0_int    | 2     | 0   | UART0 中断状态位                                                          |



# 第二组中断寄存器

| 寄存器名称     | 地址          | 读/写(R/W) | 功能描述       | 复位值 |
|-----------|-------------|----------|------------|-----|
| INT1_SR   | 0xbfd0_1058 | R        | 中断状态寄存器 1  | 0x0 |
|           |             |          | 同 INT0_SR  |     |
| INT1_EN   | 0xbfd0_105c | R/W      | 中断使能寄存器 1  | 0x0 |
|           |             |          | 同 INT0_EN  |     |
| INT1_SET  | 0xbfd0_1060 | R/W      | 中断置位寄存器 1  | 0x0 |
|           |             |          | 同 INT0_SET |     |
| INT1_CLR  | 0xbfd0_1064 | R/W      | 中断清0寄存器1   | 0x0 |
|           |             |          | 同 INT0_CLR |     |
| INT1_POL  | 0xbfd0_1068 | R/W      | 中断极性选择寄    | 0x0 |
|           |             |          | 存器 1       |     |
|           |             |          | 同中断极性选择    |     |
|           |             |          | 寄存器 0      |     |
| INT1_EDGE | 0xbfd0_106c | R/W      | 中断边沿选择寄    | 0x0 |
|           |             |          | 存器 1       |     |
|           |             |          | 中断边沿选择寄    |     |
|           |             |          | 存器 0       |     |

| 寄存器名称   | 地址          | 读/写(R/W) | 功能描述  | 复位值 |
|---------|-------------|----------|-------|-----|
| INT1_SR | 0xbfd0_1058 | R        | 中断状态寄 |     |
|         |             |          | 存器 1  |     |

| INT1_SR      | 位     | 缺省值 | 描述                       |
|--------------|-------|-----|--------------------------|
| Gpio[105:96] | 31:22 | 0   | GPIO[105:96]作为中断输入,中断状态位 |
| Reserved     | 21:20 | 0   |                          |
| I2C_int0     | 19    | 0   | I2C0 中断状态位               |
| I2C_int1     | 18    | 0   | I2C1 中断状态位               |
| I2C_int2     | 17    | 0   | I2C2 中断状态位               |
| Reserved     | 16    | 0   |                          |
| UART11_int   | 15    | 0   | UART11 中断状态位             |



| UART10_int | 14 | 0 | UART10 中断状态位   |
|------------|----|---|----------------|
| UART9_int  | 13 | 0 | UART9 中断状态位    |
| UART8_int  | 9  | 0 | UART8 中断状态位    |
| UART7_int  | 8  | 0 | UART7 中断状态位    |
| UART6_int  | 7  | 0 | UART6 中断状态位    |
| UART5_int  | 6  | 0 | UART5 中断状态位    |
| UART4_int  | 5  | 0 | UART4 中断状态位    |
| cam_int    | 4  | 0 | CAMERA 中断状态位   |
| mac_int    | 3  | 0 | MAC 中断状态位      |
| otg_int    | 2  | 0 | OTG 中断状态位      |
| ohci_int   | 1  | 0 | USB_OHCI 中断状态位 |
| ehci_int   | 0  | 0 | USB_EHCI 中断状态位 |

# 第三组中断寄存器

| 寄存器名称     | 地址          | 读/写(R/W) | 功能描述       | 复位值 |
|-----------|-------------|----------|------------|-----|
| INT2_SR   | 0xbfd0_1070 | R        | 中断状态寄存器 2  | 0x0 |
|           |             |          | 同 INT0_SR  |     |
| INT2_EN   | 0xbfd0_1074 | R/W      | 中断使能寄存器2   | 0x0 |
|           |             |          | 同 INT0_EN  |     |
| INT2_SET  | 0xbfd0_1078 | R/W      | 中断置位寄存器2   | 0x0 |
|           |             |          | 同 INT0_SET |     |
| INT2_CLR  | 0xbfd0_107c | R/W      | 中断清0寄存器2   | 0x0 |
|           |             |          | 同 INT0_CLR |     |
| INT2_POL  | 0xbfd0_1080 | R/W      | 中断极性选择寄    | 0x0 |
|           |             |          | 存器 2       |     |
|           |             |          | 中断极性选择寄    |     |
|           |             |          | 存器 0       |     |
| INT2_EDGE | 0xbfd0_1084 | R/W      | 中断边沿选择寄    | 0x0 |
|           |             |          | 存器 2       |     |
|           |             |          | 同中断边沿选择    |     |
|           |             |          | 寄存器 2      |     |



| 寄存器名称   | 地址          | 读/写(R/W) | 功能描述  | 复位值 |
|---------|-------------|----------|-------|-----|
| INT2_SR | 0xbfd0_1070 | R        | 中断状态寄 | 0x0 |
|         |             |          | 存器 2  |     |

| INT2_SR    | 位    | 缺省值 | 描述                     |
|------------|------|-----|------------------------|
| GPIO[31:0] | 31:0 | 0   | GPIO[31:0]作为中断输入,中断状态位 |

# 第四组中断寄存器

| 寄存器名称     | 地址          | 读/写(R/W) | 功能描述        | 复位值 |
|-----------|-------------|----------|-------------|-----|
| INT3_SR   | 0xbfd0_1088 | R        | 中断状态寄存器3    | 0x0 |
|           |             |          | 同 INT0_SR   |     |
| INT3_EN   | 0xbfd0_108c | R/W      | 中断使能寄存器3    | 0x0 |
|           |             |          | 同 INT0_EN   |     |
| INT3_SET  | 0xbfd0_1090 | R/W      | 中断置位寄存器3    | 0x0 |
|           |             |          | 同 INT0_SET  |     |
| INT3_CLR  | 0xbfd0_1094 | R/W      | 中断清0寄存器3    | 0x0 |
|           |             |          | 同 INT0_CLR  |     |
| INT3_POL  | 0xbfd0_1098 | R/W      | 中断极性选择寄     | 0x0 |
|           |             |          | 存器 3        |     |
|           |             |          | 同 INT0_POL  |     |
| INT3_EDGE | 0xbfd0_109c | R/W      | 中断边沿选择寄     | 0x0 |
|           |             |          | 存器 3        |     |
|           |             |          | 同 INT0_EDGE |     |

| 寄存器名称   | 地址          | 读/写(R/W) | 功能描述  | 复位值 |
|---------|-------------|----------|-------|-----|
| INT3_SR | 0xbfd0_1088 | R        | 中断状态寄 | 0x0 |
|         |             |          | 存器 3  |     |

| INT3_SR     | 位    | 缺省值 | 描述                          |
|-------------|------|-----|-----------------------------|
| GPIO[64:32] | 31:0 | ()  | GPIO[63:32]作为中断输入,中断状态<br>位 |

第五组中断寄存器



| 寄存器名称     | 地址          | 读/写(R/W) | 功能描述        | 复位值 |
|-----------|-------------|----------|-------------|-----|
| INT4_SR   | 0xbfd0_10a0 | R        | 中断状态寄存器 4   | 0x0 |
|           |             |          | 同 INT0_SR   |     |
| INT4_EN   | 0xbfd0_10a4 | R/W      | 中断使能寄存器 4   | 0x0 |
|           |             |          | 同 INT0_EN   |     |
| INT4_SET  | 0xbfd0_10a8 | R/W      | 中断置位寄存器 4   | 0x0 |
|           |             |          | 同 INT0_SET  |     |
| INT4_CLR  | 0xbfd0_10ac | R/W      | 中断清 0 寄存器 4 | 0x0 |
|           |             |          | 同 INT0_CLR  |     |
| INT4_POL  | 0xbfd0_10b0 | R/W      | 中断极性选择寄存    | 0x0 |
|           |             |          | 器 4         |     |
|           |             |          | 同 INT0_POL  |     |
| INT4_EDGE | 0xbfd0_10b4 | R/W      | 中断边沿选择寄存    | 0x0 |
|           |             |          | 器 4         |     |
|           |             |          | 同 INT0_EDGE |     |

| 寄存器名称   | 地址          | 读/写(R/W) | 功能描述  | 复位值 |
|---------|-------------|----------|-------|-----|
| INT4_SR | 0xbfd0_10a0 | R        | 中断状态寄 | 0x0 |
|         |             |          | 存器 4  |     |

| INT4_SR     | 位    | 缺省值 | 描述                          |
|-------------|------|-----|-----------------------------|
| GPIO[95:64] | 31:0 | (1) | GPIO[95:64]作为中断输入,中断状态<br>位 |



# 6 SDRAM 控制器

## 6.1 概述

龙芯 1C 处理器内部集成的 SDRAM 内存控制器,能实现的一般的内存读/写/休眠操作,支持 8/16 位数据宽度,支持最大容量为 1GB(1C2 支持 2GB)。

## 6.2 寄存器描述

SDRAM 有一个 64 位的配置寄存器 SD\_CONFIG[63:0], 其中有效为[41:0], 系统分配的配置寄存器为 SD\_CONFIG [63:0], 地址为 0x0410~0x0414, 详细定义如下:

| 寄存器名称            | 地址          | 读/写(R/W) | 功能描述    | 复位值        |
|------------------|-------------|----------|---------|------------|
| SD_CONFIG[31:0]  | 0xbfd0_0410 | R/W      | SDRAM参数 | 0x00143803 |
|                  |             |          | 配置寄存器   |            |
| SD_CONFIG[63:32] | 0xbfd0_0414 | R/W      | SDRAM参数 | 0x80000080 |
|                  |             |          | 配置寄存器   |            |

| SD_CONFIG    | 位     | 缺省值  | 描述           |
|--------------|-------|------|--------------|
| CONFIG_VALID | 41    |      | 配置寄存器有效      |
| HANG_UP      | 40    |      | 挂起标志位        |
| DEF_SEL      | 39    |      | 采用默认配置       |
| TWR          | 38:37 |      | 颗粒的写后预充电时间   |
| TREF         | 36:25 |      | 颗粒的自动刷新周期    |
| TRAS         | 24:21 |      | 颗粒的行打开最小时间   |
| TRFC         | 20:17 |      | 颗粒的自动刷新时间    |
| TRP          | 16:14 |      | 颗粒的预充电时间     |
| TCL          | 13:11 |      | 颗粒的读数据延时     |
| TRCD         | 10:8  |      | 颗粒的行命令到列命令延时 |
| SD_BIT       | 7:6   |      | 颗粒的位宽        |
| SD_CSIZE     | 5:3   | 3'h0 | 颗粒的列数        |
| SD_RSIZE     | 2:0   | 3'h0 | 颗粒的行数        |



## 6.3 软件配置说明

SD\_CONFIG 寄存器详细说明如下:

1. SD\_RSIZE、SD\_CSIZE

SD\_RSIZE 有效值为 00、01、10、11, 分别对应 2K、4K、8K、16K;

SD\_CSIZE 有效值为 00、01、10、11、111, 分别对应 512、1K、2K、4K、256;

这两项配置需要与颗粒对应,其中列数不能比行数大,所以有效配置为:

| 列 / 行 | 00     | 01     | 10          | 11           |
|-------|--------|--------|-------------|--------------|
| 00    | 2Kx512 | 4Kx512 | 8Kx512(不常见) | 16Kx512(不常见) |
| 01    | 2Kx1K  | 4Kx1K  | 8Kx1K       | 16Kx1K(不常见)  |
| 10    | 无      | 4Kx2K  | 8Kx2K       | 16Kx2K       |
| 11    | 无      | 无      | 8Kx4K       | 16Kx4K       |
| 111   | 2Kx256 | 4Kx256 | 8Kx256(不常见) | 16Kx256(不常见) |

#### 2. SD\_BIT

SD\_BIT 的有效值为 00、01、10,分别对应 8bit、16bit 和 32bit。

#### 3. TRCD, TCL, TRP, TRFC, TRAS, TREF, TWR

这些参数都和颗粒的物理特性相关,为物理时间,要根据频率换算成周期数, 下面列出了一些典型频率值时的参数。

| 参数 / 频率(MHZ) | 150   | 133   | 100   | 75    | 33    |
|--------------|-------|-------|-------|-------|-------|
| TRCD         | 3     | 3     | 2     | 2     | 1     |
| TCL          | 3     | 3     | 3     | 2     | 2     |
| TRP          | 3     | 3     | 2     | 2     | 1     |
| TRFC         | 9     | 8     | 6     | 5     | 2     |
| TRAS         | 7     | 6     | 5     | 4     | 2     |
| TREF         | 'h926 | 'h818 | 'h620 | 'h494 | 'h204 |
| TWR          | 2     | 2     | 2     | 1     | 1     |



#### 4. DEF SEL

为 1 时采用默认配置(133MHZ 配置),为 0 时采用外部输入配置。采用默 认配置时外部输入的寄存器配置无效。

#### 5. HANG\_UP

为1时通知控制器进入挂起状态,SDRAM 完成队列里面的操作后进入休眠状态,直至 HANG\_UP 为0退出休眠状态;为0时正常工作,从休眠状态退出时需要将所有行都刷新一遍,至少需要240~480us。SD\_CONFIG 寄存器只有这1位在正常工作是有效。

#### 6. CONFIG VALID

为1时寄存器配置有效;为0时无效,如果一直为低则 SDRAM 不能正常初始化,不能正常工作。建议先将参数配置好,最后再将这1位置高。

注:配置这两个寄存器,必须先写低位 0x410,再写高位 0x414,否则会出现 SDRAM 控制器会在写 0x414 时,将 0x410 初始化的数据当成配置参数,而之后再写的 0x410 数据无效,造成 SDRAM 配置错误,不能正常工作。建议写三次寄存器,最后一次将最高位置 1,配置寄存器使能。(valid 位在 0x414)



# 7 SRAM 控制器

## 7.1 概述

龙芯 1C 处理器内部集成的 SRAM 内存控制器,和 SDRAM 引脚复用,最大可支持 32MB,支持 8/16 位数据宽度。SRAM 控制器可以用于和 SRAM 接口时序相同的 IO 设备。

# 7.2 配置寄存器

内部只有一个配置寄存器 SRAM\_CTRL[15:0],详细配置如下:

| 寄存器名称           | 地址          | 读/写(R/W) | 功能描述    | 复位值    |
|-----------------|-------------|----------|---------|--------|
| MISC_CTRI[15:0] | 0xbfd0_0424 | R/W      | SRAM 参数 | 0x0004 |
|                 |             |          | 配置寄存器   |        |

| SRAM_CTRL    | 位    | 缺省值 | 描述                                                                        |
|--------------|------|-----|---------------------------------------------------------------------------|
| SRAM_EN      | 15   | 0x0 | SRAM 使能,为 1 时 SDRAM 接口用作 SRAM,为 0 时用作 SDRAM 接口                            |
| reserved     | 14:8 | 0x0 | 保留,必须为0                                                                   |
| SRAM_WIDTH16 | 7    | 0x0 | ROM 操作数据宽度,为 1 时表示 16 位,为 0 时表示 8 位                                       |
| ROM_INIT_CNT | 6:2  | 0x1 | RAM 操作的计数初值,用于调整输出信号的相位,范围从 0~0x1f                                        |
| CLOCK_PERIOD | 1:0  | 0x0 | SRAM 操作的计数步进值,用于调整输出信号的时间长度及操作快慢00: 步进为1,最慢01: 步进为210: 步进为4,最快11: 步进为8,最慢 |



# 8 Camera 接口

### 8.1 概述

CAMERA 接口 (Camera Interface), 支持 ITU-R BT.601/656 YCbCr 8-bit 标准 和 RGB565/888 8-bit 标准的输入。输入视频为 640x480 和 320x240 以及其他任意分辨率模式, 支持 RGB565\888、ITU-R BT.601 模式 640x480 分辨率下的缩小一倍, 其余分辨率不支持缩放功能,以及有选择的提供yuv4:2:2/rgb565/rgb888/rgb0888 格式输出。

Camera 接口控制器的功能特性包括:

- 支持 ITU-R BT.601/656 8-bit 和 RGB565/RGB888 8-bit 模式外部接口
- 支持任意分辨率输入的配置
- 仅 640x480 支持缩小 1 倍
- 输出格式: YCbCr 4:2:2, RGB565, RGB888, RGB0888 (32 位), 当输出格式为 RGB565/ YCbCr 4:2:2, 输入像素必须是 32 的整数倍; 输出格式为 RGB888/RGB0888, 输入像素为 16 的整数倍
- 支持任意像素分辨率下格式 ITU-R BT.601/656 8-bit 输入转 RGB (565/0888) 格式的输出,不支持 RGB 输入转 YCbCr4:2:2 输出
- 输出区域为 4 段各能容纳一帧图象的地址空间,可分别配置各地址空间的基地址以及 YCbCr4:2:2 格式下 u 和 v 分量存放的偏移地址
- 支持 RGB565 转 RGB565
- 支持 RGB888 转 RGB888、RGB0888
- 支持 BT601 转 RGB565、RGB0888、YUV
- 支持 BT656 转 RGB565、RGB0888、YUV
- 支持 640\*480 像素的缩小 1 倍(TU-R BT.656 格式除外)
- 支持 RGB 格式输出的矩阵显示



该模块的接口框图:



图 8-1 Camera 接口(CAMIF)功能框图

## 8.2 接口协议

PCLK: 1位输入信号: Camera 处理器驱动的像素时钟。

VSYNC: 1 位输入信号; Camera 处理器驱动的帧同步信号。

HREF: 1位输入信号; Camera 处理器驱动的行同步信号。

DATA: 8位输入信号; Camera 处理器启动的像素数据。

ITU-R BT.601 8-bit 输入时序如图 1 所示,其中数据输入顺序可以为 YCbY Cr 或者 YCrYCb 或者 CrYCbY 或者 CbYCrY。

RGB565/RGB888 8-bit 输入时序与 ITU-R BT.601 8-bit 输入时序一致, 仅数据输入顺序有区别。对于 RGB888,数据输入顺序可以为 R G B 或 B G R。对于 RGB565,数据输入顺序可以为 R5G3 G3B5 或 B5G3 G3R5。RGB565/RGB888 和 ITU-R BT.601 输入模式 可以根据状态寄存器的低两位来设置行有效和帧有效的高低电平。





图 8-2 ITU-R BT. 601 输入时序

ITU-R BT.656 输入时序如图 8-3 所示,其中数据输入顺序可以为 Y CbYCr 或者 YCrYCb 或者 CrYCbY 或者 CbYCrY。SAV 为行起始码,EAV 为行结束码。 基准码(reference code)定义如表 8-1 所示,其中 XY 值的定义如表 8-2 所示。 仅当 XY 为 80、9D 组合或者 C7、DA 组合时,为有效行数据。



图 8-3 ITU-R BT. 656 输入时序

| 数据比特编号 | 第一个字(3FF) | 第二个字(000) | 第三个字(000) | 第四个字(XYZ)      |
|--------|-----------|-----------|-----------|----------------|
| 7(MSB) | 1         | 0         | 0         | 1              |
| 6      | 1         | 0         | 0         | F              |
| 5      | 1         | 0         | 0         | V              |
| 4      | 1         | 0         | 0         | Н              |
| 3      | 1         | 0         | 0         | P <sub>3</sub> |
| 2      | 1         | 0         | 0         | P <sub>2</sub> |
| 1      | 1         | 0         | 0         | P <sub>1</sub> |
| 0      | 1         | 0         | 0         | P <sub>0</sub> |

表 8-1 ITU-R BT. 656 基准码

- F 在场1中为0;在场2中为1
- V 其它位置为 0:场消隐期间为 1
- H SAV 中为 0; EAV 中为 1
- P<sub>0</sub>, P<sub>1</sub>, P<sub>2</sub>, P<sub>3</sub>: 保护比特(见表 8-2)



| MSB | LSB |   |   |       |       |                |       | XY    |
|-----|-----|---|---|-------|-------|----------------|-------|-------|
| 1   | F   | V | Н | $P_3$ | $P_2$ | $\mathbf{P}_1$ | $P_0$ | 16 进制 |
| 1   | 0   | 0 | 0 | 0     | 0     | 0              | 0     | 80    |
| 1   | 0   | 0 | 1 | 1     | 1     | 0              | 1     | 9D    |
| 1   | 0   | 1 | 0 | 1     | 0     | 1              | 1     | AB    |
| 1   | 0   | 1 | 1 | 0     | 1     | 1              | 0     | В6    |
| 1   | 1   | 0 | 0 | 0     | 1     | 1              | 1     | C7    |
| 1   | 1   | 0 | 1 | 1     | 0     | 1              | 0     | DA    |
| 1   | 1   | 1 | 0 | 1     | 1     | 0              | 0     | EC    |
| 1   | 1   | 1 | 1 | 0     | 0     | 0              | 1     | F1    |

表 8-2 第四个字节 XY 值

# 8.3 寄存器描述

帧缓冲区基地址配置寄存器  $DMA\_ADDRi\_CONFIG$  (i=0,...,3)的配置定义如下:

| 寄存器名称            | 地址         | 读/写(R/W) | 功能描述          | 复位值   |
|------------------|------------|----------|---------------|-------|
| DMA_ADDR0_CONFIG | 0xbc280000 | R/W      | 帧缓冲区基<br>地址 0 | 32'h0 |
| DMA_ADDR1_CONFIG | 0xbc280008 | R/W      | 帧缓冲区基<br>地址 1 | 32'h0 |
| DMA_ADDR2_CONFIG | 0xbc280010 | R/W      | 帧缓冲区基<br>地址 2 | 32'h0 |
| DMA_ADDR3_CONFIG | 0xbc280018 | R/W      | 帧缓冲区基<br>地址3  | 32'h0 |

| DMA_ADDRi_CONFIG | 位    | 缺省值   | 描述                                                                                       |
|------------------|------|-------|------------------------------------------------------------------------------------------|
| 帧缓冲区基地址          | 31:0 | 32'h0 | 软件分配 4 个缓冲区的基地址,硬件从地址 0 到地址 3 依次存放好 4 帧数据,然后循环回地址 0 存放。每个缓冲区大小为一帧图象大小。用于 DMA 读数据,采用物理地址。 |

视频分辨率配置寄存器 CAMIF\_CONFIG\_PIX 的配置定义如下。其中,除



640x480 和 320x240 外,其余视频分辨率需要通过配置 CAMIF\_CONFIG\_PIX 寄存器进行定义。

| 寄存器名称            | 地址         | 读/写(R/W) | 功能描述           | 复位值   |
|------------------|------------|----------|----------------|-------|
| CAMIF_CONFIG_PIX | 0xbc280020 | R/W      | 视频分辨率<br>配置寄存器 | 32'h0 |

| CAMIF_CONFIG_PIX | 位     | 缺省值   | 描述                                  |
|------------------|-------|-------|-------------------------------------|
| 浮动像素分辨率行数 y      | 23:12 | 12'h0 | 分辨率行数,例如 1280x720 分辨率下,配置为 720      |
| 浮动像素分辨率列数 x      | 11:0  | 12'h0 | 分辨率列数,例如 1280x720 分辨率下,配置<br>为 1280 |

U、V基地址配置寄存器(CAMIF\_CONFIG\_UOFFSET 和CAMIF\_CONFIG\_VOFFSET)的定义如下表所示。除 640x480 和 320x240 之外的视频分辨率,配置缓冲区需要通过基址配置寄存器指定 YUV4:2:2 格式中 U 和 V 分量在帧缓冲区中的存放基地址。而在进行 RGB 输出显示时,CAMIF\_CONFIG\_UOFFSET 配置矩阵显示地址的偏移量,即一副图像行与行之间的地址间隔。例如,640x480 的图像显示在 1280x720 的屏幕上,则uoffset=(1280-640)x 像素字节。

| 寄存器名称                | 地址         | 读/写(R/W) | 功能描述  | 复位值   |
|----------------------|------------|----------|-------|-------|
| CAMIF_CONFIG_UOFFSET | 0xbc280028 | R/W      | U 基地址 | 32'h0 |
| CAMIF_CONFIG_VOFFSET | 0xbc280030 | R/W      | V 基地址 | 32'h0 |

| CAMIF_CONFIG_UOFFSET | 位    | 缺省值   | 描述                                                                                |
|----------------------|------|-------|-----------------------------------------------------------------------------------|
| U 基地址配置寄存器           | 31:0 | 32'h0 | YUV4:2:2 格式帧缓冲区的 1/2 处为 u 分量的基址。例如 1280x720 分辨率下,voffset 为十进制 1280x720,单位为字节。     |
| CAMIF_CONFIG_VOFFSET | 位    | 缺省值   | 描述                                                                                |
| V 基地址配置寄存器           | 31:0 | 32'h0 | YUV4:2:2 格式帧缓冲区的 3/4 处为 v 分量的基址。例如 1280x720 分辨率下,voffset 为十进制 1280x720x3/2,单位为字节。 |

CAMIF\_CONFIG 配置是启动和关闭 camera 模块的控制寄存器,定义如下: 62



| 寄存器名称        | 地址         | 读/写(R/W) | 功能描述  | 复位值   |
|--------------|------------|----------|-------|-------|
| CAMIF_CONFIG | 0xbc280038 | R/W      | 状态寄存器 | 32'h0 |

|                          | n     | titi dis titi | Inst                           |
|--------------------------|-------|---------------|--------------------------------|
| CAMIF_CONFIG             | 位     | 缺省值           | 描述                             |
| CONFIG_PARA_CLR          | 31:31 | 1'b0          | 1: 启动 CAMERA                   |
|                          | 31.31 | 100           | 0: 关闭 CAMERA                   |
|                          |       |               | 软复位状态位 (只读)                    |
| RST_STATUS               | 30:30 | 1'b0          | 1:表示软复位状态                      |
|                          |       |               | 0: 正常工作状态                      |
|                          |       |               | 软复位清除操作(只写),写1清除软复位            |
| RST_CLR                  | 29:29 | 1'b0          | 写 CAMIF_CONFIG[31]启动 CAMERA 后硬 |
|                          |       |               | 件自动清零                          |
|                          |       |               | buffer 数据覆盖标志位(只读)             |
| DATA_ERR_STATUS          | 28:28 | 1'b0          | 1: 出现数据覆盖错误                    |
|                          |       |               | 0: 未出现错误                       |
|                          |       |               | 由低到高分别对应 4 个帧缓冲区。              |
| CONFIG_BUF_FULL          | 23:20 | 4'b0          | 1: 写满                          |
|                          |       |               | 0: 没写过或者正在写                    |
| CONFIG_PARA_H_WD         | 19:16 | 4'b0          | 等待 Hsync 有效的延迟拍数               |
|                          |       |               | 0: YUV422                      |
| CONFIG_PARA_OUTPUT_D     |       |               | 1: RGB565                      |
| ATA_MODE                 | 14:13 | 2'b0          | 2: RGB888                      |
|                          |       |               | 3: RGB0888                     |
|                          |       |               | 0: RGB                         |
| CONFIG_PARA_INPUT_DAT    | 12:11 | 2'b0          | 1: ITU-R BT.601                |
| A_MODE                   |       |               | 2: ITU-R BT.656                |
|                          |       |               | 0: 不缩放                         |
| CONFIG_PARA_SCALE_MO     | 10:9  | 2'b0          | 1:缩1倍                          |
| DE                       | 20.7  | 200           | 可配像素时固定配为 0。                   |
|                          |       |               | 0: 320x240                     |
| CONFIG_PARA_640X480      | 8:7   | 2'b0          | 1: 640x480                     |
| 2 31.120_111111_01011100 | 0.7   | _ 50          | 2: 可配像素                        |
|                          |       |               | 2. 11日                         |



| CONFIG_PARA_SINGLEFIE LDEN | 6:6 | 1'b0 | 1: 单场<br>0: 非单场 (帧模式下配 0)                                       |
|----------------------------|-----|------|-----------------------------------------------------------------|
| CONFIG_PARA_YUV_ORDE<br>R  | 5:4 | 2'b0 | YUV422的排列格式。 0: YCbYCr 1: YCrYCb 2: CrYCbY 3: CbYCrY            |
| CONFIG_PARA_BGR_EN         | 3:3 | 1'b0 | 1: RGB 排列为 BGR<br>0: RGB 排列为 RGB (ITU-R BT.601/656 转<br>RGB 有效) |
| CONFIG_PARA_RGB_FORM<br>AT | 2:2 | 1'b0 | 0: RGB 输入格式为 565<br>1: RGB 输入格式为 888                            |
| CONFIG_PARA_HS             | 1:1 | 1'b0 | 1: HSYNC 低电平有效<br>0: HSYNC 高电平有效                                |
| CONFIG_PARA_VS             | 0:0 | 1'b0 | 1: VSYNC 低电平有效<br>0: VSYNC 高电平有效                                |

注: 输入格式为 ITU-R BT.656 时 Config\_para\_hs、Config\_para\_vs 只能配 0。

## 8.4 配置操作

#### 8.4.1 访存方式

Camera 接口控制器的输出数据,其帧存储层次如下:

CAMIF 输出的帧存储由 4 个循环的存储空间组成。对于 YCbCr 输出,每个存储空间由亮度 Y、色度 Cb 和 Cr 三个存储空间组成,yuv3 种分量存放的起始地址分别对应空间的基地址处,1/2 地址处,3/4 地址处;对于 RGB 输出,则每个存储空间顺次存放每个 RGB 像素。

Camera 接口控制器的输出数据在内存中的存储方式如下:

帧存储中采用小尾端存储方式。AXI 总线宽度为 64 位。输出为 YCbCr 格式时,每个 Y 或 Cb 或 Cr 各一个字节,分别排放到帧地址的各自对应区域中;输出为 RGB565 时,每个像素 2 个字节;输出为 RGB888(32 位)时,每个像素 4 个字节;输出为 RGB888(24 位)时,每个像素 3 个字节。具体如图 8-4 所示。





图 8-4 存储方式

#### 8.4.2 配置顺序

CAMERA 接口在工作之前需要根据不同的转化模式对一些寄存器进行配置,系统在复位之后,寄存器都是缺省值,只有对各个寄存器进行配置后模块才能工作。配置 CAMERA 接口的工作流程如下:

- 1. 读取 CAMERA 接口中状态寄存器信息,得到其第 30 位,如果为 1 则表示里面的 DMA 处于闲置状态,可以进行下次工作配置。这是因为 DMA 需要和内存交互,在我们控制 CAMERA 接口工作和停止时, DMA 无法做到实时停止。
- 2. 在进行工作配置时,配置顺序为先配置获取图象所要存储到的 4 段地址空间基地址,如果采用任意像素的配置并输出 YUV 格式则还需要配置U 和 V 地址,最后配置状态寄存器,将其第 31 位配置为 1 即可开始工作。
- 3. CAMERA 接口在工作过程中,每完成一个帧地址空间的填写或者 DMA 模块 buffer 中的数据被覆盖都会发送一个中断给 CPU,软件收到中断后可以去查询状态寄存器的第 23-20 位和 28 位,这 5 位在刚启动 CAMERA 接口时初始化为全 0,其后每填满一个帧地址空间 23-20 位就由低到高



值依次变 1,当正在填写一个帧地址空间时,该空间所对应的位变为 0,软件也可自己一直查询状态寄存器来判断帧地址空间的存储状况。当有数据被覆盖 28 位就会置 1。

- 4. 当软件要停止 CAMERA 接口工作时,只需要将状态寄存器的第 31 位写为 0 即可。CAMERA 接口在此情况下会停止对 CAMERA 的输入进行分析, DMA 会停止发送任何数据到帧地址空间,并在接受到所有已发送的请求应答后,将状态寄存器的第 30 位置 1。
- 5. 当 CAMERA 接口的应用软件被其他中断所打断时,可以在中断处理程序中加入关闭 CAMERA 接口的配置请求等待恢复后重启,也可不关闭 CAMERA 接口而在恢复后根据状态寄存器的信息自己判断帧地址空间的存储信息进行图象的取舍。其中 CAMERA 控制器的恢复重启过程如下:
  - ▶ 将状态寄存器的第 31 位写 0,停止 CAMERA 控制器工作
  - ➤ 读状态寄存器的第 30 位,等待 CAMERA 控制器的软复位操作(第 30 位为 1)
  - ▶ 将状态寄存器的第 29 位写 1,清除 CAMERA 控制器软复位
  - ➤ 读状态寄存器的第 30 位,等待 CAMERA 控制器的软复位操作结束 (第 30 位为 0)
- 6. 将状态寄存器的第 31 位写 1, 重新启动 CAMERA 控制器正常工作



# 9 I2S 控制器

### 9.1 概述

1C 中 I2S 控制器,通过 APB 接口,数据宽度是 32 位,支持 DMA 传输,支持多家公司的 codec 芯片。I2S 控制器仅支持主模式,由 I2S 产生位时钟信号和左右声道选择时钟信号。

I2S 的功能特性包括:

- 支持8、16、20、24、32位的音频数据采样位宽
- 支持 8、16、20、24、32 位的左右声道处理字宽
- 包含两个缓存 FIFO, FIFO 的缓存容量为 8 bytes
- I2S 的中断处理模式可配,在 I2S 的发送和接收中断功能都使能后,当两个通道的缓存 fifo 为满仍要写以及为空仍要读时,则向 CPU 发出中断信号
- I2S 可以为 codec 芯片提供系统时钟,时钟频率可配

该模块的接口框图:





图 9-1 I2S 接口框图

## 9.2 接口协议

I2S 发送器和接收器的操作时序如图 9-2 所示。发送器和接收器的 I2S 格式传输操作时序要求都是在信道选择信号(WS)改变之后的第二个位时钟开始传输下一帧数据,数据先传 MSB 位,再传输 LSB 位。发送器和接收器能处理的字位宽可以不一致,若发送器所需发送的数据的位宽比系统所支持的数据位宽要短,则 LSB 补零发送,反之,则忽略部分 LSB 数据;同理,对接收器而言,当接收到的数据的位宽比自己能处理的位宽小时,则 LSB 补零接收,反之,则忽略接收部分 LSB 数据。所以,对收发的数据而言,MSB 是具有固定的,而 LSB 则要取决于要收发的数据的字长已经系统所配置的字长位宽。



图 9-2 I2S 传输协议



## 9.3 专用寄存器

I2S 包含 5 个寄存器, 定义如下图所示。

| 寄存器名称      | 地址          | 读/写(R/W) | 功能描述                            | 复位值   |
|------------|-------------|----------|---------------------------------|-------|
| IISVersion | 0xbfe6_0000 | R/W      | I2S 标识寄存器                       | 32'h0 |
| IISConfig  | 0xbfe6_0004 | R/W      | I2S 配置寄存器                       | 32'h0 |
| IISControl | 0xbfe6_0008 | R/W      | I2S 控制寄存器                       | 32'h0 |
| IISRxData  | 0xbfe6_000c | R/W      | I2S 接收数据寄存器(用于 DMA接收数据)         | 32'h0 |
| IISTxData  | 0xbfe6_0010 | R/W      | I2S 发送数据寄<br>存器(用于 DMA<br>发送数据) | 32'h0 |

接收标识寄存器允许主控机读取接收器的相关工作信息。它标识了 IIS 的地址位宽,数据位宽以及版本号等信息。

| IISVersion | 位   | 缺省值  | 描述                                                             |
|------------|-----|------|----------------------------------------------------------------|
| ADRW       | 9:8 | 2'h0 | 地址总线宽度: 00: 地址宽度 8 位 01: 地址宽度 16 位 10: 地址宽度 32 位 11: 地址宽度 64 位 |
| DATW       | 5:4 | 2'h0 | 数据宽度: 00: 地址宽度 8 位 01: 地址宽度 16 位 10: 地址宽度 32 位 11: 地址宽度 64 位   |
| VER        | 3:0 | 4'h0 | I2S 版本号                                                        |

接收配置寄存器是配置 I2S 的声道字长,音频数据的采样深度以及各个时钟的分频系数的。

| IISConfig | 位     | 缺省值 | 描述                                                                                                     |
|-----------|-------|-----|--------------------------------------------------------------------------------------------------------|
| LR_LEN    | 31:24 | 'h0 | 左右声道处理的字长。                                                                                             |
| RES_DEPTH | 23:16 |     | 采样深度设置:<br>IIS 采样数据长度,有效范围为 8-32,如果<br>发送或者接收到的数据宽度小于采样数据<br>长度,则低位补 0;如果发送或者接收到<br>的数据宽度大于采样数据长度,则低位忽 |



|            |      |     | 略。                                                                         |
|------------|------|-----|----------------------------------------------------------------------------|
| BCLK_RATIO | 15:8 | 'h0 | 位时钟(BCLK)分频系数:<br>位时钟分频系数,分频数为总线时钟频率                                       |
| MCLK_RATIO | 7:0  | 'h0 | 除以 2x(RATIO+1)<br>系统时钟(MCLK)分频系数,<br>系统时钟分频系数,分频数为总线时钟频<br>率除以 2x(RATIO+1) |

控制寄存器用于配置 IIS 的工作使能信号,缓存 FIFO 的存储状态以及中断相关信息状态。

| IISControl | 位   | 缺省值         | 描述                       |
|------------|-----|-------------|--------------------------|
| MASTER     | 15  | 'h0         | 1: IIS 工作于主模式            |
| MSB/LSB    | 14  | 'h0         | 1: 高位在左端                 |
| MSD/LSD    | 14  | 110         | 0: 高位在右端                 |
| RX_EN      | 13  | 'h0         | 控制器接收使能,为 1 时有效,开始接收数据   |
| TX_EN      | 12  | 'h0         | 控制器发送使能,为1时有效,开始发送<br>数据 |
| DV DVA EV  | 11  | п.о         |                          |
| RX_DMA_EN  | 11  | 'h0         | DMA 接收使能,为 1 时有效         |
| Reserved   | 10: | 'h0         |                          |
| Reserved   | 8   | 110         |                          |
| TX_DMA_EN  | 7   | 'h0         | DMA 发送使能,为 1 时有效         |
| Reserved   | 6:2 | 'h0         |                          |
| DV INT EN  | 1   | 11-0        | RX 中断使能,为1时使能中断,为0时      |
| RX_INT_EN  | 1   | 'h0         | 禁止                       |
| TV INT EN  | 0   | <b>"</b> -0 | TX 中断使能,为1时使能中断,为0时      |
| TX_INT_EN  | 0   | 'h0         | 禁止                       |

# 9.4 配置操作

I2S 正常工作,需要先配置好 CODEC 芯片,然后配置 I2S 控制器的的配置 寄存器和控制寄存器。

1C 芯片通过 I2C 接口和 CODEC 芯片通信,CODEC 芯片作为 I2C 总线上的 从设备,详细地址、寄存器和配置方法请参考具体 CODEC 芯片的数据手册。

配置完 CODEC 之后,需要对 I2S 控制器进行配置。可以将一些配置信息写



入标志寄存器(I2SVersion),以供查询。先配置好 I2SConfig 寄存器,再配置 I2SControl 寄存器。

I2SConfig 寄存器建议 LR\_LEN 和 RES\_DEPTH 配成一样,不至于在传输过程中丢数据或者空数据。BCK 时钟根据配置 CODEC 的采样频率、采样深度和倍频系数来计算,计算公式如下:

BCK = 256xfs(或者 512xfs) 或者(768xfs); (详细见 CODEC 手册推荐配置)
BCK\_RATIO= Freq\_SDRAM / (256 x fs) /2 - 1;

双通道的话, 计算公式下:

 $SCK = RES_DEPTH \times 2 xfs;$ 

SCK\_RATIO= Freq\_SDRAM / (RES\_DEPTH x 2 x fs) /2 - 1;

其中 fs 为配置的采样频率。发送和读取数据时,需要先配置好 DMA,再配置控制器,以免发生数据丢失。DMA 复用的配置方法见第 14.3 节。



# 10 显示控制器(DC)

## 10.1 概述

显示控制器从内存中取帧缓冲输出到外部显示接口上。

龙芯 1C 的显示控制器支持的特性包括:

- 一路 DVO 显示,最大支持至 1024x768@60Hz
- RGB444,RGB555,RGB565,RGB888, RGB8888 五种数据格式
- 输出抖动和伽马校正

# 10.2 寄存器定义和说明

#### 10.2.1 帧缓冲配置寄存器

| 寄存器名             | 地址      |       | R/W     | 描述       | 复位值    |
|------------------|---------|-------|---------|----------|--------|
| frameBufferConfi | 0xbc30_ | 124   | R/W     | 帧缓冲配置寄存器 | 32' h0 |
| g                | 0       |       |         |          |        |
| frameBufferConfi | bit     | 描述    |         |          | 初始值    |
| g                |         |       |         |          |        |
| Reset            | 20      | 从值    | 1 变为 01 | 时软复位     | 0      |
| Gamma            | 12      | 写 1   | 使能伽马林   | 0        |        |
| Output Enable    | 8       | 写 1   | 使能显示    | 0        |        |
| Format           | 2:0     | 色深    | 格式:     | 0        |        |
|                  |         | 0: nc | one     |          |        |
|                  |         | 1: R  | GB444   |          |        |
|                  |         | 2: R  | GB555   |          |        |
|                  |         | 3: R  | GB565   |          |        |
|                  |         | 4: R  | GB888   |          |        |
|                  |         | 5: R  | GB8888  |          |        |

#### 10.2.2 帧缓冲地址寄存器 0

| 寄存器名             | 地址         |    | R/W  | 描述         | 复位值    |
|------------------|------------|----|------|------------|--------|
| frameBufferAddr0 | 0xbc301260 |    | R/W  | 帧缓冲地址寄存器 0 | 32' h0 |
| frameBufferAddr0 | bit        | 描述 |      | 初始值        |        |
| Address          | 31:0       | 缓冲 | 区0在内 | 0          |        |

#### 10.2.3 帧缓冲地址寄存器 1

| 寄存器名             | 地址         |    | R/W   | 描述         | 复位值    |
|------------------|------------|----|-------|------------|--------|
| frameBufferAddr1 | 0xbfe51580 |    | R/W   | 帧缓冲地址寄存器 1 | 32' h0 |
| frameBufferAddr1 | bit        | 描述 |       | 初始值        |        |
| Address          | 31:0       | 缓冲 | 区1在内7 | 0          |        |
|                  |            | 址寄 | 存器0相  |            |        |

#### 10.2.4 帧缓冲跨度寄存器



| 寄存器名              | 地址         |                | R/W                         | 描述                                                                      | 复位值    |
|-------------------|------------|----------------|-----------------------------|-------------------------------------------------------------------------|--------|
| frameBufferStride | 0xbc301280 |                | R/W                         | 帧缓冲跨度寄存器                                                                | 32' h0 |
| frameBufferStride | bit        | 描述             |                             | 初始值                                                                     |        |
| Stride            | 31:0       | 当使<br>要按<br>当使 | 用 RGB88<br>120 字节<br>用 RGB8 | 的字节数。<br>38(24 位)格式时,stride 需<br>向上取整。<br>888(32 位)格式时,stride<br>节向上取整。 | 0      |

#### 10.2.5 颜色抖动配置寄存器

| 寄存器名         | 地址         |    | R/W  | 描述        | 复位值    |
|--------------|------------|----|------|-----------|--------|
| ditherConfig | 0xbc301360 |    | R/W  | 颜色抖动配置寄存器 | 32' h0 |
| ditherConfig | bit        | 描述 |      | 初始值       |        |
| Enable       | 31         | 写1 | 使能颜色 | 0         |        |
| RedSize      | 19:16      | 红色 | 域宽度  | 0         |        |
| GreenSize    | 11:8       | 绿色 | 域宽度  | 0         |        |
| BlueSize     | 3:0        | 蓝色 | 域宽度  |           | 0      |

#### 10.2.6 颜色抖动查找表低位寄存器

| 寄存器名           | 地址      |     | R/W     | 描述           | 复位值    |
|----------------|---------|-----|---------|--------------|--------|
| ditherTableLow | 0xbc301 | 380 | R/W     | 颜色抖动查找表低位寄存器 | 32' h0 |
| 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      |

## 10.2.7 颜色抖动查找表高位寄存器

| 寄存器名            | 地址      |     | R/W     | 描述           | 复位值    |
|-----------------|---------|-----|---------|--------------|--------|
| ditherTableHigh | 0xbc301 | 3a0 | R/W     | 颜色抖动查找表高位寄存器 | 32' h0 |
| 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      |

#### 10.2.8 颜色抖动说明

颜色抖动功能用于根据一定规则来增强像素值。

在下面的这个例子中,将解释颜色抖动功能的实现步骤。

首先,确定是对哪一数据位进行增强(即该数据位加1),为此需要配置寄存 73



器 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]不是 6'b111111,则 RedColor[2]位加 1,实现颜色增强。

#### 10.2.9 液晶面板配置寄存器

| 寄存器名        | 地址         |    | R/W   | 描述        | 复位值      |
|-------------|------------|----|-------|-----------|----------|
| panelConfig | 0xbc3013c0 |    | R/W   | 液晶面板配置寄存器 | 32' h101 |
| panelConfig | bit        | 描述 |       | 初始值       |          |
| ClockPol    | 9          | 时钟 | 极性,写  | 0         |          |
| ClockEn     | 8          | 时钟 | 使能,写  | 1         |          |
| DEPol       | 1          | 数据 | 使能极性, | 0         |          |
| DE          | 0          | 数据 | 使能,写  | 1 使能      | 1        |

#### 10.2.10 水平显示宽度寄存器

| 寄存器名     | 地址         |    | R/W   | 描述        | 复位值    |
|----------|------------|----|-------|-----------|--------|
| HDisplay | 0xbc301400 |    | R/W   | 水平显示宽度寄存器 | 32' h0 |
| HDisplay | bit        | 描述 |       | 初始值       |        |
| Total    | 27:16      | 显示 | 屏一行的点 | 0         |        |
| Display  | 11:0       | 显示 | 屏一行中。 | 显示区的像素数   | 0      |

#### 10.2.11 行同步配置寄存器

| 寄存器名  | 地址         |    | R/W   | 描述       | 复位值           |
|-------|------------|----|-------|----------|---------------|
| HSync | 0xbc301420 |    | R/W   | 行同步配置寄存器 | 32' h40000000 |
| HSync | bit        | 描述 |       | 初始值      |               |
| Pol   | 31         | 行同 | 步极性,  | 0        |               |
| Pulse | 30         | 行同 | 步使能,  | 1        |               |
| End   | 27:16      | 行同 | 步结束时间 | 0        |               |
| Start | 11:0       | 行同 | 步开始时间 | 的像素数     | 0             |

#### 10.2.12垂直显示高度寄存器

| 寄存器名     | 地址         |    | R/W   | 描述           | 复位值    |  |
|----------|------------|----|-------|--------------|--------|--|
| VDisplay | 0xbc301480 |    | R/W   | 垂直显示高度寄存器    | 32' h0 |  |
| VDisplay | bit        | 描述 |       |              | 初始值    |  |
| Total    | 26:16      | 显示 | 屏一列的  | 总像素数(包括非显示区) | 0      |  |
| Display  | 10:0       | 显示 | 屏一列中、 | 0            |        |  |



#### 10.2.13 场同步配置寄存器

| 寄存器名  | 地址         |    | R/W  | 描述       | 复位值           |  |  |
|-------|------------|----|------|----------|---------------|--|--|
| VSync | 0xbc3014a0 |    | R/W  | 场同步配置寄存器 | 32' h40000000 |  |  |
| VSync | bit        | 描述 |      | 初始值      |               |  |  |
| Pol   | 31         | 场同 | 步极性, | 0        |               |  |  |
| Pulse | 30         | 场同 | 步使能, | 1        |               |  |  |
| End   | 26:16      | 场同 | 步结束时 | 0        |               |  |  |
| Start | 10:0       | 场同 | 步开始时 | 0        |               |  |  |

10.2.14 输出定序说明



图 10-1 显示控制器输出定序

## 10.2.15 伽马校正目录寄存器

| 寄存器名       | 地址         |     | R/W     | 描述        | 复位值    |
|------------|------------|-----|---------|-----------|--------|
| GammaIndex | 0xbc3014e0 |     | R/W     | 伽马校正目录寄存器 | 32' h0 |
| GammaIndex | bit        | 描述  |         | 初始值       |        |
| Index      | 7:0        | 表示  | 从 0-255 | 0         |        |
|            |            | Gam | ıma 调整, |           |        |
|            |            | 值硬  | 件会自增。   |           |        |

#### 10.2.16 伽马校正值寄存器

| 寄存器名       | 地址      |     | R/W     | 描述                   | 复位值    |
|------------|---------|-----|---------|----------------------|--------|
| GammaData  | 0xbc301 | 500 | R/W     | 伽马校正值寄存器             | 32' h0 |
| GammaIndex | bit     | 描述  |         | 初始值                  |        |
| Red        | 23:16   | Gam | ıma 调整的 | 的红色域,将 Gamma Index 指 | 0      |
|            |         | 示的  | 值调整为    |                      |        |
| Green      | 15:8    | Gam | ıma 调整的 | 0                    |        |
|            |         | 示的  | 值调整为    |                      |        |
| Blue       | 7:0     | Gam | ıma 调整的 | 0                    |        |
|            |         | 示的  | 值调整为    |                      |        |



#### 10.2.17 伽马校正说明

Gamma 调整模块包含三个查找表,一个负责红色,一个负责绿色,一个负责蓝色。

查找表可以通过寄存器改写。查找表只可写。

考虑一个 Gamma 调整如下: (原色,调整色)。当设置 Gamma 颜色查找表时, 我们应该按照颜色值大小顺序配置寄存器.。

如果我们想要一个调整为 (0,0)(1,2)(2,5)(3,6) ……, 先对寄存器 Gamma Index 配置 0,表示 gamma 调整从 0 开始,然后对 Gamma Data 寄存器配置 256 次完成整个配置过程: 0, 2, 5, 6……



# 11 MAC 控制器

## 11.1 DMA 寄存器描述

龙芯 1C 集成了 1 个 MAC 控制器。MAC 内部集成独有的 DMA 控制器,专门配合 MAC 数据传输;该 DMA 控制器不能被其他模块使用,MAC 也无法使用外部其他 DMA。MAC 控制器寄存器包括 MAC 寄存器部分和 DMA 寄存器部分。MAC 寄存器的起始地址是 0xbfe1\_0000; DMA 寄存器的起始地址是 0xbfe1\_1000。

下面分别介绍 DMA 寄存器和 MAC 寄存器的意义。

11.1.1 Register0 (Bus Mode Register)

| 参数名称                                    | 位        | 缺省值         | 描述                                                                                               |
|-----------------------------------------|----------|-------------|--------------------------------------------------------------------------------------------------|
| Register0 (Bus Mode                     | Register | ) Offset: ( | )x00                                                                                             |
| Reserved<br>保留                          | 31:27    | 0x0         | 保留,只读                                                                                            |
| MB: Mixed Burst<br>混合突发访问               | 26       | 0x0         | 当此位为高,FB 位为低时,AXI master 在突发访问长度大于 16 时采用 INCR 访问模式,当突发访问长度为 16 或者小于 16 时采用 FIX 访问模式。用户不用关心此位设置。 |
| AAL:Address-Align<br>ed Beats<br>地址对齐节拍 | 25       | 0x0         | 当此位和 FB 位同时为高时,AXI 接口的所有访问将对齐到起始地址的 LS 位。如果 FB 位为 0,首次访问地址访问不对齐,剩余的访问地址对齐。用户不用关心此位设置。            |
| 8XPBL Mode<br>是否使能 PBLX8 模<br>式         | 24       | 0x0         | 此位为高时, MAC DMA 的最大突发数据传输长度为8,16,32,64,128 或者 256。最大突发长度取决于PBL。用户不用关心此位设置。                        |
| USP:Use Separate<br>PBL<br>使用分离的 PBL 值  | 23       | 0x0         | 此位为高时,PBL值只应用于TxDMA。此位为低时,PBL值应用于TxDMA和RxDMA。用户不用关心此位设置。                                         |
| RPBL: RxDMA PBL<br>RxDMA 突发传输长<br>度     | 22:17    | 0x01        | 表示一次 RxDMA 传输的最大突发传输长度。只能为1,2,4,8,16 和 32, 其它值无效。                                                |
| FB: Fixed Burst                         | 16       | 0x0         | 指定 AXI Master 接口是否采用 FIX 突发传输模式。                                                                 |



| 定长突发传输长度           |       |      | 用户不用关心此位设置。                                |  |  |  |
|--------------------|-------|------|--------------------------------------------|--|--|--|
| 使能                 |       |      |                                            |  |  |  |
| PR: Rx:Tx priority |       |      | 在 DA 位为 0 时起作用。                            |  |  |  |
| ratio              | 15:14 | 0x0  | 00: 1: 1                                   |  |  |  |
| RxDMA 与 TxDMA      | 15.14 | UXU  | 01: 2: 1<br>10: 3: 1                       |  |  |  |
| 优先级比例              |       |      | 11: 4: 1                                   |  |  |  |
| PBL:Programmable   |       |      |                                            |  |  |  |
| Burst Length       | 13:8  | 0x1  | <br> 用户不用关心此设置。                            |  |  |  |
| 可编程突发传输长           | 13.0  | UXI  | 四,作四人心此 <b>以</b> 直。                        |  |  |  |
| 度                  |       |      |                                            |  |  |  |
| ATDS:Alternate     |       |      |                                            |  |  |  |
| Descriptor size    | 7     | 0x0  | 此位为 1 时使用 32 字节大小的描述符                      |  |  |  |
| 是否使用 32 字节         |       |      | 此位为 0 时使用 16 字节大小的描述符                      |  |  |  |
| 大小描述符              |       |      |                                            |  |  |  |
| DSL: Descriptor    |       |      | 设置 2 个描述符间的距离。但此值为 0 时,默认为                 |  |  |  |
| Skip Length        | 6:2   | 0x00 | DMA 描述符大小。                                 |  |  |  |
| 描述符间隔距离            |       |      | DIVIA 抽处的人小。                               |  |  |  |
| DA: DMA            |       |      | 0:在 RxDMA 和 TxDMA 间采用轮转仲裁机制                |  |  |  |
| Arbitration scheme | 4     |      | , , , , , , , , , , , , , , , , , , , ,    |  |  |  |
| DMA                | 1     | 0x0  | 1: RxDMA 优先级高于 TxDMA 优先级。具体比值见PR 值。        |  |  |  |
| 传输仲裁策略             |       |      | FN 但。                                      |  |  |  |
| SWR:Software       |       |      |                                            |  |  |  |
| Reset              | 0     | 0x1  | 此位置高 DMA 控制器将复位 MAC 内部寄存器和逻辑。当复位结束时该位自动清零。 |  |  |  |
| 软件复位               |       |      | 件。                                         |  |  |  |

**11.1.2** Register1 (Transmit Poll Demand Register)

| Register1 (Transmit Poll Demand Register) Offset: 0x04 |      |     |                            |  |  |
|--------------------------------------------------------|------|-----|----------------------------|--|--|
| TPD: Transmit Poll                                     |      | 0x0 | 向此值写入任意值,发送 DMA 控制器将会读取寄存  |  |  |
| Demand                                                 | 31:0 |     | 器 18 对应的描述符。如果该描述符无效,DMA 传 |  |  |
| 传输轮询使能<br>传输轮询使能                                       |      |     | 输将会停止。如果该描述符有效,DMA 传输将会继   |  |  |
| 文制化 构 区形                                               |      | 续。  |                            |  |  |

11.1.3 Register2 (Receive Poll Demand Register)

| Register2 (Receive Po | Offset: 0x08 |     |                           |
|-----------------------|--------------|-----|---------------------------|
| RPD: Receive Poll     | 31:0         | 0x0 | 向此值写入任意值,接收 DMA 控制器将会读取寄存 |



| Demand |  | 器 18 对原 | 应的 | 描述符。 | 如果该抗  | 描述符无   | 效, | DMA | 传  |
|--------|--|---------|----|------|-------|--------|----|-----|----|
| 接收轮询使能 |  | 输将会停    | 止。 | 如果该抗 | 描述符有效 | 效, DMA | 传  | 输将会 | 会继 |
|        |  | 续。      |    |      |       |        |    |     |    |

11.1.4 Register3 (Receive Descriptor List Address Register)

| Register3 (Receive Descriptor List Address Register) Offset: 0x0C |      |     |             |  |  |
|-------------------------------------------------------------------|------|-----|-------------|--|--|
| Start of Receive<br>List<br>接收描述符起始地<br>址                         | 31:0 | 0x0 | 指向接收描述符首地址。 |  |  |

11.1.5 Register4 (Transmit Descriptor List Address Register)

| Register4 (Transmit Descriptor List Address Register) Offset: 0x10 |      |     |            |  |  |  |  |
|--------------------------------------------------------------------|------|-----|------------|--|--|--|--|
| Start of Transmit                                                  |      |     |            |  |  |  |  |
| List                                                               | 04.0 | 0.0 | +v         |  |  |  |  |
| 发送描述符起始地                                                           | 31:0 | 0x0 | 指向发送描述符首地址 |  |  |  |  |
| 址                                                                  |      |     |            |  |  |  |  |

**11.1.6** Register5 (Status Register)

| Register5 (Status Regi                                  | Register5 (Status Register) Offset: 0x14 |     |                                 |  |  |  |
|---------------------------------------------------------|------------------------------------------|-----|---------------------------------|--|--|--|
| Reserved                                                | 31:30                                    |     | 保留,只读                           |  |  |  |
| TTI: Time-Stamp<br>Trigger Interrupt<br>时间戳触发中断         | 29                                       | 0x0 | 时间戳模块触发中断。只读。                   |  |  |  |
| GPI:MAC PMT<br>Interrutp<br>电源管理模块触发<br>中断              | 28                                       | 0x0 | 电源管理模块触发中断。只读。                  |  |  |  |
| GMI:MAC MMC<br>Interrupt<br>MMC 模块触发中断                  | 27                                       | 0x0 | MMC 模块触发中断。只读。                  |  |  |  |
| GLI:MAC Line<br>interface Interrupt<br>MAC 模块线路触发<br>中断 | 26                                       | 0x0 | MAC 模块的 PCS 或者 RGMII 模块触发中断。只读。 |  |  |  |



| EB: Error Bits<br>错误位                       | 25:23 | 0x0 | <ul> <li>23: 1'b1 TxDMA 数据传输过程中发生错误</li> <li>1'b0 RxDMA 数据传输过程中发生错误</li> <li>24: 1'b1 读传输错误</li> <li>1'b0 写传输错误</li> <li>25: 1'b1 描述符访问错误</li> <li>1'b0 数据缓存访问错误</li> </ul>     |
|---------------------------------------------|-------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TS:Transmit<br>Process State<br>传输过程状态      | 22:20 | 0x0 | 3'b000:传输停止;复位或者停止命令发送 3'b001:正在进行;获取传输描述符 3'b010:正在进行;等待传输状态 3'b011:正在进行;从发送缓存读取数据并发送到传输FIFO(TxFIFO) 3'b100:写入时间戳状态 3'b101:保留 3'b111:运行;关闭传输描述符不可用或者传输缓存下溢。 3'b111:运行;关闭传输描述符。 |
| RS:Receive<br>Process State<br>接收过程状态       | 19:17 | 0x0 | 3'b000:停止;复位或者接收到停止命令<br>3'b001:运行;获取接收描述符。<br>3'b010:保留;<br>3'b011:运行;等待接收包。<br>3'b100:暂停;接收描述符不可用。<br>3'b101:运行;关闭接收描述符。<br>3'b110:时间戳写状态。<br>3'b111:运行;将包内容从接收缓存传输到系统内存。     |
| NIS:Normal<br>Interrutp Summary<br>正常中断汇总   | 16    | 0x0 | 提示系统是否存在正常中断。                                                                                                                                                                   |
| AIS:Abnormal<br>Interrutp Summary<br>异常中断汇总 | 15    | 0x0 | 提示系统是否存在异常中断。                                                                                                                                                                   |
| ERI:Early Receive<br>Interrutp<br>提前接收中断    | 14    | 0x0 | 提示 DMA 控制器已经把包的第一个数据写入接收缓存                                                                                                                                                      |



| FBI:Fatal Bus Error |       |     | 提示总线错误,具体信息见[25:23]。当此位设置后                           |
|---------------------|-------|-----|------------------------------------------------------|
| Interrutp           | 13    | 0x0 | DMA 引擎停止总线访问操作。                                      |
| 总线错误中断              |       |     | 31 3 13 12.2.33(331 33)(11 6                         |
| Reserved            | 12:11 | 0x0 | 保留                                                   |
| ETI:Early Transmit  |       |     |                                                      |
| Interrupt           | 10    | 0x0 | 提示需要传输的以太网帧已经完全传输到 MTL 模块                            |
| 提前发送中断              |       |     | 中的传输 FIFO                                            |
| RWT:Receive         |       |     | 提示接收到一个大小超过2048字节的以太网帧。(当                            |
| Watchdog Timeout    | 9     | 0x0 | 巨帧使能时,提示接收到大小超过 10240 字节的以                           |
| 接收看门狗超时             |       |     | 太网帧)                                                 |
| RPS:Receive         |       |     |                                                      |
| Process Stopped     | 8     | 0x0 | 指示接收过程停止                                             |
| 接收过程停止              |       |     |                                                      |
| RU:Receive Buffer   |       |     |                                                      |
| Unavailable         | 7     | 0x0 | 指示接收缓存不可用                                            |
| 接收缓存不可用             |       |     |                                                      |
| RI:Receive          |       |     | HV _ mt 40 ub ch |
| Interrupt           | 6     | 0x0 | 指示帧接收完成。帧接收的状态信息已经写入接收描述符。接收处于运行状态。                  |
| 接收中断                |       |     | 处内。 按权处 1 运11 <b></b> 机态。                            |
| UNF:Transmit        |       |     |                                                      |
| Underflow           | 5     | 0x0 | 指示帧发送过程中产生接收缓存下溢。                                    |
| 传输缓存下溢              |       |     |                                                      |
| OVF:Receive         |       |     |                                                      |
| Overflow            | 4     | 0x0 | 指示帧接收过程中接收缓存上溢。                                      |
| 接收缓存上溢              |       |     |                                                      |
| TJT:Transmit        | 3     | 0x0 |                                                      |
| Jabber Timeout      | J     | UXU |                                                      |
| TU:Transmit Buffer  |       |     | 提示传输列表中的下一个描述符不能被 DMA 控制器                            |
| Unavailable         | 2     | 0x0 | 旋水位制列农中的下一个抽处行个能被 DWA 经制备<br>访问。                     |
| 传输缓存不可用             |       |     | N1 L 1 o                                             |
| TPS:Transmit        |       |     |                                                      |
| Process Stopped     | 1     | 0x0 | 提示传输过程停止                                             |
| 传输过程停止              |       |     |                                                      |



| TI:Transmit |   |     |                        |
|-------------|---|-----|------------------------|
| Interrutp   | 0 | 0x0 | 提示帧传输完成并且第一个描述符的31位置位。 |
| 传输完成中断      |   |     |                        |

| 11.1.7 Register6 (Operation Mode Register) |         |            |                                         |  |
|--------------------------------------------|---------|------------|-----------------------------------------|--|
| Register6 (Operation l                     | Mode Re | egister) O | ffset: 0x18                             |  |
| Reserved                                   | 04.07   | 00         | In Su                                   |  |
| 保留                                         | 31:27   | 0x0        | 保留                                      |  |
| DT                                         |         |            |                                         |  |
| 关闭丢弃 TCP/IP                                | 26      | 0x0        | 此位为1时 MAC 将不丢弃 checksum 错误的以太网          |  |
| Checksum 错误以                               | 20      | OXO        | 帧。                                      |  |
| 太网帧的功能                                     |         |            |                                         |  |
| RSF:Receive Store                          |         |            | 此位为 1 时 MTL 模块只接收已经全部存储在接收              |  |
| and Forward                                | 25      | 0x0        | FIFO 中的以太网帧。                            |  |
| 接收存储转发                                     |         |            | III O T HJØAKF319X0                     |  |
| DFF:Disable                                |         |            |                                         |  |
| Flushing of                                |         |            | 此位为 1 时,接收 DMA 在接收描述符或者接收缓存             |  |
| Received Frames                            | 24      | 0x0        | 而也为了的,接收 DMA 在接收抽处行或有接收缓行不可用时不冲刷任何以太网帧。 |  |
| 关闭冲刷接收的以                                   |         |            | 1 4/13/2   11/0/4 [[13/5/X] 1]/2        |  |
| 太网帧的功能                                     |         |            |                                         |  |
| RFA[2]:MSB of                              |         |            | 100: 最大值减去 5KB                          |  |
| Threshold for                              |         |            | 101:最大值减去 6KB                           |  |
| Activating Flow                            | 23      | 0x0        | 110: 最大值减去 7KB                          |  |
| Control                                    |         |            | 111: 保留                                 |  |
| 激活流控阈值                                     |         |            | (注: 最大值为 8KB)                           |  |
| RFD[2]:MSB of                              |         |            | 100: 最大值减去 5KB                          |  |
| Threshold for                              |         |            | 101: 最大值减去 6KB                          |  |
| Deactivating Flow                          | 22      | 0x0        | 110: 最大值减去 7KB                          |  |
| Control                                    |         |            | 111: 保留                                 |  |
| 关闭流控阈值                                     |         |            | (注:最大值为 8KB)                            |  |
| TSF:Transmit Store                         |         |            |                                         |  |
| and Forward                                | 21      | 0x0        | 此位为 1 时,帧的发送只在帧的内容已经全部进入                |  |
| 发送存储转发                                     |         |            | MTL 的传输 FIFO 中。                         |  |
| FTF:Flush Transmit                         | 20      | 0x0        | 此位为 1 时,传输控制逻辑复位为默认值,并且会                |  |



| FIFO                                                        |       |     | 导致发送 FIFO 里面的数据全部丢失。                                                                                                 |
|-------------------------------------------------------------|-------|-----|----------------------------------------------------------------------------------------------------------------------|
| 冲刷传输 FIFO                                                   |       |     |                                                                                                                      |
| Reserved                                                    | 19:17 | 0x0 | 保留                                                                                                                   |
|                                                             |       |     | 当帧大小超过此值时 MTL 将会传输该帧。                                                                                                |
|                                                             |       |     | 000: 64 字节                                                                                                           |
|                                                             |       |     | 001: 128 字节                                                                                                          |
| TTC:Transmit                                                |       |     | 010: 192 字节                                                                                                          |
| Threshold Control                                           | 16:14 | 0x0 | 011: 256 字节                                                                                                          |
| 传输阈值控制                                                      |       |     | 100: 40 字节                                                                                                           |
|                                                             |       |     | 101: 32 字节                                                                                                           |
|                                                             |       |     | 110: 24 字节                                                                                                           |
|                                                             |       |     | 111: 16 字节                                                                                                           |
| ST:Start/Stop<br>Transmission<br>Command<br>开始/停止传输命令       | 13    | 0x0 | 此位为 1, 传输进入运行状态。<br>此位为 0, 传输进入停止状态。                                                                                 |
| RFD:Threshold for<br>deactivating flow<br>control<br>关闭流控阈值 |       | 0x0 | <ul><li>00: 最大值减去 1KB</li><li>01: 最大值减去 2KB</li><li>10: 最大值减去 3KB</li><li>11: 最大值减去 4KB</li><li>(最大值为 8KB)</li></ul> |
| RFA:Threshold for<br>Activating flow<br>control<br>激活流控阈值   |       | 0x0 | <ul><li>00: 最大值减去 1KB</li><li>01: 最大值减去 2KB</li><li>10: 最大值减去 3KB</li><li>11: 最大值减去 4KB</li><li>(最大值为 8KB)</li></ul> |
| EFC:Enable HW<br>flow control<br>使能硬件流控                     | 8     | 0x0 | 此位为 1 时,基于接收 FIFO 利用率的硬件流控电路<br>生效。                                                                                  |
| FEF:Forward Error<br>Frames<br>传输错误帧                        | 7     | 0x0 | 此位为 1 时,接收错误帧(错误帧包括: CRC 错误,冲突错误,巨帧,看门狗超时,溢出等)                                                                       |



| FUF:Forward<br>Undersized Good<br>Frames<br>接收无错误的小帧 | 6   | 0x0 | 此位为 1 时,接收 FIFO 将会接收没有错误但小于64 字节的以太网帧。                                |
|------------------------------------------------------|-----|-----|-----------------------------------------------------------------------|
| Reserved                                             | 5   | 0x0 | 保留                                                                    |
| RTC:Receive<br>Threshold Control<br>接收阈值控制           | 4:3 | 0x0 | MTL 传输接收 FIFO 中帧内容已经超过此项设置大小。 00: 64 字节 01:32 字节 10: 96 字节 11: 128 字节 |
| OSF:Operate on<br>Second Frame<br>是否操作第二个以<br>太网帧    | 2   | 0x0 | 此位为高时,DMA 在第一个以太网帧的状态尚未写回时即可以开始处理第二个以太网帧。                             |
| SR:Start/Stop<br>Receive<br>开始/停止接收                  | 1   | 0x0 | 此位设置为高时,接收进入运行状态。<br>此位设置为低时,接收进入停止状态。                                |
| Reserved<br>保留                                       | 0   | 0x0 | 保留                                                                    |

**11.1.8** Register7 (Interrupt Enable Register)

|                        | 11.1.0 Register/ (interrupt Enable Register)       |        |                  |  |  |
|------------------------|----------------------------------------------------|--------|------------------|--|--|
| Register7 (Interrupt E | Register7 (Interrupt Enable Register) Offset: 0x1C |        |                  |  |  |
| Reserved               | 04.47                                              | 0 0    | /ru sar          |  |  |
| 保留                     | 31:17                                              | 0x0    | 保留               |  |  |
| NIE:Normal             |                                                    |        |                  |  |  |
| Interrupt Summary      |                                                    |        | 此位为1时:正常中断使能     |  |  |
| Enable                 | 16                                                 | 0x0    | 此位为0时:正常中断不使能    |  |  |
| 正常中断汇总使能               |                                                    |        |                  |  |  |
| AIE:Abnormal           |                                                    |        |                  |  |  |
| Interrupt Summary      |                                                    |        | 此位为 1 时:非正常中断使能。 |  |  |
| Enable                 | 15                                                 | 15 0x0 |                  |  |  |
| 非正常中断汇总使               |                                                    |        | 此位为0时:非正常中断不使能。  |  |  |
| 能                      |                                                    |        |                  |  |  |



| ERE: Early Receive<br>Interrupt Enable<br>早期接收中断使能              | 14    | 0x0 | 此位为高时:早期接收中断使能        |
|-----------------------------------------------------------------|-------|-----|-----------------------|
| FBE:Fatal Bus<br>Error Enable<br>总线致命错误中断<br>使能                 | 13    | 0x0 | 此位为高时:总线致命错误中断使能。     |
| Reserved<br>保留                                                  | 12:11 | 0x0 | 保留                    |
| ETE:Early Transmit<br>Interrupt Enable<br>早期传输中断使能              | 10    | 0x0 | 此位为高时: 使能早期传输中断       |
| RWE:Receive<br>Watchdog Timeout<br>Enable<br>接收看门狗超时中<br>断使能    | 9     | 0x0 | 此位为高时: 使能接收看门狗超时中断    |
| RSE:Receive<br>Stopped Enable<br>接收停止中断使能                       | 8     | 0x0 | 此位为高时: 使能接收停止中断。      |
| RUE:Receive<br>Buffer Unavailable<br>Enable<br>接收缓冲区不可用<br>中断使能 | 7     | 0x0 | 此位为高时: 使能接收缓冲区不可用中断。  |
| RIE:Receive<br>Interrupt Enable<br>接收中断使能                       | 6     | 0x0 | 此位为高时: 使能接收完成中断       |
| UNE:Underflow<br>Interrupt Enable<br>传输 FIFO 下溢中断<br>使能         | 5     | 0x0 | 此位为高时:使能传输 FIFO 下溢中断  |
| OVE:Overflow Interrupt Enable                                   | 4     | 0x0 | 此位为高时:使能接收 FIFO 上溢中断。 |



| 接收 FIFO 上溢中断<br>使能                                        |   |     |                       |
|-----------------------------------------------------------|---|-----|-----------------------|
| TJE:Transmit<br>Jabber Timeout<br>Enable<br>传输 Jabber 超时中 | 3 | 0x0 | 此位为高时:使能 Jabber 超时中断。 |
| 断使能<br>TUE:Transmit                                       |   |     |                       |
| Buffer Unavailable<br>Enable<br>传输缓存不可用中                  | 2 | 0x0 | 此位为高时: 使能传输缓存不可用中断。   |
| 断使能                                                       |   |     |                       |
| TSE:Transmit<br>Stopped Enable<br>传输停止中断使能                | 1 | 0x0 | 此位为高时: 使能传输停止中断。      |
| TIE:Transmit<br>Interrupt Enable<br>传输完成中断使能              | 0 | 0x0 | 此位为高时: 使能传输完成中断。      |

11.1.9 Register8 (Missed Frame and Buffer Overflow Counter Register)

| Register8 (Missed Frame and Buffer Overflow Counter Register) Offset: 0x20 |       |     |                    |  |
|----------------------------------------------------------------------------|-------|-----|--------------------|--|
| Reserved                                                                   | 31:29 | 0x0 | 保留                 |  |
| 保留                                                                         |       |     |                    |  |
| Overflow bit for<br>FIFO Overflow<br>Counter                               |       | 0x0 | FIFO 溢出指示位         |  |
| FIFO 溢出指示位                                                                 |       |     |                    |  |
| Indicates the number of frames missed by the application 应用程序丢失的帧个数        | 27:17 | 0x0 | 指示应用程序丢失帧的个数       |  |
| Overflow bit for Missed Frame                                              | 16    | 0x0 | 提示丢失帧个数已经超过计数的最大值。 |  |



| Counter<br>丢失帧个数溢出指<br>示                                                                                                     |      |     |                              |
|------------------------------------------------------------------------------------------------------------------------------|------|-----|------------------------------|
| Indicates the number of frames missed by the controller due to the Host Receive Buffer being unavailable 因为主机接收缓存不可用导致帧丢失的个数 | 15:0 | 0x0 | 指示因为主机接收缓存不可用导致帧丢失个数的计<br>数。 |

**11.1.10** Register9(Receive Interrupt Watchdog Timer Register)

| Register9(Receive Interrupt Watchdog Timer Register) Offset: 0x24 |      |     |                                |  |
|-------------------------------------------------------------------|------|-----|--------------------------------|--|
| Reserved                                                          | 31:8 | 0x0 |                                |  |
| 保留                                                                | 31.0 | UXU |                                |  |
| RIWT: RI Watchdog                                                 | 7:0  | 0x0 | 当看门狗设置后,表示以时钟周期 x256 的时间为单     |  |
| Timer count                                                       |      |     | 位计时。当 DMA 接收到数据包且 status 寄存器中  |  |
| 接收看门狗时间计                                                          |      |     | RI 位为 0 时开始计时, 当看门狗计数超时后 RI 位置 |  |
| 数                                                                 |      |     | 1。当 RI 位为 1 后该域复位              |  |

11.1.11 Register10 (AXI Bus Mode Register)

| Register10 (AXI Bus                                                                     | Mode Re | egister) ( | Offset: 0x28                                                                                              |
|-----------------------------------------------------------------------------------------|---------|------------|-----------------------------------------------------------------------------------------------------------|
| EN_LPI: Enable LPI<br>(Low Power<br>Interface)<br>启用低功耗接口                               |         | 0x0        | 该位为 1 时,启用低功耗接口(Low Power Interface),系统接受来自 AXI 系统时钟控制器的 LPI 请求。该位为 0 时,不启用低功耗接口,系统永远拒绝 LPI 请求            |
| UNLCK_ON_MGK_<br>RWK: Unlock on<br>Magic Packet or<br>Remote Wake Up<br>解锁魔法包或远程<br>唤醒包 | 30      | 0x0        | 当该位为 1 时,MAC 处于低功耗(Low Power)状态下时只能通过魔法包或者远程唤醒包来重新回到工作状态;当该位为 0 时,MAC 处于低功耗(Low Power)状态下时只能通过任意包重新回到工作状态 |



|                    |       | Ī    |                                      |
|--------------------|-------|------|--------------------------------------|
| Reserved           | 29:23 | 0x0  |                                      |
| 保留                 | 23.23 | 0.00 |                                      |
| WR_OSR_LMT: AXI    |       |      |                                      |
| Maximum Write Out  |       |      |                                      |
| Standing Request   | 22:20 | 0x0  | 该位设置了 AXI 接口写操作发出最大的 outstanding     |
| Limit              | 22.20 | UXU  | 请求数                                  |
| AXI 最大 outstanding |       |      |                                      |
| 写请求                |       |      |                                      |
| Reserved           | 40    | 0.0  |                                      |
| 保留                 | 19    | 0x0  |                                      |
| WR_OSR_LMT: AXI    |       |      |                                      |
| Maximum Read Out   |       |      |                                      |
| Standing Request   |       |      | 该位设置了 AXI 接口读操作发出最大的 outstanding     |
| Limit              | 18:16 | 0x0  | 请求数                                  |
| AXI 最大 outstanding |       |      |                                      |
| 读请求                |       |      |                                      |
| Reserved           |       |      |                                      |
| 保留                 | 15:13 | 0x0  |                                      |
| AXI_AAL:           |       |      |                                      |
| Address-Aligned    | 4.0   |      | NAME A DATE.                         |
| Beats              | 12    | 0x0  | 这位是一个只读位,与 AAL 位 0 相同                |
| AXI 地址对齐           |       |      |                                      |
| Reserved           |       |      |                                      |
| 保留                 | 11:8  | 0x0  |                                      |
| BLEN256: AXI Burst |       |      | 该位只有当 AXI BURST LENGTH 配置 256 时有效,   |
| Length 256         | 7     | 0x0  | 为 1 时表示 AXI 支持 Burst 长度为 256 的请求, 否则 |
| AXI Burst 长度 256   |       |      | 保留                                   |
| BLEN256: AXI Burst |       |      | 该位只有当 AXI_BURST_LENGTH 配置 128 时有效,   |
| Length 128         | 6     | 0x0  | 为 1 时表示 AXI 支持 Burst 长度为 128 的请求; 否则 |
| AXI Burst 长度 128   |       |      | 保留                                   |
| BLEN256: AXI Burst |       |      | 该位只有当 AXI_BURST_LENGTH 配置 64 时有效,    |
| Length 64          | 5     | 0x0  | 为 1 时表示 AXI 支持 Burst 长度为 64 的请求, 否则保 |
| AXI Burst 长度 64    |       |      | 留                                    |
| BLEN256: AXI Burst | 4     | 0x0  | 该位只有当 AXI_BURST_LENGTH 配置 32 时有效,    |
|                    |       |      |                                      |



| Length 32          |   |     | 为 1 时表示 AXI 支持 Burst 长度为 32 的请求; 否则保 |
|--------------------|---|-----|--------------------------------------|
| AXI Burst 长度 32    |   |     | 留                                    |
| BLEN256: AXI Burst |   |     | 该位只有当 AXI_BURST_LENGTH 配置 16 时有效,    |
| Length 16          | 3 | 0x0 | 为 1 时表示 AXI 支持 Burst 长度为 16 的请求;否则   |
| AXI Burst 长度 16    |   |     | 保留                                   |
| BLEN256: AXI Burst |   |     | 该位只有当 AXI_BURST_LENGTH 配置 8 时有效,     |
| Length 8           | 2 | 0x0 | 为 1 时表示 AXI 支持 Burst 长度为 8 的请求;否则    |
| AXI Burst 长度 8     |   |     | 保留                                   |
| BLEN256: AXI Burst |   |     | 该位只有当 AXI_BURST_LENGTH 配置 4 时有效,     |
| Length 4           | 1 | 0x0 | 为 1 时表示 AXI 支持 Burst 长度为 4 的请求;否则    |
| AXI Burst 长度 4     |   |     | 保留                                   |
| UNDEF: AXI         |   |     |                                      |
| Undefined Burst    |   |     | 该位为1时表示AXI接口可以发出任意Burst长度的           |
| Length             | 0 | 0x0 | 请求,为0时表示 AXI 支持以上 bit7-1 定义的长度       |
| 为定义 AXI Burst 长    |   |     | 为 256/128/64/32/16/8/4 或者 1 的请求      |
| 度                  |   |     |                                      |

**11.1.12** Register11 (AXI Status Register)

| Register11 (AXI Status Register) Offset: 0x2C |      |          |                         |  |  |
|-----------------------------------------------|------|----------|-------------------------|--|--|
| Reserved<br>保留                                | 31:2 | 31:2 0x0 |                         |  |  |
|                                               | 1    | 0x0      | 该为为 1 时表示当前 AXI 正在发送读请求 |  |  |
|                                               | 0    | 0x0      | 该为为 1 时表示当前 AXI 正在发送写请求 |  |  |

Register12- Register18: Reserved

11.1.13 Register18 (Current Host Transmit Descriptor Register)

| Register18 (Current H | Register18 (Current Host Transmit Descriptor Register) Offset: 0x48 |     |    |  |  |  |  |  |
|-----------------------|---------------------------------------------------------------------|-----|----|--|--|--|--|--|
| Host Transmit         |                                                                     |     |    |  |  |  |  |  |
| Descriptor Address    |                                                                     |     |    |  |  |  |  |  |
| Pointer               | 31:0                                                                | 0x0 | 只读 |  |  |  |  |  |
| 当前发送描述符主<br>机地址指针     |                                                                     |     |    |  |  |  |  |  |



**11.1.14** Register19 (Current Host Receive Descriptor Register)

| Register19 (Curre | Register19 (Current Host Receive Descriptor Register) Offset: 0x4C |     |    |  |  |  |  |
|-------------------|--------------------------------------------------------------------|-----|----|--|--|--|--|
| Host Rece         | eive                                                               |     |    |  |  |  |  |
| Descriptor Addr   | ess                                                                |     |    |  |  |  |  |
| Pointer           | 31:0                                                               | 0x0 | 只读 |  |  |  |  |
| 当前接收描述符<br>机地址指针  | 夺主                                                                 |     |    |  |  |  |  |

11.1.15 Register20 (Current Host Transmit Buffer Address Register)

|              | Time regional (Carrette real and real and region)                       |      |     |    |  |  |
|--------------|-------------------------------------------------------------------------|------|-----|----|--|--|
| Register20 ( | Register20 (Current Host Transmit Buffer Address Register) Offset: 0x50 |      |     |    |  |  |
|              | Transmit<br>Address                                                     |      |     |    |  |  |
| Pointer      |                                                                         | 31:0 | 0x0 | 只读 |  |  |
| 当前传输级 机地址指针  |                                                                         |      |     |    |  |  |

**11.1.16** Register21 (Current Host Receive Buffer Address Register)

| Register21 | Register21 (Current Host Receive Buffer Address Register) Offset: 0x54 |      |     |    |  |  |  |
|------------|------------------------------------------------------------------------|------|-----|----|--|--|--|
| Host       | Receive                                                                |      |     |    |  |  |  |
| Buffer     | Address                                                                |      |     |    |  |  |  |
| Pointer    |                                                                        | 31:0 | 0x0 | 只读 |  |  |  |
| 当前接收约      | 缓冲区主                                                                   |      |     |    |  |  |  |
| 机地址指针      | †                                                                      |      |     |    |  |  |  |

# 11.2 MAC 控制器寄存器描述

11.2.1 Register0 (MAC Configuration Register)

| 参数名称                                                        | 位     | 缺省值 | 范围    | 描述                                             |  |  |  |
|-------------------------------------------------------------|-------|-----|-------|------------------------------------------------|--|--|--|
| Register0 (MAC Configuration Register) Offset: 0x0000       |       |     |       |                                                |  |  |  |
| Reserved<br>保留                                              | 31:26 | 0x0 | 保留    |                                                |  |  |  |
| TC: Transmi<br>Configuration ir<br>RGMII<br>使能 RGMII 链路信息传输 | 24    | 0x0 |       | J,将会把双工模式,链路速度,链路以及<br>新开等信息通过 RGMⅡ 接口传输给 PHY。 |  |  |  |
| WD: Watchdog                                                | 23    | 0x0 | 此位为高时 | t,MAC 将关闭接收端的看门狗定时器,                           |  |  |  |



| Disable                                                        |       |     | 可以接收最大 16384 字节的以太网帧。                                          |
|----------------------------------------------------------------|-------|-----|----------------------------------------------------------------|
| 关闭看门狗                                                          |       |     |                                                                |
| JD: Jabber Disable<br>关闭 Jabber 定时器                            | 22    | 0x0 | 此位为高时,MAC 关闭发送过程中的 Jabber 定时器,可以发送最大 16384 字节的以太网帧。            |
| BE: Frame Burst<br>Enable<br>帧突发传输使能                           | 21    | 0x0 | 此位为高时,MAC 使能传输过程中的帧突发传输模式。                                     |
| JE: Jumbo Frame<br>Enable<br>巨帧使能                              | 20    | 0x0 | 此位为高时,MAC 使能巨帧(最大 9018 字节)的接收。                                 |
| IFG: Inter-Frame<br>Gap<br>最小帧间距                               | 19:17 | 0x0 | 设置传输过程中的最小帧间距。 000: 96 位时间 001: 88 位时间 010: 80 位时间 111: 40 位时间 |
| DCRS: Disable Carrier Sense During Transmission 传输过程中关闭载 波冲突检测 | 16    | 0x0 | 此位为高时, MAC 忽略半双工模式下 CRS 信号的检测。                                 |
| PS: Port Select<br>端口选择                                        | 15    | 0x0 | 0: GMII (1000Mbps)<br>1: MII (10/100Mbps)                      |
| FES: Speed<br>快速以太网速度提<br>示                                    | 14    | 0x0 | 0: 10Mbps<br>1: 100Mbps                                        |
| DO: Disable<br>Receive Own<br>关闭接收自己发出<br>的以太网帧                | 13    | 0x0 | 此位为高时, MAC 不接收半双工模式下 gmii_txen_o<br>有效的以太网帧。                   |
| LM: Loopback<br>Mode                                           | 12    | 0x0 | 此位为高时,GMII/MII 工作在环回模式下。                                       |



| 使能环回模式                                                      |     |     |                                                                                   |
|-------------------------------------------------------------|-----|-----|-----------------------------------------------------------------------------------|
| DM: Duplex Mode<br>使能全双工模式                                  | 11  | 0x0 | 此位为高时,MAC 工作在全双工模式下,在全双工模式下可以同时发送和接收以太网帧。                                         |
| IPC: Checksum<br>Offload<br>校验和卸载使能                         | 10  | 0x0 | 此位为高时,MAC 硬件计算接收到以太网帧的负载(payload)。还检查 IPV4 头的校验和是否正确。                             |
| DR: Disable Retry<br>关闭重传                                   | 9   | 0x0 | 此位为高时,MAC 在遇到冲突时不重传发送冲突的以太网帧,而只报告冲突错误。                                            |
| LUD: Link Up/Down<br>链路连接/链路断开                              | 8   | 0x0 | <ul><li>0: 链路断开</li><li>1: 链路连接</li></ul>                                         |
| ACS: Automatic<br>Pad/CRC Stripping<br>以太网帧 Pad/CRC<br>自动去除 | 7   | 0x0 | 此位为 1 时,MAC 中去除接收到的以太网帧的 Pad和 FCS。                                                |
| BL: Back-Off Limit<br>回退限制                                  | 6:5 | 0x0 | 回退限制决定基于 slot 的延迟时间。 00: k=min(n,10) 01: k=min(n,8) 10: k=min(n,4) 11: k=min(n,1) |
| DC: Deferral Check<br>Deferral 检查                           | 4   | 0x0 | 此位为 1 时,使能 deferral 检测功能。                                                         |
| TE: Transmitter<br>Enable<br>传输使能                           | 3   | 0x0 | 此位为 1 时,使能 MAC 传输功能。                                                              |
| RE: Receiver<br>Enable<br>接收使能                              | 2   | 0x0 | 此位为 1 时,使能 MAC 接收功能。                                                              |
| Reserved                                                    | 1:0 | 0x0 | 保留。                                                                               |

## 11.2.2 Register1 (MAC Frame Filter)

| Register1 (MAC Fran | gister1 (MAC Frame Filter) Offset: |     |        |                    |
|---------------------|------------------------------------|-----|--------|--------------------|
| RA: Receive All     | 0.4                                | 00  | 此位为1时, | MAC 接收模块把接收到的所有帧都发 |
| 接收全部                | 31                                 | 0x0 | 给应用程序, | 忽略源地址/目标地址过滤机制。    |



| Reserved<br>保留                                     | 30:11 | 0x0 | 保留                                                                                                                                                    |
|----------------------------------------------------|-------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| HPF: Hash or<br>Perfect Filter<br>哈希或者完全过滤         | 10    | 0x0 | 此位为 1 时,在哈希/完全过滤机制中匹配的以太网帧发送给应用。<br>此位为 0 时,只有在哈希过滤机制中匹配的以太网帧才发送给应用。                                                                                  |
| SAF: Source<br>Address Filter<br>Enable<br>源地址过滤使能 |       | 0x0 | MAC CORE 比较比较接收到以太网帧的源地址域和在 SA 寄存器中的值,如果匹配,接收状态寄存器中的 SAMatch 位设置为高。如果此位为 1,源地址匹配失败,MAC CORE 将丢弃该以太网帧。如果此位为 0,不管源地址匹配结果 MAC CORE 都接收此帧,而匹配结果写入接收状态寄存器。 |
| SAIF: SA Inverse<br>Filtering<br>源地址反转过滤           | 8     | 0x0 | 此位为 1 时,和 SA 寄存器中源地址匹配的以太网帧将会标记为源地址匹配失败。<br>此位为 0 时,和 SA 寄存器中源地址不匹配的以太网帧将会标记为源地址匹配失败。                                                                 |
| PCF: Pass Control<br>Frames<br>接收控制帧               | 7:6   | 0x0 | 00: MAC 过滤所有控制帧 01: MAC 接收除了 pause 帧以外的所有控制帧。 10: MAC 接收所有控制帧。 11: MAC 根据地址过滤情况接收控制帧                                                                  |
| DBF: Disable<br>Broadcast Frames<br>关闭广播帧          | 5     | 0x0 | 此位为 1 时,过滤所有接收的广播帧。<br>此位为 0 时,接收所有广播帧。                                                                                                               |
| PM: Pass All<br>Multicast<br>接收所有多播帧               | 4     | 0x0 | 此位为 1 时,接收所有多播帧。<br>此位为 0 时,过滤所有多播帧。                                                                                                                  |
| DAIF: DA Inverse<br>Filtering<br>目标地址反转过滤          | 3     | 0x0 | 此位为 1 时,对单播和多播帧进行反向目标地址匹配。<br>此位为 0 时,对单播和多播帧进行正常目标地址匹配。                                                                                              |
| HMC: Hash<br>Multicast<br>哈希多播过滤                   | 2     | 0x0 | 此位为 1 时,对接收到的多播帧根据哈希表的内容进行目标地址过滤。                                                                                                                     |
| HUC: Hash Unicast                                  | 1     | 0x0 | 此位为1时,对接收到的单播帧根据哈希表的内容进                                                                                                                               |



| 哈希单播过滤          |   |     | 行目标地址过滤。  |
|-----------------|---|-----|-----------|
| PR: Promiscuous |   |     |           |
| Mode            | 0 | 0x0 | 接收所有以太网帧。 |
| 混杂模式            |   |     |           |

11.2.3 Register2 (Hash Table High Register)

| Register2 (Hash Table High Register) Offset: 0x0008 |      |     |             |  |  |
|-----------------------------------------------------|------|-----|-------------|--|--|
| HTH: Hash Table                                     |      |     |             |  |  |
| High                                                | 31:0 | 0x0 | 哈希表的高 32 位。 |  |  |
| 哈希表高位                                               |      |     |             |  |  |

**11.2.4** Register3 (Hash Table Low Register)

| Register3 (Hash Table Low Register) Offset: 0x000C |      |     |             |  |  |
|----------------------------------------------------|------|-----|-------------|--|--|
| HTL: Hash Table                                    |      |     |             |  |  |
| Low                                                | 31:0 | 0x0 | 哈希表的低 32 位。 |  |  |
| 哈希表低位                                              |      |     |             |  |  |

**11.2.5** Register4 (GMII Address Register)

| Register4 (GMII Addı                       | Register4 (GMII Address Register) Offset: 0x0010 |     |                                                                                                                                          |  |  |
|--------------------------------------------|--------------------------------------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Reserved<br>保留                             | 31:16                                            | 0x0 | 保留                                                                                                                                       |  |  |
| PA: Physical Layer<br>Address<br>PHY 地址    | 15:11                                            | 0x0 | 此域选择需要访问 32 个 PHY 中的哪个。                                                                                                                  |  |  |
| GR: GMII Register<br>需要访问的 PHY 设<br>备中的寄存器 | 10:6                                             | 0x0 | 此域选择需要访问的的 PHY 的哪个 GMII 配置寄存器。                                                                                                           |  |  |
| Reserved<br>保留                             | 5                                                | 0x0 | 保留                                                                                                                                       |  |  |
| CR: CSR Clock<br>Range<br>CSR 时钟范围         | 4:2                                              | 0x0 | 此域决定 MDC 时钟是 clk_csr_i 时钟频率比例。<br>0000 clk_csr_i/42<br>0001 clk_csr_i/62<br>0010 clk_csr_i/16<br>0011 clk_csr_i/26<br>0100 clk_csr_i/102 |  |  |



|                          |   |     | 0101 clk_csr_i/124                                                                               |
|--------------------------|---|-----|--------------------------------------------------------------------------------------------------|
|                          |   |     | 0110, 0111 Reserved                                                                              |
| GW: GMII Write<br>GMII 写 | 1 | 0x0 | 此位为 1 时,通过 GMII 数据寄存器对 PHY 进行写操作<br>此位为 0 时,通过 GMII 数据寄存器对 PHY 进行读操作。                            |
| GB: GMII Busy<br>GMII 忙  | 0 | 0x0 | 对寄存器 4 和寄存器 5 写之前,此位应为 0。在写寄存器 4 之前此位必须先置 0。在访问 PHY 的寄存器时,应用程序需要将此位设置为 1,表示 GMII 接口上有写或者读操作正在进行。 |

**11.2.6** Register5 (GMII Data Register)

| 111210 1 togistoro ( |          |            |                             |  |
|----------------------|----------|------------|-----------------------------|--|
| Register5 (GMII Data | Register | c) Offset: | 0x0014                      |  |
| Reserved             | 04:40    | 00         | VEL IST                     |  |
| 保留                   | 31:16    | 0x0        | 保留                          |  |
| GD: GMII Data        | 15:0     | 0.40       | 此域保存了对 PHY 进行管理读访问操作的 16 位数 |  |
| GMII 数据              | 15:0     | 0x0        | 据,或者对 PHY 进行管理写访问的 16 位数据。  |  |

11.2.7 Register6 (Flow Control Register)

| 11.2.7 (registero (riow Control (register) |                                                  |     |                                    |  |  |
|--------------------------------------------|--------------------------------------------------|-----|------------------------------------|--|--|
| Register6 (Flow Contr                      | Register6 (Flow Control Register) Offset: 0x0018 |     |                                    |  |  |
| PT: Pause Time                             | 04.40                                            | 0.0 |                                    |  |  |
| 暂停时间                                       | 31:16                                            | 0x0 | 此域保存了需要填入传输控制帧中的暂停时间域。             |  |  |
| Reserved                                   | 45.0                                             | 00  | /EL 1571                           |  |  |
| 保留                                         | 15:8                                             | 0x0 | 保留                                 |  |  |
| DZPQ: Disable                              |                                                  |     |                                    |  |  |
| Zero-Quanta Pause                          | 7                                                | 0x0 | 此位为 1 时,禁止自动零时间片的暂停控制帧的产生。         |  |  |
| 禁止零时间片暂停                                   |                                                  |     |                                    |  |  |
| 帧                                          |                                                  |     |                                    |  |  |
| Reserved                                   | 0                                                | 0x0 | VEL 1571                           |  |  |
| 保留                                         | 6                                                |     | 保留                                 |  |  |
|                                            | 5:4                                              |     | 此域用于设置暂停时间的阈值。                     |  |  |
| PLT: Pause Low                             |                                                  | 0x0 | 00: 暂停时间减少 4 个时间槽                  |  |  |
| Threshold                                  |                                                  |     | 01: 暂停时间减少 28 个时间槽                 |  |  |
| 暂停帧的低阈值                                    |                                                  |     | <b>10</b> : 暂停时间减少 <b>144</b> 个时间槽 |  |  |



| 流控忙/反压激活           |   |     |                                                                     |
|--------------------|---|-----|---------------------------------------------------------------------|
| Activate           |   | 0x0 | 或在半双工模式下启动反压操作。                                                     |
| Busy/Backpressure  | 0 |     | 此位为1时,在全双工模式下发起暂停控制帧的发送                                             |
| Control            |   |     | 此位为 <b>4</b> 时 左秦亚王横尹玉尘却新度按魁峙的华兴                                    |
| FCB/BPA: Flow      |   |     |                                                                     |
| 发送流控使能             |   |     | 在半双工模式下,此位为1时,MAC 使能反压操作。                                           |
| Control Enable     | 1 | 0x0 | 发送。                                                                 |
| TEF: Transmit Flow |   |     | 在全双工模式下,此位为 1 时, MAC 使能暂停帧的                                         |
| 接收流控使能             |   |     | 12 12 12 12 12 12 13 14 1 日 1 1 12 11 12 12 12 12 12 12 12 12 12 12 |
| Control Enable     | 2 | 0x0 | 按照暂停帧指定的时间暂停帧的发送。                                                   |
| RFE: Receive Flow  |   |     | 此位为 1 时,MAC 将会解析接收到的暂停帧,并且                                          |
| 单播的暂停帧探测           |   |     | トロ 11 11 12 0 0 1 1 1 1 1 1 1 1 1 1 1 1 1                           |
| Frame Detect       | 3 | 0x0 | 此位为 T 的,MAC 将会根据 MAC 地址 U 指定的本站单播地址来探测暂停帧。                          |
| UP: Unicast Pause  |   |     | 此位为 1 时,MAC 将会根据 MAC 地址 0 指定的本                                      |
|                    |   |     | 者 64 字节的时间)                                                         |
|                    |   |     | (一个时间槽为在 GMII/MII 接口上传输 512 比特或                                     |
|                    |   |     | 11: 暂停时间减少 256 个时间槽                                                 |

11.2.8 Register7 (VLAN Tag Register)

| Register7 (VLAN Tag                                                     | Registe | r) Offset: | 0x001C                                                           |
|-------------------------------------------------------------------------|---------|------------|------------------------------------------------------------------|
| Reserved<br>保留                                                          | 31:17   | 0x0        | 保留                                                               |
| ETV: Enable 12-Bit<br>VLAN Tag<br>Comparison<br>使能 12 位 VLAN<br>Tag 比较  | 16      | 0x0        | 此位为 1 时,使用 12 位 VLAN Tag 而不是使用 16<br>位 VLAN Tag 用于以太网帧比较和过滤。     |
| VL: VLAN Tag<br>Identifier for<br>Receive Frames<br>帧接收的 VLAN Tag<br>标识 | 15:0    | 0x0        | 此域保存 802.1Q 格式的 VLAN Tag,用于比较接收到的以太网帧的位于第 15 和第 16 个字节的 VLANTag。 |

11.2.9 Register8 (Version Register)

Register8 (Version Register) Offset: 0x0020



| Reserved<br>保留 | 15:8 | 0x0 | 保留   |
|----------------|------|-----|------|
| Version<br>版本号 | 7:0  | 0x0 | 0X35 |

11.2.10 Register14 (Interrupt Status Register)

| <b>11.2.10</b> Regis                                                       | 11.2.10 Register14 (Interrupt Status Register) |            |                                                          |  |  |
|----------------------------------------------------------------------------|------------------------------------------------|------------|----------------------------------------------------------|--|--|
| Register14 (Interrupt S                                                    | Status Re                                      | egister) O | ffset: 0x0038                                            |  |  |
| Reserved<br>保留                                                             | 15:8                                           | 0x0        | 保留                                                       |  |  |
| MMC Receive<br>Checksum Offload<br>Interrupt Status<br>MMC 接收校验和卸<br>载状态中断 | 7                                              | 0x0        | MMC 校验和卸载寄存器产生任何中断产生时,此位<br>设置为 1。                       |  |  |
| MMC Transmit<br>Interrupt Status<br>MMC 传输中断                               | 6                                              | 0x0        | MMC 传输中断寄存器产生任何中断时,此位设置为1。                               |  |  |
| MMC Receive<br>Interrupt Status<br>MMC 接收中断状态                              | 5                                              | 0x0        | MMC 接收中断寄存器产生任何中断时,此位设置为1。                               |  |  |
| MMC Interrupt<br>Status<br>MMC 中断状态                                        | 4                                              | 0x0        | 7:5 的任何位为高时,此位设置为 1。                                     |  |  |
| PMT Interrupt<br>Status<br>电源管理中断状态                                        | 3                                              | 0x0        | 在 Power Down 状态下,收到 magic 帧或在<br>Wake-on-LAN 帧时,此位设置为 1。 |  |  |
| PCS<br>Auto-Negotiation<br>Complete<br>PCS 自动协商完成                          | 2                                              | 0x0        | RGMII PHY 接口自动协商完成时,此位设置为 1。                             |  |  |
| PCS Link Status<br>Changed<br>PCS 链路状态变化                                   | 1                                              | 0x0        | RGMII PHY 接口的链路状态发生任何变化时,此位设置为 1。                        |  |  |
| RGMII Interrupt                                                            | 0                                              | 0x0        | RGMII 接口的链路状态发生任何变化时,此位设置                                |  |  |



| Status     |  | 为1。 |
|------------|--|-----|
| RGMII 中断状态 |  |     |

**11.2.11** Register15 (Interrupt Mask Register)

| 11.2.11 Register15 (Interrupt Mask Register) |                                                     |      |                             |  |  |
|----------------------------------------------|-----------------------------------------------------|------|-----------------------------|--|--|
| Register15 (Interrupt l                      | Register15 (Interrupt Mask Register) Offset: 0x003C |      |                             |  |  |
| Reserved                                     | 15:10                                               | 0x0  | 保留                          |  |  |
| 保留                                           | 10.10                                               | 0.00 | IN H                        |  |  |
| Time Stamp                                   |                                                     |      |                             |  |  |
| Interrupt Mask                               | 9                                                   | 0x0  | 此位为1时,禁止时间戳发生的中断            |  |  |
| 时间戳中断使能                                      |                                                     |      |                             |  |  |
| Reserved                                     | 8:4                                                 | 0x0  | 保留                          |  |  |
| 保留                                           | 0.4                                                 | UXU  | 休笛                          |  |  |
| PMT Interrupt Mask                           | 0                                                   | 0.0  |                             |  |  |
| 电源管理中断使能                                     | 3                                                   | 0x0  | 此位为 1 时,禁止电源管理引起的中断。        |  |  |
| PCS AN                                       |                                                     |      |                             |  |  |
| Completion                                   |                                                     |      |                             |  |  |
| Interrupt Mask                               | 2                                                   | 0x0  | 此位为 1 时,禁止 PCS 自动协商完成中断。    |  |  |
| PCS 自动协商完成                                   |                                                     |      |                             |  |  |
| 中断使能                                         |                                                     |      |                             |  |  |
| PCS Link Status                              |                                                     |      |                             |  |  |
| Interrupt Mask                               | 1                                                   | 0x0  | 此位为 1 时,禁止由于 PCS 链路状态变化引起的中 |  |  |
| PCS 链路状态中断                                   | -                                                   |      | 断。                          |  |  |
| 使能                                           |                                                     |      |                             |  |  |
| RGMII Interrupt                              |                                                     |      |                             |  |  |
| Mask                                         | 0                                                   | 0x0  | 此位为 1 时,禁止 RGMII 引起的中断。     |  |  |
| RGMII 中断使能                                   |                                                     |      |                             |  |  |

11.2.12 Register16 (MAC Address0 High Register)

| Register16 (MAC Address0 High Register) Offset: 0x0040 |       |     |                           |  |
|--------------------------------------------------------|-------|-----|---------------------------|--|
| MO: Always 1                                           | 31    | 0x0 | 保留                        |  |
| 保留                                                     |       |     |                           |  |
| Reserved                                               | 30:16 | 0.0 | /a sa                     |  |
| 保留                                                     | 30:16 | 0x0 | 保留                        |  |
| MAC                                                    | 15:0  | 0x0 | 存放用于接收地址过滤和传输流控帧的 MAC 地址。 |  |



| Address0[47:32] |  |  |
|-----------------|--|--|
| MAC 地址高 16 位    |  |  |

11.2.13 Register17 (MAC Address0 Low Register)

|                                                       |      |     | <u> </u>                  |  |  |
|-------------------------------------------------------|------|-----|---------------------------|--|--|
| Register17 (MAC Address0 Low Register) Offset: 0x0044 |      |     |                           |  |  |
| MAC                                                   |      |     |                           |  |  |
| Address0[31:0]                                        | 31:0 | 0x0 | 存放用于接收地址过滤和传输流控帧的 MAC 地址。 |  |  |
| MAC 地址低 32 位                                          |      |     |                           |  |  |

11.2.14 Register18 (MAC Address1 High Register)

| 11.2.14 Regis                                     | terro (  | IVIAC AGC    | iress1 High Register)                                                                 |
|---------------------------------------------------|----------|--------------|---------------------------------------------------------------------------------------|
| Register18 (MAC Add                               | dress1 H | igh Register | r) Offset: 0x0048                                                                     |
| AE: Address<br>Enable<br>地址使能                     | 31       | 0x0          | 此位为 1 时,地址过滤模块使用第 2 个 MAC 地址用于完全地址过滤。此位为 0 时,地址过滤模块不使用第 2 个 MAC 地址用于地址过滤。             |
| SA: Source<br>Address<br>源 MAC 地址                 | 30       | 0x0          | 此位为 1 时, MAC 地址 1 用于比较接收帧的源 MAC 地址。<br>地址。<br>此位为 0 时, MAC 地址 1 用于比较接收帧的目标<br>MAC 地址。 |
| MBC: Mask Byte<br>Control<br>掩模字节控制               | 29:24    | 0x0          | 此域用于比较每个 MAC 地址的字节掩模控制位。比如第 29 位用于掩码寄存器 18 的[15:8]这个字节。                               |
| Reserved<br>保留                                    | 23:16    | 0x0          | 保留。                                                                                   |
| MAC<br>Address1[47:32]<br>第 2 个 MAC 地址的<br>高 16 位 | 15:0     | 0xFFFF       |                                                                                       |

11.2.15 Register19 (MAC Address1 Low Register)

| Register19 (MAC Add                              | dress1 Lo | ow Register) | Offset: 0x004C |
|--------------------------------------------------|-----------|--------------|----------------|
| MAC<br>Address1[31:0]<br>第 2 个 MAC 地址的<br>低 32 位 | 31:0      | 0x0          |                |



**11.2.16** Register48 (AN Control Register)

|                                              | Register48 (AN Control Register) Offset: 0x00C0 |     |                                    |  |  |
|----------------------------------------------|-------------------------------------------------|-----|------------------------------------|--|--|
| Reserved<br>保留                               | 31:19                                           | 0x0 | 保留                                 |  |  |
| SGMII RAL Control<br>保留                      | 18                                              | 0x0 | 保留                                 |  |  |
| LR: Lock to<br>Reference<br>锁定到参考时钟          | 17                                              | 0x0 | 此位为 1 时,PHY 将其锁相环锁定到 125MHz 的参考时钟。 |  |  |
| ECD: Enable<br>Comma Detect<br>使能停顿探测        | 16                                              | 0x0 | 此位为 1 时,使能 PHY 的停顿探测和字重同步。         |  |  |
| Reserved<br>保留                               | 15                                              | 0x0 | 保留                                 |  |  |
| ELE: External<br>Loopback Enable<br>外部环回使能   | 14                                              | 0x0 | 此位为 1 时,使能 PHY 进入环回模式。             |  |  |
| Reserved<br>保留                               | 13                                              | 0x0 | 保留                                 |  |  |
| ANE:<br>Auto-Negotiation<br>Enable<br>自动协商使能 | 12                                              | 0x0 | 此位为 1 时,MAC 将会和链路对方进行自动协商。         |  |  |
| Reserved<br>保留                               | 11:10                                           | 0x0 | 保留                                 |  |  |
| RAN: Restart<br>Auto-Negotiation<br>重新进行自动协商 | 9                                               | 0x0 | 此位为 1 时,重新进行自动协商。                  |  |  |
| Reserved<br>保留                               | 8:0                                             | 0x0 | 保留                                 |  |  |

11.2.17 Register49 (AN Status Register)

| Register49 (AN Status | s Registe | r) Offset: | 0x00C4 |
|-----------------------|-----------|------------|--------|
| Reserved              | 31:9      | 0x0        | 保留     |



| 保留                                             |     |     |                                  |
|------------------------------------------------|-----|-----|----------------------------------|
| ES: Extended<br>Status<br>扩展状态                 | 8   | 0x0 | 只读,因为 MAC 支持扩展状态信息。              |
| Reserved<br>保留                                 | 7:6 | 0x0 | 保留                               |
| ANC:<br>Auto-Negotiation<br>Complete<br>自动协商完成 | 5   | 0x0 | 只读,指示自动协商完成。                     |
| Reserved<br>保留                                 | 4   | 0x0 | 保留                               |
| ANA:<br>Auto-Negotiation<br>Ability<br>自动协商能力  | 3   | 0x0 | 只读,因为 MAC 支持自动协商。                |
| LS: Link Status<br>链路状态                        | 2   | 0x0 | 此位为1时,指示链路连接上。<br>此位为0时,指示链接未连接。 |
| Reserved<br>保留                                 | 1:0 | 0x0 | 保留。                              |

11.2.18 Register50 (Auto-Negotiation Advertisement Register)

| Register50 (Auto-Neg | Register50 (Auto-Negotiation Advertisement Register) Offset: 0x00C8 |        |                                                  |  |  |
|----------------------|---------------------------------------------------------------------|--------|--------------------------------------------------|--|--|
| Reserved             | 31:16                                                               | 0.40   | 保留                                               |  |  |
| 保留                   | 31.10                                                               | 0x0    | 休田                                               |  |  |
| NP: Next Page        |                                                                     |        |                                                  |  |  |
| Support              | 15                                                                  | 0x0    | 只读为 0,因为 MAC 不支持下一页面。                            |  |  |
| 下一页面支持               |                                                                     |        |                                                  |  |  |
| Reserved             | 14                                                                  | 14 0x0 | 保留                                               |  |  |
| 保留                   |                                                                     |        | 休笛                                               |  |  |
| RFE: Remote Fault    |                                                                     |        | 业。                                               |  |  |
| Encoding             | 13:12                                                               | 0x0    | 此 2 位指示链路对端发生错误,具体编码将 IEEE 802.3z 第 37.2.1.5 小节。 |  |  |
| 远端错误编码               |                                                                     |        | OOC.3C 为 31.2.1.3 小 p。                           |  |  |



| Reserved        | 44.0 | 0.0 | In St.                      |
|-----------------|------|-----|-----------------------------|
| 保留              | 11:9 | 0x0 | 保留                          |
| PSE: Pause      |      |     |                             |
| Encoding        | 8:7  | 0x0 | 见 IEEE 802.3z 第 37.2.1.4 小节 |
| Pause 位编码       |      |     |                             |
| HD: Half-Duplex | 6    | 0x0 | 此位为 1 时,指示 MAC 支持半双工。       |
| 半双工             |      |     |                             |
| FD: Full-Duplex | _    | 0x0 | 此位为 1 时,指示 MAC 支持全双工。       |
| 全双工             | 5    |     |                             |
| Reserved        | 4.0  | 0×0 | II SI                       |
| 保留              | 4:0  | 0x0 | 保留                          |

11.2.19 Register51 (Auto-Negotiation Link Partner Ability Register)

| 11.2.19 Registers (Auto-Negotiation Link Partner Ability Register) |                                                                            |     |                                               |  |
|--------------------------------------------------------------------|----------------------------------------------------------------------------|-----|-----------------------------------------------|--|
| Register51 (Auto-Neg                                               | Register51 (Auto-Negotiation Link Partner Ability Register) Offset: 0x00CC |     |                                               |  |
| Reserved<br>保留                                                     | 31:16                                                                      | 0x0 | 保留                                            |  |
| NP: Next Page<br>Support<br>下一页面支持                                 | 15                                                                         | 0x0 | 此位为 1 时,指示有更多下一页面信息可用<br>此位为 0 时,指示下一页面交换不可用。 |  |
| ACK: Acknowledge<br>确认                                             | 14                                                                         | 0x0 | 指示在自动协商中,链路对端成功接收到 MAC 的基本页面。                 |  |
| RFE: Remote Fault<br>Encoding<br>远端错误编码                            | 13:12                                                                      | 0x0 | 见 IEEE 802.3z 第 37.2.1.5 小节。                  |  |
| Reserved<br>保留                                                     | 11:9                                                                       | 0x0 | 保留                                            |  |
| PSE: Pause<br>Encoding<br>对端 pause 状态编<br>码                        | 8:7                                                                        | 0x0 | 见 IEEE 802.3z 第 37.2.14 小节。                   |  |
| HD: Half-Duplex<br>半双工                                             | 6                                                                          | 0x0 | 指示对端可以运行在半双工模式。                               |  |
| FD: Full-Duplex                                                    | 5                                                                          | 0x0 | 指示对端可以运行在全双工模式。                               |  |



| 全双工      |     |     |    |
|----------|-----|-----|----|
| Reserved | 4:0 | 0.0 | 保留 |
| 保留       |     | 0x0 |    |

**11.2.20** Register52 (Auto-Negotiation Expansion Register)

| Register52 (Auto-Negotiation Expansion Register) Offset: 0x00D0 |      |      |                        |  |  |
|-----------------------------------------------------------------|------|------|------------------------|--|--|
| Reserved                                                        | 31:3 | 0x0  | 保留                     |  |  |
| 保留                                                              | 01.0 | 5,10 | N. III                 |  |  |
| NPA: Next Page                                                  |      |      |                        |  |  |
| Ability                                                         | 2    | 0x0  | 只读为 0,因为 MAC 不支持下一页面。  |  |  |
| 下一页面能力                                                          |      |      |                        |  |  |
| NPR: New Page                                                   |      |      |                        |  |  |
| Received                                                        | 1    | 0x0  | 此位为 1 时,指示 MAC 接收到新页面。 |  |  |
| 接收到新页面                                                          |      |      |                        |  |  |
| Reserved                                                        | 0    | 0.40 | VII DI                 |  |  |
| 保留                                                              | 0    | 0x0  | 保留                     |  |  |

**11.2.21** Register54 (SGMII/RGMII Status Register)

| Register54 (SGMII/RGMII Status Register) Offset: 0x00D8 |      |      |                 |  |
|---------------------------------------------------------|------|------|-----------------|--|
| Reserved                                                | 24.4 | 0.40 | /u śn           |  |
| 保留                                                      | 31:4 | 0x0  | 保留              |  |
| Link Status                                             |      | 0.40 | 此位为1时,指示链路连接上。  |  |
| 链路状态                                                    | 3    | 0x0  | 此位为0时,指示链路未连接上。 |  |
|                                                         |      |      | 指示链路当前速度        |  |
| Link Speed                                              | 2:1  | 0.40 | 00: 2.5MHz      |  |
| 链路速度                                                    |      | 0x0  | 01: 25MHz       |  |
|                                                         |      |      | 10: 125MHz      |  |
| Link Mode                                               | 0    |      | 0: 半双工          |  |
| 链路模式                                                    |      | 0x0  | 1: 全双工          |  |

#### IEEE1588 寄存器:

**11.2.22** Register448 (Time Stamp Control Register)

| Register448 (Time Stamp Control Register) Offset: 0x0700 |       |     |       |  |
|----------------------------------------------------------|-------|-----|-------|--|
| Reserved                                                 | 31:20 | 0x0 | 保留    |  |
| 保留                                                       |       |     | IX EI |  |



| ATSFC: Auxiliary<br>Snapshot FIFO<br>Clear<br>Auxiliary 快照 FIFO<br>清除                 | 19 | 0x0 | 该位为 1 时重置 Auxiliary Snapshot FIFO 的指针,<br>FIFO 清空,完成后为 0                                                                                                 |
|---------------------------------------------------------------------------------------|----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| TSENMACADDR: Enable MAC address for PTP frame filtering 启用 PTP 帧的 MAC 地址过滤            | 18 | 0x0 | 此位为 1 时,接收到的 PTP 包会经过 MAC 的 MAC目的地址过滤器(DA Fiter),不匹配的 PTP 包会被丢弃                                                                                          |
| TSCLKTYPE: Select<br>the type of clock<br>node<br>选择时间节点类型                            |    | 0x0 | 该域按照以下类型编码:  00: 普通时钟(Ordinary clock)  01: 边界时钟(Boundary clock)  10: 端到端的透明时钟(End-to-End Transparent clock)  11: 点到点透明时钟(Peer-to-peer Transparent clock) |
| TSMSTRENA:<br>Enable Snapshot for<br>Messages Relevant<br>to Master<br>启用主机相关信息快<br>照 | 15 | 0x0 | 该位为 1 时快照 (Snapshot) 记录主机相关信息<br>(Relevant to Master); 为 0 时快照记录从机相关信息<br>(Relevant to Slave)                                                            |
| TSEVNTENA: Enable Time Stamp Snapshot for Event Messages 启用事件信息时间戳 快照                 |    | 0x0 | 该位为 1 时快照(Snapshot)只记录事件相关信息<br>(Event Message);为0时快照记录所有信息                                                                                              |
| TSIPV4ENA: Enable<br>Time Stamp<br>Snapshot for IPv4<br>frames<br>启用 IPv4 时间戳快        | 13 | 0x0 | 该位为 1 时,IPv4 帧的时间戳快照(Time Stamp<br>Snapshot)启用                                                                                                           |



| 照                                                                                             |     |     |                                                                                                             |
|-----------------------------------------------------------------------------------------------|-----|-----|-------------------------------------------------------------------------------------------------------------|
| TSIPV4ENA: Enable<br>Time Stamp<br>Snapshot for IPv4<br>frames<br>启用 IPv6 时间戳快<br>照           | 12  | 0x0 | 该位为 1 时,IPv6 帧的时间戳快照(Time Stamp<br>Snapshot)启用                                                              |
| TSIPENA: Enable Time Stamp Snapshot for PTP over Ethernet frames 启用以太网PTP包时                   | 11  | 0x0 | 该位为 1 时,以太网格式的 PTP 包(PTP over Ethernet)启用时间戳快照(Time Stamp Snapshot); 为 0 时 UDP-IP-Ethernet 格式的 PTP 包启用时间戳快照 |
| TSVER2ENA:<br>Enable PTP packet<br>snooping for version<br>2 format<br>基于第二版本格式启<br>用 PTP 包快照 | 10  | 0x0 | 该位为 1 时,以太网格式的 PTP 包快照为第二版本格式(version 2 format);为 0 时为第一版本格式(version 1 format)                              |
| TSCTRLSSR: Time<br>Stamp Digital or<br>Binary rollover<br>control<br>时间戳数字或二进制<br>更新控制        | 9   | 0x0 | 该位为 1 时,时间戳低位寄存器(Time Stamp Low register)在值超过0x3B9A_C9FF后更新且增加时间戳高位寄存器的秒;该为为 0 时,时间戳低位寄存器复位为0x7FFF_FFFF     |
| TSENALL: Enable<br>Time Stamp for All<br>Frames<br>对所有帧启用时间戳                                  | 8   | 0x0 | 该为为 1 时,表示对所有 MAC 接收到的帧启用时间<br>戳                                                                            |
| Reserved<br>保留                                                                                | 7:6 | 0x0 | 保留                                                                                                          |
| TSADDREG:<br>Addend Reg Update<br>被加数寄存器                                                      | 5   | 0x0 | 该位为 1 时,时间戳被加数寄存器(Time Stamp Addend register)的值被用来更新 PTP 块来做 fine correction. 当更新结束时该位为 0                   |



| TSTRIG: Time<br>Stamp Interrupt<br>Trigger Enable<br>启用时间戳中断触发               | 4 | 0x0 | 该位为 1 时,当系统时间大于目标时间寄存器(Target Time register)中的值时,产生一个时间戳中断,中断产生后该位重置为 0                                          |
|------------------------------------------------------------------------------|---|-----|------------------------------------------------------------------------------------------------------------------|
| TSUPDT: Time<br>Stamp Update<br>时间戳更新                                        | 3 | 0x0 | 该位为 1 时,系统根据时间戳更新高位寄存器和时间 戳低位寄存器的值(Time Stamp High Update and Time Stamp Low Update registers)更新当前系统时间,完成后该位为 0  |
| TSINIT: Time Stamp<br>Initialize<br>时间戳初始化                                   | 2 | 0x0 | 该位为 1 时,系统根据时间戳更新高位寄存器和时间 戳低位寄存器的值(Time Stamp High Update and Time Stamp Low Update registers)初始化当前系统时间,完成后该位为 0 |
| TSCFUPDT: Time<br>Stamp Fine or<br>Coarse Update<br>时间戳 Fine or<br>Coarse 更新 | 1 | 0x0 | 该位为 1 时,表示时间戳更新将会用 Fine Update 的方式,为 0 时表示时间戳更新将会用 Coarse 的方式                                                    |
| TSENA: Time Stamp<br>Enable<br>时间戳启用                                         | 1 | 0x0 | 该位为 1 时,表示当前对于接收和发送帧系统将会启用时间戳记录;为 0 时表示当前停止向接收和发送帧进行时间戳记录,并且暂停时间戳发生器;该为置 1 后应该接着进行时间戳初始化(bit 2)                  |

11.2.23 Register449 (Sub-Second Increment Register)

| Trizizo registeras (Sub Second Indicinent register) |                                                            |     |                                                      |  |  |
|-----------------------------------------------------|------------------------------------------------------------|-----|------------------------------------------------------|--|--|
| Register449 (Sub-Sec                                | Register449 (Sub-Second Increment Register) Offset: 0x0704 |     |                                                      |  |  |
| Reserved                                            | 31:8 0x0                                                   | 0.0 | 保留                                                   |  |  |
| 保留                                                  |                                                            | UXU |                                                      |  |  |
| SSINC: Sub-second                                   |                                                            |     | 业场中的传收入进业型亚轨安方思(************************************ |  |  |
| increment value                                     | 7:0                                                        | 0x0 | 此域中的值将会被加到亚秒寄存器(sub-second register)                 |  |  |
| 亚秒增加值                                               |                                                            |     | register)                                            |  |  |

11.2.24 Register 450 (System Time - Seconds Register)

| Register 450 (System Time - Seconds Register) Offset: 0x0708 |      |     |                   |  |  |
|--------------------------------------------------------------|------|-----|-------------------|--|--|
| TSS: Time Stamp                                              |      |     |                   |  |  |
| Second                                                       | 31:0 | 0x0 | 该域的值表示当前系统时间的秒级计数 |  |  |
| 时间戳秒                                                         |      |     |                   |  |  |

**11.2.25** Register 451 (System Time - Nanoseconds Register)
Register 451 (System Time - Nanoseconds Register) Offset: 0x070C



| PSNT: Positive or<br>Negative Time<br>正或负时间 | 31   | 0x0 | 该域表示正或负的时间,当为 1 时表示时间为正数,<br>为 0 时表示为负数                                            |
|---------------------------------------------|------|-----|------------------------------------------------------------------------------------|
| TSSS: Time Stamp<br>Sub Seconds<br>时间戳亚秒    | 30:0 | 0x0 | 该域的值表示当前系统时间的亚秒级计数,默认时间<br>精度为 0.46 纳秒(当 TSCTRLSSR 置起时精度为<br>1ns,最大值为 0x3B9A_C9FF) |

**11.2.26** Register 452 (System Time - Seconds Update Register)

|                                                                     | rizize register rez (e) etem rime e e e en ac e paate register/ |     |                              |  |  |  |
|---------------------------------------------------------------------|-----------------------------------------------------------------|-----|------------------------------|--|--|--|
| Register 452 (System Time - Seconds Update Register) Offset: 0x0710 |                                                                 |     |                              |  |  |  |
| TSS: Time Stamp                                                     |                                                                 |     | 安禄的唐左至统初始从时的初唐 武县再架时的梯加      |  |  |  |
| Second                                                              | 31:0                                                            | 0x0 | 该域的值在系统初始化时的初值,或是更新时的增加<br>值 |  |  |  |
| 时间戳秒                                                                |                                                                 |     | IE.                          |  |  |  |

11.2.27 Register 453 (System Time - Nanoseconds Update Register)

| 11.2.27 Regis                            | ter 453  | s (System  | i Time - Nanoseconds Update Register)                                               |
|------------------------------------------|----------|------------|-------------------------------------------------------------------------------------|
| Register 453 (System                     | Time - N | Vanosecond | s Update Register) Offset: 0x0714                                                   |
| ADDSUB: Add or<br>subtract time<br>加或减时间 | 31       | 0x0        | 该域表示加或减时间,当为 1 时表示更新时减去更新<br>寄存器的值,为 0 时表示增加更新寄存器的值                                 |
| TSSS: Time Stamp<br>Sub Seconds<br>时间戳亚秒 | 30:0     | 0x0        | 该域的值表示当前系统时间更新时增加或减少的亚秒级计数,默认时间精度为 0.46 纳秒(当 TSCTRLSSR 置起时精度为 1ns,最大值为 0x3B9A_C9FF) |

**11.2.28** Register 454 (Time Stamp Addend Register)

| Register 454 (Time Stamp Addend Register) Offset: 0x0718 |      |     |                                     |  |  |
|----------------------------------------------------------|------|-----|-------------------------------------|--|--|
| TSAR: Time Stamp<br>Addend Register                      | 31:0 | 0x0 | 该域的值表示在系统时间同步时需要被增加的 <b>32</b> 位时间值 |  |  |
| 时间戳加数寄存器                                                 |      |     | H) 101/1E                           |  |  |

**11.2.29** Register 455 (Target Time Seconds Register)

| regio                                                      | Trizizo register los (larget lime eccentas register) |     |                                                                              |  |  |  |  |
|------------------------------------------------------------|------------------------------------------------------|-----|------------------------------------------------------------------------------|--|--|--|--|
| Register 455 (Target Time Seconds Register) Offset: 0x071C |                                                      |     |                                                                              |  |  |  |  |
| TSTR: Target Time<br>Seconds Register<br>目标时间秒寄存器          | 31:0                                                 | 0x0 | 该域保存了以秒为单位的时间,当时间戳时间匹配或超过了该域的值及低位寄存器(reg 456)的值且包MAC地址匹配,系统会产生一个中断(中断必须事先启用) |  |  |  |  |

**11.2.30** Register 456 (Target Time Nanoseconds Register)

| Register 456 (Target 7 | Time Nar | noseconds R | degister) Offset: 0x0720 |
|------------------------|----------|-------------|--------------------------|
| Reserve                | 31       | 0x0         |                          |



| 保留                 |      |     |                             |
|--------------------|------|-----|-----------------------------|
| TSTR: Target Time  |      | 0x0 | 该域保存了以纳秒为单位的时间, 当时间戳时间匹配    |
| Stamp Low Register |      |     | 或超过了该域的值及目标时间寄存器(reg 455)的值 |
| 目标时间戳低寄存           | 30:0 |     | 且包 MAC 地址匹配,系统会产生一个中断(中断必须  |
| 器                  |      |     | 事先启用)                       |

11.2.31 Register 457 (System Time - Higher Word Seconds Register)

| II.Z.JI INEGIS       | 161 431  | (System     | i filitie - filgiter word Seconds Register) |
|----------------------|----------|-------------|---------------------------------------------|
| Register 457 (System | Time - H | Iigher Word | Seconds Register) Offset: 0x0724            |
| Reserve              | 21:16    | 0.0         |                                             |
| 保留                   | 31:16    | 0x0         |                                             |
| TSHWR: Time          |          |             |                                             |
| Stamp Higher Word    |          | 00          | 流域但存實 46 位/most significant hit)如叶间熟体       |
| Register             | 15:0     | 0x0         | 该域保存高 16 位(most significant bit)的时间戳值       |
| 时间戳高位寄存器             |          |             |                                             |

11.2.32 Register 458 (Time Stamp Status Register)

| Register 458 (Time St                                              |       |     | ) Offset: 0x0728                                          |
|--------------------------------------------------------------------|-------|-----|-----------------------------------------------------------|
| Reserve                                                            | 31:28 | 0x0 |                                                           |
| 保留                                                                 |       |     |                                                           |
| ATSNS: Auxiliary<br>Time Stamp Number<br>of Snapshots<br>附属时间戳快照个数 |       | 0x0 | 该域表示了 FIFO 中快照的个数,4(3`b100)表示<br>FIFO 满,0(3`000)表示 FIFO 空 |
| ATSSTM: Auxiliary Time Stamp Snapshot Trigger Missed 附属时间戳快照触发 缺失  |       | 0x0 | 该位为 1 时表示当前 FIFO 满且设置了外部触发,表示最后一个快照因为 FIFO 满被丢失了; 否则为 0   |
| Reserve<br>保留                                                      | 23:3  | 0x0 |                                                           |
| Auxiliary Time<br>Stamp Trigger<br>Snapshot<br>附属时间戳快照触发           |       | 0x0 | 该位为 1 时表示有快照(snapshot)写入了 FIFO                            |
| TSTARGT: Time                                                      | 1     | 0x0 | 该位为 1 时表示系统时间已经大于或等于目标时间                                  |



| Stamp Target Time                         |     | 戳寄存器中的值                                      |
|-------------------------------------------|-----|----------------------------------------------|
| Reached                                   |     |                                              |
| 达到时间戳目标时间                                 |     |                                              |
| TSSOVF: Time<br>Stamp Seconds<br>Overflow | 0x0 | 该位为 1 时表示当前时间戳的时间已经溢出(大于 0xFFFF_FFFF); 反之为 0 |
| 时间戳秒溢出                                    |     |                                              |

11.2.33 Register 459 (PPS Control Register)

|                                                                                                        | Register 459 (PPS Control Register) Offset: 0x072C |     |                                                                                                                                                                                                                                                                                                            |  |  |  |
|--------------------------------------------------------------------------------------------------------|----------------------------------------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Reserve<br>保留                                                                                          | 31:4                                               | 0x0 |                                                                                                                                                                                                                                                                                                            |  |  |  |
| PPSCTRL: Control<br>the duration<br>between 2-pulses of<br>PPS signal output<br>2个 PPS 信号输出的<br>时间间隔控制 | 15:0                                               | 0x0 | 该域设置 2 个 PPS 信号输出的时间间隔,编码如下: 0000: 1.0 秒(Binary & Digital Rollover) 0001: 0.5 秒(Binary Rollover), 0.536 秒(Digital Rollover) 0010: 0.25 秒(Binary Rollover), 0.26 秒(Digital Rollover) 0011: 0.125 秒(Binary Rollover), 0.13 秒(Digital Rollover) 1111: 15.28 μ 秒(Binary Rollover), 32.77 μ 秒(Digital Rollover) |  |  |  |

11.2.34 Register 460 (PPS Auxiliary Time Stamp - Nanoseconds Register)

| Register 460 (PPS Auxiliary Time Stamp - Nanoseconds Register) Offset: 0x0730 |     |                                           |  |  |  |
|-------------------------------------------------------------------------------|-----|-------------------------------------------|--|--|--|
| 31:0                                                                          | 0x0 | 包含了附属时间戳(Auxiliary Time Stamp)的低(纳秒)32 位值 |  |  |  |

11.2.35 Register 461 (PPS Auxiliary Time Stamp - Seconds Register)

| Register 460 (PPS Auxiliary Time Stamp - Seconds Register) Offset: 0x0730 |      |     |                                             |  |  |
|---------------------------------------------------------------------------|------|-----|---------------------------------------------|--|--|
| 3                                                                         | 31:0 | 0x0 | 包含了附属时间戳(Auxiliary Time Stamp)的高(秒)32<br>位值 |  |  |

# 11.3 DMA 描述符

DMA 描述符是 MAC 驱动和硬件的交互接口,记录了数据包的内存地址和传输状态。在此分别定义了发送描述符(Tx Desciptor)和接收描述符(Rx Descriptor)



两种数据结构。两种描述符可以自由选择分别以环式(ring mode)或者链式(chain mode)相连,以供 MAC 使用。

#### 11.3.1 DMA 描述符的基本格式

每一个 DMA 描述符包含两个数据 buffer、两个字节计数 buffer 和两个指向数据 buffer 地址的指针。需要注意的是描述符的地址必须保证按照所连接的系统总线位宽对齐,同时保证与系统字节序相同(默认小尾端)。



图 11-1 DMA 描述符的基本格式 (小尾端 32 位总线)



图 11-2 DMA 描述符的基本格式(小尾端 64 位总线)

#### 11.3.2 DMA 接收描述符

GMAC 子系统在工作模式下需要至少两个接收描述符才能够正常的接收一个网络数据包。其内部的接收模块在处理一个网络数据包时,总是在同时尝试获取下一个接收描述符。每一个网络数据包被称为一个帧(frame)。





图 11-3 DMA 接收描述符的基本格式(小尾端 32 位总线)

#### 11.3.2.1 RDES0

RDES0包括了当前接收帧状态、长度以及该描述符的所有情况(主机或 DMA 拥有)。RDES0的具体细节参见下表。

| RDES0                                                | 位     |                                                                                                     |
|------------------------------------------------------|-------|-----------------------------------------------------------------------------------------------------|
| OWN<br>所有模式                                          | 31    | 该位为 1 时表示描述符当前属于 DMA 控制, 0 表示属于主机控制。当 DMA 模块完成一次传输时,会将该位主动清 0                                       |
| AFM: Destination<br>Address Filter Fai<br>目标地址过滤错误 I | 30    | 当该位为 1 时,表示当前数据帧目标地址不符合 GMAC 内部的帧目标地址过滤器                                                            |
| FR: Frame length<br>帧长度                              | 29:16 | 表示接收当前帧的长度,当 ES 位为 0 时有效                                                                            |
| ES: Error Summary<br>总体错误信息                          | 15    | 指示当前帧是否出错,其值为 RDES[0]、RDES[1]、RDES[3]、<br>RDES[4]、RDES[6]、RDES[7、RDES[11]、RDES[14]各位<br>作或运算(OR)的结果 |
| DE: Descriptor<br>Error<br>描述符错误                     | 14    | 当该位为 1 时表示,当前描述符所指向的 buffer 与帧不相符或者 OWN 为 0(主机控制)                                                   |
| SAF: Source<br>Address Filter Fail<br>源地址过滤错误        | 13    | 当该位为 1 时,表示当前数据帧的源地址不符合 GMAC 内部的帧源地址过滤器                                                             |
| LE: Length Error                                     | 12    | 当该位为 1 时,表示当前接收帧长度与默认长度不符。当                                                                         |



| 长度错误                                                             |    | Frame Type 位为 1 且 CRC Error 位为 0 时有效                                                                                                                                                 |
|------------------------------------------------------------------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| OE: Over Flow                                                    |    | I talle type E/3 i er eite Eiler E/3 e in h/m                                                                                                                                        |
| Error<br>溢出错误                                                    | 11 | 当该位为 1 时,表示接收该帧时 GMAC 内部 RxFIFO 溢出                                                                                                                                                   |
| VLAN: VLAN Tag<br>VLAN 标志                                        | 10 | 当该位为 1 时,表示该帧的类型为 VLAN                                                                                                                                                               |
| FS: First Desciptor<br>第一个描述符                                    | 9  | 当该位为 1 时,表示当前描述符所指向的 buffer 为当前接收帧的第一个保存 buffer                                                                                                                                      |
| LS: Last Desciptor<br>最后一个描述符                                    | 8  | 当该位为 1 时,表示当前描述符所指向的 buffer 为当前接收<br>帧的最后一个保存 buffer                                                                                                                                 |
| IPC Checksum<br>Error/Giant Frame<br>校验错误/超长帧                    | 7  | 当该位为 1 时,如果 IPC 校验功能启用则表示当前帧的 IPv4 头校验值与帧内部校验域的值不相符。如果未启用则表示当前帧为一个超长帧(长度大于 1518 字节)                                                                                                  |
| LC: late collision<br>后期冲突                                       | 6  | 当该位为 1 时,表示在半双工模式下,当前帧接收时发生了一个后期冲突                                                                                                                                                   |
| FT: Frame Type<br>帧类型                                            | 5  | 当该位为 1 时,表示当前帧为一个以太网格式帧,为 0 时表示当前帧为一个 IEEE802.3 格式帧                                                                                                                                  |
| RWT: Receive<br>Watchdog Timeout                                 | 4  | 当该位为 1 时,表示当前时钟值超过了接收模块看门狗电路时钟的值,既接收帧超时                                                                                                                                              |
| RE: Receive Error<br>接收错误                                        | 3  | 当该位为 1 时,表示接收当前帧时内部模块出错。内部信号rxer 置 1 且 rxdv 置 1                                                                                                                                      |
| DE: Dribble bit<br>Error<br>奇数位错误                                | 2  | 当该位为 1 时,表示接收帧长度不是整数,即总长度为奇数位,该位只有在 mii 模式下有效                                                                                                                                        |
| CE: CRC Error<br>接收 CRC 校验错误                                     | 1  | 当该位为 1 时,表示接收当前帧时内部 CRC 校验出错。该位只有在 last descriptor(RDES0[8])为 1 时有效                                                                                                                  |
| RX MAC:<br>Checksum/payload<br>Checksum Error<br>接受校验/负载校验<br>错误 | 0  | 当该位为 1 时,表示接收当前帧时内部 RX MAC 寄存器组 1-15 中存在一个匹配当前帧目的地址。为 0 时表示 RX MAC 寄存器组 0 匹配接受帧目的地址。如果 Full Checksum Offload Engine 启用时,为 1 表示该帧 TCP/UDP/ICMP 校验错误。该位为 1 时也可能表示当前帧实际接受长度与帧内部记载长度不相符。 |



#### 11.3.2.2 RDES1

RDES1 记录了描述符所指向的 buffer 大小,以及描述符的组织格式(环形或链型)。

| RDES1                                                      | 位     |                                                                                                                                       |
|------------------------------------------------------------|-------|---------------------------------------------------------------------------------------------------------------------------------------|
| Disable Intr in<br>Completion<br>禁止完成后发中断                  | 31    | 该位为1时表示该帧接收完成后将不会置起STATUS寄存器中RI位(CSR5[6]),这将会使得主机无法检测到该中断                                                                             |
| Reserved<br>保留                                             | 30:26 |                                                                                                                                       |
| RER: Receive End<br>of Ring<br>环型描述符结尾                     | 25    | 该位为 1 时表示该描述符为环型描述符链表的最后一个,下<br>一个描述符的地址为接收描述符链的基址                                                                                    |
| RCH: Second<br>Address Chained<br>第二个buffer地址指<br>向下个链式描述符 | 24    | 该位为 1 时表示描述符中的第二个 buffer 地址指向的是下一个描述符的地址,为 0 时表示该地址指向第二个 buffer 地址当该位为 1 时,RDES1[21-11]的值将没有意义,RDES1[25]比 RDES1[24]具有更高优先级(代表环型而不是链型) |
| Reserved<br>保留                                             | 23:22 |                                                                                                                                       |
| RBS2: Receive<br>Buffer Size 2<br>接收 buffer2 大小            | 21:11 | 该域表示数据 buffer2 的大小。根据系统总线的宽度<br>32/64/128, Buffer2 的大小应该为 4/8/16 的整数倍。如果不<br>满足则会导致未知的结果。该域在 RDES1[24]为 0 时有效                         |
| RBS2: Receive<br>Buffer Size 1<br>接收 buffer1 大小            | 10:0  | 该域表示数据 buffer1 的大小。根据系统总线的宽度32/64/128, Buffer1 的大小应该为 4/8/16 的整数倍。如果不满足则会导致未知的结果。该域一直有效。如果该域值为 0, DMA 则会自动访问 buffer2 或者下一个接收描述符       |

#### 11.3.2.3 RDES2

该域记录了数据接收 buffer1 的地址。

| RDES2           | 位    |                                    |
|-----------------|------|------------------------------------|
| Buffer1 Address |      | 该域记录了数据接收 buffer1 的 32 位物理地址。该物理地址 |
| Pointer         | 31:0 | 没有默认的对齐要求。当 GMAC DMA 内部实现了总线数据     |
| 接收 buffer1 地址   |      | 32/64/128 位对齐,则该地址的低 2/3/4 位会被忽略   |



#### 11.3.2.4 RDES3

该域记录了数据接收 buffer2 的地址。

| RDES3                      | 位    |                                                                                                        |
|----------------------------|------|--------------------------------------------------------------------------------------------------------|
| Buffer2 Address<br>Pointer | 31:0 | 该域记录了数据接收 buffer2 的 32 位物理地址。该物理地址没有默认的对齐要求。当 GMAC DMA 内部实现了总线数据 32/64/128 位对齐,则该地址的低 2/3/4 位会被忽略. 如果描 |
| 接收 buffer2 地址              |      | 32/04/128 位对介,则该地址的低 2/3/4 位层被忽略. 如采抽述符是以链式连接,则该域记录的是下一个描述符的地址                                         |

#### 11.3.3 DMA 发送描述符

发送描述符与接收描述符的格式基本相同。每个描述符的地址需要按照总线宽度(32/64/126位)对齐。



图 11-4 DMA 发送描述符的基本格式(小尾端 32 位总线)

#### 11.3.3.1 TDES0

TDES0 包含了发送帧的状态和发送描述符的所属信息。

| TDES0                              | 位     |                                                               |
|------------------------------------|-------|---------------------------------------------------------------|
| OWN<br>所属模式                        | 31    | 该位为 1 时表示描述符当前属于 DMA 控制,0 表示属于主机控制。当 DMA 模块完成一次传输时,会将该位主动清 0  |
| Reserved<br>保留                     | 30:18 |                                                               |
| TTSS: Tx Time Stamp Status 发送时间戳状态 | 17    | 当 IEEE1588 功能启用时,该位为 1 表示 TDES2 和 TDES3 中保存了该发送帧的时间戳信息。否则该位保留 |
| IHE: IP Header                     | 16    | 该位为 1 时表示内部校验模块发现该发送帧的 IP 头出错,并                               |



| Error                                    |     | 且不会对该域做任何修改                                                                                            |
|------------------------------------------|-----|--------------------------------------------------------------------------------------------------------|
| IP 头错误                                   |     |                                                                                                        |
| ES: Error Summary<br>总体错误信息              | 15  | 指示当前帧是否出错,其值为 TDES[1]、TDES[2]、TDES[8]、<br>TDES[9]、TDES[10]、TDES[11]、TDES[13]、TDES[14]各<br>位作或运算(OR)的结果 |
| JT: Jabber Timeout<br>Jabber 超时          | 14  | 该位为 1 时表示 GMAC 发送模块遇到了 Jabber 超时                                                                       |
| FF: Frame Flushed<br>帧刷新                 | 13  | 该位为 1 时表示软件发出了一个刷新命令导致 DMA/MTL 将<br>其内部的帧刷新掉                                                           |
| PCE: Payload<br>Checksum Error<br>负载校验错误 | 12  | 该位为 1 时表示内部负载校验模块再向发送帧中插入校验数据时出错。当负载校验模块启用时,该位有效                                                       |
| LC: Loss of Carrier<br>载波丢失              | 11  | 该位为1时表示在发送该帧过程中载波丢失(gmii_crs 信号多个周期未置起)                                                                |
| NC: No Carrier<br>载波无效                   | 10  | 该位为 1 时表示在发送过程中, PHY 的载波信号一直未置起                                                                        |
| LC: Late Collision<br>后期冲突               | 9   | 当该位为 1 时表示在半双工模式下,当前帧接收时发生了<br>一个后期冲突                                                                  |
| EC: Excessive<br>Collison<br>连续冲突        | 8   | 当该位为 1 时表示在发送当前帧的时候连续出现了 16 次冲<br>突                                                                    |
| VF: VLAN Frame<br>VLAN 帧                 | 7   | 该位为 1 时表示当前发送帧为一个 VLAN 帧                                                                               |
| CC: Collsion Count<br>冲突计数               | 6:3 | 该域表示当前帧在成功发送之前所遇到冲突次数的总数                                                                               |
| ED: Excessive<br>Deferral<br>连续 Deferral | 2   | 该位为 1 时表示当前帧传输结束                                                                                       |
| UF: Underflow<br>Error<br>溢出错误           | 1   | 该位为 1 时表示当前帧传输时发生了溢出错误,即数据传输<br>buffer 过小或不可用                                                          |
| DB: Defered Bit                          | 0   | 该位为1时表示此次发送被延迟,只有在半双工模式下有效                                                                             |



| 帧刷新 |  |  |  |
|-----|--|--|--|
|-----|--|--|--|

#### 11.3.3.2 TDES1

TDES1 包含了 buffer 大小以及其他一些控制描述符环型/链型连接的控制和状态位。

| TDES1                                                      | 位     |                                                                                                                                                                      |
|------------------------------------------------------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IC: Interrption on<br>Complete<br>完成时中断                    | 31    | 该位为1时表示该帧接发送完成后将会置起STATUS寄存器中 TI 位(CSR5[0])                                                                                                                          |
| LS: Last Segment<br>最后段                                    | 30    | 该位为1时表示当前 buffer 包含的是一帧数据的最后一段(如<br>果帧分为多个段)                                                                                                                         |
| FS: First Segment<br>第一段                                   | 29    | 该位为1时表示当前 buffer 包含的是一帧数据的第一段(如果<br>帧分为多个段)                                                                                                                          |
| CIC: Checksum<br>Insertion Control<br>校验数据填充控制             | 28:27 | 该域控制内部模块是否在发送帧中填充校验数据。<br>值: 2'b00: 不填充校验数据<br>2'b01: 填充 IPV4 头校验数据<br>2'b10: 在伪头数据(pseudo-header)存在的情况下,填充<br>TCP/UDP/ICMP 全校验数据<br>2'b11: 总是填充 TCP/UDP/ICMP 的全校验数据 |
| DC: Disable CRC<br>禁止 CRC 校验                               | 26    | 该位为 1 时 GMAC 硬件不在每个发送帧的结尾添加 CRC 校验数据                                                                                                                                 |
| TER: Transmit End<br>of Ring<br>环形描述符结尾                    | 25    | 该位为 1 时表示该描述符为环型描述符链表的最后一个,下<br>一个描述符的地址为发送描述符链的基址                                                                                                                   |
| TCH: Second<br>Address Chained<br>第二个buffer地址指<br>向下个链式描述符 | 24    | 该位为 1 时表示描述符中的第二个 buffer 地址指向的是下一个描述符的地址,为 0 时表示该地址指向第二个 buffer 地址当该位为 1 时,TDES1[21-11]的值将没有意义,TDES1[25]比 TDES1[24]具有更高优先级(代表环型而不是链型)                                |
| DP: Dissable<br>Pading<br>禁止填充                             | 23    | 该位为 1 时表示 GMAC 将不会对长度小于 64 字节的数据包进行空数据填充                                                                                                                             |
| TTSE: Transmit                                             | 22    | 该位为 1 时表示将启用内部模块计算 IEEE1588 硬件时间戳                                                                                                                                    |



| Time Stamp Enable |       | 计算,在 TDES1[29]为 1 时有效                                     |
|-------------------|-------|-----------------------------------------------------------|
| 启用发送时间戳           |       |                                                           |
| TBS2: Transmit    |       | 该域表示数据 buffer2 的大小。当 TDES1[24]为 1 时,该域                    |
| Buffer Size 2     | 21:11 | 因域表示数据 $Dulle12$ 的人小。 $\exists \ TDE31[24]$ 为 $T$ 时, $该域$ |
| 发送 buffer2 大小     |       | ЛLXX                                                      |
| TBS1: Transmit    |       |                                                           |
| Buffer Size 1     | 10:0  | 该域表示数据 buffer1 的大小。该域一直有效。如果该域外                           |
| 发送 buffer1 大小     |       | 为 0,DMA 则会自动访问 buffer2 或者下一个接收描述符                         |

#### 11.3.3.3 TDES2

该域记录了数据发送 buffer1 的地址。

| TDES2           | 位 |                                    |
|-----------------|---|------------------------------------|
| Buffer1 Address |   | 该域记录了数据接收 buffer1 的 32 位物理地址。该物理地址 |
| Pointer         |   | 没有默认的对齐要求。当 GMAC DMA 内部实现了总线数据     |
| 发送 buffer1 地址   |   | 32/64/128 位对齐,则该地址的低 2/3/4 位会被忽略   |

#### 11.3.3.4 TDES3

该域记录了数据发送 buffer2 的地址。

| TDES3                                       | 位    |                                                                                                                                |
|---------------------------------------------|------|--------------------------------------------------------------------------------------------------------------------------------|
| Buffer2 Address<br>Pointer<br>发送 buffer2 地址 | 31:0 | 该域记录了数据接收 buffer2 的 32 位物理地址。该物理地址没有默认的对齐要求。当 GMAC DMA 内部实现了总线数据 32/64/128 位对齐,则该地址的低 2/3/4 位会被忽略。如果描述符是以链式连接,则该域记录的是下一个描述符的地址 |



## 11.4 软件编程向导

#### DMA 初始化:

- 1. 软件重置(reset)MAC
- 2. 等待重置完成(查询 DMA reg0[0])
- 3. 对 DMA reg0 的以下域进行编程
  - a. MIX-BURST 和 AAL(DMA reg0[26]、[25])
  - b. Fixed-burst 或者 undefined-burst(DMA reg0[16])
  - c. Burst-length 和 Burst-mode
  - d. Descriptor Length(只有当环形格式时有效)
  - e. Tx和Rx仲裁调度
- 4. 对 AXI Bus Mode Reg 进行编程
  - a. 如果选择了 Fixed-burst,则需要在该寄存器内设置最大 burst length
- 5. 分别创建发送、接收描述符链,可以分别选择环形模式或者链型模式进行连接,并将接收描述符的 OWN 位设为 1(DMA 拥有)
- 6. 在软件启用 DMA 描述符之前,必须保证至少发送/接收描述符链中有三个描述符
- 7. 将发送、接收描述符链表的首地址写入 DMA reg3、4
- 8. 对 DMA reg6(DMA mode operation)中的以下位进行配置
  - a. 接收/发送的 Store and Forward
  - b. 接收/发送的阈值因子(Threshold Control)
  - c. 启用流控制(hardware flow control enable)
  - d. 错误帧和未识别的正确帧略过(forwarding enable)
  - e. 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. 对 MAC reg4(GMII Address Register)进行正确配置,使其能够正常访问 PHY 相关寄存器
- 3. 读取 MAC reg5(GMII Data Register)获取当前 PHY 的链接(link)、速度 (speed)、模式(双工)等信息
- 4. 配置 MAC 地址
- 5. 如果启用了 hash filtering,则需要对 hash filtering 进行配置
- 6. 对 MAC reg1(Mac Frame filter)以下域进行配置,来进行帧过滤 118



- a. 接收所有
- b. 混杂模式(promiscuous mode)
- c. 哈希或完美过滤(hash or perfect filter)
- d. 组播、多播过滤设置等等
- 7. 对 MAC reg6(Flow control register)以下域进行配置
  - a. 暂停时间和其他暂停控制位
  - b. 接收和发送流控制位
  - c. 流控制忙/后压力启用
- 8. 对中断掩码寄存器(Mac reg15)进行配置
- 9. 基于之前得到的线路信息(link,speed,mode)对 MAC reg0 进行正确的配置
- 10. 设置 MAC reg0[2]、[3]来启用 MAC 中的发送、接收模块

#### 发送和接收的一般过程:

- 检测到发送或接收中断后,查寻相应描述符来判断其是否属于主机,并读取描述符中的数据
- 2. 完成对描述符中数据的读取后,将描述符各位清 0 并设置其 OWN 位,使其继续发送/接收数据
- 3. 如果当前发送或接收描述符不属于 DMA(OWN=0),则 DMA 模块会进入挂起状态。当有数据需要被发送或接收时,向 DMA Tx/Rx POLL 寄存器写 1 重新使能 DMA 模块。需要注意的是接收描述符在空闲时应该总是属于DMA(OWN=1)
- 4. 发送和接收描述符及对应 buffer 地址的实时信息可以通过查寻 DMA reg18、19、20、21 获得



# 12 USB 控制器

#### 12.1 总体概述

1C的 USB 主机端口特性如下:

- 兼容 USB Rev 1.1 、USB Rev 2.0 协议
- 兼容 OHCI Rev 1.0、EHCI Rev 1.0 协议
- 支持 LS (Low Speed)、FS (Full Speed) 和 HS (HighSpeed) 的 USB 设备
- 支持一个端口,可挂LS、FS或HS设备

USB 主机控制器模块包括一个支持高速设备的 EHCI 控制器,一个支持全速与低速设备的 OHCI 控制器。其中 EHCI 控制器处于主控地位,只有当挂上的设备是全速或低速设备时,才将控制权转交给 OHCI 控制器;当全速或低速设备拔掉时,控制权返回 EHCI 控制器。

同时 USB 控制器内部集成了 AHB 总线接口(与 AMBA Specification Revision 2.0 兼容),用来和内存/应用程序之间通信。USB 控制器与外部的互联结构图如图 12-1 所示:



图 12-1 USB 主机控制器模块图

# 12.2 USB 主机控制器寄存器

#### 12.2.1 EHCI 相关寄存器

EHCI 的相关寄存器包括 Capability 寄存器、Operational 寄存器和,EHCI 实



现相关寄存器。1C 的 USB 主机控制器兼容 EHCI Rev 1.0 协议,Capability 寄存器和 Operational 寄存器的详细信息参照 Enhanced Host Controller Interface Rev 1.0 Specification。

EHCI 寄存器的基址为,以下寄存器的地址为基址加偏移。

#### 12.2.2 Capability 寄存器

| 名称        | 偏移地址 | 宽度 | 访问 | 说明                |
|-----------|------|----|----|-------------------|
| HCCAPBASE | 0x00 | 32 | RO | 默认值为 32'h01000010 |
| HCSPARAMS | 0x04 | 32 | RO | 默认值为 32'h00001116 |
| HCCPARAMS | 0x08 | 32 | RO | 默认值为 32'h0000A010 |

(注: USBBase 固定为 EHCI slave 的起始地址 0xbfe2\_0000)

#### 12.2.3 Operational 寄存器

| 名称                | 地址    | 宽度       | 访问     | 说明                                             |
|-------------------|-------|----------|--------|------------------------------------------------|
| USBCMD            | 0x10  | 32       | R/W、   | USB 主机控制器的命令寄                                  |
| USBCMD            | OXIO  | 32       | RO     | 存器                                             |
| USBSTS            | 0x14  | 32       | R/W、   | USB 主机控制器的状态                                   |
| CSDS1S            | 0.114 | 32       | RO     | 寄存器                                            |
| USBINTR           | 0x18  | 32       | R/W    | USB 主机控制器的中断设                                  |
| CSBIVIK           | OXIO  | 32       | IC/ VV | 置寄存器                                           |
| FRINDEX           | 0x1c  | 32       | R/W    | USB 主机控制器的帧索                                   |
| TKIIVDLX          | OATC  | 32       | 10 11  | 引寄存器                                           |
| CTRLDSSEGMENT     | 0x20  | 32       | R/W    | 存放 EHCI 控制数据结构                                 |
| CIREDSSECTIENT    | ON20  | 32       | 10 11  | 的地址                                            |
| PERIODICLISTBASE  | 0x24  | 32       | R/W    | 存放周期数据帧表的起始                                    |
| TERRODICEISTERISE | UAZ I |          |        | 地址                                             |
| ASYNCLISTADDR     | 0x28  | 32       | R/W    | 存放下一个要被执行的异                                    |
| TISTI (CEISTIEE)  | 0.120 | 32 10 11 |        | 步队列的起始地址                                       |
| CONFIGFLAG        | 0x50  | 32       | R/W    | 配置模式寄存器                                        |
| PORTSC 1          | 0x54  | 32       | R/W、   | 端口1状态和控制寄存器                                    |
| TORISCI           | 0334  | 32       | RO     | 利日 1 (八心/甲) 土町 日 (丁帝                           |
|                   |       |          | R/W、   |                                                |
| PORTSC 2          | 0x58  | 32       | RO     | 端口2状态和控制寄存器                                    |
|                   |       |          | R/W、   |                                                |
| PORTSC 3          | 0x5c  | 32       | RO     | 端口3状态和控制寄存器                                    |
| POPTSC 4          | 0.60  | 20       | R/W、   | <b>港口 4                                   </b> |
| PORTSC 4          | 0x60  | 32       | RO     | 端口 4 状态和控制寄存器                                  |



| PORTSC 5 | 0x64 | 32 | R/W、<br>RO | 端口 5 状态和控制寄存器 |
|----------|------|----|------------|---------------|
| PORTSC 6 | 0x88 | 32 | R/W、<br>RO | 端口6状态和控制寄存器   |

(注: USBOPBase 固定为 EHCI slave 的起始地址+ `h10)

#### 12.2.4 EHCI 实现相关寄存器

EHCI 实现相关寄存器的详细描述如下。

| 名称         | 地址   | 宽  | 访问      | 说明                   |
|------------|------|----|---------|----------------------|
|            |      | 度  |         |                      |
| INSNREG00  | 0x90 | 32 | R/W     | 帧的长度配置寄存器            |
| INSNREG01  | 0x94 | 32 | R/W     | 数据包缓冲区 OUT/IN 阈值寄存器  |
| INSNREG02  | 0x98 | 32 | RO      | 数据包缓冲深度寄存器           |
| INSNREG03  | 0x9c | 32 | RO ,R/W | 参照寄存器详细描述            |
| INSNREG04  | 0xa0 | 32 | R/W     | 用于 Debug             |
| INSNREG05  | 0xa4 | 32 | RO, R/W | UTMI 配置 (默认配置), 控制和状 |
| INSINKEGOS | 0x44 | 32 | KO, K/W | 态寄存器                 |
| INSNREG06  | 0xa8 | 32 | RO      | AHB 错误状态寄存器          |
| INSNREG07  | 0xac | 32 | RO      | AHB Master 错误地址寄存器   |
| INSNREG08  | 0xb0 | 32 | RO      | HSIC 使能寄存器           |

#### INSNREG00 寄存器 (disable)

#### INSNREG01 寄存器

| 位域    | 访问  | 复位值      | 说明                                        |
|-------|-----|----------|-------------------------------------------|
| 31:16 | R/W | 16'h0020 | OUT 阈值(单位是 4 bytes),一旦从系统内存中取出的数据         |
|       |     |          | 量达到 OUT 阈值,就开始 USB 传输,最小为 16bytes         |
| 15:0  | R/W | 16'h0020 | IN 阈值(单位是 4 bytes),一旦 Packet Buffer 里的数据量 |
|       |     |          | 达到 IN 阈值,就开始向内存传输,最小为 16bytes             |

#### INSNREG02 寄存器

|   | _     |          |          |                              |
|---|-------|----------|----------|------------------------------|
|   | 位域    | 访问       | 复位值      | 说明                           |
|   | 31:12 | Reserved | 20'h0    | 保留                           |
| • | 11:0  | RO       | 12'h0020 | <b>数据包缓冲深度</b> (单位是 4 bytes) |

#### INSNREG03 寄存器



| 位域    | 访问       | 复位值   | 说明                             |
|-------|----------|-------|--------------------------------|
| 31:13 | Reserved | 19'h0 | 保留                             |
|       |          |       |                                |
| 12:10 | RO       | 3'h0  | 这个字段指定 phy_clks 的额外延时,这个延时被添加到 |
|       |          |       | "Tx-Tx turnaround Delay"中。     |
| 9     | RO       | 1'h0  | 置 1: 将迫使主机控制器在一帧的每一微帧中获取周期数据   |
|       |          |       | 帧表,                            |
|       |          |       | 置 0: 主机控制器在一帧的微帧 0 中获取周期数据帧表   |
| 8:1   | R/W      | 8'h0  | 时间可容忍偏移,这个字段用来指明为了容忍计算可用时间     |
|       |          |       | 而要附加的字节数。计算可用时间为以后的传输弹性增加的,    |
|       |          |       | 用户程序默认不需要修改这个字段。               |
| 0     | RO       | 1'h0  | Break Memory Transaction 模式    |
|       |          |       | 置 1: 使能此功能                     |
|       |          |       | 置 0:禁止此功能                      |

## INSNRE04 寄存器(仅用于调试,软件不必更改此寄存器)

| 位域   | 访问       | 复位值   | 说明                                                                                                                                     |
|------|----------|-------|----------------------------------------------------------------------------------------------------------------------------------------|
| 31:6 | Reserved | 26'h0 | 保留                                                                                                                                     |
| 5    | R/W      | 1'h0  | 置 1: 禁止 automatic 功能,即当软件清除 Run/Stop 位时,<br>USB 主机控制器会把挂起(Suspend)的端口唤醒<br>置 0: 启用 automatic 功能,当 reset Run/Stop 位时,Suspend<br>信号会置为 1 |
| 4    | R/W      | 1'h0  | 置 1:禁止 NAK reload 修复<br>置 0:启用 NAK reload 修复                                                                                           |
| 3    | Reserved | 1'h0  | 保留                                                                                                                                     |
| 2    | R/W      | 1'h0  | 置1: 缩短端口枚举(enumeration)时间(仿真)                                                                                                          |
| 1    | R/W      | 1'h0  | 置 1: HCCPARAMS 寄存器的第 17、15:4、2:0 位均可写                                                                                                  |
| 0    | R/W      | 1'h0  | 置 1: HCSPARAMS 寄存器可写                                                                                                                   |

## INSNRE05 寄存器

| 位域    | 访问       | 复位值   | 说明                                          |
|-------|----------|-------|---------------------------------------------|
| 31:18 | Reserved | 14'h0 | 保留                                          |
| 17    | RO       | 1'h0  | 置 1:表示对这个寄存器进行了一个写操作,硬件正在执行 置 0:表示硬件已经执行完操作 |



| 16:13 | R/W | 5'h0 | 端口号           |
|-------|-----|------|---------------|
| 12    | R/W | 4'h1 | VControlLoadM |
|       |     |      | 置 1: NOP      |
|       |     |      | 置 0: Load     |
| 11:8  | R/W | 4'h0 | VControl      |
| 7:0   | RO  | 4'h0 | VStatus       |

#### INSNREG06 寄存器

| 位域    | 访问       | 复位值   | 说明                          |
|-------|----------|-------|-----------------------------|
| 31    | R/W      | 1'h0  | 一旦 AHB 出错即被捕获并置 1,写 0 清除该字段 |
| 30:12 | Reserved | 19'h0 | 保留                          |
| 11:9  | RO       | 3'h0  | AHB 出错时控制段 HBURST 的值        |
| 8:4   | RO       | 5'h0  | AHB 出错的 burst 的预计节拍数        |
| 3:0   | RO       | 4'h0  | 在当前 burst 下,AHB 出错前完成的节拍数   |

#### INSNREG07 寄存器

| 位域   | 访问 | 复位值   | 说明            |
|------|----|-------|---------------|
| 31:0 | RO | 32'h0 | AHB 出错时控制段的地址 |

#### INSNREG08 寄存器

| 位域   | 访问 | 复位值  | 说明      |
|------|----|------|---------|
| 31:0 | RO | 1'b0 | HSIC 使能 |

## 12.3 OHCI 相关寄存器

OHCI 的相关寄存器包括 Operational 寄存器和 OHCI 实现相关寄存器。1C 的 USB 主机控制器兼容 OHCI Rev 1.0 协议,Operational 寄存器的详细信息参照 Open Host Controller Interface Rev 1.0 Specification。

OHCI 寄存器的基址为 0xbfe280000,以下寄存器的地址为基址加偏移。

#### 12.3.1 Operational 寄存器

| 名称         | 地址   | 宽度 | 访问 | 说明    |
|------------|------|----|----|-------|
| HcRevision | 0x00 | 32 | -  | 控制和状态 |



| 0x04  | 32                                                                                                   | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x08  | 32                                                                                                   | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0x0C  | 32                                                                                                   | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0x10  | 32                                                                                                   | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0x14  | 32                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0x18  | 32                                                                                                   | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 内存指针                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 0x1C  | 32                                                                                                   | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0x20  | 32                                                                                                   | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0x24  | 32                                                                                                   | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0x28  | 32                                                                                                   | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0x2C  | 32                                                                                                   | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0x30  | 32                                                                                                   | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0x34  | 32                                                                                                   | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 帧计数器                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 0x38  | 32                                                                                                   | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0x3C  | 32                                                                                                   | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0x40  | 32                                                                                                   | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0x44  | 32                                                                                                   | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0x48  | 32                                                                                                   | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 根集线器                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 0x04C | 32                                                                                                   | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0x50  | 32                                                                                                   | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0x54  | 32                                                                                                   | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0x58  | 32                                                                                                   | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|       | 0x08 0x0C 0x10 0x14 0x18 0x1C 0x20 0x24 0x28 0x2C 0x30 0x34 0x38 0x3C 0x40 0x44 0x48 0x04C 0x50 0x54 | 0x08         32           0x0C         32           0x10         32           0x14         32           0x18         32           0x1C         32           0x20         32           0x24         32           0x28         32           0x30         32           0x34         32           0x38         32           0x3C         32           0x40         32           0x44         32           0x48         32           0x50         32           0x54         32 | 0x08       32       -         0x0C       32       -         0x10       32       -         0x14       32       -         0x18       32       -         0x1C       32       -         0x20       32       -         0x24       32       -         0x28       32       -         0x30       32       -         0x30       32       -         0x34       32       -         0x38       32       -         0x40       32       -         0x44       32       -         0x48       32       -         0x50       32       -         0x54       32       - |

## 12.3.2 OHCI 实现相关寄存器

除了标准的 OHCI 操作寄存器,还实现了两个额外寄存器(寄存器偏移 0x98 和 0x9C)用来报告 AHB 的错误状态。

| 名称        | 地址   | 宽度 | 访问 | 说明                 |
|-----------|------|----|----|--------------------|
| INSNREG06 | 0x98 | 32 | RO | AHB 错误状态寄存器        |
| INSNREG07 | 0x9c | 32 | RO | AHB Master 错误地址寄存器 |

#### INSNREG06 寄存器

|       | * ** *** |       |                              |  |
|-------|----------|-------|------------------------------|--|
| 位域    | 访问       | 复位值   | 说明                           |  |
| 31    | R/W      | 1'h0  | 一旦 AHB 出错即被捕获并置 1, 写 0 清除该字段 |  |
| 30:12 | RO       | 19'h0 | 保留                           |  |



| 11:9 | RO | 3'h0 | AHB 出错时控制段 HBURST 的值      |
|------|----|------|---------------------------|
| 8:4  | RO | 5'h0 | AHB 出错的 burst 的预计节拍数      |
| 3:0  | RO | 4'h0 | 在当前 burst 下,AHB 出错前完成的节拍数 |

## INSNREG07 寄存器

| 位 | 立域  | 访问 | 复位值   | 说明            |
|---|-----|----|-------|---------------|
| 3 | 1:0 | RO | 32'h0 | AHB 出错时控制段的地址 |



# 13 OTG 控制器

### 13.1 概述

1C的OTG支持特性如下:

- 支持 HNP 与 SRP 协议;
- 内嵌 DMA, 无需占用处理器带宽即可在 OTG 与外部存储之间移动数据
- 在 device 模式下,为高速设备 (480Mbps);
- 在 host 模式下, 仅能支持高速设备(480Mbps);
- 在 device 模式下,支持 2 个双向的 endpoint, 其中仅有默认的 endpoint0 支持控制传输;
- 在 device 模式下, 最多同时支持 2 个 IN 方向的传输;
- 在 host 模式下, 支持 6 个 channel, 且软件可配置每个 channel 的方向;
- 在 host 模式下, 支持 periodic OUT 传输;

## 13.2 寄存器描述

应用程序通过 AHB slave 接口来读写 OTG 控制器里的控制与状态寄存器 (CSRs),这些寄存器都是 32 位宽,寄存器地址为 32 位对齐。

这里需要注意的是,在 host 模式与 device 模式下都能访问的寄存器组仅包括全局寄存器组(Core Global),功耗与门控时钟(Power and Clock Gating)寄存器组,数据 FIFO 访问(Data FIFO Access)寄存器组,端口(Host Port)寄存器组。当 OTG 控制器处于 host 或 device 模式下,不能访问另一个模式下的寄存器。如果发生非法的寄存器读写,将发生模式不匹配(Mode Mismatch)中断,这个中断将反映在中断寄存器中(Core Interrupt Register).

当 OTG 从一个模式转换到另一个模式时,必须重新配置这个模式下的寄存器,因为这些寄存器在转换后的状态与上电重启时是一样的。

CSR 的地址映射是固定的,其中 Host 模式下的寄存器与 Device 模式下的寄存器处于不同的地址空间,所有的寄存器都工作在 AHB 时钟域里。下图显示了 CSR 的地址映射关系:



| 0000h  |                                                 |
|--------|-------------------------------------------------|
|        | Core Global CSRs(1KB)                           |
| 0400h  | Host Mode CSRs(1KB)                             |
| 0800h  | Device Mode CSRs(1.5KB)                         |
| 0E00h  | Power and Clock Gating CSRs (1.5KB)             |
| 1000h  | Device EP 0/Host Channel 0<br>FIFO (4KB)        |
| 2000h  | Device EP 1/Host Channel 1<br>FIFO (4KB)        |
| 3000h  |                                                 |
| 7000h  | Device EP 6/Host Channel 6<br>FIFO (4KB)        |
| 8000h  |                                                 |
|        | Reserved                                        |
| 20000h | Direct Access to Data FIFO<br>RAM for Debugging |
| 3FFFFh | (128KB)                                         |
|        |                                                 |

图 13-1 OTG CSRs 地址映射

以下章节分组列出了 OTG 所有的寄存器及其偏移地址, 其基地址为 0xbfe0 0000。

## **13.2.1** 全局控制与状态寄存器(Global CSR Map)

不管 OTG 工作在 host 模式下还是 Device 模式下都可访问这组寄存器,其对应的偏移地址如下表所示:

| 寄存器缩略名    | 偏移地址 | 寄存器名                                             |  |  |
|-----------|------|--------------------------------------------------|--|--|
| GOTGCTL   | 000h | Control and Status Register                      |  |  |
| GOTGINT   | 004h | Interrupt Register                               |  |  |
| GAHBCFG   | 008h | AHB Configuration Register                       |  |  |
| GUSBCFG   | 00Ch | USB Configuration Register                       |  |  |
| GRSTCTL   | 010h | Reset Register                                   |  |  |
| GINTSTS   | 014h | Interrupt Status Register                        |  |  |
| GINTMSK   | 018h | Interrupt Mask Register                          |  |  |
| GRXSTSR   | 01Ch | Receive Status Debug Read/Status Read and Pop    |  |  |
| GRXSTSP   | 020h | Registers                                        |  |  |
| GRXFSIZ   | 024h | Receive FIFO Size Register                       |  |  |
| GNPTXFSIZ | 028h | Non-Periodic Transmit FIFO Size Register         |  |  |
| GNPTXSTS  | 02Ch | Non-Periodic Transmit FIFO/Queue Status Register |  |  |
| GSNPSID   | 040h | Synopys ID Register                              |  |  |
| GHWCFG1   | 044h | User HW Config1 Register                         |  |  |
| GHWCFG2   | 048h | User HW Config2 Register                         |  |  |
| GHWCFG3   | 04Ch | User HW Config3 Register                         |  |  |
| GHWCFG4   | 050h | User HW Config4 Register                         |  |  |



| GDFIFOCFG | 05Ch      | DFIFO Software Config Register                 |  |  |  |
|-----------|-----------|------------------------------------------------|--|--|--|
| HPTXFSIZ  | 100h      | Host Periodic Transmit FIFO Size Register      |  |  |  |
| DIEPTXFn  | 104h-3FFh | Device IN Endpoint Transmit FIFO Size Register |  |  |  |

### **13.2.2** Host 模式控制与状态寄存器(Host Mode CSR)

一旦 OTG 工作在 Host 模式下,这组寄存器必须被重新配置。

| 寄存器缩略名    | 偏移地址        | 寄存器名                                              |  |
|-----------|-------------|---------------------------------------------------|--|
| HCFG      | 400h        | Host Configuration                                |  |
| HFIR      | 404h        | Host Frame Interval Register                      |  |
| HFNUM     | 408h        | Host Frame Number/Frame Time Remaining Register   |  |
|           | 40ch        | Reserved                                          |  |
| HPTXSTS   | 410h        | Host Periodic Transmit FIFO/Queue Status Register |  |
| HAINT     | 414h        | Host All Channels Interrupt Register              |  |
| HAINTMSK  | 418h        | Host All Channels Interrupt Mask Register         |  |
| HPRT      | 440h        | Host Port Control and Status Register             |  |
|           | 444h-4FCh   | Reserved                                          |  |
| HCCHARn   | 500h        | Moving the Host Core to Test Mode                 |  |
| HCSPLTn   | 504h        | Host Channel-n Split Control Register (HCSPLTn    |  |
| HCINTn    | 508h        | Host Channel-n Interrupt Register (HCINTn)        |  |
| HCINTMSKn | 50Ch        | Host Channel-n Interrupt Mask Register (HCINTMSKn |  |
| HCTSIZn   | 510h        | Host Channel-n Transfer Size Register (HCTSIZn    |  |
| HCDMAn    | 514h        | Host Channel-n DMA Address Register               |  |
|           | 518h        | Reserved                                          |  |
| HCDMABn   | 51Ch        | Host Channel-n DMA Buffer Address Register        |  |
| HCCHARn   | 520h - 53Ch | Host Channel-n Characteristics Register           |  |
|           | 540h-55h    |                                                   |  |
|           | •••         |                                                   |  |
|           | 6C0h—6DCh   |                                                   |  |
|           | 6E0h-6FCh   |                                                   |  |
|           | 6FDh-7FFh   |                                                   |  |

## 13.2.3 Device 模式控制与状态寄存器(Device Mode CSR)

一旦 OTG 工作在 Device 模式下,这组寄存器必须被重新配置。

| 寄存器缩略名   | 偏移地址 | 寄存器名                                         |
|----------|------|----------------------------------------------|
| DCFG     | 800h | Device Configuration Register                |
| DCTL     | 804h | Device Control Register                      |
| DSTS     | 808h | Device Status Register                       |
|          | 80Ch | Reserved                                     |
| DIEPMSK  | 810h | Device IN Endpoint Common Interrupt Mask     |
|          |      | Register                                     |
| DOEPMSK  | 814h | Device OUT Endpoint Common Interrupt Mask    |
|          |      | Register                                     |
| DAINT    | 818h | Device All Endpoints Interrupt Register      |
| DAINTMSK | 81Ch | Device All Endpoints Interrupt Mask Register |



| DVBUSDIS            | 828h      | Device VBUS Discharge Time Register              |  |  |
|---------------------|-----------|--------------------------------------------------|--|--|
| DVBUSPULSE          | 82Ch      | Device VBUS Pulsing Time Register                |  |  |
| DTHRCTL             | 830h      | Device Threshold Control Register                |  |  |
| DIEPEPMSK           | 834h      | Device IN Endpoint FIFO Empty Interrupt Mask     |  |  |
|                     |           | Register                                         |  |  |
| DIEPCTL0            | 900h      | Device Control IN Endpint0 Control Register      |  |  |
|                     | 904h      | Reserved                                         |  |  |
| DIEPCTLn            | 920-AE0h  | Device Endpoint-n Control Register               |  |  |
| DIEPINTn            | 908h      | Device Endoint-n Interrupt Register              |  |  |
|                     | 90Ch      | Reserved                                         |  |  |
| DIEPTSIZ0/DOEPTSIZ0 | 910h      | Device Endpoint0 Transfer Size Register          |  |  |
| DIEPTSIZn/DOEPTSIZn | 910h      | Device Endpointn Transfer Size Register          |  |  |
| DIEPDMAn            | 914h      | Device Endpoint-n DMA Address Register           |  |  |
| DTXFSTSn            | 918h      | Device IN Endpoint Transmit FIFO Status Register |  |  |
| DIEPDMAB0           | 91Ch      | Device Endpoint-n DMA Buffer Address Register    |  |  |
| DOEPCTL0            | B00h      | Device Control OUT Endpint0 Control Register     |  |  |
|                     | B04h      | Reserved                                         |  |  |
| DOEPCTLn            | B20-BE0h  | Device Endpoint-n Control Register               |  |  |
| DOEPINTn            | B08h      | Device Endoint-n Interrupt Register              |  |  |
|                     | B0Ch      | Reserved                                         |  |  |
| DOEPTSIZ0           | B10h      | Device Endpoint0 Transfer Size Register          |  |  |
| DOEPTSIZn           | B10h      | Device Endpointn Transfer Size Register          |  |  |
| DOEPDMAn            | B14h-CF4h | Device Endpoint-n DMA Address Register           |  |  |
| DOEPDMAB0           | B1Ch-CFCh | Device Endpoint-n DMA Buffer Address Register    |  |  |

## 13.2.4 数据 FIFO 访问寄存器组(DFIFO Access Register MAP)

不管 OTG 工作在 host 模式下还是 Device 模式下,都可访问这组寄存器。这组寄存器用作读写某个给定方向的 endpoint 或 channel 的 FIFO。如果 host 模式下 channel 的方向为 IN,那么只能读这个 channel 上的 FIFO;相类似地,若 host 模式下 channel 的方向为 OUT,那么只能写这个 channel 上的 FIFO。

| 寄存器名                                                   | 偏移地址        | 读写特性  |
|--------------------------------------------------------|-------------|-------|
| Device IN Endpoint 0/Host OUT Channel 0: DFIFO Write   | 1000h-1FFCh | WO/RO |
| Access                                                 |             |       |
| Device OUT Enpoint 0/Host IN Channel 0 : DFIFO Read    |             |       |
| Access                                                 |             |       |
| Device IN Endpoint 0/Host OUT Channel 0: DFIFO Write   | 2000h-2FFCh | WO/RO |
| Access                                                 |             |       |
| Device OUT Enpoint 0/Host IN Channel 0 : DFIFO Read    |             |       |
| Access                                                 |             |       |
|                                                        |             |       |
| Device IN Endpoint 14/Host OUT Channel 14: DFIFO Write | F000h-FFFCh | WO/RO |
| Access                                                 |             |       |
| Device OUT Enpoint 14/Host IN Channel 14 : DFIFO Read  |             |       |



| Access                                                 |               |       |
|--------------------------------------------------------|---------------|-------|
| Device IN Endpoint 15/Host OUT Channel 15: DFIFO Write | 10000h-10FFCh | WO/RO |
| Access                                                 |               |       |
| Device OUT Enpoint 15/Host IN Channel 15: DFIFO Read   |               |       |
| Access                                                 |               |       |

#### 13.2.5 功耗控制与门控时钟寄存器组(Power and Clock Gating CSR Map)

不管 OTG 工作在 host 模式下还是 Device 模式下,都可访问这组寄存器。这组寄存器用作功耗控制与门控时钟。

| 寄存器缩略名  | 偏移地址 | 描述                                      |
|---------|------|-----------------------------------------|
| PCGCCTL | E00h | Power and Clock Gating Control Register |

## 13.3 寄存器描述

#### 13.3.1 寄存器访问特性

在以下章节描述寄存器时,会有一栏访问特性,用来标示这些寄存器的读写特性。下面的内容将列出这些访问特性的具体含义。

| Read Only (RO)            | 只读                                  |  |  |
|---------------------------|-------------------------------------|--|--|
| Write Only(WO)            | 只写                                  |  |  |
| Read and Write(R_W)       | 可读可写                                |  |  |
| Read, Write, and Self     | 可读可写;且 OTG 控制器自身可清 0,具体清 0 的条件在以下章  |  |  |
| Clear(R_W_SC)             | 节的各个域中有详细解释                         |  |  |
| Read, Write, Self Set and | 可读可写;且 OTG 控制器自身可置位,可清 0,具体置位与清 0   |  |  |
| Self Clear                | 的条件在以下章节的各个域中有详细解释                  |  |  |
| (R W SS SC)               |                                     |  |  |
| Read, Self Set, and Write | 可读;且 OTG 控制器自身可置位;且当软件往这位写 1 完成清 0  |  |  |
| Clear                     | 效果,往这位写 0 不会产生效果。OTG 置位的条件在以下章节的    |  |  |
| (R_SS_WC)                 | 各个域中有详细解释                           |  |  |
| Read, Write Set, and Self | 可读;且当软件往这位写 1 完成置位效果;且 OTG 控制器自身    |  |  |
| Clear                     | 可清 0, 软件不可清 0, 即软件往这位写 1 不会产生效果。OTG |  |  |
| (R_WS_SC)                 | 清 0 的条件在以下章节的各个域中有详细解释              |  |  |
| Read, Self Set, and Self  | 可读;且 OTG 控制器自身可置位,可清 0;当软件往这位写 1    |  |  |
| Clear or Write Clear      | 完成清 0 效果,往这位写 0 不会产生效果。OTG 具体置位与清 0 |  |  |
| (R_SS_SC_WC)              | 的条件在以下章节的各个域中有详细解释                  |  |  |

#### 13.3.2 全局寄存器

不管 OTG 工作在 host 模式下还是 Device 模式下都可访问这组寄存器,当 OTG 从一种工作模式转换到另一种工作模式时,无需重新例化这些寄存器。

#### 控制与状态寄存器(GOTGCTL)

偏移地址: 000h

OTG 控制与状态寄存器(GOTGCTL)控制 OTG 的功能以及反映其状态。

| 域     | 说明     | 工作模式         | 复位值  | 访问特性 |
|-------|--------|--------------|------|------|
| 31:21 | 保留域    | Host; Device |      | RO   |
| 20    | OTG 版本 | Host;        | 1'b0 | RW   |



|          |                                                    | - ·         | 1     |     |
|----------|----------------------------------------------------|-------------|-------|-----|
|          | ● 1'b0: 版本 1.3; 此版本 OTG 支持                         | Device      |       |     |
|          | Data line pulsing 与 VBus pulsing                   |             |       |     |
|          | 的 SRP                                              |             |       |     |
|          | ● 1'b1: 版本 2.0; 此版本的 OTG 仅                         |             |       |     |
|          | 支持 Data line pulsing 的 SRP                         |             |       |     |
| 19       | B-session valid(BSesVId)                           | Device only | 1'b1  | RO  |
|          | 指定 device 模式下 transceiver 的状                       |             |       |     |
|          | 态。                                                 |             |       |     |
|          | ● 1'b0: B-session 非法                               |             |       |     |
|          | ● 1'b1: B-session 合法                               |             |       |     |
|          | 在 OTG 模式下,用这位来决定设备是                                |             |       |     |
|          | 否连接上<br>                                           |             | 411.0 |     |
| 18       | ssesion valid(ASesVId)                             | Host only   | 1'b0  | RO  |
|          | 指定 host 模式下 transceiver 的状态。  ● 1'b0: A-session 非法 |             |       |     |
|          | ,,                                                 |             |       |     |
|          | ● 1'b1: A-session 合法                               |             |       |     |
| 47       | 在 device 模式下,此位为保留位                                | Heat and    | 1'b0  | DO. |
| 17       | Long/Short Debounce Time (DbncTime)                | Host only   | 1 60  | RO  |
|          | 指定一个发现连接的 debounce 时间                              |             |       |     |
|          | ● 1'b0: long debounce time,用作                      |             |       |     |
|          | 物理连接(100ms + 2.5us)                                |             |       |     |
|          | ● 1'b1: short debounce time,用作                     |             |       |     |
|          | 软连接(2.5us)                                         |             |       |     |
| 16       | 连接器 ID 的状态                                         | Host:       | 1'b1  | RO  |
|          | 在一次连接事件中,指示 ID 的状态                                 | Device      |       |     |
|          | ● 1'b0: OTG 工作在 A 设备模式下                            |             |       |     |
|          | ● 1'b1: OTG 工作在 B 设备模式下                            |             |       |     |
| 15:12    | 保留域                                                | Host;       |       | RO  |
|          |                                                    | Device      |       |     |
| 11       | 设备 HNP 使能位(DevHNPEn)                               | Device Only | 1'b0  | R_W |
|          | ● 1'b0: HNP 未被使能                                   |             |       |     |
|          | ● 1'b1: HNP 使能                                     |             |       |     |
| 10       | Host Set HNP 使能位                                   | Host Only   | 1'b0  | R_W |
|          | ● 1'b0: Host Set HNP 未被使能                          |             |       |     |
|          | ● 1'b1: Host Set HNP 使能                            |             |       |     |
| 9        | HNP 请求                                             | Device Only | 1'b0  | R_W |
|          | 软件将这位置位从而发起一个 HNP 请                                |             |       |     |
|          | 求 给 host 。 当                                       |             |       |     |
|          | GOTGINT.HstNegSucStsChng 位置                        |             |       |     |
| <u> </u> | ı                                                  | 1           | ı     | ı   |



|   | <b>拉叶 拉班逐步经济是</b> 《本述》          | T           | 1    | <del>                                     </del> |
|---|---------------------------------|-------------|------|--------------------------------------------------|
|   | 位时,软件通过往这位写 0 来清 0。当            |             |      |                                                  |
|   | HstNegSucStsChng 位为 0,OTG 控     |             |      |                                                  |
|   | 制器将这位清 0.                       |             |      |                                                  |
|   | ● 1'b0: 无 HNP 请求                |             |      |                                                  |
|   | ● 1'b1: HNP 请求                  |             |      |                                                  |
| 8 | Host Negotiation Success        | Device only | 1'b0 | RO                                               |
|   | (HstNegScs)                     |             |      |                                                  |
|   | 当 host 互换(Host Negotiation) 成   |             |      |                                                  |
|   | 功后,OTG 控制器将这位置起。                |             |      |                                                  |
|   | ● 1'b0: host 互换失败               |             |      |                                                  |
|   | ● 1'b1: host 互换成功               |             |      |                                                  |
| 7 | B-Peripheral Session Valid 覆盖值  | Device only | 1'b0 | R_W                                              |
|   | (BvalidOvVal)                   |             |      |                                                  |
|   | 当 GOTGCTL.BvalidOvEn 置位时,       |             |      |                                                  |
|   | BValidOvVal 位用来重新设置 Bvalid      |             |      |                                                  |
|   | 信号                              |             |      |                                                  |
|   | ● 1'b0: 当                       |             |      |                                                  |
|   | GOTGCTL.BvalidOvEn = 1 时,       |             |      |                                                  |
|   | Bvalid 信号的值为 0;                 |             |      |                                                  |
|   | ● 1'b1: 当 GOTGCTL.BvalidOvEn    |             |      |                                                  |
|   | = 1 时,Bvalid 信号的值为 1;           |             |      |                                                  |
| 6 | B-Peripheral Session Valid 重置使能 | Device only | 1'b0 | R_W                                              |
|   | (BvalidOvEn)                    |             |      |                                                  |
|   | 这位用来使能软件通过                      |             |      |                                                  |
|   | GOTGCTL.BValidOvVal 位来覆盖        |             |      |                                                  |
|   | Bvalid 信号。                      |             |      |                                                  |
|   | ● 1'b1:从PHY接收到的Bvalid信号         |             |      |                                                  |
|   | 值被 BvalidOvVal 重新设置。            |             |      |                                                  |
|   | ● 1'b0:Bvalid 信号重置功能关闭,         |             |      |                                                  |
|   | OTG 控制器内部使用的 Bvalid 信           |             |      |                                                  |
|   | 号的值即位从 PHY 接收到的值                |             |      |                                                  |
| 5 | A-Peripheral Session Valid 重置值  | Host only   | 1'b0 | R_W                                              |
|   | (AvalidOvVal)                   |             |      |                                                  |
|   | 当 GOTGCTL.AvalidOvEn 置位时,       |             |      |                                                  |
|   | AValidOvVal 位用来重新设置 Avalid 信    |             |      |                                                  |
|   | 号                               |             |      |                                                  |
|   | ● 1'b0: 当                       |             |      |                                                  |
|   | GOTGCTL.AvalidOvEn = 1 时,       |             |      |                                                  |
|   | Avalid 信号的值为 0;                 |             |      |                                                  |
|   | ● 1'b1: 当 GOTGCTL.AvalidOvEn    |             |      |                                                  |
|   | <u> </u>                        | I           |      |                                                  |



|   | 4 叶 A.a.u.a 冶口炉压工 4                 |              |      | <del>                                     </del> |
|---|-------------------------------------|--------------|------|--------------------------------------------------|
| 4 | = 1 时,Avalid 信号的值为 1;               | Hoot only    | 1160 | D \\\                                            |
| 4 | A-Peripheral Session Valid 重置使能     | Host only    | 1'b0 | R_W                                              |
|   | (AvalidOvEn)<br>这 位 用 来 使 能 软 件 通 过 |              |      |                                                  |
|   | GOTGCTL.AValidOvVal 位 来             |              |      |                                                  |
|   | Override Avalid 信号。                 |              |      |                                                  |
|   | ● 1'b1:从 PHY 接收到的 Avalid 信号         |              |      |                                                  |
|   | 值被 AvalidOvVal 重新设置。                |              |      |                                                  |
|   | ■ 1'b0:Avalid 信号重置功能关闭,             |              |      |                                                  |
|   | OTG 控制器内部使用的 Avalid 信               |              |      |                                                  |
|   | 号的值即位从 PHY 接收到的值                    |              |      |                                                  |
| 3 | VBUS Valid 重置值(VbvalidOvVal)        | Host only    | 1'b0 | R_W                                              |
|   | 当 GOTGCTL.VbvalidOvEn 置位时,          | . 1001 01119 | . 55 | ``=''                                            |
|   | VbvalidOvVal 位用来重新设置 vbus           |              |      |                                                  |
|   | valid 信号                            |              |      |                                                  |
|   | ● 1'b0: 当                           |              |      |                                                  |
|   | GOTGCTL.VbvalidOvEn = 1 时,          |              |      |                                                  |
|   | Vbus valid 信号的值为 0;                 |              |      |                                                  |
|   | ● 1'b1: 当                           |              |      |                                                  |
|   | GOTGCTL.VbvalidOvEn = 1 时,          |              |      |                                                  |
|   | vbus valid 信号的值为 1;                 |              |      |                                                  |
| 2 | VBUS Valid 重置使能(AvalidOvEn)         | Host only    | 1'b0 | R_W                                              |
|   | 这位用来使能软件通过                          |              |      |                                                  |
|   | GOTGCTL.VbValidOvVal 位 来            |              |      |                                                  |
|   | Override vbus valid 信号。             |              |      |                                                  |
|   | ● 1'b1: 从PHY接收到的vbus valid          |              |      |                                                  |
|   | 信号值被 VbvalidOvVal 重新设               |              |      |                                                  |
|   | 置。                                  |              |      |                                                  |
|   | ● 1'b0: vbus valid 信号重置功能关          |              |      |                                                  |
|   | 闭, OTG 控制器内部使用的 vbus                |              |      |                                                  |
|   | valid 信号的值即位从 PHY 接收到               |              |      |                                                  |
|   | 的值                                  |              |      |                                                  |
| 1 | 会话请求 (Session Request,              | Device only  | 1'b0 | R_W                                              |
|   | SesReq)                             |              |      |                                                  |
|   | 软件通过置位 SesReq 位在 USB 总线             |              |      |                                                  |
|   | 上发起一次会话请求。当 OTG 中断寄                 |              |      |                                                  |
|   | 存器的 Host Negotiation Success        |              |      |                                                  |
|   | Status Change 位置位时,软件通过             |              |      |                                                  |
|   | 往这位写 0 来清 0。当                       |              |      |                                                  |
|   | HstNegSucStsChng 位为 0,OTG 控         |              |      |                                                  |



|   | 制器将这位清 0.              |             |      |     |
|---|------------------------|-------------|------|-----|
|   | ● 1'b0: 无会话请求          |             |      |     |
|   | ● 1'b1: 请求会话           |             |      |     |
| 0 | 会话请求成功(Session Request | Device only | 1'b0 | R_W |
|   | Success, SesReqScs)    |             |      |     |
|   | ● 1'b0: 会话请求失败         |             |      |     |
|   | ● 1'b1: 会话请求成功         |             |      |     |

## 中断寄存器(GOTGINT)

偏移地址: 004h

| 域     | <b>说明</b>                         | 工作模式          | 复位值  | 访问特性   |
|-------|-----------------------------------|---------------|------|--------|
| 31:20 | 保留域                               | Host; Device  |      | RO     |
| 19    | Debounce Done (DbnceDone )        | Host only     | 1'b0 | R_SS_W |
|       | 当设备连接上的 debounce 完成后,             |               |      | С      |
|       | OTG 控制器置起这位。当应用看到这                |               |      |        |
|       | 个中断后,可以开始 USB 复位操作。               |               |      |        |
| 18    | A 设备超时改变(ADevTOUTChg)             | Host ; Device | 1'b0 | R_SS_W |
|       | 当A设备等待B设备连接超时时,OTG                |               |      | С      |
|       | 控制器置起这位                           |               |      |        |
| 17    | 检测到角色互换(HstNegDet):               | Host ; Device | 1'b0 | R_SS_W |
|       | 当在 USB 总线上发现角色互换请求                |               |      | С      |
|       | (Host Negotiation Req)时,OTG 控     |               |      |        |
|       | 制器置起这位。                           |               |      |        |
| 16:10 | 保留域                               | Host and      |      | RO     |
|       |                                   | Device        |      |        |
| 9     | 角色互换成功状态改变位                       | Host and      | 1'b0 | R_SS_W |
|       | ( HstNegSucStsChng ) : Host       | Device        |      | С      |
|       | Negotiation Success Status Change |               |      |        |
|       | 当 USB 总线上的角色请求成功或失败               |               |      |        |
|       | 时,OTG 控制器将这位置起。软件可                |               |      |        |
|       | 通过查询 GOTGCTL.HstNegSus 位来         |               |      |        |
|       | 确定角色互换请求是否成功                      |               |      |        |
| 8     | 会话请求成功状态改变位                       | Host and      | 1'b0 | R_SS_W |
|       | ( SesReqSusStsChng ) : Session    | Device        |      | С      |
|       | Request Success Status Change     |               |      |        |
|       | 当 USB 总线上的会话请求成功或失败               |               |      |        |
|       | 时,OTG 控制器将这位置起。软件可                |               |      |        |
|       | 通过查询 GOTGCTL.SesReqScs 位          |               |      |        |
|       | 来确定会话请求是否成功                       |               |      |        |



| 7:3 | 保留域                        | Host   | and | 1'b0 | RO     |
|-----|----------------------------|--------|-----|------|--------|
|     |                            | Device |     |      |        |
| 2   | 会话结束检测位(SesEndDet):        | Device |     | 1'b0 | R_SS_W |
|     | Session End Detected       |        |     |      | С      |
|     | 当 utmisrp_bvalid 信号拉低时,OTG |        |     |      |        |
|     | 控制器置起这位                    |        |     |      |        |
| 1:0 | 保留域                        | Host   | and |      | RO     |
|     |                            | Device |     |      |        |

#### AHB 配置寄存器(GAHBCFG)

偏移地址: 008h

这个寄存器用来在上电或工作模式改变时配置 OTG 控制器, 配置的内容主要包括 AHB 相关的系统参数。在初始配置完成后,不能再修改这个寄存器的值。不管是在 AHB 总线还是 USB 总线上开始一次事务(transaction)时,都需要重新配置这个寄存器。

| 配直这个<br> |                                  | <b>工作#</b> -P | 与公压  | >> ≥→ 4→ 4±. |
|----------|----------------------------------|---------------|------|--------------|
| 域        | 说明                               | 工作模式          | 复位值  | 访问特性         |
| 31:23    | 保留域                              | Host; Device  |      | RO           |
| 22       | 通知所有的 DMA 写事务                    | Host;         | 1'b0 | R_W          |
|          | (NotiAllDmaWrit): Notify All Dma | Device        |      |              |
|          | Write Transactions               |               |      |              |
|          | 用来使能对所有的 DMA 写事务(to              |               |      |              |
|          | endpoint/Channel )的 DMA Done 功能. |               |      |              |
|          | 只有当 GAHBCFG.RemMemSupp 位         |               |      |              |
|          | 为 1'b1 时,这位才意义。                  |               |      |              |
|          | ● 1'b1: 对于所有的 DMA 写事务,           |               |      |              |
|          | OTG 控制器都会在 AHB 总线上置              |               |      |              |
|          | 起 ( assert ) dma_req,            |               |      |              |
|          | int_dma_done,                    |               |      |              |
|          | chep_last_transact 以 及           |               |      |              |
|          | chep_number 信号。为了完成对             |               |      |              |
|          | 某个 channel/endpoint 的传输,         |               |      |              |
|          | OTG 控制器需要等待所有写事务                 |               |      |              |
|          | 的 sys_dma_done 信号。               |               |      |              |
|          | ● 1'b0: 仅对写传输(transfer)的         |               |      |              |
|          | 最后一个事务(transaction),OTG          |               |      |              |
|          | 控制器才会置起int_dma_done信             |               |      |              |
|          | 号。同样,为了完成对某个                     |               |      |              |
|          | channel/endpoint 的传输,OTG         |               |      |              |
|          | 控制器仅需要等待那个 DMA 写事                |               |      |              |
|          | 务的 sys_dma_done 信号。              |               |      |              |



| 21 | Remote Memory Support            | Host      | and | 1'b0 | R_W |
|----|----------------------------------|-----------|-----|------|-----|
|    | (RemMemSupp)                     | Device    |     |      |     |
|    | 使能为 DMA 写传输等待系统 DMA              |           |     |      |     |
|    | DONE 信号功能                        |           |     |      |     |
|    | ● 1'b1: 当 OTG DMA 开始对外部存         |           |     |      |     |
|    | 储空间的传输时,置起输出信号                   |           |     |      |     |
|    | int_dma_req。当完成这个传输,             |           |     |      |     |
|    | OTG 控制器置起 int_dma_done           |           |     |      |     |
|    | 信号用来指示从 OTG 控制器来的                |           |     |      |     |
|    | DMA 写完成。然后 OTG 控制器等              |           |     |      |     |
|    | 待从系统来 sys_dma_done 信号,           |           |     |      |     |
|    | 以 便 完 成 对 某 个                    |           |     |      |     |
|    | channel/endpoint的数据传输。           |           |     |      |     |
|    | ● 无需置起 int_dma_req 与             |           |     |      |     |
|    | int_dma_done 信号; 一旦 DMA          |           |     |      |     |
|    | 写传输完成,XferComp中断之气,              |           |     |      |     |
|    | OTG 控制器继续工作。且无需等                 |           |     |      |     |
|    | 待 sys_dma_done 信号以完成数            |           |     |      |     |
|    | 据传输。                             |           |     |      |     |
| 8  | 周期性 TxFIFO Empty Level           | Host only |     | 1'b0 | R_W |
|    | (PTxFIFOEmpLvI): Periodic TxFIFO |           |     |      |     |
|    | Empty Level 指示周期性 TxFIFO 空中      |           |     |      |     |
|    | 断位(GINTSTS.PTxFEMp)何时置起。         |           |     |      |     |
|    | 这位仅用在 slave 模式下。                 |           |     |      |     |
|    | ● 1'b0:GINTSTS.PTxFEMp 中断位       |           |     |      |     |
|    | 指示当周期性 TxFIFO 半空                 |           |     |      |     |
|    | ● 1'b1: GINTSTS.PTxFEMp 中断位      |           |     |      |     |
|    | 指示周期性 TxFIFO 全空                  |           |     |      |     |
| 7  | 非周期性 TxFIFO Empty Level          | Host      | and | 1'b0 | R_W |
|    | (NPTxFIFOEmpLvI): Non-Periodic   | device    |     |      |     |
|    | TxFIFO Empty Level 这位仅用在         |           |     |      |     |
|    | slave 模式下。                       |           |     |      |     |
|    | 指示 IN 端点的 TxFIFO 空中断位            |           |     |      |     |
|    | (DIEPINTn.TxFEmp)何时置起。           |           |     |      |     |
|    | Host 模式:                         |           |     |      |     |
|    | ● 1'b0: GINTSTS.PTxFEMp 中断位      |           |     |      |     |
|    | 指示非周期性 TxFIFO 半空;                |           |     |      |     |
|    | ● 1'b1: GINTSTS.PTxFEMp 中断位      |           |     |      |     |
|    | 指示非周期性 TxFIFO 全空;                |           |     |      |     |
|    | device 模式:                       |           |     |      |     |
|    |                                  |           |     |      |     |



|     | ● 1'b0: 中断对软件可见             |        |          |      |     |
|-----|-----------------------------|--------|----------|------|-----|
|     | ● 1'b0: 中断对软件不可见            |        |          |      |     |
|     | 寄存器。                        |        |          |      |     |
|     | 这位,OTG 控制器总是更新中断状态          |        |          |      |     |
|     | 用来屏蔽对软件的中断。不管是否置起           | Device | •        |      |     |
| 0   | 全局中断屏蔽位(GlblIntrMsk)        | Host;  |          | 1'b0 | R_W |
|     | ● 其他: 保留                    |        |          |      |     |
|     | • 4'b0000: INCR16           |        |          |      |     |
|     | • 4'b0000: INCR8            |        |          |      |     |
|     | • 4'b0000: INCR4            |        |          |      |     |
|     | • 4'b0001: INCR             |        |          |      |     |
|     | ● 4'b0000: Single           |        |          |      |     |
|     | AHB Master 的 burst 类型       | Device | <b>!</b> |      |     |
| 4:1 | Burst 长度(HBstLen)           | Host;  |          | 4'b0 | R_W |
|     | ● 1'b1: OTG 工作在 DMA 模式      |        |          |      |     |
| -   | ● 1'b0: OTG 工作在 Slave 模式    | 1.00., | 201.00   |      |     |
| 5   | DMA 使能 (DMAEn)              | Host:  | Device   | 1'b0 | R_W |
| 6   | 保留域                         | Host:  | Device   |      | RO  |
|     | 指示 IN 端点的 TxFIFO 全空;        |        |          |      |     |
|     | ● 1'b1: DIEPINTn.TxFEmp 中断位 |        |          |      |     |
|     | 指示 IN 端点的 TxFIFO 半空;        |        |          |      |     |
|     | ● 1'b0: DIEPINTn.TxFEmp 中断位 |        |          |      |     |

## USB 配置寄存器(GUSBCFG)

偏移地址: 00Ch

这个寄存器用来在上电或工作模式改变时配置 OTG 控制器, 配置的内容主要包括 USB 与 USB-PHY 相关的参数。不管是在 AHB 总线还是 USB 总线上开始一次事务(transaction)时,都需要配置这个寄存器。在初始配置完成后,不能再修改这个寄存器的值。

| 域  | 说明                            | 工作模式   | 复位值  | 访问特性 |
|----|-------------------------------|--------|------|------|
| 31 | Corrupt Tx package ()         | Host;  | 1'b0 | WO   |
|    | 仅用来做调试使用,不可写 1.               | Device |      |      |
| 30 | 强制 device 模式(ForceDevMod)     | Host;  | 1'b0 | R_W  |
|    | 写 1 意味着 OTG 控制器将工作在 device 模式 | Device |      |      |
|    | 下,而不管 utmiotg_iddig 输入管脚的值。   |        |      |      |
|    | ● 1'b0: 正常工作模式                |        |      |      |
|    | ● 1'b1: 强制 device 模式          |        |      |      |
|    | 将这位写 1 后,软件必须等待至少 25ms 的生     |        |      |      |
|    | 效时间。当在 scale down 模式下的仿真环境    |        |      |      |
|    | 下,500us 已经足够。                 |        |      |      |
| 29 | 强制 Host 模式(ForceHostMod)      | Host;  | 1'b0 | R_W  |



|        |                                  | Davida | <u> </u> | 1   |
|--------|----------------------------------|--------|----------|-----|
|        | 写 1 意味着 OTG 控制器将工作在 Host 模式      | Device |          |     |
|        | 下,而不管 utmiotg_iddig 输入管脚的值。      |        |          |     |
|        | ● 1'b0: 正常工作模式                   |        |          |     |
|        | ● 1'b1: 强制 Host 模式               |        |          |     |
|        | 将这位写 1 后,软件必须等待至少 25ms 的生        |        |          |     |
|        | 效时间。当在 scale down 模式下的仿真环境       |        |          |     |
|        | 下,500us 已经足够。                    |        |          |     |
| 28     | Tx End 延时(TxEndDelay)            | Device | 1'b0     | R_W |
|        | 写 1 使能 TxEndDelay 计时器。           | only   |          |     |
|        | ● 1'b0: 正常模式                     |        |          |     |
|        | ● 1'b1: 引入 Tx end 延时计时器          |        |          |     |
| 27: 23 | 保留                               | Host;  |          | RO  |
|        |                                  | Device |          |     |
| 22     | TermSel DLine Pulsing 选 择        | Device | 1'b0     | R_W |
|        | (TermSelDLPulse)                 |        |          |     |
|        | 用来在 SRP 过程中,选择 utmi_termselect   |        |          |     |
|        | 驱动数据脉冲(data line pulse)。         |        |          |     |
|        | ● 1'b0: 用 utmi_txvalid 驱动数据脉冲(默  |        |          |     |
|        | 认)                               |        |          |     |
|        | ● 1'b1: 用 utmi_termselect 驱动数据脉冲 |        |          |     |
| 21: 16 | 保留                               | Host;  |          | RO  |
|        |                                  | Device |          |     |
| 15     | PHY 的低功耗时钟选择(PhyLpwClkSel)       | Host;  | 1'b0     | R_W |
|        | 选择使用 480MHz 或 48Mhz(低功耗)PHY 模    | Device |          |     |
|        | 式。在 FS 与 LS 模式下, PHY 通常工作在       |        |          |     |
|        | 48MHz 下以节省功耗。                    |        |          |     |
|        | ● 1'b0: 480MHz 内部 PLL 时钟         |        |          |     |
|        | ● 1'b1: 48MHz 外部时钟               |        |          |     |
| 14     | 保留位                              | Host;  |          | RO  |
|        |                                  | Device |          |     |
| 13:10  | USB 周期时间 (USBTrdTime): USB       | Device | 4'h5     | R_W |
|        | Turnaround Time                  |        |          |     |
|        | 设置 PHY 时钟位单位的周期时间。               |        |          |     |
|        | 即指定 MAC 请求 PFC(数据 FIFO 控制器)去     |        |          |     |
|        | 数据 FIFO 中获取数据的响应时间。其值必须          |        |          |     |
|        | 如下设置:                            |        |          |     |
|        | ● 4'h5: 当 MAC 接口位 16 位的 UTMI+    |        |          |     |
|        | ● 4'h6: 当 MAC 接口位 8 位的 UTMI+     |        |          |     |
| 9      | HNP-Capable(HNPCap)              | Host,  | 1'b0     | R_W |
| 1      |                                  | Device |          |     |
|        | 软件用此控制 OTG 控制器的 HNP 功能。          | Device |          | l l |



|      | ● 1'b0: HNP 功能不可用                 |        |      |     |
|------|-----------------------------------|--------|------|-----|
|      | ● 1'b0: HNP 功能可用                  |        |      |     |
|      | <br>  注意,如果 HNP 功能被软件禁掉,那么 PHY    |        |      |     |
|      | 域相应的 OTG 信号必须固定为确定的值              |        |      |     |
|      | (?).                              |        |      |     |
| 8    | SRP-Capable(SRPCap)               | Host;  | 1'b0 | R_W |
|      | 软件用此控制 OTG 控制器的 SRP 功能。           | Device |      | _   |
|      | ● 1'b0: SRP 功能不可用                 |        |      |     |
|      | ● 1'b0: SRP 功能可用                  |        |      |     |
|      | <br>  注意,如果 SRP 功能被软件禁掉,那么 PHY    |        |      |     |
|      | 域相应的 OTG 信号必须固定为确定的值              |        |      |     |
| 7: 4 | 保留位                               | Host;  |      | RO  |
|      |                                   | Device |      |     |
| 3    | PHY 接口 (PHYIf)                    | Host;  | 可配   | RO  |
|      | 用来配置 UTMI+PHY 的接口。                | Device |      |     |
|      | • 1'b0: 8bits                     |        |      |     |
|      | • 1'b1: 16bits                    |        |      |     |
|      | 若选择 ULPI 接口,则仅能配置位 8bits。         |        |      |     |
| 2:0  | HS 超时校准(TOutCal): HS Timeout      | Host;  | 3'h0 | R_W |
|      | Calibration 单位为一个 PHY 时钟。用来修正     | Device |      |     |
|      | 因为 PHY 引起的包之间超时时间。不同的             |        |      |     |
|      | PHY 引入的延时不同。                      |        |      |     |
|      | 对于 HS 而言, USB 标准的超时值为 736 -       |        |      |     |
|      | 816 bit times;软件必须基于枚举的速度来配       |        |      |     |
|      | 置这个域。每个 PHY 时钟的 bits 时间如下解        |        |      |     |
|      | 释:                                |        |      |     |
|      | HS:                               |        |      |     |
|      | ● 一个 30MHz 的 PHY 时钟 = 16bit times |        |      |     |
|      | ● 一个 60MHz 的 PHY 时钟 = 8bit times  |        |      |     |

## 复位寄存器(GRSTCTL)

◆ 偏移地址: 010h

| 域     | 说明                          | 工作模式   | 复位值  | 访问特性 |
|-------|-----------------------------|--------|------|------|
| 31    | .AHB Master Idle(AHBIdle)   | Host;  | 1'b1 | RO   |
|       | 指示 AHB Master 状态机处于 IDLE 状态 | Device |      |      |
| 30    | DMA 请求信号(DMAReq)            | Host;  | 1'b0 | RO   |
|       | 指示现在总线上有个 DMA 请求;调试使用       | Device |      |      |
| 29:11 | 保留域                         | Host;  |      | RO   |
|       |                             | Device |      |      |
| 10:6  | TxFIFO 号(TxFNum)            | Host;  | 5'h0 | R_W  |
|       |                             | Device |      |      |



|   | 指示必须用 TxFIFO Flush 位清空的 FIFO 号。      |        |      |             |
|---|--------------------------------------|--------|------|-------------|
|   | 直到控制器清空了 TxFIFO 位,TxFNum 才可          |        |      |             |
|   | 修改。                                  |        |      |             |
|   | • 5'h0:                              |        |      |             |
|   | - host 模式下清空非周期性 TxFIFO              |        |      |             |
|   | - device 模式下清空 TxFIFO 0              |        |      |             |
|   | • 5'h1:                              |        |      |             |
|   | - host 模式下清空周期性 TxFIFO               |        |      |             |
|   | - device 模式下清空 TxFIFO 1              |        |      |             |
|   | • 5'h2:                              |        |      |             |
|   | - device 模式下清空 TxFIFO 2              |        |      |             |
|   | • 5'h3:                              |        |      |             |
|   | - device 模式下清空 TxFIFO 3              |        |      |             |
|   |                                      |        |      |             |
|   | ● 5'H10:                             |        |      |             |
|   | 清空所有的 TxFIFO(不管是 host 模式下            |        |      |             |
| _ | 还是 device 模式下)                       | 11     | 4150 | D WC C      |
| 5 | TxFIFO 清空(TxFFIsh)                   | Host;  | 1'b0 | R_WS_S<br>C |
|   | 用来选择性地清空一个或所有的 TxFIFO。但              | Device |      |             |
|   | 是有事务正在进行时不可进行此操作。                    |        |      |             |
|   | 软件必须在确认 OTG 控制器没有读或写                 |        |      |             |
|   | TxFIFO 时才可写此位。确认方式如下:                |        |      |             |
|   | 读 - NAK 有效中断能确保 OTG 控制器没             |        |      |             |
|   | 有读 FIFO;                             |        |      |             |
|   | 写 - GRSTCTL.AHBIdle 能确保 OTG 控制       |        |      |             |
|   | 器没有写 FIFO<br>清空 FIFO 的操作可以在以下情形下使用,比 |        |      |             |
|   |                                      |        |      |             |
|   | 如 FIFO 需要重新配置或在共享 FIFO 模式与           |        |      |             |
|   | 专用 FIFO 模式下转换以及禁用某个 device endpoint。 |        |      |             |
|   | y件必须等待 OTG 控制器将此位清 0 后才能             |        |      |             |
|   | 继续其他操作。这大概需要8个时钟,且是使                 |        |      |             |
|   | 用 phy_clk 与 hclk 中比较慢的那个时钟。          |        |      |             |
| 4 | RxFIFO 清空(RxFFIsh)                   | Host:  | 1'b0 | R_WS_S      |
|   | 用来清空整个 RxFIFO,同样有事务正在进行              | Device | . 50 | C C         |
|   | 时不可进行此操作。                            | 201100 |      |             |
|   |                                      | 1      |      | i l         |
|   |                                      |        |      |             |
|   | 软件必须在确认 OTG 控制器没有读或写                 |        |      |             |
|   | 软件必须在确认 OTG 控制器没有读或写 RxFIFO 时才可写此位。  |        |      |             |
|   | 软件必须在确认 OTG 控制器没有读或写                 |        |      |             |



|   | 用 phy_clk 与 hclk 中比较慢的那个时钟。                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                 |      |             |
|---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------|-------------|
| 3 | 保留位                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Host;<br>Device |      | RO          |
| 2 | Host Frame Counter Reset (FrmCntrRst) 软件通过写此位来重置 OTG 控制器内的帧数。一旦帧数被重置,下一个 OTG 控制器发出的 SOF 的帧号为 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Host            | 1'b0 | R_WS_S<br>C |
| 1 | 保留域                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Host;<br>Device |      | RO          |
| 0 | OTG 控制器软重启(CSftRst) 复位 hclk 与 phy_clock 时钟域的内容如下: ● 清空除以下列以外的所有中断以及 CSR 寄存器 - PCGCCTL.RstPdwn - PCGCCTL.GateHclk - PCGCCTL.PwrCImp - GUSBCFG.DDRSel - GUSBCFG.PHYSel - GUSBCFG.PHYIf - HCFG>FSLSPclkSel - DCFG.DevSpd - GGPIO - GPWRDN - GADPCTL ● 所有模块的状态机(除 AHB Slave 单元)都被复位至 IDLE 状态;清空所有的TxFIFO与RxFIFO ● 在平滑地完整最后一个 AHB 传输的数据相后,立即结束所有的 AHB Master 事务。立即结束所有的USB事务 ● PMU 模块(功耗管理单元)不会被复位软件在任意时刻都可软复位 OTG 控制器。这位是自清 0 的,即在所有必要的逻辑复位后控制器会清 0 此位。根据控制器当时的状态不同,这将花费数个时钟。一旦此位被清 0,软件必须等待 3 个 PHY 时钟后才能操作 PHY 域(同步延时)。软件在开始任何动作之前,必须确保 AHBIdle 位位 1。 | Host;<br>Device | 1'b0 | R_WS_S<br>C |



### 中断寄存器(GINTSTS)

偏移地址: 014h

| 域  | 说明                                  | 工作模式   | 复位值  | 访问特性   |
|----|-------------------------------------|--------|------|--------|
| 31 | 系统恢复/远程唤醒中断                         | Host;  | 1'b0 | R_SS_W |
|    | (WkUpInt):Resume/Remote Wakeup      | Device |      | С      |
|    | Detected Interrupt                  |        |      |        |
|    | 处于挂起(L2)状态时的唤醒中断。                   |        |      |        |
|    | ● Device 模式: 仅当在 USB 总线上发现          |        |      |        |
|    | Host 发起的唤醒操作时,发生此中断                 |        |      |        |
|    | ● Host 模式: 仅当在 USB 总线上发现            |        |      |        |
|    | device 发起的远程唤醒操作时,发生此中断             |        |      |        |
| 30 | 会话请求/发现新会话 中断                       | Host;  | 1'b0 | R_SS_W |
|    | ( SessRegInt ) :Session Request/New | Device | 150  | C C    |
|    | Session Detected Interrupt.         |        |      |        |
|    | ● 在 Host 模式下,当发现从 device 来的会        |        |      |        |
|    | 话请求时,置 1.                           |        |      |        |
|    | ● 在 device 模式下,当 utmisrp_bvalid 信   |        |      |        |
|    |                                     |        |      |        |
| 29 | 断开中断(DisconnInt)                    | Host   | 1'b0 | R_SS_W |
|    | 当 device 断开时,置 1.                   |        |      | С      |
| 28 | 连接器 ID 状态变化(ConIDStsChng)           | Host;  | 1'b1 | R_SS_W |
|    | 当连接器 ID 状态有变化时,置 1.                 | Device |      | С      |
| 27 | 保留位                                 | Host;  |      | RO     |
|    |                                     | Device |      |        |
| 26 | 周期性 TxFIFO 空(PTxFEmp)               | Host   | 1'b1 | RO     |
|    | 当周期性 TxFIFO 是半空或全空,且在周期性            |        |      |        |
|    | 请求队列中至少有一项请求时,此位置 1.是半              |        |      |        |
|    | 空还是全空时置1由GAHBCFG.PTxFEmpLvl         |        |      |        |
|    | 来决定。                                |        |      |        |
| 25 | Host Channels Interrupt (HChInt)    | Host   | 1'b0 | RO     |
|    | 在 host 模式下,当 OTG 控制器里某一个通道          |        |      |        |
|    | 上有一个等待处理的中断时,置1.软件必须读               |        |      |        |
|    | HAINT寄存器来确定有未处理中断的channel           |        |      |        |
|    | 号, 然后读取对应的 HCINTn 寄存器来确定发           |        |      |        |
|    | 生中断的原因。为了将这位清 0, 软件必须先              |        |      |        |
|    | 将 HCINTn 寄存器中对应状态位清 0.              |        |      |        |
| 24 | Host 端口中断(PrtInt)                   | Host   | 1'b0 | RO     |
|    | 在 Host 模式下, 若 OTG 控制器的某个端口状         |        |      |        |



|    | 大心山本儿山 图 4 4 // W/不过 UBBT 京古 图              | I      |       | <u> </u>        |
|----|---------------------------------------------|--------|-------|-----------------|
|    | 态发生变化时,置1.软件必须读HPRT寄存器                      |        |       |                 |
|    | 来确定引起这个中断的真正原因。为了将这位                        |        |       |                 |
|    | 清 0, 软件必须先将 HPRT 寄存器中对应状态                   |        |       |                 |
| 23 | 位清 0.                                       | Device | 1'b0  | R_SS_W          |
| 23 | 复位中断(ResetDet): Reset Detected<br>Interrupt | Device | 1 00  | R_SS_W  <br>  C |
|    | 在 device 模式下,处于挂起状态下的 OTG 控                 |        |       |                 |
|    | 制器发下一复位操作时,置 1.                             |        |       |                 |
|    | 仅当 OTG 控制器处于 device 模式,且工作在                 |        |       |                 |
|    | partial Power-down,或是门控挂起状态下才               |        |       |                 |
|    | 效。                                          |        |       |                 |
|    | 当 OTG 控制器工作在 Hibernation 挂起状态               |        |       |                 |
|    | 时,这位无效。                                     |        |       |                 |
| 22 | 数据获取挂起(FetSusp): Data Fetch                 | Device | 1'b0  | R_SS_W          |
|    | Suspended                                   |        |       | C               |
|    | 仅在 DMA 模式下有效。当 TxFIFO 或请求队                  |        |       |                 |
|    | 列没有空间时 OTG 会停止为 IN endpoint 取数              |        |       |                 |
|    | 据,这时置 1. 软件在 endpoint 不匹配算法中                |        |       |                 |
|    | 使用此中断。                                      |        |       |                 |
| 21 | 未完成周期性传输(incomplIP)                         | Host   | 1'b0  | R_SS_W          |
|    | Host 模式下,当有一未完成的周期性事务仍                      |        |       | С               |
|    | 等待在当前帧时间内处理时,置 1.                           | Dovice |       |                 |
|    | 未完成的实时 OUT 传输(incomplSOOUT)                 | Device |       |                 |
|    | device 模式下,若在当前帧时间内,至少有一                    |        |       |                 |
|    | 个实时 OUT endpoint 上有一个未完成的传输                 |        |       |                 |
|    | 时,置 1.同时置 EOPF 位                            |        |       |                 |
| 20 | 未完成的实时 IN 传输(incomplSOIN)                   | Device | 1'b0  | R_SS_W          |
|    | 若在当前帧时间内,至少有一个实时 IN                         |        |       | С               |
|    | endpoint 上有一个未完成的传输时,置 1.同时                 |        |       |                 |
|    | 置 EOPF 位                                    |        | 411.0 |                 |
| 19 | OUT endpoint 中断(OEPInt)                     | Device | 1'b0  | RO              |
|    | 当在 OUT endpint 上有一等待处理的中断时,                 |        |       |                 |
|    | OTG 控制器置 1.软件必须读 DAINT 寄存器从                 |        |       |                 |
|    | 而确定具体是哪个 enpoint 上有等待处理的中                   |        |       |                 |
|    | 断;然后读 DOEPINTn 寄存器从而确定引起                    |        |       |                 |
|    | 这个中断的原因。为了将这位清 0,软件必须                       |        |       |                 |
| 40 | 先将 DOEPINTn 寄存器中对应状态位清 0.                   | Davisa | 1150  | DO              |
| 18 | IN endpoint 中断(IEPInt)                      | Device | 1'b0  | RO              |
|    | 当在 IN endpint 上有一等待处理的中断时,                  |        |       |                 |
|    | OTG 控制器置 1.软件必须读 DAINT 寄存器从                 |        |       |                 |



|     |                                                               | 1      | 1    |        |
|-----|---------------------------------------------------------------|--------|------|--------|
|     | 而确定具体是哪个 enpoint 上有等待处理的中                                     |        |      |        |
|     | 断; 然后读 DOEPINTn 寄存器从而确定引起                                     |        |      |        |
|     | 这个中断的原因。为了将这位清 0, 软件必须                                        |        |      |        |
|     | 先将 DOEPINTn 寄存器中对应状态位清 0.                                     |        |      |        |
| 17  | 保留位                                                           | Host;  |      | RO     |
|     |                                                               | Device |      |        |
| 16  | 保留位                                                           | Host;  |      | RO     |
|     |                                                               | Device |      |        |
| 15  | 周期性帧结束(EOPF)                                                  | Device | 1'b0 | R_SS_W |
|     | 当在当前帧时间内,DCFG.PerFrInt 指示的阈                                   |        |      | C      |
|     | 值达到时,置 1.                                                     |        |      |        |
| 14  | 实时的 OUT 包结束(ISOOutDrop)                                       | Device | 1'b0 | R_SS_W |
|     | 若 RxFIFO 没有足够的空间来为实时 OUT                                      |        |      | С      |
|     | endpoint 存放一 maximum package size                             |        |      |        |
|     | packet,则 OTG 控制器将无法将一个实时                                      |        |      |        |
|     | OUT 包写入到 RxFIFO。当发生这种情况时,                                     |        |      |        |
|     | 置此位为 1.                                                       |        |      |        |
| 13  | 枚举结束(EnumDone): Enumeration                                   | Device | 1'b0 | R_SS_W |
|     | 当速度枚举结束是,置1.软件读取 DSTS 寄存                                      |        |      | С      |
|     | 器获取枚举的确切速度                                                    |        |      |        |
| 12  | USB 复位(USBRst)                                                | Device | 1'b0 | R_SS_W |
|     | 当 USB 总线上有一复位操作时,置 1                                          |        |      | С      |
| 11  | USB 挂起(USBSusp)                                               | Device | 1'b0 | R_SS_W |
|     | 当OTG控制器检测到USB总线上有一挂起操                                         |        |      | С      |
|     | 作时,置1.若在一段较长的时间内                                              |        |      |        |
|     | utmi_linestate 信号线上没有活动,那么 OTG                                |        |      |        |
|     | 控制器将进去挂起状态                                                    |        |      |        |
| 10  | Early Suspend(ErlySusp)                                       | Device | 1'b0 | R_SS_W |
|     | 当检测到 USB 已进入空闲状态超过 3ms 时,                                     |        |      | С      |
|     | OTG 控制器置此位为 1.                                                |        |      |        |
| 9:8 | 保留位                                                           | Host;  |      | RO     |
|     |                                                               | Device |      |        |
| 7   | 全局 OUT NAK 有效(GOUTNakEff)                                     | Device | 1'b0 | RO     |
|     | 软件置 DCTL.SGOUTNak 位后其开始有效                                     |        |      |        |
|     | 时,置 1.通过清 0 DCTL.SGOUTNak 位达到                                 |        |      |        |
|     | 清 0 此位的效果                                                     |        |      |        |
|     |                                                               |        |      |        |
| 6   | 全局 IN 非周期性 NAK 有效(GINNakFff)                                  | Device | 1'b0 | RO     |
| 6   | 全局 IN 非周期性 NAK 有效(GINNakEff) 软件置 DCTL SGNPInNak 位后其开始有效       | Device | 1'b0 | RO     |
| 6   | 全局 IN 非周期性 NAK 有效(GINNakEff) 软件置 DCTL.SGNPInNak 位后其开始有效时,置 1. | Device | 1'b0 | RO     |



|   | 通过清 0 DCTL. SGNPInNak 位达到清 0 此         |         |      |        |
|---|----------------------------------------|---------|------|--------|
|   | 位的效果                                   |         |      |        |
| 5 | 保留位                                    | Host;   |      | RO     |
|   | NH E                                   | Device  |      |        |
| 4 | RxFIFO 非空(RxFLvI)                      | Host;   | 1'b0 | RO     |
|   | 当 RxFIFO 中至少有一个包时,置 1.                 | Device1 |      |        |
| 3 | 帧开始(Sof)                               | Host;   | 1'b0 | R_SS_W |
|   | Host 模式下,当 SOF 在 USB 总线上传输时,           | Device  |      | С      |
|   | OTG 控制器将此位置 1.软件写 1 将此位清 0.            |         |      |        |
|   | Device 模式下,当 OTG 控制器收到 SOF 标           |         |      |        |
|   | 志(token)时,置 1.软件可通过读 Deivce            |         |      |        |
|   | status 寄存器来获取当前帧的帧号。                   |         |      |        |
| 2 | OTO HINE (OTOLA)                       | Host;   | 1'b0 | RO     |
| 2 | OTG 中断(OTGInt) 置 1 指示发生了 OTG 协议事件。软件可读 | Device  | 1 00 | RO     |
|   | GOTGINT 寄存器来确定发生中断的原因。为                | Device  |      |        |
|   | 了将这位清 0,软件必须清空 GOTGINT 寄存              |         |      |        |
|   | 器相应的状态位。                               |         |      |        |
| 1 | 模式不匹配中断(ModeMis)                       | Host:   | 1'b0 | R SS W |
|   | 当软件试图进行一下操作时,置 1.                      | Device  | 1 50 | C C    |
|   |                                        | 201.00  |      |        |
|   | 问 host 模式下的寄存器。                        |         |      |        |
|   | ● 当 OTG 工作在 Host 模式下时, 试图访问            |         |      |        |
|   | device 模式下的寄存器。                        |         |      |        |
| 0 | 当前工作模式(CurMod)                         | Host;   | 1'b0 | RO     |
|   | 指示当前 OTG 控制器的工作模式                      | Device  |      |        |
|   | ● 1'b0: device 模式                      |         |      |        |
|   | ● 1'b1: host 模式                        |         |      |        |

#### 中断屏蔽寄存器(GINTMSK)

偏移地址: 018h

这个寄存器与 GINTSTS 寄存器共同使用。当某个中断被屏蔽,那么这个中断不会被软件看到。当然, GINTSTS 对应的位仍旧置位。

| 域  | 说明                                                                             | 工作模式            | 复位值  | 访问特性    |
|----|--------------------------------------------------------------------------------|-----------------|------|---------|
| 31 | 系统恢复/远程唤醒中断屏蔽位<br>(WkUpIntMsk):Resume/Remote Wakeup<br>Detected Interrupt Mask | Host;<br>Device | 1'b0 | R_SS_WC |



| 30    | 会话请求/发现新会话 中断屏蔽位<br>(SessReqIntMsk):Session Request/New<br>Session Detected Interrupt Mask. | Host;<br>Device | 1'b0 | R_SS_WC |
|-------|---------------------------------------------------------------------------------------------|-----------------|------|---------|
| 29    | 断开中断屏蔽位(DisconnIntMsk)                                                                      | Host            | 1'b0 | R_SS_WC |
| 28    | 连接器 ID 状态变化屏蔽位<br>(ConIDStsChngMsk)                                                         | Host;<br>Device | 1'b1 | R_SS_WC |
| 27    | 保留位                                                                                         | Host;<br>Device |      | RO      |
| 26    | 周期性 TxFIFO 空屏蔽位(PTxFEmpMsk)                                                                 | Host            | 1'b1 | RO      |
| 25    | Host Channels Interrupt 屏蔽位(HChIntMsk)                                                      | Host            | 1'b0 | RO      |
| 24    | Host 端口中断屏蔽位(PrtIntMsk)                                                                     | Host            | 1'b0 | RO      |
| 23    | 复位中断屏蔽位(ResetDetMsk): Reset<br>Detected Interrupt Mask                                      | Device          | 1'b0 | R_SS_WC |
| 22    | 数据获取挂起屏蔽位(FetSuspMsk): Data<br>Fetch Suspended Mask                                         | Device          | 1'b0 | R_SS_WC |
| 21    | 未完成周期性传输屏蔽位(incomplIPMsk)<br>未 完 成 的 实 时 OUT 传 输 屏 蔽 位                                      | Host            | 1'b0 | R_SS_WC |
|       | (incomplSOOUTMsk)<br>未完成的实时 IN 传输屏蔽位                                                        | Device          |      |         |
| 20    | (incomplSOINMsk)                                                                            | Device          | 1'b0 | R_SS_WC |
| 19    | OUT endpoint 中断屏蔽位(OEPIntMsk)                                                               | Device          | 1'b0 | RO      |
| 18    | IN endpoint 中断屏蔽位(IEPIntMsk)                                                                | Device          | 1'b0 | RO      |
| 17:16 | 保留位                                                                                         | Host;<br>Device |      | RO      |
| 15    | 周期性帧结束屏蔽位(EOPFMsk)                                                                          | Device          | 1'b0 | R_SS_WC |
| 14    | 实时的 OUT 包结束屏蔽位(ISOOutDropMsk)                                                               | Device          | 1'b0 | R_SS_WC |
| 13    | 枚举结束屏蔽位(EnumDoneMsk):<br>Enumeration Mask                                                   | Device          | 1'b0 | R_SS_WC |
| 12    | USB 复位屏蔽位(USBRstMsk)                                                                        | Device          | 1'b0 | R_SS_WC |
| 11    | USB 挂起屏蔽位(USBSuspMsk)                                                                       | Device          | 1'b0 | R_SS_WC |
| 10    | Early Suspend 屏蔽位(ErlySuspMsk)                                                              | Device          | 1'b0 | R_SS_WC |
| 9:8   | 保留位                                                                                         | Host;<br>Device |      | RO      |
| 7     | 全 局 OUT NAK 有 效 屏 蔽 位<br>(GOUTNakEffMsk)                                                    | Device          | 1'b0 | RO      |



| 6 | 全局 IN 非周期性 NAK 有效屏蔽位 (GINNakEffMsk)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Device  | 1'b0 | RO        |
|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|------|-----------|
| 5 | 保留位                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Host;   |      | RO        |
|   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Device  |      | 10        |
| 4 | RxFIFO 非空屏蔽位(RxFLvlMsk)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Host;   | 1'b0 | RO        |
| - | TATILITY OF THE TATION OF THE | Device1 | 1 00 |           |
| 3 | 帧开始屏蔽位(SofMsk)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Host;   | 1'b0 | R_SS_WC   |
|   | 1971 ALITH BX EX (CONVION)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Device  | 1 00 | 11_00_110 |
| 2 | │<br>│OTG 中断屏蔽位(OTGIntMsk)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Host;   | 1'b0 | RO        |
|   | oro parminony                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Device  | 1 50 | 110       |
| 1 | <br>  模式不匹配中断屏蔽位(ModeMisMsk)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Host;   | 1'b0 | R SS WC   |
| ' | · 快入 「 E II                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Device  | 1 50 | 11_00_110 |
| 0 | 当前工作模式(CurModMsk)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Host;   | 1'b0 | RO        |
|   | 当时工下疾入(Cullinoulvisk)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Device  | 1 00 | NO        |

#### 接收状态调试寄存器/状态 read 以及 pop 寄存器(GRXSTSR/GRXSTSP)

读偏移地址: 01Ch Pop 偏移地址: 020h

对接收状态调试寄存器的读操作返回的是 RxFIFO 的第一项内容。对状态 read 以及 pop 寄存器的读操作额外还会将 RxFIFO 的第一项内容 pop 出来。

接收状态寄存器的内容在 host 模式与 device 模式下有着不同的解释。若 RxFIFO 空, 那么 OTG 控制器将忽略对这个寄存器的读以及 pop 操作,且返回 32'h0000\_0000。当 GINTSTS. RxFLv1 位为 1 时,软件仅能 pop the receive Stastus FIFO.

NOTE: OTG 在不同的工作模式下,此寄存器的各个域有着不同的解释 Host 模式

| 域     | 说明                            | 复位值   | 访问特性 |
|-------|-------------------------------|-------|------|
| 31:21 | 保留域                           | 1     | RO   |
| 20:17 | 包状态(PktSts)                   | 4'b0  | RO   |
|       | 指示接收包的状态:                     |       |      |
|       | ● 4'b0010: 接收到 IN 数据包         |       |      |
|       | ● 4'b0011: IN 传输结束(触发中断)      |       |      |
|       | ● 4'b0101: 数据 toggle 错误(触发中断) |       |      |
|       | ● 4'b0111: 通道 halt(触发中断)      |       |      |
|       | ● 其他:保留                       |       |      |
| 16:15 | 数据 PID(DPID)                  | 2'b0  | RO   |
|       | 指示接收包的数据 PID                  |       |      |
|       | • 2'b00:DATA0                 |       |      |
|       | • 2'b10:DATA1                 |       |      |
|       | • 2'b01:DATA2                 |       |      |
|       | • 2'b11:MDATA                 |       |      |
| 14:4  | 字节数(BCnt)                     | 11'h0 | RO   |



|    |    | 指示接收到的 IN 数据包的字节数 |      |    |
|----|----|-------------------|------|----|
| 3: | :0 | 通道号(ChNum)        | 4'h0 | RO |
|    |    | 指示当前接收到的数据包所属的通道号 |      |    |

#### Device 模式

| 域     | 说明                             | 复位值   | 访问特性 |
|-------|--------------------------------|-------|------|
| 31:25 | 保留域                            |       | RO   |
| 24:21 | 帧号 (FN)                        | 4'h0  | RO   |
|       | 接收包所在帧的帧号最低四位。                 |       |      |
|       | 仅当支持实时 OUT 端点时,此域有效            |       |      |
| 20:17 | 包状态(PktSts)                    | 4'b0  | RO   |
|       | 指示接收包的状态:                      |       |      |
|       | ● 4'b0001: 全局 OUT NAK (触发中断)   |       |      |
|       | ● 4'b0010:接收到 OUT 数据包          |       |      |
|       | ● 4'b0011: OUT 传输结束(触发中断)      |       |      |
|       | ● 4'b0100: SETUP 事务结束(触发中断)    |       |      |
|       | ● 4'b0110:接收到 SETUP 数据包        |       |      |
|       | ● 其他:保留                        |       |      |
| 16:15 | 数据 PID(DPID)                   | 2'b0  | RO   |
|       | 指示接收到的 OUT 包的数据 PID            |       |      |
|       | • 2'b00:DATA0                  |       |      |
|       | • 2'b10:DATA1                  |       |      |
|       | • 2'b01:DATA2                  |       |      |
| 14:4  | • 2'b11:MDATA                  | 11'h0 | RO   |
| 14.4  | 字节数(BCnt)<br>华元接收到的INI 粉握包的字节粉 | 11110 | INO  |
| 2.0   | 指示接收到的 IN 数据包的字节数              | 4'h0  | RO   |
| 3:0   | 端点号(EPNum)                     | 4 NU  | KU   |
|       | 指示当前接收到的数据包所属的端点号              |       |      |

#### RxFIFO 容量寄存器 (GRXFSIZ)

读偏移地址: 024h

软件用此寄存器分配分配给 RxFIFO 的 RAM 大小。

| 域     | 说明                | 复位值 | 访问特性 |
|-------|-------------------|-----|------|
| 31:16 | 保留域               |     | RO   |
| 15:0  | RxFIFO 深度(RxFDep) | 533 | R_W  |
|       | 以 32-bits 的字为单位。  |     |      |
|       | ● 最小值为 16         |     |      |
|       | ● 最大值为 32768      |     |      |

#### 非周期性 TxFIFO 容量寄存器 (GNPTXFSIZ)



读偏移地址: 028h

软件用此寄存器分配分配给非周期性 TxFIFO 的 RAM 大小以及开始地址。 Note: OTG 在 host 工作模式下,还是在 device 工作模式下,此寄存器有不

同的解释。

#### Host 模式下

| 域     | 说明                          | 复位值 | 访问特性 |
|-------|-----------------------------|-----|------|
| 31:16 | 非周期性 TxFIFO 深度(NPTxDep)     | 256 | R_W  |
|       | 以 32-bits 的字为单位。            |     |      |
|       | ● 最小值为 16                   |     |      |
|       | ● 最大值为 32768                |     |      |
| 15:0  | 非周期性 TxRAM 开始地址(NPTxStAddr) | 533 | R_W  |

#### Device 模式下

| 域     | 说明                                | 复位值 | 访问特性 |
|-------|-----------------------------------|-----|------|
| 31:16 | IN 端点 TxFIFO 0 的深度。仅当 Device 模式下, | 32  | R_W  |
|       | 且 OTG_EN_DED_TX_FIFO = 1 时有效。     |     |      |
|       | ● 最小值为 16                         |     |      |
|       | ● 最大值为 32768                      |     |      |
| 15:0  | IN 端点 FIFO0 TxRAM 开始地址            | 533 | R_W  |

#### Synopsys ID 寄存器 (GSNPSID)

读偏移地址: 040h

包含 OTG 控制器的版本号

| 域     | 说明                       | 复位值      | 访问特性 |
|-------|--------------------------|----------|------|
| 31: 0 | Synopsys ID (SynopsysID) | 32'h4F54 | RO   |
|       | OTG 控制器的版本号              |          |      |

#### User HW Config1 寄存器

读偏移地址: 044h

用户硬件配置寄存器 2, 指定 endpont 的方向。

| 域      | 说明                         | 复位值   | 访问特性 |
|--------|----------------------------|-------|------|
| 31: 14 | 保留域                        | 18'b0 | RO   |
| 13: 0  | Bits[13:12]: endpoint 6 方向 | 14'b0 | RO   |
|        | Bits[11:10]: endpoint 5 方向 |       |      |
|        | Bits[9:8]: endpoint 4 方向   |       |      |
|        | Bits[7:6]: endpoint 3 方向   |       |      |
|        | Bits[5:4]: endpoint 2 方向   |       |      |
|        | Bits[3:2]: endpoint 1 方向   |       |      |
|        | Bits[1:0]: endpoint 0 方向   |       |      |
|        | ● 2'b00: 双向 endpoint       |       |      |
|        | 2'b01: IN endpoint         |       |      |



| • | • | 2'b10: OUT endpoint |  |
|---|---|---------------------|--|
|   | • | 2'b11: 保留           |  |

## User HW Config2 寄存器

读偏移地址: 048h 用户硬件配置寄存器 2

| 用户硬件配置寄存器 2 |                                                  |       |      |
|-------------|--------------------------------------------------|-------|------|
| 域           | 说明                                               | 复位值   | 访问特性 |
| 31: 26      | 保留域                                              | 6'b0  | RO   |
| 25: 24      | Host 模式下,周期性请求队列的深度                              | 2'b10 | RO   |
|             | • 2'b00: 2                                       |       |      |
|             | • 2'b01: 4                                       |       |      |
|             | • 2'b10: 8                                       |       |      |
| 23: 22      | ● 2'b11: 16<br>非周期性请求队列的深度                       | 2'b10 | RO   |
| 23. 22      | <ul><li>中间新任何水顶列的休度</li><li>● 2'b00: 2</li></ul> | 2010  | KO   |
|             | • 2'b01: 4                                       |       |      |
|             | • 2'b10: 8                                       |       |      |
|             | • 2'b11: 16                                      |       |      |
| 21          | 保留域                                              |       | RO   |
| 20          | 使能多个处理器中断                                        | 1'b0  | RO   |
|             | ● 1'b0: 否                                        |       |      |
|             | ● 1'b1: 是                                        |       |      |
| 19          | 使能动态 FIFO 大小                                     | 1'b1  | RO   |
|             | ● 1'b0: 否                                        |       |      |
|             | ● 1'b1: 是                                        |       |      |
| 18          | 使能周期性 OUT channel                                | 1'b1  | RO   |
|             | ● 1'b0: 否                                        |       |      |
|             | 1'b1: 是                                          |       |      |
| 17:14       | Host 模式下的 Channel 数                              | 4'd12 | RO   |
| 13:10       | Device 模式下的端点数,除 endpoint 0 外                    | 4'd6  | RO   |
| 9: 8        | 全速 PHY 接口类型                                      | 2'b00 | RO   |
|             | ● 2'b00: 无                                       |       |      |
|             | ● 2'b01: FS 有专用 pin                              |       |      |
|             | ● 2'b10: 与 UTMI+共用                               |       |      |
|             | ● 2'b11: 与 ULPI 共用                               |       |      |
| 7:6         | HS PHY 接口类型                                      | 2'b01 | RO   |
|             | ● 2'b00: 无                                       |       |      |
|             | • 2'b01: UTMI+                                   |       |      |
|             | • 2'b10: ULPI                                    |       |      |
|             | ● 2'b11: UTMI+与ULPI                              |       |      |
| 5           | 点对点                                              | 1'b1  | RO   |



|      | ● 1'b0: 否                         |        |    |
|------|-----------------------------------|--------|----|
|      | ● 1'b1: 是                         |        |    |
| 4: 3 | 结构                                | 2'b10  | RO |
|      | <ul><li>● 2'b00: 仅能做从设备</li></ul> |        |    |
|      | ● 2'b01: 外部 DMA                   |        |    |
|      | ● 2'b10: 内嵌 DMA                   |        |    |
|      | ● 2'b11: 保留                       |        |    |
| 2:0  | 操作模式                              | 3'b000 | RO |
|      | ● 3'b000: 支持 HNP 与 SRP 的 OTG      |        |    |
|      | (host 与 device)                   |        |    |
|      | ● 3'b001: 仅支持 SRP 的 OTG (host     |        |    |
|      | 与 device)                         |        |    |
|      | ● 3'b010: 不支持 HNP 与 SRP 的 OTG     |        |    |
|      | (host 与 device)                   |        |    |
|      | ● 3'b011:支持 SRP 的 device          |        |    |
|      | ● 3'b100: 非 OTG 的 device          |        |    |
|      | ● 3'b101: 支持 SRP 的 device         |        |    |
|      | ● 3'b110: 非 OTG 的 host            |        |    |
|      | ● 其他:保留                           |        |    |

## User HW Config3 寄存器

读偏移地址: 04Ch 用户硬件配置寄存器 3

| 域      | 说明                 | 复位值      | 访问特性 |
|--------|--------------------|----------|------|
| 31: 16 | DFIFO 的深度          | 16'd3072 | RO   |
|        | ● 最小值: 32          |          |      |
|        | ● 最大值: 32768       |          |      |
| 15     | OTG_ENABLE_LPM     | 1'b0     | RO   |
|        | 指定 OTG 是否支持 LPM 模式 |          |      |
|        | ● 1'b0: 否          |          |      |
|        | ● 1'b1: 是          |          |      |
| 14     | OTG_BC_SUPPOT      | 1'b0     | RO   |
|        | 指定是否支持 USB 充电功能    |          |      |
|        | ● 1'b0: 否          |          |      |
|        | ● 1'b1: 是          |          |      |
| 13     | OTG_ENABLE_HSIC    | 1'b0     | RO   |
|        | 指定是否支持 HSIC        |          |      |
|        | ● 1'b0: 否          |          |      |
|        | ● 1'b1: 是          |          |      |
| 12     | OTG_ADP_SUPPORT    | 1'b0     | RO   |



|      | 指定是否支持 ADP                                            |         |    |
|------|-------------------------------------------------------|---------|----|
|      | ● 1'b0: 否                                             |         |    |
|      | ● 1'b1: 是                                             |         |    |
| 11   | OTG_SYNC_RESET_TYPE                                   | 1'b0    | RO |
|      |                                                       |         |    |
|      | ● 1'b0: 否                                             |         |    |
|      | ● 1'b1: 是                                             |         |    |
| 10   | 去掉一些非必须的特性(OptFeature)                                | 1'b1    | RO |
|      | ● 1'b0: 否                                             |         |    |
|      | ● 1'b1: 是                                             |         |    |
| 9    | 是否支持 vendor control 接口(VndctlSupt)                    | 1'b0    | RO |
|      | 此接口用于访问 PHY 的内部寄存器。                                   |         |    |
|      | ● 1'b0: 否                                             |         |    |
|      | ● 1'b1: 是                                             |         |    |
| 8    | 是否支持 I2C 接口(I2CIntSel)                                | 1'b0    | RO |
|      | ● 1'b0: 否                                             |         |    |
|      | ● 1'b1: 是                                             |         |    |
| 7    | OTG 功能使能(OtgEn)                                       | 1'b1    | RO |
|      | 指定是否使能 OTG 功能                                         |         |    |
|      | ● 1'b0: 否                                             |         |    |
|      | ● 1'b1: 是                                             |         |    |
| 6: 4 | Packet Counters 的宽度(PktSizeWidth)                     | 3'b110  | RO |
|      | 表示在一次传输中 USB 控制器                                      |         |    |
|      | send/receive 的 Packet 的最大个数.                          |         |    |
|      | • 3'b000: 4bits                                       |         |    |
|      | • 3'b001: 5bits                                       |         |    |
|      | 3'b010: 6bits                                         |         |    |
|      | <ul><li>3'b011: 7bits</li><li>3'b100: 8bits</li></ul> |         |    |
|      | • 3'b101: 9bits                                       |         |    |
|      | • 3'b110: 10bits                                      |         |    |
|      | ● 其他:保留                                               |         |    |
| 3: 0 | Transfer Size Counters 的 宽 度                          | 4'b1000 | RO |
|      | (XferSizeWidth),表示最大传输数据大小                            |         |    |
|      | • 4'b0000: 11bits                                     |         |    |
|      | • 4'b0001: 12bits                                     |         |    |
|      |                                                       |         |    |
|      | • 4'b1000: 19bits                                     |         |    |
|      | ● 其他: 保留                                              |         |    |

# User HW Config4 寄存器



读偏移地址: 050h 用户硬件配置寄存器 4

| 域     | '硬件配置寄存器 4                          | 复位值         | 访问特性 |
|-------|-------------------------------------|-------------|------|
| 31    | 保留                                  | <b>文</b> 压压 | RO   |
| 30    | 是否支持 Scatter/Gather DMA             | 1'b1        | RO   |
|       | ● 1'b0: 否                           |             |      |
|       | ● 1'b1: 是                           |             |      |
| 29:26 | Device 模式下, IN endpoint 的个数,包括      | 4           | RO   |
|       | endpoint0 (INEps)                   |             |      |
|       | 0: 1 个 IN endpoint                  |             |      |
|       | <ul><li>1:2 个 IN endpoint</li></ul> |             |      |
|       | • ···                               |             |      |
|       | ● 16: 16 个 IN endpoint              |             |      |
| 25    | 对 Device In endpoint 使能专用的 TxFIFO   | 1'b1        | RO   |
|       | ● 1'b0: 否                           |             |      |
|       | ● 1'b1: 是                           |             |      |
| 24    | 是否加一个对 session_end 信号的去抖逻           | 1'b1        | RO   |
|       | 辑                                   |             |      |
|       | ● 1'b0: 否                           |             |      |
|       | ● 1'b1: 是                           |             |      |
| 23    | 是否加一个对 b_valid 信号的去抖逻辑              | 1'b1        | RO   |
|       | ● 1'b0: 否                           |             |      |
|       | ● 1'b1: 是                           |             |      |
| 22    | 是否加一个对 a_valid 信号的去抖逻辑              | 1'b1        | RO   |
|       | ● 1'b0: 否                           |             |      |
|       | ● 1'b1: 是                           |             |      |
| 21    | 是否加一个对 vbus_valid 信号的去抖逻辑           | 1'b1        | RO   |
|       | ● 1'b0: 否                           |             |      |
|       | ● 1'b1: 是                           |             |      |
| 20    | 是否加一个对 iddig_valid 信号的去抖逻辑          | 1'b1        | RO   |
|       | ● 1'b0: 否                           |             |      |
|       | ● 1'b1: 是                           |             |      |
| 19:16 | 除去 endpointO, device 模式下控制          | 4'b0        | RO   |
|       | ednpoint 的个数                        |             |      |
| 15:14 | UTMI+ PHY 数据宽度                      | 2'b10       | RO   |
|       | • 2'b00: 8bits                      |             |      |
|       | • 2'b01: 16bits                     |             |      |
|       | ● 2'b10: 8/16 bits 软件可选             |             |      |
|       | ● 2'b11: 保留                         |             |      |
| 13:7  | 保留域                                 |             | RO   |



| 6   | 使能 Hibernation | 1'b0 | RO |
|-----|----------------|------|----|
|     | ● 1'b0 :否      |      |    |
|     | ● 1'b1: 是      |      |    |
| 5   | AHB频率是否最小不能低于  | 1'b0 | RO |
|     | 60MHA(AhbFreq) |      |    |
|     | ● 1'b0 :否      |      |    |
|     | ● 1'b1: 是      |      |    |
| 4   | 是否使能降低部分功耗     | 1'b1 | RO |
|     | ● 1'b0 :否      |      |    |
|     | ● 1'b1: 是      |      |    |
| 3:0 | 保留域            |      | RO |

#### DFIFO 软件配置寄存器(GDFIFOCFG)

读偏移地址: 05Ch

| 域     | 说明                | 工作模式   | 复位值             | 访问特性 |
|-------|-------------------|--------|-----------------|------|
| 31:16 | EPInfoBaseAddr    | Host;  | EPINFO_BASEADDR | R_W  |
|       | Endpoint 控制器的起始地址 | Device |                 |      |
| 15:0  | GDFIFOCfg         | Host;  | 3072            | R_W  |
|       | 动态配置 DFIFO 的大小    | Device |                 |      |

#### Host 周期性 TxFIFO 容量寄存器(HPTXFSIZ)

读偏移地址: 0100h

| 域     | 说明                                                                          | 复位值 | 访问特性 |
|-------|-----------------------------------------------------------------------------|-----|------|
| 31:16 | PTxFSize<br>周期性 TxFIFO 深度,以 32-bits 的字位单<br>位。<br>● 最小值: 16<br>● 最大值: 32768 | 512 | R_W  |
| 15:0  | PTxFStAddr<br>Host 模式下周期性 TxFIFO 的起始地址                                      | 789 | R_W  |

## Device 模式下 IN 端点 TxFIFO1 容量寄存器(DIEPTXF1)

读偏移地址: 0104h

| 域 | 说明 | 复位值 | 访问特性 |  |
|---|----|-----|------|--|
|   |    |     |      |  |



| 31:16 | INEPnTxFDep                    | 256 | R_W |
|-------|--------------------------------|-----|-----|
|       | IN 端点 TxFIFO1 深度,以 32-bits 的字位 |     |     |
|       | 单位。                            |     |     |
|       | ● 最小值: 16                      |     |     |
|       | ● 最大值: 32768                   |     |     |
| 15:0  | INEPnTxFStAddr                 | 565 | R_W |
|       | IN 端点 FIFO 1 开始地址              |     |     |

#### Device 模式下 IN 端点 TxFIFO2 容量寄存器(DIEPTXF2)

读偏移地址: 0108h

| 域     | 说明                             | 复位值 | 访问特性 |
|-------|--------------------------------|-----|------|
| 31:16 | INEPnTxFDep                    | 256 | R_W  |
|       | IN 端点 TxFIFO2 深度,以 32-bits 的字位 |     |      |
|       | 单位。                            |     |      |
|       | ● 最小值: 16                      |     |      |
|       | ● 最大值: 32768                   |     |      |
| 15:0  | INEPnTxFStAddr                 | 821 | R_W  |
|       | IN 端点 FIFO 2 开始地址              |     |      |

#### Device 模式下 IN 端点 TxFIFO3 容量寄存器(DIEPTXF3)

读偏移地址: 010Ch

| 域     | 说明                              | 复位值  | 访问特性 |
|-------|---------------------------------|------|------|
| 31:16 | INEPnTxFDep                     | 512  | R_W  |
|       | IN 端点 TxFIFO3 深度,以 32-bits 的字位单 |      |      |
|       | 位。                              |      |      |
|       | ● 最小值: 16                       |      |      |
|       | ● 最大值: 32768                    |      |      |
| 15:0  | INEPnTxFStAddr                  | 1077 | R_W  |
|       | IN 端点 FIFO 3 开始地址               |      |      |

#### 13.3.3 Host 模式寄存器

这组寄存器仅在 Host 模式下有效; 在 Device 模式下不可访问这组寄存器。

### Host 模式配置寄存器(HCFG)

偏移地址: 400h

| 域     | 说明  | 复位值 | 访问特性 |
|-------|-----|-----|------|
| 31:28 | 保留域 |     | RO   |



| 27    | ModeChTimEn                                    | 1'b0  | R_W |
|-------|------------------------------------------------|-------|-----|
|       | 是否使能模式转换准备计时器.                                 |       |     |
|       | 用来决定是否使能 host 控制器在 Resume 状态结束时,等待             |       |     |
|       | 200PHY 时钟以改变对 PHY 的 opmode 信号从 2'b10 到 00      |       |     |
|       | ● 1'b0: 否                                      |       |     |
|       | ● 1'b1: 是                                      |       |     |
| 26    | PerSchedEna                                    | 1'b0  | R_W |
|       | 是否使能周期调度.                                      |       |     |
|       | ● 1'b0: 否                                      |       |     |
|       | ● 1'b1: 是                                      |       |     |
| 25:24 | FrListEn                                       | 2'b00 | R/W |
|       | Frame list 项数                                  |       |     |
|       | • 2'b00: 8                                     |       |     |
|       | • 2'b01: 16                                    |       |     |
|       | • 2'b00: 32                                    |       |     |
|       | • 2'b00: 64                                    |       |     |
| 23    | DescDMA                                        | 1'b0  | RO  |
|       | Host 模式下,使能 Scatter/gather DMA                 |       |     |
|       | 注意,在复位之后,这位仅能背修改一次。以下配置是可用                     |       |     |
|       | 的:                                             |       |     |
|       | • GAHBCFG.DMAEn = 0, HCFG.DescDMA = 0 => slave |       |     |
|       | 模式;                                            |       |     |
|       | ● GAHBCFG.DMAEn = 0, HCFG.DescDMA = 1 => 非法    |       |     |
|       | 配置;                                            |       |     |
|       | • GAHBCFG.DMAEn = 1, HCFG.DescDMA = 0 =>       |       |     |
|       | Buffered DMA 模式;                               |       |     |
|       | • GAHBCFG.DMAEn = 0, HCFG.DescDMA = 1 =>       |       |     |
|       | Scatter/Gather 模式;                             |       |     |
| 15:0  | 保留域                                            |       | RO  |

# Host 帧间隔寄存器(HFIR)

偏移地址: 404h

| 域     | 说明                            | 复位值       | 访问特性 |
|-------|-------------------------------|-----------|------|
| 31:17 | 保留域                           |           | RO   |
| 16    | Reload 控制                     | 1'b0      | R_W  |
|       | 是否允许动态重新载入 HFIR 寄存器。          |           |      |
|       | ● 1'b0: 否                     |           |      |
|       | ● 1'b1: 是                     |           |      |
| 15:0  | 帧间隔(FrInt)                    | 16'd60000 | R_W  |
|       | 软件用这个值来制定两个连续 micro-SOFs 之间的间 |           |      |



| 隔。以 PHY 时钟位单位。仅当 HPRT.PrtEnaPort 置 |  |
|------------------------------------|--|
| 1 后才能更改此位。在最初配置后,不能再更改。            |  |
| 125us * (PHY 时钟频率)                 |  |

### Host 帧号/剩余帧时间寄存器 (HFNUM)

读偏移地址: 408h

| 域     | 说明                               | 复位值      | 访问特性 |
|-------|----------------------------------|----------|------|
| 31:16 | 剩余帧时间                            | 16'h0    | RO   |
|       | 指示当前 micorFrame 的剩余时间,以 PHY 时钟为  |          |      |
|       | 单位。当为 0 时,重新载入 HFIR.FrInt 的值,并在  |          |      |
|       | USB 总线上发送一个新的 SOF                |          |      |
| 15:0  | 帧号(FrNum)                        | 16'h3FFF | RO   |
|       | 当一个新的 SOF 传输时,此域加 1,当达到 16'h3FFF |          |      |
|       | 时复位为 0.                          |          |      |

## Host 周期性 TxFIFO/Queue 状态寄存器(HPTXSTS)

偏移地址: 410h

| , , , | 多地址: 410h                          |      | 3 3 3 4 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 |
|-------|------------------------------------|------|-----------------------------------------|
| 域     | 说明                                 | 复位值  | 访问特性                                    |
| 31:24 | PTxQTop                            | 8'h0 | RO                                      |
|       | 周期性 TxFIFO 请求队列的第一项(TOP)用作调试。      |      |                                         |
|       | ● Bits[31]: 奇偶帧                    |      |                                         |
|       | - 1'b0: 在偶帧发送                      |      |                                         |
|       | - 1'b1: 在奇帧发送                      |      |                                         |
|       | ● Bits[30:27]: channel 号           |      |                                         |
|       | ● Bits[26:25]: 类型                  |      |                                         |
|       | - 2'b00: IN/OUT                    |      |                                         |
|       | - 2'b01:0 长度包                      |      |                                         |
|       | - 2'b10:CSPLIT                     |      |                                         |
|       | - 2'b11:无效 channel 命令              |      |                                         |
|       | ● Bits[24]: 终止(对选定的 channel 来讲为最后一 |      |                                         |
|       | 项)                                 |      |                                         |
| 23:16 | PTxQSpcAvali                       | 8    | RO                                      |
|       | 周期性 Tx 请求队列可用项数.                   |      |                                         |
|       | 指示周期性请求队列中的空项数,请求队列中包含 IN          |      |                                         |
|       | 与 OUT                              |      |                                         |
|       | ● 8'h0: 队列满                        |      |                                         |
|       | ● 8'h1: 1 个空项                      |      |                                         |
|       | ● 8'h2: 2 个空项                      |      |                                         |
|       | 0000                               |      |                                         |



|      | ● 8'h8: 8 个空项      |     |    |
|------|--------------------|-----|----|
|      | ● 其他: 保留           |     |    |
| 15:0 | PTxFSpcAvail       | 512 | RO |
|      | 周期性 TxFIFO 可用项数。   |     |    |
|      | 以 32-bits 的字为单位。   |     |    |
|      | ● 16'h0: FIFO 满    |     |    |
|      | ● 16'h1: 1 个空项     |     |    |
|      | •                  |     |    |
|      | ● 16'h200: 512 个空项 |     |    |

### Host 所有 channel 中断寄存器 (HAINT)

读偏移地址: 414h

| 域     | 说明                                                                              | 复位值   | 访问特性 |
|-------|---------------------------------------------------------------------------------|-------|------|
| 31:16 | 保留域                                                                             |       | RO   |
| 15:0  | Channel 中断(HAINT) 一个 bit 对应一个 channel: Bits 11: channel 11 。。。 Bits0: channel 0 | 16'h0 | RO   |

## Host 所有 channel 中断屏蔽寄存器 (HAINTMSK)

读偏移地址: 414h

| 域     | 说明                                                               | 复位值   | 访问特性 |
|-------|------------------------------------------------------------------|-------|------|
| 31:16 | 保留域                                                              |       | RO   |
| 15:0  | Channel 中断屏蔽位(HAINTMSK) 一个 bit 对应一个 channel: Bits 11: channel 11 | 16'h0 | R_W  |
|       | Bits 0: channel 0                                                |       |      |

#### Host 端口控制与状态寄存器 (HPRT)

读偏移地址: 440h

| 域     | 说明          | 复位值  | 访问特性 |
|-------|-------------|------|------|
| 31:19 | 保留域         |      | RO   |
| 18:17 | PrtSpd      | 2'b0 | RO   |
|       | 端口速度        |      |      |
|       | ● 2'b00: 高速 |      |      |
|       | ● 2'b01: 全速 |      |      |
|       | ● 2'b10: 低速 |      |      |



|       | ● 2'b11: 保留                              |       |         |
|-------|------------------------------------------|-------|---------|
| 16:13 | PrtTstCtl                                | 4'h0  | R_W     |
|       | 端口测试控制                                   |       |         |
|       | 当软件往此域写非 0 值时,使此端口进入测试模式。                |       |         |
|       | 相应的 Pattern 出现端口上。                       |       |         |
|       | ● 4'b0000: 非测试模式                         |       |         |
|       | ● 4'b0001: Test_J 模式                     |       |         |
|       | ● 4'b0010: Test_K 模式                     |       |         |
|       | ● 4'b0011: Test_SE0_NAK 模式               |       |         |
|       | ● 4'b0100: Test_Packet 模式                |       |         |
|       | ● 4'b0101: Test_Force 模式                 |       |         |
|       | ● 其他: 保留                                 |       |         |
| 12    | PrtPwr                                   | 1'b0  | R_W_SC  |
|       | 端口供电。                                    |       |         |
|       | • 1'b0: power off                        |       |         |
| 44.40 | • 1'b1: power on                         | 411.0 | D0      |
| 11:10 | Port Line Status(PrtLnSts)  Bits[10]: D+ | 1'b0  | RO      |
|       | Bits[10]: D+     Bits[11]: D-            |       |         |
| 9     | 保留                                       |       | RO      |
| 8     | 端口复位(PrtRst)                             | 1'b0  | R_W     |
| 7     | 端口挂起(PrtSup)                             | 1'b0  | R_WS_SC |
| 6     | 端口恢复(PrtRes)                             | 1'b0  | R_W_SS_ |
|       |                                          |       | SC      |
| 5     | 端口过载改变(PrtOvrCurrChng)                   | 1'b0  | R_SS_WC |
|       | 当 PrtOvrCurrAct 位改变时,OTG 控制器将这位置 1       |       |         |
| 4     | 端口过载活动(PrtOvrCurrAct)                    | 1'b0  | RO      |
|       | ● 无                                      |       |         |
|       | ● 有                                      |       |         |
| 3     | 端口使能状态改变(PrtEnChng)                      | 1'b0  | R_SS_WC |
|       | 当 PrtEna 位改变时,OTG 控制器将这位置 1              |       |         |
| 2     | 端口使能位(PrtEna)                            | 1'b0  | R_SS_SC |
|       | ● 1'b0: 否                                |       | _WC     |
|       | ● 1'b1: 是                                |       |         |
| 1     | 发现端口连接(PrtConnDet)当发现设备连接时,将             | 1'b0  | R_SS_WC |
|       | 通过 GINTSTS.PrtInt 触发中断。软件写 1 将此位清 0.     |       |         |
| 0     | 端口连接状态(PrtConnSts)                       | 1'b0  | RO      |
|       | ● 无设备连接到此端口                              |       |         |
|       | ● 有设备连接到此端口                              |       |         |
| _     |                                          |       |         |

# Host Channel-n 特性寄存器(HCCHARn)



Channel\_num:  $0 \le n \le 11$ 

读偏移地址: 500h + (Channel num \* 20h)

| 域     | K偏移地址: 500h + (Channel_num * 20h) <b>说明</b> | 复位值  | 访问特性       |
|-------|---------------------------------------------|------|------------|
| 31    | Channel 使能(ChEna)                           | 1'b0 | R_WS_SC    |
|       | 当 Scatter/Gather 模式使能时                      |      |            |
|       | ● 1'b0: 指示描述符结构还未准备好                        |      |            |
|       | ● 1'b1: 指示描述符结构以及数据缓冲已经准备好,                 |      |            |
|       | 这个通道可以访问描述符                                 |      |            |
|       | 当 Scatter/Gather 模式未使能时:                    |      |            |
|       | ● 1'b0: 通道失效                                |      |            |
|       | ● 1'b1: 通道使能                                |      |            |
| 30    | 通道失效(ChDis)                                 | 1'b0 | R_WS_SC_SS |
|       | 即使此通道上的传输还未完成,软件也可通过将这位                     |      |            |
|       | 置 1 来停止在此通道上的数据发送与接收。软件必须                   |      |            |
|       | 等待通道失效中断发生后,才能认为此通道已失效。                     |      |            |
| 29    | 奇帧(OddFrm)                                  | 1'b0 | R_W        |
|       | 软件通过将此位置 1 来告知 OTG host 必须在奇数               |      |            |
|       | micro Frame 内完成一个传输。此域仅对周期性事务               |      |            |
|       | (实时与中断) 有效                                  |      |            |
|       | ● 1'b0: 偶帧                                  |      |            |
|       | ● 1'b1: 奇帧                                  |      |            |
| 28:22 | 设备地址(DevAddr)                               | 7'h0 | R_W        |
| 21:20 | Multi Count (MC) /Error Count(EC)           | 2'b0 | R_W        |
|       | 当 HCSPLTn.SpltEna 为 1'b0 时,此域指示对于每个         |      |            |
|       | 周期性的 endpoint, 在每个 microFrame 时间内完成的        |      |            |
|       | 事务数。对于非周期性传输,此域尽在 DMA 模式下使                  |      |            |
|       | 用,用来指定在 DMA 改变仲裁之前,host 必须为此通               |      |            |
|       | 道获取的包数。                                     |      |            |
|       | ● 2'b00: 保留                                 |      |            |
|       | ● 2'b01: 1 个事务                              |      |            |
|       | ● 2'b10: 2 个事务                              |      |            |
|       | ● 2'b11: 3 个事务                              |      |            |
|       | 当 CSPLTn.SpltEna 为 1'b1 时,此域指定对于一个周         |      |            |
|       | 期性 split 事务出错时,必须重传的次数。至少设置为                |      |            |
|       | 2'b01                                       |      |            |



| 19:18 | 端点类型(EPType) | 2'b0  | R_W |
|-------|--------------|-------|-----|
|       | ● 2'b00: 控制  |       |     |
|       | ● 2'b01: 实时  |       |     |
|       | ● 2'b10: 批量  |       |     |
|       | ● 2'b11: 中断  |       |     |
|       |              |       |     |
| 17:16 | 保留           |       | RO  |
| 15    | 端点方向(EPDir)  | 1'b0  | R_W |
|       | • 1'b0: OUT  |       |     |
|       | • 1'b1: IN   |       |     |
| 14:11 | 端点号          | 4'b0  | R_W |
| 10:0  | 最大的包容量(MPS)  | 11'h0 | R_W |

### Host Channel-n Split 控制寄存器(HCSPLTn)

Channel\_num:  $0 \le n \le 11$ 

读偏移地址: 504h + (Channel num \* 20h)

| 域     | 说明                      | 复位值   | 访问特性 |
|-------|-------------------------|-------|------|
| 31    | Split 使能                | 1'b0  | R_W  |
| 30:17 | 保留                      |       | RO   |
| 16    | Do Complete Split       | 1'b0  | R_W  |
|       | 指示 OTG host 必须完成一个完整    |       |      |
|       | 的 split 传输              |       |      |
| 45.44 |                         | 011.0 | 5.14 |
| 15:14 | 事务位置(XactPos)           | 2'h0  | R_W  |
|       | ● 2'b00; all, 此事务的整个数据  |       |      |
|       | (少于或等于 188B)            |       |      |
|       | ● 2'b01: begin, 此事务的开始数 |       |      |
|       | 据(少于或等于 188B)           |       |      |
|       | ● 2'b10: Mid, 此事务的中间数据  |       |      |
|       | (少于或等于 188B)            |       |      |
|       | ● 2'b01: End, 此事务的最后数   |       |      |
|       | 据(少于或等于 188B)           |       |      |
| 13:7  | Hub 地址(HubAddr)         | 7'b0  | R_W  |
| 6: 0  | 端口地址(PrtAddr)           | 7'h0  | R_W  |

### Host Channel-n 中断寄存器(HCINTn)

Channel\_num:  $0 \le n \le 11$ 

读偏移地址: 508h + (Channel\_num \* 20h)

| 域     | 说明 | 复位值 | 访问特性 |
|-------|----|-----|------|
| 31:14 | 保留 |     | RO   |



| 13 | 描述符 rollover 中断(DESC_LST_ROLLIntr)     | 1'b0 | R_SS_WC |
|----|----------------------------------------|------|---------|
|    | 仅当 Scatter/Gather DMA 模式使能时,此域有效。当对    |      |         |
|    | 应通道的描述符列表 roll over 时置 1.              |      |         |
|    | 对于非 Scatter/Gather DMA 模式,此域位保留域       |      |         |
| 12 | 过多事务错(XCS_XACT_ERR)                    | 1'b0 | R_SS_WC |
|    | 当 Scatter/Gather DMA 模式使能时,此域有效。当 3 个  |      |         |
|    | 连续的事务出错时时置 1.                          |      |         |
|    | 对于非 Scatter/Gather DMA 模式,此域位保留域       |      |         |
| 11 | BNA(buffer 不可用)中断(BNAIntr)             | 1'b0 | R_SS_WC |
|    | 当 Scatter/Gather DMA 模式使能时,此域有效。当描述    |      |         |
|    | 符访问还未准备好时置 1.                          |      |         |
|    | 对于非 Scatter/Gather DMA 模式,此域位保留域       |      |         |
| 10 | 数据反转位错(DataTglErr)                     | 1'b0 | R_SS_WC |
| 9  | 帧 overrun(FrmOvrun)                    | 1'b0 | R_SS_WC |
| 8  | 空泡错(BblErr)                            | 1'b0 | R_SS_WC |
| 7  | 事务错(XactErr)                           | 1'b0 | R_SS_WC |
|    | 当 USB 总线上发生了以下错误时置 1:                  |      |         |
|    | ● CRC 验证失败                             |      |         |
|    | ● 超时                                   |      |         |
|    | ● 位填充错                                 |      |         |
|    | ● 错误的 EOP                              |      |         |
| 6  | 收到 NYET 握手(NYET)                       | 1'b0 | R_SS_WC |
| 5  | 收到 ACK 握手(ACK)                         | 1'b0 | R_SS_WC |
| 4  | 收到 NAK 握手(NAK)                         | 1'b0 | R_SS_WC |
| 3  | 收到 STALL 握手(STALL)                     | 1'b0 | R_SS_WC |
| 2  | AHB 错(AHBErr)                          | 1'b0 | R_SS_WC |
| 1  | 通道停止(ChHltd)                           | 1'b0 | R_SS_WC |
|    | 对于非 Scatter/Gather DMA 模式,由于 USB 传输错或软 |      |         |
|    | 件置无效请求而引起传输的非正常结束,或正常结束时置              |      |         |
|    | 1.                                     |      |         |
|    | 对于 Scatter/Gather DMA 模式,若因为以下原因导致传    |      |         |
|    | 输结束,则置 1:                              |      |         |
|    | ● 描述符中 EOL 置位                          |      |         |
|    | ● AHB 错                                |      |         |
|    | ● 过多的事务错                               |      |         |
|    | ● 软件置无效请求                              |      |         |
|    | ● 空泡                                   |      |         |
|    | Stall                                  |      |         |



| 0 | 传输结束 (XferCompl)                    | 1'b0 | R_SS_WC |
|---|-------------------------------------|------|---------|
|   | 对于 Scatter/Gather DMA 模式,指示完成对当前描述符 |      |         |
|   | 的处理,其描述符的 IOC 位置 1。                 |      |         |
|   | 对于非 Scatter/Gather DMA 模式,表示没有任何错误的 |      |         |
|   | 传输完成。                               |      |         |

## Host Channel-n 中断屏蔽寄存器(HCINTMSKn)

Channel\_num:  $0 \le n \le 11$ 

读偏移地址: 50Ch + (Channel\_num \* 20h)

| 域     | 说明                              | 复位值  | 访问特性 |
|-------|---------------------------------|------|------|
| 31:14 | 保留                              |      | RO   |
| 13    | 描述符 rollover 中断屏蔽位              | 1'b0 | R_W  |
|       | (DESC_LST_ROLLIntrMsk)          |      |      |
|       | 仅当 Scatter/Gather DMA 模式使能时,此域有 |      |      |
|       | 效。                              |      |      |
|       | 对于非 Scatter/Gather DMA 模式,此域位保留 |      |      |
|       | 域                               |      |      |
| 12    | 保留                              |      | RO   |
| 11    | 保留                              |      | RO   |
| 10    | 数据反转位错中断屏蔽位(DataTglErrMsk)      | 1'b0 | R_W  |
| 9     | 帧 overrun 中断屏蔽位(FrmOvrunMsk)    | 1'b0 | R_W  |
| 8     | 空泡错中断屏蔽位(BblErrMsk)             | 1'b0 | R_W  |
| 7     | 事务错中断屏蔽位(XactErrMsk)            | 1'b0 | R_W  |
| 6     | 收到 NYET 握手中断屏蔽位(NYETMsk)        | 1'b0 | R_W  |
| 5     | 收到 ACK 握手中断屏蔽位(ACKMsk)          | 1'b0 | R_W  |
| 4     | 收到 NAK 握手中断屏蔽位(NAKMsk)          | 1'b0 | R_W  |
| 3     | 收到 STALL 握手中断屏蔽位(STALLMsk)      | 1'b0 | R_W  |
| 2     | AHB 错中断屏蔽位(AHBErrMsk)           | 1'b0 | R_W  |
| 1     | 通道停止中断屏蔽位(ChHltdMsk)            | 1'b0 | R_W  |
| 0     | 传输结束中断屏蔽位(XferComplMsk)         | 1'b0 | R_W  |

## Host Channel-n 传输大小寄存器(HCTSIZn)

 $Channel\_num: \ 0 \ <= \ n \ <= \ 11$ 

读偏移地址: 510h + (Channel num \* 20h)

在 Scatter/Gather DMA 模式下,此寄存器各个域定义如下

| 域  | 说明             | 复位值  | 访问特性 |
|----|----------------|------|------|
| 31 | Do ping(DoPng) | 1'b0 | R_W  |



|       | 仅对 OUT 传输有效,置 1 时,指示 Host 做 PING 协议。     |       |     |
|-------|------------------------------------------|-------|-----|
|       | 若对 IN 传输将此位置 1,将使此通道无效                   |       |     |
| 30:29 | PID(Pid)                                 | 2'b00 | R_W |
|       | • 2'b00:DATA0                            |       |     |
|       | • 2'b01:DATA2                            |       |     |
|       | • 2'b10:DATA1                            |       |     |
|       | ● 2'b11:MDATA(非控制)                       |       |     |
| 28:16 | 保留域                                      | 9'b0  | RO  |
| 15:8  | NTD(传输描述符的数目)                            | 8'h0  | R_W |
|       | (非实时传输)                                  |       |     |
|       | ● 0 - 1 个描述符                             |       |     |
|       | ● 63 - 64 个描述符                           |       |     |
|       | (实时传输)                                   |       |     |
|       | ● 7 - 8 个描述符                             |       |     |
|       | ● 15 - 16 个描述符                           |       |     |
|       | ● 31 - 32 个描述符                           |       |     |
|       | ● 63 - 64 个描述符                           |       |     |
|       | ● 127 - 128 个描述符                         |       |     |
|       | ● 255 - 256 个描述符                         |       |     |
| 7:0   | SCHED_INFO(调度信息)                         | 8'h0  | R_W |
|       | 对应的每一位代表着在那个 microFrame 中角度。Bit0 代       |       |     |
|       | 表在 1st microFrame 中调度。Bits7 代表在 8th 中调度。 |       |     |
|       | 8'b11111111 代表着对应的中断通道被调度,在对应帧时          |       |     |
|       | 间内每个 microFrame 都发送一个标记。8'b10101010 代    |       |     |
|       | 表对应的中断通道被调度,在对应帧时间内每隔一个                  |       |     |
|       | microFrame 发送一个标记。                       |       |     |
|       | 注意,此域仅对周期性传输有效。                          |       |     |

## 在非 Scatter/Gather DMA 模式下,此寄存器各个域定义如下

| 域     | 说明                                   | 复位值   | 访问特性 |
|-------|--------------------------------------|-------|------|
| 31    | Do ping(DoPng)                       | 1'b0  | R_W  |
|       | 仅对 OUT 传输有效,置 1 时,指示 Host 做 PING 协议。 |       |      |
|       | 若对 IN 传输将此位置 1,将使此通道无效               |       |      |
| 30:29 | PID(Pid)                             | 2'b00 | R_W  |
|       | • 2'b00:DATA0                        |       |      |
|       | • 2'b01:DATA2                        |       |      |
|       | • 2'b10:DATA1                        |       |      |
|       | ● 2'b11:MDATA(非控制)                   |       |      |



| 28:19 | 包数目(PktCnt).                    | 10'h0 | R_W |
|-------|---------------------------------|-------|-----|
|       | 软件写入传输的包数据。                     |       |     |
|       | 每当一个传输完成,host 将此域减 1.一旦为 0, 软件将 |       |     |
|       | 接收到中断表示正常结束。                    |       |     |
| 18:0  | 传输大小(XferSize)                  | 19'h0 | R_W |
|       | 对于 OUT 传输,指定 host 将发送的数据字节数;对于  |       |     |
|       | IN 传输,指定 host 将接收到的数据字节数。       |       |     |

#### Host Channel-n DMA 地址寄存器(HCDMAn)

Channel\_num:  $0 \le n \le 11$ 

读偏移地址: 514h + (Channel\_num \* 20h)

在 IN/OUT 传输中,此寄存器用来维持当前 buffer 的地址。DMA 传输的起始地址必须双字对齐。

| 地址必须刈                          | 说明                                                                                                                                                                                                                                                                             | 复位值   | 访问特性 |  |
|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|------|--|
| Buffer DMA Mode                |                                                                                                                                                                                                                                                                                |       |      |  |
| 31:0                           | DMA 地址(DMAAddr)<br>每个 AHB 事务后累加。                                                                                                                                                                                                                                               | Х     | R_W  |  |
|                                | 描述符 DMA 模式                                                                                                                                                                                                                                                                     |       |      |  |
| 31: N<br>(实时)<br>31:9<br>(非实时) | DMA 地址 (DMAAddr)         非实时传输: 保存 512 字节页的起始地址。描述符列表的第一个描述符即在此地址上。OTG 控制器从CTD 开始处理描述符列表实时传输: 保存 2*(nTD+1)个字节的地址,此地址为实时描述符所在位置。其中 N 的值基于 nTD 而来,具体如下表:         31: N N-1: 3 2:0 基址 偏移 000         mTD N 6         15 7         31 8         63 9         127 10         255 11 | 23'h0 | R/W  |  |
| N-1: 3<br>(实时)<br>8:<br>(非实时)  | 当前传输描述符(CTD)<br>非实时传输:以描述符为单位,范围 0 - 63.指定<br>当前正在处理的描述符。<br>实时传输:基于当前 micorFrame 的值,需被软件<br>清 0                                                                                                                                                                               | 6'h0  | R/W  |  |
| 2:0                            | 保留                                                                                                                                                                                                                                                                             | 3'h0  | RO   |  |



### Host Channel-n DMA Buffer 地址寄存器(HCDMBAn)

Channel\_num:  $0 \le n \le 11$ 

读偏移地址: 518h + (Channel\_num \* 20h) 此仅在 Scatter/Gather DMA 模式下有效

| -    |                |     |      |
|------|----------------|-----|------|
| 域    | 说明             | 复位值 | 访问特性 |
| 31:0 | 当前 buffer 的地址。 | X   | RO   |

#### Host Frame List 基地址寄存器(HFLBAddr)

Offset: 41Ch

此仅在 Scatter/Gather DMA 模式下有效

| 域    | 说明               | 复位值   | 访问特性 |
|------|------------------|-------|------|
| 31:0 | Frame list 的起始地址 | 32'h0 | RO   |

#### **13.3.4** Device 模式寄存器

这组寄存器仅在 device 模式下有效, host 模式下不可访问。

#### Device 配置寄存器(DCFG)

Offset: 800h

在初始配置过后,不能修改此寄存器的值

| 域     | 住彻始即直过后,个能够以此奇仔益的但<br><b>说明 复位值访问特性</b>       |       |     |
|-------|-----------------------------------------------|-------|-----|
|       | ****                                          |       |     |
| 31:26 | Resume 有效期(ResValid)                          | 6'd2  | R_W |
|       | 此域控制 OTG 控制器从挂起状态到 resume 的时间。以时钟             |       |     |
|       | 周期为单位。仅当 DCFG.Ena32KHzSusp 置 1 时,此位有效         |       |     |
| 25:24 | 周期性调度间隔(PerSchIntvI)                          | 2'b00 | R_W |
|       | 仅在 Scatter/Gather DMA 模式下有效。                  |       |     |
|       | 用来指定 DMA 引擎给周期性 IN 端点获取数据分配的时间。               |       |     |
|       | 基于周期性 IN 端点的数目,其值必须设定为 75%                    |       |     |
|       | microFrame.                                   |       |     |
|       | ● 当任意周期性端节点活动时,DMA 引擎给周期性 IN 端                |       |     |
|       | 点获取数据分配一定的时间                                  |       |     |
|       | ● 当无周期性端节点活动时,忽略此域                            |       |     |
|       | ● 在指定时间后,DMA 引擎开始给非周期性端节点获取数                  |       |     |
|       | 据。                                            |       |     |
|       | • 2'b00: 25% microFrame                       |       |     |
|       | • 2'b01: 50% microFrame                       |       |     |
|       | • 2'b10: 75% microFrame                       |       |     |
|       | ● 2'b11: 保留                                   |       |     |
| 23    | 在 device 模式下使能 Scatter/Gather DMA 模式(DescDMA) | 1'b0  | R_W |
|       | ● GAHBCFG.DMAEn=0, DCFG.DescDMA=0 => 从模式      |       |     |
|       | ● GAHBCFG.DMAEn=0, DCFG.DescDMA=1 => 非法       |       |     |



|       | ● GAHBCFG.DMAEn=1, DCFG.DescDMA=0 => buffer DMA 模式 |      |     |
|-------|----------------------------------------------------|------|-----|
|       | GAHBCFG.DMAEn=0, DCFG.DescDMA=0 =>                 |      |     |
|       | Scatter/Gather DMA 模式                              |      |     |
| 22:14 | 保留                                                 |      | RO  |
| 13    | 是否使能 device OUT NAK。                               | 1'b0 | R_W |
|       | 仅对描述符 DMA 模式有效。                                    |      |     |
|       | ● 1'b0: 在批量 OUT 传输结束时, OTG 控制器不送出 NAK              |      |     |
|       | 握手信号                                               |      |     |
|       | ● 1'b0: 在批量 OUT 传输结束时,OTG 控制器送出 NAK                |      |     |
|       | 握手信号                                               |      |     |
| 12:11 | 周期帧的间隔(PerFrInt)                                   | 2'h0 | R_W |
|       | 指示在一个 microFrame 内何时用 EOP 中断来通知软件。此                |      |     |
|       | 域可用来决定当前 microFrame 内是否所有的实时传输已经                   |      |     |
|       | 完成。                                                |      |     |
|       | • 2'b00: 80%                                       |      |     |
|       | • 2'b01: 85%                                       |      |     |
|       | • 2'b00: 90%                                       |      |     |
|       | • 2'b00: 95%                                       |      |     |
| 10:4  | Device 地址(DevAddr)                                 | 7'h0 | R_W |
| 3     | 保留                                                 | 1'b0 | RO  |
| 2     | 非 0 长度的 Status OUT 握手(NZStsOUTHShk)                | 1'b0 | R_W |
|       | 当控制传输的 Status 阶段的 OUT 事务中,OTG 接收到一个                |      |     |
|       | 非 0 的数据包,此域用来选着 OTG 控制送出的不同的握手信                    |      |     |
|       | 号。                                                 |      |     |
|       | • 1'b1: STALL                                      |      |     |
|       | ● 1'b0:送出接收到的OUT数据包,并基于 device endpoint            |      |     |
|       | 控制寄存器中 NAK 与 STALL 位,送出握手信号                        |      |     |
| 1:0   | 设备速度(DevSpd)                                       | 2'b0 | R_W |
|       | • 2'b00: HS(USB2.0 PHY)                            |      |     |
|       | • 2'b01: FS(USB2.0 PHY)                            |      |     |
|       | • 2'b10: LS(USB1.1 PHY)                            |      |     |
|       | • 2'b11: FS(USB1.1 PHY)                            |      |     |

# Device 控制寄存器(DCTL)

Offset: 804h

| 域     | 说明                   | 复位值  | 访问特性 |
|-------|----------------------|------|------|
| 31:17 | 保留                   |      | RO   |
| 16    | 遇到 babble 发送 NAK 握手。 | 1'b0 | R_W  |



| 15    | 对实时端节点忽略帧号(IgnrFrmNum)                  | 1'b0  | R_W   |
|-------|-----------------------------------------|-------|-------|
|       | ● GAHBCFG.DMAEn=0,此域无效                  |       |       |
|       | ● GAHBCFG.DMAEn=1 , DCFG.DescDMA = 0: 当 |       |       |
|       | threshold 模式有效时,此位无效。否则,软件用此位来          |       |       |
|       | 使能周期性传输中断。                              |       |       |
|       | - 1'b0 周期性传输中断无效。                       |       |       |
|       | - 1'b1 当接收到 ISOC IN 标记时,无需清空包。          |       |       |
|       | OTG 控制器忽略帧号,一旦包准备好且接收到                  |       |       |
|       | 对应的标记,就将这个包发送出去。此域也用来                   |       |       |
|       | 使能周期性传输中断                               |       |       |
|       | • GAHBCFG.DMAEn=1, DCFG.DescDMA = 1:    |       |       |
|       | 对高速的传输无效                                |       |       |
| 14:13 | 全局 Multi Count(GMC)                     | 2'h0  | R_W   |
|       | 仅在 Scatter/Gater DMA 模式下有效。用来指示在转移到下一   |       |       |
|       | 个结束点之前,接收或发送的包个数。仅对非周期性端节点              |       |       |
|       | 有效。                                     |       |       |
|       | ● 2'b00: 非法;                            |       |       |
|       | ● 2'b01: 1 个包;                          |       |       |
|       | ● 2'b00: 2 个包;                          |       |       |
|       | ● 2'b00: 3 个包;                          |       |       |
|       | 当 DCFG.DescDMA =1 时,此域自动改变成 2'h1        |       |       |
| 12    | 保留域                                     |       | RO    |
| 11    | Powr-on 编程完成(PWROnPrgDone)              | 1'b0  | R_W   |
|       | 从 power_down 模式恢复后,寄存器编程完成时,此位置 1.      | 411.0 | 1110  |
| 10    | 清空全局 OUT NAK(CGOUTNak)                  | 1'b0  | WO    |
|       | 对此位的写,将清空全局 OUT NAK                     | 411.0 | 1110  |
| 9     | 设置全局 OUT NAK(SGOUTNak)                  | 1'b0  | WO    |
|       | 对此位的写,将设置全局 OUT NAK                     | 411.0 | \\\C  |
| 8     | 清空全局的非周期性 IN NAK(CGNPInNak)             | 1'b0  | WO    |
|       | 此位的写,将清空全局非周期性 IN NAK                   | 411.0 | 1110  |
| 7     | 设置全局的非周期性 IN NAK (SGNPInNak)            | 1'b0  | WO    |
|       | 此位的写,将设置全局非周期性 IN NAK                   | 011.0 | D 147 |
| 6: 4  | 测试控制(TstCtl)                            | 3'b0  | R_W   |
|       | ● 3'b000: 无效 Test 模式                    |       |       |
|       | ● 3'b001: Test_J 模式                     |       |       |
|       | ● 3'b010: Test_K 模式                     |       |       |
|       | ● 3'b011: Test_SE0_NAK 模式               |       |       |
|       | ● 3'b100: Test_Packet 模式                |       |       |
|       | ● 3'b101: Test_Force_Enable 模式          |       |       |



|   | ● 其他:保留                                    |      |     |
|---|--------------------------------------------|------|-----|
| 3 | 全局 OUT NAK 状态(GOUTNakSts)                  | 1'b0 | RO  |
|   | ● 1'b0: 基于 FIFO 的状态以及 NAK, STALL 位的设置情     |      |     |
|   | 况来发送相应的握手                                  |      |     |
|   | ● 1'b1:不管 RxFIFO 是否有空项,都无数据写入 RxFIFO.      |      |     |
|   | 除 SETUP 事务以外,对所有的包都发送 NAK 握手。终             |      |     |
|   | 止所有的实时 OUT 包。                              |      |     |
| 2 | 全局非周期性 IN NAK 状态位                          | 1'b0 | RO  |
|   | 1'b0: 基于 TxFIFO 的有效数据发送相应的握手;              |      |     |
|   | 1'b1: 对于所有的非周期性 IN 端节点,发送 NAK 握手信号,        |      |     |
|   | 不管 TxFIFO 是否有有效数据                          |      |     |
| 1 | 软断开(SftDisCon)                             | 1'b0 | R_W |
|   | 一旦此位置 1, host 将看不到 device 的连接, device 也讲接  |      |     |
|   | 收不到 USB 上的信号。                              |      |     |
|   | ● 1'b0: 正常操作                               |      |     |
|   | ● 1'b1: OTG 控制器将 utmi+接口上的 phy_opmode_o 信号 |      |     |
|   | 置为 2'b01,这将给 USB host 产生一个断开事件             |      |     |
| 0 | 远程唤醒信号(RmtWkUpSig)                         | 1'b0 | R_W |
|   | 当次位置 1, OTG 控制器将发送一个远程唤醒信号去唤醒              |      |     |
|   | USB host。                                  |      |     |

# Device 状态寄存器(DSTS)

Offset: 808h

| 域      | 说明                                                 | 复位值   | 访问特性 |
|--------|----------------------------------------------------|-------|------|
| 31: 22 | 保留                                                 |       | RO   |
| 21:8   | 接收到的 SOF 的帧号(SOFN)                                 | 14'h0 | RO   |
| 7: 4   | 保留                                                 |       | RO   |
| 3      | 严重错 (ErrticErr)                                    |       | RO   |
|        | OTG 控制器通过此域来报告发生了严重错误(由于 PHY 出                     |       |      |
|        | 错,phy_rxvalid_i/phy_rxvldh_i 或 phy_rxactive_i 置位超过 |       |      |
|        | 2ms),一旦发生严重错误,OTG 控制器进入挂起模式,                       |       |      |
|        | GINTSTS.ErlySusp 位置 1.且软件仅能通过软断开来恢复                |       |      |
| 2:1    | 枚举速度(EnumSpd)                                      |       | RO   |
|        | • 2'b00: HS(USB2.0 PHY)                            |       |      |
|        | • 2'b01: FS(USB2.0 PHY)                            |       |      |
|        | • 2'b10: LS(USB1.1 PHY)                            |       |      |
|        | • 2'b11: FS(USB1.1 PHY)                            |       |      |



| 0 | 挂起状态(SuspSts)                         | 1'b0 | RO |
|---|---------------------------------------|------|----|
|   | Device 模式下,只要在 USB 总线上发现挂起状态,则置 1.    |      |    |
|   | 当 utmi_linestate 信号在一定事件内无活动,则 OTG 控制 |      |    |
|   | 器进入挂起状态。一旦以下条件发生,则 OTG 控制器退出          |      |    |
|   | 挂起状态:                                 |      |    |
|   | ● 当 utmi_linestate 信号有活动              |      |    |
|   | ● 当软件往 DCTL.RmtWkUpSig 位写 1 时。        |      |    |

# Device IN 端点共用的中断屏蔽寄存器(DIEPMSK)

♦ Offset: 810h

| 域      | 说明                             | 复位值  | 访问特性 |
|--------|--------------------------------|------|------|
| 31: 14 | 保留                             |      | RO   |
| 13     | NAK 中断屏蔽位(NAKMsk)              | 1'h0 | R_W  |
| 12:10  | 保留                             |      | RO   |
| 9      | BNA 中断品屏蔽位(BNAInIntrMsk)       | 1'h0 | R_W  |
|        | 仅当描述符 DMA 模式时有效                |      |      |
| 8      | FIFO 下溢中断屏蔽位屏蔽(TxFifoUndrnMSK) | 1'b0 | R_W  |
| 7      | 保留                             | 1'b0 | RO   |
| 6      | IN 端节点 NAK 有效中断屏蔽位             | 1'b0 | R_W  |
|        | (INEPNakEffMsk)                |      |      |
| 5      | 接收到 EP 不匹配的 IN 标记中断屏蔽位         | 1'b0 | R_W  |
|        | (INTknEPMisMsk)                |      |      |
| 4      | 当 TxFIFO 空时接收到 IN 标记中断屏蔽位      | 1'b0 | R_W  |
|        | (INTknTXFEmpMsk)               |      |      |
| 3      | 超时中断屏蔽位                        | 1'b0 | R_W  |
|        | (TImeOUTMsk)                   |      |      |
|        | 仅对非实时端节点有效                     |      |      |
| 2      | AHB 错误中断屏蔽位                    | 1'b0 | R_W  |
|        | (AHBErrMsk)                    |      |      |
| 1      | 端节点失效中断屏蔽位                     | 1'b0 | R_W  |
|        | (EPDisbldMsk)                  |      |      |
| 0      | 传输完成中断屏蔽位                      | 1'b0 | R_W  |
|        | (XferComplMsk)                 |      |      |

## device OUT 端点共用的中断屏蔽寄存器(DOEPMSK)

♦ Offset: 814h

| 域      | 说明 | 复位值 | 访问特性 |
|--------|----|-----|------|
| 31: 15 | 保留 |     | RO   |



| 14    | NYET 中断屏蔽位             | 1'b0 | R_W |
|-------|------------------------|------|-----|
|       | (NYETMsk)              |      |     |
| 12    | 空泡中断屏蔽位                | 1'b0 | R_W |
|       | (BbleErrMsk)           |      |     |
| 11:10 | 保留                     |      | RO  |
| 9     | BNA 中断屏蔽位              | 1'b0 | R_W |
|       | (BnaOutIntrMsk)        |      |     |
| 8     | OUT 包错误中断屏蔽位           | 1'b0 | R_W |
|       | (OutPktErrMsk)         |      |     |
| 7     | 保留                     |      | RO  |
| 6     | 接收到背对背的 SETUP 包中断屏蔽位   | 1'b0 | R_W |
|       | (Back2BackSETup)       |      |     |
| 5     | 保留                     |      | RO  |
| 4     | 当端节点失效时接收到 OUT 标记中断屏蔽位 | 1'b0 | R_W |
|       | (OUTTknEPdisMsk)       |      |     |
| 3     | SETUP 阶段完成中断屏蔽位        | 1'b0 | R_W |
|       | (SetUPMsk)             |      |     |
| 2     | AHB 错误中断屏蔽位            | 1'b0 | R_W |
|       | (AHBErrMsk)            |      |     |
| 1     | 端节点失效中断屏蔽位             | 1'b0 | R_W |
|       | (EPDisbldMsk)          |      |     |
| 0     | 传输完成中断屏蔽位              | 1'b0 | R_W |
|       | (XferComplMsk)         |      |     |
|       |                        |      |     |

### Device 所有端点共用的中断寄存器(DAINT)

♦ Offset: 818h

| 域      | 说明                   | 复位值   | 访问特性 |
|--------|----------------------|-------|------|
| 31: 16 | OUT 端节点中断位(OutEPInt) | 16'h0 | RO   |
|        | 一个 OUT 端节点对应一位。      |       |      |
|        | 位 16 对应端节点 0         |       |      |
|        |                      |       |      |
| 15:0   | IN 端节点中断位(InEPInt)   | 16'h0 | RO   |
|        | 一个 IN 端节点对应一位。       |       |      |
|        | 位 0 对应端节点 0          |       |      |
|        |                      |       |      |

## Device 所有端点共用的中断屏蔽寄存器(DAINTMSK)

♦ Offset: 81Ch



| 域      | 说明                        | 复位值     | 访问特性  |
|--------|---------------------------|---------|-------|
| 31: 16 | OUT 端节点中断屏蔽位(OutEPIntMsk) | 16'h0   | R_W   |
|        | 一个 OUT 端节点对应一位。           |         |       |
|        | 位 16 对应端节点 0              |         |       |
| 45.0   |                           | 4.015.0 | D 14/ |
| 15:0   | IN 端节点中断屏蔽位(InEPIntMsk)   | 16'h0   | R_W   |
|        | 一个 IN 端节点对应一位。            |         |       |
|        | 位 0 对应端节点 0               |         |       |
|        |                           |         |       |

### Device VBUS 放电寄存器(DVBUSDIS)

♦ Offset: 828h

| 域     | 说明                                                            | 复位值                | 访问特性 |
|-------|---------------------------------------------------------------|--------------------|------|
| 31:16 | 保留                                                            |                    | RO   |
| 15:0  | Device Vbus 放电时间(DVBUSDis) SRP 期间,在 Vbus 脉冲后 Vbus 放电的时间。以 PHY | 30MHZ:<br>16'h0B8F | R_W  |
|       | 时钟为单位。                                                        | 60MHZ:<br>16'h17D7 |      |

### Device VBUS 脉冲寄存器(DVBUSPULSE)

♦ Offset: 82Ch

| 域     | 说明                                                           | 复位值               | 访问特性 |
|-------|--------------------------------------------------------------|-------------------|------|
| 31:12 | 保留                                                           |                   | RO   |
| 11:0  | Device Vbus 脉冲时间(DVBUSPulse) SRP 期间,在 Vbus 脉冲的时间。以 PHY 时钟为单位 | 30MHZ:<br>12'h2c6 | R_W  |
|       | 位。                                                           | 60MHZ:<br>12'h5b8 |      |

### Device 阈值控制寄存器(DTHRCTL)

♦ Offset: 830h

| 域     | 说明                   | 复位值  | 访问特性 |
|-------|----------------------|------|------|
| 31:28 | 保留                   |      | RO   |
| 27    | 仲裁器 parking 使能       | 1'b1 | R_W  |
| 26    | 保留                   |      | RO   |
| 25:17 | 接收阈值长度(RxThrLen)     | 9'h8 | R_W  |
| 16    | 接收阈值使能(RxTHrEn)      | 1'b0 | R_W  |
| 15:13 | 保留                   |      | RO   |
| 12:11 | AHB 阈值率(AHBThrRatio) | 2'b0 | R_W  |



| 10:2 | 发送阈值长度(TxThrLen)            | 9'h8 | R_W |
|------|-----------------------------|------|-----|
| 1    | 实时 IN 端节点阈值使能(ISOThrEn)     | 1'b0 | R_W |
| 0    | 非实时 IN 端节点阈值使能(NonISOThrEn) | 1'b0 | R_W |

### Device IN 端节 FIFO 空中断屏蔽寄存器(DIEPEMPMSK)

♦ Offset: 834h

| 域     | 说明                            | 复位值   | 访问特性 |
|-------|-------------------------------|-------|------|
| 31:16 | 保留                            |       | RO   |
| 15:0  | IN 端节点 Tx FIFO 空中断屏蔽位         | 16'b0 | R_W  |
|       | (InEpTxfEmpMsk)               |       |      |
|       | 作为 DIEPINTn 的中断屏蔽位,一位对应一个端节点。 |       |      |
|       | Bit0 对应端节点 0,以此类推             |       |      |

# Device 控制 IN 端节 0 控制寄存器(DIEPCTL0)

♦ Offset: 900h

| 域     | 说明                                   | 复位值  | 访问特性    |
|-------|--------------------------------------|------|---------|
|       | 7-7.                                 |      |         |
| 31    | 端节点使能(EPEna)                         | 1'b0 | R_WS_SC |
|       | ● 对于 Scatter/Gather DMA 模式,对于 IN 端节点 |      |         |
|       | 来讲,此域置 1 意味着描述符以及数据缓冲都已              |      |         |
|       | 经准备好。                                |      |         |
|       | ● 对于非 Scatter/Gather DMA 模式,此域置 1 意味 |      |         |
|       | 着数据缓冲已经准备好。                          |      |         |
|       | 当 OTG 设置以下中断时,将此位清 0:                |      |         |
|       | ● 端节点失效                              |      |         |
|       | ● 传输完成                               |      |         |
| 30    | 端节点失效 (EPDis)                        | 1'b0 | R_WS_SC |
|       | 软件将此位置 1,即使此端节点上的传输未完成,也将            |      |         |
|       | 停止在此端节点上发送数据。软件必须等待端节点失              |      |         |
|       | 效中断发生后,才能认为此端节点已经失效。当 OTG            |      |         |
|       | 控制器设置端节点失效中断时,将此位清 0.软件仅当            |      |         |
|       | 在 EPEna 位为 1 时才能置此位为 1.              |      |         |
|       | 此域仅在 DMA 模式下有效。                      |      |         |
| 29:28 | 保留                                   |      | RO      |
| 27    | 设置 NAk(SNAK)                         | 1'b0 | WO      |
|       | 置 1,设置此端节点对应的 NAK 位为 1.              |      |         |
| 26    | 清空 NAK(CNAK)                         | 1'b0 | WO      |
|       | 置 1,设置此端节点对应的 NAK 位为 0.              |      |         |
|       |                                      |      |         |



| 25:22 | TxFIFO 号(TxFNum)                | 4'h0 | R_W     |
|-------|---------------------------------|------|---------|
|       | 设置为 IN 端点 0 对应的 FIFO 号          |      |         |
| 21    | STALL 握手(Stall)                 | 1'b0 | R_WS_SC |
|       | 当收到 SETUP 包时,软件置 1,OTG 控制器清 0.  |      |         |
|       | 如果同时 NAK 位,全局非周期性 IN NAK,全局 OUT |      |         |
|       | NAK 位都置 1,那么 STALL 位优先级最高。      |      |         |
| 20    | 保留                              |      | RO      |
| 19:18 | 端节点类型(EPType)                   | 2'h0 | RO      |
|       | 对于控制节点为 2'b00                   |      |         |
| 17    | NAK 状态(NAKSts)                  | 1'b0 | RO      |
|       | ● 1'b0: 基于 FIFO 的状态,OTG 控制器发送非  |      |         |
|       | Non-NAK 握手                      |      |         |
|       | ● 1'b1: OTG 控制器发送 NAK 握手        |      |         |
| 16    | 保留                              |      | RO      |
| 15    | USB 活动端节点(USBActEP)             | 1'b1 | RO      |
|       | 一直为 1,表示控制端节点 0 总是可用            |      |         |
| 14:2  | 保留                              |      | RO      |
| 1:0   | 最大的包大小(MPS)                     | 2'h0 | R_W     |
|       | • 2'b00: 64B                    |      |         |
|       | • 2'b01: 32B                    |      |         |
|       | • 2'b10: 16B                    |      |         |
|       | • 2'b11: 8B                     |      |         |

## Device 控制 OUT 端节 0 控制寄存器(DOEPCTL0)

♦ Offset: B00h

| 域  | 说明                                     | 复位值  | 访问特性    |
|----|----------------------------------------|------|---------|
| 31 | 端节点使能(EPEna)                           | 1'b0 | R_WS_SC |
|    | ● 对于 Scatter/Gather DMA 模式,对于 OUT 端节点来 |      |         |
|    | 讲,此域置 1 意味着描述符以及数据缓冲都已经准备              |      |         |
|    | 好接收数据。                                 |      |         |
|    | ● 对于非 Scatter/Gather DMA 模式,此域置 1 意味着数 |      |         |
|    | 据缓冲已经准备好。                              |      |         |
|    | 当 OTG 设置以下中断时,将此位清 0:                  |      |         |
|    | ● SETUP 时相完成                           |      |         |
|    | ● 端节点失效                                |      |         |
|    | ● 传输完成                                 |      |         |
|    | 在 DMA 模式下,若 OTG 控制器传输 SETUP 数据包时,      |      |         |



|       | 此位必须置 1.                                |      |         |
|-------|-----------------------------------------|------|---------|
| 30    | 端节点失效(EPDis)                            | 1'b0 | RO      |
|       | 软件不能使 OUT 控制节点 0 失效                     |      |         |
| 29:28 | 保留                                      |      | RO      |
| 27    | 设置 NAk(SNAK)                            | 1'b0 | WO      |
|       | 置 1,设置此端节点对应的 NAK 位为 1.                 |      |         |
| 26    | 清空 NAK (CNAK)                           | 1'b0 | WO      |
|       | 置 1,清空此端节点对应的 NAK 位为 1.                 |      |         |
| 25:22 | 保留                                      |      | RO      |
| 21    | STALL 握手                                | 1'b0 | R_WS_SC |
|       | 当收到 SETUP 包时,软件置 1, OTG 控制器清 0.         |      |         |
|       | 如果同时 NAK 位,全局非周期性 NAK,全局 OUT NAK        |      |         |
|       | 位都置 1,那么 STALL 位优先级最高。但是不管此位是否          |      |         |
|       | 置 1,OTG 控制器对 SETUP 数据包的握手信号总是 ACK       |      |         |
| 20    | Snoop 模式(Snp)                           | 1'b0 | R_W     |
|       | 在 snoop 模式下,在传输数据给内存时,OTG 控制器不检         |      |         |
|       | 查 OUT 数据包的正确性                           |      |         |
| 19:18 | 端节点类型(EPType)                           | 2'h0 | RO      |
|       | 对于控制节点为 2'b00                           |      |         |
| 17    | NAK 状态(NAKSts)                          | 1'b0 | RO      |
|       | ● 1'b0: 基于 FIFO 的状态, OTG 控制器发送非 Non-NAK |      |         |
|       | 握手                                      |      |         |
|       | ● 1'b1: OTG 控制器发送 NAK 握手                |      |         |
| 16    | 保留                                      |      | RO      |
| 15    | USB 活动端节点(USBActEP)                     | 1'b1 | RO      |
|       | 一直为 1,表示控制端节点 0 总是可用                    |      |         |
| 14:2  | 保留                                      |      | RO      |
| 1:0   | 最大的包大小(MPS)                             | 2'h0 | R_W     |
|       | • 2'b00: 64B                            |      |         |
|       | • 2'b01: 32B                            |      |         |
|       | • 2'b10: 16B                            |      |         |
|       | • 2'b11: 8B                             |      |         |

## Device 端节-n 控制寄存器(DIEPCTLn/DOEPCTLn)

- ◆ Endpoint\_num: 1 <= n <= 6
- ◆ Offset for IN: 900h + (Endpoint\_num\*20h)
- ◆ Offset for OUT: B00h + (Endpoint\_num\*20h)

| 域 | 说明 | 复位值 | 访问特性 |
|---|----|-----|------|
|   |    |     |      |



| 31    | 端节点使能(EPEna)                             | 1'b0 | R_WS_SC |
|-------|------------------------------------------|------|---------|
|       | 应用于 IN/OUT 端节点。                          |      |         |
|       | ● 对于 Scatter/Gather DMA 模式,对于 IN 端节点来讲,  |      |         |
|       | 此域置 1 意味着描述符以及数据缓冲都已经准备好;对               |      |         |
|       | 于 OUT 端节点来讲,此域置 1 意味着描述符以及数据             |      |         |
|       | 缓冲都已经准备好接收数据。                            |      |         |
|       | ● 对于非 Scatter/Gather DMA 模式,对于 IN 端节点来讲, |      |         |
|       | 此域置 1 意味着数据缓冲已经准备好发送数据; 对于 IN            |      |         |
|       | 端节点来讲,此域置 1 意味着数据缓冲已经准备好接收               |      |         |
|       | 数据:                                      |      |         |
|       | 当 OTG 设置以下中断时,将此位清 0:                    |      |         |
|       | ● SETUP 时相完成                             |      |         |
|       | ● 端节点失效                                  |      |         |
|       | <ul><li>● 传输完成</li></ul>                 |      |         |
| 30    | 端节点失效(EPDis)                             | 1'b0 | R_WS_SC |
|       | 应用于 IN/OUT 端节点                           |      |         |
|       | 软件将此位置 1,即使此端节点上的传输未完成,也将停止              |      |         |
|       | 在此端节点上发送数据。软件必须等待端节点失效中断发生               |      |         |
|       | 后,才能认为此端节点已经失效。当 OTG 控制器设置端节             |      |         |
|       | 点失效中断时,将此位清 0.软件仅当在 EPEna 位为 1 时才        |      |         |
|       | 能置此位为 1.                                 |      |         |
| 29    | 设置 DATA1 PID(SetD1PID)                   | 1'b0 | WO      |
|       | 仅对中断/批量 IN 以及 OUT 端节点有效。                 |      |         |
|       | 对此位写 1,则置 DPID 位 DATA1。                  |      |         |
|       | 对描述符 DMA 与非描述符 DMA 模式都有效                 |      |         |
| 28    | 设置 DATA0 PID(SetD0PID)                   | 1'b0 | WO      |
|       | 仅对中断/批量 IN 以及 OUT 端节点有效。                 |      |         |
|       | 对此位写 1,则置 DPID 位 DATAO。                  |      |         |
|       | 对描述符 DMA 与非描述符 DMA 模式都有效。                |      |         |
| 27    | 设置 NAK(SNAK)                             | 1'b0 | WO      |
|       | 应用于 IN/OUT 端节点                           |      |         |
|       | 置 1,设置此端节点对应的 NAK 位为 1.                  |      |         |
| 26    | 清空 NAK (CNAK)                            | 1'b0 | WO      |
|       | 应用于 IN/OUT 端节点                           |      |         |
|       | 置 1,清空此端节点对应的 NAK 位为 1.                  |      |         |
| 25:22 | TxFIFO 号(TxFNum)                         | 4'h0 | R_W     |
|       | 仅对 IN 端节点有效;                             |      |         |
|       | 设置为 IN 端对应的 FIFO 号                       |      |         |
| 21    | STALL 握手                                 | 1'b0 | R_W     |



|       | 仅对非控制,非实时的 IN/OUT 端节点有效。                |      |     |
|-------|-----------------------------------------|------|-----|
|       | 通过设置此位,来 stall 所有从 host 来的标记。如果同时 NAK   |      |     |
|       | 位,全局非周期性 NAK,全局 OUT NAK 位都置 1,那么        |      |     |
|       | STALL 位优先级最高。但是不管此位是否置 1, OTG 控制        |      |     |
|       | 器对 SETUP 数据包的握手信号总是 ACK                 |      |     |
|       | 备列 SETUP 数据也的推于信号态定 ACK                 |      |     |
|       | 仅对控制端节点有效。                              |      |     |
|       | 当收到 SETUP 包时,软件置 1,OTG 控制器清 0.          |      |     |
|       | 如果同时 NAK 位,全局非周期性 NAK,全局 OUT NAK 位      |      |     |
|       | 都置 1, 那么 STALL 位优先级最高。但是不管此位是否置 1,      |      |     |
|       | OTG 控制器对 SETUP 数据包的握手信号总是 ACK           |      |     |
| 20    | Snoop 模式(Snp)                           | 1'b0 | R_W |
|       | 仅对 OUT 端节点有效                            |      |     |
|       | 在 snoop 模式下,在传输数据给内存时,OTG 控制器不检         |      |     |
|       | 查 OUT 数据包的正确性                           |      |     |
| 19:18 | 端节点类型(EPType)                           | 2'h0 | R_W |
|       | ● 2'b00: 控制                             |      |     |
|       | ● 2'b01: 实时                             |      |     |
|       | ● 2'b10: 批量                             |      |     |
|       | ● 2'b11: 中断                             |      |     |
| 17    | NAK 状态(NAKSts)                          | 1'b0 | RO  |
|       | 应用于所有的 IN/OUT 端节点                       |      |     |
|       | ● 1'b0:基于 FIFO 的状态, OTG 控制器发送非 Non-NAK  |      |     |
|       | 握手                                      |      |     |
|       | ● 1'b1: OTG 控制器发送 NAK 握手                |      |     |
| 16    | 端节点数据 PID(DPID)                         | 1'b0 | RO  |
|       | 应用于中断/批量 IN 以及 OUT 端节点。                 |      |     |
|       | 包括在此端节点接收或发送的数据包的 PID。当此端节点活            |      |     |
|       | 动后,软件必须设置此端节点接收或发送的第一个包的 PID。           |      |     |
|       | 使用此寄存器的 SetD0PID 以及 SetD1PID 域来设置 DATA0 |      |     |
|       | 或 DATA1 PID                             |      |     |
|       | • 1'b0: DATA0                           |      |     |
|       | • 1'b1: DATA1                           |      |     |
|       | 奇偶帧(EO_FrNum)                           |      |     |
|       | 在非描述符 DMA 模式下,应用于实时的 IN/OUT 端节点。        |      |     |
|       | 指定为此端节点发送或接收实时数据所用地帧号。通过此寄              |      |     |
|       | 存器的 SetEvnFr 与 SetOddFr 域来设置。           |      |     |
|       | ● 1'b0: 偶帧                              |      |     |
|       | ● 1'b1: 奇帧                              |      |     |



|       | 在描述符 DMA 模式下,此域位保留域             |       |        |
|-------|---------------------------------|-------|--------|
| 15    | USB 活动端节点                       | 1'b0  | R_W_Sc |
|       | 应用于 IN 或 OUT 端节点。               |       |        |
|       | 指示在当前配置与接口下,端节点是否活动。            |       |        |
| 14:11 | 保留                              |       | RO     |
| 10:0  | 最大包大小(MPS)                      | 11'b0 | R_W    |
|       | 应用于 IN 或 OUT 端节点。设置最大的包大小,以字节为单 |       |        |
|       | 位                               |       |        |

## Device 端节-n 中断寄存器(DIEPCTLn /DOEPCTLn)

◆ Endpoint\_num: 1 <= n <= 6

◆ Offset for IN: 908h + (Endpoint\_num\*20h)

◆ Offset for OUT: B08h + (Endpoint\_num\*20h)

| 域     | 说明                        | 复位值  | 访问特性    |
|-------|---------------------------|------|---------|
| 31:15 | 保留                        |      | RO      |
| 14    | NYET 中断(NYETIntrpt)       | 1'b0 | R_SS_WC |
| 13    | NAK 中断(NAKIntrpt)         | 1'b0 | R_SS_WC |
| 12    | 空泡错中断(BbleErrIntrpt)      | 1'b0 | R_SS_WC |
| 11    | 包 drop 状态(PktDrpSts)      | 1'b0 | R_SS_WC |
| 10    | 保留                        |      | RO      |
| 9     | BNA(缓冲不可用)中断(BNAIntr)     | 1'b0 | R_SS_WC |
| 8     | FIFO 下溢(TxFifoUndrn)      | 1'b0 | R_SS_WC |
| 7     | TxFIFO 空(TxFEmp)          | 1'b0 | R_SS_WC |
| 6     | IN 端节点 NAK 有效(INEPNakEff) | 1'b0 | R_SS_WC |
| 5     | 接收到 EP 不匹配的 IN 标记中断       | 1'b0 | R_SS_WC |
|       | (INTknEPMis)              |      |         |
| 4     | 当 TxFIFO 空时接收到 IN 标记中断    | 1'b0 | R_SS_WC |
|       | (INTknTXFEmp)             |      |         |
| 3     | 超时中断                      | 1'b0 | R_SS_WC |
|       | (TImeOUT)                 |      |         |
|       | 仅对非实时端节点有效                |      |         |
| 2     | AHB 错误中断                  | 1'b0 | R_SS_WC |
|       | (AHBErr)                  |      |         |
| 1     | 端节点失效中断                   | 1'b0 | R_SS_WC |
|       | (EPDisbld)                |      |         |
| 0     | 传输完成中断                    | 1'b0 | R_SS_WC |
|       | (XferCompl)               |      |         |
|       |                           |      |         |

## Device 端节 0 传输大小寄存器(DIEPTSIZ0/DOEPTSIZ0)



Offset for IN: 910hOffset for OUT: B10h

对于 IN 端节点:

| 域     | 说明                                                                              | 复位值  | 访问特性 |
|-------|---------------------------------------------------------------------------------|------|------|
| 31:15 | 保留                                                                              |      | RO   |
| 20:19 | 包数量(PktCnt)<br>指示在此传输大小数量下的包数目。                                                 | 2'b0 | R_W  |
|       | 每当从 TxFIFO 中读取一个包,此域减 1。                                                        |      |      |
| 18:7  | 保留域                                                                             | 7'h0 | R_W  |
| 6:0   | 传输大小<br>指示端节点 0 的传输大小(以字节为单位),当超出这个值,则将引发中断。可被设置为此端节点的 MPS。每次一个包写入 TxFIFO,此域减 1 | 7'h0 | R_W  |

#### 对于 OUT 端节点:

| 域     | 说明                             | 复位值  | 访问特性 |
|-------|--------------------------------|------|------|
| 31    | 保留                             |      | RO   |
| 30:29 | SETUP 包数量(SUPPktCnt)           | 2'b0 | R_W  |
|       | 指示此端节点能接受到的背对背 SETUP 包的数量      |      |      |
|       | ● 2'b01: 1 个包                  |      |      |
|       | ● 2'b10: 2 个包                  |      |      |
|       | ● 2'b11: 3 个包                  |      |      |
| 28:20 | 保留域                            | 7'h0 | R_W  |
| 19    | 包数量(PktCnt)                    | 1'b0 | R_W  |
|       | 每当一个包写入 RxFIFO,此域减到 0.         |      |      |
| 18:7  | 保留                             |      | RO   |
| 6:0   | 传输大小(XferSize)                 | 7'h0 | R_W  |
|       | 指示端节点0的传输大小(以字节为单位),当超出这个值,    |      |      |
|       | 则将引发中断。可被设置为此端节点的MPS。每次从RxFIFO |      |      |
|       | 中读取一个包,此域减 1                   |      |      |

# Device 端节-n 传输大小寄存器(DIEPSIZn /DOEPSIZn)

◆ Endpoint\_num: 1 <= n <= 6

◆ Offset for IN: 910h + (Endpoint\_num\*20h)

◆ Offset for OUT: B10h + (Endpoint\_num\*20h)

| 域     | 说明              | 复位值  | 访问特性 |
|-------|-----------------|------|------|
| 31:29 | 保留              |      | RO   |
| 30:29 | MC (MultiCount) | 2'b0 | R_W  |
|       | 仅对 IN 端节点有效。    |      |      |



|       | 对周期性 IN 端节点,此域指定在一个 microFrame 时间内传    |       |     |
|-------|----------------------------------------|-------|-----|
|       | 输的包个数。OTG 控制器使用此域为实时 IN 端节点计算数据        |       |     |
|       | PID.                                   |       |     |
|       | ● 2'b01: 1 个包;                         |       |     |
|       | ● 2'b10: 2 个包;                         |       |     |
|       | ● 2'b11: 3 个包                          |       |     |
|       | 对于非周期性 IN 端节点,指定 OTG 控制器必须为此端节点        |       |     |
|       | 获取的包数,在转换到下由 DIEPCTLn.Nextep 指定的下一个    |       |     |
|       | 端节点时。                                  |       |     |
|       | RxPID(接收到的数据 PID)                      |       |     |
|       | 仅对实时 OUT 端节点有效                         |       |     |
|       | 此端节点接收到的最后一个包的数据 PID                   |       |     |
|       | • 2'b00: DATA0                         |       |     |
|       | • 2'b01: DATA2                         |       |     |
|       | • 2'b10: DATA1;                        |       |     |
|       | • 2'b11: MDATA;                        |       |     |
|       | SETUP 包数(SUPCnt)                       |       |     |
|       | 仅对控制 OUT 端节点有效                         |       |     |
|       | 指示此端节点能接受到的背对背 SETUP 包的数量              |       |     |
|       | ● 2'b01: 1 个包                          |       |     |
|       | ● 2'b10: 2 个包                          |       |     |
|       | ● 2'b11: 3 个包                          |       |     |
| 28:19 | 包数量(PktCnt)                            | 10'h0 | R_W |
|       | 指示在此传输大小数量下的包数目(PktCnt = XferSize/MPS) |       |     |
|       | ● IN 端节点:每当从 TxFIFO 中读取一个包,此域减 1。      |       |     |
|       | ● OUT 端节点:每当一个包写入 RxFIFO,此域减到 1。       |       |     |
| 18:0  | 传输大小(XferSize)                         | 19'b0 | R_W |
|       | 指示端节点的传输大小(以字节为单位)。                    |       |     |
|       | ● 每次从 RxFIFO 中读取一个包,此域减 1              |       |     |
|       | ● 每次一个包写入 TxFIFO,此域减 1                 |       |     |
|       |                                        |       |     |

# Device 端节-n DMA 地址寄存器(DIEPDMAn/DOEPDMAn)

◆ Endpoint\_num: 1 <= n <= 6

◆ Offset for IN: 914h + (Endpoint\_num\*20h)

◆ Offset for OUT: B14h + (Endpoint\_num\*20h)

| X   X   X   X   X   X   X   X   X   X | 域 | 说明 | 复位值 | 访问特性 |  |
|---------------------------------------|---|----|-----|------|--|
|---------------------------------------|---|----|-----|------|--|



| 31:0 | DMA 地址(DMAAddr)                    | Χ | R_W |
|------|------------------------------------|---|-----|
|      | 保存分配给此 endpoint 的外部存储的起始地址         |   |     |
|      | ● 非 Scatter/Gather DMA 模式下,为起始地址   |   |     |
|      | ● Scatter/Gather DMA 模式下,为描述符表的基准地 |   |     |
|      | 址                                  |   |     |

#### Device 端节-n DMA Buffer 地址寄存器 (DIEPDMABn/DOEPDMABn)

◆ Endpoint\_num: 1 <= n <= 6

◆ Offset for IN: 91Ch + (Endpoint\_num\*20h)

◆ Offset for OUT: B1Ch + (Endpoint\_num\*20h)

| 域    | 说明                            | 复位值 | 访问特性 |
|------|-------------------------------|-----|------|
| 31:0 | DMA buffer 地址(DMABufferAddr)  | Х   | RO   |
|      | 保存当前 buffer 的地址。当对应此端节点的数据传输在 |     |      |
|      | 进行时,此地址将实时更新。                 |     |      |
|      | 仅在 Scatter/Gather DMA 模式下有效。  |     |      |
|      |                               |     |      |

#### Device IN 端节点-nTxFIFO 状态寄存器(DTXSTSn)

◆ Endpoint\_num: 1 <= n <= 6</p>

◆ Offset 918h + (Endpoint\_num\*20h)

| 域     | 说明                                   | 复位值 | 访问特性 |
|-------|--------------------------------------|-----|------|
| 31:16 | 保留                                   |     | RO   |
| 15: 0 | IN 端节点 TxFIFO 可用空间(INEPTxFSpcAvail)  |     | RO   |
|       | 以 32 字节为单位。<br>● 16'h0: 端节点 TxFIFO 满 |     |      |
|       | ● 16'h1: 一个字可用                       |     |      |
|       |                                      |     |      |
|       | ● 16'hn: n 个字可用                      |     |      |
|       | ● 其他: 保留                             |     |      |

#### 13.3.5 功耗与门控时钟寄存器

时钟控制寄存器功耗与门控 (PCGCCTL)

#### ◆ Offset E00h

| 域    | 说明                                 | 复位值  | 访问特性 |
|------|------------------------------------|------|------|
| 31:9 | 保留                                 |      | RO   |
| 8    | 挂起后复位(ResetAfterSusp)              | 1'b1 | R_W  |
|      | 如果 host 需要在挂起后发出复位,那么在 clamp 移除之前, |      |      |
|      | 软件需置 1 此位。如果此位未置 1,那么 host 在挂起之后发出 |      |      |
|      | 复位信号                               |      |      |



| 7 | 深度睡眠(L1 Suspended)                       | 1'b0 | RO  |
|---|------------------------------------------|------|-----|
|   | 当处于 L1 状态时,PHY 进入深度睡眠。                   |      |     |
| 6 | PHY 睡眠(PhySleep)                         | 1'b0 | RO  |
|   | PHY 进入睡眠状态。                              |      |     |
| 5 | 使能睡眠门控(Enbl_L1Gating)                    | 1'b0 | R_W |
|   | 如果 OTG 控制器不能置位 utmi_l1_suspend_n 时,设置此位  |      |     |
|   | 后,在睡眠状态下能对内部时钟做门控                        |      |     |
| 4 | 保留                                       |      | RO  |
| 3 | 复位低功耗模块(RstPdwnModule)                   | 1'b0 | R_W |
|   | 当断电时,软件置 1.在上电以及 PHY 时钟起来后,软件清 0         |      |     |
| 2 | 供电隔离 (PwrClmp)                           | 1'b0 | R_W |
|   | 在关电之前,软件将此位置 1 用来隔离 power-on 与 power-off |      |     |
|   | 模块。在上电之前,软件清0                            |      |     |
| 1 | 门控 Hclk(GateHclk)                        | 1'b0 | R_W |
|   | 置 1,则当 USB 处于挂起状态时,对 Hclk 使用门控时钟。当       |      |     |
|   | USB 恢复或新的对话开始时,软件清 0                     |      |     |
| 0 | 停止 Pclk(StopPclk)                        | 1'b0 | R_W |
|   | 置 1,则当 USB 处于挂起状态时,停止 PHY 时钟。当 USB       |      |     |
|   | 恢复或新的对话开始时,软件清 0                         |      |     |

# 14 通用 DMA

龙芯 1C 处理器包含一个 DMA 模块,共有三路 DMA,用于块数据或者流数据的操作,以提高处理器工作效率。1C 芯片一共有五个模块(SDIO、ADC、AC97、I2S、NAND)会用到通用 DMA,通过软件配置共用三路 DMA。

# 14.1 DMA 控制器结构描述

DMA 传送数据的过程由三个阶段组成:

- 1. 传送前的预处理:由 CPU 完成以下步骤:配置 DMA 描述符相关的寄存器。
- 2. 数据传送: 在 DMA 控制器的控制下自动完成。
- 3. 传送结束处理:发送中断请求。

本 DMA 控制器限定为以字(4 字节)为单位的数据搬运。设计了下个描述 符地址寄存器、源地址寄存器、目的地址寄存器、传送字数计数器、传送步长间 183



隔、传送循环次数、DMA 控制逻辑等必备寄存器。DMA 的缓存大小为 128Byte (32x4Byte),以字为单位读写。

CPU 通过配置 DMA 寄存器,将来自于内存或设备的数据保存在缓存中,将缓存中的数据写入要对应的内存或设备中去,最后发送 DMA 传输结束信号。在 DMA 传输过程中,CPU 可以随时监听 DMA 的工作状态。

# 14.2 DMA 寄存器

#### 14.2.1 ORDER\_ADDR\_IN

中文名: 该寄存器广播到三路 DMA,被选中的 DMA 根据寄存器的配置开始工作

寄存器位宽: [31: 0] 地址: 0xbfd0\_1160 复位值: 0x00000000

| 夕世山; | 0.00000000  |    |       |                                 |
|------|-------------|----|-------|---------------------------------|
| 位域   | 位域名称        | 位宽 | 访问    | 描述                              |
| 31:6 | Ask_addr    | 26 | R/W   | 被选中 DMA 第一个描述符地址的高 26 位, 低 6    |
|      |             |    |       | 位为 0;相当于 26 为的 Ask_addr 左移 6 位。 |
| 5    | 保留          | 1  |       |                                 |
| 4    | dma_stop    | 1  | R/W   | 用户请求停止 DMA 操作;                  |
| •    | ama_otop    | '  | 10,00 | 完成当前数据读写操作后,停止操作                |
|      |             |    |       | 可以开始读描述符链的第一个 DMA 描述符;          |
| 3    | dma_start   | 1  | R/W   | 当第一个描述符相关的寄存器读回后,该位清            |
|      |             |    |       | 零                               |
|      |             |    |       | 用户请求将当前 DMA 操作的相关信息写回到          |
| 2    | Ask_valid   | 1  | R/W   | 指定的内存地址;                        |
|      |             |    |       | 当用户写回 DMA 操作相关信息后,该位清零。         |
|      |             |    |       | 表示当前 DMA 的通道,使用哪一路 DMA。为        |
| 1:0  | DMA_channel | 2  | R/W   | 0表示第0路,为1表示第1路,为2表示第2           |
|      |             |    |       | 路,3为保留值                         |

#### 说明:

第一个描述符的地址在 ORDER\_ADDR\_IN 寄存器中,该寄存器由 CPU 来配置,也就是 Ask addr 左移 6 位后组成了所有描述符寄存器的基地址。

每次 DMA 操作,DMA\_ORDER\_ADDR 寄存器存放的下个描述符的地址和有效位。

如果 ask\_valid=1,表示 CPU 要侦听 DMA 操作,此时要将 DMA 控制器寄存器的值写 回到 ask addr 指向的内存中。

如果 dma\_start=1,表示开始 DMA 操作,DMA 先从 ask\_addr 指向的内存地址读描述符,然后根据描述符的信息开始执行 DMA 操作。

#### 14.2.2 DMA ORDER ADDR

中文名: 下一个描述符地址寄存器

寄存器位宽: [31:0]

基地址: 描述符地址低 5 位清 0

偏移地址: 0x0

复位值: 0x00000000

| 火压田• | 000000000      |    |     |                  |
|------|----------------|----|-----|------------------|
| 位域   | 位域名称           | 位宽 | 访问  | 描述               |
| 31:1 | dma_order_addr | 31 | R/W | 存储器内部下一个描述符地址寄存器 |
| 0    | Dma_order_en   | 1  | R/W | 描述符是否有效信号        |

说明:存储下一个 DMA 描述符的地址,dma\_order\_en 是下个 DMA 描述符的使能位,如果该位为 1 表示下个描述符有效,该位为 0 表示下个描述符无效,不执行操作,地址 16 字节对齐。在配置 DMA 描述符时,该寄存器存放的是下个描述符的地址,执行完该次 DMA



操作后,通过判断 dma order en 信号确定是否开始下次 DMA 操作。

#### **14.2.3** DMA SADDR

中文名: 内存地址寄存器

寄存器位宽: [31:0]

基地址: 描述符地址低 5 位清 0

偏移地址: 0x4

复位值: 0x00000000

| 位域   | 位域名称      | 位宽 | 访问  | 描述          |
|------|-----------|----|-----|-------------|
| 31:0 | dma_saddr | 32 | R/W | DMA 操作的内存地址 |

说明: DMA 操作分为: 从内存中读数据,保存在 DMA 控制器的缓存中,由 APB 发请求来访问 DMA 缓存中的数据,该寄存器指定了读内存的地址;从 APB 设备读数据保存在 DMA 缓存中,当 DMA 缓存中的字超过一定数目,就往内存中写,该寄存器指定了写内存的地址。

#### **14.2.4** DMA\_DADDR

中文名: 设备地址寄存器

寄存器位宽: [31: 0]

基地址: 描述符地址低5位清0

偏移地址: 0x8

复位值: 0x00000000

| 位域    | 位域名称      | 位宽 | 访问  | 描述                                  |
|-------|-----------|----|-----|-------------------------------------|
| 31    |           | 1  | R/W | AC97 写使能,"1"表示是写操作                  |
| 30    |           | 1  | R/W | 0:mono 1: 2 stero                   |
| 29:28 |           | 2  | R/W | AC97 写模式,0: 1byte,1: 2byte,2: 4byte |
| 27:0  | dma_daddr | 32 | R/W | DMA 操作的 APB 设备地址                    |

说明:从内存中读数据,保存在 DMA 控制器的缓存中,由 APB 发请求来访问 DMA 缓存中的数据,该寄存器指定了写 APB 设备的地址;从 APB 设备读数据保存在 DMA 缓存中,当 DMA 缓存中的字超过一定数目,就往内存中写,该寄存器指定了读 APB 设备的地址。

#### **14.2.5** DMA\_LENGTH

中文名: 长度寄存器 寄存器位宽: [31: 0]

基地址: 描述符地址低5位清0

偏移地址: 0xc

复位值: 0x00000000

| 位域   | 位域名称       | 位宽 | 访问  | 描述        |
|------|------------|----|-----|-----------|
| 31:0 | dma_length | 32 | R/W | 传输数据长度寄存器 |

说明:代表一块被搬运内容的长度,单位是字。当搬运完 length 长度的字之后,开始下个 step 即下一个循环。开始新的循环,则再次搬运 length 长度的数据。当 step 变为 1,单个 DMA 描述符操作结束,开始读下个描述符。

#### 14.2.6 DMA\_STEP\_LENGTH

中文名: 间隔长度寄存器

寄存器位宽: [31:0]

基地址: 描述符地址低5位清0

偏移地址: 0x10

复位值: 0x00000000

185



| 位域   | 位域名称            | 位宽 | 访问  | 描述          |
|------|-----------------|----|-----|-------------|
| 31:0 | dma_step_length | 32 | R/W | 数据传输间隔长度寄存器 |

说明:间隔长度说明两块被搬运内存数据块之间的长度,前一个 step 的结束地址与后一个 step 的开始地址之间的间隔。

#### 14.2.7 DMA STEP TIMES

中文名: 循环次数寄存器

寄存器位宽: [31:0]

基地址: 描述符地址低5位清0

偏移地址: 0x14

复位值: 0x00000000

| 位域   | 位域名称           | 位宽 | 访问  | 描述          |
|------|----------------|----|-----|-------------|
| 31:0 | dma_step_times | 32 | R/W | 数据传输循环次数寄存器 |

说明:循环次数说明在一次 DMA 操作中需要搬运的块的数目。如果只想搬运一个连续的数据块,循环次数寄存器的值可以赋值为 1。

#### **14.2.8** DMA CMD

中文名: 控制寄存器 寄存器位宽: [31: 0]

基地址: 描述符地址低5位清0

偏移地址: 0x18 复位值: 0x00000000

| 位域   | 位域名称                  | 位宽 | 访问  | 描述                      |
|------|-----------------------|----|-----|-------------------------|
| 12   | dma_r_w               | 1  | R/W | DMA 操作类型,"1"为读内存写设备,"0" |
|      |                       |    |     | 为读设备写内存                 |
| 11:8 | dma_write_state       | 4  | R   | DMA 写数据状态               |
| 7:4  | dma_read_state        | 4  | R   | DMA 读数据状态               |
| 3    | dma_trans_over        | 1  | R   | DMA 执行完被配置的所有描述符操作      |
| 2    | dma_single_trans_over | 1  | R   | DMA 执行完一次描述符操作          |
| 1    | dma_int               | 1  | R   | 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 包括以下几个写状态:

|               |       | <b>1</b>                                                        |
|---------------|-------|-----------------------------------------------------------------|
| 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 处于写内存操作完                            |



|                |       | 成状态                                  |
|----------------|-------|--------------------------------------|
| 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 ST | ATE[3:0])描述,DMA | 、包括以下几个读状态: |
|-----------------|-----------------|-------------|
|-----------------|-----------------|-------------|

| Read_state       | 【3:0】 | 描述                                     |
|------------------|-------|----------------------------------------|
| Read_idle        | 4' h0 | 读状态正处于空闲状态                             |
| Read_ready       | 4' h1 | 接收到开始 dma 操作的 start 信号后,进入准备好状态,开始读描述符 |
| 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           |

# 14.3 多个模块使用 DMA 配置说明

如果某个模块需要使用 DMA 操作,则需要发送请求到 DMA 的 req 信号。 通过配置 misc\_ctrl 寄存器,将该模块的 req 信号连接到 DMA 的 req[2:0]信号上 之后,才能正常使用 DMA。

其中 SDIO 的优先级最高,可以配置为 3 通道中的任意一路; 当 SDIO 不使用第 0 通道时,NAND 使用第 0 通道; 当 SDIO 不使用第 1 通道时,I2S 和 AC97 复用第 1 通道; 当 SDIO 不使用第 2 通道路,ADC、I2S、AC97 复用第 2 通道。ADC 优先级比 I2S 和 AC97 要高。

DMA 复用配置对应 misc\_ctrl[25:22], 其中 misc\_ctrl[22]为 adc\_dma\_en, misc\_ctrl[24:23]为 sdio\_dma\_en, misc\_ctrl[25]为 ac97\_en。

比如 SDIO 使用第 1 通道, ADC 使用第 2 通道, NAND 使用第 0 通道, 则应该配置如下:

sdio\_dma\_en 为 2, adc\_dma\_en 为 1, ac97 和 I2S 都不能使用 DMA。

如果 SDIO 使用第 0 通道, ADC 使用第 2 通道, I2S 使用第 1 通道, 则应该配置如下:

sdio\_dma\_en 为 1, adc\_dma\_en 为 1, ac97\_en 为 0。



# 15 SPIO 控制器

串行外围设备接口 SPI 总线技术是 Motorola 公司推出的多种微处理器、微控制器以及外围设备之间的一种全双工、同步、串行数据接口标准。

### 15.1 SPI 控制器结构

本系统集成的 SPI 控制器仅可作为主控端,所连接的是从设备。对于软件而言,SPI 控制器除了有若干 IO 寄存器外还有一段映射到 SPI Flash 的只读 memory 空间。如果将这段 memory 空间分配在 0xbfc00000,复位后不需要软件干预就可以直接访问,从而支持处理器从 SPI Flash 启动。SPI 的 IO 寄存器的基地址 0xbfe8\_0000,外部存储地址空间是 0xbd00\_0000 - 0xbd7f\_ffff 共 8MB。

其结构如图 15-1 所示,由 AXI 内部总线接口、简单的 SPI 主控制器、SPI Flash 读引擎和总线选择模块组成。根据访问的地址和类型,来自内部总线接口上的合法请求转发到 SPI 主控制器或者 SPI Flash 读引擎中(非法请求被丢弃)。



# 15.2配置寄存器

| 偏移 | 名称            | 描述      |
|----|---------------|---------|
| 0  | SPCR          | 控制寄存器   |
| 1  | SPSR          | 状态寄存器   |
| 2  | TxFIFO/RxFIFO | 数据寄存器   |
| 3  | SPER          | 外部寄存器   |
| 4  | SFC_PARAM     | 参数控制寄存器 |
| 5  | SFC_SOFTCS    | 片选控制寄存器 |
| 6  | SFC_TIMING    | 时序控制寄存器 |

#### 15.2.1 控制寄存器(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 |
|     |      |     |    | 一起使用                        |

# 15.2.2 状态寄存器(SPSR)

| 位域  | 名称      | 访问  | 初值 | 描述                    |
|-----|---------|-----|----|-----------------------|
| 7   | spif    | R/W | 0  | 中断标志位 1 表示有中断申请,写 1 则 |
|     |         |     |    | 清零                    |
| 6   | wcol    | R/W | 0  | 写寄存器溢出标志位 为 1 表示已经溢   |
|     |         |     |    | 出,写1则清零               |
| 5:4 | =       | -   | 0  | 保留                    |
| 3   | wffull  | R   | 0  | 写寄存器满标志 1 表示已经满       |
| 2   | wfempty | R   | 1  | 写寄存器空标志 1 表示空         |
| 1   | rffull  | R   | 0  | 读寄存器满标志 1 表示已经满       |
| 0   | rfempty | R   | 1  | 读寄存器空标志 1 表示空         |

# 15.2.3 数据寄存器(TxFIFO/RxFIFO)

| 位均 | Ž | 名称     | 访问 | 初值 | 描述     |
|----|---|--------|----|----|--------|
| 7: | 0 | TxFIFO | W  | -  | 数据发送端口 |
|    |   | RxFIFO | R  |    | 数据接收端口 |

# **15.2.4** 外部寄存器(SPER)

| 位域  | 名称   | 访问  | 初值 | 描述              |
|-----|------|-----|----|-----------------|
| 7:6 | icnt | R/W | 0  | 传输完多少个字节后发中断    |
|     |      |     |    | 00: 1           |
|     |      |     |    | 01: 2           |
|     |      |     |    | 10: 3           |
|     |      |     |    | 11: 4           |
| 5:3 | _    | -   | -  | 保留              |
| 2   | mode | R/W | 0  | spi 接口模式控制      |
|     |      |     |    | 0: 采样与发送时机同时    |
|     |      |     |    | 1: 采样与发送时机错开半周期 |
| 1:0 | spre | R/W | 0  | 与 spr 一起设定分频的比率 |

#### 表 15-1 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 |



#### **15.2.5** 参数控制寄存器(SFC\_PARAM)

| 位域  | 名称        | 访问  | 初值 | 描述                         |
|-----|-----------|-----|----|----------------------------|
| 7:4 | clk_div   | R/W | 2  | 时钟分频数选择                    |
|     |           |     |    | 分频系数与{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]可由 |
|     |           |     |    | 软件控制。                      |

注:通过 EJTAG 往 SPI flash 烧写时需要将 memory\_en 置为 0。

## **15.2.6** 片选控制寄存器(SFC\_SOFTCS)

| 位域  | 名称   | 访问  | 初值 | 描述                     |
|-----|------|-----|----|------------------------|
| 7:4 | csn  | R/W | 0  | csn 引脚输出值              |
| 3:0 | csen | R/W | 0  | 为1时对应位的 csn 线由 7:4 位控制 |

## **15.2.7** 时序控制寄存器(SFC\_TIMING)

| 位域  | 名称    | 访问  | 初值 | 描述                                                                      |
|-----|-------|-----|----|-------------------------------------------------------------------------|
| 7:3 | =     | =   | =  | 保留                                                                      |
| 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          |

# 15.3 接口时序

#### 15.3.1 SPI 主控制器接口时序





#### 15.3.2 SPI Flash 访问时序



图 15-3 SPI Flash 标准读时序



图 15-4 SPI Flash 快速读时序



图 15-5 SPI Flash 双向 I/0 读时序

# 15.4 使用指南

#### 15.4.1 SPI 主控制器的读写操作

- 1. 模块初始化
  - 停止 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

#### 2. 模块的发送/传输操作

- 往数据传输寄存器写入数据
- 传输完成后从数据传输寄存器读出数据。由于发送和接收同时进行,即使 SPI 从设备没有发送有效数据也必须进行读出操作。

#### 3. 中断处理

- 接收到中断申请
- 读状态寄存器 spsr 的值,若 spsr[2]为1则表示数据发送完成,若 spsr[0] 为1则表示已经接收数据
- 读或写数据传输寄存器
- 往状态寄存器 spsr 的 spif 位写 1,清除控制器的中断申请

### **15.4.2** 硬件 SPI Flash 读

#### 1. 初始化

- 将 SFC\_PARAM 的 memory\_en 位写 1。当 SPI 被选为启动设备时此位复位为 1。
- 设置读参数(时钟分频、连续地址读、快速读、双 I/O、tCSH 等)。这些参数复位值均为最保守的值。

#### 2. 更改参数

如果所使用的 SPI Flash 支持更高的频率或者提供增强功能,修改相应参数可以大大加快 Flash 的访问速度。参数的修改不需要关闭 SPI Flash 读使能 (memory\_en)。具体参考寄存器说明。

#### **15.4.3** 混合访问 SPI Flash 和 SPI 主控制器

● 对 SPI Flash 进行读以外的访问

将 SPI Flash 读使能关闭后,软件就可直接控制 csn[0],并通过 SPI 主控制器 访问 SPI 总线。这意味着在进行此操作时,不能从 SPI Flash 中取指。



除了读以外, SPI Flash 还实现了很多命令(如擦除、写入), 具体参见相关 Flash 的文档。



# 16 SPI1 控制器

串行外围设备接口 SPI 总线技术是 Motorola 公司推出的多种微处理器、微控制器以及外围设备之间的一种全双工、同步、串行数据接口标准。

## 16.1 SPI 主控制器结构

SPI1 和 SPI0 的实现完全一样,系统启动地址不会映射到 SPI1 控制器,所以 SPI1 不支持系统启动。SPI1 的 IO 寄存器的基地址 0xbfec0000,SPI1 的外部存储 地址空间是 0xbe00,0000 - 0xbe3f,ffff 共 4MB。所有结构和配置相关请参考第 15 章信息。



# 17 AC97 控制器

# 17.1 概述(1C2 无该模块)

在系统里一个 AC97 应用系统如 图 19-1 所示。在一个片上系统中,与 AC97 控制器相连的有 3 部分:一是外设总线,接收来自微处理器的控制信息以及配置信息;二是 AC97 Codec,多媒体数字信号编解码器,该解码器对 PCM 信号进行调制,输出人耳接受的模拟声音或者把真实的声音转换为 PCM 信号,转换通过 D/A 转换器实现;三是 DMA 引擎,通过 DMA 的方式写或读 AC97 控制器内部的 FIFO,实现 PCM 音频数据的不间断操作。 DMA 是通过微处理器配置的,从处理器设定的内存区域搬运数据给 FIFO 或者把 FIFO 的数据搬运到设定的内存区域。



17.2 AC97 控制器寄存器

本模块寄存器物理地址基址为 0xbfe6\_0000。

| 寄存器名 | 宽度 | 偏移量  | 描述          |
|------|----|------|-------------|
| CSR  | 2  | 0x00 | 配置状态寄存器     |
| OCC0 | 24 | 0x04 | 输出通道配置寄存器 0 |
| OCC1 | 24 | 0x08 | 保留          |
| OCC2 | 24 | 0x0c | 保留          |
| ICC  | 24 | 0x10 | 输入通道配置寄存器   |



| 寄存器名     | 宽度 | 偏移量  | 描述            |
|----------|----|------|---------------|
| CODEC_ID | 32 | 0x14 | Codec ID 寄存器  |
| CRAC     | 32 | 0x18 | Codec 寄存器访问命令 |
| OC0      | 20 | 0x20 | 输出声道 0        |
| OC1      | 20 | 0x24 | 输出声道 1        |
| OC2      | 20 | 0x28 | 保留            |
| OC3      | 20 | 0x2c | 保留            |
| OC4      | 20 | 0x30 | 保留            |
| OC5      | 20 | 0x34 | 保留            |
| OC6      | 20 | 0x38 | 保留            |
| OC7      | 20 | 0x3c | 保留            |
| OC8      | 20 | 0x40 | 保留            |
| IC0      | 20 | 0x44 | 保留            |
| IC1      | 20 | 0x48 | 保留            |
| IC2      | 20 | 0x4c | 输入声道 2        |
| INTRAW   | 32 | 0x54 | 中断状态寄存器       |
| INTM     | 32 | 0x58 | 中断掩膜          |
| INTS     | 32 | 0x5c | 保留            |

## **17.2.1** CSR 寄存器

中文名: 配置状态寄存器

寄存器位宽: [31: 0] 偏移量: 0x00

复位值: 0x00000000

| 位域   | 位域名称      | 位宽 | 访问  | 描述                      |
|------|-----------|----|-----|-------------------------|
| 31:2 | Reserved  | 30 | RO  | 保留                      |
| 1    | RESUME    | 1  | R/W | 挂起,读此位返回现在 AC97 子系统的    |
|      |           |    |     | 状态                      |
|      |           |    |     | 1: AC97 子系统挂起           |
|      |           |    |     | 0: 正常工作状态               |
|      |           |    |     | 在挂起状态下,写入 1 到该位,将会开     |
|      |           |    |     | 始恢复操作。                  |
| 0    | RST_FORCE | 1  | W   | AC97 冷启动                |
|      |           |    |     | 写入 1 会导致 AC97 Codec 冷启动 |

#### **17.2.2** OCC 寄存器

中文名: 输出通道配置寄存器

寄存器位宽: [31: 0] 偏移量: 0x04

| 位域    | 位域名称      | 位宽 | 访问  | 描述             |
|-------|-----------|----|-----|----------------|
| 31:24 | Reserved  | 8  | R/W | 保留             |
| 23:16 | Reserved  | 8  | R/W | 保留             |
| 15:8  | OC1_CFG_R | 8  | R/W | 输出通道 1: 右声道配置。 |
| 7:0   | OC0_CFG_L | 8  | R/W | 输出通道 0: 左声道配置。 |



#### 17.2.3 ICC 寄存器

中文名: 输入通道配置寄存器

寄存器位宽: [31: 0] 偏移量: 0x10

复位值: 0x00410000

| 位域    | 位域名称       | 位宽 | 访问  | 描述                |
|-------|------------|----|-----|-------------------|
| 31:24 | Reserved   | 8  | R/W | 保留                |
| 23:16 | IC_CFG_MIC | 8  | R/W | 输入通道 2: MIC 声道配置。 |
| 15:8  | Reserved   | 8  | R/W | 保留                |
| 7:0   | Reserved   | 8  | R/W | 保留                |

OCC 和 ICC 寄存器中的声道配置格式相同,即 17.2.2 中 OCC 寄存器的OC0\_CFG\_L 和 OC0\_CFG\_R 域,以及 17.2.3 中 OCC 寄存器的IC\_CFG\_MIC域,声道格式说明如下:

| 位域  | 位域名称       | 位宽 | 访问  | 描述                        |
|-----|------------|----|-----|---------------------------|
| 7   | Reserved   | 1  | R/W | 保留                        |
| 6   | DMA_EN     | 1  | R/W | DMA 使能                    |
|     |            |    |     | 1: DMA 打开                 |
|     |            |    |     | 0: DMA 关闭                 |
| 5:4 | FIFO_THRES | 2  | R/W | FIFO 门限                   |
|     |            |    |     | 5: 4 输出通道 输入通道            |
|     |            |    |     | 00: FIFO 1/4 空 FIFO 1/4 满 |
|     |            |    |     | 01: FIFO 1/2 空 FIFO 1/2 满 |
|     |            |    |     | 10: FIFO 3/4 空 FIFO 3/4 满 |
|     |            |    |     | 11: FIFO 全空 FIFO 全满       |
| 3:2 | SW         | 2  | R/W | 采样位数                      |
|     |            |    |     | 00:8位                     |
|     |            |    |     | 10: 16 位                  |
| 1   | VSR        | 1  | R/W | 采样率                       |
|     |            |    |     | 1: 采样率可变                  |
|     |            |    |     | 0: 采样率固定(48KHz)           |
| 0   | CH_EN      | 1  | R/W | 通道使能                      |
|     |            |    |     | 1: 通道打开                   |
|     |            |    |     | 0: 通道关闭(或者进入节能状态)         |

#### 17.2.4 Codec 寄存器访问命令

中文名: Codec 寄存器访问命令

寄存器位宽: [31: 0] 偏移量: 0x18

| 位域 | 位域名称     | 位宽 | 访问  | 描述                                                       |
|----|----------|----|-----|----------------------------------------------------------|
| 31 | CODEC_WR | 1  | R/W | 读/写选择 1:读,读取数据时,先设置 CODEC_WR 为读方式,并在 CODEC_ADR 设置欲访问的寄存器 |



|       |           |    |     | 地址; 等到返回数据完成中断时再读 CODEC_DAT 寄存器读取值。 0: 写 |
|-------|-----------|----|-----|------------------------------------------|
| 30:23 | Reserved  | 8  | R   | 保留                                       |
| 22:16 | CODEC_ADR | 7  | R/W | Codec 寄存器地址                              |
| 15:0  | CODEC_DAT | 16 | R/W | Codec 寄存器数据                              |

#### 17.2.5 中断状态寄存器/中断掩膜寄存器

中文名: 中断状态/中断掩膜寄存器

寄存器位宽:[31: 0]偏移量:0x54/58复位值:0x00000000

| 位域   | 位域名称       | 位宽 | 访问  | 描述                |
|------|------------|----|-----|-------------------|
| 31   | IC_FULL    | 1  | R/W | 输入通道 2: FIFO 满    |
| 30   | IC_TH_INT  | 1  | R/W | 输入通道 2: FIFO 达到门限 |
| 29:8 | Reserved   | 22 | R/W | 保留                |
| 7    | OC1_FULL   | 1  | R/W | 输出通道 1: FIFO 满    |
| 6    | OC1_EMPTY  | 1  | R/W | 输出通道 1: FIFO 空    |
| 5    | OC1_TH_INT | 1  | R/W | 输出通道 1: FIFO 达到门限 |
| 4    | OC0_FULL   | 1  | R/W | 输出通道 0: FIFO 满    |
| 3    | OC0_EMPTY  | 1  | R/W | 输出通道 0: FIFO 空    |
| 2    | OC0_TH_INT | 1  | R/W | 输出通道 0: FIFO 达到门限 |
| 1    | CW_DONE    | 1  | R/W | Codec 寄存器写完成      |
| 0    | CR_DONE    | 1  | R/W | Codec 寄存器读完成      |

#### 17.2.6 中断状态/清除寄存器

中文名: 中断状态/清除寄存器

寄存器位宽: [31: 0] 偏移量: 0x5c

复位值: 0x00000000

| 位域   | 位域名称    | 位宽 | 访问 | 描述                                          |
|------|---------|----|----|---------------------------------------------|
| 31:0 | INT_CLR | 32 | RO | 屏蔽后的中断状态寄存器,对本寄存器的 读操作将清除寄存器 0x54 中的所有中断 状态 |

#### 17.2.7 OC 中断清除寄存器

中文名: OC 中断清除

寄存器位宽: [31: 0] 偏移量: 0x60

| 位域   | 位域名称       | 位宽 | 访问 | 描述                          |
|------|------------|----|----|-----------------------------|
| 31:0 | INT_OC_CLR | 32 | RO | 对本寄存器的读操作将清除寄存器 0x54        |
|      |            |    |    | 中的所有 output channel 的中断状态对应 |
|      |            |    |    | 的 bit[7:2]                  |



#### 17.2.8 IC 中断清除寄存器

中文名: IC 中断清除

寄存器位宽: [31: 0] 偏移量: 0x64

复位值: 0x00000000

| 位域   | 位域名称       | 位宽 | 访问 | 描述                         |
|------|------------|----|----|----------------------------|
| 31:0 | INT_IC_CLR | 32 | RO | 对本寄存器的读操作将清除寄存器 0x54       |
|      |            |    |    | 中的所有 input channel 的中断状态对应 |
|      |            |    |    | 的 bit[31:30]               |

#### **17.2.9** CODEC WRITE 中断清除寄存器

中文名: CODEC WRITE 中断清除

寄存器位宽: [31: 0] 偏移量: 0x68

复位值: 0x00000000

| 位域   | 位域名称       | 位宽 | 访问 | 描述                              |
|------|------------|----|----|---------------------------------|
| 31:0 | INT_CW_CLR | 32 | RO | 对本寄存器的读操作将清除寄存器 0x54 中的中 bit[1] |

#### 17.2.10 CODEC READ 中断清除寄存器

中文名: CODEC READ 中断清除

寄存器位宽: [31: 0] 偏移量: 0x6c

| 位域   | 位域名称       | 位宽 | 访问 | 描述                   |
|------|------------|----|----|----------------------|
| 31:0 | INT_CR_CLR | 32 | RO | 对本寄存器的读操作将清除寄存器 0x54 |
|      |            |    |    | 中的中 bit[0]           |



# 18 I2C 控制器

## 18.1 概述

本章给出 I2C 的详细描述和配置使用。本系统芯片集成了 I2C 接口,主要用于实现两个器件之间数据的交换。I2C 总线是由数据线 SDA 和时钟 SCL 构成的串行总线,可发送和接收数据。器件与器件之间进行双向传送,最高传送速率400kbps。龙芯 1C 共集成 3 路 I2C 接口。

# 18.2 I2C 控制器结构

I2C 主控制器结构的主要模块包括,时钟发生器(Clock Generator)、字节命令控制器(Byte Command Controller)、位命令控制器(Bit Command controller)、数据移位寄存器(Data Shift Register)。其余为 LPB 总线接口和一些寄存器。

时钟发生器模块:产生分频时钟,同步位命令的工作。

字节命令控制器模块:将一个命令解释为按字节操作的时序,即把字节操作分解为位操作。

位命令控制器模块:进行实际数据的传输,以及位命令信号产生。数据移位寄存器模块:串行数据移位。



图 18-1 I2C 主控制器结构

# 18.3 I2C 控制器寄存器说明



I2C-0 模块寄存器物理地址基址为: 0xbfe5 8000,地址空间 16KB。

I2C-1 模块寄存器物理地址基址为: 0xbfe6\_8000,地址空间 16KB。

I2C-2 模块寄存器物理地址基址为: 0xbfe7 0000,地址空间 16KB。

#### 18.3.1 分频锁存器低字节寄存器(PRERIo)

中文名: 分频锁存器低字节寄存器

寄存器位宽: [7: 0]偏移量: 0x00复位值: 0xff

| 位域  | 位域名称   | 位宽 | 访问 | 描述          |
|-----|--------|----|----|-------------|
| 7:0 | PRERIo | 8  | RW | 存放分频锁存器的低8位 |

#### 18.3.2 分频锁存器高字节寄存器(PRERhi)

中文名: 分频锁存器高字节寄存器

寄存器位宽: [7: 0] 偏移量: 0x01 复位值: 0xff

| 位域  | 位域名称   | 位宽 | 访问 | 描述          |
|-----|--------|----|----|-------------|
| 7:0 | PRERhi | 8  | RW | 存放分频锁存器的高8位 |

模块中被分频时钟 clock\_a 的频率是 DDR\_clk 频率的的一半 (DDR\_clk 配置 见 29 章); 假设分频锁存器的值为 prescale, SCL 总线的输出频率为 clock\_s (该时钟根据用户需要和外部 I2C 设备特性确定),则应满足如下关系:

Prcescale = clock\_a/(5\*clock\_s)-1

或者 Prcescale = DDR\_clk/(10\*clock\_s)-1

#### 18.3.3 控制寄存器 (CTR)

中文名: 控制寄存器

寄存器位宽: [7: 0]偏移量: 0x02复位值: 0x00

| 位域  | 位域名称     | 位宽 | 访问 | 描述                  |
|-----|----------|----|----|---------------------|
| 7   | EN       | 1  | RW | 模块工作使能位 为1正常工作模式,0对 |
|     |          |    |    | 分频寄存器进行操作           |
| 6   | IEN      | 1  | RW | 中断使能位 为 1 则打开中断     |
| 5:0 | Reserved | 6  | RW | 保留                  |

#### 18.3.4 发送数据寄存器(TXR)

中文名: 发送寄存器

寄存器位宽: [7: 0] 偏移量: 0x03

201



复位值: 0x00

| 位域  | 位域名称 | 位宽 | 访问 | 描述                 |
|-----|------|----|----|--------------------|
| 7:1 | DATA | 7  | W  | 存放下个将要发送的字节        |
| 0   | DRW  | 1  | W  | 当数据传送时,该位保存的是数据的最低 |
|     |      |    |    | 位;                 |
|     |      |    |    | 当地址传送时,该位指示读写状态    |

#### 18.3.5 接受数据寄存器(RXR)

中文名: 接收寄存器

寄存器位宽: [7: 0]偏移量: 0x03复位值: 0x00

| 位域  | 位域名称 | 位宽 | 访问 | 描述           |
|-----|------|----|----|--------------|
| 7:0 | RXR  | 8  | R  | 存放最后一个接收到的字节 |

### 18.3.6 命令控制寄存器(CR)

中文名: 命令寄存器

寄存器位宽:[7:0]偏移量:0x04复位值:0x00

| 位域  | 位域名称     | 位宽 | 访问 | 描述          |
|-----|----------|----|----|-------------|
| 7   | STA      | 1  | W  | 产生 START 信号 |
| 6   | STO      | 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'。

#### 18.3.7 状态寄存器(SR)

中文名: 状态寄存器

寄存器位宽:[7:0]偏移量:0x04复位值:0x00

| 位域  | 位域名称     | 位宽 | 访问 | 描述                         |
|-----|----------|----|----|----------------------------|
| 7   | RxACK    | 1  | R  | 收到应答位                      |
|     |          |    |    | 1 没收到应答位<br>0 收到应答位        |
| 6   | Busy     | 1  | R  | I <sup>2</sup> c 总线忙标志位    |
|     |          |    |    | 1 总线在忙<br>0 总线空闲           |
| 5   | AL       | 1  | R  | 当 I2C 核失去 I2C 总线控制权时,该位置 1 |
| 4:2 | Reserved | 3  | R  | 保留                         |



| 1 | TIP | 1 | R | 指示传输的过程            |
|---|-----|---|---|--------------------|
|   |     |   |   | 1 表示正在传输数据         |
|   |     |   |   | 0 表示数据传输完毕         |
| 0 | IF  | 1 | R | 中断标志位,一个数据传输完,或另外一 |
|   |     |   |   | 个器件发起数据传输,该位置1     |



# 19 UART 控制器

### 19.1 概述

1C集成了十二个 UART 控制器,通过 APB 总线与总线桥通信。UART 控制器提供与 MODEM 或其他外部设备串行通信的功能,例如与另外一台计算机,以 RS232 为标准使用串行线路进行通信。 该控制器在设计上能很好地兼容国际工业标准半导体设备 16550A。

UART 控制器支持通过配置寄存器扩展为 USART 模式。USART 控制器遵循 ISO7816 的 T=0, T=1 两个基本协议,提供了对红外和智能卡接口模式的支持。

# 19.2 控制器结构

UART 控制器有发送和接收模块(Transmitter and Receiver)、MODEM 模块、中断仲裁模块(Interrupt Arbitrator)、和访问寄存器模块(Register Access Control),这些模块之间的关系见下图所示。主要模块功能及特征描述如下:

- 发送和接收模块:负责处理数据帧的发送和接收。发送模块是将 FIFO 发送队列中的数据按照设定的格式把并行数据转换为串行数据帧,并通过发送端口送出去。接收模块则监视接收端信号,一旦出现有效开始位,就进行接收,并实现将接收到的异步串行数据帧转换为并行数据,存入 FIFO 接收队列中,同时检查数据帧格式是否有错。UART 的帧结构是通过行控制寄存器(LCR)设置的,发送和接收器的状态被保存在行状态寄存器(LSR)中
- MODEM 模块: MODEM 控制寄存器 (MCR) 控制输出信号 DTR 和 RTS 的状态。MODEM 控制模块监视输入信号 DCD,CTS,DSR 和 RI 的线路状态,并将这些信号的状态记录在 MODEM 状态寄存器 (MSR) 的相对应位中。
- 中断仲裁模块:当任何一种中断条件被满足,并且在中断使能寄存器 (IER)中相应位置 1,那么 UART 的中断请求信号 UAT\_INT 被置为有 效状态。为了减少和外部软件的交互,UART 把中断分为四个级别,并 且在中断标识寄存器 (IIR)中标识这些中断。四个级别的中断按优先级



级别由高到低的排列顺序为,接收线路状态中断,接收数据准备好中断, 传送拥有寄存器为空中断; MODEM 状态中断。

● 访问寄存器模块: 当 UART 模块被选中时, CPU 可通过读或写操作访问 被地址线选中的寄存器。



图 19-1 UART 控制器结构

USART 扩展部分增加了支持 ISO7816 规范的相关寄存器,并修改了收发模块,增加了收发错误校验和重传控制功能。

# 19.3 UART0 split 配置说明

龙芯 1C 中 UARTO 的全功能串口可以分割成两个四线串口。配置寄存器见 5.2.4 节 SHUT\_CTRL[31:30]。

当 UART\_split = 0 时, UART0 的引脚作为 UART00 的全功能串口。

当 UART\_split = 1 时,UART0 分割成两个控制器 UART00 和 UART01,UART 的全功能引脚作为两个串口 UART00 和 UART01 的四线串口输出,其对应关系如下:

| 原 UARTO 功能引脚 | Uart_split = 0 | Uart_split = 1 |
|--------------|----------------|----------------|
| UART0_TXD    | UART00_TXD     | UART00_TXD     |
| UART0_RTS    | UART00_RTS     | UART00_RTS     |
| UART0_DTR    | UART00_DTR     | UART01_TXD     |
| UART0_RI     | UART00_RI      | UART01_RTS     |
| UART0_RXD    | UART00_RXD     | UART00_RXD     |
| UART0_CTS    | UART00_CTS     | UART00_CTS     |

表 19-1 UART split 配置及功能复用



| UART0_DSR | UART00_DSR | UART01_RXD |
|-----------|------------|------------|
| UART0_DCD | UART00_DCD | UART01_CTS |

UART0 和 UART01 的功能寄存器和 19.4 中描述的寄存器完全相同,只是访问基地址不同。其中 UART00 的寄存器物理地址基址为 0xbfe4\_0000, UART01 的寄存器物理地址基址为 0xbfe4\_1000,

# 19.4 寄存器描述

龙芯 1C 中有 12 个 UART/USART(记为 URT)接口,其功能寄存器完全相同, 只是访问基址不一样。

- URTO 寄存器物理地址基址为 0xbfe4\_0000。
- URT1 寄存器物理地址基址为 0xbfe4\_4000。
- URT2 寄存器物理地址基址为 0xbfe4\_8000。
- URT3 寄存器物理地址基址为 0xbfe4\_c000。
- URT4 寄存器物理地址基址为 0xbfe4 c400。
- URT5 寄存器物理地址基址为 0xbfe4\_c500。
- URT6 寄存器物理地址基址为 0xbfe4\_c600。
- URT7 寄存器物理地址基址为 0xbfe4\_c700。
- URT8 寄存器物理地址基址为 0xbfe4\_c800。
- URT9 寄存器物理地址基址为 0xbfe4 c900。
- URT10 寄存器物理地址基址为 0xbfe4\_ca00。
- URT11 寄存器物理地址基址为 0xbfe4\_cb00。

#### 19.4.1 数据寄存器(DAT)

中文名: 数据传输寄存器

寄存器位宽: [7:0]

偏移量: 0x00

复位值: 0x00

| 位域  | 位域名称    | 位宽 | 访问 | 描述      |
|-----|---------|----|----|---------|
| 7:0 | Tx FIFO | 8  | W  | 数据传输寄存器 |

#### 19.4.2 中断使能寄存器(IER)

中文名: 中断使能寄存器

206



寄存器位宽: [7:0]

偏移量: 0x01

复位值: 0x00

| 位域  | 位域名称     | 位宽 | 访问 | 描述                                 |
|-----|----------|----|----|------------------------------------|
| 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' - 打开    |
| 0   | IRxE     | 1  | RW | 接收有效数据中断使能 '0' - 关闭 '1' - 打开       |

#### 19.4.3 中断标识寄存器(IIR)

中文名: 中断源寄存器

寄存器位宽: [7:0]

偏移量: 0x02

复位值: 0xc1

| 位域  | 位域名称     | 位宽 | 访问 | 描述          |
|-----|----------|----|----|-------------|
| 7:4 | Reserved | 4  | R  | 保留          |
| 3:1 | II       | 3  | R  | 中断源表示位,详见下表 |
| 0   | INTp     | 1  | R  | 中断表示位       |

#### 中断控制功能表:

| Bit 3 | Bit 2 | Bit 1 | 优先级             | 中断类型          | 中断源                                      | 中断复位控制                  |
|-------|-------|-------|-----------------|---------------|------------------------------------------|-------------------------|
| 0     | 1     | 1     | 1 <sup>st</sup> | 接收线路状态        | 奇偶、溢出或帧错误,<br>或打断中断                      | 读 LSR                   |
| 0     | 1     | 0     | 2 <sup>nd</sup> | 接收到有效数据       | FIFO 的字符个数达到 trigger 的水平                 | FIFO 的字符个数低于 trigger 的值 |
| 1     | 1     | 0     | 2 <sup>nd</sup> | 接收超时          | 在 FIFO 至少有一个字符,但在 4 个字符时间内没有任何操作,包括读和写操作 | 读接收 FIFO                |
| 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                   |

#### 19.4.4 FIFO 控制寄存器 (FCR)

中文名: FIFO 控制寄存器



寄存器位宽: [7:0]

偏移量: 0x02

复位值: 0xc0

| 位域  | 位域名称     | 位宽 | 访问 | 描述                             |
|-----|----------|----|----|--------------------------------|
| 7:6 | TL       | 2  | W  | 接收 FIFO 提出中断申请的 trigger 值 '00' |
|     |          |    |    | - 1 字节 '01' - 4 字节             |
|     |          |    |    | '10' - 8 字节 '11' - 14 字节       |
| 5:3 | Reserved | 3  | W  | 保留                             |
| 2   | Txset    | 1  | W  | '1' 清除发送 FIFO 的内容,复位其逻辑        |
| 1   | Rxset    | 1  | W  | '1' 清除接收 FIFO 的内容,复位其逻辑        |
| 0   | Reserved | 1  | W  | 保留                             |

#### 19.4.5 线路控制寄存器(LCR)

中文名: 线路控制寄存器

寄存器位宽: [7:0]

偏移量: 0x03

复位值: 0x03

| 位域  | 位域名称 | 位宽 | 访问   | 描述                           |
|-----|------|----|------|------------------------------|
| 7   | dlab | 1  | RW   | 分频锁存器访问位                     |
|     |      |    |      | '1' - 访问操作分频锁存器              |
|     |      |    |      | '0' - 访问操作正常寄存器              |
| 6   | bcb  | 1  | RW   | 打断控制位                        |
|     |      |    |      | '1' - 此时串口的输出被置为 0(打断状态).    |
|     |      |    |      | '0' - 正常操作                   |
| 5   | spb  | 1  | RW   | 指定奇偶校验位                      |
|     |      |    |      | '0' - 不用指定奇偶校验位              |
|     |      |    |      | '1' - 如果LCR[4]位是1则传输和检查奇偶校验  |
|     |      |    |      | 位为 0。如果 LCR[4]位是 0 则传输和检查奇偶校 |
|     |      |    |      | 验位为 <b>1</b> 。               |
| 4   | eps  | 1  | RW   | 奇偶校验位选择                      |
|     |      |    |      | '0' - 在每个字符中有奇数个 1(包括数据和奇    |
|     |      |    |      | 偶校验位)                        |
|     |      |    |      | '1' - 在每个字符中有偶数个 1           |
| 3   | pe   | 1  | RW   | 奇偶校验位使能                      |
|     |      |    |      | '0' - 没有奇偶校验位                |
|     |      |    |      | '1' - 在输出时生成奇偶校验位,输入则判断奇     |
|     |      |    |      | 偶校验位                         |
| 2   | sb   | 1  | RW   | 定义生成停止位的位数                   |
|     |      |    |      | '0' - 1 个停止位                 |
|     |      |    |      | '1' - 在5位字符长度时是1.5个停止位,其他    |
| 4.0 |      |    | D)A/ | 长度是2个停止位                     |
| 1:0 | bec  | 2  | RW   | 设定每个字符的位数                    |
|     |      |    |      | '00' - 5 位 '01' - 6 位        |
|     |      |    |      | '10' - 7 位 '11' - 8 位        |

## **19.4.6** MODEM 控制寄存器(MCR)

中文名: Modem 控制寄存器

208



寄存器位宽: [7:0]

偏移量: 0x04

复位值: 0x00

| 位域  | 位域名称     | 位宽 | 访问 | 描述                                                                                                            |
|-----|----------|----|----|---------------------------------------------------------------------------------------------------------------|
| 7:5 | Reserved | 3  | W  | 保留                                                                                                            |
| 4   | Loop     | 1  | W  | 回环模式控制位 '0' - 正常操作 '1' - 回环模式。在在回环模式中,TXD输出一直为 1,输出移位寄存器直接连到输入移位寄存器中。其他连接如下。 DTR DSR RTS CTS Out1 RI Out2 DCD |
| 3   | OUT2     | 1  | W  | 在回环模式中连到 DCD 输入                                                                                               |
| 2   | OUT1     | 1  | W  | 在回环模式中连到 RI 输入                                                                                                |
| 1   | RTSC     | 1  | W  | RTS 信号控制位                                                                                                     |
| 0   | DTRC     | 1  | W  | DTR 信号控制位                                                                                                     |

# 19.4.7 线路状态寄存器(LSR)

中文名: 线路状态寄存器

寄存器位宽: [7:0]

偏移量: 0x05

| 位域 | 位域名称  | 位宽 | 访问 | 描述                                         |
|----|-------|----|----|--------------------------------------------|
| 7  | ERROR | 1  | R  | 错误表示位<br>'1' - 至少有奇偶校验位错误,帧错误或打断中          |
|    |       |    |    | 断的一个。<br>'0' - 没有错误                        |
| 6  | TE    | 1  | R  | 传输为空表示位                                    |
|    |       |    |    | '1' - 传输 FIFO 和传输移位寄存器都为空。给 传输 FIFO 写数据时清零 |
|    |       |    |    | '0' - 有数据                                  |
| 5  | TFE   | 1  | R  | 传输 FIFO 位空表示位                              |
|    |       |    |    | '1' - 当前传输 FIFO 为空,给传输 FIFO 写数             |
|    |       |    |    | 据时清零                                       |
|    |       |    |    | '0' - 有数据                                  |
| 4  | BI    | 1  | R  | 打断中断表示位                                    |
|    |       |    |    | '1' - 接收到 起始位+数据+奇偶位+停止位                   |
|    |       |    |    | 都是 0,即有打断中断                                |
|    |       |    |    | '0' - 没有打断                                 |
| 3  | FE    | 1  | R  | 帧错误表示位                                     |
|    |       |    |    | '1' - 接收的数据没有停止位                           |
|    |       |    |    | '0' - 没有错误                                 |
| 2  | PE    | 1  | R  | 奇偶校验位错误表示位                                 |
|    |       |    |    | '1' - 当前接收数据有奇偶错误                          |
|    |       |    |    | '0' - 没有奇偶错误                               |



| 位域 | 位域名称 | 位宽 | 访问 | 描述                   |
|----|------|----|----|----------------------|
| 1  | OE   | 1  | R  | 数据溢出表示位              |
|    |      |    |    | ' <b>1</b> ' - 有数据溢出 |
|    |      |    |    | '0' - 无溢出            |
| 0  | DR   | 1  | R  | 接收数据有效表示位            |
|    |      |    |    | '0' - 在 FIFO 中无数据    |
|    |      |    |    | '1' - 在 FIFO 中有数据    |

对这个寄存器进行读操作时,LSR[4:1]和 LSR[7]被清零,LSR[6:5]在给传输 FIFO 写数据时清零,LSR[0]则对接收 FIFO 进行判断。

#### 19.4.8 MODEM 状态寄存器 (MSR)

中文名: Modem 状态寄存器

寄存器位宽: [7: 0]偏移量: 0x06复位值: 0x00

| 位域 | 位域名称 | 位宽 | 访问 | 描述                        |
|----|------|----|----|---------------------------|
| 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 指示位                  |

#### 19.4.9 分频锁存器

中文名: 分频锁存器 1

寄存器位宽: [7: 0]偏移量: 0x00复位值: 0x00

| 位域  | 位域名称 | 位宽 | 访问 | 描述          |
|-----|------|----|----|-------------|
| 7:0 | LSB  | 8  | RW | 存放分频锁存器的低8位 |

中文名: 分频锁存器 2

寄存器位宽: [7: 0]偏移量: 0x01复位值: 0x00

| 位域  | 位域名称 | 位宽 | 访问 | 描述          |
|-----|------|----|----|-------------|
| 7:0 | MSB  | 8  | RW | 存放分频锁存器的高8位 |

# 19.5 USART 寄存器描述

USART 在 UART 的基础上又增加了支持 ISO7816 规范的寄存器 CR、MR和 FIDIR。

#### 19.5.1 控制寄存器 (CR)

中文名: 控制寄存器

210



寄存器位宽: [7: 0]偏移量: 0x8复位值: 0x00

| 位域  | 位域名称    | 位宽 | 访问 | 描述      |
|-----|---------|----|----|---------|
| 0   | UART_EN | 1  | RW | 串口使能    |
|     |         |    |    | 0: 不使能  |
|     |         |    |    | 1: 使能   |
| 1   | IRDA_EN | 1  | RW | 红外接口使能  |
|     |         |    |    | 0: 不使能  |
|     |         |    |    | 1: 使能   |
| 2   | SC_EN   | 1  | RW | 智能卡接口使能 |
|     |         |    |    | 0: 不使能  |
|     |         |    |    | 1: 使能   |
| 3-7 | _       | -  | -  | 保留      |

# 19.5.2 模式寄存器 (MR)

中文名: 模式寄存器 寄存器位宽: [7:0] 偏移量: 0x9 复位值: 0x00

| 位域  | 位域名称       | 位宽 | 访问 | 描述                |
|-----|------------|----|----|-------------------|
| 0-3 | USART_MODE | 4  | RW | USART 的工作模式:      |
|     |            |    |    | 0000: Normal      |
|     |            |    |    | 0001: 串口          |
|     |            |    |    | 0010:硬件握手         |
|     |            |    |    | 0011: modem       |
|     |            |    |    | 0100: IS07816 T=0 |
|     |            |    |    | 0110: IS07816 T=1 |
|     |            |    |    | 1000: IrDA        |
|     |            |    |    | Others:保留         |
| 4-7 | -          | -  | -  | 保留                |

#### 19.5.3 FI/DI 参数寄存器(FIDIR)

中文名: 模式寄存器 寄存器位宽: [31: 0] 偏移量: 0xA

| 位域    | 位域名称        | 位宽 | 访问 | 描述                                               |
|-------|-------------|----|----|--------------------------------------------------|
| 0-10  | FI_DI_RATIO | 11 | RW | 0: IS07816 模式不产生波特率信号<br>1~2047: IS07816 产生波特率信号 |
| 11-31 | -           | _  | _  | 保留                                               |



# 20 NAND 控制器

# 20.1 NAND 控制器结构描述

NAND FLASH 控制器最多支持 4 个片选和 4 个 RDY 信号, 控制器支持 SLC 和 MLC 两种类型 FLASH 的操作, 支持 512Bytes、2K、4K、8K 页大小 FLASH 操作, 最大支持单片 8GB 容量, 4 片共 32GB 容量。NAND FLASH 控制器支持系统启动, 启动模式包括 ECC 模式启动和普通模式启动。

系统启动模式选择包括两种,如下表所示:

| 启动模式   | 配置            | 说明                              |
|--------|---------------|---------------------------------|
| ECC 模式 | NAND_CLE 外部上拉 | 外部 NAND FLASH 中的第一个 page 的内容必须是 |
| 启动     |               | 原始数据经过 RS(204,188)译码后生成的数据      |
| 普通启动   | NAND_CLE 外部下拉 | 外部 NAND FLASH 第一个 page 的数据普通原始数 |
|        |               | 据                               |

## 20.2 NAND 控制器寄存器配置描述

NAND 内部的寄存器的列表如下:

| 地址          | 寄存器名称              |
|-------------|--------------------|
| 0xbfe7_8000 | NAND_CMD           |
| 0xbfe7_8004 | ADDR_C             |
| 0xbfe7_8008 | ADDR_R             |
| 0xbfe7_800C | NAND_TIMING        |
| 0xbfe7_8010 | ID_L               |
| 0xbfe7_8014 | STATUS & ID_H      |
| 0xbfe7_8018 | NAND_PARAMETER     |
| 0xbfe7_801C | NAND_OP_NUM        |
| 0xbfe7_8020 | CS_RDY_MAP         |
| 0xbfe7_8040 | DMA access address |

#### 20.2.1 命令寄存器(NAND\_CMD)

|        | 201211 AP & HJ [] HH (10 11 12 _ CM 2) |     |                            |  |  |
|--------|----------------------------------------|-----|----------------------------|--|--|
| 位      | 位域名                                    | 读写  | 描述                         |  |  |
| 31     | DMA_REQ                                | R/- | 非 ECC 模式下 NAND 发出 DMA 请求   |  |  |
| 30     | ECC_DMA_REQ                            | R/- | ECC 模式下 NAND 发出 DMA 请求     |  |  |
| 29:25  | STATUS                                 | R/- | 内部状态机 (供测试用)               |  |  |
| 24     |                                        | R/- | Reserved                   |  |  |
| 23: 20 | NAND_CE                                | R/- | 外部 NAND 芯片片选情况,四位分别对应片外    |  |  |
|        |                                        |     | 四个片选,0表示选中                 |  |  |
| 19: 16 | NAND_RDY                               | R/- | 外部 NAND 芯片 RDY 情况,对应关系和    |  |  |
|        |                                        |     | NAND_CE 一致,1 表示准备好         |  |  |
| 15     |                                        |     | Reserved                   |  |  |
| 14     | Wait_rs_rd_done                        | R/W | 为 1 表示等待 ECC 读完成(用于 ECC 读) |  |  |
| 13     | INT_EN                                 | R/W | NAND 中断使能信号,为 1 表示使能中断     |  |  |



| 12 | RS_WR           | R/W | 为 1 表示写操作时候 ECC 功能开启       |
|----|-----------------|-----|----------------------------|
| 11 | RS_RD           | R/W | 为 1 表示读操作时候 ECC 功能开启       |
| 10 | done            | R/W | 为 1 表示操作完成,需要软件清零          |
| 9  | Spare           | R/W | 为 1 表示操作发生在 NAND 的 SPARE 区 |
| 8  | Main            | R/W | 为 1 表示操作发生在 NAND 的 MAIN 区  |
| 7  | Read status     | R/W | 为 1 表示读 NAND 的状态操作         |
| 6  | Reset           | R/W | 为 1 表示 Nand 复位操作           |
| 5  | read id         | R/W | 为 1 表示读 ID 操作              |
| 4  | blocks erase    | R/W | 连续擦除标志,缺省0;1有效,连续擦擦块的      |
|    |                 |     | 数目由 nand_op_num 决定         |
| 3  | erase operation | R/W | 为 1 表示擦除操作                 |
| 2  | write operation | R/W | 为 1 表示写操作                  |
| 1  | read operation  | R/W | 为 1 表示读操作                  |
| 0  | command valid   | R/W | 为 1 表示命令有效,操作完成后硬件自动清零     |

# 20.2.2 页内偏移地址寄存器(ADDR\_C)

| 位域名      | 读写  | 描述                                                                                                                                                                                                                                          |
|----------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | R/- | Reserved                                                                                                                                                                                                                                    |
| Nand_Col | R/W | 读、写、擦除操作起始地址页内地址<br>(必须以字对齐,为 4 的倍数),和页大小<br>对应关系如下:<br>512Bytes: 只需要填充[8:0]<br>2K: 需要填充[11:0], [11]表示 spare<br>区, [10:0]表示页内偏移地址<br>4K: 需要填充[12:0], [12]表示 spare<br>区, [11:0]表示页内偏移地址<br>8K: 需要填充[13:0], [13]表示 spare<br>区, [12:0]表示页内偏移地址 |
|          |     | R/-<br>R/W                                                                                                                                                                                                                                  |

## 20.2.3 页地址寄存器(ADDR\_R)

| 位     | 位域名      | 读写  | 描述                             |
|-------|----------|-----|--------------------------------|
| 31:25 |          | R/- | Reserved                       |
| 24:0  |          | R/W | 读、写、擦除操作起始地址页地址,地址             |
|       | Nand_Row |     | 组成如下:                          |
|       |          |     | {片选,页数}                        |
|       |          |     | 其中片选固定为2位,页数根据实际的单             |
|       |          |     | 片颗粒容量确定,如 1M 页则为[19:0],[21:20] |
|       |          |     | 用于选择4片中的第几片                    |

# 20.2.4 时序寄存器(NAND\_TIMING)

| 位     | 位域名        | 读写  | 描述                    |
|-------|------------|-----|-----------------------|
| 31:16 |            | R/- | Reserved              |
| 15:8  | Hold cycle | R/W | NAND 命令有效需等待的周期数,缺省 4 |
| 7:0   | Wait cycle | R/W | NAND 一次读写所需总时钟周期数,缺省  |
|       |            |     | 18,ECC 模式下配置为 8'hb    |

# **20.2.5** ID 寄存器(ID\_L)

|   | 位 | 位域名 | 读写 | 描述 |
|---|---|-----|----|----|
| _ |   |     |    |    |



| 31: 0 | ID[31:0] | R/- | ID[31:0] |
|-------|----------|-----|----------|

## 20.2.6 ID 和状态寄存器(STATUS & ID\_H)

| 位     | 位域名       | 访问  |                                      |
|-------|-----------|-----|--------------------------------------|
| 31:24 |           | R/- | Reserved                             |
| 23:16 | STATUS    | R/- | NAND 设备当前的读写完成状态                     |
| 15:0  | ID[47:32] | R/- | ID 高 16位(如果 ID 只有 5Bytes,则 ID[47:40] |
|       |           |     | 为 0)                                 |

#### **20.2.7** 参数配置寄存器(NAND\_PARAMETER)

| 位     | 位域名       | 读写  | 描述                                                                                                                                                               |
|-------|-----------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30 |           | R/- | Reserved                                                                                                                                                         |
| 29:16 | op_scope  | R/W | 每次能操作的范围,配置如下:  1.操作 main 区,配置为一页的 main 区大小  2.操作 spare 区,配置为一页的 spare 区大小  3.操作 main 加 spare 区,配置为一页的 main 区加上 spare 区大小                                        |
| 15    |           | R/- | Reserved                                                                                                                                                         |
| 14:12 | ID_number | R/W | ID 号的字节数                                                                                                                                                         |
| 11:8  | 外部颗粒容量大小  | R/W | 0: 1Gb(2K页) 1: 2Gb(2K页) 2: 4Gb(2K页) 3: 8Gb(2K页) 4: 16Gb(4K页) 5: 32Gb(8K页) 6: 64Gb(8K页) 7: 128Gb(8K页) 9: 64Mb(512B页) a:128Mb(512B页) b:256Mb(512B页) c:512Mb(512B页) |
| 7:0   |           | R/- | Reserved                                                                                                                                                         |

## **20.2.8** 操作数量寄存器(NAND\_OP\_NUM)

| 位     | 位域名         | 读写  | 描述                        |
|-------|-------------|-----|---------------------------|
| 31: 0 | NAND_OP_NUM | R/W | NAND 读写操作 Byte 数(必须以字对齐,为 |
|       |             |     | 4 的倍数);擦除为块数              |

## **20.2.9** 映射寄存器(CS\_RDY\_MAP)

NAND 的 4 个 CS 由所访问的地址硬件自动生成,CS0/RDY0 对应最低一块空间,CS1/RDY1 对应次低一块空间,其它以此类推。如果需要调整外部芯片和NAND 地址的关系,可通过设置本寄存器,对 cs\_rdy 1/2/3 进行重新映射。



| 位     | 位域名      | 读写  | 描述                                   |
|-------|----------|-----|--------------------------------------|
| 31:28 | rdy3_sel | R/W | rdy3 信号从芯片引脚到 NAND 控制器的映射            |
|       |          |     | 4' b0001:NAND_RDY[0] 4'              |
|       |          |     | b0010:NAND_RDY[1] 4'                 |
|       |          |     | b0100:NAND_RDY[2] 4'                 |
|       |          |     | b1000:NAND_RDY[3]                    |
| 27:24 | cs3_sel  | R/W | cs3 信号从 NAND 控制器到芯片引脚的映射             |
|       |          |     | 4' b0001:NAND_CS[0] 4'               |
|       |          |     | b0010:NAND_CS[1] 4' b0100:NAND_CS[2] |
|       |          |     | 4' b1000:NAND_CS[3]                  |
| 23:20 | rdy2_sel | R/W | rdy2 信号从芯片引脚到 NAND 控制器的映射            |
|       |          |     | 4'b0001:NAND_RDY[0] 4'               |
|       |          |     | b0010:NAND_RDY[1] 4'                 |
|       |          |     | b0100:NAND_RDY[2] 4'                 |
|       |          |     | b1000:NAND_RDY[3]                    |
| 19:16 | cs2_sel  | R/W | cs2 信号从 NAND 控制器到芯片引脚的映射             |
|       |          |     | 4' b0001:NAND_CS[0] 4'               |
|       |          |     | b0010:NAND_CS[1] 4' b0100:NAND_CS[2] |
|       |          |     | 4' b1000:NAND_CS[3]                  |
| 15:12 | rdy1_sel | R/W | rdy1 信号从芯片引脚到 NAND 控制器的映射            |
|       |          |     | 4'b0001:NAND_RDY[0] 4'               |
|       |          |     | b0010:NAND_RDY[1] 4'                 |
|       |          |     | b0100:NAND_RDY[2] 4'                 |
|       |          |     | b1000:NAND_RDY[3]                    |
| 11:8  | cs1_sel  | R/W | cs1 信号从 NAND 控制器到芯片引脚的映射             |
|       |          |     | 4' b0001:NAND_CS[0] 4'               |
|       |          |     | b0010:NAND_CS[1] 4' b0100:NAND_CS[2] |
|       |          |     | 4' b1000:NAND_CS[3]                  |
| 7:0   |          | R/- | Reserved                             |

## **20.2.10** DMA 读写数据寄存器(DMA\_ADDRESS)

| 位     | 位域名         | 读写  | 描述                                                                |
|-------|-------------|-----|-------------------------------------------------------------------|
| 31: 0 | DMA_ADDRESS | R/W | DMA 读写 NAND flash 数据(ID/STATUS 除外)时候的访问地址,读/写地址相同,读写方向通过 DMA 配置实现 |

## 20.3 NAND ADDR 说明

以 2K 页的 NAND flash 为例, 定义如下:

每一页的 main 区大小为 2KB, spare 区大小为 64B

main\_op = NAND\_CMD[8];

spare\_op = NAND\_CMD[9];

addr\_in\_page ={ A11, A10.. A2, A1, A0}=ADDR\_C

page\_number = { ····A30,A29,A28,A27····A13,A12} = ADDR\_R

NAND flash 的 main 区总容量计算公式为 215



容量=2^(ADDR\_C-1) \* 2^(ADDR\_R)\*8bit = 2K\*2^(ADDR\_R)\*8bit NAND 地址空间示例如下表:

|          | 74        |     |     |     |     |     |     |      |      |  |  |  |
|----------|-----------|-----|-----|-----|-----|-----|-----|------|------|--|--|--|
|          | I/O       | 0   | 1   | 2   | 3   | 4   | 5   | 6    | 7    |  |  |  |
| Column1  | 1st Cycle | A0  | A1  | A2  | A3  | A4  | A5  | A6   | A7   |  |  |  |
| Column2  | 2nd Cycle | A8  | A9  | A10 | A11 | *L  | *L  | *L   | *L   |  |  |  |
| Row1     | 3rd Cycle | A12 | A13 | A14 | A15 | A16 | A17 | A18  | A19  |  |  |  |
| Row2     | 4th Cycle | A20 | A21 | A22 | A23 | A24 | A25 | A26  | A27  |  |  |  |
| Row3 (注) | 5th Cycle | A28 | A29 | A30 | A31 | A32 | A33 | •••. | •••. |  |  |  |

表 20-1 NAND 地址空间示意图

(注: 2K页的 1Gb 容量 NAND flash 对应的 Row 最大值为 A27,发送地址给 NAND flash 时只用发 Column1~2 和 Row1~2,不用发 Row3。配置 NAND 参数时,注意不要配错型号,否则可能会读不出数据并且控制器会死等)

对系统板上 NAND 颗粒来说,如果仅仅操作 spare 区,A11=1 是唯一标志。 所以软件配置内部寄存器时,需要配置 A11 和 spare\_op 均为 1(见 Examples5), 错误的示例见 Examples2。

对系统板上 NAND 颗粒来说,如果仅仅操作 main 区,A11=0 是唯一标志.; 所以软件配置内部寄存器时,需要配置 A11 和 spare\_op 均为 0 (见 Examples1),错误的示例见 Examples4。

对系统板上 NAND 颗粒来说,如果操作 main+spare 区,A11 可以为 0 (见 Examples3); 也可以为 1 (见 Examples6)。

Examples1: (非 ECC 模式下。NAND 颗粒中一个 page 的数据只能位于 0x0-0x83f,第一个 op 表示读写开始的数据,接下来的 op 表示随后的读写数据; NO\_op 表示不能被本次 NAND 配置读写的数据)

(spare\_op = 1'b0 & main\_op = 1'b0) equal to (spare\_op = 1'b0 & main\_op = 1'b1); ADDR\_C = 0x30

| Data in a page | 0               | 0x30            | ···. | 0x7ff           | 0x800 | 0x830 | 0x83f |
|----------------|-----------------|-----------------|------|-----------------|-------|-------|-------|
| Page 0         | NO_op           | <mark>op</mark> | op   | op              | NO_op | NO_op | NO_op |
| Page 1         | <mark>op</mark> | <mark>op</mark> | op   | <mark>op</mark> | NO_op | NO_op | NO_op |
| Page 2         | ор              | op              | op   | op              | NO_op | NO_op | NO_op |

Examples2:

spare\_op=1' b1 & main\_op=1' b0; ADDR\_C = 0x30 (配置出错!! 开始操作不在 spare 区,下图是可能的错误访问顺序)



| Data in a page | 0     | 0x30  | ···.  | 0x7ff           | 0x800 | 0x830           | 0x83f           |
|----------------|-------|-------|-------|-----------------|-------|-----------------|-----------------|
| Page 0         | NO_op | ор    | ор    | <mark>op</mark> | Op    | ор              | ор              |
| Page 1         | NO_op | NO_op | NO_op | NO_op           | Ор    | <mark>op</mark> | <mark>op</mark> |
| Page 2         | NO_op | NO_op | NO_op | NO_op           | Ор    | <mark>op</mark> | <mark>op</mark> |
| Page 3         | NO_op | NO_op | NO_op | NO_op           | Ор    | <mark>op</mark> | <mark>op</mark> |

#### Examples3:

spare\_op = 1' b1 & main\_op =1' b1; ADDR\_C = 0x30

| Data in a page | 0               | 0x30 | •••. | 0x7ff           | 0x800           | 0x830           | 0x83f           |
|----------------|-----------------|------|------|-----------------|-----------------|-----------------|-----------------|
| Page 0         | NO_op           | op   | op   | <mark>op</mark> | <mark>op</mark> | <mark>op</mark> | <mark>op</mark> |
| Page 1         | <mark>op</mark> | op   | op   | <mark>op</mark> | op              | op              | op              |
| Page 2         | op              | op   | op   | <mark>op</mark> | <mark>op</mark> | <mark>op</mark> | <mark>op</mark> |

#### Examples4:

(spare\_op=1' b0 & main\_op=1' b0), (equal to spare\_op=1' b0 & main\_op=1' b1); ADDR\_C =0x830: (配置出错!! 开始操作在 spare 区,下图是可能的错误访问顺序)

| Data in a page | 0               | 0x30            | •••.            | 0x7ff           | 0x800           | 0x830 | 0x83f |
|----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-------|-------|
| Page 0         | NO_op           | NO_op           | NO_op           | NO_op           | NO_op           | NO_op | NO_op |
| Page 1         | NO_op           | <mark>op</mark> | <mark>op</mark> | <mark>op</mark> | <mark>op</mark> | NO_op | NO_op |
| Page 2         | ор              | ор              | ор              | ор              | ор              | NO_op | NO_op |
| Page 3         | <mark>op</mark> | ор              | op              | <mark>op</mark> | ор              | NO_op | NO_op |

#### Examples5:

spare\_op = 1' b1 and main\_op =1' b0; ADDR\_C = 0x830

| Data in a page | 0     | 0x30  | ···.  | 0x7ff | 0x800 | 0x830           | 0x83f           |
|----------------|-------|-------|-------|-------|-------|-----------------|-----------------|
| Page 0         | NO_op | NO_op | NO_op | NO_op | NO_op | <mark>op</mark> | <mark>op</mark> |
| Page 1         | NO_op | NO_op | NO_op | NO_op | ор    | <mark>op</mark> | <mark>op</mark> |
| Page 2         | NO_op | NO_op | NO_op | NO_op | ор    | ор              | <mark>op</mark> |

#### Examples6:

spare\_op = 1' b1 & main\_op =1' b1; ADDR\_C = 0x830

| Data in a page | 0               | 0x30            | ···.            | 0x7ff           | 0x800           | 0x830           | 0x83f           |
|----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|
| Page 0         | NO_op           | NO_op           | NO_op           | NO_op           | NO_op           | ор              | <mark>op</mark> |
| Page 1         | op              | ор              | ор              | ор              | ор              | ор              | <mark>op</mark> |
| Page 2         | <mark>op</mark> | <mark>op</mark> | <mark>op</mark> | <mark>op</mark> | <mark>op</mark> | op              | op              |
| Page 3         | <mark>op</mark> |

512B 页大小的 NAND flash 和 2KB 页大小配置类似,但在以下几个地方会有不同,需要注意:

每一页的 main 区大小为 512B, spare 区大小为 16B。其中 main 区分为两个 256B 区,每个 256B 区通过 A0~A7 来寻址。读写操作时,通过发送命令 0x00、 0x01 和 0x50 来选择是在哪个 256B 区或者 spare 区 (软件不必关心,硬件自动选择,如配置 NAND 控制器写 0x100 时,硬件会自动发送到高 256B 区)。

发送地址命令顺序如下:



|          | I/O       | 0   | 1   | 2   | 3   | 4   | 5   | 6   | 7   |
|----------|-----------|-----|-----|-----|-----|-----|-----|-----|-----|
| Column1  | 1st Cycle | A0  | A1  | A2  | A3  | A4  | A5  | A6  | A7  |
| Row1     | 2nd Cycle | A9  | A10 | A11 | A12 | A13 | A14 | A15 | A16 |
| Row2     | 3rd Cycle | A17 | A18 | A19 | A20 | A21 | A22 | A23 | A24 |
| Row3 (注) | 4th Cycle | A25 | A26 | *L  | *L  | *L  | *L  | *L  | *L  |

(注: Nand flash 容量为 64Mb、128Mb 和 256Mb 时,对应的最大列地址 ADDR\_R 分别为 A22、A23 和 A24,只用发送三次地址命令 Column1 和 Row1~2,不用发送 Row3;容量为 512Mb 和 1Gb 时,需要发送 Row3)

4K/8K 页大小的配置和 2K 页配置一样,4K 页的 main 区大小为 4KB, spare 区大小为 128B; 8K 页的 main 区大小为 8KB, spare 区大小为 640B。都需要发送五次地址命令。

## 20.4 Nand-flash 读写操作举例

寄存器的'command valid '位不能与其他读写使能位同时置位,要先设置好要进行的操作,最后才置'command valid '位。

例如:现在要读 Main 区的数据,那么操作分成以下两步:

- a、先 NAND\_CMD = 0x102
- b、再 NAND\_CMD = 0x103

## 20.5 NAND ECC 说明

硬件集成 ECC 功能, ECC 采用 RS(204,188)方法进行编码和解码,在配置软件过程中需要注意以下几点:

- 1. 每次读写 NAND 的时候,推荐配置 PAGE 的页内部地址(ADDR\_C)为 0:
- 2. NAND 每个 PAGE 有 2048Bytes,采用 RS(204,188)方式编解码后,只会用到前面的 2040Bytes,会有 8 个 Bytes 不用;采用 ECC 后 NAND 利用率为 188/204;
- 3. 在配置操作数的时候,如果每次操作一个页面,请配置 NAND 里面的 op\_num 为 204 的倍数(byte 为单位);在配置 DMA 控制器时候,操作数 为 47(188/4)的倍数(word 为单位)。
- 4. ECC 操作和 OOB 操作可以分开,比如对一个页完成 ECC 读/写后可以对 其 OOB 进行操作。

可以在 ECC 操作完成后通过普通方式读回所有内容,包括原始数据和 ECC



校验增加的数据(此时配置操作数 op\_num 和 DMA 相同)。

校验能力说明:最多可以纠错 8 个 Bytes,这些 Bytes 内部出错的位数可以是 1-8 个。

第一行数据共出错 64bit, 恰好是 8 个 Bytes, 可以纠错; 最后一行数据虽然错 9bits, 分散在 9Bytes 中, 无法纠错。

| 原始数据       | ff |     |      |
|------------|----|----|----|----|----|----|----|----|----|----|----|----|-----|------|
| (204Bytes) |    |    |    |    |    |    |    |    |    |    |    |    |     |      |
| 数据 1       | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | ff | ff | ff | ff | ••• | 可纠错  |
| 数据 2       | 1  | ff | ••• | 可纠错  |
| 数据 3       | fe | ff | ••• | 可纠错  |
| 数据 4       | 1  | 2  | 3  | 4  | 5  | 6  | 07 | 80 | ff | ff | ff | ff | ••• | 可纠错  |
| 数据 5       | fe | ff | ff | ff | ••• | 不可纠错 |

## 20.6 NAND BOOT 说明

NAND BOOT 支持 512B、2K 页、4K 页和 8K 页 NAND flash 启动。根据 FLASH 的容量大小和页大小配置好 NAND\_D[7:6]的上下拉电阻(需要对应好,否则可能会出现死等的情况)。如下表所示:

|             |           | NAND boot 时配置 NAND flash 颗粒容量大小 |
|-------------|-----------|---------------------------------|
|             |           | 11:表示容量大等于 2GB(2K 页/4K 页/8K 页)  |
| NAND_D[7:6] | nand_type | 10:表示容量为 1GB(2K 页)              |
|             |           | 01:表示容量为 512MB(512 Bytes 页)     |
|             |           | 00:表示容量为小等于 256MB(512 Bytes 页)  |

NAND 启动时会取出第 0 页开始的 1K 字节,进行芯片的初始化。如果是 512B 页则会读两页,如果是 2K 页或者更大,则会读取 1K 字节。故系统初始化代码需要放在从第 0 页 0 字节开始。

NAND BOOT 可以通过 NAND\_CLE 的上下拉来选择 ECC 和非 ECC 方式启动。两者的区别在于: ECC 方式采用了 RS(204,188)编码,ECC 启动时读取 1020 字节,有效数据为 940 字节,其余为编码数据。(注: ECC 启动时不支持 512B页。)



# **21 RTC**

## 21.1 概述

龙芯 1C 实时时钟(RTC)单元可以在主板上电后进行配置,当主板断电后,该单元任然运作,可以仅靠板上的电池供电就正常运行。RTC 单元运行时功耗仅几个微瓦。

RTC 由外部 32.768KHZ 晶振驱动,内部经可配置的分频器分频后,该时钟用来计数,年月日,时分秒等信息被更新。同时该时钟也用于产生各种定时和计数中断。

RTC 单元由计数器和定时器组成, 其构架如下图所示:



图 21-1 RTC 结构框图

## 21.2 寄存器描述

RTC 模块寄存器位于 0xbfe6\_4000——0xbfe6\_7fff 的 16KB 地址空间内, 其基地址为 0xbfe6\_4000, 所有寄存器位宽均为 32 位。

## 21.2.1 寄存器地址列表

| 名称            | 地址          | 位宽 | RW | 描述             | 复位值 |
|---------------|-------------|----|----|----------------|-----|
| sys_toywrite0 | 0xbfe6_4024 | 32 | W  | TOY 低 32 位数值写入 |     |
| sys_toywrite1 | 0xbfe6_4028 | 32 | W  | TOY 高 32 位数值写入 |     |
| sys_toyread0  | 0xbfe6_402C | 32 | R  | TOY 低 32 位数值读出 |     |
| sys_toyread1  | 0xbfe6_4030 | 32 | R  | TOY 高 32 位数值读出 |     |

注意: 其中 sys\_toytrim 及 sys\_rtctrim 寄存器复位后,其值不确定,如果不需要对外部晶振进行分频,请对这两个寄存器清零,这样 RTC 模块才能正常计时工作。



## 21.2.2 SYS\_TOYWRITE0

中文名: 设置 TOY 计数器低 32 位数值

寄存器位宽: [31:0]

偏移量: 0x24

复位值: 0x00000000

| 位域    | 位域名称         | 访问 | 缺省 | 描述                      |
|-------|--------------|----|----|-------------------------|
| 31:26 | TOY_MONTH    | W  |    | 月,范围 1~12               |
| 25:21 | TOY_DAY      | W  |    | 日,范围 1~31               |
| 20:16 | TOY_HOUR     | W  |    | 小时,范围 0 <sup>~</sup> 23 |
| 15:10 | TOY_MIN      | W  |    | 分,范围 0 <sup>~</sup> 59  |
| 9:4   | TOY_SEC      | W  |    | 秒,范围 0 <sup>~</sup> 59  |
| 3:0   | TOY_MILLISEC | W  |    | 0.1 秒,范围 0~9            |

## **21.2.3** SYS\_TOYWRITE1

中文名: 设置 TOY 计数器高 32 位数值

寄存器位宽: [31: 0]

偏移量: 0x28

复位值: 0x00000000

| 位域   | 位域名称     | 访问 | 缺省 | 描述         |
|------|----------|----|----|------------|
| 31:0 | TOY_YEAR | W  |    | 年, 范围 0~99 |

## 21.2.4 SYS\_TOYREAD0

中文名: 设置 TOY 计数器低 32 位数值

寄存器位宽: [31:0]

偏移量: 0x2c

复位值: 0x00000000

| 位域    | 位域名称         | 访问 | 缺省 | 描述                      |
|-------|--------------|----|----|-------------------------|
| 31:26 | TOY_MONTH    | R  |    | 月,范围 1~12               |
| 25:21 | TOY_DAY      | R  |    | 日,范围 1~31               |
| 20:16 | TOY_HOUR     | R  |    | 小时,范围 0 <sup>~</sup> 23 |
| 15:10 | TOY_MIN      | R  |    | 分,范围 0 <sup>~</sup> 59  |
| 9:4   | TOY_SEC      | R  |    | 秒,范围 0 <sup>~</sup> 59  |
| 3:0   | TOY_MILLISEC | R  |    | 0.1 秒,范围 0~9            |

## 21.2.5 SYS\_TOYREAD1

中文名: 设置 TOY 计数器高 32 位数值

寄存器位宽: [31:0]



偏移量: 0x30

复位值: 0x00000000

| 位域   | 位域名称     | 访问 | 缺省 | 描述         |
|------|----------|----|----|------------|
| 31:0 | TOY_YEAR | R  |    | 年, 范围 0~99 |



# 22 SDIO 控制器

## 22.1 功能概述

龙芯 1C 集成了一个 SDIO 控制器,用于 SD Memory 和 SDIO 卡的读写,支持 SD Memory 卡启动。SDIO 控制器特性如下:

- 兼容 SD 存储卡规格(2.0 版本)
- 兼容 SDIO 卡规格(2.0 版本)
- 8字(32字节)数据发送/接收 FIFO
- 扩展的 256 位 SD 卡状态寄存器
- 8 位预分频逻辑(频率=系统时钟/(p+1))
- DMA 数据传输模式
- 1位/4位(宽总线)的SD模式

## 22.2 SDIO 协议概述

SDIO 是一个串行通信方式,主设备和从设备通过消息传递来实现数据和状态的传输。如下图是一个写多块数据的示意框图,过程如下:

- 1. 主设备通过命令线发送写命令消息给从设备
- 2. 从设备接收完消息之后通过命令线发送应答消息给主设备
- 3. 主设备接收到正确的应答消息后,通过数据线发送一块数据(512K Byte 或者更多)给从设备,并且检测数据线忙状态
- 4. 从设备接收到正确的数据后会进入编程状态,此时将数据线置为忙状态, 不再响应主设备的数据请求
- 5. 主设备检测到从设备编程完成,继续发送下一块数据
- 6. 主设备发送完最后一块数据时,通过命令线发送停止命令给从设备,收 到正确应答之后完成这次多块写操作





图 22-1 SD 卡多块写操作示意图

多块读操作的过程和多块写操作的过程类似(等补充说明)。



图 22-2 SD 卡多块读操作示意图

不同的命令都有统一的格式。一般命令的格式如下表,1bit 起始位,1bit 传输方向位,6bit 命令序号,32bit 命令参数,7bit CRC 检验位再加上 1bit 结束位。 表 22-1 SD 模式下命令格式

| Bit position | 47        | 46               | [45:40]       | [39:8]   | [7:1] | 0       |
|--------------|-----------|------------------|---------------|----------|-------|---------|
| Width (bits) | 1         | 1                | 6             | 32       | 7     | 1       |
| Value        | ·O'       | '1'              | x             | х        | х     | '1'     |
| Description  | start bit | transmission bit | command index | argument | CRC7  | end bit |

其中 command index 对应命令的序号,比如命令 0, cmdindex 为 0, 命令 55, cmdindex 为 37。不同命令的参数可能不同,具体参考 SD 协议规范。

## 22.3 寄存器描述

SDIO 控制器的寄存器详细说明如下:

| 寄存器名称   | 地址         | 读/写(R/W) | 功能描述     | 复位值 |
|---------|------------|----------|----------|-----|
| sdi_con | 0xbfe6c000 | r/w      | SDIO 控制寄 | 0x0 |
|         |            |          | 存器       |     |

| sdi_con  | 位    | 缺省值 | 描述                          |
|----------|------|-----|-----------------------------|
| reserved | 31:9 | 0x0 |                             |
| soft_rst | 8    | 0x0 | 软件复位,整个模块复位。复位完成后硬<br>件自动清零 |
| reserved | 7:0  | 0x0 |                             |



| enclk | 0 | 0x0 | SD 时钟输出使能 |
|-------|---|-----|-----------|
|-------|---|-----|-----------|

| 寄存器名称   | 地址         | 读/写(R/W) | 功能描述     | 复位值 |
|---------|------------|----------|----------|-----|
| sdi_pre | 0xbfe6c004 | r/w      | SDIO 预分频 | 0x1 |
|         |            |          | 寄存器      |     |

| sdi_pre  | 位    | 缺省值 | 描述                             |  |
|----------|------|-----|--------------------------------|--|
| reserved | 31:8 | 0x0 |                                |  |
| sdi_pre  | 7:0  | 0x1 | SDIO 时钟预分频值,输出频率=PCLK/<br>预分频值 |  |

| 寄存器名称       | 地址         | 读/写(R/W) | 功能描述     | 复位值 |
|-------------|------------|----------|----------|-----|
| sdi_cmd_arg | 0xbfe6c008 | r/w      | SDIO 命令参 | 0x0 |
|             |            |          | 数寄存器     |     |

| sdi_cmd_arg | 位    | 缺省值 | 描述   |
|-------------|------|-----|------|
| sdi_cmd_arg | 31:0 | 0x0 | 命令参数 |

| 寄存器名称       | 地址         | 读/写(R/W) | 功能描述     | 复位值 |
|-------------|------------|----------|----------|-----|
| sdi_cmd_con | 0xbfe6c00c | r/w      | SDIO 命令控 | 0x0 |
|             |            |          | 制寄存器     |     |

| sdi_cmd_con    | 位      | 缺省值 | 描述                                                                                |
|----------------|--------|-----|-----------------------------------------------------------------------------------|
| reserved       | 31:18  | 0x0 |                                                                                   |
| func_num_abort | 17: 15 | 0x0 | SDIO 卡时中断的功能号,用于多块读写时, 硬件自动发送停止命令。如果auto_stop_en为0,则此位无效                          |
| sdio_en        | 14     | 0x0 | SDIO 使能信号。用于多块读写时,硬件自动发送停止命令,为 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 时开始,命令结束后硬件<br>自动清零            |
| cmd_index    | 7:0 | 0x0 | 带开始2位的命令索引(共8位)                         |

| 寄存器名称       | 地址         | 读/写(R/W) | 功能描述     | 复位值 |
|-------------|------------|----------|----------|-----|
| sdi_cmd_sta | 0xbfe6c010 | ro       | SDIO 命令状 | 0x0 |
|             |            |          | 态寄存器     |     |

| sdi_cmd_sta  | 位     | 缺省值 | 描述                                                                |
|--------------|-------|-----|-------------------------------------------------------------------|
| reserved     | 31:13 | 0x0 |                                                                   |
| cmd_sent_fin | 14    | 0x0 | 命令发送完成(包含响应)标志位,为 <b>1</b><br>表示命令发送完成及响应完成。                      |
| auto_stop    | 13    | 0x0 | 硬件自动发送停止命令标志位,为1表示<br>硬件自动发送停止命令,为0则没有                            |
| rsp_crc_err  | 12    | 0x0 | 响应 CRC 错误。接收到的响应 CRC 错误。<br>为 1 时表示响应 CRC 错误,为 0 时未发现             |
| cmd_end      | 11    | 0x0 | 命令发送完成(不关心响应)。为 1 时表示命令发送完成,为0时未完成                                |
| cmd_tout     | 10    | 0x0 | 命令超时。命令响应超时(64个时钟周期),<br>或者 R1b 类型的命令, 忙等待超时。为 1时表示响应超时, 为 0时未超时。 |
| rsp_fin      | 9     | 0x0 | 响应结束,接收完成从设备的返回信息。<br>为1时表示响应结束,为0时未完成。                           |
| cmd_on       | 8     | 0x0 | 命令传输标志位。为1时表示传输进行中,<br>为0表示结束                                     |



| rsp_index | 7:0 | 0x0 | 从设备返回的带开始 2 位的响应索引(共8 位) | Ļ |
|-----------|-----|-----|--------------------------|---|
|-----------|-----|-----|--------------------------|---|

| 寄存器名称    | 地址         | 读/写(R/W) | 功能描述     | 复位值 |
|----------|------------|----------|----------|-----|
| sdi_rsp0 | 0xbfe6c014 | ro       | SDIO 命令响 | 0x0 |
|          |            |          | 应寄存器 0   |     |

| sdi_cmd_arg | 位    | 缺省值   | 描述                                                     |
|-------------|------|-------|--------------------------------------------------------|
| sdi_rsp0    | 31:0 | ()y() | 卡状态[31:0](短),卡状态[127:96](长)<br>长响应的配置见 sdi_cmd_con[10] |

| 寄存器名称    | 地址         | 读/写(R/W) | 功能描述     | 复位值 |
|----------|------------|----------|----------|-----|
| sdi_rsp1 | 0xbfe6c018 | ro       | SDIO 命令响 | 0x0 |
|          |            |          | 应寄存器 1   |     |

| sdi_cmd_arg | 位    | 缺省值  | 描述                      |
|-------------|------|------|-------------------------|
| adi ran1    | 24-0 | 0.40 | 未使用(短),卡状态[95:64](长)    |
| sdi_rsp1    | 31:0 | 0x0  | 长响应的配置见 sdi_cmd_con[10] |

| 寄存器名称    | 地址         | 读/写(R/W) | 功能描述     | 复位值 |
|----------|------------|----------|----------|-----|
| sdi_rsp2 | 0xbfe6c01c | ro       | SDIO 命令响 | 0x0 |
|          |            |          | 应寄存器 2   |     |

| sdi_cmd_arg | 位    | 缺省值      | 描述                      |
|-------------|------|----------|-------------------------|
| adi ran?    | 21.0 | 31:0 0x0 | 未使用 (短), 卡状态[63:32] (长) |
| sdi_rsp2    | 31.0 |          | 长响应的配置见 sdi_cmd_con[10] |

| 寄存器名称    | 地址         | 读/写(R/W) | 功能描述     | 复位值 |
|----------|------------|----------|----------|-----|
| sdi_rsp3 | 0xbfe6c020 | ro       | SDIO 命令响 | 0x0 |
|          |            |          | 应寄存器 3   |     |

| sdi_cmd_arg | 位 | 缺省值 | 描述 |
|-------------|---|-----|----|
|-------------|---|-----|----|



| sdi_rsp3 | 31:0 | 0x0 | 未使用(短),卡状态[31:0](长)     |
|----------|------|-----|-------------------------|
| Sui_isps | 31.0 |     | 长响应的配置见 sdi_cmd_con[10] |

| 寄存器名称      | 地址         | 读/写(R/W) | 功能描述     | 复位值 |
|------------|------------|----------|----------|-----|
| sdi_dtimer | 0xbfe6c024 | r/w      | SDIO 命令数 | 0x0 |
|            |            |          | 据超时寄存    |     |
|            |            |          | 器        |     |

| sdi_dtimer | 位     | 缺省值 | 描述                |
|------------|-------|-----|-------------------|
| reserved   | 31:24 | 0x0 |                   |
| sdi_dtimer | 23:0  | 0x0 | 数据超时计数值,用分频后的时钟计数 |

| 寄存器名称     | 地址         | 读/写(R/W) | 功能描述     | 复位值 |
|-----------|------------|----------|----------|-----|
| sdi_bsize | 0xbfe6c028 | r/w      | SDIO 块大小 | 0x0 |
|           |            |          | 寄存器      |     |

| sdi_bsize | 位     | 缺省值 | 描述           |
|-----------|-------|-----|--------------|
| reserved  | 31:23 | 0x0 |              |
| sdi_bsize | 11:0  | 0x0 | 块大小值(0~4095) |

| 寄存器名称       | 地址         | 读/写(R/W) | 功能描述         | 复位值 |
|-------------|------------|----------|--------------|-----|
| sdi_dat_con | 0xbfe6c02c | r/w      | SDIO 数据控制寄存器 | 0x0 |

| sdi_dat_con | 位     | 缺省值 | 描述                                                                            |
|-------------|-------|-----|-------------------------------------------------------------------------------|
| reserved    | 31:15 | 0x0 |                                                                               |
| resume_rw   | 20    |     | SDIO 挂起恢复读写标志位。为 1 时, SDIO 挂起后恢复之前的写操作;为 0 是,恢复之前的读操作。                        |
| IO_resume   | 19    |     | SDIO 恢复请求。在 SDIO 设备进入挂起<br>状态后,将此位写 1,并且 IO_suspend<br>位写 0 后,SDIO 设备恢复之前的操作。 |



| IO_suspend | 18    | 0x0 | SDIO 挂起请求。写 1 后控制器会在合适的时机发送 CMD52 命令,通知 SDIO 设备进入挂起状态。恢复操作时需要将此位写 0. |
|------------|-------|-----|----------------------------------------------------------------------|
| RwaitReq   | 17    | 0x0 | 读等待请求。写 1 后控制器会在合适的时机将 DAT2 拉低,通知 SDIO 设备进入读等待状态。写 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 |                                                                      |
| blk_num    | 11:0  | 0x0 | 读写操作的块数                                                              |

| 寄存器名称       | 地址         | 读/写(R/W) | 功能描述     | 复位值 |
|-------------|------------|----------|----------|-----|
| sdi_dat_cnt | 0xbfe6c030 | 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 | 0xbfe6c034 | ro       | SDIO 数据状 | 0x0 |
|             |            |          | 态寄存器     |     |

| sdi_dat_sta | 位     | 缺省值 | 描述                      |
|-------------|-------|-----|-------------------------|
| reserved    | 31:11 | 0x0 |                         |
| suspend_on  | 16    | 0x0 | 为 1 表示正在挂起状态。           |
| rst_suspend | 15    | 0x0 | 为 1 表示正在挂起复位。用于 SDIO 设备 |



|            |                |      | 挂起后,控制器复位 FIFO 和 DMA 请求。     |
|------------|----------------|------|------------------------------|
| R1b_tout   | 14             | 0x0  | 为 1 表示 R1b 类型命令超时。           |
| data_start | 13             | 0x0  | 为 1 表示数据传输开始。                |
|            |                |      | 检测到带 busy 状态的命令完成。当发送        |
| R1b_fin    | 12             | 0x0  | 带 busy 状态的命令时,此位为 0; 当 busy  |
|            |                |      | 状态结束时变成 1.                   |
| auto_stop  | 11             | 0x0  | 为 1 时表示硬件正在自动发送停止命令          |
| reserved   | 10             | 0x0  |                              |
| r wait rog | 9              | 0x0  | 读等待发生。发送读等待请求信号到             |
| r_wait_req | 9              | UXU  | SDIO 卡。                      |
| 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 时标志数据传输结束      |
| busy_fin   | 3              | 0x0  | 忙结束标志位(比如编程时)。为 1 时标<br>志忙结束 |
| prog_err   | 2              | 0x0  | 编程错误标志位,为1时表示编程错误            |
| t. dat     | <_dat_on 1 0x0 | 0.40 | Tx 数据发送中,为 1 时表示正在发送,为       |
| ix_uai_UII |                | UXU  | 0 时发送完成                      |
| rx_dat_on  | 0              | 0x0  | rX 数据接收中,为1时表示正在接收,为         |
|            | _dat_on 0 0x0  |      | 0 时发送完成                      |

| 寄存器名称        | 地址         | 读/写(R/W) | 功能描述      | 复位值 |
|--------------|------------|----------|-----------|-----|
| sdi_fifo_sta | 0xbfe6c038 | 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_msk | 0xbfe6c03c | r/c      | SDIO 中断寄 | 0x0 |
|             |            |          | 存器       |     |

| sdi_int_msk  | 位     | 缺省值 | 描述                         |
|--------------|-------|-----|----------------------------|
| 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 | 0xbfe6c040 | ro       | SDIO 命令数 | 0x0 |
|         |            |          | 据寄存器     |     |

| sdi_dat | 位    | 缺省值 | 描述                              |
|---------|------|-----|---------------------------------|
| sdi_dat | 31:0 | 0x0 | SDIO 控制器发送或者接收的数据(用于<br>DMA 操作) |

| 寄存器名称 | 地址 | 读/写(R/W) | 功能描述 | 复位值 |
|-------|----|----------|------|-----|
|-------|----|----------|------|-----|



| sdi_int_en | 0xbfe6c064 | 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_crc_int_en  | 2     | 0x0 | 数据接收 CRC 错误中断使能,为 1 时有效     |
| dat_tout_int_en | 1     | 0x0 | 数据超时中断使能,为1时有效              |
| dat_fin_int_en  | 0     | 0x0 | 数据完成中断使能,为1时有效              |

## 22.4 软件编程说明

## **22.4.1** SD Memory 卡软件编程说明

SD Memory 卡要想正常工作,必须要先初始化。初始化的过程需要发送不同的命令序列来配置从设备。初始化的流程示意图如下:





图 22-3 SD Memory 卡初始化流程示意图

初始化完成之后就可以正常工作了。

配置寄存器的流程如下:

- 1. 配置 sdi con, 使能输出时钟
- 2. 配置 sdi\_pre,设置一个分频系数,如果时序不满足,可以设置输出反向 时钟来调整时序
- 3. 配置 sdi int en, 使能命令、数据完成及其他中断
- 4. 按照上图初始化流程初始化控制器

发送命令的配置寄存器过程如下:

- ▶ 根据发送的命令,配置 cmd\_arg 寄存器
- ▶ 配置 cmd\_con 寄存器,发送命令
- ▶ 读 sdi\_int\_msk 寄存器,检查是否传输完成,是否有错误
- ➤ 如果需要,读 sdi\_rsp 寄存器

初始化的流程如下:

CMD0→CMD8→ACMD41(即 CMD55→CMD41)→CMD2→CMD3 →CMD7→ACMD6(用于配置是否用 4bit 数据线传输)



- 5. 进行数据操作之前需要配置 Bsize 寄存器, Dtimer 寄存器
- 6. 数据的操作必须要配置 DMA, 配置 dat\_con 寄存器并配置 DMA(注: 读操作时先配置 DMA, 写操作时先配置 dat\_con)
- 7. 读 sdi int msk 寄存器, 检测是否传输完成, 是否有错误
- 8. 没有错误则完成一次数据传输,不需要软件发送停止命令

#### 22.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 拉低,通知 SDIO 卡停止 发送数据。所以如果当前正在传输数据过程中,控制器可能会在当前一块数据传输结束后,发出读等待信号,这时才不会接收下一块数据
- 13. 对于挂起和恢复操作。有可能出现挂起嵌套情况,比如说操作 1 被操作 2 中断而挂起,然后操作 2 被操作 3 中断而挂起。挂起时中断的现场需要软件保存(如当前的读写标志位,当前传输的块数,地址等),进行入栈操作。恢复时需要软件再按相应的顺序出栈



# 23 CAN 控制器

## 23.1 概述

1C 集成了两路 CAN 接口控制器。CAN 总线是由发送数据线 TX 和接收数据线 RX 构成的串行总线,可发送和接收数据。器件与器件之间进行双向传送,最高传送速率 1Mbps。

两个 CAN 总线控制器的中断连接到中断控制的第一组寄存器中,其中 can0 的中断对应 bit6, can1 的中断对应 bit7。参考第 15 章的说明。

CANO 总线控制器的寄存器基地址为 0xbfe5 0000 开始的 16KB:

CAN1 总线控制器的寄存器基地址为 0xbfe5 4000 开始的 16KB。

## 23.2 CAN 控制器结构

下图为 CAN 主控制器的结构,主要模块有 APB 总线接口、位流处理单元、位时序逻辑、错误管理逻辑、接收滤波和数据缓存区。

- APB 总线接口:接收 APB 总线的指令和返回数据
- 位流处理单元:实现对发送缓存器、接收 FIFO 和 CAN 总线之间数据流的控制,同时还执行错误检测、总线仲裁、数据填充和错误处理等功能。
- 位时序逻辑: 监视串口的 CAN 总线和处理与总线有关的位时序。还提供了可编程的时间段来补偿传播延迟时间、相位转换(例如由于振荡漂移)和定义采样点和一位时间内的采样次数
- 错误管理逻辑: 判断传输的 CRC 错误并对错误计数
- 接收滤波:把接收的识别码的内容相比较以决定是否接收信息
- 数据缓存区:接收缓冲器是验收滤波器和 CPU 之间的接口,用来储存从 CAN 总线上接收和接收的信息。接收缓冲器(13 个字节)作为接收 FIFO(长 64 字节)的一个窗口可被 CPU 访问





图 23-1 CAN 主控制器结构

CAN 支持两种工作模式,即标准模式和扩展模式。工作模式通过命令寄存器中的 CAN 模式位来选择。复位默认是标准模式。

## 23.3 标准模式

#### 23.3.1 标准模式地址表

地址区包括控制段和信息缓冲区,控制段在初始化载入是可被编程来配置通 讯参数的,应发送的信息会被写入发送缓冲器,成功接收信息后,微控制器从接 收缓冲器中读取接收的信息,然后释放空间以做下一步应用。

初始载入后,寄存器的验收代码,验收屏蔽,总线定时寄存器 0 和 1 以及输出控制就不能改变了。只有控制寄存器的复位位被置高时,才可以访问这些寄存器。在复位模式和工作模式两种不同的模式中,访问寄存器是不同的。当硬件复位或控制器掉线,状态寄存器的总线状态位时会自动进入复位模式。工作模式是通过置位控制寄存器的复位请求位激活的。

|        |    | 工作 | 模式 | 复位植 | 莫式 |
|--------|----|----|----|-----|----|
| CAN 地址 | 段  | 读  | 写  | 读   | 写  |
| 0      |    | 控制 | 控制 | 控制  | 控制 |
| 1      |    | FF | 命令 | FF  | 命令 |
| 2      |    | 状态 | _  | 状态  | _  |
| 3      | 控制 | FF | _  | 中断  | _  |



| 4  |       | FF       | _        | 验收代码   | 验收代码   |
|----|-------|----------|----------|--------|--------|
| 5  |       | FF       | _        | 验收屏蔽   | 验收屏蔽   |
| 6  |       | FF       | _        | 总线定时 0 | 总线定时 0 |
| 7  |       | FF       | _        | 总线定时 1 | 总线定时 1 |
| 8  |       | 保留       | 保留       | 保留     | 保留     |
| 9  |       | 保留       | 保留       | 保留     | 保留     |
| 10 |       | ID(10-3) | ID(10-3) | FF     | _      |
|    |       | ID(2-0), | ID(2-0), |        |        |
| 11 |       | RTR, DLC | RTR, DLC | FF     | _      |
| 12 |       | 数据字节1    | 数据字节1    | FF     | _      |
| 13 |       | 数据字节2    | 数据字节2    | FF     | _      |
| 14 |       | 数据字节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     | _      |
|    |       | ID(2-0), | ID(2-0), |        |        |
| 21 |       | RTR, DLC | 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     |        |

## 23.3.2 控制寄存器(CR)

中文名: 控制寄存器

寄存器位宽: [7: 0]偏移量: 0x00复位值: 0x01

读此位的值总是逻辑 1。在硬启动或总线状态位设置为 1(总线关闭)时,复位请求位被置为 1。如果这些位被软件访问,其值将发生变化而且会影响内部时钟的下一个上升沿,在外部复位期间微控制器不能把复位请求位置为 0。如果把复位请求位设为 0,微控制器就必须检查这一位以保证外部复位引脚不保持为低。复位请求位的变化是同内部分频时钟同步的。读复位请求位能够反映出这种同步状态。

复位请求位被设为0后控制器将会等待

a) 一个总线空闲信号(11 个弱势位),如果前一次复位请求是硬件复位或 CPU 初始复位。



b) 128 个总线空闲,如果前一次复位请求是 CAN 控制器在重新进入总线开启模式前初始化总线造成的。

| 位域           | 位域名称    | 位宽 | 访问 | 描述     |
|--------------|---------|----|----|--------|
| 7 <b>:</b> 5 | Reserve | 3  | _  | 保留     |
| 4            | OIE     | 1  | RW | 溢出中断使能 |
| 3            | EIE     | 1  | RW | 错误中断使能 |
| 2            | TIE     | 1  | RW | 发送中断使能 |
| 1            | RIE     | 1  | RW | 接收中断使能 |
| 0            | RR      | 1  | RW | 复位请求   |

## 23.3.3 命令寄存器(CMR)

中文名: 命令寄存器

寄存器位宽:[7:0]偏移量:0x01复位值:0x00

命令寄存器对微控制器来说是只写存储器如果去读这个地址返回值是 1111

#### 1111

| 位域          | 位域名称    | 位宽 | 访问 | 描述      |
|-------------|---------|----|----|---------|
| 7           | EFF     | 1  | W  | 扩展模式    |
| <b>6:</b> 5 | Reserve | 2  | _  | 保留      |
| 4           | GTS     | 1  | W  | 睡眠      |
| 3           | CD0     | 1  | W  | 清除数据溢出  |
| 2           | RRB     | 1  | W  | 释放接收缓冲器 |
| 1           | AT      | 1  | W  | 中止发送    |
| 0           | TR      | 1  | W  | 发送请求    |

#### 23.3.4 状态寄存器(SR)

中文名: 状态寄存器

寄存器位宽: [7: 0]偏移量: 0x02复位值: 0x00

| 位域 | 位域名称 | 位宽 | 访问 | 描述      |
|----|------|----|----|---------|
| 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  | 接收缓存器状态 |

## 23.3.5 中断寄存器 (IR)

中文名: 中断寄存器

寄存器位宽: [7: 0] 偏移量: 0x03



复位值: 0x00

| 位域   | 位域名称     | 位宽 | 访问 | 描述     |
|------|----------|----|----|--------|
| 7: 5 | Reserved | 1  | R  | 保留     |
| 4    | WUI      | 1  | R  | 唤醒中断   |
| 3    | DOI      | 1  | R  | 数据溢出中断 |
| 2    | EI       | 1  | R  | 错误中断   |
| 1    | TI       | 1  | R  | 发送中断   |
| 0    | RI       | 1  | R  | 接收中断   |

#### 23.3.6 验收代码寄存器(ACR)

中文名: 验收代码寄存器

寄存器位宽:[7:0]偏移量:0x04复位值:0x00

在复位情况下, 该寄存器是可以读写的。

| 位域  | 位域名称 | 位宽 | 访问 | 描述      |
|-----|------|----|----|---------|
| 7:0 | AC   | 8  | RW | ID 验收代码 |

#### 23.3.7 验收屏蔽寄存器(AMR)

中文名: 验收屏蔽寄存器

寄存器位宽: [7: 0]偏移量: 0x05复位值: 0x00

验收代码位 AC 和信息识别码的高 8 位 ID.10-ID.3 相等且与验收屏蔽位 AM 的相应位相或为 1 时数据可以接收。在复位情况下,该寄存器是可以读写的。

| 位域  | 位域名称 | 位宽 | 访问 | 描述     |
|-----|------|----|----|--------|
| 7:0 | AM   | 8  | RW | ID 屏蔽位 |

#### 23.3.8 发送缓冲区列表

缓冲器是用来存储微控制器要 CAN 控制器发送的信息,它被分为描述符区和数据区。发送缓冲器的读/写只能由微控制器在工作模式下完成,在复位模式下读出的值总是 FF。

| 地址 | X     | 名称      | 数据位               |
|----|-------|---------|-------------------|
| 10 |       | 识别码字节1  | ID (10-3)         |
|    |       |         |                   |
| 11 |       | 识别码字节 2 | ID(2-0), RTR, DLC |
| 12 |       | TX 数据 1 | 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           |



#### 23.3.9 接收缓冲区列表

接收缓冲区的配置和发送缓冲区的一样,只是地址变为20-29。

## 23.4 扩展模式

#### 23.4.1 扩展模式地址表

| 20.7.  | 1 0 成侯以地址仪 |          |          |        |
|--------|------------|----------|----------|--------|
|        | 工作模式       |          | 复位模      |        |
| CAN 地址 | 读          | 写        | 读        | 写      |
| 0      | 控制         | 控制       | 控制       | 控制     |
| 1      | 0          | 命令       | 0        | 命令     |
| 2      | 状态         | _        | 状态       | _      |
| 3      | 中断         | _        | 中断       | _      |
| 4      | 中断使能       | 中断使能     | 中断使能     | 中断使能   |
| 5      | _          | _        | 验收屏蔽     | 验收屏蔽   |
| 6      | 总线定时 0     | _        | 总线定时 0   | 总线定时 0 |
| 7      | 总线定时 1     | _        | 总线定时1    | 总线定时 1 |
| 8      | 保留         | 保留       | 保留       | 保留     |
| 9      | 保留         | 保留       | 保留       | 保留     |
| 10     | 保留         | 保留       | 保留       | 保留     |
| 11     | 仲裁丢失捕捉     | _        | 仲裁丢失捕捉   | _      |
| 12     | 错误代码捕捉     | _        | 错误代码捕捉   | _      |
| 13     | 错误警报限制     | _        | 错误警报限制   | _      |
| 14     | RX 错误计数器   | _        | RX 错误计数器 | _      |
| 15     | TX 错误计数器   | _        | TX 错误计数器 | _      |
| 16     | RX 帧信息     | TX 帧信息   | 验收代码 0   | 验收代码 0 |
| 17     | RX 识别码 1   | TX 识别码 1 | 验收代码1    | 验收代码1  |
| 18     | RX 识别码 2   | TX 识别码 2 | 验收代码 2   | 验收代码 2 |
| 19     | RX 识别码 3   | TX 识别码 3 | 验收代码 3   | 验收代码3  |
| 20     | RX 识别码 4   | TX 识别码 4 | 验收屏蔽 0   | 验收屏蔽 0 |
| 21     | RX 数据 1    | TX 数据 1  | 验收屏蔽 1   | 验收屏蔽1  |
| 22     | RX 数据 2    | TX 数据 2  | 验收屏蔽 2   | 验收屏蔽 2 |
| 23     | RX 数据 3    | TX 数据 3  | 验收屏蔽 3   | 验收屏蔽3  |
| 24     | RX 数据 4    | TX 数据 4  | _        | _      |
| 25     | RX 数据 5    | TX 数据 5  | _        | _      |
| 26     | RX 数据 6    | TX 数据 6  | _        |        |
| 27     | RX 数据 7    | TX 数据 7  |          |        |
| 28     | RX 数据 8    | TX 数据 8  | _        | _      |
| 29     | RX 信息计数器   | _        | RX 信息计数器 | _      |
|        | 古代字太器 (MOI | - \      |          |        |

#### 23.4.2 模式寄存器 (MOD)

中文名: 模式寄存器

寄存器位宽: [7: 0] 偏移量: 0x00 复位值: 0x01

读此位的值总是逻辑 1。在硬启动或总线状态位设置为 1 (总线关闭)时, 复位请求位被置为 1。如果这些位被软件访问,其值将发生变化而且会影响内部



时钟的下一个上升沿,在外部复位期间微控制器不能把复位请求位置为 0。如果把复位请求位设为 0,微控制器就必须检查这一位以保证外部复位引脚不保持为低。复位请求位的变化是同内部分频时钟同步的。读复位请求位能够反映出这种同步状态。

复位请求位被设为0后控制器将会等待

- a) 一个总线空闲信号(11个弱势位),如果前一次复位请求是硬件复位或CPU 初始复位。
- b) 128 个总线空闲,如果前一次复位请求是 CAN 控制器在重新进入总线开启模式前初始化总线造成的。

| 位域           | 位域名称    | 位宽 | 访问 | 描述      |
|--------------|---------|----|----|---------|
| 7 <b>:</b> 5 | Reserve | 3  | _  | 保留      |
| 4            | SM      | 1  | RW | 睡眠模式    |
| 3            | AFM     | 1  | RW | 单/双滤波模式 |
| 2            | STM     | 1  | RW | 正常工作模式  |
| 1            | LOM     | 1  | RW | 只听模式    |
| 0            | RM      | 1  | RW | 复位模式    |

#### 23.4.3 命令寄存器(CMR)

中文名: 命令寄存器

寄存器位宽: [7:0]偏移量: 0x01复位值: 0x00

命令寄存器对微控制器来说是只写存储器如果去读这个地址返回值是 1111

#### 1111

| 位域          | 位域名称    | 位宽 | 访问 | 描述      |
|-------------|---------|----|----|---------|
| 7           | EFF     | 1  | W  | 扩展模式    |
| <b>6:</b> 5 | Reserve | 2  | _  | 保留      |
| 4           | SRR     | 1  | W  | 自接收请求   |
| 3           | CDO     | 1  | W  | 清除数据溢出  |
| 2           | RRB     | 1  | W  | 释放接收缓冲器 |
| 1           | AT      | 1  | W  | 中止发送    |
| 0           | TR      | 1  | W  | 发送请求    |

## 23.4.4 状态寄存器(SR)

中文名: 状态寄存器

寄存器位宽: [7: 0]偏移量: 0x02复位值: 0x00

| 位域 | 位域名称 | 位宽 | 访问 | 描述   |
|----|------|----|----|------|
| 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 | 接收缓存器状态 |

## 23.4.5 中断寄存器 (IR)

中文名: 中断寄存器

寄存器位宽:[7:0]偏移量:0x03复位值:0x00

| 位域 | 位域名称 | 位宽 | 访问 | 描述     |
|----|------|----|----|--------|
| 7  | BEI  | 1  | R  | 总线错误中断 |
| 6  | ALI  | 1  | R  | 仲裁丢失中断 |
| 5  | EPI  | 1  | R  | 错误消极中断 |
| 4  | WUI  | 1  | R  | 唤醒中断   |
| 3  | DOI  | 1  | R  | 数据溢出中断 |
| 2  | El   | 1  | R  | 错误中断   |
| 1  | TI   | 1  | R  | 发送中断   |
| 0  | RI   | 1  | R  | 接收中断   |

## 23.4.6 中断使能寄存器(IER)

中文名: 中断使能寄存器

寄存器位宽: [7: 0]偏移量: 0x04复位值: 0x00

| 位域 | 位域名称 | 位宽 | 访问 | 描述       |
|----|------|----|----|----------|
| 7  | BEIE | 1  | RW | 总线错误中断使能 |
| 6  | ALIE | 1  | RW | 仲裁丢失中断使能 |
| 5  | EPIE | 1  | RW | 错误消极中断使能 |
| 4  | WUIE | 1  | RW | 唤醒中断使能   |
| 3  | DOIE | 1  | RW | 数据溢出中断使能 |
| 2  | EIE  | 1  | RW | 错误中断使能   |
| 1  | TIE  | 1  | RW | 发送中断使能   |
| 0  | RIE  | 1  | RW | 接收中断使能   |

## **23.4.7** 仲裁丢失捕捉寄存器(IER)

中文名: 仲裁丢失捕捉寄存器

寄存器位宽: [7: 0]偏移量: 0xB复位值: 0x00

| 位域   | 位域名称   | 位宽 | 访问 | 描述  |
|------|--------|----|----|-----|
| 7: 5 | _      | 3  | R  | 保留  |
| 4    | BITNO4 | 1  | R  | 第四位 |
| 3    | BITNO3 | 1  | R  | 第三位 |
| 2    | BITNO2 | 1  | R  | 第二位 |



| 1 | BITNO1 | 1 | R | 第一位 |
|---|--------|---|---|-----|
| 0 | BITNO0 | 1 | R | 第零位 |

| 位                                     |                  |
|---------------------------------------|------------------|
| 一- (其 年)(1) Th (2)                    | 功能               |
| 4 ALC. 3 ALC. 2 ALC. 1 ALC. 0 十进制值 功能 | is .             |
| 0 0 0 0 0 m 种裁丢失在识别码的bit              | t1               |
| 0 0 0 1 1 仲裁丢失在识别码的bi                 | t2               |
| 0 0 1 0 2 仲裁丢失在识别码的bit                | t3               |
| 0 0 1 1 3 仲裁丢失在识别码的bi                 | t4               |
| 0 0 1 0 0 4 仲裁丢失在识别码的bit              | t5               |
| 0 0 1 0 1 5 仲裁丢失在识别码的bit              | t6               |
| 0 0 1 1 0 6 仲裁丢失在识别码的bit              | t7               |
| 0 0 1 1 1 7 仲裁丢失在识别码的bit              | t8               |
| 0 1 0 0 0 8 仲裁丢失在识别码的bit              | t9               |
| 0 1 0 0 1 9 仲裁丢失在识别码的bit              | t10              |
| 0 1 0 1 0 10 仲裁丢失在识别码的bi              | t11              |
| 0 1 0 1 1 11 仲裁丢失在SRTR位.              |                  |
| 0 1 1 0 0 12 仲裁丢失在IDE位                |                  |
| 0 1 1 0 1 13 仲裁丢失在识别码的bit             | t12              |
| 0 1 1 1 0 14 仲裁丢失在识别码的bit             | t13              |
| 0 1 1 1 1 15 仲裁丢失在识别码的bit             | t14.             |
| 1 0 0 0 0 16 仲裁丢失在识别码的bit             | t15              |
| 1 0 0 0 1 17 仲裁丢失在识别码的bit             | t16              |
| 1 0 0 1 0 18 仲裁丢失在识别码的bit             | t17              |
| 1 0 0 1 1 19 仲裁丢失在识别码的bit             | t18              |
| 1 0 1 0 0 20 仲裁丢失在识别码的bit             | t19              |
| 1 0 1 0 1 21 仲裁丢失在识别码的bit             | t20              |
| 1 0 1 1 0 22 仲裁丢失在识别码的bit             | t21              |
| 1 0 1 1 1 23 仲裁丢失在识别码的bit             | t22 <sup>.</sup> |
| 1 1 0 0 0 24 仲裁丢失在识别码的bit             | t28              |
| 1 1 0 0 1 25 仲裁丢失在识别码的bit             | t24;             |
| 1 1 0 1 0 26 仲裁丢失在识别码的bit             |                  |
| 1 1 0 1 1 27 仲裁丢失在识别码的bit             | t26;             |
| 1 1 1 0 0 28 仲裁丢失在识别码的bit             | t27              |
| 1 1 1 0 1 29 仲裁丢失在识别码的bit             | t28              |
| 1 1 1 0 30 仲裁丢失在识别码的bit               | t29              |
| 1 1 1 1 1 31 仲裁丢失在RTR位                |                  |

## 23.4.8 错误警报限制寄存器(EMLR)

中文名: 错误警报限制寄存器

寄存器位宽: [7: 0]偏移量: 0xD复位值: 0x60

| 位域   | 位域名称 | 位宽 | 访问 | 描述     |
|------|------|----|----|--------|
| 7: 0 | EML  | 8  | RW | 错误警报阀值 |



#### **23.4.9** RX 错误计数寄存器(RXERR)

中文名: RX 错误计数寄存器

寄存器位宽: [7: 0]偏移量: 0xE复位值: 0x60

| 位域   | 位域名称  | 位宽 | 访问 | 描述     |
|------|-------|----|----|--------|
| 7: 0 | RXERR | 8  | R  | 接收错误计数 |

#### 23.4.10 TX 错误计数寄存器(TXERR)

中文名: TX 错误计数寄存器

寄存器位宽: [7: 0] 偏移量: 0xF 复位值: 0x60

| 位域   | 位域名称  | 位宽 | 访问 | 描述     |
|------|-------|----|----|--------|
| 7: 0 | TXERR | 8  | R  | 发送错误计数 |

#### 23.4.11 验收滤波器

在验收滤波器的帮助下,只有当接收信息中的识别位和验收滤波器预定义的值相等时,CAN 控制器才允许将已接收信息存入 RXFIFO。验收滤波器由验收代码寄存器和验收屏蔽寄存器定义。在模式寄存器中选择单滤波器模式或者双滤波器模式。具体的配置可以参考 SJA1000 的数据手册。

#### **23.4.12** RX 信息计数寄存器(RMCR)

中文名: RX 信息计数寄存器

寄存器位宽: [7: 0] 偏移量: 0x1D 复位值: 0x00

|   | 位域   | 位域名称 | 位宽 | 访问 | 描述        |
|---|------|------|----|----|-----------|
| Ī | 7: 0 | RMCR | 8  | R  | 接收的数据帧计数器 |

## 23.5 公共寄存器

#### 23.5.1 总线定时寄存器 0(BTR0)

中文名: 总线定时寄存器

寄存器位宽: [7: 0]偏移量: 0x06复位值: 0x00

## 注: 在复位模式是可以读写的,工作模式是只读的

| 位域   | 位域名称 | 位宽 | 访问 | 描述      |
|------|------|----|----|---------|
| 7: 6 | SJW  | 8  | RW | 同步跳转宽度  |
| 5: 0 | BRP  | 8  | RW | 波特率分频系数 |

#### 23.5.2 总线定时寄存器 1(BTR1)

中文名: 总线定时寄存器 1

寄存器位宽: [7:0]



偏移量: 0x07 复位值: 0x00

| 位域   | 位域名称  | 位宽 | 访问 | 描述                  |
|------|-------|----|----|---------------------|
| 7    | SAM   | 1  | RW | 为1时三次采样,否则是一次采用     |
| 6: 4 | TESG2 | 3  | RW | 一个 bit 中的时间段 2 的计数值 |
| 3: 0 | TSEG1 | 4  | RW | 一个 bit 中的时间段 1 的计数值 |

## 23.5.3 输出控制寄存器(OCR)

中文名: 输出控制寄存器

寄存器位宽:[7:0]偏移量:0x08复位值:0x00

| 位域   | 位域名称 | 位宽 | 访问 | 描述 |
|------|------|----|----|----|
| 7: 0 | OCR  | 8  | RW | 保留 |



# 24 ADC 控制器

## 24.1 概述

龙芯 1C 集成了 ADC 控制器,用于控制 ADC 的通道的使用,实现一些特定的应用,如连续转换、单次转换、触摸屏应用和模拟看门狗等。

龙芯 1C 中的 ADC 控制器的主要特性参数如下:

- 4 通道 ADC 模拟输入, 10bit 输出精度
- 测量电压范围为 0.01~0.99VREF, 推荐 VREF 输入 0.5~0.9VDDA
- ADC 的工作频率可配置,从 0~16M
- ADC 的工作模式有单次、连续转换、触摸屏应用属于特殊的连续转换
- ADC 的连续转换采用 DMA 传输数据,但触摸屏的坐标不采用 DMA
- ADC 的连续转换时间间隔可配置,从 0~1M
- ADC 的一些通道在连续转换时,未被用到的通道可进行单次转换
- 触摸屏应用时,当触摸屏被按下时产生中断,当触摸屏被释放时也产生 中断
- 可支持四线式触摸屏和五线式触摸屏,连接四线式触摸屏时有两路通用
   ADC 可以使用,连接五线式触摸屏时有三路通用 ADC 可以使用
- 可支持多通道扫描式单次转换
- 可支持 analog watchdog 功能,上限下限阈值可配置,超过阈值时产生中断

## 24.2 寄存器描述

| 寄存器名称   | 地址         | 读/写(R/W) | 功能描述  | 复位值      |
|---------|------------|----------|-------|----------|
| adc_cnt | 0xbfe74000 | R/W      | 分频和采样 | 0x400010 |
|         |            |          | 间隔寄存器 |          |



| Adc_cnt | 位     | 缺省值  | 描述                                                  |
|---------|-------|------|-----------------------------------------------------|
| adc_pre | 31:20 | 0x4  | adc 转换时钟的分频值,从 0~16M,分频<br>后的时钟为 F= sys_clk/adc_pre |
| cc_gap  | 19:0  | 0x10 | 连续转换的时间间隔计数,从 0~1M,使<br>用分频后的时钟计数                   |

| 寄存器名称      | 地址         | 读/写(R/W) | 功能描述  | 复位值 |
|------------|------------|----------|-------|-----|
| adc_s_ctrl | 0xbfe74004 | R/W      | 单次采样控 | 0x0 |
|            |            |          | 制寄存器  |     |

| adc_s_ctrl | 位    | 缺省值 | 描述                                    |
|------------|------|-----|---------------------------------------|
| reserved   | 31:7 | 0x0 |                                       |
| power_down | 6    | 0x0 | 停止 ADC 转换,包含所有的 AD 转换。<br>高电平有效,关闭电源。 |
| soft_reset | 5    | 0x0 | 软复位,高电平有效,硬件自动清0                      |
| soc        | 4    | 0x0 | 转换开始,高电平有效,硬件自动清 0                    |
| ch_s_sel   | 3:0  | 0x0 | 单次转换通道选择,4位对应4通道                      |

| 寄存器名称      | 地址         | 读/写(R/W) | 功能描述  | 复位值 |
|------------|------------|----------|-------|-----|
| adc_c_ctrl | 0xbfe74008 | r/w      | 连续采样控 | 0x0 |
|            |            |          | 制寄存器  |     |

| adc_c_ctrl     | 位    | 缺省值 | 描述                      |
|----------------|------|-----|-------------------------|
| reserved       | 31:8 | 0x0 |                         |
| cc_en          | 7    | 0x0 | 连续转换使能,为1时有效,为0时不启动连续转换 |
| touch_pad_sel  | 6    | 0x0 | 触摸屏应用使能,为1时使用触摸屏        |
|                |      |     | 四线式或者五线式触摸屏。            |
| mode5_or_mode4 | 5    | 0x0 | 为1时,五线式触摸屏;             |
|                |      |     | 为0时,四线式触摸屏。             |



| awatchdog_sel | 4   | 0x0 | 模拟看门狗使能,为1时有效    |
|---------------|-----|-----|------------------|
| ch_s_sel      | 3:0 | 0x0 | 单次转换通道选择,4位对应4通道 |

| 寄存器名称   | 地址         | 读/写(R/W) | 功能描述    | 复位值       |
|---------|------------|----------|---------|-----------|
| x_range | 0xbfe74010 | r/w      | 触摸屏 X 方 | 0x3ff0000 |
|         |            |          | 向阈值     |           |

| x_range     | 位     | 缺省值   | 描述                          |
|-------------|-------|-------|-----------------------------|
| reserved    | 31:26 | 0x0   |                             |
| x_range_max | 25:16 | 0x3ff | x 方向最大阈值,用于判断是否触摸屏是<br>否被按下 |
| reserved    | 15:10 | 0x0   |                             |
| x_range_min | 9:0   | 0x0   | x 方向最小阈值,用于判断是否触摸屏是<br>否被按下 |

| 寄存器名称   | 地址         | 读/写(R/W) | 功能描述    | 复位值       |
|---------|------------|----------|---------|-----------|
| y_range | 0xbfe74014 | r/w      | 触摸屏 X 方 | 0x3ff0000 |
|         |            |          | 向阈值     |           |

| y_range     | 位     | 缺省值   | 描述                          |
|-------------|-------|-------|-----------------------------|
| reserved    | 31:26 | 0x0   |                             |
| y_range_max | 25:16 | 0x3ff | y 方向最大阈值,用于判断是否触摸屏是<br>否被按下 |
| reserved    | 15:10 | 0x0   |                             |
| y_range_min | 9:0   | 0x0   | y 方向最小阈值,用于判断是否触摸屏是<br>否被按下 |

| 寄存器名称           | 地址         | 读/写(R/W) | 功能描述  | 复位值       |
|-----------------|------------|----------|-------|-----------|
| awatchdog_range | 0xbfe74018 | r/w      | 模拟看门狗 | 0x3f0000f |
|                 |            |          | 阈值    |           |



| awatchdog_range | 位     | 缺省值   | 描述                       |  |
|-----------------|-------|-------|--------------------------|--|
| reserved        | 31:26 | 0x0   |                          |  |
| awcg_range_max  | 25:16 | 0x3f0 | 模拟看门狗最大阈值,用于判断是否产生<br>中断 |  |
| reserved        | 15:10 | 0x0   |                          |  |
| awcg_range_min  | 9:0   | 0xf   | 模拟看门狗最小阈值,用于判断是否产生<br>中断 |  |

| 寄存器名称 | 地址         | 读/写(R/W) | 功能描述  | 复位值 |
|-------|------------|----------|-------|-----|
| axis  | 0xbfe7401c | ro       | 触摸屏坐标 | 0x0 |

| axis     | 位     | 缺省值 | 描述     |
|----------|-------|-----|--------|
| reserved | 31:26 | 0x0 |        |
| y_axis   | 25:16 | 0x0 | 触摸屏Y坐标 |
| reserved | 15:10 | 0x0 |        |
| x_axis   | 9:0   | 0x0 | 触摸屏X坐标 |

| 寄存器名称       | 地址         | 读/写(R/W) | 功能描述   | 复位值 |
|-------------|------------|----------|--------|-----|
| adc_s_dout0 | 0xbfe74020 | ro       | 单次转换结  | 0x0 |
|             |            |          | 果,通道 0 |     |
|             |            |          | 和通道 1  |     |

| adc_s_dout0 | 位     | 缺省值 | 描述                                     |
|-------------|-------|-----|----------------------------------------|
| adc_busy    | 31    | 0x0 | 转换忙状态,写 soc 后置为 1,所有单次<br>转换完成之后,硬件清 0 |
| reserved    | 30:26 | 0x0 |                                        |
| adc_data1   | 25:16 | 0x0 | 通道 1 单次转换的结果                           |
| reserved    | 15:10 | 0x0 |                                        |
| adc_data0   | 9:0   | 0x0 | 通道 0 单次转换的结果                           |



| 寄存器名称       | 地址         | 读/写(R/W) | 功能描述   | 复位值 |
|-------------|------------|----------|--------|-----|
| adc_s_dout1 | 0xbfe74024 | ro       | 单次转换结  | 0x0 |
|             |            |          | 果,通道 0 |     |
|             |            |          | 和通道 1  |     |

| adc_s_dout1 | 位     | 缺省值 | 描述                                     |
|-------------|-------|-----|----------------------------------------|
| adc_busy    | 31    | 0x0 | 转换忙状态,写 soc 后置为 1,所有单次<br>转换完成之后,硬件清 0 |
| reserved    | 30:26 | 0x0 |                                        |
| adc_data3   | 25:16 | 0x0 | 通道3单次转换的结果                             |
| reserved    | 15:10 | 0x0 |                                        |
| adc_data2   | 9:0   | 0x0 | 通道2单次转换的结果                             |

| 寄存器名称      | 地址         | 读/写(R/W) | 功能描述  | 复位值 |
|------------|------------|----------|-------|-----|
| adc_c_dout | 0xbfe74028 | ro       | 连续转换结 | 0x0 |
|            |            |          | 果     |     |

| adc_c_dout | 位     | 缺省值 | 描述                  |
|------------|-------|-----|---------------------|
| reserved   | 31:26 | 0x0 |                     |
| adc[i+1]   | 25:16 | 0x0 | 连续转换时 ADC[i+1]的转换结果 |
| reserved   | 15:10 | 0x0 |                     |
| adc[i]     | 9:0   | 0x0 | 连续转换时 ADC[i]的转换结果   |

| 寄存器名称            | 地址         | 读/写(R/W) | 功能描述  | 复位值   |
|------------------|------------|----------|-------|-------|
| adc_debounce_cnt | 0xbfe7402c | ro       | 触摸屏去抖 | 0x640 |
|                  |            |          | 动时间   |       |

| adc_debounce_cnt | 位     | 缺省值 | 描述 |
|------------------|-------|-----|----|
| reserved         | 31:20 | 0x0 |    |



| debounce_cnt | 19:0 | 0x640 | 去抖动延时时间 |
|--------------|------|-------|---------|
|--------------|------|-------|---------|

| 寄存器名称   | 地址         | 读/写(R/W) | 功能描述    | 复位值 |
|---------|------------|----------|---------|-----|
| adc_int | 0xbfe74030 | ro       | ADC 中断标 | 0x0 |
|         |            |          | 志和控制    |     |

| adc_int          | 位     | 缺省值 | 描述                              |
|------------------|-------|-----|---------------------------------|
| reserved         | 31:10 | 0x0 |                                 |
| fifo_empty       | 9     | 0x0 | 连续转换时 fifo 为空状态                 |
| fifo_full_int_en | 8     | 0x0 | 连续转换时 fifo 满中断使能,为1时开启中断,为0时屏蔽  |
| awcg_int_en      | 7     | 0x0 | 模拟看门狗中断使能,为1时开启中断,<br>为0时屏蔽     |
| release_int_en   | 6     | 0x0 | 触摸屏被释放中断使能,为1时开启中断,<br>为0时屏蔽    |
| press_int_en     | 5     | 0x0 | 触摸屏被按下中断使能,为1时开启中断,<br>为0时屏蔽    |
| Fifo_full_int    | 4     | 0x0 | 连续转换时 fifo 满中断状态,软件写 1 清        |
| awcg_h_int       | 3     | 0x0 | 模拟看门狗电压超过最大阈值中断状态,<br>软件写 1 清 0 |
| awcg_l_int       | 2     | 0x0 | 模拟看门狗电压低于最小阈值中断状态,<br>软件写 1 清 0 |
| release_int      | 1     | 0x0 | 触摸屏被释放中断状态,软件写 1 清 0            |
| press_int        | 0     | 0x0 | 触摸屏被按下中断状态,软件写 1 清 0            |

# 24.3 配置操作

ADC 接口在正常工作之前,需要对各个寄存器进行配置。

配置 ADC 控制器接口的工作流程如下:

1. 配置 adc\_int 寄存器,开启或者关闭 ADC 控制器的中断。



- 2. 配置时间参数寄存器 adc\_cnt,设置分频系数和连续转换的间隔时间。
- 3. 如果有触摸屏应用,配置 adc\_debounce\_cnt,设置按下或释放的去抖动时间,另外配置 X 方向和 Y 方向的阈值,用于判断是否产生中断。
- 4. 如果有模拟看门狗应用,配置 awatchdog\_range 寄存器,设置看门狗的 阈值。
- 5. 配置 adc\_c\_ctrl 寄存器,设置应用模式(如触摸屏应用、模拟看门狗) 和连续转换的通道。
- 6. 配置 adc\_s\_ctrl 寄存器,设置单次转换的通道,以及开始和停止转换。
- 7. 读结果寄存器。单次转换的结果存放在 adc\_s\_dout0 和 adc\_s\_dout1; 触 摸屏的坐标存放在 axis; 连续转换的结果通过 DMA 读 adc\_c\_dout 寄存器。

注:连续转换开始之后,除非配置 adc\_c\_ctrl[7]为 0,否则连续转换不会停止。如果需要改变连续转换的通道,则需要先停止连续转换,重新配置完通道之后,再开始转换。如果连续转换过程中需要插入单次转换(正在使用的连续转换通道不能再做单次转换),不需要停止连续转换。每一次连续转换的结果会替换前一次的值,所以触摸屏坐标 axis 和 adc\_c\_dout 要及时读走。

另外通用 ADC 连续转换时,通道选择与 adc\_c\_dout 输出的对应关系如下表。如: ch\_c\_sel[3:0]=b 时,选择 ADC0,ADC1 和 ADC3 连续转换,则 ADC0 的数据放在第 1 个 word 的 adc\_c\_dout[9:0], ADC1 的数据放在第 1 个 word 的 adc c dout[25:16], ADC3 的数据放第 2 个 word 的 adc c dout[9:0]。

| ch_c_sel[3:0] | ch[0]      | ch[1]        | ch[2]        | ch[3]      |
|---------------|------------|--------------|--------------|------------|
| 1             | Dout0[9:0] |              |              |            |
| 2             |            | Dout0[9:0]   |              |            |
| 3             | Dout0[9:0] | Dout0[25:16] |              |            |
| 4             |            |              | Dout0[9:0]   |            |
| 5             | Dout0[9:0] |              | Dout0[25:16] |            |
| 6             |            | Dout0[9:0]   | Dout0[25:16] |            |
| 7             | Dout0[9:0] | Dout0[25:16] | Dout1[9:0]   |            |
| 8             |            |              |              | Dout0[9:0] |



| 9 | Dout0[9:0] |              |              | Dout0[25:16] |
|---|------------|--------------|--------------|--------------|
| а |            | Dout0[9:0]   |              | Dout0[25:16] |
| b | Dout0[9:0] | Dout0[25:16] |              | Dout1[9:0]   |
| С |            |              | Dout0[9:0]   | Dout0[25:16] |
| d | Dout0[9:0] |              | Dout0[25:16] | Dout1[9:0]   |
| е |            | Dout0[9:0]   | Dout0[25:16] | Dout1[9:0]   |
| f | Dout0[9:0] | Dout0[25:16] | Dout1[9:0]   | Dout1[25:16] |

连续转换中插入单次转换的时序图如下:



图 24-1 ADC 单次转换/连续转换示意图

如果 cc\_gap 时间间隔不够插入一次单次转换,则会导致下一次连续转换时间点往后移,需要软件配置 cc\_gap 时注意。



# 25 PWM 控制器

## 25.1 概述

龙芯 1C 里实现了四路脉冲宽度调节/计数控制器,以下简称 PWM. 每一路 PWM 工作和控制方式完全相同. 每路 PWM 有一路脉冲宽度输出信号 (pwm\_o). 系统时钟高达 100MHz, 计数寄存器和参考寄存器均 24 位数据宽度。

四路 PWM 控制器系统的基地址具体如下:

|      | 四江市沿河田火     |
|------|-------------|
| 名称   | 基地址(Base)   |
| PWM0 | 0xbfe5_c000 |
| PWM1 | 0xbfe5_c010 |
| PWM2 | 0xbfe5_c020 |
| PWM3 | 0xbfe5_c030 |

表 25-1 四路控制器描述

每路控制器共有四个控制寄存器,具体描述如下:

| <b>在 23-2 控制 奇仔</b> 舒伸处 |            |    |     |            |  |
|-------------------------|------------|----|-----|------------|--|
| 名称                      | 地址         | 宽度 | 访问  | 说明         |  |
| CNTR                    | Base + 0x0 | 24 | R/W | 主计数器       |  |
| HRC                     | Base + 0x4 | 24 | R/W | 高脉冲定时参考寄存器 |  |
| LRC                     | Base + 0x8 | 24 | R/W | 低脉冲定时参考寄存器 |  |
| CTRL                    | Base + 0xC | 8  | R/W | 控制寄存器      |  |

表 25-2 控制寄存器描述

## 25.2 PWM 寄存器说明

实现脉冲宽度功能

CNTR 寄存器可以由系统编程写入获得初始值,系统编程写入完毕后,CNTR 寄存器在系统时钟驱动下不断自加,当到达 LRC 寄存器的值后清 0. 然后重新开始不断自加,控制器就产生连续不断的脉冲宽度输出。

| 7 = 5 = 77 88 82 |        |     |     |                                                                                                                |  |  |  |
|------------------|--------|-----|-----|----------------------------------------------------------------------------------------------------------------|--|--|--|
| CNTR             | 位域     | 访问  | 复位值 | 说明                                                                                                             |  |  |  |
| Reserved         | 31: 24 | R/W | 0x0 |                                                                                                                |  |  |  |
| CNTR             | 23: 0  | R/W | 0x0 | 主计数器计数值,计数器开始<br>工作(CTRL[0]为1)后,计<br>数到 Lvalue 时,计数器清零。<br>如果 CTRL[4]为0,则计数器<br>从头开始计数;如果 CTRL[4]<br>为1,则计数器停止 |  |  |  |

表 25-3 主计数器设置

HRC 寄存器由系统写入,当 CNTR 寄存器的值等于 HRC 的值的时候,控制 255



器产生高脉冲电平。

表 25-4 高脉冲计数阈值设置

| Hvalue   | 位域    | 访问  | 复位值 | 说明                                       |
|----------|-------|-----|-----|------------------------------------------|
| Reserved |       |     |     |                                          |
| Hvalue   | 23: 0 | R/W | 0x0 | 高脉冲计数阈值,当计数器计到该阈值时,输出高电平(需将 CTRL[3]配置成0) |

LRC 寄存器由系统写入,当 CNTR 寄存器的值等于 LRC 的值的时候,控制器产生低脉冲电平。

表 25-5 低脉冲计数阈值设置

|          | 71 - 1 |     |     |                                    |  |  |
|----------|--------|-----|-----|------------------------------------|--|--|
| Lvalue   | 位域     | 访问  | 复位值 | 说明                                 |  |  |
| Reserved |        |     |     |                                    |  |  |
| Lvalue   | 23: 0  | R/W | 0x0 | 低脉冲计数阈值,当计数器<br>计到该阈值时,同时输出低<br>电平 |  |  |

例:如果要产生宽度为系统始终周期 50 倍的高脉宽和 90 倍的低脉宽,在 HRC 中应该配置初始值(90-1)=89,在 LRC 寄存器中配置初始值(50+90-1)=139.

当工作在定时器模式下,CNTR 记录内部系统时钟. HRC 和 LRC 寄存器的 初始值系统编程写入,当 CNTR 寄存器的值等于 HRC 或者 LRC 的时候,芯片会产生一个中断,这样就实现了定时器功能.

CTRL 控制寄存器,在上面三种工作模式下,控制寄存器的功能不变,根据功能需求选择不同的配置。

表 25-6 控制寄存器设置

| CTRL       | 位域  | 访问  | 复位值 | 描述                                                                      |
|------------|-----|-----|-----|-------------------------------------------------------------------------|
| INT_LRC_EN | 11  | R/W | 0   | 低脉冲计数器中断使能<br>置 1 时:当 INTEN 为 1 时,CNTR<br>计数到 LRC 后产生中断<br>置 0 时:不产生中断  |
| INT_HRC_EN | 10  | R/W | 0   | 高脉冲计数器中断使能<br>置 1 时:当 INTEN 为 1 时,CNTR<br>计数到 HRC 后产生中断,<br>置 0 时:不产生中断 |
| Reserved   | 9:8 | R/W | 0   |                                                                         |
| CNTR_RST   | 7   | R/W | 0   | 使得 CNTR 计数器清零 置 1 时: CNTR 计数器清零                                         |



|          |      |     |       | 置 0 时: CNTR 计数器正常工作                                                 |
|----------|------|-----|-------|---------------------------------------------------------------------|
| INT_SR   | 6    | R/W | 0     | 中断状态位<br>读操作:1表示有中断产生,0表示没<br>有中断<br>写入1:清中断                        |
| INTEN    | 5    | R/W | 0     | 中断使能位<br>置1时:中断使能,仅当此位为1<br>并且满足高脉冲或低脉冲中断条件<br>时会产生中断。<br>置0时:不产生中断 |
| SINGLE   | 4    | R/W | 0     | 单脉冲控制位置1时:脉冲仅产生一次置0时:脉冲扶续产生                                         |
| OE       | 3    | R/W | 0     | ,脉冲输出使能控制位,低有效<br>置 0 时:脉冲输出使能<br>置 1 时:脉冲输出屏蔽                      |
| Reserved | 2: 1 | R/W | 2' b0 | 预留                                                                  |
| CNT_EN   | 0    | R/W | 0     | 主计数器使能位<br>置 1 时: CNTR 用来计数<br>置 0 时: CNTR 停止计数                     |



# 26 看门狗 (WDT)

## 26.1 概述

在系统中看门狗定时器(WDT, Watch Dog Timer)实际上是一个计数器,一般给看门狗一个大数,程序开始运行后看门狗开始倒计数。如果程序运行正常,过一段时间 CPU 应发出指令让看门狗复位,重新开始倒计数。如果看门狗减到0 就认为程序没有正常工作,强制整个系统复位。下图是看门狗的实现,系统对看门狗进行配置,看门狗内部有个计数器,同时看门狗里面的比较器比较计数器值是否为零,如果为零就发出软复位信号让系统重启。



图 26-1 看门狗结构图

## 26.2 WATCH DOG 寄存器描述

看门狗逻辑可编程寄存器主要有三个。这些寄存器描述如下:

#### 26.2.1 看门狗使能寄存器(WDT EN)

地址: 0xbfe5\_c060

| 位    | 位域名    | 读写  | 描述       |
|------|--------|-----|----------|
| 31:1 |        |     | Reserved |
| 0    | WDT_EN | R/W | 看门狗使能    |

## 26.2.2 看门狗设置寄存器(WDT\_SET)

地址: 0xbfe5\_c068

| 位    | 位域名     | 读写  | 描述        |
|------|---------|-----|-----------|
| 31:1 |         |     | Reserved  |
| 0    | WDT_SET | R/W | 看门狗中计数器设置 |



## 26.2.3 看门狗计数器 (WDT\_timer)

地址: 0xbfe5\_c064

| 位    | 位域名       | 读写  | 描述        |
|------|-----------|-----|-----------|
| 31:0 | WDT_timer | R/W | 看门狗计数器计数值 |

系统这三个寄存器的设置顺序:系统先配置看门狗使能位 WDT\_EN;然后配置看门狗开始计数器的初始值 WDT\_TIMER,该值保持在一个特别的寄存器中;当系统设置 WDT\_SET 后,计数器开始计数。

看门狗不实现低功耗功能,看门狗功能的工作和硬件设计没有关系。如果需要看门狗工作,软件需要定时去更新器计数器的数值。



# 27 高精度定时器(HCNTR)

## 27.1 概述

1C2 芯片内部增加了一个高精度定时器,采用 1M 时钟计数,根据配置寄存器可产生最小 1us,最大 2<sup>31</sup>us 周期的中断输出。该定时器时钟来自于外部晶振,不受芯片运行频率影响,在系统实现动态降频时,能提供稳定的时钟。

## 27.2 寄存器描述

| 寄存器名称      | 地址         | 读/写 | 功能描述       | 复位值 |
|------------|------------|-----|------------|-----|
| hcntr_ctrl | 0xbfe7c000 | r/w | CNTR 控制寄存器 | 0x0 |

| hcntr_ctrl | 位    | 缺省值 | 描述                                        |
|------------|------|-----|-------------------------------------------|
| cnt_en     | 31   | 0x0 | 计数器使能。为 1 时计数器开始计数,为 0 时停止计数。             |
| Reserved   | 30:5 | 0x0 |                                           |
| int_prd    | 4:0  | 0x0 | 定时器中断周期。中断的周期为<br>2 <sup>int_prd</sup> us |

| 寄存器名称      | 地址         | 读/写 | 功能描述      | 复位值 |
|------------|------------|-----|-----------|-----|
| hcntr_cntr | 0xbfe7c004 | ro  | CNTR 计数器值 | 0x0 |

| hcntr_ctrl | 位     | 缺省值 | 描述            |
|------------|-------|-----|---------------|
| Reserved   | 31:20 | 0x0 |               |
| hcntr_cntr | 19:0  | 0x0 | 定时器计数值,为当前计数值 |

该定时器只能实现 2 的幂次周期定时,如 1、2、4、8、16us 等。例如将  $int_prd$  配置为 5,则中断周期为  $2^5=32us$ 。