基于ST20嵌入式系統(tǒng)的Java虛擬機研究與移植
摘要:分析了開放源碼的Java虛擬機Kaffe的結構、運行機制,并針對DVB(DigitalVideoBroadcast)數(shù)字機頂盒軟件架構中對基于Java虛擬機的MHP(MultimediaHomePlatform)中間件研發(fā)的需求,研究了將Kaffe移植到Sti5516處理器和其專用OS20操作系統(tǒng)的關鍵技術,給出了相應的移植方案。對深入了解MHP在數(shù)字機頂盒中的應用給出了研究方向和基本思路。
關鍵詞:嵌入式系統(tǒng);Java虛擬機;DVB;中間件
1 引言
隨著現(xiàn)代信息技術的迅猛發(fā)展,電視數(shù)字化步伐加快了。從一開始的模擬電視到現(xiàn)在的數(shù)字電視,不僅大大提高了電視節(jié)目的質(zhì)量,也推動了電視數(shù)字化的進一步發(fā)展。在各種數(shù)字視頻廣播標準中,歐洲的DVB(Digital Video Broadcast)標準使用比較廣泛,它為在同一信道中傳輸視頻、音頻、數(shù)據(jù)提供了一種靈活、高效的方式,可以通過衛(wèi)星、電纜和地面信道傳輸高質(zhì)量的電視節(jié)目。同時基于DVB的數(shù)據(jù)廣播標準也能滿足人們對于寬帶數(shù)據(jù)業(yè)務的要求,如證券信息服務、電子節(jié)目、MP3音樂下載、電子郵件、網(wǎng)頁瀏覽等,在現(xiàn)代信息技術領域應用極為廣泛。
圖一 數(shù)字機頂盒架構
從圖一我們可以看到, 一個完整的數(shù)字機頂盒由硬件平臺和軟件系統(tǒng)組成,可以將其分為4層,從底向上分別為硬件、底層軟件、中間件、應用軟件。硬件提供機頂盒的硬件平臺;底層軟件提供操作系統(tǒng)內(nèi)核以及各種硬件驅(qū)動程序;應用軟件包括本機存儲的應用和可下載的應用;中間件是一種將應用程序與底層的操作系統(tǒng)、硬件細節(jié)隔離開來,使應用不依賴于具體的硬件平臺的軟件環(huán)境。這樣用戶可以在任何廠家的硬件平臺上進行應用軟件開發(fā),和應用軟件下載。而不必介意任何底層的有關信息,保證了機頂盒的開發(fā)專業(yè)化。這種分層的思想在現(xiàn)代系統(tǒng)設計中十分常見,如大名鼎鼎的TCP/IP協(xié)議。中間件通常由各種虛擬機來構成,如HTML虛擬機、JavaScript虛擬機、Java虛擬機[1]等。
現(xiàn)在廣電行業(yè)傾向于DVB-MHP(多媒體家庭平臺)中間件標準。DVB-MHP基于開放性的Java程序語言,具有軟硬件兼容性好、可移植成本低、二次再開發(fā)功能強等優(yōu)點,是一種很有發(fā)展前途的中間件技術標準??梢韵嘈牛琂ava在數(shù)字視頻廣播中的應用將越來越多,我們有必要研究Java技術核心―虛擬機,包括其結構、運行機制及虛擬機移植到數(shù)字機頂盒平臺的關鍵技術。本文面向采用ST(意法半導體公司)Sti5516芯片的數(shù)字機頂盒平臺,將基于數(shù)字電視播放(Digital Video Broadcast,DVB)的多媒體家庭平臺(Multimedia Home Platform,MHP)規(guī)范[2]進行中間件平臺分析,重點研究開放源碼的Java虛擬機---Kaffe在其中的作用和相關的移植技術。
2 平臺介紹
2.1 硬件平臺
數(shù)字機頂盒硬件平臺基于ST公司的芯片Sti5516[3],Sti5516芯片集成了CPU內(nèi)核ST20-C2、音/視頻MPEG-2解碼器、PAL/NTSC/SECAM編碼器等。開發(fā)板上有8MB的共享內(nèi)存和16MB的外部內(nèi)存,4MB的Flash,并采用實時處理的嵌入式操作系統(tǒng)OS20。
2.2 軟件平臺
一個典型的適用于嵌入式的Java運行環(huán)境包括以下組件:
1.一個Java虛擬機。用來將獨立于平臺的Java字節(jié)碼解釋成目標機本地機器碼,并執(zhí)行動態(tài)類加載。這可以采取解釋執(zhí)行或?qū)崟r編譯執(zhí)行(JIT)的形式。兩者的不同點就在于字節(jié)碼的執(zhí)行速度;因為JIT避免了重復解釋以前執(zhí)行過的程序塊。
2.一個標準Java類庫集,以字節(jié)碼的形式存在。如果應用程序并不引用任何類庫,那這些類庫就并不一定要求存在。
3.任何類庫或虛擬機所需的本地方法(JNI)。這些函數(shù)是由其它高級語言所寫,并和Java虛擬機一起預編譯,鏈接。這些函數(shù)被用來執(zhí)行處理器相關或Java無法直接實現(xiàn)的功能。
4.一個多任務操作系統(tǒng),用來提供Java線程及線程同步機制的底層實現(xiàn)。
5.一個垃圾回收線程。垃圾回收周期運行或當動態(tài)內(nèi)存池不能滿足分配請求時運行,用來申明那些已經(jīng)被分配但不再被應用程序所使用的內(nèi)存。
圖二 Kaffe架構
如圖二虛線所示,Kaffe是一個完整的Java實現(xiàn),它由3部分組成:遵從 Personal Java1.1規(guī)范的 Java類庫[4],Java1.1虛擬機和本地動態(tài)或靜態(tài)鏈接庫。Kaffe虛擬機源碼按以下子目錄組織:
kaffe---包括了解釋器與JIT平臺無關部分,以及垃圾回收,動態(tài)類加載和Java runtime environment其它模塊的源代碼。
config---包括了解釋器與JIT平臺相關部分。它按所支持的處理器來劃分子目錄,里面存放系統(tǒng)相關代碼。
package---Java類庫以及任何它所依賴的本地方法。
include---在子目錄中提供的本地方法的接口定義。這些接口被平臺獨立文件所需要。
3 Kaffe移植的關鍵技術及方案
經(jīng)過對Kaffe深入分析和研究,筆者已在Sti5516平臺上成功地移植了Kaffe[5],并依據(jù)DVB-MHP規(guī)范,結合機頂盒特定軟硬件環(huán)境要求,建立了能運行Kaffe虛擬機的Java應用程序運行平臺。下面將移植工作及相應步驟總結如下:
3.1字節(jié)碼解釋器
由于Kaffe源碼中沒有映射Java字節(jié)碼到處理器相關的匯編代碼塊,而是使用C實現(xiàn)了每個字節(jié)碼。這樣就導致字節(jié)碼解釋器的源代碼沒有一行是處理器相關的。這意味著移植最簡虛擬機(無JIT)將非常簡單:只需要使用交叉編譯器來編譯kaffe/kaffevm子目錄下的文件即可。
3.2內(nèi)部線程
Kaffe有它自己的內(nèi)部線程包。換句話說,它維護自己的線程數(shù)據(jù)結構,并在適當?shù)臅r候執(zhí)行線程調(diào)度及上下文切換。為了使內(nèi)部線程包能運行在ST20處理器架構上, 需要在config/os20子目錄中創(chuàng)建一個threads.h文件。這個文件定義了兩個常量和四個宏。這些常量和宏被內(nèi)部線程包里處理器無關的部分代碼所使用。
Ø USE_INTERNAL_THREADS定義為ENABLE。
Ø THREADSTACKSIZE是一個常量,定義為每個線程堆棧的大小,單位bytes。
Ø THREADINIT(ctx * pContex, void (*func)())執(zhí)行新線程的上下文初始化。該線程的入口點被func指針所提供。
Ø THREADSWITCH(ctx * pNewContext, ctx * pOldContext)執(zhí)行實際的上下文切換。
Ø THREADINFO(ctx * pContext)在Kaffe初始化期間重置整個任務控制塊。
Ø THREADFRAMES(thread * taskId, int count)返回活動的堆棧楨個數(shù)。
3.3支持軟件
和其它大多數(shù)用C寫的程序一樣,Kaffe依賴于標準C庫里的例程。由于ST采用符合GNU規(guī)范的GCC編譯器,如strcmp(),atoi(),sin()等標準C庫函數(shù)被支持。除此之外OS20提供以下支持:
Ø 動態(tài)內(nèi)存分配malloc()。盡管Java程序員不會直接調(diào)用malloc(),但Kaffe虛擬機需要從底層調(diào)用內(nèi)存分配例程來請求大的內(nèi)存池。
Ø 信號。Kaffe依賴于與POSIX兼容的信號實現(xiàn)機制來執(zhí)行相應的軟件中斷。而這可以用來喚醒休眠線程和異常句柄。
Ø 非阻塞I/O接口。和select()相似。
3.4動態(tài)類加載器
為了在OS20操作系統(tǒng)中使用,須修改源代碼中平臺無關的部分---動態(tài)類加載器。它是Java運行時環(huán)境的一部分,被用來負責加載被調(diào)用的方法(methods)。在桌面環(huán)境中,與方法相關的字節(jié)碼被放在類文件中,動態(tài)類加載器使用給定的方法名在類路徑下的子目錄和文件里搜索。但由于OS20操作系統(tǒng)沒有文件系統(tǒng),所以類加載器必須被修改成在內(nèi)存(RAM或ROM)中搜索類文件。為此我們完全重寫動態(tài)類加載器。
我們采用了靜態(tài)查找表裝載機制,建立了一個查找表。這個查找表的結構定義如下:
typedef struct
{
int index;
int size;
char name;
}classIndexTable;
這個查找表用來映射類名或方法名到它們在內(nèi)存中的起始地址。這樣就可以用查找表來替代類加載器。即將類型和路徑組合為一個唯一的標識, 比如“java string”,組合起來就是“java_string”,然后再利用這個組合的結果檢索查找表。
利用組合的結果與查找表中每一項的name字段進行字符串比較,直到完全匹配為止。如果沒有任何匹配則說明系統(tǒng)不支持這個類型。匹配上name 后,類裝載器將獲得index和size的值。index是一張存放所有.class文件起始地址表的索引,根據(jù)這個索引就可以找到具體的.class文件的二進制映像的起始地址,而size則是該.class文件的大小。這樣根據(jù).class文件存儲位置的地址和大小就可以成功地完成類的裝載。
3.5虛擬機啟動
由于OS20操作系統(tǒng)是被GCC編譯到主程序中,我們需要將kaffe虛擬機的初始化函數(shù)做為主應用程序中的某個任務來運行。kaffe虛擬機的初始化與啟動是通過在主程序中運行initializeKaffe()函數(shù)來完成的。
4 測試與結果
在主程序中,調(diào)用OS20操作系統(tǒng)中的系統(tǒng)調(diào)用task_create()來將Kaffe虛擬機初始化為系統(tǒng)的一個進程。并為它分配必要資源,包括進程優(yōu)先級、系統(tǒng)需要的內(nèi)存空間等。依照分配的優(yōu)先級,參與系統(tǒng)的進程調(diào)度。最后,將整個修改好的源代碼在新的編譯環(huán)境下編譯連接成可執(zhí)行代碼,通過JTAG口下載到機頂盒開發(fā)板中運行。
Kaffe虛擬機的“輸入”是“hello.java”,經(jīng)過編譯后生成類文件“hello.class”。運行下載到Flash的主程序,在調(diào)試終端可以看到“hello world”字樣,這是Kaffe虛擬機解釋字節(jié)碼的結果。說明基于Sti5516芯片的Kaffe虛擬機移植成功。
5 結束語
以上介紹了Java虛擬機Kaffe的軟件架構,從中我們可以看出,Kaffe虛擬機具有較好的可擴展結構模型,是遵循Java規(guī)范的優(yōu)良的開放源碼虛擬機,可以適應多種嵌入式應用環(huán)境。本文按照歐洲D(zhuǎn)VB-MHP規(guī)范,給出了Kaffe虛擬機在Sti5516機頂盒環(huán)境下的移植方案,使其可以應用于要求較高的嵌入式系統(tǒng)中,為機頂盒在證券信息服務、電子節(jié)目、MP3音樂下載、電子郵件、網(wǎng)頁瀏覽等新型服務領域的開發(fā)應用奠定堅實的基礎。我們相信,隨著基于Java技術的DVB-MHP中間件技術的廣泛使用,將使嵌入式系統(tǒng)的應用開發(fā)更加簡捷方便。
參考文獻
[1] 李F楓. Jeode讓Java在嵌入式系統(tǒng)中運轉(zhuǎn)如飛[J].微計算機信息, 2002,18(4):45-46.
[2] Digital Video broadcasting (DVB): Multimedia home Platform(MHP) Specification 1.1[S]. tm2485, tam668r12.
[3] Sti5516 Data sheet, STMicroelectronics. [DB/OL]. www.st.com.
[4] Sun Document. The JavaTM Virtual Machine Specification. 1999.
[5] 嚴東華,張凱,Java虛擬機及其移植. 北京理工大學學報,2002;2:64-67.
本文作者創(chuàng)新點:本文作者給出了Kaffe虛擬機在Sti5516機頂盒環(huán)境下的移植方案,使其可以作用于被廣泛使用在數(shù)字機頂盒系統(tǒng)中的ST芯片上,為機頂盒在證券信息服務、電子節(jié)目、MP3音樂下載、電子郵件、網(wǎng)頁瀏覽等新型服務領域的開發(fā)應用奠定堅實的基礎。這一移植方案為在意法半導體Sti5516芯片上移植Java中間件提供了一種思路,也對在其它嵌入式系統(tǒng)上移植Java虛擬機有一定的參考價值。
linux操作系統(tǒng)文章專題:linux操作系統(tǒng)詳解(linux不再難懂)
評論