《電子技術應用》
您所在的位置:首頁 > 可編程邏輯 > 設計應用 > 基于VHDL和FPGA的非對稱同步FIFO設計實現
基于VHDL和FPGA的非對稱同步FIFO設計實現
摘要: 基于VHDL和FPGA的非對稱同步FIFO設計實現,FIFO是一種常用于數據緩存的電路器件,可應用于包括高速數據采集、多處理器接口和通信中的高速緩沖等各種領域。然而在某些應用,例如在某數據采集和處理系統中,需要通過同步FIFO來連接8位A/D和16位數據總線的MCU,但
關鍵詞: FPGA VHDL 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的深度
else 0; 
empty<= '1' when (Offset = 0) else '0'; 
full<= '1' when (Offset = (m-1)) else '0'; 

方案實現

文中用VHDL語言描述了硬件結構,在Xilinx 公司Spartan II FPGA XC2S100-TQ144中通過了Xilinx ISE WebPACK的綜合及布局布線。FPGA的規模是10萬門,速度可達到56.344MHz。

有幾點需要說明的是:(1) VHDL程序設計采用多層次的結構設計方法,把系統分解成若干個模塊,其中模塊又由若干個元件構成。設計從元件開始,其中設計中用到的CLKDLL、IBUFG、IBUF、BUFG、OBUF等元件位于Xilinx公司 FPGA專用器件庫UNISIM中,在編寫VHDL程序時,用COMPONENT和PORT MAP指令調用專門的模塊,就可以在程序中導入所需元件。(2) 作為非對稱同步FIFO,用波形圖的方式進行仿真不太合適,可用VHDL建立測試平臺的方式進行仿真,測試平臺中把非對稱同步FIFO主程序作為一個元件調用,主要包括初始化、時鐘產生塊、讀寫數據等內容,輸入激勵由測試平臺產生。(3)由于Spartan II FPGA中BlockRAM單位容量和總體容量有限,如XC2S100中BlockRAM的單位容量為4Kbit,共10個, 則總體容量為40Kbit。設計時可以用多個BlockRAM組成不同深度和寬度的存儲單元,如果容量還是不夠則需要選用其它型號的FPGA。

 

結語

采用本文的設計思路,同樣可以設計出Win>Wout情形下的非對稱同步FIFO,而且該方案具有很強的靈活性并易于實現。如通信只需單向進行,則只用一片FPGA即可;雙向通信時需用兩片FPGA。經過實際驗證,該方案可以滿足一般需要.

