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。"

相关推荐
cjie2214 小时前
安路好用的调试工具VPI
fpga开发
chenlance1 天前
基于FPGA的激光器多通道数据采集与波形控制系统设计
fpga开发
9527华安1 天前
FPGA实现GTP高速收发器2路视频传输,基于aurora 8b10b编解码架构,提供4套工程源码和技术支持
图像处理·fpga开发·aurora·高速收发器·8b10b·derdes
cjie2211 天前
lanczos插值引起的振铃现象
计算机视觉·fpga开发
liuluyang5301 天前
Verilog 中 wire 与 wor 的区别详解
fpga开发·verilog
GateWorld2 天前
LCD显示技术完全指南:原理·制造·驱动·FPGA实现之点屏五 miniLVDS
fpga开发·lcd显示·fpga点亮屏幕·minilvds
nuoxin1143 天前
WILX1200HC-5TG144I替代 LCMXO2-1200HC-5TG144I(富利威)
人工智能·嵌入式硬件·fpga开发·电脑·硬件工程·dsp开发
Bahair_3 天前
【FPGA】使用fdatool设计滤波器系数,使用FIR Compiler导入系数联合滤波
fpga开发
qq_411262423 天前
硬件是ESP32-P4连接LAN8720A,正常初始化之后,设备DHCP失败
stm32·单片机·fpga开发