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

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

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

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

STM32嵌入式開發(fā) ? 來(lái)源:gitee.com ? 2023-08-30 09:28 ? 次閱讀

來(lái)源:https://gitee.com/simpost/EFSM/tree/master/

介紹

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)心:

當(dāng)事件到來(lái)時(shí),通過EFSM取得對(duì)應(yīng)事件的處理方法;

當(dāng)特定事件到來(lái),或者條件滿足時(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總共提供了兩套接口,你只需要選擇其中套用法即可。全部接口概述如下:

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

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

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

1d1ec06e-46b9-11ee-a2ef-92fbcf53809c.png

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

1d3ae50a-46b9-11ee-a2ef-92fbcf53809c.png

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

1d4bfd68-46b9-11ee-a2ef-92fbcf53809c.png

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

1d62a5f4-46b9-11ee-a2ef-92fbcf53809c.png

使用狀態(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)操作接口

1d6aa1d2-46b9-11ee-a2ef-92fbcf53809c.png

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

1d7d3af4-46b9-11ee-a2ef-92fbcf53809c.png

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

1d9aaef4-46b9-11ee-a2ef-92fbcf53809c.png

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

1db5239c-46b9-11ee-a2ef-92fbcf53809c.png

總結(jié)

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

使用說明

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

定義事件集

在我們?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),    //not require continuous
 };

定義狀態(tài)集

定義狀態(tài):使用EFSM_CREATE(state)創(chuàng)建一個(gè)狀態(tài)state;在其它使用到它的地方用EFSM_DECLEAR(state)宏進(jìn)行聲明;

定義處理集:使用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);

綁定狀態(tài)與處理集:在模塊初始化函數(shù)中調(diào)用EFSM_BIND(state, sets)宏將狀態(tài)state與處理集sets進(jìn)行綁定;

使用狀態(tài)集

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

定義狀態(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)行聲明;

綁定初始狀態(tài):在整個(gè)狀態(tài)機(jī)運(yùn)作之前,需要使用EFSM_PTR_BIND(name, state)宏將狀態(tài)指針name與狀態(tài)state進(jìn)行綁定;

獲取處理函數(shù)指針:當(dāng)接收到某個(gè)事件時(shí),可以通過EFSM_HANDLER(name,event)宏從狀態(tài)指針name中獲取對(duì)該事件的處理方法,第一個(gè)參數(shù)是狀態(tài)指針,第二個(gè)參數(shù)為事件;

狀態(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)是否必要與合理。

常見問題

使用過程中若遇到如下錯(cuò)誤,是因?yàn)樵谡绞褂们埃瑳]有把狀態(tài)指針綁定到具體的狀態(tài):


EFSM: cur-state-ptr have't bind a state: %xxx!!!
使用過程中若遇到如下錯(cuò)誤,是因?yàn)闋顟B(tài)切換動(dòng)作不滿足ENABLE()->TRANSFER()->DISABLE()的流程:
EFSM:'xxx'switchto'xxx'failed!!!
使用過程中,若遇到了死鎖或卡死,是因?yàn)闋顟B(tài)切換動(dòng)作不滿足ENABLE()->TRANSFER()->DISABLE()的流程。 命名定義了處理函數(shù),為什么每次EFSM_HANDLER()得到的都是NULL?答:因?yàn)槟銢]有將狀態(tài)與事件集進(jìn)行綁定。 對(duì)于某個(gè)狀態(tài)沒有使用到的事件,我是否可以不對(duì)其定義? 答:完全可以,這樣還可以加快EFSM的處理速度。不過不建議直接刪除,而采用注釋的形式,比如:

EFSM_SETS online[] = { {EVENT_PLAY, online_play},
                        /*{EVENT_STOP, NULL}, */
                        {EVENT_NEXT, online_next},
                        /*{EVENT_PREV, NULL}, */
                        {EVENT_START, online_start},
                      };

審核編輯:湯梓紅

