VerilogHDL语言基础学习教案课件.pptx
- 【下载声明】
1. 本站全部试题类文档,若标题没写含答案,则无答案;标题注明含答案的文档,主观题也可能无答案。请谨慎下单,一旦售出,不予退换。
2. 本站全部PPT文档均不含视频和音频,PPT中出现的音频或视频标识(或文字)仅表示流程,实际无音频或视频文件。请谨慎下单,一旦售出,不予退换。
3. 本页资料《VerilogHDL语言基础学习教案课件.pptx》由用户(晟晟文业)主动上传,其收益全归该用户。163文库仅提供信息存储空间,仅对该用户上传内容的表现方式做保护处理,对上传内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知163文库(点击联系客服),我们立即给予删除!
4. 请根据预览情况,自愿下载本文。本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
5. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007及以上版本和PDF阅读器,压缩文件请下载最新的WinRAR软件解压。
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- VerilogHDL 语言 基础 学习 教案 课件
- 资源描述:
-
1、会计学1VerilogHDL语言基础语言基础2Verilog HDLVerilog HDL是目前应用最为广泛的硬件描述语言。是目前应用最为广泛的硬件描述语言。Verilog HDLVerilog HDL可以用来进行各种层次的逻辑设计,也可以进行数可以用来进行各种层次的逻辑设计,也可以进行数字系统的逻辑综合,仿真验证和时序分析等。字系统的逻辑综合,仿真验证和时序分析等。Verilog HDLVerilog HDL适合算法级,寄存器级,逻辑级,开关级、系适合算法级,寄存器级,逻辑级,开关级、系统级和版图级等各个层次的设计和描述。统级和版图级等各个层次的设计和描述。Verilog HDLVerilo
2、g HDL进行设计最大的优点是其工艺无关性。这使得进行设计最大的优点是其工艺无关性。这使得工程师在功能设计,逻辑验证阶段可以不必过多考虑门级及工工程师在功能设计,逻辑验证阶段可以不必过多考虑门级及工艺实现的具体细节,只需根据系统设计的要求施加不同的约束艺实现的具体细节,只需根据系统设计的要求施加不同的约束条件,即可设计出实际电路。条件,即可设计出实际电路。第1页/共69页3模块化设计理念支持以模块集合的形式构造数字系统。利用层支持以模块集合的形式构造数字系统。利用层次化、结构化的设计方法,一个完整的硬件设计任务可以划分成次化、结构化的设计方法,一个完整的硬件设计任务可以划分成若干个模块,每一个
3、模块又可以划分成若干个子模块,子模块还若干个模块,每一个模块又可以划分成若干个子模块,子模块还可以进一步划分。可以进一步划分。各个模块可以是自主开发的模块,也可以是从商业渠道购买各个模块可以是自主开发的模块,也可以是从商业渠道购买的具有知识产权的的具有知识产权的IPIP核。核。第2页/共69页442 VerilogHDL基础知识Verilog HDLVerilog HDL的运算符与的运算符与C C语言的运算符几乎完全相同,但数语言的运算符几乎完全相同,但数据类型是据类型是Verilog HDLVerilog HDL特有的。特有的。在实际应用中,要认真体会、深入理解硬件描述语言与软件在实际应用中
4、,要认真体会、深入理解硬件描述语言与软件编程语言的本质区别。编程语言的本质区别。421 VerilogHDL模块结构模块是模块是Verilog HDLVerilog HDL的基本单元,的基本单元,用于描述某个设计的功能用于描述某个设计的功能或结构以及与其他模块通信的外部端口或结构以及与其他模块通信的外部端口。模块的实际意义是代表硬件电路上的逻辑实体,每个模块都模块的实际意义是代表硬件电路上的逻辑实体,每个模块都实现特定的功能。实现特定的功能。第3页/共69页5模块的基本结构第4页/共69页6Verilog HDL语言描述模块结构举例VerilogHDLVerilogHDL模块结构完全嵌在模块结
5、构完全嵌在modulemodule和和endmoduleendmodule关键字关键字之间,包括四部分,即模块声明、端口定义、信号类型说明和之间,包括四部分,即模块声明、端口定义、信号类型说明和逻辑功能定义。逻辑功能定义。第5页/共69页71模块声明模块声明包括模块名和模块的端口列表。其格式如下:模块声明包括模块名和模块的端口列表。其格式如下:Module Module 模块名模块名(端口名端口名1,1,端口名端口名2,2,端口名端口名n)n);模块的其他部分模块的其他部分 endmodule endmodule 模块结束关键字模块结束关键字模块端口列表中端口名的排列顺序是任意的。模块端口列表
6、中端口名的排列顺序是任意的。第6页/共69页82端口(Port)定义端口是模块与外界或其他模块进行连接、通信的信号线。端口是模块与外界或其他模块进行连接、通信的信号线。因此,对端口列表中哪些端口是输入端口、哪些端口是输出端因此,对端口列表中哪些端口是输入端口、哪些端口是输出端口要进行明确说明。口要进行明确说明。在在Verilog HDLVerilog HDL中有中有3 3种端口类型;输入端口、输出端口、种端口类型;输入端口、输出端口、双向端口双向端口(既可用作输入也可用作输出既可用作输入也可用作输出)。第7页/共69页9)用)用inputinput定义输入端口,格式如下:定义输入端口,格式如下
7、:input input 位宽位宽 端口名端口名1 1,端口名,端口名2 2,端口名,端口名n n;)用)用outputoutput定义输出端口,格式如下:定义输出端口,格式如下:output output 位宽位宽 端口名端口名1 1,端口名,端口名2 2,端口名,端口名n n;)用)用inoutinout定义双向端口,格式如下:定义双向端口,格式如下:inout inout 位宽位宽 端口名端口名1 1,端口名,端口名2 2,端口名,端口名n n;使用上述使用上述3 3种定义格式时应注意:种定义格式时应注意:位宽的说明应遵循位宽的说明应遵循n:1n:1或或n-1:0n-1:0的规则;的规则
8、;不同位宽的端口应分别定义;不同位宽的端口应分别定义;位宽说明省略时,默认值为位宽说明省略时,默认值为1 1。第8页/共69页103数据(信号)类型说明在模块中用到的所有信号在模块中用到的所有信号(包括端口信号、节点信号、中包括端口信号、节点信号、中间变量等间变量等)都必须进行数据类型的定义。都必须进行数据类型的定义。VerilogHDLVerilogHDL中提供了中提供了各种信号类型,最常用的是各种信号类型,最常用的是连线型连线型(wire)(wire)、寄存器型、寄存器型(reg)(reg)和和参数型参数型(parameter)(parameter)。数据类型定义的实例:数据类型定义的实例
9、:reg 4reg 4:1 cout1 cout;定义信号定义信号coutcout的数据类型为的数据类型为4 4位寄存器位寄存器(reg)(reg)型型 wire awire a,b b,c c;定义信号定义信号a a,b b,c c为为1 1位连线位连线(wire)(wire)型型 注意:注意:输入端口输入端口和和双向端口双向端口不能说明为寄存器型;端口信号的数不能说明为寄存器型;端口信号的数据类型说明缺省时,据类型说明缺省时,EDAEDA的综合器将其默认为的综合器将其默认为wirewire型。型。第9页/共69页114逻辑功能定义 模块中的核心部分是逻辑功能的定义。模块中的核心部分是逻辑功
10、能的定义。Verilog HDLVerilog HDL提供了多种逻辑功能的定义方式,其中提供了多种逻辑功能的定义方式,其中调用调用逻辑门元件逻辑门元件(元件例化元件例化)、持续赋值语句、持续赋值语句(assign)(assign)、过程块、过程块(always)(always)3 3种定义方式比较常用。种定义方式比较常用。相对应在模块设计中的相对应在模块设计中的3 3种描述方法:种描述方法:门级描述方式、数门级描述方式、数据流描述方式、行为描述方式,以及以上混合描述方式据流描述方式、行为描述方式,以及以上混合描述方式。第10页/共69页121)通过调用逻辑门元件(元件例化)定义通过调用通过调用
11、Verilog HDLVerilog HDL提供的内置逻辑门元件,按照元件模提供的内置逻辑门元件,按照元件模型,进行它们之间的信号连接,完成逻辑电路的结构描述。型,进行它们之间的信号连接,完成逻辑电路的结构描述。采用这种方法可以将传统的电路原理图转换成采用这种方法可以将传统的电路原理图转换成Verilog HDLVerilog HDL文本形式。文本形式。例例1 1:and myand3(outand myand3(out,a a,b)b)例例2 2:and u3(fand u3(f,a a,b b,c)c);第11页/共69页132)用持续赋值语句(assign)定义assignassign语
12、句一般用在数据流描述方式中,常用来描述组合语句一般用在数据流描述方式中,常用来描述组合逻辑电路的功能,称为持续赋值方式。逻辑电路的功能,称为持续赋值方式。这种描述方式比较简单,只需将传统逻辑表达式转换成符这种描述方式比较简单,只需将传统逻辑表达式转换成符合合VerilogHDLVerilogHDL规范的表达式放在关键字规范的表达式放在关键字assignassign后面即可。后面即可。例如:例如:assign Fassign F(A&B)|(C&D)(A&B)|(C&D);3)用过程块(always)定义行为描述方式中采用行为描述方式中采用alwaysalways定义逻辑功能时,可不关心电定义逻
13、辑功能时,可不关心电路结构,只描述电路的行为,即在某种输入情况下产生相应的路结构,只描述电路的行为,即在某种输入情况下产生相应的输出。输出。硬件描述语言支持与逻辑电路结构无关的行为描述。行为硬件描述语言支持与逻辑电路结构无关的行为描述。行为描述转化为具体电路结构的工作由描述转化为具体电路结构的工作由EDAEDA工具完成。工具完成。第12页/共69页14例、用例、用alwaysalways过程块描述一个过程块描述一个4 4位计数器。位计数器。module counter(outmodule counter(out,resetreset,clk)clk);output 4output 4:1 ou
14、t1 out;input resetinput reset,clkclk;reg 4reg 4:1 out1 out;always (posedge clk)always (posedge clk)begin beginif(reset)out=0if(reset)out=0;else out=out+1else out=out+1;endend endmodule endmodule第13页/共69页15第14页/共69页164.2.2 词法表示第15页/共69页17第16页/共69页18第17页/共69页19第18页/共69页20423 数据类型 数据类型数据类型(DataType)(Da
15、taType)也称为变量类型。在也称为变量类型。在Verilog HDLVerilog HDL中中,数据类型用来表示数字电路中的物理连线、数据存储和数据,数据类型用来表示数字电路中的物理连线、数据存储和数据传送等物理量。传送等物理量。VerilogHDLVerilogHDL中共有中共有1919种数据类型,分成种数据类型,分成连线型连线型(Net Type)(Net Type)和和寄存器型寄存器型(Register Type)(Register Type)两类。两类。其中最常用的是其中最常用的是wirewire型、型、regreg型和型和parameterparameter型。型。第19页/共6
16、9页211连线型数据用来描述电路中的各种物理连接,没有状态保持能力,输用来描述电路中的各种物理连接,没有状态保持能力,输出随着输入变化而变化。必须对网络型数据进行连续的驱动。出随着输入变化而变化。必须对网络型数据进行连续的驱动。有两种驱动连线型数据的方式,有两种驱动连线型数据的方式,一是在结构描述中将其连一是在结构描述中将其连接到逻辑门的输出端或其他模块的输出端;另一种是用接到逻辑门的输出端或其他模块的输出端;另一种是用assignassign语句进行赋值语句进行赋值。当没有获得驱动时,它的取值为。当没有获得驱动时,它的取值为z z。Verilog HDLVerilog HDL中的连线型数据包
17、括中的连线型数据包括wirewire型、型、tritri型、型、worwor型、型、triortrior型、型、wandwand型、型、triandtriand型、型、triltril型、型、triotrio型、型、triregtrireg型、型、vectoredvectored型、型、largelarge型、型、mediummedium型、型、scalaredscalared型、型、smallsmall型。其型。其中,在可综合模块中最常用的是中,在可综合模块中最常用的是wirewire型。型。第20页/共69页22wire型数据用来表示用用来表示用assignassign语句赋值的组合逻辑信
18、号。语句赋值的组合逻辑信号。Verilog HDLVerilog HDL模块输入输出端口信号类型说明缺省时,自动定义为模块输入输出端口信号类型说明缺省时,自动定义为wirewire型。型。wirewire型变量可以用作任何表达时的输入,也可用作型变量可以用作任何表达时的输入,也可用作assignassign语句、元件调用语句和模块调用语句的输出。语句、元件调用语句和模块调用语句的输出。wirewire型变量的取值可为型变量的取值可为0 0、1 1、X X、Z Z。wirewire型数据的定义格型数据的定义格式如下:式如下:wire wire 数据名数据名1 1,数据名,数据名2 2,数据名,数
展开阅读全文