sanitizers: compile with -O1 under debug
authorDmitry Vyukov <dvyukov@google.com>
Thu, 12 Aug 2021 13:43:09 +0000 (15:43 +0200)
committerDmitry Vyukov <dvyukov@google.com>
Mon, 16 Aug 2021 08:01:50 +0000 (10:01 +0200)
commit7142eb17fb3419a76c9ac4afce0df986ff08d61c
treebbfe0d79953d4444b4e39efafcbab054da26f316
parent09507b53250dc266632c204558cb1c2b56e8ddea
sanitizers: compile with -O1 under debug

Tsan's check_memcpy.c test was disabled under debug because it failed.
But it points to real issues and does not help to just disable it.
I tried to enable it and see what fail and the first hit was default ctor for:

  struct ChainedOriginDepotDesc {
    u32 here_id;
    u32 prev_id;
  };

initializing these fields to 0's help partially,
but compiler still emits memset before calling ctor.
I did not try to see what's the next failure, because if it fails
on such small structs, it won't be realistic to fix everything
and keep working.

Compile runtimes with -O1 under debug instead.
It seems to fix all current failures. At least I run check-tsan
under clang/gcc x debug/non-debug and all combinations passed.
-O1 does not usually use too aggressive optimizations
and sometimes even makes debugging easier because machine code
is not exceedingly verbose.

Reviewed By: vitalybuka

Differential Revision: https://reviews.llvm.org/D107962
compiler-rt/CMakeLists.txt
compiler-rt/test/tsan/Linux/check_memcpy.c