Home | History | Annotate | Download | only in msan
      1 // RUN: %clangxx_msan -fsanitize-memory-track-origins=2 -m64 -O3 %s -o %t && \
      2 // RUN:     MSAN_OPTIONS=store_context_size=1 not %run %t 2>&1 | FileCheck %s
      3 
      4 // Test that stack trace for the intermediate store is not empty.
      5 
      6 // CHECK: MemorySanitizer: use-of-uninitialized-value
      7 // CHECK:   #0 {{.*}} in main
      8 
      9 // CHECK: Uninitialized value was stored to memory at
     10 // CHECK:   #0 {{.*}} in fn_g
     11 // CHECK-NOT: #1
     12 
     13 // CHECK: Uninitialized value was created by an allocation of 'z' in the stack frame of function 'main'
     14 // CHECK:   #0 {{.*}} in main
     15 
     16 #include <stdio.h>
     17 
     18 volatile int x;
     19 
     20 __attribute__((noinline))
     21 void fn_g(int a) {
     22   x = a;
     23 }
     24 
     25 __attribute__((noinline))
     26 void fn_f(int a) {
     27   fn_g(a);
     28 }
     29 
     30 int main(int argc, char *argv[]) {
     31   int volatile z;
     32   fn_f(z);
     33   return x;
     34 }
     35