summaryrefslogtreecommitdiffstats
path: root/compiler-rt/test/sanitizer_common/lit.common.cfg
diff options
context:
space:
mode:
authorAlexey Samsonov <samsonov@google.com>2014-05-09 00:28:18 +0000
committerAlexey Samsonov <samsonov@google.com>2014-05-09 00:28:18 +0000
commit0bef819f9f2bf02baa05b1f8d698f25ab63c6012 (patch)
tree66ee6c82cc7b439e639de500c6ea764be423808a /compiler-rt/test/sanitizer_common/lit.common.cfg
parent14048090026bbb098a1913a44cb0573dbdad27ee (diff)
downloadbcm5719-llvm-0bef819f9f2bf02baa05b1f8d698f25ab63c6012.tar.gz
bcm5719-llvm-0bef819f9f2bf02baa05b1f8d698f25ab63c6012.zip
[Sanitizer] Add the machinery to run the same test under several sanitizers
llvm-svn: 208378
Diffstat (limited to 'compiler-rt/test/sanitizer_common/lit.common.cfg')
-rw-r--r--compiler-rt/test/sanitizer_common/lit.common.cfg30
1 files changed, 30 insertions, 0 deletions
diff --git a/compiler-rt/test/sanitizer_common/lit.common.cfg b/compiler-rt/test/sanitizer_common/lit.common.cfg
new file mode 100644
index 00000000000..86c9d33d90d
--- /dev/null
+++ b/compiler-rt/test/sanitizer_common/lit.common.cfg
@@ -0,0 +1,30 @@
+# -*- Python -*-
+
+# Setup source root.
+config.test_source_root = os.path.join(os.path.dirname(__file__), "TestCases")
+
+config.name = "SanitizerCommon-" + config.tool_name
+
+if config.tool_name == "asan":
+ tool_cflags = ["-fsanitize=address"]
+elif config.tool_name == "tsan":
+ tool_cflags = ["-fsanitize=thread"]
+elif config.tool_name == "msan":
+ tool_cflags = ["-fsanitize=memory"]
+else:
+ lit_config.fatal("Unknown tool for sanitizer_common tests: %r" % config.tool_name)
+
+clang_cflags = ["-g"] + tool_cflags
+clang_cxxflags = config.cxx_mode_flags + clang_cflags
+
+def build_invocation(compile_flags):
+ return " " + " ".join([config.clang] + compile_flags) + " "
+
+config.substitutions.append( ("%clang ", build_invocation(clang_cflags)) )
+config.substitutions.append( ("%clangxx ", build_invocation(clang_cxxflags)) )
+
+config.suffixes = ['.c', '.cc', '.cpp']
+
+if config.host_os not in ['Linux', 'Darwin']:
+ config.unsupported = True
+
OpenPOWER on IntegriCloud