Virtex-Ⅱ Pro FPGA的嵌入系統(tǒng)設(shè)計與應(yīng)用
隨著通信技術(shù)的飛速發(fā)展,為滿足高速數(shù)字電路和數(shù)字信號處理等對時鐘管理、信號完整性、高速寬帶接口的要求,高速處理器與通信的融合日趨緊密,高速處理器、可編程邏輯器件和高速存儲器成為設(shè)計的關(guān)鍵。Virtex- ⅡPro 系列FPGA 將可編程邏輯結(jié)構(gòu)和高速處理器集成在同一芯片內(nèi)部,直接的連接克服了利用總線在FPGA 和附加外部處理器之間接口的瓶頸。
Virtex-II Pro 簡介
Virtex- ⅡPro 系列最大容量的FPGA 目前能提供多達(dá)5 萬個邏輯單元具有超過10 Mb 的RAM;556 個乘法單元12 個數(shù)字時鐘管理單元以及24個集成3. 125 GbPs 的Rocket IOTM 收發(fā)器最大可提供1 200 個IO 引腳, 支持CMOS、SSTL 、HSTL 、LVDS、GTL 和3. 3V PCI 信號標(biāo)準(zhǔn)。Virtex - II Pro 系列FPGA 支持多達(dá)4 個運(yùn)行頻率高達(dá)300 MHz 的PowerPC 405 處理器。PowerPC405 采用嵌入式300 MHz哈佛(Harvard) 結(jié)構(gòu)的RISC 核具有五級數(shù)據(jù)通道流水線、硬件乘除單元、32 個32 位通用寄存器、16 KB指令Cache 和16 KB 數(shù)據(jù)Cache 、1 KB~16MB 可變頁尺寸組成存儲器管理單元(MMU) 和專用的片內(nèi)存儲器接口。
PowerPC405 處理器由IBM CoreConnect 技術(shù)支持,CoreConnect 是運(yùn)行在100~133 MHz 的64 位總線,為了使系統(tǒng)設(shè)計靈活性達(dá)到最大,CoreConnect 結(jié)構(gòu)是作為軟IP 核在Virtex - ⅡPRO FPGA 中實現(xiàn)的。CoreConnect 總線結(jié)構(gòu)有2 個主要總線組成,處理器局部總線(PLB) 和片內(nèi)外設(shè)總線(OPB) 。這些總線可以用來分別連接高速和低速外設(shè)到PowerPC處理器。此外,設(shè)備控制寄存器總線對通用外設(shè)器件寄存器的進(jìn)行管理和控制。
EDK(Embedded Development Kit) 是Xilinx 公司提供的嵌入開發(fā)工具,用于在FPGA 內(nèi)部集成多種不同的IP 核,可方便地規(guī)劃、設(shè)計并生成整個片上系統(tǒng)的硬件和軟件結(jié)構(gòu)。通過編寫硬件描述文件(MHS) 來設(shè)置FPGA 內(nèi)部硬件系統(tǒng),主要包括定制嵌入處理器PowerPC405、外圍設(shè)備IP 核、設(shè)定外部存儲器和其他外設(shè)的地址空間、管理外圍設(shè)備的控制信號及中斷信號。EDK 的硬件生成平臺根據(jù)用戶編輯的MHS 文件生成相應(yīng)的VHD 文件,原理圖文件等,同時支持系統(tǒng)仿真。EDK工具提供了大量可供使用的IP 核, 包括SDRAM,DDRRAM,UARTController ,10/ 100 M以太網(wǎng)MAC ,總線仲裁器等,使FPGA 可方便地與其他外圍器件連接。EDK 實現(xiàn)FPGA 片內(nèi)軟、硬件設(shè)計過程如圖1 所示。
應(yīng)用系統(tǒng)結(jié)構(gòu)
數(shù)據(jù)糾錯譯碼接入設(shè)備要求對同步傳輸?shù)臄?shù)據(jù)進(jìn)行幀同步、解擾、糾錯譯碼處理并對處理后的數(shù)據(jù)進(jìn)行網(wǎng)絡(luò)接入。在以太網(wǎng)接入部分,要求對解碼后的數(shù)據(jù)進(jìn)行IP 協(xié)議封裝,然后使用數(shù)據(jù)鏈路層協(xié)議對協(xié)議包進(jìn)行以太網(wǎng)幀的封裝,最終通過網(wǎng)口接入局域網(wǎng)。
在對Virtex - II 系列FPGA 充分理解和研究的基礎(chǔ)上,根據(jù)系統(tǒng)設(shè)計需求,進(jìn)行系統(tǒng)硬件的設(shè)計。本設(shè)計采用了VII - Pro 系列的XC2VP7FG456 芯片,在芯片內(nèi)部設(shè)計嵌入了一個PowerPC405 處理器IP核。應(yīng)用系統(tǒng)由XC2VP7FG456 芯片及其上電復(fù)位電路, 系統(tǒng)時鐘電路、內(nèi)存電路、程序存儲電路、PROM電路、以太網(wǎng)PHY接口電路和RS - 232 接口電路、JTAG接口、LVPECL 電平接口電路組成。系統(tǒng)組成框圖如圖2 所示。
由于FPGA 可允許PowerPC 硬IP 核心分布在Virtex 結(jié)構(gòu)中的任何位置,設(shè)計時需要綜合考慮系統(tǒng)的設(shè)計要求,合理地指定FPGA 各個管腳的信號??紤]到輸入輸出標(biāo)準(zhǔn)的不同,FPGA 芯片劃分了8 個不同的Bank ,每個Bank 可支持不同的I/ O 特性。在設(shè)計過程中,盡量把同一特性的外圍芯片管腳連接到FPGA 芯片的同一Bank 的IO 管腳。同時,為了方便進(jìn)行調(diào)試,可將FPGA 芯片內(nèi)部不可測內(nèi)部狀態(tài)引到空余管腳。
應(yīng)用系統(tǒng)實現(xiàn)
系統(tǒng)時鐘
參考時鐘由外部晶振產(chǎn)生,通過FPGA 芯片全局時鐘管腳接入到FPGA 內(nèi)部數(shù)字時鐘管理模塊(DCM) 和時鐘分配樹。DCM 支持超過400 MHz 的時鐘輸出,提供了一個可保證精確50/ 50 占空比的零延遲時鐘緩沖。同時提供了精確控制90 ,180 ,270 相移的能力,實現(xiàn)對時鐘信號的綜合,支持24~420 MHz間的精確頻率產(chǎn)生。在FPGA 內(nèi)部,DCM統(tǒng)一分配時鐘信號,將DCM 的時鐘輸出設(shè)置為PowerPC 的系統(tǒng)時鐘,并提供給PLB ,OPB 總線仲裁器。
外部存儲器
PPC405 的PLB 總線支持高性能的高速存儲器,如DDR RAM,SDRAM 等。OPB 總線支持通用的存儲電路, 如EPROM, SRAM, FALSH 和外部寄存器等低速的存儲器。在本設(shè)計中采用了2 片MT48V8M16 高速同步SDRAM, 構(gòu)成PowerPC405處理器數(shù)據(jù)總線寬度32 位,容量為32 MB 的外部數(shù)據(jù)存儲區(qū)。在編輯MHS 文件時, 選擇加入PLBSDRAM核,在其中配置存儲器地址總線和數(shù)據(jù)總線寬度,指定存儲區(qū)的起始地址。程序存儲器除選用OPB 總線外,其余設(shè)置與數(shù)據(jù)存儲器類似。
以太網(wǎng)接口
在FPGA 內(nèi)部集成10/ 100 MEthernet MAC 核。外接BCM5221 以太網(wǎng)物理層芯片,該芯片適用于IEEE802. 3 物理層的應(yīng)用,然后通過網(wǎng)絡(luò)變壓器后接入以太網(wǎng)。在編輯MHS 文件時,選擇加入以太網(wǎng)MAC 層內(nèi)核。
RS232 接口
根據(jù)需要,在FPGA 內(nèi)部集成UART 控制器,外接RS232 電平轉(zhuǎn)換器,連接到計算機(jī)的串口,用作應(yīng)用程序的調(diào)試信息輸出。在MHS文件中可配置串口的波特率,數(shù)據(jù)位寬度,奇偶校驗等設(shè)置。
在線可編程PROM
FPGA 是基于門陣列方式為用戶提供可編程資源的,其內(nèi)部邏輯結(jié)構(gòu)的形成是由配置數(shù)據(jù)決定的。這些配置數(shù)據(jù)通過外部控制電路或微處理器加載到FPGA 內(nèi)部的SRAM 中,由于SRAM 的易失性,每次上電時,都必須對FPGA 進(jìn)行重新配置。在實際應(yīng)用時,采用2 片XC18V04 PROM,用以存放FPGA 的配置數(shù)據(jù)流。通過硬件跳線將FPGA 設(shè)置為串行主模式配置方式,在FPGA 每次上電后,自動將配置數(shù)據(jù)從PROM讀入到SRAM中,實現(xiàn)內(nèi)部結(jié)構(gòu)映射。
JTAG端口
JTAG端口用于進(jìn)行FPGA 配置信息的下載,編程PROM。在VII - Pro 中嵌入PowerPC 內(nèi)核時,還可進(jìn)行應(yīng)用程序代碼的下載和調(diào)試。為方便軟件代碼的調(diào)試,除FPGA 專用配置管腳TCK,TMS ,TDO ,TDI外,還可在FPGA 芯片上指定4 個普通I/ O 管腳,內(nèi)部配置連接PowerPC 內(nèi)核的JTAG 接口, 用于PowerPC 內(nèi)核的調(diào)試,軟件代碼跟蹤調(diào)試。在這種模式下,軟件代碼可單獨(dú)下載到PowerPC 內(nèi)核進(jìn)行軟件的調(diào)試。在利用JTAG引腳配置FPGA 時,需要注意:JTAG配置引腳最好接上拉電阻,在配置期間INIT 引腳要接地。[!--empirenews.page--]
結(jié)束語
本文成功使用 XC2VP7FG456 型FPGA 及其內(nèi)部的PowerPC405 嵌入處理器開發(fā)了數(shù)據(jù)處理和網(wǎng)絡(luò)接入板,經(jīng)電路測試,可實現(xiàn)傳輸速率為100 Mb/ s的同步數(shù)據(jù)接收和處理,滿足系統(tǒng)需要。Virtex - IIPro 系列FPGA 支持內(nèi)部嵌入運(yùn)行頻率高達(dá)300 MHz的PowerPC405 處理器IP 核,設(shè)計人員可以并行進(jìn)行快速的硬件和軟件開發(fā),在系統(tǒng)結(jié)構(gòu)一級利用可編程性能所提供的優(yōu)點,從而使設(shè)計投入生產(chǎn)所需要的時間更短。