Always语句和assign的用法

Always语句

简介

always语句块从仿真0时刻开始执行其中的行为语句;最后一条执行完成后,再开始执行其中的第一条语句,如此往复循环,直到整个仿真结束。因此,always语句块常用于对数字电路中一组反复执行的活动进行建模。

应用场景

always块是Verilog中用来描述组合逻辑以及时序逻辑的语法。

在这上面的语法小节中也说过了。

需要补充的是一个设计中可以有多个always块,或者说一定有很多个always块。

这些硬件块都是相互独立同时工作的。每个块之间的连接是决定数据流的原因。为了模拟这种行为,一个always块被做成一个连续的过程(硬件不可能断断续续工作),当敏感列表中的一个信号变化时,它就会被触发并执行一些动作(always块内的语句)

语法简介

always 和 always@(*) 的区别

有@时,是每次执行语句时,必须满足括号内的条件才能继续执行语句,否则不执行。

always@(敏感事件列表) 用于描述时序逻辑;

敏感事件(上升沿 posedge、下降沿 negedge);always @ (posedge clk)

或电平。Always@(a)

verilog规定,always@()中的是指该always块内的所有输入信号的变化为敏感列表,也就是仿真时只有当always@(*)块内的输入信号产生变化,该块内描述的信号才会产生变化。

若没有@,则是一般在testbench 中产生时钟信号,指不会满足特定的条件,执行完一次后立马继续执行下一次,一直重复执行。always #5 CLK=~CLK;

有@时,是每次执行语句时,必须满足括号内的条件才能继续执行语句,否则不执行

always@()语句的意思是always模块中的任何一个输入信号或电平发生变化时,

该语句下方的模块将被执行。

1、always语句有两种触发方式。第一种是电平触发,例如always @(a or b or c),a、b、c均为变量,当其中一个发生变化时,下方的语句将被执行。

2、第二种是沿触发,例如always @(posedge clk or negedge rstn),即当时钟处在上升沿或下降沿时,语句被执行。

3、而对于always@(),意思是以上两种触发方式都包含在内,任意一种发生变化都会触发该语句。

敏感列表: 触发always块内部语句的条件。

只有一条语句,不需要使用begin -end;第二种是有多条语法,需要使用begin end包裹起来。推荐全部都用begin end包裹起来,这样形式比较固定,比较方面阅读以及形成固定风格。

Assigin语句

简介:

assign相当于一条连线,将表达式右边的电路直接通过wire(线)连接到左边,左边信号必须是wire型。当右边变化了左边立马变化,方便用来描述简单的组合逻辑

应用场景:

wire类型或类似于wire数据类型的信号需要连续赋值。类比用于连接面包板上零件的电线。只要+5V电池施加在导线的一端,连接到导线另一端的部件就会获得所需的电压。

在Verilog中,这个概念是通过assign语句实现的,其中任何或其他类似的wire数据类型都可以用一个值连续驱动。该值可以是常数,也可以是由一组信号组成的表达式。

使用规则:

LHS(左值) 应该始终是wire类型的标量或向量网络, 或者标量或矢量网络的串联, 而绝对不能是reg类型的标量或矢量寄存器。(这是扩展一个知识点:

Reg与wire的区别,wire用于连续赋值语句,而reg用于过程赋值语句,reg会保持上一次赋值,而wire在持续不断的改变,在电路理解上来说,wire相当于一根导线,而reg,则相当于在wire中间加了一个寄存器,有条件的赋值,这就需要根据敏感信号来判定)

RHS 可以包含标量或向量寄存器以及函数调用。

只要 RHS 上的任何操作数的值发生变化, LHS 就会使用新值进行更新。

assign 语句也称为连续赋值, 并且始终处于活动状态。

相关推荐
步达硬件9 小时前
【FPGA】DP、HDMI、USB4、GPMI、eDP、LVDS等音视频协议及性能对比
fpga开发
-木槿昔年-1 天前
【米尔-安路MYD-YM90X创意秀】飞龙派学习和PS串口实践
学习·fpga开发
Aaron15881 天前
基于RFSOC+VU13P+GPU架构在雷达电子战的技术
人工智能·算法·fpga开发·架构·硬件工程·信号处理·基带工程
jifengzhiling1 天前
伺服驱动器中DSP与FPGA高效协同架构解析
fpga开发·foc电机控制
太爱学习了1 天前
FPGA图像处理之:图像畸变矫正原理及matlab与fpga实现
图像处理·matlab·fpga开发
技术性摸鱼2 天前
FPGA选型参数
fpga开发
FPGA_小田老师2 天前
ibert 7 Series GT:IBERT远近端(内外)环回测试
fpga开发·ibert·gt测试·近端pcs环回·近端pma环回·远端pcs环回·远端pma环回
尤老师FPGA2 天前
【无标题】
fpga开发
175063319452 天前
VIVADO VLA VIO 硬件调试 降采样
fpga开发
FPGA小迷弟2 天前
基于FPGA开发高速ADC/DAC芯片笔记
图像处理·fpga开发·数据采集·fpga·adc