[compiler-rt] r342011 - [hwasan] tests for a buffer overflow with a large allocation

Kostya Serebryany via llvm-commits llvm-commits at lists.llvm.org
Tue Sep 11 17:27:34 PDT 2018


Author: kcc
Date: Tue Sep 11 17:27:34 2018
New Revision: 342011

URL: http://llvm.org/viewvc/llvm-project?rev=342011&view=rev
Log:
[hwasan] tests for a buffer overflow with a large allocation

Modified:
    compiler-rt/trunk/test/hwasan/TestCases/heap-buffer-overflow.c

Modified: compiler-rt/trunk/test/hwasan/TestCases/heap-buffer-overflow.c
URL: http://llvm.org/viewvc/llvm-project/compiler-rt/trunk/test/hwasan/TestCases/heap-buffer-overflow.c?rev=342011&r1=342010&r2=342011&view=diff
==============================================================================
--- compiler-rt/trunk/test/hwasan/TestCases/heap-buffer-overflow.c (original)
+++ compiler-rt/trunk/test/hwasan/TestCases/heap-buffer-overflow.c Tue Sep 11 17:27:34 2018
@@ -2,6 +2,8 @@
 // RUN: not %run %t 40 2>&1 | FileCheck %s --check-prefix=CHECK40
 // RUN: not %run %t 80 2>&1 | FileCheck %s --check-prefix=CHECK80
 // RUN: not %run %t -30 2>&1 | FileCheck %s --check-prefix=CHECKm30
+// RUN: not %run %t -30 1000000 2>&1 | FileCheck %s --check-prefix=CHECKMm30
+// RUN: not %run %t 1000000 1000000 2>&1 | FileCheck %s --check-prefix=CHECKM
 
 // REQUIRES: stable-runtime
 
@@ -12,10 +14,13 @@
 int main(int argc, char **argv) {
   __hwasan_enable_allocator_tagging();
   int offset = argc < 2 ? 40 : atoi(argv[1]);
-  char * volatile x = (char*)malloc(30);
+  int size = argc < 3 ? 30 : atoi(argv[2]);
+  char * volatile x = (char*)malloc(size);
   x[offset] = 42;
 // CHECK40: is located 10 bytes to the right of 30-byte region
 // CHECK80: is located 50 bytes to the right of 30-byte region
 // CHECKm30: is located 30 bytes to the left of 30-byte region
+// CHECKMm30: is located 30 bytes to the left of 1000000-byte region
+// CHECKM: is located 0 bytes to the right of 1000000-byte region
   free(x);
 }




More information about the llvm-commits mailing list