【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
          └─────────────┴─────────────┘
相关推荐
尤老师FPGA3 小时前
HDMI数据的接收发送实验(十)
fpga开发
逻辑诗篇4 小时前
破核拆解:PCIE719——基于Xilinx Zynq UltraScale+的高性能SAS扩展卡设计
fpga开发·架构
逻辑诗篇9 小时前
高性能存储扩展利器|PCIE719 基于Zynq UltraScale+的企业级可编程SAS方案
fpga开发
liuluyang53011 小时前
SV主要关键词详解
fpga开发·uvm·sv
happyDogg_13 小时前
验证环境采样rtl时序数据遇到的问题
fpga开发
unicrom_深圳市由你创科技15 小时前
项目分析和FPGA器件选型外包服务包括哪些内容?别让选错芯片毁了整个项目
fpga开发
Aaron158815 小时前
27DR/47DR/67DR技术对比及应用分析
人工智能·算法·fpga开发·硬件架构·硬件工程·信息与通信·基带工程
my_daling16 小时前
DSMC通信协议理解,以及如何在FPGA上实现DSMC从设备(2)
学习·fpga开发
珞光电子USRP SDR软件无线电平台1 天前
打破通用瓶颈:珞光电子发布 Luowave Driver V2 定制化驱动方案
fpga开发
9527华安1 天前
FPGA实现PCIe数据通信培训课程,提供工程源码+视频教程+FPGA开发板
fpga开发·pcie·视频教程·培训