1*9880d681SAndroid Build Coastguard Worker; RUN: opt < %s -analyze -scalar-evolution | FileCheck %s 2*9880d681SAndroid Build Coastguard Worker 3*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" 4*9880d681SAndroid Build Coastguard Worker 5*9880d681SAndroid Build Coastguard Worker; CHECK: Loop %bb7.i: Unpredictable backedge-taken count. 6*9880d681SAndroid Build Coastguard Worker 7*9880d681SAndroid Build Coastguard Worker %struct.complex = type { float, float } 8*9880d681SAndroid Build Coastguard Worker %struct.element = type { i32, i32 } 9*9880d681SAndroid Build Coastguard Worker %struct.node = type { %struct.node*, %struct.node*, i32 } 10*9880d681SAndroid Build Coastguard Worker@seed = external global i64 ; <i64*> [#uses=0] 11*9880d681SAndroid Build Coastguard Worker@_2E_str = external constant [18 x i8], align 1 ; <[18 x i8]*> [#uses=0] 12*9880d681SAndroid Build Coastguard Worker@_2E_str1 = external constant [4 x i8], align 1 ; <[4 x i8]*> [#uses=0] 13*9880d681SAndroid Build Coastguard Worker@value = external global float ; <float*> [#uses=0] 14*9880d681SAndroid Build Coastguard Worker@fixed = external global float ; <float*> [#uses=0] 15*9880d681SAndroid Build Coastguard Worker@floated = external global float ; <float*> [#uses=0] 16*9880d681SAndroid Build Coastguard Worker@permarray = external global [11 x i32], align 32 ; <[11 x i32]*> [#uses=0] 17*9880d681SAndroid Build Coastguard Worker@pctr = external global i32 ; <i32*> [#uses=0] 18*9880d681SAndroid Build Coastguard Worker@tree = external global %struct.node* ; <%struct.node**> [#uses=0] 19*9880d681SAndroid Build Coastguard Worker@stack = external global [4 x i32], align 16 ; <[4 x i32]*> [#uses=0] 20*9880d681SAndroid Build Coastguard Worker@cellspace = external global [19 x %struct.element], align 32 ; <[19 x %struct.element]*> [#uses=0] 21*9880d681SAndroid Build Coastguard Worker@freelist = external global i32 ; <i32*> [#uses=0] 22*9880d681SAndroid Build Coastguard Worker@movesdone = external global i32 ; <i32*> [#uses=0] 23*9880d681SAndroid Build Coastguard Worker@ima = external global [41 x [41 x i32]], align 32 ; <[41 x [41 x i32]]*> [#uses=0] 24*9880d681SAndroid Build Coastguard Worker@imb = external global [41 x [41 x i32]], align 32 ; <[41 x [41 x i32]]*> [#uses=0] 25*9880d681SAndroid Build Coastguard Worker@imr = external global [41 x [41 x i32]], align 32 ; <[41 x [41 x i32]]*> [#uses=0] 26*9880d681SAndroid Build Coastguard Worker@rma = external global [41 x [41 x float]], align 32 ; <[41 x [41 x float]]*> [#uses=0] 27*9880d681SAndroid Build Coastguard Worker@rmb = external global [41 x [41 x float]], align 32 ; <[41 x [41 x float]]*> [#uses=0] 28*9880d681SAndroid Build Coastguard Worker@rmr = external global [41 x [41 x float]], align 32 ; <[41 x [41 x float]]*> [#uses=0] 29*9880d681SAndroid Build Coastguard Worker@piececount = external global [4 x i32], align 16 ; <[4 x i32]*> [#uses=0] 30*9880d681SAndroid Build Coastguard Worker@class = external global [13 x i32], align 32 ; <[13 x i32]*> [#uses=0] 31*9880d681SAndroid Build Coastguard Worker@piecemax = external global [13 x i32], align 32 ; <[13 x i32]*> [#uses=0] 32*9880d681SAndroid Build Coastguard Worker@puzzl = external global [512 x i32], align 32 ; <[512 x i32]*> [#uses=0] 33*9880d681SAndroid Build Coastguard Worker@p = external global [13 x [512 x i32]], align 32 ; <[13 x [512 x i32]]*> [#uses=0] 34*9880d681SAndroid Build Coastguard Worker@n = external global i32 ; <i32*> [#uses=0] 35*9880d681SAndroid Build Coastguard Worker@kount = external global i32 ; <i32*> [#uses=0] 36*9880d681SAndroid Build Coastguard Worker@sortlist = external global [5001 x i32], align 32 ; <[5001 x i32]*> [#uses=0] 37*9880d681SAndroid Build Coastguard Worker@biggest = external global i32 ; <i32*> [#uses=0] 38*9880d681SAndroid Build Coastguard Worker@littlest = external global i32 ; <i32*> [#uses=0] 39*9880d681SAndroid Build Coastguard Worker@top = external global i32 ; <i32*> [#uses=0] 40*9880d681SAndroid Build Coastguard Worker@z = external global [257 x %struct.complex], align 32 ; <[257 x %struct.complex]*> [#uses=0] 41*9880d681SAndroid Build Coastguard Worker@w = external global [257 x %struct.complex], align 32 ; <[257 x %struct.complex]*> [#uses=0] 42*9880d681SAndroid Build Coastguard Worker@e = external global [130 x %struct.complex], align 32 ; <[130 x %struct.complex]*> [#uses=0] 43*9880d681SAndroid Build Coastguard Worker@zr = external global float ; <float*> [#uses=0] 44*9880d681SAndroid Build Coastguard Worker@zi = external global float ; <float*> [#uses=0] 45*9880d681SAndroid Build Coastguard Worker 46*9880d681SAndroid Build Coastguard Workerdeclare void @Initrand() nounwind 47*9880d681SAndroid Build Coastguard Worker 48*9880d681SAndroid Build Coastguard Workerdeclare i32 @Rand() nounwind 49*9880d681SAndroid Build Coastguard Worker 50*9880d681SAndroid Build Coastguard Workerdeclare void @Try(i32, i32*, i32*, i32*, i32*, i32*) nounwind 51*9880d681SAndroid Build Coastguard Worker 52*9880d681SAndroid Build Coastguard Workerdeclare i32 @puts(i8* nocapture) nounwind 53*9880d681SAndroid Build Coastguard Worker 54*9880d681SAndroid Build Coastguard Workerdeclare void @Queens(i32) nounwind 55*9880d681SAndroid Build Coastguard Worker 56*9880d681SAndroid Build Coastguard Workerdeclare i32 @printf(i8* nocapture, ...) nounwind 57*9880d681SAndroid Build Coastguard Worker 58*9880d681SAndroid Build Coastguard Workerdeclare i32 @main() nounwind 59*9880d681SAndroid Build Coastguard Worker 60*9880d681SAndroid Build Coastguard Workerdeclare void @Doit() nounwind 61*9880d681SAndroid Build Coastguard Worker 62*9880d681SAndroid Build Coastguard Workerdeclare void @Doit_bb7([15 x i32]*, [17 x i32]*, [9 x i32]*) nounwind 63*9880d681SAndroid Build Coastguard Worker 64*9880d681SAndroid Build Coastguard Workerdefine void @Doit_bb7_2E_i([9 x i32]* %x1, [15 x i32]* %c, [17 x i32]* %b, [9 x i32]* %a, i32* %q, i32* %x1.sub, i32* %b9, i32* %a10, i32* %c11) nounwind { 65*9880d681SAndroid Build Coastguard WorkernewFuncRoot: 66*9880d681SAndroid Build Coastguard Worker br label %bb7.i 67*9880d681SAndroid Build Coastguard Worker 68*9880d681SAndroid Build Coastguard WorkerTry.exit.exitStub: ; preds = %bb7.i 69*9880d681SAndroid Build Coastguard Worker ret void 70*9880d681SAndroid Build Coastguard Worker 71*9880d681SAndroid Build Coastguard Workerbb.i: ; preds = %bb7.i 72*9880d681SAndroid Build Coastguard Worker %tmp = add i32 %j.0.i, 1 ; <i32> [#uses=5] 73*9880d681SAndroid Build Coastguard Worker store i32 0, i32* %q, align 4 74*9880d681SAndroid Build Coastguard Worker %tmp1 = sext i32 %tmp to i64 ; <i64> [#uses=1] 75*9880d681SAndroid Build Coastguard Worker %tmp2 = getelementptr [9 x i32], [9 x i32]* %a, i64 0, i64 %tmp1 ; <i32*> [#uses=1] 76*9880d681SAndroid Build Coastguard Worker %tmp3 = load i32, i32* %tmp2, align 4 ; <i32> [#uses=1] 77*9880d681SAndroid Build Coastguard Worker %tmp4 = icmp eq i32 %tmp3, 0 ; <i1> [#uses=1] 78*9880d681SAndroid Build Coastguard Worker br i1 %tmp4, label %bb.i.bb7.i.backedge_crit_edge, label %bb1.i 79*9880d681SAndroid Build Coastguard Worker 80*9880d681SAndroid Build Coastguard Workerbb1.i: ; preds = %bb.i 81*9880d681SAndroid Build Coastguard Worker %tmp5 = add i32 %j.0.i, 2 ; <i32> [#uses=1] 82*9880d681SAndroid Build Coastguard Worker %tmp6 = sext i32 %tmp5 to i64 ; <i64> [#uses=1] 83*9880d681SAndroid Build Coastguard Worker %tmp7 = getelementptr [17 x i32], [17 x i32]* %b, i64 0, i64 %tmp6 ; <i32*> [#uses=1] 84*9880d681SAndroid Build Coastguard Worker %tmp8 = load i32, i32* %tmp7, align 4 ; <i32> [#uses=1] 85*9880d681SAndroid Build Coastguard Worker %tmp9 = icmp eq i32 %tmp8, 0 ; <i1> [#uses=1] 86*9880d681SAndroid Build Coastguard Worker br i1 %tmp9, label %bb1.i.bb7.i.backedge_crit_edge, label %bb2.i 87*9880d681SAndroid Build Coastguard Worker 88*9880d681SAndroid Build Coastguard Workerbb2.i: ; preds = %bb1.i 89*9880d681SAndroid Build Coastguard Worker %tmp10 = sub i32 7, %j.0.i ; <i32> [#uses=1] 90*9880d681SAndroid Build Coastguard Worker %tmp11 = sext i32 %tmp10 to i64 ; <i64> [#uses=1] 91*9880d681SAndroid Build Coastguard Worker %tmp12 = getelementptr [15 x i32], [15 x i32]* %c, i64 0, i64 %tmp11 ; <i32*> [#uses=1] 92*9880d681SAndroid Build Coastguard Worker %tmp13 = load i32, i32* %tmp12, align 4 ; <i32> [#uses=1] 93*9880d681SAndroid Build Coastguard Worker %tmp14 = icmp eq i32 %tmp13, 0 ; <i1> [#uses=1] 94*9880d681SAndroid Build Coastguard Worker br i1 %tmp14, label %bb2.i.bb7.i.backedge_crit_edge, label %bb3.i 95*9880d681SAndroid Build Coastguard Worker 96*9880d681SAndroid Build Coastguard Workerbb3.i: ; preds = %bb2.i 97*9880d681SAndroid Build Coastguard Worker %tmp15 = getelementptr [9 x i32], [9 x i32]* %x1, i64 0, i64 1 ; <i32*> [#uses=1] 98*9880d681SAndroid Build Coastguard Worker store i32 %tmp, i32* %tmp15, align 4 99*9880d681SAndroid Build Coastguard Worker %tmp16 = sext i32 %tmp to i64 ; <i64> [#uses=1] 100*9880d681SAndroid Build Coastguard Worker %tmp17 = getelementptr [9 x i32], [9 x i32]* %a, i64 0, i64 %tmp16 ; <i32*> [#uses=1] 101*9880d681SAndroid Build Coastguard Worker store i32 0, i32* %tmp17, align 4 102*9880d681SAndroid Build Coastguard Worker %tmp18 = add i32 %j.0.i, 2 ; <i32> [#uses=1] 103*9880d681SAndroid Build Coastguard Worker %tmp19 = sext i32 %tmp18 to i64 ; <i64> [#uses=1] 104*9880d681SAndroid Build Coastguard Worker %tmp20 = getelementptr [17 x i32], [17 x i32]* %b, i64 0, i64 %tmp19 ; <i32*> [#uses=1] 105*9880d681SAndroid Build Coastguard Worker store i32 0, i32* %tmp20, align 4 106*9880d681SAndroid Build Coastguard Worker %tmp21 = sub i32 7, %j.0.i ; <i32> [#uses=1] 107*9880d681SAndroid Build Coastguard Worker %tmp22 = sext i32 %tmp21 to i64 ; <i64> [#uses=1] 108*9880d681SAndroid Build Coastguard Worker %tmp23 = getelementptr [15 x i32], [15 x i32]* %c, i64 0, i64 %tmp22 ; <i32*> [#uses=1] 109*9880d681SAndroid Build Coastguard Worker store i32 0, i32* %tmp23, align 4 110*9880d681SAndroid Build Coastguard Worker call void @Try(i32 2, i32* %q, i32* %b9, i32* %a10, i32* %c11, i32* %x1.sub) nounwind 111*9880d681SAndroid Build Coastguard Worker %tmp24 = load i32, i32* %q, align 4 ; <i32> [#uses=1] 112*9880d681SAndroid Build Coastguard Worker %tmp25 = icmp eq i32 %tmp24, 0 ; <i1> [#uses=1] 113*9880d681SAndroid Build Coastguard Worker br i1 %tmp25, label %bb5.i, label %bb3.i.bb7.i.backedge_crit_edge 114*9880d681SAndroid Build Coastguard Worker 115*9880d681SAndroid Build Coastguard Workerbb5.i: ; preds = %bb3.i 116*9880d681SAndroid Build Coastguard Worker %tmp26 = sext i32 %tmp to i64 ; <i64> [#uses=1] 117*9880d681SAndroid Build Coastguard Worker %tmp27 = getelementptr [9 x i32], [9 x i32]* %a, i64 0, i64 %tmp26 ; <i32*> [#uses=1] 118*9880d681SAndroid Build Coastguard Worker store i32 1, i32* %tmp27, align 4 119*9880d681SAndroid Build Coastguard Worker %tmp28 = add i32 %j.0.i, 2 ; <i32> [#uses=1] 120*9880d681SAndroid Build Coastguard Worker %tmp29 = sext i32 %tmp28 to i64 ; <i64> [#uses=1] 121*9880d681SAndroid Build Coastguard Worker %tmp30 = getelementptr [17 x i32], [17 x i32]* %b, i64 0, i64 %tmp29 ; <i32*> [#uses=1] 122*9880d681SAndroid Build Coastguard Worker store i32 1, i32* %tmp30, align 4 123*9880d681SAndroid Build Coastguard Worker %tmp31 = sub i32 7, %j.0.i ; <i32> [#uses=1] 124*9880d681SAndroid Build Coastguard Worker %tmp32 = sext i32 %tmp31 to i64 ; <i64> [#uses=1] 125*9880d681SAndroid Build Coastguard Worker %tmp33 = getelementptr [15 x i32], [15 x i32]* %c, i64 0, i64 %tmp32 ; <i32*> [#uses=1] 126*9880d681SAndroid Build Coastguard Worker store i32 1, i32* %tmp33, align 4 127*9880d681SAndroid Build Coastguard Worker br label %bb7.i.backedge 128*9880d681SAndroid Build Coastguard Worker 129*9880d681SAndroid Build Coastguard Workerbb7.i.backedge: ; preds = %bb3.i.bb7.i.backedge_crit_edge, %bb2.i.bb7.i.backedge_crit_edge, %bb1.i.bb7.i.backedge_crit_edge, %bb.i.bb7.i.backedge_crit_edge, %bb5.i 130*9880d681SAndroid Build Coastguard Worker br label %bb7.i 131*9880d681SAndroid Build Coastguard Worker 132*9880d681SAndroid Build Coastguard Workerbb7.i: ; preds = %bb7.i.backedge, %newFuncRoot 133*9880d681SAndroid Build Coastguard Worker %j.0.i = phi i32 [ 0, %newFuncRoot ], [ %tmp, %bb7.i.backedge ] ; <i32> [#uses=8] 134*9880d681SAndroid Build Coastguard Worker %tmp34 = load i32, i32* %q, align 4 ; <i32> [#uses=1] 135*9880d681SAndroid Build Coastguard Worker %tmp35 = icmp eq i32 %tmp34, 0 ; <i1> [#uses=1] 136*9880d681SAndroid Build Coastguard Worker %tmp36 = icmp ne i32 %j.0.i, 8 ; <i1> [#uses=1] 137*9880d681SAndroid Build Coastguard Worker %tmp37 = and i1 %tmp35, %tmp36 ; <i1> [#uses=1] 138*9880d681SAndroid Build Coastguard Worker br i1 %tmp37, label %bb.i, label %Try.exit.exitStub 139*9880d681SAndroid Build Coastguard Worker 140*9880d681SAndroid Build Coastguard Workerbb.i.bb7.i.backedge_crit_edge: ; preds = %bb.i 141*9880d681SAndroid Build Coastguard Worker br label %bb7.i.backedge 142*9880d681SAndroid Build Coastguard Worker 143*9880d681SAndroid Build Coastguard Workerbb1.i.bb7.i.backedge_crit_edge: ; preds = %bb1.i 144*9880d681SAndroid Build Coastguard Worker br label %bb7.i.backedge 145*9880d681SAndroid Build Coastguard Worker 146*9880d681SAndroid Build Coastguard Workerbb2.i.bb7.i.backedge_crit_edge: ; preds = %bb2.i 147*9880d681SAndroid Build Coastguard Worker br label %bb7.i.backedge 148*9880d681SAndroid Build Coastguard Worker 149*9880d681SAndroid Build Coastguard Workerbb3.i.bb7.i.backedge_crit_edge: ; preds = %bb3.i 150*9880d681SAndroid Build Coastguard Worker br label %bb7.i.backedge 151*9880d681SAndroid Build Coastguard Worker} 152