[tsan] Enable ignore_noninstrumented_modules=1 on Darwin by default

TSan recently got the "ignore_noninstrumented_modules" flag, which disables tracking of read and writes that come from noninstrumented modules (via interceptors). This is a way of suppressing false positives coming from system libraries and other noninstrumented code. This patch turns this on by default on Darwin, where it's supposed to replace the previous solution, "ignore_interceptors_accesses", which disables tracking in *all* interceptors. The new approach should re-enable TSan's ability to find races via interceptors on Darwin.

Differential Revision: https://reviews.llvm.org/D29041

llvm-svn: 292981
This commit is contained in:
Kuba Mracek 2017-01-24 21:37:50 +00:00
parent 8981f3aacf
commit e4c1dd2c08
51 changed files with 66 additions and 53 deletions

View File

@ -79,7 +79,7 @@ TSAN_FLAG(bool, die_after_fork, true,
TSAN_FLAG(const char *, suppressions, "", "Suppressions file name.") TSAN_FLAG(const char *, suppressions, "", "Suppressions file name.")
TSAN_FLAG(bool, ignore_interceptors_accesses, false, TSAN_FLAG(bool, ignore_interceptors_accesses, false,
"Ignore reads and writes from all interceptors.") "Ignore reads and writes from all interceptors.")
TSAN_FLAG(bool, ignore_noninstrumented_modules, false, TSAN_FLAG(bool, ignore_noninstrumented_modules, SANITIZER_MAC ? true : false,
"Interceptors should only detect races when called from instrumented " "Interceptors should only detect races when called from instrumented "
"modules.") "modules.")
TSAN_FLAG(bool, shared_ptr_interceptor, true, TSAN_FLAG(bool, shared_ptr_interceptor, true,

View File

@ -2,7 +2,7 @@
// quits the main thread. // quits the main thread.
// RUN: %clang_tsan %s -o %t -framework Foundation // RUN: %clang_tsan %s -o %t -framework Foundation
// RUN: %env_tsan_opts=ignore_interceptors_accesses=1 %run %t 2>&1 | FileCheck %s // RUN: %run %t 2>&1 | FileCheck %s
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>

View File

@ -1,7 +1,7 @@
// Check that calling dispatch_once from a report callback works. // Check that calling dispatch_once from a report callback works.
// RUN: %clang_tsan %s -o %t -framework Foundation // RUN: %clang_tsan %s -o %t -framework Foundation
// RUN: %env_tsan_opts=ignore_interceptors_accesses=1 not %run %t 2>&1 | FileCheck %s // RUN: not %run %t 2>&1 | FileCheck %s
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>
#import <pthread.h> #import <pthread.h>

View File

@ -1,5 +1,5 @@
// RUN: %clang_tsan %s -o %t -framework Foundation // RUN: %clang_tsan %s -o %t -framework Foundation
// RUN: %env_tsan_opts=ignore_interceptors_accesses=1 %run %t 2>&1 | FileCheck %s // RUN: %run %t 2>&1 | FileCheck %s
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>

View File

@ -1,5 +1,5 @@
// RUN: %clang_tsan %s -o %t -framework Foundation // RUN: %clang_tsan %s -o %t -framework Foundation
// RUN: %env_tsan_opts=ignore_interceptors_accesses=1 %deflake %run %t 2>&1 | FileCheck %s // RUN: %deflake %run %t 2>&1 | FileCheck %s
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>

View File

@ -1,5 +1,5 @@
// RUN: %clang_tsan %s -o %t -framework Foundation // RUN: %clang_tsan %s -o %t -framework Foundation
// RUN: %env_tsan_opts=ignore_interceptors_accesses=1 %run %t 2>&1 | FileCheck %s // RUN: %run %t 2>&1 | FileCheck %s
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>

View File

@ -1,5 +1,5 @@
// RUN: %clang_tsan %s -o %t -framework Foundation // RUN: %clang_tsan %s -o %t -framework Foundation
// RUN: %env_tsan_opts=ignore_interceptors_accesses=1 %run %t 2>&1 | FileCheck %s // RUN: %run %t 2>&1 | FileCheck %s
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>

View File

@ -1,5 +1,5 @@
// RUN: %clang_tsan %s -o %t -framework Foundation // RUN: %clang_tsan %s -o %t -framework Foundation
// RUN: %env_tsan_opts=ignore_interceptors_accesses=1 %deflake %run %t 2>&1 | FileCheck %s // RUN: %deflake %run %t 2>&1 | FileCheck %s
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>

View File

@ -1,5 +1,5 @@
// RUN: %clang_tsan %s -o %t -framework Foundation // RUN: %clang_tsan %s -o %t -framework Foundation
// RUN: %env_tsan_opts=ignore_interceptors_accesses=1 %deflake %run %t 2>&1 | FileCheck %s // RUN: %deflake %run %t 2>&1 | FileCheck %s
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>

View File

@ -1,5 +1,5 @@
// RUN: %clang_tsan %s -o %t -framework Foundation // RUN: %clang_tsan %s -o %t -framework Foundation
// RUN: %env_tsan_opts=ignore_interceptors_accesses=1 %run %t 2>&1 | FileCheck %s // RUN: %run %t 2>&1 | FileCheck %s
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>

View File

@ -1,5 +1,5 @@
// RUN: %clangxx_tsan %s -o %t -framework Foundation // RUN: %clangxx_tsan %s -o %t -framework Foundation
// RUN: %env_tsan_opts=ignore_interceptors_accesses=1 %run %t 2>&1 | FileCheck %s // RUN: %run %t 2>&1 | FileCheck %s
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>

View File

@ -1,5 +1,5 @@
// RUN: %clang_tsan %s -o %t -framework Foundation // RUN: %clang_tsan %s -o %t -framework Foundation
// RUN: %env_tsan_opts=ignore_interceptors_accesses=1 %run %t 2>&1 | FileCheck %s // RUN: %run %t 2>&1 | FileCheck %s
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>

View File

@ -1,5 +1,5 @@
// RUN: %clang_tsan %s -o %t -framework Foundation // RUN: %clang_tsan %s -o %t -framework Foundation
// RUN: %env_tsan_opts=ignore_interceptors_accesses=1 %run %t 2>&1 | FileCheck %s // RUN: %run %t 2>&1 | FileCheck %s
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>

View File

@ -1,5 +1,5 @@
// RUN: %clangxx_tsan %s -o %t -framework Foundation // RUN: %clangxx_tsan %s -o %t -framework Foundation
// RUN: %env_tsan_opts=ignore_interceptors_accesses=1 %run %t 2>&1 | FileCheck %s // RUN: %run %t 2>&1 | FileCheck %s
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>

View File

@ -1,5 +1,5 @@
// RUN: %clang_tsan %s -o %t -framework Foundation // RUN: %clang_tsan %s -o %t -framework Foundation
// RUN: %env_tsan_opts=ignore_interceptors_accesses=1 %run %t 2>&1 | FileCheck %s // RUN: %run %t 2>&1 | FileCheck %s
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>

View File

@ -1,5 +1,5 @@
// RUN: %clang_tsan %s -o %t -framework Foundation // RUN: %clang_tsan %s -o %t -framework Foundation
// RUN: %env_tsan_opts=ignore_interceptors_accesses=1 %run %t 2>&1 | FileCheck %s // RUN: %run %t 2>&1 | FileCheck %s
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>

View File

@ -1,5 +1,5 @@
// RUN: %clang_tsan %s -o %t -framework Foundation // RUN: %clang_tsan %s -o %t -framework Foundation
// RUN: %env_tsan_opts=ignore_interceptors_accesses=1 %run %t 2>&1 | FileCheck %s // RUN: %run %t 2>&1 | FileCheck %s
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>

View File

@ -1,5 +1,5 @@
// RUN: %clang_tsan %s -o %t -framework Foundation // RUN: %clang_tsan %s -o %t -framework Foundation
// RUN: %env_tsan_opts=ignore_interceptors_accesses=1 %deflake %run %t 2>&1 | FileCheck %s // RUN: %deflake %run %t 2>&1 | FileCheck %s
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>

View File

@ -1,5 +1,5 @@
// RUN: %clang_tsan %s -o %t -framework Foundation // RUN: %clang_tsan %s -o %t -framework Foundation
// RUN: %env_tsan_opts=ignore_interceptors_accesses=1 %run %t 2>&1 | FileCheck %s // RUN: %run %t 2>&1 | FileCheck %s
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>

View File

@ -1,5 +1,5 @@
// RUN: %clang_tsan %s -o %t -framework Foundation // RUN: %clang_tsan %s -o %t -framework Foundation
// RUN: %env_tsan_opts=ignore_interceptors_accesses=1 %run %t 2>&1 | FileCheck %s // RUN: %run %t 2>&1 | FileCheck %s
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>

View File

@ -1,5 +1,5 @@
// RUN: %clang_tsan %s -o %t -framework Foundation // RUN: %clang_tsan %s -o %t -framework Foundation
// RUN: %env_tsan_opts=ignore_interceptors_accesses=1 %deflake %run %t 2>&1 | FileCheck %s // RUN: %deflake %run %t 2>&1 | FileCheck %s
// REQUIRES: disabled // REQUIRES: disabled

View File

@ -1,5 +1,5 @@
// RUN: %clang_tsan %s -o %t -framework Foundation // RUN: %clang_tsan %s -o %t -framework Foundation
// RUN: %env_tsan_opts=ignore_interceptors_accesses=1 %run %t 2>&1 | FileCheck %s // RUN: %run %t 2>&1 | FileCheck %s
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>

View File

@ -1,5 +1,5 @@
// RUN: %clang_tsan %s -o %t -framework Foundation // RUN: %clang_tsan %s -o %t -framework Foundation
// RUN: %env_tsan_opts=ignore_interceptors_accesses=1 %run %t 2>&1 | FileCheck %s // RUN: %run %t 2>&1 | FileCheck %s
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>

View File

@ -1,5 +1,5 @@
// RUN: %clang_tsan %s -o %t -framework Foundation // RUN: %clang_tsan %s -o %t -framework Foundation
// RUN: %env_tsan_opts=ignore_interceptors_accesses=1 %run %t 2>&1 | FileCheck %s // RUN: %run %t 2>&1 | FileCheck %s
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>

View File

@ -1,5 +1,5 @@
// RUN: %clang_tsan %s -o %t -framework Foundation // RUN: %clang_tsan %s -o %t -framework Foundation
// RUN: %env_tsan_opts=ignore_interceptors_accesses=1 %run %t 2>&1 | FileCheck %s // RUN: %run %t 2>&1 | FileCheck %s
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>

View File

@ -1,5 +1,5 @@
// RUN: %clang_tsan %s -o %t -framework Foundation // RUN: %clang_tsan %s -o %t -framework Foundation
// RUN: %env_tsan_opts=ignore_interceptors_accesses=1 %run %t 2>&1 | FileCheck %s // RUN: %run %t 2>&1 | FileCheck %s
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>

View File

@ -1,5 +1,5 @@
// RUN: %clang_tsan %s -o %t -framework Foundation // RUN: %clang_tsan %s -o %t -framework Foundation
// RUN: %env_tsan_opts=ignore_interceptors_accesses=1 %run %t 2>&1 | FileCheck %s // RUN: %run %t 2>&1 | FileCheck %s
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>

View File

@ -1,5 +1,5 @@
// RUN: %clang_tsan %s -o %t -framework Foundation // RUN: %clang_tsan %s -o %t -framework Foundation
// RUN: %env_tsan_opts=ignore_interceptors_accesses=1 %run %t 2>&1 | FileCheck %s // RUN: %run %t 2>&1 | FileCheck %s
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>

View File

@ -1,5 +1,5 @@
// RUN: %clang_tsan %s -o %t -framework Foundation // RUN: %clang_tsan %s -o %t -framework Foundation
// RUN: %env_tsan_opts=ignore_interceptors_accesses=1 %run %t 2>&1 | FileCheck %s // RUN: %run %t 2>&1 | FileCheck %s
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>

View File

@ -1,5 +1,5 @@
// RUN: %clang_tsan %s -o %t -framework Foundation // RUN: %clang_tsan %s -o %t -framework Foundation
// RUN: %env_tsan_opts=ignore_interceptors_accesses=1 %run %t 2>&1 | FileCheck %s // RUN: %run %t 2>&1 | FileCheck %s
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>

View File

@ -1,5 +1,5 @@
// RUN: %clang_tsan %s -o %t -framework Foundation // RUN: %clang_tsan %s -o %t -framework Foundation
// RUN: %env_tsan_opts=ignore_interceptors_accesses=1 %run %t 2>&1 | FileCheck %s // RUN: %run %t 2>&1 | FileCheck %s
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>

View File

@ -1,5 +1,5 @@
// RUN: %clang_tsan %s -o %t -framework Foundation // RUN: %clang_tsan %s -o %t -framework Foundation
// RUN: %env_tsan_opts=ignore_interceptors_accesses=1 %run %t 2>&1 | FileCheck %s // RUN: %run %t 2>&1 | FileCheck %s
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>

View File

@ -1,5 +1,5 @@
// RUN: %clang_tsan %s -o %t -framework Foundation // RUN: %clang_tsan %s -o %t -framework Foundation
// RUN: %env_tsan_opts=ignore_interceptors_accesses=1 %run %t 2>&1 | FileCheck %s // RUN: %run %t 2>&1 | FileCheck %s
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>

View File

@ -1,5 +1,5 @@
// RUN: %clang_tsan %s -o %t -framework Foundation // RUN: %clang_tsan %s -o %t -framework Foundation
// RUN: %env_tsan_opts=ignore_interceptors_accesses=1 %run %t 2>&1 | FileCheck %s // RUN: %run %t 2>&1 | FileCheck %s
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>

View File

@ -1,5 +1,5 @@
// RUN: %clang_tsan %s -o %t -framework Foundation // RUN: %clang_tsan %s -o %t -framework Foundation
// RUN: %env_tsan_opts=ignore_interceptors_accesses=1 %deflake %run %t 2>&1 | FileCheck %s // RUN: %deflake %run %t 2>&1 | FileCheck %s
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>

View File

@ -1,5 +1,5 @@
// RUN: %clang_tsan %s -o %t -framework Foundation // RUN: %clang_tsan %s -o %t -framework Foundation
// RUN: %env_tsan_opts=ignore_interceptors_accesses=1 %run %t 2>&1 | FileCheck %s // RUN: %run %t 2>&1 | FileCheck %s
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>

View File

@ -3,7 +3,7 @@
// RUN: %clang_tsan %s -o %t -framework Foundation // RUN: %clang_tsan %s -o %t -framework Foundation
// Check that without the flag, there are false positives. // Check that without the flag, there are false positives.
// RUN: %deflake %run %t 2>&1 | FileCheck %s --check-prefix=CHECK-RACE // RUN: %env_tsan_opts=ignore_noninstrumented_modules=0 %deflake %run %t 2>&1 | FileCheck %s --check-prefix=CHECK-RACE
// With ignore_noninstrumented_modules=1, no races are reported. // With ignore_noninstrumented_modules=1, no races are reported.
// RUN: %env_tsan_opts=ignore_noninstrumented_modules=1 %run %t 2>&1 | FileCheck %s // RUN: %env_tsan_opts=ignore_noninstrumented_modules=1 %run %t 2>&1 | FileCheck %s

View File

@ -6,13 +6,13 @@
// RUN: %clang_tsan %s -o %t -framework Foundation // RUN: %clang_tsan %s -o %t -framework Foundation
// Check that without the flag, there are false positives. // Check that without the flag, there are false positives.
// RUN: %deflake %run %t 2>&1 | FileCheck %s --check-prefix=CHECK-RACE // RUN: %env_tsan_opts=ignore_noninstrumented_modules=0 %deflake %run %t 2>&1 | FileCheck %s --check-prefix=CHECK-RACE
// With ignore_interceptors_accesses=1, no races are reported. // With ignore_interceptors_accesses=1, no races are reported.
// RUN: %env_tsan_opts=ignore_interceptors_accesses=1 %run %t 2>&1 | FileCheck %s // RUN: %env_tsan_opts=ignore_noninstrumented_modules=0:ignore_interceptors_accesses=1 %run %t 2>&1 | FileCheck %s
// With ignore_interceptors_accesses=1, races in user's code are still reported. // With ignore_interceptors_accesses=1, races in user's code are still reported.
// RUN: %env_tsan_opts=ignore_interceptors_accesses=1 %deflake %run %t race 2>&1 | FileCheck %s --check-prefix=CHECK --check-prefix=CHECK-RACE // RUN: %env_tsan_opts=ignore_noninstrumented_modules=0:ignore_interceptors_accesses=1 %deflake %run %t race 2>&1 | FileCheck %s --check-prefix=CHECK --check-prefix=CHECK-RACE
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>

View File

@ -1,5 +1,5 @@
// RUN: %clangxx_tsan %s -o %t -framework Foundation -std=c++11 // RUN: %clangxx_tsan %s -o %t -framework Foundation -std=c++11
// RUN: %env_tsan_opts=ignore_interceptors_accesses=1 %run %t 2>&1 | FileCheck %s // RUN: %run %t 2>&1 | FileCheck %s
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>

View File

@ -1,5 +1,5 @@
// RUN: %clangxx_tsan %s -o %t // RUN: %clangxx_tsan %s -o %t
// RUN: %env_tsan_opts=ignore_interceptors_accesses=1 %run %t 2>&1 | FileCheck %s // RUN: %run %t 2>&1 | FileCheck %s
#include <iostream> #include <iostream>
#include <future> #include <future>

View File

@ -1,5 +1,5 @@
// RUN: %clangxx_tsan %s -o %t -framework Foundation // RUN: %clangxx_tsan %s -o %t -framework Foundation
// RUN: %env_tsan_opts=ignore_interceptors_accesses=1 %run %t 2>&1 | FileCheck %s // RUN: %run %t 2>&1 | FileCheck %s
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>

View File

@ -1,5 +1,5 @@
// RUN: %clangxx_tsan %s -o %t -framework Foundation // RUN: %clangxx_tsan %s -o %t -framework Foundation
// RUN: %env_tsan_opts=ignore_interceptors_accesses=1 %run %t 2>&1 | FileCheck %s // RUN: %run %t 2>&1 | FileCheck %s
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>

View File

@ -1,5 +1,5 @@
// RUN: %clangxx_tsan %s -o %t -framework Foundation // RUN: %clangxx_tsan %s -o %t -framework Foundation
// RUN: %env_tsan_opts=ignore_interceptors_accesses=1 %run %t 2>&1 | FileCheck %s // RUN: %run %t 2>&1 | FileCheck %s
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>

View File

@ -7,3 +7,5 @@ root = getRoot(config)
if root.host_os not in ['Darwin']: if root.host_os not in ['Darwin']:
config.unsupported = True config.unsupported = True
config.environment['TSAN_OPTIONS'] += ':ignore_noninstrumented_modules=1'

View File

@ -1,5 +1,5 @@
// RUN: %clang_tsan %s -lc++ -fobjc-arc -lobjc -o %t -framework Foundation // RUN: %clang_tsan %s -lc++ -fobjc-arc -lobjc -o %t -framework Foundation
// RUN: %env_tsan_opts=ignore_interceptors_accesses=1 %run %t 2>&1 | FileCheck %s // RUN: %run %t 2>&1 | FileCheck %s
// Check that we do not report races between: // Check that we do not report races between:
// - Object retain and initialize // - Object retain and initialize

View File

@ -1,7 +1,7 @@
// RUN: %clangxx_tsan -O0 %s -o %t -framework Foundation && %env_tsan_opts=ignore_interceptors_accesses=1 %run %t 2>&1 | FileCheck %s // RUN: %clangxx_tsan -O0 %s -o %t -framework Foundation && %run %t 2>&1 | FileCheck %s
// RUN: %clangxx_tsan -O1 %s -o %t -framework Foundation && %env_tsan_opts=ignore_interceptors_accesses=1 %run %t 2>&1 | FileCheck %s // RUN: %clangxx_tsan -O1 %s -o %t -framework Foundation && %run %t 2>&1 | FileCheck %s
// RUN: %clangxx_tsan -O2 %s -o %t -framework Foundation && %env_tsan_opts=ignore_interceptors_accesses=1 %run %t 2>&1 | FileCheck %s // RUN: %clangxx_tsan -O2 %s -o %t -framework Foundation && %run %t 2>&1 | FileCheck %s
// RUN: %clangxx_tsan -O3 %s -o %t -framework Foundation && %env_tsan_opts=ignore_interceptors_accesses=1 %run %t 2>&1 | FileCheck %s // RUN: %clangxx_tsan -O3 %s -o %t -framework Foundation && %run %t 2>&1 | FileCheck %s
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>

View File

@ -1,7 +1,7 @@
// Test that a simple Obj-C program runs and exits without any warnings. // Test that a simple Obj-C program runs and exits without any warnings.
// RUN: %clang_tsan %s -o %t -framework Foundation // RUN: %clang_tsan %s -o %t -framework Foundation
// RUN: %env_tsan_opts=ignore_interceptors_accesses=1 %run %t 2>&1 | FileCheck %s // RUN: %run %t 2>&1 | FileCheck %s
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>

View File

@ -1,5 +1,5 @@
// RUN: %clang_tsan %s -o %t -framework Foundation // RUN: %clang_tsan %s -o %t -framework Foundation
// RUN: %env_tsan_opts=ignore_interceptors_accesses=1 %deflake %run %t 2>&1 | FileCheck %s // RUN: %deflake %run %t 2>&1 | FileCheck %s
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>
#import <xpc/xpc.h> #import <xpc/xpc.h>

View File

@ -1,5 +1,5 @@
// RUN: %clang_tsan %s -o %t -framework Foundation // RUN: %clang_tsan %s -o %t -framework Foundation
// RUN: %env_tsan_opts=ignore_interceptors_accesses=1 %run %t 2>&1 | FileCheck %s // RUN: %run %t 2>&1 | FileCheck %s
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>
#import <xpc/xpc.h> #import <xpc/xpc.h>

View File

@ -14,3 +14,10 @@ config.test_source_root = config.test_exec_root
if config.host_os == 'Darwin': if config.host_os == 'Darwin':
config.parallelism_group = config.darwin_sanitizer_parallelism_group_func config.parallelism_group = config.darwin_sanitizer_parallelism_group_func
# On Darwin, we default to ignore_noninstrumented_modules=1, which also
# suppresses some races the tests are supposed to find. See tsan/lit.cfg.
if 'TSAN_OPTIONS' in config.environment:
config.environment['TSAN_OPTIONS'] += ':ignore_noninstrumented_modules=0'
else:
config.environment['TSAN_OPTIONS'] = 'ignore_noninstrumented_modules=0'

View File

@ -24,6 +24,10 @@ if config.host_os == 'Darwin':
# On Darwin, we default to `abort_on_error=1`, which would make tests run # On Darwin, we default to `abort_on_error=1`, which would make tests run
# much slower. Let's override this and run lit tests with 'abort_on_error=0'. # much slower. Let's override this and run lit tests with 'abort_on_error=0'.
default_tsan_opts += ':abort_on_error=0' default_tsan_opts += ':abort_on_error=0'
# On Darwin, we default to ignore_noninstrumented_modules=1, which also
# suppresses some races the tests are supposed to find. Let's run without this
# setting, but turn it back on for Darwin tests (see Darwin/lit.local.cfg).
default_tsan_opts += ':ignore_noninstrumented_modules=0'
# Platform-specific default TSAN_OPTIONS for lit tests. # Platform-specific default TSAN_OPTIONS for lit tests.
if default_tsan_opts: if default_tsan_opts: