[compiler-rt] r216494 - [asan] add a test for poison_array_cookie=1

Kostya Serebryany kcc at google.com
Tue Aug 26 15:05:13 PDT 2014


Author: kcc
Date: Tue Aug 26 17:05:12 2014
New Revision: 216494

URL: http://llvm.org/viewvc/llvm-project?rev=216494&view=rev
Log:
[asan] add a test for poison_array_cookie=1

Added:
    compiler-rt/trunk/test/asan/TestCases/Linux/new_array_cookie_test.cc

Added: compiler-rt/trunk/test/asan/TestCases/Linux/new_array_cookie_test.cc
URL: http://llvm.org/viewvc/llvm-project/compiler-rt/trunk/test/asan/TestCases/Linux/new_array_cookie_test.cc?rev=216494&view=auto
==============================================================================
--- compiler-rt/trunk/test/asan/TestCases/Linux/new_array_cookie_test.cc (added)
+++ compiler-rt/trunk/test/asan/TestCases/Linux/new_array_cookie_test.cc Tue Aug 26 17:05:12 2014
@@ -0,0 +1,19 @@
+// REQUIRES: asan-64-bits
+// RUN: %clangxx_asan -O0 %s -o %t && not %run %t 2>&1 | FileCheck %s
+// RUN: %clangxx_asan -O3 %s -o %t && not %run %t 2>&1 | FileCheck %s
+// RUN: ASAN_OPTIONS=poison_array_cookie=1 not %run %t 2>&1  | FileCheck %s
+// RUN: ASAN_OPTIONS=poison_array_cookie=0 %run %t
+#include <stdio.h>
+struct C {
+  int x;
+  ~C() {fprintf(stderr, "ZZZZZZZZ\n");}
+};
+
+int main(int argc, char **argv) {
+  C *buffer = new C[argc];
+  buffer[-2].x = 10;
+// CHECK: AddressSanitizer: heap-buffer-overflow
+// CHECK: in main {{.*}}new_array_cookie_test.cc:[[@LINE-2]]
+// CHECK: is located 0 bytes inside of 12-byte region
+  delete [] buffer;
+}





More information about the llvm-commits mailing list