Vivado使用系列:IP Integrator HDL

2023-10-31 18:30

本文主要是介绍Vivado使用系列:IP Integrator HDL,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

测试平台Vivado 2017.2

在Vivado的Block设计里,全IP化逐渐形成了一种新型的设计方案,受Vivado内的IP可配置的GUI界面影响,使用IP要比RTL代码更有良好的用户体验;然而,在Block设计里,并不是只有IP这一种可添加并可配置,RTL也可实现上述功能,只需要在Block内右键Add Module..,会弹出下面界面:

选择我之前写的模块add,点击ok,

这样就添加了一个add的RTL Module到Block Design内了。默认Vivado左边是输入端口,右边是输出端口。

上面是一个很简单的操作,接下来进入正题,讲解如何利用IP Integrator HDL语言使我们的RTL Module在Block内更像一个IP,IP Integrator HDL语言支持Verilog、VHDL,这里只用Verilog进行演示。

先看一下Xilinx提供的IP Integrator HDL的Language Templates:

分析一下结构,得出以下几点结论:

1.每个端口定义都是以(*起始,并以*)结束,并写在端口定义之前;

2.每个端口定义结构满足 X_INTERFACE_INFO = "{存在的接口类型} {接口的名字} 接口内的端口(必须与接口类型定义的端口一致)"

3.除了端口定义,还有Parameter定义,以X_INTERFACE_PARAMETER = "开始,内部采用键值对,即Param = value型结构;

下面是vivado内的原话:

//

// Verilog attributes are used to declare signal interfaces and set parameters on them.

// Due to the language, the attributes need to be placed before a port which is part of the interface.

// When adding one or more parameters for an interface, a single attribute with multiple

// key value pairs should be added to before of the ports that is mapped into the interface.

// Generally, the form of the attributes are:

// (* X_INTERFACE_INFO = "<interface vlnv> <interface_name> <logical_port_name>" *)

// (* X_INTERFACE_PARAMETER = "<parameter_name1> <parameter_value1>, <parameter_name2> <parameter_value2>" *)

// input <portname>;

接下来以一个AXI4_controller模块做例子演示一下。

首先按上述步骤添加一个AXI4_controller模块到Block内:

 

module axi4_controller_top #(parameter DATA_WIDTH = 'h100, parameter ADDR_WIDTH = 'h20, parameter LENGTH_WIDTH = 'h8,parameter ID_WIDTH = 'h2,parameter MASTER_ID = 'h1,parameter CLK_FREQ = 'hc8,parameter BASE_ADDR = 'h000000
)(
//
//Other Port
//input s_axil_aclk0,input s_axil_aresetn0,input [31:0] s_axil_awaddr0,input s_axil_awvalid0,output s_axil_awready0,input [31:0] s_axil_wdata0,input [3:0] s_axil_wstrb0,input s_axil_wvalid0,output s_axil_wready0,output [1:0] s_axil_bresp0,output s_axil_bvalid0,input s_axil_bready0,input [31:0] s_axil_araddr0,input s_axil_arvalid0,output s_axil_arready0,output [31:0] s_axil_rdata0,output [1:0] s_axil_rresp0,output s_axil_rvalid0,input s_axil_rready0,// AXI4_masteroutput m_axi_aclk0,output m_axi_aresetn0,output [AXI4_ID_WIDTH-1:0] m_axi_awid0,output [AXI4_ADDR_WIDTH-1:0] m_axi_awaddr0,output [AXI4_LENGTH_WIDTH-1:0] m_axi_awlen0,output [2:0] m_axi_awsize0,output [1:0] m_axi_awburst0,output [3:0] m_axi_awcache0,output [2:0] m_axi_awprot0,output m_axi_awvalid0,input m_axi_awready0,output [AXI4_DATA_WIDTH-1:0] m_axi_wdata0,output [AXI4_DATA_WIDTH/8-1:0] m_axi_wstrb0,output m_axi_wlast0,output m_axi_wvalid0,input m_axi_wready0,input [AXI4_ID_WIDTH-1:0] m_axi_bid0,input [1:0] m_axi_bresp0,input m_axi_bvalid0,output m_axi_bready0,output [AXI4_ID_WIDTH-1:0] m_axi_arid0,output [AXI4_ADDR_WIDTH-1:0] m_axi_araddr0,output [AXI4_LENGTH_WIDTH-1:0] m_axi_arlen0,output [2:0] m_axi_arsize0,output [1:0] m_axi_arburst0,output [3:0] m_axi_arcache0,output [2:0] m_axi_arprot0,output m_axi_arvalid0,input m_axi_arready0,input [AXI4_ID_WIDTH-1:0] m_axi_rid0,input [AXI4_DATA_WIDTH-1:0] m_axi_rdata0,input [1:0] m_axi_rresp0,input m_axi_rlast0,input m_axi_rvalid0,output m_axi_rready0
);endmodule

