| 1 | // RUN: %clangxx -O0 %s -o %t && %env_tool_opts=stack_trace_format=DEFAULT %run %t 2>&1 | FileCheck %s |
| 2 | // RUN: %clangxx -O3 %s -o %t && %env_tool_opts=stack_trace_format=DEFAULT %run %t 2>&1 | FileCheck %s |
| 3 | // RUN: %env_tool_opts=stack_trace_format=frame%n_lineno%l %run %t 2>&1 | FileCheck %s --check-prefix=CUSTOM |
| 4 | // RUN: %env_tool_opts=symbolize_inline_frames=false:stack_trace_format=DEFAULT %run %t 2>&1 | FileCheck %s --check-prefix=NOINLINE |
| 5 | // RUN: %env_tool_opts=stack_trace_format='"frame:%n address:%%p"' %run %t 2>&1 | FileCheck %s --check-prefix=NOSYMBOLIZE |
| 6 | |
| 7 | // UNSUPPORTED: darwin |
| 8 | |
| 9 | // TODO(yln): temporary failing due to refactoring |
| 10 | // UNSUPPORTED: ubsan |
| 11 | |
| 12 | #include <sanitizer/common_interface_defs.h> |
| 13 | |
| 14 | static inline void FooBarBaz() { |
| 15 | __sanitizer_print_stack_trace(); |
| 16 | } |
| 17 | |
| 18 | int main() { |
| 19 | FooBarBaz(); |
| 20 | return 0; |
| 21 | } |
| 22 | // CHECK: {{ #0 0x.* in __sanitizer_print_stack_trace}} |
| 23 | // CHECK: {{ #1 0x.* in FooBarBaz(\(\))? .*}}print-stack-trace.cpp:[[@LINE-8]] |
| 24 | // CHECK: {{ #2 0x.* in main.*}}print-stack-trace.cpp:[[@LINE-5]] |
| 25 | |
| 26 | // CUSTOM: frame1_lineno[[@LINE-11]] |
| 27 | // CUSTOM: frame2_lineno[[@LINE-8]] |
| 28 | |
| 29 | // NOINLINE: #0 0x{{.*}} in __sanitizer_print_stack_trace |
| 30 | // NOINLINE: #1 0x{{.*}} in main{{.*}}print-stack-trace.cpp:[[@LINE-15]] |
| 31 | |
| 32 | // NOSYMBOLIZE: frame:0 address:{{0x.*}} |
| 33 | // NOSYMBOLIZE: frame:1 address:{{0x.*}} |
| 34 | // NOSYMBOLIZE: frame:2 address:{{0x.*}} |
| 35 | |