在verilog中对mux的反馈

时间:2015-03-11 08:15:35

标签: verilog feedback mux

我正在使用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

2 个答案:

答案 0 :(得分:1)

根据测试平台(初始化),似乎b不是input(它只是多路复用器的输出)

我想你想实现以下电路:

enter image description here

但为了避免创建循环(当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==1w1 = a+bb =w1为w1 = a + w1;作为组合循环。这不行。如果内部有一个触发器来打破循环,那么它的行为就像一个累加器。

Emman注意到b是输入,因此无法覆盖该值。

此行assign b = (sel)? w1 : in_0;无效。请注意,它实际上从不使用输入值,因为这会在所有情况下完全覆盖它。