verlog中阻塞赋值和非阻塞赋值

初始值:

a=1 b=6 c=9

复制代码
always @(posedge clk) begin
  a = b+1;      // 阻塞赋值
  b <= a;       // 非阻塞赋值
  c = a;        
end  

得到的结果是:

a=7 b=1 c=7


核心逻辑:阻塞赋值(=)立即更新左值,非阻塞赋值(<=)仅记录意图、过程块结束后统一更新,且非阻塞赋值的右值采样于「过程块起始时刻的旧值」。

  1. 初始状态 :时钟沿触发前,a=1、b=6、c=9(均为 reg 类型);
  2. 执行 a = b+1;(阻塞赋值) :立即用 b 的当前值(初始值 6)计算,6+1=7a 实时更新为 7 → 此时状态:a=7、b=6、c=9
  3. 执行 b <= a;(非阻塞赋值) :采样「过程块起始时 a 的旧值(1)」,记录赋值意图「b=1」,不立即更新 b → 此时状态不变:a=7、b=6、c=9
  4. 执行 c = a;(阻塞赋值) :立即用 a 的实时值(7)更新 cc=7,此时状态:a=7、b=6、c=7
  5. 过程块结束,非阻塞赋值生效 :记录的「b=1」生效,b 最终更新为 1。

非阻塞赋值的右值,永远采样于「整个 always 块刚开始执行时的变量旧值」,与该语句在块中的位置、块内其他语句是否修改了右值变量,都没有关系。

FR:徐海涛(hunkxu)

相关推荐
传感器与混合集成电路10 小时前
1/16砖电源模块使能逻辑解析与上电时序设计
fpga开发
FPGA_小田老师15 小时前
ZYNQ7020笔记:MIO、EMIO、GPIO的区别及应用
fpga开发·gpio·zynq·外设·mio·emio
不会武功的火柴16 小时前
SystemVerilog语法(7)-接口(interface)
嵌入式硬件·fpga开发·仿真·ic验证·rtl
高速上的乌龟16 小时前
Lattice LFCPNX-100 Fpga开发+源码:基于I2c协议的IMU驱动控制
fpga开发
GateWorld17 小时前
LCD显示技术完全指南:原理·制造·驱动·FPGA实现之基础三
fpga开发·lcd显示·minilvds·fpga点屏
cjie22117 小时前
图像缩放因子的计算
计算机视觉·fpga开发
XINVRY-FPGA1 天前
XC7Z010-2CLG400I Xilinx Zynq-7000 FPGA
arm开发·嵌入式硬件·算法·fpga开发·硬件工程·dsp开发·fpga
XINVRY-FPGA1 天前
XCZU11EG-2FFVC1156I Xilinx Zynq UltraScale+ MPSoC EG FPGA
图像处理·嵌入式硬件·计算机视觉·fpga开发·硬件工程·dsp开发·fpga
unicrom_深圳市由你创科技2 天前
USB通信在FPGA上怎么实现?
fpga开发
GateWorld2 天前
LCD显示技术完全指南:原理·制造·驱动·FPGA实现之基础二
fpga开发·lcd显示·minilvds·fpga点屏