通過USB接口實(shí)現(xiàn)FPGA的SelectMap配置
1.引言
FPGA器件結(jié)合了 ASIC的高性能和微處理器的靈活,不僅擁有豐富的邏輯資源,而且可以進(jìn)行方便靈活的配置。主動配置方式盡管配置速度快、實(shí)現(xiàn)簡單,但并未發(fā)揮 FPGA配置靈活的特點(diǎn),適合于 FPGA用作單一應(yīng)用的場合,并且大容量的配置芯片及其占用的電路板面積也帶來了較高的成本;被動配置方式需要使用外部控制單元產(chǎn)生配置時(shí)序,實(shí)現(xiàn)一般較為復(fù)雜,而且在目前常見的方案中,常由于接口速率限制 [1]或者采用微處理器介入數(shù)據(jù)傳輸?shù)仍颍斐膳渲盟俣炔桓摺?br /> USB2.0協(xié)議在目前 PC外設(shè)的接口方案中非常流行,它支持高速率、多管道、多類型的數(shù)據(jù)傳輸,可以方便的構(gòu)建出高性能的數(shù)據(jù)傳輸通道和靈活的控制通道。
本文提出了一種基于 USB接口的 FPGA SelectMap(并行被動)配置方式的實(shí)現(xiàn)方案,不但具有被動配置靈活、設(shè)計(jì)成本低的特點(diǎn),而且實(shí)現(xiàn)簡單、配置快速。方案以 Xilinx Spartan3系列目前最大容量的 500萬門 FPGA(XC3S5000)作為配置目標(biāo),選用 Cypress EZ-USB FX2LP作為 USB設(shè)備芯片,并使用其內(nèi)部的大容量端點(diǎn) FIFO,在 GPIF狀態(tài)機(jī)的控制下,實(shí)現(xiàn)了一個(gè)高性能的配置數(shù)據(jù)傳輸通道。配置的進(jìn)程則由設(shè)計(jì)的 USB請求來控制。此配置方案具有開發(fā)簡單、配置成本低、速度快、使用靈活的特點(diǎn),具有很強(qiáng)的實(shí)用性。
2.系統(tǒng)的總體設(shè)計(jì)
如圖 1所示,系統(tǒng)使用 USB通道連接上位機(jī)和 EZ-USB。EZ-USB是一塊高速 USB外設(shè)芯片,它支持 USB協(xié)議所描述全部四種傳輸模式,并擁有 1個(gè) 64Byte 的控制傳輸專用端點(diǎn)、2個(gè)緩存為 64Byte的普通端點(diǎn)和 4個(gè)緩存最大可達(dá) 1KB、并可以進(jìn)行四倍緩沖的大數(shù)據(jù)從端點(diǎn)轉(zhuǎn)移到外設(shè)(FPGA)的過程中,如果使用 USB設(shè)備芯片內(nèi)嵌的 8051 MCU進(jìn)行轉(zhuǎn)移的話,最快 8個(gè)時(shí)鐘周期才能傳輸一個(gè)字節(jié)的數(shù)據(jù)[2],在 8051的時(shí)鐘周期為 48MHz情況下,傳輸速度為 6MB/s,遠(yuǎn)小于 USB通道的傳輸速率,會成為瓶頸而無法發(fā)揮出 USB傳輸通道高傳輸速率的優(yōu)勢;而如果通過位寬為 8bit的 FIFO來傳輸?shù)脑挘羁烨闆r下,每時(shí)鐘周期都可以傳輸一個(gè)字節(jié)數(shù)據(jù)[2]。在 EZ-USB中,大端點(diǎn)的緩存可以作為端點(diǎn) FIFO直接連接 FPGA的配置數(shù)據(jù)輸入口形成高速傳輸通道,端點(diǎn) FIFO的讀寫時(shí)序可由 EZ-USB內(nèi)嵌的 GPIF[4](General Programmable Interface)產(chǎn)生,MCU可以不參與端點(diǎn)到 FPGA的數(shù)據(jù)轉(zhuǎn)移,只起到配置和控制的作用,在 FIFO位寬為 8bit,GPIF時(shí)鐘頻率為 48MHz的情況下,傳輸速率為 48MB/s,這樣數(shù)據(jù)從端點(diǎn)到 FPGA的傳輸速度超過了上位機(jī)到端點(diǎn)的 USB中斷傳輸管道的最大速度,不對 USB傳輸通道構(gòu)成瓶頸。
評論