chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

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

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

FPGA設計中的亞穩(wěn)態(tài)解析

電子發(fā)燒友論壇 ? 來源:FPGA技術江湖 ? 2023-09-19 15:18 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

歡迎大俠來到FPGA技術江湖新欄目今日說“法”,當然,在這里我們肯定不是去研究討論法律法規(guī)知識,那我們討論什么呢,在這里我們討論的是產品研發(fā)以及技術學習時一些小細節(jié)小方法等,歡迎大家一起學習交流。今天帶來讓FPGA設計中的亞穩(wěn)態(tài)“無處可逃”,話不多說,上貨。

說起亞穩(wěn)態(tài),首先我們先來了解一下什么叫做亞穩(wěn)態(tài)。亞穩(wěn)態(tài)現(xiàn)象:信號在無關信號或者異步時鐘域之間傳輸時導致數(shù)字器件失效的一種現(xiàn)象。

接下來主要討論在異步時鐘域之間數(shù)據(jù)傳輸所產生的亞穩(wěn)態(tài)現(xiàn)象,以及如何降低亞穩(wěn)態(tài)現(xiàn)象發(fā)生的概率(只能降低,不能消除),這在FPGA設計(尤其是大工程中)是非常重要的。

亞穩(wěn)態(tài)的產生:所有的器件都定義了一個信號時序要求,只有滿足了這個要求,才能夠正常的在輸入端獲取數(shù)據(jù),在輸出端輸出數(shù)據(jù)。正常的數(shù)據(jù)傳遞是:在觸發(fā)時鐘沿前必須有一小段時間(Tsu)用來穩(wěn)定輸入信號(0 or 1),觸發(fā)時鐘沿之后需要有一小段特定的時間(Th)再次穩(wěn)定一下,最后再經過一個特定的始終到輸出延時(Tco)后才有效。如果數(shù)據(jù)的傳遞過程違反了這個時間約束,那么寄存器輸出就會出現(xiàn)亞穩(wěn)態(tài),此時輸出的數(shù)據(jù)是不穩(wěn)定的(在0和1之間游蕩)。但是這種現(xiàn)象并不是絕對的,但是我們在實際設計中應當盡量避免這種現(xiàn)象。下面我們來循序漸進的分析一下。

背景

1、亞穩(wěn)態(tài)發(fā)生原因

在FPGA系統(tǒng)中,如果數(shù)據(jù)傳輸中不滿足觸發(fā)器的Tsu和Th不滿足,或者復位過程中復位信號的釋放相對于有效時鐘沿的恢復時間(recovery time)不滿足,就可能產生亞穩(wěn)態(tài),此時觸發(fā)器輸出端Q在有效時鐘沿之后比較長的一段時間處于不確定的狀態(tài),在這段時間里Q端在0和1之間處于振蕩狀態(tài),而不是等于數(shù)據(jù)輸入端D的值。這段時間稱為決斷時間(resolution time)。經過resolution time之后Q端將穩(wěn)定到0或1上,但是穩(wěn)定到0或者1,是隨機的,與輸入沒有必然的關系。

2、亞穩(wěn)態(tài)發(fā)生場合

只要系統(tǒng)中有異步元件,亞穩(wěn)態(tài)就是無法避免的,亞穩(wěn)態(tài)主要發(fā)生在異步信號檢測、跨時鐘域信號傳輸以及復位電路等常用設計中。

3、亞穩(wěn)態(tài)危害

由于產生亞穩(wěn)態(tài)后,寄存器Q端輸出在穩(wěn)定下來之前可能是毛刺、振蕩、固定的某一電壓值。在信號傳輸中產生亞穩(wěn)態(tài)就會導致與其相連其他數(shù)字部件將其作出不同的判斷,有的判斷到“1”有的判斷到“0”,有的也進入了亞穩(wěn)態(tài),數(shù)字部件就會邏輯混亂。在復位電路中產生亞穩(wěn)態(tài)可能會導致復位失敗。怎么降低亞穩(wěn)態(tài)發(fā)生的概率成了FPGA設計需要重視的一個注意事項。

