2013-03-26 16:01:37 +08:00
|
|
|
// Check that __asan_poison_memory_region works.
|
2014-05-01 05:34:17 +08:00
|
|
|
// RUN: %clangxx_asan -O0 %s -o %t && not %run %t 2>&1 | FileCheck %s
|
2013-03-26 16:01:37 +08:00
|
|
|
//
|
|
|
|
// Check that we can disable it
|
2015-08-13 07:50:12 +08:00
|
|
|
// RUN: %env_asan_opts=allow_user_poisoning=0 %run %t
|
2013-03-26 16:01:37 +08:00
|
|
|
|
|
|
|
#include <stdlib.h>
|
|
|
|
|
|
|
|
extern "C" void __asan_poison_memory_region(void *, size_t);
|
|
|
|
|
|
|
|
int main(int argc, char **argv) {
|
|
|
|
char *x = new char[16];
|
2013-04-04 19:17:14 +08:00
|
|
|
x[10] = 0;
|
2013-03-26 16:01:37 +08:00
|
|
|
__asan_poison_memory_region(x, 16);
|
|
|
|
int res = x[argc * 10]; // BOOOM
|
|
|
|
// CHECK: ERROR: AddressSanitizer: use-after-poison
|
|
|
|
// CHECK: main{{.*}}use-after-poison.cc:[[@LINE-2]]
|
|
|
|
delete [] x;
|
|
|
|
return res;
|
|
|
|
}
|