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

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

3天內不再提示

介紹3種方法跨時(shí)鐘域處理方法

FPGA設計論壇 ? 來(lái)源:CSDN技術(shù)社區 ? 作者:weixin_43343190 ? 2021-09-18 11:33 ? 次閱讀

時(shí)鐘域處理是FPGA設計中經(jīng)常遇到的問(wèn)題,而如何處理好跨時(shí)鐘域間的數據,可以說(shuō)是每個(gè)FPGA初學(xué)者的必修課。如果是還是在校的學(xué)生,跨時(shí)鐘域處理也是面試中經(jīng)常常被問(wèn)到的一個(gè)問(wèn)題。

在本篇文章中,主要介紹3種跨時(shí)鐘域處理的方法,這3種方法可以說(shuō)是FPGA界最常用也最實(shí)用的方法,這三種方法包含了單bit和多bit數據的跨時(shí)鐘域處理,學(xué)會(huì )這3招之后,對于FPGA相關(guān)的跨時(shí)鐘域數據處理便可以手到擒來(lái)。

本文介紹的3種方法跨時(shí)鐘域處理方法如下:

1.打兩拍;“

2.異步雙口RAM;”

3.格雷碼轉換;“

第一種方法:打兩拍

大家很清楚,處理跨時(shí)鐘域的數據有單bit和多bit之分,而打兩拍的方式常見(jiàn)于處理單bit數據的跨時(shí)鐘域問(wèn)題。

打兩拍的方式,其實(shí)說(shuō)白了,就是定義兩級寄存器,對輸入的數據進(jìn)行延拍。

先簡(jiǎn)單說(shuō)下兩級寄存器的原理:兩級寄存是一級寄存的平方,兩級并不能完全消除亞穩態(tài)危害,但是提高了可靠性減少其發(fā)生概率??偟膩?lái)講,就是一級概率很大,三級改善不大。

這樣說(shuō)可能還是有很多人不夠完全理解,那么請看下面的時(shí)序示意圖:

65ba5808-13d8-11ec-8fb8-12bb97331649.jpg

data是時(shí)鐘域1的數據,需要傳到時(shí)鐘域2(clk)進(jìn)行處理,寄存器1和寄存器2使用的時(shí)鐘都為clk。假設在clk的上升沿正好采到data的跳變沿(從0變1的上升沿,實(shí)際上的數據跳變不可能是瞬時(shí)的,所以有短暫的跳變時(shí)間),那這時(shí)作為寄存器1的輸入到底應該是0還是1呢?

這是一個(gè)不確定的問(wèn)題。所以Q1的值也不能確定,但至少可以保證,在clk的下一個(gè)上升沿,Q1基本可以滿(mǎn)足第二級寄存器的保持時(shí)間和建立時(shí)間要求,出現亞穩態(tài)的概率得到了很大的改善。

如果再加上第三級寄存器,由于第二級寄存器對于亞穩態(tài)的處理已經(jīng)起到了很大的改善作用,第三級寄存器在很大程度上可以說(shuō)只是對于第二級寄存器的延拍,所以意義是不大的。

第二種方法:異步雙口RAM

處理多bit數據的跨時(shí)鐘域,一般采用異步雙口RAM。假設我們現在有一個(gè)信號采集平臺,ADC芯片提供源同步時(shí)鐘60MHz,ADC芯片輸出的數據在60MHz的時(shí)鐘上升沿變化,而FPGA內部需要使用100MHz的時(shí)鐘來(lái)處理ADC采集到的數據(多bit)。

在這種類(lèi)似的場(chǎng)景中,我們便可以使用異步雙口RAM來(lái)做跨時(shí)鐘域處理。先利用ADC芯片提供的60MHz時(shí)鐘將ADC輸出的數據寫(xiě)入異步雙口RAM,然后使用100MHz的時(shí)鐘從RAM中讀出。

對于使用異步雙口RAM來(lái)處理多bit數據的跨時(shí)鐘域,相信大家還是可以理解的。當然,在能使用異步雙口RAM來(lái)處理跨時(shí)鐘域的場(chǎng)景中,也可以使用異步FIFO來(lái)達到同樣的目的。

第三種方法:格雷碼轉換

對于第三種方法,Kevin在大學(xué)里邊從沒(méi)接觸過(guò),也是在工作中才接觸到。

