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

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

3天內(nèi)不再提示

介紹3種方法跨時鐘域處理方法

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

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

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

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

1.打兩拍;“

2.異步雙口RAM;”

3.格雷碼轉換;“

第一種方法:打兩拍

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

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

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

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

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

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

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

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

第二種方法:異步雙口RAM

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

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

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

第三種方法:格雷碼轉換

對于第三種方法,Kevin在大學里邊從沒接觸過,也是在工作中才接觸到。

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

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

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

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

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

編輯:jq

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

    關注

    455

    文章

    50816

    瀏覽量

    423612
  • RAM
    RAM
    +關注

    關注

    8

    文章

    1368

    瀏覽量

    114693
  • adc
    adc
    +關注

    關注

    98

    文章

    6498

    瀏覽量

    544640
  • 函數(shù)
    +關注

    關注

    3

    文章

    4331

    瀏覽量

    62618
  • 代碼
    +關注

    關注

    30

    文章

    4788

    瀏覽量

    68611

原文標題:解決跨時鐘域問題的三大方法

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

收藏 人收藏

    評論

    相關推薦

    一文解析時鐘傳輸

    采樣到的信號質量!最常用的同步方法是雙級觸發(fā)器緩存法,俗稱延遲打拍法。信號從一個時鐘進入另一個時鐘之前,將該信號用兩級觸發(fā)器連續(xù)緩存兩次
    的頭像 發(fā)表于 11-16 11:55 ?533次閱讀
    一文解析<b class='flag-5'>跨</b><b class='flag-5'>時鐘</b><b class='flag-5'>域</b>傳輸

    簡單高效配置FPGA的方法

    本文描述了一簡單高效配置FPGA的方法,該方法利用微處理器從串行外圍接口(SPI)閃存配置FPGA設備。這種方法減少了硬件組件、板空間和成
    的頭像 發(fā)表于 10-24 14:57 ?603次閱讀
    一<b class='flag-5'>種</b>簡單高效配置FPGA的<b class='flag-5'>方法</b>

    pwm脈寬調制的四種方法有哪些

    于電機控制、LED調光、音頻處理等領域。以下是四常見的PWM脈寬調制方法: 固定頻率PWM(Fixed-Frequency PWM) 固定頻率PWM是一最基本的PWM調制
    的頭像 發(fā)表于 08-08 15:10 ?1336次閱讀

    FPGA異步信號處理方法

    FPGA(現(xiàn)場可編程門陣列)在處理異步信號時,需要特別關注信號的同步化、穩(wěn)定性以及潛在的亞穩(wěn)態(tài)問題。由于異步信號可能來自不同的時鐘或外部設備,其到達時間和頻率可能不受FPGA內(nèi)部時鐘
    的頭像 發(fā)表于 07-17 11:10 ?1154次閱讀

    人臉檢測的五種方法各有什么特征和優(yōu)缺點

    人臉檢測是計算機視覺領域的一個重要研究方向,主要用于識別和定位圖像中的人臉。以下是五常見的人臉檢測方法及其特征和優(yōu)缺點的介紹: 基于膚色的方法 特征:基于膚色的
    的頭像 發(fā)表于 07-03 14:47 ?840次閱讀

    介紹一個IC設計錯誤案例:可讀debug寄存器錯誤時鐘

    本文將介紹一個時鐘錯誤的案例如圖所示,phy_status作為一個多bit的phy_clk時鐘的信號,需要輸入csr模塊作為一個可讀狀態(tài)
    的頭像 發(fā)表于 03-11 15:56 ?517次閱讀
    <b class='flag-5'>介紹</b>一個IC設計錯誤案例:可讀debug寄存器錯誤<b class='flag-5'>跨</b><b class='flag-5'>時鐘</b>

    三菱M70 PLC增加注解的三種方法簡析

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

    3雙控開關的接線方法

    3雙控開關的接線方法? 雙控開關是常用的電氣元件之一,能夠實現(xiàn)同一電路的多個位置進行開關控制。它一般由兩個普通開關和一個互補開關組成,通過合理的接線,可以實現(xiàn)控制電路在不同位置進行開關。今天我將
    的頭像 發(fā)表于 02-05 13:46 ?5540次閱讀

    傳統(tǒng)激光功率衰減的三種方法

    傳統(tǒng)激光功率衰減通常使用以下三種方法,分別為中性密度衰減片衰減法、偏振衰減法、鍍膜光學鏡片衰減法。
    的頭像 發(fā)表于 01-20 10:42 ?1756次閱讀
    傳統(tǒng)激光功率衰減的三<b class='flag-5'>種方法</b>

    異步電路中的時鐘同步處理方法

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

    批量替換多個文件中特定字符串的3種方法

    在驗證工作中我們經(jīng)常遇到批量處理某些文件,或者某些文件中關鍵詞的問題,如果單個打開編輯,效率就太低,本文分享3簡單易用的批量處理多個文件中特定字符串的
    的頭像 發(fā)表于 01-09 10:36 ?2207次閱讀
    批量替換多個文件中特定字符串的<b class='flag-5'>3</b><b class='flag-5'>種方法</b>

    時鐘的解決方案

    在很久之前便陸續(xù)談過亞穩(wěn)態(tài),F(xiàn)IFO,復位的設計。本次亦安做一個簡單的總結,從宏觀上給大家展示時鐘的解決方案。
    的頭像 發(fā)表于 01-08 09:42 ?907次閱讀
    <b class='flag-5'>跨</b><b class='flag-5'>時鐘</b><b class='flag-5'>域</b>的解決方案

    如何處理時鐘這些基礎問題

    對于數(shù)字設計人員來講,只要信號從一個時鐘跨越到另一個時鐘,那么就可能發(fā)生亞穩(wěn)態(tài)。我們稱為“時鐘
    發(fā)表于 01-08 09:39 ?647次閱讀
    如何<b class='flag-5'>處理</b><b class='flag-5'>跨</b><b class='flag-5'>時鐘</b><b class='flag-5'>域</b>這些基礎問題

    labview與sql數(shù)據(jù)庫連接5種方法

    連接LabVIEW和SQL數(shù)據(jù)庫是一常見的需求,可以通過多種方法實現(xiàn)。本文將介紹連接LabVIEW和SQL數(shù)據(jù)庫的方法。
    的頭像 發(fā)表于 01-07 16:01 ?4908次閱讀

    編寫PLC程序的7種方法

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