三段式描述电路的心得

来源:本站
导读:目前正在解读《三段式描述电路的心得》的相关信息,《三段式描述电路的心得》是由用户自行发布的知识型内容!下面请观看由(电工技术网 - www.9ddd.net)用户发布《三段式描述电路的心得》的详细说明。
简介:什么是三段式描述电路? 所谓三段式描述指的是状态机的描述. 内国FPGA和CPLD设计者由于多年C语言程序设计风格的影响,常采用一段式状态机描述.

状态机采用VerilogHDL/VHDL语言编码,建议分为三个always/PROCESS段完成。

三段式建模描述FSM的状态机输出时,只需指定case敏感表为次态寄存器,然后直接在每个次态的case分支中描述该状态的输出即可,不用考虑状态转移条件。

三段式描述方法虽然代码结构复杂了一些,但是换来的优势是:使FSM做到了同步寄存器输出,消除了组合逻辑输出的不稳定与毛刺的隐患,而且更利于时序路径分组,一般来说在FPGA/CPLD等可编程逻辑器件上的综合与布局布线效果更佳。

示列如下:

//第一个进程,同步时序always模块,格式化描述次态寄存器迁移到现态寄存器

always @ (posedge clk or negedge rst_n)//异步复位

if(!rst_n)

current_state <= IDLE;

else

current_state <= next_state;//注意,使用的是非阻塞赋值

//第二个进程,组合逻辑always模块,描述状态转移条件判断

always @ (current_state)//电平触发

begin

next_state = x;//要初始化,使得系统复位后能进入正确的状态

case(current_state)

S1: if(...)

next_state = S2;//阻塞赋值

...

endcase

end

//第三个进程,同步时序always模块,格式化描述次态寄存器输出

always @ (posedge clk or negedge rst_n)

...//初始化

case(next_state)

S1:

out1 <= 1'b1;//注意是非阻塞逻辑

S2:

out2 <= 1'b1;

default:...//default的作用是免除综合工具综合出锁存器

endcase

end

一段,两段式有限状态机与三段式有限状态机的区别

FSM将时序部分(状态转移部分)和组合部分(判断状态转移条件和产生输出)在一个always/process中的CASE语句完成,即为一段式有限状态机。(一段式有限状态机定义)

FSM将时序部分(状态转移部分)和组合部分(判断状态转移条件和产生输出)分开,写为两个always语句,即为两段式有限状态机。(两段式有限状态机定义)

将组合部分中的判断状态转移条件和产生输入再分开写,则为三段式有限状态机(三段式组有限状态机定义)。

区别:

一段式描述的电路结构冗长,特别繁杂.组合逻辑复杂,是序路径不唯一,组合逻辑输出毛刺无法避免.

二段式在组合逻辑特别复杂时适用,但要注意需在后面加一个触发器以消除组合逻辑对输出产生的毛刺。三段式没有这个问题,由于第三个always会生成触发器。

设计时注意方面:

1.编码原则,binary和gray-code适用于触发器资源较少,组合电路资源丰富的情况(CPLD),对于FPGA,适用one-hot code。这样不但充分利用FPGA丰富的触发器资源,还因为只需比较一个bit,速度快,组合电路简单。

2.FSM初始化问题:

GSR(Gobal Set/Reset)只是在加电时清零所有的reg和片内ram,并不保证FSM能进入初始化状态,要利用GSR,方案是适用one-hot code with zero idle,即初始状态编码为全零。已可以适用异步复位rst

3.FSM输出可以适用task

4FSM中的case最好加上default,默认态可以设为初始态

5.尤其注意:

第二段的always(组合部分,赋值用=)里面判断条件一定要包含所有情况!可以用else保证包含完全,否则产生锁存器,电路工作不正常。

6第二段always中,组合逻辑电平要维持超过一个clock,仿真时注意。

提醒:《三段式描述电路的心得》最后刷新时间 2024-03-14 01:00:18,本站为公益型个人网站,仅供个人学习和记录信息,不进行任何商业性质的盈利。如果内容、图片资源失效或内容涉及侵权,请反馈至,我们会及时处理。本站只保证内容的可读性,无法保证真实性,《三段式描述电路的心得》该内容的真实性请自行鉴别。