mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-06-28 06:24:57 +00:00
Fix PR22762. When emitting a DWARF expression check whether this is the
frame register before checking if there is a DWARF register number for it. Thanks to H.J. Lu for diagnosing this and providing the testcase! git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@231121 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@ -66,17 +66,18 @@ void DwarfExpression::AddShr(unsigned ShiftBy) {
|
||||
}
|
||||
|
||||
bool DwarfExpression::AddMachineRegIndirect(unsigned MachineReg, int Offset) {
|
||||
int DwarfReg = TRI.getDwarfRegNum(MachineReg, false);
|
||||
if (DwarfReg < 0)
|
||||
return false;
|
||||
|
||||
if (isFrameRegister(MachineReg)) {
|
||||
// If variable offset is based in frame register then use fbreg.
|
||||
EmitOp(dwarf::DW_OP_fbreg);
|
||||
EmitSigned(Offset);
|
||||
} else {
|
||||
AddRegIndirect(DwarfReg, Offset);
|
||||
return true;
|
||||
}
|
||||
|
||||
int DwarfReg = TRI.getDwarfRegNum(MachineReg, false);
|
||||
if (DwarfReg < 0)
|
||||
return false;
|
||||
|
||||
AddRegIndirect(DwarfReg, Offset);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user