当前位置: 首页 > 编程日记 > 正文

利用ZYNQ SOC快速打开算法验证通路(5)——system generator算法IP导入IP integrator

一、前言

利用FPGA设计算法一直以来都是热点,同样也是难点。将复杂的数学公式 模型通过硬件系统来搭建,在低延时 高并行性等优势背后极大提高了设计难度和开发周期。Xilinx公司的sysGen(system generator)工具扩展了MATLAB的simulink,提供很多IP Catalog中没有的基础模块和针对DSP应用的硬件模型。工程师利用丰富的模块和MATLAB强大的数据处理及可视化能力能够更快速完成设计与仿真验证工作。

二、sysGen算法系统设计

  本文以个最简单的例子讲述利用sysGen搭建算法IP核,并集成到IP Integrator中作为ZYNQ PS端CPU的“定制外设”。仅用于测试目的。设计需求:在sysGen中搭建系统,将输入定点整数数据*2后输出,输入位宽为8bit。

在System Generator token中设定仿真步长为1sec。点击需要观测的信号连线,右击选择Xilinx add to viewer。启动仿真并启动Xilinx waveform viewer:

本质上就是调用Vivado的XSim工具进行行为仿真。仿真结果可见完成预期目标,现双击System Generator token ,选择Compiliation类型为IP Catalog并勾选Create  testbench,按下Generate生成IP核。

三、仿真测试

  根据User Guide介绍sysGen是“周期和比特精准的”,我们还是在Vivado环境下再次验证下。netlist文件夹内子文件夹ip_catalog中为IP核示例工程,由于自动生成了testbench,打开后直接进行行为仿真。sysGen在创建testbench时会将经过gatein和gateout的数据储存到文件中,testbench进行的工作为:将gatein数据作为测试激励送入到相应设计输入端口,之后把设计输出得到结果与gateout文件数据进行逐一比较从而验证设计是否与sysGen环境下仿真结果一致。

  发现个比较有意思的现象,自动生成的testbench中clock生成并约束的50MHz,而是认为进行了拓展。

仿真波形如图:

将clock处改动为50MHz后,经过测试发现如果系统一开始就输入数据,前几个数据没有被真正处理,输出错误。可能是软件BUG吧,不过这种情况也非常少见,实际系统中输入数据大多情况会启动一段时间后才输入。这里等待100ns后再启动clock翻转:

 改动后仿真波形:

四、AXI-Stream总线形式IP

到此算法IP的设计与验证结束。如果想将这个IP核导入到IP Integrator中作为CPU的外设,其接口必须满足AXI总线标准,因此回到sysGen中更改端口名称和位宽。端口要符合AXI-Stream标准信号名称,位宽为8bit整数倍。

生成IP核后,打开新的工程,导入该IP核到repository。

五、Block Design系统搭建

 系统结构与上一篇该系列博文类似,均是以AXI DMA为核心的Loop系统,只是将AXI-Stream Data FIFO改成了自定义IP核。由于IP核slave和master接口只包含tdata和tvalid信号,因此需要添加接口衔接的一些简单逻辑。tready信号和tkeep信号直接连接constant使用常数驱动,DMA的s_axis_s2mm接口的tlast由wrapper内计数器逻辑驱动,将system中FCLK_CLK0 peripheral_aresetn m_axis_tvalid和s_axis_s2mm_tlast信号引出到wrapper中。

有一点比较坑:自定义IP通过AXI总线与DMA互联时,总线下相应的接口不一定会正确对应,所以需要分别将两端的每个接口相连。可以通过打开综合后的设计来确认连线无误。

