我正在使用verilog执行反馈多路复用计算。但是系统不响应(给出X)输入之一B(由多路复用器控制的输入)。可以帮我指出错误在哪里以及如何修复它。
以下是代码:
module test(input sel,input [3:0]a,b,output [3:0]o);
localparam in_0 = 4'd0;
wire [3:0]w1;
assign w1 = a + b;
assign o = w1 | 4'd0;
assign b = (sel)?w1:in_0;
endmodule
以下是测试平台:
module test_tb();
reg sel;
reg [3:0] a,b;
wire [3:0]o;
test U1(.sel(sel),.a(a),.b(b),.o(o));
initial begin
sel <= 1'b0;
a <= 4'd2;
#2;
sel <= 1'b1;
#2;
a <= 4'd1;
#2;
sel <= 1'b0;
a <= 4'd4;
#2;
end
endmodule
答案 0 :(得分:1)
根据测试平台(初始化),似乎b
不是input
(它只是多路复用器的输出)
我想你想实现以下电路:
但为了避免创建循环(当sel = 1时),您应该在设计中添加clk
端口以控制操作:
module test(
input clk,
input sel,
input [3:0] a,
output [3:0] o
);
wire [3:0] b;
reg [3:0] w1;
assign o = w1;
assign b = (sel)?w1:4'd0;
always @(posedge clk)
w1 <= a + b;
endmodule
答案 1 :(得分:0)
看看你的例子:
module test(
input sel,
input [3:0] a,
input [3:0] b,
output [3:0]o
);
localparam in_0 = 4'd0;
wire [3:0]w1;
assign w1 = a + b;
assign o = w1 | 4'd0;
assign b = (sel)? w1 : in_0;
请注意,sel==1
为w1 = a+b
,b =w1
为w1 = a + w1;作为组合循环。这不行。如果内部有一个触发器来打破循环,那么它的行为就像一个累加器。
由Emman注意到b是输入,因此无法覆盖该值。
此行assign b = (sel)? w1 : in_0;
无效。请注意,它实际上从不使用输入值,因为这会在所有情况下完全覆盖它。