基于FPGA的微型數(shù)字存儲系統(tǒng)設計方案
按照上述控制邏輯關系編寫CY7C68013的同件程序。CY7C68013有3種可用接口模式:端口、GPIF主控和從FI-FO?!癎PIF主控”接口模式使用PORTB和PORTD構(gòu)成通向4個FX2端點FIFO(EP2、EP4、EP6和EP8)的16位數(shù)據(jù)接口。GPIF作為內(nèi)部的主控制器與 FIFO直接相連.具有6個可編程控制輸出信號(CTR0~CTR5)和6個通用準備就緒輸入信號(RDY0~RDY5),用戶可通過編程設置控制信號的輸出狀態(tài),即器件在接收到何種就緒信號后執(zhí)行相應操作,GPIF控制代碼存放于器件內(nèi)部RAM的波形描述器中。從該系統(tǒng)需求出發(fā),將CY7C68013設為FIFO Read模式,使GPIF中的Slave FIFO與USB通信中端點緩沖直接建立連接,數(shù)據(jù)傳送無需CPU參與。
固件程序代碼設計主要是根據(jù)系統(tǒng)需求設計相應的程序框架圖,再調(diào)用同件函數(shù)庫 (Ezusb.lib)的函數(shù)進行編程,初始化并重新列舉端點,然后在任務處理器中設定任務,在Keil C51環(huán)境中編譯代碼。編譯通過后,將同件代碼下載到USB單片機中,即可實現(xiàn)GPIF多字節(jié)讀操作。
4 系統(tǒng)可靠性驗證
為驗證系統(tǒng)可靠性,在數(shù)據(jù)輸入端循環(huán)輸入00~0F遞增數(shù)據(jù),通過上位機讀出、寫入Flash中的數(shù)據(jù),圖4為試驗數(shù)據(jù)。通過讀出的數(shù)據(jù)驗證了該系統(tǒng)數(shù)據(jù)存儲及回讀的正確性、可靠性。
5 結(jié)束語
采用FPGA對Flash進行讀、寫、擦除操作,利用狀態(tài)機分時控制3種操作,簡化程序設計,簡單修改地址將Flash的容量從32 MB增加到1 GB,提高了系統(tǒng)的可移植性、可擴展性和通用性,便于維護設備,有利于產(chǎn)品的優(yōu)化和改進,縮短了開發(fā)周期。采用USB單片機與PC機建立通信連接,與現(xiàn)有設備很好兼容,數(shù)據(jù)讀取速度可達1O MB/s,可方便、快捷地讀取數(shù)據(jù)。通過多次驗證,該系統(tǒng)工作穩(wěn)定、可靠。
評論