[compiler-rt] 77e3a2e - [ubsan] Link shared runtime library with a version script.
Evgenii Stepanov via llvm-commits
llvm-commits at lists.llvm.org
Thu Apr 16 17:34:08 PDT 2020
Author: Evgenii Stepanov
Date: 2020-04-16T17:33:54-07:00
New Revision: 77e3a2e0fe02e8bdeb8276c08c95290d9e78feba
URL: https://github.com/llvm/llvm-project/commit/77e3a2e0fe02e8bdeb8276c08c95290d9e78feba
DIFF: https://github.com/llvm/llvm-project/commit/77e3a2e0fe02e8bdeb8276c08c95290d9e78feba.diff
LOG: [ubsan] Link shared runtime library with a version script.
Summary:
Do not reexport libgcc.a symbols and random sanitizer internal symbols
by applying a version script to the shared library build.
This fixes unwinder conflicts on Android that are created by reexporting
the unwinder interface from libgcc_real.a. The same is already done in
asan and hwasan.
Reviewers: vitalybuka, srhines
Subscribers: mgorny, #sanitizers, llvm-commits
Tags: #sanitizers
Differential Revision: https://reviews.llvm.org/D78325
Added:
Modified:
compiler-rt/lib/ubsan/CMakeLists.txt
Removed:
################################################################################
diff --git a/compiler-rt/lib/ubsan/CMakeLists.txt b/compiler-rt/lib/ubsan/CMakeLists.txt
index 378cbac6a31a..164f7aadcc0c 100644
--- a/compiler-rt/lib/ubsan/CMakeLists.txt
+++ b/compiler-rt/lib/ubsan/CMakeLists.txt
@@ -199,21 +199,41 @@ else()
PARENT_TARGET ubsan)
if (FUCHSIA OR UNIX)
- add_compiler_rt_runtime(clang_rt.ubsan_standalone
- SHARED
+ file(WRITE ${CMAKE_CURRENT_BINARY_DIR}/dummy.cpp "")
+ add_compiler_rt_object_libraries(RTUbsan_dynamic_version_script_dummy
ARCHS ${UBSAN_SUPPORTED_ARCH}
- OBJECT_LIBS RTSanitizerCommon
- RTSanitizerCommonLibc
- RTSanitizerCommonCoverage
- RTSanitizerCommonSymbolizer
- RTUbsan
- RTUbsan_cxx
- RTUbsan_standalone
- RTInterception
- CFLAGS ${UBSAN_CFLAGS}
- LINK_FLAGS ${SANITIZER_COMMON_LINK_FLAGS}
- LINK_LIBS ${UBSAN_DYNAMIC_LIBS}
- PARENT_TARGET ubsan)
+ SOURCES ${CMAKE_CURRENT_BINARY_DIR}/dummy.cpp
+ CFLAGS ${UBSAN_CFLAGS})
+
+ foreach(arch ${UBSAN_SUPPORTED_ARCH})
+ add_sanitizer_rt_version_list(clang_rt.ubsan_standalone-dynamic-${arch}
+ LIBS clang_rt.ubsan_standalone-${arch}
+ clang_rt.ubsan_standalone_cxx-${arch}
+ EXTRA ubsan.syms.extra)
+ set(VERSION_SCRIPT_FLAG
+ -Wl,--version-script,${CMAKE_CURRENT_BINARY_DIR}/clang_rt.ubsan_standalone-dynamic-${arch}.vers)
+ set_property(SOURCE
+ ${CMAKE_CURRENT_BINARY_DIR}/dummy.cpp
+ APPEND PROPERTY
+ OBJECT_DEPENDS ${CMAKE_CURRENT_BINARY_DIR}/clang_rt.ubsan_standalone-dynamic-${arch}.vers)
+
+ add_compiler_rt_runtime(clang_rt.ubsan_standalone
+ SHARED
+ ARCHS ${arch}
+ OBJECT_LIBS RTSanitizerCommon
+ RTSanitizerCommonLibc
+ RTSanitizerCommonCoverage
+ RTSanitizerCommonSymbolizer
+ RTUbsan
+ RTUbsan_cxx
+ RTUbsan_standalone
+ RTInterception
+ RTUbsan_dynamic_version_script_dummy
+ CFLAGS ${UBSAN_CFLAGS}
+ LINK_FLAGS ${UBSAN_LINK_FLAGS} ${VERSION_SCRIPT_FLAG}
+ LINK_LIBS ${UBSAN_DYNAMIC_LIBS}
+ PARENT_TARGET ubsan)
+ endforeach()
set(ARCHS_FOR_SYMBOLS ${UBSAN_SUPPORTED_ARCH})
list(REMOVE_ITEM ARCHS_FOR_SYMBOLS i386)
More information about the llvm-commits
mailing list