【Verilog】阻塞/非阻塞赋值

目录

阻塞赋值

非阻塞赋值

Verilog模块编码的8个原则


阻塞赋值

阻塞赋值使用的赋值运算符为"="

阻塞赋值的过程是立刻执行的,即阻塞赋值运算符右侧表达式求值完后立刻会更新至运算符左侧,并且这个执行的过程不受其他语句执行的影响,其后的语句只有当前的赋值操作执行完成后才能顺利执行

非阻塞赋值

非阻塞赋值使用的赋值运算符为"<="

非阻塞赋值执行过程为:当当前仿真时间槽(time-slot)开始分析计算获得右侧表达式的值,在当前时间槽执行结束时更新左侧表达式的值,在右侧表达式分析计算和左侧表达式被更新之前,任何其他事件都可以执行,同时也有可能修改已经计算完成的右侧表达式的值,即非阻塞赋值的过程不影响其他语句的执行

根据非阻塞赋值的特点,其赋值运算符左侧操作数只能作为寄存器类型,因此非阻塞赋值只能用于过程语句中(initial和always),不允许在连续赋值语句中使用非阻塞赋值

所谓阻塞的概念是指在同一个always块中,其后面的赋值语句从概念上是前一条赋值语句结束后开始赋值的

Verilog模块编码的8个原则

  • 时序电路建模时,用非阻塞赋值
  • 锁存器电路建模时,用非阻塞赋值
  • 用always块建立组合逻辑模型时,用阻塞赋值
  • 在同一个always块中建立时序和组合逻辑电路时,用非阻塞赋值
  • 在同一个always块中不要既用非阻塞赋值又用阻塞赋值
  • 不要在一个以上的always块中为同一个变量赋值
  • 用$strobe系统任务来显示用非阻塞赋值的变量值
  • 在赋值时不要使用#0延时

下面两段代码中in、q1、q2和q3的初值分别为0、1、2、3,那么经历1个时钟周期后,左侧q3的值和右侧q3的值分别变成了()

always@(posedge clk)begin

q1=in;

q2=q1;

q3=q2;

end

always@(posedge clk)begin

q1<=in;

q2<=q1;

q3<=q2;

end

A. 0、0

B. 0、3

C. 2、0

D. 0、2

D
"="是阻塞赋值,当 clk 的上升沿到来时,in 的值赋给 q1,然后 q1 的值赋给 q2,然
后 q2 的值赋给 q3。最终结果 q3 等于 in 的值,为 0。"<="是非阻塞赋值,当 clk 的上升沿
到来时,in 的值赋给 q1,同时 q1 的值赋给 q2,同时 q2 的值赋给 q3。最终结果 q3 等于 q2
的值,为 2

复制代码
       ┌─────┐
 in ──►│  D  │──► q1
       │  Q  │──► q2
       │     │──► q3
       └──▲──┘
          │ clk

       ┌─────┐      ┌─────┐      ┌─────┐
 in ──►│ D Q │──►──►│ D Q │──►──►│ D Q │──► q3
       │     │ q1   │     │ q2   │     │
       └──▲──┘      └──▲──┘      └──▲──┘
          │ clk         │ clk         │ clk
          └─────────────┴─────────────┘
相关推荐
尤老师FPGA1 小时前
HDMI数据的接收发送实验(十四)
fpga开发
Szime11 小时前
全球首创10位40GSPS超宽带ADC选型参考:国产超高速ADC深智微科技选型支持
科技·单片机·嵌入式硬件·fpga开发
Szime16 小时前
AD9653、AD9253、AD9694国产替代怎么评估?深智微科技整理ADI高速ADC选型思路
科技·fpga开发
FPGA小徐16 小时前
Xilinx zynq-7000系列FPGA移植Linux操作系统详细教程
fpga开发·架构
Zebros19 小时前
LC无线无源传感器读取方案设计研究综述
fpga开发·信息与通信·射频工程
国科安芯20 小时前
商业航天通信载荷数字处理单元供电架构研究——基于ASP7A84AS的高精度低压差线性稳压器技术分析
前端·单片机·嵌入式硬件·fpga开发·架构·安全性测试
Szime21 小时前
AD9653 国产替代怎么选?四通道 16 位 125MSPS ADC 选型参考
嵌入式硬件·fpga开发
cjie2211 天前
常用视频缩放架构
fpga开发·架构
尤老师FPGA1 天前
LVDS系列51:Xilinx Ultrascale系 ADC LVDS接口参考方法(十三)
fpga开发
Eloudy1 天前
NVIDIA Holoscan Sensor Bridge 简介
fpga开发·量子计算