1*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -regalloc=greedy -mcpu=cortex-a8 -relocation-model=pic -disable-fp-elim -verify-machineinstrs | FileCheck %s 2*9880d681SAndroid Build Coastguard Worker; 3*9880d681SAndroid Build Coastguard Worker; ARM tests that crash or fail with the greedy register allocator. 4*9880d681SAndroid Build Coastguard Worker 5*9880d681SAndroid Build Coastguard Workertarget triple = "thumbv7-apple-darwin" 6*9880d681SAndroid Build Coastguard Worker 7*9880d681SAndroid Build Coastguard Workerdeclare double @exp(double) 8*9880d681SAndroid Build Coastguard Worker 9*9880d681SAndroid Build Coastguard Worker; CHECK: remat_subreg 10*9880d681SAndroid Build Coastguard Workerdefine void @remat_subreg(float* nocapture %x, i32* %y, i32 %n, i32 %z, float %c, float %lambda, float* nocapture %ret_f, float* nocapture %ret_df) nounwind { 11*9880d681SAndroid Build Coastguard Workerentry: 12*9880d681SAndroid Build Coastguard Worker %conv16 = fpext float %lambda to double 13*9880d681SAndroid Build Coastguard Worker %mul17 = fmul double %conv16, -1.000000e+00 14*9880d681SAndroid Build Coastguard Worker br i1 undef, label %cond.end.us, label %cond.end 15*9880d681SAndroid Build Coastguard Worker 16*9880d681SAndroid Build Coastguard Workercond.end.us: ; preds = %entry 17*9880d681SAndroid Build Coastguard Worker unreachable 18*9880d681SAndroid Build Coastguard Worker 19*9880d681SAndroid Build Coastguard Workercond.end: ; preds = %cond.end, %entry 20*9880d681SAndroid Build Coastguard Worker %mul = fmul double undef, 0.000000e+00 21*9880d681SAndroid Build Coastguard Worker %add = fadd double undef, %mul 22*9880d681SAndroid Build Coastguard Worker %add46 = fadd double undef, undef 23*9880d681SAndroid Build Coastguard Worker %add75 = fadd double 0.000000e+00, undef 24*9880d681SAndroid Build Coastguard Worker br i1 undef, label %for.end, label %cond.end 25*9880d681SAndroid Build Coastguard Worker 26*9880d681SAndroid Build Coastguard Workerfor.end: ; preds = %cond.end 27*9880d681SAndroid Build Coastguard Worker %conv78 = sitofp i32 %z to double 28*9880d681SAndroid Build Coastguard Worker %conv83 = fpext float %c to double 29*9880d681SAndroid Build Coastguard Worker %mul84 = fmul double %mul17, %conv83 30*9880d681SAndroid Build Coastguard Worker %call85 = tail call double @exp(double %mul84) nounwind 31*9880d681SAndroid Build Coastguard Worker %mul86 = fmul double %conv78, %call85 32*9880d681SAndroid Build Coastguard Worker %add88 = fadd double 0.000000e+00, %mul86 33*9880d681SAndroid Build Coastguard Worker; CHECK: bl _exp 34*9880d681SAndroid Build Coastguard Worker %call100 = tail call double @exp(double %mul84) nounwind 35*9880d681SAndroid Build Coastguard Worker %mul101 = fmul double undef, %call100 36*9880d681SAndroid Build Coastguard Worker %add103 = fadd double %add46, %mul101 37*9880d681SAndroid Build Coastguard Worker %mul111 = fmul double undef, %conv83 38*9880d681SAndroid Build Coastguard Worker %mul119 = fmul double %mul111, undef 39*9880d681SAndroid Build Coastguard Worker %add121 = fadd double undef, %mul119 40*9880d681SAndroid Build Coastguard Worker %div = fdiv double 1.000000e+00, %conv16 41*9880d681SAndroid Build Coastguard Worker %div126 = fdiv double %add, %add75 42*9880d681SAndroid Build Coastguard Worker %sub = fsub double %div, %div126 43*9880d681SAndroid Build Coastguard Worker %div129 = fdiv double %add103, %add88 44*9880d681SAndroid Build Coastguard Worker %add130 = fadd double %sub, %div129 45*9880d681SAndroid Build Coastguard Worker %conv131 = fptrunc double %add130 to float 46*9880d681SAndroid Build Coastguard Worker store float %conv131, float* %ret_f, align 4 47*9880d681SAndroid Build Coastguard Worker %mul139 = fmul double %div129, %div129 48*9880d681SAndroid Build Coastguard Worker %div142 = fdiv double %add121, %add88 49*9880d681SAndroid Build Coastguard Worker %sub143 = fsub double %mul139, %div142 50*9880d681SAndroid Build Coastguard Worker; %lambda is passed on the stack, and the stack slot load is rematerialized. 51*9880d681SAndroid Build Coastguard Worker; The rematted load of a float constrains the D register used for the mul. 52*9880d681SAndroid Build Coastguard Worker; CHECK: vldr 53*9880d681SAndroid Build Coastguard Worker %mul146 = fmul float %lambda, %lambda 54*9880d681SAndroid Build Coastguard Worker %conv147 = fpext float %mul146 to double 55*9880d681SAndroid Build Coastguard Worker %div148 = fdiv double 1.000000e+00, %conv147 56*9880d681SAndroid Build Coastguard Worker %sub149 = fsub double %sub143, %div148 57*9880d681SAndroid Build Coastguard Worker %conv150 = fptrunc double %sub149 to float 58*9880d681SAndroid Build Coastguard Worker store float %conv150, float* %ret_df, align 4 59*9880d681SAndroid Build Coastguard Worker ret void 60*9880d681SAndroid Build Coastguard Worker} 61*9880d681SAndroid Build Coastguard Worker 62*9880d681SAndroid Build Coastguard Worker; CHECK: insert_elem 63*9880d681SAndroid Build Coastguard Worker; This test has a sub-register copy with a kill flag: 64*9880d681SAndroid Build Coastguard Worker; %vreg6:ssub_3<def> = COPY %vreg6:ssub_2<kill>; QPR_VFP2:%vreg6 65*9880d681SAndroid Build Coastguard Worker; The rewriter must do something sensible with that, or the scavenger crashes. 66*9880d681SAndroid Build Coastguard Workerdefine void @insert_elem() nounwind { 67*9880d681SAndroid Build Coastguard Workerentry: 68*9880d681SAndroid Build Coastguard Worker br i1 undef, label %if.end251, label %if.then84 69*9880d681SAndroid Build Coastguard Worker 70*9880d681SAndroid Build Coastguard Workerif.then84: ; preds = %entry 71*9880d681SAndroid Build Coastguard Worker br i1 undef, label %if.end251, label %if.then195 72*9880d681SAndroid Build Coastguard Worker 73*9880d681SAndroid Build Coastguard Workerif.then195: ; preds = %if.then84 74*9880d681SAndroid Build Coastguard Worker %div = fdiv float 1.000000e+00, undef 75*9880d681SAndroid Build Coastguard Worker %vecinit207 = insertelement <4 x float> undef, float %div, i32 1 76*9880d681SAndroid Build Coastguard Worker %vecinit208 = insertelement <4 x float> %vecinit207, float 1.000000e+00, i32 2 77*9880d681SAndroid Build Coastguard Worker %vecinit209 = insertelement <4 x float> %vecinit208, float 1.000000e+00, i32 3 78*9880d681SAndroid Build Coastguard Worker %mul216 = fmul <4 x float> zeroinitializer, %vecinit209 79*9880d681SAndroid Build Coastguard Worker store <4 x float> %mul216, <4 x float>* undef, align 16 80*9880d681SAndroid Build Coastguard Worker br label %if.end251 81*9880d681SAndroid Build Coastguard Worker 82*9880d681SAndroid Build Coastguard Workerif.end251: ; preds = %if.then195, %if.then84, %entry 83*9880d681SAndroid Build Coastguard Worker ret void 84*9880d681SAndroid Build Coastguard Worker} 85*9880d681SAndroid Build Coastguard Worker 86*9880d681SAndroid Build Coastguard Worker; Coalescer failure: removeCopyByCommutingDef leaves a bad kill flag 87*9880d681SAndroid Build Coastguard Worker; behind. 88*9880d681SAndroid Build Coastguard Workerdefine void @rdar11950722() nounwind readonly optsize ssp align 2 { 89*9880d681SAndroid Build Coastguard Workerentry: 90*9880d681SAndroid Build Coastguard Worker br i1 undef, label %land.lhs.true7, label %lor.lhs.false.i 91*9880d681SAndroid Build Coastguard Worker 92*9880d681SAndroid Build Coastguard Workerlor.lhs.false.i: 93*9880d681SAndroid Build Coastguard Worker br i1 undef, label %if.then10.i, label %land.lhs.true7 94*9880d681SAndroid Build Coastguard Worker 95*9880d681SAndroid Build Coastguard Workerif.then10.i: 96*9880d681SAndroid Build Coastguard Worker %xFlags.1.i = select i1 undef, i32 0, i32 undef 97*9880d681SAndroid Build Coastguard Worker br i1 undef, label %land.lhs.true33.i, label %f.exit 98*9880d681SAndroid Build Coastguard Worker 99*9880d681SAndroid Build Coastguard Workerland.lhs.true33.i: 100*9880d681SAndroid Build Coastguard Worker %and26.i = and i32 %xFlags.1.i, 8 101*9880d681SAndroid Build Coastguard Worker %cmp27.i = icmp eq i32 %and26.i, 0 102*9880d681SAndroid Build Coastguard Worker %and29.i = and i32 %xFlags.1.i, 2147483645 103*9880d681SAndroid Build Coastguard Worker %xFlags.1.and29.i = select i1 %cmp27.i, i32 %xFlags.1.i, i32 %and29.i 104*9880d681SAndroid Build Coastguard Worker %and34.i = and i32 %xFlags.1.i, 8 105*9880d681SAndroid Build Coastguard Worker %cmp35.i = icmp eq i32 %and34.i, 0 106*9880d681SAndroid Build Coastguard Worker %and37.i = and i32 %xFlags.1.i, 2147483645 107*9880d681SAndroid Build Coastguard Worker %yFlags.1.and37.i = select i1 %cmp35.i, i32 %xFlags.1.i, i32 %and37.i 108*9880d681SAndroid Build Coastguard Worker br label %f.exit 109*9880d681SAndroid Build Coastguard Worker 110*9880d681SAndroid Build Coastguard Workerf.exit: 111*9880d681SAndroid Build Coastguard Worker %xFlags.3.i = phi i32 [ %xFlags.1.and29.i, %land.lhs.true33.i ], [ %xFlags.1.i, %if.then10.i ] 112*9880d681SAndroid Build Coastguard Worker %yFlags.2.i = phi i32 [ %yFlags.1.and37.i, %land.lhs.true33.i ], [ %xFlags.1.i, %if.then10.i ] 113*9880d681SAndroid Build Coastguard Worker %cmp40.i = icmp eq i32 %xFlags.3.i, %yFlags.2.i 114*9880d681SAndroid Build Coastguard Worker br i1 %cmp40.i, label %land.lhs.true7, label %land.end 115*9880d681SAndroid Build Coastguard Worker 116*9880d681SAndroid Build Coastguard Workerland.lhs.true7: 117*9880d681SAndroid Build Coastguard Worker br i1 undef, label %land.lhs.true34, label %lor.lhs.false27 118*9880d681SAndroid Build Coastguard Worker 119*9880d681SAndroid Build Coastguard Workerlor.lhs.false27: 120*9880d681SAndroid Build Coastguard Worker br i1 undef, label %land.lhs.true34, label %land.end 121*9880d681SAndroid Build Coastguard Worker 122*9880d681SAndroid Build Coastguard Workerland.lhs.true34: 123*9880d681SAndroid Build Coastguard Worker br i1 undef, label %land.end, label %lor.lhs.false44 124*9880d681SAndroid Build Coastguard Worker 125*9880d681SAndroid Build Coastguard Workerlor.lhs.false44: 126*9880d681SAndroid Build Coastguard Worker ret void 127*9880d681SAndroid Build Coastguard Worker 128*9880d681SAndroid Build Coastguard Workerland.end: 129*9880d681SAndroid Build Coastguard Worker ret void 130*9880d681SAndroid Build Coastguard Worker} 131