基于VHDL的SDRAM控制器的实现.docx
文本预览下载声明
PAGE 1
PAGE 1
基于VHDL的SDRAM控制器的实现
在高速实时或者非实时信号处理系统当中,使用大容量存储器实现数据缓存是一个必不行少的环节,也是系统实现中的重点和难点之一。SDRAM(同步动态随机访问存储器)具有价格低廉、密度高、数据读写速度快的优点,从而成为数据缓存的存储介制裁。但是SDRAM存储体结构与RAM有较大差异,其掌握时序和机制也较简单,限制了SDRAM的使用。目前,虽然一些能家长微处理器供应了和SDRAM的透亮?????接口,但其可扩展性和敏捷性不够,难以满意现实系统的要求,限制了SDRAM的使用。 在具体阐读SDRAM数据文档的前提下,参考ALTERA公司的IP core,利用可编程器件(CPLD,FPGA)设计了一种通用的SDRAM掌握器。它具有很高的敏捷性,可以便利地和其它数据采集分析系统中,如图1所示。在该系统中,以SDRAM存储阵列缓存中频来的高速数据。存满后,数据被慢速读出至数据处理模块。下面将对SDRAM掌握模块的设计进行具体的描述。 1 SDRAM内存条的结构 SDRAM内存条由SDRAM内存芯片构成,依据内存条的容量大小打算内存条上内存芯片的个数。现以MICRON公司生产的TIM16LSDT6464A型SDRAM内存条为例,简要介绍SDRAM的结构。 MIT16LSDT6464A内存条容量为512M Byte,由16片容量为32M Byte的内存芯片MT46LC32M8A2构成。16片内存芯片被分为两级,每个芯片的数据位宽为8bit.8片一组,64bit数据宽度。每个内存芯片的数据线和掌握均是复用的。对内存条的读写操作,是以内存芯片组为单位的,通过内存条的片选信号S0、S1、S2、S3打算组号。S0、S2掌握芯片组1,S1、S3掌握芯片组2. SDRAM内存芯片的主要信号有掌握信号、掌握信号、数据信号,均为工作时钟同步输入、输出信号。 掌握信号主要有:CS(片选信号),CKE(时钟使能信号),DQM(输入、输出访能信号),CAS、RAS、WE(读写掌握命令字)。通过CAS、RAS、WE的各种规律组合,可产生各种掌握命令。 地址信号有:BA0和BA1页地址选择信号,A0~A12地址信号,行、列地址选择信号。通过分时复用打算地址是行地址还是列地址。在读写操作中,在地线上依次给出页地址、行地址、列地址,终确定存储单元地址。 数据信号有:DQ0~DQ7,双向数据。其使能受DQM掌握。 SDRAM的工作模式通过LOAD MODE REGISTER命令对工作模式寄存器进行设置来选择。设置参量有Reserved(备用的人)Write Burst Mode(WB,写突发模式)、Operation Mode(Op Mode,工作模式)、CAS Latency(CAS延迟)、Burst Type(BT,突发类型)、Burst Length(突发长度)。 2 SDRAM的基本读写操作 SDRAM的基本读操作需要掌握线和地址线相协作地发出一系列命令来完成。先发出BANK激活命令(ACTIVE),并锁存相应的BANK地址(BA0、BA1给出)和行地址(A0~A12给出)。BANK激活命令后必需等待大于tRCD(SDRAM的RAS到CAS的延迟指标)时间后,发出读命令字。CL(CAS延迟值)个工作时钟后,读出数据依次消失在数据总线上。在读操作的,要向SDRAM发出预充电(PRECHARGE)命令,以关闭已经激活的页。等待tRP时间(PRECHARGE)命令,以关闭已经激活的页。等待tRP时间(PRECHAREG命令后,相隔tRP时间,才可再次访问该行)后,可以开头下的读、写操作。SDRAM的读操作只有突发模式(Burst Mode),突发长度为1、2、4、8可选。 SDRAM的基本写操作也需要掌握线和地址线相协作地发出一系列命令来完成。先发出BANK激活命令(ACTIVE),并锁存相应的BANK地址(BA0、BA1给出)和行地址(A0~A12给出)。BANK激活命令后必需等待大于tRCD的时间后,发出写命令字。写命令可以马上写入,需写入数据依次送到DQ(数据线)上。在一个数据写入后延迟tWR时间。发出预充电命令,关闭已经激活的页。等待tRP时间后,可以绽开下操作。写操作可以有突发写和非突发写两种。突发长度同读操作。 tRCD、tRP、tWR的详细要求,详见SDRAM厂家供应的数据手册。所等待的工作时钟个数由tRCD、tRP、tWR的值和工作时钟周期共同打算。 由以上介绍可以得出,SDRAM的读、写操作均由一系列命令组成,因此读、写操作是有时钟损耗的,工
显示全部