一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

基于事件驅(qū)動(dòng)的有限狀態(tài)機(jī)介紹

Q4MP_gh_c472c21 ? 來源:Gitee ? 作者:Gitee ? 2021-11-16 15:29 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

一、介紹

EFSM(event finite state machine,事件驅(qū)動(dòng)型有限狀態(tài)機(jī)),是一個(gè)基于事件驅(qū)動(dòng)的有限狀態(tài)機(jī),主要應(yīng)用于嵌入式設(shè)備的軟件系統(tǒng)中。

EFSM的設(shè)計(jì)原則是:簡(jiǎn)單!EFSM的使用者只需要關(guān)心:

  1. 當(dāng)事件到來時(shí),通過EFSM取得對(duì)應(yīng)事件的處理方法;
  2. 當(dāng)特定事件到來,或者條件滿足時(shí),調(diào)用狀態(tài)切換方法進(jìn)行狀態(tài)切換。

由于EFSM的巧妙設(shè)計(jì),避免了命名沖突的問題,你可以在一個(gè)程序中定義多個(gè)狀態(tài)機(jī);要是能對(duì)不同狀態(tài)進(jìn)行組織,還可以做出層次狀態(tài)機(jī)的結(jié)構(gòu)。

EFSM總共分為兩個(gè)部分:

  • EFSM核心:由uthash.h、efsm.h和efsm_conf.h三個(gè)文件組成;他們構(gòu)成了事件驅(qū)動(dòng)型狀態(tài)機(jī)的核心;使用的時(shí)候只需要包含efsm.h即可;
  • EFSM擴(kuò)展:在EFSM核心的基礎(chǔ)上,增加efsmt.h和efsmt.c兩個(gè)文件,這兩個(gè)文件會(huì)根據(jù)具體的狀態(tài)機(jī)創(chuàng)建狀態(tài)機(jī)線程,用于驅(qū)動(dòng)狀態(tài)機(jī)運(yùn)轉(zhuǎn);使用的時(shí)候只需要包含efsmt.h即可;

二、接口總覽

EFSM總共提供了兩套接口,你只需要選擇其中套用法即可。全部接口概述如下:

2.1 使用狀態(tài)機(jī)工具集(EFSM核心)

若你想自己把控狀態(tài)機(jī)的整個(gè)運(yùn)轉(zhuǎn)過程,可以直接使用EFSM核心,詳細(xì)接口如下。

1. 狀態(tài)操作接口

API 說明 參數(shù)
EFSM_SETS 用于創(chuàng)建某一狀態(tài)下不同時(shí)間的處理集合 類型,無參數(shù)
EFSM_CREATE(state) 用于創(chuàng)建某一狀態(tài)名 state是狀態(tài)名
EFSM_DECLEAR(state) 當(dāng)在其它地方需要使用到某個(gè)狀態(tài)時(shí),用于聲明 state是狀態(tài)名
EFSM_BIND(state, sets) 用于將狀態(tài)state與處理集sets進(jìn)行綁定 state是狀態(tài)名,sets是處理集

2. 狀態(tài)指針操作接口

API 說明 參數(shù)
EFSM_PTR_CREATE(name) 用于創(chuàng)建一個(gè)狀態(tài)機(jī)指針 name是狀態(tài)機(jī)指針名
EFSM_PTR_DECLEAR(name) 當(dāng)在其它地方需要使用到某個(gè)狀態(tài)指針時(shí),用于聲明 name是狀態(tài)機(jī)指針名
EFSM_PTR_BIND(name, state) 用于為狀態(tài)機(jī)指針name綁定到初始狀態(tài)state,只調(diào)用一次 name是狀態(tài)機(jī)指針名,state是狀態(tài)名

3. 狀態(tài)切換接口

API 說明 參數(shù)
EFSM_TRANSFER(name, state) 用于把狀態(tài)機(jī)name切換到state狀態(tài) name是狀態(tài)機(jī)指針名,state是狀態(tài)名
EFSM_TRANSFER_ENABLE(name) 使能狀態(tài)切換功能,在EFSM_TRANSFER()前調(diào)用 name是狀態(tài)機(jī)指針名
EFSM_TRANSFER_DISABLE(name) 除能狀態(tài)切換功能,在EFSM_TRANSFER()后調(diào)用 name是狀態(tài)機(jī)指針名

4. 獲取處理函數(shù)接口

