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

在学习verilog的时候,阻塞赋值与非阻塞赋值一直都是困扰我们的一个难题。

大家通常都会听到一个说法:简单来说就是组合逻辑用阻塞赋值,时序逻辑用非阻塞式赋值。这样的做法一般是不会出错的,尤其在如今数字电路规模越来越大的情况下,遵循这一规则往往是比较好的做法。如果仅仅理解到了这一步,那就是知其然但不知其所以然了。

下面讲一些我个人对于赋值的一些拙见,欢迎大佬们批评指正。

首先,我们先要搞懂阻塞和非阻塞的含义。
阻塞与非阻塞其实是软件中的概念,阻塞是指该条语句或进程是在整个流程中的某一步,必须执行完这一步才能往下执行。而非阻塞也是指该条语句或进程是整个流程中的某一步,但是并不需要执行完这一步才能执行后面的流程,这一步在执行过程中可以“挂起来”,在没有执行完从情况下,就可以先执行后面的流程。
现在,我们回到赋值。
硬件描述语言有两个作用:仿真与综合。

要搞懂阻塞与非阻塞赋值,也需要从这两个方面进行说明。

1、仿真

仿真是软件行为,在讲仿真的时候我们暂时不需要考虑代码与实际生成的电路的关系,而只需要认为我们写的代码是对电路行为的建模。

仿真器在执行代码的时候,实际上是有先后顺序的。比如说在5ns时刻,我们需要同时完成下面两个赋值:

a=b;
c<=a;

这两条语句在我们看来在同一时刻发生的事情,但是仿真器执行必然是有先后顺序的。

在这里,我们需要引入一个时间片(time slot)的概念。一个时间片可以认为是一个时刻,在一个时间片内可以划

  • 2
    点赞
  • 33
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值