《電子技術(shù)應(yīng)用》
您所在的位置:首頁(yè) > 可編程邏輯 > 設(shè)計(jì)應(yīng)用 > 基于VHDL和FPGA的非對(duì)稱同步FIFO設(shè)計(jì)實(shí)現(xiàn)
基于VHDL和FPGA的非對(duì)稱同步FIFO設(shè)計(jì)實(shí)現(xiàn)
摘要: 基于VHDL和FPGA的非對(duì)稱同步FIFO設(shè)計(jì)實(shí)現(xiàn),FIFO是一種常用于數(shù)據(jù)緩存的電路器件,可應(yīng)用于包括高速數(shù)據(jù)采集、多處理器接口和通信中的高速緩沖等各種領(lǐng)域。然而在某些應(yīng)用,例如在某數(shù)據(jù)采集和處理系統(tǒng)中,需要通過(guò)同步FIFO來(lái)連接8位A/D和16位數(shù)據(jù)總線的MCU,但
關(guān)鍵詞: FPGA VHDL FIFO
Abstract:
Key words :

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

非對(duì)稱同步FIFO的設(shè)計(jì)難點(diǎn)

對(duì)于非對(duì)稱同步FIFO的設(shè)計(jì)來(lái)說(shuō),不能簡(jiǎn)單地通過(guò)修改現(xiàn)成的同步FIFO模塊而得到,這是因?yàn)榉菍?duì)稱同步FIFO的設(shè)計(jì)有以下幾個(gè)需要解決的難點(diǎn)問(wèn)題:

(1) 寫(xiě)數(shù)據(jù)與讀數(shù)據(jù)總線寬度不同。設(shè)寫(xiě)數(shù)據(jù)與讀數(shù)據(jù)總線寬度分別為Win和Wout,必須對(duì)Win>Wout和Win (2) 如何協(xié)調(diào)內(nèi)部處理過(guò)程中不同的時(shí)鐘頻率。例如輸入2個(gè)8位字節(jié)需2個(gè)時(shí)鐘周期,而輸出1個(gè)16位字節(jié)只需1個(gè)時(shí)鐘周期,所以必須為內(nèi)部數(shù)據(jù)處理提供不同的時(shí)鐘頻率。
(3) 由于寫(xiě)數(shù)據(jù)與讀數(shù)據(jù)總線寬度不同,所以,要操作正確,必須保證數(shù)據(jù)存儲(chǔ)排列的順序及空/滿標(biāo)志產(chǎn)生的正確。

另外,由于FPGA中的寄存器個(gè)數(shù)有限,而FIFO是一種基于RAM的器件,需要占用大量的存儲(chǔ)空間。通常在編寫(xiě)VHDL程序時(shí)用數(shù)組描述的方法來(lái)設(shè)計(jì)數(shù)據(jù)存儲(chǔ)結(jié)構(gòu),在綜合時(shí)會(huì)耗用大量的寄存器,所以這種方法在FIFO的設(shè)計(jì)中是不可行的。

非對(duì)稱同步FIFO的設(shè)計(jì)

針對(duì)以上設(shè)計(jì)中的難點(diǎn),本文采用VHDL描述語(yǔ)言,利用Xilinx公司Spartan II FPGA設(shè)計(jì)實(shí)現(xiàn)了一種非對(duì)稱同步FIFO,設(shè)計(jì)中充分利用了FPGA中的資源如時(shí)鐘延遲鎖相環(huán)(DLL)和BlockRAM。

FPGA中的DLL

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

本設(shè)計(jì)中要利用Spartan II系列器件中的DLL產(chǎn)生二倍頻時(shí)鐘信號(hào)。其中IBUFG、IBUF、BUFG、OBUF是時(shí)鐘緩沖器,提供時(shí)鐘信號(hào)的最小時(shí)延。

FPGA中的RAM

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

非對(duì)稱同步FIFO的結(jié)構(gòu)

下面以Win

(1) 由于寫(xiě)數(shù)據(jù)與讀數(shù)據(jù)總線寬度不同,所以在設(shè)計(jì)雙口RAM時(shí)把雙口RAM設(shè)計(jì)成寫(xiě)口RAM和讀口RAM兩個(gè)部分。例如FIFO寫(xiě)口RAM部分為512×8,讀口RAM部分為256×16,這樣通過(guò)數(shù)據(jù)存儲(chǔ)格式的改變達(dá)到寫(xiě)數(shù)據(jù)與讀數(shù)據(jù)總線寬度的轉(zhuǎn)換。
(2) 由于讀數(shù)據(jù)時(shí)鐘頻率是寫(xiě)數(shù)據(jù)時(shí)鐘頻率的兩倍,因此可利用FPGA中的DLL產(chǎn)生二倍頻時(shí)鐘信號(hào)來(lái)提高寫(xiě)數(shù)據(jù)的時(shí)鐘頻率,使讀數(shù)據(jù)和寫(xiě)數(shù)據(jù)的時(shí)鐘頻率相等。二倍頻時(shí)鐘信號(hào)提供給寫(xiě)口RAM、寫(xiě)地址產(chǎn)生模塊,而源時(shí)鐘信號(hào)(一倍頻)提供給讀口RAM、讀地址產(chǎn)生模塊及空/滿標(biāo)志產(chǎn)生模塊,從而解決了內(nèi)部數(shù)據(jù)處理同步的問(wèn)題。
(3) 由于雙口RAM中存在兩種數(shù)據(jù)存儲(chǔ)格式,因此地址位數(shù)不同,讀地址和寫(xiě)地址不能一一對(duì)應(yīng),例如FIFO寫(xiě)口RAM部分為512×8,讀口RAM部分為256×16,因此寫(xiě)地址要求9位,而讀地址要求8位,對(duì)于同一數(shù)據(jù)的寫(xiě)地址與讀地址,寫(xiě)地址的高8位與讀地址的8位相等,它們的區(qū)別僅在寫(xiě)地址的最低一位。因此可把寫(xiě)地址的高8位與讀地址一同輸入空/滿標(biāo)志產(chǎn)生模塊,從而得到正確的full和empty信號(hào)。下面僅給出讀寫(xiě)地址產(chǎn)生邏輯及空/滿標(biāo)志產(chǎn)生邏輯的VHDL設(shè)計(jì)程序:
fifo_write : process
begin
wait until rising_edge(clk);
if rst = '1' then
wr_addr <= 0; //寫(xiě)地址初始化
else
if (wr_en = '1' and full = '0')then
wr_data_buf (wr_addr) <= To_Bitvector(wr_data (7 downto 0));
//寫(xiě)數(shù)據(jù),其中wr_data_buf定義為基于BlockRAM的存儲(chǔ)矩陣
wr_addr <= (wr_addr + 1) mod 8;// 寫(xiě)地址增加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);//讀數(shù)據(jù)
rd_addr <= (rd_addr - 1) mod 16;// 讀地址減1
end if;
end if;
end process;
wr_addr1 <= wr_addr / 2 ;//取寫(xiě)地址的高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'; 

方案實(shí)現(xiàn)

文中用VHDL語(yǔ)言描述了硬件結(jié)構(gòu),在Xilinx 公司Spartan II FPGA XC2S100-TQ144中通過(guò)了Xilinx ISE WebPACK的綜合及布局布線。FPGA的規(guī)模是10萬(wàn)門,速度可達(dá)到56.344MHz。

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

 

結(jié)語(yǔ)

采用本文的設(shè)計(jì)思路,同樣可以設(shè)計(jì)出Win>Wout情形下的非對(duì)稱同步FIFO,而且該方案具有很強(qiáng)的靈活性并易于實(shí)現(xiàn)。如通信只需單向進(jìn)行,則只用一片F(xiàn)PGA即可;雙向通信時(shí)需用兩片F(xiàn)PGA。經(jīng)過(guò)實(shí)際驗(yàn)證,該方案可以滿足一般需要.

