Fix a miscompilation of 197.parser that occurs when you have single basic

block loops.


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@11990 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Chris Lattner 2004-02-29 07:10:16 +00:00
parent 4279f3c984
commit 168aa90bf6
2 changed files with 28 additions and 16 deletions

View File

@ -567,23 +567,22 @@ void ISel::SelectPHINodes() {
const Function &LF = *F->getFunction(); // The LLVM function... const Function &LF = *F->getFunction(); // The LLVM function...
for (Function::const_iterator I = LF.begin(), E = LF.end(); I != E; ++I) { for (Function::const_iterator I = LF.begin(), E = LF.end(); I != E; ++I) {
const BasicBlock *BB = I; const BasicBlock *BB = I;
MachineBasicBlock *MBB = MBBMap[I]; MachineBasicBlock &MBB = *MBBMap[I];
// Loop over all of the PHI nodes in the LLVM basic block... // Loop over all of the PHI nodes in the LLVM basic block...
MachineBasicBlock::iterator instr = MBB->begin(); MachineBasicBlock::iterator PHIInsertPoint = MBB.begin();
for (BasicBlock::const_iterator I = BB->begin(); for (BasicBlock::const_iterator I = BB->begin();
PHINode *PN = const_cast<PHINode*>(dyn_cast<PHINode>(I)); ++I) { PHINode *PN = const_cast<PHINode*>(dyn_cast<PHINode>(I)); ++I) {
// Create a new machine instr PHI node, and insert it. // Create a new machine instr PHI node, and insert it.
unsigned PHIReg = getReg(*PN); unsigned PHIReg = getReg(*PN);
MachineInstr *PhiMI = BuildMI(X86::PHI, PN->getNumOperands(), PHIReg); MachineInstr *PhiMI = BuildMI(MBB, PHIInsertPoint,
MBB->insert(instr, PhiMI); X86::PHI, PN->getNumOperands(), PHIReg);
MachineInstr *LongPhiMI = 0; MachineInstr *LongPhiMI = 0;
if (PN->getType() == Type::LongTy || PN->getType() == Type::ULongTy) { if (PN->getType() == Type::LongTy || PN->getType() == Type::ULongTy)
LongPhiMI = BuildMI(X86::PHI, PN->getNumOperands(), PHIReg+1); LongPhiMI = BuildMI(MBB, PHIInsertPoint,
MBB->insert(instr, LongPhiMI); X86::PHI, PN->getNumOperands(), PHIReg+1);
}
// PHIValues - Map of blocks to incoming virtual registers. We use this // PHIValues - Map of blocks to incoming virtual registers. We use this
// so that we only initialize one incoming value for a particular block, // so that we only initialize one incoming value for a particular block,
@ -636,6 +635,13 @@ void ISel::SelectPHINodes() {
LongPhiMI->addMachineBasicBlockOperand(PredMBB); LongPhiMI->addMachineBasicBlockOperand(PredMBB);
} }
} }
// Now that we emitted all of the incoming values for the PHI node, make
// sure to reposition the InsertPoint after the PHI that we just added.
// This is needed because we might have inserted a constant into this
// block, right after the PHI's which is before the old insert point!
PHIInsertPoint = LongPhiMI ? LongPhiMI : PhiMI;
++PHIInsertPoint;
} }
} }
} }

View File

@ -567,23 +567,22 @@ void ISel::SelectPHINodes() {
const Function &LF = *F->getFunction(); // The LLVM function... const Function &LF = *F->getFunction(); // The LLVM function...
for (Function::const_iterator I = LF.begin(), E = LF.end(); I != E; ++I) { for (Function::const_iterator I = LF.begin(), E = LF.end(); I != E; ++I) {
const BasicBlock *BB = I; const BasicBlock *BB = I;
MachineBasicBlock *MBB = MBBMap[I]; MachineBasicBlock &MBB = *MBBMap[I];
// Loop over all of the PHI nodes in the LLVM basic block... // Loop over all of the PHI nodes in the LLVM basic block...
MachineBasicBlock::iterator instr = MBB->begin(); MachineBasicBlock::iterator PHIInsertPoint = MBB.begin();
for (BasicBlock::const_iterator I = BB->begin(); for (BasicBlock::const_iterator I = BB->begin();
PHINode *PN = const_cast<PHINode*>(dyn_cast<PHINode>(I)); ++I) { PHINode *PN = const_cast<PHINode*>(dyn_cast<PHINode>(I)); ++I) {
// Create a new machine instr PHI node, and insert it. // Create a new machine instr PHI node, and insert it.
unsigned PHIReg = getReg(*PN); unsigned PHIReg = getReg(*PN);
MachineInstr *PhiMI = BuildMI(X86::PHI, PN->getNumOperands(), PHIReg); MachineInstr *PhiMI = BuildMI(MBB, PHIInsertPoint,
MBB->insert(instr, PhiMI); X86::PHI, PN->getNumOperands(), PHIReg);
MachineInstr *LongPhiMI = 0; MachineInstr *LongPhiMI = 0;
if (PN->getType() == Type::LongTy || PN->getType() == Type::ULongTy) { if (PN->getType() == Type::LongTy || PN->getType() == Type::ULongTy)
LongPhiMI = BuildMI(X86::PHI, PN->getNumOperands(), PHIReg+1); LongPhiMI = BuildMI(MBB, PHIInsertPoint,
MBB->insert(instr, LongPhiMI); X86::PHI, PN->getNumOperands(), PHIReg+1);
}
// PHIValues - Map of blocks to incoming virtual registers. We use this // PHIValues - Map of blocks to incoming virtual registers. We use this
// so that we only initialize one incoming value for a particular block, // so that we only initialize one incoming value for a particular block,
@ -636,6 +635,13 @@ void ISel::SelectPHINodes() {
LongPhiMI->addMachineBasicBlockOperand(PredMBB); LongPhiMI->addMachineBasicBlockOperand(PredMBB);
} }
} }
// Now that we emitted all of the incoming values for the PHI node, make
// sure to reposition the InsertPoint after the PHI that we just added.
// This is needed because we might have inserted a constant into this
// block, right after the PHI's which is before the old insert point!
PHIInsertPoint = LongPhiMI ? LongPhiMI : PhiMI;
++PHIInsertPoint;
} }
} }
} }