EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
大侠好,欢迎来到FPGA技术江湖。本系列将带来FPGA的系统性学习,从最基本的数字电路基础开始,最详细操作步骤,最直白的言语描述,手把手的“傻瓜式”讲解,让电子、信息、通信类专业学生、初入职场小白及打算进阶提升的职业开发者都可以有系统性学习的机会。 系统性的掌握技术开发以及相关要求,对个人就业以及职业发展都有着潜在的帮助,希望对大家有所帮助。本次带来Vivado系列,本篇为FPGA零基础学习之Vivado-LED流水灯实验。话不多说,上货。
( e: ` S- T+ K
9 D6 @# L3 ]. P! o9 aFPGA零基础学习之Vivado-LED流水灯实验 7 h7 k' @/ J% {" S/ t+ c4 Q
6 C3 f% O# D: S+ r
4 g0 I& }6 o8 b1 O+ q: _" |9 `3 y8 N2 t6 k
流水灯是大多数学习者接触到的第一个实验,也是非常经典的一个实验,在此,我们一起学习一下流水灯。
: V- o5 |- @$ l1 |
LED,又名发光二极管。LED灯工作电流很小(有的仅零点几毫安即可发光),抗冲击和抗震性能好,可靠性高,寿命长。由于这些优点,LED灯被广泛用在仪器仪表中作指示灯、液晶屏背光源等诸多领域。
' U" r0 q4 A* X. C5 R# Y7 C n3 K
发光二极管与普通二极管一样具有单向导电性。给它加上阳极正向电压后,通过5mA左右的电流就可以使二极管发光。通过二极管的电流越大,发出的光亮度越强。不过我们一般将电流限定在3~20mA之间,否则电流过大就会烧坏二极管。
& P- y4 p; p/ Y7 U* n
在我们的开发板上有四个LED,设计逻辑为:FPGA 输出高电平时,LED 点亮;FPGA 输出低电平时,LED 熄灭。 6 ~3 f2 j3 O: e, g* V
# i; x# C! M9 Q+ `
' n6 k$ o9 V- b6 r# A4 L2 Y8 ^% `* N: ~* [+ _/ |
( U% ]6 A4 {# L8 [% c, B* s) f) L* o7 x& _" z$ f6 A* }8 W0 f
本次设计框架如上图。 " ?% d/ _# s4 W; ~( n- P' Z1 d% T
* i' A0 i8 l% K- S管脚说明:
7 y9 R9 R; c# J4 H& c' w- Z
1 j6 c: r) W+ k) n2 I$ V+ q" n/ s! d. p* S, M) d
设计代码如下:
% A0 C9 J( K$ y7 i
! M6 g+ W! E. o4 V
. n9 Z" Q! g6 W' i4 z& b
3 O" L6 T& P% s1 ~ n4 y3 p5 m! R) [* T L' B( q
parameter 可以定义一个参数(默认是32 位)。在写代码时,对于某些数字,设计者经常利用定义参数的方式进行编写,方便修改,也方便阅读。 . S7 {! d" e% M5 S; S
其中计数器,需要计数到1s所需的次数,时间到了之后,LED灯切换点亮。按照此规则,实现LED的循环点亮。 # {( `/ U( j+ W# Z5 K. ~
在verilog 中,“{}”( 大括号)的第一个特殊作用为位拼接。{a,b}相当于将a 和b 拼接为一个整体,并且是高位为a,低位为b。当led 输出为4’b0001 时,第一个led 点亮;经过1 秒钟,输出4’b0010 时,第二个led 点亮;经过1 秒钟,输出4’b0100 时,第三个led 点亮;经过1 秒钟,输出4’b1000 时,第四个led 点亮;经过1 秒钟,输出4’b0001 时,第一个led 点亮······按照上述的过程周而复始,就形成了流水灯。 . {# \* i1 ]( }
不难发现,led 的输出,一直为3 个0,1 个1。并且1 的位置每1 秒钟移动一次,从头到尾,然后又到头。这种现象可以利用移位的思想进行实现。即:led[3]<=led[2]; led[2]<=led[1];led[1]<=led[0]; led[0]<=led[3];如果将被赋值的组成一个整体,那就是led,赋值的组成一个整体就是{led[2:0], led[3]}。
, M3 h' M0 H, B/ V( t( [) N/ H
仿真代码: 0 h3 s% a7 D- j2 a# F
& C+ T+ P8 |) c, Q( `5 E6 l1 ^( W
+ [" @/ |9 @% T* k! {* @* C
! ~+ Z8 c- H9 a; r/ o! l3 S
7 A0 a, ^* O! E
$stop 是一个系统任务,功能为将仿真工具的仿真停止。运行分析综合后,打开RTL 仿真。
! k0 _: F- ]3 m' e J3 Q
1 A/ ^, h4 T' [" g, B. D
% _0 K; d" @/ l2 X3 q
3 `1 C8 A2 N7 ], {
点击Run Simulation,打开仿真器。可以看到如图所示波形。
8 _4 W3 @# u/ H7 o. C
3 C% k# s2 K$ b2 u
% L8 p* n+ n: e/ c2 s3 S" n+ g& I6 T K7 `+ O7 s
+ U7 D' x% K/ e% V+ ^
由于我们设计的流水灯是每1 秒钟流动一个,在上述的仿真中,led 数值是不会变化的。如果仿真几秒钟的话,仿真的时间会比较长。在此不建议仿真几秒钟的时长,有可能会导致电脑卡住。 : H& w/ F6 H1 Y ~
1 G: J$ [8 M6 r
仿真时,可以将t 的值,改成一个较小值。例如:10。然后在此编译仿真。改的时候我们可以在仿真文件中加入一句话:
& [- w* V7 t8 s5 d: U# p3 W
- L$ ]+ ~6 X' j& {' _5 i9 v; F& G n1 B/ W
: n4 |2 R% A1 h) n
修改后我们重新运行仿真工具,可以看到如图所示波形: 0 P8 K" B( j. Y6 y' R* S; [
9 `4 w4 c: ?: k8 x1 H0 E3 \
' b8 ~( n4 ?1 j" L- ]
) }/ \1 g3 w. J) w
这样我们可以清楚的看到输出变化的过程。另外,我们这样做还有一个省事的地方,就是我们下板不需要再修改t的参数。 7 k& R$ `; U$ V$ r. a9 H; k
2 z$ }$ S0 ?5 A% m- d& L; Z
接下来我们分配引脚,生成下板文件。 5 p2 y7 K/ \% @; a1 I1 E" f
/ b! l" \1 r U( F, B: |
' q1 J" p8 _; y! z% n2 i' z: u, } ?8 d" V+ `
分配好之后,点击Generate Bitstream。 7 y5 B8 _! \3 c3 R) @! p, V1 r( F
r' t1 i9 W5 @% P1 w. A# j) Z' t0 }
0 `8 w0 i# U, j' u7 ?
6 ^6 y/ R4 `& |
生成完成之后,点击open Hardware Manager。下板即可。
! Y: N Y2 b. v
5 N) T& Z6 O% ~' ~% I6 w- R8 ^! F8 j2 |0 C
|