《電子技術(shù)應(yīng)用》
您所在的位置:首頁 > 可編程邏輯 > 設(shè)計應(yīng)用 > 在FPGA中實現(xiàn)狀態(tài)機的方法
在FPGA中實現(xiàn)狀態(tài)機的方法
摘要: 狀態(tài)機往往是FPGA開發(fā)的主力。選擇合適的架構(gòu)和實現(xiàn)方法將確保您獲得一款最佳解決方案FPGA常常用于執(zhí)行基于序列和控制的行動,比如實現(xiàn)一個簡單的通信協(xié)議。對于設(shè)計人員來說,滿足這些行動和序列
關(guān)鍵詞: FPGA 狀態(tài)機
Abstract:
Key words :
 
狀態(tài)機往往是FPGA 開發(fā)的主力。選擇合適的架構(gòu)和實現(xiàn)方法將確保您獲得一款最佳解決方案
FPGA 常常用于執(zhí)行基于序列和控制的行動, 比如實現(xiàn)一個簡單的通信協(xié)議。對于設(shè)計人員來說,滿足這些行動和序列要求的最佳方法則是使用狀態(tài)機。狀態(tài)機是在數(shù)量有限的狀態(tài)之間進(jìn)行轉(zhuǎn)換的邏輯結(jié)構(gòu)。一個狀態(tài)機在某個特定的時間點只處于一種狀態(tài)。但在一系列觸發(fā)器的觸發(fā)下,將在不同狀態(tài)間進(jìn)行轉(zhuǎn)換。理論上講,狀態(tài)機可以分為Moore 狀態(tài)機和Mealy 狀態(tài)機兩大類。它們之間的差異僅在于如何生成狀態(tài)機的輸出。Moore 狀態(tài)機的輸出僅為當(dāng)前狀態(tài)的函數(shù)。典型的例子就是計數(shù)器。而Mealy 狀態(tài)機的輸出是當(dāng)前狀態(tài)和輸入的函數(shù)。典型的例子就是Richards 控制器。
定義狀態(tài)機
      當(dāng)需要定義一個狀態(tài)機時,首先要繪制一張狀態(tài)圖。狀態(tài)圖可用來顯示狀態(tài)、狀態(tài)間的轉(zhuǎn)換和狀態(tài)機的輸出。圖1 顯示了Moore 狀態(tài)機的狀態(tài)圖(左)和Mealy 狀態(tài)機的狀態(tài)圖(右)。
 
圖1
如果要在物理組件中實現(xiàn)這些狀態(tài)圖,首先要生成當(dāng)前狀態(tài)和后續(xù)狀態(tài)表,然后生成實現(xiàn)狀態(tài)機所需的邏輯。不過由于我們將使用FPGA來實現(xiàn)設(shè)計,因此我們可以直接從狀態(tài)轉(zhuǎn)換圖開始工作。
算法狀態(tài)圖
      雖然有許多狀態(tài)機是使用圖1 所示的狀態(tài)圖方法進(jìn)行設(shè)計的,但另外還有一種描述狀態(tài)機行為的方法,這就是算法狀態(tài)圖法。ASM 圖(圖2)在外觀上更加接近軟件工程流程圖。它由三個基本部分構(gòu)成:
       1. 狀態(tài)框。它與狀態(tài)名稱有關(guān),并包含Moore 狀態(tài)輸出列表。
       2. 決策框。如果檢驗?zāi)硹l件為真,則進(jìn)行下一狀態(tài)的判斷。
       3. 條件輸出框。讓狀態(tài)機根據(jù)當(dāng)前狀態(tài)和輸入描述Mealy輸出。
一些工程師認(rèn)為,如果使用VHDL 等硬件描述語言,則采用ASM 格式進(jìn)行描述的狀態(tài)更易于映射到實現(xiàn)方案中機。
 
 
圖2
MOORE 和MEALY:應(yīng)該選擇哪個?
      實現(xiàn)Moore 狀態(tài)機還是Mealy 狀態(tài)機,取決于狀態(tài)機需要實現(xiàn)的功能,以及特定的反應(yīng)次數(shù)要求。兩種狀態(tài)機之間的最大差別在于狀態(tài)機如何對輸入做出反應(yīng)。在輸入和設(shè)置的適當(dāng)輸出之間,Moore 狀態(tài)機一般有一個時鐘周期的延遲。這就意味著Moore 狀態(tài)機無法對輸入變化立即做出反應(yīng),這點在圖3中可以清楚地看到。而Mealy 狀態(tài)機則能夠立即對輸入做出反應(yīng),這通常意味著:實現(xiàn)相同的函數(shù),Mealy 狀態(tài)機比Moore狀態(tài)機需要更少的狀態(tài)。Mealy 狀態(tài)機的不足之處就是在與另一個狀態(tài)機進(jìn)行通信時,如果輸出出乎意料地嚴(yán)重依賴于其它事件的序列或時序,就可能會發(fā)生紊亂情況。
