StrongPHIElim: Now with even fewer trivial bugs!
authorOwen Anderson <resistor@mac.com>
Wed, 9 Jan 2008 10:41:39 +0000 (10:41 +0000)
committerOwen Anderson <resistor@mac.com>
Wed, 9 Jan 2008 10:41:39 +0000 (10:41 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@45775 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CodeGen/StrongPHIElimination.cpp

index aa25dfebd80165fb4c9ed13059f0306006194505..efe838186bdf6435139c7bced6f23d7429f35a1b 100644 (file)
@@ -215,7 +215,9 @@ StrongPHIElimination::computeDomForest(std::set<unsigned>& regs) {
       stack.pop_back();
       CurrentParent = stack.back();
       
-      parentBlock = LV.getVarInfo(CurrentParent->getReg()).DefInst->getParent();
+      parentBlock = CurrentParent->getReg() ?
+                   LV.getVarInfo(CurrentParent->getReg()).DefInst->getParent() :
+                   0;
     }
     
     DomForestNode* child = new DomForestNode(*I, CurrentParent);
@@ -361,7 +363,7 @@ void StrongPHIElimination::processBlock(MachineBasicBlock* MBB) {
   std::set<unsigned> ProcessedNames;
   
   MachineBasicBlock::iterator P = MBB->begin();
-  while (P->getOpcode() == TargetInstrInfo::PHI) {
+  while (P != MBB->end() && P->getOpcode() == TargetInstrInfo::PHI) {
     LiveVariables::VarInfo& PHIInfo = LV.getVarInfo(P->getOperand(0).getReg());
 
     unsigned DestReg = P->getOperand(0).getReg();