2 回答

TA貢獻(xiàn)1847條經(jīng)驗 獲得超11個贊
感覺沒什么問題 我測試了下 輸入串碼1111 101
你可以用我的tb跑跑看
-----------------------
module test_test();
reg sys_clk ;
reg sys_rst ;
reg data_input_1;
wire [2:0] xlat_address_port_1;
always #5 sys_clk = ~sys_clk;
initial begin
sys_clk = 1'b0;
sys_rst = 1'b0;
data_input_1 = 1'b0;
#10 sys_rst = 1'b1;
#5;
#10 data_input_1 = 1'b1;
#10 data_input_1 = 1'b1;
#10 data_input_1 = 1'b1;
#10 data_input_1 = 1'b1;
#10 data_input_1 = 1'b1;
#10 data_input_1 = 1'b0;
#10 data_input_1 = 1'b1;
#10 data_input_1 = 1'b0;
end
serial_in serial_in(
.sys_clk (sys_clk ),
.sys_rst (sys_rst ),
.data_input_1 (data_input_1 ),
.xlat_address_port_1 (xlat_address_port_1)
);
endmodule

TA貢獻(xiàn)1801條經(jīng)驗 獲得超16個贊
這種情況一般都是狀態(tài)機(jī)出問題了
data_input_1信號在在S3的情況下過早為0,會導(dǎo)致current_state不能進(jìn)入S4狀態(tài).data_input_1必須值到下一個時鐘周期開始時也為1,保證next_state最終為S4,這樣才能在上升沿加載到current_state寄存器中,因此這個設(shè)計對于前導(dǎo)碼之后第1位為0是失效的,第一位為1則可以運(yùn)行,你可以做個實驗驗證一下.
解決方案:用個寄存器先對輸入信號同步采樣一下.
添加回答
舉報