打印

谁能给好好解释下非阻塞赋值和阻塞赋值呢?

[复制链接]
1964|7
手机看帖
扫描二维码
随时随地手机跟帖
沙发
GoldSunMonkey| | 2012-4-12 11:39 | 只看该作者
哥给你解忧~

使用特权

评论回复
板凳
GoldSunMonkey| | 2012-4-12 11:40 | 只看该作者
先说下:组合逻辑中是实时变化的,而时序逻辑中一个cycle才变化一次
比如:
always @(a or b)
begin
    c = a + b;
end
always @(posedge clk)
begin
    if(rst)
      c <= 0;
   else
     c <= a + b;
end
在组合逻辑的always block中,a和b的变化都会引起c值的变化;
而时序逻辑中c至少会维持一个clock cycle,也就是说如果a和b的变化导致c变化的时间是在下一个clock的上升沿,而不会让c立刻改变
---------------------------------------------------------
好,说正题
阻塞赋值“=”与非阻塞赋值“<=”的本质区别在于:
阻塞赋值语句右端表达式计算完后并不立即赋值给左端,而是同时启动下一条语句继续执行,可以将其理解为所有的右端表达式RHS1、RHS2等在进程开始时同时计算,计算完后 ,等进程结束时同时分别赋给左端变量LHS1、LHS2等;
阻塞赋值语句在每个右端表达式计算完后立即赋给左端变量,即赋值语句LHS1=RHS1执行完后LHS1是立即更新的,同时只有LHS1=RHS1执行完后才可执行语句LHS1=RHS2,依次类推。前一条语句的执行结果直接影响到后面语句的执行结果。

使用特权

评论回复
地板
xuehua230|  楼主 | 2012-4-12 11:40 | 只看该作者
猴哥在?谢谢啦。

使用特权

评论回复
5
mr.king| | 2012-4-12 21:53 | 只看该作者
VHDL中如何对应阻塞非阻塞代码?

使用特权

评论回复
6
zaiming| | 2012-4-13 17:10 | 只看该作者
谢谢3楼的解释,学习了。不过有个疑问,在利用VHDL编写时不能用“=”,那阻塞式怎么用呢?

使用特权

评论回复
7
GoldSunMonkey| | 2012-4-13 17:49 | 只看该作者
5# mr.king Verilog 有这个概念。
VHDL没有这个概念。

使用特权

评论回复
8
mr.king| | 2012-4-13 18:43 | 只看该作者
7# GoldSunMonkey
怪不得我写了好多代码都不理解阻塞,早年翻过书,知道有这词,一直与自己写的代码对应不出阻塞概念

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

25

主题

336

帖子

1

粉丝