《電子技術應用》
您所在的位置:首頁 > 可編程邏輯 > 業界動態 > 基于FPGA的跨時鐘域信號處理——亞穩態

基于FPGA的跨時鐘域信號處理——亞穩態

2015-02-12

    在特權的上篇博文《基于FPGA的跨時鐘域信號處理——專用握手信號》中提出了使用專門的握手信號達到異步時鐘域數據的可靠傳輸。列舉了一個簡單的由請求信號req、數據信號data、應答信號ack組成的簡單握手機制。riple兄更是提出了req和ack這兩個直接的跨時鐘域信號在被另一個時鐘域的寄存器同步時的亞穩態問題。這個問題估計是整個異步通信中最值得探討和關注的。

 很幸運,特權同學找到了很官方的說法——《Application Note42:Metastability in Altera Devices》,一口氣讀完全文,有一個單詞送給這篇文章很合適——“nice”。特權同學過去的所有疑惑都在文章中找到了答案,盡管altera在文章的最后只是竭盡全力的在吹捧自己的好。

  如果你E文還不錯(該不會比我這個4次都沒過掉4級考試的家伙差吧,~_~),那么去享受原文吧。或者你可以考慮看看特權同學的翻譯水平,哈哈……

  什么是亞穩態?

  所有數字器件(例如FPGA)的信號傳輸都會有一定的時序要求,從而保證每個寄存器將捕獲的輸入信號正確輸出。為了確保可靠的操作,輸入寄存器的信號必須在時鐘沿的某段時間(寄存器的建立時間Tsu)之前保持穩定,并且持續到時鐘沿之后的某段時間(寄存器的保持時間Th)之后才能改變。而該寄存器的輸入反映到輸出則需要經過一定的延時(時鐘到輸出的時間Tco)。如果數據信號的變化違反了Tsu后者Th的要求,那么寄存器的輸出就會處于亞穩態。此時,寄存器的輸出會在高電平1和低電平0之間盤旋一段時間,這也意味著寄存器的輸出達到一個穩定的高或者低電平的狀態所需要的時間會大于Tco。

  在同步系統中,輸入信號總是能夠達到寄存器的時序要求,所以亞穩態不會發生。亞穩態問題通常發生在一些跨時鐘域信號的傳輸上。由于數據信號可能在任何時間到達異步時鐘域的目的寄存器,所以設計者無法保證滿足Tsu和Th的要求。然而,并非所有違反寄存器的Tsu或Th要求的信號會導致輸出亞穩態。某個寄存器進入了亞穩態后重新回到穩定狀態的時間取決于器件的制造工藝及工作環境。在大多數情況下,寄存器將會快速的返回穩定狀態。

  寄存器在時鐘沿采樣數據信號好比一個球從小山的一側拋到另一側。如圖1所示,小山的兩側代表數據的穩定狀態——舊的數據值或者新的數據值;山頂代表亞穩態。如果球被拋到山頂上,它可能會停在山頂上,但實際上它只要稍微有些動靜就會滾落到山底。在一定時間內,球滾的越遠,它達到穩定狀態的時間也就越短。

  如果數據信號的變化發生在時鐘沿的某段時間之后(Th),就好像球跌落到了小山的“old data value”一側,輸出信號仍然保持時鐘變化前的值不變。如果數據信號的變化發生在時鐘沿的某段時間(Tsu)之前,并且持續到時鐘沿之后的某段時間(Th)都不再變化,那就好像球跌落到了小山的“new data value”一側,輸出數據達到穩定狀態的時間為Tco。然而,當一個寄存器的輸入數據違反了Tsu或者Th,就像球被拋到了山頂。如果球在山頂停留的越久,那么它到達山底的時間也就越長,這就相應的延長了從時鐘變化到輸出數據達到穩定狀態的時間(Tco)。

  

點擊看大圖

 

  圖1

  圖2很好的闡釋了亞穩態信號。在時鐘變化的同時,寄存器的輸入數據信號也處于從低電平到高電平的變化狀態,這就違反了寄存器的Tsu要求。圖中的輸出信號從低電平變化到亞穩態,即盤旋于高低電平之間的一個狀態。信號輸出A最終達到輸入信號的新狀態值1,信號輸出B卻返回了輸入信號的舊狀態值0。在這兩種情況下,信號輸出變化穩定在固定的1或者0狀態的時間遠超過了寄存器的固有Tco。

  