我們依然繼續使用介紹第二種方法中用到的ADC例子,將ADC采樣的數據寫(xiě)入RAM時(shí),需要產(chǎn)生RAM的寫(xiě)地址,但我們讀出RAM中的數據時(shí),肯定不是一上電就直接讀取,而是要等RAM中有ADC的數據之后才去讀RAM。這就需要100MHz的時(shí)鐘對RAM的寫(xiě)地址進(jìn)行判斷,當寫(xiě)地址大于某個(gè)值之后再去讀取RAM。

在這個(gè)場(chǎng)景中,其實(shí)很多人都是使用直接用100MHz的時(shí)鐘于RAM的寫(xiě)地址進(jìn)行打兩拍的方式,但RAM的寫(xiě)地址屬于多bit,如果單純只是打兩拍,那不一定能確保寫(xiě)地址數據的每一個(gè)bit在100MHz的時(shí)鐘域變化都是同步的,肯定有一個(gè)先后順序。如果在低速的環(huán)境中不一定會(huì )出錯,在高速的環(huán)境下就不一定能保證了。所以更為妥當的一種處理方法就是使用格雷碼轉換。

對于格雷碼,相鄰的兩個(gè)數間只有一個(gè)bit是不一樣的(格雷碼,在本文中不作詳細介紹),如果先將RAM的寫(xiě)地址轉為格雷碼,然后再將寫(xiě)地址的格雷碼進(jìn)行打兩拍,之后再在RAM的讀時(shí)鐘域將格雷碼恢復成10進(jìn)制。這種處理就相當于對單bit數據的跨時(shí)鐘域處理了。對于格雷碼與十進(jìn)制互換的代碼,僅提供給大家作參考:

65c5065e-13d8-11ec-8fb8-12bb97331649.png

代碼使用的是函數的形式,方便調用,op表示編碼或者譯碼,WADDRWIDTH和RADDRWIDTH表示位寬。

編輯:jq

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

    關(guān)注

    447

    文章

    48392

    瀏覽量

    412258
  • RAM
    RAM
    +關(guān)注

    關(guān)注

    8

    文章

    1330

    瀏覽量

    113892
  • adc
    adc
    +關(guān)注

    關(guān)注

    95

    文章

    5696

    瀏覽量

    540458
  • 函數
    +關(guān)注

    關(guān)注

    3

    文章

    4117

    瀏覽量

    61515
  • 代碼
    +關(guān)注

    關(guān)注

    30

    文章

    4591

    瀏覽量

    67239

原文標題:解決跨時(shí)鐘域問(wèn)題的三大方法

