From 3239d4af408b7e24e29ee8d17a400fd4919714c8 Mon Sep 17 00:00:00 2001 From: Scott McKay Date: Thu, 12 Sep 2024 19:22:40 +1000 Subject: [PATCH 1/2] Enable 16KB page size support when building shared libraries on Android --- cmake/adjust_global_compile_flags.cmake | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/cmake/adjust_global_compile_flags.cmake b/cmake/adjust_global_compile_flags.cmake index 6eb784a4063ed..870907f46d778 100644 --- a/cmake/adjust_global_compile_flags.cmake +++ b/cmake/adjust_global_compile_flags.cmake @@ -1,11 +1,15 @@ # work around Android NDK bug which doesn't include -O flag for Release configuration # https://github.com/android/ndk/issues/1740 # TODO: remove this when the NDK version(s) we support get fixed -if (CMAKE_SYSTEM_NAME STREQUAL "Android") +if (Android) # NB: attempting to match the effects of this fix: https://android-review.googlesource.com/c/platform/ndk/+/2168845 string(APPEND CMAKE_C_FLAGS_RELEASE " -O3") string(APPEND CMAKE_CXX_FLAGS_RELEASE " -O3") string(APPEND CMAKE_ASM_FLAGS_RELEASE " -O3") + + # Build shared libraries with support for 16 KB ELF alignment + # https://source.android.com/docs/core/architecture/16kb-page-size/16kb#build-lib-16kb-alignment + set(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} -Wl,-z,max-page-size=16384") endif() # Suggested by https://gitlab.kitware.com/cmake/cmake/-/issues/20132 From 66269cbcfae192d9b9bbb617629f089a28fb4da4 Mon Sep 17 00:00:00 2001 From: Scott McKay Date: Thu, 12 Sep 2024 19:23:59 +1000 Subject: [PATCH 2/2] Fix casing --- cmake/adjust_global_compile_flags.cmake | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/cmake/adjust_global_compile_flags.cmake b/cmake/adjust_global_compile_flags.cmake index 870907f46d778..c04d67ea4ce3f 100644 --- a/cmake/adjust_global_compile_flags.cmake +++ b/cmake/adjust_global_compile_flags.cmake @@ -1,7 +1,7 @@ # work around Android NDK bug which doesn't include -O flag for Release configuration # https://github.com/android/ndk/issues/1740 # TODO: remove this when the NDK version(s) we support get fixed -if (Android) +if (ANDROID) # NB: attempting to match the effects of this fix: https://android-review.googlesource.com/c/platform/ndk/+/2168845 string(APPEND CMAKE_C_FLAGS_RELEASE " -O3") string(APPEND CMAKE_CXX_FLAGS_RELEASE " -O3")