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

Verilog HDL硬件描述语言

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2022-8-30 09:53 | 只看该作者 |只看大图 回帖奖励 |倒序浏览 |阅读模式

EDA365欢迎您登录!

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

x
第1章 简 介0 Q. n0 d! g9 B6 I
本章介绍Verilog HDL语言的发展历史和它的主要能力。2 l; J( z! O7 x% K1 k
1.1 什么是Verilog HDL?1 |" r$ Z$ `" \+ ^6 k  n; O
Verilog HDL是一种硬件描述语言,用于从算法级、门级到开关级的多种抽象设计层次的数字系统建模。被建模的数字系统对象的复杂性可以介于简单的门和完整的电子数字系统之间。数字系统能够按层次描述,并可在相同描述中显式地进行时序建模。% L/ c$ z" J8 ^  H( r+ K3 Z( D. B
Verilog HDL 语言具有下述描述能力:设计的行为特性、设计的数据流特性、设计的结构组成以及包含响应监控和设计验证方面的时延和波形产生机制。所有这些都使用同一种建模语言。此外,Verilog HDL语言提供了编程语言接口,通过该接口可以在模拟、验证期间从设计外部访问设计,包括模拟的具体控制和运行。
2 N% a+ d7 y6 i( w; oVerilog HDL语言不仅定义了语法,而且对每个语法结构都定义了清晰的模拟、仿真语义。因此,用这种语言编写的模型能够使用Verilog仿真器进行验证。语言从C编程语言中继承了多种操作符和结构。 Verilog HDL提供了扩展的建模能力,其中许多扩展最初很难理解。但是,Verilog HDL语言的核心子集非常易于学习和使用,这对大多数建模应用来说已经足够。当然 ,完整的硬件描述语言足以对从最复杂的芯片到完整的电子系统进行描述。8 V9 H. {5 w2 A4 U

' t* b1 q) x2 z, e1 h$ Y. [1.2 历史1 |' i+ Q9 v& }2 @- x; Y/ P
Verilog HDL语言最初是于1983年由Gateway Design Automation公司为其模拟器产品开发的硬件建模语言。那时它只是一种专用语言。由于他们的模拟、仿真器产品的广泛使用,Verilog HDL作为一种便于使用且实用的语言逐渐为众多设计者所接受。在一次努力增加语言普及性的活动中,Verilog HDL语言于1990年被推向公众领域。Open Verilog International(OVI)是促进Verilog发展的国际性组织。1992年,OVI决定致力于推广Verilog OVI标准成为IEEE标准。这一努力最后获得成功,Verilog语言于1995年成为IEEE标准,称为IEEEStd1364-1995。完整的标准在Verilog硬件描述语言参考手册中有详细描述。
6 ^& }  R# z1 m8 e
" q7 O' {* g& s. F1.3 主要能力
2 j( w3 s( f& d' d下面列出的是Verilog硬件描述语言的主要能力:: O: `7 r0 K  h% k) T' x/ {+ P
•基本逻辑门,例如and、or和NAND等都内置在语言中。1 M, R4 a( a* G. Q
•用户定义原语(UDP)创建的灵活性。用户定义的原语既可以是组合逻辑原语,也可以是时序逻辑原语。
3 y7 u4 e! r: e7 {, k& O7 }% y/ P2 F•开关级基本结构模型,例如pmos和nmos等也被内置在语言中。
$ m/ j& U7 D6 k" y/ e• 提供显式语言结构指定设计中的端口到端口的时延及路径时延和设计的时序检查。% h8 ~/ [* k! Y/ ]
• 可采用三种不同方式或混合方式对设计建模。这些方式包括:行为描述方式—使用过
& V6 g0 k) n) S) g1 }  n6 @/ G& B程化结构建模;数据流方式—使用连续赋值语句方式建模;结构化方式—使用门和模块实例语句描述建模。
5 f5 C6 z4 `4 n! _2 U$ T2 Z) G• Verilog HDL中有两类数据类型:线网数据类型和寄存器数据类型。线网类型表示构件间的物理连线,而寄存器类型表示抽象的数据存储元件。, o/ f: |' [- P$ v- A! i9 i
• 能够描述层次设计,可使用模块实例结构描述任何层次。
; V8 [7 _$ R  R# d0 B; ~• 设计的规模可以是任意的;语言不对设计的规模(大小)施加任何限制。
0 M0 ^: _6 Q% a6 v1 ~6 F+ T• Verilog HDL不再是某些公司的专有语言而是IEEE标准。4 `; F. g6 @* b: @  w
• 人和机器都可阅读Verilog语言,因此它可作为EDA的工具和设计者之间的交互语言。
( R( {6 o* z/ F/ l4 {( F• Verilog HDL语言的描述能力能够通过使用编程语言接口(PLI)机制进一步扩展。PLI是允许外部函数访问Verilog 模块内信息、允许设计者与模拟器交互的例程集合。0 P  V+ x+ O* D6 o; o4 B, ]
• 设计能够在多个层次上加以描述,从开关级、门级、寄存器传送级(RTL)到算法级,包括进程和队列级。
, ~8 o2 c* `6 u- {( s3 ?• 能够使用内置开关级原语在开关级对设计完整建模。9 y9 G* K: F, c% g: \5 i1 l, ]
• 同一语言可用于生成模拟激励和指定测试的验证约束条件,例如输入值的指定。
4 r5 P+ e6 A3 l2 p• Verilog HDL能够监控模拟验证的执行,即模拟验证执行过程中设计的值能够被监控和显示。这些值也能够用于与期望值比较,在不匹配的情况下,打印报告消息。
4 P) y1 J. M( u• 在行为级描述中, Verilog HDL不仅能够在RTL级上进行设计描述,而且能够在体系结构级描述及其算法级行为上进行设计描述。' C) M! D/ c3 L! Q! h
• 能够使用门和模块实例化语句在结构级进行结构描述。
, S  W) c+ ?: U7 f  _. {: k• 图1 - 1显示了Verilog HDL的混合方式建模能力,即在一个设计中每个模块均可以在不同设计层次上建模。' ?% a( G) J# N* R' L
5 P- P3 O0 m5 ^4 R) a. f- r1 Q
• Verilog HDL还具有内置逻辑函数,例如&(按位与)和|(按位或)。/ ]3 ]7 r9 u! e% |
• 对高级编程语言结构,例如条件语句、情况语句和循环语句,语言中都可以使用。# b  u" X+ n1 [( \
• 可以显式地对并发和定时进行建模。
' X' a5 h7 J1 p/ m# o7 Z• 提供强有力的文件读写能力。: [$ l; q, w5 D, p" t$ j# O/ X5 s
• 语言在特定情况下是非确定性的,即在不同的模拟器上模型可以产生不同的结果;例如,事件队列上的事件顺序在标准中没有定义。6 w# M, g! v; t  T+ _  ]

5 i' S1 g2 B' ^- y3 ]第2章 HDL指南: Z' k  ~" u  ]2 x
本章提供H D L语言的速成指南。
$ ?( `, I. E! Y1 Z. _2.1 模块, W" t# g  j# j" L- m: t2 f' y" h
模块是Verilog 的基本描述单位,用于描述某个设计的功能或结构及其与其他模块通信的外部端口。一个设计的结构可使用开关级原语、门级原语和用户定义的原语方式描述 ; 设计的数据流行为使用连续赋值语句进行描述 ; 时序行为使用过程结构描述。一个模块可以在另一个模块中使用。- S. P9 K* s+ l% E4 a
一个模块的基本语法如下:
0 g: ]% U7 o. }8 |' b* S
5 @2 R8 u- u9 e: o! \说明部分用于定义不同的项,例如模块描述中使用的寄存器和参数。语句定义设计的功能和结构。说明部分和语句可以散布在模块中的任何地方;但是变量、寄存器、线网和参数等的说明部分必须在使用前出现。为了使模块描述清晰和具有良好的可读性 , 最好将所有的说明部分放在语句前。本书中的所有实例都遵守这一规范。5 K' l: J1 V. l* f8 k' z" W: n* b
5 e) e# e+ z& Q- n0 x& ~/ z
图2 - 1为建模一个半加器电路的模块的简单实例。
0 J) \; }/ i/ [: t& u% C" O; Smodule HalfAdder(A, B, Sum, Carry) ;! e* q& F9 G( w4 ]5 M
inputA,B;, _$ x7 u' r; S4 t6 ^$ o
output Sum, Carry;
4 A& B" b- Q6 w- A" v& V, \9 @assign#2 Sum=A^B;; U; r: [5 F% l- j* E( ?  p9 i) P
assign#5 Carry=A&B;
  i& o, C5 a) B" M4 ^4 fendmodule" ]. C0 Z4 N, l