聲明:本文內(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)注

    33

    文章

    8447

    瀏覽量

    150720
  • 源碼
    +關(guān)注

    關(guān)注

    8

    文章

    632

    瀏覽量

    29110
  • 函數(shù)
    +關(guān)注

    關(guān)注

    3

    文章

    4277

    瀏覽量

    62323
  • 狀態(tài)機(jī)
    +關(guān)注

    關(guān)注

    2

    文章

    491

    瀏覽量

    27456

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

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

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    FPGA有限狀態(tài)機(jī)

    FPGA有限狀態(tài)機(jī)
    發(fā)表于 09-08 08:45

    有限狀態(tài)機(jī)有什么類型?

    在實(shí)際的應(yīng)用中,根據(jù)有限狀態(tài)機(jī)是否使用輸入信號(hào),設(shè)計(jì)人員經(jīng)常將其分為Moore型有限狀態(tài)機(jī)和Mealy型有限狀態(tài)機(jī)兩種類型。
    發(fā)表于 04-06 09:00

    什么是有限狀態(tài)機(jī)

    在嵌入式,機(jī)器人領(lǐng)域,由于多的復(fù)雜邏輯狀態(tài),我們編寫程序的時(shí)候不得不考慮很多種情況,容易造成功能間的沖突。有限狀態(tài)機(jī)(finite-state machine),簡(jiǎn)稱狀態(tài)機(jī),是種表示
    發(fā)表于 12-20 06:51

    有限狀態(tài)機(jī)_FSM_的實(shí)現(xiàn)

    本文主要介紹了IP模塊的有限狀態(tài)機(jī)的實(shí)現(xiàn)。
    發(fā)表于 03-22 15:42 ?0次下載

    有限狀態(tài)機(jī)FSM在PLD中的實(shí)現(xiàn)分析

    本文通過舉例 利用VHDL 語(yǔ)言描述了不同模式的有限狀態(tài)機(jī) 分析了有限狀態(tài)機(jī)在 PLD 中綜合的特點(diǎn) 。
    發(fā)表于 03-22 15:41 ?3次下載

    有限狀態(tài)機(jī)的建模與優(yōu)化設(shè)計(jì)

    本文提出種優(yōu)秀 、高效的 Verilog HDL 描述方式來(lái)進(jìn)行有限狀態(tài)機(jī)設(shè)計(jì) 介紹了 有限狀態(tài)機(jī)的建模原則 并通過個(gè)可綜合的實(shí)例 驗(yàn)證
    發(fā)表于 03-22 15:19 ?1次下載

    VHDL有限狀態(tài)機(jī)設(shè)計(jì)-ST

    EDA的有限狀態(tài)機(jī),廣義而言是指只要涉及觸發(fā)器的電路,無(wú)論電路大小都可以歸結(jié)為狀態(tài)機(jī)。有限狀態(tài)機(jī)設(shè)計(jì)在學(xué)習(xí)EDA時(shí)是很重要的章。
    發(fā)表于 06-08 16:46 ?3次下載

    初學(xué)者對(duì)有限狀態(tài)機(jī)(FSM)的設(shè)計(jì)的認(rèn)識(shí)

    有限狀態(tài)機(jī)(FSM)是種常見的電路,由時(shí)序電路和組合電路組成。設(shè)計(jì)有限狀態(tài)機(jī)的第步是確定采用Moore狀態(tài)機(jī)還是采用Mealy
    發(fā)表于 02-11 13:51 ?4259次閱讀
    初學(xué)者對(duì)<b class='flag-5'>有限狀態(tài)機(jī)</b>(FSM)的設(shè)計(jì)的認(rèn)識(shí)

    基于有限狀態(tài)機(jī)的Linux多點(diǎn)觸摸屏驅(qū)動(dòng)設(shè)計(jì)劉斌

    基于有限狀態(tài)機(jī)的Linux多點(diǎn)觸摸屏驅(qū)動(dòng)設(shè)計(jì)_劉斌
    發(fā)表于 03-15 08:00 ?0次下載

    如何使用FPGA實(shí)現(xiàn)序列檢測(cè)有限狀態(tài)機(jī)

    有限狀態(tài)機(jī)是絕大部分控制電路的核心結(jié)構(gòu), 是表示有限個(gè)狀態(tài)以及在這些狀態(tài)之間轉(zhuǎn)移和動(dòng)作等行為的數(shù)學(xué)模型。
    發(fā)表于 11-04 17:17 ?12次下載
    如何使用FPGA實(shí)現(xiàn)序列檢測(cè)<b class='flag-5'>有限狀態(tài)機(jī)</b>

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

    ? 、介紹 EFSM(event finite state machine,事件驅(qū)動(dòng)有限狀態(tài)機(jī)),是個(gè)基于事件
    的頭像 發(fā)表于 11-16 15:29 ?2297次閱讀

    如何以面向?qū)ο蟮乃枷朐O(shè)計(jì)有限狀態(tài)機(jī)

    有限狀態(tài)機(jī)又稱有限狀態(tài)自動(dòng)機(jī),簡(jiǎn)稱狀態(tài)機(jī),是表示有限個(gè)狀態(tài)
    發(fā)表于 02-07 11:23 ?4次下載
    如何以面向?qū)ο蟮乃枷朐O(shè)計(jì)<b class='flag-5'>有限狀態(tài)機(jī)</b>

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

    EFSM(event finite state machine,事件驅(qū)動(dòng)有限狀態(tài)機(jī)),是個(gè)基于事件驅(qū)動(dòng)
    的頭像 發(fā)表于 02-11 10:17 ?1015次閱讀

    有限狀態(tài)機(jī)分割設(shè)計(jì)

    有限狀態(tài)機(jī)分割設(shè)計(jì),其實(shí)質(zhì)就是個(gè)狀態(tài)機(jī)分割成多個(gè)狀態(tài)機(jī)
    的頭像 發(fā)表于 10-09 10:47 ?602次閱讀

    基于有限狀態(tài)機(jī)的車身防盜報(bào)警的實(shí)現(xiàn)

    電子發(fā)燒友網(wǎng)站提供《基于有限狀態(tài)機(jī)的車身防盜報(bào)警的實(shí)現(xiàn).pdf》資料免費(fèi)下載
    發(fā)表于 10-26 09:48 ?0次下載
    基于<b class='flag-5'>有限狀態(tài)機(jī)</b>的車身防盜報(bào)警的實(shí)現(xiàn)