xref: /aosp_15_r20/external/llvm/test/Analysis/BranchProbabilityInfo/pr18705.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: opt < %s -analyze -branch-prob | FileCheck %s
2*9880d681SAndroid Build Coastguard Worker; RUN: opt < %s -passes='print<branch-prob>' -disable-output 2>&1 | FileCheck %s
3*9880d681SAndroid Build Coastguard Worker
4*9880d681SAndroid Build Coastguard Worker; Since neither of while.body's out-edges is an exit or a back edge,
5*9880d681SAndroid Build Coastguard Worker; calcLoopBranchHeuristics should return early without setting the weights.
6*9880d681SAndroid Build Coastguard Worker; calcFloatingPointHeuristics, which is run later, sets the weights.
7*9880d681SAndroid Build Coastguard Worker;
8*9880d681SAndroid Build Coastguard Worker; CHECK: edge while.body -> if.then probability is 0x50000000 / 0x80000000 = 62.50%
9*9880d681SAndroid Build Coastguard Worker; CHECK: edge while.body -> if.else probability is 0x30000000 / 0x80000000 = 37.50%
10*9880d681SAndroid Build Coastguard Worker
11*9880d681SAndroid Build Coastguard Workerdefine void @foo1(i32 %n, i32* nocapture %b, i32* nocapture %c, i32* nocapture %d, float* nocapture readonly %f0, float* nocapture readonly %f1) {
12*9880d681SAndroid Build Coastguard Workerentry:
13*9880d681SAndroid Build Coastguard Worker  %tobool8 = icmp eq i32 %n, 0
14*9880d681SAndroid Build Coastguard Worker  br i1 %tobool8, label %while.end, label %while.body.lr.ph
15*9880d681SAndroid Build Coastguard Worker
16*9880d681SAndroid Build Coastguard Workerwhile.body.lr.ph:
17*9880d681SAndroid Build Coastguard Worker  %0 = sext i32 %n to i64
18*9880d681SAndroid Build Coastguard Worker  br label %while.body
19*9880d681SAndroid Build Coastguard Worker
20*9880d681SAndroid Build Coastguard Workerwhile.body:
21*9880d681SAndroid Build Coastguard Worker  %indvars.iv = phi i64 [ %0, %while.body.lr.ph ], [ %indvars.iv.next, %if.end ]
22*9880d681SAndroid Build Coastguard Worker  %b.addr.011 = phi i32* [ %b, %while.body.lr.ph ], [ %b.addr.1, %if.end ]
23*9880d681SAndroid Build Coastguard Worker  %d.addr.010 = phi i32* [ %d, %while.body.lr.ph ], [ %incdec.ptr4, %if.end ]
24*9880d681SAndroid Build Coastguard Worker  %c.addr.09 = phi i32* [ %c, %while.body.lr.ph ], [ %c.addr.1, %if.end ]
25*9880d681SAndroid Build Coastguard Worker  %indvars.iv.next = add nsw i64 %indvars.iv, -1
26*9880d681SAndroid Build Coastguard Worker  %arrayidx = getelementptr inbounds float, float* %f0, i64 %indvars.iv.next
27*9880d681SAndroid Build Coastguard Worker  %1 = load float, float* %arrayidx, align 4
28*9880d681SAndroid Build Coastguard Worker  %arrayidx2 = getelementptr inbounds float, float* %f1, i64 %indvars.iv.next
29*9880d681SAndroid Build Coastguard Worker  %2 = load float, float* %arrayidx2, align 4
30*9880d681SAndroid Build Coastguard Worker  %cmp = fcmp une float %1, %2
31*9880d681SAndroid Build Coastguard Worker  br i1 %cmp, label %if.then, label %if.else
32*9880d681SAndroid Build Coastguard Worker
33*9880d681SAndroid Build Coastguard Workerif.then:
34*9880d681SAndroid Build Coastguard Worker  %incdec.ptr = getelementptr inbounds i32, i32* %b.addr.011, i64 1
35*9880d681SAndroid Build Coastguard Worker  %3 = load i32, i32* %b.addr.011, align 4
36*9880d681SAndroid Build Coastguard Worker  %add = add nsw i32 %3, 12
37*9880d681SAndroid Build Coastguard Worker  store i32 %add, i32* %b.addr.011, align 4
38*9880d681SAndroid Build Coastguard Worker  br label %if.end
39*9880d681SAndroid Build Coastguard Worker
40*9880d681SAndroid Build Coastguard Workerif.else:
41*9880d681SAndroid Build Coastguard Worker  %incdec.ptr3 = getelementptr inbounds i32, i32* %c.addr.09, i64 1
42*9880d681SAndroid Build Coastguard Worker  %4 = load i32, i32* %c.addr.09, align 4
43*9880d681SAndroid Build Coastguard Worker  %sub = add nsw i32 %4, -13
44*9880d681SAndroid Build Coastguard Worker  store i32 %sub, i32* %c.addr.09, align 4
45*9880d681SAndroid Build Coastguard Worker  br label %if.end
46*9880d681SAndroid Build Coastguard Worker
47*9880d681SAndroid Build Coastguard Workerif.end:
48*9880d681SAndroid Build Coastguard Worker  %c.addr.1 = phi i32* [ %c.addr.09, %if.then ], [ %incdec.ptr3, %if.else ]
49*9880d681SAndroid Build Coastguard Worker  %b.addr.1 = phi i32* [ %incdec.ptr, %if.then ], [ %b.addr.011, %if.else ]
50*9880d681SAndroid Build Coastguard Worker  %incdec.ptr4 = getelementptr inbounds i32, i32* %d.addr.010, i64 1
51*9880d681SAndroid Build Coastguard Worker  store i32 14, i32* %d.addr.010, align 4
52*9880d681SAndroid Build Coastguard Worker  %5 = trunc i64 %indvars.iv.next to i32
53*9880d681SAndroid Build Coastguard Worker  %tobool = icmp eq i32 %5, 0
54*9880d681SAndroid Build Coastguard Worker  br i1 %tobool, label %while.end, label %while.body
55*9880d681SAndroid Build Coastguard Worker
56*9880d681SAndroid Build Coastguard Workerwhile.end:
57*9880d681SAndroid Build Coastguard Worker  ret void
58*9880d681SAndroid Build Coastguard Worker}
59*9880d681SAndroid Build Coastguard Worker
60