版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
第一部分数字系统设计概论第二部分CPLD/FPGA第三部分VerilogHDL第四部分上机实验
第三部分
VerilogHDL
一、初识VerilogHDL二、VerilogHDL语法基础三、VerilogHDL行为语句四、数字电路Verilog设计主要内容四、数字电路Verilog设计组合逻辑电路设计时序逻辑电路设计多层次结构电路设计目标:写简单电路读较为复杂电路掌握多层次结构电路设计基本方法例1:一、组合逻辑电路设计三种设计风格:结构描述(调用门元件)数据流描述(assign)行为描述(always过程语句)例1:一、组合逻辑电路设计notandor元件名称实例化名称(输出端口,输入端口)
modulemux4_1a(out,in1,in2,in3,in4,ct1,ct2);
inputin1,in2,in3,in4,ct1,ct2;
outputout;
endmodule
not(nct1,ct1),(nct2,ct2);and(w,in1,nct1,nct2),(x,in2,nct1,ct2),
(y,in3,ct1,nct2),(z,in4,ct1,ct2);or(out,w,x,y,z);结构描述:写例1:一、组合逻辑电路设计out=(in1&~ct1&~ct2)∣(in2&~ct1&ct2)∣(in3&ct1&~ct2)∣(in4&ct1&ct2)
数据流描述
modulemux4_1(out,in1,in2,in3,in4,ct1,ct2);
inputin1,in2,in3,in4,ct1,ct2;
outputout;
assignout=(in1&~ct1&~ct2)∣(in2&~ct1&ct2)∣(in3&ct1&~ct2)∣(in4&ct1&ct2);
endmodule写
行为描述
modulemux4_1b(out,in1,in2,in3,in4,ct1,ct2);
inputin1,in2,in3,in4,ct1,ct2;
outputout;regout;
always@()
out=(in1&~ct1&~ct2)∣(in2&~ct1&ct2)∣(in3&ct1&~ct2)∣(in4&ct1&ct2);
endmodulein1orin2orin3orin4orct1orct2写例2:三态门(2)数据流描述 (3)行为描述(1)结构描述assignout=en?in:’bz;regout;beginalways@(enorin)out=en?in:’bz;endbufif1b1(out,in,en);写例3:设计一个3线-8线译码器,输出低电平有效2case(in)3’b000:out=8’b11111110;3’b001:out=8’b11111101;3’b010:out=8’b11111011;3’b011:out=8’b11110111;3’b100:out=8’b11101111;3’b101:out=8’b11011111;3’b110:out=8’b10111111;3’b111:out=8’b01111111;default:
out
=8
’bx;
endcasealways@(in)begin
endreg[7:0]out;moduledecoder_38(out,in);output[7:0]out;input[2:0]in;endmodule写总线名称例4:设计一个3线-8线优先编码器,输入高电平有效,输出为原码always@(aorborcordoreorforgorh)begin
if(h)outcode=3’b111;elseif(g)outcode=3’b110;elseif(f)outcode=3’b101;elseif(e)outcode=3’b100;elseif(d)outcode=3’b011;elseif(c)outcode=3’b010;elseif(b)outcode=3’b001;elseif(a)outcode=3’b000;elseoutcode=3’bzzz;end
reg[2:0]outcode;写练习1:采用VerilogHDLcase语句对半加器进行行为描述modulehalfadder(A,B,S,C);inputA,B;outputS,C;regS,C;always@(AorB)begin
case({A,B})2’b00:{C,S}=2’b00;2’b01:{C,S}=2’b01;2’b10:{C,S}=2’b01;2’b11:{C,S}=2’b10;endcaseendendmodule练习2:(作业)设计一个BCD码——七段数码显示译码器例5:说明如下电路的功能modulevoter7(pass,vote);outputpass;input[6:0]vote;integeri;regpass;reg[2:0]sum;
always@(vote)begin
sum=0;
for(i=0;i<=6;i=i+1)if(vote[i])sum=sum+1;
if(sum[2])pass=1;elsepass=0;endendmodule七人投票表决器读组合逻辑电路设计小结1.在VerilogHDL中,描述简单的组合逻辑通常使用assign结构2.一般用always块实现较复杂的组合逻辑电路例1:设计一个同步低电平清零、上升沿触发的D触发器二、时序电路Verilog设计DFFCLKdqqnresetmoduleDFF(q,qn,d,clk,reset);outputq,qn;inputd,clk,reset;regq,qn;always@(posedgeclk)beginif(!reset)beginq<=0;qn<=1;endelsebeginq<=d;qn<=~d;endendendmodule写例2:设计一个下降沿触发的JK触发器regQ;always@(negedgeCLK)begincase({J,K})2’b00:Q<=Q;2’b01:Q<=1’b0;2’b10:Q<=1’b1;2’b11:Q<=~Q;endcaseend写练习1:设计一个上升沿触发的8位数据寄存器modulereg8(out_data,in_data,clk,clr);output[7:0]out_data;input[7:0]in_data;inputclk,clr;reg[7:0]out_data;always@(posedgeclk)beginout_data=in_data;endendmodule
练习2(作业)把上例变成带异步低电平有效清零端的数据寄存器例3:分析如下电路的功能moduleshifter(clk,clr,dout,load,d);input[7:0]d;output[7:0]dout;reg[7:0]dout;regdin;always@(posedgeclk)beginif(clr)dout=8‘b0;
elseif(load)dout=d;elsebegindin=dout[7];
dout=dout<<1;dout[0]=din;endendendmodule读同步清零端同步置数端循环左移寄存器moduleupdown_count(d,clk,clear,load,up_down,qd);input[3:0]d;inputclk,clear,load,up_down;output[3:0]qd;reg[3:0]qd;always@(posedgeclk)beginif(!clear)qd<=4’h00;elseif(load)qd<=d;elseif(up_dwon)qd<=qd+1;elseqd<=qd-1;endendmodule练习1:分析如下电路的功能(作业)时序电路设计小结1.通常使用always@(posedgeclk)或@(negedgeclk)块来描述时序逻辑;2.在always语句里面可以包括:赋值语句,条件语句,循环语句;各种语句之间可以配合使用.三、多层次结构电路设计问题的提出:利用半加器构造全加器例1:问题提出:
输入输出ABCCoutSout0000010100111001011101110010100110010111全加器moduleHA(A,B,S,C); inputA,B; outputS,C; assigns=A^B,C=A&B;endmoduleC=A•BS=A⊕B半加器:由半加器构成全加器:h1h2ABCSoutCout※模块的调用(重点)调用格式:模块名称实例名(信号端口)※信号端口可以通过位置或名称关联;但是关联方式不能够混合使用。位置关联:(端口1,端口2,端口3,….);名称关联:
(.被调用模块端口名称1(端口名称1),.模块端口名称2(端口名称2),.....);1位全加器的编程:moduleFA(A,B,C,Sout,Cout); inputA,B,C; outputSout,Cout;HAh1(A,B,S1,C1); //通过位置相关连
HAh2(.A(S1),.B(C),.S(Sout),.C(C2));//通过名称相关连
orO(Cout,C1,C2);endmodule
h1h2ABCSoutCout练习1:分别说出下面两个模块的作用。
moduletrist(out1,in1,enable1);outputout1;inputin1,enable1;
mytritrist1(out1,in1,enable1);endmodulemodule
mytri(out,in,enable);outputout;inputin,enable;assignout=enable?In:'bz;
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025至2030年中国篱笆修剪机数据监测研究报告
- 福州市老旧社区公共空间的适老性评价研究
- 2025年度智慧医疗系统开发与应用合同4篇
- 二零二五年度新能源汽车充电桩土地租赁合同3篇
- 2025年个人水利工程建设与维护承包合同模板3篇
- 2025年度报刊亭承揽加工安装与绿色出行倡导合同4篇
- 二零二五年度生态农业项目种植与加工承包合同4篇
- 2025年度诚意金协议模板:新能源汽车采购预付款协议4篇
- 2023年-2024年公司项目部负责人安全教育培训试题及答案【易错题】
- 二零二五年IT运维团队绩效考核合同3篇
- 乳腺癌的综合治疗及进展
- 【大学课件】基于BGP协议的IP黑名单分发系统
- 2025年八省联考高考语文试题真题解读及答案详解课件
- 信息安全意识培训课件
- 2024年山东省泰安市初中学业水平生物试题含答案
- 美的MBS精益管理体系
- 中国高血压防治指南(2024年修订版)解读课件
- 2024安全员知识考试题(全优)
- 2024年卫生资格(中初级)-中医外科学主治医师考试近5年真题集锦(频考类试题)带答案
- 中国大百科全书(第二版全32册)08
- 医院出入口安检工作记录表范本
评论
0/150
提交评论