From: Evan Cheng Date: Tue, 5 Aug 2008 07:10:38 +0000 (+0000) Subject: Fix PR2568: Fix bug that cause redudant kill marker after its live interval has been... X-Git-Url: http://plrg.eecs.uci.edu/git/?a=commitdiff_plain;h=068b4ff5531062a0c6e93d038c24fcf209527406;p=oota-llvm.git Fix PR2568: Fix bug that cause redudant kill marker after its live interval has been extended due to coalescing. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@54346 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/CodeGen/SimpleRegisterCoalescing.cpp b/lib/CodeGen/SimpleRegisterCoalescing.cpp index 68be3e111fb..9cb06ced3fe 100644 --- a/lib/CodeGen/SimpleRegisterCoalescing.cpp +++ b/lib/CodeGen/SimpleRegisterCoalescing.cpp @@ -533,14 +533,16 @@ void SimpleRegisterCoalescing::RemoveUnnecessaryKills(unsigned Reg, MachineOperand &UseMO = UI.getOperand(); if (UseMO.isKill()) { MachineInstr *UseMI = UseMO.getParent(); +#if 0 unsigned SReg, DReg; if (!tii_->isMoveInstr(*UseMI, SReg, DReg)) continue; +#endif unsigned UseIdx = li_->getUseIndex(li_->getInstructionIndex(UseMI)); if (JoinedCopies.count(UseMI)) continue; const LiveRange *UI = LI.getLiveRangeContaining(UseIdx); - if (!LI.isKill(UI->valno, UseIdx+1)) + if (!UI || !LI.isKill(UI->valno, UseIdx+1)) UseMO.setIsKill(false); } } diff --git a/test/CodeGen/X86/2008-08-05-SpillerBug.ll b/test/CodeGen/X86/2008-08-05-SpillerBug.ll new file mode 100644 index 00000000000..ca42f2bc137 --- /dev/null +++ b/test/CodeGen/X86/2008-08-05-SpillerBug.ll @@ -0,0 +1,44 @@ +; RUN: llvm-as < %s | llc -mtriple=i386-apple-darwin -disable-fp-elim -stats -info-output-file - | not grep {Number of dead stores elided} +; PR2568 + +@g_3 = external global i16 ; [#uses=1] +@g_5 = external global i32 ; [#uses=3] + +declare i32 @func_15(i16 signext , i16 signext , i32) nounwind + +define void @func_9_entry_2E_ce(i8 %p_11) nounwind { +newFuncRoot: + br label %entry.ce + +entry.ce.ret.exitStub: ; preds = %entry.ce + ret void + +entry.ce: ; preds = %newFuncRoot + load i16* @g_3, align 2 ; :0 [#uses=1] + icmp sgt i16 %0, 0 ; :1 [#uses=1] + zext i1 %1 to i32 ; :2 [#uses=1] + load i32* @g_5, align 4 ; :3 [#uses=4] + icmp ugt i32 %2, %3 ; :4 [#uses=1] + zext i1 %4 to i32 ; :5 [#uses=1] + icmp eq i32 %3, 0 ; :6 [#uses=1] + %.0 = select i1 %6, i32 1, i32 %3 ; [#uses=1] + urem i32 1, %.0 ; :7 [#uses=2] + sext i8 %p_11 to i16 ; :8 [#uses=1] + trunc i32 %3 to i16 ; :9 [#uses=1] + tail call i32 @func_15( i16 signext %8, i16 signext %9, i32 1 ) nounwind ; :10 [#uses=0] + load i32* @g_5, align 4 ; :11 [#uses=1] + trunc i32 %11 to i16 ; :12 [#uses=1] + tail call i32 @func_15( i16 signext %12, i16 signext 1, i32 %7 ) nounwind ; :13 [#uses=0] + sext i8 %p_11 to i32 ; :14 [#uses=1] + %p_11.lobit = lshr i8 %p_11, 7 ; [#uses=1] + %tmp = zext i8 %p_11.lobit to i32 ; [#uses=1] + %tmp.not = xor i32 %tmp, 1 ; [#uses=1] + %.015 = ashr i32 %14, %tmp.not ; [#uses=2] + icmp eq i32 %.015, 0 ; :15 [#uses=1] + %.016 = select i1 %15, i32 1, i32 %.015 ; [#uses=1] + udiv i32 %7, %.016 ; :16 [#uses=1] + icmp ult i32 %5, %16 ; :17 [#uses=1] + zext i1 %17 to i32 ; :18 [#uses=1] + store i32 %18, i32* @g_5, align 4 + br label %entry.ce.ret.exitStub +}