一定要避免latch
在做项目的项目的时候遇到了一个很有意思的问题,功能仿真没有问题,可是在FPGA上面上板调试就是不对,最后通过检查综合后的电路发现有一处生成了latch,在实际电路中latch容易产生毛刺,导致下一级电路可能出现错误状态,如果书写不规范,仿真是发现不了这个问题的,平时书上经常看到一定要避免latch这样的字眼,自己感觉懂了,直到这次真的遇到问题时,调试好久才发现,所以就把不规范的代码都在vivado上面跑了一下综合,给自己长长记性。(由于笔者比较菜,有不对的地方,欢迎大家批评指正)
一个变量声明为寄存器时,它既可以被综合成触发器,也可能被综合成 Latch,甚至是 wire 型变量。
第一种:组合逻辑中,不完整的 if - else 结构会综合成latch,这种是最为常见的,因为平时多用时序逻辑电路, if - else不完整并不会综合成latch,可能由于习惯,组合逻辑中有时候也会忘记。
always@(*)
if(a_i)
out_o = c_i;
else if(b_i)
out_o = 1'b1;
第二种:组合逻辑电路中将值赋值给自己
always@(*)
if(a_i)
out_o = c_i;
else if(b_i)
out_o = 1'b0;
else
out_o = out_o;
第三种、这种情况是正确的
always@(*)
if(a_i)
out_o = c_i;
else if(b_i)
out_o = 1'b1;
else
out_o = 1'b0;
这个是通过时序逻辑电路完成相同功能
always@(posedge clk or negedge rst_n)
if(~rst_n)
out_o <= 1'b0;
else if(a_i)
out_o = c_i;
else if(b_i)
out_o = 1'b1;