FPGA线上课程平台|最全栈的FPGA学习平台|FPGA工程师认证培训
登录
首页-工程案例-正文

基于ZYNQ ECO开发板的呼吸灯实验

shaonianxue_guojpshaonianxue_guojp
工程案例
3年前
6
0
979

一、简介

呼吸灯常见于我们的手机指示灯上,本实验将会教会大家利用FPGA构建一个呼吸灯。

二、需要的工具与知识

我们的开发工具运用的Vivado 2020.1 硬件平台选择的是ZYNQ ECO开发板,你需要了解一下PWM波。

呼吸灯的原理是当你不断的增加PWM波的占空比就可以让灯不断的变亮,当降低占空比的时候灯就会逐渐变暗。

三、Vivado的使用

创建项目以及芯片选型

基于ZYNQ ECO开发板的呼吸灯实验 - 第1张
基于ZYNQ ECO开发板的呼吸灯实验 - 第2张
基于ZYNQ ECO开发板的呼吸灯实验 - 第3张
基于ZYNQ ECO开发板的呼吸灯实验 - 第4张
基于ZYNQ ECO开发板的呼吸灯实验 - 第5张
基于ZYNQ ECO开发板的呼吸灯实验 - 第6张
基于ZYNQ ECO开发板的呼吸灯实验 - 第7张

创建源文件(.v文件)

基于ZYNQ ECO开发板的呼吸灯实验 - 第8张
基于ZYNQ ECO开发板的呼吸灯实验 - 第9张
基于ZYNQ ECO开发板的呼吸灯实验 - 第10张
基于ZYNQ ECO开发板的呼吸灯实验 - 第11张
基于ZYNQ ECO开发板的呼吸灯实验 - 第12张
基于ZYNQ ECO开发板的呼吸灯实验 - 第13张
基于ZYNQ ECO开发板的呼吸灯实验 - 第14张
基于ZYNQ ECO开发板的呼吸灯实验 - 第15张

四、呼吸灯代码

如果你是新手可以复制以下代码替换掉原有.v文件的内容