此內容為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>
          欧美日韩一区二区三区四区在线观看| 噜噜噜躁狠狠躁狠狠精品视频| 韩国精品一区二区三区| 91久久精品一区| 亚洲国产综合91精品麻豆| 先锋亚洲精品| 欧美韩日高清| 美女网站久久| 国产精品永久免费在线| 老司机67194精品线观看| 亚洲精品视频免费在线观看| 国产精品二区在线观看| 亚洲国产99精品国自产| 噜噜噜久久亚洲精品国产品小说| 欧美激情性爽国产精品17p| 在线中文字幕日韩| 欧美色图一区二区三区| 欧美中文字幕在线| 欧美麻豆久久久久久中文| 久久伊人精品天天| 国产精品卡一卡二| 亚洲电影欧美电影有声小说| 免费欧美日韩国产三级电影| 国产日韩在线视频| 久久激情五月激情| 亚洲已满18点击进入久久| 久久综合亚州| 国产精品视频久久一区| 久久亚洲春色中文字幕久久久| 欧美99在线视频观看| 久久精品72免费观看| 欧美一区二区私人影院日本| 欧美一区二区| 欧美日韩一区二区在线| 欧美精品福利在线| 伊甸园精品99久久久久久| 亚洲综合色在线| 亚洲毛片在线免费观看| 亚洲日韩欧美视频一区| 亚洲综合视频在线| 99成人免费视频| 一区二区高清视频| 亚洲免费电影在线| 亚洲激情偷拍| 亚洲一区国产精品| 国产精品porn| 亚洲在线观看免费视频| 国产精品欧美在线| 亚洲激情在线观看| 久久久久久久久久久久久9999| 牛夜精品久久久久久久99黑人| 欧美一区二区成人6969| 香蕉久久夜色| 亚洲欧洲一区二区天堂久久| 久久免费视频在线观看| 欧美精品一区二区高清在线观看| 亚洲精品一区二区三区av| 久久九九久久九九| 亚洲欧美久久久久一区二区三区| 在线一区免费观看| 欧美高清视频在线| 久久夜精品va视频免费观看| 亚洲欧美日韩在线高清直播| 欧美人与性禽动交情品| 久久精视频免费在线久久完整在线看| 亚洲欧美日本在线| 国产亚洲va综合人人澡精品| 亚洲精品久久久久久久久| 激情久久中文字幕| 欧美日韩在线视频首页| 国产亚洲一区二区三区在线播放| 亚洲成人在线| **欧美日韩vr在线| 国产一区二区三区直播精品电影| 在线一区日本视频| 99爱精品视频| 久久久噜噜噜久久人人看| 9色精品在线| 国产一区二区久久精品| 亚洲欧美自拍偷拍| 今天的高清视频免费播放成人| 亚洲精品在线免费| 激情欧美一区| 国产日本亚洲高清| 亚洲精品视频免费在线观看| 国产欧美日韩免费| 国产精品久久九九| 久久字幕精品一区| 亚洲高清精品中出| 亚洲欧美日韩国产一区二区三区| 亚洲欧洲一区二区三区久久| 久久视频一区| 香蕉av777xxx色综合一区| 亚洲欧美日韩在线高清直播| 国产精品高清一区二区三区| 一区二区三区产品免费精品久久75| 亚洲欧美国产va在线影院| 欧美精品乱码久久久久久按摩| 精品成人一区二区三区四区| 国产精品男gay被猛男狂揉视频| 欧美在线三级| 欧美xxxx在线观看| 欧美精品少妇一区二区三区| 欧美不卡一卡二卡免费版| 亚洲精品久久视频| 久久久久se| 国产欧美日韩亚洲| 精品1区2区3区4区| 亚洲欧美一区二区在线观看| 一本久久综合| 欧美三区免费完整视频在线观看| 欧美影院精品一区| 国产欧美一区二区三区另类精品| 国内精品久久久| 在线日韩电影| 欧美日韩大陆在线| 欧美综合激情网| 91久久中文字幕| 一区免费在线| 国产乱子伦一区二区三区国色天香| 久久精品国产综合| 欧美91精品| 久久婷婷国产综合精品青草| 日韩亚洲欧美在线观看| 亚洲欧美综合网| 黑人一区二区三区四区五区| 亚洲精品免费看| 国产视频久久| 亚洲一区二区三区免费在线观看| 1769国内精品视频在线播放| 亚洲欧美日韩区| 国自产拍偷拍福利精品免费一| 国产区日韩欧美| 亚洲永久免费精品| 久久久久久久久久久久久久一区| 欧美在线日韩精品| 一区二区三区视频在线播放| 欧美激情亚洲国产| 老司机67194精品线观看| 一区二区三区四区国产| 国产精品视频大全| 国产一区二区三区在线观看网站| 久久精品女人| 噜噜噜在线观看免费视频日韩| 久久福利资源站| 国产欧美日韩精品专区| 欧美亚洲一区二区在线观看| 国产精品私拍pans大尺度在线| 日韩一区二区久久| 欧美日韩网址| 久久黄色小说| avtt综合网| 欧美日韩国产综合视频在线观看| 久久综合一区二区三区| 欧美一区二区精品久久911| 性做久久久久久久久| 先锋资源久久| 尤物九九久久国产精品的特点| 久久人人97超碰精品888| 国产欧美日韩亚洲| 亚洲第一视频网站| 亚洲精品久久久久| 一本色道久久加勒比精品| 久久久www成人免费毛片麻豆| 亚洲影院高清在线| 国产精品美女久久久浪潮软件| 久久国产精品一区二区| 欧美日韩在线一区| 欧美日本精品一区二区三区| 国产精品夜色7777狼人| 欧美日韩国产一区二区| 亚洲精品一区在线观看香蕉| 欧美制服第一页| 影音先锋久久精品| 欧美.日韩.国产.一区.二区| 欧美精品激情在线观看| 另类av一区二区| 欧美顶级大胆免费视频| 国产午夜精品全部视频播放| 国产精品高潮呻吟久久av黑人| 国产精品国码视频| 亚洲激情国产精品| 米奇777在线欧美播放| 狠狠色丁香婷综合久久| 亚洲激情亚洲| 欧美日韩直播| 一区二区三区免费看| 欧美激情精品久久久久久蜜臀| 国产精品对白刺激久久久| 久久婷婷国产麻豆91天堂| 亚洲无线一线二线三线区别av| 欧美一区二区三区视频| 亚洲毛片在线观看| 国产欧美日韩视频| 在线观看视频免费一区二区三区| 亚洲自拍另类| 亚洲一区免费看| 一二三区精品福利视频| 欲色影视综合吧| 欧美大片va欧美在线播放| 亚洲欧美自拍偷拍| 久久久久久久性| 欧美电影在线| 欧美日韩在线看| 国产原创一区二区| 国产精品日韩欧美一区| 美女啪啪无遮挡免费久久网站| 亚洲国产精品一区在线观看不卡| 午夜精品视频在线| 夜夜精品视频一区二区| 99在线|亚洲一区二区| 亚洲无人区一区| 正在播放欧美视频| 一区二区三区在线观看视频| 久久成人免费网| 免费h精品视频在线播放| 在线观看视频免费一区二区三区| 在线精品视频在线观看高清| 国产情人综合久久777777| 亚洲视频在线观看网站| 国产区在线观看成人精品| 国产视频一区二区在线观看| 国产精品亚洲激情| 欧美精品国产精品日韩精品| 欧美中文字幕在线观看| 性娇小13――14欧美| 亚洲精品黄网在线观看| 欧美精品一区二区三区一线天视频| 亚洲精品美女免费| 国产精品三区www17con| 国产在线视频欧美一区二区三区| 国产精一区二区三区| 久久夜精品va视频免费观看| 久久久久久9999| 国产免费成人| 欧美激情五月| 欧美日韩大片一区二区三区| 国产精品高清一区二区三区| 亚洲视频999| 国产精品视频第一区| 欧美3dxxxxhd| 国产精品久久久久久户外露出| 尤物yw午夜国产精品视频明星| 国产自产v一区二区三区c| 国产精品青草久久| 另类成人小视频在线| 女生裸体视频一区二区三区| 国产精品成人一区二区| 久久久久九九九九| 狠狠色丁香久久婷婷综合_中| 亚洲欧美国产高清va在线播| 亚洲免费福利视频| 99在线精品观看| 国产精品一区二区三区久久| 国产日韩高清一区二区三区在线| 精东粉嫩av免费一区二区三区| 免费成人在线观看视频| 亚洲美女网站| 老司机久久99久久精品播放免费| 香蕉久久精品日日躁夜夜躁| 99国产一区| 久久综合狠狠综合久久综合88| 99精品视频免费观看视频| 欧美一区二区日韩一区二区| 亚洲国产另类 国产精品国产免费| 欧美制服丝袜第一页| 久久久久国产免费免费| 久久久国产91| 韩国av一区二区| 蜜臀av性久久久久蜜臀aⅴ四虎| 久久国产欧美| 精品69视频一区二区三区| 一区二区三区高清在线| 国模私拍一区二区三区| 国产目拍亚洲精品99久久精品| 亚洲激情中文1区| 久久久久久久97| 99国产精品一区| 欧美成人免费网站| 在线观看国产一区二区| 久久综合久久88| 欧美另类极品videosbest最新版本| 国产精品久久久久久久久动漫| 久久精品国产第一区二区三区最新章节| 国产亚洲一区二区在线观看| 欧美 亚欧 日韩视频在线| 欧美日韩三级| 9人人澡人人爽人人精品| 久久精品电影| 欧美在线|欧美| 欧美久久精品午夜青青大伊人| 久久精品30| 欧美日韩中文另类| 国产精品自拍视频| 国产欧美一区二区三区在线看蜜臀| 亚洲激情视频在线观看| 欧美性猛交xxxx免费看久久久| 中文成人激情娱乐网| 欧美视频在线免费看| 一区二区三区日韩精品视频| 亚洲第一精品福利| 欧美视频中文一区二区三区在线观看| 欧美精品91| 欧美激情在线观看| 久久精品国产久精国产一老狼| 亚洲一级在线| 欧美日韩精品高清| 亚洲大片在线| 精品999久久久| 欧美一区二区三区男人的天堂| 国内精品写真在线观看| 亚洲视频 欧洲视频| 亚洲人成高清| 亚洲一区二区三区影院| 亚洲风情在线资源站| 亚洲国产欧美一区二区三区久久| 免费观看成人鲁鲁鲁鲁鲁视频| 在线观看日产精品| 欧美成人精品三级在线观看| 亚洲视频自拍偷拍| 久久先锋影音| 午夜精品在线| 亚洲日本成人| 伊人久久大香线蕉综合热线| 欧美日韩精品国产| 亚洲激情一区二区三区| 免费成人高清视频| 国产精品另类一区|