1、概述

  i.MX 6ULL系列芯片的MMDC是一个多模式DDR控制器,支持DDR3/DDR3Lx16和LPDDR2x16的存储类型,MMDC是可配置,高性能,优化的内存控制器。

  注:DDR3/DDR3Lx16、LPDDR2x16 ,此处的x16表示芯片位宽,每个传输周期能够提供的数据量(bit)。也就是说明,如果要提供32位的位宽内存存储,需要2颗以上型号的内存进行并联使用。

  下面是MMDC逻辑框图:

  •   MMDC由内核(MMDC_CORE)和物理层(MMDC_PHYl)两部分构成。
  •   内核负责通过AXI接口,DDR命令发生器,DDR命令优化器,和读写数据通道与系统通信,物理层负责定时调整,它使用特殊校准机制确保数据获取400MHz的时钟频率。
  •   MMDC的内部配置寄存器通过IP通道进行配置。

  DDR标准:

  • DDR3L,DDR3x16 LPDDR2x16
  • 不支持LPDDR1MDDR 和DDR2

DDR接口:

  • 16位数据总线宽度;
  • 器件密度-256Mbits-8Gbits,其中列8-12bit,行11-16bit;
  • 通过配置CS0,CS1可以达到4Gbyte地址空间;
  • DDR3支持的突发长度为8;
  • LPDDR2支持的突发长度为4;

DDR性能:

  • 400MHz核心频率,800MHz数据频率
  • 支持实时优先级,支持不同优先级的重新排序机制:实时,延时敏感,正常优先级
  • 页面碰撞错过优化
  • 连续读写访问优化
  • 支持深度读写请求队列,支持bank预测
  • 支持bank交叉
  • ddr3模式下(突发长度)的非对齐换行访问情况下的特殊优化

AXI接口:

  • 运行在400MHz,支持传输8/16/64 bits(单一访问和突发)
  • 支持最大突发长度为16
  • 支持16bits AXI ID

DDR通用设置:

  • 可配置时序参数
  • 可配置刷新周期
  • 支持页边界交叉
  • 支持LPDDR2 MRW和MRR指令

 2、外部接口信号

3、时钟源

  

  时钟设置参考CCM(clock controller module)模块

4、功能性说明

  4.1 读/写数据流

   4.2 MMDC初始化

   4.3 配置MMDC寄存器

   4.4 MMDC地址空间

   4.5 LPDDR2与DDR3引脚复用映射

      4.6  节能和时钟切换模式

   4.7 复位

   4.8 刷新计划

   4.9 用于DDR的突发长度选项

   4.10 独家访问处理

   4.11 AXI错误处理

5、性能

   5.1 仲裁和重新排序机制

   5.2 预测机制

   5.3 针对DDR3访问的特殊优化

6、MMDC 调试

7、 MMDC 剖析

8、LPDDR2刷新率更新和定时减量

9、DLL切换

10、ODT配置

11、校准过程

12、MMDC 内存映射/寄存器定义

  参考资料:

https://blog.csdn.net/u011124985/article/details/81140819

IMX6ULLRM.pdf——恩智浦提供下载

https://baike.baidu.com/item/%E5%86%85%E5%AD%98%E6%9D%A1

