FSL總線IP核及其在MicoBlaze系統(tǒng)中的應(yīng)用
4 FSL總線應(yīng)用實(shí)例
在下面的實(shí)例中,嘗試通過(guò)FSL總線技術(shù),將實(shí)現(xiàn)特定函數(shù)功能的用戶自定義IP核整合到MicroBlaze軟核系統(tǒng)中,以實(shí)現(xiàn)硬件加速的目的。這里以一個(gè)矢量漢字(vector font)還原功能的硬件模塊的整合為例,說(shuō)明FSL總線的應(yīng)用過(guò)程。所使用的開(kāi)發(fā)平臺(tái)是Memec Insight公司生產(chǎn)的Virtex—II系列的MicroBlaze開(kāi)發(fā)板,板上采用的FPGA器件為Virtex—II 1000,系統(tǒng)時(shí)鐘為100 MHz,開(kāi)發(fā)工具為Xilinx公司的EDK 6.3及ISE 6.3。
4.1 FSL總線應(yīng)用方案
如圖5所示,vectOr_font核通過(guò)FSL_Code-與FSL_Lattice兩條FSL總線與MicroBlaze軟核直接相連。
對(duì)于FSL_Code總線,MicroBlaze核是主設(shè)備,而vector_font核是從設(shè)備。這樣MicroBlaze可以通過(guò) FSL_Code總線向vectOr_font核發(fā)送漢字的區(qū)位碼(或者其他格式的漢字編碼,由使用的矢量字庫(kù)和還原算法決定)以及漢字的屬性信息(如字體、大小等)。
對(duì)于FSL_Lattice總線則正好相反。vector font 核作為主設(shè)備可以通過(guò)它向MicroBlaze核發(fā)送經(jīng)過(guò)還原處理后的漢字點(diǎn)陣數(shù)據(jù)以及漢字點(diǎn)陣尺寸信息(用于將點(diǎn)陣數(shù)據(jù)在顯存中組織成正確的顯示格式)。
4.2 數(shù)據(jù)傳輸指令與控制位指令的應(yīng)用
FSL 提供的獨(dú)立于數(shù)據(jù)傳輸?shù)目刂莆豢梢杂脕?lái)對(duì)正在傳輸中的數(shù)據(jù)進(jìn)行標(biāo)記。為了區(qū)分區(qū)位碼數(shù)據(jù)與漢字屬性數(shù)據(jù),以及點(diǎn)陣數(shù)據(jù)與漢字點(diǎn)陣尺寸數(shù)據(jù)。 MicroBlaze分別通過(guò)FSL的數(shù)據(jù)傳輸指令和控制位傳輸指令來(lái)發(fā)送漢字的區(qū)位碼和漢字屬性信息,接收點(diǎn)陣數(shù)據(jù)和漢字點(diǎn)陣尺寸信息。對(duì)應(yīng)的實(shí)現(xiàn)代碼如下:
//使用非阻塞的數(shù)據(jù)寫(xiě)函數(shù)向FSL總線寫(xiě)入漢字區(qū)位碼Microblaze_nbwrite_datatsl(code,O)
//使用非阻塞的控制位寫(xiě)函數(shù)向FSL總線寫(xiě)入漢字屬性信息maicroblaze_cnbwrite_cnlfsl(attibute,O)
//使用非阻塞的數(shù)據(jù)讀函數(shù)從FSL總線讀取漢字點(diǎn)陣數(shù)據(jù)microblaze_nbread_datafsl(1attice[i],O)
//使用非阻塞的控制位讀函數(shù)從FSL總線讀取漢字點(diǎn)陣尺寸信息microblaze_cnbread_cnlfsl(size,O)
代碼中用到的與FSL有關(guān)函數(shù)的定義,都在include目錄下的mb_inteRFace.h文件中。其中,各函數(shù)的第二個(gè)參數(shù)代表進(jìn)行讀寫(xiě)操作的 FSL總線接口的編號(hào),對(duì)應(yīng)Mi—croBlaze軟核的8對(duì)FSL接口。該參數(shù)的取值范圍從0到7。本例中,MicroBlaze只使用了一對(duì)FSL接口,故而值為0。
4.3 實(shí)現(xiàn)步驟
首先,在Base System Wizard中設(shè)計(jì)圖5虛線框中所示的一個(gè)簡(jiǎn)單的MicroBlaze嵌入式處理器系統(tǒng)。然后,在XPS集成開(kāi)發(fā)環(huán)境下完成用戶自定義IP核(本例中即 vectoz__font核)的添加、Microblaze核FSL接口的添加(設(shè)置參數(shù)C_FSL_LINKS=1),同時(shí)添加兩個(gè)FSL總線IP核,分別用于實(shí)現(xiàn)FSL_Code和FSL_Lattice總線。另外,將兩個(gè)FSL總線IP核的參數(shù)C_USE_CONTROL置為1,以打開(kāi)FSL總線的控制位傳輸功能。所有這些改動(dòng),最后都會(huì)被更新到MES文件中。這樣,硬件平臺(tái)生成工具platgen就可以根據(jù)它生成所需要的FPGA配置文件了。
硬件的實(shí)現(xiàn)完成后,進(jìn)行相應(yīng)軟件參數(shù)的設(shè)置,如將系統(tǒng)標(biāo)準(zhǔn)輸入輸出設(shè)備指向UART模塊等。然后,用庫(kù)生成工具libgen,根據(jù)MSS(系統(tǒng)軟件描述文件)文件,將所需外設(shè)函數(shù)庫(kù)的頭文件添加進(jìn)工程中。
通過(guò)調(diào)用這些函數(shù),可以操作和控制這些外設(shè)。通過(guò)Tool項(xiàng)里的build命令,調(diào)用mb—gcc:編譯工具,將編寫(xiě)的應(yīng)用程序編譯成ELF文件,再用 updatebitstrcam命令將程序代碼對(duì)應(yīng)的RAM初始化數(shù)據(jù)添加到前面生成的FPGA配置文件中,生成最終的bit配置文件。最后,使用 download命令將bit文件下載到目標(biāo)板中。
以上就是整個(gè)FSL應(yīng)用實(shí)例設(shè)計(jì)的實(shí)現(xiàn)過(guò)程。本例只是為了說(shuō)明FSL總線的使用。實(shí)際應(yīng)用中,還可以根據(jù)具體情況通過(guò)FSL,將更多的用戶自定義IP核(如DCT、FFT等)添加到.MicroBlaze軟核系統(tǒng)中去。
結(jié) 語(yǔ)
在嵌入式系統(tǒng)的開(kāi)發(fā)中,人們一直希望能夠有一個(gè)滿足自己需要的“定制”的嵌入式處理器,而不是手頭大量存在的通用微處理器。但是,直接將用戶自定義IP 核添加到處理器核中,不僅受到處理器原架構(gòu)的束縛,還有可能降低處理器的性能(處理器工作頻率);而通過(guò)與內(nèi)部寄存器直接相連的FSL接口,用戶自定義 IP可以在不破壞處理器原有結(jié)構(gòu)的情況下,緊密地與MicroB- laze軟核結(jié)合在一起。這樣,即使關(guān)鍵路徑覆蓋了用戶IP 核,由于它在處理器內(nèi)核之外,也不會(huì)導(dǎo)致處理器時(shí)鐘頻率的降低。
通過(guò)對(duì)FSL總線的分析以及上述實(shí)例的驗(yàn)證,證明了在基于 MicroBlaze的SoC 系統(tǒng)設(shè)計(jì)中,一方面可以針對(duì)具體應(yīng)用進(jìn)行“量體裁衣”式的設(shè)計(jì);另一方面,利用其專用的FSL總線接口技術(shù),實(shí)現(xiàn)嵌入式軟處理器系統(tǒng)與用戶自定義邏輯的整合,從而在不提高系統(tǒng)主頻的前提下,通過(guò)部分函數(shù)功能的硬件實(shí)現(xiàn)來(lái)提升系統(tǒng)的性能。
評(píng)論