xref: /llvm-project/llvm/test/tools/llvm-profgen/pseudoprobe-decoding.test (revision 467652486f24b9f33eca7b4aaa6cb1e8ec6d18a7)
1aaa826faSWenlei He; RUN: llvm-profgen --format=text --perfscript=%s  --binary=%S/Inputs/inline-cs-pseudoprobe.perfbin --output=%t --show-pseudo-probe --show-disassembly-only | FileCheck %s
2734f4d83SHongtao Yu; RUN: llvm-profgen --format=text --perfscript=%s  --binary=%S/Inputs/inline-cs-pseudoprobe.perfbin --output=%t --show-pseudo-probe --show-disassembly-only --disassemble-functions=main,foo  | FileCheck %s -check-prefix=SYM
3b3154d11Swlei
4b3154d11SwleiPERF_RECORD_MMAP2 2854748/2854748: [0x400000(0x1000) @ 0 00:1d 123291722 526021]: r-xp /home/inline-cs-pseudoprobe.perfbin
5b3154d11Swlei
6b3154d11Swlei; CHECK: Pseudo Probe Desc:
7b3154d11Swlei; CHECK: GUID: 6699318081062747564 Name: foo
8bd524955SHongtao Yu; CHECK: Hash: 563088904013236
9b3154d11Swlei; CHECK: GUID: 15822663052811949562 Name: main
10bd524955SHongtao Yu; CHECK: Hash: 281479271677951
11b3154d11Swlei; CHECK: GUID: 16434608426314478903 Name: bar
12b3154d11Swlei; CHECK: Hash: 72617220756
13b3154d11Swlei
14b3154d11Swlei
15b3154d11Swlei
16b3154d11Swlei; CHECK:      <bar>:
17b3154d11Swlei
18b3154d11Swlei; CHECK:       [Probe]: FUNC: bar Index: 1  Type: Block
19bd524955SHongtao Yu; CHECK-NEXT:  [Probe]: FUNC: bar Index: 4  Type: Block
20*46765248Swlei; CHECK-NEXT:   201754: imull $2863311531, %edi, %eax
21b3154d11Swlei
22b3154d11Swlei; CHECK:      <foo>:
23b3154d11Swlei; CHECK:       [Probe]: FUNC: foo Index: 1  Type: Block
24b3154d11Swlei; CHECK-NEXT:  [Probe]: FUNC: foo Index: 2  Type: Block
25*46765248Swlei; CHECK-NEXT:   201770: movl  $1, %ecx
26b3154d11Swlei
27b3154d11Swlei; CHECK:       [Probe]: FUNC: foo Index: 5  Type: Block
28*46765248Swlei; CHECK-NEXT:    201780: addl  $30, %esi
29b3154d11Swlei; CHECK:       [Probe]: FUNC: foo Index: 6  Type: Block
30b3154d11Swlei; CHECK-NEXT:  [Probe]: FUNC: foo Index: 2  Type: Block
31*46765248Swlei; CHECK-NEXT:   201783: addl  $1, %ecx
32b3154d11Swlei
33b3154d11Swlei; CHECK:       [Probe]: FUNC: foo Index: 3  Type: Block
34*46765248Swlei; CHECK-NEXT:   20178e:	movl	%ecx, %edx
35b3154d11Swlei
36b3154d11Swlei; CHECK:       [Probe]: FUNC: foo Index: 4  Type: Block
37b3154d11Swlei; CHECK-NEXT:  [Probe]: FUNC: bar Index: 1  Type: Block  Inlined: @ foo:8
38bd524955SHongtao Yu; CHECK-NEXT:  [Probe]:	FUNC: bar Index: 4  Type: Block  Inlined: @ foo:8
39*46765248Swlei; CHECK-NEXT:   2017bf: addl  %ecx, %edx
40b3154d11Swlei
41b3154d11Swlei
42b3154d11Swlei; CHECK:       [Probe]: FUNC: foo Index: 6  Type: Block
43b3154d11Swlei; CHECK-NEXT:  [Probe]: FUNC: foo Index: 2  Type: Block
44*46765248Swlei; CHECK-NEXT:   2017cf:	addl	$1, %ecx
45b3154d11Swlei
46b3154d11Swlei; CHECK:       [Probe]: FUNC: foo Index: 7  Type: Block
47*46765248Swlei; CHECK-NEXT:   2017de: movl  $2098432, %edi
48b3154d11Swlei
49b3154d11Swlei; CHECK:       [Probe]: FUNC: foo Index: 9  Type: DirectCall
50*46765248Swlei; CHECK-NEXT:   2017e5: callq 0x201930
51b3154d11Swlei
52b3154d11Swlei
53b3154d11Swlei; CHECK:      <main>:
54b3154d11Swlei; CHECK:       [Probe]: FUNC: main Index: 1  Type: Block
55b3154d11Swlei; CHECK-NEXT:  [Probe]: FUNC: foo Index: 1  Type: Block  Inlined: @ main:2
56b3154d11Swlei; CHECK-NEXT:  [Probe]: FUNC: foo Index: 2  Type: Block  Inlined: @ main:2
57*46765248Swlei; CHECK-NEXT:   2017f0: movl  $1, %ecx
58b3154d11Swlei
59b3154d11Swlei; CHECK:       [Probe]: FUNC: foo Index: 5  Type: Block  Inlined: @ main:2
60*46765248Swlei; CHECK-NEXT:   201800: addl  $30, %esi
61b3154d11Swlei; CHECK:       [Probe]: FUNC: foo Index: 6  Type: Block  Inlined: @ main:2
62b3154d11Swlei; CHECK-NEXT:  [Probe]: FUNC: foo Index: 2  Type: Block  Inlined: @ main:2
63*46765248Swlei; CHECK-NEXT:   201803: addl  $1, %ecx
64b3154d11Swlei
65b3154d11Swlei; CHECK:       [Probe]: FUNC: foo Index: 3  Type: Block  Inlined: @ main:2
66*46765248Swlei; CHECK-NEXT:   20180e:	movl	%ecx, %edx
67b3154d11Swlei
68b3154d11Swlei; CHECK:       [Probe]: FUNC: foo Index: 4  Type: Block  Inlined: @ main:2
69b3154d11Swlei; CHECK-NEXT:  [Probe]: FUNC: bar Index: 1  Type: Block  Inlined: @ main:2 @ foo:8
70bd524955SHongtao Yu; CHECK-NEXT:  [Probe]:	FUNC: bar Index: 4  Type: Block  Inlined: @ main:2 @ foo:8
71*46765248Swlei; CHECK-NEXT:   20183f: addl  %ecx, %edx
72b3154d11Swlei
73b3154d11Swlei; CHECK:       [Probe]: FUNC: foo Index: 6  Type: Block  Inlined: @ main:2
74b3154d11Swlei; CHECK-NEXT:  [Probe]: FUNC: foo Index: 2  Type: Block  Inlined: @ main:2
75*46765248Swlei; CHECK-NEXT:   20184f: addl  $1, %ecx
76b3154d11Swlei
77b3154d11Swlei; CHECK:       [Probe]: FUNC: foo Index: 7  Type: Block  Inlined: @ main:2
78*46765248Swlei; CHECK-NEXT:   20185e: movl  $2098432, %edi
79b3154d11Swlei
80b3154d11Swlei; CHECK:       [Probe]: FUNC: foo Index: 9  Type: DirectCall  Inlined: @ main:2
81*46765248Swlei; CHECK-NEXT:   201865: callq 0x201930
82b3154d11Swlei
83734f4d83SHongtao Yu; SYM-NOT: <bar>:
84734f4d83SHongtao Yu; SYM: <foo>:
85734f4d83SHongtao Yu; SYM: <main>:
86734f4d83SHongtao Yu
87734f4d83SHongtao Yu
88b3154d11Swlei
8961d418f9SArthur Eubanks; clang -O3 -fuse-ld=lld -fpseudo-probe-for-profiling
90b3154d11Swlei; -fno-omit-frame-pointer -mno-omit-leaf-frame-pointer -Xclang -mdisable-tail-calls
91b3154d11Swlei; -g test.c  -o a.out
92b3154d11Swlei
93b3154d11Swlei#include <stdio.h>
94b3154d11Swlei
95b3154d11Swleiint bar(int x, int y) {
96b3154d11Swlei  if (x % 3) {
97b3154d11Swlei    return x - y;
98b3154d11Swlei  }
99b3154d11Swlei  return x + y;
100b3154d11Swlei}
101b3154d11Swlei
102b3154d11Swleivoid foo() {
103b3154d11Swlei  int s, i = 0;
104b3154d11Swlei  while (i++ < 4000 * 4000)
105b3154d11Swlei    if (i % 91) s = bar(i, s); else s += 30;
106b3154d11Swlei  printf("sum is %d\n", s);
107b3154d11Swlei}
108b3154d11Swlei
109b3154d11Swleiint main() {
110b3154d11Swlei  foo();
111b3154d11Swlei  return 0;
112b3154d11Swlei}
113