當(dāng)然,并非只能使用單純的Moore狀態(tài)機或Mealy 狀態(tài)機,也可以將這兩種狀態(tài)機混合使用,從而更有效地實現(xiàn)所需的函數(shù)。比如說,用于接收RS232 串行數(shù)據(jù)的狀態(tài)機就可以是混合機。
 實現(xiàn)狀態(tài)機
使用VHDL 這樣的高級語言,可以輕松地直接從狀態(tài)圖實現(xiàn)狀態(tài)機。VHDL 支持多種枚舉類型,方便您定義實際的狀態(tài)名稱。舉例如下:
上面的類型定義對應(yīng)的是圖1 中所示的狀態(tài)圖,即用于在按下按鈕時切換發(fā)光二極管開/ 關(guān)的狀態(tài)機。
實現(xiàn)狀態(tài)機有許多種方法,可分為兩類基本方法。第一類基本方法就是一次性將所有內(nèi)容集成到單個進(jìn)程中。第二類基本方法是雙進(jìn)程法,將組合邏輯和順序邏輯分開。
一般來說,大多數(shù)工程師都傾向于實現(xiàn)單進(jìn)程狀態(tài)機。與傳統(tǒng)上講授的雙進(jìn)程法相比,這種方法具有以下優(yōu)勢:
      • 可以避免組合過程中信號覆蓋不完全造成的閉鎖風(fēng)險。
      • 狀態(tài)機的輸出與時鐘保持同步。
      • 通常比雙進(jìn)程實現(xiàn)方案更容易調(diào)試。
無論您決定采用哪一種方法來實現(xiàn)狀態(tài)機,都需要使用CASE 語句來評估下一狀態(tài)的判定和任何輸出。

狀態(tài)機編碼
     狀態(tài)變量存儲在觸發(fā)器中,使用下一時鐘邊緣上的下一狀態(tài)進(jìn)行更新(即使沒有狀態(tài)變化也是如此)。如何使用觸發(fā)器來表示狀態(tài)值具體取決于狀態(tài)的數(shù)量和是否選擇用某種特定的方法來管理綜合工具。狀態(tài)編碼最常見的三種類型是:
      • 順序碼——狀態(tài)編碼遵循傳統(tǒng)的狀態(tài)二進(jìn)制序列。
      • 格雷碼——除了狀態(tài)編碼使用格雷碼,且狀態(tài)編碼串之間只有一個位變化外,其它基本與順序編碼方法類似。
      • 獨熱碼——這種方法在狀態(tài)機中為每一種狀態(tài)分配一個觸發(fā)器。只有一個觸發(fā)器當(dāng)前設(shè)置為高位,其余均設(shè)置為低位。故稱為“獨熱”。

順序編碼和格雷編碼都需要一定數(shù)量的觸發(fā)器,可以通過下列等式來確定:

 

 

相比之下,獨熱編碼法所需的觸發(fā)器數(shù)量和狀態(tài)數(shù)量一樣多。
狀態(tài)編碼的自動分配取決于狀態(tài)機所包含的狀態(tài)數(shù)量。同時還需要考慮您選擇使用的綜合工具。您可以根據(jù)下列經(jīng)驗法則來選取編碼方法:
      • 順序:少于5 種狀態(tài)。
      • 獨熱:5-50 種狀態(tài)。
      • 格雷:多于50 種狀態(tài)。
一般情況下您不必去考慮使用哪一種狀態(tài)編碼方法,而是讓綜合引擎工具確定合適的實現(xiàn)方案,只在選擇的方法出現(xiàn)問題時進(jìn)行考慮。但是,如果您要全盤自行掌控,并定義狀態(tài)編碼方法,也沒必要手動操作,只需使用狀態(tài)編碼為每一種狀態(tài)設(shè)定常數(shù)即可。相反地,可以使用代碼中的一個屬性來驅(qū)動綜合工具,從而選擇特定的編碼方法。具體如下所示:

TYPE state ISidle,led_on,led_off;

SIGNAL current_state:state:=idle;

ATTRIBUTE syn_encoding STRING;

ATTRIBUTE syn_encoding OF current_state:

SIGNAL IS “sequential”;

其中“sequential”也可以是“gray”和“onehot”。您還可以通過結(jié)合使用“safe”屬性來確保在狀態(tài)機進(jìn)入非法狀態(tài)時能夠恢復(fù)到有效狀態(tài)。

