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 语句也称为连续赋值, 并且始终处于活动状态。

相关推荐
I'm a winner15 小时前
新手入门Makefile:FPGA项目实战教程(二)
笔记·fpga开发
我爱C编程18 小时前
基于FPGA的8PSK+卷积编码Viterbi译码通信系统,包含帧同步,信道,误码统计,可设置SNR
fpga开发·通信·8psk·帧同步·snr·卷积编码·维特比译码
I'm a winner1 天前
新手入门 Makefile:FPGA 项目实战教程(三)
fpga开发
范纹杉想快点毕业1 天前
嵌入式 C 语言编程规范个人学习笔记,参考华为《C 语言编程规范》
linux·服务器·数据库·笔记·单片机·嵌入式硬件·fpga开发
lazyduck2 天前
从半年到一年的 bug 往事:TCP modbus的卡死与补救
fpga开发·modbus
范纹杉想快点毕业2 天前
《嵌入式 C 语言编码规范与工程实践个人笔记》参考华为C语言规范标准
服务器·c语言·stm32·单片机·华为·fpga开发·51单片机
Chipi Chipi2 天前
FPGA即插即用Verilog驱动系列——串口数据、命令解析
fpga开发
FPGA_ADDA3 天前
基于 AMDXCVU47P HBM2 FPGA 的 2 路 100G 光纤 PCIe 高性能计算加速卡
fpga开发·vu47p·100g光纤pcie·高性能计算加速卡
霖003 天前
高级项目——基于FPGA的串行FIR滤波器
人工智能·经验分享·matlab·fpga开发·信息与通信·信号处理
I'm a winner3 天前
FPGA+护理:跨学科发展的探索(四)
笔记·fpga开发