看到了Vivado有两条axi总线,一条Master一条Slave,我们现在要做的就是用IP Integretor HDL语言强制将两条AXI总线指定出来,并让它们以总线形式显示。

我添加好的axi_dma_controller的代码:

module axi4_controller_top #(parameter DATA_WIDTH = 'h100,parameter ADDR_WIDTH = 'h20,parameter LENGTH_WIDTH = 'h8,parameter ID_WIDTH = 'h2,parameter MASTER_ID = 'h1,parameter CLK_FREQ = 'hc8,parameter ADDR = 'h109000
)(//Other port// AXI4Lite_slave(* X_INTERFACE_INFO = "xilinx.com:interface:aximm:1.0 S_AXI_Lite AWADDR" *)input [31:0] s_axil_awaddr0, // Write address (optional)(* X_INTERFACE_INFO = "xilinx.com:interface:aximm:1.0 S_AXI_Lite AWVALID" *)input s_axil_awvalid0, // Write address valid (optional)(* X_INTERFACE_INFO = "xilinx.com:interface:aximm:1.0 S_AXI_Lite AWREADY" *)output s_axil_awready0, // Write address ready (optional)(* X_INTERFACE_INFO = "xilinx.com:interface:aximm:1.0 S_AXI_Lite WDATA" *)input [31:0] s_axil_wdata0, // Write data (optional)(* X_INTERFACE_INFO = "xilinx.com:interface:aximm:1.0 S_AXI_Lite WSTRB" *)input [3:0] s_axil_wstrb0, // Write strobes (optional)(* X_INTERFACE_INFO = "xilinx.com:interface:aximm:1.0 S_AXI_Lite WVALID" *)input s_axil_wvalid0, // Write valid (optional)(* X_INTERFACE_INFO = "xilinx.com:interface:aximm:1.0 S_AXI_Lite WREADY" *)output s_axil_wready0, // Write ready (optional)(* X_INTERFACE_INFO = "xilinx.com:interface:aximm:1.0 S_AXI_Lite BRESP" *)output [1:0] s_axil_bresp0, // Write response (optional)(* X_INTERFACE_INFO = "xilinx.com:interface:aximm:1.0 S_AXI_Lite BVALID" *)output s_axil_bvalid0, // Write response valid (optional)(* X_INTERFACE_INFO = "xilinx.com:interface:aximm:1.0 S_AXI_Lite BREADY" *)input s_axil_bready0, // Write response ready (optional)(* X_INTERFACE_INFO = "xilinx.com:interface:aximm:1.0 S_AXI_Lite ARADDR" *)input [31:0] s_axil_araddr0, // Read address (optional)(* X_INTERFACE_INFO = "xilinx.com:interface:aximm:1.0 S_AXI_Lite ARVALID" *)input s_axil_arvalid0, // Read address valid (optional)(* X_INTERFACE_INFO = "xilinx.com:interface:aximm:1.0 S_AXI_Lite ARREADY" *)output s_axil_arready0, // Read address ready (optional)(* X_INTERFACE_INFO = "xilinx.com:interface:aximm:1.0 S_AXI_Lite RDATA" *)output [31:0] s_axil_rdata0, // Read data (optional)(* X_INTERFACE_INFO = "xilinx.com:interface:aximm:1.0 S_AXI_Lite RRESP" *)output [1:0] s_axil_rresp0, // Read response (optional)(* X_INTERFACE_INFO = "xilinx.com:interface:aximm:1.0 S_AXI_Lite RVALID" *)output s_axil_rvalid0, // Read valid (optional)(* X_INTERFACE_INFO = "xilinx.com:interface:aximm:1.0 S_AXI_Lite RREADY" *)input s_axil_rready0, // Read ready (optional)(* X_INTERFACE_PARAMETER = "ASSOCIATED_BUSIF S_AXI_Lite, ASSOCIATED_RESET s_axil_aresetn0, FREQ_HZ 100000000" *)(* X_INTERFACE_INFO = "xilinx.com:signal:clock:1.0 s_axil_aclk0 CLK" *)input s_axil_aclk0,(* X_INTERFACE_PARAMETER = "POLARITY ACTIVE_LOW" *)(* X_INTERFACE_INFO = "xilinx.com:signal:reset:1.0 s_axil_aresetn0 RST" *) output s_axi_aresetn0,// AXI4_masteroutput [AXI4_ID_WIDTH-1:0] m_axi_awid0,(* X_INTERFACE_INFO = "xilinx.com:interface:aximm:1.0 M_AXI AWADDR" *)output [AXI4_ADDR_WIDTH-1:0] m_axi_awaddr0,(* X_INTERFACE_INFO = "xilinx.com:interface:aximm:1.0 M_AXI AWLEN" *)output [AXI4_LENGTH_WIDTH-1:0] m_axi_awlen0,(* X_INTERFACE_INFO = "xilinx.com:interface:aximm:1.0 M_AXI AWSIZE" *)output [2:0] m_axi_awsize0,(* X_INTERFACE_INFO = "xilinx.com:interface:aximm:1.0 M_AXI AWBURST" *)output [1:0] m_axi_awburst0,(* X_INTERFACE_INFO = "xilinx.com:interface:aximm:1.0 M_AXI AWCACHE" *)output [3:0] m_axi_awcache0,(* X_INTERFACE_INFO = "xilinx.com:interface:aximm:1.0 M_AXI AWPROT" *)output [2:0] m_axi_awprot0,(* X_INTERFACE_INFO = "xilinx.com:interface:aximm:1.0 M_AXI AWVALID" *)input m_axil_awvalid0, // Write address valid (optional)(* X_INTERFACE_INFO = "xilinx.com:interface:aximm:1.0 M_AXI AWREADY" *)output m_axil_awready0, // Write address ready (optional)(* X_INTERFACE_INFO = "xilinx.com:interface:aximm:1.0 M_AXI WDATA" *)output [AXI4_DATA_WIDTH-1:0] m_axi_wdata0,(* X_INTERFACE_INFO = "xilinx.com:interface:aximm:1.0 M_AXI WSTRB" *)output [AXI4_DATA_WIDTH/8-1:0] m_axi_wstrb0,(* X_INTERFACE_INFO = "xilinx.com:interface:aximm:1.0 M_AXI WLAST" *)output m_axi_wlast0,(* X_INTERFACE_INFO = "xilinx.com:interface:aximm:1.0 M_AXI WVALID" *)input m_axil_wvalid0, // Write valid (optional)(* X_INTERFACE_INFO = "xilinx.com:interface:aximm:1.0 M_AXI WREADY" *)output m_axil_wready0, // Write ready (optional)(* X_INTERFACE_INFO = "xilinx.com:interface:aximm:1.0 M_AXI BID" *)input [AXI4_ID_WIDTH-1:0] m_axi_bid0,(* X_INTERFACE_INFO = "xilinx.com:interface:aximm:1.0 M_AXI BRESP" *)output [1:0] m_axil_bresp0, // Write response (optional)(* X_INTERFACE_INFO = "xilinx.com:interface:aximm:1.0 M_AXI BVALID" *)output m_axil_bvalid0, // Write response valid (optional)(* X_INTERFACE_INFO = "xilinx.com:interface:aximm:1.0 M_AXI BREADY" *)input m_axil_bready0, // Write response ready (optional)(* X_INTERFACE_INFO = "xilinx.com:interface:aximm:1.0 M_AXI ARID" *)output [AXI4_ID_WIDTH-1:0] m_axi_arid0,(* X_INTERFACE_INFO = "xilinx.com:interface:aximm:1.0 M_AXI ARADDR" *)output [AXI4_ADDR_WIDTH-1:0] m_axi_araddr0,(* X_INTERFACE_INFO = "xilinx.com:interface:aximm:1.0 M_AXI ARLEN" *)output [AXI4_LENGTH_WIDTH-1:0] m_axi_arlen0,(* X_INTERFACE_INFO = "xilinx.com:interface:aximm:1.0 M_AXI ARSIZE" *)output [2:0] m_axi_arsize0,(* X_INTERFACE_INFO = "xilinx.com:interface:aximm:1.0 M_AXI ARBURST" *)output [1:0] m_axi_arburst0,(* X_INTERFACE_INFO = "xilinx.com:interface:aximm:1.0 M_AXI ARCACHE" *)output [3:0] m_axi_arcache0,(* X_INTERFACE_INFO = "xilinx.com:interface:aximm:1.0 M_AXI ARPROT" *)output [2:0] m_axi_arprot0,(* X_INTERFACE_INFO = "xilinx.com:interface:aximm:1.0 M_AXI ARVALID" *)input m_axil_arvalid0, // Read address valid (optional)(* X_INTERFACE_INFO = "xilinx.com:interface:aximm:1.0 M_AXI ARREADY" *)output m_axil_arready0, // Read address ready (optional)(* X_INTERFACE_INFO = "xilinx.com:interface:aximm:1.0 M_AXI RID" *)input [AXI4_ID_WIDTH-1:0] m_axi_rid0,(* X_INTERFACE_INFO = "xilinx.com:interface:aximm:1.0 M_AXI RDATA" *)input [AXI4_DATA_WIDTH-1:0] m_axi_rdata0,(* X_INTERFACE_INFO = "xilinx.com:interface:aximm:1.0 M_AXI RRESP" *)output [1:0] m_axil_rresp0, // Read response (optional)(* X_INTERFACE_INFO = "xilinx.com:interface:aximm:1.0 M_AXI RLAST" *)input m_axi_rlast0,(* X_INTERFACE_INFO = "xilinx.com:interface:aximm:1.0 M_AXI RVALID" *)output m_axil_rvalid0, // Read valid (optional)(* X_INTERFACE_INFO = "xilinx.com:interface:aximm:1.0 M_AXI RREADY" *)input m_axil_rready0, // Read ready (optional)(* X_INTERFACE_PARAMETER = "ASSOCIATED_BUSIF M_AXI, ASSOCIATED_RESET m_axi_aresetn0, FREQ_HZ 100000000" *)(* X_INTERFACE_INFO = "xilinx.com:signal:clock:1.0 m_axil_aclk0 CLK" *)output m_axi_aclk0,(* X_INTERFACE_PARAMETER = "POLARITY ACTIVE_LOW" *)(* X_INTERFACE_INFO = "xilinx.com:signal:reset:1.0 m_axil_aresetn0 RST" *)output m_axi_aresetn0
);endmodule

 

