verilog中wire和reg的用法区别

看到一个文档,很详细的讲了wire和reg的区别,随便记录一下

wire(组合逻辑)

wire在verilog设计中表示简单的线,规则如下:
1.在设计中wire用于将例化模块的input、output端口和其他元素连接
2.在声明模块时wire可以做input和output
3.wire只能被驱动,不能存储值
4.在always@块中wire不能在=或<=的左边
5.assign只允许wire型变量在=左边
6.wire elements are a stateless way of connecting two peices in a Verilog-based design(不太懂意思)

无状态对象(Stateless Bean),就是没有实例变量的对象,不能保存数据,是不变类。

7.wire只能用来建模组合逻辑

reg(组合和时序逻辑)

reg与wires相似,但是可以用来像寄存器一样存储信息,规则:
1.reg可以用来连接例化模块的input
2.reg不能连接例化模块的output
3.reg可以用作模块声明的output
4.reg不能用作模块声明的input
5.reg是唯一可以在always@块中放在<=或=左边的类型
6.reg是唯一可以在initial块中放在=左边的类型
7.reg不能放在assign语句中的=左边
8.在always@(posedge clk)中可以综合为寄存器
9.reg可以创造时序和组合逻辑

可以相互替代的情况

1.都可以放在assign = 的右边和always@ <= 或 = 的右边
2.都能作为例化模块的input

不少人都认为verilog中区分wire和reg是有一定历史包袱和缺陷的,不然sv中为啥要再设计一个logic呢?所以我觉得不要强求自己从实际电路中理解wire和reg,像我这种新手就应该牢记规则去用就好了_

  • 2
    点赞
  • 34
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值