欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 健康 > 美食 > Verilog中非阻塞赋值与阻塞赋值

Verilog中非阻塞赋值与阻塞赋值

2024/10/25 0:27:36 来源:https://blog.csdn.net/weixin_38786847/article/details/141877099  浏览:    关键词:Verilog中非阻塞赋值与阻塞赋值

1、阻塞赋值:b=a;

1.1、特点:

一般用于组合逻辑。
这种方式是马上执行,也就是说,执行找下一条语句时,b已经等于a。

1.2、为什么“=”称为阻塞赋值?

在赋值计算时,先计算“=”右手方向(RHS)部分的值,这时赋值语句不允许任何别的Verilog语句的干扰,直到现行的赋值完成时刻。也就是说,把RHS赋值给LHS的时刻,它允许别的赋值语句的执行。
一般可综合的赋值操作在RHS不能设定有延迟。若在RHS上加上延迟,则在延迟期间会阻止赋值语句的执行,延迟后才执行赋值,这种赋值语句是不可综合的。
因此,可以认为:只有一个步骤的操作,即:计算RHS并更新LHS,此时,不允许有来自任何其他Verilog语句的干扰。

2、非阻塞赋值:b<=a;

2.1、特点:

一般用于时序逻辑。
一般“always”模块内的reg型信号都是采用这种赋值方式。
“always”块内的下一条语句执行后,b并不等于a,而是保持原来的值,“always”块执行结束后,才进行赋值。

2.2、为什么“<=”称为非阻塞赋值?

在赋值操作时刻开始时,计算RHS表达式,赋值操作结束时刻结束才更新LHS,在计算RHS和更新LHS期间,其他的Verilog语句,包括其他的verilog非阻塞赋值语句都能同时计算RHS和更新LHS。
允许其他的Verilog语句同时进行操作。
因此,可认为:
(1)在赋值开始时刻,计算非阻塞赋值RHS
(2)在赋值结束时刻,更新非阻塞赋值LHS

3、用非阻塞赋值法确定reg型信号

always@(posedge clk)beginb<=a;c<=b;end

在这里插入图片描述

4、编程要点

(1)时序电路、锁存器电路,用非阻塞赋值;
(2)用always块描述组合逻辑时,用阻塞赋值;
(3)在同一个always块中描述时序和混合电路时,用非阻塞赋值;
(4)不要在同一个always块中同时使用阻塞和非阻塞赋值;
(5)严禁在多个always块中对同一个变量赋值;

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com