`timescale 1ns / 1ps
module PWM_live_led(
input sysclk ,
input rst_n ,
output reg led
);
reg [31:0] cnt;
reg [28:0] cnt_1000us;
reg [28:0] cnt_1000ms;
reg cnt_s;
always@(posedge sysclk or negedge rst_n)begin
if(!rst_n)
cnt<=0;
else if(cnt>=50-1)
cnt<=0;
else
cnt<=cnt+1;
end
always@(posedge sysclk or negedge rst_n)begin
if(!rst_n)
cnt_1000us<=0;
else if(cnt==50-1&&cnt_1000us==1000-1)
cnt_1000us<=0;
else if(cnt==50-1)
cnt_1000us<=cnt_1000us+1;
else
cnt_1000us<=cnt_1000us;
end
always@(posedge sysclk or negedge rst_n)begin
if(!rst_n)
cnt_1000ms<=0;
else if(cnt==50-1&&cnt_1000us==1000-1&&cnt_1000ms==1000-1)
cnt_1000ms<=0;
else if(cnt==50-1&&cnt_1000us==1000-1)
cnt_1000ms<=cnt_1000ms+1;
else
cnt_1000ms<=cnt_1000ms;
end
always@(posedge sysclk or negedge rst_n)begin
if(!rst_n)
cnt_s<=0;
else if(cnt==50-1&&cnt_1000us==1000-1&&cnt_1000ms==1000-1)
cnt_s<=cnt_s+1;
else
cnt_s<=cnt_s;
end
always@(posedge sysclk or negedge rst_n)begin
if(!rst_n)
led<=0;
else if(cnt_s==0)begin
if(cnt_1000us<=cnt_1000ms)
led<=1;
else
led<=0;
end
else begin
if(cnt_1000us<=cnt_1000ms)
led<=0;
else
led<=1;
end
end
endmodule

五、添加管脚约束

基于ZYNQ ECO开发板的呼吸灯实验 - 第16张
基于ZYNQ ECO开发板的呼吸灯实验 - 第17张
基于ZYNQ ECO开发板的呼吸灯实验 - 第18张
基于ZYNQ ECO开发板的呼吸灯实验 - 第19张
基于ZYNQ ECO开发板的呼吸灯实验 - 第20张

六、约束文件代码

set_property -dict { PACKAGE_PIN K17 IOSTANDARD LVCMOS33 } [get_ports { sysclk }];
set_property -dict { PACKAGE_PIN T12 IOSTANDARD LVCMOS33 } [get_ports { led }];
set_property -dict { PACKAGE_PIN M20 IOSTANDARD LVCMOS33 } [get_ports { rst_n }];

七、生成bitstream (比特流)

基于ZYNQ ECO开发板的呼吸灯实验 - 第21张
基于ZYNQ ECO开发板的呼吸灯实验 - 第22张
基于ZYNQ ECO开发板的呼吸灯实验 - 第23张
基于ZYNQ ECO开发板的呼吸灯实验 - 第24张
基于ZYNQ ECO开发板的呼吸灯实验 - 第25张
基于ZYNQ ECO开发板的呼吸灯实验 - 第26张
基于ZYNQ ECO开发板的呼吸灯实验 - 第27张
基于ZYNQ ECO开发板的呼吸灯实验 - 第28张

现在你就能在ECO板上看见一颗正在“呼吸”的LED。

其实呼吸灯有很多写法,这里笔者提供了另一种仅9行就实现功能的呼吸灯代码,感兴趣的同学可以登录查看!

module PWM_live_led(
input sysclk,
output led
);
reg [27:0] cnt;
always@(posedge sysclk)
cnt<=cnt+1;
assign led = cnt[27]?(cnt[26:17]>=cnt[16:7]?1'b1:1'b0):(cnt[26:17]>=cnt[16:7]?1'b0:1'b1);
endmodule

约束文件

set_property -dict { PACKAGE_PIN K17 IOSTANDARD LVCMOS33 } [get_ports { sysclk }];
set_property -dict { PACKAGE_PIN T12 IOSTANDARD LVCMOS33 } [get_ports { led }];
标签:
本文原创,作者:shaonianxue_guojp,其版权均为FPGA线上课程平台|最全栈的FPGA学习平台|FPGA工程师认证培训所有。
如需转载,请注明出处:https://z.shaonianxue.cn/197.html
shaonianxue_guojp

shaonianxue_guojp

初级工程师
这家伙真懒,几个字都不愿写!
18.22W8.16K7.60K
分享:
成电国芯FPGA赛事课即将上线
Xilinx FPGA 入门基础指导教程(教材)
Xilinx FPGA 入门基础指导教程(教材)上一篇
基于ZYNQ ECO开发板的跑马灯实验下一篇
基于ZYNQ ECO开发板的跑马灯实验
相关文章
总数:42
modelsim安装使用及Vivado关联

modelsim安装使用及Vivado关联

使用Vivado关联modelsim仿真使用Modelsim下载…
工程案例, 资源分享
3个月前
0
0
72
0
基于FPGA的手动及红外循迹_王同学

基于FPGA的手动及红外循迹_王同学

基于FPGA的手动及红外循迹,中期项目答辩。…
工程案例
2个月前
0
0
53
0
FPGA很有价值的27实例经典案例

FPGA很有价值的27实例经典案例

FPGA很有价值的27实例经典案例…
工程案例
2个月前
0
0
47
0
评论表单游客 您好,欢迎参与讨论。
请输入昵称
请输入邮箱
请输入网址
0 / 100
评论列表
总数:0
FPGA线上课程平台|最全栈的FPGA学习平台|FPGA工程师认证培训
暂无评论,第一个评论下?