|
|
|
@ -280,6 +280,9 @@ |
|
|
|
|
# - November 2012 |
|
|
|
|
# [+] updated for NDK r8c |
|
|
|
|
# [+] added support for clang compiler |
|
|
|
|
# - December 2012 |
|
|
|
|
# [~] fixed ccache full path search |
|
|
|
|
# [+] updated for NDK r8d |
|
|
|
|
# ------------------------------------------------------------------------------ |
|
|
|
|
|
|
|
|
|
cmake_minimum_required( VERSION 2.6.3 ) |
|
|
|
@ -302,7 +305,7 @@ set( CMAKE_SYSTEM_VERSION 1 ) |
|
|
|
|
# rpath makes low sence for Android |
|
|
|
|
set( CMAKE_SKIP_RPATH TRUE CACHE BOOL "If set, runtime paths are not added when using shared libraries." ) |
|
|
|
|
|
|
|
|
|
set( ANDROID_SUPPORTED_NDK_VERSIONS ${ANDROID_EXTRA_NDK_VERSIONS} -r8c -r8b -r8 -r7c -r7b -r7 -r6b -r6 -r5c -r5b -r5 "" ) |
|
|
|
|
set( ANDROID_SUPPORTED_NDK_VERSIONS ${ANDROID_EXTRA_NDK_VERSIONS} -r8d -r8c -r8b -r8 -r7c -r7b -r7 -r6b -r6 -r5c -r5b -r5 "" ) |
|
|
|
|
if(NOT DEFINED ANDROID_NDK_SEARCH_PATHS) |
|
|
|
|
if( CMAKE_HOST_WIN32 ) |
|
|
|
|
file( TO_CMAKE_PATH "$ENV{PROGRAMFILES}" ANDROID_NDK_SEARCH_PATHS ) |
|
|
|
@ -962,7 +965,11 @@ if( BUILD_WITH_ANDROID_NDK ) |
|
|
|
|
set( ANDROID_STL_INCLUDE_DIRS "${ANDROID_NDK}/sources/cxx-stl/gabi++/include" ) |
|
|
|
|
set( __libstl "${ANDROID_NDK}/sources/cxx-stl/gabi++/libs/${ANDROID_NDK_ABI_NAME}/libgabi++_static.a" ) |
|
|
|
|
elseif( ANDROID_STL MATCHES "stlport" ) |
|
|
|
|
set( ANDROID_EXCEPTIONS OFF ) |
|
|
|
|
if( NOT ANDROID_NDK_RELEASE STRLESS "r8d" ) |
|
|
|
|
set( ANDROID_EXCEPTIONS ON ) |
|
|
|
|
else() |
|
|
|
|
set( ANDROID_EXCEPTIONS OFF ) |
|
|
|
|
endif() |
|
|
|
|
if( ANDROID_NDK_RELEASE STRLESS "r7" ) |
|
|
|
|
set( ANDROID_RTTI OFF ) |
|
|
|
|
else() |
|
|
|
@ -974,7 +981,13 @@ if( BUILD_WITH_ANDROID_NDK ) |
|
|
|
|
set( ANDROID_EXCEPTIONS ON ) |
|
|
|
|
set( ANDROID_RTTI ON ) |
|
|
|
|
if( EXISTS "${ANDROID_NDK}/sources/cxx-stl/gnu-libstdc++/${ANDROID_COMPILER_VERSION}" ) |
|
|
|
|
set( __libstl "${ANDROID_NDK}/sources/cxx-stl/gnu-libstdc++/${ANDROID_COMPILER_VERSION}" ) |
|
|
|
|
if( ARMEABI_V7A AND ANDROID_COMPILER_VERSION VERSION_EQUAL "4.7" AND ANDROID_NDK_RELEASE STREQUAL "r8d" ) |
|
|
|
|
# gnustl binary for 4.7 compiler is buggy :( |
|
|
|
|
# TODO: look for right fix |
|
|
|
|
set( __libstl "${ANDROID_NDK}/sources/cxx-stl/gnu-libstdc++/4.6" ) |
|
|
|
|
else() |
|
|
|
|
set( __libstl "${ANDROID_NDK}/sources/cxx-stl/gnu-libstdc++/${ANDROID_COMPILER_VERSION}" ) |
|
|
|
|
endif() |
|
|
|
|
else() |
|
|
|
|
set( __libstl "${ANDROID_NDK}/sources/cxx-stl/gnu-libstdc++" ) |
|
|
|
|
endif() |
|
|
|
@ -1263,7 +1276,7 @@ endif() |
|
|
|
|
if( ANDROID_COMPILER_VERSION VERSION_EQUAL "4.6" ) |
|
|
|
|
if( ANDROID_GOLD_LINKER AND (CMAKE_HOST_UNIX OR ANDROID_NDK_RELEASE STRGREATER "r8b") AND (ARMEABI OR ARMEABI_V7A OR X86) ) |
|
|
|
|
set( ANDROID_LINKER_FLAGS "${ANDROID_LINKER_FLAGS} -fuse-ld=gold" ) |
|
|
|
|
elseif( ANDROID_NDK_RELEASE STREQUAL "r8c") |
|
|
|
|
elseif( ANDROID_NDK_RELEASE STRGREATER "r8b") |
|
|
|
|
set( ANDROID_LINKER_FLAGS "${ANDROID_LINKER_FLAGS} -fuse-ld=bfd" ) |
|
|
|
|
elseif( ANDROID_NDK_RELEASE STREQUAL "r8b" AND ARMEABI AND NOT _CMAKE_IN_TRY_COMPILE ) |
|
|
|
|
message( WARNING "The default bfd linker from arm GCC 4.6 toolchain can fail with 'unresolvable R_ARM_THM_CALL relocation' error message. See https://code.google.com/p/android/issues/detail?id=35342 |
|
|
|
@ -1523,7 +1536,7 @@ endif() |
|
|
|
|
# BUILD_WITH_STANDALONE_TOOLCHAIN : TRUE if standalone toolchain is used |
|
|
|
|
# ANDROID_NDK_HOST_SYSTEM_NAME : "windows", "linux-x86" or "darwin-x86" depending on host platform |
|
|
|
|
# ANDROID_NDK_ABI_NAME : "armeabi", "armeabi-v7a", "x86" or "mips" depending on ANDROID_ABI |
|
|
|
|
# ANDROID_NDK_RELEASE : one of r5, r5b, r5c, r6, r6b, r7, r7b, r7c, r8, r8b, r8c; set only for NDK |
|
|
|
|
# ANDROID_NDK_RELEASE : one of r5, r5b, r5c, r6, r6b, r7, r7b, r7c, r8, r8b, r8c, r8d; set only for NDK |
|
|
|
|
# ANDROID_ARCH_NAME : "arm" or "x86" or "mips" depending on ANDROID_ABI |
|
|
|
|
# ANDROID_SYSROOT : path to the compiler sysroot |
|
|
|
|
# TOOL_OS_SUFFIX : "" or ".exe" depending on host platform |
|
|
|
|