1REQUIRES: x86_64-linux
2
3The input raw profile test has been generated from the following source code:
4
5```
6#include <stdlib.h>
7#include <string.h>
8int main(int argc, char **argv) {
9  char *x = (char *)malloc(10);
10  memset(x, 0, 10);
11  free(x);
12  x = (char *)malloc(10);
13  memset(x, 0, 10);
14  free(x);
15  return 0;
16}
17```
18
19The following commands were used to compile the source to a memprof instrumented
20executable and collect a raw binary format profile. Since the profile contains
21virtual addresses for the callstack, we do not expect the raw binary profile to
22be deterministic. The summary should be deterministic apart from changes to
23the shared libraries linked in which could change the number of segments
24recorded.
25
26```
27clang -fuse-ld=lld -Wl,--no-rosegment -gmlt -fdebug-info-for-profiling \
28      -fmemory-profile -mno-omit-leaf-frame-pointer -fno-omit-frame-pointer \
29      -fno-optimize-sibling-calls -m64 -Wl,-build-id source.c -o basic.memprofexe
30
31env MEMPROF_OPTIONS=log_path=stdout ./rawprofile.out > basic.memprofraw
32```
33
34RUN: llvm-profdata show --memory %p/Inputs/basic.memprofraw --profiled-binary %p/Inputs/basic.memprofexe -o - | FileCheck %s
35
36We expect 3 MIB entries, 1 each for the malloc calls in the program and one
37additional entry from a realloc in glibc/libio/vasprintf.c.
38
39CHECK: MemprofProfile:
40CHECK-NEXT:   -
41CHECK-NEXT:   Header:
42CHECK-NEXT:     Version: 1
43CHECK-NEXT:     TotalSizeBytes: 1016
44CHECK-NEXT:     NumSegments: 9
45CHECK-NEXT:     NumMibInfo: 3
46CHECK-NEXT:     NumStackOffsets: 3
47CHECK-NEXT:   Records:
48CHECK-NEXT:   -
49CHECK-NEXT:     Callstack:
50CHECK-NEXT:     -
51CHECK-NEXT:       Function: {{[0-9]+}}
52CHECK-NEXT:       LineOffset: 73
53CHECK-NEXT:       Column: 3
54CHECK-NEXT:       Inline: 0
55CHECK-NEXT:     -
56CHECK-NEXT:       Function: {{[0-9]+}}
57CHECK-NEXT:       LineOffset: 0
58CHECK-NEXT:       Column: 0
59CHECK-NEXT:       Inline: 0
60CHECK-NEXT:     MemInfoBlock:
61CHECK-NEXT:       AllocCount: 1
62CHECK-NEXT:       TotalAccessCount: 0
63CHECK-NEXT:       MinAccessCount: 0
64CHECK-NEXT:       MaxAccessCount: 0
65CHECK-NEXT:       TotalSize: 53
66CHECK-NEXT:       MinSize: 53
67CHECK-NEXT:       MaxSize: 53
68CHECK-NEXT:       AllocTimestamp: 0
69CHECK-NEXT:       DeallocTimestamp: 987
70CHECK-NEXT:       TotalLifetime: 987
71CHECK-NEXT:       MinLifetime: 987
72CHECK-NEXT:       MaxLifetime: 987
73CHECK-NEXT:       AllocCpuId: 4294967295
74CHECK-NEXT:       DeallocCpuId: 56
75CHECK-NEXT:       NumMigratedCpu: 1
76CHECK-NEXT:       NumLifetimeOverlaps: 0
77CHECK-NEXT:       NumSameAllocCpu: 0
78CHECK-NEXT:       NumSameDeallocCpu: 0
79CHECK-NEXT:       DataTypeId: {{[0-9]+}}
80CHECK-NEXT:   -
81CHECK-NEXT:     Callstack:
82CHECK-NEXT:     -
83CHECK-NEXT:       Function: {{[0-9]+}}
84CHECK-NEXT:       LineOffset: 57
85CHECK-NEXT:       Column: 3
86CHECK-NEXT:       Inline: 0
87CHECK-NEXT:     -
88CHECK-NEXT:       Function: {{[0-9]+}}
89CHECK-NEXT:       LineOffset: 1
90CHECK-NEXT:       Column: 21
91CHECK-NEXT:       Inline: 0
92CHECK-NEXT:     -
93CHECK-NEXT:       Function: {{[0-9]+}}
94CHECK-NEXT:       LineOffset: 0
95CHECK-NEXT:       Column: 0
96CHECK-NEXT:       Inline: 0
97CHECK-NEXT:     MemInfoBlock:
98CHECK-NEXT:       AllocCount: 1
99CHECK-NEXT:       TotalAccessCount: 2
100CHECK-NEXT:       MinAccessCount: 2
101CHECK-NEXT:       MaxAccessCount: 2
102CHECK-NEXT:       TotalSize: 10
103CHECK-NEXT:       MinSize: 10
104CHECK-NEXT:       MaxSize: 10
105CHECK-NEXT:       AllocTimestamp: 986
106CHECK-NEXT:       DeallocTimestamp: 986
107CHECK-NEXT:       TotalLifetime: 0
108CHECK-NEXT:       MinLifetime: 0
109CHECK-NEXT:       MaxLifetime: 0
110CHECK-NEXT:       AllocCpuId: 56
111CHECK-NEXT:       DeallocCpuId: 56
112CHECK-NEXT:       NumMigratedCpu: 0
113CHECK-NEXT:       NumLifetimeOverlaps: 0
114CHECK-NEXT:       NumSameAllocCpu: 0
115CHECK-NEXT:       NumSameDeallocCpu: 0
116CHECK-NEXT:       DataTypeId: {{[0-9]+}}
117CHECK-NEXT:   -
118CHECK-NEXT:     Callstack:
119CHECK-NEXT:     -
120CHECK-NEXT:       Function: {{[0-9]+}}
121CHECK-NEXT:       LineOffset: 57
122CHECK-NEXT:       Column: 3
123CHECK-NEXT:       Inline: 0
124CHECK-NEXT:     -
125CHECK-NEXT:       Function: {{[0-9]+}}
126CHECK-NEXT:       LineOffset: 5
127CHECK-NEXT:       Column: 15
128CHECK-NEXT:       Inline: 0
129CHECK-NEXT:     -
130CHECK-NEXT:       Function: {{[0-9]+}}
131CHECK-NEXT:       LineOffset: 0
132CHECK-NEXT:       Column: 0
133CHECK-NEXT:       Inline: 0
134CHECK-NEXT:     MemInfoBlock:
135CHECK-NEXT:       AllocCount: 1
136CHECK-NEXT:       TotalAccessCount: 2
137CHECK-NEXT:       MinAccessCount: 2
138CHECK-NEXT:       MaxAccessCount: 2
139CHECK-NEXT:       TotalSize: 10
140CHECK-NEXT:       MinSize: 10
141CHECK-NEXT:       MaxSize: 10
142CHECK-NEXT:       AllocTimestamp: 987
143CHECK-NEXT:       DeallocTimestamp: 987
144CHECK-NEXT:       TotalLifetime: 0
145CHECK-NEXT:       MinLifetime: 0
146CHECK-NEXT:       MaxLifetime: 0
147CHECK-NEXT:       AllocCpuId: 56
148CHECK-NEXT:       DeallocCpuId: 56
149CHECK-NEXT:       NumMigratedCpu: 0
150CHECK-NEXT:       NumLifetimeOverlaps: 0
151CHECK-NEXT:       NumSameAllocCpu: 0
152CHECK-NEXT:       NumSameDeallocCpu: 0
153CHECK-NEXT:       DataTypeId: {{[0-9]+}}
154