當(dāng)前位置:首頁 > 嵌入式 > 嵌入式教程
[導(dǎo)讀]MTK系統(tǒng)下的J2ME運(yùn)行平臺(tái)設(shè)計(jì)

摘要 在目前手機(jī)移動(dòng)開發(fā)上,Java技術(shù)提供給用戶多種應(yīng)用服務(wù),發(fā)展空間比較大。本文描述了J2ME運(yùn)行平臺(tái)在MTK系統(tǒng)下的設(shè)計(jì)和實(shí)現(xiàn)。首先,簡要介紹了J2ME運(yùn)行環(huán)境和MTK平臺(tái)。然后,在分析此系統(tǒng)需要實(shí)現(xiàn)的功能基礎(chǔ)上,根據(jù)現(xiàn)有資源和平臺(tái)特性,提出了整個(gè)平臺(tái)的框架,并且詳細(xì)描述平臺(tái)各個(gè)子功能模塊的設(shè)計(jì)。最后,詳細(xì)介紹了系統(tǒng)各個(gè)模塊的實(shí)現(xiàn)。
關(guān)鍵詞 嵌入式系統(tǒng) J2ME MTK Java虛擬機(jī) 移植接口


引 言
    現(xiàn)在Java技術(shù)十分流行,發(fā)展勢(shì)頭強(qiáng)勁,而且在SUN公司推出了J2ME平臺(tái)后,眾多移動(dòng)式系統(tǒng)都紛紛支持Java應(yīng)用程序。由于Java已經(jīng)成為了業(yè)界公認(rèn)的通用網(wǎng)絡(luò)語言,具有超強(qiáng)的跨平臺(tái)性,所以Java這種Write once,Run anywhere的特性被目前幾乎所有的手機(jī)系統(tǒng)開發(fā)商所承認(rèn)并運(yùn)用。無一例外,當(dāng)今的智能手機(jī)操作系統(tǒng)都支持KJava技術(shù)。為了保證手機(jī)操作系統(tǒng)支持運(yùn)行Java程序,需要將Java虛擬機(jī)移植到手機(jī)操作系統(tǒng)上。由于手機(jī)這種移動(dòng)式信息設(shè)備都采用小容量的Flash和RAM,所以就要求虛擬機(jī)體積更小,實(shí)時(shí)效率更高,故這種Java虛擬機(jī)被稱為KVM(K Virtual Machine)。
    由于J2ME是以消費(fèi)性產(chǎn)品為目標(biāo)而設(shè)計(jì)的Java運(yùn)行環(huán)境,專門針對(duì)移動(dòng)電話、數(shù)字機(jī)頂盒和汽車導(dǎo)航系統(tǒng),因而影響力巨大。本文將研究在MTK手機(jī)操作系統(tǒng)上實(shí)現(xiàn)嵌入式Java。整個(gè)J2ME運(yùn)行平臺(tái)包括Java應(yīng)用的下載、安裝、運(yùn)行及觸摸屏支持等一系列功能。


