欢迎来到三一办公! | 帮助中心 三一办公31ppt.com(应用文档模板下载平台)
三一办公
全部分类
  • 办公文档>
  • PPT模板>
  • 建筑/施工/环境>
  • 毕业设计>
  • 工程图纸>
  • 教育教学>
  • 素材源码>
  • 生活休闲>
  • 临时分类>
  • ImageVerifierCode 换一换
    首页 三一办公 > 资源分类 > PPT文档下载  

    Verilog设计初步.ppt

    • 资源ID:4515495       资源大小:581.04KB        全文页数:32页
    • 资源格式: PPT        下载积分:5金币
    快捷下载 游客一键下载
    会员登录下载
    三方登录下载: 微信开放平台登录 QQ登录  
    下载资源需要5金币
    邮箱/手机:
    温馨提示:
    用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP免费专享
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    Verilog设计初步.ppt

    第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年,Cadence公开发表了Verilog HDL,并成立了OVI组织专门负责Verilog HDL的发展。Verilog于1995年成为IEEE标准,称为IEEE Standard 1364-1995(Verilog-1995)IEEE“1364-2001”标准(Verilog-2001)也获得通过,多数综合器、仿真器都已支持Verilog-2001标准,Verilog语言的特点,既适于可综合的电路设计,也可胜任电路与系统的仿真。能在多个层次上对所设计的系统加以描述,从开关级、门级、寄存器传输级(RTL)到行为级,都可以胜任,同时语言不对设计规模施加任何限制。灵活多样的电路描述风格,可进行行为描述,也可进行结构描述;支持混合建模,在一个设计中各个模块可以在不同的设计层次上建模和描述。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,doutput f;/模块的输出端口为fwire a,b,c,d,f;/定义信号的数据类型assign f=(a/逻辑功能描述endmodule,“与-或-非”电路,4.2 Verilog模块的结构,Verilog程序是由模块构成的。每个模块的内容都嵌在module和endmodule两个关键字之间;每个模块实现特定的功能。每个模块首先要进行端口定义,并说明输入和输出口(input、output或inout),然后对模块的功能进行定义。Verilog程序书写格式自由,一行可以写几个语句,一个语句也可以分多行写。除了endmodule等少数语句外,每个语句的最后必须有分号。可用/*/和/对Verilog程序作注释。,1模块声明,模块声明包括模块名字,模块输入、输出端口列表。模块定义格式如下:module 模块名(端口1,端口2,端口3,);,2端口(Port)定义,对模块的输入输出端口要明确说明,其格式为:input 端口名1,端口名2,端口名n;/输入端口output 端口名1,端口名2,端口名n;/输出端口inout 端口名1,端口名2,端口名n;/输入输出端口,3信号类型声明,对模块中所用到的所有信号(包括端口信号、节点信号等)都必须进行数据类型的定义。Verilog语言提供了各种信号类型,分别模拟实际电路中的各种物理连接和物理实体。如果信号的数据类型没有定义,则综合器将其默认为是wire型。,4逻辑功能定义,模块中最核心的部分是逻辑功能定义。定义逻辑功能的几种基本方法:(1)用assign持续赋值语句定义assign语句多用于组合逻辑的赋值,称为持续赋值方式。(2)用always过程块定义always过程语句既可以用来描述组合电路,也可以描述时序电路。(3)调用元件(元件例化)调用元件的方法类似于在电路图输入方式下调入图形符号来完成设计,这种方法侧重于电路的结构描述。,Verilog 模块的模板,module();output 输出端口列表;/输出端口声明input 输入端口列表;/输入端口声明/*定义数据,信号的类型,函数声明*/reg 信号名;/逻辑功能定义assign=;/使用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/逻辑功能描述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),【例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;endendmodule,4.3 Verilog基本组合电路设计,4.4 Verilog基本时序电路设计,【例4.9】基本D触发器的Verilog描述module dff(q,d,clk);input d,clk;output reg q;always(posedge clk)begin q=d;endendmodule,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/同步清0,低电平有效else if(set)begin q=1b1;qn=1b0;end/同步置1,低电平有效else begin q=d;qn=d;end endendmodule,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)beginif(reset)begin q=1b0;qn=1b1;end/异步清0,低电平有效else if(set)begin q=1b1;qn=1b0;end/异步置1,低电平有效else begin q=d;qn=d;end endendmodule,4.4 Verilog基本时序电路设计,【例4.12】4位二进制加法计数器module count4(out,reset,clk);input reset,clk;output reg3:0 out;always(posedge clk)beginif(reset)out=0;/同步复位else out=out+1;/计数endendmodule,综合(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;endendendmodule,Synplify Pro新建项目对话框,Synplify Pro新建文件对话框,Implementation Option对话框,约翰逊计数器综合后的RTL级原理图,约翰逊计数器综合后的门级原理图(MAX7000器件),在Synplify Pro中启动Quartus 进行编译,Quartus 将johnson_cnt.edf作为顶层文件,约翰逊计数器时序仿真波形图,习 题 4,4.1 用Verilog设计一个8位加法器,进行综合和仿真,查看综合和仿真结果。4.2 用Verilog设计一个8位二进制加法计数器,带异步复位端口,进行综合和仿真,查看综合和仿真结果。4.3 用Verilog设计一个模60的BCD码计数器,进行综合和仿真,查看综合和仿真的结果,

    注意事项

    本文(Verilog设计初步.ppt)为本站会员(laozhun)主动上传,三一办公仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知三一办公(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    备案号:宁ICP备20000045号-2

    经营许可证:宁B2-20210002

    宁公网安备 64010402000987号

    三一办公
    收起
    展开