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 跳转至页
回复
打赏帖 | |
---|---|
宏定义和const关键字定义被打赏5分 | |
【功率监测与控制系统DIY活动成果贴】DIY功率计与LabVIEW数据采集被打赏100分 | |
【Freertos】任务管理被打赏10分 | |
分享博世的两种不同的喷射系统模式被打赏5分 | |
汽车+开路实验与短路实验被打赏10分 | |
多点式电子控制汽油喷射系统知识分享被打赏10分 | |
分享机械控制式汽油喷射系统被打赏5分 | |
【分享开发笔记,赚取电动螺丝刀】解决基于CH341制作无线模块时芯片发热问题被打赏31分 | |
【分享开发笔记,赚取电动螺丝刀】使用STM32F103ZE主控调试RS485通讯的避坑经验被打赏36分 | |
【分享开发笔记,赚取电动螺丝刀】移植xprintf模块被打赏27分 |