ZYNQ 调用AXI WR RD ip及其代码

2024-01-20 16:52
文章标签 代码 ip 调用 zynq axi wr rd

本文主要是介绍ZYNQ 调用AXI WR RD ip及其代码,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

首先调用ip

值得注意的是:zynq支持axi4.0 ,但是创建的ip是属于axi3.0,其区别主要是在数据位宽以及突发长度的区别。

下面附读写控制模块(稍作修改就可使用,数据位宽是64bit 突发长度是256):

assign fifo_wr_data = {8'd0,pixel_rgb};assign fifo_wr_en =  hv;//fifo 2 clock domain switchasfifo_wr32x4096_rd64x2048 asfifo_wr32x4096_rd64x2048inst (.wr_clk(pixel_clk),                // input wire wr_clk.rd_clk(M_AXI_ACLK),                // input wire rd_clk.din(fifo_wr_data),                      // input wire [31 : 0] din.wr_en(fifo_wr_en),                  // input wire wr_en.rd_en(fifo_rd_en),                  // input wire rd_en.dout(fifo_rd_data),                    // output wire [63 : 0] dout.full(),                    // output wire full.empty(),                  // output wire empty.rd_data_count(rd_data_count)  // output wire [10 : 0] rd_data_count
);//dma write channel assign fifo_rd_en = axi_wvalid & M_AXI_WREADY;always @(posedge M_AXI_ACLK) beginif(M_AXI_ARESETN == 1'b0) beginburst_start <= 1'b0;endelse if (rd_data_count >='d256 && axi_wvalid == 1'b0 && axi_awvalid == 1'b0) beginburst_start <= 1'b1;endelse beginburst_start <= 1'b0;endendalways @(posedge M_AXI_ACLK) beginif(M_AXI_ARESETN == 1'b0) beginaxi_awvalid <= 1'b0;endelse if (axi_awvalid == 1'b1 &&M_AXI_AWREADY == 1'b1) beginaxi_awvalid <= 1'b0;endelse if (burst_start == 1'b1 && axi_awvalid == 1'b0 && axi_wvalid == 1'b0) beginaxi_awvalid <= 1'b1;endendalways @(posedge M_AXI_ACLK) beginif(M_AXI_ARESETN == 1'b0) beginaxi_awaddr <= 'd0;endelse if (M_AXI_AWREADY == 1'b1 && axi_awvalid == 1'b1 && axi_awaddr == 'd8292352) beginaxi_awaddr <= 'd0;endelse if (M_AXI_AWREADY == 1'b1 && axi_awvalid == 1'b1) beginaxi_awaddr <= axi_awaddr + 'd2048;endendalways @(posedge M_AXI_ACLK) beginif(M_AXI_ARESETN == 1'b0) beginaxi_wvalid <= 1'b0;endelse if (M_AXI_WREADY == 1'b1 && axi_wvalid == 1'b1 && burst_cnt == 'd255) begin //burst endaxi_wvalid <= 1'b0;endelse if (M_AXI_AWREADY == 1'b1 && axi_awvalid == 1'b1) beginaxi_wvalid <= 1'b1;endendalways @(posedge M_AXI_ACLK) beginif(M_AXI_ARESETN == 1'b0) beginburst_cnt <='d0;endelse if (M_AXI_WREADY == 1'b1 && axi_wvalid == 1'b1 && burst_cnt == 'd255) beginburst_cnt <= 'd0;endelse if (M_AXI_WREADY == 1'b1 && axi_wvalid == 1'b1) beginburst_cnt <= burst_cnt + 1'b1;endendalways @* beginif(M_AXI_WREADY == 1'b1 && axi_wvalid == 1'b1 && burst_cnt == 'd255) beginaxi_wlast <= 1'b1;endelse beginaxi_wlast <= 1'b0;endendalways @* beginaxi_wdata = fifo_rd_data;endalways @(posedge M_AXI_ACLK) beginif(M_AXI_ARESETN == 1'b0) beginaxi_bready <= 1'b0;endelse beginaxi_bready <= 1'b1;endend

写模块代码(数据位宽是64bit 突发长度是256):