API 說明 參數(shù)
EFSM_HANDLER(name, event) 用與當(dāng)某個(gè)事件到來時(shí),通過該方法獲取到當(dāng)前狀態(tài)下的對(duì)應(yīng)處理方法 name是狀態(tài)機(jī)指針名,event是事件

2.2 使用狀態(tài)機(jī)

若你不關(guān)心狀態(tài)機(jī)的內(nèi)部細(xì)節(jié)實(shí)現(xiàn),需要一個(gè)可直接運(yùn)轉(zhuǎn)的狀態(tài)機(jī),那么請(qǐng)使用efsmt.h頭文件,并將efsmt.c編譯進(jìn)你的源碼。詳細(xì)接口如下。

1. 狀態(tài)操作接口

API 說明 參數(shù)
EFSM_SETS 用于創(chuàng)建某一狀態(tài)下不同時(shí)間的處理集合 類型,無參數(shù)
EFSM_CREATE(state) 用于創(chuàng)建某一狀態(tài)名 state是狀態(tài)名
EFSM_DECLEAR(state) 當(dāng)在其它地方需要使用到某個(gè)狀態(tài)時(shí),用于聲明 state是狀態(tài)名
EFSM_BIND(state, sets) 用于將狀態(tài)state與處理集sets進(jìn)行綁定 state是狀態(tài)名,sets是處理集

2. 狀態(tài)機(jī)操作接口

API 說明 參數(shù)
EFSMT_CREATE(name) 創(chuàng)建一個(gè)狀態(tài)機(jī) name是狀態(tài)機(jī)名
EFSMT_DESTROY(name) 當(dāng)不再使用狀態(tài)機(jī)時(shí),用于銷毀 name是狀態(tài)機(jī)名
EFSMT_DECLEAR(name) 當(dāng)在其它地方需要使用到狀態(tài)機(jī)時(shí),用于聲明 name是狀態(tài)機(jī)名
EFSMT_BIND(name, state) 用于綁定狀態(tài)機(jī)的初始狀態(tài) name是狀態(tài)機(jī)名,state是狀態(tài)名

3. 狀態(tài)切換接口

API 說明 參數(shù)
EFSM_TRANSFER(name, state) 用于把狀態(tài)機(jī)name切換到state狀態(tài) name是狀態(tài)機(jī)指針名,state是狀態(tài)名
EFSM_TRANSFER_ENABLE(name) 使能狀態(tài)切換功能,在EFSM_TRANSFER()前調(diào)用 name是狀態(tài)機(jī)指針名
EFSM_TRANSFER_DISABLE(name) 除能狀態(tài)切換功能,在EFSM_TRANSFER()后調(diào)用 name是狀態(tài)機(jī)指針名

4. 觸發(fā)事件接口

API 說明 參數(shù)
EFSMT_INVOKE(name, event, arg) 當(dāng)事件到來時(shí),觸發(fā)該事件,狀態(tài)機(jī)會(huì)自動(dòng)尋找并調(diào)用對(duì)應(yīng)的處理事件 name是狀態(tài)機(jī)名,event是事件,arg是事件參數(shù)

2.3 總結(jié)

從接口可以看出,創(chuàng)建處理集與狀態(tài)集,和狀態(tài)切換方法是完全一樣的;兩種方法的唯一差異就是:當(dāng)事件來了之后,事件對(duì)應(yīng)的處理是由你來控制,還是由狀態(tài)機(jī)內(nèi)部進(jìn)行控制。

三、使用說明

要使用EFSM,非常簡(jiǎn)單,只需要如下三步:定義事件集、定義狀態(tài)集、使用狀態(tài)集。

3.1 定義事件集

在我們?cè)O(shè)計(jì)業(yè)務(wù)/功能時(shí),首先對(duì)需要使用到的事件進(jìn)行定義。具體實(shí)現(xiàn)方法是在efsm_event.h文件中,使用EFSM_EVENT()宏定義需要的事件。如果你需要定義多個(gè)狀態(tài)機(jī),那請(qǐng)將不同狀態(tài)機(jī)的事件分塊保存,建議使用enum進(jìn)行管理。比如:

enum{
EVENT_PLAY=EFSM_EVENT(1),
EVENT_STOP=EFSM_EVENT(2),
EVENT_NEXT=EFSM_EVENT(3),
EVENT_PREV=EFSM_EVENT(4),
EVENT_START=EFSM_EVENT(7),//notrequirecontinuous
};

