|
EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
/ w# V% i% C! ~8 D! S- c, ^
5 _/ O* G$ j% v0 z- V/ g
1、Verilog的基本设计单元是模块(block)。一个模块是有两部分组成的 ,一部分描述接口,另一部分描述逻辑功能,及定义输入时如何影响输出的。下图为模块结构的组成。
4 v& J3 X7 F. m. @: M* d" b" X* ~7 @$ s- q6 ?" [9 t
2 R- u9 A4 l. o; F7 f$ w
(1)Verilog结构位于module和endmodule声明语句之间,每个Verilog程序包括四个主要部分:端口定义、I/O说明、内部信号声明和功能定义。模块的端口表示的是模块的输入还是输出口,其格式如下:module 模块名(口1,口2,口3,口4,……); K6 B {$ O( F- S9 v" P3 D& _* z
1 `2 g% o `: P1 \(2)模块的内容包括I/O说明、内部信号声明和功能定义。
- F1 v. T6 K5 Z
7 P' v j1 B& t) w, QI/O说明的格式,其中输入口:input[信号位宽-1:0] 端口名i;(共有i个输入端口),输出口:output[信号位宽-1:0] 端口名j;(共有j个输出口),输入/输出口:inout[信号位宽-1:0] 端口名k;(共有k个双向总线端口)。另外I/O说明也可以卸载端口声明语句里,其格式如下:module module_name(input port1,input port2,...output port1,output port2...);* c+ o7 c) U' w; Y0 a* I
5 v7 o5 T0 {& _( ^, l! G' [4 _# a+ U2 u6 g9 ~
K* x; J+ l9 Z* P内部信号说明,在模块内用到的和与端口有关的wire和reg类型变量的声明。如:reg[width-1:0] R变量1,R变量2...;wire[width-1:0] W变量1,W变量2...; C) I6 M( U: x9 L
5 J" [& Q" k1 B& v* H) f! l: q Y/ F* c$ k: A! b
. u V9 f; @+ r% n模块中最重要的部分是逻辑功能定义部分。有三种方法可在模块中产生逻辑。9 E) E2 D' p6 ]
" j- l8 c5 F V: |1 d
1)用“assign”声明语句:assign a = b & c;方程式描述了一个有两个输入的与门。) M# I, g% p3 P0 @& _
) @! k' ]8 m$ {! f% H2 |# m$ E
2)用实例元件,如:and #2 u1(q, a, b);表示在设计中用到一个跟与门(and)一样的名为u1的与门,其输入端为a,b,输出为q,输出延迟2个单位时间,实例元件的名字必须是唯一的,以免与其他调用与门(and)的实例混淆。& V7 G9 d( z& S% M# m3 w
0 ~' F8 A _# W5 Z- V/ l
3)用“always”块,如:) {, H+ s1 M$ Y, d" J
Z) k) a0 I8 n4 h3 T) Z4 ^always @(posedge clk or posedge clr)
- r+ T5 b! c4 [" O+ z, n' Z7 O( R% Y; S9 n
begin/ O* J) g6 O6 P* L. k
6 f- R9 a6 \! U
if(clr) q<= 0;
7 }' t/ ?' I+ h+ U1 q, ^( I
0 e8 s n+ T. X% z' a, helse if(en) q <= d;
$ O" {# m m* k5 X% K- m5 D) `+ m2 w
end/ E/ i) T" x% u
. r0 ~! z# H; b0 D7 \2 H6 u
采用“assign”语句是描述组合逻辑最常用的方法之一,而“always”块既可用于描述组合逻辑也可描述时序逻辑。5 w7 j) m8 n V" q. h4 ^
( o _; B1 m* Z' F* Y: w( s$ X# q
6 n7 Y% {1 z. E0 y: k
+ G* J; }, S9 }9 c9 x. \& A# g! X3 c/ ~9 c) O/ d: `
2、数据类型及其常量及变量,Verilog HDL中总共有19种数据类型。数据类型是用来表示数字电路硬件中的数据储存和传送元素的,其中reg型、wire型、integer型和parameter型为四个最基本的数据类型。其他的类型有large型、medium型、scalared型、time型、small型、tri型、trio型、tril型、triand型、trior型、trireg型、vectored型、wand型和wor型。其中除了time型外都与基本逻辑单元建库有关,与设计系统没有很大的关系。7 R6 z* {' Q$ i1 u
3 _3 a2 v- Z) W4 |2 J7 e' H) g6 J/ P( A: u) j" i+ W- V' t" W ~0 O
8 N* T( ?% W0 N2 [1 s(1)在程序运行过程中,其值不能被改变的量称为常量,包括数字和参数型(parameter)。
! d5 M" W3 n# V' P( g# |( M6 G$ ^ T+ F% Z$ R
(2)变量即在程序运行过程中其值可以改变的量,在Verilog HDL中变量的数据类型有很多种,其中只介绍wire型、reg型和memory型
# p3 Y6 M7 D% r( }& B4 `7 D5 D6 X0 v
3 ?$ c- D7 i1 \7 U% f. I4 A g7 A0 L" M
3、运算符及表达式,按功能可分为算术运算符、赋值运算符、关系运算符、逻辑运算符、条件运算符、位运算符、移动运算符和拼接运算符等。按其操作数可分为单目运算符、双目运算符和三目运算符。
0 T4 E6 `3 F& l# J7 r, y; S3 ?; E
+ ~9 E3 [: v- r% ?" h, F& @" s5 ?% x
7 \& d; [, R. |' S# b/ J0 k9 [+ F& J9 o) z
刚接触Verilog应注意以下几点:* G( `3 v( v- k. g) H ]+ U, H
) T5 N$ L: c: D+ m
1】在Verilog模块中所有过程块(initial块,always块)、连续赋值语句、实例引用都是并行的;
) M6 X% ]" |" L8 w/ p8 ]8 W0 h( N3 O! k
2】它们表示的是一种通过变量名相互连接的关系;' d6 B1 E7 r( r! m( J6 ~/ n
5 |& r! {# T5 ^& [& F( L0 V3】在同一模块中这三者出险的先后顺序没有关系;
9 x( Q8 S5 N, j9 q1 n/ s- ~6 Z, C' R% F* V( i o- T; B
4】只有连续赋值语句assign和实例引用语句可以独立于过程块而存在于模块的功能定义部分。 b0 _, d1 }+ O0 m( Y2 G
: E9 x# z6 Z) Q3 \# V
5】被实例引用的模块,其端口可以通过不同名的连线或寄存器类型变量连接到别的模块相应的输出输入信号端。" m3 s5 e. a" S. K8 W, S0 }# ]
7 [; E3 `7 ~, T( Z0 r
6】在“always”块内被赋值的每一个信号都必须定义成reg型。. X, R. o2 O5 P
|
|