Verilog-1995风格,reg变量声明两次

为什么 count 要声明两次?

这是 Verilog 语法的一个经典特性 ,并不是真的"声明两次",而是对同一个信号的两种不同属性分别说明。


一、两次声明的不同含义

Apply

复制代码
output [3:0] count;   // 声明 1:端口方向 + 位宽
reg    [3:0] count;   // 声明 2:数据类型
声明 作用 回答的问题
output 3:0 count 声明它是模块的输出端口,位宽 4 位 "它是输入还是输出?"
reg 3:0 count 声明它的数据类型为 reg(寄存器型) "它是 wire 还是 reg?"

这两条信息是正交的(互相独立),所以需要分开声明。


二、为什么必须声明为 reg

Verilog 中信号有两大类数据类型:

类型 用途 赋值场景
wire 表示连线,由组合逻辑驱动 用 assign 连续赋值
reg 表示变量,能保存值 在 always / initial 块中赋值

规则 :凡是在 always 块中被赋值的信号,必须声明为 reg

本例中:

Apply

复制代码
always @(posedge clk)
    count <= ...;   // 在 always 块里赋值

所以 count 必须是 reg 类型,否则编译报错。


三、为什么默认不是 reg?

因为 Verilog 中端口默认类型是 wire

Apply

复制代码
output [3:0] count;   // 等价于 output wire [3:0] count;

wire 不能在 always 块中赋值 ,所以必须额外用 reg 覆盖默认类型。


四、简化写法(Verilog-2001 及以后)

现代 Verilog 支持合并写法,一行搞定:

Apply

复制代码
output reg [3:0] count;   // 端口方向 + 数据类型 + 位宽 一次声明

这样就不用写两遍了。原代码采用的是 Verilog-1995 风格,必须分开写。


五、总结

问题 答案
为什么声明两次? 一次说明端口方向(output),一次说明数据类型(reg),两者是不同维度的属性
为什么必须是 reg? 因为它在 always 块中被赋值
能否合并? 可以,用 output reg 3:0 count;(Verilog-2001 语法)

一句话记忆:"output 管方向,reg 管类型,always 里赋值就得是 reg。"

相关推荐
坏孩子的诺亚方舟13 天前
FPGA系统架构设计实践15_高云Arora V系列时钟体系
fpga开发·系统架构
FPGA小徐13 天前
入门 CNN 结构全解析|从流程图理论到 FPGA Verilog 硬件实现(含习题带讲解)
fpga开发
FPGA小徐13 天前
FPGA 数字信号处理:并行 FIR 与串行滤波器设计原理、对比与完整 Verilog 实现
fpga开发
Saniffer_SH14 天前
【高清视频】Gen6 服务器还没到,Gen6 SSD 怎么测?Emily 现场演示三种测试环境
人工智能·驱动开发·测试工具·缓存·fpga开发·计算机外设·压力测试
zlinear数据采集卡14 天前
双核架构深度解析:ARM+FPGA如何让数据采集卡实现500Ksps高性能?
arm开发·fpga开发·架构
9527华安14 天前
FPGA实现GTH Transceivers Wizard传输2路视频,基于aurora 8b10b编解码架构,提供4套工程源码和技术支持
fpga开发·gth·aurora 8b10b·transceivers
FPGA小徐15 天前
FPGA 数字信号处理(二):并行 FIR 滤波器的 Verilog 全流程设计与实现
fpga开发
国科安芯15 天前
基于AS32S601ZIT2型抗辐照MCU的商业航天卫星姿态确定与控制系统研究
单片机·嵌入式硬件·安全·fpga开发·架构·risc-v
ALINX技术博客15 天前
【黑金云课堂】FPGA技术教程FPGA基础:I2C 总线通信技术
fpga开发·i2c
Hello-FPGA15 天前
Xilinx KU040 FPGA Camera Link 图像采集
c++·fpga开发