国产毛片a精品毛-国产毛片黄片-国产毛片久久国产-国产毛片久久精品-青娱乐极品在线-青娱乐精品

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

發(fā)布時(shí)間:2013-4-3 10:32    發(fā)布者:eechina
關(guān)鍵詞: FPGA , 狀態(tài)機(jī)
作者:EADS Astrium公司首席工程師 Adam Taylor

FPGA常常用于執(zhí)行基于序列和控制的行動,比如實(shí)現(xiàn)一個(gè)簡單的通信協(xié)議。對于設(shè)計(jì)人員來說,滿足這些行動和序列要求的最佳方法則是使用狀態(tài)機(jī)。狀態(tài)機(jī)是在數(shù)量有限的狀態(tài)之間進(jìn)行轉(zhuǎn)換的邏輯結(jié)構(gòu)。一個(gè)狀態(tài)機(jī)在某個(gè)特定的時(shí)間點(diǎn)只處于一種狀態(tài)。但在一系列觸發(fā)器的觸發(fā)下,將在不同狀態(tài)間進(jìn)行轉(zhuǎn)換。

理論上講,狀態(tài)機(jī)可以分為Moore狀態(tài)機(jī)和Mealy狀態(tài)機(jī)兩大類。它們之間的差異僅在于如何生成狀態(tài)機(jī)的輸出。Moore狀態(tài)機(jī)的輸出僅為當(dāng)前狀態(tài)的函數(shù)。典型的例子就是計(jì)數(shù)器。而Mealy狀態(tài)機(jī)的輸出是當(dāng)前狀態(tài)和輸入的函數(shù)。典型的例子就是Richards控制器。

定義狀態(tài)機(jī)


當(dāng)需要定義一個(gè)狀態(tài)機(jī)時(shí),首先要繪制一張狀態(tài)圖。狀態(tài)圖可用來顯示狀態(tài)、狀態(tài)間的轉(zhuǎn)換和狀態(tài)機(jī)的輸出。圖1顯示了Moore狀態(tài)機(jī)的狀態(tài)圖(左)和Mealy狀態(tài)機(jī)的狀態(tài)圖(右)。


圖1,用于開/關(guān)LED的Moore狀態(tài)機(jī)(左)和Mealy狀態(tài)機(jī)(右)的狀態(tài)圖。

如果您要在物理組件中實(shí)現(xiàn)這些狀態(tài)圖(工程師在FPGA問世之前就是這么做的),首先就得生成當(dāng)前狀態(tài)和后續(xù)狀態(tài)表,然后生成實(shí)現(xiàn)狀態(tài)機(jī)所需的邏輯。不過由于我們將使用FPGA來實(shí)現(xiàn)設(shè)計(jì),因此我們可以直接從狀態(tài)轉(zhuǎn)換圖開始工作。

算法狀態(tài)圖

雖然有許多狀態(tài)機(jī)是使用圖1所示的狀態(tài)圖方法進(jìn)行設(shè)計(jì)的,但另外還有一種描述狀態(tài)機(jī)行為的方法,這就是算法狀態(tài)圖法。ASM圖(圖2)在外觀上更加接近軟件工程流程圖。它由三個(gè)基本部分構(gòu)成:

1. 狀態(tài)框。它與狀態(tài)名稱有關(guān),并包含Moore狀態(tài)輸出列表。

2. 決策框。如果檢驗(yàn)?zāi)硹l件為真,則進(jìn)行下一狀態(tài)的判斷。

3. 條件輸出框。讓狀態(tài)機(jī)根據(jù)當(dāng)前狀態(tài)和輸入描述Mealy輸出。

一些工程師認(rèn)為,如果使用VHDL等硬件描述語言,則采用ASM格式進(jìn)行描述的狀態(tài)機(jī)更易于映射到實(shí)現(xiàn)方案中。


圖2,用于圖1所示的狀態(tài)機(jī)(Moore狀態(tài)機(jī)(左),Mealy狀態(tài)機(jī)(右))的算法狀態(tài)圖。

Moore和Mealy:應(yīng)該選擇哪個(gè)?


