If we're not using reg+reg offset we're using reg+imm, set the opcode

to be the one we want to use. bugpoint reduced testcase is a little large,
I'll see if I can simplify it down more.

Fixes part of rdar://8782207


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@122307 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Eric Christopher 2010-12-21 02:12:07 +00:00
parent 5df1578dec
commit 6e90ce21cc

View File

@ -656,7 +656,7 @@ Thumb1RegisterInfo::eliminateFrameIndex(MachineBasicBlock::iterator II,
*this, dl); *this, dl);
} }
MI.setDesc(TII.get(ARM::tLDRr)); MI.setDesc(TII.get(UseRR ? ARM::tLDRr : ARM::tLDRi));
MI.getOperand(i).ChangeToRegister(TmpReg, false, false, true); MI.getOperand(i).ChangeToRegister(TmpReg, false, false, true);
if (UseRR) if (UseRR)
// Use [reg, reg] addrmode. // Use [reg, reg] addrmode.
@ -676,7 +676,7 @@ Thumb1RegisterInfo::eliminateFrameIndex(MachineBasicBlock::iterator II,
} else } else
emitThumbRegPlusImmediate(MBB, II, VReg, FrameReg, Offset, TII, emitThumbRegPlusImmediate(MBB, II, VReg, FrameReg, Offset, TII,
*this, dl); *this, dl);
MI.setDesc(TII.get(ARM::tSTRr)); MI.setDesc(TII.get(UseRR ? ARM::tSTRr : ARM::tSTRi));
MI.getOperand(i).ChangeToRegister(VReg, false, false, true); MI.getOperand(i).ChangeToRegister(VReg, false, false, true);
if (UseRR) // Use [reg, reg] addrmode. if (UseRR) // Use [reg, reg] addrmode.
MI.addOperand(MachineOperand::CreateReg(FrameReg, false)); MI.addOperand(MachineOperand::CreateReg(FrameReg, false));