可以看到Slave AXI和Master AXI已经以总线图标显示,并能以总线接口进行连线,这是System Verilog才具有的功能,但是Vivado通过Block将其应用在Verilog和VHDL上了。

有的时候Vivado可以根据RTL Module自动推断出模块内的接口,这时候可以不用,但是自动推断的接口,经常会有莫名其妙的问题。如果系统内没有满足自己需要的接口,可以自定义接口,同样可以被IP Integrator HDL使用。

 

这篇关于Vivado使用系列:IP Integrator HDL的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

vue使用docxtemplater导出word

《vue使用docxtemplater导出word》docxtemplater是一种邮件合并工具,以编程方式使用并处理条件、循环,并且可以扩展以插入任何内容,下面我们来看看如何使用docxtempl... 目录docxtemplatervue使用docxtemplater导出word安装常用语法 封装导出方

Linux换行符的使用方法详解

《Linux换行符的使用方法详解》本文介绍了Linux中常用的换行符LF及其在文件中的表示,展示了如何使用sed命令替换换行符,并列举了与换行符处理相关的Linux命令,通过代码讲解的非常详细,需要的... 目录简介检测文件中的换行符使用 cat -A 查看换行符使用 od -c 检查字符换行符格式转换将

使用Jackson进行JSON生成与解析的新手指南

