Don't try to sink 3-address instruction if convertToThreeAddress created more than one instructions.

llvm-svn: 48336
This commit is contained in:
Evan Cheng 2008-03-13 07:56:58 +00:00
parent ecde45ecb5
commit 8f8a8b28e9
1 changed files with 6 additions and 1 deletions

View File

@ -291,7 +291,12 @@ bool TwoAddressInstructionPass::runOnMachineFunction(MachineFunction &MF) {
if (MachineInstr *New=TII->convertToThreeAddress(mbbi, mi, *LV)) {
DOUT << "2addr: CONVERTING 2-ADDR: " << *mi;
DOUT << "2addr: TO 3-ADDR: " << *New;
bool Sunk = Sink3AddrInstruction(mbbi, New, regB, mi);
bool Sunk = false;
if (New->findRegisterUseOperand(regB, New, TRI))
// FIXME: Temporary workaround. If the new instruction doesn't
// uses regB, convertToThreeAddress must have created more
// then one instruction.
Sunk = Sink3AddrInstruction(mbbi, New, regB, mi);
mbbi->erase(mi); // Nuke the old inst.
if (!Sunk) mi = New;
++NumConvertedTo3Addr;