reg	[7:0]rx_Cnt;always @(posedge M_AXI_ACLK) begin if (M_AXI_ARESETN == 0 ) begin                                                                    axi_arvalid<=1'b0;                                     endelse if(axi_arvalid==1'b1 && M_AXI_ARREADY==1'b1)beginaxi_arvalid<=1'b0;                                                                           		end                                                                               else if(rd_data_count<=1024 && axi_arvalid==1'b0 && axi_rready==1'b0 ) begin  axi_arvalid<=1'b1;                                           end                                                                      endalways @(posedge M_AXI_ACLK) begin if (M_AXI_ARESETN == 0 ) begin                                                                    axi_araddr<='d0;                                 endelse if(axi_arvalid==1'b1 && M_AXI_ARREADY==1'b1 && axi_araddr=='d8292352)beginaxi_araddr<='d0;                                                                            		end                                                                             else if(axi_arvalid==1'b1 && M_AXI_ARREADY==1'b1) begin  axi_araddr<=axi_araddr+'d2048;                                           end                                                                      endalways @(posedge M_AXI_ACLK) begin if (M_AXI_ARESETN == 0 ) begin                                                                    axi_rready<=1'b0;                                     endelse if(M_AXI_RVALID==1'b1 && M_AXI_RREADY==1'b1 && rx_Cnt=='d255)beginaxi_rready<=1'b0;                                                                              		end                                                                               else if(axi_arvalid==1'b1 && M_AXI_ARREADY==1'b1) begin  axi_rready<=1'b1;                                          end                                                                      endalways @(posedge M_AXI_ACLK) begin if (M_AXI_ARESETN == 0 ) begin                                                                    rx_Cnt <= 'd0;                                     endelse if(M_AXI_RVALID==1'b1 && M_AXI_RREADY==1'b1 && rx_Cnt=='d255)beginrx_Cnt <='d0;                                                                            		end                                                                               else if(M_AXI_RVALID==1'b1 && M_AXI_RREADY==1'b1) begin  rx_Cnt<=rx_Cnt+1'b1;                                            end                                                                      end// Add user logic herefifo_generator_0 fifo_generator_0inst (.wr_clk(M_AXI_ACLK),                // input wire wr_clk.rd_clk(hdmi_clk),                // input wire rd_clk.din(M_AXI_RDATA),                      // input wire [63 : 0] din.wr_en(M_AXI_RVALID==1'b1 && M_AXI_RREADY==1'b1),                  // input wire wr_en.rd_en(rd_fifo_en),                  // input wire rd_en.dout(pixel_rgb),                    // output wire [31 : 0] dout.full(),                    // output wire full.empty(),                  // output wire empty.rd_data_count(rd_data_count)  // output wire [10 : 0] rd_data_count
);

这篇关于ZYNQ 调用AXI WR RD ip及其代码的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/626683

相关文章

使用Python实现IP地址和端口状态检测与监控

《使用Python实现IP地址和端口状态检测与监控》在网络运维和服务器管理中,IP地址和端口的可用性监控是保障业务连续性的基础需求,本文将带你用Python从零打造一个高可用IP监控系统,感兴趣的小伙... 目录概述:为什么需要IP监控系统使用步骤说明1. 环境准备2. 系统部署3. 核心功能配置系统效果展

C#如何调用C++库

《C#如何调用C++库》:本文主要介绍C#如何调用C++库方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录方法一:使用P/Invoke1. 导出C++函数2. 定义P/Invoke签名3. 调用C++函数方法二:使用C++/CLI作为桥接1. 创建C++/CL

Go语言开发实现查询IP信息的MCP服务器

《Go语言开发实现查询IP信息的MCP服务器》随着MCP的快速普及和广泛应用,MCP服务器也层出不穷,本文将详细介绍如何在Go语言中使用go-mcp库来开发一个查询IP信息的MCP... 目录前言mcp-ip-geo 服务器目录结构说明查询 IP 信息功能实现工具实现工具管理查询单个 IP 信息工具的实现服

利用Python调试串口的示例代码

《利用Python调试串口的示例代码》在嵌入式开发、物联网设备调试过程中,串口通信是最基础的调试手段本文将带你用Python+ttkbootstrap打造一款高颜值、多功能的串口调试助手,需要的可以了... 目录概述:为什么需要专业的串口调试工具项目架构设计1.1 技术栈选型1.2 关键类说明1.3 线程模

Python Transformers库(NLP处理库)案例代码讲解

《PythonTransformers库(NLP处理库)案例代码讲解》本文介绍transformers库的全面讲解,包含基础知识、高级用法、案例代码及学习路径,内容经过组织,适合不同阶段的学习者,对... 目录一、基础知识1. Transformers 库简介2. 安装与环境配置3. 快速上手示例二、核心模

Java的栈与队列实现代码解析

《Java的栈与队列实现代码解析》栈是常见的线性数据结构,栈的特点是以先进后出的形式,后进先出,先进后出,分为栈底和栈顶,栈应用于内存的分配,表达式求值,存储临时的数据和方法的调用等,本文给大家介绍J... 目录栈的概念(Stack)栈的实现代码队列(Queue)模拟实现队列(双链表实现)循环队列(循环数组

使用Java将DOCX文档解析为Markdown文档的代码实现

《使用Java将DOCX文档解析为Markdown文档的代码实现》在现代文档处理中,Markdown(MD)因其简洁的语法和良好的可读性,逐渐成为开发者、技术写作者和内容创作者的首选格式,然而,许多文... 目录引言1. 工具和库介绍2. 安装依赖库3. 使用Apache POI解析DOCX文档4. 将解析

C++使用printf语句实现进制转换的示例代码

《C++使用printf语句实现进制转换的示例代码》在C语言中,printf函数可以直接实现部分进制转换功能,通过格式说明符(formatspecifier)快速输出不同进制的数值,下面给大家分享C+... 目录一、printf 原生支持的进制转换1. 十进制、八进制、十六进制转换2. 显示进制前缀3. 指

Python中使用正则表达式精准匹配IP地址的案例

《Python中使用正则表达式精准匹配IP地址的案例》Python的正则表达式(re模块)是完成这个任务的利器,但你知道怎么写才能准确匹配各种合法的IP地址吗,今天我们就来详细探讨这个问题,感兴趣的朋... 目录为什么需要IP正则表达式?IP地址的基本结构基础正则表达式写法精确匹配0-255的数字验证IP地

使用Python实现全能手机虚拟键盘的示例代码

《使用Python实现全能手机虚拟键盘的示例代码》在数字化办公时代,你是否遇到过这样的场景:会议室投影电脑突然键盘失灵、躺在沙发上想远程控制书房电脑、或者需要给长辈远程协助操作?今天我要分享的Pyth... 目录一、项目概述:不止于键盘的远程控制方案1.1 创新价值1.2 技术栈全景二、需求实现步骤一、需求