版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、第4章 Verilog设计初步,主要内容,4.1 Verilog简介 4.2 Verilog模块的结构 4.3 Verilog基本组合电路设计 4.4 Verilog基本时序电路设计 4.5 Synplify Pro综合器 4.6 Synplify综合器,4.1 Verilog简介,Verilog语言是1983年由GDA(Gateway Design Automation)公司的Phil Moorby首创的,之后Moorby又设计了Verilog-XL仿真器,Verilog-XL仿真器大获成功,也使得Verilog语言得到推广使用。 1989年,Cadence收购了GDA,1990年,Cade
2、nce公开发表了Verilog HDL,并成立了OVI组织专门负责Verilog HDL的发展。 Verilog于1995年成为IEEE标准,称为IEEE Standard 1364-1995(Verilog-1995) IEEE“1364-2001”标准(Verilog-2001)也获得通过,多数综合器、仿真器都已支持Verilog-2001标准,Verilog语言的特点,既适于可综合的电路设计,也可胜任电路与系统的仿真。 能在多个层次上对所设计的系统加以描述,从开关级、门级、寄存器传输级(RTL)到行为级,都可以胜任,同时语言不对设计规模施加任何限制。 灵活多样的电路描述风格,可进行行为描
3、述,也可进行结构描述;支持混合建模,在一个设计中各个模块可以在不同的设计层次上建模和描述。 Verilog的行为描述语句,如条件语句、赋值语句和循环语句等,类似于软件高级语言,便于学习和使用。 内置各种基本逻辑门,便于进行门级结构描述;内置各种开关级元件,可进行开关级的建模。 易学易用,功能强,可满足各个层次设计人员的需要。,4.2 Verilog模块的结构,module aoi(a,b,c,d,f); /* 模块名为aoi,端口列表a,b,c,d,f */ input a,b,c,d;/模块的输入端口为a,b,c,d output f; /模块的输出端口为f wire a,b,c,d,f;
4、/定义信号的数据类型 assign f=(a /逻辑功能描述 endmodule,“与-或-非”电路,4.2 Verilog模块的结构,Verilog程序是由模块构成的。每个模块的内容都嵌在module和endmodule两个关键字之间;每个模块实现特定的功能。 每个模块首先要进行端口定义,并说明输入和输出口(input、output或inout),然后对模块的功能进行定义。 Verilog程序书写格式自由,一行可以写几个语句,一个语句也可以分多行写。 除了endmodule等少数语句外,每个语句的最后必须有分号。 可用 /*/ 和 /对Verilog程序作注释。,1模块声明,模块声明包括模块
5、名字,模块输入、输出端口列表。模块定义格式如下: module 模块名(端口1,端口2,端口3,);,2端口(Port)定义,对模块的输入输出端口要明确说明,其格式为: input 端口名1,端口名2, 端口名n;/输入端口 output 端口名1,端口名2, 端口名n; /输出端口 inout 端口名1,端口名2, 端口名n;/输入输出端口,3信号类型声明,对模块中所用到的所有信号(包括端口信号、节点信号等)都必须进行数据类型的定义。Verilog语言提供了各种信号类型,分别模拟实际电路中的各种物理连接和物理实体。 如果信号的数据类型没有定义,则综合器将其默认为是wire型。,4逻辑功能定义
6、,模块中最核心的部分是逻辑功能定义。 定义逻辑功能的几种基本方法: (1)用assign持续赋值语句定义 assign语句多用于组合逻辑的赋值,称为持续赋值方式。 (2)用always过程块定义 always过程语句既可以用来描述组合电路,也可以描述时序电路。 (3)调用元件(元件例化) 调用元件的方法类似于在电路图输入方式下调入图形符号来完成设计,这种方法侧重于电路的结构描述。,Verilog 模块的模板,module (); output 输出端口列表; /输出端口声明 input 输入端口列表; /输入端口声明 /*定义数据,信号的类型,函数声明*/ reg 信号名; /逻辑功能定义 a
7、ssign =; /使用assign语句定义逻辑功能 /用always块描述逻辑功能 always () begin /过程赋值 /if-else,case语句 /while,repeat,for循环语句 /task,function调用 end /调用其他模块 (); /门元件例化 门元件关键字 (); endmodule,【例4.5】 三人表决电路的Verilog描述 module vote(a,b,c,f);/模块名与端口列表 input a,b,c;/模块的输入端口 output f;/模块的输出端口 wire a,b,c,f; /定义信号的数据类型 assign f=(a/逻辑功能描
8、述 endmodule,4.3 Verilog基本组合电路设计,4.3 Verilog基本组合电路设计,【例4.6】4位二进制加法器的Verilog描述 module add4_bin(cout,sum,ina,inb,cin); input cin; input3:0 ina,inb; output3:0 sum; output cout; assign cout,sum=ina+inb+cin; /*逻辑功能定义*/ endmodule,综合 (RTL级),4位二进制加法器RTL级综合结果(Synplify Pro),综合(门级),4位二进制加法器门级综合视图(Synplify Pro),
9、【例4.8】 BCD码加法器 module add4_bcd(cout,sum,ina,inb,cin); input cin; input3:0 ina,inb; output3:0 sum; reg3:0 sum; output cout; reg cout; reg4:0 temp; always (ina,inb,cin) /always过程语句 begin temp9) cout,sum=temp+6; /两重选择的IF语句 else cout,sum=temp; end endmodule,4.3 Verilog基本组合电路设计,4.4 Verilog基本时序电路设计,【例4.9】
10、 基本D触发器的Verilog描述 module dff(q,d,clk); input d,clk; output reg q; always (posedge clk) begin q=d; end endmodule,4.4 Verilog基本时序电路设计,【例4.10】 带同步清0/同步置1(低电平有效)的D触发器 module dff_syn(q,qn,d,clk,set,reset); input d,clk,set,reset; output reg q,qn; always (posedge clk) begin if(reset) begin q=1b0;qn=1b1;end
11、 /同步清0,低电平有效 else if(set) begin q=1b1;qn=1b0;end /同步置1,低电平有效 else begin q=d; qn=d; end end endmodule,4.4 Verilog基本时序电路设计,【例4.11】 带异步清0/异步置1(低电平有效)的D触发器 module dff_asyn(q,qn,d,clk,set,reset); input d,clk,set,reset; output reg q,qn; always (posedge clk or negedge set or negedge reset) begin if(reset)
12、begin q=1b0;qn=1b1; end /异步清0,低电平有效 else if(set) begin q=1b1;qn=1b0; end /异步置1,低电平有效 else begin q=d;qn=d; end end endmodule,4.4 Verilog基本时序电路设计,【例4.12】 4位二进制加法计数器 module count4(out,reset,clk); input reset,clk; output reg3:0 out; always (posedge clk) begin if(reset) out=0;/同步复位 else out=out+1;/计数 end
13、 endmodule,综合 (RTL级),4位二进制加法计数器RTL级综合视图 (Synplify Pro),综合(门级),4位二进制加法计数器门级综合视图 (Synplify Pro),【例4.15】 Johnson计数器(异步复位) module johnson(clk,clr,qout); parameter WIDTH=4; input clk,clr; output reg(WIDTH-1):0 qout; always (posedge clk or posedge clr) begin if(clr) qout=0; else begin qout=qout1; qout0=qoutWIDTH-1; end end endmodule,Synplify Pro新建项目对话框,Synplify Pro新建文件对话框,Implementation Option对话框,约翰逊计数器综合后的RTL级原理图,约翰逊计数器综合后的门级原理图(MAX7000器件),在Synplify
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2024版技术转移合作协议
- 2024年度单车城市交通规划承包合同
- 2024年度分包工程安全生产合同2篇
- 二零二四年度烤肠生产许可与场地租赁合同
- 大连二手房地产保险合同
- 二零二四年度战略合作合同:某互联网公司与电信运营商关于网络服务合作的协议
- 二零二四年度化妆品研发销售合同
- 2024年度窗帘环保材质采购与生产合同
- 2024版知识产权许可合同许可知识产权与使用条件2篇
- 电梯维护保养合同书范本
- 法律常识题库500题及参考答案【达标题】
- 镇静药物的使用课件
- 2024-企业与高校科研合作协议完整版
- 职业生涯规划-体验式学习智慧树知到期末考试答案章节答案2024年华侨大学
- 25题机器视觉算法岗位常见面试问题含HR问题考察点及参考回答
- MOOC 流行歌曲演唱-武汉理工大学 中国大学慕课答案
- (正式版)SHT 3227-2024 石油化工装置固定水喷雾和水(泡沫)喷淋灭火系统技术标准
- 中小学人工智能教育方案
- (2024年)初中宾语从句课件
- 脱发知识课件
- 新部编版小学三年级上册语文第三单元基础过关卷(单元测试)
评论
0/150
提交评论