xref: /llvm-project/compiler-rt/test/profile/instrprof-groups.c (revision af58684f272046f293a9f469f03d23bd2b138349)
1 // RUN: %clang_pgogen -fprofile-function-groups=3 -fprofile-selected-function-group=0 %s -o %t.0.out
2 // RUN: %clang_pgogen -fprofile-function-groups=3 -fprofile-selected-function-group=1 %s -o %t.1.out
3 // RUN: %clang_pgogen -fprofile-function-groups=3 -fprofile-selected-function-group=2 %s -o %t.2.out
4 // RUN: env LLVM_PROFILE_FILE=%t.0.profraw %run %t.0.out
5 // RUN: env LLVM_PROFILE_FILE=%t.1.profraw %run %t.1.out
6 // RUN: env LLVM_PROFILE_FILE=%t.2.profraw %run %t.2.out
7 // RUN: llvm-profdata merge -o %t.profdata %t.*.profraw
8 // RUN: llvm-profdata show %t.profdata --all-functions | FileCheck %s
9 
foo(int i)10 int foo(int i) { return 4 * i + 1; }
bar(int i)11 int bar(int i) { return 4 * i + 2; }
goo(int i)12 int goo(int i) { return 4 * i + 3; }
13 
main(int argc,char * argv[])14 int main(int argc, char *argv[]) {
15   foo(5);
16   bar(6);
17   goo(7);
18   return 0;
19 }
20 
21 // Even though we ran this code three times, we expect all counts to be one if
22 // functions were partitioned into groups correctly.
23 
24 // CHECK: Counters: 1
25 // CHECK: Counters: 1
26 // CHECK: Counters: 1
27 // CHECK: Counters: 1
28 // CHECK: Total functions: 4
29