1 | // Check atexit option. |
2 | |
3 | // RUN: %clangxx_memprof -O0 %s -o %t |
4 | // RUN: %env_memprof_opts=print_text=true:log_path=stderr:atexit=1 %run %t 2>&1 | FileCheck %s |
5 | // RUN: %env_memprof_opts=print_text=true:log_path=stderr:atexit=0 %run %t 2>&1 | FileCheck %s --check-prefix=NOATEXIT |
6 | |
7 | // CHECK: MemProfiler exit stats: |
8 | // CHECK: Stats: {{[0-9]+}}M malloced ({{[0-9]+}}M for overhead) by {{[0-9]+}} calls |
9 | // CHECK: Stats: {{[0-9]+}}M realloced by {{[0-9]+}} calls |
10 | // CHECK: Stats: {{[0-9]+}}M freed by {{[0-9]+}} calls |
11 | // CHECK: Stats: {{[0-9]+}}M really freed by {{[0-9]+}} calls |
12 | // CHECK: Stats: {{[0-9]+}}M ({{[0-9]+}}M-{{[0-9]+}}M) mmaped; {{[0-9]+}} maps, {{[0-9]+}} unmaps |
13 | // CHECK: mallocs by size class: |
14 | // CHECK: Stats: malloc large: {{[0-9]+}} |
15 | |
16 | // NOATEXIT-NOT: MemProfiler exit stats |
17 | |
18 | int main() { |
19 | return 0; |
20 | } |
21 | |