mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-06-19 03:24:09 +00:00
Reapply r201180 with an additional error path.
Debug info: Emit values in subregisters that do not have a separate DWARF register number by emitting a super-register + DW_OP_bit_piece. This is necessary because on x86_64, there are no DWARF register numbers for i386-style subregisters. Fixes a bunch of FIXMEs. rdar://problem/16015314 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@201190 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@ -24,6 +24,7 @@
|
||||
#include "llvm/IR/Instructions.h"
|
||||
#include "llvm/IR/Mangler.h"
|
||||
#include "llvm/MC/MCAsmInfo.h"
|
||||
#include "llvm/MC/MCContext.h"
|
||||
#include "llvm/MC/MCSection.h"
|
||||
#include "llvm/MC/MCStreamer.h"
|
||||
#include "llvm/Support/CommandLine.h"
|
||||
@ -476,13 +477,45 @@ void DwarfUnit::addVariableAddress(const DbgVariable &DV, DIE *Die,
|
||||
/// addRegisterOp - Add register operand.
|
||||
void DwarfUnit::addRegisterOp(DIEBlock *TheDie, unsigned Reg) {
|
||||
const TargetRegisterInfo *RI = Asm->TM.getRegisterInfo();
|
||||
unsigned DWReg = RI->getDwarfRegNum(Reg, false);
|
||||
int DWReg = RI->getDwarfRegNum(Reg, false);
|
||||
bool isSubRegister = DWReg < 0;
|
||||
|
||||
unsigned Idx = 0;
|
||||
|
||||
// Go up the super-register chain until we hit a valid dwarf register number.
|
||||
for (MCSuperRegIterator SR(Reg, RI); SR.isValid() && DWReg < 0; ++SR) {
|
||||
DWReg = RI->getDwarfRegNum(*SR, false);
|
||||
if (DWReg >= 0)
|
||||
Idx = RI->getSubRegIndex(*SR, Reg);
|
||||
}
|
||||
|
||||
if (DWReg < 0) {
|
||||
DEBUG(llvm::dbgs() << "Invalid Dwarf register number.\n");
|
||||
addUInt(TheDie, dwarf::DW_FORM_data1, dwarf::DW_OP_nop);
|
||||
return;
|
||||
}
|
||||
|
||||
// Emit register
|
||||
if (DWReg < 32)
|
||||
addUInt(TheDie, dwarf::DW_FORM_data1, dwarf::DW_OP_reg0 + DWReg);
|
||||
else {
|
||||
addUInt(TheDie, dwarf::DW_FORM_data1, dwarf::DW_OP_regx);
|
||||
addUInt(TheDie, dwarf::DW_FORM_udata, DWReg);
|
||||
}
|
||||
|
||||
// Emit Mask
|
||||
if (isSubRegister) {
|
||||
unsigned Size = RI->getSubRegIdxSize(Idx);
|
||||
unsigned Offset = RI->getSubRegIdxOffset(Idx);
|
||||
if (Offset > 0) {
|
||||
addUInt(TheDie, dwarf::DW_FORM_data1, dwarf::DW_OP_bit_piece);
|
||||
addUInt(TheDie, dwarf::DW_FORM_data1, Size);
|
||||
addUInt(TheDie, dwarf::DW_FORM_data1, Offset);
|
||||
} else {
|
||||
addUInt(TheDie, dwarf::DW_FORM_data1, dwarf::DW_OP_piece);
|
||||
addUInt(TheDie, dwarf::DW_FORM_data1, Size);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/// addRegisterOffset - Add register offset.
|
||||
|
Reference in New Issue
Block a user