HLS入门-LED闪烁仿真

一、创建项目

1、点击Vivado HLS 中的Create New Project

在这里插入图片描述

2、设置项目名

在这里插入图片描述
在这里插入图片描述

3、加入文件

在这里插入图片描述

右键Source与Test Bench,分别新建文件Helloworld.cpp,Helloworld.h与tb_Helloworld.h。

4、C仿真

1、编写代码

在三个文件中分别编写以下代码:

Helloworld.h
//helloworld.h
#ifndef _HELLOWORLD_H_
#define _HELLOWORLD_H_
#include "ap_int.h"
typedef 	ap_int<1> led_t;
void flash_led(led_t *led_o);
#endif

Helloworld.cpp

//Helloworld.cpp
#include "HelloWorld.h"
void flash_led(led_t *led_o){
#pragma HLS INTERFACE ap_ovld port=led_o
	int i;
	for(i=0;i<10000;i++){
		if(i==9999){
			*led_o = ~(*led_o);
		}
	}
}

tb_Helloworld.cpp

#include "HelloWorld.h"
#include <stdio.h>
int main(){
	led_t led_o;
	const int SHIFT_TIME = 4;
	int i;
	for(i=0;i<SHIFT_TIME;i++){
		flash_led(&led_o);
		printf("result : %d \n",(int)(led_o&0x01));
	}
}

2、仿真

在保存好代码之后,点击图中的这个按钮进行C仿真:
在这里插入图片描述
在这里插入图片描述
弹出这个界面,什么都不用选。

运行仿真后,出现下面这个界面就说明仿真成功了:
在这里插入图片描述

3、综合

进行综合之前,先选择Top Function。

点击Project -> Project Setting -> Synthesis ,点击Helloworld.cpp,并点击Browse选择函数flash_led。
在这里插入图片描述
然后点击运行

4、联合仿真

在这里插入图片描述
在Helloworld.cpp界面,右边的Drective界面,右键led_o,进入如下界面:
在这里插入图片描述
按上图来配置,并点击OK。

然后点击联合仿真:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

二、总结

实验成功完成了LED闪烁的硬件实现。通过HLS工具,我们能够快速地将C语言代码转换为硬件电路,并在FPGA上运行。LED以预定的频率闪烁,验证了HLS流程的有效性。本实验通过LED闪烁项目成功地介绍了HLS的基本概念和流程。HLS作为一种新兴的硬件开发技术,具有简化设计流程、提高开发效率的潜力。通过本次实验,我们认识到了HLS的便捷性和其在现代硬件开发中的重要性。随着技术的不断发展,HLS有望在未来的硬件设计中扮演更加重要的角色。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值