《電子技術應用》
您所在的位置:首頁 > 可編程邏輯 > 設計應用 > 基于FPGA的非對稱同步FIFO設計
基于FPGA的非對稱同步FIFO設計
摘要: FIFO是一種常用于數據緩存的電路器件,可應用于包括高速數據采集、多處理器接口和通信中的高速緩沖等各種領域。然而在某些應用,例如在某數據采集和處理系統中,需要通過同步FIFO來連接8位A/D和16位數據總線的MCU,但是由于目前同步FIFO器件的輸入與輸出數據總線寬度相等,不能滿足這種應用,因此通常采用輸入與輸出數據總線寬度均為8位的同步FIFO作為它們之間的數據緩沖,并對MCU數據總線的高8位采用軟件進行屏蔽,或是在同步FIFO外圍增加數據鎖存器及邏輯控制器件的方法解決。為了提高效率和降低系統設計的難度,本文采用VHDL描述語言,充分利用Xilinx公司Spartan II FPGA的系統資源,設計實現了一種非對稱同步FIFO(輸入與輸出數據總線寬度不一致的同步FIFO),它不僅提供數據緩沖,而且能進行數據總線寬度的轉換。
關鍵詞: FPGA FIFO
Abstract:
Key words :

引言

FIFO是一種常用于數據緩存的電路器件,可應用于包括高速數據采集、多處理器接口和通信中的高速緩沖等各種領域。然而在某些應用,例如在某數據采集和處理系統中,需要通過同步FIFO來連接8位A/D和16位數據總線的MCU,但是由于目前同步FIFO器件的輸入與輸出數據總線寬度相等,不能滿足這種應用,因此通常采用輸入與輸出數據總線寬度均為8位的同步FIFO作為它們之間的數據緩沖,并對MCU數據總線的高8位采用軟件進行屏蔽,或是在同步FIFO外圍增加數據鎖存器及邏輯控制器件的方法解決。為了提高效率和降低系統設計的難度,本文采用VHDL描述語言,充分利用Xilinx公司Spartan II FPGA的系統資源,設計實現了一種非對稱同步FIFO(輸入與輸出數據總線寬度不一致的同步FIFO),它不僅提供數據緩沖,而且能進行數據總線寬度的轉換。

非對稱同步FIFO的設計難點

對于非對稱同步FIFO的設計來說,不能簡單地通過修改現成的同步FIFO模塊而得到,這是因為非對稱同步FIFO的設計有以下幾個需要解決的難點問題:
(1) 寫數據與讀數據總線寬度不同。設寫數據與讀數據總線寬度分別為Win和Wout,必須對Win>Wout和Win(2) 如何協調內部處理過程中不同的時鐘頻率。例如輸入2個8位字節需2個時鐘周期,而輸出1個16位字節只需1個時鐘周期,所以必須為內部數據處理提供不同的時鐘頻率。
(3) 由于寫數據與讀數據總線寬度不同,所以,要操作正確,必須保證數據存儲排列的順序及空/滿標志產生的正確。
另外,由于FPGA中的寄存器個數有限,而FIFO是一種基于RAM的器件,需要占用大量的存儲空間。通常在編寫VHDL程序時用數組描述的方法來設計數據存儲結構,在綜合時會耗用大量的寄存器,所以這種方法在FIFO的設計中是不可行的。

非對稱同步FIFO的設計

針對以上設計中的難點,本文采用VHDL描述語言,利用Xilinx公司Spartan II FPGA設計實現了一種非對稱同步FIFO,設計中充分利用了FPGA中的資源如時鐘延遲鎖相環(DLL)和BlockRAM。

FPGA中的DLL

FPGA 中的DLL是一種很好的資源,Xilinx公司Spartan II、Spartan IIE、Virtex-E等系列器件中就采用時鐘延遲鎖相環技術進行FPGA內部的時鐘控制,它可以對時鐘進行倍頻、鎖相等操作。