點擊看大圖

 

  圖2

  如果輸出信號在下一個寄存器捕獲數據前(下一個時鐘鎖存沿的Tsu時間前)處于一個穩定的有效狀態,那么亞穩態信號不會對該系統照成影響。但是如果亞穩態信號在下一個寄存器捕獲數據時仍然盤旋于高或者低電平之間,那將會對系統的后續電路產生影響。繼續討論球和小山的比喻,當球到達山底的時間(處于穩定的邏輯值0或1)超過了扣除寄存器Tco以外的余量時間,那么問題就隨著而來。

  同步寄存器

  當信號變化處于一個不相關的電路或者以不時鐘域,它在被使用前就需要先被同步到新的時鐘域中。新的時鐘域中的第一個寄存器將扮演同步寄存器的角色。

  為了盡可能減少異步信號傳輸中由于亞穩態引發的問題,設計者通常在目的時鐘域中使用一串連續的寄存器(同步寄存器鏈或者同步裝置)將信號同步到新的時鐘域中。這些寄存器有額外的時間用于信號在被使用前從亞穩態達到穩定值。同步寄存器到寄存器路徑的時序余量,也就是亞穩態信號達到穩定的最大時間,也被認為是亞穩態持續時間。

  同步寄存器鏈,或者同步裝置,被定義為一串達到以下要求的連續寄存器:

  ■ 鏈中的寄存器都由相同的時鐘或者相位相關的時鐘觸發;

  ■ 鏈中的第一個寄存器由不相關時鐘域或者是異步的時鐘來觸發;

  ■ 每個寄存器的扇出值都為1,鏈中的最后一個寄存器可以例外。

  同步寄存器鏈的長度就是達到以上要求的同步時鐘域的寄存器數量,圖3是一個兩級的同步寄存器鏈,

  

