xref: /aosp_15_r20/external/llvm/test/CodeGen/X86/MachineSink-CritEdge.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s | FileCheck %s
2*9880d681SAndroid Build Coastguard Workertarget datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128-n8:16:32:64"
3*9880d681SAndroid Build Coastguard Workertarget triple = "x86_64-apple-darwin10.0.0"
4*9880d681SAndroid Build Coastguard Worker
5*9880d681SAndroid Build Coastguard Workerdefine i32 @f(i32 %x) nounwind ssp {
6*9880d681SAndroid Build Coastguard Workerentry:
7*9880d681SAndroid Build Coastguard Worker  %shl.i = shl i32 %x, 12
8*9880d681SAndroid Build Coastguard Worker  %neg.i = xor i32 %shl.i, -1
9*9880d681SAndroid Build Coastguard Worker  %add.i = add nsw i32 %neg.i, %x
10*9880d681SAndroid Build Coastguard Worker  %shr.i = ashr i32 %add.i, 22
11*9880d681SAndroid Build Coastguard Worker  %xor.i = xor i32 %shr.i, %add.i
12*9880d681SAndroid Build Coastguard Worker  %shl5.i = shl i32 %xor.i, 13
13*9880d681SAndroid Build Coastguard Worker  %neg6.i = xor i32 %shl5.i, -1
14*9880d681SAndroid Build Coastguard Worker  %add8.i = add nsw i32 %xor.i, %neg6.i
15*9880d681SAndroid Build Coastguard Worker  %shr10.i = ashr i32 %add8.i, 8
16*9880d681SAndroid Build Coastguard Worker  %xor12.i = xor i32 %shr10.i, %add8.i
17*9880d681SAndroid Build Coastguard Worker  %add16.i = mul i32 %xor12.i, 9
18*9880d681SAndroid Build Coastguard Worker  %shr18.i = ashr i32 %add16.i, 15
19*9880d681SAndroid Build Coastguard Worker  %xor20.i = xor i32 %shr18.i, %add16.i
20*9880d681SAndroid Build Coastguard Worker  %shl22.i = shl i32 %xor20.i, 27
21*9880d681SAndroid Build Coastguard Worker  %neg23.i = xor i32 %shl22.i, -1
22*9880d681SAndroid Build Coastguard Worker  %add25.i = add nsw i32 %xor20.i, %neg23.i
23*9880d681SAndroid Build Coastguard Worker  %shr27.i = ashr i32 %add25.i, 31
24*9880d681SAndroid Build Coastguard Worker  %rem = srem i32 %x, 7
25*9880d681SAndroid Build Coastguard Worker  %cmp = icmp eq i32 %rem, 3
26*9880d681SAndroid Build Coastguard Worker  br i1 %cmp, label %land.lhs.true, label %do.body.preheader
27*9880d681SAndroid Build Coastguard Worker
28*9880d681SAndroid Build Coastguard Workerland.lhs.true:
29*9880d681SAndroid Build Coastguard Worker  %call3 = tail call i32 @g(i32 %x) nounwind
30*9880d681SAndroid Build Coastguard Worker  %cmp4 = icmp eq i32 %call3, 10
31*9880d681SAndroid Build Coastguard Worker  br i1 %cmp4, label %do.body.preheader, label %if.then
32*9880d681SAndroid Build Coastguard Worker
33*9880d681SAndroid Build Coastguard Worker; %add16.i should be sinked all the way down to do.body.preheader, but not into the loop.
34*9880d681SAndroid Build Coastguard Worker; CHECK: do.body.preheader
35*9880d681SAndroid Build Coastguard Worker; CHECK-NOT: do.body
36*9880d681SAndroid Build Coastguard Worker; CHECK: leal ([[SRC:%r[a-z0-9]+]],[[SRC]],8)
37*9880d681SAndroid Build Coastguard Worker
38*9880d681SAndroid Build Coastguard Workerdo.body.preheader:
39*9880d681SAndroid Build Coastguard Worker  %xor29.i = xor i32 %shr27.i, %add25.i
40*9880d681SAndroid Build Coastguard Worker  br label %do.body
41*9880d681SAndroid Build Coastguard Worker
42*9880d681SAndroid Build Coastguard Workerif.then:
43*9880d681SAndroid Build Coastguard Worker  %add = add nsw i32 %x, 11
44*9880d681SAndroid Build Coastguard Worker  ret i32 %add
45*9880d681SAndroid Build Coastguard Worker
46*9880d681SAndroid Build Coastguard Workerdo.body:
47*9880d681SAndroid Build Coastguard Worker  %x.addr.1 = phi i32 [ %add9, %do.body ], [ %x, %do.body.preheader ]
48*9880d681SAndroid Build Coastguard Worker  %xor = xor i32 %xor29.i, %x.addr.1
49*9880d681SAndroid Build Coastguard Worker  %add9 = add nsw i32 %xor, %x.addr.1
50*9880d681SAndroid Build Coastguard Worker  %and = and i32 %add9, 13
51*9880d681SAndroid Build Coastguard Worker  %tobool = icmp eq i32 %and, 0
52*9880d681SAndroid Build Coastguard Worker  br i1 %tobool, label %if.end, label %do.body
53*9880d681SAndroid Build Coastguard Worker
54*9880d681SAndroid Build Coastguard Workerif.end:
55*9880d681SAndroid Build Coastguard Worker  ret i32 %add9
56*9880d681SAndroid Build Coastguard Worker}
57*9880d681SAndroid Build Coastguard Worker
58*9880d681SAndroid Build Coastguard Workerdeclare i32 @g(i32)
59