当前位置: 首页 > news >正文

DDR自学笔记

DDR的技术发展

标准名称

内核时钟(MHz)

I/O时钟(MHz)

工作电压(v)

预取位数

突发长度

数据速率(MT/s)

数据带宽(GB/s)

拓扑

SDRAM

100-166

100-166

3.3

1

/

100-166

0.8-1.3

T

DDR

133-200

133-200

2.5

2n

2

266-400

2.1-3.2

T

DDR2

133-200

266-400

1.8

4n

4

533-800

4.2-6.4

T

DDR3

133-200

533-800

1.5

8n

8

1066-1600

8.5-14.9

Fly-by

DDR4

133-200

1066-1600

1.2

8n

8

2133-3200

17-21.5

Fly-by

DDR5

?

1600-3200

1.1

16n

3200-6400

32

Fly-by

DDR3之前都是内核时钟与外部IO的时钟的Prefetch预取数的倍数关系,DDR4是引入bank grounp的概念,导致与DDR3同样的预取数,但是IO时钟可以加倍,由于上下边沿采样数据,所以数据的速率又是IO时钟的2倍关系。

数据速率和带宽的关系是:数据速率*位宽数据带宽 

DDR4内部框图

                                                   图: MT40A1G8 的内部框图

1Gx8表示SDRAM具有8位的I/O数据位宽度(参见图中右侧的DQ[7:0]信号)。所以8G也有2Gx4,4位I/O宽度,512M x 16的16位I/O数据位宽度。

每个内存阵列为65536x128x64,称为一个bank,4个bank组成一个bank组,共有4个bank组,所以总容量为65536*128*64*4*4= 8Gb。这里注意存储的最小单元就是1bit。

具体来说,在65536x128x64的每个存储阵列规格中,65536代表行数,每行存储128*64=8192位的数据,同时也是

图中Sense放大器与I/0栅极、DM掩码逻辑之间传输的位宽。每行有1024列,每列包含8位数据。由于DDR4预取宽度为8n,一次访问需要8列数据,即64位。所以每一行都有128个64位,这就是65536x128x64位中的128x64的来源。

DDR3内部框图

                                                图:MT41J256M8 的内部框图

DDR3中没有bank组的概念,只有8个bank。

32768x128x64的每个存储阵列规格中,32768代表行数,每行存储128*64=8192位的数据,同时也是

图中Sense放大器与I/O栅极、DM掩模逻辑之间传输的位宽。每行有1024列,每列包含8位数据。DDR3预取宽度为8n,一次访问需要8列数据,即64位。所以每一行都有128个64位。

容量计算:

以256Meg x 8这个规格的内存计算,32k *128 * 8 *8 *8 = 2Gb,这3个8分别来自bank,位宽,prefetch。

1DDRPrefetch预取

以下面的DDR3读取为例,下图中共有8条数据线,每一条数据线都是一个8选1模拟开关的输出,每个输出前面还有8个输入,这个8个输入分别来自8个bank,8个输入会先存在fifo中缓存,MUX读出的时钟就是内核时钟的4倍,由于DDR的时钟上下边沿采样,所以读出8个数据的时间就是1个内核时钟,8个输出就对应64个输入,prefetch的8n的n是指DQ的IO位宽,表示以位宽的8倍来预取数据,n也就是DQ的数量一般可以是4,8,16,对应预取数据就是32,64,128。

读取流程是先激活行地址,锁存行数据到Sense放大器,激活列地址,数据送到输出缓存,利用Sense放大器值刷新行数据,关闭位线,关闭行线,位线预充电。

2DDRbank grounp

