|
EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
主要内容:+ S" ~( x( G) o8 Q8 E) }
Verilog 的应用& G6 L( [) R9 h9 _ _
Verilog 语言的组成部件
2 v( d/ p8 J+ Y, n2 D结构级的建模与仿真
( Z( r$ r1 r% X! w/ h0 s# v& N) p行为级的建模与仿真
+ o. J) o' P6 O, Y( `/ J延迟参数的表示% V+ t/ W' H7 @# }+ ]" r
Verilog 的测试平台:
, t: k2 R. M' e9 m. {/ ]7 [7 }怎样产生激励信号和控制信号" r; q$ G& N- z" R4 X6 G
输出响应的产生、记录和验证
* _' `; N @, z7 I. n* E任务和函数8 ^1 u8 ?' G f& s; b) Z. Z
用户定义的元器件(primitives)$ l& u- [% G4 a: |0 e/ n
可综合风格的Verilog 建模' y" }5 R! e4 S
3 Q3 A# t, w1 a# S1 X. eVerilog 的应用
4 a* u* B& q+ m pVerilog HDL是一种用于数字逻辑电路设计的语言:1 R' R/ ]1 @( Z! j! M- @ x
- 用Verilog HDL描述的电路设计就是该电路的Verilog HDL模型。3 d7 P% s& o6 w0 m# M" G
- Verilog HDL既是一种行为描述的语言也是一种结构描述的语言。8 I) ^, S+ w0 |
这也就是说,既可以用电路的功能描述也可以用元器件和它们之间的连接来建立所设计电路的Verilog HDL模型。Verilog模型可以是实际电路的不同级别的抽象。这些抽象的级别和它们对应的模型类型共有以下五种:
' z4 K% h- C3 L# N2 p●系统级(system): 用高级语言结构实现设计模块的外部性能的模
5 o7 V: u- |) T# @; A3 @% x6 T6 F●算法级(algorithmic): 用高级语言结构实现设计算法的模型。' S2 c* _& B8 d) N
●RTL级(Register Transfer Level): 描述数据在寄存器之间流动和如何处理这些数据的模型。/ @: `5 [& ~- A, T9 N
●门级(gate-level): 描述逻辑门以及逻辑门之间的连接的模型。6 u4 S( D1 ?3 |* A
●开关级(switch-level): 描述器件中三极管和储存节点以及它们之间连接的模型。
: f6 R' z |' g* i0 D* K" o$ @& }1 I& `( c( [
一个复杂电路的完整Verilog HDL模型是由若个 Verilog HDL 模块构成的,每一个模块又可以由若干个子模块构成。
6 m0 Y9 B0 B. F利用Verilog HDL语言结构所提供的这种功能就可以构造一个模块间的清晰层次结构来描述极其复杂的大型设计。
. u6 L4 v$ T- e/ }1 QVerilog HDL行为描述语言作为一种结构化和过程性的语言,其语法结构非常适合于算法级和RTL级的模型设计。这种行为描述语言具有以下八项功能:
0 e. e* @0 i" J: d7 V$ L$ a●可描述顺序执行或并行执行的程序结构。* l; o+ L. [) F. e. y
●用延迟表达式或事件表达式来明确地控制过程的启动时间。
; u" g6 j. V7 d●通过命名的事件来触发其它过程里的激活行为或停止行为。! Z( S. F N4 Z Z( O* R
●提供了条件、if-else、case、循环程序结构。0 D- X" r- ? q/ ~/ h& [1 j
●提供了可带参数且非零延续时间的任务(task)程序结构。, R, }" ~5 m: L+ U) y( _3 E* \1 O
●提供了可定义新的操作符的函数结构(function)。4 h5 G2 m0 d" U- u1 ?$ F6 O
●提供了用于建立表达式的算术运算符、逻辑运算符、位运算符。* y8 g* ~% m+ }* C' w) _/ n+ G
●Verilog HDL语言作为一种结构化的语言也非常适合于门级和开关级的模型设计。
1 z, N. C2 P6 y& x; K% O1 f●Verilog HDL的构造性语句可以精确地建立信号的模型。这是因为在Verilog HDL中,提供了延迟和输出强度的原语来建立精确程度很高的信号模型。信号值可以有不同的的强度,可以通过设定宽范围的模糊值来降低不确定条件的影响。* i3 E1 ]" G( Q; _: `# x1 q' S
6 n2 D# q7 C" K8 \8 z {1 ?Verilog HDL作为一种高级的硬件描述编程语言,有着类似C语言的风格。其中有许多语句如:if语句、case语句等和C语言中的对应语句十分相似。如果读者已经掌握C语言编程的基础,那么学习 Verilog HDL并不困难,我们只要对Verilog HDL某些语句的特殊方面着重理解,并加强上机练习就能很好地掌握它,利用它的强大功能来设计复杂的数字逻辑电路。下面我们将对Verilog HDL中的基本语法逐一加以介绍。+ m! }& k$ f) P
/ k4 g1 ^ P4 l! J6 e" f6 ^6 z模块的抽象' r- p; Z1 L& o) P+ E
技术指标:用文字表示;用算法表示;用高级行为的Verilog模块表示
- t% r1 t+ T, l* J" U0 z) aRTL/功能级:用可综合的Verilog模块表示( }: o3 s" r0 P* Z- G
门级/结构级:用实例引用的Verilog模块表示. P( @( `; J2 p0 H
版图布局/物理级:用几何形状来表示
2 [9 O) M; o# l% d* A* w, B; Q& h4 X8 b. m& j" P# |; @' R: {
简单的 Verilog HDL 模块
6 n! B$ ^$ N$ X" D, ~下面先介绍几个简单的Verilog HDL程序,然后从中分析Verilog HDL程序的特性。
& L6 `$ Z/ i1 } H$ }" \4 F' d9 l例[2.1.1]: module adder ( count,sum,a,b,cin );
2 y" n4 x8 t7 _ input [2:0] a,b;5 g" s' {1 ?, C# I8 \& G" O8 h
input cin;
( j5 p- b% V( n4 R3 Y, u' s- R output count;
2 L {9 O- W* ]' L2 W1 ? output [2:0] sum;$ V5 N7 l9 D7 C. M( w: E: S( A1 H
assign {count,sum}=a+b+cin;9 `4 B2 P) R9 d
endmodule
; i! P: {) v' p2 Q2 D3 x这个例子描述了一个三位的加法器。从例子中可以看出整个Verilog HDL程序是嵌套在module和endmodule声明语句里的。4 i9 y' g/ v2 t" r$ _1 K2 L
例[2.1.2]:$ ^. ]# T- ~' _1 Z! M$ o
module compare ( equal,a,b );
0 Z+ S. i8 v4 a. Q: e. z2 Z- ~0 C+ E8 { output equal; //声明输出信号equal' b# m6 l2 j' D1 ~6 T: b
input [1:0] a,b; //声明输入信号a,b
: I: u& @9 l9 k2 R$ ~2 M assign equal=(a==b)?1:0; 1 }& N5 I2 |6 T, \6 A6 h! W
/*如果两个输入信号相等,输出为1。否则为0*/
& c8 Y O/ e d8 T1 y% h8 T6 Gendmodule
* O7 i7 o% r+ p) \: K0 J这个程序描述了一个比较器.在这个程序中,/*........*/和//.........表示注释部分,注释只是为了方便程序员理解程序,对编译是不起作用的。
) o- L6 V. U8 e T4 d, i |
|