理論分析

1、信號傳輸中的亞穩(wěn)態(tài)

在同步系統(tǒng)中,輸入信號總是系統(tǒng)時鐘同步,能夠達到寄存器的時序要求,所以亞穩(wěn)態(tài)不會發(fā)生。亞穩(wěn)態(tài)問題通常發(fā)生在一些跨時鐘域信號傳輸以及異步信號采集上。

它們發(fā)生的原因如下:

(1)在跨時鐘域信號傳輸時,由于源寄存器時鐘和目的寄存器時鐘相移未知,所以源寄存器數(shù)據(jù)發(fā)出數(shù)據(jù),數(shù)據(jù)可能在任何時間到達異步時鐘域的目的寄存器,所以無法保證滿足目的寄存器Tsu和Th的要求;

(2)在異步信號采集中,由于異步信號可以在任意時間點到達目的寄存器,所以也無法保證滿足目的寄存器Tsu和Th的要求;

當數(shù)據(jù)在目的寄存器Tsu-Th時間窗口發(fā)生變化,也即當數(shù)據(jù)的建立時間或者保持時間不滿足時,就可能發(fā)生亞穩(wěn)態(tài)現(xiàn)象。如下圖亞穩(wěn)態(tài)產生示意圖所示。

f9512be6-569d-11ee-939d-92fbcf53809c.png


由圖可知,當產生亞穩(wěn)態(tài)后Tco時間后會有Tmet(決斷時間)的振蕩時間段,當振蕩結束回到穩(wěn)定狀態(tài)時為“0”或者“1”,這個是隨機的。因此,會對后續(xù)電路判斷造成影響。

2、復位電路的亞穩(wěn)態(tài)

2.1、異步復位電路
在復位電路設計中,復位信號基本都是異步的,常用異步復位電路Verilog描述如下:

f9638b6a-569d-11ee-939d-92fbcf53809c.png


綜合出來復位電路模型如下圖異步復位電路模型所示:

f96ebf9e-569d-11ee-939d-92fbcf53809c.png


如下圖異步復位時序所示,為復位電路復位時序圖。如果異步復位信號的撤銷時間在Trecovery(恢復時間)和Tremoval(移除時間)之內,那勢必造成亞穩(wěn)態(tài)的產生,輸出在時鐘邊沿的Tco后會產生振蕩,振蕩時間為Tmet(決斷時間),最終穩(wěn)定到“0”或者“1”,就會可能造成復位失敗。

f979ff58-569d-11ee-939d-92fbcf53809c.png



2.2、同步復位電路的亞穩(wěn)態(tài)

在復位電路中,由于復位信號是異步的,因此,有些設計采用同步復位電路進行復位,并且絕大多數(shù)資料對于同步復位電路都認為不會發(fā)生亞穩(wěn)態(tài),其實不然,同步電路也會發(fā)生亞穩(wěn)態(tài),只是幾率小于異步復位電路。


如下面verilog代碼對同步復位電路的描述。

f98da5a8-569d-11ee-939d-92fbcf53809c.png


綜合出硬件電路如下圖同步復位電路所示。

f9a02336-569d-11ee-939d-92fbcf53809c.png


在此,我們不討論同步復位的消耗資源問題,只討論同步復位的亞穩(wěn)態(tài)產生情況。

當輸入端Din為高電平,而且復位信號的撤銷時間在clk的Tsu和Th內時候,亞穩(wěn)態(tài)就隨之產生了。如下圖同步復位電路時序圖所示,當復位撤銷時間在clk的Tsu和Th內,輸入數(shù)據(jù)為“1”,通過和輸入數(shù)據(jù)相與后的數(shù)據(jù)也在clk的Tsu和Th內,因此,勢必會造成類似異步信號采集的亞穩(wěn)態(tài)情況。

