在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

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

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

3天內不再提示

采用格雷碼異步FIFO跟標準FIFO有什么區別

CHANBAEK ? 來源:硬件王國 ? 作者:小山哥 ? 2023-09-14 11:21 ? 次閱讀

導讀:

異步FIFO包含"讀"和"寫“兩個部分,寫操作和讀操作在不同的時鐘域中執行,這意味著Write_Clk和Read_Clk的頻率和相位可以完全獨立。異步FIFO的原理很簡單,寫操作是在寫使能有效時,寫地址指針(Write_Pointer)逐漸遞增,將數據寫入存儲器的相應位置。讀操作是在讀使能信號有效時,讀地址指(Read_Pointer)逐漸遞增,從存儲器的相應位置讀取數據。

但異步FIFO有一個難點就是—滿和空的產生。寫操作,我們得判斷FIFO是不是滿了,滿了就不能繼續往里面寫,不然就會覆蓋還沒取走的數據。對于讀操作,我們得判斷FIFO是不是空了,空了就不能接著取,不然舊的數據會被取多次。

觸發異步FIFO的滿和空,是拿讀和寫的Pointer做比較得到的。問題在于:寫操作下的Write_Pointer和讀操作下的Read_Pointer屬于兩個不同的時鐘域信號。兩個不同的時鐘域信號是不能直接做運算的,需要同步到同一個時鐘域之后才行,因為有這個CDC同步器的開銷,導致FIFO出現 真 滿空和 假 滿空。

接下來我們一起來看看標準異步FIFO的”真“滿空和“假“滿空如何產生,以及采用格雷碼異步FIFO跟標準FIFO有什么區別。(這里所謂標準異步FIFO是指不使用特殊編碼方式(如格雷碼)的異步FIFO,即使用常規的二進制地址指針。)

標準異步FIFO

圖片

標準異步FIFO結構如上圖,假設FIFO的深度為8,addr(地址范圍)為0 ~ 7。那么設計讀寫地址指針都是4bit,即w_ptr[3:0],r_ptr[3:0],其中最高bit是擴展位。ptr取值范圍是0 ~15,要比FIFO地址(addr)多一倍。為什么這么設計呢?因為滿和空本質上是讀和寫指向了FIFO的同一個存儲單元,但是“空”是讀指針追上了寫指針,“滿”是寫指針超過了讀指針整整一圈。其中最高位就是用來確定是 “誰追上了誰”

如果兩個ptr低位全等,最高位不等,就是“滿”;

如果兩個Ptr低位全等,最高位相等,就是“空”。

如圖所示,將w_ptr通過CDC同步之后,送到讀時鐘域,得到w_ptr_syn,然后再將它和r_ptr作比較,就可以得到“空”信號,代碼如下:

assign empty = (w_ptr_syn[3:0]== r_ptr[3:0]);

同理,將r_ptr通過CDC同步之后,送到寫時鐘域,得到r_ptr_syn,然后將它和w_ptr作比較,就可以得到滿信號,代碼如下:

assign full = (w_ptr[3] != r_ptr_syn[3]) && (w_ptr[2:0] == r_ptr_syn[2:0]);

大家覺得上面的代碼得到的滿和空是“ 真”滿空嗎?

答案是否定的。因為CDC同步器本身也需要開銷,一般簡單的兩級同步器需要目標時鐘域兩個時鐘周期。當我們判斷滿信號的時候,我們是在 寫時鐘域 ,用w_ptr和同步過來的r_ptr_syn做比較。r_ptr_syn要比真正的r_ptr要滯后,導致判滿的邏輯并不完全準確。當FIFO接近滿的時候,full信號就會為1,從而阻止對FIFO繼續寫入(腦補:“滿”意味著寫比讀塊,寫指針馬上趕上讀指針一圈,此刻還與滯后同步過來的讀指針比較,是不是快滿還沒滿時就滿足full條件了?)。同理,當FIFO接近空,但是實際可能還沒空的時候,empty信號就會為1。

這種假滿空并不會導致FIFO的行為出錯,只會導致FIFO的利用率并非百分百,相當于FIFO的深度少了那么一兩層。

那么FIFO能得到真滿空嗎?