3.2 定義狀態(tài)集

  1. 定義狀態(tài):使用EFSM_CREATE(state)創(chuàng)建一個(gè)狀態(tài)state;在其它使用到它的地方用EFSM_DECLEAR(state)宏進(jìn)行聲明;
  2. 定義處理集:使用EFSM_SETS state_sets定義一個(gè)狀態(tài)集合state_sets,其中每個(gè)事件可以對(duì)應(yīng)一個(gè)處理函數(shù),也可以對(duì)應(yīng)多個(gè)函數(shù),當(dāng)然也可以為NULL;處理函數(shù)需滿足如下格式:
typedefvoid(*EFSM_EVENT_HANDLER)(EFSM_EVENT_TYPEevent,void*arg);
  1. 綁定狀態(tài)與處理集:在模塊初始化函數(shù)中調(diào)用EFSM_BIND(state, sets)宏將狀態(tài)state與處理集sets進(jìn)行綁定;

3.3 使用狀態(tài)集

當(dāng)為模塊/產(chǎn)品實(shí)現(xiàn)了所有的狀態(tài),那么編寫業(yè)務(wù)應(yīng)用程序來實(shí)現(xiàn)調(diào)度,讓所有的狀態(tài)機(jī)完美的運(yùn)作起來。具體使用方法如下:

  1. 定義狀態(tài)指針:使用EFSM_PTR_CREATE(name)定義一個(gè)狀態(tài)指針name;當(dāng)然你也可以定義多個(gè)狀態(tài)指針,每個(gè)指針對(duì)應(yīng)一個(gè)狀態(tài)機(jī)。在其它使用到該狀態(tài)指針的地方使用EFSM_PTR_DECLEAR(name)宏進(jìn)行聲明;
  2. 綁定初始狀態(tài):在整個(gè)狀態(tài)機(jī)運(yùn)作之前,需要使用EFSM_PTR_BIND(name, state)宏將狀態(tài)指針name與狀態(tài)state進(jìn)行綁定;
  3. 獲取處理函數(shù)指針:當(dāng)接收到某個(gè)事件時(shí),可以通過EFSM_HANDLER(name,event)宏從狀態(tài)指針name中獲取對(duì)該事件的處理方法,第一個(gè)參數(shù)是狀態(tài)指針,第二個(gè)參數(shù)為事件;
  4. 狀態(tài)切換:當(dāng)遇到某個(gè)事件,或者在事件處理函數(shù)中條件滿足,需要進(jìn)行狀態(tài)切換時(shí),使用下面流程進(jìn)行切換:
EFSM_TRANSFER_ENABLE(name);
EFSM_TRANSFER(name,state);
EFSM_TRANSFER_DISABLE(name);
  • EFSM_TRANSFER_ENABLE(name)宏使能狀態(tài)指針name的切換能力;
  • EFSM_TRANSFER_DISABLE(name)宏除能狀態(tài)指針name的切換能力;
  • EFSM_TRANSFER(name, state)宏執(zhí)行狀態(tài)指針name切換到state;

注意:做狀態(tài)切換時(shí),必須滿足ENABLE()->TRANSFER()->DISABLE()的流程。這么做的目的,是為了讓編程者思考:狀態(tài)設(shè)計(jì)與狀態(tài)的跳轉(zhuǎn)是否必要與合理。

四、常見問題

  1. 使用過程中若遇到如下錯(cuò)誤,是因?yàn)樵谡绞褂们?,沒有把狀態(tài)指針綁定到具體的狀態(tài):
EFSM:cur-state-ptrhave'tbindastate:%xxx!!!
  1. 使用過程中若遇到如下錯(cuò)誤,是因?yàn)闋顟B(tài)切換動(dòng)作不滿足ENABLE()->TRANSFER()->DISABLE()的流程:
EFSM:'xxx'switchto'xxx'failed!!!
  1. 使用過程中,若遇到了死鎖或卡死,是因?yàn)闋顟B(tài)切換動(dòng)作不滿足ENABLE()->TRANSFER()->DISABLE()的流程:
  2. 命名定義了處理函數(shù),為什么每次EFSM_HANDLER()得到的都是NULL?答:因?yàn)槟銢]有將狀態(tài)與事件集進(jìn)行綁定。
  3. 對(duì)于某個(gè)狀態(tài)沒有使用到的事件,我是否可以不對(duì)其定義?答:完全可以,這樣還可以加快EFSM的處理速度。不過不建議直接刪除,而采用注釋的形式,比如:
