Avalon-MM总线控制DDR读写

这篇具有很好参考价值的文章主要介绍了Avalon-MM总线控制DDR读写。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

Intel FPGA 的DDR控制器通过 Avalon总线进行读写控制,本文对Avalon总线突发读写DDR方法进行详细介绍。

Avalon-MM突发读写时序

突发写

下图是avalon突发写时序,当突发长度设置为4时,每次写入4个数据。waitrequest信号时从机发出的,主机操作只有在waitrequest为0低时有效,写是能信号write在waitrequest为低时,写入data1和addr1,在发送过程中如果waitrequest变为高电平,writedata、address和write需要保持原来的值,直到waitrequest变为低。突发写过程中,只需要写入首地址,其余地址会自动加1。

avalon协议,fpga开发

突发读

突发读时序中,在waitrequest为低时,读使能有效,主机输出突发读首地址,根据burstcount数值,在readdatavalid为高时,读取相应数量的数据。readdatavalid不受waitrequest影响。

avalon协议,fpga开发

DDR4接口ctrl_amm

DDR控制器的ctrl_amm接口是Avalon MM类型。通过ctrl_amm接口控制DDR读写。

avalon协议,fpga开发

avalon协议,fpga开发

DDR4读写时序

DDR接口读时序

对比DDR接口时序与Avalon总线协议接口时序,发现waitrequest信号存在差异,Avalon总线协议中waitrequest为低有效,DDR接口时序中waitrequest为高有效。

avalon协议,fpga开发

DDR接口写时序

DDR接口写时序更能明显看出waitrequest的差异。

avalon协议,fpga开发

代码

下面代码实现DDR简单读写。突发长度设置为4,将4个数据写入DDR,再读出4个数据。代码需要将输入的waitrequest先取反,把高电平有效改成低电平有效。文章来源地址https://www.toymoban.com/news/detail-590305.html