f9afe12c-569d-11ee-939d-92fbcf53809c.png


3、亞穩(wěn)態(tài)產生概率以及串擾概率
在實際的FPGA電路設計中,常常人們想的是怎么減少亞穩(wěn)態(tài)對系統(tǒng)的影響,很少有人考慮怎么才能減少亞穩(wěn)態(tài)發(fā)生幾率,以及亞穩(wěn)態(tài)串擾的概率問題。


3.1、亞穩(wěn)態(tài)發(fā)生概率
由上面分析得知,系統(tǒng)亞穩(wěn)態(tài)發(fā)生的都是由于clk的Tsu和Th不滿足,又或者是復位信號的移除和恢復時間不滿足。常用FPGA器件的Tsu+Th約等于1ns,復位移除和恢復時間相加約等于1ns。

當異步信號不是一組數(shù)據(jù),或者信號量較少,那就需要對異步信號進行同步處理,例如對一個異步脈沖信號進行采集,只要脈沖信號變化發(fā)生在時鐘Tsu和Th窗口內,那就很可能會產生亞穩(wěn)態(tài),亞穩(wěn)態(tài)產生的概率大概為:

概率 = (建立時間 + 保持時間)/ 采集時鐘周期

由上述公式可以看出,隨著clk頻率的增加,亞穩(wěn)態(tài)發(fā)生的幾率是增加的。

例如,為系統(tǒng)采用100M時鐘對一個外部信號進行采集,采集時鐘周期為10ns,那采集產生亞穩(wěn)態(tài)的概率為:1ns/10ns = 10%

同理采用300M時鐘對一個外部信號進行采集,那產生亞穩(wěn)態(tài)的概率為:1ns/3.3ns = 30%。如果采用三相相位差為120°的時鐘對一個外部信號進行采集,那產生亞穩(wěn)態(tài)的概率接近90%。所以在異步信號采集過程中,要想減少亞穩(wěn)態(tài)發(fā)生的概率:

(1) 降低系統(tǒng)工作時鐘,增大系統(tǒng)周期,亞穩(wěn)態(tài)概率就會減??;

(2) 采用工藝更好的FPGA,也就是Tsu和Th時間較小的FPGA器件。

3.2、亞穩(wěn)態(tài)的串擾概率
使用異步信號進行使用的時候,好的設計都會對異步信號進行同步處理,同步一般采用多級D觸發(fā)器級聯(lián)處理,如下圖三級寄存器同步所示,采用三級D觸發(fā)器對異步信號進行同步處理。

f9bdc1f2-569d-11ee-939d-92fbcf53809c.png


這種模型大部分資料都說的是第一級寄存器產生亞穩(wěn)態(tài)后,第二級寄存器穩(wěn)定輸出概率為90%,第三極寄存器穩(wěn)定輸出的概率為99%,如果亞穩(wěn)態(tài)跟隨電路一直傳遞下去,那就會另自我修護能力較弱的系統(tǒng)直接崩潰。接下來我們分析這種串擾的概率問題。

如下圖三級寄存器消除亞穩(wěn)態(tài)所示為一個正常第一級寄存器發(fā)生了亞穩(wěn)態(tài),第二級、第三極寄存器消除亞穩(wěn)態(tài)時序模型。

f9c88f06-569d-11ee-939d-92fbcf53809c.png


由上圖可以看出,當?shù)谝粋€寄存器發(fā)生亞穩(wěn)態(tài)后,經過Tmet的振蕩穩(wěn)定后,第二級寄存器能采集到一個穩(wěn)定的值。但是為什么第二級寄存器還是可能會產生亞穩(wěn)態(tài)呢?

由于振蕩時間Tmet是受到很多因素影響的,所以Tmet時間有長有短,所以當Tmet時間長到大于一個采集周期后,那第二級寄存器就會采集到亞穩(wěn)態(tài)。如下圖二級寄存器亞穩(wěn)態(tài)所示。

