vivado hls的应用(带ddr读取的ip)

【 声明:版权所有,欢迎转载,请勿用于商业用途。 联系信箱:feixiaoxing @163.com】

前面我们也写了两个ip,一个是直接显示led的,另外一个是带axi总线。某种意义上说,这已经是大部分场景下ip的使用方法。但那只是满足非接口类ip需求,算法类ip的话,就还需要了一部分内容,那就是如何从ddr读取数据。

1、设计一个统计类的ip

这个ip的功能非常简单,就是设置好ddr地址、设置好数据的数量之后,然后ip就开始计数。等到所有计数结束之后,就可以触发一个中断给cpu。这就是ip的全部功能。和之前ip相比较,它最大的不同就是它可以访问内存,也就是ddr。就zynq而言,所有访问ddr的操作都是通过hp0接口完成的。

2、准备代码

代码部分其实是比较容易完成的。这里先不考虑ip的效率,暂时只实现功能。所以说要实现这一点,只要对interface做一些改变就可以了。

复制代码
#include <ap_cint.h>

uint32 result;
uint32 _average_int(uint32* array, int num)
{
	uint32 sum = 0;
	int i;

	for(i = 0; i < num; i++)
	{
		sum += array[i];
	}

	return sum / num;
}

uint32 led_control(uint32* array, int num)
{
#pragma HLS INTERFACE s_axilite port=return
#pragma HLS INTERFACE s_axilite port=num
#pragma HLS INTERFACE m_axi depth=1024  offset=slave port=array

	result = _average_int(array, num);
	return result;
}

**大家可以观察一下,这里面最大的区别就是array的设置。**首先,它的类型是m_axi,其次最大depth是1024,最后访问类型是slave,这些都代表说它要访问ddr的。

3、综合、导出rtl

综合是为了确认语法有没有问题,导出rtl则是为了确认c可以转变成verilog。

4、准备vivado工程

这里的vivado工程就是准备一个cpu,准备一个gpio,其他都使用默认连线就可以了,这就保证了整个最小系统至少是可以运行起来的。

5、导入ip,开始连线

vivado工程都准备好了之后,就可以导入之前生成的ip。当然,ip选择soc类型的时候,要和vivado里面的类型保持一致,不然哪怕是路径都设对了,在添加ip的时候,也会找不到的。添加ip之后,一般还需要补充一个axi smart connect,ip通过smart connect,直连zynq的hp0。ip的中断,也要提前设置好。剩下的部分,就采用默认的方式就可以。不出意外,你就可以看到这样的框图,

6、调整和确认

连线什么都设置好之后,这个时候通常还要double check下,看看有没有连线出错的,有没有没有连上线的。都没有问题之后,就可以继续综合、生成bitfile、生成sdk代码了。

相关推荐
@insist1236 分钟前
网络工程师-网络安全核心加密技术体系:对称 / 非对称加密、数字签名与证书全解析
网络·安全·web安全·网络工程师·软考·软件水平考试
non-action_pilgrim7 分钟前
《小坦克大战小怪兽》小游戏实战四:基于 protoactor-go 的游戏服务器框架与状态持久化实战
服务器·游戏·golang
盐真卿8 分钟前
华为数通 | VRRP负载分担与网关冗余实验:主备切换+流量分流,企业高可用网络实战
网络·华为
落羽的落羽17 分钟前
【算法札记】练习 | Week1
linux·服务器·c++·人工智能·python·算法·机器学习
isyangli_blog18 分钟前
4、sdn 网络性能的测试与验证
网络
王琦031821 分钟前
第十章 管理Linux的联网
linux·服务器·php
qq_2602412323 分钟前
将盾CDN:网络安全情报共享的实践与挑战
网络·安全·web安全
Run_Teenage25 分钟前
Linux:进程间通信-System V 共享内存
linux·运维·服务器
木子欢儿28 分钟前
Ubuntu 24.04 执行超微服务器 JNLP 程序
linux·运维·服务器·ubuntu
柠檬味的Cat29 分钟前
腾讯云轻量服务器一键部署OpenClaw教程
服务器·腾讯云