HI3531的DDR3配置流程

简介: <p>DDR3 初始化配置流程</p> <p>系统上电之后,必须先完成DDR3 SDRAM 的初始化操作,系统才能访问DDR3<br> SDRAM。在进行初始化之前需要注意以下几点:<br></p> <p>对DDR3 SDRAM 进行上电操作时,需要遵循JEDEC 标准。即先提供VDD,然<br> 后提供VDDQ,最后提供VREF 和VTT。<br>  该初始化过程需要在系统进入

DDR3 初始化配置流程

系统上电之后,必须先完成DDR3 SDRAM 的初始化操作,系统才能访问DDR3
SDRAM。在进行初始化之前需要注意以下几点:

对DDR3 SDRAM 进行上电操作时,需要遵循JEDEC 标准。即先提供VDD,然
后提供VDDQ,最后提供VREF 和VTT。
 该初始化过程需要在系统进入NORMAL 模式后进行。
在DDRC 32bit 模式下,假设存储空间由两片容量为1Gbit,数据总线位宽为16bit 的
DDR3 SDRAM 构成,DDRC 的初始化步骤如下:
1. 软件等待200us 以上。
2. 把DDRC_IOCFG 寄存器配置为0x467,配置IO 的工作模式、匹配电阻以及信号驱
动。
3. 根据器件的单片容量配置DDRC_RNKCFG 寄存器为0x122。总线地址映射模式为RB-
C-DW 模式,AP 为A10,列地址宽度为10,行地址宽度为13。
4. 把DDRC_PHYSRST 配置为0x0,把DDRC_CDLLCFG,DDRC_QDLLCFG0~3 寄存器
配置为0x52,复位DDR PHY 和DLL。
5. 软件等待50ns。
6. 把DDRC_PHYSRST 配置为0x1,把DDRC_CDLLCFG,DDRC_QDLLCFG0~3 寄存器
配置为0x56,撤消DDR PHY 和DLL 复位。
7. 软件等待3us 以上。
8. 配置DDRC_TIMING2 寄存器[taref]为0x000,禁止自动刷新。
9. 配置DDRC_CTRL 寄存器为0x1,配置DDR3 SDRAM 退出复位状态。
10. 软件等待500us 以上。
11. 把DDRC_SREFCTRL 寄存器配置为0x0,退出自刷新状态。
12. 软件等待1us 以上。
13. 根据工作频率和器件要求,配置DDRC_EMRS01 寄存器和DDRC_EMRS23 寄存器,
以设置DDR 的读延迟(cas latency),写延迟(cas write latency),写恢复延迟(write
recovery),突发长度(burst length),DDR 器件的输出驱动阻抗和输入ODT 阻抗
等。
cas latency 和必须和DDRC_TIMING1[cl]设置成同一个值。
cas write latency 和必须和DDRC_TIMING1[wl]设置成同一个值。
DDRC_EMRS01 寄存器对应DDR3 SDRAM 的模式寄存器MRS 和扩展模式寄存器1
(EMRS1)。配置该寄存器时,只需要DDR3 SDRAM 器件手册的模式寄存器的A15-A0(实际有
效位为:A13~A0),不需要配置模式寄存器的最高3 位A18~A16 寄存器选择位,即bank 地址。
但是,有些DDRn SDRAM 厂家的bank 地址是:A17~A15。
14. 根据器件的类型和存储空间配置DDRC_CONFIG0 寄存器为0x8000_0610,
DDRC_CONFIG1 寄存器为0x785,表示DDRC 为32bit DDR3 SDRAM 模式。
低功耗配置的上电复位值是关闭的,初始化过程中必须关闭低功耗自动进入功能以及时钟自动关
闭功能,但在正常使用中,建议使能低功耗的控制,可以降低功耗。
15. 配置存储空间基地址寄存器DDRC_BASEADDR 为0x8000_0000。
16. 根据工作频率和器件要求配置DDRC_TIMING0~DDRC_TIMING3 的值,其中cl 和wl
值必须跟DDRC_EMRS01 和DDRC_EMRS23 模式寄存器中的配置一致。
17. 配置DDRC_DTRCTRL 寄存器为0x0F00_0503,使能初始化自动训练模式。
18. 配置DDRC_ODTCFG 寄存器DDRC_ODTCFG[wodt0]=0x1,
DDRC_ODTCFG[rodt0]=0x0。
19. 配置DDRC_PHYCFG 寄存器0x2。
20. 将DDRC_INITCTRL 寄存器设置为0x1,启动初始化过程。
21. 等待DDRC_INITCTRL 寄存器的值变为0,初始化完成。
----结束
完成以上步骤以后,DDR3 SDRAM 就可以正常工作。

 

相关文章
|
Linux
项目总结:i.mx6ull基于S485控制外设
项目总结:i.mx6ull基于S485控制外设
699 1
项目总结:i.mx6ull基于S485控制外设
DDR3L内存,12800S/12800R/12800L分别是什么意思?
DDR3L内存,12800S/12800R/12800L分别是什么意思?
673 0
|
2月前
|
缓存 Ubuntu Linux
Linux环境下测试服务器的DDR5内存性能
通过使用 `memtester`和 `sysbench`等工具,可以有效地测试Linux环境下服务器的DDR5内存性能。这些工具不仅可以评估内存的读写速度,还可以检测内存中的潜在问题,帮助确保系统的稳定性和性能。通过合理配置和使用这些工具,系统管理员可以深入了解服务器内存的性能状况,为系统优化提供数据支持。
73 4
|
8月前
|
存储 API 开发工具
【ZYNQ】SD 卡读写及文件扫描实验
【ZYNQ】SD 卡读写及文件扫描实验
380 0
|
8月前
|
存储 芯片 C++
STM32启动详细流程分析(一)
STM32启动详细流程分析(一)
341 0
|
缓存 开发工具 内存技术
ZYNQ-使用自定义AXI总线IP核进行DDR读写测试(二)
ZYNQ-使用自定义AXI总线IP核进行DDR读写测试
922 0
ZYNQ-使用自定义AXI总线IP核进行DDR读写测试(二)
|
Linux Windows 内存技术
PCIe初始化枚举和资源分配流程分析
本文主要是对PCIe的初始化枚举、资源分配流程进行分析,代码对应的是alikernel-4.19,平台是arm64 ## 1. PCIe architecture ### 1.1 pcie的拓扑结构 在分析PCIe初始化枚举流程之前,先描述下pcie的拓扑结构。 如下图所示: ![11.png](https://ata2-img.oss-cn-zhangjiakou.aliyuncs
7699 1
PCIe初始化枚举和资源分配流程分析
RK3399平台开发系列讲解(USB转串口)5.49、/dev/ttyUSB 修改串口名
RK3399平台开发系列讲解(USB转串口)5.49、/dev/ttyUSB 修改串口名
240 0
 RK3399平台开发系列讲解(USB转串口)5.49、/dev/ttyUSB 修改串口名
|
弹性计算
阿里云开mc我的世界服务器CPU内存配置选择及报价
阿里云服务器搭建Minecraft我的世界CPU内存配置怎么选择?公网带宽和系统盘选择多少合适?一般20人以内玩家、1.12版本的大型整合包、100个以内个轻量mod,2核4G配置就够用了,公网带宽选择3M或5M都可以,系统盘就高效云盘40GB够用了
901 0
阿里云开mc我的世界服务器CPU内存配置选择及报价
|
芯片 异构计算 内存技术
FPGA - DDR IP配置
FPGA - DDR IP配置
290 0
FPGA - DDR IP配置