f9d463c6-569d-11ee-939d-92fbcf53809c.png

由上圖可知,第二級也是一個亞穩(wěn)態(tài),所以在這種情況下,亞穩(wěn)態(tài)產生了串擾,從第一級寄存器傳到了第二級寄存器,同樣也可能從第二級寄存器串擾到第三級寄存器。這樣會讓設計邏輯判斷出錯,產生亞穩(wěn)態(tài)傳輸,可能導致系統(tǒng)死機奔潰。

3.3、亞穩(wěn)態(tài)振蕩時間Tmet

亞穩(wěn)態(tài)震蕩時間Tmet關系到后級寄存器的采集穩(wěn)定問題,Tmet影響因素包括:器件的生產工藝、溫度、環(huán)境以及寄存器采集到亞穩(wěn)態(tài)離穩(wěn)定態(tài)的時刻等。甚至某些特定條件,如干擾、輻射等都會造成Tmet增長。

應用分析

有亞穩(wěn)態(tài)產生,我們就要對亞穩(wěn)態(tài)進行消除,常用對亞穩(wěn)態(tài)消除有三種方式:

對異步信號進行同步處理;

采用FIFO對跨時鐘域數(shù)據(jù)通信進行緩沖設計;

對復位電路采用異步復位、同步釋放方式處理。

1、對異步信號進行同步提取邊沿

在異步通信或者跨時鐘域通信過程中,最常用的就是對異步信號進行同步提取邊沿處理。對一個異步信號進行提取上升沿通常采用如下例子所示。

舉例:雙極寄存器提取邊沿

f9e89e5e-569d-11ee-939d-92fbcf53809c.png


這種邊沿提取方式對于一個穩(wěn)定的系統(tǒng)是不合適的,例如:當?shù)谝患壖拇嫫鞑杉絹喎€(wěn)態(tài),那勢必造成sig_nsyn_p輸出亞穩(wěn)態(tài),這樣就會對采用sig_nsyn_p的信號進行判斷的電路造成影響,甚至判斷出錯誤的值。

根據(jù)上述介紹的亞穩(wěn)態(tài)產生概率,如果在100M時種下那第一級寄存器產生亞穩(wěn)態(tài)的概率約為10%,隨著系統(tǒng)采集頻率升高,那產生亞穩(wěn)態(tài)的概率也會隨之上升。因此,在進行異步信號跨頻提取邊沿時候,一般采用多進行一級寄存器消除亞穩(wěn)態(tài),可能在系統(tǒng)穩(wěn)定性要求高的情況下,采用更多級寄存器來消除亞穩(wěn)態(tài),如下舉例所示,即為采用4級寄存器消除亞穩(wěn)態(tài),相應的邊沿信號產生的時間就晚了兩個時鐘周期。

舉例:多級寄存器提取邊沿信號

f9ef2b8e-569d-11ee-939d-92fbcf53809c.png


2、FIFO進行異步跨頻數(shù)據(jù)處理
當數(shù)據(jù)流從一個時鐘域到另一個時鐘域的時候,絕大多數(shù)情況下都采用FIFO來作為中間緩沖,采用雙時鐘對數(shù)據(jù)緩沖,就可以避免亞穩(wěn)態(tài)的發(fā)生。

3、異步復位,同步釋放
對于復位情況下的亞穩(wěn)態(tài),常常是由于恢復時間和移除時鐘不滿足造成的,因此,最常用的處理方式是采用異步復位、同步釋放。常用電路模型如所示。采用第二級寄存器輸出作為全局復位信號輸出。

舉例:異步復位處理

f9fcbaec-569d-11ee-939d-92fbcf53809c.png


通過上面三種方式處理異步信號、異步數(shù)據(jù)、以及異步復位可有效的提高系統(tǒng)的穩(wěn)定性。減少亞穩(wěn)態(tài)的產生。

通過上述對亞穩(wěn)態(tài)的分析以及各種模式的處理,相信各位大俠應該有所收獲,今日說"法"到此結束,下篇再見,歡迎各位大俠投稿,交流學習,共同進步,祝一切安好!

