mirror of
https://github.com/RPCS3/llvm.git
synced 2025-01-19 16:35:10 +00:00
Handle AddrMode4 for Thumb2 in rewriteT2FrameIndex. This occurs for
VLDM/VSTM instructions, and without this check, the code assumes that an offset is allowed, as it would be with VLDR/VSTR. The asm printer, however, silently drops the offset, producing incorrect code. Since the address register in this case is either the stack or frame pointer, the spill location ends up conflicting with some other stack slot or with outgoing arguments on the stack. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@81879 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
85111a9c07
commit
e4863f4759
@ -383,6 +383,11 @@ bool llvm::rewriteT2FrameIndex(MachineInstr &MI, unsigned FrameRegIdx,
|
||||
"Bit extraction didn't work?");
|
||||
MI.getOperand(FrameRegIdx+1).ChangeToImmediate(ThisImmVal);
|
||||
} else {
|
||||
|
||||
// AddrMode4 cannot handle any offset.
|
||||
if (AddrMode == ARMII::AddrMode4)
|
||||
return false;
|
||||
|
||||
// AddrModeT2_so cannot handle any offset. If there is no offset
|
||||
// register then we change to an immediate version.
|
||||
unsigned NewOpc = Opcode;
|
||||
|
Loading…
x
Reference in New Issue
Block a user