verilog HDL中reg和wire类型的区别

问题:verilog HDL中reg和wire类型的区别

回答:

1.基本概念的区别

①wire型数据常用来表示以assign关键字指定的组合逻辑信号,模块的输入输出端口类型都默认为wire型,wire相当于物理连线,默认初始值是z。

②reg型表示的寄存器类型,用于always模块内被赋值的信号,必须定义为reg型,代表触发器,常用于时序逻辑电路,reg相当于存储单元,默认初始值是x。

 
2.在赋值语句中的区别

①在连续赋值语句中,表达式右侧的计算结果可以立即更新表达式的左侧。在理解上,相当于一个逻辑之后直接连了一条线,这个逻辑对应于表达式的右侧,而这条线就对应于wire。

②在过程赋值语句中,表达式右侧的计算结果在某种条件的触发下放到一个变量当中,而这个变量可以声明成reg类型。根据触发条件的不同,过程赋值语句可以建模不同的硬件结构:如果这个条件是时钟的上升沿或下降沿,那么这个硬件模型就是一个触发器;如果这个条件是某一信号的高电平或低电平,那么这个硬件模型就是一个锁存器;如果这个条件是赋值语句右侧任意操作数的变化,那么这个硬件模型就是一个组合逻辑。

wire只能被assign连续赋值,reg只能在initial和always中赋值

3.端口信号和内部信号的区别


信号可以分为端口信号和内部信号。

出现在端口列表中的信号是端口信号,其它的信号为内部信号。

①对于端口信号,一旦定义位input或者output端口,默认就定义成了wire类型,输入端口只能是net类型(wire/tri)。输出端口可以是net类型,也可以是reg类型。若输出端口在过程块中赋值则为register类型;若在过程块外赋值(包括实例化语句),则为net类型。

②内部信号类型与输出端口相同,可以是net或reg类型。判断方法也与输出端口相同。若在过程块中赋值,则为reg类型;若在过程块外如assign赋值,则为net类型。

③若信号既需要在过程块中赋值,又需要在过程块外赋值。这种情况是有可能出现的,如决断信号。这时需要一个中间信号转换。inout是一个双向端口, inout端口不能声明为reg类型,只能是wire类型。

//1、输入端口定义,默认定义为wire类型,省略声明为wire A1,A2,A3;
	input A1;  
	input A2;
	input A3;
	input [1:0]A4;
	input A5;
	input CLK;
	
	
	//2、输出端口定义,默认定义为wire类型,省略声明为wire E1,E2,E3;
	output E1;
	output E2;
	output E3;
	output [9:0]E4;
	output reg E5;
	reg E2;
	reg E3;
	reg [9:0]E4;
	
	//内部信号:过程块中赋值,则为reg类型;若在过程块外如assign赋值,则为net类型。
	reg [9:0]in_var1;
	reg [5:0]in_var2;
	reg [3:0]cc;


 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值