| 1 | // RUN: rm -fr %t.promo.prof |
| 2 | // RUN: rm -fr %t.nopromo.prof |
| 3 | // RUN: %clang_pgogen=%t.promo.prof/ -o %t.promo.gen -O2 %s -fno-slp-vectorize |
| 4 | // RUN: %clang_pgogen=%t.promo.prof/ -o %t.promo.gen.ll -emit-llvm -S -O2 %s -fno-slp-vectorize |
| 5 | // RUN: cat %t.promo.gen.ll | FileCheck --check-prefix=PROMO %s |
| 6 | // RUN: %run %t.promo.gen |
| 7 | // RUN: llvm-profdata merge -o %t.promo.profdata %t.promo.prof/ |
| 8 | // RUN: llvm-profdata show --counts --all-functions %t.promo.profdata > %t.promo.dump |
| 9 | // RUN: %clang_pgogen=%t.nopromo.prof/ -mllvm -do-counter-promotion=false -mllvm -simplifycfg-sink-common=false -o %t.nopromo.gen -O2 %s -fno-slp-vectorize |
| 10 | // RUN: %clang_pgogen=%t.nopromo.prof/ -mllvm -do-counter-promotion=false -mllvm -simplifycfg-sink-common=false -o %t.nopromo.gen.ll -emit-llvm -S -O2 %s -fno-slp-vectorize |
| 11 | // RUN: cat %t.nopromo.gen.ll | FileCheck --check-prefix=NOPROMO %s |
| 12 | // RUN: %run %t.nopromo.gen |
| 13 | // RUN: llvm-profdata merge -o %t.nopromo.profdata %t.nopromo.prof/ |
| 14 | // RUN: llvm-profdata show --counts --all-functions %t.nopromo.profdata > %t.nopromo.dump |
| 15 | // RUN: llvm-profdata show %t.promo.profdata > %t.promo.dump |
| 16 | // RUN: llvm-profdata show %t.nopromo.profdata > %t.nopromo.dump |
| 17 | // RUN: diff %t.promo.dump %t.nopromo.dump |
| 18 | int g; |
| 19 | __attribute__((noinline)) void bar(int i) { g += i; } |
| 20 | __attribute__((noinline)) void foo(int n, int N) { |
| 21 | // PROMO-LABEL: @foo |
| 22 | // PROMO: load{{.*}}@__profc_foo, align |
| 23 | // PROMO-NEXT: add |
| 24 | // PROMO-NEXT: store{{.*}}@__profc_foo, align |
| 25 | // PROMO-NEXT: load{{.*}}@__profc_foo{{.*}} 8){{.*}} |
| 26 | // PROMO-NEXT: add |
| 27 | // PROMO-NEXT: store{{.*}}@__profc_foo{{.*}} 8){{.*}} |
| 28 | // PROMO-NEXT: load{{.*}}@__profc_foo{{.*}} 16){{.*}} |
| 29 | // PROMO-NEXT: add |
| 30 | // PROMO-NEXT: store{{.*}}@__profc_foo{{.*}} 16){{.*}} |
| 31 | // |
| 32 | // NOPROMO-LABEL: @foo |
| 33 | // NOPROMO: load{{.*}}@__profc_foo, align |
| 34 | // NOPROMO-NEXT: add |
| 35 | // NOPROMO-NEXT: store{{.*}}@__profc_foo, align |
| 36 | // NOPROMO: load{{.*}}@__profc_foo{{.*}} 8){{.*}} |
| 37 | // NOPROMO-NEXT: add |
| 38 | // NOPROMO-NEXT: store{{.*}}@__profc_foo{{.*}} 8){{.*}} |
| 39 | // NOPROMO: load{{.*}}@__profc_foo{{.*}} 16){{.*}} |
| 40 | // NOPROMO-NEXT: add |
| 41 | // NOPROMO-NEXT: store{{.*}}@__profc_foo{{.*}} 16){{.*}} |
| 42 | int i = 0; |
| 43 | while (i < N) { |
| 44 | if (i < n + 1) |
| 45 | bar(i: 1); |
| 46 | else if (i == n - 1) |
| 47 | bar(i: 2); |
| 48 | else |
| 49 | bar(i: 3); |
| 50 | i++; |
| 51 | } |
| 52 | } |
| 53 | |
| 54 | int main() { |
| 55 | foo(n: 10, N: 20); |
| 56 | return 0; |
| 57 | } |
| 58 | |