點擊看大圖

 

  圖3

  傳輸在不相關時鐘域的信號,都有可能在相對于捕獲寄存器時鐘沿的任何時間點變化。因此,設計者無法預測信號變化的順序或者說信號兩次變化間經過了幾個鎖存時鐘周期。例如,一條異步總線的各個數據信號可能在不同的時鐘沿變化,結果接收到的數據值可能是錯誤的。

  設計者必須考慮到電路的這些情況,而使用雙時鐘FIFO(DCFIFO)傳輸信號或者使用握手信號進行控制。FIFO使用同步裝置處理來自不同時鐘域的控制信號,數據的讀寫使用兩套獨立的總線。此外,如果異步信號作為兩個時鐘域的握手邏輯,這些控制信號就需要用于指示何時數據信號可以被接收時鐘域鎖存。如此一來,就可以利用同步寄存器確保亞穩態不會影響控制信號的傳輸,從而保證數據在使用前有充足的時間等待亞穩態達到穩定。

  文章其實還沒有結束,只不過altera在后面很官方的提出了所謂的MTBF(mean time between failures)的概念,即所謂的平均無故障時間的概念。列了個公式,分析了各個參數,當然也不忘提他們的器件參數對于這個MTBF做了多大的貢獻。然后也提出了它們是如何進行該公式參數的推導。

  我們還是回到主題,在明確了這些基本的概念和基本的方法后,就要學以致用。在上篇博文沒有解決的一個關鍵問題在于如何最有效的進行握手信號req、ack的采樣。這個問題我們可以先以altera提出的MTBF推導公式的各個參數入手分析。

  

 

  在這個公式中,Tmet就是指寄存器從時鐘上升沿觸發后的時序余量時間,Fclk是接收時鐘域的時鐘頻率,Fdata是數據的變化頻率,而C1、C2則是與器件有關的參數,對于用戶是一個固定值。由此看來,設計者只能通過改變Tmet、Fclk、Fdata來提高MTBF值。MTBF值越大,說明出現亞穩態的幾率越小。要增大MTBF值,可以延長Tmet、也可以降低Fclk和Fdata這兩個頻率。

  首先我們看看如何延長Tmet時間。

  Tmet時間 = 采樣時鐘周期時間 – 輸出信號正常的Tco時間 - 數據到達下一級寄存器的輸入端口的其它延時時間Tdata - 下一級寄存器Tsu時間。

  

 

  圖4

  從嚴格意義上來說,Tmet時間還應該加上時鐘網絡延時時間(Tclk2-Tclk1)。總之,這個Tmet時間是指正常沒有亞穩態情況下,寄存器輸出信號從源寄存器到目的寄存器的建立時間余量。由于決定Tmet取值的參數中Tco和Tsu都是由FPGA器件本身的工藝以及工作環境決定的,設置時鐘網絡延時參數也很大程度上由器件決定,所以,如果在時鐘頻率Fclk和數據變化率Fdata固定的情況下,要增大Tmet值,那么設計者要做的只能是減小Tdata值。而這個Tdata是指兩個寄存器間的邏輯延時以及走線延時之和,要最大程度的減小它,估計也只能是不在連個寄存器間添加任何邏輯而已,正如我們的實例中也只有簡單的input=output。

  再看Fclk,它是接收域的采樣時鐘,就是異步信號需要被同步到的那個時鐘域,它的頻率是越小越好。當然了,事物都其兩面性,這個頻率小到影響系統正常工作可就不行了。設計者需要從各個方面考慮來決定這個頻率,不會僅僅為了降低亞穩態發生的概率而無限制的降低系統的時鐘頻率。如此分析,發現這個Fclk基本也是一個比較固定的值,不是可以隨便說降就降的。降低Fclk其實也就是在增大Tmet時間,因為它是Tmet公式計算中的被減數,哈哈,好像是一環扣一環。另外,在不降低采樣頻率Fclk的情況下,通過使用使能信號的方式得到一個二分頻時鐘去采樣信號也可以達到降頻的目的,只不過這樣會多耗費幾個時鐘周期用于同步,但是有時也能夠明顯改善性能。

  特權同學的二分頻采樣思路如圖5所示,前兩級采樣電路都做了2分頻,然后第三級使用原來時鐘進行采樣。它的好處在于給第一級和第二級同步寄存器更多的Tmet時間,將亞穩態抑制在第二級寄存器輸入之前,從而保證第三級寄存器的可靠采樣。雖然它在一、二級寄存器的輸入端增加了一些邏輯,可能會增大Tdata,但是相比于這個采樣時鐘的一半將額,它的變化是可以忽略不計的。

  

點擊看大圖

 

  圖5

  另一種辦法是在不降低每級寄存器的采樣頻率的情況下采用更多的同步寄存器,盡量去使用后級的寄存器,這也是一個笨辦法。Altera的筆記里打了一個比喻,如果一個設計你使用了9級的同步寄存器,那么MTBF是100年,而當你使用了10級的同步寄存器,那么MTBF是1000年。這個辦法其實有點類似冗余,這是所有人都知道的可以提高可靠性的原始辦法。這種思路的弊端和前面提到的方法一樣,需要付出多個時鐘周期為代價。

  最后看這個Fdata,這個是發送時鐘域的數據變化率,似乎也是由系統決定的,設計者也無法做太多改變。

  其實對于一般的應用,如果系統的時鐘頻率不太高,器件的特性還算可以(只是一些泛泛的說法,具體問題要具體分析),特權同學覺得上篇博文提出的握手信號同步方法就足以應付亞穩態問題。如果到高頻范疇來討論亞穩態,那將會是一項更有挑戰性的任務,只可惜特權同學目前接觸的最高頻也只不過100MHz而已。特權同學自覺才疏學淺,班門弄斧了。

  無獨有偶,特權同學這篇博文即將收官之際,無意中看到船長的博客中《理解FPGAs中的亞穩態》一文也涉及到了altera的這篇筆記,也做了一下翻譯,似乎比特權同學翻譯的好。不過在此做個聲明,特權同學的博文一貫堅持原創,即便參考其它資料,也大都有所提及,并且有自己的評論和思考,這應該是每位電子工程師應該有的嚴謹和認真的態度。

