1*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -regalloc=fast -optimize-regalloc=0 -verify-machineinstrs 2*9880d681SAndroid Build Coastguard Workertarget triple = "arm-pc-linux-gnu" 3*9880d681SAndroid Build Coastguard Worker 4*9880d681SAndroid Build Coastguard Worker; This test case would accidentally use the same physreg for two virtregs 5*9880d681SAndroid Build Coastguard Worker; because allocVirtReg forgot to check if registers were already used in the 6*9880d681SAndroid Build Coastguard Worker; instruction. 7*9880d681SAndroid Build Coastguard Worker; This caused the RegScavenger to complain, but -verify-machineinstrs also 8*9880d681SAndroid Build Coastguard Worker; catches it. 9*9880d681SAndroid Build Coastguard Worker 10*9880d681SAndroid Build Coastguard Worker%struct.CHESS_POSITION = type { i64, i64, i64, i64, i64, i64, i64, i64, i64, i64, i64, i64, i64, i64, i64, i64, i64, i64, i32, i32, i8, i8, [64 x i8], i8, i8, i8, i8, i8 } 11*9880d681SAndroid Build Coastguard Worker 12*9880d681SAndroid Build Coastguard Worker@search = external global %struct.CHESS_POSITION ; <%struct.CHESS_POSITION*> [#uses=1] 13*9880d681SAndroid Build Coastguard Worker@bishop_mobility_rr45 = external global [64 x [256 x i32]] ; <[64 x [256 x i32]]*> [#uses=1] 14*9880d681SAndroid Build Coastguard Worker 15*9880d681SAndroid Build Coastguard Workerdeclare fastcc i32 @FirstOne() 16*9880d681SAndroid Build Coastguard Worker 17*9880d681SAndroid Build Coastguard Workerdefine fastcc void @Evaluate() { 18*9880d681SAndroid Build Coastguard Workerentry: 19*9880d681SAndroid Build Coastguard Worker br i1 false, label %cond_false186, label %cond_true 20*9880d681SAndroid Build Coastguard Worker 21*9880d681SAndroid Build Coastguard Workercond_true: ; preds = %entry 22*9880d681SAndroid Build Coastguard Worker ret void 23*9880d681SAndroid Build Coastguard Worker 24*9880d681SAndroid Build Coastguard Workercond_false186: ; preds = %entry 25*9880d681SAndroid Build Coastguard Worker br i1 false, label %cond_true293, label %bb203 26*9880d681SAndroid Build Coastguard Worker 27*9880d681SAndroid Build Coastguard Workerbb203: ; preds = %cond_false186 28*9880d681SAndroid Build Coastguard Worker ret void 29*9880d681SAndroid Build Coastguard Worker 30*9880d681SAndroid Build Coastguard Workercond_true293: ; preds = %cond_false186 31*9880d681SAndroid Build Coastguard Worker br i1 false, label %cond_true298, label %cond_next317 32*9880d681SAndroid Build Coastguard Worker 33*9880d681SAndroid Build Coastguard Workercond_true298: ; preds = %cond_true293 34*9880d681SAndroid Build Coastguard Worker br i1 false, label %cond_next518, label %cond_true397.preheader 35*9880d681SAndroid Build Coastguard Worker 36*9880d681SAndroid Build Coastguard Workercond_next317: ; preds = %cond_true293 37*9880d681SAndroid Build Coastguard Worker ret void 38*9880d681SAndroid Build Coastguard Worker 39*9880d681SAndroid Build Coastguard Workercond_true397.preheader: ; preds = %cond_true298 40*9880d681SAndroid Build Coastguard Worker ret void 41*9880d681SAndroid Build Coastguard Worker 42*9880d681SAndroid Build Coastguard Workercond_next518: ; preds = %cond_true298 43*9880d681SAndroid Build Coastguard Worker br i1 false, label %bb1069, label %cond_true522 44*9880d681SAndroid Build Coastguard Worker 45*9880d681SAndroid Build Coastguard Workercond_true522: ; preds = %cond_next518 46*9880d681SAndroid Build Coastguard Worker ret void 47*9880d681SAndroid Build Coastguard Worker 48*9880d681SAndroid Build Coastguard Workerbb1069: ; preds = %cond_next518 49*9880d681SAndroid Build Coastguard Worker br i1 false, label %cond_next1131, label %bb1096 50*9880d681SAndroid Build Coastguard Worker 51*9880d681SAndroid Build Coastguard Workerbb1096: ; preds = %bb1069 52*9880d681SAndroid Build Coastguard Worker ret void 53*9880d681SAndroid Build Coastguard Worker 54*9880d681SAndroid Build Coastguard Workercond_next1131: ; preds = %bb1069 55*9880d681SAndroid Build Coastguard Worker br i1 false, label %cond_next1207, label %cond_true1150 56*9880d681SAndroid Build Coastguard Worker 57*9880d681SAndroid Build Coastguard Workercond_true1150: ; preds = %cond_next1131 58*9880d681SAndroid Build Coastguard Worker ret void 59*9880d681SAndroid Build Coastguard Worker 60*9880d681SAndroid Build Coastguard Workercond_next1207: ; preds = %cond_next1131 61*9880d681SAndroid Build Coastguard Worker br i1 false, label %cond_next1219, label %cond_true1211 62*9880d681SAndroid Build Coastguard Worker 63*9880d681SAndroid Build Coastguard Workercond_true1211: ; preds = %cond_next1207 64*9880d681SAndroid Build Coastguard Worker ret void 65*9880d681SAndroid Build Coastguard Worker 66*9880d681SAndroid Build Coastguard Workercond_next1219: ; preds = %cond_next1207 67*9880d681SAndroid Build Coastguard Worker br i1 false, label %cond_true1223, label %cond_next1283 68*9880d681SAndroid Build Coastguard Worker 69*9880d681SAndroid Build Coastguard Workercond_true1223: ; preds = %cond_next1219 70*9880d681SAndroid Build Coastguard Worker br i1 false, label %cond_true1254, label %cond_true1264 71*9880d681SAndroid Build Coastguard Worker 72*9880d681SAndroid Build Coastguard Workercond_true1254: ; preds = %cond_true1223 73*9880d681SAndroid Build Coastguard Worker br i1 false, label %bb1567, label %cond_true1369.preheader 74*9880d681SAndroid Build Coastguard Worker 75*9880d681SAndroid Build Coastguard Workercond_true1264: ; preds = %cond_true1223 76*9880d681SAndroid Build Coastguard Worker ret void 77*9880d681SAndroid Build Coastguard Worker 78*9880d681SAndroid Build Coastguard Workercond_next1283: ; preds = %cond_next1219 79*9880d681SAndroid Build Coastguard Worker ret void 80*9880d681SAndroid Build Coastguard Worker 81*9880d681SAndroid Build Coastguard Workercond_true1369.preheader: ; preds = %cond_true1254 82*9880d681SAndroid Build Coastguard Worker ret void 83*9880d681SAndroid Build Coastguard Worker 84*9880d681SAndroid Build Coastguard Workerbb1567: ; preds = %cond_true1254 85*9880d681SAndroid Build Coastguard Worker %tmp1591 = load i64, i64* getelementptr inbounds (%struct.CHESS_POSITION, %struct.CHESS_POSITION* @search, i32 0, i32 4) ; <i64> [#uses=1] 86*9880d681SAndroid Build Coastguard Worker %tmp1572 = tail call fastcc i32 @FirstOne() ; <i32> [#uses=1] 87*9880d681SAndroid Build Coastguard Worker %tmp1594 = load i32, i32* undef ; <i32> [#uses=1] 88*9880d681SAndroid Build Coastguard Worker %tmp1594.upgrd.5 = trunc i32 %tmp1594 to i8 ; <i8> [#uses=1] 89*9880d681SAndroid Build Coastguard Worker %shift.upgrd.6 = zext i8 %tmp1594.upgrd.5 to i64 ; <i64> [#uses=1] 90*9880d681SAndroid Build Coastguard Worker %tmp1595 = lshr i64 %tmp1591, %shift.upgrd.6 ; <i64> [#uses=1] 91*9880d681SAndroid Build Coastguard Worker %tmp1595.upgrd.7 = trunc i64 %tmp1595 to i32 ; <i32> [#uses=1] 92*9880d681SAndroid Build Coastguard Worker %tmp1596 = and i32 %tmp1595.upgrd.7, 255 ; <i32> [#uses=1] 93*9880d681SAndroid Build Coastguard Worker %gep.upgrd.8 = zext i32 %tmp1596 to i64 ; <i64> [#uses=1] 94*9880d681SAndroid Build Coastguard Worker %tmp1598 = getelementptr [64 x [256 x i32]], [64 x [256 x i32]]* @bishop_mobility_rr45, i32 0, i32 %tmp1572, i64 %gep.upgrd.8 ; <i32*> [#uses=1] 95*9880d681SAndroid Build Coastguard Worker %tmp1599 = load i32, i32* %tmp1598 ; <i32> [#uses=1] 96*9880d681SAndroid Build Coastguard Worker %tmp1602 = sub i32 0, %tmp1599 ; <i32> [#uses=1] 97*9880d681SAndroid Build Coastguard Worker br i1 undef, label %cond_next1637, label %cond_true1607 98*9880d681SAndroid Build Coastguard Worker 99*9880d681SAndroid Build Coastguard Workercond_true1607: ; preds = %bb1567 100*9880d681SAndroid Build Coastguard Worker ret void 101*9880d681SAndroid Build Coastguard Worker 102*9880d681SAndroid Build Coastguard Workercond_next1637: ; preds = %bb1567 103*9880d681SAndroid Build Coastguard Worker %tmp1662 = sub i32 %tmp1602, 0 ; <i32> [#uses=0] 104*9880d681SAndroid Build Coastguard Worker ret void 105*9880d681SAndroid Build Coastguard Worker} 106