《使用Jackson进行JSON生成与解析的新手指南》这篇文章主要为大家详细介绍了如何使用Jackson进行JSON生成与解析处理,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 核心依赖2. 基础用法2.1 对象转 jsON(序列化)2.2 JSON 转对象(反序列化)3.

使用Python实现快速搭建本地HTTP服务器

《使用Python实现快速搭建本地HTTP服务器》:本文主要介绍如何使用Python快速搭建本地HTTP服务器,轻松实现一键HTTP文件共享,同时结合二维码技术,让访问更简单,感兴趣的小伙伴可以了... 目录1. 概述2. 快速搭建 HTTP 文件共享服务2.1 核心思路2.2 代码实现2.3 代码解读3.

Elasticsearch 在 Java 中的使用教程

《Elasticsearch在Java中的使用教程》Elasticsearch是一个分布式搜索和分析引擎,基于ApacheLucene构建,能够实现实时数据的存储、搜索、和分析,它广泛应用于全文... 目录1. Elasticsearch 简介2. 环境准备2.1 安装 Elasticsearch2.2 J

使用C#代码在PDF文档中添加、删除和替换图片

《使用C#代码在PDF文档中添加、删除和替换图片》在当今数字化文档处理场景中,动态操作PDF文档中的图像已成为企业级应用开发的核心需求之一,本文将介绍如何在.NET平台使用C#代码在PDF文档中添加、... 目录引言用C#添加图片到PDF文档用C#删除PDF文档中的图片用C#替换PDF文档中的图片引言在当

