找回密码
 注册
关于网站域名变更的通知
查看: 458|回复: 1
打印 上一主题 下一主题

Xilinx FPGA Vivado 开发流程

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2023-4-13 15:14 | 只看该作者 |只看大图 回帖奖励 |倒序浏览 |阅读模式

EDA365欢迎您登录!

您需要 登录 才可以下载或查看,没有帐号?注册

x

大侠好,欢迎来到FPGA技术江湖。本系列将带来FPGA的系统性学习,从最基本的数字电路基础开始,最详细操作步骤,最直白的言语描述,手把手的“傻瓜式”讲解,让电子、信息、通信类专业学生、初入职场小白及打算进阶提升的职业开发者都可以有系统性学习的机会。


% j& d) [6 @- T$ X

系统性的掌握技术开发以及相关要求,对个人就业以及职业发展都有着潜在的帮助,希望对大家有所帮助。本次带来Vivado系列,Vivado开发软件开发设计流程。话不多说,上货。

6 d: M: u* F, ?+ n3 r1 Y
Xilinx FPGA Vivado 开发流程
6 A' P1 `- D$ V/ H* I. a+ ~
5 ]. @+ S% R6 C3 U& [1 s

6 W7 ?- H  A- L' J. H" i

在做任何设计之前,我们都少不了一个工作,那就是新建工程,我们设计的一些操作,必须在工程下完成,那么接下来就向大家介绍一下新建工程的步骤。那么我以简单的二输入与门为例向大家介绍一下操作步骤。


8 h8 v% g% V$ K. o

在后续的开发设计中,我们会做各种各样的设计。每个设计都有自己的名字,在上述文件内,用实验的名字命名一个文件夹。名字的话一定要带有某种含义,不建议随便给个字母序列当做名字。例如:第一个要做的二输入与门的设计,命名为and_gate2_1。


0 I) X+ n% ^2 P& b9 T, n# }3 ]

做好设计前准备后,我们开始新建工程。

; C# f  {4 P9 K4 U( b* d! a: r: R% D% j

* 新建工程


% |# A+ W9 a5 _

双击打开Vivado。


* G. A- e( d% C! ]2 k

$ E+ U  m$ S1 K/ @: C( ]% g( C

9 w/ G3 Z/ ~1 B6 p4 B& V

: w6 U1 k6 J7 V  ]

