// RUN: %clang_pgogen -fprofile-function-groups=3 -fprofile-selected-function-group=0 %s -o %t.0.out // RUN: %clang_pgogen -fprofile-function-groups=3 -fprofile-selected-function-group=1 %s -o %t.1.out // RUN: %clang_pgogen -fprofile-function-groups=3 -fprofile-selected-function-group=2 %s -o %t.2.out // RUN: env LLVM_PROFILE_FILE=%t.0.profraw %run %t.0.out // RUN: env LLVM_PROFILE_FILE=%t.1.profraw %run %t.1.out // RUN: env LLVM_PROFILE_FILE=%t.2.profraw %run %t.2.out // RUN: llvm-profdata merge -o %t.profdata %t.*.profraw // RUN: llvm-profdata show %t.profdata --all-functions | FileCheck %s int foo(int i) { return 4 * i + 1; } int bar(int i) { return 4 * i + 2; } int goo(int i) { return 4 * i + 3; } int main(int argc, char *argv[]) { foo(5); bar(6); goo(7); return 0; } // Even though we ran this code three times, we expect all counts to be one if // functions were partitioned into groups correctly. // CHECK: Counters: 1 // CHECK: Counters: 1 // CHECK: Counters: 1 // CHECK: Counters: 1 // CHECK: Total functions: 4