今天解决了一个很基础的问题

今天解决了一个很基础的问题
在论坛里看到有人提问如下代码报错:
define plus 3'd0
`define minus 3'd1
`define band 3'd2
`define bor 3'd3
`define unegate 3'd4
module alu(opcode,out,a,b);
input[2:0]opcode;
input [7:0]a,b;
output[7:0]out;
reg[7:0]out;
always@(opcode or a or b)
begin
case(opcode)
plus:out=a+b;
minus:out=a-b;
band:out=a&b;
bor:out=a|b;
unegate:out=~a;
default:out=8'hx;
endcase
end
endmodule
显示错误 :Error (10161): Verilog HDL error at alu.v(14): object "plus" is not declared

首先plus 3'd0这样的应该为3'b0,否则和后面的t[2:0]opcode;位数无法对应
语法没有什么问题,但是编译确实提示错误
把`define 改成reg或者 parameter肯定没问题
最后我明白了,`define unegate 4定义的变量,在引用时也要`plus这样才行哈哈,原来竟是一个小小的`符号惹的祸。

今天解决了一个很基础的问题_设计制作_可编程逻辑
7
104
0
84

相关资讯

  1. 1、雅虎就史上最大数据泄密案达成和解协议,金额达1.175亿美元2104
  2. 2、物理学家开发高效的调制解调器可实现高度敏感的量子信息远程传输668
  3. 3、利亚德​2018净利润获增,2019年Q1业绩将预喜3549
  4. 4、熬夜现象普遍存在监测仪器让睡眠质量更高3952
  5. 5、国内首台大尺寸集成电路硅单晶生长设备试产成功!加快解决“卡脖子”问题4535
  6. 6、全球传感器市场规模超2000亿美元,增量市场在何处?699
  7. 7、vivoNEX3S发布!换芯骁龙865,售价4998元起值不值得买?333
  8. 8、超越二进制,一种不使用二进制的多状态数据存储49
  9. 9、风华高科涉嫌信披违规被立案,股价半月跌逾30%1432
  10. 10、潘建伟团队‘墨子号’量子卫星成果获克利夫兰奖90余年中国本土科研首获奖341
全部评论(0)
我也有话说
0
收藏
点赞
顶部