RAM,SRAM,SDRAM工作原理

发布 2019-07-11 05:25:57 阅读 4498

存储原理: 为了便于不同层次的读者都能基本的理解本文,所以我先来介绍一下很多用户都知道的东西。ram主要的作用就是存储**和数据供cpu在需要的时候调用。

但是这些数据并不是像用袋子盛米那么简单,更像是图书馆用有格子的书架存放书籍一样,不但要放进去还要能够在需要的时候准确的调用出来,虽然都是书但是每本书是不同的。对于ram等存储器来说也是一样的,虽然存储的都是代表0和1的**,但是不同的组合就是不同的数据。

让我们重新回到书和书架上来,如果有一个书架上有10行和10列格子(每行和每列都有0-9的编号),有100本书要存放在里面,那么我们使用一个行的编号+一个列的编号就能确定某一本书的位置。如果已知这本书的编号87,那么我们首先锁定第8行,然后找到第7列就能准确的找到这本书了。在ram存储器中也是利用了相似的原理。

现在让我们回到ram存储器上,对于ram存储器而言数据总线是用来传入数据或者传出数据的。因为存储器中的存储空间是如果前面提到的存放图书的书架一样通过一定的规则定义的,所以我们可以通过这个规则来把数据存放到存储器上相应的位置,而进行这种定位的工作就要依靠地址总线来实现了。对于cpu来说,ram就象是一条长长的有很多空格的细线,每个空格都有一个唯一的地址与之相对应。

如果cpu想要从ram中调用数据,它首先需要给地址总线发送地址数据定位要存取的数据,然后等待若干个时钟周期之后,数据总线就会把数据传输给cpu。下面的示意图可以帮助你很好的理解这个过程。

存储原理。上图中的小园点代表ram中的存储空间,每一个都有一个唯一的地址线同它相连。当地址解码器接收到地址总线送来的地址数据之后,它会根据这个数据定位cpu想要调用的数据所在的位置,然后数据总线就会把其中的数据传送到cpu。

上面所列举的例子中cpu在一行数据中每次知识存取一个字节的数据,但是在现实世界中是不同的,通常cpu每次需要调用32bit或者是64bit的数据(这是根据不同计算机系统的数据总线的位宽所决定的)。如果数据总线是64bit的话,cpu就会在一个时间中存取8个字节的数据,因为每次还是存取1个字节的数据,64bit总线将不会显示出来任何的优势,women工作的效率将会降低很多。

从“线”到“矩阵”

如果ram对于cpu来说仅仅是一条“线”的话,还不能体现实际的运**况。因为如果实际情况真的是这样的话,在实际制造芯片的时候,会有很多实际的困难,特别是在需要设计大容量的ram的时候。所以,一种更好的能够降低成本的方法是让存储信息的“空格”排列为很多行--每个“空格”对应一个bit存储的位置。

这样,如果要存储1024bits的数据,那么你只要使用32x32的矩阵就能够达到这个目的了。很明显,一个32x32的矩阵比一个1024bit的行设备更紧凑,实现起来也更加容易。请看下图:

知道了ram的基本结构是什么样子的,我们就下面谈谈当存储字节的过程是怎样的:上面的示意图显示的也仅仅是最简单状态下的情况,也就是当内存条上仅仅只有一个ram芯片的情况。对于x86处理器,它通过地址总线发出一个具有22位二进制数字的地址编码--其中11位是行地址,另外11位是列地址,这是通过ram地址接口进行分离的。

行地址解码器(row decoder)将会首先确定行地址,然后列地址解码器(column decoder)将会确定列地址,这样就能确定唯一的存储数据的位置,然后该数据就会通过ram数据接口将数据传到数据总线。另外,需要注意的是,ram内部存储信息的矩阵并不是一个正方形的,也就是行和列的数目不是相同的--行的数目比列的数目少。(后面我们在讨论dram的过程中会讲到为什么会这样)

上面的示意图粗略的概括了一个基本的sram芯片是如何工作的。sram是“static ram(静态随机存储器)”的简称,之所以这样命名是因为当数据被存入其中后不会消失(同dram动态随机存储器是不同,dram必须在一定的时间内不停的刷新才能保持其中存储的数据)。一个sram单元通常由4-6只晶体管组成,当这个sram单元被赋予0或者1的状态之后,它会保持这个状态直到下次被赋予新的状态或者断电之后才会更改或者消失。

sram的速度相对比较快,而且比较省电,但是存储1bit的信息需要4-6只晶体管制造成本太高了(dram只要1只晶体管就可以实现)。

ram芯片和sram芯片。

ram芯片:

前面的介绍都相对比较简单、抽象。下面我们会结合实际的ram芯片进行介绍。在谈到这个问题的时候,我们会涉及到一个比较重要的技术:

封装。你应该听说过诸如30线simms、72线simms和168线dimms或者rimms其中的一个或者几个术语吧。如果要解释这些术语之间的不同,就应该了解ram的封装技术。

sram芯片:

早期的sram芯片采用了20线双列直插(dip:dual inline package)封装技术,它们之所以具有这么多的针脚,是因为它们必须:每个地址信号都需要一根信号线;一根数据输入线和一根数据输出线部分控制线(write enable, chip select);线和电源线。

上图显示的是sram芯片,但是并不是下面示意图中的sram芯片,下面的是一个16k x 1-bit sram芯片的针脚功能示意图:

a0-a13是地址输入信号引脚,cs是芯片选择引脚。在一个实际的系统中,一定具有很多片sram芯片,所以需要选择究竟从那一片sram芯片中写入或者读取数据。we是写入启用引脚(如上表,在cs、we上面的线我没有写入,表示低电平有效或者是逻辑0时有效):

当sram得到一个地址之后,它需要知道进行什么操作,究竟是写入还是读取,we就是告诉sram要写入数据。vcc是供电引脚。din是数据输入引脚。

dout是数据输出引脚。gnd是接地引脚。

output:

enable(oe):有的sram芯片中也有这个引脚,但是上面的图中并没有。这个引脚同we引脚的功能是相对的,它是让sram知道要进行读取操作而不是写入操作。

从dout引脚读取1bit数据需要以下的步骤:

sram读取操作:1)通过地址总线把要读取的bit的地址传送到相应的读取地址引脚(这个时候/we引脚应该没有激活,所以sram知道它不应该执行写入操作)。2)激活/cs选择该sram芯片。

3)激活/oe引脚让sram知道是读取操作。第三步之后,要读取的数据就会从dout引脚传输到数据总线。怎么过程非常的简单吧?

同样,写入1bit数据的过程也是非常的简单的。sram写入操作:1)通过地址总线确定要写入信息的位置(确定/oe引脚没有被激活)。

2)通过数据总线将要写入的数据传输到dout引脚。3)激活/cs引脚选择sram芯片。4)激活/we引脚通知sram知道要尽心写入操作。

经过上面的四个步骤之后,需要写入的数据就已经放在了需要写入的地方。

dram芯片介绍。

现在我们知道了在一个简单的sram芯片中进行读写操作的步骤了了,然后我们来了解一下普通的dram芯片的工作情况。dram相对于sram来说更加复杂,因为在dram存储数据的过程中需要对于存储的信息不停的刷新,这也是它们之间最大的不同。下面让我们看看dram芯片的针脚的作用。

最早、最简单也是最重要的一款dram芯片是intel在1979年发布的2188,这款芯片是16kx1 dram 18线dip封装。“16k x 1”的部分意思告诉我们这款芯片可以存储16384个bit数据,在同一个时期可以同时进行1bit的读取或者写入操作。(很抱歉找不到这款芯片的实物**,只好自己简单的画了一个示意图)。

上面的示意图可以看出,dram和sram之间有着明显的不同。首先你会看到地址引脚从14根变为7根,那么这颗16k dram是如何完成同16k sram一样的工作的呢?答案很简单,dram通过dram接口把地址一分为二,然后利用两个连续的时钟周期传输地址数据。

这样就达到了使用一半的针脚实现同sgram同样的功能的目的,这种技术被称为多路技术(multiplexing)。

那么为什么好减少地址引脚呢?这样做有什么好处呢?前面我们曾经介绍过,存储1bit的数据sram需要4-6个晶体管但是dram仅仅需要1个晶体管,那么这样同样容量的sram的体积比dram大至少4倍。

这样就意味着你没有足够空间安放同样数量的引脚(因为针脚并没有因此减少4倍)。当然为了安装同样数量的针脚,也可以把芯片的体积加大,但是这样就提高芯片的生产成本和功耗,所以减少针脚数目也是必要的,对于现在的大容量dram芯片,多路寻址技术已经是必不可少的了。

当然多路寻址技术也使得读写的过程更加复杂了,这样在设计的时候不仅仅dram芯片更加复杂了,dram接口也要更加复杂,在我们介绍dram读写过程之前,请大家看一张dram芯片内部结构示意图:

在上面的示意图中,你可以看到在dram结构中相对于sram多了两个部分:由/ras (row address

strobe:行地址脉冲选通器)引脚控制的行地址门闩线路(row address latch)和由/cas(column address strobe:列地址脉冲选通器)引脚控制的列地址门闩线路(column address latch)。

dram读取过程:1)通过地址总线将行地址传输到地址引脚。2)/ras引脚被激活,这样行地址被传送到行地址门闩线路中。

3)行地址解码器根据接收到的数据选择相应的行。

4)/we引脚被确定不被激活,所以dram知道它不会进行写入操作。5)列地址通过地址总线传输到地址引脚。6)/cas引脚被激活,这样列地址被传送到行地址门闩线路中。

