吴忠躺衫网络科技有限公司

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

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

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

FPGA設(shè)計(jì)中解決跨時(shí)鐘域的三大方案

454398 ? 來源:CSDN博主 ? 作者:weixin_43343190 ? 2020-11-21 11:13 ? 次閱讀

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

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

本文介紹的3種方法跨時(shí)鐘域處理方法如下:
1. 打兩拍;"
2. 異步雙口RAM;"
3. 格雷碼轉(zhuǎn)換;"

第一種方法:打兩拍

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

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


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

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


data是時(shí)鐘域1的數(shù)據(jù),需要傳到時(shí)鐘域2(clk)進(jìn)行處理,寄存器1和寄存器2使用的時(shí)鐘都為clk。假設(shè)在clk的上升沿正好采到data的跳變沿(從0變1的上升沿,實(shí)際上的數(shù)據(jù)跳變不可能是瞬時(shí)的,所以有短暫的跳變時(shí)間),那這時(shí)作為寄存器1的輸入到底應(yīng)該是0還是1呢?這是一個(gè)不確定的問題。所以Q1的值也不能確定,但至少可以保證,在clk的下一個(gè)上升沿,Q1基本可以滿足第二級(jí)寄存器的保持時(shí)間和建立時(shí)間要求,出現(xiàn)亞穩(wěn)態(tài)的概率得到了很大的改善。

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

第二種方法:異步雙口RAM

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

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

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

第三種方法:格雷碼轉(zhuǎn)換

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

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

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

對(duì)于格雷碼,相鄰的兩個(gè)數(shù)間只有一個(gè)bit是不一樣的(格雷碼,在本文中不作詳細(xì)介紹),如果先將RAM的寫地址轉(zhuǎn)為格雷碼,然后再將寫地址的格雷碼進(jìn)行打兩拍,之后再在RAM的讀時(shí)鐘域?qū)⒏窭状a恢復(fù)成10進(jìn)制。這種處理就相當(dāng)于對(duì)單bit數(shù)據(jù)的跨時(shí)鐘域處理了。

對(duì)于格雷碼與十進(jìn)制互換的代碼,僅提供給大家作參考:

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