另外,您也可以使用syn_encoding 屬性直接定義狀態(tài)編碼的值。例如,假設(shè)您想要使用下列狀態(tài)編碼法來對三態(tài)狀態(tài)機進(jìn)行編碼:Idle = “11,” led_on = “10,” led_off = “01(與較傳統(tǒng)的順序“00”、“01”和“10”不同)。

前面給出的等式可確定狀態(tài)機實現(xiàn)方案所需的觸發(fā)器數(shù)量。由于不是所有的狀態(tài)機都是2 的冪次方,因此某些狀態(tài)在設(shè)計中將不會用到。實現(xiàn)狀態(tài)機的工程師必須負(fù)責(zé)確保未使用的狀態(tài)在設(shè)計中得到妥善處理。可以采用幾種適用于多種設(shè)計的基本技巧來實現(xiàn)這一目標(biāo)。對于高度可靠的安全關(guān)鍵型設(shè)計,則需要采用其它更高級的技巧。

不過對于大多數(shù)應(yīng)用來說,只需要確保狀態(tài)機能夠妥善地處理未使用的狀態(tài)并在進(jìn)入非法狀態(tài)時能夠正確地恢復(fù)。要做到這一點有兩種主要的方法。第一種方法是使用綜合工具實現(xiàn)一個安全的狀態(tài)機。綜合工具通常會插入額外的邏輯,用于檢測非法狀態(tài)并將狀態(tài)機返回到有效狀態(tài)。第二種方法是加強對實現(xiàn)邏輯的控制,聲明所有2 的冪次方狀態(tài)機的狀態(tài),并使用另一屬性來確保即便是在沒有入口條件下,2 的冪次方狀態(tài)機的狀態(tài)也不會被優(yōu)化掉。這意味著除非出錯(單粒子翻轉(zhuǎn)等),狀態(tài)機內(nèi)部的任何條件都不會進(jìn)入狀態(tài)。下面的代碼顯示了通過使用屬性以防止清除未使用的狀態(tài)。

TYPE state IS(idle,led_on,led_off);
SIGNAL current_state:state:=idle;
ATTRIBUTE syn_keep BOOLEEAN;
ATTRIBUTE syn_keep OF current_state:

SIGNAL IS “TURE”;

