基于簡單的FIFO提供數(shù)據(jù)寬度轉(zhuǎn)換
許多設(shè)計需要FIFO彈性緩沖器,在不同時鐘速率的次系統(tǒng)和通道的需求中形成橋梁。然而,在某些應(yīng)用中,需要FIFO緩沖器實現(xiàn)數(shù)據(jù)轉(zhuǎn)換。一個例子是,通過FIFO緩沖器,將8位ADC連接到16位數(shù)據(jù)總線的微處理器(圖1)。不幸地,大部分普遍使用的FIFO緩沖器不適于這個應(yīng)用。本設(shè)計方案描述了為不同寬度讀寫數(shù)據(jù)端口的數(shù)據(jù)寬度轉(zhuǎn)換,怎樣基于FPGA的FIFO實現(xiàn)共有時鐘(同步)??梢允褂肵ilinx的Spartan II系列FPGA實現(xiàn)這種FIFO。這個方法使用了片上DLL(延遲鎖相環(huán))宏、分布式存儲器和簡單的計數(shù)器邏輯(圖2)。
本文引用地址:http://www.biyoush.com/article/186034.htmFIFO輸入數(shù)據(jù)的寬度為8位;然而,輸出數(shù)據(jù)的寬度為16位。在讀寫動作中只使用一個共有時鐘。關(guān)鍵是為了使用時鐘DLL,它不只是最小化時鐘脈沖相位差,還提供雙倍輸出的時鐘頻率。所以,可以實現(xiàn)輸入數(shù)據(jù)的雙重數(shù)據(jù)率,write_data_in。通過監(jiān)測DLL輸出時鐘的樣本,DLL可以補償走線網(wǎng)絡(luò)的延遲,有效地消除外部輸入端口到設(shè)備中單獨時鐘負載的延遲。替代使用的阻塞存儲器,本設(shè)計在FIFO中使用分布式存儲器保存數(shù)據(jù)。實際上,選擇阻塞存儲器還是分布式存儲器,依靠系統(tǒng)中FIFO的重要性。如果不是很關(guān)鍵,可以考慮使用分布式存儲器。
存儲器可以放在FPGA的任何位置。如果堅持使用阻塞存儲器,可以簡單的改變VHDL代碼??芍皇褂靡恍㏑AM宏來替代分布式存儲器。點擊下載FIFO 的VHDL代碼。FIFO一般使用Gray代碼計數(shù)器或線性反饋移位寄存器作為讀或?qū)懹嫈?shù)器。為實現(xiàn)邏輯大小的最小化,本設(shè)計只使用兩個從0到7的整數(shù)和帶進位的計數(shù)器。當(dāng)讀和寫計數(shù)器相等,且進位為0時,F(xiàn)IFO為空。當(dāng)寫計數(shù)器加1等于讀計數(shù)器,且進位為1時,F(xiàn)IFO為滿。
更多資訊請關(guān)注:21ic模擬頻道
存儲器相關(guān)文章:存儲器原理
塵埃粒子計數(shù)器相關(guān)文章:塵埃粒子計數(shù)器原理 鎖相環(huán)相關(guān)文章:鎖相環(huán)原理
評論