文章出處:【微信號:gh_9d70b445f494,微信公眾號:FPGA設計論壇】歡迎添加關(guān)注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    三菱M70 PLC增加注解的三種方法簡(jiǎn)析

    三菱M70 PLC增加注解的三種方法
    的頭像 發(fā)表于 02-26 09:59 ?348次閱讀
    三菱M70 PLC增加注解的三<b class='flag-5'>種方法</b>簡(jiǎn)析

    異步電路中的時(shí)鐘同步處理方法

    異步電路中的時(shí)鐘同步處理方法? 時(shí)鐘同步在異步電路中是至關(guān)重要的,它確保了電路中的各個(gè)部件在正確的時(shí)間進(jìn)行操作,從而使系統能夠正常工作。在本文中,我將
    的頭像 發(fā)表于 01-16 14:42 ?467次閱讀

    編寫(xiě)PLC程序的7種方法

    種方法是最原始最初級的寫(xiě)法,也是最簡(jiǎn)單的一種寫(xiě)法,比如第一步置位M0,M0接通后控制某個(gè)結果,結果實(shí)現后復位M0,再置位M1,依次進(jìn)行l流程控制。這種寫(xiě)法通用所有的PLC。
    發(fā)表于 01-02 11:08 ?9118次閱讀
    編寫(xiě)PLC程序的7<b class='flag-5'>種方法</b>

    PoE以太網(wǎng)供電的兩種方法

    電力,簡(jiǎn)化了設備的安裝和布線(xiàn)。在本文中,我們將詳細介紹PoE以太網(wǎng)供電的兩種方法。 第一種方法是標準PoE供電(IEEE 802.3af)。這種方法需要一個(gè)雙絞線(xiàn)以太網(wǎng)電纜來(lái)傳輸電力和
    的頭像 發(fā)表于 11-28 15:51 ?619次閱讀

    linux網(wǎng)絡(luò )配置的3種方法

    Linux是一種流行的操作系統,廣泛應用于服務(wù)器和網(wǎng)絡(luò )設備中。Linux系統提供了多種方法來(lái)配置網(wǎng)絡(luò )連接,使得網(wǎng)絡(luò )設置更加靈活和可定制。本文將會(huì )介紹Linux網(wǎng)絡(luò )配置的三種方法,包括命令行方式
    的頭像 發(fā)表于 11-27 14:33 ?1679次閱讀

    修復鋰電池的三種方法

    電子發(fā)燒友網(wǎng)站提供《修復鋰電池的三種方法.doc》資料免費下載
    發(fā)表于 11-15 10:40 ?5次下載
    修復鋰電池的三<b class='flag-5'>種方法</b>

    單片機軟件濾波的幾種方法

    電子發(fā)燒友網(wǎng)站提供《單片機軟件濾波的幾種方法.pdf》資料免費下載
    發(fā)表于 10-20 15:09 ?2次下載
    單片機軟件濾波的幾<b class='flag-5'>種方法</b>

    Docker鏡像國內加速的幾種方法

    在國內,拉取 Docker 鏡像速度慢/時(shí)不時(shí)斷線(xiàn)/無(wú)賬號導致限流等,比較痛苦. 這里提供加速/優(yōu)化的幾種方法。
    的頭像 發(fā)表于 10-19 10:02 ?1664次閱讀
    Docker鏡像國內加速的幾<b class='flag-5'>種方法</b>

    PCB走線(xiàn)鍍錫:用這種方法,既簡(jiǎn)單又漂亮!

    PCB走線(xiàn)鍍錫:用這種方法,既簡(jiǎn)單又漂亮!
    的頭像 發(fā)表于 10-17 15:10 ?1959次閱讀
    PCB走線(xiàn)鍍錫:用這<b class='flag-5'>種方法</b>,既簡(jiǎn)單又漂亮!

    C語(yǔ)言獲取文件長(cháng)度的兩種方法

    C語(yǔ)言中沒(méi)有直接獲取文件長(cháng)度的接口,但是我們可以使用標準庫提供的函數來(lái)間接的獲取文件長(cháng)度。這里提供兩種方法。
    的頭像 發(fā)表于 10-10 16:15 ?783次閱讀
    C語(yǔ)言獲取文件長(cháng)度的兩<b class='flag-5'>種方法</b>

    2種方法檢驗MSP430FR6043的測量性能

    2種方法檢驗MSP430FR6043的測量性能
    的頭像 發(fā)表于 09-18 10:58 ?551次閱讀
    2<b class='flag-5'>種方法</b>檢驗MSP430FR6043的測量性能

    用于實(shí)現電源排序的各種方法

    電子發(fā)燒友網(wǎng)站提供《用于實(shí)現電源排序的各種方法.pdf》資料免費下載
    發(fā)表于 09-14 11:02 ?0次下載
    用于實(shí)現電源排序的各<b class='flag-5'>種方法</b>

    pwm產(chǎn)生的三種方法

    技術(shù)被廣泛應用于電力電子器件(如IGBT、MOS)的控制中,也可以用于調節LED照明、伺服電機等應用中。本文將詳細介紹PWM產(chǎn)生的三種方法。 一、比較式PWM 比較式PWM是最常見(jiàn)的PWM產(chǎn)生方法,它通過(guò)比較一個(gè)變量信號與一個(gè)固
    的頭像 發(fā)表于 09-02 10:25 ?6415次閱讀

    測電阻的六種方法 電阻測試方法 電阻好壞測量方法

    ,所以對于電阻的好壞,我們需要進(jìn)行測量。下面介紹的六種方法,可供參考: 一、萬(wàn)用表測試法 這是最普遍也是最基本的電阻測試方法。將萬(wàn)用表的電位檔選為電阻檔,測量要測試的電阻兩端的電阻值即可。不過(guò),需要注意的是在測量
    的頭像 發(fā)表于 08-24 15:17 ?3.3w次閱讀

    變頻器出現跳閘狀況處理方法

    變頻器在運行中出現跳閘,即視為事故。跳閘事故的處理有以下幾種方法。
    發(fā)表于 06-27 09:25 ?2831次閱讀
    亚洲欧美日韩精品久久_久久精品AⅤ无码中文_日本中文字幕有码在线播放_亚洲视频高清不卡在线观看