本站內容除特別聲明的原創文章之外,轉載內容只為傳遞更多信息,并不代表本網站贊同其觀點。轉載的所有的文章、圖片、音/視頻文件等資料的版權歸版權所有權人所有。本站采用的非本站原創文章及圖片等內容無法一一聯系確認版權者。如涉及作品內容、版權和其它問題,請及時通過電子郵件或電話通知我們,以便迅速采取適當措施,避免給雙方造成不必要的經濟損失。聯系電話:010-82306118;郵箱:aet@chinaaet.com。
欧美激情办公室aⅴ_国产欧美综合一区二区三区_欧美午夜精品久久久久免费视_福利视频欧美一区二区三区

          欧美日韩精品一本二本三本| 久久久久久一区| 午夜一级久久| 欧美中日韩免费视频| 久久婷婷亚洲| 欧美亚州在线观看| 一区二区三区国产盗摄| 亚洲一区在线直播| 欧美日韩理论| 国产精品综合| 国内精品久久久久国产盗摄免费观看完整版| 精品91久久久久| 国产欧美91| 欧美日韩无遮挡| 国产精品推荐精品| 国产综合色一区二区三区| 91久久综合| 可以看av的网站久久看| 99视频一区| 欧美日韩福利| 噜噜爱69成人精品| 亚洲狠狠婷婷| 欧美日韩成人| 久久亚洲高清| 国产精品区一区| 极品日韩久久| 午夜视频精品| 免费亚洲网站| 国产一级一区二区| 亚洲视频碰碰| 午夜久久tv| 久久高清国产| 国产美女在线精品免费观看| 激情综合视频| 红桃视频欧美| 欧美日韩一区二区国产| 久久综合久久久| 国产一级精品aaaaa看| 一区二区视频欧美| 欧美亚韩一区| 国产综合欧美在线看| 欧美激情四色| 欧美日韩国产精品一卡| 女人色偷偷aa久久天堂| 久久久久一区| 牛牛国产精品| 欧美a级片网站| 欧美91精品| 欧美人成在线| 伊人久久成人| 99精品视频免费观看视频| 亚洲欧洲日本国产| 亚洲精品综合| 国产日韩1区| 免费日韩视频| 欧美在线播放一区二区| 亚洲欧美综合| 伊人久久综合| 国产日韩一区二区三区在线| 蘑菇福利视频一区播放| 久久亚洲综合| 禁久久精品乱码| 亚洲黄色毛片| 午夜一区不卡| 欧美日韩一区二区国产| 亚洲午夜av| 一区二区三区四区五区视频| 午夜一级在线看亚洲| 老牛嫩草一区二区三区日本| 欧美破处大片在线视频| 在线精品亚洲一区二区| av成人毛片| 免费亚洲视频| 狠色狠色综合久久| 亚洲欧美卡通另类91av| 欧美激情 亚洲a∨综合| 亚洲三级毛片| 久久久久久久高潮| 亚洲国产专区校园欧美| 久久精品五月| 亚洲国产一区二区三区高清| 校园激情久久| 亚洲一级一区| 久久深夜福利| 国产一区91| 国产主播一区二区三区四区| 国产精品亚洲欧美| 亚洲无线视频| 欧美a级在线| 国产日韩一区二区三区| 国产一区二区三区四区老人| 免费亚洲婷婷| 99精品国产高清一区二区 | 欧美激情性爽国产精品17p| 伊人久久成人| 欧美在线1区| 亚洲免费在线| 一区二区91| 亚洲成人中文| 欧美午夜精品| 午夜日本精品| 久久亚洲精选| 嫩草成人www欧美| 国产精品久久久一区二区三区| 黄色成人91| 欧美~级网站不卡| 久久精品30| 亚洲欧美成人综合| 国产精品亚洲综合| aa级大片欧美三级| 亚洲乱亚洲高清| 在线欧美三区| 亚洲欧洲另类| 日韩视频在线一区二区三区| 亚洲国产第一| 亚洲精品一区二区三区樱花| 亚洲激情在线| 亚洲国产片色| 99一区二区| 国产亚洲精品久久飘花 | 久久久精品网| 免费亚洲网站| 久久av一区| 久久精品日产第一区二区三区| 亚洲欧美日本视频在线观看| 在线亚洲国产精品网站| 亚洲美女91| 亚洲色诱最新| 蜜桃久久av| 欧美91福利在线观看| 欧美国产91| 亚洲午夜黄色| 中文日韩在线| 性一交一乱一区二区洋洋av| 久久精品动漫| 欧美在线一二三区| 亚洲性图久久| 国产精品毛片一区二区三区| 免费中文字幕日韩欧美| 欧美大片专区| 亚洲区一区二区三区| 国产精品亚洲综合色区韩国| 久久久久免费| 国产一区二区中文字幕免费看| 激情五月***国产精品| 99香蕉国产精品偷在线观看| 欧美资源在线| 国产在线精品二区| 国产欧美日韩一区二区三区在线 | 久久久久成人精品免费播放动漫| 欧美精品福利| 一区二区三区高清视频在线观看| 裸体丰满少妇做受久久99精品| 久久精品伊人| 91久久极品少妇xxxxⅹ软件| 久久国产精品高清| 亚洲特级毛片| 久久看片网站| 一区二区精品| 国产一区二区在线观看免费播放| 中文一区二区| 黄页网站一区| 欧美~级网站不卡| 国产精品久久777777毛茸茸| 韩日成人av| 免费日韩av片| 一区二区日韩免费看| 欧美激情亚洲| 另类亚洲自拍| 国产精品老牛| 亚洲精品1区| 欧美日韩喷水| 久久综合久久综合这里只有精品| 亚洲免费黄色| 精品999成人| 国产精品va| 欧美精品99| 久久久久久九九九九| 国产一区二区三区高清| 亚洲第一毛片| 激情久久中文字幕| 欧美日韩精品免费观看| 久久在线91| 欧美亚洲一区| 先锋a资源在线看亚洲| 99热这里只有成人精品国产| 黄色精品一区| 黄色日韩精品| 国产一区二区三区四区老人| 欧美淫片网站| 欧美一区二区三区在线免费观看| 亚洲一卡久久| 国产精品久久久一区二区| 日韩午夜一区| 国产视频欧美| 国产视频精品网| 国产精品外国| 亚洲一区二区三区在线观看视频| 国产亚洲二区| 亚洲尤物影院| 久久综合图片| 国产精品二区三区四区| 午夜精品网站| 亚洲视频综合| 亚洲激情二区| 国产精品免费区二区三区观看| 国产视频一区在线观看一区免费| 国产精品一区二区a| 久久不射中文字幕| 久热这里只精品99re8久| 欧美精品91| 亚洲国产裸拍裸体视频在线观看乱了中文 | 亚洲福利一区| 99re热精品| 久久婷婷一区| 一区二区在线不卡| 国产亚洲午夜| 久久亚洲电影| 亚洲精选一区| 久久综合久久综合这里只有精品| 亚洲欧美一区二区原创| 影音欧美亚洲| 蘑菇福利视频一区播放| 欧美日韩免费高清| 一本一本a久久| 欧美日韩一卡| 亚洲制服av| 雨宫琴音一区二区在线| 免费日韩一区二区| 激情视频一区二区| 久久亚洲午夜电影| 亚洲深夜影院| 国产一区观看| 久久精品一区二区国产| 亚洲精品女人| 欧美区亚洲区| 亚洲在线视频| 99精品国产福利在线观看免费 | 欧美凹凸一区二区三区视频| 99视频精品| 亚洲午夜高清视频| 久久一二三四| 国产精品永久| 亚洲经典在线| 激情综合电影网| 欧美日韩1080p| 另类天堂av| 亚洲综合精品| 国产精品一区二区a| 亚洲黄色成人| 在线观看欧美亚洲| 黑丝一区二区| 欧美日本一区| 欧美黄色一级视频| 欧美 日韩 国产一区二区在线视频 | 久久久久久精| 国产乱码精品| 国产亚洲永久域名| 国产欧美日韩一级| 亚洲神马久久| 一本色道88久久加勒比精品| 国语精品中文字幕| 欧美久久久久久久| 欧美欧美天天天天操| 午夜久久tv| 欧美视频不卡| 亚洲国产激情| 亚洲国产精品一区| 亚洲黑丝一区二区| 99国产一区| 亚洲欧美精品在线观看| 亚洲综合精品四区| 久久看片网站| 欧美日韩无遮挡| 精品福利电影| 国产日韩欧美三区| 美女精品国产| 国产精品a级| 日韩图片一区| 米奇777在线欧美播放| 你懂的网址国产 欧美| 欧美另类综合| 亚洲精品日韩久久| 欧美中文日韩| 欧美日韩综合网| 99国产精品久久久久老师| 国产精品试看| 欧美日韩精品免费观看视一区二区| 亚洲午夜激情| 亚洲欧美日本日韩| 欧美色综合网| 一区二区欧美日韩| 狼狼综合久久久久综合网| 欧美另类女人| 一本色道久久综合亚洲精品婷婷 | 亚洲午夜高清视频| 中文一区在线| 欧美日本韩国在线| 国产日韩欧美一区二区三区在线观看| 国产女主播一区二区| 欧美精品九九| 国产一区二区三区高清| 久久亚洲免费| 99精品视频网| 欧美不卡一区| 国产久一道中文一区| 国产一区日韩一区| 亚洲在线日韩| 亚洲高清激情| 午夜精品婷婷| 久久不射2019中文字幕| 在线精品观看| 久久综合九色综合网站| 中文在线一区| 好看的亚洲午夜视频在线| 久久精品九九| 国产欧美亚洲日本| 亚洲高清不卡| 国产精品成人一区二区网站软件 | 亚洲视频中文| 久久欧美肥婆一二区| 亚洲美女网站| 伊人久久大香线蕉av超碰演员| 久久三级视频| 亚洲欧美日本日韩| 一本久道久久综合狠狠爱| 亚洲小说区图片区| 国产精品99免费看| 午夜天堂精品久久久久| 久久激情久久| 久久精品道一区二区三区| 在线亚洲精品| 国产日韩一区二区| 亚洲美女少妇无套啪啪呻吟| 精品91久久久久| 国产在线视频欧美一区二区三区| 久久综合久久久| 久久久国产精品一区二区中文| 亚洲一区二区三区精品视频| 一区二区三区四区五区精品视频| 亚洲国产影院| 99国产一区| 国产精品日韩一区二区| 国产精品日本一区二区| 99视频一区| 国产九区一区在线| 性娇小13――14欧美| 久久国产精品一区二区三区四区| 免费日韩精品中文字幕视频在线| 欧美亚洲免费| 欧美一区91| 国产一区再线| 亚洲日本视频| 国产精品社区| 米奇777在线欧美播放| 久久婷婷影院| 国产精品v亚洲精品v日韩精品| 国产精品v亚洲精品v日韩精品| 狠狠色综合网| 一区二区动漫| 免费日韩av片| 午夜日韩视频| 亚洲婷婷在线| 99精品热6080yy久久| 亚洲免费在线| 欧美日韩综合另类| 亚洲三级国产| 久久精品三级| 国产一区自拍视频| 夜夜爽99久久国产综合精品女不卡| 国产精品日韩久久久| 久久激情综合| 1024日韩| 久久国产精品高清| 国产一区二区在线观看免费播放| 亚洲精品日韩精品| 久久国产精品久久w女人spa| 欧美日韩精品免费观看| 国产日韩一区欧美| 欧美黄在线观看| 在线亚洲免费| 午夜精品剧场| 国产精品毛片在线| 国内久久精品| 亚洲欧美日韩精品久久久| 欧美另类专区| 99香蕉国产精品偷在线观看| 欧美在线日韩| 国产日韩欧美| 国内自拍视频一区二区三区| 免费在线一区二区| 亚洲日本视频| 国产精品v欧美精品v日韩精品| 亚洲一区日本| 亚洲精品精选| 亚洲私人影院| 欧美激情国产日韩| 午夜亚洲视频| 国产日韩欧美| 99香蕉国产精品偷在线观看 |