module compare_n ( X, Y, XGY, XSY, XEY);
input [width-1:0] X, Y;
output XGY, XSY, XEY;
reg XGY, XSY, XEY;
parameter width = 8;
always @ ( X or Y ) // 每当 X 或 Y 变化时
begin
if ( X = = Y )
XEY = 1; // 设置X 等于Y的信号为1
else XEY = 0;
if (X > Y)
XGY = 1; // 设置X 大于Y的信号为1
else XGY = 0;
if (X < Y)
XSY = 1; // 设置X 小于Y的信号为1
else XSY = 0;
end
endmodule
在上面比较器的程序中, XGY, XSY, XEY已经定义为输出,为什么还要从新定义为寄存器变量呢?
共8条
1/1 1 跳转至页

2楼
输出只是IO方向,与信号类型无关,output可以是wire,也可以是reg,input都是wire。默认是wire型,可不写,但reg型必须要写明。

5楼
wire是在assign中赋值的,reg是在always里赋值的。 但上例中的XGY, XSY, XEY综合得到的是线而不是寄存器。


共8条
1/1 1 跳转至页
回复
打赏帖 | |
---|---|
【Zephyr】MCXN947 Zephyr 开发入门适配shell被打赏20分 | |
【我要开发板】6.联合MATLAB记录数据被打赏50分 | |
【瑞萨RA2E1开发板】:使用ADC功能实现位移传感器采集方案被打赏20分 | |
【nRF7002DK】基于sht30的温湿度计被打赏20分 | |
【nRF7002DK】日志打印被打赏20分 | |
【换取手持示波器】RGB屏幕移植ARM-2D库被打赏35分 | |
【分享开发笔记,赚取电动螺丝刀】分享一下如何解决瑞萨RA2E1使用printf编译报错问题被打赏27分 | |
rtthread硬件加密-5hash加密分析被打赏10分 | |
【换取手持示波器】Mongoose 零代码创建网页仪表盘被打赏33分 | |
【分享开发笔记,赚取电动螺丝刀】基于.Net6.0 WPF简单做一个MQTT收发小工具被打赏24分 |