[compiler-rt] r217487 - [asan-assembly-instrumentation] Added end-to-end test for proper stack unwind for functions with inline assembly.
Yuri Gorshenin
ygorshenin at google.com
Wed Sep 10 03:44:35 PDT 2014
Author: ygorshenin
Date: Wed Sep 10 05:44:35 2014
New Revision: 217487
URL: http://llvm.org/viewvc/llvm-project?rev=217487&view=rev
Log:
[asan-assembly-instrumentation] Added end-to-end test for proper stack unwind for functions with inline assembly.
Summary: [asan-assembly-instrumentation] Added end-to-end test for proper stack unwind for functions with inline assembly.
Reviewers: eugenis
Subscribers: llvm-commits
Differential Revision: http://reviews.llvm.org/D5260
Added:
compiler-rt/trunk/test/asan/TestCases/Linux/asan-asm-stacktrace-test.cc
Added: compiler-rt/trunk/test/asan/TestCases/Linux/asan-asm-stacktrace-test.cc
URL: http://llvm.org/viewvc/llvm-project/compiler-rt/trunk/test/asan/TestCases/Linux/asan-asm-stacktrace-test.cc?rev=217487&view=auto
==============================================================================
--- compiler-rt/trunk/test/asan/TestCases/Linux/asan-asm-stacktrace-test.cc (added)
+++ compiler-rt/trunk/test/asan/TestCases/Linux/asan-asm-stacktrace-test.cc Wed Sep 10 05:44:35 2014
@@ -0,0 +1,29 @@
+// Check that a stack unwinding algorithm works corretly even with the assembly
+// instrumentation.
+
+// REQUIRES: x86_64-supported-target,i386-supported-target
+// RUN: %clangxx_asan -g -O1 %s -fno-inline-functions -fno-omit-frame-pointer -mno-omit-leaf-frame-pointer -mllvm -asan-instrument-assembly -o %t && not %run %t 2>&1 | FileCheck %s
+// RUN: %clangxx_asan -g -O1 %s -fno-inline-functions -fomit-frame-pointer -momit-leaf-frame-pointer -mllvm -asan-instrument-assembly -o %t && not %run %t 2>&1 | FileCheck %s
+
+#include <cstddef>
+
+// CHECK: READ of size 4
+// CHECK: {{#0 0x[0-9a-fA-F]+ in foo}}
+// CHECK: {{#1 0x[0-9a-fA-F]+ in main}}
+
+__attribute__((noinline)) int foo(size_t n, int *buffer) {
+ int r;
+ __asm__("movl (%[buffer], %[n], 4), %[r] \n\t"
+ : [r] "=r"(r)
+ : [buffer] "r"(buffer), [n] "r"(n)
+ : "memory");
+ return r;
+}
+
+int main() {
+ const size_t n = 16;
+ int *buffer = new int[n];
+ foo(n, buffer);
+ delete[] buffer;
+ return 0;
+}
More information about the llvm-commits
mailing list