From 653109e677fd92a230afaa87d0841818e27c2699 Mon Sep 17 00:00:00 2001 From: Petr Hosek Date: Fri, 27 Dec 2024 19:08:48 +0000 Subject: [PATCH 1/2] [TYSan][CMake] CMake build fixes TYSan CMake build follows patterns used by other sanitizers, but there's also a number of issues, like referring to undefined variables, which breaks the build in some cases (such as cross-compiling). This change addresses the issues. --- compiler-rt/lib/tysan/CMakeLists.txt | 28 +++++++++++++++++++++------- 1 file changed, 21 insertions(+), 7 deletions(-) diff --git a/compiler-rt/lib/tysan/CMakeLists.txt b/compiler-rt/lib/tysan/CMakeLists.txt index 859b67928f004..a041ba5ee5937 100644 --- a/compiler-rt/lib/tysan/CMakeLists.txt +++ b/compiler-rt/lib/tysan/CMakeLists.txt @@ -3,12 +3,25 @@ include_directories(..) # Runtime library sources and build flags. set(TYSAN_SOURCES tysan.cpp - tysan_interceptors.cpp) + tysan_interceptors.cpp + ) + +SET(TYSAN_HEADERS + tysan_flags.inc + ) + set(TYSAN_COMMON_CFLAGS ${SANITIZER_COMMON_CFLAGS}) append_rtti_flag(OFF TYSAN_COMMON_CFLAGS) # Prevent clang from generating libc calls. append_list_if(COMPILER_RT_HAS_FFREESTANDING_FLAG -ffreestanding TYSAN_COMMON_CFLAGS) +set(TYSAN_COMMON_DEFINITIONS "") +set(TYSAN_DYNAMIC_DEFINITIONS ${TYSAN_COMMON_DEFINITIONS}) + +set(TYSAN_DYNAMIC_CFLAGS ${TYSAN_COMMON_CFLAGS}) + +# Compile TYSan sources into an object library. + add_compiler_rt_object_libraries(RTTysan_dynamic OS ${SANITIZER_COMMON_SUPPORTED_OS} ARCHS ${TYSAN_SUPPORTED_ARCH} @@ -47,17 +60,18 @@ if(APPLE) DEFS ${TYSAN_COMMON_DEFINITIONS} PARENT_TARGET tysan) else() + set(TYSAN_CFLAGS ${TYSAN_COMMON_CFLAGS}) + append_list_if(COMPILER_RT_HAS_FPIE_FLAG -fPIE TYSAN_CFLAGS) + foreach(arch ${TYSAN_SUPPORTED_ARCH}) - set(TYSAN_CFLAGS ${TYSAN_COMMON_CFLAGS}) - append_list_if(COMPILER_RT_HAS_FPIE_FLAG -fPIE TYSAN_CFLAGS) add_compiler_rt_runtime(clang_rt.tysan STATIC ARCHS ${arch} SOURCES ${TYSAN_SOURCES} - $ - $ - $ - $ + OBJECT_LIBS RTInterception + RTSanitizerCommon + RTSanitizerCommonLibc + RTSanitizerCommonSymbolizer CFLAGS ${TYSAN_CFLAGS} PARENT_TARGET tysan) endforeach() From bc154bb73e133d88e4f39bbf2934ed4747c7a6a9 Mon Sep 17 00:00:00 2001 From: Petr Hosek Date: Fri, 27 Dec 2024 19:16:16 +0000 Subject: [PATCH 2/2] More fixes --- compiler-rt/lib/tysan/CMakeLists.txt | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/compiler-rt/lib/tysan/CMakeLists.txt b/compiler-rt/lib/tysan/CMakeLists.txt index a041ba5ee5937..7d13ae3963919 100644 --- a/compiler-rt/lib/tysan/CMakeLists.txt +++ b/compiler-rt/lib/tysan/CMakeLists.txt @@ -7,18 +7,19 @@ set(TYSAN_SOURCES ) SET(TYSAN_HEADERS + tysan.h tysan_flags.inc + tysan_platform.h ) set(TYSAN_COMMON_CFLAGS ${SANITIZER_COMMON_CFLAGS}) append_rtti_flag(OFF TYSAN_COMMON_CFLAGS) # Prevent clang from generating libc calls. append_list_if(COMPILER_RT_HAS_FFREESTANDING_FLAG -ffreestanding TYSAN_COMMON_CFLAGS) +set(TYSAN_DYNAMIC_CFLAGS ${TYSAN_COMMON_CFLAGS}) set(TYSAN_COMMON_DEFINITIONS "") -set(TYSAN_DYNAMIC_DEFINITIONS ${TYSAN_COMMON_DEFINITIONS}) - -set(TYSAN_DYNAMIC_CFLAGS ${TYSAN_COMMON_CFLAGS}) +set(TYSAN_DYNAMIC_DEFINITIONS ${TYSAN_COMMON_DEFINITIONS} TYSAN_DYNAMIC=1) # Compile TYSan sources into an object library.