0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

如何在FPGA中实现状态机

FPGA设计论坛 来源:未知 2023-07-18 16:05 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

状态机往往是FPGA 开发的主力。选择合适的架构和实现方法将确保您获得一款最佳解决方案。

FPGA 常常用于执行基于序列和控制的行动, 比如实现一个简单的通信协议。对于设计人员来说,满足这些行动和序列要求的最佳方法则是使用状态机。状态机是在数量有限的状态之间进行转换的逻辑结构。一个状态机在某个特定的时间点只处于一种状态。但在一系列触发器的触发下,将在不同状态间进行转换。理论上讲,状态机可以分为Moore 状态机和Mealy 状态机两大类。它们之间的差异仅在于如何生成状态机的输出。Moore 状态机的输出仅为当前状态的函数。典型的例子就是计数器。而Mealy 状态机的输出是当前状态和输入的函数。典型的例子就是Richards 控制器.

定义状态机
当需要定义一个状态机时,首先要绘制一张状态图。状态图可用来显示状态、状态间的转换和状态机的输出。图1 显示了Moore 状态机的状态图(左)和Mealy 状态机的状态图(右)。

wKgZomToDwqAPwQ0AABPk6bb5_g765.jpg

如果您要在物理组件中实现这些状态图(工程师在FPGA问世之前就是这么做的),首先就得生成当前状态和后续状态表,然后生成实现状态机所需的逻辑。不过由于我们将使用FPGA来实现设计,因此我们可以直接从状态转换图开始工作。

算法状态图
虽然有许多状态机是使用图1 所示的状态图方法进行设计的,但另外还有一种描述状态机行为的方法,这就是算法状态图法。ASM 图(图2)在外观上更加接近软件工程流程图。它由三个基本部分构成:
1. 状态框。它与状态名称有关,并包含Moore 状态输出列表。
2. 决策框。如果检验某条件为真,则进行下一状态的判断。
3. 条件输出框。让状态机根据当前状态和输入描述Mealy输出。

一些工程师认为,如果使用VHDL 等硬件描述语言,则采用ASM 格式进行描述的状态机更易于映射到实现方案中。

wKgZomToDwqALcL6AACv6iaOBNg611.jpg

MOORE 和MEALY:应该选择哪个?
实现Moore 状态机还是Mealy 状态机,取决于状态机需要实现的功能,以及特定的反应次数要求。两种状态机之间的最大差别在于状态机如何对输入做出反应。在输入和设置的适当输出之间,Moore 状态机一般有一个时钟周期的延迟。这就意味着Moore 状态机无法对输入变化立即做出反应,这点在图3中可以清楚地看到。而Mealy 状态机则能够立即对输入做出反应,这通常意味着:实现相同的函数,Mealy 状态机比Moore状态机需要更少的状态。Mealy 状态机的不足之处就是在与另一个状态机进行通信时,如果输出出乎意料地严重依赖于其它事件的序列或时序,就可能会发生紊乱情况。

wKgZomToDwqADNpDAACW_hidFhM360.jpg

当然,并非只能使用单纯的Moore状态机或Mealy 状态机,也可以将这两种状态机混合使用,从而更有效地实现所需的函数。比如说,用于接收RS232 串行数据的状态机就可以是混合机。

实现状态机
使用VHDL 这样的高级语言,可以轻松地直接从状态图实现状态机。VHDL 支持多种枚举类型,方便您定义实际的状态名称。举例如下:

wKgZomToDwqAAog_AAAK-wQ9T_k852.jpg

上面的类型定义对应的是图1 中所示的状态图,即用于在按下按钮时切换发光二极管开/ 关的状态机。

实现状态机有许多种方法,可分为两类基本方法。第一类基本方法就是一次性将所有内容集成到单个进程中。第二类基本方法是双进程法,将组合逻辑和顺序逻辑分开。

一般来说,大多数工程师都倾向于实现单进程状态机。与传统上讲授的双进程法相比,这种方法具有以下优势:
• 可以避免组合过程中信号覆盖不完全造成的闭锁风险。
• 状态机的输出与时钟保持同步。
• 通常比双进程实现方案更容易调试。

无论您决定采用哪一种方法来实现状态机,都需要使用CASE 语句来评估下一状态的判定和任何输出,如图4 所示。该图并行比较了使用单进程法的Moore 状态机( 左) 和Mealy 状态机(右)。

wKgZomToDwqAdOcAAACCLiB89Yc881.jpg

状态机编码
状态变量存储在触发器中,使用下一时钟边缘上的下一状态进行更新(即使没有状态变化也是如此)。如何使用触发器来表示状态值具体取决于状态的数量和是否选择用某种特定的方法来管理综合工具。状态编码最常见的三种类型是:
• 顺序码——状态编码遵循传统的状态二进制序列。
• 格雷码——除了状态编码使用格雷码,且状态编码串
之间只有一个位变化外,其它基本与顺序编码方法类似。
• 独热码——这种方法在状态机中为每一种状态分配一个触发器。只有一个触发器当前设置为高位,其余均设置为低位。故称为“独热”。

