2016-09-02 277 views
1

這是使用兩個4位移位寄存器的8位移位寄存器模塊。 4位寄存器模塊工作正常。 (只是現在測試右移)Verilog輸出給出'x'

module shift_reg_8 (Out,In,shift_left,shift_right,s0,s1,enable,clock); 

    output [7:0] Out; 
    wire [3:0]Least_Out,Most_Out;     

    input [7:0] In;     
    wire [3:0]Least_In,Most_In; 
    reg temp; 

    initial 
    temp = In[4]; 

    assign {Most_In,Least_In} = In; 
    input shift_left,shift_right,enable,s0,s1,clock;   

    shift_reg least_sig_reg(Least_Out,Least_In,shift_left,shift_right,s0,s1,enable,clock);     
    shift_reg most_sig_reg(Most_Out,Most_In,shift_left,shift_right,s0,s1,enable,clock);   

    assign Out = {Most_Out,Least_Out}; 
    assign Out[3] = temp; 

endmodule 

這裏是測試臺。

module stimulus; 


reg [7:0]INPUT; 
reg ENABLE,CLOCK,S0,S1,SL,SR; 

wire [7:0] OUTPUT; 

shift_reg_8 my8shiftreg(OUTPUT,INPUT,SL,SR,S0,S1,ENABLE,CLOCK);  // SL = Shift_Left, SR = Shift_Right, SO,S1 = Controls 

initial 
begin 

    CLOCK = 1'b0; 

    INPUT = 8'b01101110; ENABLE = 1;S0 = 0;S1 = 1;SL = 0;SR = 1; 
    #14 $display("Test 1 (Right Shift): INPUT = %b, S1 = %b, S0 = %b, SR = %b, OUTPUT = %b\n",INPUT,S1,S0,SR,OUTPUT); 

end 

always 
#5 CLOCK = ~CLOCK; 

    initial 
#100 $stop; 

endmodule

模擬時,這提供了這樣的輸出。

測試1(右移):Input = 01101110,S1 = 1,S0 = 0,SR = 1,輸出= 1011x111

可能是什麼問題?

這裏的shift_reg代碼...

module shift_reg(Out,In,shift_left,shift_right,s0,s1,enable,clock); 

    output [3:0] Out; 
    input [3:0] In; 
    input shift_left,shift_right,enable,s0,s1,clock; 

    reg [3:0] out_reg; 

always @(posedge clock & enable) 


begin 

if ((s0 == 1'b0) && (s1 == 1'b0))     // Holding 
    begin     

    end 

else if ((s0 == 1'b1) && (s1 == 1'b0))    // Left Shift 
    begin 

    out_reg[0] <= shift_left; 
    out_reg[1] <= In[0]; 
    out_reg[2] <= In[1]; 
    out_reg[3] <= In[2]; 

    end 

else if ((s0 == 1'b0) && (s1 == 1'b1))    // Right Shift 
     begin 

     out_reg[0] <= In[1]; 
     out_reg[1] <= In[2]; 
     out_reg[2] <= In[3]; 
     out_reg[3] <= shift_right;       

     end 

else if ((s0 == 1'b1) && (s1 == 1'b1))   // Loading 
     begin 

     out_reg <= In;   

     end 

end 

assign Out = out_reg; 

endmodule

回答

2

您分配了[3]兩次。

assign Out = {Most_Out,Least_Out}; // Assigns all 8 bits 
assign Out[3] = temp; // Assigns bit 3 again. 

多個驅動程序導致未知狀態。

+0

感謝您的回答......您能爲此提出解決方案嗎? – Arcane

+0

我分配了所有的位。仍然存在問題.. – Arcane

+0

這不是一個一個地分配它們的問題。首先嚐試完全註釋掉「分配[3] =溫度」行,看看X是否解析。可能還有更多的功能問題。 –