assign burstcount = 7'd4;
assign byteenable = 16'hffff;
assign writedata = {124'd0,cnt};

reg [5:0] state;
reg [3:0] cnt;
			 
always@(posedge clk,negedge rst_n)
begin
	if(!rst_n)
	begin
		state <= st0;
		address <= 25'd0;
		cnt <= 4'd0;
		write <= 1'b0;
		read <= 1'b0;
	end
	else
	begin
		case(state)
		st0:
		begin
			if(cal_success)
			begin
				state <= st1;
			end
		end
		st1:
		begin
			if(!waitrequest_n)
			begin
				if(cnt < 4'd4)
				begin
					cnt <= cnt + 1'b1;
					write <= 1'b1;
				end
				else
				begin
					cnt <= 4'd0;
					write <= 1'b0;
					state <= st2;
				end
			end
		end
		st2:
		begin
			if(!waitrequest_n)
			begin
				read <= 1'b1;
				state <= st3;
			end	
		end
		st3:
		begin
			read <= 1'b0;
			state <= st4;
		end
		st4:
		begin
			if(readdatavalid)
			begin
				state <= st5;
			end
		end
		st5:
		begin
			state <= st0;
		end

		endcase;
	end
end

到了这里,关于Avalon-MM总线控制DDR读写的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • STM32基于CAN总线协议控制步进电机

    如上图所示,实现了以下功能: 1.两块stm32单片机通过CAN控制器与收发器进行半双工通信; 2.stm32主机通过检测按键,切换不同的模式,将不同模式的case值发送给stm32从机; 3.stm32从机根据收到的case值,控制步进电机进行不同的运动操作; 4.OLED用于显示收发内容与按键状态等

    2024年01月19日
    浏览(51)
  • DDR3读写模块

    使用xilinx官方提供的MIG IP核进行设计,接口协议为AXI,关于AXI协议的内容此处不做过多介绍。 关于IP核个参数的介绍可以参考野火教程,以下为目前使用的通用配置。 DDR物理接口的位宽为32bit DDR用户接口的位宽为64bit MIG核的XADC是关闭的,需要外部模块例化XADC模块读取FPGA的内

    2024年02月03日
    浏览(52)
  • DDR官方例程读写仿真记录

    1、配置MIG控制器   a、在 IP Catalog里搜索MIG,点击下方的Memory Interface Generator核 b、接下来是查看FPGA的器件,速度等级,语言等等,全部和工程一致 c、接下来勾选 Creat Design ,设计名称保持默认 mig_7series_0 ,底部勾选使用AXI4接口 d、之后是 兼容的FPGA型号选择(默认不选) 和

    2024年04月27日
    浏览(40)
  • 手把手教你学会 Xilinx PCIE/XDMA 读写DDR系列(三) ——XDMA读写DDR项目工程讲解和下板测试

    因最近想通过PCIE把数据从FPGA传到PC,借此机会和大家一起学习XDMA读写DDR 制作不易,记得三连哦,给我动力,持续更新!!! 完整工程文件下载:XDMA读写DDR工程   提取码:4sxh 在前两篇文章的学习中,我们已经成功配置了XDMA读写DDR所需的两个关键IP核,并深入学习了XDMA读写

    2024年03月12日
    浏览(63)
  • ZYNQ AXI4总线访问DDR3实现图像数据乒乓存储与显示

    目录 前言 一、添加端口 二、添加局部变量 三、例化读写FIFO 四、内部变量修改,设置一次读写进行多少次突发操作 五、写地址 六、读地址 七、状态机 1.写状态机 2.读状态机 总结 在Altera FPGA进行图像处理时,我们采用的存储芯片为SDRAM,当时参照正点原子的例程是封装SDR

    2024年02月02日
    浏览(69)
  • ZYNQ使用AXI4-HP接口总线读取DDR中的数据

    最近笔者在做项目的时候需要使用zynq中的AXI4-HP总线在PL端读取DDR中的数据这种功能,但是网上很多历程对于这方面只是创建了一个官方提供的IP核用于测试,并且每次写入和读取的长度为4K字节。所以为了满足我自己的项目需求,笔者将官方提供的测试IP核上做修改,主要实现

    2023年04月15日
    浏览(46)
  • Xilinx FPGA DDR3设计(三)DDR3 IP核详解及读写测试

    引言 :本文我们介绍下Xilinx DDR3 IP核的重要架构、IP核信号管脚定义、读写操作时序、IP核详细配置以及简单的读写测试。 7系列FPGA DDR接口解决方案如图1所示。 图1、7系列FPGA DDR3解决方案 1.1 用户FPGA逻辑(User FPGA Logic) 如图1中①所示,用户FPGA逻辑块是任何需要连接到外部

    2024年02月06日
    浏览(56)
  • 【FPGA】MIG DDR3读写逻辑测试

            笔者在之前通过microblaze软核的方式实现了DDR3芯片的读写测试,当时对于Xilinx MIG DDR控制器的理解还比较肤浅。还是想通过控制用户接口时序的方式来读写DDR,扩展和加深自己对DDR的理解。 MIG IP核配置请看我的前一篇文章 【FPGA测试】Microblaze测试DDR读写_microblaze

    2024年01月22日
    浏览(43)
  • 基于紫光同创 FPGA 的 DDR3 读写实验

    此篇为专栏 《紫光同创FPGA开发笔记》 的第二篇,记录我的学习FPGA的一些开发过程和心得感悟,刚接触FPGA的朋友们可以先去此专栏置顶 《FPGA零基础入门学习路线》来做最基础的扫盲。 本篇内容基于笔者实际开发过程和正点原子资料撰写,将会详细讲解此 FPGA 实验的全流程

    2024年01月20日
    浏览(50)
  • 【Quartus FPGA】EMIF DDR3 读写带宽测试

    在通信原理中,通信系统的有效性用带宽来衡量,带宽定义为每秒传输的比特数,单位 b/s,或 bps。在 DDR3 接口的产品设计中,DDR3 读/写带宽是设计者必须考虑的指标。本文主要介绍了 Quartus FPGA 平台 EMIF 参数配置,以及测试 DDR3 读写带宽的过程,FPGA 器件型号是 Cyclone 10 GX

    2024年02月13日
    浏览(45)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包