顺序编码和格雷编码都需要一定数量的触发器,可以通过下列等式来确定:

wKgZomToDwuABxOnAAARFGQ_GUw364.jpg

相比之下,独热编码法所需的触发器数量和状态数量一样多。

状态编码的自动分配取决于状态机所包含的状态数量。同时还需要考虑您选择使用的综合工具。您可以根据下列经验法则来选取编码方法:
• 顺序:少于5 种状态。
• 独热:5-50 种状态。
• 格雷:多于50 种状态。

一般情况下您不必去考虑使用哪一种状态编码方法,而是让综合引擎工具确定合适的实现方案,只在选择的方法出现问题时进行考虑。但是,如果您要全盘自行掌控,并定义状态编码方法,也没必要手动操作,只需使用状态编码为每一种状态设定常数即可。相反地,可以使用代码中的一个属性来驱动综合工具,从而选择特定的编码方法。具体如下所示:

wKgZomToDwuAW8oiAAA64RouyEA374.jpg

其中“sequential”也可以是“gray”和“onehot”。您还可以通过结合使用“safe”属性来确保在状态机进入非法状态时能够恢复到有效状态。

另外,您也可以使用syn_encoding 属性直接定义状态编码的值。例如,假设您想要使用下列状态编码法来对三态状态机进行编码:Idle = “11,” led_on = “10,” led_off = “01(与较传统的顺序“00”、“01”和“10”不同):

wKgZomToDwuASNbwAAA4TkPhX84039.jpg

前面给出的等式可确定状态机实现方案所需的触发器数量。由于不是所有的状态机都是2 的幂次方,因此某些状态在设计中将不会用到。实现状态机的工程师必须负责确保未使用的状态在设计中得到妥善处理。可以采用几种适用于多种设计的基本技巧来实现这一目标。对于高度可靠的安全关键型设计,则需要采用其它更高级的技巧。(参见Xcell 杂志第73 期刊登的深度文章《在关键任务系统中使用FPGA》。该文章着重阐述状态机保护问题。)

不过对于大多数应用来说,只需要确保状态机能够妥善地处理未使用的状态并在进入非法状态时能够正确地恢复。要做到这一点有两种主要的方法。第一种方法是使用综合工具实现一个安全的状态机。综合工具通常会插入额外的逻辑,用于检测非法状态并将状态机返回到有效状态。第二种方法是加强对实现逻辑的控制,声明所有2 的幂次方状态机的状态,并使用另一属性来确保即便是在没有入口条件下,2 的幂次方状态机的状态也不会被优化掉。这意味着除非出错(单粒子翻转等),状态机内部的任何条件都不会进入状态。下面的代码显示了通过使用属性以防止清除未使用的状态。

wKgZomToDwuAIR0QAAArEANyBi0199.jpg

简而言之,安全高效的状态机设计对于任何使用FPGA的工程师而言都是一项重要技能。选择Moore 状态机、Mealy
状态机还是混合机取决于整个系统的需求。无论选择哪种类型的状态机,充分掌握实现方案所需的工具和技巧,将确保您实现最佳解决方案。

wKgZomToDwuAfSyyAAAJM7aZU1A696.png

有你想看的精彩 至芯科技-FPGA就业培训来袭!你的选择开启你的高薪之路!7月12号北京中心开课、欢迎咨询! 至芯科技奋斗的小孩之verilog 基础语法 基于matlab FPGA verilog的FIR滤波器设计

wKgZomToDwuAFZTPAABUdafP6GM512.jpg

扫码加微信邀请您加入FPGA学习交流群

wKgZomToDwuAaCsXAAACXWrmhKE084.png

欢迎加入至芯科技FPGA微信学习交流群,这里有一群优秀的FPGA工程师、学生、老师、这里FPGA技术交流学习氛围浓厚、互分享、相互帮助、叫上小伙伴一起加入吧

点个在看你最好看


原文标题:如何在FPGA中实现状态机

文章出处:【微信公众号:FPGA设计论坛】欢迎添加关注!文章转载请注明出处。


声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • FPGA
    +关注

    关注

    1655

    文章

    22283

    浏览量

    630289

原文标题:如何在FPGA中实现状态机

