From f6f87ebec5eb6054950ffac22688b2da9399ddab Mon Sep 17 00:00:00 2001 From: Cen Zhang Date: Sat, 27 Jul 2019 00:16:01 +0800 Subject: [PATCH] fix for make.sh for android (#1523) * fix for make.sh for android * remove commented line --- .gitignore | 3 +++ Makefile | 6 ++++++ make.sh | 19 ++++++++++++------- 3 files changed, 21 insertions(+), 7 deletions(-) diff --git a/.gitignore b/.gitignore index 388893f322..da89f952c8 100644 --- a/.gitignore +++ b/.gitignore @@ -119,3 +119,6 @@ capstone_get_setup *.s cstool/cstool + +# android +android-ndk-* diff --git a/Makefile b/Makefile index 3a576030c3..751f81f184 100644 --- a/Makefile +++ b/Makefile @@ -22,6 +22,11 @@ endif ifeq ($(CROSS),) RANLIB ?= ranlib +else ifeq ($(ANDROID), 1) +CC = $(CROSS)/../../bin/clang +AR = $(CROSS)/ar +RANLIB = $(CROSS)/ranlib +STRIP = $(CROSS)/strip else CC = $(CROSS)gcc AR = $(CROSS)ar @@ -437,6 +442,7 @@ clean: rm -f $(LIBOBJ) rm -f $(BLDIR)/lib$(LIBNAME).* $(BLDIR)/$(LIBNAME).pc rm -f $(PKGCFGF) + [ ${ANDROID} -eq 1 ] && rm -rf android-ndk-* $(MAKE) -C cstool clean ifeq (,$(findstring yes,$(CAPSTONE_BUILD_CORE_ONLY))) diff --git a/make.sh b/make.sh index b6c50ac2bd..eb400a99a9 100755 --- a/make.sh +++ b/make.sh @@ -15,6 +15,7 @@ build_android() { echo "ERROR! Please set \$NDK to point at your Android NDK directory." exit 1 fi + HOSTOS=$(uname -s | tr 'LD' 'ld') HOSTARCH=$(uname -m) @@ -24,13 +25,11 @@ build_android() { case "$TARGARCH" in arm) [ -n "$APILEVEL" ] || APILEVEL="android-14" # default to ICS - [ -n "$GCCVER" ] || GCCVER="4.8" - CROSS=arm-linux-androideabi- + CROSS=arm-linux-androideabi ;; arm64) [ -n "$APILEVEL" ] || APILEVEL="android-21" # first with arm64 - [ -n "$GCCVER" ] || GCCVER="4.9" - CROSS=aarch64-linux-android- + CROSS=aarch64-linux-android ;; *) @@ -39,10 +38,16 @@ build_android() { ;; esac - TOOLCHAIN="$NDK/toolchains/$CROSS$GCCVER/prebuilt/$HOSTOS-$HOSTARCH" - PLATFORM="$NDK/platforms/$APILEVEL/arch-$TARGARCH" + STANDALONE=`realpath android-ndk-${TARGARCH}-${APILEVEL}` + + [ -d $STANDALONE ] || { + python ${NDK}/build/tools/make_standalone_toolchain.py \ + --arch ${TARGARCH} \ + --api ${APILEVEL##*-} \ + --install-dir ${STANDALONE} + } - CROSS="$TOOLCHAIN/bin/$CROSS" CFLAGS="--sysroot=$PLATFORM" LDFLAGS="--sysroot=$PLATFORM" ${MAKE} $* + ANDROID=1 CROSS="${STANDALONE}/${CROSS}/bin" CFLAGS="--sysroot=${STANDALONE}/sysroot" ${MAKE} $* } # build iOS lib for all iDevices, or only specific device