2 回答
TA贡献1847条经验 获得超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贡献1801条经验 获得超16个赞
这种情况一般都是状态机出问题了
data_input_1信号在在S3的情况下过早为0,会导致current_state不能进入S4状态.data_input_1必须值到下一个时钟周期开始时也为1,保证next_state最终为S4,这样才能在上升沿加载到current_state寄存器中,因此这个设计对于前导码之后第1位为0是失效的,第一位为1则可以运行,你可以做个实验验证一下.
解决方案:用个寄存器先对输入信号同步采样一下.
- 2 回答
- 0 关注
- 217 浏览
添加回答
举报