審核編輯:湯梓紅
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • FPGA
    +關注

    關注

    1655

    文章

    22286

    瀏覽量

    630295
  • FPGA設計
    +關注

    關注

    9

    文章

    429

    瀏覽量

    28003
  • 信號
    +關注

    關注

    11

    文章

    2902

    瀏覽量

    79670
  • 觸發(fā)器
    +關注

    關注

    14

    文章

    2050

    瀏覽量

    63043
  • 亞穩(wěn)態(tài)

    關注

    0

    文章

    47

    瀏覽量

    13651

原文標題:今日說“法”:讓FPGA設計中的亞穩(wěn)態(tài)“無處可逃”

文章出處:【微信號:gh_9b9470648b3c,微信公眾號:電子發(fā)燒友論壇】歡迎添加關注!文章轉載請注明出處。

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    FPGA亞穩(wěn)態(tài)——讓你無處可逃

    1. 應用背景1.1亞穩(wěn)態(tài)發(fā)生原因在FPGA系統(tǒng),如果數(shù)據(jù)傳輸不滿足觸發(fā)器的Tsu和Th不滿足,或者復位過程復位信號的釋放相對于有效時
    發(fā)表于 01-11 11:49

    FPGA亞穩(wěn)態(tài)——讓你無處可逃

    本帖最后由 eehome 于 2013-1-5 09:55 編輯 1. 應用背景1.1亞穩(wěn)態(tài)發(fā)生原因在FPGA系統(tǒng),如果數(shù)據(jù)傳輸不滿足觸發(fā)器的Tsu和Th不滿足,或者復位過程
    發(fā)表于 04-25 15:29

    FPGA觸發(fā)器的亞穩(wěn)態(tài)認識

    返回到低電平, 這和輸入的數(shù)據(jù)無關。且在亞穩(wěn)態(tài)的過程,觸發(fā)器的輸出可能在震蕩,也可能徘徊在一個固定的中間電平上。我們來看一個真實案例。見圖3. 在這個案例,我們測試一個FPGA
    發(fā)表于 12-04 13:51

    亞穩(wěn)態(tài)問題解析

    亞穩(wěn)態(tài)是數(shù)字電路設計中最為基礎和核心的理論。同步系統(tǒng)設計的多項技術,如synthesis,CTS,STA等都是為了避免同步系統(tǒng)產生亞穩(wěn)態(tài)。異步系統(tǒng),更容易產生
    發(fā)表于 11-01 17:45

    簡談FPGA學習中亞穩(wěn)態(tài)現(xiàn)象

    亞穩(wěn)態(tài)現(xiàn)象發(fā)生的概率(只能降低,不能消除),這在FPGA設計(尤其是大工程)是非常重要的。亞穩(wěn)態(tài)的產生:所有的器件都定義了一個信號時序要求,只有滿足了這個要求,才能夠正常的在輸入端獲
    發(fā)表于 08-01 09:50

    FPGA亞穩(wěn)態(tài)現(xiàn)象是什么?

    說起亞穩(wěn)態(tài),首先我們先來了解一下什么叫做亞穩(wěn)態(tài)亞穩(wěn)態(tài)現(xiàn)象:信號在無關信號或者異步時鐘域之間傳輸時導致數(shù)字器件失效的一種現(xiàn)象。
    發(fā)表于 09-11 11:52

    FPGA復位電路中產生亞穩(wěn)態(tài)的原因

    亞穩(wěn)態(tài)概述01 亞穩(wěn)態(tài)發(fā)生原因在 FPGA 系統(tǒng),如果數(shù)據(jù)傳輸不滿足觸發(fā)器的 Tsu 和 Th 不滿足,或者復位過程
    發(fā)表于 10-19 10:03

    FPGA--復位電路產生亞穩(wěn)態(tài)的原因

    FPGA 系統(tǒng),如果數(shù)據(jù)傳輸不滿足觸發(fā)器的 Tsu 和 Th 不滿足,或者復位過程復位信號的釋放相對于有效時鐘沿的恢復時間(recovery time)不滿足,就可能產生
    發(fā)表于 10-22 11:42

    FPGA,同步信號、異步信號和亞穩(wěn)態(tài)的理解

    性的培訓誘導,真正的去學習去實戰(zhàn)應用,這種快樂試試你就會懂的。話不多說,上貨。在FPGA,同步信號、異步信號和亞穩(wěn)態(tài)的理解PGA(Field-Programmable Gate Array),即現(xiàn)場
    發(fā)表于 02-28 16:38

    今日說“法”:讓FPGA設計亞穩(wěn)態(tài)“無處可逃”

    ,有好的靈感以及文章隨筆,歡迎投稿,投稿請標明筆名以及相關文章,投稿接收郵箱:1033788863@qq.com。今天帶來讓FPGA設計亞穩(wěn)態(tài)“無處可逃”,話不多說,上貨。 說起亞穩(wěn)態(tài)
    發(fā)表于 04-27 17:31

    基于FPGA亞穩(wěn)態(tài)參數(shù)測量方法

    基于FPGA亞穩(wěn)態(tài)參數(shù)測量方法_田毅
    發(fā)表于 01-07 21:28 ?0次下載

    關于FPGA設計亞穩(wěn)態(tài)及其緩解措施的分析和介紹

    在進行FPGA設計時,往往只關心“0”和“1”兩種狀態(tài)。然而在工程實踐,除了“0”、“1”外還有其他狀態(tài),亞穩(wěn)態(tài)就是其中之一。亞穩(wěn)態(tài)是指觸發(fā)器或鎖存器無法在某個規(guī)定時間段內達到一個可
    發(fā)表于 10-06 09:42 ?1724次閱讀
    關于<b class='flag-5'>FPGA</b>設計<b class='flag-5'>中</b>的<b class='flag-5'>亞穩(wěn)態(tài)</b>及其緩解措施的分析和介紹

    簡談FPGA學習中亞穩(wěn)態(tài)現(xiàn)象

    大家好,又到了每日學習的時間了,今天我們來聊一聊FPGA學習,亞穩(wěn)態(tài)現(xiàn)象。 說起亞穩(wěn)態(tài),首先我們先來了解一下什么叫做亞穩(wěn)態(tài)。
    的頭像 發(fā)表于 06-22 14:49 ?3892次閱讀
    簡談<b class='flag-5'>FPGA</b>學習中<b class='flag-5'>亞穩(wěn)態(tài)</b>現(xiàn)象

    如何理解FPGA設計的打拍(寄存)和亞穩(wěn)態(tài)

    可能很多FPGA初學者在剛開始學習FPGA設計的時候(當然也包括我自己),經常聽到類似于”這個信號需要打一拍、打兩拍(寄存),以防止亞穩(wěn)態(tài)問題的產生“這種話,但是對這個打拍和亞穩(wěn)態(tài)問題
    的頭像 發(fā)表于 02-26 18:43 ?9323次閱讀
    如何理解<b class='flag-5'>FPGA</b>設計<b class='flag-5'>中</b>的打拍(寄存)和<b class='flag-5'>亞穩(wěn)態(tài)</b>

    什么是亞穩(wěn)態(tài)?如何克服亞穩(wěn)態(tài)?

    亞穩(wěn)態(tài)在電路設計是常見的屬性現(xiàn)象,是指系統(tǒng)處于一種不穩(wěn)定的狀態(tài),雖然不是平衡狀態(tài),但可在短時間內保持相對穩(wěn)定的狀態(tài)。對工程師來說,亞穩(wěn)態(tài)的存在可以帶來獨特的性質和應用,如非晶態(tài)材料、晶體缺陷等
    的頭像 發(fā)表于 05-18 11:03 ?5947次閱讀