|
| 1 | +Follow Google's BuildSystemMaintainers doc to support future NDK releases. |
| 2 | + |
| 3 | +Upstream commit: |
| 4 | + - Qt 5.14: 9b14950ff600a4ce5a8698b67ab38907c50417f1 |
| 5 | + |
| 6 | +--- old/qtbase/mkspecs/android-clang/qmake.conf |
| 7 | ++++ new/qtbase/mkspecs/android-clang/qmake.conf |
| 8 | +@@ -14,43 +14,29 @@ |
| 9 | + QMAKE_CC = $$NDK_LLVM_PATH/bin/clang |
| 10 | + QMAKE_CXX = $$NDK_LLVM_PATH/bin/clang++ |
| 11 | + |
| 12 | ++# Follow https://android.googlesource.com/platform/ndk/+/ndk-release-r20/docs/BuildSystemMaintainers.md |
| 13 | ++ |
| 14 | + equals(ANDROID_TARGET_ARCH, armeabi-v7a): \ |
| 15 | +- QMAKE_CFLAGS += -target armv7-none-linux-androideabi |
| 16 | +-else: equals(ANDROID_TARGET_ARCH, armeabi): \ |
| 17 | +- QMAKE_CFLAGS += -target armv5te-none-linux-androideabi |
| 18 | ++ QMAKE_CFLAGS = -target armv7a-linux-androideabi$$replace(ANDROID_PLATFORM, "android-", "") |
| 19 | + else: equals(ANDROID_TARGET_ARCH, arm64-v8a): \ |
| 20 | +- QMAKE_CFLAGS += -target aarch64-none-linux-android |
| 21 | ++ QMAKE_CFLAGS = -target aarch64-linux-android$$replace(ANDROID_PLATFORM, "android-", "") |
| 22 | + else: equals(ANDROID_TARGET_ARCH, x86): \ |
| 23 | +- QMAKE_CFLAGS += -target i686-none-linux-android -mstackrealign |
| 24 | ++ QMAKE_CFLAGS = -target i686-linux-android$$replace(ANDROID_PLATFORM, "android-", "") -mstackrealign |
| 25 | + else: equals(ANDROID_TARGET_ARCH, x86_64): \ |
| 26 | +- QMAKE_CFLAGS += -target x86_64-none-linux-android |
| 27 | +-else: equals(ANDROID_TARGET_ARCH, mips): \ |
| 28 | +- QMAKE_CFLAGS += -target mipsel-none-linux-android |
| 29 | +-else: equals(ANDROID_TARGET_ARCH, mips64): \ |
| 30 | +- QMAKE_CFLAGS += -target mips64el-none-linux-android |
| 31 | +- |
| 32 | +-QMAKE_CFLAGS += -gcc-toolchain $$NDK_TOOLCHAIN_PATH -fno-limit-debug-info |
| 33 | +- |
| 34 | +-QMAKE_LINK = $$QMAKE_CXX $$QMAKE_CFLAGS -Wl,--exclude-libs,libgcc.a -Wl,--exclude-libs,libatomic.a -nostdlib++ |
| 35 | +-equals(ANDROID_TARGET_ARCH, armeabi-v7a): QMAKE_LINK += -Wl,--exclude-libs,libunwind.a |
| 36 | +- |
| 37 | +-QMAKE_CFLAGS += -DANDROID_HAS_WSTRING --sysroot=$$NDK_ROOT/sysroot \ |
| 38 | +- -isystem $$NDK_ROOT/sysroot/usr/include/$$NDK_TOOLS_PREFIX \ |
| 39 | +- -isystem $$NDK_ROOT/sources/cxx-stl/llvm-libc++/include \ |
| 40 | +- -isystem $$NDK_ROOT/sources/android/support/include \ |
| 41 | +- -isystem $$NDK_ROOT/sources/cxx-stl/llvm-libc++abi/include |
| 42 | ++ QMAKE_CFLAGS = -target x86_64-linux-android$$replace(ANDROID_PLATFORM, "android-", "") |
| 43 | + |
| 44 | +-ANDROID_SOURCES_CXX_STL_LIBDIR = $$NDK_ROOT/sources/cxx-stl/llvm-libc++/libs/$$ANDROID_TARGET_ARCH |
| 45 | ++QMAKE_CFLAGS += -fno-limit-debug-info |
| 46 | + |
| 47 | +-ANDROID_STDCPP_PATH = $$ANDROID_SOURCES_CXX_STL_LIBDIR/libc++_shared.so |
| 48 | ++QMAKE_LINK = $$QMAKE_CXX $$QMAKE_CFLAGS |
| 49 | + |
| 50 | +-ANDROID_USE_LLVM = true |
| 51 | ++ANDROID_STDCPP_PATH = $$NDK_LLVM_PATH/sysroot/usr/lib/$$NDK_TOOLS_PREFIX/libc++_shared.so |
| 52 | + |
| 53 | +-exists($$ANDROID_SOURCES_CXX_STL_LIBDIR/libc++.so): \ |
| 54 | +- ANDROID_CXX_STL_LIBS = -lc++ |
| 55 | +-else: \ |
| 56 | +- ANDROID_CXX_STL_LIBS = $$ANDROID_SOURCES_CXX_STL_LIBDIR/libc++.so.$$replace(ANDROID_PLATFORM, "android-", "") |
| 57 | ++ANDROID_USE_LLVM = true |
| 58 | + |
| 59 | +-QMAKE_CFLAGS_OPTIMIZE_SIZE = -Oz |
| 60 | ++QMAKE_CFLAGS_OPTIMIZE_SIZE = -Oz |
| 61 | ++QMAKE_LIBDIR_POST = |
| 62 | ++QMAKE_LFLAGS = |
| 63 | ++QMAKE_LIBS_PRIVATE = |
| 64 | ++ANDROID_CXX_STL_LIBS = |
| 65 | + |
| 66 | + include(../common/android-base-tail.conf) |
| 67 | + |
| 68 | +--- old/qtbase/mkspecs/common/android-base-head.conf |
| 69 | ++++ new/qtbase/mkspecs/common/android-base-head.conf |
| 70 | +@@ -64,7 +58,6 @@ |
| 71 | + } |
| 72 | + |
| 73 | + CONFIG += $$ANDROID_PLATFORM |
| 74 | +-QMAKE_CFLAGS = -D__ANDROID_API__=$$replace(ANDROID_PLATFORM, "android-", "") |
| 75 | + |
| 76 | + ANDROID_PLATFORM_ROOT_PATH = $$NDK_ROOT/platforms/$$ANDROID_PLATFORM/arch-$$ANDROID_ARCHITECTURE/ |
| 77 | + |
| 78 | +--- old/qtbase/mkspecs/common/android-base-tail.conf |
| 79 | ++++ new/qtbase/mkspecs/common/android-base-tail.conf |
| 80 | +@@ -6,22 +6,17 @@ |
| 81 | + QMAKE_CFLAGS += -fstack-protector-strong -DANDROID |
| 82 | + |
| 83 | + equals(ANDROID_TARGET_ARCH, armeabi-v7a): \ |
| 84 | +- QMAKE_CFLAGS += -march=armv7-a -mfloat-abi=softfp -mfpu=vfp -fno-builtin-memmove |
| 85 | ++ QMAKE_CFLAGS += -march=armv7-a -mfloat-abi=softfp -mfpu=vfp |
| 86 | + else: equals(ANDROID_TARGET_ARCH, armeabi): \ |
| 87 | +- QMAKE_CFLAGS += -march=armv5te -mtune=xscale -msoft-float -fno-builtin-memmove |
| 88 | +-# -fno-builtin-memmove is used to workaround https://code.google.com/p/android/issues/detail?id=81692 |
| 89 | ++ QMAKE_CFLAGS += -march=armv5te -mtune=xscale -msoft-float |
| 90 | + |
| 91 | + QMAKE_CFLAGS_WARN_ON = -Wall -W |
| 92 | + QMAKE_CFLAGS_WARN_OFF = |
| 93 | + equals(ANDROID_TARGET_ARCH, armeabi-v7a) | equals(ANDROID_TARGET_ARCH, armeabi) { |
| 94 | + CONFIG += optimize_size |
| 95 | + QMAKE_CFLAGS_DEBUG = -g -marm -O0 |
| 96 | +- equals(ANDROID_TARGET_ARCH, armeabi):if(equals(NDK_TOOLCHAIN_VERSION, 4.8)|equals(NDK_TOOLCHAIN_VERSION, 4.9)) { |
| 97 | +- DEFINES += QT_OS_ANDROID_GCC_48_WORKAROUND |
| 98 | +- } else { |
| 99 | +- QMAKE_CFLAGS_RELEASE += -mthumb |
| 100 | +- QMAKE_CFLAGS_RELEASE_WITH_DEBUGINFO += -mthumb |
| 101 | +- } |
| 102 | ++ QMAKE_CFLAGS_RELEASE += -mthumb |
| 103 | ++ QMAKE_CFLAGS_RELEASE_WITH_DEBUGINFO += -mthumb |
| 104 | + } |
| 105 | + |
| 106 | + QMAKE_CFLAGS_SHLIB = -fPIC |
| 107 | +@@ -61,15 +56,12 @@ |
| 108 | + QMAKE_RANLIB = $${CROSS_COMPILE}ranlib |
| 109 | + |
| 110 | + QMAKE_INCDIR_POST = |
| 111 | +-QMAKE_LIBDIR_POST = $$ANDROID_SOURCES_CXX_STL_LIBDIR |
| 112 | + QMAKE_INCDIR_X11 = |
| 113 | + QMAKE_LIBDIR_X11 = |
| 114 | + QMAKE_INCDIR_OPENGL = |
| 115 | + QMAKE_LIBDIR_OPENGL = |
| 116 | + |
| 117 | + QMAKE_LINK_SHLIB = $$QMAKE_LINK |
| 118 | +-QMAKE_LFLAGS = --sysroot=$$ANDROID_PLATFORM_ROOT_PATH |
| 119 | +-equals(ANDROID_TARGET_ARCH, x86_64) QMAKE_LFLAGS += -L$$ANDROID_PLATFORM_ROOT_PATH/usr/lib64 |
| 120 | + QMAKE_LFLAGS_APP = -Wl,--no-undefined -Wl,-z,noexecstack -shared |
| 121 | + QMAKE_LFLAGS_SHLIB = -Wl,--no-undefined -Wl,-z,noexecstack -shared |
| 122 | + QMAKE_LFLAGS_PLUGIN = $$QMAKE_LFLAGS_SHLIB |
0 commit comments