EFSM_SETSonline[]={{EVENT_PLAY,online_play},
/*{EVENT_STOP,NULL},*/
{EVENT_NEXT,online_next},
/*{EVENT_PREV,NULL},*/
{EVENT_START,online_start},
};

END 原文地址:https://gitee.com/simpost/EFSM/tree/master/ 責(zé)任編輯:haq

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 嵌入式
    +關(guān)注

    關(guān)注

    5150

    文章

    19659

    瀏覽量

    317394
  • 驅(qū)動(dòng)
    +關(guān)注

    關(guān)注

    12

    文章

    1916

    瀏覽量

    86909

原文標(biāo)題:分享一個(gè)基于事件驅(qū)動(dòng)的有限狀態(tài)機(jī)

文章出處:【微信號(hào):gh_c472c2199c88,微信公眾號(hào):嵌入式微處理器】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    NVMe高速傳輸之?dāng)[脫XDMA設(shè)計(jì)之十:NVMe初始化狀態(tài)機(jī)設(shè)計(jì)

    1為NVMe配置初始化狀態(tài)機(jī)狀態(tài)轉(zhuǎn)移圖。各狀態(tài)的說明如下: 圖1NVMe初始化狀態(tài)轉(zhuǎn)移圖 IDLE:空閑狀態(tài),復(fù)位后的初始
    發(fā)表于 07-05 22:03

    NVMe高速傳輸之?dāng)[脫XDMA設(shè)計(jì)之八:PCIe初始化狀態(tài)機(jī)設(shè)計(jì)

    PCIe配置初始化狀態(tài)機(jī)實(shí)現(xiàn)PCIe設(shè)備枚舉和配置空間初始化過程,在完成鏈路訓(xùn)練后,使用DFS(深度優(yōu)先搜索)算法枚舉PCIe總線上的設(shè)備,完成PCIe總線域的地址分配和設(shè)備的初始化。PCIe配置
    發(fā)表于 07-05 22:00

    有可能在 FX3 GPIF2 中創(chuàng)建兩個(gè)獨(dú)立的狀態(tài)機(jī)嗎?

    我想,如果我想通過 FX3 GPIF2 創(chuàng)建兩個(gè)獨(dú)立的傳輸流接口,我需要在 GPIF2 設(shè)計(jì)器中創(chuàng)建兩個(gè)獨(dú)立的狀態(tài)機(jī),我是否有可能在 GPIF2 設(shè)計(jì)器中創(chuàng)建兩個(gè)獨(dú)立的狀態(tài)機(jī)?
    發(fā)表于 05-20 06:14

    cypress3014視頻格式改變的話,GPIF狀態(tài)機(jī)需不需要重新配置?

    你好,請(qǐng)問視頻格式改變的話,GPIF狀態(tài)機(jī)需不需要重新配置
    發(fā)表于 05-14 07:28

    求助,關(guān)于srammaster.cydsn中狀態(tài)機(jī)的問題求解

    晚上好。 我目前正在學(xué)習(xí) GPIF II。 查看..EZ-USB FX3 SDK1.3firmwaregpif_examplescyfxsrammastersrammaster.cydsn中的狀態(tài)機(jī),有狀態(tài)START和START1。 這意味著什么?
    發(fā)表于 05-12 06:20

    NVME控制器設(shè)計(jì)之指令控制

    指令控制模塊由一個(gè)指令信息緩存, 一個(gè)指令組裝狀態(tài)機(jī)和一個(gè) ID 池組成。 指令信息緩存中存放著由系統(tǒng)控制模塊寫入的待處理指令信息; 指令組裝狀態(tài)機(jī)獲取緩存的指令信息, 將其組裝成提交隊(duì)列條目寫入提交隊(duì)列中; ID 池則用于存放可使用的指令 ID。
    的頭像 發(fā)表于 04-24 10:22 ?281次閱讀
    NVME控制器設(shè)計(jì)之指令控制

    高速ssd存儲(chǔ)系統(tǒng)中數(shù)據(jù)緩存控制器流程控制設(shè)計(jì)

    高速SSD系統(tǒng)中流程控制模塊設(shè)計(jì)。該模塊主要由寄存器、讀狀態(tài)機(jī)、寫狀態(tài)機(jī)和命令生成模塊組成,系統(tǒng)介紹各模塊功能。
    的頭像 發(fā)表于 04-14 10:43 ?267次閱讀
    高速ssd存儲(chǔ)系統(tǒng)中數(shù)據(jù)緩存控制器流程控制設(shè)計(jì)

    基于FPGA的DS18B20數(shù)字溫度傳感器測(cè)溫實(shí)例

    本文將使用三段式狀態(tài)機(jī)(Moore型)的寫法來對(duì)DS18B20進(jìn)行測(cè)溫操作,以便了解DS18B20和熟悉三段式狀態(tài)機(jī)的寫法。
    的頭像 發(fā)表于 03-17 11:06 ?1486次閱讀
    基于FPGA的DS18B20數(shù)字溫度傳感器測(cè)溫實(shí)例

    如何快速入門PLD電路設(shè)計(jì)

    基本的數(shù)字邏輯概念,如與、或、非、異或等邏輯門。 布爾代數(shù) :掌握布爾代數(shù)的基本原理,這對(duì)于設(shè)計(jì)復(fù)雜的邏輯電路至關(guān)重要。 狀態(tài)機(jī) :學(xué)習(xí)有限狀態(tài)機(jī)(F
    的頭像 發(fā)表于 01-20 09:48 ?884次閱讀

    Simulink中的狀態(tài)機(jī)建模方法 Simulink數(shù)據(jù)可視化與分析功能

    1. Simulink中的狀態(tài)機(jī)建模方法 1.1 理解狀態(tài)機(jī)的基本概念 在開始建模之前,了解狀態(tài)機(jī)的基本概念是必要的。狀態(tài)機(jī)由以下幾個(gè)部分組成:
    的頭像 發(fā)表于 12-12 09:27 ?2985次閱讀

    基于狀態(tài)機(jī)和面向?qū)ο蟮乃枷朐O(shè)計(jì)按鍵檢測(cè)模塊

    嵌入式入門學(xué)習(xí)的教程里面,按鍵原理普遍被認(rèn)為是“很簡(jiǎn)單”的知識(shí)點(diǎn)之一,按鍵輸入檢測(cè)的原理,無非就是通過CPU不斷掃描按鍵引腳的電平狀態(tài),或者采用單片機(jī)引腳外部中斷方式,然后在死循環(huán)或者中斷服務(wù)程序里面處理按鍵被按下
    的頭像 發(fā)表于 11-14 11:44 ?950次閱讀
    基于<b class='flag-5'>狀態(tài)機(jī)</b>和面向?qū)ο蟮乃枷朐O(shè)計(jì)按鍵檢測(cè)模塊

    【「數(shù)字IC設(shè)計(jì)入門」閱讀體驗(yàn)】+目錄和前2章

    建模139 12.4條件操作建模141 12.5同步時(shí)序邏輯建模142 12.6通用移位寄存器145 12.7狀態(tài)機(jī)建模145 12.8交互狀態(tài)機(jī)147 12.9Moore有限狀態(tài)機(jī)建模150 12.10Mealy型
    發(fā)表于 10-10 17:12

    時(shí)序邏輯電路的描述方法有哪些

    圖、狀態(tài)表、有限狀態(tài)機(jī)、卡諾圖、布爾差分方程、布爾函數(shù)、時(shí)序邏輯仿真等。 狀態(tài)狀態(tài)圖是一種圖形化的描述方法,用于表示時(shí)序邏輯電路的狀態(tài)轉(zhuǎn)
    的頭像 發(fā)表于 08-28 11:37 ?1407次閱讀

    觸發(fā)器和狀態(tài)機(jī)的關(guān)系是什么

    觸發(fā)器和狀態(tài)機(jī)在數(shù)字電路設(shè)計(jì)中有著緊密的關(guān)系,它們共同構(gòu)成了時(shí)序邏輯電路的基礎(chǔ),用于實(shí)現(xiàn)數(shù)據(jù)的存儲(chǔ)、處理和傳輸。
    的頭像 發(fā)表于 08-12 11:24 ?940次閱讀

    如何在FPGA中實(shí)現(xiàn)狀態(tài)機(jī)

    在FPGA(現(xiàn)場(chǎng)可編程門陣列)中實(shí)現(xiàn)狀態(tài)機(jī)是一種常見的做法,用于控制復(fù)雜的數(shù)字系統(tǒng)行為。狀態(tài)機(jī)能夠根據(jù)當(dāng)前的輸入和系統(tǒng)狀態(tài),決定下一步的動(dòng)作和新的狀態(tài)。這里,我們將詳細(xì)探討如何在FPG
    的頭像 發(fā)表于 07-18 15:57 ?1225次閱讀