<del id="dhfrq"></del>

    1. <tr id="dhfrq"></tr>
      成人午夜激情在线观看,国产精品一线天粉嫩av,99精品国产综合久久久久五月天 ,一卡2卡三卡4卡免费网站,国产高清在线男人的天堂,五月天国产成人AV免费观看,67194熟妇在线观看线路,成人无码潮喷在线观看
      現在位置:范文先生網>理工論文>電子通信論文>異步FIFO結構及FPGA設計

      異步FIFO結構及FPGA設計

      時間:2023-02-21 00:10:49 電子通信論文 我要投稿
      • 相關推薦

      異步FIFO結構及FPGA設計

        摘要:首先介紹異步FIFO的概念、應用及其結構,然后分析實現異步FIFO的難點問題及其解決辦法;在傳統設計的基礎上提出一種新穎的電路結構并對其進行綜合仿真和FPGA實現。
        關鍵詞:異步電路FIFO亞穩態格雷碼
        
        1異步FIFO介紹
        
        在現代的集成電路芯片中,隨著設計規模的不斷擴大,一個系統中往往含有數個時鐘。多時鐘域帶來的一個問題就是,如何設計異步時鐘之間的接口電路。異步FIFO(FirstInFirstOut)是解決這個問題一種簡便、快捷的解決方案。使用異步FIFO可以在兩個不同時鐘系統之間快速而方便地傳輸實時數據。在網絡接口、圖像處理等方面,異步FIFO得到了廣泛的應用。
        
        異步FIFO是一種先進先出的電路,使用在需要產時數據接口的部分,用來存儲、緩沖在兩個異步時鐘之間的數據傳輸。在異步電路中,由于時鐘之間周期和相位完全獨立,因而數據的丟失概率不為零。如何設計一個高可靠性、高速的異步FIFO電路便成為一個難點。本文介紹解決這一問題的一種方法。
        
        圖1是異步FIFO的結構框圖。
        
        由圖1可以看出:整個系統分為兩個完全獨立的時鐘域——讀時鐘域和寫時間域;FIFO的存儲介質為一塊雙端口RAM,可以同時進行讀寫操作。在寫時鐘域部分,由寫地址產生邏輯產生寫控制信號和寫地址;讀時鐘部分由讀地址產生邏輯產生讀控制信號和讀地址。在空/滿標志產生部分,由讀寫地址相互比較產生空/滿標志。
        
        2異步FIFO的設計難點
        
        設計異步FIFO有兩個難點:一是如何同步異步信號,使觸發器不產生亞穩態;二是如何正確地設計空、滿以及幾乎滿等信號的控制電路。
        
        下面闡述解決問題的具體方法。
        
        2.1亞穩態問題的解決
        
        在數字集成電路中,觸發器要滿足setup/hold的時間要求。當一個信號被寄存器鎖存時,如果信號和時鐘之間不滿足這個要求,Q端的值是不確定的,并且在未知的時刻會固定到高電平或低電平。這個過程稱為亞穩態(Metastability)。圖2所示為異步時鐘和亞穩態,圖中clka和clkb為異步時鐘。
        
        亞穩態必定會發生在異步FIFO中。圖中在異步FIFO中,電路外部的輸入和內部的時鐘之間是毫無時間關系的,因此setup/hold沖突是必然的;同在電路內部的兩個沒有關系的時鐘域之間的信號傳遞,也必須會導致setup/hold沖突。
        
        雖然亞穩態是不可避免的,但是,下面的設計改進可以將其發生的概率降低到一個可以接受的程度。
        
        ①對寫地址/讀地址采用格雷碼。由實踐可知,同步多個異步輸入信號出現亞穩態的概率遠遠大于同步一個異步信號的概率。對多個觸發器的輸出所組成的寫地址/讀地址可以采用格雷碼。由于格雷碼每次只變化一位,采用格雷碼可以有效地減少亞穩態的產生。
        
        ②采用觸發器來同步異步輸入信號,如圖3中的兩極觸發器可以將出現亞穩態的幾率降低到一個很小的程度。但是,正如圖3所示,這種方法同時帶來了對輸入信號的一級延時,需要在設計時鐘的時候加以注意。
        
        2.2空/滿標志的產生
        
        空/滿標志的產生FIFO的核心部分。如何正確設計此部分的邏輯,直接影響到FIFO的性能。
        
        空/滿標志產生的原則是:寫滿不溢出,讀空不多讀。即無論在什么進修,都不應出現讀寫地址同時對一個存儲器地址操作的情況。在讀寫地址相等或相差一個或多個地址的時候,滿標志應該有效,表示此時FIFO已滿,外部電路應對FIFO發數據。在滿信號有效時寫數據,應根據設計的要求,或保持、或拋棄重發。同理,空標志的產生也是如此,即:
        
        空標志<=(|寫地址-讀地址|<=預定值)AND(寫地址超前讀地址)
        
        滿標志<=(|寫地址-讀地址|<=預定值)AND(讀地址超前寫地址)
        
        最直接的做法是,采用讀寫地址相比較來產生空滿標志。如圖4所示,當讀寫地址的差值等于一個預設值的時候,空/滿信號被置位。這種實現方法邏輯簡單,但它是減法器形成的一個比較大的組合邏輯,因而限制了FIFO的速度。所以,一般只采用相等不相等的比較邏輯,避免使用減法器。
        
        圖5是另外一種常用的設計,比較器只對讀寫地址比較是否相等。在讀寫地址相等的時候有兩種情況:滿或者空。所以,附加了一個并行的區間判斷邏輯來指示是空還是滿。這個區間判斷邏輯將整個地址空間分為幾個部分,以指示讀寫地址的相對位置。這種做法提高了整個電路的速度,但是也有其缺點。主要是直接采用讀寫地址等于不等于的比較邏輯來進行空/滿標志的判斷,可以帶來誤判。
        
        3新穎的FIF0空/滿標志控制邏輯
        
        3.1對讀寫地址的分析
        
        由以上對FIFO的分析可以看出,由地址直接相減和將地址相互比較產生空/滿標志都不可取。如何簡單地進行直接比較,又不提高邏輯的復雜程度呢?對地址加延時可以做到這一點。設讀地址為Rd_bin_addr,用讀地址Rd_addr產生讀地址的格雷碼Rd_next_gray_addr,將Rd_next_gray_addr延一拍得到Rd_gray_addr,再將Rd_gray_addr延一拍得到Rd_last_gray_addr。在絕對時間上,Rd_next_gray_addr、Rd_gray_addr、Rd_last_gray_addr這些地址先后關系,從大到小排列,并且相差一個地址,如圖6所示。
        
        寫地址的格雷碼的產生也與此類似,即:Wt_next_gray_addr、Wt_gray_addr、Wt_last_gray_addr。利用這6個格雷碼進行比較,同時加上讀寫使能,就能方便而靈活地產生空/滿標志。
        
        以空標志Empty的產生為例,當讀寫格雷碼地址相等或者FIFO內還剩下一個深度的字,并且正在不空的情況下執行讀操作,這時Emptr標志應該置為有效(高電平有效)。
        
        即EMPTY<=(Rd_gray_addr=Wt_gray_addr)and(Read_enable=1)或EMPTY<=(Rd_next_gray_addr=Wt_gray_addr)and(Read_enable=1)
        
        同理可類推滿標志的產生邏輯。
        
        3.2基于延時格雷碼的FIFO標志產生邏輯
        
        圖7是使用上述思想設計的地址產生和標志產生的邏輯。首先,在地址產生部分,將產生的格雷碼地址加一級延時,利用其前一級地址與當前的讀地址作比較。其次,在空/滿標志有效的時候,采用了內部保護機制,不使讀/寫地址進一步增加而出現讀寫地址共同對一個存儲單元操作的現象。
        
        3.3仿真信號波形
        
        利用圖7電路設計的思想構造了一個256×8的FIFO,用MODELSIM進行仿真。圖8為系統中主要信號對讀空情況的仿真波形。
        
        圖6經過延時后格雷碼之間的關系
        
        圖8中,WDATA為寫數據,RDATA為讀數據,WCLK為寫時鐘,RCLK為讀時鐘,REMPTY為空信號,AEMPTY的幾乎空信號,RPTR為讀地址WPTR為寫地址,RGNEXT為下一位讀地址格雷碼,RBIN讀地址二進制,RBNEXT為下一位讀地址的二進制碼。
        
        由圖8可以看出,由于讀時鐘高于寫時鐘,讀地址逐漸趕上寫地址,其中由AEMPTY信號指示讀地址和寫地址的接近程度。當這個信號足夠長而被觸發器捕捉到時,真正的空信號REMPTY有效。
        
        4電路優點的分析
        
        由圖7可見,該電路最大的瓶頸為二進制到格雷碼和比較器的延時之和。由于這兩個組合邏輯的延時都很小,因此該電路的速度很高。經測試,在Xilinx的FPGA中,時鐘頻率可達140MHz。另外,由于將異步的滿信號加了一級鎖存,從而輸出了可靠而穩定的標志。
        
        圖8讀空情況的仿真波形圖
        
        5總結
        
        在實際工作中,分別用圖4、圖5與圖7中所示的邏輯實現了一個256×8的FIFO。綜合工具為SYNPLIFY7.0,由FoundationSeries3.3i布局布線后燒入Xilinx公司的WirtexEV100ECS144。三者的性能指標比較見表1。
        
        表1三種不同設計的比較
        
        邏輯設計方式時鐘頻率/MHz有效結果輸出頻率/MHzslice數目/個圖4所示邏輯16078.917圖5所示邏輯1609215圖7所示邏輯16014013
        由表1可知,圖7所示的異步FIFO的電路速度高,面積小,從而降低了功耗,提高了系統的穩定性
        
        
        
        

      【異步FIFO結構及FPGA設計】相關文章:

      一種異步FIFO的設計方法08-06

      用FIFO設計A/D與DSP之間的接口08-06

      固定幾何結構的FFT算法及其FPGA實現08-06

      異步串行通信接口的IP核設計08-06

      集系統級FPGA芯片XCV50E的結構與開發08-06

      基于FPGA的高頻時鐘的分頻和分配設計08-06

      利用FPGA實現MMC2107與SDRAM接口設計08-06

      基于FPGA的LCD&VGA控制器設計08-06

      基于FPGA的總線型LVDS通信系統設計08-06

      主站蜘蛛池模板: 少妇被粗大的猛烈进出69影院一 | 国产老熟女乱子一区二区| 日本一区二区三本视频在线观看| 在线看免费无码的av天堂| 国产精品VA尤物在线观看| 国产一区二区四区不卡| 亚洲国产日韩一区三区| 91热在线精品国产一区| 国产一区二区三区自拍视频 | 幻女free性俄罗斯毛片| 国产综合视频一区二区三区| 午夜精品福利亚洲国产| 日夜啪啪一区二区三区| 日韩精品二区三区四区| 天天做天天爱夜夜爽导航| 成人自拍小视频在线观看| 在线看无码的免费网站| 婷婷色爱区综合五月激情韩国| 国产精品成人网址在线观看| 亚洲国产精品一区二区久| 亚洲中文字幕一区二区| 亚洲人妻一区二区精品| 在线播放亚洲成人av| 欧美一区二区三区欧美日韩亚洲| 亚洲日本韩国欧美云霸高清| 国产精品免费AⅤ片在线观看| 亚洲av免费看一区二区| 亚洲精中文字幕二区三区| 日本一区二区三区黄色网| 黄页网址大全免费观看| 精品精品国产国产自在线| 大地资源高清免费观看| 精品国产亚洲av麻豆特色| 亚洲av成人一区在线| 国产人妻人伦精品婷婷| 亚洲国产成人自拍视频网| 国产亚洲精品自在久久蜜TV| 久久精品久久精品久久精品| AV喷水高潮喷水在线观看COM| 久久大香萑太香蕉av黄软件 | 日韩精品国产精品十八禁|