自动生成wrapper后改动添加代码如下:

  1 `timescale 1 ps / 1 ps
  2 
  3 module user_wrapper
  4    (DC,
  5     DDR_addr,
  6     DDR_ba,
  7     DDR_cas_n,
  8     DDR_ck_n,
  9     DDR_ck_p,
 10     DDR_cke,
 11     DDR_cs_n,
 12     DDR_dm,
 13     DDR_dq,
 14     DDR_dqs_n,
 15     DDR_dqs_p,
 16     DDR_odt,
 17     DDR_ras_n,
 18     DDR_reset_n,
 19     DDR_we_n,
 20     //FCLK_CLK0,
 21     FIXED_IO_ddr_vrn,
 22     FIXED_IO_ddr_vrp,
 23     FIXED_IO_mio,
 24     FIXED_IO_ps_clk,
 25     FIXED_IO_ps_porb,
 26     FIXED_IO_ps_srstb,
 27     RES,
 28     SCLK,
 29     SDIN,
 30     VBAT,
 31     VDD
 32     //m_axis_tvalid,
 33     //peripheral_aresetn,
 34     //s_axis_s2mm_tlast
 35 );
 36   output DC;
 37   inout [14:0]DDR_addr;
 38   inout [2:0]DDR_ba;
 39   inout DDR_cas_n;
 40   inout DDR_ck_n;
 41   inout DDR_ck_p;
 42   inout DDR_cke;
 43   inout DDR_cs_n;
 44   inout [3:0]DDR_dm;
 45   inout [31:0]DDR_dq;
 46   inout [3:0]DDR_dqs_n;
 47   inout [3:0]DDR_dqs_p;
 48   inout DDR_odt;
 49   inout DDR_ras_n;
 50   inout DDR_reset_n;
 51   inout DDR_we_n;
 52   //output FCLK_CLK0;
 53   inout FIXED_IO_ddr_vrn;
 54   inout FIXED_IO_ddr_vrp;
 55   inout [53:0]FIXED_IO_mio;
 56   inout FIXED_IO_ps_clk;
 57   inout FIXED_IO_ps_porb;
 58   inout FIXED_IO_ps_srstb;
 59   output RES;
 60   output SCLK;
 61   output SDIN;
 62   output VBAT;
 63   output VDD;
 64   //output [0:0]m_axis_tvalid;
 65   //output [0:0]peripheral_aresetn;
 66   //input s_axis_s2mm_tlast;
 67 
 68 
 69   localparam DATA_NUM = 256;
 70 
 71   wire DC;
 72   wire [14:0]DDR_addr;
 73   wire [2:0]DDR_ba;
 74   wire DDR_cas_n;
 75   wire DDR_ck_n;
 76   wire DDR_ck_p;
 77   wire DDR_cke;
 78   wire DDR_cs_n;
 79   wire [3:0]DDR_dm;
 80   wire [31:0]DDR_dq;
 81   wire [3:0]DDR_dqs_n;
 82   wire [3:0]DDR_dqs_p;
 83   wire DDR_odt;
 84   wire DDR_ras_n;
 85   wire DDR_reset_n;
 86   wire DDR_we_n;
 87   wire FCLK_CLK0;
 88   wire FIXED_IO_ddr_vrn;
 89   wire FIXED_IO_ddr_vrp;
 90   wire [53:0]FIXED_IO_mio;
 91   wire FIXED_IO_ps_clk;
 92   wire FIXED_IO_ps_porb;
 93   wire FIXED_IO_ps_srstb;
 94   wire RES;
 95   wire SCLK;
 96   wire SDIN;
 97   wire VBAT;
 98   wire VDD;
 99   wire [0:0]m_axis_tvalid;
100   wire [0:0]peripheral_aresetn;
101   wire s_axis_s2mm_tlast;
102 
103   reg [8-1:0] cnt;
104   wire add_cnt;
105   wire end_cnt;
106 
107   system system_i
108        (.DC(DC),
109         .DDR_addr(DDR_addr),
110         .DDR_ba(DDR_ba),
111         .DDR_cas_n(DDR_cas_n),
112         .DDR_ck_n(DDR_ck_n),
113         .DDR_ck_p(DDR_ck_p),
114         .DDR_cke(DDR_cke),
115         .DDR_cs_n(DDR_cs_n),
116         .DDR_dm(DDR_dm),
117         .DDR_dq(DDR_dq),
118         .DDR_dqs_n(DDR_dqs_n),
119         .DDR_dqs_p(DDR_dqs_p),
120         .DDR_odt(DDR_odt),
121         .DDR_ras_n(DDR_ras_n),
122         .DDR_reset_n(DDR_reset_n),
123         .DDR_we_n(DDR_we_n),
124         .FCLK_CLK0(FCLK_CLK0),
125         .FIXED_IO_ddr_vrn(FIXED_IO_ddr_vrn),
126         .FIXED_IO_ddr_vrp(FIXED_IO_ddr_vrp),
127         .FIXED_IO_mio(FIXED_IO_mio),
128         .FIXED_IO_ps_clk(FIXED_IO_ps_clk),
129         .FIXED_IO_ps_porb(FIXED_IO_ps_porb),
130         .FIXED_IO_ps_srstb(FIXED_IO_ps_srstb),
131         .RES(RES),
132         .SCLK(SCLK),
133         .SDIN(SDIN),
134         .VBAT(VBAT),
135         .VDD(VDD),
136         .m_axis_tvalid(m_axis_tvalid),
137         .peripheral_aresetn(peripheral_aresetn),
138         .s_axis_s2mm_tlast(s_axis_s2mm_tlast));
139 
140     always @(posedge FCLK_CLK0)begin
141         if(!peripheral_aresetn)begin
142             cnt <= 0;
143         end
144         else if(add_cnt)begin
145             if(end_cnt)
146                 cnt <= 0;
147             else
148                 cnt <= cnt + 1;
149         end
150     end
151 
152     assign add_cnt = m_axis_tvalid;       
153     assign end_cnt = add_cnt && cnt== DATA_NUM-1;   
154 
155     assign s_axis_s2mm_tlast = end_cnt;
156 
157 endmodule
user_wrapper

当自定义IP核输出256个数据时,拉高tlast信号结束传输。打开综合后的设计,添加调试探针,抓取DMA与自定义IP之间的接口信号,set up debug后完成接下来的流程。

六、软硬件联调

在硬件系统中定义数据帧长度为256个,数据位宽为16bit,因此C代码中DMA启动传输函数中数据长度参数为512byte。测试数据生成与检测代码非常简单:

  我们直接查看ILA抓取AXI S总线波形:

看到CPU产生数据从1到4重复递增,IP核输出结果从2到8重复递增,输出为输入的2倍。

  传输完成后进入DMA发送和接收中断,软件检测结果正确。在Memory窗口能够直接查看内存绝对地址里的数据,选定DDR接收缓存区起始地址,其中的数据与AXI总线传回数据一致,证明系统联调成功。之后任意算法模块均可采用本文方式进行设计和集成,可以说一劳永逸!

转载于:https://www.cnblogs.com/moluoqishi/p/9585434.html

相关文章:

JS下计算当前日期(当天)后N天出现NAN或者undefined的情况

前言&#xff1a; 帮客户做一个订单系统&#xff0c;需要一个日期1&#xff0c;一个日期2&#xff0c;默认情况下日期1为当天&#xff0c;日期2为明天&#xff0c;只是当时有些疑惑的是日期2偶尔会出现NAN的情况&#xff0c;今天在segmentfault.com看到了同样的问题&#xff0c…

VCL 中的 Windows API 函数(6): BeginDeferWindowPos

BeginDeferWindowPos 和 DeferWindowPos、EndDeferWindowPos 是一组一起使用的函数, 可对一组窗口的位置、大小、Z 序等进行调整, 在 ExtCtrls 单元有用到.下面先用常规方法实现对 Panel1 中的一组 Button 进行调整, 然后再用上面三个函数重新实现.本例效果图:代码文件:unit Un…

base64格式的图片数据如何转成图片

base64格式的图片数据如何转成图片 一、总结 一句话总结&#xff1a;不仅要去掉前面的格式串&#xff0c;还需要base64_decode&#xff08;&#xff09;解码才行。 1 // $base_img是获取到前端传递的值2 $base_img str_replace(data:image/jpg;base64,, , $base_img);3 // 设…

拷贝构造函数和赋值函数的一些知识

/*******************拷贝构造函数和赋值运算符重载有以下两个不同之处***************************/ 1.拷贝构造函数生成新的类对象&#xff0c;而赋值运算符不能。 2.由于拷贝构造函数是直接构造一个新的类对象&#xff0c;所以在初始化这个对象之前不用检验源对象是否和新对…

代码重构之三种取代类型码(类、子类、状态对象或策略对象)的方式辨析

1.以类取代类型码 适用情况&#xff1a;类之中有一个数值类型码&#xff0c;但它并不影响类的行为。 重构手段&#xff1a;以一个新的类替换该数值类型码。 重构类图示意&#xff1a; 这里的“不影响类的行为”是什么意思呢&#xff1f; 类型码往往和switch语句一起出现&#…

NHibernate之旅(11):探索多对多关系及其关联查询

本节内容 多对多关系引入多对多映射关系多对多关联查询1.原生SQL关联查询2.HQL关联查询3.Criteria API关联查询结语多对多关系引入 让我们再次回顾在第二篇中建立的数据模型&#xff1a; 在图上&#xff0c;我已经清晰的标注了表之间的关系&#xff0c;上两篇分析Customer和Ord…

自动化运维—saltstack

2019独角兽企业重金招聘Python工程师标准>>> 自动化运维——saltstack 、ansible 一、自动化运维介绍 传统运维&#xff1a;传统运维效率低&#xff0c;大多工作需要人工完成&#xff0c;工作繁琐&#xff0c;容易出错&#xff0c;每日重复做相同的事情&#xff0c;…

史上最浅显易懂的Git教程!

Git初学者很好的一篇教程 mark : ) http://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000 转载于:https://www.cnblogs.com/anthony0859/p/3900327.html

狎昵关系和依恋情结辨诠

Inappropriate Intimacy&#xff08;狎昵关系&#xff09; 表现&#xff1a;两个classes过于亲密&#xff0c;花费太多时间去探究彼此的private成分 解决&#xff1a;你可以采用 Move Method 和 Move Field 帮它们划清界线&#xff0c;从而减少狎昵行径。你也可以看看是否运用…

win2000.win2003关闭端口详解--防黑必备

我相信有很多人都不知道自己开了什么端口.更加不知道怎么关闭端口. 你可以用查看端口的软件查看. 也可以通过在运行里输入"cmd" 在弹出的cmd命令行里输入 netstat -an 来查看自己开放端口.ip地址的后面的就是端口号. 以下是我自己写的一篇关于关闭端口的详细步骤和多…

网站基于vs,复选框,单选款

前端代码&#xff1a; <% Page Language"C#" AutoEventWireup"true" CodeFile"Default2.aspx.cs" Inherits"Default2" %><!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.or…

thinphp 整合ueditor

我的ueditor是部署在public/editor 部署前台页面 <script type"text/javascript" > var UEDITOR_HOME_URL: "__PUBLIC__/ueditor/" </script><script id"container" name"$des" type"text/plain">这里写你…

笔画宽度变化(C++和matlab算法)

最近一直在看工作方面的书籍&#xff0c;把论文的事情搁置了&#xff0c;之前承诺的贴代码的事一直拖。现在把代码整理发上来&#xff0c;只有核心部分的&#xff0c;都不是我写的&#xff0c;我是网上整理下载的&#xff0c;matlab代码的效果比较差。 全部文件网盘下载地址:ht…

bzoj1227: [SDOI2009]虔诚的墓主人(树状数组,组合数)

传送门 首先&#xff0c;对于每一块墓地&#xff0c;如果上下左右各有$a,b,c,d$棵树&#xff0c;那么总的虔诚度就是$C_k^a*C_k^b*C_k^c*C_k^d$ 那么我们先把所有的点都给离散&#xff0c;然后按$x$为第一关键字&#xff0c;$y$为第二关键字&#xff0c;那么同一横坐标的一定在…

[导入]源代码版本控制(一)

开发过程当中源代码的版本控制一直是个大问题。项目规模小了还好办&#xff0c;人的脑子还能记过来&#xff0c;项目大了&#xff0c;可能用各式各样的表格来记录版本信息和源代码内容&#xff0c;但这个办法本身的文档组织又是个问题&#xff0c;谁来维护&#xff1f;谁来更改…

重构技巧分别能够解决哪些代码味道

1.提炼类可以解决的5种代码味道&#xff1a; 过大类 重复代码 基本类型偏执 令人迷惑的暂时值域 狎昵关系 2.将类内联化可以解决的3种代码味道 冗赘类 夸夸其谈的未来性 霰弹式修改 3.隐藏委托关系解决的2种代码味道 狎昵关系 过度耦合的消息链 4.复制被监视的数据 过大类 5.以…

python爬取电影和美食数据实战

本文使用的是requests正则来匹配网页内容&#xff0c;对于数据量较多的采用了多线程抓取的方法&#xff0c;共3个案例&#xff0c;分别是抓取猫眼电影TOP100榜单和淘票票正在热映的电影信息、以及美团的美食数据。这几个案例采用的方法大同小异。1、首先选择想要爬取的网站2、确…

Asp.Net页面执行流程分析

在我的上一篇文章中说到了HttpModule、HttpHandle的简单使用&#xff0c;我们可以利用它们在页面请求的过程中加入自己的事件处理程序。那么在一个aspx页面请求时后台到底做了什么&#xff1f;当然asp.net做了很多事情&#xff0c;过程也比较复杂&#xff0c;本文主要分析一下大…

正则验证非法字符

function regText(text){var reg /^[\s\u4e00-\u9fa5a-z0-9_-]{0,}$/;if(!reg.exec(text)){console.log("非法字符")}else{console.log("有效字符")} } regText("abc") 验证 &#xff1a;汉字、英文、数字、下划线、中划线、空格 转载于:https…

活动排序工具之双代号网络(AOA)与单代号网络(AON)[cont.]

箭线图ADM/双代号网络AOA 图示 箭线表示活动 节点表示一个活动的开始或结束 三要素&#xff1a;结点、箭线、线路 唯一使用虚活动的活动排序工具&#xff0c;虚活动用虚线箭头表示&#xff0c;没有历时&#xff0c;不需资源&#xff0c;只表达活动关系的需要 只使用一种活动之…

并发任务的可视化

一、任务要求&#xff1a;在linux系统中设计一个父进程&#xff0c;三个子进程(A,B,C)。子进程A,B同时被父进程启动来计算&#xff08;不实现具体的计算任务&#xff0c;先用CPU空跑来代替&#xff09;。进程A计算5分钟&#xff0c;而进程B计算8分钟。当进程A,B都计算完成后才能…

银监会警示担保圈贷款风险 联保贷款变异 防多米诺效应

互保联保本是解决小微企业以及农村金融贷款需求的重要创新&#xff0c;但却在部分行业、部分地区逐渐变异&#xff0c;成为引发风险事件的诱因。 据媒体报道&#xff0c;银监会近日发文要求加强企业担保圈贷款风险的防范和化解工作。银监会警示&#xff0c;担保圈企业风险较高的…

SharePoint 2007 系列(4) -Site Settings

Site administration 转载于:https://www.cnblogs.com/xuxiaoguang/archive/2008/11/05/1326913.html

软件项目管理重点总结

文章目录概论走进项目管理把控环境&#xff0c;控制过程整合项目资源控制项目范围保障项目进度驾驭项目成本保证项目质量协调项目人力资源改善项目的沟通应对项目风险关注项目的采购和外包概论 项目的定义&#xff1a;为创造一个特定的产品、服务或者成果而采取的临时性的努力…

jQuery发送含有数组参数的ajax请求以及后台Struts2的OGNL解析错误

当使用jquery1.3以上版本时&#xff0c;进行ajax参数传值时&#xff0c;会出现以下的一个错误: ognl.ExpressionSyntaxException: Malformed OGNL expression: f[] [ognl.ParseException: Encountered " "]" "] "" at line 1, column 3. 这个错…

数据绑定以及Container.DataItem绑定技巧

数据绑定以及Container.DataItem绑定技巧 灵活的运用数据绑定操作绑定到简单属性:<%#UserName%>绑定到集合:<asp:ListBox id"ListBox1" datasource<%# myArray%> runat"server">绑定到表达式:<%#(class1.property1.ToString() "…

LeetCode 76. Minimum Window Substring / 567. Permutation in String

76. Minimum Window Substring 典型Sliding Window的问题&#xff0c;维护一个区间&#xff0c;当区间满足要求则进行比较选择较小的字串&#xff0c;重新修改start位置。 思路虽然不难&#xff0c;但是如何判断当前区间是否包含所有t中的字符是一个难点&#xff08;t中字符有重…

计算机网络中的协议数据单元的控制信息主要包括哪些内容

在计算机网络的数据传输过程中会对数据进行封装&#xff0c;俗称加头(链路层还会加尾)&#xff0c;增加的控制信息主要包括以下内容&#xff1a; 地址(Address)&#xff1a;用来标识发送端或接收端差错检测编码(Error-detecting code)&#xff1a;用于差错检测或纠正协议控制(…