Need to insert all moves due to PHI nodes before *ALL* jumps in a predecessor

basic block, as there could be multiple.

llvm-svn: 5016
This commit is contained in:
Misha Brukman 2002-12-13 11:55:59 +00:00
parent d4c5013c04
commit 86ca8840a1
1 changed files with 10 additions and 15 deletions

View File

@ -92,21 +92,6 @@ namespace {
regs = Desc.ImplicitDefs;
while (*regs)
RegsUsed[*regs++] = 1;
/*
for (int i = MI->getNumOperands() - 1; i >= 0; --i) {
const MachineOperand &op = MI->getOperand(i);
if (op.isMachineRegister())
RegsUsed[op.getAllocatedRegNum()] = 1;
}
for (int i = MI->getNumImplicitRefs() - 1; i >= 0; --i) {
const MachineOperand &op = MI->getImplicitOp(i);
if (op.isMachineRegister())
RegsUsed[op.getAllocatedRegNum()] = 1;
}
*/
}
void cleanupAfterFunction() {
@ -297,6 +282,16 @@ bool RegAllocSimple::runOnMachineFunction(MachineFunction &Fn) {
MachineBasicBlock::iterator opI = opBlock->end();
MachineInstr *opMI = *(--opI);
const MachineInstrInfo &MII = TM.getInstrInfo();
// must backtrack over ALL the branches in the previous block, until no more
while ((MII.isBranch(opMI->getOpcode()) || MII.isReturn(opMI->getOpcode()))
&& opI != opBlock->begin())
{
opMI = *(--opI);
}
// move back to the first branch instruction so new instructions
// are inserted right in front of it and not in front of a non-branch
++opI;
// insert the move just before the return/branch
if (MII.isReturn(opMI->getOpcode()) || MII.isBranch(opMI->getOpcode()))