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
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
|
; RUN: llvm-profgen --format=text --use-dwarf-correlation --perfscript=%S/Inputs/coff-profile.perfscript --binary=%S/Inputs/coff-profile.exe --output=%t
; RUN: FileCheck %s --input-file %t --check-prefix=DWARF
; RUN: llvm-profgen --format=text --perfscript=%S/Inputs/coff-profile.perfscript --binary=%S/Inputs/coff-profile.exe --output=%t
; RUN: FileCheck %s --input-file %t --check-prefix=PROBE
DWARF: main:31341:0
DWARF-NEXT: 0: 0
DWARF-NEXT: 3: 0
DWARF-NEXT: 3.1: 0
DWARF-NEXT: 3.2: 0
DWARF-NEXT: 8: 0
DWARF-NEXT: 65501: 0
DWARF-NEXT: 1: ??$init@HG@MyNameSpace2@@YAXHPEAG@Z:0
DWARF-NEXT: 1: 0
DWARF-NEXT: 1.1: 0
DWARF-NEXT: 1.2: 0
DWARF-NEXT: 2: 0
DWARF-NEXT: 65514: 0
DWARF-NEXT: 4: ?work1@?$MyClass@GH@MyNameSpace1@@QEAAXQEAGH@Z:3038
DWARF-NEXT: 0: ?work@?$MyClass@GH@MyNameSpace1@@AEAAXQEAGHH@Z:3038
DWARF-NEXT: 1.1: 31
DWARF-NEXT: 1.2: 31
DWARF-NEXT: 2: 31
DWARF-NEXT: 3: 31
DWARF-NEXT: 5: ?work2@?$MyClass@GH@MyNameSpace1@@QEAAXQEAGH@Z:28303
DWARF-NEXT: 0: ?work@?$MyClass@GH@MyNameSpace1@@AEAAXQEAGHH@Z:28303
DWARF-NEXT: 1.1: 341
DWARF-NEXT: 1.2: 341
DWARF-NEXT: 2: 341
DWARF-NEXT: 3: 341
DWARF-NEXT: 7: ?print@MyNameSpace2@@YAXPEAGH@Z:0
DWARF-NEXT: 1: 0
PROBE: main:1116:0
PROBE-NEXT: 1: 0
PROBE-NEXT: 3: 0
PROBE-NEXT: 4: 0
PROBE-NEXT: 5: 0
PROBE-NEXT: 8: 0
PROBE-NEXT: 9: 0
PROBE-NEXT: 2: ??$init@HG@MyNameSpace2@@YAXHPEAG@Z:0
PROBE-NEXT: 1: 0
PROBE-NEXT: 2: 0
PROBE-NEXT: 3: 0
PROBE-NEXT: 4: 0
PROBE-NEXT: 5: 0
PROBE-NEXT: 6: 0
PROBE-NEXT: !CFGChecksum: 107105011060
PROBE-NEXT: 6: ?work1@?$MyClass@GH@MyNameSpace1@@QEAAXQEAGH@Z:93
PROBE-NEXT: 1: 0
PROBE-NEXT: 2: ?work@?$MyClass@GH@MyNameSpace1@@AEAAXQEAGHH@Z:93
PROBE-NEXT: 1: 0
PROBE-NEXT: 2: 31
PROBE-NEXT: 4: 31
PROBE-NEXT: 5: 31
PROBE-NEXT: !CFGChecksum: 107105011060
PROBE-NEXT: !CFGChecksum: 281479271677951
PROBE-NEXT: 7: ?work2@?$MyClass@GH@MyNameSpace1@@QEAAXQEAGH@Z:1023
PROBE-NEXT: 2: ?work@?$MyClass@GH@MyNameSpace1@@AEAAXQEAGHH@Z:1023
PROBE-NEXT: 2: 341
PROBE-NEXT: 3: 0
PROBE-NEXT: 4: 341
PROBE-NEXT: 5: 341
PROBE-NEXT: 6: 0
PROBE-NEXT: !CFGChecksum: 107105011060
PROBE-NEXT: !CFGChecksum: 281479271677951
PROBE-NEXT: 10: ?print@MyNameSpace2@@YAXPEAGH@Z:0
PROBE-NEXT: 1: 0
PROBE-NEXT: 2: 0
PROBE-NEXT: !CFGChecksum: 281479271677951
PROBE-NEXT: !CFGChecksum: 1126005794311845
; Original code
; clang-cl.exe -O2 -gdwarf -gline-tables-only -fpseudo-probe-for-profiling coff-profile.cpp -fuse-ld=lld -Xclang -fdebug-info-for-profiling -link -debug:dwarf
#include <stdio.h>
namespace MyNameSpace1 {
template <typename T1, typename T2> class MyClass {
void work(T1 map[], T2 n, T2 m) {
for (int i = 1; i < n; i++) {
map[i] = map[i - 1] * map[i - 1];
map[i] += (i * map[i - 1]) / m + i % m;
}
}
public:
void work1(T1 map[], T2 n) { work(map, n, 7); }
void work2(T1 map[], T2 n) { work(map, n, 3); }
};
} // namespace MyNameSpace1
namespace MyNameSpace2 {
template <typename T1, typename T2> void init(T1 c, T2 *p) {
for (int i = 0; i < c * 1000000; i++) {
p[i] = i / 3 + (i * i) % 3;
}
}
void print(unsigned short *p, int i) {
printf("%d %d %d\n", p[i * i * 100], p[i * i * 100 + 1], p[i * i * 100 + 2]);
}
} // namespace MyNameSpace2
unsigned short M[3000000];
int main(int argc, char *argv[]) {
MyNameSpace2::init(argc, M);
MyNameSpace1::MyClass<unsigned short, int> Obj;
for (int i = 0; i <= argc * 10; i++) {
Obj.work1(&M[argc], argc * 100000);
Obj.work2(&M[argc * argc], argc * 1000000);
}
MyNameSpace2::print(M, argc);
return 0;
}
|