1 相關(guān)技術(shù)研究
1.1 J2ME平臺(tái)
    現(xiàn)在的Java系統(tǒng)是一個(gè)全方位的開發(fā)、運(yùn)行平臺(tái),可以在任何計(jì)算環(huán)境中實(shí)現(xiàn)。在嵌入式系統(tǒng),SUN公司推出了J2 ME(Java 2 platform Micro Edition)。
    J2ME是Java 2標(biāo)準(zhǔn)版本的微型版本,支持各種各樣的消費(fèi)類產(chǎn)品和嵌入式設(shè)備,如移動(dòng)電話、PDA、互聯(lián)網(wǎng)可視電話、數(shù)字機(jī)頂盒、車載娛樂和導(dǎo)航系統(tǒng)、網(wǎng)絡(luò)交換設(shè)備以及信息家電等。J2ME是為了那些使用有限的能源、有限的網(wǎng)絡(luò)連接(通常是無線連接)以及有限圖形用戶界面能力的設(shè)備開發(fā)的。
    J2ME體系結(jié)構(gòu)如圖1所示。其中簡表層、配置層和Java虛擬機(jī)是J2ME的組成部分。J2ME是一個(gè)簡化的Java,是針對(duì)各種不同的低端設(shè)備而設(shè)計(jì)的。為了滿足各種環(huán)境,J2ME設(shè)計(jì)了簡表一配置規(guī)范。配置是一個(gè)語言特性和核心類的配置規(guī)范,針對(duì)不同的環(huán)境(內(nèi)存、顯示、網(wǎng)絡(luò)連接和處理能力)給定不同的配置。也就是定義了該環(huán)境的Java語言子集和核心類庫,虛擬機(jī)開發(fā)者遵照此配置來開發(fā)虛擬機(jī)。最著名的兩個(gè)配置是連接設(shè)備配置(CDC)和連接有限設(shè)備配置(CLDC)。

    CLDC包括K虛擬機(jī)(KVM)和一組核心類庫,主要是針對(duì)用戶接口簡單、內(nèi)存較小、網(wǎng)絡(luò)運(yùn)行時(shí)連時(shí)斷以及帶寬較窄的小型無線設(shè)備。其中KVM是JVM的一個(gè)實(shí)現(xiàn),特別用于移動(dòng)電話、PDA等設(shè)備。
    簡表是針對(duì)相同配置的不同特性而開發(fā)的擴(kuò)展類庫,它提供給開發(fā)者在特定類型設(shè)備上開發(fā)的類庫。例如,移動(dòng)信息設(shè)備子集MIDP(Mobile Information Device Pro—file)綜合考慮了移動(dòng)設(shè)備的屏幕和內(nèi)存限制,定義了J2ME適用的硬件和軟件框架,并提供了這個(gè)框架要實(shí)現(xiàn)的基本功能及標(biāo)準(zhǔn)接口;應(yīng)用開發(fā)者可以基于這個(gè)框架開發(fā)出各種應(yīng)用。MIDP 2.0定義了一系列軟件接口,包括基本輸入輸出、圖形用戶接口、網(wǎng)絡(luò)、事件機(jī)制、文件系統(tǒng)、應(yīng)用管理系統(tǒng)、游戲接口、聲音輸出接口和安全機(jī)制。
    由于CLDC的設(shè)備資源受到限制,所以SUN公司專門開發(fā)了一個(gè)新的虛擬機(jī)KVM。Sun公司于2000年公布了KVM的參考實(shí)現(xiàn),采用解釋執(zhí)行字節(jié)碼的Java虛擬機(jī)。與編譯執(zhí)行相比,解釋執(zhí)行的Java虛擬機(jī)在移動(dòng)通信設(shè)備上具有顯著的優(yōu)點(diǎn):虛擬機(jī)占用移動(dòng)通信設(shè)備非易失性存儲(chǔ)空間比較?。惶摂M機(jī)運(yùn)行時(shí)占用RAM空間比較??;解釋執(zhí)行核心代碼量小;字節(jié)碼占用RAM空間比較??;實(shí)現(xiàn)難度低,可移植性好?,F(xiàn)有的具有KVM支持的移動(dòng)通信設(shè)備大多是基于該參考實(shí)現(xiàn)的。[!--empirenews.page--]
1.2 MTK系統(tǒng)
    MTK方案是臺(tái)灣聯(lián)發(fā)科技公司提供的手機(jī)解決方案。近70%的國產(chǎn)手機(jī)采用MTK的芯片和平臺(tái)。有資料顯示,2007年MTK手機(jī)芯片出貨量高達(dá)1.5億片,全球市場(chǎng)占有率近14%,僅次于德州儀器及高通公司。若只計(jì)算MTK進(jìn)入全球GSM手機(jī)芯片的市場(chǎng)規(guī)模,大約省7億~8億部手機(jī),市場(chǎng)占有率已高達(dá)20%以上,排名僅次于德州儀器公司。
    在目前MTK市場(chǎng)上,MTK6225平臺(tái)占據(jù)主導(dǎo)地位。該系統(tǒng)的主要功能如下:
    ①任務(wù)管理。系統(tǒng)任務(wù)采用靜態(tài)創(chuàng)建方式,靜態(tài)配置任務(wù)優(yōu)先級(jí)、棧大小、任務(wù)全局唯一ID等;不提供動(dòng)態(tài)創(chuàng)建Task的方式;任務(wù)內(nèi)部以及任務(wù)之間的通信通過內(nèi)部事件隊(duì)列和外部事件隊(duì)列完成。
    ②內(nèi)存管理。平臺(tái)不提供動(dòng)態(tài)分配內(nèi)存的方式;應(yīng)用程序需要使用動(dòng)態(tài)分配內(nèi)存時(shí),可以采用以下幾種方式:與系統(tǒng)其他模塊共享內(nèi)存,典型的是使用MED模塊的內(nèi)存;定義一個(gè)靜態(tài)數(shù)組,交給系統(tǒng)adm托管,然后調(diào)用kal_adm_alloc、kal_adm_free等內(nèi)存操作函數(shù)實(shí)現(xiàn)動(dòng)態(tài)內(nèi)存分配;定義一個(gè)靜態(tài)數(shù)組,應(yīng)用自己實(shí)現(xiàn)基于此數(shù)組的分配和管理,也就是實(shí)現(xiàn)自己的內(nèi)存管理模塊。
    ③事件機(jī)制。平臺(tái)事件機(jī)制采用“注冊(cè)一回調(diào)”機(jī)制,把需要處理的各個(gè)按鍵、觸摸屏等通過系統(tǒng)函數(shù)注冊(cè),當(dāng)有事件發(fā)生時(shí)系統(tǒng)調(diào)用所注冊(cè)的監(jiān)聽者。
    ④UI。系統(tǒng)MMI層提供了豐富的UI元素,如各種消息框、列表、圖標(biāo)等。
    ⑤系統(tǒng)局限性。MTK6225平臺(tái)只有一種中文字體,字體大小固定。


2 平臺(tái)設(shè)計(jì)
2.1 平臺(tái)功能分析
    在MTK平臺(tái)上實(shí)現(xiàn)J2ME運(yùn)行環(huán)境,需要實(shí)現(xiàn)的功能如下:
    ①應(yīng)用程序管理。Java擁有豐富的應(yīng)用程序,平臺(tái)需要管理這些應(yīng)用程序,因此要實(shí)現(xiàn)應(yīng)用程序管理系統(tǒng)。應(yīng)用程序管理系統(tǒng)功能包括程序的安裝、刪除、運(yùn)行、下載等。
    ②虛擬機(jī)的實(shí)現(xiàn)平臺(tái)。嵌入式Java虛擬機(jī)的實(shí)現(xiàn)平臺(tái)有多種方式。它可以直接嵌入到裸機(jī)上,也可以加載于其他嵌入式操作系統(tǒng)之上,成為一臺(tái)抽象的計(jì)算機(jī)。它的平臺(tái)無關(guān)性給它帶來了巨大的發(fā)展前景。經(jīng)過研究,在MTK平臺(tái)上,采用SUN公司公布的KVM作為核心,結(jié)合虛擬機(jī)所需要實(shí)現(xiàn)的功能和MTK平臺(tái),設(shè)計(jì)和實(shí)現(xiàn)移植接口,最后在MTK平臺(tái)上運(yùn)行KVM,在KVM之上運(yùn)行Java應(yīng)用程序。
2.2 平臺(tái)框架設(shè)計(jì)
    系統(tǒng)平臺(tái)由應(yīng)用程序管理系統(tǒng)(ApplicationManagement System,AMS)、KVM核心(KVM core)、KVM移植接口層、MTK系統(tǒng)平臺(tái)構(gòu)成。平臺(tái)框圖如圖2所示。