實(shí)現(xiàn)Moore狀態(tài)機(jī)還是Mealy狀態(tài)機(jī),取決于狀態(tài)機(jī)需要實(shí)現(xiàn)的功能,以及特定的反應(yīng)次數(shù)要求。兩種狀態(tài)機(jī)之間的最大差別在于狀態(tài)機(jī)如何對輸入做出反應(yīng)。在輸入和設(shè)置的適當(dāng)輸出之間,Moore狀態(tài)機(jī)一般有一個(gè)時(shí)鐘周期的延遲。這就意味著Moore狀態(tài)機(jī)無法對輸入變化立即做出反應(yīng),這點(diǎn)在圖3中可以清楚地看到。而Mealy狀態(tài)機(jī)則能夠立即對輸入做出反應(yīng),這通常意味著:實(shí)現(xiàn)相同的函數(shù),Mealy狀態(tài)機(jī)比Moore狀態(tài)機(jī)需要更少的狀態(tài)。Mealy狀態(tài)機(jī)的不足之處就是在與另一個(gè)狀態(tài)機(jī)進(jìn)行通信時(shí),如果輸出出乎意料地嚴(yán)重依賴于其它事件的序列或時(shí)序,就可能會發(fā)生紊亂情況。


圖3,截屏顯示了Moore狀態(tài)機(jī)(上)和Mealy狀態(tài)機(jī)(下)輸出的仿真結(jié)果。

當(dāng)然,并非只能使用單純的Moore狀態(tài)機(jī)或Mealy狀態(tài)機(jī),也可以將這兩種狀態(tài)機(jī)混合使用,從而更有效地實(shí)現(xiàn)所需的函數(shù)。比如說,用于接收RS232串行數(shù)據(jù)的狀態(tài)機(jī)就可以是混合機(jī)。

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

使用VHDL這樣的高級語言,可以輕松地直接從狀態(tài)圖實(shí)現(xiàn)狀態(tài)機(jī)。VHDL支持多種枚舉類型,方便您定義實(shí)際的狀態(tài)名稱。舉例如下:

TYPE state IS (idle, led_on, led_off) ;

上面的類型定義對應(yīng)的是圖1中所示的狀態(tài)圖,即用于在按下按鈕時(shí)切換發(fā)光二極管開/關(guān)的狀態(tài)機(jī)。

實(shí)現(xiàn)狀態(tài)機(jī)有許多種方法,可分為兩類基本方法。第一類基本方法就是一次性將所有內(nèi)容集成到單個(gè)進(jìn)程中。第二類基本方法是雙進(jìn)程法,將組合邏輯和順序邏輯分開。

一般來說,大多數(shù)工程師都傾向于實(shí)現(xiàn)單進(jìn)程狀態(tài)機(jī)。與傳統(tǒng)上講授的雙進(jìn)程法相比,這種方法具有以下優(yōu)勢:

●可以避免組合過程中信號覆蓋不完全造成的閉鎖風(fēng)險(xiǎn)。

●狀態(tài)機(jī)的輸出與時(shí)鐘保持同步。

●通常比雙進(jìn)程實(shí)現(xiàn)方案更容易調(diào)試。

無論您決定采用哪一種方法來實(shí)現(xiàn)狀態(tài)機(jī),都需要使用CASE語句來評估下一狀態(tài)的判定和任何輸出,如圖4所示。該圖并行比較了使用單進(jìn)程法的Moore狀態(tài)機(jī)(左)和Mealy狀態(tài)機(jī)(右)。


圖4,使用VHDL語言的Moore狀態(tài)機(jī)(左)和Mealy狀態(tài)機(jī)。

狀態(tài)機(jī)編碼


狀態(tài)變量存儲在觸發(fā)器中,使用下一時(shí)鐘邊緣上的下一狀態(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)編碼串之間只有一個(gè)位變化外,其它基本與順序編碼方法類似。

●獨(dú)熱碼——這種方法在狀態(tài)機(jī)中為每一種狀態(tài)分配一個(gè)觸發(fā)器。只有一個(gè)觸發(fā)器當(dāng)前設(shè)置為高位,其余均設(shè)置為低位。故稱為“獨(dú)熱”。

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



相比之下,獨(dú)熱編碼法所需的觸發(fā)器數(shù)量和狀態(tài)數(shù)量一樣多。

狀態(tài)編碼的自動分配取決于狀態(tài)機(jī)所包含的狀態(tài)數(shù)量。同時(shí)還需要考慮您選擇使用的綜合工具。您可以根據(jù)下列經(jīng)驗(yàn)法則來選取編碼方法:

●順序:少于5種狀態(tài)。

●獨(dú)熱:5-50種狀態(tài)。

●格雷:多于50種狀態(tài)。

