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