aboutsummaryrefslogtreecommitdiff
path: root/llvm/test/tools/llvm-profdata/vtable-value-prof.test
blob: 5ed4a356e1041baa8b583b3f5d6465ceecc92c14 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
; RUN: rm -rf %t && mkdir %t

; Generate indexed profiles from text profiles
RUN: llvm-profdata merge --keep-vtable-symbols %S/Inputs/vtable-value-prof.proftext -o %t/indexed.profdata

; Show indexed profiles
RUN: llvm-profdata show --function=main --ic-targets --show-vtables %t/indexed.profdata | FileCheck %s --check-prefix=INDEXED

; Show text profiles
RUN: llvm-profdata show --function=main --ic-targets --show-vtables --text %S/Inputs/vtable-value-prof.proftext | FileCheck %s --check-prefix=ICTEXT

; Convert indexed profiles to its textual output and show it.
RUN: llvm-profdata merge --keep-vtable-symbols --text -o %t/text-from-indexed.proftext %t/indexed.profdata
RUN: llvm-profdata show --function=main --ic-targets --show-vtables %t/text-from-indexed.proftext | FileCheck %s --check-prefix=INDEXED
RUN: llvm-profdata show --function=main --ic-targets --show-vtables --text %t/text-from-indexed.proftext | FileCheck %s --check-prefix=ICTEXT

INDEXED:      Counters:
INDEXED-NEXT:   main:
INDEXED-NEXT:     Hash: 0x0f9a16fe6d398548
INDEXED-NEXT:     Counters: 2
INDEXED-NEXT:     Indirect Call Site Count: 2
INDEXED-NEXT:     Number of instrumented vtables: 2
INDEXED-NEXT:     Indirect Target Results:
INDEXED-NEXT:         [  0, {{.*}}vtable_prof.cc;_ZN12_GLOBAL__N_18Derived25func1Eii,        750 ] (75.00%)
INDEXED-NEXT:         [  0, _ZN8Derived15func1Eii,        250 ] (25.00%)
INDEXED-NEXT:         [  1, {{.*}}vtable_prof.cc;_ZN12_GLOBAL__N_18Derived25func2Eii,        750 ] (75.00%)
INDEXED-NEXT:         [  1, _ZN8Derived15func2Eii,        250 ] (25.00%)
INDEXED-NEXT:     VTable Results:
INDEXED-NEXT:         [  0, {{.*}}vtable_prof.cc;_ZTVN12_GLOBAL__N_18Derived2E,        750 ] (75.00%)
INDEXED-NEXT:         [  0, _ZTV8Derived1,        250 ] (25.00%)
INDEXED-NEXT:         [  1, {{.*}}vtable_prof.cc;_ZTVN12_GLOBAL__N_18Derived2E,        750 ] (75.00%)
INDEXED-NEXT:         [  1, _ZTV8Derived1,        250 ] (25.00%)
INDEXED-NEXT: Instrumentation level: IR  entry_first = 0
INDEXED-NEXT: Functions shown: 1
INDEXED-NEXT: Total functions: 6
INDEXED-NEXT: Maximum function count: 1000
INDEXED-NEXT: Maximum internal block count: 250
INDEXED-NEXT: Total number of blocks: 8
INDEXED-NEXT: Total count: 4001
INDEXED-NEXT: Statistics for indirect call sites profile:
INDEXED-NEXT:   Total number of sites: 2
INDEXED-NEXT:   Total number of sites with values: 2
INDEXED-NEXT:   Total number of profiled values: 4
INDEXED-NEXT:   Value sites histogram:
INDEXED-NEXT:       NumTargets, SiteCount
INDEXED-NEXT:       2, 2
INDEXED-NEXT: Statistics for vtable profile:
INDEXED-NEXT:   Total number of sites: 2
INDEXED-NEXT:   Total number of sites with values: 2
INDEXED-NEXT:   Total number of profiled values: 4
INDEXED-NEXT:   Value sites histogram:
INDEXED-NEXT:       NumTargets, SiteCount
INDEXED-NEXT:       2, 2

ICTEXT: :ir
ICTEXT: main
ICTEXT: # Func Hash:
ICTEXT: 1124236338992350536
ICTEXT: # Num Counters:
ICTEXT: 2
ICTEXT: # Counter Values:
ICTEXT: 1000
ICTEXT: 1
ICTEXT: # Num Value Kinds:
ICTEXT: 2
ICTEXT: # ValueKind = IPVK_IndirectCallTarget:
ICTEXT: 0
ICTEXT: # NumValueSites:
ICTEXT: 2
ICTEXT: 2
ICTEXT: {{.*}}vtable_prof.cc;_ZN12_GLOBAL__N_18Derived25func1Eii:750
ICTEXT: _ZN8Derived15func1Eii:250
ICTEXT: 2
ICTEXT: {{.*}}vtable_prof.cc;_ZN12_GLOBAL__N_18Derived25func2Eii:750
ICTEXT: _ZN8Derived15func2Eii:250
ICTEXT: # ValueKind = IPVK_VTableTarget:
ICTEXT: 2
ICTEXT: # NumValueSites:
ICTEXT: 2
ICTEXT: 2
ICTEXT: {{.*}}vtable_prof.cc;_ZTVN12_GLOBAL__N_18Derived2E:750
ICTEXT: _ZTV8Derived1:250
ICTEXT: 2
ICTEXT: {{.*}}vtable_prof.cc;_ZTVN12_GLOBAL__N_18Derived2E:750
ICTEXT: _ZTV8Derived1:250