2849|3

112

帖子

0

TA的资源

一粒金砂(高级)

楼主
 

阻塞与非阻塞 [复制链接]

always @(a or b or c)

begin

    x=c+y;//语句1

    y=a+b;//语句2

end   

y原来的值是5;

a=1;

b=1;

c=3;

我仿真的结果是 x=5+3=8    y=1+1=2

资料上的解释是说 语句1和语句2同时进行,但是由于是阻塞赋值,所以要等语句1执行完了之后才能执行第二条语句,所以语句1中的值是原来的值;

与我自己的仿真结果一致;

 

always @(a or b or c)

begin

x<=c+y;

y<=a+b;

end

y原来的值是5;

a=1;

b=1;

c=3;

仿真的结果是 x=8 y=2;

我看的资料上说 在此时刻 x=3+2=5   y=1+1=2 他的意思是说 a+b 的值给 y ;然后 y+c的值再给x;

仿真的结果和 资料上说的不一样

求指教!!!!

此帖出自FPGA/CPLD论坛

最新回复

always块中语句是顺序执行的,也就是说第一个例子中先执行语句1,再执行语句2,结果就是x=5+3=8    y=1+1=2 ;第二个例子中用到非阻塞语句,它的原理是同时所有赋值语句右边进行计算,结果存到虚拟寄存器中,在语句结束时同时对左边赋值,有点类似并行执行,这样语句1和语句2先同时计算右边分别为8和2,然后赋值给x和y,。还有就是非阻塞赋值语句用于计算的值都是上一次的值,不会立即使用本次更新的值,也就是说x  详情 回复 发表于 2011-11-5 11:01
点赞 关注
个人签名无一事而不学,无一时而不学
 

回复
举报

452

帖子

0

TA的资源

五彩晶圆(初级)

沙发
 
后面那个工具默认优化的吧,要不我认为会有竞争和冒险的风险,看下RTL电路图就知道了,这个纯个人看法,因为没有这样写过........
此帖出自FPGA/CPLD论坛
个人签名人生苦短,何必为声名所累,放开自己心态,去追求自己想要的梦想去吧!http://pytech-inc.taobao.com/
 
 

回复

10

帖子

0

TA的资源

一粒金砂(中级)

板凳
 

我怎么觉得是对的呢

always @(a or b or c)
begin
x<=c+y;
y<=a+b;
end
y原来的值是5;
a=1;
b=1;
c=3;
仿真的结果是 x=8 y=2;

我们老师说,这是非阻塞赋值,就是这个结果呀!两条语句同时执行
此帖出自FPGA/CPLD论坛
 
 
 

回复

329

帖子

27

TA的资源

纯净的硅(初级)

4
 
always块中语句是顺序执行的,也就是说第一个例子中先执行语句1,再执行语句2,结果就是x=5+3=8    y=1+1=2 ;第二个例子中用到非阻塞语句,它的原理是同时所有赋值语句右边进行计算,结果存到虚拟寄存器中,在语句结束时同时对左边赋值,有点类似并行执行,这样语句1和语句2先同时计算右边分别为8和2,然后赋值给x和y,。还有就是非阻塞赋值语句用于计算的值都是上一次的值,不会立即使用本次更新的值,也就是说x<=c+y里的y不可能是新值2,而应该是旧值5。祝学习愉快
此帖出自FPGA/CPLD论坛
 
 
 

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

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/10 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表