diff options
author | Naomi Musgrave <nmusgrave@google.com> | 2015-07-30 18:46:18 +0000 |
---|---|---|
committer | Naomi Musgrave <nmusgrave@google.com> | 2015-07-30 18:46:18 +0000 |
commit | 64a1bd9db87d61c25be94bc24a3caabd313e3e61 (patch) | |
tree | 12b1b756b78ec4fd80e5602f0257d2fbc22e6a13 | |
parent | a6438ca12a72efe147e74b6ea4698f696f52b969 (diff) | |
download | bcm5719-llvm-64a1bd9db87d61c25be94bc24a3caabd313e3e61.tar.gz bcm5719-llvm-64a1bd9db87d61c25be94bc24a3caabd313e3e61.zip |
testing for tail call optimization repression when sanitizing use-after-dtor
Summary: Verify that running in optimized mode while checking for use-after-dtor errors, does not generate tail call invocation of destructor. This avoids possible error where stack frame for the destructor is eliminated, making tracking down the errors more difficult.
Reviewers: eugenis, kcc
Subscribers: cfe-commits
Differential Revision: http://reviews.llvm.org/D11614
simplified test cases
updated line numbering on test
renamed test
llvm-svn: 243675
-rw-r--r-- | compiler-rt/test/msan/use-after-dtor.cc | 45 |
1 files changed, 45 insertions, 0 deletions
diff --git a/compiler-rt/test/msan/use-after-dtor.cc b/compiler-rt/test/msan/use-after-dtor.cc new file mode 100644 index 00000000000..6c751a14f37 --- /dev/null +++ b/compiler-rt/test/msan/use-after-dtor.cc @@ -0,0 +1,45 @@ +// RUN: %clangxx_msan %s -fsanitize=memory -fsanitize-memory-use-after-dtor -o %t && MSAN_OPTIONS=poison_in_dtor=1 not %run %t >%t.out 2>&1 +// RUN: FileCheck %s < %t.out + +// RUN: %clangxx_msan %s -O1 -fsanitize=memory -fsanitize-memory-use-after-dtor -o %t && MSAN_OPTIONS=poison_in_dtor=1 not %run %t >%t.out 2>&1 +// RUN: FileCheck %s < %t.out + +// RUN: %clangxx_msan %s -O2 -fsanitize=memory -fsanitize-memory-use-after-dtor -o %t && MSAN_OPTIONS=poison_in_dtor=1 not %run %t >%t.out 2>&1 +// RUN: FileCheck %s < %t.out + +// RUN: %clangxx_msan %s -O1 -fsanitize=memory -fsanitize-memory-use-after-dtor -fsanitize-memory-track-origins -o %t && MSAN_OPTIONS=poison_in_dtor=1 not %run %t >%t.out 2>&1 +// RUN: FileCheck %s --check-prefix=CHECK-ORIGINS < %t.out + +#include <sanitizer/msan_interface.h> +#include <assert.h> +#include <stdio.h> +#include <new> + +struct Simple { + int x_; + Simple() { + x_ = 5; + } + ~Simple() { + x_ += 1; + } +}; + +int main() { + unsigned long buf[1]; + assert(sizeof(Simple) <= sizeof(buf)); + + Simple *s = new(&buf) Simple(); + s->~Simple(); + + return s->x_; + + // CHECK: WARNING: MemorySanitizer: use-of-uninitialized-value + // CHECK: {{#0 0x.* in main.*use-after-dtor.cc:}}[[@LINE-3]] + + // CHECK-ORIGINS: Memory was marked as uninitialized + // CHECK-ORIGINS: {{#0 0x.* in __sanitizer_dtor_callback}} + // CHECK-ORIGINS: {{#1 0x.* in Simple::~Simple}} + + // CHECK: SUMMARY: MemorySanitizer: use-of-uninitialized-value {{.*main}} +} |