0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

关于Prefetch和Burst相关的内容

SwM2_ChinaAET 来源:未知 作者:李倩 2018-07-02 14:20 次阅读

学习DDR有一段时间了,期间看了好多的资料(部分公司培训资料、几十篇的博文,Micron的Datasheet,JESD79规范等)。但是有一个问题,想了好久(很多资料都没有说明白),至今才算搞明白,所以写一篇文章和大家分享一下。

如题,接下来要讨论的主要是关于Prefetch和Burst相关的内容。

1、Prefetch介绍

首先,简单介绍一下Prefetch技术。所谓prefetch,就是预加载,这是DDR时代提出的技术。在SDR中,并没有这一技术,所以其每一个cell的存储容量等于DQ的宽度(芯片数据IO位宽)。【关于什么是cell(存储单元,可以去看一下,我之前的博文:http://blog.chinaaet.com/justlxy/p/5100051913)】

进入DDR时代之后,就有了prefetch技术,DDR是两位预取(2-bit Prefetch),有的公司则贴切的称之为2-n Prefetch(n代表芯片位宽)。DDR2是四位预取(4-bit Prefetch),DDR3和DDR4都是八位预取(8-bit Prefetch)。而8-bit Prefetch可以使得内核时钟是DDR时钟的四分之一,这也是Prefetch的根本意义所在。

补充说明:芯片位宽的另一种说法是配置模式(Configuration),在DDR3时代,一般有x4,x8,x16。

下面以DDR3为例,下图是个简单 一个简单Read预取示意图,Write可以看做是 个逆向过程。

当DDR3 为x8 Configuration时,一个Cell的容量为8x8bits,即8个字节。换一句话说,在指定bank、row地址和col地址之后,可以往该地址内写入(或读取)8 Bytes。

2、如何计算DDR3 SDRAM的容量

以Mircon的某型号DDR3 SDRAM为例:

以图中红色部分的内容作为分析案例(8个bank,x8的Configuration):

计算方式一(错误):

64K*8*1K*8(Row Addressing * Bank Addressing * Column Addressing * x8 Configuration)= 4Gb(512 Megx8)。

大部分材料给出的都是这种错误的计算方法,误导了很多的初学者。这种计算方法咋一看好像是对的。但是,仔细推敲一下,便可以发现,按照计算方式一的逻辑,则认为每一个Cell的容量是1bit*8(x8 Configuration),即8bit。这与我们在第一部分所讨论的结果(一个Cell的容量为64bits,x8 Configuration下)不符。

当然,从某种角度来说,计算方式一也是正确的,因为分离出的Column Address的位数实际上是和prefetch对应的。比如DDR3 8-bit Prefetch对3bits的Column Address,DDR2 4-bit Prefetch对应的是2bits的Column Address。只是如果直接按照计算方式一来计算的话,对于初次接触DDR的人来说,理解起来存在一定的困难,这也是我写这一篇博文的原因。

下面给出正确的计算方式,并说明原因。

计算方式二(正确):

64K*8*(1K/8)*8*8(Row Addressing * Bank Addressing * (Column Addressing / 8) * x8 Configuration * 8-bit Prefetch)= 4Gb(512 Megx8)。

很多人都会问,为什么要把列地址寻址(Column Addressing)除以8呢?似乎计算方式二看起来更加不合理。接下来,我们先来回顾一下DDR3 SDRAM的结构框图(还是以Mircon的某型号为例):

大图可能看的不太清楚,下面来几个特写:

没错!你没有看错!10bit的Column Address的寻址能力只有128!!!刚好差了8倍(这就是我们在计算方式二中将Column Addressing除以8的原因)!

那么问题又来了,为什么Column Address的寻址能力只有128呢?莫急,请继续看下图:

在上图中,可以清晰地发现,10bits的Column Address只有7bits用于列地址译码!列地址0,1,2并没有用!!!

那么,问题又来了!……

列地址0,1,2,这3bits被用于什么功能了?或者是Mircon的设计者脑残,故意浪费了这三个bits?显然不是。

在JESD79-3规范中有如下的这个表格:

可以发现,Column Address的A2,A1,A0三位被用于Burst Order功能,并且A3也被用于Burst Type功能。由于一般情况,我们采用的都是顺序读写模式(即{A2,A1,A0}={0,0,0}),所以此时的A3的取值并无直接影响。

那么,问题又来了!……

Burst又是什么鬼呢?且看第三部分。

3、DDR中的Burst Length

Burst Lengths,简称BL,指突发长度,突发是指在同一行中相邻的存储单元连续进行数据传输的方式,连续传输所涉及到存储单元(列)的数量就是突发长度(SDRAM),在DDR SDRAM中指连续传输的周期数。上一部分讲到的Burst Type和Burst Order实际上就是关于Burst Length的读写顺序的配置。

在DDR3 SDRAM时代,内部配置采用了8n prefetch(预取)来实现高速读写.这也导致了DDR3的Burst Length一般都是8。当然也有Bursth ength为4的设置(BC4),是指另外4笔数据是不被传输的或者被认为无效而已。

在DDR2时代,内部配置采用的是4n prefetch,Burst length有4和8两种,对于BL=8的读写操作,会出现两次4n Prefetch的动作。

上图是JESD79-3规范中给出的DDR3 SDRAM的Command Truth Table。可以看到,读取和写入都有三种基本模式(Fixed BL8 or BC4,BC4 on the fly,BL8 on the fly)。这一部分的内容,在我之前的博文中有所提及,此处不再详细介绍。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 存储
    +关注

    关注

    12

    文章

    3856

    浏览量

    84660
  • DDR
    DDR
    +关注

    关注

    9

    文章

    677

    浏览量

    64239
  • Burst
    +关注

    关注

    1

    文章

    5

    浏览量

    10059

原文标题:【博文连载】DDR扫盲——关于prefetch与Burst的深入讨论

文章出处:【微信号:ChinaAET,微信公众号:电子技术应用ChinaAET】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    关于Labview里 LJ burst函数的使用

    本帖最后由 Wolfshadow 于 2012-12-13 11:23 编辑 最近在做一个基于labjack的电子血压计的设计里面要用到AI burst.vi不过这个我完全不懂 不知道各位能否给点建议 怎么实现收缩压 舒张压 以及平均压的测定 怎么设定l***urst
    发表于 12-13 11:16

    关于plb burst write 的问题

    在edk中搭建emc,怎样通过cpu(powerpc)向外面emc所连接的sram进行plb burst write,我感觉有点矛盾,cpu只有普通的输入输出函数XIo_32Out(),实在不知道怎么burst write,求指教!
    发表于 07-17 15:20

    burst mode flash哪些地方有详细介绍,page mode flash和burst mode flash的区别是什么

    burst mode flash哪些地方有详细介绍,page mode flash和burst mode flash的区别是什么
    发表于 08-10 14:39

    关于电路设计相关课程,您想学习哪些方面内容

    关于学习硬件电路设计,您还想学习哪些内容。比如:硬件原理图设计规范、外围器件选型和设计、如何选择CPU、设计需求分析思路,还是诸如PADS、AD软件设计实践应用,或者手动焊接方法、示波器调试
    发表于 04-04 15:43

    请问C6678中EDMA的传输,burstburst size、数据总线位宽以及一个TR之间的关系是什么

    急求指点,请问C6678,EDMA传输过程中,burstburst size、数据总线位宽以及一个TR之间的关系?如果设定为AB型传输的话,一个TR会触发一次ACNT*BCNT字节数的搬移么?还有
    发表于 01-08 10:49

    Programmable Transfer Burst Size是什么意思?

    Programmable Transfer Burst Size总是能够看到Burst Size,可能我自己的理解为传输的阀值,但是总觉的这样理解不太好,恳请你们给说一下,谢谢!
    发表于 07-31 11:30

    Burst模式是什么意思呢

    #1, Burst 模式是Light loading mode, 假如inductor大的话,Burst的频率会变小,这样的噪声会很大。因为Burst Event几率会变小,在人耳的频率范围内
    发表于 12-30 07:46

    请问一下Arm AMBA协议集中,axi burst 和ahb burst的区别是什么?

    请问一下Arm AMBA协议集中,axi burst 和ahb burst的区别是什么?
    发表于 10-08 15:48

    光突发交换(Optical Burst Switching,

    光突发交换(Optical Burst Switching, OBS) 光突发交换(Optical Burst Switching, OBS)是近年来提出的一种新技术,它使用的带宽粒度介于光电路交换
    发表于 03-04 11:47 1643次阅读
    光突发交换(Optical <b class='flag-5'>Burst</b> Switching,

    Burst Mode电压控制电路图

    图为Burst Mode电压控制电路,当S43电平>C54(此时C54和电平C96相等为0.84 V),时,Burst_on信号为低电平,关断功率管;当S43
    发表于 08-31 09:22 3037次阅读
    <b class='flag-5'>Burst</b> Mode电压控制电路图

    关于单片机相关芯片的介绍

    关于单片机相关芯片的介绍,内容基本覆盖了设计所需,有不全的地方希望大家多多理解啊
    发表于 11-19 17:21 11次下载

    关于STM32CubeProgrammer的内容

    几点关于STM32CubeProgrammer的内容
    的头像 发表于 03-04 11:08 5917次阅读

    关于 STM32 的几点内容

    关于STM32的几点内容
    的头像 发表于 03-08 12:02 1804次阅读

    SPI协议相关内容

    今天分享SPI协议相关内容
    的头像 发表于 09-05 10:50 864次阅读

    AMBA AHB协议的burst termination简析

    在AMBA AHB协议中,AHB master可以用burst传输连续取多笔数据。AHB定义了4、8和16拍的burst传输、未定义长度的burst传输和单次传输。
    发表于 06-29 15:54 1042次阅读
    AMBA AHB协议的<b class='flag-5'>burst</b> termination简析