1*9880d681SAndroid Build Coastguard Worker; RUN: opt < %s -analyze -scalar-evolution | FileCheck %s 2*9880d681SAndroid Build Coastguard Worker 3*9880d681SAndroid Build Coastguard Worker; The addrecs in this loop are analyzable only by using nsw information. 4*9880d681SAndroid Build Coastguard Worker 5*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" 6*9880d681SAndroid Build Coastguard Worker 7*9880d681SAndroid Build Coastguard Worker; CHECK: Classifying expressions for: @test1 8*9880d681SAndroid Build Coastguard Workerdefine void @test1(double* %p) nounwind { 9*9880d681SAndroid Build Coastguard Workerentry: 10*9880d681SAndroid Build Coastguard Worker %tmp = load double, double* %p, align 8 ; <double> [#uses=1] 11*9880d681SAndroid Build Coastguard Worker %tmp1 = fcmp ogt double %tmp, 2.000000e+00 ; <i1> [#uses=1] 12*9880d681SAndroid Build Coastguard Worker br i1 %tmp1, label %bb.nph, label %return 13*9880d681SAndroid Build Coastguard Worker 14*9880d681SAndroid Build Coastguard Workerbb.nph: ; preds = %entry 15*9880d681SAndroid Build Coastguard Worker br label %bb 16*9880d681SAndroid Build Coastguard Worker 17*9880d681SAndroid Build Coastguard Workerbb: ; preds = %bb1, %bb.nph 18*9880d681SAndroid Build Coastguard Worker %i.01 = phi i32 [ %tmp8, %bb1 ], [ 0, %bb.nph ] ; <i32> [#uses=3] 19*9880d681SAndroid Build Coastguard Worker; CHECK: %i.01 20*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: --> {0,+,1}<nuw><nsw><%bb> 21*9880d681SAndroid Build Coastguard Worker %tmp2 = sext i32 %i.01 to i64 ; <i64> [#uses=1] 22*9880d681SAndroid Build Coastguard Worker %tmp3 = getelementptr double, double* %p, i64 %tmp2 ; <double*> [#uses=1] 23*9880d681SAndroid Build Coastguard Worker %tmp4 = load double, double* %tmp3, align 8 ; <double> [#uses=1] 24*9880d681SAndroid Build Coastguard Worker %tmp5 = fmul double %tmp4, 9.200000e+00 ; <double> [#uses=1] 25*9880d681SAndroid Build Coastguard Worker %tmp6 = sext i32 %i.01 to i64 ; <i64> [#uses=1] 26*9880d681SAndroid Build Coastguard Worker %tmp7 = getelementptr double, double* %p, i64 %tmp6 ; <double*> [#uses=1] 27*9880d681SAndroid Build Coastguard Worker; CHECK: %tmp7 28*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: --> {%p,+,8}<%bb> 29*9880d681SAndroid Build Coastguard Worker store double %tmp5, double* %tmp7, align 8 30*9880d681SAndroid Build Coastguard Worker %tmp8 = add nsw i32 %i.01, 1 ; <i32> [#uses=2] 31*9880d681SAndroid Build Coastguard Worker; CHECK: %tmp8 32*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: --> {1,+,1}<nuw><nsw><%bb> 33*9880d681SAndroid Build Coastguard Worker %p.gep = getelementptr double, double* %p, i32 %tmp8 34*9880d681SAndroid Build Coastguard Worker %p.val = load double, double* %p.gep 35*9880d681SAndroid Build Coastguard Worker br label %bb1 36*9880d681SAndroid Build Coastguard Worker 37*9880d681SAndroid Build Coastguard Workerbb1: ; preds = %bb 38*9880d681SAndroid Build Coastguard Worker %phitmp = sext i32 %tmp8 to i64 ; <i64> [#uses=1] 39*9880d681SAndroid Build Coastguard Worker; CHECK: %phitmp 40*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: --> {1,+,1}<nuw><nsw><%bb> 41*9880d681SAndroid Build Coastguard Worker %tmp9 = getelementptr inbounds double, double* %p, i64 %phitmp ; <double*> [#uses=1] 42*9880d681SAndroid Build Coastguard Worker; CHECK: %tmp9 43*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: --> {(8 + %p)<nsw>,+,8}<nsw><%bb> 44*9880d681SAndroid Build Coastguard Worker %tmp10 = load double, double* %tmp9, align 8 ; <double> [#uses=1] 45*9880d681SAndroid Build Coastguard Worker %tmp11 = fcmp ogt double %tmp10, 2.000000e+00 ; <i1> [#uses=1] 46*9880d681SAndroid Build Coastguard Worker br i1 %tmp11, label %bb, label %bb1.return_crit_edge 47*9880d681SAndroid Build Coastguard Worker 48*9880d681SAndroid Build Coastguard Workerbb1.return_crit_edge: ; preds = %bb1 49*9880d681SAndroid Build Coastguard Worker br label %return 50*9880d681SAndroid Build Coastguard Worker 51*9880d681SAndroid Build Coastguard Workerreturn: ; preds = %bb1.return_crit_edge, %entry 52*9880d681SAndroid Build Coastguard Worker ret void 53*9880d681SAndroid Build Coastguard Worker} 54*9880d681SAndroid Build Coastguard Worker 55*9880d681SAndroid Build Coastguard Worker; CHECK: Classifying expressions for: @test2 56*9880d681SAndroid Build Coastguard Workerdefine void @test2(i32* %begin, i32* %end) ssp { 57*9880d681SAndroid Build Coastguard Workerentry: 58*9880d681SAndroid Build Coastguard Worker %cmp1.i.i = icmp eq i32* %begin, %end 59*9880d681SAndroid Build Coastguard Worker br i1 %cmp1.i.i, label %_ZSt4fillIPiiEvT_S1_RKT0_.exit, label %for.body.lr.ph.i.i 60*9880d681SAndroid Build Coastguard Worker 61*9880d681SAndroid Build Coastguard Workerfor.body.lr.ph.i.i: ; preds = %entry 62*9880d681SAndroid Build Coastguard Worker br label %for.body.i.i 63*9880d681SAndroid Build Coastguard Worker 64*9880d681SAndroid Build Coastguard Workerfor.body.i.i: ; preds = %for.body.i.i, %for.body.lr.ph.i.i 65*9880d681SAndroid Build Coastguard Worker %__first.addr.02.i.i = phi i32* [ %begin, %for.body.lr.ph.i.i ], [ %ptrincdec.i.i, %for.body.i.i ] 66*9880d681SAndroid Build Coastguard Worker; CHECK: %__first.addr.02.i.i 67*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: --> {%begin,+,4}<nuw><%for.body.i.i> 68*9880d681SAndroid Build Coastguard Worker store i32 0, i32* %__first.addr.02.i.i, align 4 69*9880d681SAndroid Build Coastguard Worker %ptrincdec.i.i = getelementptr inbounds i32, i32* %__first.addr.02.i.i, i64 1 70*9880d681SAndroid Build Coastguard Worker; CHECK: %ptrincdec.i.i 71*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: --> {(4 + %begin)<nsw>,+,4}<nuw><%for.body.i.i> 72*9880d681SAndroid Build Coastguard Worker %cmp.i.i = icmp eq i32* %ptrincdec.i.i, %end 73*9880d681SAndroid Build Coastguard Worker br i1 %cmp.i.i, label %for.cond.for.end_crit_edge.i.i, label %for.body.i.i 74*9880d681SAndroid Build Coastguard Worker 75*9880d681SAndroid Build Coastguard Workerfor.cond.for.end_crit_edge.i.i: ; preds = %for.body.i.i 76*9880d681SAndroid Build Coastguard Worker br label %_ZSt4fillIPiiEvT_S1_RKT0_.exit 77*9880d681SAndroid Build Coastguard Worker 78*9880d681SAndroid Build Coastguard Worker_ZSt4fillIPiiEvT_S1_RKT0_.exit: ; preds = %entry, %for.cond.for.end_crit_edge.i.i 79*9880d681SAndroid Build Coastguard Worker ret void 80*9880d681SAndroid Build Coastguard Worker} 81*9880d681SAndroid Build Coastguard Worker 82*9880d681SAndroid Build Coastguard Worker; Various checks for inbounds geps. 83*9880d681SAndroid Build Coastguard Workerdefine void @test3(i32* %begin, i32* %end) nounwind ssp { 84*9880d681SAndroid Build Coastguard Workerentry: 85*9880d681SAndroid Build Coastguard Worker %cmp7.i.i = icmp eq i32* %begin, %end 86*9880d681SAndroid Build Coastguard Worker br i1 %cmp7.i.i, label %_ZSt4fillIPiiEvT_S1_RKT0_.exit, label %for.body.i.i 87*9880d681SAndroid Build Coastguard Worker 88*9880d681SAndroid Build Coastguard Workerfor.body.i.i: ; preds = %entry, %for.body.i.i 89*9880d681SAndroid Build Coastguard Worker %indvar.i.i = phi i64 [ %tmp, %for.body.i.i ], [ 0, %entry ] 90*9880d681SAndroid Build Coastguard Worker; CHECK: %indvar.i.i 91*9880d681SAndroid Build Coastguard Worker; CHECK: {0,+,1}<nuw><nsw><%for.body.i.i> 92*9880d681SAndroid Build Coastguard Worker %tmp = add nsw i64 %indvar.i.i, 1 93*9880d681SAndroid Build Coastguard Worker; CHECK: %tmp = 94*9880d681SAndroid Build Coastguard Worker; CHECK: {1,+,1}<nuw><nsw><%for.body.i.i> 95*9880d681SAndroid Build Coastguard Worker %ptrincdec.i.i = getelementptr inbounds i32, i32* %begin, i64 %tmp 96*9880d681SAndroid Build Coastguard Worker; CHECK: %ptrincdec.i.i = 97*9880d681SAndroid Build Coastguard Worker; CHECK: {(4 + %begin)<nsw>,+,4}<nsw><%for.body.i.i> 98*9880d681SAndroid Build Coastguard Worker %__first.addr.08.i.i = getelementptr inbounds i32, i32* %begin, i64 %indvar.i.i 99*9880d681SAndroid Build Coastguard Worker; CHECK: %__first.addr.08.i.i 100*9880d681SAndroid Build Coastguard Worker; CHECK: {%begin,+,4}<nsw><%for.body.i.i> 101*9880d681SAndroid Build Coastguard Worker store i32 0, i32* %__first.addr.08.i.i, align 4 102*9880d681SAndroid Build Coastguard Worker %cmp.i.i = icmp eq i32* %ptrincdec.i.i, %end 103*9880d681SAndroid Build Coastguard Worker br i1 %cmp.i.i, label %_ZSt4fillIPiiEvT_S1_RKT0_.exit, label %for.body.i.i 104*9880d681SAndroid Build Coastguard Worker; CHECK: Loop %for.body.i.i: backedge-taken count is ((-4 + (-1 * %begin) + %end) /u 4) 105*9880d681SAndroid Build Coastguard Worker; CHECK: Loop %for.body.i.i: max backedge-taken count is ((-4 + (-1 * %begin) + %end) /u 4) 106*9880d681SAndroid Build Coastguard Worker_ZSt4fillIPiiEvT_S1_RKT0_.exit: ; preds = %for.body.i.i, %entry 107*9880d681SAndroid Build Coastguard Worker ret void 108*9880d681SAndroid Build Coastguard Worker} 109*9880d681SAndroid Build Coastguard Worker 110*9880d681SAndroid Build Coastguard Worker; A single AddExpr exists for (%a + %b), which is not always <nsw>. 111*9880d681SAndroid Build Coastguard Worker; CHECK: @addnsw 112*9880d681SAndroid Build Coastguard Worker; CHECK-NOT: --> (%a + %b)<nsw> 113*9880d681SAndroid Build Coastguard Workerdefine i32 @addnsw(i32 %a, i32 %b) nounwind ssp { 114*9880d681SAndroid Build Coastguard Workerentry: 115*9880d681SAndroid Build Coastguard Worker %tmp = add i32 %a, %b 116*9880d681SAndroid Build Coastguard Worker %cmp = icmp sgt i32 %tmp, 0 117*9880d681SAndroid Build Coastguard Worker br i1 %cmp, label %greater, label %exit 118*9880d681SAndroid Build Coastguard Worker 119*9880d681SAndroid Build Coastguard Workergreater: 120*9880d681SAndroid Build Coastguard Worker %tmp2 = add nsw i32 %a, %b 121*9880d681SAndroid Build Coastguard Worker br label %exit 122*9880d681SAndroid Build Coastguard Worker 123*9880d681SAndroid Build Coastguard Workerexit: 124*9880d681SAndroid Build Coastguard Worker %result = phi i32 [ %a, %entry ], [ %tmp2, %greater ] 125*9880d681SAndroid Build Coastguard Worker ret i32 %result 126*9880d681SAndroid Build Coastguard Worker} 127*9880d681SAndroid Build Coastguard Worker 128*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: PR12375 129*9880d681SAndroid Build Coastguard Worker; CHECK: --> {(4 + %arg)<nsw>,+,4}<nuw><%bb1>{{ U: [^ ]+ S: [^ ]+}}{{ *}}Exits: (4 + (4 * ((-1 + (-1 * %arg) + ((4 + %arg)<nsw> umax (8 + %arg)<nsw>)) /u 4)) + %arg) 130*9880d681SAndroid Build Coastguard Workerdefine i32 @PR12375(i32* readnone %arg) { 131*9880d681SAndroid Build Coastguard Workerbb: 132*9880d681SAndroid Build Coastguard Worker %tmp = getelementptr inbounds i32, i32* %arg, i64 2 133*9880d681SAndroid Build Coastguard Worker br label %bb1 134*9880d681SAndroid Build Coastguard Worker 135*9880d681SAndroid Build Coastguard Workerbb1: ; preds = %bb1, %bb 136*9880d681SAndroid Build Coastguard Worker %tmp2 = phi i32* [ %arg, %bb ], [ %tmp5, %bb1 ] 137*9880d681SAndroid Build Coastguard Worker %tmp3 = phi i32 [ 0, %bb ], [ %tmp4, %bb1 ] 138*9880d681SAndroid Build Coastguard Worker %tmp4 = add nsw i32 %tmp3, 1 139*9880d681SAndroid Build Coastguard Worker %tmp5 = getelementptr inbounds i32, i32* %tmp2, i64 1 140*9880d681SAndroid Build Coastguard Worker %tmp6 = icmp ult i32* %tmp5, %tmp 141*9880d681SAndroid Build Coastguard Worker br i1 %tmp6, label %bb1, label %bb7 142*9880d681SAndroid Build Coastguard Worker 143*9880d681SAndroid Build Coastguard Workerbb7: ; preds = %bb1 144*9880d681SAndroid Build Coastguard Worker ret i32 %tmp4 145*9880d681SAndroid Build Coastguard Worker} 146*9880d681SAndroid Build Coastguard Worker 147*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: PR12376 148*9880d681SAndroid Build Coastguard Worker; CHECK: --> {(4 + %arg)<nsw>,+,4}<nuw><%bb2>{{ U: [^ ]+ S: [^ ]+}}{{ *}}Exits: (4 + (4 * ((-1 + (-1 * %arg) + ((4 + %arg)<nsw> umax %arg1)) /u 4)) + %arg) 149*9880d681SAndroid Build Coastguard Workerdefine void @PR12376(i32* nocapture %arg, i32* nocapture %arg1) { 150*9880d681SAndroid Build Coastguard Workerbb: 151*9880d681SAndroid Build Coastguard Worker br label %bb2 152*9880d681SAndroid Build Coastguard Worker 153*9880d681SAndroid Build Coastguard Workerbb2: ; preds = %bb2, %bb 154*9880d681SAndroid Build Coastguard Worker %tmp = phi i32* [ %arg, %bb ], [ %tmp4, %bb2 ] 155*9880d681SAndroid Build Coastguard Worker %tmp4 = getelementptr inbounds i32, i32* %tmp, i64 1 156*9880d681SAndroid Build Coastguard Worker %tmp3 = icmp ult i32* %tmp4, %arg1 157*9880d681SAndroid Build Coastguard Worker br i1 %tmp3, label %bb2, label %bb5 158*9880d681SAndroid Build Coastguard Worker 159*9880d681SAndroid Build Coastguard Workerbb5: ; preds = %bb2 160*9880d681SAndroid Build Coastguard Worker ret void 161*9880d681SAndroid Build Coastguard Worker} 162*9880d681SAndroid Build Coastguard Worker 163*9880d681SAndroid Build Coastguard Workerdeclare void @f(i32) 164*9880d681SAndroid Build Coastguard Worker 165*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: nswnowrap 166*9880d681SAndroid Build Coastguard Worker; CHECK: --> {(1 + %v)<nsw>,+,1}<nsw><%for.body>{{ U: [^ ]+ S: [^ ]+}}{{ *}}Exits: (1 + ((1 + %v)<nsw> smax %v)) 167*9880d681SAndroid Build Coastguard Workerdefine void @nswnowrap(i32 %v, i32* %buf) { 168*9880d681SAndroid Build Coastguard Workerentry: 169*9880d681SAndroid Build Coastguard Worker %add = add nsw i32 %v, 1 170*9880d681SAndroid Build Coastguard Worker br label %for.body 171*9880d681SAndroid Build Coastguard Worker 172*9880d681SAndroid Build Coastguard Workerfor.body: 173*9880d681SAndroid Build Coastguard Worker %i.04 = phi i32 [ %v, %entry ], [ %inc, %for.body ] 174*9880d681SAndroid Build Coastguard Worker %inc = add nsw i32 %i.04, 1 175*9880d681SAndroid Build Coastguard Worker %buf.gep = getelementptr inbounds i32, i32* %buf, i32 %inc 176*9880d681SAndroid Build Coastguard Worker %buf.val = load i32, i32* %buf.gep 177*9880d681SAndroid Build Coastguard Worker %cmp = icmp slt i32 %i.04, %add 178*9880d681SAndroid Build Coastguard Worker tail call void @f(i32 %i.04) 179*9880d681SAndroid Build Coastguard Worker br i1 %cmp, label %for.body, label %for.end 180*9880d681SAndroid Build Coastguard Worker 181*9880d681SAndroid Build Coastguard Workerfor.end: 182*9880d681SAndroid Build Coastguard Worker ret void 183*9880d681SAndroid Build Coastguard Worker} 184*9880d681SAndroid Build Coastguard Worker 185*9880d681SAndroid Build Coastguard Worker; This test checks if no-wrap flags are propagated when folding {S,+,X}+T ==> {S+T,+,X} 186*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: test4 187*9880d681SAndroid Build Coastguard Worker; CHECK: %idxprom 188*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: --> {(-2 + (sext i32 %arg to i64))<nsw>,+,1}<nsw><%for.body> 189*9880d681SAndroid Build Coastguard Workerdefine void @test4(i32 %arg) { 190*9880d681SAndroid Build Coastguard Workerentry: 191*9880d681SAndroid Build Coastguard Worker %array = alloca [10 x i32], align 4 192*9880d681SAndroid Build Coastguard Worker br label %for.body 193*9880d681SAndroid Build Coastguard Worker 194*9880d681SAndroid Build Coastguard Workerfor.body: 195*9880d681SAndroid Build Coastguard Worker %index = phi i32 [ %inc5, %for.body ], [ %arg, %entry ] 196*9880d681SAndroid Build Coastguard Worker %sub = add nsw i32 %index, -2 197*9880d681SAndroid Build Coastguard Worker %idxprom = sext i32 %sub to i64 198*9880d681SAndroid Build Coastguard Worker %arrayidx = getelementptr inbounds [10 x i32], [10 x i32]* %array, i64 0, i64 %idxprom 199*9880d681SAndroid Build Coastguard Worker %data = load i32, i32* %arrayidx, align 4 200*9880d681SAndroid Build Coastguard Worker %inc5 = add nsw i32 %index, 1 201*9880d681SAndroid Build Coastguard Worker %cmp2 = icmp slt i32 %inc5, 10 202*9880d681SAndroid Build Coastguard Worker br i1 %cmp2, label %for.body, label %for.end 203*9880d681SAndroid Build Coastguard Worker 204*9880d681SAndroid Build Coastguard Workerfor.end: 205*9880d681SAndroid Build Coastguard Worker ret void 206*9880d681SAndroid Build Coastguard Worker} 207*9880d681SAndroid Build Coastguard Worker 208*9880d681SAndroid Build Coastguard Worker 209*9880d681SAndroid Build Coastguard Workerdefine void @bad_postinc_nsw_a(i32 %n) { 210*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: Classifying expressions for: @bad_postinc_nsw_a 211*9880d681SAndroid Build Coastguard Workerentry: 212*9880d681SAndroid Build Coastguard Worker br label %loop 213*9880d681SAndroid Build Coastguard Worker 214*9880d681SAndroid Build Coastguard Workerloop: 215*9880d681SAndroid Build Coastguard Worker %iv = phi i32 [ 0, %entry ], [ %iv.inc, %loop ] 216*9880d681SAndroid Build Coastguard Worker %iv.inc = add nsw i32 %iv, 7 217*9880d681SAndroid Build Coastguard Worker; CHECK: %iv.inc = add nsw i32 %iv, 7 218*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: --> {7,+,7}<nuw><%loop> 219*9880d681SAndroid Build Coastguard Worker %becond = icmp ult i32 %iv, %n 220*9880d681SAndroid Build Coastguard Worker br i1 %becond, label %loop, label %leave 221*9880d681SAndroid Build Coastguard Worker 222*9880d681SAndroid Build Coastguard Workerleave: 223*9880d681SAndroid Build Coastguard Worker ret void 224*9880d681SAndroid Build Coastguard Worker} 225*9880d681SAndroid Build Coastguard Worker 226*9880d681SAndroid Build Coastguard Workerdefine void @bad_postinc_nsw_b(i32 %n) { 227*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: Classifying expressions for: @bad_postinc_nsw_b 228*9880d681SAndroid Build Coastguard Workerentry: 229*9880d681SAndroid Build Coastguard Worker br label %loop 230*9880d681SAndroid Build Coastguard Worker 231*9880d681SAndroid Build Coastguard Workerloop: 232*9880d681SAndroid Build Coastguard Worker %iv = phi i32 [ 0, %entry ], [ %iv.inc, %loop ] 233*9880d681SAndroid Build Coastguard Worker %iv.inc = add nsw i32 %iv, 7 234*9880d681SAndroid Build Coastguard Worker %iv.inc.and = and i32 %iv.inc, 0 235*9880d681SAndroid Build Coastguard Worker; CHECK: %iv.inc = add nsw i32 %iv, 7 236*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: --> {7,+,7}<nuw><%loop> 237*9880d681SAndroid Build Coastguard Worker %becond = icmp ult i32 %iv.inc.and, %n 238*9880d681SAndroid Build Coastguard Worker br i1 %becond, label %loop, label %leave 239*9880d681SAndroid Build Coastguard Worker 240*9880d681SAndroid Build Coastguard Workerleave: 241*9880d681SAndroid Build Coastguard Worker ret void 242*9880d681SAndroid Build Coastguard Worker} 243*9880d681SAndroid Build Coastguard Worker 244*9880d681SAndroid Build Coastguard Workerdeclare void @may_exit() nounwind 245*9880d681SAndroid Build Coastguard Worker 246*9880d681SAndroid Build Coastguard Workerdefine void @pr28012(i32 %n) { 247*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: Classifying expressions for: @pr28012 248*9880d681SAndroid Build Coastguard Workerentry: 249*9880d681SAndroid Build Coastguard Worker br label %loop 250*9880d681SAndroid Build Coastguard Worker 251*9880d681SAndroid Build Coastguard Workerloop: 252*9880d681SAndroid Build Coastguard Worker %iv = phi i32 [ 0, %entry ], [ %iv.inc, %loop ] 253*9880d681SAndroid Build Coastguard Worker %iv.inc = add nsw i32 %iv, 7 254*9880d681SAndroid Build Coastguard Worker; CHECK: %iv.inc = add nsw i32 %iv, 7 255*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: --> {7,+,7}<nuw><%loop> 256*9880d681SAndroid Build Coastguard Worker %becond = icmp ult i32 %iv.inc, %n 257*9880d681SAndroid Build Coastguard Worker call void @may_exit() 258*9880d681SAndroid Build Coastguard Worker br i1 %becond, label %loop, label %leave 259*9880d681SAndroid Build Coastguard Worker 260*9880d681SAndroid Build Coastguard Workerleave: 261*9880d681SAndroid Build Coastguard Worker ret void 262*9880d681SAndroid Build Coastguard Worker} 263