【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
          └─────────────┴─────────────┘
相关推荐
minglie12 小时前
正点原子zynq的RGB彩条实验
fpga开发
FPGA-ADDA3 小时前
第六篇:多速率信号处理——抽取、插值与半带滤波器
fpga开发·信号处理·软件无线电·rfsoc·47dr
ALINX技术博客3 小时前
【黑金云课堂】VMware Ubuntu 开发环境安装教程
linux·fpga开发·fpga
LCMICRO-133108477463 小时前
国产长芯微LDC4048完全P2P替代DAC128S085,是一款 8 通道、带输出放大器的数模转换器 (DAC)
stm32·单片机·嵌入式硬件·fpga开发·硬件工程·数模转换器dac
雅斯驰3 小时前
逐周期限流+频率折返+热关断:TPS54360DDAR的全套保护机制解析
fpga开发
雅斯驰3 小时前
电流模式控制+快速瞬态响应:LTM4650AY的FPGA供电技术解析
stm32·单片机·嵌入式硬件·物联网·fpga开发·汽车
北京青翼科技17 小时前
青翼科技PCIe总线架构的2路10G光纤通道适配器丨数据采集卡丨PCIe接口板卡 2 路 SFP+光纤收发器
fpga开发·采集卡·fpga板卡·pcie接口·多功能板卡
9527华安19 小时前
2026年FPGA就业培训,临时抱佛脚版本
fpga开发
水云桐程序员19 小时前
Quartus II集成开发环境 |FPGA
笔记·fpga开发·硬件工程·创业创新