/ V. D  D7 z" p模块的名字是HalfAdder。 模块有4个端口: 两个输入端口A和B,两个输出端口Sum和Carry。由于没有定义端口的位数, 所有端口大小都为1位;同时, 由于没有各端口的数据类型说明, 这四个端口都是线网数据类型。模块包含两条描述半加器数据流行为的连续赋值
8 ?6 P( P) r9 A& C) b语句。从这种意义上讲,这些语句在模块中出现的顺序无关紧要,这些语句是并发的。每条语句的执行顺序依赖于发生在变量 A和B上的事件。4 L# ?" K+ C( s$ O& u( Q
在模块中,可用下述方式描述一个设计:. T7 f  y/ _/ X- R3 j4 @
1) 数据流方式;- V$ y! c  b1 \& I7 C
2) 行为方式;, G/ `0 W; A$ E+ B( W# _
3) 结构方式;; F7 `1 n4 C0 a0 n/ ^& _8 \
4) 上述描述方式的混合。+ x' x1 z! Q$ N- ~) X" X

Verilog HDL硬件描述语言.PDF

4.78 MB, 下载次数: 0, 下载积分: 威望 -5

该用户从未签到

2#
发表于 2022-8-30 10:28 | 只看该作者
一起互相交流学习,共同进步

该用户从未签到

3#
发表于 2022-8-30 11:13 | 只看该作者
提高同行之间的技术水平

该用户从未签到

4#
发表于 2022-8-30 14:42 | 只看该作者
好东西,谢谢分享,学习
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

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

EDA365公众号

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

GMT+8, 2025-11-1 08:53 , Processed in 0.156250 second(s), 26 queries , Gzip On.

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

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

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