SDRAM控制器设计

SDRAM控制器设计,第1张

FPGA视频图像处理系统中,经常需要使用到SDRAM作为视频图像缓存。SDRAM控制器可以分为上电初始化,自动刷新,读 *** 作和写 *** 作这四个部分,他们之间的转换可以通过状态机来控制。下面分别实现这几个部分。

1.SDRAM上电初始化

SDRAM上电初始化时序如下图所示。

SDRAM控制器设计,e970072c-1aa0-11ed-ba43-dac502259ad0.jpg,第2张

由时序图可知初始化大概的过程为:上电后等待电源VDD和时钟信号稳定100μs(期间命令为空命令),同时在100μs内设置CKE(时钟使能)信号为高。随后对所有Bank发送预充电(PRECH ARGE)命令,发送两次自动刷新(REFRESH)命令,最后发送装载模式寄存器(LOAD MODE REGISTER)命令,并将设置寄存器的值传入地址总线A0~A11。

SDRAM控制器设计,e989048e-1aa0-11ed-ba43-dac502259ad0.png,第3张

上述过程的实现可以通过线性序列机来实现。即需要对初始化过程时间进行计数,当时间到达时就执行某个命令。下面是部分代码。

1.计时

SDRAM控制器设计,e99b1066-1aa0-11ed-ba43-dac502259ad0.png,第4张

2.命令执行时间设置

SDRAM控制器设计,e9bb0100-1aa0-11ed-ba43-dac502259ad0.jpg,第5张

3.对应时间执行对应命令

SDRAM控制器设计,e9d21688-1aa0-11ed-ba43-dac502259ad0.png,第6张

 

2.SDRAM自动刷新

同样给出自动刷新的时序图。

SDRAM控制器设计,e9f26636-1aa0-11ed-ba43-dac502259ad0.jpg,第7张

过程比较简单:首先对所有Bank预充电,然后发送两次自动刷新命令。

SDRAM控制器设计,ea154336-1aa0-11ed-ba43-dac502259ad0.png,第8张

同样可以使用线性序列机的方法来实现,这里就不重复了。但需要添加一个刷新状态标志。ref_opt_done=1表示刷新完成,ref_opt=1表示正在刷新。

SDRAM控制器设计,ea218a38-1aa0-11ed-ba43-dac502259ad0.png,第9张

3.SDRAM写 *** 作

SDRAM控制器设计,ea449154-1aa0-11ed-ba43-dac502259ad0.jpg,第10张

从时序图上看首先发出激活命令,并给出行地址Bank地址;随后发出写命令,并指定写入Bank,起始列地址和写入数据;最后进行预充电,关闭所有Bank。这里每次突发写入4个数据,即突发长度为4,突发长度可以在之前初始化的模式寄存器中设置。

SDRAM控制器设计,ea682470-1aa0-11ed-ba43-dac502259ad0.png,第11张

同样使用序列机的实现方法,在写 *** 作中也需要添加写 *** 作完成状态标志,和过程状态标志。此外只有当写入突发长度数据的时候我们才使能数据线输入有效,其他时刻让数据线保持高阻态,所以要添加一个写数据状态标志Wr_data_valid=1时表示正在写数据。

SDRAM控制器设计,ea76287c-1aa0-11ed-ba43-dac502259ad0.png,第12张

 

4.SDRAM读 *** 作

SDRAM控制器设计,ea9599c8-1aa0-11ed-ba43-dac502259ad0.jpg,第13张

与写 *** 作类似,但是我们输入读命令的时候,数据并不是立刻输出,而是要经过一个CAS_Latency后输出。这个延时也可以通过模式寄存器的配置来调整。我们同样需要给出读 *** 作完成、读 *** 作过程,读出突发数据的有效区间。

SDRAM控制器设计,eab7f6da-1aa0-11ed-ba43-dac502259ad0.png,第14张

SDRAM控制器设计,eac770c4-1aa0-11ed-ba43-dac502259ad0.png,第15张

 

5.SDRAM控制器设计

首先SDRAM上电后进入空闲状态,初始化完成后进入刷新状态,然后根据输入命令进行转换,实际上状态机的控制对于刷新 *** 作,读/写 *** 作是有一个优先级的:刷新 *** 作>写 *** 作>读 *** 作。即假设写命令和刷新命令同时到来时先执行刷新 *** 作。下图为状态机的状态转移图。具体实现可参考完整代码。

SDRAM控制器设计,eaea2010-1aa0-11ed-ba43-dac502259ad0.jpg,第16张

由于SDRAM需要固定时间间隔刷新一次,我们还得考虑一个刷新定时器,固定时间产生一个刷新请求。

SDRAM控制器设计,eb156d24-1aa0-11ed-ba43-dac502259ad0.png,第17张

最后我们还需要考虑如果在读 *** 作的时候,产生了刷新请求或写请求怎么办呢?写 *** 作的时候,产生了刷新请求或读请求怎么办?或者在刷新 *** 作时产生了读/写请求怎么办?

对于刷新请求的突然到来我们采取记住刷新标志,等待当前任务完成后进行刷新 *** 作。

在刷新 *** 作时读/写请求突然到来,我们也采取记住读/写标志,等待当前任务完成后进行读/写 *** 作。

但是对于在读/写 *** 作时外部读/写请求的到来,我们选择了忽略这次请求。部分代码如下。

SDRAM控制器设计,eb24db7e-1aa0-11ed-ba43-dac502259ad0.jpg,第18张

由于视频信号数据读入读出都是连续不断的,因此在某些时刻会导致读写的遗漏,但一般会在SDRAM读出写入前加上一个FIFO进行缓存控制数据的读写,当写FIFO中数据大于一次突发长度时,使能写信号;当读FIFO中数据小于突发长度时,使能读信号,就可以解决这个问题。

审核编辑 :李倩

 

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/dianzi/2998222.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-09-26
下一篇 2022-09-26

发表评论

登录后才能评论

评论列表(0条)

保存