在Quick Start中,我们选择Creat Project。打开新建工程向导,如下:

  f* K' S' r; k- l% ^8 [7 j, {

: W2 w  k% f( g& p
6 }% w7 L1 n0 D5 I8 F
- w& y" v; {$ ~6 a8 N

( r3 {$ y( @; Y4 ~1 w+ ^
/ ~& A. l! Z" S6 O( y

- B3 ]" r* M, U) V
2 v3 F# l5 T) |0 k% E( n( B
此界面为新建工程引导,此步骤没有可以设置的内容,所以直接点击NEXT。

4 H8 F# \! f6 x  Q$ \; v
% X- E- N8 f3 k7 ?4 {  }' V

; a! {$ R. q5 W+ `' Q

8 S$ {' p, b% F, O

( n, L! v, n- d; {8 q9 K9 ~2 \
$ j- P& B* o" ~" W4 V! N( J
在此界面,我们第一步,需要给我们的工程起一个名字,在此我们起名为and_gate2_1。在第二步设置工程存放路径,要求无中文路径。第三步,如果你指定路径位置没有对应的and_gate2_1文件夹,那么我们就可以勾选上,软件会自动帮我们新建。由于我已经新建过了文件夹,所以此处我没有勾选此选项。设置好之后,点击NEXT。
) b# C. Z1 \0 n" g( Y2 c
" |  [4 ^1 Q2 l; A$ ?

' v7 w5 F: ^/ B5 I) Y7 F
+ g- d  D3 g; [+ Q
6 C. s; g* \3 S  D6 ~; \

3 e% M) `6 M, p0 A7 \4 G: L( g

3 \6 e# _2 L3 R/ |6 j1 F2 {
8 F4 F0 i' q8 c( k
此界面我们设置工程类型,选择RTL Project。在这个选项下面,还有另外的一个选项。这个是让我们选择是否创建源文件。图示中选择不新建,在建完工程之后我们在新建源文件。继续点击NEXT。
& h/ |2 }3 T8 S6 v$ y  G' [% L

0 ^9 z, A% P5 c! N' V8 v5 F

* E4 r5 t4 e( g( ]' |8 @

8 e' K8 i) T4 y/ i1 P6 R

  p: o$ X: M$ p
  O2 X' O7 `2 P4 Y" e! c5 ^! d

在这个步骤里面,我们选择对应开发板的芯片型号。我以SANXIN-B04为例,芯片型号为XC7A35TFGG484-2。可以在搜索框里直接输入,在下面的选项里面我们选择第一个,如图所示。选中之后点击NEXT。


9 _  \8 j: T$ ?: E


2 Y7 T+ R" ~. h


4 o+ u# {8 Z+ T5 S- i

. |$ B6 f3 u/ i- p' y% |

最后一步,为工程的信息展示。确认信息无误后,点击Finish。至此,我们的工程就新建完成了。

/ m+ C0 c# H$ n1 o" C4 I

7 [9 ~( u1 |. Y+ o5 ]+ F+ ^


( t, e. z" f6 l, V


3 \$ _& I" T: c" M+ Z$ K  z

我们把整个界面分为5个区域,如上图所示。

1、菜单;

软件的常用功能全在此区域,方便我们进行后续操作。每一项的作用,会在后续的讲解中为大家介绍。

2、源文件;

新建文件可以在此区域,在这个窗口下面,有三个选项,我们在第一个选项中可以看到代码文件的层次结构。

3、属性;

窗口会显示所选内容的具体信息

4、信息;

展示任务进度,编译信息等内容。

5、报告;

展示工程信息以及状态。此外编写代码也是在此区域。

9 _  O# u& b9 {4 `* _% U. G

通过以上的介绍,我们明白了各个区域的作用,接下来我们就新建文件开始编写代码:


: Y: c: \7 [, l1 b

1 h2 ]7 @  J- [; Z6 N

# e( O  G- r1 E( @, h6 {

" H% p# j' v( \) i2 M0 A- k2 V


! I  Q+ v( N" U. R

在源文件窗口,点击+号。如下图:

+ C2 f4 Y( j  b$ C5 ^$ f

" D  S* S% [! I* s  _# o8 ~. g' k

- J! P  Q7 |' j


9 w# n2 a+ z. ?9 U$ f

三个选项,第一个是添加或者新建管脚约束文件,第二个是添加或者新建源文件,第三个是添加或者新建仿真文件。那么我们选择第二个选项。


: \4 G2 c8 {; q0 f4 _

# O) |( ]* q& S

, _0 _" w& L) I- z% G4 i8 X7 @: S


: R6 i  ]4 B! |/ h( a4 r

2 F1 P8 Z+ D* N' ]# e

选择好之后,点击NEXT。然后按照上图中所示,点击Creat File;

5 z# N5 s7 `4 H4 c

& n9 i; i% H5 I* ?+ Y! N* M


' I- e/ c( l9 G8 e" t7 m

( F$ ~3 ?  H4 B& l


, G! \/ q- a" B+ }

在File name一项中,填入文件名,其他保持默认,然后点击OK,再点击Finish。

1 e2 K  i  a' e: P

7 F% l/ H, q) y- G; L

7 _7 p. `0 f5 K$ q4 Y5 H, H4 N

# p7 U7 i: ~" V3 j# f


" g  F" R, M" O' L; u

此界面我们可以提前填入端口,选择好端口方向以及位宽。然后软件就可以帮我们写好代码的端口定义部分。如果不需要可以直接点击OK。


) E* h9 J: |0 I8 O3 M


- T; \7 q: `$ t: ~. A

9 D2 H  ?8 l$ E3 N


2 d: N) G; W. W" O) u+ ^# d


& b# |2 Z. C$ \" p5 y( |& V8 {

再点击YES。


+ ~) T7 m7 D% ~6 R& D, ?


/ ?, Y9 [- R3 _, q0 o# p4 l

新建好之后,会出现如下图:

: _/ q  S# d6 ]/ w# y


: e2 c7 J+ P1 L/ V9 j


; p; ]9 X. g' U/ ~1 V. U; m) i


5 E' V6 G; g1 P

9 x) \5 ?- e/ T: `0 O/ Q9 L

在Design Sources中,可以看到我们新建的文件。双击打开开始写代码。自动生成的代码如下:


4 `  I" L4 K1 _

6 o0 B+ H9 V7 C: T" \" W4 y

* C: ?) i" G+ [& T' u

% f! d+ E/ m6 I! F/ g# ]; B

& L0 S6 w! v  i! o

为了更好的向大家展示,我将代码文件中的注释先删除掉。代码如下:

  T9 S+ ]$ v4 N3 u3 w5 A

% Q2 m; l: ]  @, M; c* p$ H

# w1 n: E: U* J  o, [& m! J4 W

! R+ r: A6 m0 ]( [) C, ?


) E; a# a7 [0 b& A. f) R

为了验证代码的正确性,还需要写测试文件进行仿真测试。仍然点击+号新建文件,只不过这次我们选择第三个选项:

4 T: I# ?0 C6 L% T; m3 q! g


- T9 E: x9 @5 Q8 N1 r1 m

/ c3 x+ Q9 t8 g; f* N$ e) }

, P' i2 S( Q; t$ q1 R


% C3 M/ X, ~1 ?

点击NEXT;选择Creat File:

9 {, R& t( w/ {/ k" X- o: g2 ?

8 J- K2 H7 _9 o


7 `5 C* w) V! I. O/ p. m2 ^

8 b2 M; F2 j+ y


/ O7 w3 d, O' L; Q! i+ q


) Z" s5 f8 y2 j1 o0 q+ n6 W


; ^; {1 e7 x- k

# R; ]4 W; F' V

& X( v* H7 w" v0 x3 ]5 M

点击OK,点击Finish。定义端口界面直接跳过,因为我们的仿真文件没有端口。

% E  g4 a. y7 C$ q7 U- i


( X; Y2 W2 s' w% Y) v# V


+ t: e9 n5 Q% l( q

6 n+ [: b) M- o9 v* f, N2 `

新建好之后,按照上图所示,双击打开文件。代码如下:

% g0 F: C' I7 |, v) ?( m3 t. F* B


# }8 W+ |- K3 n0 A# K5 W; N


' a/ u6 u- s$ x" t6 D& ^! P2 \


9 U% s. `% N% O: U

% z& z+ H& K2 Q' _

/ L( T+ W6 m# o- V

我们可以使用随机数来产生我们需要的输入,代码写完之后,我们可以直接打开仿真。

! P, u8 i; @2 r7 I


4 D. C: k1 l6 B2 |( y

2 E( F( V7 k* r) j  M  j

* ]$ k2 X& ~9 l7 @4 ^


( S  F" e' S' S* A& T# O  B& h

1 C& C: d6 R9 m+ u( R

点击如图所示的选项,打开软件的仿真器。

# Z7 B, f: M) R+ q. u2 O

5 I% P2 h$ Z! O1 h+ a2 {: m

0 C6 R1 X# T: X8 B

# F$ f) u8 @4 Y


! @+ q/ |: V+ p1 n( u

6 @# Z6 K+ a8 b/ b4 R: L

6 y6 c6 B: X+ B2 N+ @" x$ r

仿真图打开后,我们点击如图所示的按钮,可以看到全部波形。在仿真图中,我们可以看到后半部分波形没有变化,这是因为我们随机数生成了20组,每组20ns,所以总时长为400ns。但是仿真软件是默认运行1us的,所以就看到了如图所示的情况,在此,大家可以随意生成随机数的个数。我们验证仿真时,只需要看前400ns的波形就可以了。按照波形显示,我们可以验证到波形输出与与门真值表相同,所以最终结果是正确的。至于下板验证后续再出相关文章说明。

; K2 v! H- b$ _* l; I
, v6 k/ ]  [0 q- j  H5 L) `

# E" q# L& y7 x9 d3 `  I9 l9 r

该用户从未签到

2#
发表于 2023-4-13 18:07 | 只看该作者
刚开始学,你这个流程很详细,有没有开发包
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

推荐内容上一条 /1 下一条

EDA365公众号

关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

GMT+8, 2025-10-28 18:41 , Processed in 0.171875 second(s), 27 queries , Gzip On.

深圳市墨知创新科技有限公司

地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

快速回复 返回顶部 返回列表