forked from OSchip/llvm-project
[Driver] Don't enable -fsanitize-use-after-scope when ASan is disabled
When enabling any sanitizer, -fsanitize-use-after-scope is enabled by default. This doesn't actually turn ASan on, because we've been getting lucky and there are extra checks in BackendUtil that stop this from happening. However, this has been causing a behavior change: extra lifetime markers are emitted in some cases where they aren't needed or expected. llvm-svn: 302468
This commit is contained in:
parent
d0c4676f39
commit
a9d8be68c1
|
@ -563,12 +563,11 @@ SanitizerArgs::SanitizerArgs(const ToolChain &TC,
|
|||
}
|
||||
}
|
||||
|
||||
if (Arg *A = Args.getLastArg(
|
||||
options::OPT_fsanitize_address_use_after_scope,
|
||||
options::OPT_fno_sanitize_address_use_after_scope)) {
|
||||
AsanUseAfterScope = A->getOption().getID() ==
|
||||
options::OPT_fsanitize_address_use_after_scope;
|
||||
}
|
||||
AsanUseAfterScope = Args.hasFlag(
|
||||
options::OPT_fsanitize_address_use_after_scope,
|
||||
options::OPT_fno_sanitize_address_use_after_scope, AsanUseAfterScope);
|
||||
} else {
|
||||
AsanUseAfterScope = false;
|
||||
}
|
||||
|
||||
// Parse -link-cxx-sanitizer flag.
|
||||
|
|
|
@ -30,7 +30,7 @@
|
|||
// RUN: %clang -target x86_64-pc-win32 -fsanitize-coverage=bb %s -### 2>&1 | FileCheck %s --check-prefix=CHECK-COVERAGE-WIN64
|
||||
// CHECK-COVERAGE-WIN64: "--dependent-lib={{[^"]*}}ubsan_standalone-x86_64.lib"
|
||||
|
||||
// RUN: %clang -target x86_64-linux-gnu -fsanitize=integer %s -### 2>&1 | FileCheck %s --check-prefix=CHECK-INTEGER
|
||||
// RUN: %clang -target x86_64-linux-gnu -fsanitize=integer %s -### 2>&1 | FileCheck %s --check-prefix=CHECK-INTEGER -implicit-check-not="-fsanitize-address-use-after-scope"
|
||||
// CHECK-INTEGER: "-fsanitize={{((signed-integer-overflow|unsigned-integer-overflow|integer-divide-by-zero|shift-base|shift-exponent),?){5}"}}
|
||||
|
||||
// RUN: %clang -fsanitize=bounds -### -fsyntax-only %s 2>&1 | FileCheck %s --check-prefix=CHECK-BOUNDS
|
||||
|
|
Loading…
Reference in New Issue