mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-02 07:32:52 +00:00
Use the dwarf->llvm mapping to print register names in the cfi
directives. Fixes PR9826. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@132317 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
acbf107d9b
commit
6e032942cf
@ -95,6 +95,10 @@ public:
|
|||||||
return TRI->getDwarfRegNum(RegNum, isEH);
|
return TRI->getDwarfRegNum(RegNum, isEH);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int getLLVMRegNum(unsigned DwarfRegNum, bool isEH) const {
|
||||||
|
return TRI->getLLVMRegNum(DwarfRegNum, isEH);
|
||||||
|
}
|
||||||
|
|
||||||
int getSEHRegNum(unsigned RegNum) const {
|
int getSEHRegNum(unsigned RegNum) const {
|
||||||
return TRI->getSEHRegNum(RegNum);
|
return TRI->getSEHRegNum(RegNum);
|
||||||
}
|
}
|
||||||
|
@ -802,6 +802,8 @@ public:
|
|||||||
/// debugging info.
|
/// debugging info.
|
||||||
virtual int getDwarfRegNum(unsigned RegNum, bool isEH) const = 0;
|
virtual int getDwarfRegNum(unsigned RegNum, bool isEH) const = 0;
|
||||||
|
|
||||||
|
virtual int getLLVMRegNum(unsigned RegNum, bool isEH) const = 0;
|
||||||
|
|
||||||
/// getFrameRegister - This method should return the register used as a base
|
/// getFrameRegister - This method should return the register used as a base
|
||||||
/// for values allocated in the current stack frame.
|
/// for values allocated in the current stack frame.
|
||||||
virtual unsigned getFrameRegister(const MachineFunction &MF) const = 0;
|
virtual unsigned getFrameRegister(const MachineFunction &MF) const = 0;
|
||||||
|
@ -54,6 +54,8 @@ class MCAsmStreamer : public MCStreamer {
|
|||||||
|
|
||||||
bool needsSet(const MCExpr *Value);
|
bool needsSet(const MCExpr *Value);
|
||||||
|
|
||||||
|
void EmitRegisterName(int64_t Register);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
MCAsmStreamer(MCContext &Context, formatted_raw_ostream &os,
|
MCAsmStreamer(MCContext &Context, formatted_raw_ostream &os,
|
||||||
bool isVerboseAsm, bool useLoc, bool useCFI,
|
bool isVerboseAsm, bool useLoc, bool useCFI,
|
||||||
@ -819,13 +821,25 @@ void MCAsmStreamer::EmitCFIEndProc() {
|
|||||||
EmitEOL();
|
EmitEOL();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void MCAsmStreamer::EmitRegisterName(int64_t Register) {
|
||||||
|
if (InstPrinter) {
|
||||||
|
const TargetAsmInfo &asmInfo = getContext().getTargetAsmInfo();
|
||||||
|
unsigned LLVMRegister = asmInfo.getLLVMRegNum(Register, true);
|
||||||
|
OS << '%' << InstPrinter->getRegName(LLVMRegister);
|
||||||
|
} else {
|
||||||
|
OS << Register;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void MCAsmStreamer::EmitCFIDefCfa(int64_t Register, int64_t Offset) {
|
void MCAsmStreamer::EmitCFIDefCfa(int64_t Register, int64_t Offset) {
|
||||||
MCStreamer::EmitCFIDefCfa(Register, Offset);
|
MCStreamer::EmitCFIDefCfa(Register, Offset);
|
||||||
|
|
||||||
if (!UseCFI)
|
if (!UseCFI)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
OS << "\t.cfi_def_cfa " << Register << ", " << Offset;
|
OS << "\t.cfi_def_cfa ";
|
||||||
|
EmitRegisterName(Register);
|
||||||
|
OS << ", " << Offset;
|
||||||
EmitEOL();
|
EmitEOL();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -845,7 +859,8 @@ void MCAsmStreamer::EmitCFIDefCfaRegister(int64_t Register) {
|
|||||||
if (!UseCFI)
|
if (!UseCFI)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
OS << "\t.cfi_def_cfa_register " << Register;
|
OS << "\t.cfi_def_cfa_register ";
|
||||||
|
EmitRegisterName(Register);
|
||||||
EmitEOL();
|
EmitEOL();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -855,7 +870,9 @@ void MCAsmStreamer::EmitCFIOffset(int64_t Register, int64_t Offset) {
|
|||||||
if (!UseCFI)
|
if (!UseCFI)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
OS << "\t.cfi_offset " << Register << ", " << Offset;
|
OS << "\t.cfi_offset ";
|
||||||
|
EmitRegisterName(Register);
|
||||||
|
OS << ", " << Offset;
|
||||||
EmitEOL();
|
EmitEOL();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -906,7 +923,8 @@ void MCAsmStreamer::EmitCFISameValue(int64_t Register) {
|
|||||||
if (!UseCFI)
|
if (!UseCFI)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
OS << "\t.cfi_same_value " << Register;
|
OS << "\t.cfi_same_value ";
|
||||||
|
EmitRegisterName(Register);
|
||||||
EmitEOL();
|
EmitEOL();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -916,7 +934,9 @@ void MCAsmStreamer::EmitCFIRelOffset(int64_t Register, int64_t Offset) {
|
|||||||
if (!UseCFI)
|
if (!UseCFI)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
OS << "\t.cfi_rel_offset " << Register << ", " << Offset;
|
OS << "\t.cfi_rel_offset ";
|
||||||
|
EmitRegisterName(Register);
|
||||||
|
OS << ", " << Offset;
|
||||||
EmitEOL();
|
EmitEOL();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -684,6 +684,10 @@ int ARMBaseRegisterInfo::getDwarfRegNum(unsigned RegNum, bool isEH) const {
|
|||||||
return ARMGenRegisterInfo::getDwarfRegNumFull(RegNum, 0);
|
return ARMGenRegisterInfo::getDwarfRegNumFull(RegNum, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int ARMBaseRegisterInfo::getLLVMRegNum(unsigned DwarfRegNo, bool isEH) const {
|
||||||
|
return ARMGenRegisterInfo::getLLVMRegNumFull(DwarfRegNo,0);
|
||||||
|
}
|
||||||
|
|
||||||
unsigned ARMBaseRegisterInfo::getRegisterPairEven(unsigned Reg,
|
unsigned ARMBaseRegisterInfo::getRegisterPairEven(unsigned Reg,
|
||||||
const MachineFunction &MF) const {
|
const MachineFunction &MF) const {
|
||||||
switch (Reg) {
|
switch (Reg) {
|
||||||
|
@ -172,6 +172,7 @@ public:
|
|||||||
unsigned getEHHandlerRegister() const;
|
unsigned getEHHandlerRegister() const;
|
||||||
|
|
||||||
int getDwarfRegNum(unsigned RegNum, bool isEH) const;
|
int getDwarfRegNum(unsigned RegNum, bool isEH) const;
|
||||||
|
int getLLVMRegNum(unsigned RegNum, bool isEH) const;
|
||||||
|
|
||||||
bool isLowRegister(unsigned Reg) const;
|
bool isLowRegister(unsigned Reg) const;
|
||||||
|
|
||||||
|
@ -199,6 +199,11 @@ int AlphaRegisterInfo::getDwarfRegNum(unsigned RegNum, bool isEH) const {
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int AlphaRegisterInfo::getLLVMRegNum(unsigned DwarfRegNum, bool isEH) const {
|
||||||
|
llvm_unreachable("What is the dwarf register number");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
#include "AlphaGenRegisterInfo.inc"
|
#include "AlphaGenRegisterInfo.inc"
|
||||||
|
|
||||||
std::string AlphaRegisterInfo::getPrettyName(unsigned reg)
|
std::string AlphaRegisterInfo::getPrettyName(unsigned reg)
|
||||||
|
@ -48,6 +48,7 @@ struct AlphaRegisterInfo : public AlphaGenRegisterInfo {
|
|||||||
unsigned getEHHandlerRegister() const;
|
unsigned getEHHandlerRegister() const;
|
||||||
|
|
||||||
int getDwarfRegNum(unsigned RegNum, bool isEH) const;
|
int getDwarfRegNum(unsigned RegNum, bool isEH) const;
|
||||||
|
int getLLVMRegNum(unsigned RegNum, bool isEH) const;
|
||||||
|
|
||||||
static std::string getPrettyName(unsigned reg);
|
static std::string getPrettyName(unsigned reg);
|
||||||
};
|
};
|
||||||
|
@ -351,5 +351,11 @@ int BlackfinRegisterInfo::getDwarfRegNum(unsigned RegNum, bool isEH) const {
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int BlackfinRegisterInfo::getLLVMRegNum(unsigned DwarfRegNum,
|
||||||
|
bool isEH) const {
|
||||||
|
llvm_unreachable("What is the dwarf register number");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
#include "BlackfinGenRegisterInfo.inc"
|
#include "BlackfinGenRegisterInfo.inc"
|
||||||
|
|
||||||
|
@ -60,6 +60,7 @@ namespace llvm {
|
|||||||
unsigned getEHHandlerRegister() const;
|
unsigned getEHHandlerRegister() const;
|
||||||
|
|
||||||
int getDwarfRegNum(unsigned RegNum, bool isEH) const;
|
int getDwarfRegNum(unsigned RegNum, bool isEH) const;
|
||||||
|
int getLLVMRegNum(unsigned RegNum, bool isEH) const;
|
||||||
|
|
||||||
// Utility functions
|
// Utility functions
|
||||||
void adjustRegister(MachineBasicBlock &MBB,
|
void adjustRegister(MachineBasicBlock &MBB,
|
||||||
|
@ -328,6 +328,10 @@ SPURegisterInfo::getDwarfRegNum(unsigned RegNum, bool isEH) const {
|
|||||||
return SPUGenRegisterInfo::getDwarfRegNumFull(RegNum, 0);
|
return SPUGenRegisterInfo::getDwarfRegNumFull(RegNum, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int SPURegisterInfo::getLLVMRegNum(unsigned RegNum, bool isEH) const {
|
||||||
|
return SPUGenRegisterInfo::getLLVMRegNumFull(RegNum, 0);
|
||||||
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
SPURegisterInfo::convertDFormToXForm(int dFormOpcode) const
|
SPURegisterInfo::convertDFormToXForm(int dFormOpcode) const
|
||||||
{
|
{
|
||||||
|
@ -83,6 +83,7 @@ namespace llvm {
|
|||||||
|
|
||||||
//! Get DWARF debugging register number
|
//! Get DWARF debugging register number
|
||||||
int getDwarfRegNum(unsigned RegNum, bool isEH) const;
|
int getDwarfRegNum(unsigned RegNum, bool isEH) const;
|
||||||
|
int getLLVMRegNum(unsigned RegNum, bool isEH) const;
|
||||||
|
|
||||||
//! Convert D-form load/store to X-form load/store
|
//! Convert D-form load/store to X-form load/store
|
||||||
/*!
|
/*!
|
||||||
|
@ -356,5 +356,9 @@ int MBlazeRegisterInfo::getDwarfRegNum(unsigned RegNo, bool isEH) const {
|
|||||||
return MBlazeGenRegisterInfo::getDwarfRegNumFull(RegNo,0);
|
return MBlazeGenRegisterInfo::getDwarfRegNumFull(RegNo,0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int MBlazeRegisterInfo::getLLVMRegNum(unsigned DwarfRegNo, bool isEH) const {
|
||||||
|
return MBlazeGenRegisterInfo::getLLVMRegNumFull(DwarfRegNo,0);
|
||||||
|
}
|
||||||
|
|
||||||
#include "MBlazeGenRegisterInfo.inc"
|
#include "MBlazeGenRegisterInfo.inc"
|
||||||
|
|
||||||
|
@ -75,6 +75,7 @@ struct MBlazeRegisterInfo : public MBlazeGenRegisterInfo {
|
|||||||
unsigned getEHHandlerRegister() const;
|
unsigned getEHHandlerRegister() const;
|
||||||
|
|
||||||
int getDwarfRegNum(unsigned RegNum, bool isEH) const;
|
int getDwarfRegNum(unsigned RegNum, bool isEH) const;
|
||||||
|
int getLLVMRegNum(unsigned RegNum, bool isEH) const;
|
||||||
};
|
};
|
||||||
|
|
||||||
} // end namespace llvm
|
} // end namespace llvm
|
||||||
|
@ -242,4 +242,9 @@ int MSP430RegisterInfo::getDwarfRegNum(unsigned RegNum, bool isEH) const {
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int MSP430RegisterInfo::getLLVMRegNum(unsigned RegNum, bool isEH) const {
|
||||||
|
llvm_unreachable("Not implemented yet!");
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
#include "MSP430GenRegisterInfo.inc"
|
#include "MSP430GenRegisterInfo.inc"
|
||||||
|
@ -61,6 +61,7 @@ public:
|
|||||||
|
|
||||||
//! Get DWARF debugging register number
|
//! Get DWARF debugging register number
|
||||||
int getDwarfRegNum(unsigned RegNum, bool isEH) const;
|
int getDwarfRegNum(unsigned RegNum, bool isEH) const;
|
||||||
|
int getLLVMRegNum(unsigned RegNum, bool isEH) const;
|
||||||
};
|
};
|
||||||
|
|
||||||
} // end namespace llvm
|
} // end namespace llvm
|
||||||
|
@ -278,4 +278,8 @@ getDwarfRegNum(unsigned RegNum, bool isEH) const {
|
|||||||
return MipsGenRegisterInfo::getDwarfRegNumFull(RegNum, 0);
|
return MipsGenRegisterInfo::getDwarfRegNumFull(RegNum, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int MipsRegisterInfo::getLLVMRegNum(unsigned DwarfRegNo, bool isEH) const {
|
||||||
|
return MipsGenRegisterInfo::getLLVMRegNumFull(DwarfRegNo,0);
|
||||||
|
}
|
||||||
|
|
||||||
#include "MipsGenRegisterInfo.inc"
|
#include "MipsGenRegisterInfo.inc"
|
||||||
|
@ -63,6 +63,7 @@ struct MipsRegisterInfo : public MipsGenRegisterInfo {
|
|||||||
unsigned getEHHandlerRegister() const;
|
unsigned getEHHandlerRegister() const;
|
||||||
|
|
||||||
int getDwarfRegNum(unsigned RegNum, bool isEH) const;
|
int getDwarfRegNum(unsigned RegNum, bool isEH) const;
|
||||||
|
int getLLVMRegNum(unsigned RegNum, bool isEH) const;
|
||||||
};
|
};
|
||||||
|
|
||||||
} // end namespace llvm
|
} // end namespace llvm
|
||||||
|
@ -57,6 +57,9 @@ struct PTXRegisterInfo : public PTXGenRegisterInfo {
|
|||||||
virtual int getDwarfRegNum(unsigned RegNum, bool isEH) const {
|
virtual int getDwarfRegNum(unsigned RegNum, bool isEH) const {
|
||||||
return PTXGenRegisterInfo::getDwarfRegNumFull(RegNum, 0);
|
return PTXGenRegisterInfo::getDwarfRegNumFull(RegNum, 0);
|
||||||
}
|
}
|
||||||
|
virtual int getLLVMRegNum(unsigned RegNum, bool isEH) const {
|
||||||
|
return PTXGenRegisterInfo::getLLVMRegNumFull(RegNum, 0);
|
||||||
|
}
|
||||||
}; // struct PTXRegisterInfo
|
}; // struct PTXRegisterInfo
|
||||||
} // namespace llvm
|
} // namespace llvm
|
||||||
|
|
||||||
|
@ -26,6 +26,9 @@ StringRef PPCInstPrinter::getOpcodeName(unsigned Opcode) const {
|
|||||||
return getInstructionName(Opcode);
|
return getInstructionName(Opcode);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
StringRef PPCInstPrinter::getRegName(unsigned RegNo) const {
|
||||||
|
return getRegisterName(RegNo);
|
||||||
|
}
|
||||||
|
|
||||||
void PPCInstPrinter::printInst(const MCInst *MI, raw_ostream &O) {
|
void PPCInstPrinter::printInst(const MCInst *MI, raw_ostream &O) {
|
||||||
// Check for slwi/srwi mnemonics.
|
// Check for slwi/srwi mnemonics.
|
||||||
|
@ -33,6 +33,7 @@ public:
|
|||||||
return SyntaxVariant == 1;
|
return SyntaxVariant == 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
StringRef getRegName(unsigned RegNo) const;
|
||||||
virtual void printInst(const MCInst *MI, raw_ostream &O);
|
virtual void printInst(const MCInst *MI, raw_ostream &O);
|
||||||
virtual StringRef getOpcodeName(unsigned Opcode) const;
|
virtual StringRef getOpcodeName(unsigned Opcode) const;
|
||||||
|
|
||||||
|
@ -487,6 +487,14 @@ void PPCFrameLowering::emitPrologue(MachineFunction &MF) const {
|
|||||||
int Offset = MFI->getObjectOffset(CSI[I].getFrameIdx());
|
int Offset = MFI->getObjectOffset(CSI[I].getFrameIdx());
|
||||||
unsigned Reg = CSI[I].getReg();
|
unsigned Reg = CSI[I].getReg();
|
||||||
if (Reg == PPC::LR || Reg == PPC::LR8 || Reg == PPC::RM) continue;
|
if (Reg == PPC::LR || Reg == PPC::LR8 || Reg == PPC::RM) continue;
|
||||||
|
|
||||||
|
// This is a bit of a hack: CR2LT, CR2GT, CR2EQ and CR2UN are just
|
||||||
|
// subregisters of CR2. We just need to emit a move of CR2.
|
||||||
|
if (Reg == PPC::CR2LT || Reg == PPC::CR2GT || Reg == PPC::CR2EQ)
|
||||||
|
continue;
|
||||||
|
if (Reg == PPC::CR2UN)
|
||||||
|
Reg = PPC::CR2;
|
||||||
|
|
||||||
MachineLocation CSDst(MachineLocation::VirtualFP, Offset);
|
MachineLocation CSDst(MachineLocation::VirtualFP, Offset);
|
||||||
MachineLocation CSSrc(Reg);
|
MachineLocation CSSrc(Reg);
|
||||||
Moves.push_back(MachineMove(Label, CSDst, CSSrc));
|
Moves.push_back(MachineMove(Label, CSDst, CSSrc));
|
||||||
|
@ -702,4 +702,12 @@ int PPCRegisterInfo::getDwarfRegNum(unsigned RegNum, bool isEH) const {
|
|||||||
return PPCGenRegisterInfo::getDwarfRegNumFull(RegNum, Flavour);
|
return PPCGenRegisterInfo::getDwarfRegNumFull(RegNum, Flavour);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int PPCRegisterInfo::getLLVMRegNum(unsigned RegNum, bool isEH) const {
|
||||||
|
// FIXME: Most probably dwarf numbers differs for Linux and Darwin
|
||||||
|
unsigned Flavour = Subtarget.isPPC64() ?
|
||||||
|
DWARFFlavour::PPC64 : DWARFFlavour::PPC32;
|
||||||
|
|
||||||
|
return PPCGenRegisterInfo::getLLVMRegNumFull(RegNum, Flavour);
|
||||||
|
}
|
||||||
|
|
||||||
#include "PPCGenRegisterInfo.inc"
|
#include "PPCGenRegisterInfo.inc"
|
||||||
|
@ -68,6 +68,7 @@ public:
|
|||||||
unsigned getEHHandlerRegister() const;
|
unsigned getEHHandlerRegister() const;
|
||||||
|
|
||||||
int getDwarfRegNum(unsigned RegNum, bool isEH) const;
|
int getDwarfRegNum(unsigned RegNum, bool isEH) const;
|
||||||
|
int getLLVMRegNum(unsigned RegNum, bool isEH) const;
|
||||||
};
|
};
|
||||||
|
|
||||||
} // end namespace llvm
|
} // end namespace llvm
|
||||||
|
@ -130,5 +130,9 @@ int SparcRegisterInfo::getDwarfRegNum(unsigned RegNum, bool isEH) const {
|
|||||||
return SparcGenRegisterInfo::getDwarfRegNumFull(RegNum, 0);
|
return SparcGenRegisterInfo::getDwarfRegNumFull(RegNum, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int SparcRegisterInfo::getLLVMRegNum(unsigned DwarfRegNo, bool isEH) const {
|
||||||
|
return SparcGenRegisterInfo::getLLVMRegNumFull(DwarfRegNo,0);
|
||||||
|
}
|
||||||
|
|
||||||
#include "SparcGenRegisterInfo.inc"
|
#include "SparcGenRegisterInfo.inc"
|
||||||
|
|
||||||
|
@ -52,6 +52,7 @@ struct SparcRegisterInfo : public SparcGenRegisterInfo {
|
|||||||
unsigned getEHHandlerRegister() const;
|
unsigned getEHHandlerRegister() const;
|
||||||
|
|
||||||
int getDwarfRegNum(unsigned RegNum, bool isEH) const;
|
int getDwarfRegNum(unsigned RegNum, bool isEH) const;
|
||||||
|
int getLLVMRegNum(unsigned RegNum, bool isEH) const;
|
||||||
};
|
};
|
||||||
|
|
||||||
} // end namespace llvm
|
} // end namespace llvm
|
||||||
|
@ -139,4 +139,10 @@ int SystemZRegisterInfo::getDwarfRegNum(unsigned RegNum, bool isEH) const {
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int SystemZRegisterInfo::getLLVMRegNum(unsigned DwarfRegNo, bool isEH) const {
|
||||||
|
assert(0 && "What is the dwarf register number");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
#include "SystemZGenRegisterInfo.inc"
|
#include "SystemZGenRegisterInfo.inc"
|
||||||
|
@ -54,6 +54,7 @@ struct SystemZRegisterInfo : public SystemZGenRegisterInfo {
|
|||||||
unsigned getEHHandlerRegister() const;
|
unsigned getEHHandlerRegister() const;
|
||||||
|
|
||||||
int getDwarfRegNum(unsigned RegNum, bool isEH) const;
|
int getDwarfRegNum(unsigned RegNum, bool isEH) const;
|
||||||
|
int getLLVMRegNum(unsigned RegNum, bool isEH) const;
|
||||||
};
|
};
|
||||||
|
|
||||||
} // end namespace llvm
|
} // end namespace llvm
|
||||||
|
@ -41,6 +41,10 @@ X86ATTInstPrinter::X86ATTInstPrinter(TargetMachine &TM, const MCAsmInfo &MAI)
|
|||||||
&TM.getSubtarget<X86Subtarget>()));
|
&TM.getSubtarget<X86Subtarget>()));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
StringRef X86ATTInstPrinter::getRegName(unsigned RegNo) const {
|
||||||
|
return getRegisterName(RegNo);
|
||||||
|
}
|
||||||
|
|
||||||
void X86ATTInstPrinter::printInst(const MCInst *MI, raw_ostream &OS) {
|
void X86ATTInstPrinter::printInst(const MCInst *MI, raw_ostream &OS) {
|
||||||
// Try to print any aliases first.
|
// Try to print any aliases first.
|
||||||
if (!printAliasInstr(MI, OS))
|
if (!printAliasInstr(MI, OS))
|
||||||
|
@ -26,6 +26,7 @@ class X86ATTInstPrinter : public MCInstPrinter {
|
|||||||
public:
|
public:
|
||||||
X86ATTInstPrinter(TargetMachine &TM, const MCAsmInfo &MAI);
|
X86ATTInstPrinter(TargetMachine &TM, const MCAsmInfo &MAI);
|
||||||
|
|
||||||
|
StringRef getRegName(unsigned RegNo) const;
|
||||||
virtual void printInst(const MCInst *MI, raw_ostream &OS);
|
virtual void printInst(const MCInst *MI, raw_ostream &OS);
|
||||||
virtual StringRef getOpcodeName(unsigned Opcode) const;
|
virtual StringRef getOpcodeName(unsigned Opcode) const;
|
||||||
|
|
||||||
|
@ -29,6 +29,10 @@ using namespace llvm;
|
|||||||
#define GET_INSTRUCTION_NAME
|
#define GET_INSTRUCTION_NAME
|
||||||
#include "X86GenAsmWriter1.inc"
|
#include "X86GenAsmWriter1.inc"
|
||||||
|
|
||||||
|
StringRef X86IntelInstPrinter::getRegName(unsigned RegNo) const {
|
||||||
|
return getRegisterName(RegNo);
|
||||||
|
}
|
||||||
|
|
||||||
void X86IntelInstPrinter::printInst(const MCInst *MI, raw_ostream &OS) {
|
void X86IntelInstPrinter::printInst(const MCInst *MI, raw_ostream &OS) {
|
||||||
printInstruction(MI, OS);
|
printInstruction(MI, OS);
|
||||||
|
|
||||||
|
@ -27,6 +27,7 @@ public:
|
|||||||
X86IntelInstPrinter(TargetMachine &TM, const MCAsmInfo &MAI)
|
X86IntelInstPrinter(TargetMachine &TM, const MCAsmInfo &MAI)
|
||||||
: MCInstPrinter(MAI) {}
|
: MCInstPrinter(MAI) {}
|
||||||
|
|
||||||
|
StringRef getRegName(unsigned RegNo) const;
|
||||||
virtual void printInst(const MCInst *MI, raw_ostream &OS);
|
virtual void printInst(const MCInst *MI, raw_ostream &OS);
|
||||||
virtual StringRef getOpcodeName(unsigned Opcode) const;
|
virtual StringRef getOpcodeName(unsigned Opcode) const;
|
||||||
|
|
||||||
|
@ -73,29 +73,40 @@ X86RegisterInfo::X86RegisterInfo(X86TargetMachine &tm,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static unsigned getFlavour(const X86Subtarget *Subtarget, bool isEH) {
|
||||||
|
if (!Subtarget->is64Bit()) {
|
||||||
|
if (Subtarget->isTargetDarwin()) {
|
||||||
|
if (isEH)
|
||||||
|
return DWARFFlavour::X86_32_DarwinEH;
|
||||||
|
else
|
||||||
|
return DWARFFlavour::X86_32_Generic;
|
||||||
|
} else if (Subtarget->isTargetCygMing()) {
|
||||||
|
// Unsupported by now, just quick fallback
|
||||||
|
return DWARFFlavour::X86_32_Generic;
|
||||||
|
} else {
|
||||||
|
return DWARFFlavour::X86_32_Generic;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return DWARFFlavour::X86_64;
|
||||||
|
}
|
||||||
|
|
||||||
/// getDwarfRegNum - This function maps LLVM register identifiers to the DWARF
|
/// getDwarfRegNum - This function maps LLVM register identifiers to the DWARF
|
||||||
/// specific numbering, used in debug info and exception tables.
|
/// specific numbering, used in debug info and exception tables.
|
||||||
int X86RegisterInfo::getDwarfRegNum(unsigned RegNo, bool isEH) const {
|
int X86RegisterInfo::getDwarfRegNum(unsigned RegNo, bool isEH) const {
|
||||||
const X86Subtarget *Subtarget = &TM.getSubtarget<X86Subtarget>();
|
const X86Subtarget *Subtarget = &TM.getSubtarget<X86Subtarget>();
|
||||||
unsigned Flavour = DWARFFlavour::X86_64;
|
unsigned Flavour = getFlavour(Subtarget, isEH);
|
||||||
|
|
||||||
if (!Subtarget->is64Bit()) {
|
|
||||||
if (Subtarget->isTargetDarwin()) {
|
|
||||||
if (isEH)
|
|
||||||
Flavour = DWARFFlavour::X86_32_DarwinEH;
|
|
||||||
else
|
|
||||||
Flavour = DWARFFlavour::X86_32_Generic;
|
|
||||||
} else if (Subtarget->isTargetCygMing()) {
|
|
||||||
// Unsupported by now, just quick fallback
|
|
||||||
Flavour = DWARFFlavour::X86_32_Generic;
|
|
||||||
} else {
|
|
||||||
Flavour = DWARFFlavour::X86_32_Generic;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return X86GenRegisterInfo::getDwarfRegNumFull(RegNo, Flavour);
|
return X86GenRegisterInfo::getDwarfRegNumFull(RegNo, Flavour);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// getLLVMRegNum - This function maps DWARF register numbers to LLVM register.
|
||||||
|
int X86RegisterInfo::getLLVMRegNum(unsigned DwarfRegNo, bool isEH) const {
|
||||||
|
const X86Subtarget *Subtarget = &TM.getSubtarget<X86Subtarget>();
|
||||||
|
unsigned Flavour = getFlavour(Subtarget, isEH);
|
||||||
|
|
||||||
|
return X86GenRegisterInfo::getLLVMRegNumFull(DwarfRegNo, Flavour);
|
||||||
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
X86RegisterInfo::getSEHRegNum(unsigned i) const {
|
X86RegisterInfo::getSEHRegNum(unsigned i) const {
|
||||||
int reg = getX86RegNum(i);
|
int reg = getX86RegNum(i);
|
||||||
|
@ -80,6 +80,7 @@ public:
|
|||||||
/// getDwarfRegNum - allows modification of X86GenRegisterInfo::getDwarfRegNum
|
/// getDwarfRegNum - allows modification of X86GenRegisterInfo::getDwarfRegNum
|
||||||
/// (created by TableGen) for target dependencies.
|
/// (created by TableGen) for target dependencies.
|
||||||
int getDwarfRegNum(unsigned RegNum, bool isEH) const;
|
int getDwarfRegNum(unsigned RegNum, bool isEH) const;
|
||||||
|
int getLLVMRegNum(unsigned RegNum, bool isEH) const;
|
||||||
|
|
||||||
// FIXME: This should be tablegen'd like getDwarfRegNum is
|
// FIXME: This should be tablegen'd like getDwarfRegNum is
|
||||||
int getSEHRegNum(unsigned i) const;
|
int getSEHRegNum(unsigned i) const;
|
||||||
|
@ -315,6 +315,10 @@ int XCoreRegisterInfo::getDwarfRegNum(unsigned RegNum, bool isEH) const {
|
|||||||
return XCoreGenRegisterInfo::getDwarfRegNumFull(RegNum, 0);
|
return XCoreGenRegisterInfo::getDwarfRegNumFull(RegNum, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int XCoreRegisterInfo::getLLVMRegNum(unsigned DwarfRegNo, bool isEH) const {
|
||||||
|
return XCoreGenRegisterInfo::getLLVMRegNumFull(DwarfRegNo,0);
|
||||||
|
}
|
||||||
|
|
||||||
unsigned XCoreRegisterInfo::getFrameRegister(const MachineFunction &MF) const {
|
unsigned XCoreRegisterInfo::getFrameRegister(const MachineFunction &MF) const {
|
||||||
const TargetFrameLowering *TFI = MF.getTarget().getFrameLowering();
|
const TargetFrameLowering *TFI = MF.getTarget().getFrameLowering();
|
||||||
|
|
||||||
|
@ -75,6 +75,7 @@ public:
|
|||||||
|
|
||||||
//! Get DWARF debugging register number
|
//! Get DWARF debugging register number
|
||||||
int getDwarfRegNum(unsigned RegNum, bool isEH) const;
|
int getDwarfRegNum(unsigned RegNum, bool isEH) const;
|
||||||
|
int getLLVMRegNum(unsigned RegNum, bool isEH) const;
|
||||||
};
|
};
|
||||||
|
|
||||||
} // end namespace llvm
|
} // end namespace llvm
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
; Check that eh_return & unwind_init were properly lowered
|
; Check that eh_return & unwind_init were properly lowered
|
||||||
; RUN: llc < %s | grep %ebp | count 7
|
; RUN: llc < %s | grep %ebp | count 9
|
||||||
; RUN: llc < %s | grep %ecx | count 5
|
; RUN: llc < %s | grep %ecx | count 5
|
||||||
|
|
||||||
target datalayout = "e-p:32:32:32-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:32:64-f32:32:32-f64:32:64-v64:64:64-v128:128:128-a0:0:64"
|
target datalayout = "e-p:32:32:32-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:32:64-f32:32:32-f64:32:64-v64:64:64-v128:128:128-a0:0:64"
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
; Check that eh_return & unwind_init were properly lowered
|
; Check that eh_return & unwind_init were properly lowered
|
||||||
; RUN: llc < %s | grep %rbp | count 5
|
; RUN: llc < %s | grep %rbp | count 7
|
||||||
; RUN: llc < %s | grep %rcx | count 3
|
; RUN: llc < %s | grep %rcx | count 3
|
||||||
|
|
||||||
target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128"
|
target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128"
|
||||||
|
@ -20,10 +20,10 @@ entry:
|
|||||||
; CHECK-FP-NEXT: :
|
; CHECK-FP-NEXT: :
|
||||||
; CHECK-FP-NEXT: .cfi_def_cfa_offset 16
|
; CHECK-FP-NEXT: .cfi_def_cfa_offset 16
|
||||||
; CHECK-FP-NEXT: :
|
; CHECK-FP-NEXT: :
|
||||||
; CHECK-FP-NEXT: .cfi_offset 6, -16
|
; CHECK-FP-NEXT: .cfi_offset %rbp, -16
|
||||||
; CHECK-FP-NEXT: movq %rsp, %rbp
|
; CHECK-FP-NEXT: movq %rsp, %rbp
|
||||||
; CHECK-FP-NEXT: :
|
; CHECK-FP-NEXT: :
|
||||||
; CHECK-FP-NEXT: .cfi_def_cfa_register 6
|
; CHECK-FP-NEXT: .cfi_def_cfa_register %rbp
|
||||||
; CHECK-FP-NEXT: nop
|
; CHECK-FP-NEXT: nop
|
||||||
; CHECK-FP-NEXT: :
|
; CHECK-FP-NEXT: :
|
||||||
; CHECK-FP-NEXT: .cfi_endproc
|
; CHECK-FP-NEXT: .cfi_endproc
|
||||||
|
@ -9,9 +9,9 @@ define void @f() {
|
|||||||
; CHECK-NEXT: :
|
; CHECK-NEXT: :
|
||||||
; CHECK-NEXT: .cfi_def_cfa_offset 16
|
; CHECK-NEXT: .cfi_def_cfa_offset 16
|
||||||
; CHECK-NEXT: :
|
; CHECK-NEXT: :
|
||||||
; CHECK-NEXT: .cfi_offset 6, -16
|
; CHECK-NEXT: .cfi_offset %rbp, -16
|
||||||
; CHECK-NEXT: movq %rsp, %rbp
|
; CHECK-NEXT: movq %rsp, %rbp
|
||||||
; CHECK-NEXT: :
|
; CHECK-NEXT: :
|
||||||
; CHECK-NEXT: .cfi_def_cfa_register 6
|
; CHECK-NEXT: .cfi_def_cfa_register %rbp
|
||||||
; CHECK-NEXT: popq %rbp
|
; CHECK-NEXT: popq %rbp
|
||||||
; CHECK-NEXT: ret
|
; CHECK-NEXT: ret
|
||||||
|
@ -80,6 +80,8 @@ void RegisterInfoEmitter::runHeader(raw_ostream &OS) {
|
|||||||
<< "(int CallFrameSetupOpcode = -1, int CallFrameDestroyOpcode = -1);\n"
|
<< "(int CallFrameSetupOpcode = -1, int CallFrameDestroyOpcode = -1);\n"
|
||||||
<< " virtual int getDwarfRegNumFull(unsigned RegNum, "
|
<< " virtual int getDwarfRegNumFull(unsigned RegNum, "
|
||||||
<< "unsigned Flavour) const;\n"
|
<< "unsigned Flavour) const;\n"
|
||||||
|
<< " virtual int getLLVMRegNumFull(unsigned DwarfRegNum, "
|
||||||
|
<< "unsigned Flavour) const;\n"
|
||||||
<< " virtual int getDwarfRegNum(unsigned RegNum, bool isEH) const = 0;\n"
|
<< " virtual int getDwarfRegNum(unsigned RegNum, bool isEH) const = 0;\n"
|
||||||
<< " virtual bool needsStackRealignment(const MachineFunction &) const\n"
|
<< " virtual bool needsStackRealignment(const MachineFunction &) const\n"
|
||||||
<< " { return false; }\n"
|
<< " { return false; }\n"
|
||||||
@ -989,6 +991,33 @@ void RegisterInfoEmitter::run(raw_ostream &OS) {
|
|||||||
for (unsigned i = I->second.size(), e = maxLength; i != e; ++i)
|
for (unsigned i = I->second.size(), e = maxLength; i != e; ++i)
|
||||||
I->second.push_back(-1);
|
I->second.push_back(-1);
|
||||||
|
|
||||||
|
// Emit reverse information about the dwarf register numbers.
|
||||||
|
OS << "int " << ClassName << "::getLLVMRegNumFull(unsigned DwarfRegNum, "
|
||||||
|
<< "unsigned Flavour) const {\n"
|
||||||
|
<< " switch (Flavour) {\n"
|
||||||
|
<< " default:\n"
|
||||||
|
<< " assert(0 && \"Unknown DWARF flavour\");\n"
|
||||||
|
<< " return -1;\n";
|
||||||
|
|
||||||
|
for (unsigned i = 0, e = maxLength; i != e; ++i) {
|
||||||
|
OS << " case " << i << ":\n"
|
||||||
|
<< " switch (DwarfRegNum) {\n"
|
||||||
|
<< " default:\n"
|
||||||
|
<< " assert(0 && \"Invalid DwarfRegNum\");\n"
|
||||||
|
<< " return -1;\n";
|
||||||
|
|
||||||
|
for (DwarfRegNumsMapTy::iterator
|
||||||
|
I = DwarfRegNums.begin(), E = DwarfRegNums.end(); I != E; ++I) {
|
||||||
|
int DwarfRegNo = I->second[i];
|
||||||
|
if (DwarfRegNo >= 0)
|
||||||
|
OS << " case " << DwarfRegNo << ":\n"
|
||||||
|
<< " return " << getQualifiedName(I->first) << ";\n";
|
||||||
|
}
|
||||||
|
OS << " };\n";
|
||||||
|
}
|
||||||
|
|
||||||
|
OS << " };\n}\n\n";
|
||||||
|
|
||||||
for (unsigned i = 0, e = Regs.size(); i != e; ++i) {
|
for (unsigned i = 0, e = Regs.size(); i != e; ++i) {
|
||||||
Record *Reg = Regs[i].TheDef;
|
Record *Reg = Regs[i].TheDef;
|
||||||
const RecordVal *V = Reg->getValue("DwarfAlias");
|
const RecordVal *V = Reg->getValue("DwarfAlias");
|
||||||
|
Loading…
Reference in New Issue
Block a user