日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁 > 嵌入式 > 嵌入式教程
[導(dǎo)讀]基于VHDL和FPGA的非對稱同步FIFO設(shè)計(jì)實(shí)現(xiàn)

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

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

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

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

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

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

針對以上設(shè)計(jì)中的難點(diǎn),本文采用VHDL描述語言,利用Xilinx公司Spartan II FPGA設(shè)計(jì)實(shí)現(xiàn)了一種非對稱同步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í)鐘控制,它可以對時(shí)鐘進(jìn)行倍頻、鎖相等操作。

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

FPGA中的RAM

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

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

下面以Win<Wout(設(shè)Win=8,Wout=16)這種情形為例,介紹非對稱同步FIFO模塊的設(shè)計(jì)。非對稱同步FIFO的結(jié)構(gòu)框圖,圖中還顯示了各模塊端口及信號互連關(guān)系。其主要設(shè)計(jì)特點(diǎn)為:

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

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

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

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

結(jié)語 

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

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

我們知道 Flash 讀時(shí)序里有五大子序列 CMD + ADDR + MODE + DUMMY + READ,前面的文章中痞子衡講過《串行NOR Flash的Continuous read模式》,Continuous r...

關(guān)鍵字: CMD ADDR Flash

最近為什么越來越多的研究開始利用FPGA作為CNN加速器?FPGA與CNN的相遇究竟能帶來什么神奇效果呢?原來,F(xiàn)PGA擁有大量的可編程邏輯資源,相對于GPU,它的可重構(gòu)性以及高功耗能效比的優(yōu)點(diǎn),是GPU無法比擬的;同時(shí)...

關(guān)鍵字: FPGA 可編程邏輯資源 GPU

FPGA的應(yīng)用領(lǐng)域包羅萬象,我們今天來看看在音樂科技領(lǐng)域及醫(yī)療照護(hù)的智能巧思。

關(guān)鍵字: FPGA 科技領(lǐng)域 智能

強(qiáng)大的產(chǎn)品可降低信號噪音并提高分辨率與動(dòng)態(tài)

關(guān)鍵字: Spectrum儀器 數(shù)字化儀 FPGA

最近某項(xiàng)目采用以太網(wǎng)通信,實(shí)踐起來有些奇怪,好像設(shè)計(jì)成只能應(yīng)答某類計(jì)算機(jī)的ICMP(ping)命令, 某類計(jì)算機(jī)指的是Windows特定系統(tǒng),其他系統(tǒng)發(fā)送ping都不能正確識別。

關(guān)鍵字: 嵌入式Linux FPGA 協(xié)議

近兩年,國外廠商的FPGA芯片價(jià)格飆升,由于價(jià)格,貨期,出口管制等多方面因素的影響,很多公司都在尋找FPGA國產(chǎn)化替代方案。我工作中正在使用的幾款芯片也面臨停產(chǎn)的風(fēng)險(xiǎn),用一片少一片,了解到國產(chǎn)FPGA發(fā)展的也不錯(cuò),完全自...

關(guān)鍵字: FPGA 芯片 EDA

本篇是FPGA之旅設(shè)計(jì)的第十二例,在前面的例程中,完成了DS18B20溫度傳感器數(shù)據(jù)的采集,并且將采集到的數(shù)據(jù)顯示在數(shù)碼管上。由于本例將對溫濕度傳感器DHT11進(jìn)行采集,而且兩者的數(shù)據(jù)采集過程類似,所以可以參考一下前面的...

關(guān)鍵字: FPGA DS18B20溫度傳感器

這是FPGA之旅設(shè)計(jì)的第十三例啦,本例是一個(gè)綜合性的例程,基于OLED屏幕顯示,和DHT11溫濕度采集,將DHT11采集到的溫濕度顯示到OLED屏幕上。

關(guān)鍵字: FPGA OLED屏幕

第八例啦,本例將介紹如何通過FPGA采集DS18B20傳感器的溫度值。

關(guān)鍵字: FPGA DS18B20傳感器

這是FPGA之旅設(shè)計(jì)的第九例啦?。?!本例將介紹如何使用FPGA驅(qū)動(dòng)OLED屏幕,并在接下來的幾例中,配合其它模塊,進(jìn)行一些有趣的綜合實(shí)驗(yàn)。由于使用的OLED屏是IIC接口的,對IIC接口不是很清楚的,可以參考第五例的設(shè)計(jì)...

關(guān)鍵字: FPGA OLED屏幕

嵌入式教程

6897 篇文章

關(guān)注

發(fā)布文章

編輯精選

技術(shù)子站

關(guān)閉