答案肯定是可以的。如果我們在寫時鐘域判斷“空”信號,在讀時鐘域判斷“滿”信號呢?(在寫時鐘域,通過滯后的r_ptr_syn都得到了“空”信號,那說明實際的r_ptr必然真的趕上了w_ptr,此刻FIFO絕對空了。在讀時鐘域,通過滯后的w_ptr_syn都得到了“滿”信號,那說明實際的w_ptr必然真的超過了r_ptr一圈,此刻FIFO絕對滿了)。

assign empty_real = (w_ptr[3:0] == r_ptr_syn[3:0]);

assign full_real = (r_ptr[3] != w_ptr_syn[3]) && (r_ptr[2:0] == w_ptr_syn[2:0]);

這個“真”滿空信號,用到的時候并不多。但是理解“真”滿空和“假”滿空,是理解異步FIFO的基礎。

采用格雷碼的異步FIFO

采用格雷碼的異步FIFO判斷“滿”和“空”的原理沒變,跟標準FIFO是一樣的,即在寫時鐘域判斷滿條件,在讀時鐘域判斷空條件:

如果兩個ptr低位全等,最高位不等,就是“滿”;

如果兩個Ptr低位全等,最高位相等,就是“空”。

只不過,地址指針采用的是格雷碼,如寫地址指針:

assign nxt_wptr = (!full && wr_en) ? (wptr +1'b1):wptr;  

assign nxt_wptr_gray = (nxt_wptr >>1)^nxt_wptr;

判斷空條件:則在讀時鐘域,讀地址指針格雷碼 與 兩級同步過來后的寫地址指針格雷碼(nxt_wptr_gray)進行比較:

always@(posedge rclk or negedge rst_n)

begin

    if(!rst_n) begin

        wptr_sp1<=6'b0;

        wptr_sp2<=6'b0;

    end

    else begin

        wptr_sp1<=nxt_wptr_gray;

        wptr_sp2<=wptr_sp1;    

    end                        

end

assign empty=(rptr_gray==wptr_sp2);

同理,判斷滿條件:

assign full=(wptr_gray=={~rptr_sp2[3],rptr_sp2[2:0]});

理解到這兒,本質上兩種FIFO似乎沒什么區別,那為什么要用格雷碼編碼呢? 異步FIFO采用格雷碼的主要原因是為了減少在異步時鐘域中地址指針變化時可能出現的不穩定性,從而增強異步FIFO的可靠性和穩定性即使在亞穩態進行讀寫指針抽樣也能進行正確的空滿狀態判斷”。

下面兩張圖是采用格雷碼的異步FIFO觸發滿和空條件的截圖,從圖示可看出,4根標紅的格雷碼地址指針 每一周期前后只有1位發生跳變,如wptr_gray:0010>0110>0111>0101>0100>1100>1101>1111>1110,這就是格雷碼的特性,保證了相鄰的兩個值只有一個位元發生變化,因此在變化時不會出現多個位同時變化,減少了不穩定狀態的可能性。

圖片

滿條件

圖片

空條件

為什么2 進制指針做空滿判斷存在不穩定的可能呢?事實上 2 進制讀指針在增減時,經常發生多位突變,比如 6 位地址 111111 會在下一時刻變成 000000 ,在實際電路中,這個變化過程要持續很長一段時間,會由 111111 經歷 6 個狀態轉移到達 000000 。比如 111111-> 101111 -> 100111 ->100110 -> 100100 -> 000100-> 000000 。由于寫時鐘與讀時鐘不同步,異步的寫時鐘很可能會在狀態不穩定的中間某個狀態抽樣,這樣就會得到錯誤的讀指針,進而做出錯誤的狀態判斷,導致系統異常。

當采用格雷碼只有一個比特發生改變時,即使在中間狀態抽樣,其結果也不外乎兩種:遞增前原指針和遞增后新指針。如果抽樣到遞增后的指針,預期結果跟設計一致。如果抽樣到遞增前的原指針,最壞的情況就是把“不滿”判斷成了“滿”,但是這并不會對邏輯產生影響,只是帶來了寫操作的延遲。

總結(兩種fifo的主要區別)

因此,標準范式的FIFO和采用格雷碼的FIFO都存在一定的可能出現假滿空。兩者有一些區別,主要涉及到地址指針的表示和更新方式。以下是這兩種FIFO的主要區別:

  1. 地址指針的表示:
    • 標準范式的FIFO:常常使用二進制表示的地址指針。這意味著每個存儲單元都有一個唯一的二進制地址,用于指示數據在FIFO中的位置。
    • 采用格雷碼的FIFO:地址指針通常使用格雷碼來表示。格雷碼是一種二進制碼,相鄰的兩個值只有一個位元發生變化。使用格雷碼可以減少地址指針在變化時的不穩定性,從而減少在時鐘邊沿時的不穩定狀態。
  2. 地址指針的更新方式:
    • 標準范式的FIFO:地址指針在每個時鐘周期朝一個方向遞增或遞減,用于確定要讀取或寫入的位置。在寫入數據時,寫指針增加;在讀取數據時,讀指針增加。
    • 采用格雷碼的FIFO:格雷碼地址指針的更新方式相對復雜一些。格雷碼的特性使得在更新時只有一個位發生變化,這樣可以減少指針變化的不穩定性。在讀寫操作時,格雷碼地址指針的更新可能需要一些額外的邏輯。
  3. 時序穩定性:
    • 標準范式的FIFO:由于二進制地址指針的性質,通用FIFO在時序上需要額外的同步邏輯,以確保地址指針的穩定傳遞。這尤其在不同時鐘域的情況下需要考慮。
    • 采用格雷碼的FIFO:格雷碼的特性減少了地址變化的不穩定性,因此在一些時序方面可能更容易處理。但格雷碼的使用可能需要更多的邏輯來實現。

選擇使用哪種FIFO設計取決于具體的應用需求和時序約束。格雷碼的FIFO在一些特定情況下可能提供一些優勢,但也需要權衡設計的復雜性。

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

    關注

    3

    文章

    389

    瀏覽量

    43744
  • 信號
    +關注

    關注

    11

    文章

    2794

    瀏覽量

    76893
  • 時鐘域
    +關注

    關注

    0

    文章

    52

    瀏覽量

    9542
  • 異步FIFO
    +關注

    關注

    0

    文章

    20

    瀏覽量

    8391
收藏 人收藏

    評論

    相關推薦

    基于FPGA的異步FIFO的實現

    存儲器的區別是沒有外部讀寫地址線,這樣使用起來非常簡單,但缺點就是只能順序寫入數據,順序的讀出數據,其數據地址由內部讀寫指針自動加1完成,不能像普通存儲器那樣可以由地址線決定讀取或寫入某個指定的地址。 用途1: 異步FIFO讀寫
    的頭像 發表于 06-21 11:15 ?6535次閱讀
    基于FPGA的<b class='flag-5'>異步</b><b class='flag-5'>FIFO</b>的實現

    異步FIFO設計之

    相鄰的只有1bit的差異,因此常常用于異步
    的頭像 發表于 11-01 17:37 ?1435次閱讀
    <b class='flag-5'>異步</b><b class='flag-5'>FIFO</b>設計之<b class='flag-5'>格</b><b class='flag-5'>雷</b><b class='flag-5'>碼</b>

    詳細討論異步FIFO的具體實現???

    我在網上看到一篇利用來設計異步FIFO,但是看他們寫的一些源碼,小弟有些不是很理解,在設計時為什么會出現Waddr和wptr兩個關于寫
    發表于 05-19 11:04

    請問SPI使用FIFO和不使用什么區別?使用FIFO效率更高嗎?

    本帖最后由 一只耳朵怪 于 2018-6-13 15:01 編輯 SPI使用FIFO和不使用什么區別,是不是使用FIFO效率更高
    發表于 06-13 11:12

    異步FIFO的VHDL設計

    給出了一個利用對地址編碼的羿步FIFO 的實現方法,并給出了VHDL 程序,以解決異步讀寫時鐘引起的問題。
    發表于 07-16 15:15 ?26次下載

    Camera Link接口的異步FIFO設計與實現

    介紹了異步FIFO在Camera Link接口中的應用,將Camera Link接口中的幀有效信號FVAL和行有效信號LVAL引入到異步FIFO的設計中。分析了FPGA中設計
    發表于 07-28 16:08 ?32次下載

    異步FIFO的設計分析及詳細代碼

    (每個數據的位寬) FIFO同步和異步兩種,同步即讀寫時鐘相同,異步即讀寫時鐘不相同 同步FIFO用的少,可以作為數據緩存
    發表于 11-15 12:52 ?8664次閱讀
    <b class='flag-5'>異步</b><b class='flag-5'>FIFO</b>的設計分析及詳細代碼

    利用VHDL語言和對地址進行編碼的異步FIFO的設計

    FIFO (先進先出隊列)是一種在電子系統得到廣泛應用的器件,通常用于數據的緩存和用于容納異步信號的頻率或相位的差異。FIFO的實現通常是利用雙口RAM和讀寫地址產生模塊來實現的。FIFO
    的頭像 發表于 08-02 08:10 ?2258次閱讀
    利用VHDL語言和<b class='flag-5'>格</b><b class='flag-5'>雷</b><b class='flag-5'>碼</b>對地址進行編碼的<b class='flag-5'>異步</b><b class='flag-5'>FIFO</b>的設計

    異步FIFO的原因哪些

    異步FIFO通過比較讀寫地址進行滿空判斷,但是讀寫地址屬于不同的時鐘域,所以在比較之前需要先將讀寫地址進行同步處理,將寫地址同步到讀時鐘域再和讀地址比較進行FIFO空狀態判斷(同步后的寫地址一定
    的頭像 發表于 08-04 14:05 ?4452次閱讀

    異步fifo詳解

    異步fifo詳解 一. 什么是異步FIFO FIFO即First in First out的英文簡稱,是一種先進先出的數據緩存器,與普通存儲
    的頭像 發表于 12-12 14:17 ?4219次閱讀

    FIFO設計—異步FIFO

    異步FIFO主要由五部分組成:寫控制端、讀控制端、FIFO Memory和兩個時鐘同步端
    發表于 05-26 16:17 ?1558次閱讀
    <b class='flag-5'>FIFO</b>設計—<b class='flag-5'>異步</b><b class='flag-5'>FIFO</b>

    異步FIFO-

    很多人在面試時被問到為什么異步FIFO中需要用到,可能大部分的答案是
    的頭像 發表于 08-26 14:20 ?1012次閱讀
    <b class='flag-5'>異步</b><b class='flag-5'>FIFO</b>-<b class='flag-5'>格</b><b class='flag-5'>雷</b><b class='flag-5'>碼</b>

    同步FIFO異步FIFO區別 同步FIFO異步FIFO各在什么情況下應用

    同步FIFO異步FIFO區別 同步FIFO異步FIFO
    的頭像 發表于 10-18 15:23 ?1727次閱讀

    關于另外一種設計異步FIFO的簡介

    設計者為了提升FIFO的速度使用了將二進制計數器和計數器結合在一起的方法,從最開始用一組寄存器來進行
    的頭像 發表于 10-20 10:50 ?482次閱讀
    關于另外一種設計<b class='flag-5'>異步</b><b class='flag-5'>FIFO</b>的簡介

    同步FIFO異步FIFO區別介紹

    1. FIFO簡介 FIFO是一種先進先出數據緩存器,它與普通存儲器的區別是沒有外部讀寫地址線,使用起來非常簡單,缺點是只能順序讀寫,而不能隨機讀寫。 2. 使用場景 數據緩沖:也就是數據寫入過快
    的頭像 發表于 06-04 14:27 ?1703次閱讀
    同步<b class='flag-5'>FIFO</b>和<b class='flag-5'>異步</b><b class='flag-5'>FIFO</b><b class='flag-5'>區別</b>介紹
    主站蜘蛛池模板: 九色视频播放| 国产小片| 台湾香港澳门三级在线| 中文字幕日本一区波多野不卡| www.av网站| 爆操极品美女| 在线观看一区二区三区视频| 日韩dv| 好黄好硬好爽好刺激| 视频在线播放免费| 国产免费啪啪| 免费看的黄视频| 真人一级一级特黄高清毛片| 性欧美高清强烈性视频| 色婷婷婷婷| 正在播放羽月希与黑人bd在线| 国产免费一区二区三区香蕉精| 爱逼综合| 天天躁夜夜躁狠狠躁2018a| 午夜视频在线免费观看| 久久福利青草精品资源站免费| 天堂-bt种子| 欧美午夜场| 国产女人视频免费观看| 亚洲黄视频| 97国产影院| 午夜影院网站| 久久久免费的精品| h网站在线观看| 在线免费你懂的| 日韩精品在线一区二区| 色婷婷丁香六月| 毛片日韩| 精品国产三级a∨在线| 凹凸福利视频导航| 免费成人毛片| 亚洲乱码卡一卡二卡三永久| 亚洲成a人片7777| 美国色天使| 天天噜夜夜操| 色婷婷狠狠干|