Verilog 的层次化事件队列+阻塞赋值与非阻塞赋值理解

       在IEEE1364—1995 Verilog标准的5.3节定义了层次化的事件队列在逻辑上分为用于当前仿真时间的4个不同的队列,用于下一段仿真时间的若干附加队列。

(1)动态事件队列(下列事件执行的顺序随机安排)

① 阻塞赋值;

② 计算阻塞赋值右边的表达式;

③ 连续赋值(对wire型变量用assign赋值);

④ 执行$display命令;

⑤ 计算原语的输入与输出变化。

(2)停止运行的时间队列: #0 延时阻塞赋值。

(3)非阻塞事件队列:更新非阻塞赋值语句LHS(<=左边的变量)的值。

(4)监控事件队列:

① 执行$monitor命令;

② 执行$strobe命令。

(5)其他指定的PLI命令队列:其他PLI命令。

下面用一张图来表示:

 动态事件就是活跃事件,它们的优先级最高,在当前的仿真时间中,活跃事件最先被执行。

上图可以看出,阻塞赋值是活跃事件,当前仿真时间中它最先被执行,阻塞赋值执行完RHS(右式计算&

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值