[!--empirenews.page--]

    移植接口層包含以下部分:
    ①文件系統(tǒng)部分,對(duì)文件操作,實(shí)現(xiàn)創(chuàng)建、打開、關(guān)閉、讀、寫等功能。KVM在運(yùn)行的時(shí)候需要通過這部分接口使用本地文件,如打開jar、jad文件等。
    ②網(wǎng)絡(luò)部分,提供Socket訪問功能。
    ③外部事件,獲取用戶輸入,包括按鍵輸入和觸摸屏輸入。
    ④圖形顯示部分,負(fù)責(zé)KVM圖形及文字顯示。
    ⑤系統(tǒng)時(shí)間部分,提供給KVM精確的系統(tǒng)時(shí)間。
    ⑥輸入法,Java程序運(yùn)行時(shí)可能要求用戶輸入,此接口實(shí)現(xiàn)調(diào)用系統(tǒng)輸入法功能。
    ⑦其他接口,內(nèi)存訪問、交互性事件通知以及擴(kuò)充的JSR實(shí)現(xiàn)所需要的接口,如JSRl20、JSRl35等。
2.4 應(yīng)用程序管理系統(tǒng)設(shè)計(jì)
    應(yīng)用程序管理系統(tǒng)管理整個(gè)Java運(yùn)行環(huán)境,實(shí)現(xiàn)如下功能:
    ①顯示應(yīng)用程序列表,展示給用戶當(dāng)前手機(jī)系統(tǒng)的所有可用的應(yīng)用程序。
    ②應(yīng)用管理功能選擇菜單,菜單應(yīng)包括兩種類型,分別是程序已經(jīng)安裝好的菜單項(xiàng)和程序還未下載,只有jad文件在本地,需要向服務(wù)器請(qǐng)求下載應(yīng)用安裝后才能運(yùn)行的菜單項(xiàng)。
    ③下載應(yīng)用,與服務(wù)器通信下載用戶選擇的應(yīng)用。用戶啟動(dòng)Java應(yīng)用流程如圖4所示。

    根據(jù)UI和engine的劃分,可以把應(yīng)用程序管理系統(tǒng)分為應(yīng)用程序管理界面和應(yīng)用管理系統(tǒng)核心:應(yīng)用程序管理界面提供給用戶交互式界面,包括管理系統(tǒng)主界面、程序下載界面、程序運(yùn)行界面、管理功能菜單以及各級(jí)子界面;應(yīng)用管理系統(tǒng)核心由實(shí)現(xiàn)功能的一系列API組成,提供給上層界面調(diào)用,實(shí)現(xiàn)程序的下載、安裝、刪除、運(yùn)行等功能。