一般情況下您不必去考慮使用哪一種狀態(tài)編碼方法,而是讓綜合引擎工具確定合適的實(shí)現(xiàn)方案,只在選擇的方法出現(xiàn)問題時(shí)進(jìn)行考慮。但是,如果您要全盤自行掌控,并定義狀態(tài)編碼方法,也沒必要手動操作,只需使用狀態(tài)編碼為每一種狀態(tài)設(shè)定常數(shù)即可。相反地,可以使用代碼中的一個(gè)屬性來驅(qū)動綜合工具,從而選擇特定的編碼方法。具體如下所示:

TYPE state IS (idle, 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ī)進(jìn)入非法狀態(tài)時(shí)能夠恢復(fù)到有效狀態(tài)。

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

TYPE state IS (idle, led_on, led_off) ;

SIGNAL current_state : state := idle;

ATTRIBUTE syn_encoding STRING;

ATTRIBUTE syn_encoding OF current_state :

SIGNAL IS “sequential”;

工程師負(fù)責(zé)在綜合工具中使用正確的設(shè)置,以確保該工具不會忽略任何屬性。例如,賽靈思XST工具要求將FSM選項(xiàng)設(shè)置為USER,而Synopsys的Synplify則要求關(guān)閉FSM編譯器。

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

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

TYPE state IS (idle, led_on, led_off) ;

SIGNAL current_state : state := idle;

ATTRIBUTE syn_keep BOOLEAN;

ATTRIBUTE syn_keep OF current_state :

SIGNAL IS TRUE”;

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



本文地址:http://www.qingdxww.cn/thread-113023-1-1.html     【打印本頁】

本站部分文章為轉(zhuǎn)載或網(wǎng)友發(fā)布,目的在于傳遞和分享信息,并不代表本網(wǎng)贊同其觀點(diǎn)和對其真實(shí)性負(fù)責(zé);文章版權(quán)歸原作者及原出處所有,如涉及作品內(nèi)容、版權(quán)和其它問題,我們將根據(jù)著作權(quán)人的要求,第一時(shí)間更正或刪除。
wangxn2000 發(fā)表于 2013-7-3 22:20:14
您需要登錄后才可以發(fā)表評論 登錄 | 立即注冊

廠商推薦

  • Microchip視頻專區(qū)
  • 想要避免發(fā)生災(zāi)難,就用MPLAB SiC電源仿真器!
  • 利用模擬開發(fā)工具生態(tài)系統(tǒng)進(jìn)行安全電路設(shè)計(jì)
  • 深度體驗(yàn)Microchip自動輔助駕駛應(yīng)用方案——2025巡展開啟報(bào)名!
  • 我們是Microchip
  • 貿(mào)澤電子(Mouser)專區(qū)

相關(guān)視頻

關(guān)于我們  -  服務(wù)條款  -  使用指南  -  站點(diǎn)地圖  -  友情鏈接  -  聯(lián)系我們
電子工程網(wǎng) © 版權(quán)所有   京ICP備16069177號 | 京公網(wǎng)安備11010502021702
快速回復(fù) 返回頂部 返回列表
主站蜘蛛池模板: 亚洲久草 | 日韩欧美一区二区三区免费观看 | 中文字幕精品一区二区三区在线 | 香蕉视频 在线播放 | 欧美日韩精品一区二区免费看 | 久久95 | 久久综合久久精品 | 在线不欧美 | 免费观看欧美成人1314色 | 欧美色青 | 狠狠亚洲婷婷综合色香 | 奇米视频7777| 成年人的黄色片 | 亚洲一区二区三区亚瑟 | 亚洲视频一区在线 | 国产精品久久久久不卡绿巨人 | 亚洲va欧美va人人爽夜夜嗨 | 密臀aⅴ| 国产精品香蕉夜间视频免费播放 | 中文字幕一区二区视频 | 精品国产三级a∨在线 | 91网站入口| 手机在线观看亚洲国产精品 | 九九国产精品视频 | 三级四级特黄在线观看 | 美女隐私下部无遮挡免费视频 | 粉嫩在线视频 | 日本高清在线观看视频 | 日韩一区二区三区免费体验 | 91精品欧美产品免费观看 | 毛片免费毛片一级jjj毛片 | 91在线色| 五月天综合在线 | 精品高清国产a毛片 | 若妻家庭女教师 | 欧美3p在线观看一区二区三区 | 一级毛片区 | 日韩高清第一页 | 又黄又刺激的泡妞视频 | 日韩欧美一区二区三区在线观看 | 热久久久久 |