本設計中要利用Spartan II系列器件中的DLL產生二倍頻時鐘信號。其中IBUFG、IBUF、BUFG、OBUF是時鐘緩沖器,提供時鐘信號的最小時延。

FPGA中的RAM

Xilinx公司的FPGA器件提供了片內RAM可供直接使用,而不必使用寄存器來構成存儲空間,從而大大提高了芯片的利用率。根據型號的不同,FPGA中提供了兩種結構的RAM:分布式RAM和BlockRAM。分布式RAM可以利用可配置邏輯模塊(CLB) 設計實現,主要用于小容量片內存儲;BlockRAM是FPGA內部的專用RAM模塊,通常沿芯片的垂直邊排列。根據具體型號不同,FPGA內部的BlockRAM在單位容量和總體容量上都有較大的不同。本設計將采用BlockRAM用于FIFO的編寫。由于在Xilinx公司Spartan II FPGA器件庫中沒有現成的宏模塊,就需要自己生成BlockRAM模塊,具有較高的靈活度。利用Xilinx公司的配套軟件ISE Foundation和ISE WebPACK中都帶有的CoreGenerator程序包,可以很方便地建立用戶所需的模塊。只需要輸入BlockRAM模塊的名稱、BlockRAM的類型(如單口還是雙口)、地址線和數據線的寬度,就可以生成用戶希望得到的結構。一般來說,生成的結構會自動加載到當前的項目中,從而可以像器件庫中的元件一樣調用。

非對稱同步FIFO的結構

下面以Win
(1) 由于寫數據與讀數據總線寬度不同,所以在設計雙口RAM時把雙口RAM設計成寫口RAM和讀口RAM兩個部分。例如FIFO寫口RAM部分為512×8,讀口RAM部分為256×16,這樣通過數據存儲格式的改變達到寫數據與讀數據總線寬度的轉換。
(2) 由于讀數據時鐘頻率是寫數據時鐘頻率的兩倍,因此可利用FPGA中的DLL產生二倍頻時鐘信號來提高寫數據的時鐘頻率,使讀數據和寫數據的時鐘頻率相等。二倍頻時鐘信號提供給寫口RAM、寫地址產生模塊,而源時鐘信號(一倍頻)提供給讀口RAM、讀地址產生模塊及空/滿標志產生模塊,從而解決了內部數據處理同步的問題。
(3) 由于雙口RAM中存在兩種數據存儲格式,因此地址位數不同,讀地址和寫地址不能一一對應,例如FIFO寫口RAM部分為512×8,讀口RAM部分為256×16,因此寫地址要求9位,而讀地址要求8位,對于同一數據的寫地址與讀地址,寫地址的高8位與讀地址的8位相等,它們的區別僅在寫地址的最低一位。因此可把寫地址的高8位與讀地址一同輸入空/滿標志產生模塊,從而得到正確的full和empty信號。下面僅給出讀寫地址產生邏輯及空/滿標志產生邏輯的VHDL設計程序:
fifo_write : process
begin
wait until rising_edge(clk);
if rst = '1' then
wr_addr <= 0; //寫地址初始化
else
if (wr_en = '1' and full = '0')then
wr_data_buf (wr_addr) <= To_Bitvector(wr_data (7 downto 0));
//寫數據,其中wr_data_buf定義為基于BlockRAM的存儲矩陣
wr_addr <= (wr_addr + 1) mod 8;// 寫地址增加1
end if;
end if;
end process;
fifo_read : process
begin
wait until rising_edge(clk);
if rst = '1' then
rd_addr <= 0;
//讀地址初始化
else
if (rd_en = '1' and empty = '0') then
rd_data (15 downto 0) <= wr_data_buf (rd_addr);//讀數據
rd_addr <= (rd_addr - 1) mod 16;// 讀地址減1
end if;
end if;
end process;
wr_addr1 <= wr_addr / 2 ;//取寫地址的高8bit
Offset <= (wr_addr1 - rd_addr) when (wr_addr 1> rd_addr)
else (m - (rd_addr - wr_addr1)) when (rd_addr > wr_addr1) ;// m定義為fifo的深度
&a
 

 