3 平臺(tái)的實(shí)現(xiàn)
3.1 Java虛擬機(jī)移植的實(shí)現(xiàn)
    在實(shí)現(xiàn)內(nèi)存管理模塊時(shí),由于平臺(tái)不提供動(dòng)態(tài)分配內(nèi)存方式,而虛擬機(jī)需要一塊比較大的內(nèi)存,不能從MED模塊分配,且根據(jù)需要會(huì)對(duì)內(nèi)存進(jìn)行壓縮整理,不適合采用系統(tǒng)托管方式。所以,采用虛擬機(jī)自己管理內(nèi)存的方式,實(shí)現(xiàn)內(nèi)存管理模塊。
    KVM就像一個(gè)軟處理器一樣控制解釋Java字節(jié)碼和它的執(zhí)行狀況,每一個(gè)創(chuàng)建的Java線程在Java堆中都會(huì)有各自的線程執(zhí)行棧,并且由KVM運(yùn)行來調(diào)度管理。為了使KVM能盡量正確地劃分時(shí)間片,需要給一個(gè)時(shí)間標(biāo)準(zhǔn)作為KVM的內(nèi)部時(shí)鐘,由時(shí)間接口實(shí)現(xiàn)。系統(tǒng)提供void kal_get_time(kal_uint32*tieks_ptr)函數(shù),可精確到1個(gè)ticks(4.615 ms)。
    系統(tǒng)只提供一種大小字體,而Java應(yīng)用需要使用3種大小字體??梢圆捎靡韵路绞綄?shí)現(xiàn):
    ①設(shè)計(jì)實(shí)現(xiàn)虛擬機(jī)自身的文字模塊,采用3種大小的ASCII和GB2312字體點(diǎn)陣字庫,從中提取文字點(diǎn)陣信息,由虛擬機(jī)圖形顯示模塊顯示。
    ②只提供一種大小的字體,這樣應(yīng)用會(huì)受限制。由于系統(tǒng)平臺(tái)可用內(nèi)存小,文字點(diǎn)陣字庫相對(duì)比較大,不適合在這個(gè)平臺(tái)使用,因此選擇采用第2種方式。如今在移動(dòng)多媒體領(lǐng)域,Java應(yīng)用大多要求聯(lián)網(wǎng),所以實(shí)現(xiàn)網(wǎng)絡(luò)通信,即要實(shí)現(xiàn)TCP/IP,支持套接字,是KVM一個(gè)非常重要的功能。系統(tǒng)“soc_api.h”文件中定義了套接字接口API,使用此接口實(shí)現(xiàn)虛擬機(jī)網(wǎng)絡(luò)方面移植非常方便。
    Java應(yīng)用要求支持多媒體音頻和事件處理,提供用戶最好的交互功能。在多媒體音頻方面,MTK系統(tǒng)提供了非常全面的支持——支持MID、MP3等格式的音頻播放。根據(jù)Java應(yīng)用的需求,一些基于MIDP2.O擴(kuò)展包的實(shí)現(xiàn)成為必要。本系統(tǒng)實(shí)現(xiàn)了JSRl20的短信功能以及JSRl35的部分功能。
3.2 應(yīng)用程序管理系統(tǒng)的實(shí)現(xiàn)
    實(shí)現(xiàn)了應(yīng)用程序管理核心API,包括對(duì)jar、jad文件的安裝、刪除、信息獲取等等。系統(tǒng)MMI層提供了豐富的UI元素,因此比較容易地實(shí)現(xiàn)了應(yīng)用程序管理界面。實(shí)現(xiàn)了應(yīng)用下載模塊,與服務(wù)器通信下載應(yīng)用。由于平臺(tái)未提供HTTP協(xié)議的實(shí)現(xiàn),因此在基于所設(shè)計(jì)的虛擬機(jī)Socket接口之上,實(shí)現(xiàn)了HTTP協(xié)議,連接服務(wù)器下載用戶選擇的相關(guān)應(yīng)用。


結(jié) 語
    J2ME運(yùn)行平臺(tái)在MTK系統(tǒng)上的設(shè)計(jì)和實(shí)現(xiàn),充分考慮了系統(tǒng)空間的局限性和運(yùn)行效率這兩大要素,以及Java運(yùn)行時(shí)與系統(tǒng)的交互事件處理問題,實(shí)現(xiàn)了在MTK平臺(tái)上下載、安裝、運(yùn)行Java應(yīng)用一體化平臺(tái),并在MIP2.0基礎(chǔ)上擴(kuò)充實(shí)現(xiàn)了JSR120、JSR135部分功能。該平臺(tái)已經(jīng)在多款MTK6225平臺(tái)手機(jī)上運(yùn)行。

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場(chǎng)的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競(jìng)爭(zhēng)力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競(jìng)爭(zhēng)優(yōu)勢(shì)...

關(guān)鍵字: 通信 BSP 電信運(yùn)營商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場(chǎng) NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡稱"軟通動(dòng)力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