前置作業 & 注意事項
- 產生要移植平台相對應的 standalone toolchain ,參考 Android API level (系統版本) 傳送門
- cross compile relative libs. link
- 修正 cross compile 與 auto conf 期間產生的錯誤
- 注意編譯需將 libs 都編譯成 static mode. (non-dynamic mode) 目的是可以方便使用,缺點是檔案大小會較大,不過動態連結,缺點是在入時會呼叫外部的 *.so 檔,Linux 底下的動態連函式庫(Dynamic link library)。(DLL) 但是手機的路徑與 Linux 預設路徑是不同的,所以使用 static mode 不外部呼叫 DLL 是最保險,不然還要去處理載入外部的路徑問題。
- 下載 Python source code,也可以使用 MEGA 載點的,已經修正錯誤。
- 如果使用自行下載的 source 編譯與 auto conf 發生錯誤,可以自行參考MEGA 載點中的 source 裡的檔案,看是如何修改的。
Python-2.7.1
- 從 MEGA 載點或 Python 官網下載 source code
- 若從MEGA上下載,可以跳過這一點。這一點是上 patch ,MEGA 載點裡有這個檔案可以使用:python-2.7.1-cross-compile.patch
- 編譯 host 版本的 Python
- 把產生執行檔改成:
mv python hostpython
mv Parser/pgen Parser/hostpgen - 按照下面的 android-configure bash script file
#上 patch,第 2 點 patch -p1 < /path/to/python-2.7.1-cross-compile.patch
#android-configure #!/bin/bash export TOOLCHAIN=/home/lab501/android-toolchain-16 export PATH=$TOOLCHAIN/bin:$PATH export CC=$TOOLCHAIN/bin/arm-linux-androideabi-gcc export CXX=$TOOLCHAIN/bin/arm-linux-androideabi-g++ export RANLIB=$TOOLCHAIN/bin/arm-linux-androideabi-ranlib export AR=$TOOLCHAIN/bin/arm-linux-androideabi-ar export LD=$TOOLCHAIN/bin/arm-linux-androideabi-ld export STRIP=$TOOLCHAIN/bin/arm-linux-androideabi-strip export ARCH="arm-linux-androideabi" #export LD_LIBRARY_PATH="/data/local/tmp/_install_python/lib" #change your shared libs'(libpython.so) path (LDFLAGS= --rpath) ./configure \ LDFLAGS="-static -static-libgcc -fPIE -pie" \ CFLAGS="-static -fPIE -pie" \ --host=arm-linux-androideabi \ --target=arm-linux-androideabi \ --disable-shared \ --prefix="/home/lab501/android-cross-compile-16/Python-2.7.1/_install" make \ HOSTPYTHON=/home/lab501/Python-2.7.1/hostpython \ HOSTPGEN=/home/lab501/Python-2.7.1/Parser/hostpgen \ CROSS_COMPILE=androideabi \ CROSS_COMPILE_TARGET=yes \ BLDSHARED="arm-linux-androideabi-gcc -shared" \ #make install... #make -i install \ #HOSTPYTHON=/home/lab501/Python-2.7.1/hostpython \ #BLDSHARED="arm-linux-androideabi-gcc -shared" \ #CROSS_COMPILE=androideabi \ #CROSS_COMPILE_TARGET=yes
修改:setup.py 檔,設定如何 build modules
#for example, build hashlib modules #只加入下面這兩行 #find_library_file(self.compiler, 'Modules',lib_dirs, # ['/home/lab501/Python-2.7.1/Modules'] ) if have_any_openssl: #if have_usable_openssl: # The _hashlib module wraps optimized implementations # of hash functions from the OpenSSL library. #comment this code. In order to cross compile hashlib. #exts.append( Extension('_hashlib', ['_hashopenssl.c'], # include_dirs = ssl_incs, # library_dirs = ssl_libs, # libraries = ['ssl', 'crypto']) ) #add this code. In order to cross compile hashlib. Important find_library_file(self.compiler, 'Modules',lib_dirs, ['/home/lab501/Python-2.7.1/Modules'] ) #else: # print ("warning: openssl 0x%08x is too old for _hashlib" % # openssl_ver) # missing.append('_hashlib') #if COMPILED_WITH_PYDEBUG or not have_usable_openssl: # The _sha module implements the SHA1 hash algorithm. #comment this code. In order to cross compile hashlib. #exts.append( Extension('_hashlib', ['shamodule.c']) ) # The _md5 module implements the RSA Data Security, Inc. MD5
參考資料
How-to-Cross-Compile-Python-and-Run-in-Embedded-System
後記
build modules :要自己去調整 setup.py 要試試看,有可能會調整失敗,try and error.