![]() |
|
||||||||||||||
| . 网站首页 . 新闻 . 新品 . 方案 . 专访 . 活动 . DSP . EDA . 评测室 . 技术文库 . 会员区 . 商城 . 服务导航 . 邮购 . 资源 . | ||
|
||
|
|||||
| 阻塞赋值、非阻塞赋值的差异 | |||||
作者:Free 文章来源:Free 点击数: 更新时间:2008-1-4 ![]() |
|||||
|
Tip:所谓过程性赋值就是指在initial或always语句内的赋值,它只能对寄存器数据类型的变量赋值。 阻塞式 (blocking) 的操作符为 “ = ” 非阻塞式(non-blocking) 的操作符为 “ <= ” 首先,我们通过两个例子来看看这两种赋值方式的区别,这里使用的综合工具为Qt ii。 例1:非阻塞式赋值 module test_non_blocking ( input clk, input testa, input testb, input testc, input testd, output reg testout ); reg testreg; always @ (posedge clk) begin testreg <= testb | testc; begin if (testa) begin testout <= testreg & testd; end else begin testout <= testd; end end end endmodule 例1综合后的结果为
例2:阻塞式赋值 module test_blocking ( input clk, input testa, input testb, input testc, input testd, output reg testout ); reg testreg; always @ (testa,testb.testc,testd) begin testreg = testb | testc; begin if (testa) begin testout = testreg & testd; end else begin testout = testd; end end end endmodule 例2综合后的结果为: 分析: 可以看到,例1和例2的code写法完全一样,只是在always语句块中使用了不同的赋值方式,就导致综合出来的结果不同。 在例1中,是非阻塞式赋值方式,非阻塞式赋值的赋值对象总是在当前仿真时刻结束时被赋值,所以,当在对语句2中的testout赋值这一时刻, testreg 值还没有得到语句1中的新值,而是原来的值(即上一个时刻的值)。 而在例2中,使用了阻塞式赋值方式,就是在always语句块中是一句一句执行的。在执行语句2之前,语句1就已经执行完成,testreg被赋好了新值,所以语句2中的testreg值取的是新值。 建议: 1. 阻塞式赋值用于组合逻辑建模; 2. 非阻塞式赋值用于时序逻辑建模。 |
|||||
| 欢迎点击进入:TI德州中文网 (国内唯一针对TI应用的中文技术网站) 文章录入:admin 责任编辑:admin | |||||
| 【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口】 | |||||
| 最新热点 | 最新推荐 | 相关文章 | ||
| 没有相关文章 |
| 网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!) |
| | 设为首页 | 加入收藏 | 联系站长 | 友情链接 | 版权申明 | 网站公告 | 管理登录 | | |||
|
|