1 // RUN: %clangxx_msan -fsanitize-memory-track-origins=2 -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