mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-10 02:36:06 +00:00
move gettemplabel and getdwlabel to AsmPrinter and rename
them for consistency. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@100345 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
7e1a8f882f
commit
c021572511
@ -190,6 +190,36 @@ namespace llvm {
|
|||||||
/// do nothing and return false.
|
/// do nothing and return false.
|
||||||
bool EmitSpecialLLVMGlobal(const GlobalVariable *GV);
|
bool EmitSpecialLLVMGlobal(const GlobalVariable *GV);
|
||||||
|
|
||||||
|
/// EmitAlignment - Emit an alignment directive to the specified power of
|
||||||
|
/// two boundary. For example, if you pass in 3 here, you will get an 8
|
||||||
|
/// byte alignment. If a global value is specified, and if that global has
|
||||||
|
/// an explicit alignment requested, it will unconditionally override the
|
||||||
|
/// alignment request. However, if ForcedAlignBits is specified, this value
|
||||||
|
/// has final say: the ultimate alignment will be the max of ForcedAlignBits
|
||||||
|
/// and the alignment computed with NumBits and the global. If UseFillExpr
|
||||||
|
/// is true, it also emits an optional second value FillValue which the
|
||||||
|
/// assembler uses to fill gaps to match alignment for text sections if the
|
||||||
|
/// has specified a non-zero fill value.
|
||||||
|
///
|
||||||
|
/// The algorithm is:
|
||||||
|
/// Align = NumBits;
|
||||||
|
/// if (GV && GV->hasalignment) Align = GV->getalignment();
|
||||||
|
/// Align = std::max(Align, ForcedAlignBits);
|
||||||
|
///
|
||||||
|
void EmitAlignment(unsigned NumBits, const GlobalValue *GV = 0,
|
||||||
|
unsigned ForcedAlignBits = 0,
|
||||||
|
bool UseFillExpr = true) const;
|
||||||
|
|
||||||
|
/// EmitBasicBlockStart - This method prints the label for the specified
|
||||||
|
/// MachineBasicBlock, an alignment (if present) and a comment describing
|
||||||
|
/// it if appropriate.
|
||||||
|
void EmitBasicBlockStart(const MachineBasicBlock *MBB) const;
|
||||||
|
|
||||||
|
|
||||||
|
/// EmitGlobalConstant - Print a general LLVM constant to the .s file.
|
||||||
|
void EmitGlobalConstant(const Constant *CV, unsigned AddrSpace = 0);
|
||||||
|
|
||||||
|
|
||||||
//===------------------------------------------------------------------===//
|
//===------------------------------------------------------------------===//
|
||||||
// Overridable Hooks
|
// Overridable Hooks
|
||||||
//===------------------------------------------------------------------===//
|
//===------------------------------------------------------------------===//
|
||||||
@ -229,29 +259,18 @@ namespace llvm {
|
|||||||
isBlockOnlyReachableByFallthrough(const MachineBasicBlock *MBB) const;
|
isBlockOnlyReachableByFallthrough(const MachineBasicBlock *MBB) const;
|
||||||
|
|
||||||
//===------------------------------------------------------------------===//
|
//===------------------------------------------------------------------===//
|
||||||
// Lowering Routines.
|
// Symbol Lowering Routines.
|
||||||
//===------------------------------------------------------------------===//
|
//===------------------------------------------------------------------===//
|
||||||
public:
|
public:
|
||||||
|
|
||||||
/// EmitAlignment - Emit an alignment directive to the specified power of
|
/// GetTempSymbol - Return the MCSymbol corresponding to the assembler
|
||||||
/// two boundary. For example, if you pass in 3 here, you will get an 8
|
/// temporary label with the specified stem and unique ID.
|
||||||
/// byte alignment. If a global value is specified, and if that global has
|
MCSymbol *GetTempSymbol(StringRef Name, unsigned ID) const;
|
||||||
/// an explicit alignment requested, it will unconditionally override the
|
|
||||||
/// alignment request. However, if ForcedAlignBits is specified, this value
|
/// GetTempSymbol - Return an assembler temporary label with the specified
|
||||||
/// has final say: the ultimate alignment will be the max of ForcedAlignBits
|
/// stem.
|
||||||
/// and the alignment computed with NumBits and the global. If UseFillExpr
|
MCSymbol *GetTempSymbol(StringRef Name) const;
|
||||||
/// is true, it also emits an optional second value FillValue which the
|
|
||||||
/// assembler uses to fill gaps to match alignment for text sections if the
|
|
||||||
/// has specified a non-zero fill value.
|
|
||||||
///
|
|
||||||
/// The algorithm is:
|
|
||||||
/// Align = NumBits;
|
|
||||||
/// if (GV && GV->hasalignment) Align = GV->getalignment();
|
|
||||||
/// Align = std::max(Align, ForcedAlignBits);
|
|
||||||
///
|
|
||||||
void EmitAlignment(unsigned NumBits, const GlobalValue *GV = 0,
|
|
||||||
unsigned ForcedAlignBits = 0,
|
|
||||||
bool UseFillExpr = true) const;
|
|
||||||
|
|
||||||
/// GetSymbolWithGlobalValueBase - Return the MCSymbol for a symbol with
|
/// GetSymbolWithGlobalValueBase - Return the MCSymbol for a symbol with
|
||||||
/// global value name as its base, with the specified suffix, and where the
|
/// global value name as its base, with the specified suffix, and where the
|
||||||
@ -279,15 +298,6 @@ namespace llvm {
|
|||||||
MCSymbol *GetBlockAddressSymbol(const BlockAddress *BA) const;
|
MCSymbol *GetBlockAddressSymbol(const BlockAddress *BA) const;
|
||||||
MCSymbol *GetBlockAddressSymbol(const BasicBlock *BB) const;
|
MCSymbol *GetBlockAddressSymbol(const BasicBlock *BB) const;
|
||||||
|
|
||||||
/// EmitBasicBlockStart - This method prints the label for the specified
|
|
||||||
/// MachineBasicBlock, an alignment (if present) and a comment describing
|
|
||||||
/// it if appropriate.
|
|
||||||
void EmitBasicBlockStart(const MachineBasicBlock *MBB) const;
|
|
||||||
|
|
||||||
|
|
||||||
/// EmitGlobalConstant - Print a general LLVM constant to the .s file.
|
|
||||||
void EmitGlobalConstant(const Constant *CV, unsigned AddrSpace = 0);
|
|
||||||
|
|
||||||
//===------------------------------------------------------------------===//
|
//===------------------------------------------------------------------===//
|
||||||
// Emission Helper Routines.
|
// Emission Helper Routines.
|
||||||
//===------------------------------------------------------------------===//
|
//===------------------------------------------------------------------===//
|
||||||
|
@ -962,9 +962,7 @@ void AsmPrinter::EmitLabelDifference(const MCSymbol *Hi, const MCSymbol *Lo,
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Otherwise, emit with .set (aka assignment).
|
// Otherwise, emit with .set (aka assignment).
|
||||||
MCSymbol *SetLabel =
|
MCSymbol *SetLabel = GetTempSymbol("set", SetCounter++);
|
||||||
OutContext.GetOrCreateSymbol(Twine(MAI->getPrivateGlobalPrefix()) +
|
|
||||||
"set" + Twine(SetCounter++));
|
|
||||||
OutStreamer.EmitAssignment(SetLabel, Diff);
|
OutStreamer.EmitAssignment(SetLabel, Diff);
|
||||||
OutStreamer.EmitSymbolValue(SetLabel, Size, 0/*AddrSpace*/);
|
OutStreamer.EmitSymbolValue(SetLabel, Size, 0/*AddrSpace*/);
|
||||||
}
|
}
|
||||||
@ -1345,6 +1343,29 @@ void AsmPrinter::printOffset(int64_t Offset, raw_ostream &OS) const {
|
|||||||
OS << Offset;
|
OS << Offset;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
// Symbol Lowering Routines.
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
|
/// GetTempSymbol - Return the MCSymbol corresponding to the assembler
|
||||||
|
/// temporary label with the specified stem and unique ID.
|
||||||
|
MCSymbol *AsmPrinter::GetTempSymbol(StringRef Name, unsigned ID) const {
|
||||||
|
// FIXME: REMOVE this. However, there is stuff in EH that passes counters in
|
||||||
|
// here that can be zero.
|
||||||
|
|
||||||
|
//assert(ID && "Should use GetTempSymbol if no ID");
|
||||||
|
if (ID == 0) return GetTempSymbol(Name);
|
||||||
|
return OutContext.GetOrCreateSymbol(Twine(MAI->getPrivateGlobalPrefix())+
|
||||||
|
Name + Twine(ID));
|
||||||
|
}
|
||||||
|
|
||||||
|
/// GetTempSymbol - Return an assembler temporary label with the specified
|
||||||
|
/// stem.
|
||||||
|
MCSymbol *AsmPrinter::GetTempSymbol(StringRef Name) const {
|
||||||
|
return OutContext.GetOrCreateSymbol(Twine(MAI->getPrivateGlobalPrefix())+
|
||||||
|
Name);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
MCSymbol *AsmPrinter::GetBlockAddressSymbol(const BlockAddress *BA) const {
|
MCSymbol *AsmPrinter::GetBlockAddressSymbol(const BlockAddress *BA) const {
|
||||||
return MMI->getAddrLabelSymbol(BA->getBasicBlock());
|
return MMI->getAddrLabelSymbol(BA->getBasicBlock());
|
||||||
|
@ -320,7 +320,7 @@ MCSymbol *DwarfDebug::getStringPoolEntry(StringRef Str) {
|
|||||||
if (Entry.first) return Entry.first;
|
if (Entry.first) return Entry.first;
|
||||||
|
|
||||||
Entry.second = NextStringPoolNumber++;
|
Entry.second = NextStringPoolNumber++;
|
||||||
return Entry.first = getDWLabel("string", Entry.second);
|
return Entry.first = Asm->GetTempSymbol("string", Entry.second);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -1351,9 +1351,9 @@ DIE *DwarfDebug::updateSubprogramScopeDIE(MDNode *SPNode) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
addLabel(SPDie, dwarf::DW_AT_low_pc, dwarf::DW_FORM_addr,
|
addLabel(SPDie, dwarf::DW_AT_low_pc, dwarf::DW_FORM_addr,
|
||||||
getDWLabel("func_begin", SubprogramCount));
|
Asm->GetTempSymbol("func_begin", SubprogramCount));
|
||||||
addLabel(SPDie, dwarf::DW_AT_high_pc, dwarf::DW_FORM_addr,
|
addLabel(SPDie, dwarf::DW_AT_high_pc, dwarf::DW_FORM_addr,
|
||||||
getDWLabel("func_end", SubprogramCount));
|
Asm->GetTempSymbol("func_end", SubprogramCount));
|
||||||
MachineLocation Location(RI->getFrameRegister(*MF));
|
MachineLocation Location(RI->getFrameRegister(*MF));
|
||||||
addAddress(SPDie, dwarf::DW_AT_frame_base, Location);
|
addAddress(SPDie, dwarf::DW_AT_frame_base, Location);
|
||||||
|
|
||||||
@ -1378,9 +1378,9 @@ DIE *DwarfDebug::constructLexicalScopeDIE(DbgScope *Scope) {
|
|||||||
return ScopeDIE;
|
return ScopeDIE;
|
||||||
|
|
||||||
addLabel(ScopeDIE, dwarf::DW_AT_low_pc, dwarf::DW_FORM_addr,
|
addLabel(ScopeDIE, dwarf::DW_AT_low_pc, dwarf::DW_FORM_addr,
|
||||||
Start ? Start : getDWLabel("func_begin", SubprogramCount));
|
Start ? Start : Asm->GetTempSymbol("func_begin", SubprogramCount));
|
||||||
addLabel(ScopeDIE, dwarf::DW_AT_high_pc, dwarf::DW_FORM_addr,
|
addLabel(ScopeDIE, dwarf::DW_AT_high_pc, dwarf::DW_FORM_addr,
|
||||||
End ? End : getDWLabel("func_end", SubprogramCount));
|
End ? End : Asm->GetTempSymbol("func_end", SubprogramCount));
|
||||||
|
|
||||||
return ScopeDIE;
|
return ScopeDIE;
|
||||||
}
|
}
|
||||||
@ -1669,9 +1669,9 @@ void DwarfDebug::constructCompileUnit(MDNode *N) {
|
|||||||
DIUnit.getLanguage());
|
DIUnit.getLanguage());
|
||||||
addString(Die, dwarf::DW_AT_name, dwarf::DW_FORM_string, FN);
|
addString(Die, dwarf::DW_AT_name, dwarf::DW_FORM_string, FN);
|
||||||
addLabel(Die, dwarf::DW_AT_low_pc, dwarf::DW_FORM_addr,
|
addLabel(Die, dwarf::DW_AT_low_pc, dwarf::DW_FORM_addr,
|
||||||
getTempLabel("text_begin"));
|
Asm->GetTempSymbol("text_begin"));
|
||||||
addLabel(Die, dwarf::DW_AT_high_pc, dwarf::DW_FORM_addr,
|
addLabel(Die, dwarf::DW_AT_high_pc, dwarf::DW_FORM_addr,
|
||||||
getTempLabel("text_end"));
|
Asm->GetTempSymbol("text_end"));
|
||||||
// DW_AT_stmt_list is a offset of line number information for this
|
// DW_AT_stmt_list is a offset of line number information for this
|
||||||
// compile unit in debug_line section. It is always zero when only one
|
// compile unit in debug_line section. It is always zero when only one
|
||||||
// compile unit is emitted in one object file.
|
// compile unit is emitted in one object file.
|
||||||
@ -1872,14 +1872,14 @@ void DwarfDebug::endModule() {
|
|||||||
|
|
||||||
// Standard sections final addresses.
|
// Standard sections final addresses.
|
||||||
Asm->OutStreamer.SwitchSection(Asm->getObjFileLowering().getTextSection());
|
Asm->OutStreamer.SwitchSection(Asm->getObjFileLowering().getTextSection());
|
||||||
Asm->OutStreamer.EmitLabel(getTempLabel("text_end"));
|
Asm->OutStreamer.EmitLabel(Asm->GetTempSymbol("text_end"));
|
||||||
Asm->OutStreamer.SwitchSection(Asm->getObjFileLowering().getDataSection());
|
Asm->OutStreamer.SwitchSection(Asm->getObjFileLowering().getDataSection());
|
||||||
Asm->OutStreamer.EmitLabel(getTempLabel("data_end"));
|
Asm->OutStreamer.EmitLabel(Asm->GetTempSymbol("data_end"));
|
||||||
|
|
||||||
// End text sections.
|
// End text sections.
|
||||||
for (unsigned i = 1, N = SectionMap.size(); i <= N; ++i) {
|
for (unsigned i = 1, N = SectionMap.size(); i <= N; ++i) {
|
||||||
Asm->OutStreamer.SwitchSection(SectionMap[i]);
|
Asm->OutStreamer.SwitchSection(SectionMap[i]);
|
||||||
Asm->OutStreamer.EmitLabel(getDWLabel("section_end", i));
|
Asm->OutStreamer.EmitLabel(Asm->GetTempSymbol("section_end", i));
|
||||||
}
|
}
|
||||||
|
|
||||||
// Emit common frame information.
|
// Emit common frame information.
|
||||||
@ -2255,7 +2255,8 @@ void DwarfDebug::beginFunction(const MachineFunction *MF) {
|
|||||||
collectVariableInfo();
|
collectVariableInfo();
|
||||||
|
|
||||||
// Assumes in correct section after the entry point.
|
// Assumes in correct section after the entry point.
|
||||||
Asm->OutStreamer.EmitLabel(getDWLabel("func_begin", ++SubprogramCount));
|
Asm->OutStreamer.EmitLabel(Asm->GetTempSymbol("func_begin",
|
||||||
|
++SubprogramCount));
|
||||||
|
|
||||||
// Emit label for the implicitly defined dbg.stoppoint at the start of the
|
// Emit label for the implicitly defined dbg.stoppoint at the start of the
|
||||||
// function.
|
// function.
|
||||||
@ -2287,7 +2288,7 @@ void DwarfDebug::endFunction(const MachineFunction *MF) {
|
|||||||
|
|
||||||
if (CurrentFnDbgScope) {
|
if (CurrentFnDbgScope) {
|
||||||
// Define end label for subprogram.
|
// Define end label for subprogram.
|
||||||
Asm->OutStreamer.EmitLabel(getDWLabel("func_end", SubprogramCount));
|
Asm->OutStreamer.EmitLabel(Asm->GetTempSymbol("func_end", SubprogramCount));
|
||||||
|
|
||||||
// Get function line info.
|
// Get function line info.
|
||||||
if (!Lines.empty()) {
|
if (!Lines.empty()) {
|
||||||
@ -2449,38 +2450,38 @@ void DwarfDebug::emitInitial() {
|
|||||||
// Dwarf sections base addresses.
|
// Dwarf sections base addresses.
|
||||||
if (MAI->doesDwarfRequireFrameSection()) {
|
if (MAI->doesDwarfRequireFrameSection()) {
|
||||||
Asm->OutStreamer.SwitchSection(TLOF.getDwarfFrameSection());
|
Asm->OutStreamer.SwitchSection(TLOF.getDwarfFrameSection());
|
||||||
Asm->OutStreamer.EmitLabel(getTempLabel("section_debug_frame"));
|
Asm->OutStreamer.EmitLabel(Asm->GetTempSymbol("section_debug_frame"));
|
||||||
}
|
}
|
||||||
|
|
||||||
Asm->OutStreamer.SwitchSection(TLOF.getDwarfInfoSection());
|
Asm->OutStreamer.SwitchSection(TLOF.getDwarfInfoSection());
|
||||||
Asm->OutStreamer.EmitLabel(getTempLabel("section_info"));
|
Asm->OutStreamer.EmitLabel(Asm->GetTempSymbol("section_info"));
|
||||||
Asm->OutStreamer.SwitchSection(TLOF.getDwarfAbbrevSection());
|
Asm->OutStreamer.SwitchSection(TLOF.getDwarfAbbrevSection());
|
||||||
Asm->OutStreamer.EmitLabel(getTempLabel("section_abbrev"));
|
Asm->OutStreamer.EmitLabel(Asm->GetTempSymbol("section_abbrev"));
|
||||||
Asm->OutStreamer.SwitchSection(TLOF.getDwarfARangesSection());
|
Asm->OutStreamer.SwitchSection(TLOF.getDwarfARangesSection());
|
||||||
Asm->OutStreamer.EmitLabel(getTempLabel("section_aranges"));
|
Asm->OutStreamer.EmitLabel(Asm->GetTempSymbol("section_aranges"));
|
||||||
|
|
||||||
if (const MCSection *LineInfoDirective = TLOF.getDwarfMacroInfoSection()) {
|
if (const MCSection *LineInfoDirective = TLOF.getDwarfMacroInfoSection()) {
|
||||||
Asm->OutStreamer.SwitchSection(LineInfoDirective);
|
Asm->OutStreamer.SwitchSection(LineInfoDirective);
|
||||||
Asm->OutStreamer.EmitLabel(getTempLabel("section_macinfo"));
|
Asm->OutStreamer.EmitLabel(Asm->GetTempSymbol("section_macinfo"));
|
||||||
}
|
}
|
||||||
|
|
||||||
Asm->OutStreamer.SwitchSection(TLOF.getDwarfLineSection());
|
Asm->OutStreamer.SwitchSection(TLOF.getDwarfLineSection());
|
||||||
Asm->OutStreamer.EmitLabel(getTempLabel("section_line"));
|
Asm->OutStreamer.EmitLabel(Asm->GetTempSymbol("section_line"));
|
||||||
Asm->OutStreamer.SwitchSection(TLOF.getDwarfLocSection());
|
Asm->OutStreamer.SwitchSection(TLOF.getDwarfLocSection());
|
||||||
Asm->OutStreamer.EmitLabel(getTempLabel("section_loc"));
|
Asm->OutStreamer.EmitLabel(Asm->GetTempSymbol("section_loc"));
|
||||||
Asm->OutStreamer.SwitchSection(TLOF.getDwarfPubNamesSection());
|
Asm->OutStreamer.SwitchSection(TLOF.getDwarfPubNamesSection());
|
||||||
Asm->OutStreamer.EmitLabel(getTempLabel("section_pubnames"));
|
Asm->OutStreamer.EmitLabel(Asm->GetTempSymbol("section_pubnames"));
|
||||||
Asm->OutStreamer.SwitchSection(TLOF.getDwarfPubTypesSection());
|
Asm->OutStreamer.SwitchSection(TLOF.getDwarfPubTypesSection());
|
||||||
Asm->OutStreamer.EmitLabel(getTempLabel("section_pubtypes"));
|
Asm->OutStreamer.EmitLabel(Asm->GetTempSymbol("section_pubtypes"));
|
||||||
Asm->OutStreamer.SwitchSection(TLOF.getDwarfStrSection());
|
Asm->OutStreamer.SwitchSection(TLOF.getDwarfStrSection());
|
||||||
Asm->OutStreamer.EmitLabel(getTempLabel("section_str"));
|
Asm->OutStreamer.EmitLabel(Asm->GetTempSymbol("section_str"));
|
||||||
Asm->OutStreamer.SwitchSection(TLOF.getDwarfRangesSection());
|
Asm->OutStreamer.SwitchSection(TLOF.getDwarfRangesSection());
|
||||||
Asm->OutStreamer.EmitLabel(getTempLabel("section_ranges"));
|
Asm->OutStreamer.EmitLabel(Asm->GetTempSymbol("section_ranges"));
|
||||||
|
|
||||||
Asm->OutStreamer.SwitchSection(TLOF.getTextSection());
|
Asm->OutStreamer.SwitchSection(TLOF.getTextSection());
|
||||||
Asm->OutStreamer.EmitLabel(getTempLabel("text_begin"));
|
Asm->OutStreamer.EmitLabel(Asm->GetTempSymbol("text_begin"));
|
||||||
Asm->OutStreamer.SwitchSection(TLOF.getDataSection());
|
Asm->OutStreamer.SwitchSection(TLOF.getDataSection());
|
||||||
Asm->OutStreamer.EmitLabel(getTempLabel("data_begin"));
|
Asm->OutStreamer.EmitLabel(Asm->GetTempSymbol("data_begin"));
|
||||||
}
|
}
|
||||||
|
|
||||||
/// emitDIE - Recusively Emits a debug information entry.
|
/// emitDIE - Recusively Emits a debug information entry.
|
||||||
@ -2550,7 +2551,8 @@ void DwarfDebug::emitDebugInfo() {
|
|||||||
DIE *Die = ModuleCU->getCUDie();
|
DIE *Die = ModuleCU->getCUDie();
|
||||||
|
|
||||||
// Emit the compile units header.
|
// Emit the compile units header.
|
||||||
Asm->OutStreamer.EmitLabel(getDWLabel("info_begin", ModuleCU->getID()));
|
Asm->OutStreamer.EmitLabel(Asm->GetTempSymbol("info_begin",
|
||||||
|
ModuleCU->getID()));
|
||||||
|
|
||||||
// Emit size of content not including length itself
|
// Emit size of content not including length itself
|
||||||
unsigned ContentSize = Die->getSize() +
|
unsigned ContentSize = Die->getSize() +
|
||||||
@ -2564,8 +2566,8 @@ void DwarfDebug::emitDebugInfo() {
|
|||||||
Asm->OutStreamer.AddComment("DWARF version number");
|
Asm->OutStreamer.AddComment("DWARF version number");
|
||||||
Asm->EmitInt16(dwarf::DWARF_VERSION);
|
Asm->EmitInt16(dwarf::DWARF_VERSION);
|
||||||
Asm->OutStreamer.AddComment("Offset Into Abbrev. Section");
|
Asm->OutStreamer.AddComment("Offset Into Abbrev. Section");
|
||||||
EmitSectionOffset(getTempLabel("abbrev_begin"),getTempLabel("section_abbrev"),
|
EmitSectionOffset(Asm->GetTempSymbol("abbrev_begin"),
|
||||||
true);
|
Asm->GetTempSymbol("section_abbrev"), true);
|
||||||
Asm->OutStreamer.AddComment("Address Size (in bytes)");
|
Asm->OutStreamer.AddComment("Address Size (in bytes)");
|
||||||
Asm->EmitInt8(TD->getPointerSize());
|
Asm->EmitInt8(TD->getPointerSize());
|
||||||
|
|
||||||
@ -2576,7 +2578,7 @@ void DwarfDebug::emitDebugInfo() {
|
|||||||
Asm->EmitInt8(0);
|
Asm->EmitInt8(0);
|
||||||
Asm->EmitInt8(0);
|
Asm->EmitInt8(0);
|
||||||
Asm->EmitInt8(0);
|
Asm->EmitInt8(0);
|
||||||
Asm->OutStreamer.EmitLabel(getDWLabel("info_end", ModuleCU->getID()));
|
Asm->OutStreamer.EmitLabel(Asm->GetTempSymbol("info_end", ModuleCU->getID()));
|
||||||
}
|
}
|
||||||
|
|
||||||
/// emitAbbreviations - Emit the abbreviation section.
|
/// emitAbbreviations - Emit the abbreviation section.
|
||||||
@ -2588,7 +2590,7 @@ void DwarfDebug::emitAbbreviations() const {
|
|||||||
Asm->OutStreamer.SwitchSection(
|
Asm->OutStreamer.SwitchSection(
|
||||||
Asm->getObjFileLowering().getDwarfAbbrevSection());
|
Asm->getObjFileLowering().getDwarfAbbrevSection());
|
||||||
|
|
||||||
Asm->OutStreamer.EmitLabel(getTempLabel("abbrev_begin"));
|
Asm->OutStreamer.EmitLabel(Asm->GetTempSymbol("abbrev_begin"));
|
||||||
|
|
||||||
// For each abbrevation.
|
// For each abbrevation.
|
||||||
for (unsigned i = 0, N = Abbreviations.size(); i < N; ++i) {
|
for (unsigned i = 0, N = Abbreviations.size(); i < N; ++i) {
|
||||||
@ -2605,7 +2607,7 @@ void DwarfDebug::emitAbbreviations() const {
|
|||||||
// Mark end of abbreviations.
|
// Mark end of abbreviations.
|
||||||
Asm->EmitULEB128(0, "EOM(3)");
|
Asm->EmitULEB128(0, "EOM(3)");
|
||||||
|
|
||||||
Asm->OutStreamer.EmitLabel(getTempLabel("abbrev_end"));
|
Asm->OutStreamer.EmitLabel(Asm->GetTempSymbol("abbrev_end"));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2624,7 +2626,7 @@ void DwarfDebug::emitEndOfLineMatrix(unsigned SectionEnd) {
|
|||||||
|
|
||||||
Asm->OutStreamer.AddComment("Section end label");
|
Asm->OutStreamer.AddComment("Section end label");
|
||||||
|
|
||||||
Asm->OutStreamer.EmitSymbolValue(getDWLabel("section_end", SectionEnd),
|
Asm->OutStreamer.EmitSymbolValue(Asm->GetTempSymbol("section_end",SectionEnd),
|
||||||
TD->getPointerSize(), 0/*AddrSpace*/);
|
TD->getPointerSize(), 0/*AddrSpace*/);
|
||||||
|
|
||||||
// Mark end of matrix.
|
// Mark end of matrix.
|
||||||
@ -2653,16 +2655,17 @@ void DwarfDebug::emitDebugLines() {
|
|||||||
|
|
||||||
// Construct the section header.
|
// Construct the section header.
|
||||||
Asm->OutStreamer.AddComment("Length of Source Line Info");
|
Asm->OutStreamer.AddComment("Length of Source Line Info");
|
||||||
EmitDifference(getTempLabel("line_end"), getTempLabel("line_begin"), true);
|
EmitDifference(Asm->GetTempSymbol("line_end"),
|
||||||
Asm->OutStreamer.EmitLabel(getTempLabel("line_begin"));
|
Asm->GetTempSymbol("line_begin"), true);
|
||||||
|
Asm->OutStreamer.EmitLabel(Asm->GetTempSymbol("line_begin"));
|
||||||
|
|
||||||
Asm->OutStreamer.AddComment("DWARF version number");
|
Asm->OutStreamer.AddComment("DWARF version number");
|
||||||
Asm->EmitInt16(dwarf::DWARF_VERSION);
|
Asm->EmitInt16(dwarf::DWARF_VERSION);
|
||||||
|
|
||||||
Asm->OutStreamer.AddComment("Prolog Length");
|
Asm->OutStreamer.AddComment("Prolog Length");
|
||||||
EmitDifference(getTempLabel("line_prolog_end"),
|
EmitDifference(Asm->GetTempSymbol("line_prolog_end"),
|
||||||
getTempLabel("line_prolog_begin"), true);
|
Asm->GetTempSymbol("line_prolog_begin"), true);
|
||||||
Asm->OutStreamer.EmitLabel(getTempLabel("line_prolog_begin"));
|
Asm->OutStreamer.EmitLabel(Asm->GetTempSymbol("line_prolog_begin"));
|
||||||
|
|
||||||
Asm->OutStreamer.AddComment("Minimum Instruction Length");
|
Asm->OutStreamer.AddComment("Minimum Instruction Length");
|
||||||
Asm->EmitInt8(1);
|
Asm->EmitInt8(1);
|
||||||
@ -2721,7 +2724,7 @@ void DwarfDebug::emitDebugLines() {
|
|||||||
Asm->OutStreamer.AddComment("End of files");
|
Asm->OutStreamer.AddComment("End of files");
|
||||||
Asm->EmitInt8(0);
|
Asm->EmitInt8(0);
|
||||||
|
|
||||||
Asm->OutStreamer.EmitLabel(getTempLabel("line_prolog_end"));
|
Asm->OutStreamer.EmitLabel(Asm->GetTempSymbol("line_prolog_end"));
|
||||||
|
|
||||||
// A sequence for each text section.
|
// A sequence for each text section.
|
||||||
unsigned SecSrcLinesSize = SectionSourceLines.size();
|
unsigned SecSrcLinesSize = SectionSourceLines.size();
|
||||||
@ -2810,7 +2813,7 @@ void DwarfDebug::emitDebugLines() {
|
|||||||
// put into it, emit an empty table.
|
// put into it, emit an empty table.
|
||||||
emitEndOfLineMatrix(1);
|
emitEndOfLineMatrix(1);
|
||||||
|
|
||||||
Asm->OutStreamer.EmitLabel(getTempLabel("line_end"));
|
Asm->OutStreamer.EmitLabel(Asm->GetTempSymbol("line_end"));
|
||||||
}
|
}
|
||||||
|
|
||||||
/// emitCommonDebugFrame - Emit common frame info into a debug frame section.
|
/// emitCommonDebugFrame - Emit common frame info into a debug frame section.
|
||||||
@ -2828,12 +2831,12 @@ void DwarfDebug::emitCommonDebugFrame() {
|
|||||||
Asm->OutStreamer.SwitchSection(
|
Asm->OutStreamer.SwitchSection(
|
||||||
Asm->getObjFileLowering().getDwarfFrameSection());
|
Asm->getObjFileLowering().getDwarfFrameSection());
|
||||||
|
|
||||||
Asm->OutStreamer.EmitLabel(getTempLabel("debug_frame_common"));
|
Asm->OutStreamer.EmitLabel(Asm->GetTempSymbol("debug_frame_common"));
|
||||||
Asm->OutStreamer.AddComment("Length of Common Information Entry");
|
Asm->OutStreamer.AddComment("Length of Common Information Entry");
|
||||||
EmitDifference(getTempLabel("debug_frame_common_end"),
|
EmitDifference(Asm->GetTempSymbol("debug_frame_common_end"),
|
||||||
getTempLabel("debug_frame_common_begin"), true);
|
Asm->GetTempSymbol("debug_frame_common_begin"), true);
|
||||||
|
|
||||||
Asm->OutStreamer.EmitLabel(getTempLabel("debug_frame_common_begin"));
|
Asm->OutStreamer.EmitLabel(Asm->GetTempSymbol("debug_frame_common_begin"));
|
||||||
Asm->OutStreamer.AddComment("CIE Identifier Tag");
|
Asm->OutStreamer.AddComment("CIE Identifier Tag");
|
||||||
Asm->EmitInt32((int)dwarf::DW_CIE_ID);
|
Asm->EmitInt32((int)dwarf::DW_CIE_ID);
|
||||||
Asm->OutStreamer.AddComment("CIE Version");
|
Asm->OutStreamer.AddComment("CIE Version");
|
||||||
@ -2851,7 +2854,7 @@ void DwarfDebug::emitCommonDebugFrame() {
|
|||||||
EmitFrameMoves(0, Moves, false);
|
EmitFrameMoves(0, Moves, false);
|
||||||
|
|
||||||
Asm->EmitAlignment(2, 0, 0, false);
|
Asm->EmitAlignment(2, 0, 0, false);
|
||||||
Asm->OutStreamer.EmitLabel(getTempLabel("debug_frame_common_end"));
|
Asm->OutStreamer.EmitLabel(Asm->GetTempSymbol("debug_frame_common_end"));
|
||||||
}
|
}
|
||||||
|
|
||||||
/// emitFunctionDebugFrame - Emit per function frame info into a debug frame
|
/// emitFunctionDebugFrame - Emit per function frame info into a debug frame
|
||||||
@ -2867,25 +2870,27 @@ emitFunctionDebugFrame(const FunctionDebugFrameInfo &DebugFrameInfo) {
|
|||||||
|
|
||||||
Asm->OutStreamer.AddComment("Length of Frame Information Entry");
|
Asm->OutStreamer.AddComment("Length of Frame Information Entry");
|
||||||
MCSymbol *DebugFrameBegin =
|
MCSymbol *DebugFrameBegin =
|
||||||
getDWLabel("debug_frame_begin", DebugFrameInfo.Number);
|
Asm->GetTempSymbol("debug_frame_begin", DebugFrameInfo.Number);
|
||||||
MCSymbol *DebugFrameEnd =
|
MCSymbol *DebugFrameEnd =
|
||||||
getDWLabel("debug_frame_end", DebugFrameInfo.Number);
|
Asm->GetTempSymbol("debug_frame_end", DebugFrameInfo.Number);
|
||||||
EmitDifference(DebugFrameEnd, DebugFrameBegin, true);
|
EmitDifference(DebugFrameEnd, DebugFrameBegin, true);
|
||||||
|
|
||||||
Asm->OutStreamer.EmitLabel(DebugFrameBegin);
|
Asm->OutStreamer.EmitLabel(DebugFrameBegin);
|
||||||
|
|
||||||
Asm->OutStreamer.AddComment("FDE CIE offset");
|
Asm->OutStreamer.AddComment("FDE CIE offset");
|
||||||
EmitSectionOffset(getTempLabel("debug_frame_common"),
|
EmitSectionOffset(Asm->GetTempSymbol("debug_frame_common"),
|
||||||
getTempLabel("section_debug_frame"), true);
|
Asm->GetTempSymbol("section_debug_frame"), true);
|
||||||
|
|
||||||
Asm->OutStreamer.AddComment("FDE initial location");
|
Asm->OutStreamer.AddComment("FDE initial location");
|
||||||
MCSymbol *FuncBeginSym = getDWLabel("func_begin", DebugFrameInfo.Number);
|
MCSymbol *FuncBeginSym =
|
||||||
|
Asm->GetTempSymbol("func_begin", DebugFrameInfo.Number);
|
||||||
Asm->OutStreamer.EmitSymbolValue(FuncBeginSym,
|
Asm->OutStreamer.EmitSymbolValue(FuncBeginSym,
|
||||||
TD->getPointerSize(), 0/*AddrSpace*/);
|
TD->getPointerSize(), 0/*AddrSpace*/);
|
||||||
|
|
||||||
|
|
||||||
Asm->OutStreamer.AddComment("FDE address range");
|
Asm->OutStreamer.AddComment("FDE address range");
|
||||||
EmitDifference(getDWLabel("func_end", DebugFrameInfo.Number), FuncBeginSym);
|
EmitDifference(Asm->GetTempSymbol("func_end", DebugFrameInfo.Number),
|
||||||
|
FuncBeginSym);
|
||||||
|
|
||||||
EmitFrameMoves(FuncBeginSym, DebugFrameInfo.Moves, false);
|
EmitFrameMoves(FuncBeginSym, DebugFrameInfo.Moves, false);
|
||||||
|
|
||||||
@ -2901,21 +2906,22 @@ void DwarfDebug::emitDebugPubNames() {
|
|||||||
Asm->getObjFileLowering().getDwarfPubNamesSection());
|
Asm->getObjFileLowering().getDwarfPubNamesSection());
|
||||||
|
|
||||||
Asm->OutStreamer.AddComment("Length of Public Names Info");
|
Asm->OutStreamer.AddComment("Length of Public Names Info");
|
||||||
EmitDifference(getDWLabel("pubnames_end", ModuleCU->getID()),
|
EmitDifference(Asm->GetTempSymbol("pubnames_end", ModuleCU->getID()),
|
||||||
getDWLabel("pubnames_begin", ModuleCU->getID()), true);
|
Asm->GetTempSymbol("pubnames_begin", ModuleCU->getID()), true);
|
||||||
|
|
||||||
Asm->OutStreamer.EmitLabel(getDWLabel("pubnames_begin", ModuleCU->getID()));
|
Asm->OutStreamer.EmitLabel(Asm->GetTempSymbol("pubnames_begin",
|
||||||
|
ModuleCU->getID()));
|
||||||
|
|
||||||
Asm->OutStreamer.AddComment("DWARF Version");
|
Asm->OutStreamer.AddComment("DWARF Version");
|
||||||
Asm->EmitInt16(dwarf::DWARF_VERSION);
|
Asm->EmitInt16(dwarf::DWARF_VERSION);
|
||||||
|
|
||||||
Asm->OutStreamer.AddComment("Offset of Compilation Unit Info");
|
Asm->OutStreamer.AddComment("Offset of Compilation Unit Info");
|
||||||
EmitSectionOffset(getDWLabel("info_begin", ModuleCU->getID()),
|
EmitSectionOffset(Asm->GetTempSymbol("info_begin", ModuleCU->getID()),
|
||||||
getTempLabel("section_info"), true);
|
Asm->GetTempSymbol("section_info"), true);
|
||||||
|
|
||||||
Asm->OutStreamer.AddComment("Compilation Unit Length");
|
Asm->OutStreamer.AddComment("Compilation Unit Length");
|
||||||
EmitDifference(getDWLabel("info_end", ModuleCU->getID()),
|
EmitDifference(Asm->GetTempSymbol("info_end", ModuleCU->getID()),
|
||||||
getDWLabel("info_begin", ModuleCU->getID()),
|
Asm->GetTempSymbol("info_begin", ModuleCU->getID()),
|
||||||
true);
|
true);
|
||||||
|
|
||||||
const StringMap<DIE*> &Globals = ModuleCU->getGlobals();
|
const StringMap<DIE*> &Globals = ModuleCU->getGlobals();
|
||||||
@ -2934,7 +2940,8 @@ void DwarfDebug::emitDebugPubNames() {
|
|||||||
|
|
||||||
Asm->OutStreamer.AddComment("End Mark");
|
Asm->OutStreamer.AddComment("End Mark");
|
||||||
Asm->EmitInt32(0);
|
Asm->EmitInt32(0);
|
||||||
Asm->OutStreamer.EmitLabel(getDWLabel("pubnames_end", ModuleCU->getID()));
|
Asm->OutStreamer.EmitLabel(Asm->GetTempSymbol("pubnames_end",
|
||||||
|
ModuleCU->getID()));
|
||||||
}
|
}
|
||||||
|
|
||||||
void DwarfDebug::emitDebugPubTypes() {
|
void DwarfDebug::emitDebugPubTypes() {
|
||||||
@ -2942,21 +2949,22 @@ void DwarfDebug::emitDebugPubTypes() {
|
|||||||
Asm->OutStreamer.SwitchSection(
|
Asm->OutStreamer.SwitchSection(
|
||||||
Asm->getObjFileLowering().getDwarfPubTypesSection());
|
Asm->getObjFileLowering().getDwarfPubTypesSection());
|
||||||
Asm->OutStreamer.AddComment("Length of Public Types Info");
|
Asm->OutStreamer.AddComment("Length of Public Types Info");
|
||||||
EmitDifference(getDWLabel("pubtypes_end", ModuleCU->getID()),
|
EmitDifference(Asm->GetTempSymbol("pubtypes_end", ModuleCU->getID()),
|
||||||
getDWLabel("pubtypes_begin", ModuleCU->getID()), true);
|
Asm->GetTempSymbol("pubtypes_begin", ModuleCU->getID()), true);
|
||||||
|
|
||||||
Asm->OutStreamer.EmitLabel(getDWLabel("pubtypes_begin", ModuleCU->getID()));
|
Asm->OutStreamer.EmitLabel(Asm->GetTempSymbol("pubtypes_begin",
|
||||||
|
ModuleCU->getID()));
|
||||||
|
|
||||||
if (Asm->isVerbose()) Asm->OutStreamer.AddComment("DWARF Version");
|
if (Asm->isVerbose()) Asm->OutStreamer.AddComment("DWARF Version");
|
||||||
Asm->EmitInt16(dwarf::DWARF_VERSION);
|
Asm->EmitInt16(dwarf::DWARF_VERSION);
|
||||||
|
|
||||||
Asm->OutStreamer.AddComment("Offset of Compilation ModuleCU Info");
|
Asm->OutStreamer.AddComment("Offset of Compilation ModuleCU Info");
|
||||||
EmitSectionOffset(getDWLabel("info_begin", ModuleCU->getID()),
|
EmitSectionOffset(Asm->GetTempSymbol("info_begin", ModuleCU->getID()),
|
||||||
getTempLabel("section_info"), true);
|
Asm->GetTempSymbol("section_info"), true);
|
||||||
|
|
||||||
Asm->OutStreamer.AddComment("Compilation ModuleCU Length");
|
Asm->OutStreamer.AddComment("Compilation ModuleCU Length");
|
||||||
EmitDifference(getDWLabel("info_end", ModuleCU->getID()),
|
EmitDifference(Asm->GetTempSymbol("info_end", ModuleCU->getID()),
|
||||||
getDWLabel("info_begin", ModuleCU->getID()),
|
Asm->GetTempSymbol("info_begin", ModuleCU->getID()),
|
||||||
true);
|
true);
|
||||||
|
|
||||||
const StringMap<DIE*> &Globals = ModuleCU->getGlobalTypes();
|
const StringMap<DIE*> &Globals = ModuleCU->getGlobalTypes();
|
||||||
@ -2974,7 +2982,8 @@ void DwarfDebug::emitDebugPubTypes() {
|
|||||||
|
|
||||||
Asm->OutStreamer.AddComment("End Mark");
|
Asm->OutStreamer.AddComment("End Mark");
|
||||||
Asm->EmitInt32(0);
|
Asm->EmitInt32(0);
|
||||||
Asm->OutStreamer.EmitLabel(getDWLabel("pubtypes_end", ModuleCU->getID()));
|
Asm->OutStreamer.EmitLabel(Asm->GetTempSymbol("pubtypes_end",
|
||||||
|
ModuleCU->getID()));
|
||||||
}
|
}
|
||||||
|
|
||||||
/// emitDebugStr - Emit visible names into a debug str section.
|
/// emitDebugStr - Emit visible names into a debug str section.
|
||||||
@ -3070,10 +3079,10 @@ void DwarfDebug::emitDebugInlineInfo() {
|
|||||||
Asm->getObjFileLowering().getDwarfDebugInlineSection());
|
Asm->getObjFileLowering().getDwarfDebugInlineSection());
|
||||||
|
|
||||||
Asm->OutStreamer.AddComment("Length of Debug Inlined Information Entry");
|
Asm->OutStreamer.AddComment("Length of Debug Inlined Information Entry");
|
||||||
EmitDifference(getDWLabel("debug_inlined_end", 1),
|
EmitDifference(Asm->GetTempSymbol("debug_inlined_end", 1),
|
||||||
getDWLabel("debug_inlined_begin", 1), true);
|
Asm->GetTempSymbol("debug_inlined_begin", 1), true);
|
||||||
|
|
||||||
Asm->OutStreamer.EmitLabel(getDWLabel("debug_inlined_begin", 1));
|
Asm->OutStreamer.EmitLabel(Asm->GetTempSymbol("debug_inlined_begin", 1));
|
||||||
|
|
||||||
Asm->OutStreamer.AddComment("Dwarf Version");
|
Asm->OutStreamer.AddComment("Dwarf Version");
|
||||||
Asm->EmitInt16(dwarf::DWARF_VERSION);
|
Asm->EmitInt16(dwarf::DWARF_VERSION);
|
||||||
@ -3097,11 +3106,11 @@ void DwarfDebug::emitDebugInlineInfo() {
|
|||||||
Asm->OutStreamer.EmitIntValue(0, 1, 0); // nul terminator.
|
Asm->OutStreamer.EmitIntValue(0, 1, 0); // nul terminator.
|
||||||
} else
|
} else
|
||||||
EmitSectionOffset(getStringPoolEntry(getRealLinkageName(LName)),
|
EmitSectionOffset(getStringPoolEntry(getRealLinkageName(LName)),
|
||||||
getTempLabel("section_str"), true);
|
Asm->GetTempSymbol("section_str"), true);
|
||||||
|
|
||||||
Asm->OutStreamer.AddComment("Function name");
|
Asm->OutStreamer.AddComment("Function name");
|
||||||
EmitSectionOffset(getStringPoolEntry(Name), getTempLabel("section_str"),
|
EmitSectionOffset(getStringPoolEntry(Name),
|
||||||
true);
|
Asm->GetTempSymbol("section_str"), true);
|
||||||
Asm->EmitULEB128(Labels.size(), "Inline count");
|
Asm->EmitULEB128(Labels.size(), "Inline count");
|
||||||
|
|
||||||
for (SmallVector<InlineInfoLabels, 4>::iterator LI = Labels.begin(),
|
for (SmallVector<InlineInfoLabels, 4>::iterator LI = Labels.begin(),
|
||||||
@ -3114,5 +3123,5 @@ void DwarfDebug::emitDebugInlineInfo() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Asm->OutStreamer.EmitLabel(getDWLabel("debug_inlined_end", 1));
|
Asm->OutStreamer.EmitLabel(Asm->GetTempSymbol("debug_inlined_end", 1));
|
||||||
}
|
}
|
||||||
|
@ -67,24 +67,24 @@ void DwarfException::EmitCIE(const Function *PersonalityFn, unsigned Index) {
|
|||||||
|
|
||||||
MCSymbol *EHFrameSym;
|
MCSymbol *EHFrameSym;
|
||||||
if (TLOF.isFunctionEHFrameSymbolPrivate())
|
if (TLOF.isFunctionEHFrameSymbolPrivate())
|
||||||
EHFrameSym = getDWLabel("EH_frame", Index);
|
EHFrameSym = Asm->GetTempSymbol("EH_frame", Index);
|
||||||
else
|
else
|
||||||
EHFrameSym = Asm->OutContext.GetOrCreateSymbol(Twine("EH_frame") +
|
EHFrameSym = Asm->OutContext.GetOrCreateSymbol(Twine("EH_frame") +
|
||||||
Twine(Index));
|
Twine(Index));
|
||||||
Asm->OutStreamer.EmitLabel(EHFrameSym);
|
Asm->OutStreamer.EmitLabel(EHFrameSym);
|
||||||
|
|
||||||
Asm->OutStreamer.EmitLabel(getDWLabel("section_eh_frame", Index));
|
Asm->OutStreamer.EmitLabel(Asm->GetTempSymbol("section_eh_frame", Index));
|
||||||
|
|
||||||
// Define base labels.
|
// Define base labels.
|
||||||
Asm->OutStreamer.EmitLabel(getDWLabel("eh_frame_common", Index));
|
Asm->OutStreamer.EmitLabel(Asm->GetTempSymbol("eh_frame_common", Index));
|
||||||
|
|
||||||
// Define the eh frame length.
|
// Define the eh frame length.
|
||||||
Asm->OutStreamer.AddComment("Length of Common Information Entry");
|
Asm->OutStreamer.AddComment("Length of Common Information Entry");
|
||||||
EmitDifference(getDWLabel("eh_frame_common_end", Index),
|
EmitDifference(Asm->GetTempSymbol("eh_frame_common_end", Index),
|
||||||
getDWLabel("eh_frame_common_begin", Index), true);
|
Asm->GetTempSymbol("eh_frame_common_begin", Index), true);
|
||||||
|
|
||||||
// EH frame header.
|
// EH frame header.
|
||||||
Asm->OutStreamer.EmitLabel(getDWLabel("eh_frame_common_begin", Index));
|
Asm->OutStreamer.EmitLabel(Asm->GetTempSymbol("eh_frame_common_begin",Index));
|
||||||
Asm->OutStreamer.AddComment("CIE Identifier Tag");
|
Asm->OutStreamer.AddComment("CIE Identifier Tag");
|
||||||
Asm->OutStreamer.EmitIntValue(0, 4/*size*/, 0/*addrspace*/);
|
Asm->OutStreamer.EmitIntValue(0, 4/*size*/, 0/*addrspace*/);
|
||||||
Asm->OutStreamer.AddComment("DW_CIE_VERSION");
|
Asm->OutStreamer.AddComment("DW_CIE_VERSION");
|
||||||
@ -156,7 +156,7 @@ void DwarfException::EmitCIE(const Function *PersonalityFn, unsigned Index) {
|
|||||||
// be 8-byte on 64-bit targets to match what gcc does. Otherwise you get
|
// be 8-byte on 64-bit targets to match what gcc does. Otherwise you get
|
||||||
// holes which confuse readers of eh_frame.
|
// holes which confuse readers of eh_frame.
|
||||||
Asm->EmitAlignment(TD->getPointerSize() == 4 ? 2 : 3, 0, 0, false);
|
Asm->EmitAlignment(TD->getPointerSize() == 4 ? 2 : 3, 0, 0, false);
|
||||||
Asm->OutStreamer.EmitLabel(getDWLabel("eh_frame_common_end", Index));
|
Asm->OutStreamer.EmitLabel(Asm->GetTempSymbol("eh_frame_common_end", Index));
|
||||||
}
|
}
|
||||||
|
|
||||||
/// EmitFDE - Emit the Frame Description Entry (FDE) for the function.
|
/// EmitFDE - Emit the Frame Description Entry (FDE) for the function.
|
||||||
@ -209,26 +209,28 @@ void DwarfException::EmitFDE(const FunctionEHFrameInfo &EHFrameInfo) {
|
|||||||
|
|
||||||
// EH frame header.
|
// EH frame header.
|
||||||
Asm->OutStreamer.AddComment("Length of Frame Information Entry");
|
Asm->OutStreamer.AddComment("Length of Frame Information Entry");
|
||||||
EmitDifference(getDWLabel("eh_frame_end", EHFrameInfo.Number),
|
EmitDifference(Asm->GetTempSymbol("eh_frame_end", EHFrameInfo.Number),
|
||||||
getDWLabel("eh_frame_begin", EHFrameInfo.Number),
|
Asm->GetTempSymbol("eh_frame_begin", EHFrameInfo.Number),
|
||||||
true);
|
true);
|
||||||
|
|
||||||
Asm->OutStreamer.EmitLabel(getDWLabel("eh_frame_begin",EHFrameInfo.Number));
|
Asm->OutStreamer.EmitLabel(Asm->GetTempSymbol("eh_frame_begin",
|
||||||
|
EHFrameInfo.Number));
|
||||||
|
|
||||||
Asm->OutStreamer.AddComment("FDE CIE offset");
|
Asm->OutStreamer.AddComment("FDE CIE offset");
|
||||||
EmitSectionOffset(getDWLabel("eh_frame_begin", EHFrameInfo.Number),
|
EmitSectionOffset(Asm->GetTempSymbol("eh_frame_begin", EHFrameInfo.Number),
|
||||||
getDWLabel("eh_frame_common",
|
Asm->GetTempSymbol("eh_frame_common",
|
||||||
EHFrameInfo.PersonalityIndex),
|
EHFrameInfo.PersonalityIndex),
|
||||||
true, true);
|
true, true);
|
||||||
|
|
||||||
MCSymbol *EHFuncBeginSym = getDWLabel("eh_func_begin", EHFrameInfo.Number);
|
MCSymbol *EHFuncBeginSym =
|
||||||
|
Asm->GetTempSymbol("eh_func_begin", EHFrameInfo.Number);
|
||||||
|
|
||||||
Asm->OutStreamer.AddComment("FDE initial location");
|
Asm->OutStreamer.AddComment("FDE initial location");
|
||||||
EmitReference(EHFuncBeginSym, FDEEncoding);
|
EmitReference(EHFuncBeginSym, FDEEncoding);
|
||||||
|
|
||||||
Asm->OutStreamer.AddComment("FDE address range");
|
Asm->OutStreamer.AddComment("FDE address range");
|
||||||
EmitDifference(getDWLabel("eh_func_end", EHFrameInfo.Number),EHFuncBeginSym,
|
EmitDifference(Asm->GetTempSymbol("eh_func_end", EHFrameInfo.Number),
|
||||||
SizeOfEncodedValue(FDEEncoding) == 4);
|
EHFuncBeginSym, SizeOfEncodedValue(FDEEncoding) == 4);
|
||||||
|
|
||||||
// If there is a personality and landing pads then point to the language
|
// If there is a personality and landing pads then point to the language
|
||||||
// specific data area in the exception table.
|
// specific data area in the exception table.
|
||||||
@ -238,7 +240,8 @@ void DwarfException::EmitFDE(const FunctionEHFrameInfo &EHFrameInfo) {
|
|||||||
Asm->EmitULEB128(Size, "Augmentation size");
|
Asm->EmitULEB128(Size, "Augmentation size");
|
||||||
Asm->OutStreamer.AddComment("Language Specific Data Area");
|
Asm->OutStreamer.AddComment("Language Specific Data Area");
|
||||||
if (EHFrameInfo.hasLandingPads)
|
if (EHFrameInfo.hasLandingPads)
|
||||||
EmitReference(getDWLabel("exception", EHFrameInfo.Number),LSDAEncoding);
|
EmitReference(Asm->GetTempSymbol("exception", EHFrameInfo.Number),
|
||||||
|
LSDAEncoding);
|
||||||
else
|
else
|
||||||
Asm->OutStreamer.EmitIntValue(0, Size/*size*/, 0/*addrspace*/);
|
Asm->OutStreamer.EmitIntValue(0, Size/*size*/, 0/*addrspace*/);
|
||||||
|
|
||||||
@ -254,7 +257,8 @@ void DwarfException::EmitFDE(const FunctionEHFrameInfo &EHFrameInfo) {
|
|||||||
// get holes which confuse readers of eh_frame.
|
// get holes which confuse readers of eh_frame.
|
||||||
Asm->EmitAlignment(TD->getPointerSize() == sizeof(int32_t) ? 2 : 3,
|
Asm->EmitAlignment(TD->getPointerSize() == sizeof(int32_t) ? 2 : 3,
|
||||||
0, 0, false);
|
0, 0, false);
|
||||||
Asm->OutStreamer.EmitLabel(getDWLabel("eh_frame_end", EHFrameInfo.Number));
|
Asm->OutStreamer.EmitLabel(Asm->GetTempSymbol("eh_frame_end",
|
||||||
|
EHFrameInfo.Number));
|
||||||
|
|
||||||
// If the function is marked used, this table should be also. We cannot
|
// If the function is marked used, this table should be also. We cannot
|
||||||
// make the mark unconditional in this case, since retaining the table also
|
// make the mark unconditional in this case, since retaining the table also
|
||||||
@ -686,10 +690,11 @@ void DwarfException::EmitExceptionTable() {
|
|||||||
Asm->OutContext.GetOrCreateSymbol(Twine("GCC_except_table")+
|
Asm->OutContext.GetOrCreateSymbol(Twine("GCC_except_table")+
|
||||||
Twine(SubprogramCount));
|
Twine(SubprogramCount));
|
||||||
Asm->OutStreamer.EmitLabel(GCCETSym);
|
Asm->OutStreamer.EmitLabel(GCCETSym);
|
||||||
Asm->OutStreamer.EmitLabel(getDWLabel("exception", SubprogramCount));
|
Asm->OutStreamer.EmitLabel(Asm->GetTempSymbol("exception", SubprogramCount));
|
||||||
|
|
||||||
if (IsSJLJ)
|
if (IsSJLJ)
|
||||||
Asm->OutStreamer.EmitLabel(getDWLabel("_LSDA_", Asm->getFunctionNumber()));
|
Asm->OutStreamer.EmitLabel(Asm->GetTempSymbol("_LSDA_",
|
||||||
|
Asm->getFunctionNumber()));
|
||||||
|
|
||||||
// Emit the LSDA header.
|
// Emit the LSDA header.
|
||||||
EmitEncodingByte(dwarf::DW_EH_PE_omit, "@LPStart");
|
EmitEncodingByte(dwarf::DW_EH_PE_omit, "@LPStart");
|
||||||
@ -788,14 +793,15 @@ void DwarfException::EmitExceptionTable() {
|
|||||||
I = CallSites.begin(), E = CallSites.end(); I != E; ++I) {
|
I = CallSites.begin(), E = CallSites.end(); I != E; ++I) {
|
||||||
const CallSiteEntry &S = *I;
|
const CallSiteEntry &S = *I;
|
||||||
|
|
||||||
MCSymbol *EHFuncBeginSym = getDWLabel("eh_func_begin", SubprogramCount);
|
MCSymbol *EHFuncBeginSym =
|
||||||
|
Asm->GetTempSymbol("eh_func_begin", SubprogramCount);
|
||||||
|
|
||||||
MCSymbol *BeginLabel = S.BeginLabel;
|
MCSymbol *BeginLabel = S.BeginLabel;
|
||||||
if (BeginLabel == 0)
|
if (BeginLabel == 0)
|
||||||
BeginLabel = EHFuncBeginSym;
|
BeginLabel = EHFuncBeginSym;
|
||||||
MCSymbol *EndLabel = S.EndLabel;
|
MCSymbol *EndLabel = S.EndLabel;
|
||||||
if (EndLabel == 0)
|
if (EndLabel == 0)
|
||||||
EndLabel = getDWLabel("eh_func_end", SubprogramCount);
|
EndLabel = Asm->GetTempSymbol("eh_func_end", SubprogramCount);
|
||||||
|
|
||||||
// Offset of the call site relative to the previous call site, counted in
|
// Offset of the call site relative to the previous call site, counted in
|
||||||
// number of 16-byte bundles. The first call site is counted relative to
|
// number of 16-byte bundles. The first call site is counted relative to
|
||||||
@ -915,7 +921,8 @@ void DwarfException::BeginFunction(const MachineFunction *MF) {
|
|||||||
|
|
||||||
if (shouldEmitMoves || shouldEmitTable)
|
if (shouldEmitMoves || shouldEmitTable)
|
||||||
// Assumes in correct section after the entry point.
|
// Assumes in correct section after the entry point.
|
||||||
Asm->OutStreamer.EmitLabel(getDWLabel("eh_func_begin", ++SubprogramCount));
|
Asm->OutStreamer.EmitLabel(Asm->GetTempSymbol("eh_func_begin",
|
||||||
|
++SubprogramCount));
|
||||||
|
|
||||||
shouldEmitTableModule |= shouldEmitTable;
|
shouldEmitTableModule |= shouldEmitTable;
|
||||||
shouldEmitMovesModule |= shouldEmitMoves;
|
shouldEmitMovesModule |= shouldEmitMoves;
|
||||||
@ -927,7 +934,7 @@ void DwarfException::EndFunction() {
|
|||||||
if (!shouldEmitMoves && !shouldEmitTable) return;
|
if (!shouldEmitMoves && !shouldEmitTable) return;
|
||||||
|
|
||||||
TimeRegion Timer(ExceptionTimer);
|
TimeRegion Timer(ExceptionTimer);
|
||||||
Asm->OutStreamer.EmitLabel(getDWLabel("eh_func_end", SubprogramCount));
|
Asm->OutStreamer.EmitLabel(Asm->GetTempSymbol("eh_func_end",SubprogramCount));
|
||||||
|
|
||||||
// Record if this personality index uses a landing pad.
|
// Record if this personality index uses a landing pad.
|
||||||
bool HasLandingPad = !MMI->getLandingPads().empty();
|
bool HasLandingPad = !MMI->getLandingPads().empty();
|
||||||
|
@ -37,27 +37,6 @@ DwarfPrinter::DwarfPrinter(AsmPrinter *A)
|
|||||||
RI(Asm->TM.getRegisterInfo()), M(NULL), MF(NULL), MMI(NULL),
|
RI(Asm->TM.getRegisterInfo()), M(NULL), MF(NULL), MMI(NULL),
|
||||||
SubprogramCount(0) {}
|
SubprogramCount(0) {}
|
||||||
|
|
||||||
|
|
||||||
/// getDWLabel - Return the MCSymbol corresponding to the assembler temporary
|
|
||||||
/// label with the specified stem and unique ID.
|
|
||||||
MCSymbol *DwarfPrinter::getDWLabel(const char *Name, unsigned ID) const {
|
|
||||||
// FIXME: REMOVE this. However, there is stuff in EH that passes counters in
|
|
||||||
// here that can be zero.
|
|
||||||
|
|
||||||
//assert(ID && "Should use getTempLabel if no ID");
|
|
||||||
if (ID == 0) return getTempLabel(Name);
|
|
||||||
return Asm->OutContext.GetOrCreateSymbol
|
|
||||||
(Twine(MAI->getPrivateGlobalPrefix()) + Twine(Name) + Twine(ID));
|
|
||||||
}
|
|
||||||
|
|
||||||
/// getTempLabel - Return the MCSymbol corresponding to the assembler temporary
|
|
||||||
/// label with the specified name.
|
|
||||||
MCSymbol *DwarfPrinter::getTempLabel(const char *Name) const {
|
|
||||||
return Asm->OutContext.GetOrCreateSymbol
|
|
||||||
(Twine(MAI->getPrivateGlobalPrefix()) + Name);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/// SizeOfEncodedValue - Return the size of the encoding in bytes.
|
/// SizeOfEncodedValue - Return the size of the encoding in bytes.
|
||||||
unsigned DwarfPrinter::SizeOfEncodedValue(unsigned Encoding) const {
|
unsigned DwarfPrinter::SizeOfEncodedValue(unsigned Encoding) const {
|
||||||
if (Encoding == dwarf::DW_EH_PE_omit)
|
if (Encoding == dwarf::DW_EH_PE_omit)
|
||||||
|
@ -74,14 +74,6 @@ public:
|
|||||||
const MCAsmInfo *getMCAsmInfo() const { return MAI; }
|
const MCAsmInfo *getMCAsmInfo() const { return MAI; }
|
||||||
const TargetData *getTargetData() const { return TD; }
|
const TargetData *getTargetData() const { return TD; }
|
||||||
|
|
||||||
/// getDWLabel - Return the MCSymbol corresponding to the assembler temporary
|
|
||||||
/// label with the specified stem and unique ID.
|
|
||||||
MCSymbol *getDWLabel(const char *Name, unsigned ID) const;
|
|
||||||
|
|
||||||
/// getTempLabel - Return an assembler temporary label with the specified
|
|
||||||
/// name.
|
|
||||||
MCSymbol *getTempLabel(const char *Name) const;
|
|
||||||
|
|
||||||
/// SizeOfEncodedValue - Return the size of the encoding in bytes.
|
/// SizeOfEncodedValue - Return the size of the encoding in bytes.
|
||||||
unsigned SizeOfEncodedValue(unsigned Encoding) const;
|
unsigned SizeOfEncodedValue(unsigned Encoding) const;
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user