mirror of
https://github.com/RPCSX/llvm.git
synced 2024-12-20 19:19:55 +00:00
Add getFrameIndexReference() to TargetRegisterInfo, which allows targets to
tell debug info which base register to use to reference a frame index on a per-index basis. This is useful, for example, in the presence of dynamic stack realignment when local variables are indexed via the stack pointer and stack-based arguments via the frame pointer. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@89620 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
a37aa54622
commit
a2f20b20a8
@ -698,6 +698,18 @@ public:
|
|||||||
/// the stack frame of the specified index.
|
/// the stack frame of the specified index.
|
||||||
virtual int getFrameIndexOffset(MachineFunction &MF, int FI) const;
|
virtual int getFrameIndexOffset(MachineFunction &MF, int FI) const;
|
||||||
|
|
||||||
|
/// getFrameIndexReference - This method should return the base register
|
||||||
|
/// and offset used to reference a frame index location. The offset is
|
||||||
|
/// returned directly, and the base register is returned via FrameReg.
|
||||||
|
virtual int getFrameIndexReference(MachineFunction &MF, int FI,
|
||||||
|
unsigned &FrameReg) const {
|
||||||
|
// By default, assume all frame indices are referenced via whatever
|
||||||
|
// getFrameRegister() says. The target can override this if it's doing
|
||||||
|
// something different.
|
||||||
|
FrameReg = getFrameRegister(MF);
|
||||||
|
return getFrameIndexOffset(MF, FI);
|
||||||
|
}
|
||||||
|
|
||||||
/// getRARegister - This method should return the register where the return
|
/// getRARegister - This method should return the register where the return
|
||||||
/// address can be found.
|
/// address can be found.
|
||||||
virtual unsigned getRARegister() const = 0;
|
virtual unsigned getRARegister() const = 0;
|
||||||
|
@ -1182,8 +1182,9 @@ DIE *DwarfDebug::createDbgScopeVariable(DbgVariable *DV, CompileUnit *Unit) {
|
|||||||
// Variables for abstract instances of inlined functions don't get a
|
// Variables for abstract instances of inlined functions don't get a
|
||||||
// location.
|
// location.
|
||||||
MachineLocation Location;
|
MachineLocation Location;
|
||||||
Location.set(RI->getFrameRegister(*MF),
|
unsigned FrameReg;
|
||||||
RI->getFrameIndexOffset(*MF, DV->getFrameIndex()));
|
int Offset = RI->getFrameIndexReference(*MF, DV->getFrameIndex(), FrameReg);
|
||||||
|
Location.set(FrameReg, Offset);
|
||||||
|
|
||||||
|
|
||||||
if (VD.hasComplexAddress())
|
if (VD.hasComplexAddress())
|
||||||
@ -1465,9 +1466,9 @@ DIE *DwarfDebug::constructVariableDIE(DbgVariable *DV,
|
|||||||
// Add variable address.
|
// Add variable address.
|
||||||
if (!Scope->isAbstractScope()) {
|
if (!Scope->isAbstractScope()) {
|
||||||
MachineLocation Location;
|
MachineLocation Location;
|
||||||
Location.set(RI->getFrameRegister(*MF),
|
unsigned FrameReg;
|
||||||
RI->getFrameIndexOffset(*MF, DV->getFrameIndex()));
|
int Offset = RI->getFrameIndexReference(*MF, DV->getFrameIndex(), FrameReg);
|
||||||
|
Location.set(FrameReg, Offset);
|
||||||
|
|
||||||
if (VD.hasComplexAddress())
|
if (VD.hasComplexAddress())
|
||||||
addComplexAddress(DV, VariableDie, dwarf::DW_AT_location, Location);
|
addComplexAddress(DV, VariableDie, dwarf::DW_AT_location, Location);
|
||||||
|
Loading…
Reference in New Issue
Block a user