Java中List的contains()方法的使用小结

《Java中List的contains()方法的使用小结》List的contains()方法用于检查列表中是否包含指定的元素,借助equals()方法进行判断,下面就来介绍Java中List的c... 目录详细展开1. 方法签名2. 工作原理3. 使用示例4. 注意事项总结结论:List 的 contain

C#使用SQLite进行大数据量高效处理的代码示例

《C#使用SQLite进行大数据量高效处理的代码示例》在软件开发中,高效处理大数据量是一个常见且具有挑战性的任务,SQLite因其零配置、嵌入式、跨平台的特性,成为许多开发者的首选数据库,本文将深入探... 目录前言准备工作数据实体核心技术批量插入:从乌龟到猎豹的蜕变分页查询:加载百万数据异步处理:拒绝界面

Android中Dialog的使用详解

《Android中Dialog的使用详解》Dialog(对话框)是Android中常用的UI组件,用于临时显示重要信息或获取用户输入,本文给大家介绍Android中Dialog的使用,感兴趣的朋友一起... 目录android中Dialog的使用详解1. 基本Dialog类型1.1 AlertDialog(

Python使用自带的base64库进行base64编码和解码

《Python使用自带的base64库进行base64编码和解码》在Python中,处理数据的编码和解码是数据传输和存储中非常普遍的需求,其中,Base64是一种常用的编码方案,本文我将详细介绍如何使... 目录引言使用python的base64库进行编码和解码编码函数解码函数Base64编码的应用场景注意