今天解决了一个很基础的问题
在论坛里看到有人提问如下代码报错:
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这样才行哈哈,原来竟是一个小小的`符号惹的祸。
中兴朱永涛:5G时代应通过应用创新+共赢生态圈助力产业升级
壮龙油驱多旋翼无人机召开鉴定会,已达到国际领先水平
全球移动通信系统协会发出警告称频谱的监管会影响5G的发展
适合LED固定装置的固态驱动器LXMG221W-070003
如何识别变压器引线
今天解决了一个很基础的问题
e络盟推出凌力尔特全系列电源管理和数据转换演示板
什么是软件实时控制?软件实时控制的优势
中兴、华为之后,又一国产品牌遭到禁售,自主研发坚持到底
华为P10概念图流出:曲面屏+无线充电+双摄像头
双11迎来全球最大规模流量洪峰,达58.3万笔/秒
电容补偿柜中用复合开关好还是接触器好
区块链招聘需要怎样做
寒武纪推出终端智能处理器 IP 产品1A系列
分享一个超级实用的源码阅读小技巧
高通Snapdragon Ride平台卓越算力,自动驾驶等级全覆盖
单色BMP位图的显示方法
低噪声12 GHz微波小数N分频锁相环的设计
用模拟时钟IC替代昂贵的高频率VCO,改善抖动性能
芯片组的作用