aboutsummaryrefslogtreecommitdiff
path: root/compiler-rt/test/asan/lit.cfg.py
diff options
context:
space:
mode:
Diffstat (limited to 'compiler-rt/test/asan/lit.cfg.py')
-rw-r--r--compiler-rt/test/asan/lit.cfg.py406
1 files changed, 235 insertions, 171 deletions
diff --git a/compiler-rt/test/asan/lit.cfg.py b/compiler-rt/test/asan/lit.cfg.py
index 03ac206..e245a61 100644
--- a/compiler-rt/test/asan/lit.cfg.py
+++ b/compiler-rt/test/asan/lit.cfg.py
@@ -7,257 +7,321 @@ import shlex
import lit.formats
+
def get_required_attr(config, attr_name):
- attr_value = getattr(config, attr_name, None)
- if attr_value == None:
- 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
+ attr_value = getattr(config, attr_name, None)
+ if attr_value == None:
+ 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
+
def push_dynamic_library_lookup_path(config, new_path):
- if platform.system() == 'Windows':
- dynamic_library_lookup_var = 'PATH'
- elif platform.system() == 'Darwin':
- dynamic_library_lookup_var = 'DYLD_LIBRARY_PATH'
- else:
- dynamic_library_lookup_var = 'LD_LIBRARY_PATH'
-
- new_ld_library_path = os.path.pathsep.join(
- (new_path, config.environment.get(dynamic_library_lookup_var, '')))
- config.environment[dynamic_library_lookup_var] = new_ld_library_path
-
- if platform.system() == 'FreeBSD':
- dynamic_library_lookup_var = 'LD_32_LIBRARY_PATH'
- new_ld_32_library_path = os.path.pathsep.join(
- (new_path, config.environment.get(dynamic_library_lookup_var, '')))
- config.environment[dynamic_library_lookup_var] = new_ld_32_library_path
-
- if platform.system() == 'SunOS':
- dynamic_library_lookup_var = 'LD_LIBRARY_PATH_32'
- new_ld_library_path_32 = os.path.pathsep.join(
- (new_path, config.environment.get(dynamic_library_lookup_var, '')))
- config.environment[dynamic_library_lookup_var] = new_ld_library_path_32
-
- dynamic_library_lookup_var = 'LD_LIBRARY_PATH_64'
- new_ld_library_path_64 = os.path.pathsep.join(
- (new_path, config.environment.get(dynamic_library_lookup_var, '')))
- config.environment[dynamic_library_lookup_var] = new_ld_library_path_64
+ if platform.system() == "Windows":
+ dynamic_library_lookup_var = "PATH"
+ elif platform.system() == "Darwin":
+ dynamic_library_lookup_var = "DYLD_LIBRARY_PATH"
+ else:
+ dynamic_library_lookup_var = "LD_LIBRARY_PATH"
+
+ new_ld_library_path = os.path.pathsep.join(
+ (new_path, config.environment.get(dynamic_library_lookup_var, ""))
+ )
+ config.environment[dynamic_library_lookup_var] = new_ld_library_path
+
+ if platform.system() == "FreeBSD":
+ dynamic_library_lookup_var = "LD_32_LIBRARY_PATH"
+ new_ld_32_library_path = os.path.pathsep.join(
+ (new_path, config.environment.get(dynamic_library_lookup_var, ""))
+ )
+ config.environment[dynamic_library_lookup_var] = new_ld_32_library_path
+
+ if platform.system() == "SunOS":
+ dynamic_library_lookup_var = "LD_LIBRARY_PATH_32"
+ new_ld_library_path_32 = os.path.pathsep.join(
+ (new_path, config.environment.get(dynamic_library_lookup_var, ""))
+ )
+ config.environment[dynamic_library_lookup_var] = new_ld_library_path_32
+
+ dynamic_library_lookup_var = "LD_LIBRARY_PATH_64"
+ new_ld_library_path_64 = os.path.pathsep.join(
+ (new_path, config.environment.get(dynamic_library_lookup_var, ""))
+ )
+ config.environment[dynamic_library_lookup_var] = new_ld_library_path_64
+
# Setup config name.
-config.name = 'AddressSanitizer' + config.name_suffix
+config.name = "AddressSanitizer" + config.name_suffix
# Platform-specific default ASAN_OPTIONS for lit tests.
default_asan_opts = list(config.default_sanitizer_opts)
# On Darwin, leak checking is not enabled by default. Enable on macOS
# tests to prevent regressions
-if config.host_os == 'Darwin' and config.apple_platform == 'osx':
- default_asan_opts += ['detect_leaks=1']
+if config.host_os == "Darwin" and config.apple_platform == "osx":
+ default_asan_opts += ["detect_leaks=1"]
-default_asan_opts_str = ':'.join(default_asan_opts)
+default_asan_opts_str = ":".join(default_asan_opts)
if default_asan_opts_str:
- config.environment['ASAN_OPTIONS'] = default_asan_opts_str
- default_asan_opts_str += ':'
-config.substitutions.append(('%env_asan_opts=',
- 'env ASAN_OPTIONS=' + default_asan_opts_str))
+ config.environment["ASAN_OPTIONS"] = default_asan_opts_str
+ default_asan_opts_str += ":"
+config.substitutions.append(
+ ("%env_asan_opts=", "env ASAN_OPTIONS=" + default_asan_opts_str)
+)
# Setup source root.
config.test_source_root = os.path.dirname(__file__)
-if config.host_os not in ['FreeBSD', 'NetBSD']:
- libdl_flag = "-ldl"
+if config.host_os not in ["FreeBSD", "NetBSD"]:
+ libdl_flag = "-ldl"
else:
- libdl_flag = ""
+ libdl_flag = ""
# GCC-ASan doesn't link in all the necessary libraries automatically, so
# we have to do it ourselves.
-if config.compiler_id == 'GNU':
- extra_link_flags = ["-pthread", "-lstdc++", libdl_flag]
+if config.compiler_id == "GNU":
+ extra_link_flags = ["-pthread", "-lstdc++", libdl_flag]
else:
- extra_link_flags = []
+ extra_link_flags = []
# Setup default compiler flags used with -fsanitize=address option.
# FIXME: Review the set of required flags and check if it can be reduced.
target_cflags = [get_required_attr(config, "target_cflags")] + extra_link_flags
target_cxxflags = config.cxx_mode_flags + target_cflags
-clang_asan_static_cflags = (["-fsanitize=address",
- "-mno-omit-leaf-frame-pointer",
- "-fno-omit-frame-pointer",
- "-fno-optimize-sibling-calls"] +
- config.debug_info_flags + target_cflags)
-if config.target_arch == 's390x':
- clang_asan_static_cflags.append("-mbackchain")
+clang_asan_static_cflags = (
+ [
+ "-fsanitize=address",
+ "-mno-omit-leaf-frame-pointer",
+ "-fno-omit-frame-pointer",
+ "-fno-optimize-sibling-calls",
+ ]
+ + config.debug_info_flags
+ + target_cflags
+)
+if config.target_arch == "s390x":
+ clang_asan_static_cflags.append("-mbackchain")
clang_asan_static_cxxflags = config.cxx_mode_flags + clang_asan_static_cflags
-target_is_msvc = bool(re.match(r'.*-windows-msvc$', config.target_triple))
+target_is_msvc = bool(re.match(r".*-windows-msvc$", config.target_triple))
asan_dynamic_flags = []
if config.asan_dynamic:
- asan_dynamic_flags = ["-shared-libasan"]
- if platform.system() == 'Windows' and target_is_msvc:
- # On MSVC target, we need to simulate "clang-cl /MD" on the clang driver side.
- asan_dynamic_flags += ["-D_MT", "-D_DLL", "-Wl,-nodefaultlib:libcmt,-defaultlib:msvcrt,-defaultlib:oldnames"]
- elif platform.system() == 'FreeBSD':
- # On FreeBSD, we need to add -pthread to ensure pthread functions are available.
- asan_dynamic_flags += ['-pthread']
- config.available_features.add("asan-dynamic-runtime")
+ asan_dynamic_flags = ["-shared-libasan"]
+ if platform.system() == "Windows" and target_is_msvc:
+ # On MSVC target, we need to simulate "clang-cl /MD" on the clang driver side.
+ asan_dynamic_flags += [
+ "-D_MT",
+ "-D_DLL",
+ "-Wl,-nodefaultlib:libcmt,-defaultlib:msvcrt,-defaultlib:oldnames",
+ ]
+ elif platform.system() == "FreeBSD":
+ # On FreeBSD, we need to add -pthread to ensure pthread functions are available.
+ asan_dynamic_flags += ["-pthread"]
+ config.available_features.add("asan-dynamic-runtime")
else:
- config.available_features.add("asan-static-runtime")
+ config.available_features.add("asan-static-runtime")
clang_asan_cflags = clang_asan_static_cflags + asan_dynamic_flags
clang_asan_cxxflags = clang_asan_static_cxxflags + asan_dynamic_flags
# Add win32-(static|dynamic)-asan features to mark tests as passing or failing
# in those modes. lit doesn't support logical feature test combinations.
-if platform.system() == 'Windows':
- if config.asan_dynamic:
- win_runtime_feature = "win32-dynamic-asan"
- else:
- win_runtime_feature = "win32-static-asan"
- config.available_features.add(win_runtime_feature)
+if platform.system() == "Windows":
+ if config.asan_dynamic:
+ win_runtime_feature = "win32-dynamic-asan"
+ else:
+ win_runtime_feature = "win32-static-asan"
+ config.available_features.add(win_runtime_feature)
+
def build_invocation(compile_flags):
- return " " + " ".join([config.clang] + compile_flags) + " "
+ return " " + " ".join([config.clang] + compile_flags) + " "
+
-config.substitutions.append( ("%clang ", build_invocation(target_cflags)) )
-config.substitutions.append( ("%clangxx ", build_invocation(target_cxxflags)) )
-config.substitutions.append( ("%clang_asan ", build_invocation(clang_asan_cflags)) )
-config.substitutions.append( ("%clangxx_asan ", build_invocation(clang_asan_cxxflags)) )
+config.substitutions.append(("%clang ", build_invocation(target_cflags)))
+config.substitutions.append(("%clangxx ", build_invocation(target_cxxflags)))
+config.substitutions.append(("%clang_asan ", build_invocation(clang_asan_cflags)))
+config.substitutions.append(("%clangxx_asan ", build_invocation(clang_asan_cxxflags)))
if config.asan_dynamic:
- if config.host_os in ['Linux', 'FreeBSD', 'NetBSD', 'SunOS']:
- shared_libasan_path = os.path.join(config.compiler_rt_libdir, "libclang_rt.asan{}.so".format(config.target_suffix))
- elif config.host_os == 'Darwin':
- shared_libasan_path = os.path.join(config.compiler_rt_libdir, 'libclang_rt.asan_{}_dynamic.dylib'.format(config.apple_platform))
- else:
- lit_config.warning('%shared_libasan substitution not set but dynamic ASan is available.')
- shared_libasan_path = None
-
- if shared_libasan_path is not None:
- config.substitutions.append( ("%shared_libasan", shared_libasan_path) )
- config.substitutions.append( ("%clang_asan_static ", build_invocation(clang_asan_static_cflags)) )
- config.substitutions.append( ("%clangxx_asan_static ", build_invocation(clang_asan_static_cxxflags)) )
-
-if platform.system() == 'Windows':
- # MSVC-specific tests might also use the clang-cl.exe driver.
- if target_is_msvc:
- clang_cl_cxxflags = ["-Wno-deprecated-declarations",
- "-WX",
- "-D_HAS_EXCEPTIONS=0",
- "-Zi"] + target_cflags
- clang_cl_asan_cxxflags = ["-fsanitize=address"] + clang_cl_cxxflags
- if config.asan_dynamic:
- clang_cl_asan_cxxflags.append("-MD")
-
- clang_cl_invocation = build_invocation(clang_cl_cxxflags)
- clang_cl_invocation = clang_cl_invocation.replace("clang.exe","clang-cl.exe")
- config.substitutions.append( ("%clang_cl ", clang_cl_invocation) )
-
- clang_cl_asan_invocation = build_invocation(clang_cl_asan_cxxflags)
- clang_cl_asan_invocation = clang_cl_asan_invocation.replace("clang.exe","clang-cl.exe")
- config.substitutions.append( ("%clang_cl_asan ", clang_cl_asan_invocation) )
- config.substitutions.append( ("%clang_cl_nocxx_asan ", clang_cl_asan_invocation) )
- config.substitutions.append( ("%Od", "-Od") )
- config.substitutions.append( ("%Fe", "-Fe") )
- config.substitutions.append( ("%LD", "-LD") )
- config.substitutions.append( ("%MD", "-MD") )
- config.substitutions.append( ("%MT", "-MT") )
- config.substitutions.append( ("%Gw", "-Gw") )
-
- base_lib = os.path.join(config.compiler_rt_libdir, "clang_rt.asan%%s%s.lib" % config.target_suffix)
- config.substitutions.append( ("%asan_lib", base_lib % "") )
- config.substitutions.append( ("%asan_cxx_lib", base_lib % "_cxx") )
- config.substitutions.append( ("%asan_dll_thunk", base_lib % "_dll_thunk") )
- else:
- # To make some of these tests work on MinGW target without changing their
- # behaviour for MSVC target, substitute clang-cl flags with gcc-like ones.
- config.substitutions.append( ("%clang_cl ", build_invocation(target_cxxflags)) )
- config.substitutions.append( ("%clang_cl_asan ", build_invocation(clang_asan_cxxflags)) )
- config.substitutions.append( ("%clang_cl_nocxx_asan ", build_invocation(clang_asan_cflags)) )
- config.substitutions.append( ("%Od", "-O0") )
- config.substitutions.append( ("%Fe", "-o") )
- config.substitutions.append( ("%LD", "-shared") )
- config.substitutions.append( ("%MD", "") )
- config.substitutions.append( ("%MT", "") )
- config.substitutions.append( ("%Gw", "-fdata-sections") )
+ if config.host_os in ["Linux", "FreeBSD", "NetBSD", "SunOS"]:
+ shared_libasan_path = os.path.join(
+ config.compiler_rt_libdir,
+ "libclang_rt.asan{}.so".format(config.target_suffix),
+ )
+ elif config.host_os == "Darwin":
+ shared_libasan_path = os.path.join(
+ config.compiler_rt_libdir,
+ "libclang_rt.asan_{}_dynamic.dylib".format(config.apple_platform),
+ )
+ else:
+ lit_config.warning(
+ "%shared_libasan substitution not set but dynamic ASan is available."
+ )
+ shared_libasan_path = None
+
+ if shared_libasan_path is not None:
+ config.substitutions.append(("%shared_libasan", shared_libasan_path))
+ config.substitutions.append(
+ ("%clang_asan_static ", build_invocation(clang_asan_static_cflags))
+ )
+ config.substitutions.append(
+ ("%clangxx_asan_static ", build_invocation(clang_asan_static_cxxflags))
+ )
+
+if platform.system() == "Windows":
+ # MSVC-specific tests might also use the clang-cl.exe driver.
+ if target_is_msvc:
+ clang_cl_cxxflags = [
+ "-Wno-deprecated-declarations",
+ "-WX",
+ "-D_HAS_EXCEPTIONS=0",
+ "-Zi",
+ ] + target_cflags
+ clang_cl_asan_cxxflags = ["-fsanitize=address"] + clang_cl_cxxflags
+ if config.asan_dynamic:
+ clang_cl_asan_cxxflags.append("-MD")
+
+ clang_cl_invocation = build_invocation(clang_cl_cxxflags)
+ clang_cl_invocation = clang_cl_invocation.replace("clang.exe", "clang-cl.exe")
+ config.substitutions.append(("%clang_cl ", clang_cl_invocation))
+
+ clang_cl_asan_invocation = build_invocation(clang_cl_asan_cxxflags)
+ clang_cl_asan_invocation = clang_cl_asan_invocation.replace(
+ "clang.exe", "clang-cl.exe"
+ )
+ config.substitutions.append(("%clang_cl_asan ", clang_cl_asan_invocation))
+ config.substitutions.append(("%clang_cl_nocxx_asan ", clang_cl_asan_invocation))
+ config.substitutions.append(("%Od", "-Od"))
+ config.substitutions.append(("%Fe", "-Fe"))
+ config.substitutions.append(("%LD", "-LD"))
+ config.substitutions.append(("%MD", "-MD"))
+ config.substitutions.append(("%MT", "-MT"))
+ config.substitutions.append(("%Gw", "-Gw"))
+
+ base_lib = os.path.join(
+ config.compiler_rt_libdir, "clang_rt.asan%%s%s.lib" % config.target_suffix
+ )
+ config.substitutions.append(("%asan_lib", base_lib % ""))
+ config.substitutions.append(("%asan_cxx_lib", base_lib % "_cxx"))
+ config.substitutions.append(("%asan_dll_thunk", base_lib % "_dll_thunk"))
+ else:
+ # To make some of these tests work on MinGW target without changing their
+ # behaviour for MSVC target, substitute clang-cl flags with gcc-like ones.
+ config.substitutions.append(("%clang_cl ", build_invocation(target_cxxflags)))
+ config.substitutions.append(
+ ("%clang_cl_asan ", build_invocation(clang_asan_cxxflags))
+ )
+ config.substitutions.append(
+ ("%clang_cl_nocxx_asan ", build_invocation(clang_asan_cflags))
+ )
+ config.substitutions.append(("%Od", "-O0"))
+ config.substitutions.append(("%Fe", "-o"))
+ config.substitutions.append(("%LD", "-shared"))
+ config.substitutions.append(("%MD", ""))
+ config.substitutions.append(("%MT", ""))
+ config.substitutions.append(("%Gw", "-fdata-sections"))
# FIXME: De-hardcode this path.
asan_source_dir = os.path.join(
- get_required_attr(config, "compiler_rt_src_root"), "lib", "asan")
+ get_required_attr(config, "compiler_rt_src_root"), "lib", "asan"
+)
python_exec = shlex.quote(get_required_attr(config, "python_executable"))
# Setup path to asan_symbolize.py script.
asan_symbolize = os.path.join(asan_source_dir, "scripts", "asan_symbolize.py")
if not os.path.exists(asan_symbolize):
- lit_config.fatal("Can't find script on path %r" % asan_symbolize)
-config.substitutions.append( ("%asan_symbolize", python_exec + " " + asan_symbolize + " ") )
+ lit_config.fatal("Can't find script on path %r" % asan_symbolize)
+config.substitutions.append(
+ ("%asan_symbolize", python_exec + " " + asan_symbolize + " ")
+)
# Setup path to sancov.py script.
sanitizer_common_source_dir = os.path.join(
- get_required_attr(config, "compiler_rt_src_root"), "lib", "sanitizer_common")
+ get_required_attr(config, "compiler_rt_src_root"), "lib", "sanitizer_common"
+)
sancov = os.path.join(sanitizer_common_source_dir, "scripts", "sancov.py")
if not os.path.exists(sancov):
- lit_config.fatal("Can't find script on path %r" % sancov)
-config.substitutions.append( ("%sancov ", python_exec + " " + sancov + " ") )
+ lit_config.fatal("Can't find script on path %r" % sancov)
+config.substitutions.append(("%sancov ", python_exec + " " + sancov + " "))
# Determine kernel bitness
-if config.host_arch.find('64') != -1 and not config.android:
- kernel_bits = '64'
+if config.host_arch.find("64") != -1 and not config.android:
+ kernel_bits = "64"
else:
- kernel_bits = '32'
+ kernel_bits = "32"
-config.substitutions.append( ('CHECK-%kernel_bits', ("CHECK-kernel-" + kernel_bits + "-bits")))
+config.substitutions.append(
+ ("CHECK-%kernel_bits", ("CHECK-kernel-" + kernel_bits + "-bits"))
+)
-config.substitutions.append( ("%libdl", libdl_flag) )
+config.substitutions.append(("%libdl", libdl_flag))
config.available_features.add("asan-" + config.bits + "-bits")
# Fast unwinder doesn't work with Thumb
if not config.arm_thumb:
- config.available_features.add('fast-unwinder-works')
+ config.available_features.add("fast-unwinder-works")
# Turn on leak detection on 64-bit Linux.
-leak_detection_android = config.android and 'android-thread-properties-api' in config.available_features and (config.target_arch in ['x86_64', 'i386', 'i686', 'aarch64'])
-leak_detection_linux = (config.host_os == 'Linux') and (not config.android) and (config.target_arch in ['x86_64', 'i386', 'riscv64', 'loongarch64'])
-leak_detection_mac = (config.host_os == 'Darwin') and (config.apple_platform == 'osx')
-leak_detection_netbsd = (config.host_os == 'NetBSD') and (config.target_arch in ['x86_64', 'i386'])
-if leak_detection_android or leak_detection_linux or leak_detection_mac or leak_detection_netbsd:
- config.available_features.add('leak-detection')
+leak_detection_android = (
+ config.android
+ and "android-thread-properties-api" in config.available_features
+ and (config.target_arch in ["x86_64", "i386", "i686", "aarch64"])
+)
+leak_detection_linux = (
+ (config.host_os == "Linux")
+ and (not config.android)
+ and (config.target_arch in ["x86_64", "i386", "riscv64", "loongarch64"])
+)
+leak_detection_mac = (config.host_os == "Darwin") and (config.apple_platform == "osx")
+leak_detection_netbsd = (config.host_os == "NetBSD") and (
+ config.target_arch in ["x86_64", "i386"]
+)
+if (
+ leak_detection_android
+ or leak_detection_linux
+ or leak_detection_mac
+ or leak_detection_netbsd
+):
+ config.available_features.add("leak-detection")
# Set LD_LIBRARY_PATH to pick dynamic runtime up properly.
push_dynamic_library_lookup_path(config, config.compiler_rt_libdir)
# GCC-ASan uses dynamic runtime by default.
-if config.compiler_id == 'GNU':
- gcc_dir = os.path.dirname(config.clang)
- libasan_dir = os.path.join(gcc_dir, "..", "lib" + config.bits)
- push_dynamic_library_lookup_path(config, libasan_dir)
+if config.compiler_id == "GNU":
+ gcc_dir = os.path.dirname(config.clang)
+ libasan_dir = os.path.join(gcc_dir, "..", "lib" + config.bits)
+ push_dynamic_library_lookup_path(config, libasan_dir)
# Add the RT libdir to PATH directly so that we can successfully run the gtest
# binary to list its tests.
-if config.host_os == 'Windows' and config.asan_dynamic:
- os.environ['PATH'] = os.path.pathsep.join([config.compiler_rt_libdir,
- os.environ.get('PATH', '')])
+if config.host_os == "Windows" and config.asan_dynamic:
+ os.environ["PATH"] = os.path.pathsep.join(
+ [config.compiler_rt_libdir, os.environ.get("PATH", "")]
+ )
# Default test suffixes.
-config.suffixes = ['.c', '.cpp']
+config.suffixes = [".c", ".cpp"]
-if config.host_os == 'Darwin':
- config.suffixes.append('.mm')
+if config.host_os == "Darwin":
+ config.suffixes.append(".mm")
-if config.host_os == 'Windows':
- config.substitutions.append(('%fPIC', ''))
- config.substitutions.append(('%fPIE', ''))
- config.substitutions.append(('%pie', ''))
+if config.host_os == "Windows":
+ config.substitutions.append(("%fPIC", ""))
+ config.substitutions.append(("%fPIE", ""))
+ config.substitutions.append(("%pie", ""))
else:
- config.substitutions.append(('%fPIC', '-fPIC'))
- config.substitutions.append(('%fPIE', '-fPIE'))
- config.substitutions.append(('%pie', '-pie'))
+ config.substitutions.append(("%fPIC", "-fPIC"))
+ config.substitutions.append(("%fPIE", "-fPIE"))
+ config.substitutions.append(("%pie", "-pie"))
# Only run the tests on supported OSs.
-if config.host_os not in ['Linux', 'Darwin', 'FreeBSD', 'SunOS', 'Windows', 'NetBSD']:
- config.unsupported = True
+if config.host_os not in ["Linux", "Darwin", "FreeBSD", "SunOS", "Windows", "NetBSD"]:
+ config.unsupported = True
if not config.parallelism_group:
- config.parallelism_group = 'shadow-memory'
+ config.parallelism_group = "shadow-memory"
-if config.host_os == 'NetBSD':
- config.substitutions.insert(0, ('%run', config.netbsd_noaslr_prefix))
+if config.host_os == "NetBSD":
+ config.substitutions.insert(0, ("%run", config.netbsd_noaslr_prefix))