diff --git a/compiler-rt/lib/tsan/rtl/tsan_interface.h b/compiler-rt/lib/tsan/rtl/tsan_interface.h --- a/compiler-rt/lib/tsan/rtl/tsan_interface.h +++ b/compiler-rt/lib/tsan/rtl/tsan_interface.h @@ -417,12 +417,6 @@ void __tsan_go_atomic64_compare_exchange(ThreadState *thr, uptr cpc, uptr pc, u8 *a); -SANITIZER_INTERFACE_ATTRIBUTE -void __tsan_on_initialize(); - -SANITIZER_INTERFACE_ATTRIBUTE -int __tsan_on_finalize(int failed); - } // extern "C" } // namespace __tsan diff --git a/compiler-rt/lib/tsan/rtl/tsan_platform_posix.cpp b/compiler-rt/lib/tsan/rtl/tsan_platform_posix.cpp --- a/compiler-rt/lib/tsan/rtl/tsan_platform_posix.cpp +++ b/compiler-rt/lib/tsan/rtl/tsan_platform_posix.cpp @@ -14,12 +14,14 @@ #include "sanitizer_common/sanitizer_platform.h" #if SANITIZER_POSIX -#include "sanitizer_common/sanitizer_common.h" -#include "sanitizer_common/sanitizer_errno.h" -#include "sanitizer_common/sanitizer_libc.h" -#include "sanitizer_common/sanitizer_procmaps.h" -#include "tsan_platform.h" -#include "tsan_rtl.h" +# include + +# include "sanitizer_common/sanitizer_common.h" +# include "sanitizer_common/sanitizer_errno.h" +# include "sanitizer_common/sanitizer_libc.h" +# include "sanitizer_common/sanitizer_procmaps.h" +# include "tsan_platform.h" +# include "tsan_rtl.h" namespace __tsan { @@ -70,6 +72,9 @@ meta, meta + meta_size, meta_size >> 30); InitializeShadowMemoryPlatform(); + + on_initialize = dlsym(RTLD_DEFAULT, "__tsan_on_initialize"); + on_finalize = dlsym(RTLD_DEFAULT, "__tsan_on_finalize"); } static bool TryProtectRange(uptr beg, uptr end) { diff --git a/compiler-rt/lib/tsan/rtl/tsan_rtl.h b/compiler-rt/lib/tsan/rtl/tsan_rtl.h --- a/compiler-rt/lib/tsan/rtl/tsan_rtl.h +++ b/compiler-rt/lib/tsan/rtl/tsan_rtl.h @@ -985,6 +985,11 @@ } // namespace v3 +#if !SANITIZER_GO +extern void *on_initialize; +extern void *on_finalize; +#endif + } // namespace __tsan #endif // TSAN_RTL_H diff --git a/compiler-rt/lib/tsan/rtl/tsan_rtl.cpp b/compiler-rt/lib/tsan/rtl/tsan_rtl.cpp --- a/compiler-rt/lib/tsan/rtl/tsan_rtl.cpp +++ b/compiler-rt/lib/tsan/rtl/tsan_rtl.cpp @@ -36,6 +36,11 @@ namespace __tsan { +#if !SANITIZER_GO +void *on_initialize; +void *on_finalize; +#endif + #if !SANITIZER_GO && !SANITIZER_MAC __attribute__((tls_model("initial-exec"))) THREADLOCAL char cur_thread_placeholder[sizeof(ThreadState)] ALIGNED(64); @@ -52,17 +57,16 @@ SANITIZER_WEAK_CXX_DEFAULT_IMPL bool OnFinalize(bool failed) { #if !SANITIZER_GO - if (auto *ptr = dlsym(RTLD_DEFAULT, "__tsan_on_finalize")) - return reinterpret_cast(ptr)(failed); + if (on_finalize) + return reinterpret_cast(on_finalize)(failed); #endif return failed; } SANITIZER_WEAK_CXX_DEFAULT_IMPL void OnInitialize() { #if !SANITIZER_GO - if (auto *ptr = dlsym(RTLD_DEFAULT, "__tsan_on_initialize")) { - return reinterpret_cast(ptr)(); - } + if (on_initialize) + reinterpret_cast(on_initialize)(); #endif } #endif diff --git a/compiler-rt/test/tsan/signal_exit.cpp b/compiler-rt/test/tsan/signal_exit.cpp new file mode 100644 --- /dev/null +++ b/compiler-rt/test/tsan/signal_exit.cpp @@ -0,0 +1,23 @@ +// RUN: %clang_tsan -O1 %s -o %t && %run %t 2>&1 | FileCheck %s +#include "test.h" +#include +#include + +static void handler(int, siginfo_t *, void *) { + write(2, "SIGNAL\n", 7); + // CHECK: SIGNAL + _exit(0); + // CHECK-NOT: ThreadSanitizer: signal-unsafe call +} + +int main() { + struct sigaction act = {}; + act.sa_sigaction = &handler; + act.sa_flags = SA_SIGINFO; + sigaction(SIGPROF, &act, 0); + kill(getpid(), SIGPROF); + sleep(1); // let the signal handler run + fprintf(stderr, "DONE\n"); + // CHECK-NOT: DONE + return 0; +}