我正在尝试编写一个八进制(8位输入)2对1多路复用器。下面是我的代码:
module octal2to1mux(input [7:0] a, input [7:0] b, input s, output w);
assign w= (s=1'b0) ? a:
(s=1'b1) ? b: 1'bx;
endmodule当我尝试编译时,我得到以下错误:
octal2to1mux.sv(3): Illegal assignment expression in continuous assignment.如果是s=0,我只想得到w=a;如果s=1,a和b都是8位输入,我只想得到w=b。我在testbench中使用了这个模块两次。
发布于 2020-07-31 19:14:38
编写可合成多路复用器的推荐方法是:
module octal2to1mux (input [7:0] a, input [7:0] b, input s, output [7:0] w);
assign w = (s) ? a : b;
endmodule它更简单,更容易理解,并修复你的语法错误。此外,如果s为X或Z,则w将为X;不需要将其显式设置为X。
请注意,w必须与a和b输入的位宽相同。
发布于 2020-07-27 16:44:23
输出w的宽度应该是8。正如@Serge评论的那样,在进行比较时,应该使用==或=== (不可合成)。
https://stackoverflow.com/questions/63100017
复制相似问题