标准型DDR的总线位宽是64bit,若进行16倍预取,总共有128Byte的数据,超过了目前主流处理器的 Cacheline size(用 于处理器缓存的基本数据单元64Byte 的数据通道,由于Cacheline的 限制,DDR4 没有将预取加倍,而是使用 Bank Group 技术,通过两个不同 Bank Group 的8倍预取来拼凑出一个16倍的预取,当DRAM获得了两份数据的读命令,并且这两份数据的内容分布在不同的Bank Group中时, 由于每个Bank Group可以独立完成读取操作,两个Bank Group 几乎可以同时准备好这两份8倍数据。然后这两份8倍数据被拼接成16倍的数据,数据的传输速度达到内部时钟频率的16倍,较DDR3提升2倍。

3DDR的突发长度Burst Length

突发长度BL是指在同一行中相邻的存储单元连续进行数据传输的方式,连续传输所涉及到存储单元(列)的数量就是突发长度,DDR3内部配置采用了8n prefetch(预取)来实现高速读写,这也导致了DDR3的BL一般都是8。当然也有为4的设置(BC4),是指另外4笔数据是不被传输的或者被认为无效。BL8还是BC的配置在MR0寄存器配置,这里也可以看出A0~A2是用在了burst的配置上,所以DDR3、4的列地址前三位不用做寻址。

4、预充电Precharge

以下图DDR3的BL8读取为例,在发出当前读取的read指令后的第5个周期后发送PRE指令,经过tRP时间后可以激活Row b行操作,图中的tRP为8个时钟周期,比较耗时。

                                                        图:ddr3read操作

下图为DDR的单个CELL的示意图,预充电就是把位线上充电到vcc / 2 ,读的过程是选通字线;

如果Cbit电容有电且大于vcc / 2 ,Cbit电容放电,位线上的电压会大于vcc / 2 ,再与vcc / 2 经过差分放大后输出1。

如果Cbit电容没电且小于vcc / 2 , 给Cbit电容充电,位线上的电压会大于vcc / 2 ,再与vcc / 2 经过差分放大后输出0。

                                                              图:单CELL的示意图

5

相关文章:

  • 前端利用vue如何实现导入和导出功能.md
  • springboot @configuration注解的配置, @bean注解方法a, 在@bean注解 getb(){}需要注入a
  • llm学习-3(向量数据库的使用)
  • 04-《黄蜀葵》
  • 软考的报名详细流程
  • 详解flink sql, calcite logical转flink logical
  • vue 组件el-tree添加结构指示线条
  • Leetcode 538:把二叉搜索树转化为累加树
  • C++ QT 全局信号的实现
  • 【爱上C++】详解string类2:模拟实现、深浅拷贝
  • Java [ 基础 ] HashMap详解 ✨
  • Python中的双向哈希表(双向字典)
  • Qt 使用 QZipReader 解压文件
  • Java中的并行计算与任务分发策略
  • 阿里云智能编程助手的安装使用
  • ES6指北【2】—— 箭头函数
  • [译] 怎样写一个基础的编译器
  • Android组件 - 收藏集 - 掘金
  • Apache Spark Streaming 使用实例
  • C# 免费离线人脸识别 2.0 Demo
  • css系列之关于字体的事
  • C语言笔记(第一章:C语言编程)
  • JS变量作用域
  • scrapy学习之路4(itemloder的使用)
  • zookeeper系列(七)实战分布式命名服务
  • 阿里云应用高可用服务公测发布
  • 案例分享〡三拾众筹持续交付开发流程支撑创新业务
  • 翻译 | 老司机带你秒懂内存管理 - 第一部(共三部)
  • #Linux(帮助手册)
  • %check_box% in rails :coditions={:has_many , :through}
  • (arch)linux 转换文件编码格式
  • (JS基础)String 类型
  • (力扣记录)235. 二叉搜索树的最近公共祖先
  • (六)DockerCompose安装与配置
  • (排序详解之 堆排序)
  • (求助)用傲游上csdn博客时标签栏和网址栏一直显示袁萌 的头像
  • (三)c52学习之旅-点亮LED灯
  • (学习日记)2024.01.09
  • (转) SpringBoot:使用spring-boot-devtools进行热部署以及不生效的问题解决
  • (转)http-server应用
  • (转)淘淘商城系列——使用Spring来管理Redis单机版和集群版
  • .bat批处理(七):PC端从手机内复制文件到本地
  • .NET CORE 第一节 创建基本的 asp.net core
  • .net core MVC 通过 Filters 过滤器拦截请求及响应内容
  • .NET Core SkiaSharp 替代 System.Drawing.Common 的一些用法
  • .net mvc 获取url中controller和action
  • .NET 跨平台图形库 SkiaSharp 基础应用
  • @zabbix数据库历史与趋势数据占用优化(mysql存储查询)
  • [c#基础]值类型和引用类型的Equals,==的区别
  • [C++参考]拷贝构造函数的参数必须是引用类型
  • [Contest20180313]灵大会议
  • [CQOI 2010]扑克牌
  • [C语言]——内存函数
  • [git] windows系统安装git教程和配置
  • [go-zero] 简单微服务调用