[PATCH] D23676: [asan] Add one more test for __asan_set_shadow_*

Vitaly Buka via llvm-commits llvm-commits at lists.llvm.org
Thu Aug 18 10:31:16 PDT 2016


vitalybuka created this revision.
vitalybuka added reviewers: eugenis, filcab.
vitalybuka added a subscriber: llvm-commits.
Herald added a subscriber: kubabrecka.

https://reviews.llvm.org/D23676

Files:
  test/asan/TestCases/set_shadow_test.c

Index: test/asan/TestCases/set_shadow_test.c
===================================================================
--- /dev/null
+++ test/asan/TestCases/set_shadow_test.c
@@ -0,0 +1,61 @@
+// RUN: %clang_asan -O0 %s -o %t
+// RUN: %run %t 0x00 2>&1 | FileCheck %s -check-prefix=X00
+// RUN: not %run %t 0xf1 2>&1 | FileCheck %s -check-prefix=XF1
+// R1UN: not %run %t 0xf2 2>&1 | FileCheck %s -check-prefix=XF2
+// R1UN: not %run %t 0xf3 2>&1 | FileCheck %s -check-prefix=XF3
+// R1UN: not %run %t 0xf5 2>&1 | FileCheck %s -check-prefix=XF5
+// R1UN: not %run %t 0xf8 2>&1 | FileCheck %s -check-prefix=XF8
+
+#include <assert.h>
+#include <stddef.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <sanitizer/asan_interface.h>
+
+void __asan_set_shadow_00(size_t addr, size_t size);
+void __asan_set_shadow_f1(size_t addr, size_t size);
+void __asan_set_shadow_f2(size_t addr, size_t size);
+void __asan_set_shadow_f3(size_t addr, size_t size);
+void __asan_set_shadow_f5(size_t addr, size_t size);
+void __asan_set_shadow_f8(size_t addr, size_t size);
+
+char a __attribute__((aligned(8)));
+
+void f(long arg) {
+  size_t shadow_offset;
+  size_t shadow_scale;
+  __asan_get_shadow_mapping(&shadow_scale, &shadow_offset);
+  size_t addr = (((size_t)&a) >> shadow_scale) + shadow_offset;
+
+  switch (arg) {
+      // X00-NOT: AddressSanitizer
+      // X00: PASS
+      case 0x00: return __asan_set_shadow_00(addr, 1);
+      // XF1: AddressSanitizer: stack-buffer-underflow
+      // XF1: [f1]
+      case 0xf1: return __asan_set_shadow_f1(addr, 1);
+      // XF2: AddressSanitizer: stack-buffer-overflow
+      // XF2: [f2]
+      case 0xf2: return __asan_set_shadow_f2(addr, 1);
+      // XF3: AddressSanitizer: stack-buffer-overflow
+      // XF3: [f3]
+      case 0xf3: return __asan_set_shadow_f3(addr, 1);
+      // XF5: AddressSanitizer: stack-use-after-return
+      // XF5: [f5]
+      case 0xf5: return __asan_set_shadow_f5(addr, 1);
+      // XF8: AddressSanitizer: stack-use-after-scope
+      // XF8: [f8]
+      case 0xf8: return __asan_set_shadow_f8(addr, 1);
+  }
+  assert(0);
+}
+
+int main(int argc, char **argv) {
+  assert(argc > 1);
+  
+  long arg = strtol(argv[1], 0, 16);
+  f(arg);
+  a = 1;
+  printf("PASS\n");
+  return 0;
+}


-------------- next part --------------
A non-text attachment was scrubbed...
Name: D23676.68562.patch
Type: text/x-patch
Size: 2259 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20160818/74c8d891/attachment.bin>


More information about the llvm-commits mailing list