mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-06-25 00:24:26 +00:00
Revert "Debug info: Emit values in subregisters that do not have a separate"
This reverts commit r201179 for buildbot breakage. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@201188 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@ -24,7 +24,6 @@
|
||||
#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"
|
||||
@ -477,45 +476,13 @@ 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();
|
||||
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
|
||||
unsigned DWReg = RI->getDwarfRegNum(Reg, false);
|
||||
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