在线看毛片网站电影-亚洲国产欧美日韩精品一区二区三区,国产欧美乱夫不卡无乱码,国产精品欧美久久久天天影视,精品一区二区三区视频在线观看,亚洲国产精品人成乱码天天看,日韩久久久一区,91精品国产91免费

<abbr id="27omo"></abbr>

<menu id="27omo"><dl id="27omo"></dl></menu>
    • <label id="27omo"><tt id="27omo"></tt></label>

      新聞中心

      EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計應(yīng)用 > 如何在FPGA中實現(xiàn)狀態(tài)機

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

      作者: 時間:2013-05-08 來源:網(wǎng)絡(luò) 收藏

      ●順序:少于5種

      ●獨熱:5-50種。

      ●格雷:多于50種

      一般情況下您不必去考慮使用哪一種狀態(tài)編碼方法,而是讓綜合引擎工具確定合適的方案,只在選擇的方法出現(xiàn)問題時進行考慮。但是,如果您要全盤自行掌控,并定義狀態(tài)編碼方法,也沒必要手動操作,只需使用狀態(tài)編碼為每一種狀態(tài)設(shè)定常數(shù)即可。相反地,可以使用代碼中的一個屬性來驅(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)機進入非法狀態(tài)時能夠恢復(fù)到有效狀態(tài)。

      另外,您也可以使用syn_encoding屬性直接定義狀態(tài)編碼的值。例如,假設(shè)您想要使用下列狀態(tài)編碼法來對三態(tài)狀態(tài)機進行編碼: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“;

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

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

      不過對于大多數(shù)應(yīng)用來說,只需要確保狀態(tài)機能夠妥善地處理未使用的狀態(tài)并在進入非法狀態(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)部的任何條件都不會進入狀態(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)機設(shè)計對于任何使用的工程師而言都是一項重要技能。選擇Moore狀態(tài)機、Mealy狀態(tài)機還是混合機取決于整個系統(tǒng)的需求。無論選擇哪種類型的狀態(tài)機,充分掌握實現(xiàn)方案所需的工具和技巧,將確保您實現(xiàn)最佳解決方案。

      fpga相關(guān)文章:fpga是什么


      塵埃粒子計數(shù)器相關(guān)文章:塵埃粒子計數(shù)器原理

      上一頁 1 2 下一頁

      關(guān)鍵詞: 狀態(tài) 實現(xiàn) FPGA 如何

      評論


      相關(guān)推薦

      技術(shù)專區(qū)

      關(guān)閉