此內容為AET網站原創,未經授權禁止轉載。
热re99久久精品国产66热_欧美小视频在线观看_日韩成人激情影院_庆余年2免费日韩剧观看大牛_91久久久久久国产精品_国产原创欧美精品_美女999久久久精品视频_欧美大成色www永久网站婷_国产色婷婷国产综合在线理论片a_国产精品电影在线观看_日韩精品视频在线观看网址_97在线观看免费_性欧美亚洲xxxx乳在线观看_久久精品美女视频网站_777国产偷窥盗摄精品视频_在线日韩第一页
  • <strike id="ygamy"></strike>
  • 
    
      • <del id="ygamy"></del>
        <tfoot id="ygamy"></tfoot>
          <strike id="ygamy"></strike>
          在线一区二区三区做爰视频网站| 久久这里有精品15一区二区三区| 亚洲精品欧洲| 亚洲欧美日韩国产综合精品二区| 亚洲精品日韩在线观看| 久久精品论坛| 国产精品一区在线观看你懂的| 亚洲综合色视频| 亚洲视频久久| 亚洲一二三区在线观看| 国产精品久久激情| 欧美大片一区| 亚洲国产一区二区三区a毛片| 亚洲欧美日韩一区二区| 亚洲国产精品一区二区第四页av| 久久丁香综合五月国产三级网站| 国产精品夜夜夜一区二区三区尤| 性欧美1819性猛交| 宅男精品视频| 午夜精品视频在线观看| 欧美国产精品劲爆| 久久久久99精品国产片| 欧美+亚洲+精品+三区| 久久99在线观看| 91久久线看在观草草青青| 国产一区二区三区在线观看网站| 欧美另类视频在线| 欧美日韩中文在线观看| 欧美韩国日本一区| 激情亚洲网站| 国产欧美精品一区aⅴ影院| 久久综合网色—综合色88| 亚洲伦理在线| 欧美久久成人| 99国产精品私拍| 老牛国产精品一区的观看方式| 国产精品久久久91| 亚洲欧美视频一区二区三区| 午夜老司机精品| 国产日韩欧美视频| 亚洲调教视频在线观看| 99香蕉国产精品偷在线观看| 国产日韩精品一区二区三区| 欧美高清在线一区二区| 久久亚洲免费| 国产欧美日韩一区二区三区在线| 亚洲风情亚aⅴ在线发布| 欧美 日韩 国产精品免费观看| 国语对白精品一区二区| 欧美激情按摩在线| 99视频在线观看一区三区| 欧美日韩一区二区三区在线观看免| 在线免费日韩片| 亚洲电影免费观看高清完整版在线| 午夜精品久久久久99热蜜桃导演| 一区二区三区在线视频播放| 欧美日韩视频一区二区三区| 亚洲人成欧美中文字幕| 亚洲黄色在线视频| 欧美大片在线观看一区二区| 国产日韩欧美精品综合| 国产精品日韩欧美大师| 国产一区视频在线看| 国产色产综合产在线视频| 伊人久久大香线| 国内偷自视频区视频综合| 久久国产88| 欧美一级在线视频| 精品成人一区二区三区| 亚洲青色在线| 欧美成人影音| 亚洲日本va午夜在线电影| 国产视频亚洲精品| 欧美日本三级| 亚洲激情成人网| 国产精品久久久一区二区| 日韩午夜在线视频| 欧美韩日高清| 欧美/亚洲一区| 中文精品在线| 日韩视频在线播放| 欧美福利精品| 国产日本欧美视频| 国内成+人亚洲| 欧美精品一区二区三区蜜桃| 国产在线精品成人一区二区三区| 欧美专区中文字幕| 亚洲欧美另类中文字幕| 韩国av一区二区三区在线观看| 99视频国产精品免费观看| 一区二区在线看| 久久99伊人| 免费亚洲网站| 亚洲黄色影片| 欧美日韩国产成人在线| 国产精品视频内| 欧美视频在线一区| 极品少妇一区二区三区精品视频| 久久精品国产999大香线蕉| 亚洲另类一区二区| 这里只有视频精品| 国产日韩专区在线| 亚洲制服丝袜在线| 国产一区二区三区精品久久久| 久久蜜桃av一区精品变态类天堂| 在线免费观看日韩欧美| 亚洲国产精品热久久| 亚洲国产日韩在线一区模特| 另类春色校园亚洲| 99精品欧美一区二区三区| 国产精品扒开腿做爽爽爽软件| 一区二区不卡在线视频 午夜欧美不卡'| 欧美成人综合在线| 亚洲午夜激情| 国产精品你懂的在线| 在线观看视频欧美| 日韩午夜免费视频| 亚洲欧美另类中文字幕| 亚洲国产婷婷综合在线精品| 欧美日产一区二区三区在线观看| 国产三级精品三级| 久久精品视频在线看| 日韩视频在线观看| 亚洲欧洲精品一区二区三区不卡| 欧美—级a级欧美特级ar全黄| 免费日韩视频| 国产亚洲欧美另类中文| 欧美一进一出视频| 欧美在线免费播放| 国内一区二区三区在线视频| 黄色成人在线免费| 国产精品99一区| 久久一区二区三区四区| 在线精品亚洲| 欧美日本中文| 久久一区中文字幕| 这里只有精品电影| 亚洲第一狼人社区| 国内精品免费午夜毛片| 亚洲福利视频免费观看| 国产精品99一区二区| 亚洲深夜影院| 亚洲在线中文字幕| 在线观看91精品国产麻豆| 欧美日韩国产成人在线91| 日韩亚洲欧美成人| 艳女tv在线观看国产一区| 国产精品国产自产拍高清av| 在线成人激情视频| 欧美电影免费观看大全| 国产精品热久久久久夜色精品三区| 亚洲欧美三级伦理| 国产免费观看久久| 在线亚洲免费视频| 免费看av成人| 亚洲视频一二区| 亚洲成人在线网站| 亚洲高清免费视频| 亚洲国产成人精品视频| 亚洲国产欧美日韩另类综合| 亚洲激情不卡| 欧美午夜性色大片在线观看| 亚洲一区二区三区高清| 日韩一级视频免费观看在线| 欧美午夜精品理论片a级按摩| 久久久99久久精品女同性| 欧美日韩在线免费| 免费h精品视频在线播放| 欧美三日本三级三级在线播放| 亚洲午夜国产一区99re久久| 老司机免费视频久久| 亚洲一区尤物| 欧美成人一区二区在线| 在线日本高清免费不卡| 中文在线不卡视频| 亚洲精品免费看| 欧美人与禽性xxxxx杂性| 激情综合中文娱乐网| 久久综合色影院| 99热精品在线| 在线观看欧美日本| 欧美专区一区二区三区| 欧美日韩午夜视频在线观看| 欧美三级电影一区| 欧美午夜精品久久久久免费视| 国产区欧美区日韩区| 亚洲一级在线| 欧美久久综合| 韩日精品视频一区| 欧美精品国产一区| 欧美中文字幕第一页| 国产午夜精品理论片a级大结局| 欧美一区二区三区另类| 国产精品高潮视频| 欧美色精品在线视频| 国产欧美日韩综合| 久久福利电影| 一区二区三区欧美在线| 国产精品日韩一区二区| 亚洲永久在线观看| 欧美国产日韩免费| 亚洲国产另类精品专区| 国产精品女人久久久久久| 欧美精品一区二区三区四区| 亚洲区免费影片| 亚洲国产精品第一区二区三区| 欧美夫妇交换俱乐部在线观看| 欧美日韩综合不卡| 亚洲激情偷拍| 欧美激情1区| 麻豆成人91精品二区三区| 欧美激情综合色| 欧美日韩国产一区二区| 99精品视频免费观看| 欧美a级片网| 亚洲一区二区三区在线视频| 欧美精品免费视频| 一区二区在线看| 国产精品久久久久久久浪潮网站| 国产一区视频网站| 国产精品久久久久9999吃药| 亚洲国产精品久久久| 欧美日韩国产成人高清视频| 在线一区二区三区做爰视频网站| 农村妇女精品| 在线天堂一区av电影| 老鸭窝亚洲一区二区三区| 国产午夜久久久久| 久久久久一区二区三区| 日韩视频精品在线观看| 国产日产欧美精品| 激情六月婷婷久久| 亚洲第一精品电影| 亚洲一区二区在线视频| 欧美一区国产在线| 国产精品sm| 亚洲免费小视频| 欧美日韩国产999| 亚洲欧美久久久| 国产自产精品| 欧美午夜欧美| 美女视频一区免费观看| 99人久久精品视频最新地址| 免费欧美在线视频| 精品av久久久久电影| 亚洲国产另类 国产精品国产免费| 欧美日韩一区二区三区在线看| 亚洲一卡二卡三卡四卡五卡| 欧美午夜视频在线观看| 亚洲欧美精品在线| 国产精品国产三级国产aⅴ无密码| 在线观看不卡| 亚洲欧美日韩中文播放| 国产精品www| 日韩视频在线一区二区三区| 欧美香蕉大胸在线视频观看| 在线天堂一区av电影| 一本在线高清不卡dvd| 久久国产日韩欧美| 亚洲素人在线| 亚洲日韩中文字幕在线播放| 久久精品一区四区| 亚洲国产成人精品久久久国产成人一区| 欧美一区二区三区在线免费观看| 宅男噜噜噜66国产日韩在线观看| 欧美女同视频| 国户精品久久久久久久久久久不卡| 亚洲女ⅴideoshd黑人| 久久精品一区二区三区中文字幕| 亚洲国内高清视频| 免费不卡欧美自拍视频| 理论片一区二区在线| 激情久久五月天| 亚洲国产成人一区| 亚洲综合欧美| 欧美日韩一区在线观看视频| 欧美日韩成人激情| 国外成人在线视频网站| 国产精品成人午夜| 久久久国产一区二区| 在线观看日产精品| 欧美日韩xxxxx| 国产拍揄自揄精品视频麻豆| 午夜激情久久久| 欧美精品一区二区蜜臀亚洲| 国产精品久久久久久久浪潮网站| 激情成人综合| 亚洲视频在线观看视频| 亚洲欧美经典视频| 欧美国产一区视频在线观看| 悠悠资源网亚洲青| 欧美午夜精品久久久久久孕妇| 国产精品日韩在线播放| 久久久999国产| 一区二区三欧美| 性欧美xxxx大乳国产app| 欧美影院成年免费版| 欧美成人综合一区| 亚洲人体1000| 国产精品美女| 久久久久久久综合狠狠综合| 国产伦精品免费视频| 欧美国产一区二区三区激情无套| 在线免费观看欧美| 在线视频你懂得一区| 伊人婷婷欧美激情| 久久精品中文字幕一区二区三区| 欧美视频一区二区| 国产偷国产偷精品高清尤物| 欧美成人自拍视频| 中文精品视频一区二区在线观看| 原创国产精品91| 美女在线一区二区| 欲色影视综合吧| 国产欧美精品一区aⅴ影院| 韩国av一区| 韩国成人理伦片免费播放| 国产欧美日韩三区| 久久成人人人人精品欧| 欧美精品免费视频| 亚洲欧美日韩在线| 欧美日韩在线一区二区| 欧美日韩高清在线一区| 亚洲国产美国国产综合一区二区| 欧美日韩精品伦理作品在线免费观看| 99xxxx成人网| 狠狠色狠狠色综合日日91app| 欧美视频在线免费看|