OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 7671|回复: 3

求助Verilog函数的用法

[复制链接]

14

主题

338

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
464
金钱
464
注册时间
2013-6-15
在线时间
15 小时
发表于 2013-6-28 11:33:55 | 显示全部楼层 |阅读模式

 Verilog用函数方式描述一个4选1选择器,function里的过程语句该怎么写啊我这么写报错:functions can't contain non-blocking assignments

module MUX4(a,b,c,d,s0,s1,y);
input s0,s1;
input a,b,c,d;
output y;
reg y;
function MUX;
input s0,s1;input a,b,c,d;
begin
 if(s0==0&&s1==0) MUX<=a;
 if(s0==0&&s1==1) MUX<=b;
 if(s0==1&&s1==0) MUX<=c;
 if(s0==1&&s1==0) MUX<=d;
end
endfunction
always@(a,b,c,d,s0,s1,y) begin
y=MUX(a,b,c,d,s0,s1);
end
endmodule


 

正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

557

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165001
金钱
165001
注册时间
2010-12-1
在线时间
2102 小时
发表于 2013-6-28 15:03:33 | 显示全部楼层
回复 支持 反对

使用道具 举报

0

主题

4

帖子

0

精华

新手上路

积分
36
金钱
36
注册时间
2012-6-5
在线时间
2 小时
发表于 2013-7-2 15:46:23 | 显示全部楼层
function里面不要用"<="非阻塞赋值,只能用"="阻塞赋值,至于其中的差别参考教材上的介绍,基本上都会写
回复 支持 反对

使用道具 举报

14

主题

338

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
464
金钱
464
注册时间
2013-6-15
在线时间
15 小时
 楼主| 发表于 2013-7-2 17:19:12 | 显示全部楼层
回复【3楼】ringcoolh:
---------------------------------
原来如此!
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2024-6-25 14:44

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表