verilog中wire和reg类型的区别
一、基本概念
wire
型数据常用来表示以assign
关键字指定的组合逻辑信号,模块的输入输出端口类型都默认为wire
型,wire
相当于物理连线,默认初始值是z
。
reg
型表示的寄存器类型,用于always
模块内被赋值的信号,且必须定义为reg
型,代表触发器,常用于时序逻辑电路,reg
相当于存储单元,默认初始值是x
。
二、深入理解
1、从仿真角度来说,HDL语言面对的是编译器,相当于使用软件思路,此时:
-
wire对应于连续赋值,如assign;
-
reg对应于过程赋值,如always,initial;
2、从综合角度来看,HDL语言面对的是综合器,相当于从电路角度来思考,此时:
-
wire型变量综合出来一般情况下是一根导线;
-
reg变量在always中有两种情况:
1)always @(a or b or c)
形式的,即不带时钟边沿的,综合出来还是组合逻辑;
2)always @(posedge clk)
形式的,即带有边沿的,综合出来一般是时序逻辑,会包含触发器(Flip-Flop
)
3、reg
型数据保持最后一次的赋值,而wire
型数据需要持续的驱动。
- 在连续赋值语句
assign
中,表达式右侧的计算结果可以立即更新到表达式的左侧,可以理解为逻辑之后直接连接了一条线,这个逻辑对应于表达式的右侧,这条线对应于wire
; - 在过程赋值语句中,表达式右侧的计算结果在某种条件的触发下放到一个变量当中,这个变量可以声明成
reg
型。
三、区别总结
1、使用场景区别:
wire
一般是用在组合逻辑中,reg
用在时序逻辑中。但是在always
中,变量必须定义成reg
型,即使always
块也可以实现组合逻辑。那么这里刚好说明一下,其实always
块不止能实现时序逻辑,还能实现组合逻辑:
(1)如果这个条件是时钟上升沿或下降沿,那硬件模型就是一个触发器,只有是指定了always@(posedge or negedge)
才是触发器。
(2)如果这个条件是某一信号的高低电平,那这个硬件模型就是一个锁存器。
(3) 如果这个条件是赋值语句右侧任意操作数的变化,那这个硬件模型就是一个组合逻辑。wire
用于连续赋值assign
语句中;reg
用于过程赋值always,initial
语句中;
2、在端口信号和内部信号上的使用区别
信号可以分为端口信号和内部信号。出现在端口列表中的信号是端口信号,其它的信号为内部信号。
-
对于端口信号,一旦定义为
input
或者output
端口,默认就定义成了wire类型,输入端口只能是net类型(wire/tri)。输出端口可以是net类型,也可以是reg类型。若输出端口在过程块中赋值则为reg类型;若在过程块外赋值(包括实例化语句),则为net类型。 -
内部信号类型与输出端口相同,可以是net或reg类型。判断方法也与输出端口相同。若在过程块中赋值,则为reg类型;若在过程块外如assign赋值,则为net类型。
-
inout
是一个双向端口, 不能声明为reg类型,只能是wire类型。