寄存器(reg)
寄存器(reg)用来表示存储单元,它会保持数据原有的值,直到被改写。声明举例如下:
实例
reg clk_temp;
reg flag1, flag2 ;
例如在 always 块中,寄存器可能被综合成边沿触发器,在组合逻辑中可能被综合成 wire 型变量。寄存器不需要驱动源,也不一定需要时钟信号。在仿真时,寄存器的值可在任意时刻通过赋值操作进行改写。例如:
实例
reg rstn ;
initial begin
rstn = 1'b0 ;
#100 ;
rstn = 1'b1 ;
end
向量
当位宽大于 1 时,wire 或 reg 即可声明为向量的形式。例如:
实例
reg [3:0] counter ; //声明4bit位宽的寄存器counter
wire [32-1:0] gpio_data; //声明32bit位宽的线型变量gpio_data
wire [8:2] addr ; //声明7bit位宽的线型变量addr,位宽范围为8:2
reg [0:31] data ; //声明32bit位宽的寄存器

本文详细介绍了Verilog中的寄存器(reg)类型,包括其在组合逻辑和时序逻辑中的应用,以及如何声明和使用向量、整数、实数和时间类型的寄存器变量。寄存器可以保持数据值直至被改写,且在仿真时可随时改写。文中通过实例展示了不同类型的寄存器变量声明和操作,如向量的位域选择、数据拼接以及整数、实数和时间的使用方法。
最低0.47元/天 解锁文章
3803

被折叠的 条评论
为什么被折叠?



