From 20354634ebb64023d322919633f8bd348a63891d Mon Sep 17 00:00:00 2001 From: Lang Hames Date: Thu, 23 Jul 2009 05:44:24 +0000 Subject: [PATCH] For real this time: PHI Def & Kill tracking added to PHIElimination. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@76865 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/CodeGen/PHIElimination.cpp | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/lib/CodeGen/PHIElimination.cpp b/lib/CodeGen/PHIElimination.cpp index 1cbe7989452..56dca086ef2 100644 --- a/lib/CodeGen/PHIElimination.cpp +++ b/lib/CodeGen/PHIElimination.cpp @@ -50,6 +50,8 @@ void llvm::PHIElimination::getAnalysisUsage(AnalysisUsage &AU) const { bool llvm::PHIElimination::runOnMachineFunction(MachineFunction &Fn) { MRI = &Fn.getRegInfo(); + PHIDefs.clear(); + PHIKills.clear(); analyzePHINodes(Fn); bool Changed = false; @@ -183,8 +185,8 @@ void llvm::PHIElimination::LowerAtomicPHINode( } // Record PHI def. - //assert(!hasPHIDef(DestReg) && "Vreg has multiple phi-defs?"); - //PHIDefs[DestReg] = &MBB; + assert(!hasPHIDef(DestReg) && "Vreg has multiple phi-defs?"); + PHIDefs[DestReg] = &MBB; // Update live variable information if there is any. LiveVariables *LV = getAnalysisIfAvailable(); @@ -232,7 +234,7 @@ void llvm::PHIElimination::LowerAtomicPHINode( MachineBasicBlock &opBlock = *MPhi->getOperand(i*2+2).getMBB(); // Record the kill. - //PHIKills[SrcReg].insert(&opBlock); + PHIKills[SrcReg].insert(&opBlock); // If source is defined by an implicit def, there is no need to insert a // copy.