diff options
| author | Naomi Musgrave <nmusgrave@google.com> | 2015-08-03 23:01:19 +0000 |
|---|---|---|
| committer | Naomi Musgrave <nmusgrave@google.com> | 2015-08-03 23:01:19 +0000 |
| commit | 2551b62931a96d010086d2f29c33db27bffac134 (patch) | |
| tree | 5b43400966710ecbd32dea833623880658ccc839 | |
| parent | bb4df94faa8cb027fb76d17ff7145f98700bac0a (diff) | |
| download | bcm5719-llvm-2551b62931a96d010086d2f29c33db27bffac134.tar.gz bcm5719-llvm-2551b62931a96d010086d2f29c33db27bffac134.zip | |
Runtime check of poisoning derived class members.
Summary: Simple test case to verify that an instance of a derived class with virtual base is properly poisoned
Reviewers: eugenis, kcc
Subscribers: cfe-commits
Differential Revision: http://reviews.llvm.org/D11733
modified test to be more concise, and check the local pointer to the destroyed object
revised test to not examine padding- only explicit object members
llvm-svn: 243913
| -rw-r--r-- | compiler-rt/test/msan/dtor-derived-class.cc | 47 |
1 files changed, 47 insertions, 0 deletions
diff --git a/compiler-rt/test/msan/dtor-derived-class.cc b/compiler-rt/test/msan/dtor-derived-class.cc new file mode 100644 index 00000000000..ed8122f8b70 --- /dev/null +++ b/compiler-rt/test/msan/dtor-derived-class.cc @@ -0,0 +1,47 @@ + +// RUN: %clangxx_msan %s -fsanitize=memory -fsanitize-memory-use-after-dtor -o %t && MSAN_OPTIONS=poison_in_dtor=1 %run %t >%t.out 2>&1 + +// RUN: %clangxx_msan %s -O1 -fsanitize=memory -fsanitize-memory-use-after-dtor -o %t && MSAN_OPTIONS=poison_in_dtor=1 %run %t >%t.out 2>&1 + +// RUN: %clangxx_msan %s -O2 -fsanitize=memory -fsanitize-memory-use-after-dtor -o %t && MSAN_OPTIONS=poison_in_dtor=1 %run %t >%t.out 2>&1 + +#include <stdio.h> +#include <sanitizer/msan_interface.h> +#include <assert.h> + +struct Base { + int x; + Base() { + x = 5; + } + virtual ~Base() { } +}; + +struct Derived:public Base { + int y; + Derived() { + y = 10; + } + ~Derived() { } +}; + +int main() { + Derived *d = new Derived(); + d->~Derived(); + + // Verify that local pointer is unpoisoned, and that the object's + // members are. + assert(__msan_test_shadow(&d, sizeof(d)) == -1); + assert(__msan_test_shadow(&d->x, sizeof(d->x)) != -1); + assert(__msan_test_shadow(&d->y, sizeof(d->y)) != -1); + + Base *b = new Derived(); + b->~Base(); + + // Verify that local pointer is unpoisoned, and thate the object's + // members are. + assert(__msan_test_shadow(&b, sizeof(b)) == -1); + assert(__msan_test_shadow(&b->x, sizeof(b->x)) != -1); + + return 0; +} |

