之前都是用的一段式状态机,逻辑与输出混在一起,复杂点的就比较吃力了. 所以就开始着手三段式状态机. 组合逻辑与时序逻辑分开,这样就能简单许多了. 但是两者在思考方式上也有着很大的区别. 三段式,分作:状态寄存器,次态组合逻辑,输出逻辑. 以下今天写完的程序. //state register always@(posedge clk) begin if(!rst)begin current <= IDLE; end else begin current <= next; end end //ne
1.状态转移的always中CS,同步ouput的always中NS. 2.3段fsm vs 2段fsm:output逻辑是组合逻辑和同步时序逻辑(消除里不稳的和毛刺). 3.3段fsm vs 1段fsm: output都是同步时序逻辑,直接根据NS描述output和另外还要考虑状态转移条件描述output. 4.段式划分不是数always个数,而是每种段式对应有固定的描述内容和格式化的结构.强调的是建模思路. 5.3段fsm,解决了2段fsm中不改变时序要求的前提下用寄存器做状态输出的问题.