7)/cas引脚同样还具有/oe引脚的功能,所以这个时候dout引脚知道需要向外输出数据。

8)/ras和/cas都不被激活,这样就可以进行下一个周期的数据操作了。其实dram的写入的过程和读取过程是基本一样的,所以如果你真的理解了上面的过程就能知道写入过程了,所以这里我就不赘述了。(只要把第4步改为/we引脚被激活就可以了)。

ram基础知识。

我们已经提到过,dram同sram最大的不同就是不能比较长久的保持数据,这项特性使得这种存储介质对于我们几乎没有任何的作用。但是dram设计师利用刷新的技术使得dram称为了现在对于我们最有用处的存储介质。这里我仅仅简要的提及一下dram的刷新技术,因为在后面介绍fp、edo等类型的内存的时候,你会发现它们具体的实现过程都是不同的。

dram内仅仅能保持其内存储的电荷非常短暂的时间,所以它需要在其内的电荷消失之前就进行刷新直到下次写入数据或者计算机断电才停止。每次读写操作都能刷新dram内的电荷,所以dram就被设计为有规律的读取dram内的内容。这样做有下面几个好处。

第一,仅仅使用/ras激活每一行就可以达到全部刷新的目的;第二,dram控制器来控制刷新,这样可以防止刷新操作干扰有规律的读写操作。在文章的开始,我曾经说过一般行的数目比列的数据少。现在我可以告诉为什么会这样了,因为行越少用户刷新的时间就会越少。

ram模块基础:

加湿器工作原理

目前市场上的家用加湿器一般采用超声波方式将水雾化,并通过风机将雾化的水汽吹出壳体,从而达到加湿空气的效果,其电气原理图如附图所示。市电经过开关电源后,输出两路电压36v和12v。其中36v供电水汽雾化模块。12v供电风机。电路中,d1 d2分别是缺水指示灯和工作指示灯 干簧管为液位检测开关 rt1为...

主板工作原理

1.在一块ok板在未插atx时。南桥的cmos电路在a 钮扣电池b 针帽c32768晶振都正常的条件下开始工作。保持着bios修改数据。2.当主板插上atx电源 包插220v也插在电源上 atx9脚sb5v待机电压即刻发送给主板上的待机电路使主板处于待机状态,同时atx14脚ps on为5v左右的高...

逆变器工作原理

逆变器原理 逆变器电路图 逆变器工作原理介绍。sjh系列智能型工频率正弦波逆变器,是在单片微处理控制芯片控制下,产生正弦波高频调制信号后再经驱动电路驱动大功率场效应管或igbt管,使其工作在高频开关状态而达到将直流电源转变成正弦波电源的基本工作原理。其原理图框图如下 1.逆变 充电变频电路 在外电网...

web应用的工作原理 http的工作原理

b 配置内容。为servlet制定一个在当前中唯一标记的别名。servlet的唯一的别名。servlet的物理地址。为servlet明确在服务器上的调用地址。servlet的别名。servlet的调用路径。注意 url的调用路径必须从根目录 开始。5 servlet的生命周期 工作流程 a 客户通过...

晶闸管的工作原理

在中频炉中整流侧关断时间采用kp 60微秒以内,逆变侧关短时间采用kk 30微秒以内这也是kp管与kk管的主要区别。晶闸管t在工作过程中,它的阳极a和阴极k与电源和负载连接,组成晶闸管的主电路,晶闸管的门极g和阴极k与控制晶闸管的装置连接,组成晶闸管的控制电路。晶闸管的工作条件 1.晶闸管承受反向阳...

LED灯工作原理

其发光原理跟激光的产生相似。一个原子中的电子有很多能级,当电子从高能级向低能级跳变时,电子的能量就减少了,而减少的能量则转变成光子发射出去。大量的这些光子就是激光了。led原理类似。不过不同的是,led并不是通过原子内部的电子跃变来发光的,而是通过将电压加在led的pn结两端,使pn结本身形成一个能...

接近开关工作原理

霍尔接近开关工作原理。原理简介 当一块通有电流的金属或半导体薄片垂直地放在磁场中时,薄片的两端就会产生电位差,这种现象就称为霍尔效应。两端具有的电位差值称为霍尔电势u,其表达式为。u k i b d 其中k为霍尔系数,i为薄片中通过的电流,b为外加磁场 洛伦慈力lorrentz 的磁感应强度,d是薄...

放大电路工作原理

我们知道三极管可以通过控制基极的电流来控制集电极的电流,来达到放大的目的。放大电路就是利用三极管的这种特性来组成放大电路。我们下面以共发射极的接法为例来说明一下。一 放大电路的组成原理 1 提供直流电源,为电路提供工作能源。2 电源的极性和大小应保证三极管t的基极与发射极之间处于正向偏置,而集电极与...