diff options
| author | orivej <[email protected]> | 2022-02-10 16:45:01 +0300 |
|---|---|---|
| committer | Daniil Cherednik <[email protected]> | 2022-02-10 16:45:01 +0300 |
| commit | 2d37894b1b037cf24231090eda8589bbb44fb6fc (patch) | |
| tree | be835aa92c6248212e705f25388ebafcf84bc7a1 /contrib/libs/llvm12/lib/CodeGen/AsmPrinter/DwarfFile.cpp | |
| parent | 718c552901d703c502ccbefdfc3c9028d608b947 (diff) | |
Restoring authorship annotation for <[email protected]>. Commit 2 of 2.
Diffstat (limited to 'contrib/libs/llvm12/lib/CodeGen/AsmPrinter/DwarfFile.cpp')
| -rw-r--r-- | contrib/libs/llvm12/lib/CodeGen/AsmPrinter/DwarfFile.cpp | 252 |
1 files changed, 126 insertions, 126 deletions
diff --git a/contrib/libs/llvm12/lib/CodeGen/AsmPrinter/DwarfFile.cpp b/contrib/libs/llvm12/lib/CodeGen/AsmPrinter/DwarfFile.cpp index 16de02ba2a6..838e1c9a10b 100644 --- a/contrib/libs/llvm12/lib/CodeGen/AsmPrinter/DwarfFile.cpp +++ b/contrib/libs/llvm12/lib/CodeGen/AsmPrinter/DwarfFile.cpp @@ -1,133 +1,133 @@ -//===- llvm/CodeGen/DwarfFile.cpp - Dwarf Debug Framework -----------------===// -// -// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. -// See https://llvm.org/LICENSE.txt for license information. -// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception -// -//===----------------------------------------------------------------------===// - -#include "DwarfFile.h" -#include "DwarfCompileUnit.h" -#include "DwarfDebug.h" -#include "DwarfUnit.h" -#include "llvm/CodeGen/AsmPrinter.h" -#include "llvm/IR/DebugInfoMetadata.h" +//===- llvm/CodeGen/DwarfFile.cpp - Dwarf Debug Framework -----------------===// +// +// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. +// See https://llvm.org/LICENSE.txt for license information. +// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception +// +//===----------------------------------------------------------------------===// + +#include "DwarfFile.h" +#include "DwarfCompileUnit.h" +#include "DwarfDebug.h" +#include "DwarfUnit.h" +#include "llvm/CodeGen/AsmPrinter.h" +#include "llvm/IR/DebugInfoMetadata.h" #include "llvm/IR/Metadata.h" -#include "llvm/MC/MCStreamer.h" -#include <algorithm> -#include <cstdint> - -using namespace llvm; - -DwarfFile::DwarfFile(AsmPrinter *AP, StringRef Pref, BumpPtrAllocator &DA) - : Asm(AP), Abbrevs(AbbrevAllocator), StrPool(DA, *Asm, Pref) {} - -void DwarfFile::addUnit(std::unique_ptr<DwarfCompileUnit> U) { - CUs.push_back(std::move(U)); -} - -// Emit the various dwarf units to the unit section USection with -// the abbreviations going into ASection. -void DwarfFile::emitUnits(bool UseOffsets) { - for (const auto &TheU : CUs) - emitUnit(TheU.get(), UseOffsets); -} - -void DwarfFile::emitUnit(DwarfUnit *TheU, bool UseOffsets) { - if (TheU->getCUNode()->isDebugDirectivesOnly()) - return; - - MCSection *S = TheU->getSection(); - - if (!S) - return; - - // Skip CUs that ended up not being needed (split CUs that were abandoned - // because they added no information beyond the non-split CU) - if (llvm::empty(TheU->getUnitDie().values())) - return; - - Asm->OutStreamer->SwitchSection(S); - TheU->emitHeader(UseOffsets); - Asm->emitDwarfDIE(TheU->getUnitDie()); - - if (MCSymbol *EndLabel = TheU->getEndLabel()) - Asm->OutStreamer->emitLabel(EndLabel); -} - -// Compute the size and offset for each DIE. -void DwarfFile::computeSizeAndOffsets() { - // Offset from the first CU in the debug info section is 0 initially. +#include "llvm/MC/MCStreamer.h" +#include <algorithm> +#include <cstdint> + +using namespace llvm; + +DwarfFile::DwarfFile(AsmPrinter *AP, StringRef Pref, BumpPtrAllocator &DA) + : Asm(AP), Abbrevs(AbbrevAllocator), StrPool(DA, *Asm, Pref) {} + +void DwarfFile::addUnit(std::unique_ptr<DwarfCompileUnit> U) { + CUs.push_back(std::move(U)); +} + +// Emit the various dwarf units to the unit section USection with +// the abbreviations going into ASection. +void DwarfFile::emitUnits(bool UseOffsets) { + for (const auto &TheU : CUs) + emitUnit(TheU.get(), UseOffsets); +} + +void DwarfFile::emitUnit(DwarfUnit *TheU, bool UseOffsets) { + if (TheU->getCUNode()->isDebugDirectivesOnly()) + return; + + MCSection *S = TheU->getSection(); + + if (!S) + return; + + // Skip CUs that ended up not being needed (split CUs that were abandoned + // because they added no information beyond the non-split CU) + if (llvm::empty(TheU->getUnitDie().values())) + return; + + Asm->OutStreamer->SwitchSection(S); + TheU->emitHeader(UseOffsets); + Asm->emitDwarfDIE(TheU->getUnitDie()); + + if (MCSymbol *EndLabel = TheU->getEndLabel()) + Asm->OutStreamer->emitLabel(EndLabel); +} + +// Compute the size and offset for each DIE. +void DwarfFile::computeSizeAndOffsets() { + // Offset from the first CU in the debug info section is 0 initially. uint64_t SecOffset = 0; - - // Iterate over each compile unit and set the size and offsets for each - // DIE within each compile unit. All offsets are CU relative. - for (const auto &TheU : CUs) { - if (TheU->getCUNode()->isDebugDirectivesOnly()) - continue; - - // Skip CUs that ended up not being needed (split CUs that were abandoned - // because they added no information beyond the non-split CU) - if (llvm::empty(TheU->getUnitDie().values())) - return; - - TheU->setDebugSectionOffset(SecOffset); - SecOffset += computeSizeAndOffsetsForUnit(TheU.get()); - } + + // Iterate over each compile unit and set the size and offsets for each + // DIE within each compile unit. All offsets are CU relative. + for (const auto &TheU : CUs) { + if (TheU->getCUNode()->isDebugDirectivesOnly()) + continue; + + // Skip CUs that ended up not being needed (split CUs that were abandoned + // because they added no information beyond the non-split CU) + if (llvm::empty(TheU->getUnitDie().values())) + return; + + TheU->setDebugSectionOffset(SecOffset); + SecOffset += computeSizeAndOffsetsForUnit(TheU.get()); + } if (SecOffset > UINT32_MAX && !Asm->isDwarf64()) report_fatal_error("The generated debug information is too large " "for the 32-bit DWARF format."); -} - -unsigned DwarfFile::computeSizeAndOffsetsForUnit(DwarfUnit *TheU) { - // CU-relative offset is reset to 0 here. +} + +unsigned DwarfFile::computeSizeAndOffsetsForUnit(DwarfUnit *TheU) { + // CU-relative offset is reset to 0 here. unsigned Offset = Asm->getUnitLengthFieldByteSize() + // Length of Unit Info TheU->getHeaderSize(); // Unit-specific headers - - // The return value here is CU-relative, after laying out - // all of the CU DIE. - return computeSizeAndOffset(TheU->getUnitDie(), Offset); -} - -// Compute the size and offset of a DIE. The offset is relative to start of the -// CU. It returns the offset after laying out the DIE. -unsigned DwarfFile::computeSizeAndOffset(DIE &Die, unsigned Offset) { - return Die.computeOffsetsAndAbbrevs(Asm, Abbrevs, Offset); -} - -void DwarfFile::emitAbbrevs(MCSection *Section) { Abbrevs.Emit(Asm, Section); } - -// Emit strings into a string section. -void DwarfFile::emitStrings(MCSection *StrSection, MCSection *OffsetSection, - bool UseRelativeOffsets) { - StrPool.emit(*Asm, StrSection, OffsetSection, UseRelativeOffsets); -} - -bool DwarfFile::addScopeVariable(LexicalScope *LS, DbgVariable *Var) { - auto &ScopeVars = ScopeVariables[LS]; - const DILocalVariable *DV = Var->getVariable(); - if (unsigned ArgNum = DV->getArg()) { - auto Cached = ScopeVars.Args.find(ArgNum); - if (Cached == ScopeVars.Args.end()) - ScopeVars.Args[ArgNum] = Var; - else { - Cached->second->addMMIEntry(*Var); - return false; - } - } else { - ScopeVars.Locals.push_back(Var); - } - return true; -} - -void DwarfFile::addScopeLabel(LexicalScope *LS, DbgLabel *Label) { - SmallVectorImpl<DbgLabel *> &Labels = ScopeLabels[LS]; - Labels.push_back(Label); -} - -std::pair<uint32_t, RangeSpanList *> -DwarfFile::addRange(const DwarfCompileUnit &CU, SmallVector<RangeSpan, 2> R) { - CURangeLists.push_back( - RangeSpanList{Asm->createTempSymbol("debug_ranges"), &CU, std::move(R)}); - return std::make_pair(CURangeLists.size() - 1, &CURangeLists.back()); -} + + // The return value here is CU-relative, after laying out + // all of the CU DIE. + return computeSizeAndOffset(TheU->getUnitDie(), Offset); +} + +// Compute the size and offset of a DIE. The offset is relative to start of the +// CU. It returns the offset after laying out the DIE. +unsigned DwarfFile::computeSizeAndOffset(DIE &Die, unsigned Offset) { + return Die.computeOffsetsAndAbbrevs(Asm, Abbrevs, Offset); +} + +void DwarfFile::emitAbbrevs(MCSection *Section) { Abbrevs.Emit(Asm, Section); } + +// Emit strings into a string section. +void DwarfFile::emitStrings(MCSection *StrSection, MCSection *OffsetSection, + bool UseRelativeOffsets) { + StrPool.emit(*Asm, StrSection, OffsetSection, UseRelativeOffsets); +} + +bool DwarfFile::addScopeVariable(LexicalScope *LS, DbgVariable *Var) { + auto &ScopeVars = ScopeVariables[LS]; + const DILocalVariable *DV = Var->getVariable(); + if (unsigned ArgNum = DV->getArg()) { + auto Cached = ScopeVars.Args.find(ArgNum); + if (Cached == ScopeVars.Args.end()) + ScopeVars.Args[ArgNum] = Var; + else { + Cached->second->addMMIEntry(*Var); + return false; + } + } else { + ScopeVars.Locals.push_back(Var); + } + return true; +} + +void DwarfFile::addScopeLabel(LexicalScope *LS, DbgLabel *Label) { + SmallVectorImpl<DbgLabel *> &Labels = ScopeLabels[LS]; + Labels.push_back(Label); +} + +std::pair<uint32_t, RangeSpanList *> +DwarfFile::addRange(const DwarfCompileUnit &CU, SmallVector<RangeSpan, 2> R) { + CURangeLists.push_back( + RangeSpanList{Asm->createTempSymbol("debug_ranges"), &CU, std::move(R)}); + return std::make_pair(CURangeLists.size() - 1, &CURangeLists.back()); +} |
