diff --git a/port/lang.h b/port/lang.h index eabe44b69..4a601d41c 100644 --- a/port/lang.h +++ b/port/lang.h @@ -15,6 +15,8 @@ #endif #endif +// ASAN (Address sanitizer) + #if defined(__clang__) #if defined(__has_feature) #if __has_feature(address_sanitizer) @@ -43,3 +45,18 @@ #else #define STATIC_AVOID_DESTRUCTION(Type, name) static Type& name = *new Type #endif + +// TSAN (Thread sanitizer) + +// For simplicity, standardize on the GCC define +#if defined(__clang__) +#if defined(__has_feature) && __has_feature(thread_sanitizer) +#define __SANITIZE_THREAD__ 1 +#endif // __has_feature(thread_sanitizer) +#endif // __clang__ + +#ifdef __SANITIZE_THREAD__ +#define TSAN_SUPPRESSION __attribute__((no_sanitize("thread"))) +#else +#define TSAN_SUPPRESSION +#endif // TSAN_SUPPRESSION diff --git a/port/stack_trace.cc b/port/stack_trace.cc index c82da2a20..15a36bb71 100644 --- a/port/stack_trace.cc +++ b/port/stack_trace.cc @@ -36,6 +36,8 @@ void* SaveStack(int* /*num_frames*/, int /*first_frames_to_skip*/) { #include #endif +#include "port/lang.h" + namespace ROCKSDB_NAMESPACE { namespace port { @@ -163,8 +165,7 @@ static void StackTraceHandler(int sig) { // Efforts to fix or suppress TSAN warnings "signal-unsafe call inside of // a signal" have failed, so just warn the user about them. -#if defined(__clang__) && defined(__has_feature) -#if __has_feature(thread_sanitizer) +#ifdef __SANITIZE_THREAD__ fprintf(stderr, "==> NOTE: any above warnings about \"signal-unsafe call\" are\n" "==> ignorable, as they are expected when generating a stack\n" @@ -173,7 +174,6 @@ static void StackTraceHandler(int sig) { "==> in the TSAN warning can be useful for that. (The stack\n" "==> trace printed by the signal handler is likely obscured\n" "==> by TSAN output.)\n"); -#endif #endif // re-signal to default handler (so we still get core dump if needed...) diff --git a/trace_replay/io_tracer.h b/trace_replay/io_tracer.h index 83bcaee9d..8db6e2a27 100644 --- a/trace_replay/io_tracer.h +++ b/trace_replay/io_tracer.h @@ -9,6 +9,7 @@ #include #include "monitoring/instrumented_mutex.h" +#include "port/lang.h" #include "rocksdb/file_system.h" #include "rocksdb/options.h" #include "trace_replay/trace_replay.h" @@ -157,20 +158,6 @@ class IOTracer { // mutex and ignore the operation if writer_is null. So its ok if // tracing_enabled shows non updated value. -#if defined(__clang__) -#if defined(__has_feature) && __has_feature(thread_sanitizer) -#define TSAN_SUPPRESSION __attribute__((no_sanitize("thread"))) -#endif // __has_feature(thread_sanitizer) -#else // __clang__ -#ifdef __SANITIZE_THREAD__ -#define TSAN_SUPPRESSION __attribute__((no_sanitize("thread"))) -#endif // __SANITIZE_THREAD__ -#endif // __clang__ - -#ifndef TSAN_SUPPRESSION -#define TSAN_SUPPRESSION -#endif // TSAN_SUPPRESSION - // Start writing IO operations to the trace_writer. TSAN_SUPPRESSION Status StartIOTrace(SystemClock* clock, const TraceOptions& trace_options,