SDRAM控制器(初始化)

article/2025/10/26 8:42:17

SDRAM控制器(初始化)

文章目录

  • SDRAM控制器(初始化)
    • 初始化模块
    • 时序逻辑图
    • 代码
    • 仿真结果

初始化模块

SDRAM 在上电之后,执行正常操作之前需要被初始化,实际上就是对上文提到的SDRAM 内部逻辑控制单元进行初始化,初始化成功的 SDRAM 才可进行后续的其他操作。接下来我们将要学习掌握初始化操作时序,设计、实现并仿真验证初始化模块功能。
初始化操作时序
SDRAM 的初始化是芯片上电后必须进行的一项操作,只有进行了初始化操作的SDRAM 芯片才可被正常使用。 SDRAM 的初始化是一套预先定义好的流程,除此之外的其他操作会导致 SDRAM 出现不可预知的后果。 SDRAM 初始化操作时序图,具体见图53-23。在这里插入图片描述
结合 SDRAM 初始化时序图, 列出 SDRAM 初始化参考流程如下:
(1) 对 SDRAM 上电,加载稳定时钟信号, CKE 设置为高电平;
(2) 等待至少 T=100us 的时间,此过程中操作命令保持为空操作命令;
(3) 100us 等待结束后,写入预充电命令, A10 设置为高电平,对所有 L-Bank 进行预充电;
(4) 预充电指令写入后,等待 tRP时间,此过程中操作命令保持为空操作命令;
(5) tRP等待时间结束后,写入自动刷新命令;
(6) 自动刷新命令写入后,等待 tRC时间,此过程中操作命令保持为空操作命令;
(7) tRC等待时间结束后,再次写入自动刷新命令;
(8) 自动刷新命令写入后,等待 tRC时间,此过程中操作命令保持为空操作命令;
(9) tRC 等待时间结束后,写入模式寄存器配置指令,地址总线 A0-A11 参数不同辅助模式寄存器不同模式的设置;
(10) 模式寄存器配置指令写入后,等待 tMRD 时间,此过程中操作命令保持为空操作命令;
(11) tMRD等待时间结束后, SDRAM 初始化完成。
注: 1.对于 tRP、 tRC、 tMRD 等时间参数,不同芯片或速度等级可能存在差异,读者需查阅
芯片对应数据手册进行参数设置;
2.T=100us 为最小等待时间,我们在使用 SDRAM 时,等待时间 T 可适当延长;
3.初始化过程中,至少进行两次自动刷新,也可适当增加刷新次数。

时序逻辑图

在这里插入图片描述
(1)因为对于时间等待参数,我们可以设置成时钟的倍数,所以我们可以用计数器控制 (当然也可以用状态机,因为状态机很适合设计接口) 对于预充电,自刷新,寄存器配置的指令只需要一个cycle即可写入,所以有用的控制命令只保持一个时钟 ,对于trp我们设为3个时钟周期,trp是指写入预充电指令与自动刷新指令之间的时间, 所以在逻辑图里我们只给了trp2个时钟周期,因为还要加上PRE的时钟周期,刚好三个。 类似的不写了。

代码

