扇出的 Net 不能赋值超过一个
Net, which fans out, cannot be assigned more than one value
我正在尝试设计一个基于4位乘法器的8位乘法器。所以这是我的代码:
module _8bit_multiply(a, b, q);
input [7:0] a;
input [7:0] b;
output [15:0] q;
wire [7:0] q0;
wire [7:0] q1;
wire [11:0] q2;
wire [11:0] q3;
wire [7:0] x0;
wire [11:0] x1;
wire [7:0] sum0;
wire [12:0] sum1;
wire [12:0] sum2;
wire co0;
wire co1;
wire temp;
_4bit_multiply m1(a[3:0], b[3:0], q0);
assign q[3:0] = q0[3:0];
assign x0[3:0] = q0[7:4];
_4bit_multiply m2(a[7:4], b[3:0], q1);
nbit_adder s1(x0, q1, 0, sum0, co0);
_4bit_multiply m3(a[3:0], b[7:4], q2);
_4bit_multiply m4(a[7:4], b[7:4], x1);
assign q3[11:4] = x1[7:0];
nbit_adder s2(q2, q3, 0, sum1, co1);
nbit_adder s3(sum0, sum1, co0, sum2, temp);
nbit_adder s4(sum2, 0, co1, sum2, temp);
assign q[15:4] = sum2[12:0];
endmodule
然后我得到这个错误:
Error (12014): Net "sum2[11]", which fans out to "q[15]", cannot be
assigned more than one value
Error (12015): Net is fed by "nbit_adder:s3|s[11]" Error (12015):
Net is fed by "nbit_adder:s4|s[11]"
而且不止于此。我该怎么办?
同一个变量是您代码中多个模块的输出。基本上你是这样做的:
assign sum2 = 1;
assign sum2 = 0;
所以Quartus不知道该怎么办。
我正在尝试设计一个基于4位乘法器的8位乘法器。所以这是我的代码:
module _8bit_multiply(a, b, q);
input [7:0] a;
input [7:0] b;
output [15:0] q;
wire [7:0] q0;
wire [7:0] q1;
wire [11:0] q2;
wire [11:0] q3;
wire [7:0] x0;
wire [11:0] x1;
wire [7:0] sum0;
wire [12:0] sum1;
wire [12:0] sum2;
wire co0;
wire co1;
wire temp;
_4bit_multiply m1(a[3:0], b[3:0], q0);
assign q[3:0] = q0[3:0];
assign x0[3:0] = q0[7:4];
_4bit_multiply m2(a[7:4], b[3:0], q1);
nbit_adder s1(x0, q1, 0, sum0, co0);
_4bit_multiply m3(a[3:0], b[7:4], q2);
_4bit_multiply m4(a[7:4], b[7:4], x1);
assign q3[11:4] = x1[7:0];
nbit_adder s2(q2, q3, 0, sum1, co1);
nbit_adder s3(sum0, sum1, co0, sum2, temp);
nbit_adder s4(sum2, 0, co1, sum2, temp);
assign q[15:4] = sum2[12:0];
endmodule
然后我得到这个错误:
Error (12014): Net "sum2[11]", which fans out to "q[15]", cannot be assigned more than one value
Error (12015): Net is fed by "nbit_adder:s3|s[11]" Error (12015):
Net is fed by "nbit_adder:s4|s[11]"
而且不止于此。我该怎么办?
同一个变量是您代码中多个模块的输出。基本上你是这样做的:
assign sum2 = 1;
assign sum2 = 0;
所以Quartus不知道该怎么办。