aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--tools/buildsteps/android-arm64-v8a/configure-depends5
-rw-r--r--tools/buildsteps/android/configure-depends5
-rw-r--r--tools/buildsteps/androidx86/configure-depends5
-rw-r--r--tools/buildsteps/defaultenv7
-rw-r--r--tools/depends/Makefile.include.in3
-rw-r--r--tools/depends/configure.ac43
-rw-r--r--tools/depends/target/Toolchain.cmake.in2
7 files changed, 45 insertions, 25 deletions
diff --git a/tools/buildsteps/android-arm64-v8a/configure-depends b/tools/buildsteps/android-arm64-v8a/configure-depends
index 705bc53349..95ec12cb22 100644
--- a/tools/buildsteps/android-arm64-v8a/configure-depends
+++ b/tools/buildsteps/android-arm64-v8a/configure-depends
@@ -5,7 +5,7 @@ XBMC_PLATFORM_DIR=android
NDK_ARCH=aarch64
#the following paths must exist on the slave and use the defined scheme here!
NDK_PATH=$ANDROID_DEV_ROOT/android-ndk-r$NDK_VERSION
-TOOLCHAIN=$ANDROID_DEV_ROOT/android-toolchain-$NDK_ARCH-$SDK_VERSION-r$NDK_VERSION
+TOOLCHAIN=$ANDROID_DEV_ROOT/android-toolchain-$NDK_ARCH-$NDK_API-r$NDK_VERSION
if [ "$(pathChanged $WORKSPACE/tools/depends)" == "1" ]
then
@@ -13,8 +13,9 @@ then
--with-tarballs=$TARBALLS \
--host=aarch64-linux-android \
--with-sdk-path=$SDK_PATH \
- --with-ndk=$NDK_PATH \
+ --with-ndk-path=$NDK_PATH \
$(if [ "$SDK_VERSION" != "Default" ]; then echo --with-sdk=android-$SDK_VERSION;fi) \
+ $(if [ "$NDK_API" != "Default" ]; then echo --with-ndk=$NDK_API;fi) \
--with-toolchain=$TOOLCHAIN \
--prefix=$XBMC_DEPENDS_ROOT \
--enable-neon $DEBUG_SWITCH
diff --git a/tools/buildsteps/android/configure-depends b/tools/buildsteps/android/configure-depends
index edcfbc7032..81f03a0e10 100644
--- a/tools/buildsteps/android/configure-depends
+++ b/tools/buildsteps/android/configure-depends
@@ -5,7 +5,7 @@ XBMC_PLATFORM_DIR=android
NDK_ARCH="arm"
#the following paths must exist on the slave and use the defined scheme here!
NDK_PATH=$ANDROID_DEV_ROOT/android-ndk-r$NDK_VERSION
-TOOLCHAIN=$ANDROID_DEV_ROOT/android-toolchain-$NDK_ARCH-$SDK_VERSION-r$NDK_VERSION
+TOOLCHAIN=$ANDROID_DEV_ROOT/android-toolchain-$NDK_ARCH-$NDK_API-r$NDK_VERSION
if [ "$(pathChanged $WORKSPACE/tools/depends)" == "1" ]
then
@@ -13,8 +13,9 @@ then
--with-tarballs=$TARBALLS \
--host=arm-linux-androideabi \
--with-sdk-path=$SDK_PATH \
- --with-ndk=$NDK_PATH \
+ --with-ndk-path=$NDK_PATH \
$(if [ "$SDK_VERSION" != "Default" ]; then echo --with-sdk=android-$SDK_VERSION;fi) \
+ $(if [ "$NDK_API" != "Default" ]; then echo --with-ndk=$NDK_API;fi) \
--with-toolchain=$TOOLCHAIN \
--prefix=$XBMC_DEPENDS_ROOT \
--enable-neon $DEBUG_SWITCH
diff --git a/tools/buildsteps/androidx86/configure-depends b/tools/buildsteps/androidx86/configure-depends
index 9a6e31ceed..92baf59dd3 100644
--- a/tools/buildsteps/androidx86/configure-depends
+++ b/tools/buildsteps/androidx86/configure-depends
@@ -5,7 +5,7 @@ XBMC_PLATFORM_DIR=android
NDK_ARCH=x86
#the following paths must exist on the slave and use the defined scheme here!
NDK_PATH=$ANDROID_DEV_ROOT/android-ndk-r$NDK_VERSION
-TOOLCHAIN=$ANDROID_DEV_ROOT/android-toolchain-$NDK_ARCH-$SDK_VERSION-r$NDK_VERSION
+TOOLCHAIN=$ANDROID_DEV_ROOT/android-toolchain-$NDK_ARCH-$NDK_API-r$NDK_VERSION
if [ "$(pathChanged $WORKSPACE/tools/depends)" == "1" ]
then
@@ -13,8 +13,9 @@ then
--with-tarballs=$TARBALLS \
--host=i686-linux-android \
--with-sdk-path=$SDK_PATH \
- --with-ndk=$NDK_PATH \
+ --with-ndk-path=$NDK_PATH \
$(if [ "$SDK_VERSION" != "Default" ]; then echo --with-sdk=android-$SDK_VERSION;fi) \
+ $(if [ "$NDK_API" != "Default" ]; then echo --with-ndk=$NDK_API;fi) \
--with-toolchain=$TOOLCHAIN \
--prefix=$XBMC_DEPENDS_ROOT $DEBUG_SWITCH
fi
diff --git a/tools/buildsteps/defaultenv b/tools/buildsteps/defaultenv
index 39e66ae3c0..68737e6517 100644
--- a/tools/buildsteps/defaultenv
+++ b/tools/buildsteps/defaultenv
@@ -1,6 +1,7 @@
BUILDTHREADS=${BUILDTHREADS:-1}
SDK_VERSION=${SDK_VERSION:-"Default"}
NDK_VERSION=${NDK_VERSION:-"Default"}
+NDK_API=${NDK_API:-"Default"}
Configuration=${Configuration:-"Default"}
XBMC_DEPENDS_ROOT=${XBMC_DEPENDS_ROOT:-"Default"}
DARWIN_ARM_CPU=${DARWIN_ARM_CPU:-"Default"}
@@ -35,6 +36,7 @@ case $XBMC_PLATFORM_DIR in
android)
DEFAULT_SDK_VERSION="21"
DEFAULT_NDK_VERSION="14b"
+ DEFAULT_NDK_API="21"
DEFAULT_XBMC_DEPENDS_ROOT=$WORKSPACE/tools/depends/xbmc-depends
DEFAULT_CONFIGURATION="Debug"
;;
@@ -61,6 +63,11 @@ then
NDK_VERSION=$DEFAULT_NDK_VERSION
fi
+if [ "$NDK_API" == "Default" ]
+then
+ NDK_API=$DEFAULT_NDK_API
+fi
+
if [ "$XBMC_DEPENDS_ROOT" == "Default" ]
then
XBMC_DEPENDS_ROOT=$DEFAULT_XBMC_DEPENDS_ROOT
diff --git a/tools/depends/Makefile.include.in b/tools/depends/Makefile.include.in
index a35cc85c71..41a7fa869d 100644
--- a/tools/depends/Makefile.include.in
+++ b/tools/depends/Makefile.include.in
@@ -2,7 +2,7 @@ abs_top_srcdir=@abs_top_srcdir@
DEBUG_BUILD=@use_debug@
TOOLCHAIN=@use_toolchain@
-NDKROOT=@use_ndk@
+NDKROOT=@use_ndk_path@
SDKROOT=@use_sdk_path@
CMAKE_SOURCE_DIR=$(abspath $(abs_top_srcdir)/../../)
TARBALLS_LOCATION=@use_tarballs@
@@ -11,6 +11,7 @@ HOST=@use_host@
CPU=@use_cpu@
NATIVEPLATFORM=@build_cpu@-@build_os@-native
SDK_PLATFORM=@use_sdk@
+NDK_LEVEL=@use_ndk_api@
RETRIEVE_TOOL=@CURL@
ARCHIVE_TOOL=@TAR@
PREFIX=@prefix@/@deps_dir@
diff --git a/tools/depends/configure.ac b/tools/depends/configure.ac
index 21b8edb088..317c7f754a 100644
--- a/tools/depends/configure.ac
+++ b/tools/depends/configure.ac
@@ -68,10 +68,10 @@ AC_ARG_WITH([cpu],
[optional. specify target cpu. guessed if not specified])],
[use_cpu=$withval],use_cpu=auto)
-AC_ARG_WITH([ndk],
- [AS_HELP_STRING([--with-ndk],
+AC_ARG_WITH([ndk-path],
+ [AS_HELP_STRING([--with-ndk-path],
[specify path to ndk (required for android only)])],
- [use_ndk=$withval])
+ [use_ndk_path=$withval])
AC_ARG_WITH([sdk-path],
[AS_HELP_STRING([--with-sdk-path],
@@ -83,6 +83,11 @@ AC_ARG_WITH([sdk],
[specify sdk platform version (optional for android). default is android-21])],
[use_sdk=$withval])
+AC_ARG_WITH([ndk-api],
+ [AS_HELP_STRING([--with-ndk-api],
+ [spcify ndk level (optional for android). default is 21])],
+ [use_ndk_api=$withval])
+
AC_ARG_ENABLE([gplv3],
[AS_HELP_STRING([--enable-gplv3],
[enable gplv3 components. default is yes])],
@@ -161,15 +166,16 @@ case $host in
use_cpu="armeabi-v7a"
fi
use_sdk="${use_sdk:-android-21}"
- deps_dir="$use_host-$use_sdk-$build_type"
+ use_ndk_api="${use_ndk_api:-21}"
+ deps_dir="$use_host-$use_ndk_api-$build_type"
platform_cflags="-DANDROID -fexceptions -fPIC -DPIC -D_GLIBCXX_USE_C99_MATH_TR1"
optimize_flags="-Os"
if test "x$use_cpu" = "xarmeabi-v7a"; then
platform_cflags+=" -march=armv7-a -mtune=cortex-a9 -mfloat-abi=softfp -mfpu=neon"
fi
- platform_ldflags="-L$prefix/$deps_dir/lib/$use_sdk"
+ platform_ldflags="-L$prefix/$deps_dir/lib/android-$use_ndk_api"
platform_cxxflags="$platform_cflags -frtti"
- platform_includes="-I$prefix/$deps_dir/include/$use_sdk"
+ platform_includes="-I$prefix/$deps_dir/include/android-$use_ndk_api"
platform_os="android"
#android builds are always cross
cross_compiling="yes"
@@ -179,15 +185,16 @@ case $host in
use_cpu="arm64-v8a"
fi
use_sdk="${use_sdk:-android-21}"
- deps_dir="$use_host-$use_sdk-$build_type"
+ use_ndk_api="${use_ndk_api:-21}"
+ deps_dir="$use_host-$use_ndk_api-$build_type"
platform_cflags="-DANDROID -fexceptions -fPIC -DPIC -D_GLIBCXX_USE_C99_MATH_TR1"
optimize_flags="-Os"
if test "x$use_cpu" = "xarm64-v8a"; then
platform_cflags+=" -march=armv8-a -mtune=cortex-a53"
fi
- platform_ldflags="-L$prefix/$deps_dir/lib/$use_sdk"
+ platform_ldflags="-L$prefix/$deps_dir/lib/android-$use_ndk_api"
platform_cxxflags="$platform_cflags -frtti"
- platform_includes="-I$prefix/$deps_dir/include/$use_sdk"
+ platform_includes="-I$prefix/$deps_dir/include/android-$use_ndk_api"
platform_os="android"
#android builds are always cross
cross_compiling="yes"
@@ -197,12 +204,13 @@ case $host in
use_cpu=$host_cpu
fi
use_sdk="${use_sdk:-android-21}"
- deps_dir="$use_host-$use_sdk-$build_type"
+ use_ndk_api="${use_ndk_api:-21}"
+ deps_dir="$use_host-$use_ndk_api-$build_type"
platform_cflags="-DANDROID -fexceptions -fPIC -DPIC -D_GLIBCXX_USE_C99_MATH_TR1"
optimize_flags="-Os"
- platform_ldflags="-L$prefix/$deps_dir/lib/$use_sdk"
+ platform_ldflags="-L$prefix/$deps_dir/lib/android-$use_ndk_api"
platform_cxxflags="$platform_cflags -frtti"
- platform_includes="-I$prefix/$deps_dir/include/$use_sdk"
+ platform_includes="-I$prefix/$deps_dir/include/android-$use_ndk_api"
platform_os="android"
#android builds are always cross
cross_compiling="yes"
@@ -524,12 +532,12 @@ if test -z $use_tarballs; then
fi
if test "$platform_os" == "android"; then
- if test -z $use_ndk; then
+ if test -z $use_ndk_path; then
AC_MSG_ERROR("NDK path is required for android")
fi
- if ([! test -f "$use_ndk/source.properties"] && [! test -f "$use_ndk/RELEASE.TXT"]) ; then
- AC_MSG_ERROR("$use_ndk is not an NDK directory")
+ if ([! test -f "$use_ndk_path/source.properties"] && [! test -f "$use_ndk_path/RELEASE.TXT"]) ; then
+ AC_MSG_ERROR("$use_ndk_path is not an NDK directory")
fi
if test -z $use_sdk_path; then
@@ -540,7 +548,7 @@ if test "$platform_os" == "android"; then
AC_MSG_ERROR(verify sdk path)
fi
- if [ ! test -f $use_ndk/sources/android/native_app_glue/android_native_app_glue.h ]; then
+ if [ ! test -f $use_ndk_path/sources/android/native_app_glue/android_native_app_glue.h ]; then
AC_MSG_ERROR(verify ndk path)
fi
@@ -639,8 +647,9 @@ fi
if test "$platform_os" == "android"; then
echo -e
AC_SUBST(use_sdk_path)
- AC_SUBST(use_ndk)
+ AC_SUBST(use_ndk_path)
AC_SUBST(use_sdk)
+ AC_SUBST(use_ndk_api)
AC_SUBST(build_tools_path)
fi
diff --git a/tools/depends/target/Toolchain.cmake.in b/tools/depends/target/Toolchain.cmake.in
index 4aab3f55d5..8946094ae6 100644
--- a/tools/depends/target/Toolchain.cmake.in
+++ b/tools/depends/target/Toolchain.cmake.in
@@ -79,7 +79,7 @@ endif()
# add Android directories and tools
if(CORE_SYSTEM_NAME STREQUAL android)
- set(NDKROOT @use_ndk@)
+ set(NDKROOT @use_ndk_path@)
set(SDKROOT @use_sdk_path@)
set(SDK_PLATFORM @use_sdk@)
string(REPLACE ":" ";" SDK_BUILDTOOLS_PATH "@build_tools_path@")