此內(nèi)容為AET網(wǎng)站原創(chuàng),未經(jīng)授權(quán)禁止轉(zhuǎn)載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
中国成人亚色综合网站| 欧美高清在线视频| 亚洲精品一级| 久久精品国内一区二区三区| 午夜精品福利电影| 亚洲欧美日韩成人高清在线一区| aa级大片欧美| 99国产精品99久久久久久| 亚洲三级电影全部在线观看高清| 亚洲国产高清视频| 亚洲激情视频网站| 亚洲精品欧美| 夜夜夜精品看看| 在线视频你懂得一区| 亚洲视频成人| 亚洲免费一在线| 西西裸体人体做爰大胆久久久| 亚洲欧美日韩另类| 午夜亚洲福利| 亚洲国产精品成人综合色在线婷婷| 久久精品亚洲热| 最新国产拍偷乱拍精品| 亚洲人成网站777色婷婷| 日韩视频第一页| 亚洲一区二区视频| 羞羞色国产精品| 久久国产精品99国产精| 久久久久久亚洲精品杨幂换脸 | 麻豆亚洲精品| 欧美国产日韩在线| 欧美日韩在线免费观看| 国产精品久久久久aaaa樱花 | 午夜精品视频在线观看| 久久精品视频在线播放| 亚洲狼人综合| 亚洲欧美日韩另类| 久久精品国产91精品亚洲| 乱人伦精品视频在线观看| 欧美精品自拍| 国产精品揄拍一区二区| 一区二区三区在线免费观看| 亚洲日本免费| 亚洲女人av| 最新成人在线| 午夜精品视频网站| 牛牛影视久久网| 欧美体内she精视频| 国产无遮挡一区二区三区毛片日本| 狠狠色狠狠色综合人人| 亚洲精品久久在线| 亚洲欧美日韩一区二区| 91久久线看在观草草青青| 在线视频欧美日韩| 久久久国产一区二区三区| 欧美精品久久久久久久久老牛影院| 国产精品乱码一区二三区小蝌蚪 | 在线视频亚洲欧美| 久久精品亚洲乱码伦伦中文| 在线视频欧美日韩| 久久精品中文| 欧美日韩综合视频网址| 国产一区二区三区在线观看视频 | 欧美人成网站| 在线亚洲成人| 亚洲一区二区在线| 亚洲激情综合| 欧美在线三区| 欧美日本国产视频| 国产一区二区三区在线播放免费观看| 亚洲日本成人女熟在线观看| 午夜精品久久久久久久男人的天堂 | 一区二区精品在线观看| 久久久久久久综合| 欧美视频久久| 亚洲大胆人体在线| 亚洲免费伊人电影在线观看av| 日韩视频永久免费| 久久久综合激的五月天| 国产精品xxx在线观看www| 亚洲电影免费观看高清完整版| 亚洲男人的天堂在线| 99国产精品99久久久久久粉嫩| 久久久久久91香蕉国产| 欧美午夜精品理论片a级按摩| 伊人色综合久久天天| 亚洲欧美日韩精品久久奇米色影视 | 9l视频自拍蝌蚪9l视频成人| 久久久久一区二区| 国产精品美女久久福利网站| 在线免费观看视频一区| 欧美一二三区精品| 亚洲在线一区二区| 欧美日韩另类在线| 亚洲第一色中文字幕| 午夜伦欧美伦电影理论片| 亚洲欧美在线网| 欧美视频中文字幕在线| 亚洲欧洲日韩在线| 亚洲激情黄色| 美女国产精品| 韩国女主播一区二区三区| 羞羞色国产精品| 午夜国产精品影院在线观看| 欧美日韩国产美| 91久久精品日日躁夜夜躁国产| 亚洲第一福利视频| 久久久999| 国产一区二区三区在线观看精品| 亚洲一区二区影院| 午夜久久美女| 国产精品日韩精品欧美在线| 这里是久久伊人| 亚洲欧美久久久| 国产精品卡一卡二卡三| 99视频在线观看一区三区| 一区二区日韩欧美| 欧美日韩一区二区欧美激情| 亚洲精品一二三| 一区二区久久久久久| 欧美日韩成人综合| aa成人免费视频| 亚洲免费在线| 国产模特精品视频久久久久| 亚洲欧美日韩另类| 久久精品一区二区三区中文字幕| 国产亚洲观看| 久久不射网站| 老鸭窝毛片一区二区三区| 在线观看日韩www视频免费 | 欧美在线视频二区| 国产三级精品三级| 久久精品视频免费播放| 欧美1级日本1级| 亚洲伦理久久| 亚洲综合欧美| 国产乱码精品1区2区3区| 午夜影视日本亚洲欧洲精品| 久久久女女女女999久久| 在线不卡免费欧美| 99伊人成综合| 国产精品每日更新在线播放网址| 亚洲欧美日韩天堂| 裸体女人亚洲精品一区| 亚洲人成网站影音先锋播放| 国产精品99久久99久久久二8 | 亚洲精品免费网站| 欧美日韩亚洲视频一区| 亚洲图片欧美一区| 久久久精品动漫| 亚洲国产欧美一区| 亚洲一区影院| 国产一区91| 99热在线精品观看| 国产毛片久久| 亚洲精品视频在线看| 欧美特黄一级| 久久成人综合视频| 欧美精品1区2区| 亚洲综合视频一区| 嫩模写真一区二区三区三州| 亚洲美女淫视频| 久久经典综合| 亚洲人成网站精品片在线观看| 亚洲欧美日韩中文视频| 激情亚洲网站| 亚洲综合第一| 在线不卡视频| 午夜国产精品视频| 在线观看日韩欧美| 亚洲欧美精品中文字幕在线| 黄色一区二区三区| 亚洲欧美日韩国产另类专区| 韩国在线一区| 亚洲欧美国产va在线影院| 伊人狠狠色丁香综合尤物| 亚洲一区二区三区午夜| 一区在线观看视频| 亚洲欧美日韩网| 亚洲国产精品免费| 欧美一区二区三区视频免费播放 | 亚洲视频 欧洲视频| 狠狠色香婷婷久久亚洲精品 | 亚洲欧美国产高清| 亚洲国产综合视频在线观看| 欧美怡红院视频| 亚洲精品在线观| 久久久www成人免费无遮挡大片 | 性久久久久久久| 欧美色精品天天在线观看视频| 亚洲第一色在线| 国产精品丝袜91| 一区二区三区四区国产精品| 影音先锋日韩精品| 久久超碰97人人做人人爱| 99综合在线| 欧美精选午夜久久久乱码6080| 久久se精品一区精品二区| 国产精品你懂的在线| 一本色道久久综合亚洲91| 在线观看亚洲a|