HI3531的DDR3配置流程
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 就可以正常工作。
HI3531的DDR3配置流程的更多相关文章
- QT特供 CGAL配置流程(基于QT5+VS2015)
最近做的QT项目涉及计算几何库,需要用到CGAL,其配置着实麻烦,而且相互关联的软件也存在版本兼容一类的问题,在这里就对其配置流程做一些整理说明,以便后来者能够少些烦恼.(注:以下使用Win10作说明 ...
- 转载-Linux下svn搭建配置流程
Linux下svn搭建配置流程 一. 源文件编译安装.源文件共两个,为: 1. 下载subversion源文件 subversion-1.6.1.tar.gz http://d136 ...
- win10下vagrant+centos7 rails虚拟开发机配置流程
此文写于2017.8.21 在写本文前,笔者已经尝试了多种其他的替代方法,例如wmware虚拟机安装kylin.然而发现总是还有各种问题.经大佬指点安装了virtualbox + vagrant.于是 ...
- Linux下双网卡Firewalld的配置流程
实验室拟态存储的项目需要通过LVS-NAT模式通过LVS服务器来区隔内外网的服务,所以安全防护的重心则落在了LVS服务器之上.笔者最终选择通过firewalld放行端口的方式来实现需求,由于firew ...
- Java采用RSA加密及解密技术的有关Maven项目的配置流程:
第一步: 获得RSA公钥私钥(秘钥格式:PKCS#8 ,测试使用的是无私钥密码的) 公钥: -----BEGIN PUBLIC KEY----- MIGfMA0GCSqGSIb3DQEBAQUAA4G ...
- xampp+vscode开发php的配置流程
一.所需文件 1.xampp集成服务器(个人使用7.1.7)https://www.apachefriends.org/download.html 2.vscode https://code.visu ...
- GPON介绍及华为OLT网关注册配置流程(转)
原文地址:https://blog.csdn.net/zhouzxi/article/details/79244862 一.GPON介绍 1.GPON简介 随着技术的发展,光纤变得“便宜又好用”,因此 ...
- nagios部署配置流程
nagios部署配置流程 nagios服务端:1.部署nagios服务端(参考nagios官方部署文档).nagios-plugin.php.apache2 2.需要在服务端添/etc/hosts中添 ...
- 安装完SAP后BASIS的配置流程
安装完SAP后BASIS配置流程 安装完SAP后,配置流程. 1.升级kernel. 2.TCD SLICENSE: License Administration install > Syste ...
随机推荐
- MongoDB 基本操作学习笔记
// 查看所有数据库 show dbs // amdin 0.000GB // local 0.000GB // 使用数据库 use admin // switched to db admin // ...
- java Object类是可以接收集合类型的
废话不多说,上代码: package com.core.test; import java.util.ArrayList; import java.util.HashMap; import java. ...
- 从程序员的角度设计一个Java的神经网络
欢迎大家前往云+社区,获取更多腾讯海量技术实践干货哦~ 来自维基百科: 人工神经网络(ANN)或连接系统是受生物神经网络启发构成生物大脑的计算系统.这样的系统通过考虑例子来学习(逐步提高性能)来完成任 ...
- Cypher查询语言--Neo4j-WHERE(三)
目录 Where Boolean 操作类型 节点属性上的过滤 正则表达式 转义正则表达式 不分大小些正则表达式 关系类型上的过滤 属性存在性 如果缺失属性默认为true 如果缺失属性默认为false ...
- HibernateTemplate#setMaxResults()的坑
如题所示,因为maxResults为实例属性,一经修改,则会应用于所有查询! 不是很清楚,Spring为什么要挖这个坑? 我的解决方案:如需设置返回结果集的大小,则通过HibernateCallbac ...
- Job 失败了怎么办?- 每天5分钟玩转 Docker 容器技术(133)
上一节讨论了 Job 执行成功的情况,如果失败了会怎么样呢? 修改 myjob.yml,故意引入一个错误: 先删除之前的 Job: 如果将 restartPolicy 设置为 OnFailure 会怎 ...
- 使用tcp+select实现客户端与客户端的通信
使用多路复用实现客户端与客户端进行通信: 原理:客户端只要一连上服务器,立马给服务器发送用户名,然后在服务端将newsocketfd存放在同一个结构体中,客户端先给服务器发送数据,然后通过服务器转发给 ...
- 【JavaWeb】c3p0连接池与MySQL
正文之前 在之前的文章讲到了传统的JDBC连接MySQL的方式,但是这样的方式在进行多个连接时,就显得效率低下,明显不如连接池的效率,所以我们这次来讲解一下JDBC连接池之一:c3p0 正文 1. 准 ...
- .35-浅析webpack源码之babel-loader入口文件路径读取
在处理./input.js入口文件时,在类型判断被分为普通文件,所以走的文件事件流,最后拼接得到文件的绝对路径. 但是对应"babel-loader"这个字符串,在如下正则中被判定 ...
- golang的GET请求(类似于PHP的CURL)
check_url := "https://www.baidu.com" header := make(map[string]string) res, err := util.Hp ...