Support leak sanitizer in libcxx.

Support leak sanitizer in libcxx.

Simple addition for leak checking when running the libcxx testsuite.

Differential Revision: https://reviews.llvm.org/D100775
This commit is contained in:
Sterling Augustine 2021-04-19 10:56:25 -07:00
parent 0e83780325
commit fe15556077
2 changed files with 2 additions and 17 deletions

View File

@ -37,23 +37,6 @@ class CheckResult(gdb.Command):
compare_frame = gdb.newest_frame().older()
testcase_frame = compare_frame.older()
test_loc = testcase_frame.find_sal()
expectation_val = compare_frame.read_var("expectation")
check_literal = expectation_val.string(encoding="utf-8")
# Heuristic to determine if libc++ itself has debug
# info. If it doesn't, then anything normally homed there
# won't be found, and the printer will error. We don't
# want to fail the test in this case--the printer itself
# is probably fine, or at least we can't tell.
if check_literal.startswith("std::shared_ptr"):
shared_ptr = compare_frame.read_var("value")
if not "__shared_owners_" in shared_ptr.type.fields():
print("IGNORED (no debug info in libc++): " +
test_loc.symtab.filename + ":" +
str(test_loc.line))
return
# Use interactive commands in the correct context to get the pretty
# printed version

View File

@ -526,6 +526,8 @@ class Configuration(object):
self.config.available_features.add('sanitizer-new-delete')
elif san == 'DataFlow':
self.cxx.flags += ['-fsanitize=dataflow']
elif san == 'Leaks':
self.cxx.link_flags += ['-fsanitize=leaks']
else:
self.lit_config.fatal('unsupported value for '
'use_sanitizer: {0}'.format(san))