KVM在嵌入式Linux上的移植
# 注釋掉CC = gcc, 事實(shí)上由于ifeq ($(GCC), true) 不成立,該處不會執(zhí)行到。
# CC = gcc
CFLAGS = -Wall $(CPPFLAGS) $(ROMFLAGS) $(OTHER_FLAGS)
DEBUG_FLAG = -g
OPTIMIZE_FLAG = -O2
else
# 注釋掉CC = cc 一行,這樣,系統(tǒng)采用CC=arm-elf-gcc 編譯KVM
# CC = cc
CFLAGS = -Xa $(CPPFLAGS) $(ROMFLAGS) $(OTHER_FLAGS)
DEBUG_FLAG = -g -xsb
OPTIMIZE_FLAG = -xO2
endif
DEBUG_FLAG += -DINCLUDEDEBUGCODE=1
$(TOP)/tools/jcc/ROMjavaUnix.c $(TOP)/tools/jcc/nativeFunctionTableUnix.c: jcc
Unix
.PHONY: jccUnix
jccUnix:
@(cd $(TOP)/tools/jcc; $(MAKE) unix)
kvm$(j)$(g): obj$j$g/ $(CLEANUPXPM) $(OBJFILES)
@echo Linking ... $@
# 注釋掉@$(CC) $(OBJFILES) -o $@ $(LIBS) $(EXTLIBS) 一行
# @$(CC) $(OBJFILES) -o $@ $(LIBS) $(EXTLIBS)
# 用arm-elf-ld連接目標(biāo)文件
$(LD) -o kvm.x $(WEC_LDFLAGS) -r -d $(OBJFILES) $(LIBS) $(EXTLIBS) -Map kvm.map
修改Makefile后,切換到j(luò)2me_cldc/build/linux目錄,執(zhí)行make命令編譯kvm。如果不能通過編譯,建議用arm-elf-gcc3.0以上版本的交叉編譯工具進(jìn)行編譯。編譯完成后,將在j2me_cldc/kvm/VmUnix/build目錄下生成kvm.x文件,因?yàn)閡Clinux操作系統(tǒng)上可執(zhí)行文件都必須為Flat格式,需用elf2flt工具對kvm.x進(jìn)行轉(zhuǎn)換。在終端提示符下執(zhí)行如下命令:
elf2lft –o kvm kvm.x
生成kvm可執(zhí)行文件,至此,整個kvm編譯過程完成。
6. 測試KVM
這樣編譯出來的kvm是針對ARM體系結(jié)構(gòu)的,所以在Red Hat Linux 7.3系統(tǒng)上無法運(yùn)行,讀者可以編輯“Hello World”程序。然后在終端提示符下做如下測試:
./kvm –classpath j2me_cldc/samples/classes HelloWorld
程序報錯,這說明當(dāng)前編譯出來的KVM不是針對X86體系結(jié)構(gòu)。接下來下載kvm到運(yùn)行uClinux操作系統(tǒng)的嵌入式設(shè)備上,再測試kvm。
拷貝kvm以及HelloWorld.class到 uClinux-dist/romfs/bin目錄下執(zhí)行make image,生成包含kvm及HelloWorld.class的romfs.img
下載image.ram和romfs.img到板子上uClinux系統(tǒng)啟動后,輸入如下命令測試
./kvm –classpath /bin HelloWorld
7. 小結(jié)
本文以uCLinux嵌入式操作系統(tǒng)為例討論了KVM的移植過程,若讀者希望在其他體系結(jié)構(gòu)的嵌入式Linux(比如PPC Linux, MIPS Linux)系統(tǒng)上移植KVM,可以根據(jù)其編譯環(huán)境修改KVM的Makefile進(jìn)行編譯。如果為讓系統(tǒng)支持更多的功能,如MIDP等,則需要作進(jìn)一步的研究與探索。
linux操作系統(tǒng)文章專題:linux操作系統(tǒng)詳解(linux不再難懂)c語言相關(guān)文章:c語言教程
linux相關(guān)文章:linux教程
pos機(jī)相關(guān)文章:pos機(jī)原理
評論