Linux x86編譯Android遭遇gnu/stubs-64.h – Android移動開發技術文章_手機開發 Android移動開發教學課程

這兩天心血來潮,執行完 repo sync 後,順手來瞭一下 make,不料卻發現瞭以下的錯誤:
host C: libclearsilver-jni <= external/clearsilver/java-jni/j_neo_util.c
In file included from /usr/include/features.h:378,
                      from /usr/include/string.h:26,
        from external/clearsilver/java-jni/j_neo_util.c:1:
/usr/include/gnu/stubs.h:9:27: error: gnu/stubs-64.h: No such file or directory
make: *** [out/host/linux-x86/obj/SHARED_LIBRARIES/libclearsilver-jni_intermediates/j_neo_util.o] Error 1
兵來將擋,水來土掩,用關鍵字 android “error: gnu/stubs-64.h: no such file or directory” 來搜一下吧,發現搜索結果寥寥無幾,看樣子問題比較新,其中有一個 CSDN 的鏈接,就順手點瞭過去。帖子反映的問題和我一模一樣,不過它的分析給瞭我一些提醒。
從錯誤信息入手,追蹤到/usr/include/gnu/stubs.h,看到如下代碼:
#if __WORDSIZE == 32
# include <gnu/stubs-32.h>
#elif __WORDSIZE == 64
# include <gnu/stubs-64.h>
#else
# error "unexpected value for __WORDSIZE macro"
#endif
順著 WORDSIZE,進入/usr/include/bits/wordsize,發現:
#if defined __x86_64__
# define __WORDSIZE 64
# define __WORDSIZE_COMPAT32 1
#else
# define __WORDSIZE 32
#endif
結合報錯的信息,可以知道這裡一定是有定義__x86_64__,執行一下 uname -a 可以確認 OS 明明是x86,為什麼會__x86_64__呢?追根溯源, Android 源碼或許能露出蛛絲馬跡。
果不其然,從 android.git.kernel.org 的 platform/external/clearsilver.git 上,看到5天前,有個 Ying Wang 的傢夥提交一個修改:Fix 64-bit clearsilver shared library issue,參看這裡,修改內容中 java-jni/Android.mk,和出現本次問題的路徑 java-jni/j_neo_util.c,同屬一個父目錄,看樣子有點關系,查看 Android.mk 的修改內容,發現做瞭如下修改:
+# This forces a 64-bit build for Java6
+ifneq ($(filter 1.6%,$(java_version)),)
+    LOCAL_CFLAGS += -m64
+    LOCAL_LDFLAGS += -m64
+endif
當發現你使用Java6時,它將強制使用64-bit,我想這就能解釋__x86_64__出現的原因。那麼既然它要64-bit,我就滿足它。首先要解決 gnu/stubs-64.h: No such file or directory,解決這個問題需要執行以下命令:
[xuhj@eniac mydroid]$ apt-get install libc6-dev-amd64
完成以後再執行 make,發現有錯誤:
/usr/bin/ld: cannot find -lstdc++
那就繼續滿足它:
[xuhj@eniac mydroid]$ apt-get install g++-multilib lib64stdc++6
還是不行,又發生下面的錯誤:
/usr/bin/ld: cannot find -lz
再來執行命令:
[xuhj@eniac mydroid]$ apt-get install lib64z1-dev

發佈留言