前幾天下載了Android 2.3.1的原始碼並在Ubuntu 10.04(32位)上編譯通過。這篇文章簡要記錄了下載、編譯的過程。
關於搭建Android開發環境的文章已經有很多,本文只簡要介紹一下,做為備忘。
[ 編譯前的準備]
這一步安裝擷取原始碼以及編譯所需要的軟體,使用如下命令:
$ sudo aptitude install git-core gnupg flex bison gperf libsdl-dev libesd0-dev libwxgtk2.6-dev build-essential zip curl libncurses5-dev zlib1g-dev 另外,參考別人編譯Android 2.3的經驗,安裝了下列軟體包:
$ sudo apt-get install lib64z1-dev libc6-dev-amd64 g++-multilib lib64stdc++6 雖然Android官方網站上講不支援Java 6,不過我使用Java 6也可以編譯通過,所以在這裡Easwy安裝的是Java 6。首先去掉/etc/apt/sources.list中這兩行的注釋,使能Java 6源:
deb http://archive.canonical.com/ubuntu lucid partner
deb-src http://archive.canonical.com/ubuntu lucid partner 然後安裝Java 6 JDK:
$ sudo aptitude install sun-java6-jdk 接下來下載repo工具,這是Google提供的一個Python指令碼,方便管理多個Git版本庫:
$ cd ~
$ mkdir bin
$ curl http://android.git.kernel.org/repo >~/bin/repo
$ chmod a+x ~/bin/repo 記得把repo加到你的路徑中,方便以後使用。編輯~/.bashrc,加入下面一行:
PATH=$PATH:~/bin
export PATH 然後用命令. ~/.bashrc,以後就可以直接使用repo命令了。
接下來擷取Android 2.3.1的原始碼:
$ mkdir mydroid
$ cd mydroid
$ repo init -u git://android.git.kernel.org/platform/manifest.git -b android-2.3.1_r1
$ repo sync [ 編譯Android ]
接下來開始編譯:
$ make -j`grep '^processor' /proc/cpuinfo | wc -l` 上面的命令中,-j參數告訴make啟動多個並行任務進行編譯,在支援多核的CPU上能加快編譯速度。如果你知道你CPU是幾核的,可以直接把這部分替換成-j2(雙核)。
我在編譯的過程中遇到下面的錯誤:
************************************************************
You are attempting to build on a 32-bit system.
Only 64-bit build environments are supported beyond froyo/2.2.
************************************************************
這是因為在Makefile中檢測了CPU的字長。我直接把build/core/main.mk中下面的話注釋掉:
#ifneq (64,$(findstring 64,$(build_arch)))
#$(warning ************************************************************)
#$(warning You are attempting to build on a 32-bit system.)
#$(warning Only 64-bit build environments are supported beyond froyo/2.2.)
#$(warning ************************************************************)
#$(error stop)
#endif 接下來又遇到下面的錯誤:
Docs droiddoc: out/target/common/docs/api-stubs
Could not load ‘clearsilver-jni’
www.2cto.com
java.library.path = out/host/linux-x86/lib
make: *** [out/target/common/docs/api-stubs-timestamp] Error 45
make: *** Waiting for unfinished jobs….
Could not load ‘clearsilver-jni’
java.library.path = out/host/linux-x86/lib
make: *** [out/target/common/docs/doc-comment-check-timestamp] Error 45
這是由於clearsilver在編譯時間如果檢測到使用Java JDK 6,就使用64位編譯。要避開此錯誤,需要修改下面四個檔案:
external/clearsilver/cgi/Android.mk
external/clearsilver/java-jni/Android.mk
external/clearsilver/util/Android.mk
external/clearsilver/cs/Android.mk
把這四個Makefile中的下列語句注掉即可:
# This forces a 64-bit build for Java6
# Comment by Easwy
# LOCAL_CFLAGS += -m64
# LOCAL_LDFLAGS += -m64 然後在external/clearsilver目錄中執行一下make clean,然後回到項目根目錄,繼續make即可。
當編譯完成時,產生的image檔案放在out/target/product/generic目錄中