mirror of
https://github.com/RPCSX/llvm.git
synced 2024-12-11 05:35:11 +00:00
[Stackmaps] Move the target-independent frame index elimination for stackmaps and patchpoints into target-specific code.
The lowering of the frame index for stackmaps and patchpoints requires some target-specific magic and should therefore be handled in the target-specific eliminateFrameIndex method. This is related to <rdar://problem/16106219> git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@201904 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
84ace05e8c
commit
94f20bfe6e
@ -779,18 +779,15 @@ void PEI::replaceFrameIndices(MachineBasicBlock *BB, MachineFunction &Fn,
|
||||
// Frame indicies in debug values are encoded in a target independent
|
||||
// way with simply the frame index and offset rather than any
|
||||
// target-specific addressing mode.
|
||||
if (MI->isDebugValue() ||
|
||||
MI->getOpcode() == TargetOpcode::STACKMAP ||
|
||||
MI->getOpcode() == TargetOpcode::PATCHPOINT) {
|
||||
assert((!MI->isDebugValue() || i == 0) &&
|
||||
"Frame indicies can only appear as the first operand of a "
|
||||
"DBG_VALUE machine instruction");
|
||||
if (MI->isDebugValue()) {
|
||||
assert(i == 0 && "Frame indicies can only appear as the first "
|
||||
"operand of a DBG_VALUE machine instruction");
|
||||
unsigned Reg;
|
||||
MachineOperand &Offset = MI->getOperand(i + 1);
|
||||
MachineOperand &Offset = MI->getOperand(1);
|
||||
Offset.setImm(Offset.getImm() +
|
||||
TFI->getFrameIndexReference(
|
||||
Fn, MI->getOperand(i).getIndex(), Reg));
|
||||
MI->getOperand(i).ChangeToRegister(Reg, false /*isDef*/);
|
||||
Fn, MI->getOperand(0).getIndex(), Reg));
|
||||
MI->getOperand(0).ChangeToRegister(Reg, false /*isDef*/);
|
||||
continue;
|
||||
}
|
||||
|
||||
|
@ -516,6 +516,15 @@ X86RegisterInfo::eliminateFrameIndex(MachineBasicBlock::iterator II,
|
||||
} else
|
||||
FIOffset = TFI->getFrameIndexOffset(MF, FrameIndex);
|
||||
|
||||
// The frame index format for stackmaps and patchpoints is different from the
|
||||
// X86 format. It only has a FI and an offset.
|
||||
if (Opc == TargetOpcode::STACKMAP || Opc == TargetOpcode::PATCHPOINT) {
|
||||
assert(BasePtr == FramePtr && "Expected the FP as base register");
|
||||
int64_t Offset = MI.getOperand(FIOperandNum + 1).getImm() + FIOffset;
|
||||
MI.getOperand(FIOperandNum + 1).ChangeToImmediate(Offset);
|
||||
return;
|
||||
}
|
||||
|
||||
if (MI.getOperand(FIOperandNum+3).isImm()) {
|
||||
// Offset is a 32-bit integer.
|
||||
int Imm = (int)(MI.getOperand(FIOperandNum + 3).getImm());
|
||||
|
Loading…
Reference in New Issue
Block a user