文章出处:【微信号:gh_9d70b445f494,微信公众号:FPGA设计论坛】欢迎添加关注!文章转载请注明出处。

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    睿远研究院丨IO-Link规范解读(十一):ISDU状态机与EVENT事件

    上篇我们介绍了ISDU的典型编码格式和应用案例,本篇我们就来详细介绍下,ISDU的状态机,并把EVENT事件的逻辑,给大家好好解析下。 1主站ISDU状态机 如上图所示,ISDU的状态机的核心
    的头像 发表于 11-29 18:28 2709次阅读
    睿远研究院丨IO-Link规范解读(十一):ISDU<b class='flag-5'>状态机</b>与EVENT事件

    什么是状态机

    的switch—case语句里要有400个case,这样的程序还有法儿写么?! 同样的功能改动,如果用g_stFSM这个结构体来实现状态机的话,函数fsm_active()只需要
    发表于 11-27 08:15

    嵌入式开发为何经常用到状态机架构

    状态机写的程序要好很多,拿一张标准的UML状态转换图,再配上一些简明的文字说明,程序的各个要素一览无余。 程序中有哪些状态,会发生哪些事件,状态机
    发表于 11-25 07:08

    睿远研究院丨IO-Link规范解读(八):M-Sequence Type 与消息处理状态机

    丢弃,减少后端工作量。 那么今天我们就来深入研究下,消息处理模块中提到的各类M-Sequence,以及主从站的消息处理状态机!   1 M-Sequence Type 上回讲到主站发出来的MC和CKT
    的头像 发表于 11-07 16:18 5625次阅读
    睿远研究院丨IO-Link规范解读(八):M-Sequence Type 与消息处理<b class='flag-5'>状态机</b>

    睿远研究院丨IO-Link规范解读(六):主从站状态机解析

    前言 书接上文,今天我们就来好好聊聊主从站的DL-Mode状态机,还请各位童鞋前排坐好! 1主站状态机解析 主站的DL-Mode状态机有5个大状态,也是我们很熟悉的 建立通信、开始、预
    的头像 发表于 10-28 17:34 5790次阅读
    睿远研究院丨IO-Link规范解读(六):主从站<b class='flag-5'>状态机</b>解析

    聊聊FPGA的TDC原理

    今天我们不谈高大上的物理学,只聊聊如何在 FPGA ,用一串加法器和 D 触发器,“数清楚时间”——这就是时间数字转换器(TDC)的魅力。
    的头像 发表于 09-02 15:15 940次阅读
    聊聊<b class='flag-5'>FPGA</b><b class='flag-5'>中</b>的TDC原理

    通过 BOD 或 nReset 重置时,GPIO 是否处于高实现状态

    正如标题所说,我正在使用 ML51 来控制外部 MOS 组件,GPIO 类型在复位条件下非常重要。GPIO 是否处于高实现状态
    发表于 08-25 07:04

    JTAG标准的状态机实现

    JTAG作为一项国际标准测试协议(IEEE1149.1兼容),主要用于芯片内部测试和调试。目前的主流芯片均支持JTAG协议,如DSP、FPGA、ARM、部分单片等。标准的JTAG接口是20Pin,但JTAG实际使用的只有4根信号线,再配合电源、地。
    的头像 发表于 08-21 15:12 2055次阅读
    JTAG标准的<b class='flag-5'>状态机</b><b class='flag-5'>实现</b>

    请问如何在FX10上使用GPIF III状态机 *.h 文件?

    LVCMOS 2 位 SlaveFIFO GPIF III 状态机的演示中有一个 cy_gpif_header_lvcmos.h 文件。 我想知道如何使用.h文件,只需放入.h文件放入 FX10 项目? 您有它的用户指南文档吗?
    发表于 07-16 08:17

    NVMe高速传输之摆脱XDMA设计之八:PCIe初始化状态机设计

    PCIe配置初始化状态机实现PCIe设备枚举和配置空间初始化过程,在完成链路训练后,使用DFS(深度优先搜索)算法枚举PCIe总线上的设备,完成PCIe总线域的地址分配和设备的初始化。PCIe配置
    发表于 07-05 22:00

    有可能在 FX3 GPIF2 创建两个独立的状态机吗?

    我想,如果我想通过 FX3 GPIF2 创建两个独立的传输流接口,我需要在 GPIF2 设计器创建两个独立的状态机,我是否有可能在 GPIF2 设计器创建两个独立的状态机
    发表于 05-20 06:14

    cypress3014视频格式改变的话,GPIF状态机需不需要重新配置?

    你好,请问视频格式改变的话,GPIF状态机需不需要重新配置
    发表于 05-14 07:28

    求助,关于srammaster.cydsn状态机的问题求解

    晚上好。 我目前正在学习 GPIF II。 查看..EZ-USB FX3 SDK1.3firmwaregpif_examplescyfxsrammastersrammaster.cydsn状态机,有状态START和START
    发表于 05-12 06:20

    高速ssd存储系统数据缓存控制器流程控制设计

    高速SSD系统中流程控制模块设计。该模块主要由寄存器、读状态机、写状态机和命令生成模块组成,系统介绍各模块功能。
    的头像 发表于 04-14 10:43 652次阅读
    高速ssd存储系统<b class='flag-5'>中</b>数据缓存控制器流程控制设计

    Simulink状态机建模方法 Simulink数据可视化与分析功能

    1. Simulink状态机建模方法 1.1 理解状态机的基本概念 在开始建模之前,了解状态机的基本概念是必要的。状态机由以下几个部分组
    的头像 发表于 12-12 09:27 4275次阅读