1*9880d681SAndroid Build Coastguard Worker; RUN: llc -verify-regalloc < %s | FileCheck %s 2*9880d681SAndroid Build Coastguard Worker; Check all spills are rematerialized. 3*9880d681SAndroid Build Coastguard Worker; CHECK-NOT: Spill 4*9880d681SAndroid Build Coastguard Worker 5*9880d681SAndroid Build Coastguard Workertarget datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128" 6*9880d681SAndroid Build Coastguard Workertarget triple = "x86_64-unknown-linux-gnu" 7*9880d681SAndroid Build Coastguard Worker 8*9880d681SAndroid Build Coastguard Worker@b = common global double 0.000000e+00, align 8 9*9880d681SAndroid Build Coastguard Worker@a = common global i32 0, align 4 10*9880d681SAndroid Build Coastguard Worker 11*9880d681SAndroid Build Coastguard Worker; Function Attrs: nounwind uwtable 12*9880d681SAndroid Build Coastguard Workerdefine i32 @uniform_testdata(i32 %p1) { 13*9880d681SAndroid Build Coastguard Workerentry: 14*9880d681SAndroid Build Coastguard Worker %cmp3 = icmp sgt i32 %p1, 0 15*9880d681SAndroid Build Coastguard Worker br i1 %cmp3, label %for.body.preheader, label %for.end 16*9880d681SAndroid Build Coastguard Worker 17*9880d681SAndroid Build Coastguard Workerfor.body.preheader: ; preds = %entry 18*9880d681SAndroid Build Coastguard Worker %tmp = add i32 %p1, -1 19*9880d681SAndroid Build Coastguard Worker %xtraiter = and i32 %p1, 7 20*9880d681SAndroid Build Coastguard Worker %lcmp.mod = icmp eq i32 %xtraiter, 0 21*9880d681SAndroid Build Coastguard Worker br i1 %lcmp.mod, label %for.body.preheader.split, label %for.body.prol.preheader 22*9880d681SAndroid Build Coastguard Worker 23*9880d681SAndroid Build Coastguard Workerfor.body.prol.preheader: ; preds = %for.body.preheader 24*9880d681SAndroid Build Coastguard Worker br label %for.body.prol 25*9880d681SAndroid Build Coastguard Worker 26*9880d681SAndroid Build Coastguard Workerfor.body.prol: ; preds = %for.body.prol, %for.body.prol.preheader 27*9880d681SAndroid Build Coastguard Worker %i.04.prol = phi i32 [ %inc.prol, %for.body.prol ], [ 0, %for.body.prol.preheader ] 28*9880d681SAndroid Build Coastguard Worker %prol.iter = phi i32 [ %prol.iter.sub, %for.body.prol ], [ %xtraiter, %for.body.prol.preheader ] 29*9880d681SAndroid Build Coastguard Worker %tmp1 = load double, double* @b, align 8 30*9880d681SAndroid Build Coastguard Worker %call.prol = tail call double @pow(double %tmp1, double 2.500000e-01) 31*9880d681SAndroid Build Coastguard Worker %inc.prol = add nuw nsw i32 %i.04.prol, 1 32*9880d681SAndroid Build Coastguard Worker %prol.iter.sub = add i32 %prol.iter, -1 33*9880d681SAndroid Build Coastguard Worker %prol.iter.cmp = icmp eq i32 %prol.iter.sub, 0 34*9880d681SAndroid Build Coastguard Worker br i1 %prol.iter.cmp, label %for.body.preheader.split.loopexit, label %for.body.prol 35*9880d681SAndroid Build Coastguard Worker 36*9880d681SAndroid Build Coastguard Workerfor.body.preheader.split.loopexit: ; preds = %for.body.prol 37*9880d681SAndroid Build Coastguard Worker %inc.prol.lcssa = phi i32 [ %inc.prol, %for.body.prol ] 38*9880d681SAndroid Build Coastguard Worker br label %for.body.preheader.split 39*9880d681SAndroid Build Coastguard Worker 40*9880d681SAndroid Build Coastguard Workerfor.body.preheader.split: ; preds = %for.body.preheader.split.loopexit, %for.body.preheader 41*9880d681SAndroid Build Coastguard Worker %i.04.unr = phi i32 [ 0, %for.body.preheader ], [ %inc.prol.lcssa, %for.body.preheader.split.loopexit ] 42*9880d681SAndroid Build Coastguard Worker %tmp2 = icmp ult i32 %tmp, 7 43*9880d681SAndroid Build Coastguard Worker br i1 %tmp2, label %for.end.loopexit, label %for.body.preheader.split.split 44*9880d681SAndroid Build Coastguard Worker 45*9880d681SAndroid Build Coastguard Workerfor.body.preheader.split.split: ; preds = %for.body.preheader.split 46*9880d681SAndroid Build Coastguard Worker br label %for.body 47*9880d681SAndroid Build Coastguard Worker 48*9880d681SAndroid Build Coastguard Workerfor.body: ; preds = %for.body, %for.body.preheader.split.split 49*9880d681SAndroid Build Coastguard Worker %i.04 = phi i32 [ %i.04.unr, %for.body.preheader.split.split ], [ %inc.7, %for.body ] 50*9880d681SAndroid Build Coastguard Worker %tmp3 = load double, double* @b, align 8 51*9880d681SAndroid Build Coastguard Worker %call = tail call double @pow(double %tmp3, double 2.500000e-01) 52*9880d681SAndroid Build Coastguard Worker %tmp4 = load double, double* @b, align 8 53*9880d681SAndroid Build Coastguard Worker %call.1 = tail call double @pow(double %tmp4, double 2.500000e-01) 54*9880d681SAndroid Build Coastguard Worker %inc.7 = add nsw i32 %i.04, 8 55*9880d681SAndroid Build Coastguard Worker %exitcond.7 = icmp eq i32 %inc.7, %p1 56*9880d681SAndroid Build Coastguard Worker br i1 %exitcond.7, label %for.end.loopexit.unr-lcssa, label %for.body 57*9880d681SAndroid Build Coastguard Worker 58*9880d681SAndroid Build Coastguard Workerfor.end.loopexit.unr-lcssa: ; preds = %for.body 59*9880d681SAndroid Build Coastguard Worker br label %for.end.loopexit 60*9880d681SAndroid Build Coastguard Worker 61*9880d681SAndroid Build Coastguard Workerfor.end.loopexit: ; preds = %for.end.loopexit.unr-lcssa, %for.body.preheader.split 62*9880d681SAndroid Build Coastguard Worker br label %for.end 63*9880d681SAndroid Build Coastguard Worker 64*9880d681SAndroid Build Coastguard Workerfor.end: ; preds = %for.end.loopexit, %entry 65*9880d681SAndroid Build Coastguard Worker %tmp5 = load i32, i32* @a, align 4 66*9880d681SAndroid Build Coastguard Worker ret i32 %tmp5 67*9880d681SAndroid Build Coastguard Worker} 68*9880d681SAndroid Build Coastguard Worker 69*9880d681SAndroid Build Coastguard Worker; Function Attrs: nounwind 70*9880d681SAndroid Build Coastguard Workerdeclare double @pow(double, double) 71