1*9880d681SAndroid Build Coastguard Worker; RUN: opt -loop-reduce -S < %s | FileCheck %s 2*9880d681SAndroid Build Coastguard Worker; 3*9880d681SAndroid Build Coastguard Worker; Test TransformForPostIncUse and LSR's expansion of expressions in 4*9880d681SAndroid Build Coastguard Worker; post-inc form to ensure the implementation can handle expressions 5*9880d681SAndroid Build Coastguard Worker; DAGs, not just trees. 6*9880d681SAndroid Build Coastguard Worker 7*9880d681SAndroid Build Coastguard Workertarget triple = "x86_64-apple-darwin" 8*9880d681SAndroid Build Coastguard Worker 9*9880d681SAndroid Build Coastguard Worker; Verify that -loop-reduce runs without "hanging" and reuses post-inc 10*9880d681SAndroid Build Coastguard Worker; expansions. 11*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @test( 12*9880d681SAndroid Build Coastguard Worker; CHECK: icmp 13*9880d681SAndroid Build Coastguard Worker; CHECK: icmp 14*9880d681SAndroid Build Coastguard Worker; CHECK: icmp 15*9880d681SAndroid Build Coastguard Worker; CHECK: icmp 16*9880d681SAndroid Build Coastguard Worker; CHECK: icmp 17*9880d681SAndroid Build Coastguard Worker; CHECK: icmp 18*9880d681SAndroid Build Coastguard Worker; CHECK: icmp 19*9880d681SAndroid Build Coastguard Worker; CHECK: icmp 20*9880d681SAndroid Build Coastguard Worker; CHECK: icmp 21*9880d681SAndroid Build Coastguard Worker; CHECK: icmp 22*9880d681SAndroid Build Coastguard Worker; CHECK: icmp 23*9880d681SAndroid Build Coastguard Worker; CHECK: icmp 24*9880d681SAndroid Build Coastguard Worker; CHECK: icmp 25*9880d681SAndroid Build Coastguard Worker; CHECK: icmp 26*9880d681SAndroid Build Coastguard Worker; CHECK: icmp 27*9880d681SAndroid Build Coastguard Worker; CHECK: icmp 28*9880d681SAndroid Build Coastguard Worker; CHECK: icmp 29*9880d681SAndroid Build Coastguard Worker; CHECK-NOT: icmp 30*9880d681SAndroid Build Coastguard Workerdefine void @test(i8* %base, i32 %a0) nounwind { 31*9880d681SAndroid Build Coastguard Workerentry: 32*9880d681SAndroid Build Coastguard Worker br label %bb1 33*9880d681SAndroid Build Coastguard Workerbb1: 34*9880d681SAndroid Build Coastguard Worker %n0 = sub i32 0, %a0 35*9880d681SAndroid Build Coastguard Worker %t0 = icmp ugt i32 %n0, -4 36*9880d681SAndroid Build Coastguard Worker %m0 = select i1 %t0, i32 %n0, i32 -4 37*9880d681SAndroid Build Coastguard Worker %a1 = add i32 %m0, %a0 38*9880d681SAndroid Build Coastguard Worker %n1 = sub i32 0, %a1 39*9880d681SAndroid Build Coastguard Worker %t1 = icmp ugt i32 %n1, -4 40*9880d681SAndroid Build Coastguard Worker %m1 = select i1 %t1, i32 %n1, i32 -4 41*9880d681SAndroid Build Coastguard Worker %a2 = add i32 %m1, %a1 42*9880d681SAndroid Build Coastguard Worker %n2 = sub i32 0, %a2 43*9880d681SAndroid Build Coastguard Worker %t2 = icmp ugt i32 %n2, -4 44*9880d681SAndroid Build Coastguard Worker %m2 = select i1 %t2, i32 %n2, i32 -4 45*9880d681SAndroid Build Coastguard Worker %a3 = add i32 %m2, %a2 46*9880d681SAndroid Build Coastguard Worker %n3 = sub i32 0, %a3 47*9880d681SAndroid Build Coastguard Worker %t3 = icmp ugt i32 %n3, -4 48*9880d681SAndroid Build Coastguard Worker %m3 = select i1 %t3, i32 %n3, i32 -4 49*9880d681SAndroid Build Coastguard Worker %a4 = add i32 %m3, %a3 50*9880d681SAndroid Build Coastguard Worker %n4 = sub i32 0, %a4 51*9880d681SAndroid Build Coastguard Worker %t4 = icmp ugt i32 %n4, -4 52*9880d681SAndroid Build Coastguard Worker %m4 = select i1 %t4, i32 %n4, i32 -4 53*9880d681SAndroid Build Coastguard Worker %a5 = add i32 %m4, %a4 54*9880d681SAndroid Build Coastguard Worker %n5 = sub i32 0, %a5 55*9880d681SAndroid Build Coastguard Worker %t5 = icmp ugt i32 %n5, -4 56*9880d681SAndroid Build Coastguard Worker %m5 = select i1 %t5, i32 %n5, i32 -4 57*9880d681SAndroid Build Coastguard Worker %a6 = add i32 %m5, %a5 58*9880d681SAndroid Build Coastguard Worker %n6 = sub i32 0, %a6 59*9880d681SAndroid Build Coastguard Worker %t6 = icmp ugt i32 %n6, -4 60*9880d681SAndroid Build Coastguard Worker %m6 = select i1 %t6, i32 %n6, i32 -4 61*9880d681SAndroid Build Coastguard Worker %a7 = add i32 %m6, %a6 62*9880d681SAndroid Build Coastguard Worker %n7 = sub i32 0, %a7 63*9880d681SAndroid Build Coastguard Worker %t7 = icmp ugt i32 %n7, -4 64*9880d681SAndroid Build Coastguard Worker %m7 = select i1 %t7, i32 %n7, i32 -4 65*9880d681SAndroid Build Coastguard Worker %a8 = add i32 %m7, %a7 66*9880d681SAndroid Build Coastguard Worker %n8 = sub i32 0, %a8 67*9880d681SAndroid Build Coastguard Worker %t8 = icmp ugt i32 %n8, -4 68*9880d681SAndroid Build Coastguard Worker %m8 = select i1 %t8, i32 %n8, i32 -4 69*9880d681SAndroid Build Coastguard Worker %a9 = add i32 %m8, %a8 70*9880d681SAndroid Build Coastguard Worker %n9 = sub i32 0, %a9 71*9880d681SAndroid Build Coastguard Worker %t9 = icmp ugt i32 %n9, -4 72*9880d681SAndroid Build Coastguard Worker %m9 = select i1 %t9, i32 %n9, i32 -4 73*9880d681SAndroid Build Coastguard Worker %a10 = add i32 %m9, %a9 74*9880d681SAndroid Build Coastguard Worker %n10 = sub i32 0, %a10 75*9880d681SAndroid Build Coastguard Worker %t10 = icmp ugt i32 %n10, -4 76*9880d681SAndroid Build Coastguard Worker %m10 = select i1 %t10, i32 %n10, i32 -4 77*9880d681SAndroid Build Coastguard Worker %a11 = add i32 %m10, %a10 78*9880d681SAndroid Build Coastguard Worker %n11 = sub i32 0, %a11 79*9880d681SAndroid Build Coastguard Worker %t11 = icmp ugt i32 %n11, -4 80*9880d681SAndroid Build Coastguard Worker %m11 = select i1 %t11, i32 %n11, i32 -4 81*9880d681SAndroid Build Coastguard Worker %a12 = add i32 %m11, %a11 82*9880d681SAndroid Build Coastguard Worker %n12 = sub i32 0, %a12 83*9880d681SAndroid Build Coastguard Worker %t12 = icmp ugt i32 %n12, -4 84*9880d681SAndroid Build Coastguard Worker %m12 = select i1 %t12, i32 %n12, i32 -4 85*9880d681SAndroid Build Coastguard Worker %a13 = add i32 %m12, %a12 86*9880d681SAndroid Build Coastguard Worker %n13 = sub i32 0, %a13 87*9880d681SAndroid Build Coastguard Worker %t13 = icmp ugt i32 %n13, -4 88*9880d681SAndroid Build Coastguard Worker %m13 = select i1 %t13, i32 %n13, i32 -4 89*9880d681SAndroid Build Coastguard Worker %a14 = add i32 %m13, %a13 90*9880d681SAndroid Build Coastguard Worker %n14 = sub i32 0, %a14 91*9880d681SAndroid Build Coastguard Worker %t14 = icmp ugt i32 %n14, -4 92*9880d681SAndroid Build Coastguard Worker %m14 = select i1 %t14, i32 %n14, i32 -4 93*9880d681SAndroid Build Coastguard Worker %a15 = add i32 %m14, %a14 94*9880d681SAndroid Build Coastguard Worker %n15 = sub i32 0, %a15 95*9880d681SAndroid Build Coastguard Worker %t15 = icmp ugt i32 %n15, -4 96*9880d681SAndroid Build Coastguard Worker %m15 = select i1 %t15, i32 %n15, i32 -4 97*9880d681SAndroid Build Coastguard Worker %a16 = add i32 %m15, %a15 98*9880d681SAndroid Build Coastguard Worker %gep = getelementptr i8, i8* %base, i32 %a16 99*9880d681SAndroid Build Coastguard Worker %ofs = add i32 %a16, 4 100*9880d681SAndroid Build Coastguard Worker %limit = getelementptr i8, i8* %base, i32 %ofs 101*9880d681SAndroid Build Coastguard Worker br label %loop 102*9880d681SAndroid Build Coastguard Worker 103*9880d681SAndroid Build Coastguard Workerloop: 104*9880d681SAndroid Build Coastguard Worker %iv = phi i8* [ %gep, %bb1 ], [ %inc, %loop ] 105*9880d681SAndroid Build Coastguard Worker %inc = getelementptr inbounds i8, i8* %iv, i64 1 106*9880d681SAndroid Build Coastguard Worker %exitcond = icmp eq i8* %inc, %limit 107*9880d681SAndroid Build Coastguard Worker br i1 %exitcond, label %loop, label %exit 108*9880d681SAndroid Build Coastguard Worker 109*9880d681SAndroid Build Coastguard Workerexit: 110*9880d681SAndroid Build Coastguard Worker ret void 111*9880d681SAndroid Build Coastguard Worker} 112