安全高效的狀態(tài)機設(shè)計對于任何使用FPGA的工程師而言都是一項重要技能。選擇Moore 狀態(tài)機、Mealy狀態(tài)機還是混合機取決于整個系統(tǒng)的需求。無論選擇哪種類型的狀態(tài)機,充分掌握實現(xiàn)方案所需的工具和技巧,將確保您實現(xiàn)最佳解決方案。

 

 

 
 
 
此內(nèi)容為AET網(wǎng)站原創(chuàng),未經(jīng)授權(quán)禁止轉(zhuǎn)載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
亚洲亚洲精品三区日韩精品在线视频 | 久久精品成人一区二区三区 | 午夜视频在线观看一区二区三区| 亚洲日本中文字幕| 亚洲国产精品一区二区三区| 久久av免费一区| 欧美一乱一性一交一视频| 亚洲综合久久久久| 亚洲与欧洲av电影| 亚洲一区欧美一区| 亚洲天堂av在线免费| 一区二区三区福利| 亚洲网站在线观看| 亚洲一区制服诱惑| 亚洲欧美日韩视频一区| 午夜国产一区| 欧美一区二区三区四区在线| 欧美一区二区三区视频免费| 亚洲第一精品夜夜躁人人爽| 亚洲国产精品va| 亚洲日本成人在线观看| 亚洲精品在线观看视频| 一本一本a久久| 亚洲欧美www| 香蕉成人啪国产精品视频综合网| 欧美一区国产在线| 久久亚洲欧洲| 欧美精品播放| 欧美天天在线| 国产日韩欧美综合在线| 影音先锋日韩资源| 亚洲精品资源| 亚洲免费在线播放| 亚洲高清精品中出| 日韩一级黄色av| 亚洲在线一区| 久久久久久999| 欧美第一黄色网| 欧美日韩一区在线观看| 国产精品亚洲欧美| 狠狠入ady亚洲精品| 亚洲国产综合在线| 亚洲视频网在线直播| 午夜精品久久久久久99热软件 | 国产精品99久久久久久久女警| 亚洲一区二区三区免费观看| 欧美在线视频观看| 男同欧美伦乱| 国产精品国产三级国产专播精品人| 国产精品自拍在线| 在线精品视频一区二区三四| 亚洲免费观看高清完整版在线观看熊 | 国产精品久久久久久亚洲调教 | 精品91在线| 99国产一区| 欧美制服丝袜| 一本色道久久综合亚洲二区三区| 欧美亚洲专区| 欧美+日本+国产+在线a∨观看| 欧美性做爰毛片| 狠狠入ady亚洲精品经典电影| 最新国产成人av网站网址麻豆| 亚洲视频网在线直播| 亚洲国产一区二区a毛片| 亚洲一区二区欧美| 久久婷婷国产综合国色天香| 欧美日韩在线精品| 国内精品嫩模av私拍在线观看 | 91久久国产综合久久蜜月精品| 亚洲图片欧洲图片日韩av| 久久婷婷亚洲| 国产精品美女久久久| 亚洲电影免费| 亚洲男人的天堂在线观看| 亚洲老板91色精品久久| 久久超碰97人人做人人爱| 欧美日韩国产电影| 伊人伊人伊人久久| 亚洲欧美激情视频| 一本色道久久综合亚洲精品婷婷| 久久天天躁夜夜躁狠狠躁2022| 欧美三级午夜理伦三级中文幕| 黄色资源网久久资源365| 亚洲视频在线一区| 99re6热只有精品免费观看 | 欧美成人免费观看| 国产一区二区三区久久 | 欧美在线视频免费播放| 亚洲视频中文字幕| 欧美黄色日本| 精品91在线| 午夜免费久久久久| 亚洲一区三区视频在线观看| 欧美国产极速在线| 激情五月***国产精品| 性xx色xx综合久久久xx| 亚洲永久免费视频| 欧美国产一区视频在线观看| 激情综合五月天| 欧美一乱一性一交一视频| 先锋影音国产一区| 国产精品久久久久久超碰| 亚洲伦伦在线| 亚洲精品日韩在线| 玖玖在线精品| 国内精品久久久久影院色| 销魂美女一区二区三区视频在线| 亚洲女爱视频在线| 欧美视频二区| 99pao成人国产永久免费视频| 亚洲人精品午夜在线观看| 快射av在线播放一区| 海角社区69精品视频| 欧美影片第一页| 久久av最新网址| 国产女主播在线一区二区| 亚洲视频自拍偷拍| 亚洲欧美国产日韩天堂区| 欧美视频在线免费看| 一区二区久久久久久| 一区二区久久久久| 欧美日韩免费在线| 一区二区国产精品| 午夜精品久久久久99热蜜桃导演| 国产精品xxx在线观看www| av不卡在线观看| 亚洲综合精品一区二区| 国产精品对白刺激久久久| 亚洲线精品一区二区三区八戒| 亚洲欧美三级在线| 国产欧美视频在线观看| 午夜日韩福利| 久久亚洲综合色| 亚洲韩国精品一区| 一本大道久久a久久精二百| 欧美三级免费| 亚洲无限av看| 欧美专区第一页| 国内精品一区二区| 91久久精品一区| 欧美刺激午夜性久久久久久久| 亚洲国产精品一区二区第一页 | 欧美日韩精品一区二区天天拍小说| 亚洲免费成人| 亚洲欧美综合另类中字| 国产欧美va欧美va香蕉在| 久久精品夜夜夜夜久久| 欧美大学生性色视频| 一本大道久久a久久精二百| 性欧美videos另类喷潮| 国产在线播放一区二区三区| 亚洲第一狼人社区| 欧美全黄视频| 亚洲一区欧美| 国产精品国产三级国产aⅴ入口 | 亚洲电影免费在线观看| 亚洲黄页视频免费观看| 欧美激情按摩在线| 一本色道久久综合亚洲精品不卡 | 国产日韩精品视频一区二区三区| 久久疯狂做爰流白浆xx| 欧美夫妇交换俱乐部在线观看| 亚洲精品国产欧美| 亚洲欧美在线免费| 激情久久五月天| 一本在线高清不卡dvd | 欧美一区二区视频观看视频| 蜜臀久久99精品久久久久久9| 日韩西西人体444www| 欧美在线视频一区| 亚洲高清不卡av| 亚洲在线观看| 在线观看视频亚洲| 亚洲欧美日韩国产一区二区三区 | 校园春色国产精品| 亚洲第一伊人| 午夜伦欧美伦电影理论片| 在线精品国产欧美| 亚洲欧美中日韩| 亚洲国产精品久久精品怡红院| 亚洲欧美日韩中文播放| 揄拍成人国产精品视频| 亚洲一区免费| 亚洲国产精品传媒在线观看| 午夜精品区一区二区三| 亚洲第一色在线| 欧美主播一区二区三区| 日韩视频免费看| 久久久夜夜夜| 亚洲午夜久久久| 欧美国产亚洲另类动漫| 午夜精品久久一牛影视| 欧美日韩不卡合集视频| 久久精品国产99国产精品澳门| 欧美三级免费| 亚洲人成亚洲人成在线观看图片| 国产精品乱看| 夜夜精品视频一区二区| 在线观看精品视频| 久久久国产视频91|