[DAGCombiner] Add target hook function to decide folding (mul (add x, c1), c2)
[llvm-project.git] / llvm / test / Transforms / PGOProfile / bfi_verification.ll
blob029329ba3ccc17271a1daaace202f163f71ad1bf
1 ; Note: Verify bfi counter after loading the profile.
2 ; RUN: llvm-profdata merge %S/Inputs/bfi_verification.proftext -o %t.profdata
3 ; RUN: opt < %s -pgo-instr-use -pgo-test-profile-file=%t.profdata -S -pgo-verify-bfi-ratio=2 -pgo-verify-bfi=true -pgo-fix-entry-count=false -pass-remarks-analysis=pgo 2>&1 | FileCheck %s --check-prefix=THRESHOLD-CHECK
4 ; RUN: opt < %s -pgo-instr-use -pgo-test-profile-file=%t.profdata -S -pgo-verify-hot-bfi=true -pgo-fix-entry-count=false -pass-remarks-analysis=pgo 2>&1 | FileCheck %s --check-prefix=HOTONLY-CHECK
6 target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
7 target triple = "x86_64-unknown-linux-gnu"
9 %struct.basket = type { %struct.arc*, i64, i64 }
10 %struct.arc = type { i64, %struct.node*, %struct.node*, i32, %struct.arc*, %struct.arc*, i64, i64 }
11 %struct.node = type { i64, i32, %struct.node*, %struct.node*, %struct.node*, %struct.node*, %struct.arc*, %struct.arc*, %struct.arc*, %struct.arc*, i64, i64, i32, i32 }
13 @perm = internal unnamed_addr global [351 x %struct.basket*] zeroinitializer, align 16
15 define dso_local void @sort_basket(i64 %min, i64 %max) {
16 entry:
17   %add = add nsw i64 %min, %max
18   %div = sdiv i64 %add, 2
19   %arrayidx = getelementptr inbounds [351 x %struct.basket*], [351 x %struct.basket*]* @perm, i64 0, i64 %div
20   %0 = load %struct.basket*, %struct.basket** %arrayidx, align 8
21   %abs_cost = getelementptr inbounds %struct.basket, %struct.basket* %0, i64 0, i32 2
22   %1 = load i64, i64* %abs_cost, align 8
23   br label %do.body
25 do.body:
26   %r.0 = phi i64 [ %max, %entry ], [ %r.2, %if.end ]
27   %l.0 = phi i64 [ %min, %entry ], [ %l.2, %if.end ]
28   br label %while.cond
30 while.cond:
31   %l.1 = phi i64 [ %l.0, %do.body ], [ %inc, %while.body ]
32   %arrayidx1 = getelementptr inbounds [351 x %struct.basket*], [351 x %struct.basket*]* @perm, i64 0, i64 %l.1
33   %2 = load %struct.basket*, %struct.basket** %arrayidx1, align 8
34   %abs_cost2 = getelementptr inbounds %struct.basket, %struct.basket* %2, i64 0, i32 2
35   %3 = load i64, i64* %abs_cost2, align 8
36   %cmp = icmp sgt i64 %3, %1
37   br i1 %cmp, label %while.body, label %while.cond3
39 while.body:
40   %inc = add nsw i64 %l.1, 1
41   br label %while.cond
43 while.cond3:
44   %r.1 = phi i64 [ %r.0, %while.cond ], [ %dec, %while.body7 ]
45   %arrayidx4 = getelementptr inbounds [351 x %struct.basket*], [351 x %struct.basket*]* @perm, i64 0, i64 %r.1
46   %4 = load %struct.basket*, %struct.basket** %arrayidx4, align 8
47   %abs_cost5 = getelementptr inbounds %struct.basket, %struct.basket* %4, i64 0, i32 2
48   %5 = load i64, i64* %abs_cost5, align 8
49   %cmp6 = icmp sgt i64 %1, %5
50   br i1 %cmp6, label %while.body7, label %while.end8
52 while.body7:
53   %dec = add nsw i64 %r.1, -1
54   br label %while.cond3
56 while.end8:
57   %cmp9 = icmp slt i64 %l.1, %r.1
58   br i1 %cmp9, label %if.then, label %if.end
60 if.then:
61   %6 = bitcast %struct.basket** %arrayidx1 to i64*
62   %7 = load i64, i64* %6, align 8
63   store %struct.basket* %4, %struct.basket** %arrayidx1, align 8
64   %8 = bitcast %struct.basket** %arrayidx4 to i64*
65   store i64 %7, i64* %8, align 8
66   br label %if.end
68 if.end:
69   %cmp14 = icmp sgt i64 %l.1, %r.1
70   %not.cmp14 = xor i1 %cmp14, true
71   %9 = zext i1 %not.cmp14 to i64
72   %r.2 = sub i64 %r.1, %9
73   %not.cmp1457 = xor i1 %cmp14, true
74   %inc16 = zext i1 %not.cmp1457 to i64
75   %l.2 = add nsw i64 %l.1, %inc16
76   %cmp19 = icmp sgt i64 %l.2, %r.2
77   br i1 %cmp19, label %do.end, label %do.body
79 do.end:
80   %cmp20 = icmp sgt i64 %r.2, %min
81   br i1 %cmp20, label %if.then21, label %if.end22
83 if.then21:
84   call void @sort_basket(i64 %min, i64 %r.2)
85   br label %if.end22
87 if.end22:
88   %cmp23 = icmp slt i64 %l.2, %max
89   %cmp24 = icmp slt i64 %l.2, 51
90   %or.cond = and i1 %cmp23, %cmp24
91   br i1 %or.cond, label %if.then25, label %if.end26
93 if.then25:
94   call void @sort_basket(i64 %l.2, i64 %max)
95   br label %if.end26
97 if.end26:
98   ret void
100 ; THRESHOLD-CHECK: remark: <unknown>:0:0: BB do.body Count=39637749 BFI_Count=40801304
101 ; THRESHOLD-CHECK: remark: <unknown>:0:0: BB while.cond Count=80655628 BFI_Count=83956530
102 ; THRESHOLD-CHECK: remark: <unknown>:0:0: BB while.body Count=41017879 BFI_Count=42370585
103 ; THRESHOLD-CHECK: remark: <unknown>:0:0: BB while.cond3 Count=71254487 BFI_Count=73756204
104 ; THRESHOLD-CHECK: remark: <unknown>:0:0: BB while.body7 Count=31616738 BFI_Count=32954900
105 ; THRESHOLD-CHECK: remark: <unknown>:0:0: BB while.end8 Count=39637749 BFI_Count=40801304
106 ; THRESHOLD-CHECK: remark: <unknown>:0:0: BB if.then Count=32743703 BFI_Count=33739540
107 ; THRESHOLD-CHECK: remark: <unknown>:0:0: BB if.end Count=39637749 BFI_Count=40801304
108 ; THRESHOLD-CHECK: remark: <unknown>:0:0: BB if.then25 Count=6013544 BFI_Count=6277124
109 ; THRESHOLD-CHECK: remark: <unknown>:0:0: In Func sort_basket: Num_of_BB=14, Num_of_non_zerovalue_BB=14, Num_of_mis_matching_BB=9
110 ; HOTONLY-CHECK: remark: <unknown>:0:0: BB if.then25 Count=6013544 BFI_Count=6277124 (raw-Cold to BFI-Hot)
111 ; HOTONLY-CHECK: remark: <unknown>:0:0: In Func sort_basket: Num_of_BB=14, Num_of_non_zerovalue_BB=14, Num_of_mis_matching_BB=1