- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
EDA实验九报告
实验九 任务与函数的使用
一、实验目的
学习和掌握任务与函数的使用方法
二、实验原理
任务(task)
通常用于调试,或对硬件进行行为描述
可以包含时序控制(#延迟,@, wait)
可以有 input,output,和inout参数
可以调用其他任务或函数
函数(function)
通常用于计算,或描述组合逻辑
不能包含任何延迟;函数仿真时间为0
只含有input参数并由函数名返回一个结果
可以调用其他函数,但不能调用任务
三、实验内容
1.分别使用任务和函数描述一个4选1多路选择器。
程序设计:
(1)用任务描述
module mux41a_task(a,b,c,d,s,y);
input a,b,c,d;
input [1:0]s;
output y;
reg y;
task mux41a;
input A,B,C,D;input [1:0]S;output Y;
begin
if(S==2b00) Y=A;
else if(S==2b01) Y=B;
else if(S==2b10) Y=C;
else Y=D;
end
endtask
always @(*)begin
mux41a(a,b,c,d,s,y);
end
endmodule
图9-1 mux41a_task的仿真波形图
图9-2 mux41a_task的RTL图
实验分析:
该程序主要运用任务语句,task和endtask之间为任务的定义,定义之后直接调用任务语句就可以。图9-1为该程序的仿真波形图,从图中可以看出:当a,b,c,d四个输入口分别输入不同的频率信号时,针对选通控制端的s的不同值将有对应的信号输出。例如当s=00时,y口输出来自a端的时钟信号,s=11时,y口输出来自d端的时钟信号,由此可知该程序可实现预定功能。该程序的RTL图如图9-2所示。
(2)用函数描述
程序设计:
module mux41a_function(a,b,c,d,s,y);
input a,b,c,d;
input [1:0]s;
output y;
function mux41a;
input A,B,C,D;input [1:0]S;
begin
if(S==2b00) mux41a=A;
else if(S==2b01) mux41a=B;
else if(S==2b10) mux41a=C;
else mux41a=D;
end
endfunction
assign y=mux41a(a,b,c,d,s);
endmodule
图9-3 mux41a_function的仿真波形图
图9-4 mux41a_function的RTL图
实验分析:
该程序主要运用函数语句,function和endfunction之间为函数的定义,通过将函数作为表达式中的操作数来实现函数的调用。图9-3为该程序的仿真波形图,从图中可以看出当a,b,c,d四个输入口分别输入不同的频率信号时,针对选通控制端的s的不同值将有对应的信号输出。例如当s=01时,y口输出来自b端的时钟信号,s=11时,y口输出来自d端的时钟信号,由此可知该程序可实现预定功能。该程序的RTL图如图9-4所示。
2.上网查询移位相加乘法器的设计方法,使用任务和循环语句设计一个8位移位相加的乘法器。
程序设计:
module mul(a,b,y);
input [7:0]a,b;
output [15:0]y;
reg [15:0]y;
task mult;
input [7:0]A,B;output [15:0]Y;
reg [15:0]C,D;
integer i;
begin
C=A;D=B;
Y=D[0]?C:0;
for(i=1;i=7;i=i+1)begin
if(D[i]) Y=Y+(Ci);end
end
endtask
always @(*)begin
mult(a,b,y);
end
endmodule
图9-5 8位移位相加乘法器的仿真波形图
图9-6 8位移位相加乘法器的RTL图
实验分析:
该实验程序主要运用一个任务语句和一个循环语句实现,而且是在任务语句mult当中嵌入循环语句,运用移位相加的原理实现乘法的功能。最后在过程语句always当中调用任务语句使结果输出。该程序的仿真波形图如图9-5所示,从图中可以看出当ab,当a*b=0620H;ab,a*b=0D4DH;当ab,a*b=04
文档评论(0)