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 跳转至页
回复
我要赚赏金打赏帖 |
|
|---|---|
| 【FreeRtos】FreeRtos + MPU模块的配置使用被打赏¥32元 | |
| 【分享开发笔记,赚取电动螺丝刀】墨水屏文本显示器被打赏¥25元 | |
| 【STEVAL-STWINKT1B】:结合STMcubeMX软件读取HTS221温湿度被打赏¥22元 | |
| M5PAPERESP32EINKDEVKIT评测|使用MicroPython开发M5Paper被打赏¥15元 | |
| OK1126B-S开发板下以导航按键控制云台/机械臂姿态调整被打赏¥29元 | |
| 【树莓派5】便携热成像仪被打赏¥36元 | |
| 【树莓派5】环境监测仪被打赏¥35元 | |
| OK1126B-S开发板下多时段语音提示型电子时钟被打赏¥27元 | |
| OK1126B-S开发板下函数构建及步进电机驱动控制被打赏¥25元 | |
| 【S32K3XX】LPI2C 参数配置说明被打赏¥20元 | |
我要赚赏金
