From: Chris Lattner Date: Mon, 12 May 2003 14:26:38 +0000 (+0000) Subject: Fix bug where we could iterate off the end of a basic block X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=a13f0d3f4159b1f54bcfc733ccd94977b020ea56;p=oota-llvm.git Fix bug where we could iterate off the end of a basic block git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@6116 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/CodeGen/PHIElimination.cpp b/lib/CodeGen/PHIElimination.cpp index 33537259fb7..e7f4c9f5411 100644 --- a/lib/CodeGen/PHIElimination.cpp +++ b/lib/CodeGen/PHIElimination.cpp @@ -76,8 +76,9 @@ bool PNE::EliminatePHINodes(MachineFunction &MF, MachineBasicBlock &MBB) { // into the phi node destination. // MachineBasicBlock::iterator AfterPHIsIt = MBB.begin(); - if (AfterPHIsIt != MBB.end()) - while ((*AfterPHIsIt)->getOpcode() == TargetInstrInfo::PHI) ++AfterPHIsIt; + while (AfterPHIsIt != MBB.end() && + (*AfterPHIsIt)->getOpcode() == TargetInstrInfo::PHI) + ++AfterPHIsIt; // Skip over all of the PHI nodes... RegInfo->copyRegToReg(MBB, AfterPHIsIt, DestReg, IncomingReg, RC); // Update live variable information if there is any...