編輯:hfy


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

    關(guān)注

    9

    文章

    428

    瀏覽量

    26627
  • 寄存器
    +關(guān)注

    關(guān)注

    31

    文章

    5363

    瀏覽量

    121157
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    如何處理好FPGA設(shè)計(jì)時(shí)鐘問題?

    時(shí)鐘處理是 FPGA 設(shè)計(jì)中經(jīng)常遇到的問題,而如何處理好時(shí)鐘
    發(fā)表于 09-22 10:24

    探尋FPGA時(shí)鐘處理方法

    時(shí)鐘處理是 FPGA 設(shè)計(jì)中經(jīng)常遇到的問題,而如何處理好時(shí)鐘
    發(fā)表于 10-20 09:27

    時(shí)鐘處理的方法

      時(shí)鐘處理是FPGA設(shè)計(jì)中經(jīng)常遇到的問題,而如何處理好時(shí)鐘
    發(fā)表于 01-08 16:55

    FPGA界最常用的時(shí)鐘處理法式

    時(shí)鐘處理是FPGA設(shè)計(jì)中經(jīng)常遇到的問題,而如何處理好時(shí)鐘
    發(fā)表于 02-21 07:00

    FPGA初學(xué)者的必修課:FPGA時(shí)鐘處理3大方

    時(shí)鐘處理是FPGA設(shè)計(jì)中經(jīng)常遇到的問題,而如何處理好時(shí)鐘
    發(fā)表于 03-04 09:22

    如何處理好FPGA設(shè)計(jì)時(shí)鐘間的數(shù)據(jù)

    時(shí)鐘處理是FPGA設(shè)計(jì)中經(jīng)常遇到的問題,而如何處理好時(shí)鐘
    發(fā)表于 07-29 06:19

    FPGA時(shí)鐘處理簡(jiǎn)介

    (10)FPGA時(shí)鐘處理1.1 目錄1)目錄2)FPGA簡(jiǎn)介3)Verilog HDL簡(jiǎn)介4)FPG
    發(fā)表于 02-23 07:47

    FPGA界最常用也最實(shí)用的3種時(shí)鐘處理的方法

    時(shí)鐘處理是FPGA設(shè)計(jì)中經(jīng)常遇到的問題,而如何處理好時(shí)鐘
    發(fā)表于 11-15 20:08 ?1.4w次閱讀

    如何利用FPGA設(shè)計(jì)一個(gè)時(shí)鐘的同步策略?

    基于FPGA的數(shù)字系統(tǒng)設(shè)計(jì)中大都推薦采用同步時(shí)序的設(shè)計(jì),也就是單時(shí)鐘系統(tǒng)。但是實(shí)際的工程,純粹單時(shí)鐘系統(tǒng)設(shè)計(jì)的情況很少,特別是設(shè)計(jì)模塊與外圍芯片的通信中,
    的頭像 發(fā)表于 09-01 08:29 ?5594次閱讀
    如何利用<b class='flag-5'>FPGA</b>設(shè)計(jì)一個(gè)<b class='flag-5'>跨</b><b class='flag-5'>時(shí)鐘</b><b class='flag-5'>域</b>的同步策略?

    關(guān)于FPGA時(shí)鐘的問題分析

    時(shí)鐘問題(CDC,Clock Domain Crossing )是多時(shí)鐘設(shè)計(jì)的常見現(xiàn)象。在FPGA
    發(fā)表于 08-19 14:52 ?3402次閱讀

    揭秘FPGA時(shí)鐘處理的大方

    時(shí)鐘處理是 FPGA 設(shè)計(jì)中經(jīng)常遇到的問題,而如何處理好時(shí)鐘
    的頭像 發(fā)表于 12-05 16:41 ?1703次閱讀

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

    時(shí)鐘處理是FPGA設(shè)計(jì)中經(jīng)常遇到的問題,而如何處理好時(shí)鐘
    的頭像 發(fā)表于 09-18 11:33 ?2.2w次閱讀
    介紹3種方法<b class='flag-5'>跨</b><b class='flag-5'>時(shí)鐘</b><b class='flag-5'>域</b>處理方法

    時(shí)鐘處理的方法

    時(shí)鐘處理是FPGA設(shè)計(jì)中經(jīng)常遇到的問題,而如何處理好時(shí)鐘
    的頭像 發(fā)表于 10-18 09:12 ?8000次閱讀

    FPGA時(shí)鐘處理方法(一)

    時(shí)鐘FPGA設(shè)計(jì)中最容易出錯(cuò)的設(shè)計(jì)模塊,而且一旦時(shí)鐘
    的頭像 發(fā)表于 05-25 15:06 ?2081次閱讀
    <b class='flag-5'>FPGA</b><b class='flag-5'>跨</b><b class='flag-5'>時(shí)鐘</b><b class='flag-5'>域</b>處理方法(一)

    fpga時(shí)鐘通信時(shí),慢時(shí)鐘如何讀取快時(shí)鐘發(fā)送過來的數(shù)據(jù)?

    fpga時(shí)鐘通信時(shí),慢時(shí)鐘如何讀取快時(shí)鐘發(fā)送過來的數(shù)據(jù)? 在
    的頭像 發(fā)表于 10-18 15:23 ?1140次閱讀
    励骏会百家乐官网的玩法技巧和规则 | 武冈市| 鼎龙百家乐官网的玩法技巧和规则| 广州太阳城巧克力社区| 百家乐官网之对子的技巧| 百家乐官网赢钱| 广州百家乐扫描分析| 嘉祥县| 百家乐稳赢秘笈| 萨迦县| 现金百家乐人气最高| bet365提款要多久| 百家乐官网赌博规律| 送58百家乐的玩法技巧和规则| 网上百家乐官网骗人的吗| 百家乐改单软件| 百家乐官网娱乐网站| 百家乐技巧-澳门百家乐官方网址| 新民市| 真人百家乐代理分成| 百家乐官网赢法口诀| 百家乐真人荷官网| 百家乐官网视频游戏掉线| 百家乐如何赚洗码| 神人百家乐官网赌博| 水果机破解| 八大胜百家乐官网娱乐城| 钱大发888扑克| 百家乐官网乐百家娱乐场| 足球竞猜规则| 代理百家乐免费试玩| 百家乐官网技巧之写路| 百家乐技巧开户网址| 百家乐官网园蒙| 百家乐官网娱乐官方网| 二八杠游戏机| 新澳门百家乐官网的玩法技巧和规则 | 威尼斯人娱乐网注册送38元彩金 | 六合彩挂牌| 永利高百家乐开户| 百家乐官网下注平台|