Cortext-A7_i.MX 6ULL——多模式DDR控制器(MMDC)的更多相关文章

  1. mig_7series DDR控制器的配置

    mig_7series DDR控制器的配置

  2. ThinkPHP3开发模式,控制器操作,配置文件,框架语法

    ThinkPHP的开发模式 tp框架有两种使用模式:开发模式(调试模式),一种是生产模式(运行模式) define('APP_DEBUG', true);  //调试模式 define('APP_DE ...

  3. thinkphp3.2笔记(1)目录,控制器及url模式,地址解析

    一.目录 Application  :  tp默认的应用代码存储的目录 Public :     Tp 默认的存储静态资源的目录,img,css,js ThinkPHP  :   Tp  框架的源代码 ...

  4. 编写SDR SDRAM页突发模式控制器的注意点

    网上有很多的SDR SDRAM控制器的代码,但都是基于burst1/2/4/8模式下的,这种模式下传输高速的相机数据还是有点拮据的,所以花了几天把这些模式改造成了页突发模式.我的这个控制器模型是这样的 ...

  5. zedboard如何从PL端控制DDR读写(五)

    有了前面的一堆铺垫.现在终于开始正式准备读写DDR了,开发环境:VIVADO2014.2 + SDK. 一.首先要想在PL端通过AXI去控制DDR,我们必须要有一个AXI master,由于是测试,就 ...

  6. 痞子衡嵌入式:飞思卡尔i.MX RT系列MCU特性介绍(1)- 概览

    大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是飞思卡尔i.MX RT系列MCU的基本特性. ARM Cortex-M微控制器芯片厂商向来竞争激烈,具体可参看我的另一篇文章<第一 ...

  7. DDR电源硬件设计要点

    一.DDR电源简介 1. 电源 DDR的电源可以分为三类: a.主电源VDD和VDDQ,主电源的要求是VDDQ=VDD,VDDQ是给IO buffer供电的电源,VDD是给但是一般的使用中都是把VDD ...

  8. 基于MIG IP核的DDR3控制器(一)

    最近学习了DDR3控制器的使用,也用着DDR完成了一些简单工作,想着以后一段可能只用封装过后的IP核,可能会忘记DDR3控制器的一些内容,想着把这个DDR控制器的编写过程记录下来,便于我自己以后查看吧 ...

  9. 痞子衡嵌入式:飞思卡尔i.MX RTyyyy系列MCU特性那些事(1)- 概览

    大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是飞思卡尔i.MX RTyyyy系列MCU的基本特性. ARM Cortex-M微控制器芯片厂商向来竞争激烈,具体可参看我的另一篇文章&l ...

随机推荐

  1. R和Python,对抗or融合?

    来源商业新知网,原标题:从对抗到融合,教你充分利用R+Python! 我们应该将关注点放在技能上,而不是工具上. 如果你从事数据科学的工作,可能会立即想到两种编程语言:R和Python. 事实上,R和 ...

  2. c语言作业01-分支、顺序结构

    1.本章思考总结 1.1思维导图 1.2本章学习体会及代码量学习体会 1.2.1学习体会 这一个星期算是我学习c语言的起点,因为暑假没有提前自学c语言,所以一上课时会觉得比较吃力也难以跟上其他大部分同 ...

  3. padding设置和清除

    padding设置和清除 标签(空格分隔): padding padding介绍: padding:就是内边距的意思,它是边框到内容之间的距离: 另外padding的区域是有背景颜色的.并且背景颜色和 ...

  4. SQLAlchemy介绍

    SQLAlchemy 增删改查 一对多 多对多   Python 的 ORM 框架 SQLAlchemy 有些同学已经听说过这个框架的大名了,也听说了 SQLAlchemy 没有 Django 的 M ...

  5. CSS的优先级和继承问题

    CSS的优先级和继承问题 ★CSS的冲突,即优先级 CSS本身的设置可以同时应用多个样式在同一个元素,此时样式之间可能出现冲突而达不到用户所想要的效果. ★解决CSS冲突的优先级规则: ● CSS层叠 ...

  6. 网络赛 I题 Max answer 单调栈+线段树

    题目链接:https://nanti.jisuanke.com/t/38228 题意:在给出的序列里面找一个区间,使区间最小值乘以区间和得到的值最大,输出这个最大值. 思路:我们枚举每一个数字,假设是 ...

  7. docker简单搭建gitlab

    docker启动非常简单: docker run --detach --hostname 192.168.0.33 --publish 443:443 --publish 80:80 \ --publ ...

  8. Hillstone目的地址转换DNAT配置

    目的地址映射主要用于将内网的服务器对外进行发布(如http服务,ftp服务,数据库服务等),使外网用户能够通过外网地址访问需要发布的服务. 常用的DNAT映射有一对一IP映射,一对一端口映射,多对多端 ...

  9. ABAP开发规范

    一.数据库操作 1.禁止修改系统标准表. 2.如果使用到FOR ALL ENTRIES IN语句取数,一定要校验关联内表非空性. 3.禁止一条SELECT关联的表超过5张,需要多表取值的时候建议分开取 ...

  10. mongod.service: control process exited, code=exited status=1

    Cent OS 7上需要把mongoDB添加到systemd,否则会出现上面的错误 将mongoDB添加到systemd # vim /usr/lib/systemd/system/mongod.se ...