diff options
Diffstat (limited to 'test/tsan/lit.cfg.py')
-rw-r--r-- | test/tsan/lit.cfg.py | 90 |
1 files changed, 90 insertions, 0 deletions
diff --git a/test/tsan/lit.cfg.py b/test/tsan/lit.cfg.py new file mode 100644 index 000000000..813544831 --- /dev/null +++ b/test/tsan/lit.cfg.py @@ -0,0 +1,90 @@ +# -*- Python -*- + +import os + +def get_required_attr(config, attr_name): + attr_value = getattr(config, attr_name, None) + if not attr_value: + lit_config.fatal( + "No attribute %r in test configuration! You may need to run " + "tests from your build directory or add this attribute " + "to lit.site.cfg.py " % attr_name) + return attr_value + +# Setup config name. +config.name = 'ThreadSanitizer' + config.name_suffix + +# Setup source root. +config.test_source_root = os.path.dirname(__file__) + +# Setup environment variables for running ThreadSanitizer. +default_tsan_opts = "atexit_sleep_ms=0" + +if config.host_os == 'Darwin': + # 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'. + 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.py). + default_tsan_opts += ':ignore_noninstrumented_modules=0' + +# Platform-specific default TSAN_OPTIONS for lit tests. +if default_tsan_opts: + config.environment['TSAN_OPTIONS'] = default_tsan_opts + default_tsan_opts += ':' +config.substitutions.append(('%env_tsan_opts=', + 'env TSAN_OPTIONS=' + default_tsan_opts)) + +# GCC driver doesn't add necessary compile/link flags with -fsanitize=thread. +if config.compiler_id == 'GNU': + extra_cflags = ["-fPIE", "-pthread", "-ldl", "-lrt", "-pie"] +else: + extra_cflags = [] + +tsan_incdir = config.test_source_root + "/../" +# Setup default compiler flags used with -fsanitize=thread option. +clang_tsan_cflags = (["-fsanitize=thread", + "-Wall"] + + [config.target_cflags] + + config.debug_info_flags + + extra_cflags + + ["-I%s" % tsan_incdir]) +clang_tsan_cxxflags = config.cxx_mode_flags + clang_tsan_cflags + ["-std=c++11"] + ["-I%s" % tsan_incdir] +# Add additional flags if we're using instrumented libc++. +# Instrumented libcxx currently not supported on Darwin. +if config.has_libcxx and config.host_os != 'Darwin': + # FIXME: Dehardcode this path somehow. + libcxx_path = os.path.join(config.compiler_rt_obj_root, "lib", + "tsan", "libcxx_tsan_%s" % config.target_arch) + libcxx_incdir = os.path.join(libcxx_path, "include", "c++", "v1") + libcxx_libdir = os.path.join(libcxx_path, "lib") + libcxx_a = os.path.join(libcxx_libdir, "libc++.a") + clang_tsan_cxxflags += ["-nostdinc++", + "-I%s" % libcxx_incdir] + config.substitutions.append( ("%link_libcxx_tsan", libcxx_a) ) +else: + config.substitutions.append( ("%link_libcxx_tsan", "") ) + +def build_invocation(compile_flags): + return " " + " ".join([config.clang] + compile_flags) + " " + +config.substitutions.append( ("%clang_tsan ", build_invocation(clang_tsan_cflags)) ) +config.substitutions.append( ("%clangxx_tsan ", build_invocation(clang_tsan_cxxflags)) ) + +# Define CHECK-%os to check for OS-dependent output. +config.substitutions.append( ('CHECK-%os', ("CHECK-" + config.host_os))) + +config.substitutions.append( ("%deflake ", os.path.join(os.path.dirname(__file__), "deflake.bash") + " ")) + +# Default test suffixes. +config.suffixes = ['.c', '.cc', '.cpp', '.m', '.mm'] + +if config.host_os not in ['FreeBSD', 'Linux', 'Darwin', 'NetBSD']: + config.unsupported = True + +if config.android: + config.unsupported = True + +if not config.parallelism_group: + config.parallelism_group = 'shadow-memory' |