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)

相关推荐
坏孩子的诺亚方舟15 天前
FPGA系统架构设计实践15_高云Arora V系列时钟体系
fpga开发·系统架构
FPGA小徐16 天前
入门 CNN 结构全解析|从流程图理论到 FPGA Verilog 硬件实现(含习题带讲解)
fpga开发
FPGA小徐16 天前
FPGA 数字信号处理:并行 FIR 与串行滤波器设计原理、对比与完整 Verilog 实现
fpga开发
Saniffer_SH16 天前
【高清视频】Gen6 服务器还没到,Gen6 SSD 怎么测?Emily 现场演示三种测试环境
人工智能·驱动开发·测试工具·缓存·fpga开发·计算机外设·压力测试
zlinear数据采集卡17 天前
双核架构深度解析:ARM+FPGA如何让数据采集卡实现500Ksps高性能?
arm开发·fpga开发·架构
9527华安17 天前
FPGA实现GTH Transceivers Wizard传输2路视频,基于aurora 8b10b编解码架构,提供4套工程源码和技术支持
fpga开发·gth·aurora 8b10b·transceivers
FPGA小徐18 天前
FPGA 数字信号处理(二):并行 FIR 滤波器的 Verilog 全流程设计与实现
fpga开发
国科安芯18 天前
基于AS32S601ZIT2型抗辐照MCU的商业航天卫星姿态确定与控制系统研究
单片机·嵌入式硬件·安全·fpga开发·架构·risc-v
ALINX技术博客18 天前
【黑金云课堂】FPGA技术教程FPGA基础:I2C 总线通信技术
fpga开发·i2c
Hello-FPGA18 天前
Xilinx KU040 FPGA Camera Link 图像采集
c++·fpga开发