`timescale 1ns / 1ps
//
// Company: 
// Engineer: 
// 
// Create Date: 2021/04/22 17:28:14
// Design Name:   超级无敌大猫猫
// Module Name: SDRAM_INIT
// Project Name: 
// Target Devices: 
// Tool Versions: 
// Description: 
// 
// Dependencies: 
// 
// Revision:
// Revision 0.01 - File Created
// Additional Comments:
// 
//
module SDRAM_INIT
(input        wire                sys_clk,input        wire                sys_rst_n,output       reg     [3:0]       init_cmd,output       reg     [1:0]       init_ba,output       reg     [12:0]      init_addr,output       reg                 init_end);  
reg       [14:0]      DELAY_CNT;
reg       [4:0]           command_cnt;
wire                  delay_flag;
always@(posedge sys_clk)
beginif(sys_rst_n == 1'b0)DELAY_CNT <= 'b0;else if(DELAY_CNT == 15'd20000)DELAY_CNT <= DELAY_CNT;elseDELAY_CNT <= DELAY_CNT + 1'b1;
end 
assign delay_flag = (DELAY_CNT == 15'd20000)? 1'b1:1'b0;
always@(posedge sys_clk)	
beginif(sys_rst_n == 1'b0)command_cnt <= 'b0;else if(command_cnt == 5'd31&&delay_flag)command_cnt <= command_cnt;else if(delay_flag)command_cnt <= command_cnt + 1'b1;
end 
always@(posedge sys_clk)
beginif(sys_rst_n == 1'b0)init_cmd <= 4'b0111;else if(DELAY_CNT == 15'd19999)init_cmd <= 4'b0010;else if(delay_flag == 1'b1)begincase(command_cnt)0 : init_cmd <= 4'b0111;2 : init_cmd <= 4'b0001;3 : init_cmd <= 4'b0111;10 :init_cmd <= 4'b0001;11 :init_cmd <= 4'b0111;18 :init_cmd <= 4'b0001;19 :init_cmd <= 4'b0111;26 :init_cmd <= 4'b0000;27 :init_cmd <= 4'b0111;default : init_cmd <= 4'b0111;endcaseendelse 	 init_cmd <= 4'b0111;
end 
always@(posedge sys_clk)
beginif(sys_rst_n == 1'b0)init_end <= 1'b0;else if(command_cnt == 5'd30)init_end <= 1'b1;
end 
always@(posedge sys_clk)
beginif(sys_rst_n == 1'b0)init_ba <= 2'b11;else if(command_cnt == 5'd26)init_ba <= 2'b00;elseinit_ba <= 2'b11;
end 
always@(posedge sys_clk)
beginif(sys_rst_n == 1'b0)init_addr <= 13'h1fff;else if(command_cnt == 5'd26)init_addr <= {3'b000,1'b0,2'b00,3'b011,1'b0,3'b111};elseinit_addr <= 13'h1fff;
end 
endmodule

仿真结果

在这里插入图片描述
记住一定要足够的仿真时间长能出数据,因为我们的上电是200us,所以仿真时间最好设置大于200us才出数据。


http://chatgpt.dhexx.cn/article/fix9VFmE.shtml

相关文章

SDRAM 控制器设计基本完结

项目可以拓展的地方&#xff1a; 1、接口为AXI 2、接口为AXI与AXI DMA 交互 2、优化读写时序&#xff0c;使得SDRAM输出效率最大&#xff1b; 总结&#xff1a; 项目不足&#xff1a;没有进行效率的优化&#xff0c;无地址映射&#xff0c;无外接交互接口&#xff0c;功能单一…

SDRAM读写控制

SDRAM读写控制器&#xff0c;这里分为三个部分&#xff0c;分别是SDRAM的基本操作实现&#xff0c;SDRAM控制器&#xff0c;封装成FIFO,以方便使用。 一、SDRAM的基本操作&#xff1a;初始化模块、自动刷新模块、写操作模块、读操作模块、SDRAM仲裁模块&#xff0c;顶层模块。 …

SDRAM 控制器(二)——初始化模块

1、初始化模块 SDRAM 的初始化是芯片上电后必须进行的一项操作&#xff0c;只有进行了初始化操作的 SDRAM 芯片才可被正常使用。SDRAM 的初始化是一套预先定义好的流程&#xff0c;除此之外的其 他操作会导致 SDRAM 出现不可预知的后果。 初始化时序图&#xff1a; CK&#xf…

SDRAM详细介绍

概念介绍&#xff1a; SDRAM&#xff1a;Synchronous Dynamic Random Access Memory&#xff0c;同步动态随机存储器。同步是指其时钟频率和CPU前端总线的系统时钟相同&#xff0c;并且内部命令的发送与数据的传输都以它为基准&#xff1b;动态是指存储阵列需要不断的刷新来保证…

sdram简易控制器设计

耗时一周&#xff0c;终于完成sdram简易控制器的所有代码设计&#xff0c;其中感谢开源骚客 – 邓堪文老师在b站发布的相关视频学习教材&#xff1b;其中仿真模块及所使用到的sdram仿真文件来源于开源骚客&#xff1b; 因为时间较为紧迫&#xff0c;其中就不做代码的一些注释&…

基于FPGA的SDRAM控制器设计(一)

基于FPGA的SDRAM控制器设计&#xff08;一&#xff09; 1. SDRAM控制器整体框架2.UART_RX模块3.UART_TX模块4. RX与TX模块的整合5.需要注意的问题6.代码7.参考资料 1. SDRAM控制器整体框架 图1.1整体框架 PC端通过串口模块UART_RX发送读写命令以及数据到Cmd_encode模块&#xf…

基于FPGA的SDRAM控制器设计(1)

基于FPGA的SDRAM初始化配置 SDRAM简述SDRAM的引脚及作用SDRAM初始化时序控制SDRAM上电时序代码SDRAM测试模块的代码仿真测试结果参考文献总结 SDRAM简述 SDRAM&#xff08; Synchronous Dynamic Random Access Memory&#xff09;&#xff0c;同步动态随机存储器。同步是指 Me…

FPGA进阶(3):SDRAM读写控制器的设计与验证

文章目录 第50讲&#xff1a;SDRAM读写控制器的设计与验证理论部分设计与实现1. sdram_ctrlsdram_initsdram_a_refsdram_writesdram_readsdram_arbitsdram_ctrl 2. sdram_topfifo_ctrlsdram_top 3. uart_sdramuart_rxuart_txfifo_readuart_sdram 第50讲&#xff1a;SDRAM读写控…

SDRAM

简介、优缺点、历史 1、译为“同步动态随机存取内存”&#xff0c;区别于异步DRAM。SRAM是异步静态存储器。 2、同步(Synchronous)&#xff1a;与通常的异步 DRAM 不同&#xff0c; SDRAM 存在一个同步接口&#xff0c;其工作时钟的时钟频率与对应控制器(CPU/FPGA上的读写控制…

关于SDRAM存储器

一、对SDRAM的初步认识 1.1 什么是SDRAM SDRAM&#xff08;Synchronous Dynamic Random Access Memory&#xff09;&#xff0c;同步动态随机存取存储器。 同步&#xff1a;工作频率与对应控制器的系统时钟频率相同&#xff0c;且内存内部的命令以及数据的传输都以此为基准 …

内存控制器与SDRAM

内存接口概念&#xff1a; 通常ARM芯片内置的内存很少&#xff0c;要运行Linux&#xff0c;需要扩展内存。ARM9扩展内存使用SDRAM内存&#xff0c;ARM11使用 DDR SDRAM。S3C2440通常外接32位64MBytes的SDRAM&#xff0c;采用两片16位32M的SDRAM芯片&#xff0c;SDRAM芯片通过地…

SDRAM驱动篇之简易SDRAM控制器的verilog代码实现

在Kevin写的上一篇博文《SDRAM理论篇之基础知识及操作时序》中&#xff0c;已经把SDRAM工作的基本原理和SDRAM初始化、读、写及自动刷新操作的时序讲清楚了&#xff0c;在这一片博文中&#xff0c;Kevin来根据在上一篇博文中分析的思路来把写一个简单的SDRAM控制器。 我们在上一…

FPGA之SDRAM控制器设计(一)

MT48LC128M4A2 – 32 Meg x 4 x 4 banks是512M SRAM&#xff0c;总体概述如下图 分别从上电初始化&#xff0c;刷新&#xff0c;写&#xff0c;读四个部分进行设计&#xff0c;此外还包含主控状态机&#xff0c;一个顶层。 1&#xff1a;上电初始化 整体架构&#xff1a;从控…

内存控制器与SDRAM【赞】

原文链接&#xff1a;https://blog.csdn.net/qq_31216691/article/details/87115697 内存接口概念&#xff1a; 通常ARM芯片内置的内存很少&#xff0c;要运行Linux&#xff0c;需要扩展内存。ARM9扩展内存使用SDRAM内存&#xff0c;ARM11使用 DDR SDRAM。S3C2440通常外接32位6…

SDRAM 介绍

目录 1、名词解释 2、SDRAM 内部结构 3、SDRAM 外部信号描述 4、SDRAM 命令 4.1、COMMAND INHIBIT 4.2、NO OERATION 4.3、ACTIVE 4.4、LOAD MODE REGISTER (LMR) 4.5、READ 4.6、WRITE 4.7、PRECHARGE 4.8、BURST TERMINATE 4.9、REFRESH 4.9.1、AUTO REFRESH …

SDRAM控制器操作时序

此为学习http://dengkanwen.com/137.html整理的笔记&#xff0c;侵删&#xff01; SDRAM工作原理 内部的状态跳转图 我们所需关注的几个地方&#xff1a; 1&#xff09;粗黑线表示在该状态下会自动跳转到另一个状态&#xff0c;细黑线表示需要给命令才会跳转。 2&#xff09…

SDR SDRAM控制器设计

目录 前言 1、关于刷新 2、关于数据中心对齐 3、SDRAM芯片手册介绍 3.1SDRAM芯片的管脚 3.2 SDRAM指令集 3.3 模式寄存器 3.4 关于SDRAM上电初始化和装载模式寄存器 3.5 SDRAM刷新时序 3.6 关于写访问 3.7 关于突发访问 4、FPGA工程设计 4.1状态机设计 5、仿真测试…

【GD32】从零开始学GD32单片机高级篇——外部存储器控制器EXMC详解+SDRAM读写例程

目录 简介外部设备地址映射NOR和PSRAM的地址映射NAND/PC Card地址映射SDRAM地址映射 NOR/PSRAM控制器接口描述控制时序模式1模式2 NAND Flash或PC Card控制器接口描述控制时序 SDRAM控制器接口描述控制时序突发读操作突发写操作读写FIFO跨边界读写操作低功耗模式自刷新模式掉电…

初识内存控制器和SDRAM【一文了解】

原文链接&#xff1a;https://blog.csdn.net/qq_36243942/article/details/85596249 目录 1.引入内存控制器 2.不同位宽内存设备之间的连接 3.如何确定芯片的访问地址 4.分析读写NOR FLASH的读写时序 5.SDRAM初识 6.编程读/写 SDRAM 附录&#xff1a;源代码 1.引入内存控制器 我…

存储控制器(SDRAM操作)

什么是存储控制器 2440是32位单片机&#xff0c;进行数据访问时通过32位地址访问。 CPU发出32位地址信号给存储控制器&#xff0c;存储控制器根据地址信号设置片选信号及地址总线&#xff0c;将相应数据通过数据总线传回存储控制器&#xff0c;存储控制器将收到的数据以字节为…